view flys-backend/src/main/java/de/intevation/flys/model/Waterlevel.java @ 4198:1cdbd8a0c994

Added two new tables ClickableQDTable and ClickableWTable and made Ws and Qs clickable in historical discharge calculation. The new tables define listener interfaces (clicked lower or upper icon) to listen to user clicks. In addition to this, there is an enum ClickMode with NONE, SINGLE and RANGE options, which allows to specifiy, which icons are displayed in the tables. NONE means no icon for user clicks, SINGLE has 1 icon, RANGE 2 icons for lower and upper.
author Ingo Weinzierl <ingo.weinzierl@intevation.de>
date Mon, 22 Oct 2012 13:31:25 +0200
parents 0d55b7722fae
children 99b452967737
line wrap: on
line source
package de.intevation.flys.model;

import java.io.Serializable;
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 javax.persistence.OneToMany;

import org.apache.log4j.Logger;




@Entity
@Table(name = "waterlevel")
public class Waterlevel
implements   Serializable
{
    private static Logger logger = Logger.getLogger(Waterlevel.class);

    private Integer id;

    private River river;

    private Unit unit;

    private String  description;

    private List<WaterlevelQRange> qRanges;


    public Waterlevel() {
    }

    public Waterlevel(River river, Unit unit) {
        this.river = river;
        this.unit  = unit;
    }

    public Waterlevel(River river, Unit unit, String description) {
        this(river, unit);
        this.description = description;
    }

    @Id
    @SequenceGenerator(
        name           = "SEQUENCE_WATERLEVEL_ID_SEQ",
        sequenceName   = "WATERLEVEL_ID_SEQ",
        allocationSize = 1)
    @GeneratedValue(
        strategy  = GenerationType.SEQUENCE,
        generator = "SEQUENCE_WATERLEVEL_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 = "unit_id")
    public Unit getUnit() {
        return unit;
    }

    public void setUnit(Unit unit) {
        this.unit = unit;
    }

    @Column(name = "description")
    public String getDescription() {
        return description;
    }

    public void setDescription(String description) {
        this.description = description;
    }

    @OneToMany
    @JoinColumn(name="waterlevel_id")
    public List<WaterlevelQRange> getQRanges() {
        return qRanges;
    }

    public void setQRanges(List<WaterlevelQRange> qRanges) {
        this.qRanges = qRanges;
    }

    public void addQRange(WaterlevelQRange qRange) {
        qRanges.add(qRange);
    }
}
// vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :

http://dive4elements.wald.intevation.org