Mercurial > dive4elements > river
view flys-backend/src/main/java/de/intevation/flys/model/SedimentYield.java @ 5509:627584bc0586
Datacage: Added <dc:filter> element. This allows cleaner way to narrow the datasets.
Example:
<dc:context>
<dc:statement>
SELECT DISTINCT
name AS hws_name,
official AS hws_official,
kind_id AS hws_kind
FROM hws_lines
WHERE river_id = ${river_id}
</dc:statement>
<dc:if test="dc:has-result()">
<lines>
<dc:macro name="hws-lines">
<dc:elements>
<hws factory="hwsfactory" name="{$hws_name}"/>
</dc:elements>
</dc:macro>
<dc:filter expr="$hws_official=1">
<dc:if test="dc:has-result()">
<official>
<dc:filter expr="$hws_kind=1">
<dc:if test="dc:has-result()">
<Durchlass><dc:call-macro name="hws-lines"></Durchlass>
</dc:if>
</dc:filter>
<dc:filter expr="$hws_kind=2">
<dc:if test="dc:has-result()">
<Damm><dc:call-macro name="hws-lines"></Damm>
</dc:if>
</dc:filter>
<dc:filter expr="$hws_kind=3">
<dc:if test="dc:has-result()">
<Graben><dc:call-macro name="hws-lines"></Graben>
</dc:if>
</dc:filter>
</official>
</dc:if>
</dc:filter>
</lines>
</dc:if>
</dc:context>
author | Sascha L. Teichmann <teichmann@intevation.de> |
---|---|
date | Thu, 28 Mar 2013 16:51:15 +0100 |
parents | 71175502d868 |
children |
line wrap: on
line source
package de.intevation.flys.model; import java.io.Serializable; import java.util.ArrayList; import java.util.List; import javax.persistence.Entity; import javax.persistence.Id; import javax.persistence.Table; import javax.persistence.GeneratedValue; import javax.persistence.Column; import javax.persistence.SequenceGenerator; import javax.persistence.GenerationType; import javax.persistence.JoinColumn; import javax.persistence.OneToOne; import org.apache.log4j.Logger; @Entity @Table(name = "sediment_yield") public class SedimentYield implements Serializable { private static Logger logger = Logger.getLogger(SedimentYield.class); private Integer id; private River river; private GrainFraction grainFraction; private Unit unit; private TimeInterval timeInterval; private String description; private List<SedimentYieldValue> values; public SedimentYield() { this.values = new ArrayList<SedimentYieldValue>(); } public SedimentYield(River river, Unit unit, TimeInterval timeInterval) { this(); this.river = river; this.unit = unit; this.timeInterval = timeInterval; } public SedimentYield( River river, Unit unit, TimeInterval timeInterval, GrainFraction grainFraction ) { this(river, unit, timeInterval); this.grainFraction = grainFraction; } public SedimentYield( River river, Unit unit, TimeInterval timeInterval, GrainFraction grainFraction, String description ) { this(river, unit, timeInterval, grainFraction); this.description = description; } @Id @SequenceGenerator( name = "SEQUENCE_SEDIMENT_YIELD_ID_SEQ", sequenceName = "SEDIMENT_YIELD_ID_SEQ", allocationSize = 1) @GeneratedValue( strategy = GenerationType.SEQUENCE, generator = "SEQUENCE_SEDIMENT_YIELD_ID_SEQ") @Column(name = "id") public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } @OneToOne @JoinColumn(name = "river_id") public River getRiver() { return river; } public void setRiver(River river) { this.river = river; } @OneToOne @JoinColumn(name="grain_fraction_id") public GrainFraction getGrainFraction() { return grainFraction; } public void setGrainFraction(GrainFraction grainFraction) { this.grainFraction = grainFraction; } @OneToOne @JoinColumn(name = "unit_id") public Unit getUnit() { return unit; } public void setUnit(Unit unit) { this.unit = unit; } @OneToOne @JoinColumn(name = "time_interval_id") public TimeInterval getTimeInterval() { return timeInterval; } public void setTimeInterval(TimeInterval timeInterval) { this.timeInterval = timeInterval; } @Column(name = "description") public String getDescription() { return description; } public void setDescription(String description) { this.description = description; } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :