CompoEntry.java 5.48 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.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 = "entries")
@NamedQueries( {
	@NamedQuery(name = "CompoEntry.findAll", query = "SELECT c FROM CompoEntry c"),
	@NamedQuery(name = "CompoEntry.findByEntriesId", query = "SELECT c FROM CompoEntry c WHERE c.entriesId = :entriesId"),
	@NamedQuery(name = "CompoEntry.findByEntryCreated", query = "SELECT c FROM CompoEntry c WHERE c.entryCreated = :entryCreated"),
	@NamedQuery(name = "CompoEntry.findByEntryName", query = "SELECT c FROM CompoEntry c WHERE c.entryName = :entryName"),
	@NamedQuery(name = "CompoEntry.findByNotes", query = "SELECT c FROM CompoEntry c WHERE c.notes = :notes"),
	@NamedQuery(name = "CompoEntry.findByScreenMessage", query = "SELECT c FROM CompoEntry c WHERE c.screenMessage = :screenMessage"),
	@NamedQuery(name = "CompoEntry.findBySort", query = "SELECT c FROM CompoEntry c WHERE c.sort = :sort") })
public class CompoEntry implements ModelInterface {
    private static final long serialVersionUID = 1L;
    @Id
    @Column(name = "entries_id", nullable = false)
    private Integer id;

    @Column(name = "entry_created", nullable = false)
    @Temporal(TemporalType.TIMESTAMP)
    private Date entryCreated;

    @Column(name = "entry_name", nullable = false)
    private String entryName;
    @Column(name = "notes")
    private String notes;
    @Column(name = "screen_message")
    private String screenMessage;
    @Column(name = "sort")
    private Integer sort;
    @OneToMany(cascade = CascadeType.ALL, mappedBy = "compoEntry")
    private List<Vote> voteList;
    @OneToMany(cascade = CascadeType.ALL, mappedBy = "entry")
    private List<CompoEntryFile> compoEntryFileList;
    @OneToMany(cascade = CascadeType.ALL, mappedBy = "entry")
    private List<CompoEntryParticipant> compoEntryParticipantList;
    @JoinColumn(name = "compos_id", referencedColumnName = "compos_id", nullable = false)
    @ManyToOne(optional = false)
    private Compo composId;
    @JoinColumn(name = "creator", referencedColumnName = "users_id")
    @ManyToOne
    private User creator;

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

    public Integer getId() {
	return id;
    }

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

    public CompoEntry() {
    }

    public CompoEntry(Integer entriesId) {
	this.id = entriesId;
    }

    public CompoEntry(Integer entriesId, Date entryCreated, String entryName) {
	this.id = entriesId;
	this.entryCreated = entryCreated;
	this.entryName = entryName;
    }

    public Date getEntryCreated() {
	return entryCreated;
    }

    public void setEntryCreated(Date entryCreated) {
	this.entryCreated = entryCreated;
    }

    public String getEntryName() {
	return entryName;
    }

    public void setEntryName(String entryName) {
	this.entryName = entryName;
    }

    public String getNotes() {
	return notes;
    }

    public void setNotes(String notes) {
	this.notes = notes;
    }

    public String getScreenMessage() {
	return screenMessage;
    }

    public void setScreenMessage(String screenMessage) {
	this.screenMessage = screenMessage;
    }

    public Integer getSort() {
	return sort;
    }

    public void setSort(Integer sort) {
	this.sort = sort;
    }

    public List<Vote> getVoteList() {
	return voteList;
    }

    public void setVoteList(List<Vote> voteList) {
	this.voteList = voteList;
    }

    public List<CompoEntryFile> getCompoEntryFileList() {
	return compoEntryFileList;
    }

    public void setCompoEntryFileList(List<CompoEntryFile> compoEntryFileList) {
	this.compoEntryFileList = compoEntryFileList;
    }

    public List<CompoEntryParticipant> getCompoEntryParticipantList() {
	return compoEntryParticipantList;
    }

    public void setCompoEntryParticipantList(
	    List<CompoEntryParticipant> compoEntryParticipantList) {
	this.compoEntryParticipantList = compoEntryParticipantList;
    }

    public Compo getComposId() {
	return composId;
    }

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

    public User getCreator() {
	return creator;
    }

    public void setCreator(User creator) {
	this.creator = creator;
    }

    @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 CompoEntry)) {
	    return false;
	}
	CompoEntry other = (CompoEntry) 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.CompoEntry[entriesId=" + id + "]";
    }

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

    public int getJpaVersionField() {
	return jpaVersionField;
    }

}