Objednávku lze nyní označit jako objednanou.

Na schválené položky se propíš číslo objednávky.
Všechny objednávky, které schválené a objednané položky obsahují již
není možno znovu objednat.
Objednávky mazat nelze, takže mazání dokladů neřešíme.

closes #153
This commit is contained in:
2014-10-15 16:49:39 +02:00
parent 3b4509d0a7
commit 5b380386bd
15 changed files with 187 additions and 15 deletions
@@ -7,12 +7,12 @@ import org.zkoss.util.resource.Labels;
public class StringUtils
{
private static String nullStr(String str)
public static String nullToEmptyString(String str)
{
return str == null ? "" : str;
}
private static String not0ToStr(long i)
private static String zeroToEmptyString(long i)
{
return i == 0 ? "" : String.valueOf(i);
}
@@ -60,8 +60,8 @@ public class StringUtils
public static boolean isEqualForFilter(String value, String search)
{
value = StringUtils.nullStr(value).toLowerCase();
search = StringUtils.nullStr(search).toLowerCase();
value = StringUtils.nullToEmptyString(value).toLowerCase();
search = StringUtils.nullToEmptyString(search).toLowerCase();
if (search.isEmpty())
{
@@ -73,8 +73,8 @@ public class StringUtils
public static boolean isIcEqualForFilter(long value, long search)
{
String compareValue = StringUtils.not0ToStr(value);
String searchValue = StringUtils.not0ToStr(search);
String compareValue = StringUtils.zeroToEmptyString(value);
String searchValue = StringUtils.zeroToEmptyString(search);
return compareValue.startsWith(searchValue);
}
@@ -124,7 +124,7 @@ public class StringUtils
for (int i = 0; i < list.size(); i++)
{
String item = StringUtils.nullStr(list.get(i));
String item = StringUtils.nullToEmptyString(list.get(i));
result = StringUtils.addSeparator(result, separator);
result += item;
}
@@ -138,7 +138,7 @@ public class StringUtils
for (int i = 0; i < list.size(); i++)
{
String item = StringUtils.nullStr(list.get(i));
String item = StringUtils.nullToEmptyString(list.get(i));
if (!item.isEmpty())
{
@@ -0,0 +1,8 @@
package info.bukova.isspst.dao;
import info.bukova.isspst.data.RequirementItem;
public interface RequirementItemDao extends BaseDao<RequirementItem>
{
}
@@ -0,0 +1,8 @@
package info.bukova.isspst.dao.jpa;
import info.bukova.isspst.dao.RequirementItemDao;
import info.bukova.isspst.data.RequirementItem;
public class RequirementItemDaoJPA extends BaseDaoJPA<RequirementItem> implements RequirementItemDao
{
}
@@ -19,7 +19,7 @@ import org.hibernate.annotations.LazyCollectionOption;
@Entity
@Table(name = "ORDERS")
public class Order extends BaseData
public class Order extends BaseData implements Cloneable
{
@Column(name = "NUMSER")
@@ -292,4 +292,28 @@ public class Order extends BaseData
this.invoiceTotal = invoiceTotal;
}
public boolean isIcludedRequirementItemFromAnotherOrder()
{
for (OrderItem oItem : this.getItems())
{
RequirementItem rItem = oItem.getReqItem();
if (rItem != null)
{
String orderNum = rItem.getOrderNum();
boolean isIncluded = !((orderNum == null) || (orderNum.isEmpty()));
return isIncluded;
}
}
return false;
}
@Override
public Object clone() throws CloneNotSupportedException
{
Order cloned = (Order) super.clone();
cloned.setTotal(new BigDecimal(this.getTotal().toString()));
return cloned;
}
}
@@ -56,6 +56,9 @@ public class RequirementItem
@Column(name = "DELIVERED")
private Boolean delivered;
@Column(name = "ORDERNUM")
private String orderNum;
public int getId()
{
return id;
@@ -187,4 +190,14 @@ public class RequirementItem
public void setDelivered(Boolean delivered) {
this.delivered = delivered;
}
public String getOrderNum()
{
return orderNum;
}
public void setOrderNum(String orderNum)
{
this.orderNum = orderNum;
}
}
@@ -42,6 +42,7 @@ public class OrderFilter implements Filter<Order>
@Override
public boolean matchesSafely(Order item)
{
boolean foundOrdered = (item.isOrdered() == condition.isOrdered());
boolean foundNumSer = StringUtils.isEqualForFilter(item.getNumser(), condition.getNumser());
boolean foundOrderDate = DateTimeUtils.isEqualByDateForFilter(item.getOrderDate(), condition.getOrderDate());
boolean foundTotal = true;// BigDecimalUtils.isEqualByDecimalForFilter(item.getTotal(),
@@ -56,7 +57,8 @@ public class OrderFilter implements Filter<Order>
boolean foundInvoiceAddr = AddressEmb.isEqualByAddressEmbForFilter(item.getAddress(), condition.getAddress());
boolean foundOwnedBy = User.isEqualByUserForFilter(item.getOwnedBy(), condition.getOwnedBy());
boolean foundDescription = StringUtils.isEqualForFilter(item.getDescription(), condition.getDescription());
return (foundNumSer
return (foundOrdered
&& foundNumSer
&& foundOrderDate
&& foundTotal
&& foundDeliveryDate
@@ -35,7 +35,7 @@ public class ApprovedServiceImpl extends AbstractService<JoinedItem> implements
{
List<Workgroup> wgList = workgroupService.getUserCentres(userService.getCurrent());
Query q = queryDao
.getQuery("select item from RequirementItem item left join item.requirement rq join rq.centre c where rq.kind is not null and rq.state = :state and c in (:wgList)");
.getQuery("select item from RequirementItem item left join item.requirement rq join rq.centre c where rq.kind is not null and rq.state = :state and c in (:wgList) and (item.orderNum Is Null or item.orderNum = '')");
q.setParameterList("wgList", wgList);
q.setParameter("state", RequirementState.APPROVED);
List<JoinedItem> items = new ArrayList<JoinedItem>();
@@ -22,4 +22,5 @@ public interface OrderService extends Service<Order> {
public BigDecimal calcSumTotalFromItems(List<OrderItem> items);
public void updateApprovedItems(Order order, boolean orderedChanged);
}
@@ -1,9 +1,11 @@
package info.bukova.isspst.services.approved;
import info.bukova.isspst.dao.RequirementItemDao;
import info.bukova.isspst.data.AddressEmb;
import info.bukova.isspst.data.JoinedItem;
import info.bukova.isspst.data.Order;
import info.bukova.isspst.data.OrderItem;
import info.bukova.isspst.data.RequirementItem;
import info.bukova.isspst.data.Workgroup;
import info.bukova.isspst.services.AbstractOwnedService;
import info.bukova.isspst.services.LazyLoader;
@@ -23,7 +25,10 @@ public class OrderServiceImpl extends AbstractOwnedService<Order> implements
@Autowired
private GlobalSettingsService globalSettings;
@Autowired
private RequirementItemDao requirementItemDao;
@Override
@PreAuthorize("hasPermission(this, 'PERM_ADD')")
public Order createOrder(List<JoinedItem> items) {
@@ -171,4 +176,24 @@ public class OrderServiceImpl extends AbstractOwnedService<Order> implements
return sumTotal;
}
@Transactional
public void updateApprovedItems(Order order, boolean orderedChanged)
{
if (orderedChanged)
{
for (OrderItem item : order.getItems())
{
RequirementItem rItem = item.getReqItem();
if (rItem != null)
{
rItem.setOrderNum(order.isOrdered() ? order.getNumser() : null);
requirementItemDao.modify(rItem);
}
}
}
super.update(order);
}
}
@@ -17,6 +17,8 @@ public class DocumentViewModel
{
protected BigDecimalConverter standardBigDecimalConverter;
protected BoolConverter standardBoolConverter;
public BigDecimalConverter getStandardBigDecimalConverter()
{
return standardBigDecimalConverter;
@@ -27,10 +29,21 @@ public class DocumentViewModel
this.standardBigDecimalConverter = standardBigDecimalConverter;
}
public BoolConverter getStandardBoolConverter()
{
return standardBoolConverter;
}
public void setStandardBoolConverter(BoolConverter standardBoolConverter)
{
this.standardBoolConverter = standardBoolConverter;
}
@Init
public void initDocumentViewModel()
{
this.standardBigDecimalConverter = new BigDecimalConverter();
this.standardBoolConverter = new BoolConverter();
}
@Command
@@ -51,6 +51,11 @@ public class OrderForm extends FormViewModel<Order>
protected List<OrderItem> syncOrderItems;
/**
* Obsah záznamu před editací
*/
protected Order recordBeforeEdit;
@Init(superclass = true)
public void initOrderForm()
{
@@ -78,6 +83,16 @@ public class OrderForm extends FormViewModel<Order>
}
this.syncOrderItems = this.getDataBean().getItems();
try
{
this.recordBeforeEdit = (Order) this.getDataBean().clone();
}
catch (CloneNotSupportedException e)
{
log.error("Nelze provést hlubokou kopii objednávky!");
e.printStackTrace();
}
}
public OrderFormValidator getOrderFormValidator()
@@ -165,6 +180,16 @@ public class OrderForm extends FormViewModel<Order>
this.syncOrderItems = syncOrderItems;
}
public Order getRecordBeforeEdit()
{
return recordBeforeEdit;
}
public void setRecordBeforeEdit(Order recordBeforeEdit)
{
this.recordBeforeEdit = recordBeforeEdit;
}
@Command
@NotifyChange("dataBean")
public void doFillSuppAddress()
@@ -252,4 +277,14 @@ public class OrderForm extends FormViewModel<Order>
// Calculate total price at form
this.calcAndUpdateFormTotalPrice(form);
}
@Override
protected void doSave()
{
// Zjisti, zda se změnil příznak objednávky (objednáno/neobjednáno)
boolean orderedChanged = (this.recordBeforeEdit.isOrdered() != this.getDataBean().isOrdered());
// Aktualizovat příznak schválených položek, aby se nemohli vložit do
// jiných objednávek
orderService.updateApprovedItems(this.getDataBean(), orderedChanged);
}
}