Mercurial > dive4elements > river
view flys-client/src/main/java/de/intevation/flys/client/shared/model/ToLoad.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 | 01b18db3b288 |
children |
line wrap: on
line source
package de.intevation.flys.client.shared.model; import java.util.ArrayList; import java.util.List; import java.util.Map; import java.util.HashMap; import java.io.Serializable; public class ToLoad implements Serializable { public class StringPair { public String first; public String second; public StringPair(String first, String second) { this.first = first; this.second = second; } public int hashCode() { return first.hashCode() + second.hashCode(); } public boolean equals(StringPair other) { return (this.second.equals(other.second)) && (this.first.equals(other.first)); } } public static final String SYNTHETIC_KEY = "key-"; protected Map<String, Map<StringPair, ArtifactFilter>> artifacts; public ToLoad() { artifacts = new HashMap<String, Map<StringPair, ArtifactFilter>>(); } public static final String uniqueKey(Map<?, ?> map) { int idx = map.size(); String key = SYNTHETIC_KEY + idx; while (map.containsKey(key)) { key = SYNTHETIC_KEY + ++idx; } return key; } public void add( String artifactName, String factory, String out, String name, String ids, String displayName ) { if (artifactName == null) { artifactName = uniqueKey(artifacts); } Map<StringPair, ArtifactFilter> artifact = artifacts.get(artifactName); if (artifact == null) { artifact = new HashMap<StringPair, ArtifactFilter>(); artifacts.put(artifactName, artifact); } ArtifactFilter filter = artifact.get(factory); if (filter == null) { filter = new ArtifactFilter(factory); artifact.put(new StringPair(factory, displayName), filter); } filter.add(out, name, ids); } public boolean isEmpty() { return artifacts.isEmpty(); } public List<Recommendation> toRecommendations() { List<Recommendation> recommendations = new ArrayList<Recommendation>(); for (Map.Entry<String, Map<StringPair, ArtifactFilter>> all: artifacts.entrySet() ) { String masterArtifact = all.getKey(); if (masterArtifact.startsWith(SYNTHETIC_KEY)) { // system data masterArtifact = null; } for (Map.Entry<StringPair, ArtifactFilter> entry: all.getValue().entrySet() ) { StringPair pair = entry.getKey(); String factory = pair.first; ArtifactFilter artifactFilter = entry.getValue(); String ids; Recommendation.Filter filter; if (masterArtifact == null) { // system data ids = artifactFilter.collectIds(); filter = null; } else { // user specific ids = null; filter = artifactFilter.toFilter(); } Recommendation recommendation = new Recommendation( factory, ids, masterArtifact, filter); recommendation.setDisplayName(pair.second); recommendations.add(recommendation); } } return recommendations; } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :