采购订单明细计算逻辑标品逻辑去除
This commit is contained in:
parent
dd302c682d
commit
1b725ff2fb
|
@ -0,0 +1,122 @@
|
||||||
|
package shkd.repc.repe.formplugin;
|
||||||
|
|
||||||
|
import kd.bos.dataentity.entity.DynamicObject;
|
||||||
|
import kd.bos.dataentity.entity.DynamicObjectCollection;
|
||||||
|
import kd.bos.dataentity.resource.ResManager;
|
||||||
|
import kd.bos.entity.datamodel.events.PropertyChangedArgs;
|
||||||
|
import kd.bos.orm.query.QFilter;
|
||||||
|
import kd.bos.servicehelper.BusinessDataServiceHelper;
|
||||||
|
import kd.repc.repe.formplugin.order.OrderFormEdit;
|
||||||
|
|
||||||
|
import java.math.BigDecimal;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
|
public class OrderFormEditExt extends OrderFormEdit {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void calculatePrice(int rowIndex, String fieldKey, PropertyChangedArgs e) {
|
||||||
|
DynamicObject orderForm = this.getModel().getDataEntity(true);
|
||||||
|
DynamicObjectCollection orderformEntryColl = orderForm.getDynamicObjectCollection("orderformentry");
|
||||||
|
DynamicObject orderFormEntry = (DynamicObject)orderformEntryColl.get(rowIndex);
|
||||||
|
DynamicObject material = orderFormEntry.getDynamicObject("material");
|
||||||
|
if (material != null) {
|
||||||
|
BigDecimal orderCount = orderFormEntry.getBigDecimal("ordercount");
|
||||||
|
BigDecimal unitPrice;
|
||||||
|
BigDecimal transportPrice;
|
||||||
|
BigDecimal installPrice;
|
||||||
|
if (fieldKey.equals("ordercount") && this.getNpFlag(orderForm)) {
|
||||||
|
unitPrice = this.getContractOrderCount(orderForm, material.getPkValue());
|
||||||
|
transportPrice = ((DynamicObject)orderForm.getDynamicObjectCollection("orderformentry").get(rowIndex)).getBigDecimal("contractnum");
|
||||||
|
installPrice = transportPrice.subtract(unitPrice);
|
||||||
|
if (orderCount.compareTo(installPrice) > 0) {
|
||||||
|
this.getView().showTipNotification(ResManager.loadKDString("本次订货数量只可填≤合同剩余数量的值", "OrderFormEdit_25", "repc-repe-formplugin", new Object[0]));
|
||||||
|
orderFormEntry.set("ordercount", 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
orderFormEntry.set("contractremainnum", installPrice.subtract(orderCount));
|
||||||
|
this.getView().setEnable(Boolean.FALSE, rowIndex, new String[]{"brand", "model", "contractnum", "unitprice", "transportprice", "installprice", "taxprice", "taxrate", "description"});
|
||||||
|
}
|
||||||
|
|
||||||
|
unitPrice = orderFormEntry.getBigDecimal("unitprice").setScale(4, 1);
|
||||||
|
transportPrice = orderFormEntry.getBigDecimal("transportprice").setScale(4, 1);
|
||||||
|
installPrice = orderFormEntry.getBigDecimal("installprice").setScale(4, 1);
|
||||||
|
DynamicObject taxRate = orderFormEntry.getDynamicObject("taxrate");
|
||||||
|
BigDecimal totalPrice;
|
||||||
|
BigDecimal noTaxTotalPrice;
|
||||||
|
if (fieldKey.equals("taxprice")) {
|
||||||
|
totalPrice = orderFormEntry.getBigDecimal("taxprice");
|
||||||
|
if (null != taxRate) {
|
||||||
|
noTaxTotalPrice = taxRate.getBigDecimal("taxrate");
|
||||||
|
totalPrice = totalPrice.divide(BigDecimal.ONE.add(noTaxTotalPrice.divide(new BigDecimal("100"))), 4, 4).setScale(4, 4);
|
||||||
|
}
|
||||||
|
|
||||||
|
unitPrice = totalPrice.subtract(transportPrice).subtract(installPrice);
|
||||||
|
//orderFormEntry.set("unitprice", unitPrice);
|
||||||
|
}
|
||||||
|
|
||||||
|
totalPrice = transportPrice.add(unitPrice).add(installPrice);
|
||||||
|
noTaxTotalPrice = orderCount.multiply(totalPrice).setScale(4, 4);
|
||||||
|
BigDecimal taxPrice = totalPrice;
|
||||||
|
BigDecimal taxTotalPrice = noTaxTotalPrice;
|
||||||
|
BigDecimal taxAmount = BigDecimal.ZERO;
|
||||||
|
if (taxRate != null) {
|
||||||
|
BigDecimal rate = taxRate.getBigDecimal("taxrate");
|
||||||
|
taxPrice = totalPrice.multiply(BigDecimal.ONE.add(rate.divide(new BigDecimal("100")))).setScale(4, 4);
|
||||||
|
taxTotalPrice = noTaxTotalPrice.multiply(BigDecimal.ONE.add(rate.divide(new BigDecimal("100")))).setScale(4, 4);
|
||||||
|
taxAmount = noTaxTotalPrice.multiply(rate.divide(new BigDecimal(100))).setScale(4, 4);
|
||||||
|
}
|
||||||
|
|
||||||
|
//orderFormEntry.set("totalprice", totalPrice);
|
||||||
|
//orderFormEntry.set("notaxtotalprice", noTaxTotalPrice);
|
||||||
|
//orderFormEntry.set("taxprice", taxPrice);
|
||||||
|
orderFormEntry.set("taxamount", taxAmount);
|
||||||
|
//orderFormEntry.set("taxtotalprice", taxTotalPrice);
|
||||||
|
this.getView().updateView("orderformentry");
|
||||||
|
this.setTotalAmoTaxAndNotTax(orderformEntryColl);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private BigDecimal getContractOrderCount(DynamicObject orderForm, Object pkValue) {
|
||||||
|
DynamicObject insideNprContract = orderForm.getDynamicObject("insidenprcontract");
|
||||||
|
String entityName = orderForm.getDynamicObjectType().getName();
|
||||||
|
List<QFilter> qFilters = new ArrayList();
|
||||||
|
qFilters.add(new QFilter("insidenprcontract", "=", insideNprContract.getPkValue()));
|
||||||
|
qFilters.add(new QFilter("isfrom", "=", true));
|
||||||
|
qFilters.add(new QFilter("id", "!=", orderForm.getPkValue()));
|
||||||
|
if ("repe_orderform_change".equals(entityName)) {
|
||||||
|
DynamicObject relatedorderform = orderForm.getDynamicObject("relatedorderform");
|
||||||
|
if (relatedorderform != null) {
|
||||||
|
qFilters.add(new QFilter("id", "!=", relatedorderform.getPkValue()));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
DynamicObject[] orderForms = BusinessDataServiceHelper.load("repe_orderform", "material,ordercount", (QFilter[])qFilters.toArray(new QFilter[0]));
|
||||||
|
BigDecimal totalCount = new BigDecimal(0);
|
||||||
|
if (orderForms != null && orderForms.length > 0) {
|
||||||
|
DynamicObject[] var8 = orderForms;
|
||||||
|
int var9 = orderForms.length;
|
||||||
|
|
||||||
|
for(int var10 = 0; var10 < var9; ++var10) {
|
||||||
|
DynamicObject order = var8[var10];
|
||||||
|
DynamicObjectCollection entrys = order.getDynamicObjectCollection("orderformentry");
|
||||||
|
Map<Object, DynamicObject> map = (Map)entrys.stream().collect(Collectors.toMap((item) -> {
|
||||||
|
return item.getDynamicObject("material").getPkValue();
|
||||||
|
}, (item) -> {
|
||||||
|
return item;
|
||||||
|
}, (v1, v2) -> {
|
||||||
|
return v1;
|
||||||
|
}));
|
||||||
|
if (map.containsKey(pkValue)) {
|
||||||
|
BigDecimal ordercount = ((DynamicObject)map.get(pkValue)).getBigDecimal("ordercount");
|
||||||
|
totalCount = totalCount.add(ordercount);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return totalCount;
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue