CompoEntry.java 5.87 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 = "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
    @Basic(optional = false)
    @Column(name = "entries_id", nullable = false)
    private Integer id;
    @Basic(optional = false)
    @Column(name = "entry_created", nullable = false)
    @Temporal(TemporalType.TIMESTAMP)
    private Date entryCreated;
    @Basic(optional = false)
    @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;
    }

}