PlaceGroup.java 5.94 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 = "groups")
@NamedQueries({
    @NamedQuery(name = "PlaceGroup.findAll", query = "SELECT p FROM PlaceGroup p"),
    @NamedQuery(name = "PlaceGroup.findByGroupsId", query = "SELECT p FROM PlaceGroup p WHERE p.groupsId = :groupsId"),
    @NamedQuery(name = "PlaceGroup.findByGroupCreated", query = "SELECT p FROM PlaceGroup p WHERE p.groupCreated = :groupCreated"),
    @NamedQuery(name = "PlaceGroup.findByGroupEdited", query = "SELECT p FROM PlaceGroup p WHERE p.groupEdited = :groupEdited"),
    @NamedQuery(name = "PlaceGroup.findByGroupCode", query = "SELECT p FROM PlaceGroup p WHERE p.groupCode = :groupCode"),
    @NamedQuery(name = "PlaceGroup.findByGroupName", query = "SELECT p FROM PlaceGroup p WHERE p.groupName = :groupName"),
    @NamedQuery(name = "PlaceGroup.findByGroupActive", query = "SELECT p FROM PlaceGroup p WHERE p.groupActive = :groupActive"),
    @NamedQuery(name = "PlaceGroup.findByGroupDetails", query = "SELECT p FROM PlaceGroup p WHERE p.groupDetails = :groupDetails")})
public class PlaceGroup implements ModelInterface {

    private static final long serialVersionUID = 1L;
    @Id
    
    @Column(name = "groups_id", nullable = false)
    private Integer id;
    
    @Column(name = "group_created", nullable = false)
    @Temporal(TemporalType.TIMESTAMP)
    private Date groupCreated;
    
    @Column(name = "group_edited", nullable = false)
    @Temporal(TemporalType.TIMESTAMP)
    private Date groupEdited;
    @Column(name = "group_code")
    private String groupCode;
    @Column(name = "group_name")
    private String groupName;
    
    @Column(name = "group_active", nullable = false)
    private boolean groupActive;
    @Column(name = "group_details")
    private String groupDetails;
    @JoinColumn(name = "group_creator", referencedColumnName = "users_id")
    @ManyToOne
    private User groupCreator;
    @OneToMany(cascade = CascadeType.ALL, mappedBy = "groupsId")
    private List<GroupMembership> groupMembershipList;
    @OneToMany(mappedBy = "groupsId")
    private List<Place> placeList;
    @Version
    @Column(nullable = false)
    private int jpaVersionField;

    public PlaceGroup() {
    }

    public PlaceGroup(Integer groupsId) {
        this.id = groupsId;
    }

    public PlaceGroup(Integer groupsId, Date groupCreated, Date groupEdited, boolean groupActive) {
        this.id = groupsId;
        this.groupCreated = groupCreated;
        this.groupEdited = groupEdited;
        this.groupActive = groupActive;
    }

    public Date getGroupCreated() {
        return groupCreated;
    }

    public void setGroupCreated(Date groupCreated) {
        this.groupCreated = groupCreated;
    }

    public Date getGroupEdited() {
        return groupEdited;
    }

    public void setGroupEdited(Date groupEdited) {
        this.groupEdited = groupEdited;
    }

    public String getGroupCode() {
        return groupCode;
    }

    public void setGroupCode(String groupCode) {
        this.groupCode = groupCode;
    }

    public String getGroupName() {
        return groupName;
    }

    public void setGroupName(String groupName) {
        this.groupName = groupName;
    }

    public boolean getGroupActive() {
        return groupActive;
    }

    public void setGroupActive(boolean groupActive) {
        this.groupActive = groupActive;
    }

    public String getGroupDetails() {
        return groupDetails;
    }

    public void setGroupDetails(String groupDetails) {
        this.groupDetails = groupDetails;
    }

    public User getGroupCreator() {
        return groupCreator;
    }

    public void setGroupCreator(User groupCreator) {
        this.groupCreator = groupCreator;
    }

    public List<GroupMembership> getGroupMembershipList() {
        return groupMembershipList;
    }

    public void setGroupMembershipList(List<GroupMembership> groupMembershipList) {
        this.groupMembershipList = groupMembershipList;
    }

    public List<Place> getPlaceList() {
        return placeList;
    }

    public void setPlaceList(List<Place> placeList) {
        this.placeList = placeList;
    }

    @Override
    public int hashCode() {
        int hash = 0;
        hash += (getId() != null ? getId().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 PlaceGroup)) {
            return false;
        }
        PlaceGroup other = (PlaceGroup) object;
        if ((this.getId() == null && other.getId() != null) || (this.getId() != null && !this.id.equals(other.id))) {
            return false;
        }
        return true;
    }

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

    /**
     * @return the id
     */
    public Integer getId() {
        return id;
    }

    /**
     * @param id the id to set
     */
    public void setId(Integer id) {
        this.id = id;
    }

    /**
     * @return the jpaVersionField
     */
    public int getJpaVersionField() {
        return jpaVersionField;
    }

    /**
     * @param jpaVersionField the jpaVersionField to set
     */
    public void setJpaVersionField(int jpaVersionField) {
        this.jpaVersionField = jpaVersionField;
    }
}