Mercurial > dive4elements > river
view flys-client/src/main/java/de/intevation/flys/client/shared/model/Recommendation.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 | 0b79630e3bcb |
children |
line wrap: on
line source
package de.intevation.flys.client.shared.model; import java.util.List; import java.util.Map; import java.util.HashMap; import java.io.Serializable; /** * Information bundle to let client create/clone an artifact with facets. * @author <a href="mailto:ingo.weinzierl@intevation.de">Ingo Weinzierl</a> */ public class Recommendation implements Serializable { /** Index and name of a facet. */ public static class Facet implements Serializable { /** Facet name. */ protected String name; /** Facet index. */ protected String index; public Facet() { } public Facet(String name, String index) { this.name = name; this.index = index; } public String getName() { return name; } public String getIndex() { return index; } @Override public int hashCode() { int hash = 0; if (getName() != null) { hash += getName().hashCode(); } if (getIndex() != null) { hash += getIndex().hashCode(); } return hash; } @Override public boolean equals(Object other) { if (!(other instanceof Facet) || other == null) { return false; } Facet facet = (Facet) other; return (same(facet.getIndex(), this.getIndex())) && (same(facet.getName(), this.getName())); } } // class Facet /** Mapping of outnames to Facet-Lists. */ public static class Filter implements Serializable { protected Map<String, List<Facet>> outs; public Filter() { outs = new HashMap<String, List<Facet>>(); } public void add(String out, List<Facet> facets) { outs.put(out, facets); } public Map<String, List<Facet>> getOuts() { return outs; } @Override public int hashCode() { if (getOuts() != null) { return getOuts().hashCode(); } return 0; } @Override public boolean equals(Object other) { if (!(other instanceof Filter) || other == null) { return false; } Filter filter = (Filter) other; return Recommendation.same(filter.getOuts(), this.getOuts()); } } // class Filter /** Factory to speak to when creating/cloning. */ protected String factory; /** Sometimes database ids, sometimes other freeform text. */ protected String ids; /** Artifacts uuid that should serve as master artifact. */ protected String masterArtifact; /** Optional facet filter. */ protected Filter filter; protected String displayName = null; public Recommendation() { } public Recommendation(String factory, String ids) { this(factory, ids, null, null); } public Recommendation( String factory, String ids, String masterArtifact, Filter filter ) { this.factory = factory; this.ids = ids; this.masterArtifact = masterArtifact; this.filter = filter; } public String getFactory() { return factory; } public void setFactory(String factory) { this.factory = factory; } public void setDisplayName(String displayName) { this.displayName = displayName; } public String getDisplayName() { return this.displayName; } public String getIDs() { return ids; } public String getMasterArtifact() { return masterArtifact; } public void setMasterArtifact(String masterArtifact) { this.masterArtifact = masterArtifact; } public Filter getFilter() { return filter; } public void setFilter(Filter filter) { this.filter = filter; } @Override public int hashCode() { int hash = 0; hash += (getFactory() != null) ? getFactory().hashCode() : 0; hash += (getIDs() != null) ? getIDs().hashCode() : 0; hash += (getFilter() != null) ? getFilter().hashCode() : 0; hash += (getMasterArtifact() != null) ? getMasterArtifact().hashCode() : 0; return hash; } /** * Null-pointer guarded equals. * Two null's are assumed equal (returns true); * @param a Object to compare against parameter b. * @param b Object to compare against parameter a. * @return true if either a and b are null or a.equals(b) returns true. */ protected static boolean same(Object a, Object b) { // Do null-check. if (a == null) { return b == null; } else if (b == null) { return false; } return a.equals(b); } @Override public boolean equals(Object other) { if (!(other instanceof Recommendation) || other == null) { return false; } Recommendation rec = (Recommendation) other; return (same(this.getFactory(), rec.getFactory())) && (same(this.getIDs(), rec.getIDs())) && (same(this.getFilter(), rec.getFilter())) && (same(this.getMasterArtifact(), rec.getMasterArtifact())); } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :