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

package fi.insomnia.bortal.model;

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

/**
 * 
 * @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 Serializable {
    private static final long serialVersionUID = 1L;
    @Id
    @Basic(optional = false)
    @Column(name = "compos_id", nullable = false)
    private Integer composId;
    @Basic(optional = false)
    @Column(name = "compo_name", nullable = false, length = 2147483647)
    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;
    @Basic(optional = false)
    @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;

    public Compo() {
    }

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

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

    public Integer getComposId() {
	return composId;
    }

    public void setComposId(Integer composId) {
	this.composId = composId;
    }

    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 += (composId != null ? composId.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.composId == null && other.composId != null)
		|| (this.composId != null && !this.composId
			.equals(other.composId))) {
	    return false;
	}
	return true;
    }

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

}