/**
* Most of the code in the Qalingo project is copyrighted Hoteia and licensed
* under the Apache License Version 2.0 (release version 0.8.0)
* http://www.apache.org/licenses/LICENSE-2.0
*
* Copyright (c) Hoteia, 2012-2014
* http://www.hoteia.com - http://twitter.com/hoteia - contact@hoteia.com
*
*/
package org.hoteia.qalingo.core.domain;
import java.math.BigDecimal;
import java.util.Date;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.Table;
import javax.persistence.Temporal;
import javax.persistence.TemporalType;
import javax.persistence.Version;
import org.hoteia.qalingo.core.domain.impl.DomainEntity;
@Entity
@Table(name="TECO_PRODUCT_SKU_STORE_PRICE")
public class ProductSkuStorePrice extends AbstractPrice<ProductSkuStorePrice> implements DomainEntity {
/**
* Generated UID
*/
private static final long serialVersionUID = -4776613203202967926L;
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name="ID", nullable=false)
private Long id;
@Version
@Column(name="VERSION", nullable=false) // , columnDefinition="int(11) default 1"
private int version;
@Column(name="SALE_PRICE")
private BigDecimal salePrice;
@Column(name = "IS_CATALOG_PRICE", nullable = false) // , columnDefinition = "tinyint(1) default 0"
private boolean isCatalogPrice = false;
@Column(name = "IS_DISCOUNT", nullable = false) // , columnDefinition = "tinyint(1) default 0"
private boolean isDiscount = false;
@Column(name = "IS_VAT_INCLUDED", nullable = false) // , columnDefinition = "tinyint(1) default 0"
private boolean isVATIncluded = false;
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name="CURRENCY_ID", insertable = true, updatable = true)
private CurrencyReferential currency;
@Column(name="MARKET_AREA_ID")
private Long marketAreaId;
@ManyToOne(fetch = FetchType.LAZY, targetEntity = org.hoteia.qalingo.core.domain.Store.class)
@JoinColumn(name="STORE_ID", insertable = true, updatable = true)
private Store store;
@ManyToOne(fetch = FetchType.LAZY, targetEntity = org.hoteia.qalingo.core.domain.ProductSku.class)
@JoinColumn(name="PRODUCT_SKU_ID", insertable = true, updatable = true)
private ProductSku productSku;
@Temporal(TemporalType.TIMESTAMP)
@Column(name = "DATE_START")
private Date dateStart;
@Temporal(TemporalType.TIMESTAMP)
@Column(name = "DATE_END")
private Date dateEnd;
@Temporal(TemporalType.TIMESTAMP)
@Column(name = "DATE_CREATE")
private Date dateCreate;
@Temporal(TemporalType.TIMESTAMP)
@Column(name = "DATE_UPDATE")
private Date dateUpdate;
public ProductSkuStorePrice() {
this.dateCreate = new Date();
this.dateUpdate = new Date();
}
public ProductSkuStorePrice(Long marketAreaId) {
this.marketAreaId = marketAreaId;
this.dateCreate = new Date();
this.dateUpdate = new Date();
}
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public int getVersion() {
return version;
}
public void setVersion(int version) {
this.version = version;
}
@Override
public BigDecimal getSalePrice() {
return salePrice;
}
public void setSalePrice(BigDecimal salePrice) {
this.salePrice = salePrice;
}
public boolean isCatalogPrice() {
return isCatalogPrice;
}
public void setCatalogPrice(boolean isCatalogPrice) {
this.isCatalogPrice = isCatalogPrice;
}
public boolean isDiscount() {
return isDiscount;
}
public void setDiscount(boolean isDiscount) {
this.isDiscount = isDiscount;
}
public boolean isVATIncluded() {
return isVATIncluded;
}
public void setVATIncluded(boolean isVATIncluded) {
this.isVATIncluded = isVATIncluded;
}
@Override
public CurrencyReferential getCurrency() {
return currency;
}
public void setCurrency(CurrencyReferential currency) {
this.currency = currency;
}
public Long getMarketAreaId() {
return marketAreaId;
}
public void setMarketAreaId(Long marketAreaId) {
this.marketAreaId = marketAreaId;
}
public Store getStore() {
return store;
}
public void setStore(Store store) {
this.store = store;
}
public ProductSku getProductSku() {
return productSku;
}
public void setProductSku(ProductSku productSku) {
this.productSku = productSku;
}
public Date getDateStart() {
return dateStart;
}
public void setDateStart(Date dateStart) {
this.dateStart = dateStart;
}
public Date getDateEnd() {
return dateEnd;
}
public void setDateEnd(Date dateEnd) {
this.dateEnd = dateEnd;
}
public Date getDateCreate() {
return dateCreate;
}
public void setDateCreate(Date dateCreate) {
this.dateCreate = dateCreate;
}
public Date getDateUpdate() {
return dateUpdate;
}
public void setDateUpdate(Date dateUpdate) {
this.dateUpdate = dateUpdate;
}
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + ((dateCreate == null) ? 0 : dateCreate.hashCode());
result = prime * result + ((id == null) ? 0 : id.hashCode());
result = prime * result + ((marketAreaId == null) ? 0 : marketAreaId.hashCode());
return result;
}
@Override
public boolean equals(Object sourceObj) {
Object obj = deproxy(sourceObj);
if (this == obj)
return true;
if (obj == null)
return false;
if (getClass() != obj.getClass())
return false;
ProductSkuStorePrice other = (ProductSkuStorePrice) obj;
if (dateCreate == null) {
if (other.dateCreate != null)
return false;
} else if (!dateCreate.equals(other.dateCreate))
return false;
if (id == null) {
if (other.id != null)
return false;
} else if (!id.equals(other.id))
return false;
if (marketAreaId == null) {
if (other.marketAreaId != null)
return false;
} else if (!marketAreaId.equals(other.marketAreaId))
return false;
return true;
}
@Override
public String toString() {
return "ProductSkuPrice [id=" + id + ", version=" + version + ", currency=" + currency + ", marketAreaId=" + marketAreaId + ", dateStart=" + dateStart + ", dateEnd=" + dateEnd + ", dateCreate=" + dateCreate + ", dateUpdate=" + dateUpdate + "]";
}
}