Mercurial > dive4elements > river
view flys-client/src/main/java/de/intevation/flys/client/server/ArtifactHelper.java @ 3719:e82acd5c86f7
Merged revisions 5495-5496,5509,5514-5515,5521-5526 via svnmerge from
file:///home/clients/bsh/bsh-generischer-viewer/Material/SVN/flys-client/trunk
........
r5495 | ingo | 2012-09-17 14:55:09 +0200 (Mo, 17 Sep 2012) | 1 line
Added missing i18n strings for minfo state description.
........
r5496 | ingo | 2012-09-17 15:47:43 +0200 (Mo, 17 Sep 2012) | 1 line
Tagged 'flys-client' as 2.9.1
........
r5509 | teichmann | 2012-09-18 17:54:37 +0200 (Di, 18 Sep 2012) | 1 line
Removed trailing whitespace.
........
r5514 | bricks | 2012-09-19 09:56:42 +0200 (Mi, 19 Sep 2012) | 2 lines
Add missing Changelog entry for r5472
........
r5515 | bricks | 2012-09-19 09:59:35 +0200 (Mi, 19 Sep 2012) | 2 lines
Implement a scrolling gauge info tree
........
r5521 | bricks | 2012-09-19 14:41:48 +0200 (Mi, 19 Sep 2012) | 2 lines
Add station info to the gauges
........
r5522 | bricks | 2012-09-19 14:43:43 +0200 (Mi, 19 Sep 2012) | 2 lines
Improve the handling of the GaugePanel in the ParameterList
........
r5523 | bricks | 2012-09-19 14:51:02 +0200 (Mi, 19 Sep 2012) | 4 lines
Improve the GaugePanel
Be locale aware and only load the gauge info if the river name changes.
........
r5524 | bricks | 2012-09-19 15:14:46 +0200 (Mi, 19 Sep 2012) | 5 lines
Fix a NullPointerException
When iterating over a list it must be checked if the reference to the list is
valid.
........
r5525 | bricks | 2012-09-19 15:16:24 +0200 (Mi, 19 Sep 2012) | 2 lines
Don't display the GaugePanel if no river is selected
........
r5526 | bricks | 2012-09-19 15:18:36 +0200 (Mi, 19 Sep 2012) | 2 lines
Use the wstunit from the river as unit for the Pegelnullpunkt
........
flys-client/tags/2.9.1@5528 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author | Ingo Weinzierl <ingo.weinzierl@intevation.de> |
---|---|
date | Wed, 19 Sep 2012 14:42:48 +0000 |
parents | ab8eb2f544f2 |
children | 436eec3be6ff |
line wrap: on
line source
package de.intevation.flys.client.server; import org.w3c.dom.Document; import org.apache.log4j.Logger; import java.util.ArrayList; import java.util.List; import java.util.Map; import de.intevation.artifacts.common.utils.ClientProtocolUtils; import de.intevation.artifacts.common.utils.CreationFilter; import de.intevation.artifacts.httpclient.exceptions.ConnectionException; import de.intevation.artifacts.httpclient.http.HttpClient; import de.intevation.artifacts.httpclient.http.HttpClientImpl; import de.intevation.flys.client.shared.exceptions.ServerException; import de.intevation.flys.client.shared.model.Artifact; import de.intevation.flys.client.shared.model.Recommendation; /** * @author <a href="mailto:ingo.weinzierl@intevation.de">Ingo Weinzierl</a> */ public class ArtifactHelper { private static final Logger logger = Logger.getLogger(ArtifactHelper.class); /** The error message key that is thrown if an error occured while artifact * creation.*/ public static final String ERROR_CREATE_ARTIFACT = "error_create_artifact"; private ArtifactHelper() { } /** * @param factory ArtifactFactory to use. */ public static Artifact createArtifact( String serverUrl, String locale, String factory, Recommendation recommendation) throws ServerException { logger.debug("ArtifactHelper.create"); String uuid; String ids; CreationFilter filter; if (recommendation != null) { uuid = recommendation.getMasterArtifact(); ids = recommendation.getIDs(); filter = convertFilter(recommendation.getFilter()); } else { uuid = null; ids = null; filter = null; } Document create = ClientProtocolUtils.newCreateDocument( factory, uuid, ids, filter); HttpClient client = new HttpClientImpl(serverUrl, locale); try { return (Artifact) client.create(create, new FLYSArtifactCreator()); } catch (ConnectionException ce) { logger.error(ce, ce); } throw new ServerException(ERROR_CREATE_ARTIFACT); } /** * Create CreationFilter from Recommendation.Filter. */ public static CreationFilter convertFilter(Recommendation.Filter filter) { if (filter == null) { return null; } CreationFilter cf = new CreationFilter(); Map<String, List<Recommendation.Facet>> outs = filter.getOuts(); for (Map.Entry<String, List<Recommendation.Facet>> entry: outs.entrySet()) { List<Recommendation.Facet> rfs = entry.getValue(); List<CreationFilter.Facet> cfs = new ArrayList<CreationFilter.Facet>(rfs.size()); for (Recommendation.Facet rf: rfs) { cfs.add(new CreationFilter.Facet(rf.getName(), rf.getIndex())); } cf.add(entry.getKey(), cfs); } return cf; } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :