teichmann@5863: /* Copyright (C) 2011, 2012, 2013 by Bundesanstalt für Gewässerkunde teichmann@5863: * Software engineering by Intevation GmbH teichmann@5863: * teichmann@5994: * This file is Free Software under the GNU AGPL (>=v3) teichmann@5863: * and comes with ABSOLUTELY NO WARRANTY! Check out the teichmann@5994: * documentation coming with Dive4Elements River for details. teichmann@5863: */ teichmann@5863: teichmann@5831: package org.dive4elements.river.artifacts; raimund@3614: raimund@3614: import java.util.ArrayList; raimund@3614: import java.util.List; raimund@3614: raimund@3614: import org.apache.log4j.Logger; teichmann@5831: import org.dive4elements.artifactdatabase.state.DefaultOutput; teichmann@5831: import org.dive4elements.artifactdatabase.state.Facet; teichmann@5831: import org.dive4elements.artifactdatabase.state.FacetActivity; gernotbelger@8961: import org.dive4elements.artifacts.Artifact; teichmann@5831: import org.dive4elements.artifacts.ArtifactFactory; teichmann@5831: import org.dive4elements.artifacts.CallMeta; teichmann@5831: import org.dive4elements.artifacts.common.utils.XMLUtils; felix@7337: import org.dive4elements.river.artifacts.model.FacetTypes; teichmann@5831: import org.dive4elements.river.artifacts.model.minfo.BedHeightFacet; gernotbelger@8961: import org.dive4elements.river.artifacts.model.minfo.BedHeightMinMaxFacet; rrenkert@7984: import org.dive4elements.river.artifacts.model.minfo.BedHeightSoundingWidthFacet; gernotbelger@8961: import org.dive4elements.river.artifacts.resources.Resources; teichmann@5831: import org.dive4elements.river.artifacts.states.StaticState; gernotbelger@8961: import org.dive4elements.river.exports.process.BedHeightProcessor; gernotbelger@8964: import org.dive4elements.river.model.BedHeightValueType; gernotbelger@8961: import org.w3c.dom.Document; felix@7477: gernotbelger@8961: public class BedHeightsArtifact extends AbstractStaticStateArtifact implements FacetTypes { teichmann@8202: /** The log for this class. */ gernotbelger@8961: private static Logger log = Logger.getLogger(BedHeightsArtifact.class); raimund@3614: felix@7337: /** Artifact name. */ raimund@3614: private static final String NAME = "bedheights"; raimund@3614: raimund@3614: static { raimund@3614: // TODO: Move to configuration. gernotbelger@8961: FacetActivity.Registry.getInstance().register(NAME, FacetActivity.INACTIVE); raimund@3614: } raimund@3614: gernotbelger@8961: public static final String STATIC_STATE_NAME = "state.additional_bedheights.static"; raimund@3614: gernotbelger@8961: /** gernotbelger@8961: * Data Item name to know whether we are Heighmarks and receive gernotbelger@8961: * some data slightly different. gernotbelger@8961: */ gernotbelger@8961: public static final String DATA_HEIGHT_TYPE = "height_marks"; raimund@3614: raimund@3614: /** raimund@3614: * Trivial Constructor. raimund@3614: */ raimund@3614: public BedHeightsArtifact() { teichmann@8202: log.debug("BedHeightsArtifact.BedHeightsArtifact"); raimund@3614: } raimund@3614: raimund@3614: @Override raimund@3614: public String getName() { raimund@3614: return NAME; raimund@3614: } raimund@3614: raimund@3614: /** raimund@3614: * Gets called from factory, to set things up. raimund@3614: */ raimund@3614: @Override gernotbelger@8961: public void setup(final String identifier, final ArtifactFactory factory, final Object context, final CallMeta callMeta, final Document data, gernotbelger@8961: final List loadFacets) { teichmann@8202: log.debug("BedHeightsArtifact.setup"); raimund@3614: teichmann@8202: if (log.isDebugEnabled()) { teichmann@8202: log.debug(XMLUtils.toString(data)); raimund@3614: } raimund@3614: gernotbelger@8961: final String code = getDatacageIDValue(data); rrenkert@7984: gernotbelger@8961: createFacets(callMeta, code); raimund@3614: gernotbelger@8961: super.setup(identifier, factory, context, callMeta, data, loadFacets); gernotbelger@8961: } felix@7477: gernotbelger@8961: private void createFacets(final CallMeta callMeta, final String code) { gernotbelger@8961: if (code == null) gernotbelger@8961: return; bjoern@4535: gernotbelger@8961: final String[] parts = code.split("-", 5); gernotbelger@8961: if (parts.length < 5) { gernotbelger@8961: log.error("Invalid datacage ID '" + code + "'"); gernotbelger@8961: return; raimund@3614: } gernotbelger@8961: gernotbelger@8961: // String name = parts[0]; gernotbelger@8961: gernotbelger@8961: // type may only be 'single' or 'soundings' gernotbelger@8961: final String type = parts[1]; gernotbelger@8961: gernotbelger@8961: final String heightId = parts[2]; gernotbelger@8961: // final int hId = Integer.parseInt(heightId); gernotbelger@8961: gernotbelger@8961: // final String year = parts[3]; gernotbelger@8961: final String bedHName = parts[4]; gernotbelger@8961: gernotbelger@8961: addStringData("height_id", heightId); gernotbelger@8961: if (type.equals("soundings")) gernotbelger@8961: addStringData("type", "singlevalues"); gernotbelger@8961: else gernotbelger@8961: addStringData("type", type); gernotbelger@8961: gernotbelger@8961: final ArrayList facets = new ArrayList<>(1); gernotbelger@8961: gernotbelger@8961: if ("soundings".equals(type)) { gernotbelger@8961: final String description = Resources.getMsg(callMeta, "facet.bedheight.sounding_width", new Object[] { bedHName }); gernotbelger@8961: facets.add(new BedHeightSoundingWidthFacet(BEDHEIGHT_SOUNDING_WIDTH, description)); gernotbelger@8961: } else if ("single".equals(type)) gernotbelger@8961: facets.add(new BedHeightFacet(BEDHEIGHT, bedHName)); gernotbelger@8961: else if ("singleMin".equals(type)) gernotbelger@8961: facets.add(new BedHeightMinMaxFacet(BedHeightProcessor.FACET_BED_HEIGHTS_MIN, bedHName, BedHeightValueType.min)); gernotbelger@8961: else if ("singleMax".equals(type)) gernotbelger@8961: facets.add(new BedHeightMinMaxFacet(BedHeightProcessor.FACET_BED_HEIGHTS_MAX, bedHName, BedHeightValueType.max)); gernotbelger@8961: gernotbelger@8961: addFacets(STATIC_STATE_NAME, facets); raimund@3614: } raimund@3614: bjoern@4535: @Override bjoern@4535: protected void initStaticState() { bjoern@4535: teichmann@8202: log.debug("initStaticState " + getName() + " " + identifier()); bjoern@4535: gernotbelger@8961: final StaticState state = new StaticState(STATIC_STATE_NAME); gernotbelger@8961: final DefaultOutput output = new DefaultOutput("general", "general", "image/png", "chart"); bjoern@4535: gernotbelger@8961: final List facets = getFacets(STATIC_STATE_NAME); bjoern@4535: output.addFacets(facets); bjoern@4535: state.addOutput(output); bjoern@4535: bjoern@4535: setStaticState(state); bjoern@4535: } bjoern@4535: bjoern@4535: @Override gernotbelger@8961: protected void initialize(final Artifact artifact, final Object context, final CallMeta meta) { bjoern@4535: // do not clone facets, etc. from master artifact bjoern@4535: teichmann@8202: log.debug("initialize"); gernotbelger@8961: importData((D4EArtifact) artifact, "river"); gernotbelger@8961: importData((D4EArtifact) artifact, "ld_from"); gernotbelger@8961: importData((D4EArtifact) artifact, "ld_to"); bjoern@4535: teichmann@8202: log.debug("ld_from " + getDataAsString("ld_from")); teichmann@8202: log.debug("ld_to " + getDataAsString("ld_to")); bjoern@4535: } gernotbelger@8961: }