/** * 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 java.util.HashSet; import java.util.Set; import javax.persistence.CascadeType; 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.OneToMany; import javax.persistence.OneToOne; import javax.persistence.Table; import javax.persistence.Temporal; import javax.persistence.TemporalType; import javax.persistence.Version; import org.hibernate.Hibernate; import org.hoteia.qalingo.core.domain.impl.DomainEntity; @Entity @Table(name="TECO_ORDER_PURCHASE") public class OrderPurchase extends AbstractEntity<OrderPurchase> implements DomainEntity { /** * Generated UID */ private static final long serialVersionUID = -3979521859173438793L; @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 = "TYPE") private String type; @Column(name="STATUS") private String status; @Column(name="ORDER_NUM", unique = true) private String orderNum; @Column(name = "PREFIX_HASH_FOLDER", unique = true) private String prefixHashFolder; @Column(name = "MARKET_AREA_ID") private Long marketAreaId; @Column(name = "RETAILER_ID") private Long retailerId; @Column(name = "LOCALIZATION_ID") private Long localizationId; @ManyToOne(fetch = FetchType.LAZY, targetEntity = org.hoteia.qalingo.core.domain.Customer.class) @JoinColumn(name = "CUSTOMER_ID", insertable = true, updatable = true) private Customer customer; @ManyToOne(fetch = FetchType.LAZY, targetEntity = org.hoteia.qalingo.core.domain.User.class) @JoinColumn(name = "USER_ID", insertable = true, updatable = true) private User user; @Column(name = "USER_STORE_ID") private Long userStoreId; @OneToOne(fetch = FetchType.LAZY, cascade = CascadeType.ALL, targetEntity = org.hoteia.qalingo.core.domain.OrderAddress.class) @JoinColumn(name="BILLING_ORDER_ADDRESS_ID") private OrderAddress billingAddress; @OneToOne(fetch = FetchType.LAZY, cascade = CascadeType.ALL, targetEntity = org.hoteia.qalingo.core.domain.OrderAddress.class) @JoinColumn(name="SHIPPING_ORDER_ADDRESS_ID") private OrderAddress shippingAddress; @ManyToOne(fetch = FetchType.LAZY, targetEntity = org.hoteia.qalingo.core.domain.CurrencyReferential.class) @JoinColumn(name = "CURRENCY_ID", insertable = true, updatable = true) private CurrencyReferential currency; @OneToMany(fetch = FetchType.LAZY, cascade = CascadeType.ALL, targetEntity = org.hoteia.qalingo.core.domain.OrderShipment.class) @JoinColumn(name="ORDER_ID") private Set<OrderShipment> shipments = new HashSet<OrderShipment>(); @OneToMany(fetch = FetchType.LAZY, cascade = CascadeType.ALL, targetEntity = org.hoteia.qalingo.core.domain.OrderPayment.class) @JoinColumn(name="ORDER_ID") private Set<OrderPayment> payments = new HashSet<OrderPayment>(); @OneToMany(fetch = FetchType.LAZY, cascade = CascadeType.ALL, targetEntity = org.hoteia.qalingo.core.domain.OrderDocument.class) @JoinColumn(name = "ORDER_ID") private Set<OrderDocument> documents = new HashSet<OrderDocument>(); @OneToMany(fetch = FetchType.LAZY, cascade = CascadeType.ALL, targetEntity = org.hoteia.qalingo.core.domain.OrderState.class) @JoinColumn(name="ORDER_ID") private Set<OrderState> states = new HashSet<OrderState>(); @Temporal(TemporalType.TIMESTAMP) @Column(name="DATE_CREATE") private Date dateCreate; @Temporal(TemporalType.TIMESTAMP) @Column(name="DATE_UPDATE") private Date dateUpdate; public OrderPurchase(){ 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; } public String getType() { return type; } public void setType(String type) { this.type = type; } public String getStatus() { return status; } public void setStatus(String status) { this.status = status; } public String getOrderNum() { return orderNum; } public void setOrderNum(String orderNum) { this.orderNum = orderNum; } public String getPrefixHashFolder() { return prefixHashFolder; } public void setPrefixHashFolder(String prefixHashFolder) { this.prefixHashFolder = prefixHashFolder; } public Long getMarketAreaId() { return marketAreaId; } public void setMarketAreaId(Long marketAreaId) { this.marketAreaId = marketAreaId; } public Long getLocalizationId() { return localizationId; } public void setLocalizationId(Long localizationId) { this.localizationId = localizationId; } public Long getRetailerId() { return retailerId; } public void setRetailerId(Long retailerId) { this.retailerId = retailerId; } public Customer getCustomer() { return customer; } public void setCustomer(Customer customer) { this.customer = customer; } public User getUser() { return user; } public void setUser(User user) { this.user = user; } public Long getUserStoreId() { return userStoreId; } public void setUserStoreId(Long userStoreId) { this.userStoreId = userStoreId; } public OrderAddress getBillingAddress() { return billingAddress; } public void setBillingAddress(OrderAddress billingAddress) { this.billingAddress = billingAddress; } public OrderAddress getShippingAddress() { return shippingAddress; } public void setShippingAddress(OrderAddress shippingAddress) { this.shippingAddress = shippingAddress; } public CurrencyReferential getCurrency() { return currency; } public void setCurrency(CurrencyReferential currency) { this.currency = currency; } public Set<OrderShipment> getShipments() { return shipments; } public void setShipments(Set<OrderShipment> shipments) { this.shipments = shipments; } public Set<OrderPayment> getPayments() { return payments; } public void setPayments(Set<OrderPayment> payments) { this.payments = payments; } public Set<OrderDocument> getDocuments() { return documents; } public void setDocuments(Set<OrderDocument> documents) { this.documents = documents; } public Set<OrderState> getStates() { return states; } public void setStates(Set<OrderState> states) { this.states = states; } 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; } public Date getExpectedDeliveryDate() { Date expectedDeliveryDate = null; if(shipments != null && Hibernate.isInitialized(shipments)){ for (final OrderShipment orderShipment : shipments) { if (expectedDeliveryDate == null) { expectedDeliveryDate = orderShipment.getExpectedDeliveryDate(); } else { if (expectedDeliveryDate.getTime() > orderShipment.getExpectedDeliveryDate().getTime()) { expectedDeliveryDate = orderShipment.getExpectedDeliveryDate(); } } } } return expectedDeliveryDate; } public Set<OrderTax> getOrderTaxes() { Set<OrderTax> orderTaxes = null; if(shipments != null && Hibernate.isInitialized(shipments)){ orderTaxes = new HashSet<OrderTax>(); for (final OrderShipment orderShipment : shipments) { for (final OrderItem orderItem : orderShipment.getOrderItems()) { for (OrderTax orderTax : orderItem.getTaxes()) { orderTaxes.add(orderTax); } } } } return orderTaxes; } public Set<OrderItem> getOrderItems() { Set<OrderItem> orderItems = null; if (shipments != null && Hibernate.isInitialized(shipments)) { orderItems = new HashSet<OrderItem>(); for (final OrderShipment orderShipment : shipments) { for (final OrderItem orderItem : orderShipment.getOrderItems()) { orderItems.add(orderItem); } } } return orderItems; } public Set<Long> getStoreIds() { Set<Long> stores = null; if (shipments != null && Hibernate.isInitialized(shipments)) { stores = new HashSet<Long>(); for (final OrderShipment orderShipment : shipments) { for (final OrderItem orderItem : orderShipment.getOrderItems()) { stores.add(orderItem.getStoreId()); } } } return stores; } public String getOrderTotalWithStandardCurrencySign() { return getCurrency().formatPriceWithStandardCurrencySign(getOrderTotal()); } public BigDecimal getOrderTotal() { BigDecimal total = new BigDecimal(0); Set<OrderItem> orderItems = getOrderItems(); for (OrderItem orderItem : orderItems) { total = total.add(orderItem.getOrderItemTotalPriceWithTaxes()); } return total; } public String getDeliveryMethodTotalWithStandardCurrencySign() { return getCurrency().formatPriceWithStandardCurrencySign(getDeliveryMethodTotal()); } public BigDecimal getDeliveryMethodTotal() { Set<OrderShipment> shipments = getShipments(); BigDecimal shippingTotal = new BigDecimal("0"); if (shipments != null && Hibernate.isInitialized(shipments)) { for (final OrderShipment orderShipment : shipments) { BigDecimal price = orderShipment.getPrice(); if (price != null) { shippingTotal = shippingTotal.add(price); } } } return shippingTotal; } public String getTaxTotalWithStandardCurrencySign() { return getCurrency().formatPriceWithStandardCurrencySign(getTaxTotal()); } public String getOrderItemTotalWithStandardCurrencySign() { return getCurrency().formatPriceWithStandardCurrencySign(getOrderItemTotal()); } public BigDecimal getOrderItemTotal() { BigDecimal cartItemsTotal = new BigDecimal(0); Set<OrderItem> orderItems = getOrderItems(); for (OrderItem orderItem : orderItems) { cartItemsTotal = cartItemsTotal.add(orderItem.getOrderItemTotalPrice()); } return cartItemsTotal; } public String getOrderItemTotalWithTaxesWithStandardCurrencySign() { return getCurrency().formatPriceWithStandardCurrencySign(getOrderItemTotalWithTaxes()); } public BigDecimal getOrderItemTotalWithTaxes() { BigDecimal cartItemsTotal = new BigDecimal(0); Set<OrderItem> orderItems = getOrderItems(); for (OrderItem orderItem : orderItems) { cartItemsTotal = cartItemsTotal.add(orderItem.getOrderItemTotalPriceWithTaxes()); } return cartItemsTotal; } public BigDecimal getTaxTotal() { BigDecimal totalAmount = new BigDecimal(0); for (OrderItem orderItem : getOrderItems()) { BigDecimal orderItemTaxesAmount = orderItem.getOrderItemTaxesAmount(); totalAmount = totalAmount.add(orderItemTaxesAmount); } return totalAmount; } @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 + ((orderNum == null) ? 0 : orderNum.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; OrderPurchase other = (OrderPurchase) 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 (orderNum == null) { if (other.orderNum != null) return false; } else if (!orderNum.equals(other.orderNum)) return false; return true; } @Override public String toString() { return "OrderPurchase [id=" + id + ", version=" + version + ", status=" + status + ", orderNum=" + orderNum + ", prefixHashFolder=" + prefixHashFolder + ", marketAreaId=" + marketAreaId + ", retailerId=" + retailerId + ", dateCreate=" + dateCreate + ", dateUpdate=" + dateUpdate + "]"; } }