ingo@392: package de.intevation.flys.artifacts.states;
ingo@392:
ingo@687: import java.util.List;
ingo@687:
ingo@392: import org.apache.log4j.Logger;
ingo@392:
ingo@692: import de.intevation.artifacts.CallContext;
ingo@692:
ingo@687: import de.intevation.artifactdatabase.state.Facet;
ingo@687:
ingo@687: import de.intevation.flys.artifacts.FLYSArtifact;
ingo@687: import de.intevation.flys.artifacts.WINFOArtifact;
sascha@703:
ingo@692: import de.intevation.flys.artifacts.model.FacetTypes;
ingo@696: import de.intevation.flys.artifacts.model.WaterlevelFacet;
sascha@703: import de.intevation.flys.artifacts.model.DataFacet;
ingo@692: import de.intevation.flys.artifacts.model.WQKms;
sascha@703:
ingo@692: import de.intevation.flys.artifacts.resources.Resources;
ingo@687:
sascha@703:
ingo@392: /**
ingo@392: * The final state that will be reached after the discharge curve calculation
ingo@392: * mode has been chosen.
ingo@392: *
ingo@392: * @author Ingo Weinzierl
ingo@392: */
ingo@692: public class ComputedDischargeCurveState
ingo@692: extends DefaultState
ingo@692: implements FacetTypes
ingo@692: {
ingo@392: /** The logger that is used in this state.*/
ingo@392: private static Logger logger =
ingo@392: Logger.getLogger(ComputedDischargeCurveState.class);
ingo@392:
sascha@660: public ComputedDischargeCurveState() {
ingo@392: }
ingo@687:
ingo@687:
ingo@687: @Override
sascha@697: public Object computeAdvance(
sascha@697: FLYSArtifact artifact,
sascha@697: String hash,
sascha@697: CallContext context,
sascha@697: List facets,
sascha@697: Object old
sascha@697: ) {
sascha@697: WINFOArtifact winfo = (WINFOArtifact)artifact;
ingo@692:
sascha@697: WQKms res;
ingo@692:
sascha@697: if (old instanceof WQKms []) {
sascha@697: res = ((WQKms [])old)[0];
sascha@697: }
sascha@697: else {
sascha@697: res = winfo.getComputedDischargeCurveData();
ingo@692:
sascha@697: if (res == null) {
sascha@697: logger.debug("No results given.");
sascha@697: return null;
sascha@697: }
sascha@697: }
ingo@692:
sascha@697: Object[] args = new Object[] {
sascha@697: winfo.getRiver().getName(),
sascha@697: res.getName()
sascha@697: };
ingo@692:
sascha@697: String name = Resources.getMsg(
sascha@697: context.getMeta(),
sascha@697: "chart.computed.discharge.curve.curve.label",
sascha@697: "",
sascha@697: args);
sascha@697:
sascha@703: facets.add(new WaterlevelFacet(0, COMPUTED_DISCHARGE_Q, name));
sascha@703: facets.add(new DataFacet(CSV, "CSV data"));
sascha@697:
sascha@697: return new WQKms[] { res };
ingo@687: }
ingo@392: }
ingo@392: // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf-8 :