Compo.java 5.55 KB
/*
 * To change this template, choose Tools | Templates
 * and open the template in the editor.
 */

package fi.insomnia.bortal.model;


import java.util.Date;
import java.util.List;

import javax.persistence.Basic;
import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.NamedQueries;
import javax.persistence.NamedQuery;
import javax.persistence.OneToMany;
import javax.persistence.Table;
import javax.persistence.Temporal;
import javax.persistence.TemporalType;
import javax.persistence.Version;

/**
 *
 * @author jkj
 */
@Entity
@Table(name = "compos")
@NamedQueries({
    @NamedQuery(name = "Compo.findAll", query = "SELECT c FROM Compo c"),
    @NamedQuery(name = "Compo.findByComposId", query = "SELECT c FROM Compo c WHERE c.composId = :composId"),
    @NamedQuery(name = "Compo.findByCompoName", query = "SELECT c FROM Compo c WHERE c.compoName = :compoName"),
    @NamedQuery(name = "Compo.findByCompoStart", query = "SELECT c FROM Compo c WHERE c.compoStart = :compoStart"),
    @NamedQuery(name = "Compo.findByVoteStart", query = "SELECT c FROM Compo c WHERE c.voteStart = :voteStart"),
    @NamedQuery(name = "Compo.findByVoteEnd", query = "SELECT c FROM Compo c WHERE c.voteEnd = :voteEnd"),
    @NamedQuery(name = "Compo.findBySubmitStart", query = "SELECT c FROM Compo c WHERE c.submitStart = :submitStart"),
    @NamedQuery(name = "Compo.findBySubmitEnd", query = "SELECT c FROM Compo c WHERE c.submitEnd = :submitEnd"),
    @NamedQuery(name = "Compo.findByHoldVoting", query = "SELECT c FROM Compo c WHERE c.holdVoting = :holdVoting")})
public class Compo implements ModelInterface {
    private static final long serialVersionUID = 1L;
    @Id
    
    @Column(name = "compos_id", nullable = false)
    private Integer id;
    
    @Column(name = "compo_name", nullable = false)
    private String compoName;
    @Column(name = "compo_start")
    @Temporal(TemporalType.TIMESTAMP)
    private Date compoStart;
    @Column(name = "vote_start")
    @Temporal(TemporalType.TIMESTAMP)
    private Date voteStart;
    @Column(name = "vote_end")
    @Temporal(TemporalType.TIMESTAMP)
    private Date voteEnd;
    @Column(name = "submit_start")
    @Temporal(TemporalType.TIMESTAMP)
    private Date submitStart;
    @Column(name = "submit_end")
    @Temporal(TemporalType.TIMESTAMP)
    private Date submitEnd;
    
    @Column(name = "hold_voting", nullable = false)
    private boolean holdVoting;
    @OneToMany(cascade = CascadeType.ALL, mappedBy = "composId")
    private List<CompoEntry> compoEntryList;
    @JoinColumn(name = "events_id", referencedColumnName = "events_id", nullable = false)
    @ManyToOne(optional = false)
    private Event eventsId;

    @Version
    @Column(nullable = false)
    private int jpaVersionField;


    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public Compo() {
    }

    public Compo(Integer composId) {
        this.id = composId;
    }

    public Compo(Integer composId, String compoName, boolean holdVoting) {
        this.id = composId;
        this.compoName = compoName;
        this.holdVoting = holdVoting;
    }

    public String getCompoName() {
        return compoName;
    }

    public void setCompoName(String compoName) {
        this.compoName = compoName;
    }

    public Date getCompoStart() {
        return compoStart;
    }

    public void setCompoStart(Date compoStart) {
        this.compoStart = compoStart;
    }

    public Date getVoteStart() {
        return voteStart;
    }

    public void setVoteStart(Date voteStart) {
        this.voteStart = voteStart;
    }

    public Date getVoteEnd() {
        return voteEnd;
    }

    public void setVoteEnd(Date voteEnd) {
        this.voteEnd = voteEnd;
    }

    public Date getSubmitStart() {
        return submitStart;
    }

    public void setSubmitStart(Date submitStart) {
        this.submitStart = submitStart;
    }

    public Date getSubmitEnd() {
        return submitEnd;
    }

    public void setSubmitEnd(Date submitEnd) {
        this.submitEnd = submitEnd;
    }

    public boolean getHoldVoting() {
        return holdVoting;
    }

    public void setHoldVoting(boolean holdVoting) {
        this.holdVoting = holdVoting;
    }

    public List<CompoEntry> getCompoEntryList() {
        return compoEntryList;
    }

    public void setCompoEntryList(List<CompoEntry> compoEntryList) {
        this.compoEntryList = compoEntryList;
    }

    public Event getEventsId() {
        return eventsId;
    }

    public void setEventsId(Event eventsId) {
        this.eventsId = eventsId;
    }

    @Override
    public int hashCode() {
        int hash = 0;
        hash += (id != null ? id.hashCode() : 0);
        return hash;
    }

    @Override
    public boolean equals(Object object) {
        // TODO: Warning - this method won't work in the case the id fields are not set
        if (!(object instanceof Compo)) {
            return false;
        }
        Compo other = (Compo) object;
        if ((this.id == null && other.id != null) || (this.id != null && !this.id.equals(other.id))) {
            return false;
        }
        return true;
    }

    @Override
    public String toString() {
        return "fi.insomnia.bortal.model.Compo[composId=" + id + "]";
    }

    public void setJpaVersionField(int jpaVersionField) {
	this.jpaVersionField = jpaVersionField;
    }

    public int getJpaVersionField() {
	return jpaVersionField;
    }

}