出库单添加使用设备赋值逻辑
This commit is contained in:
parent
6385e97a73
commit
b05a23820f
|
@ -11,6 +11,7 @@ import java.util.HashMap;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
import kd.bos.bill.AbstractBillPlugIn;
|
import kd.bos.bill.AbstractBillPlugIn;
|
||||||
import kd.bos.bill.OperationStatus;
|
import kd.bos.bill.OperationStatus;
|
||||||
import kd.bos.dataentity.entity.DynamicObject;
|
import kd.bos.dataentity.entity.DynamicObject;
|
||||||
|
@ -33,7 +34,7 @@ import kd.bos.servicehelper.BusinessDataServiceHelper;
|
||||||
import kd.ec.basedata.common.utils.OpenPageUtils;
|
import kd.ec.basedata.common.utils.OpenPageUtils;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 出库单:领料出库与领料申请关联逻辑
|
* 出库单:领料出库与领料申请关联逻辑和使用设备赋值逻辑
|
||||||
*/
|
*/
|
||||||
public class MaterialOutApplyPluginExt extends AbstractBillPlugIn implements BeforeF7SelectListener {
|
public class MaterialOutApplyPluginExt extends AbstractBillPlugIn implements BeforeF7SelectListener {
|
||||||
private static final String APPLYBILL = "applybill";
|
private static final String APPLYBILL = "applybill";
|
||||||
|
@ -45,7 +46,7 @@ public class MaterialOutApplyPluginExt extends AbstractBillPlugIn implements Bef
|
||||||
|
|
||||||
public void registerListener(EventObject e) {
|
public void registerListener(EventObject e) {
|
||||||
super.registerListener(e);
|
super.registerListener(e);
|
||||||
BasedataEdit basedataEdit = (BasedataEdit)this.getControl("applybill");
|
BasedataEdit basedataEdit = (BasedataEdit) this.getControl("applybill");
|
||||||
basedataEdit.addBeforeF7SelectListener(this);
|
basedataEdit.addBeforeF7SelectListener(this);
|
||||||
basedataEdit.addBeforeF7ViewDetailListener((beforeF7ViewDetailEvent) -> {
|
basedataEdit.addBeforeF7ViewDetailListener((beforeF7ViewDetailEvent) -> {
|
||||||
beforeF7ViewDetailEvent.setCancel(true);
|
beforeF7ViewDetailEvent.setCancel(true);
|
||||||
|
@ -63,9 +64,9 @@ public class MaterialOutApplyPluginExt extends AbstractBillPlugIn implements Bef
|
||||||
|
|
||||||
public void beforeDoOperation(BeforeDoOperationEventArgs args) {
|
public void beforeDoOperation(BeforeDoOperationEventArgs args) {
|
||||||
super.beforeDoOperation(args);
|
super.beforeDoOperation(args);
|
||||||
FormOperate operate = (FormOperate)args.getSource();
|
FormOperate operate = (FormOperate) args.getSource();
|
||||||
String operateKey = operate.getOperateKey();
|
String operateKey = operate.getOperateKey();
|
||||||
DynamicObject applyBill = (DynamicObject)this.getModel().getValue("applybill");
|
DynamicObject applyBill = (DynamicObject) this.getModel().getValue("applybill");
|
||||||
if (StringUtils.equals("addnewentry", operateKey)) {
|
if (StringUtils.equals("addnewentry", operateKey)) {
|
||||||
if (applyBill != null) {
|
if (applyBill != null) {
|
||||||
this.openApplyEntryForm();
|
this.openApplyEntryForm();
|
||||||
|
@ -77,8 +78,8 @@ public class MaterialOutApplyPluginExt extends AbstractBillPlugIn implements Bef
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void beforeApplyBillSelect(BeforeF7SelectEvent arg0) {
|
protected void beforeApplyBillSelect(BeforeF7SelectEvent arg0) {
|
||||||
DynamicObject project = (DynamicObject)this.getModel().getValue("project");
|
DynamicObject project = (DynamicObject) this.getModel().getValue("project");
|
||||||
DynamicObject warehouse = (DynamicObject)this.getModel().getValue("warehouse");
|
DynamicObject warehouse = (DynamicObject) this.getModel().getValue("warehouse");
|
||||||
if (warehouse == null) {
|
if (warehouse == null) {
|
||||||
this.getView().showTipNotification(ResManager.loadKDString("请先选中仓库。", "MaterialOutApplyPlugin_1", "ec-ecma-formplugin", new Object[0]), 3000);
|
this.getView().showTipNotification(ResManager.loadKDString("请先选中仓库。", "MaterialOutApplyPlugin_1", "ec-ecma-formplugin", new Object[0]), 3000);
|
||||||
arg0.setCancel(true);
|
arg0.setCancel(true);
|
||||||
|
@ -103,12 +104,24 @@ public class MaterialOutApplyPluginExt extends AbstractBillPlugIn implements Bef
|
||||||
ChangeData changeData = e.getChangeSet()[0];
|
ChangeData changeData = e.getChangeSet()[0];
|
||||||
if (StringUtils.equals(name, "applybill")) {
|
if (StringUtils.equals(name, "applybill")) {
|
||||||
this.applyBillChanged(changeData);
|
this.applyBillChanged(changeData);
|
||||||
|
} else if (StringUtils.equals(name, "material")) {
|
||||||
|
//资源编码
|
||||||
|
DynamicObject material = (DynamicObject) changeData.getNewValue();
|
||||||
|
int rowIndex = changeData.getRowIndex(); //修改行所在行行号
|
||||||
|
DynamicObject applybill = (DynamicObject) this.getModel().getValue("applybill");//领料申请单
|
||||||
|
if (material != null && rowIndex > 0 && applybill == null) {
|
||||||
|
DynamicObjectCollection entryEntityCollection = this.getModel().getDataEntity(true).getDynamicObjectCollection("entryentity");//出库单明细
|
||||||
|
DynamicObject entryEntity = entryEntityCollection.get(0);
|
||||||
|
DynamicObject zcgj_shebei = entryEntity.getDynamicObject("zcgj_shebei");//使用设备
|
||||||
|
if (zcgj_shebei != null) {
|
||||||
|
this.getModel().setValue("zcgj_shebei", zcgj_shebei, rowIndex);//使用设备
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void applyBillChanged(ChangeData changeData) {
|
protected void applyBillChanged(ChangeData changeData) {
|
||||||
DynamicObject newValue = (DynamicObject)changeData.getNewValue();
|
DynamicObject newValue = (DynamicObject) changeData.getNewValue();
|
||||||
if (newValue != null) {
|
if (newValue != null) {
|
||||||
newValue = BusinessDataServiceHelper.loadSingle(newValue.getPkValue(), "ecma_materialapplybill");
|
newValue = BusinessDataServiceHelper.loadSingle(newValue.getPkValue(), "ecma_materialapplybill");
|
||||||
this.carryHeadData(newValue);
|
this.carryHeadData(newValue);
|
||||||
|
@ -128,8 +141,8 @@ public class MaterialOutApplyPluginExt extends AbstractBillPlugIn implements Bef
|
||||||
if (applyEntries != null && !applyEntries.isEmpty()) {
|
if (applyEntries != null && !applyEntries.isEmpty()) {
|
||||||
Iterator var4 = applyEntries.iterator();
|
Iterator var4 = applyEntries.iterator();
|
||||||
|
|
||||||
while(var4.hasNext()) {
|
while (var4.hasNext()) {
|
||||||
DynamicObject applyEntry = (DynamicObject)var4.next();
|
DynamicObject applyEntry = (DynamicObject) var4.next();
|
||||||
BigDecimal restQty = applyEntry.getBigDecimal("restqty");
|
BigDecimal restQty = applyEntry.getBigDecimal("restqty");
|
||||||
if (restQty.compareTo(BigDecimal.ZERO) != 0) {
|
if (restQty.compareTo(BigDecimal.ZERO) != 0) {
|
||||||
DynamicObject newEntry = new DynamicObject(entries.getDynamicObjectType());
|
DynamicObject newEntry = new DynamicObject(entries.getDynamicObjectType());
|
||||||
|
@ -168,8 +181,8 @@ public class MaterialOutApplyPluginExt extends AbstractBillPlugIn implements Bef
|
||||||
if (applyEntries != null && !applyEntries.isEmpty()) {
|
if (applyEntries != null && !applyEntries.isEmpty()) {
|
||||||
Iterator var5 = applyEntries.iterator();
|
Iterator var5 = applyEntries.iterator();
|
||||||
|
|
||||||
while(var5.hasNext()) {
|
while (var5.hasNext()) {
|
||||||
DynamicObject applyEntry = (DynamicObject)var5.next();
|
DynamicObject applyEntry = (DynamicObject) var5.next();
|
||||||
if (applyEntryIdList.contains(applyEntry.getPkValue())) {
|
if (applyEntryIdList.contains(applyEntry.getPkValue())) {
|
||||||
DynamicObject newEntry = new DynamicObject(entries.getDynamicObjectType());
|
DynamicObject newEntry = new DynamicObject(entries.getDynamicObjectType());
|
||||||
newEntry.set("applyentryid", applyEntry.getLong("id"));
|
newEntry.set("applyentryid", applyEntry.getLong("id"));
|
||||||
|
@ -259,13 +272,13 @@ public class MaterialOutApplyPluginExt extends AbstractBillPlugIn implements Bef
|
||||||
}
|
}
|
||||||
|
|
||||||
private void openApplyEntryForm() {
|
private void openApplyEntryForm() {
|
||||||
DynamicObject applyBill = (DynamicObject)this.getModel().getValue("applybill");//领料申请单
|
DynamicObject applyBill = (DynamicObject) this.getModel().getValue("applybill");//领料申请单
|
||||||
DynamicObjectCollection entries = this.getModel().getEntryEntity("entryentity");
|
DynamicObjectCollection entries = this.getModel().getEntryEntity("entryentity");
|
||||||
StringBuffer selectedEntryIdBuff = new StringBuffer();
|
StringBuffer selectedEntryIdBuff = new StringBuffer();
|
||||||
Iterator var4 = entries.iterator();
|
Iterator var4 = entries.iterator();
|
||||||
|
|
||||||
while(var4.hasNext()) {
|
while (var4.hasNext()) {
|
||||||
DynamicObject entry = (DynamicObject)var4.next();
|
DynamicObject entry = (DynamicObject) var4.next();
|
||||||
selectedEntryIdBuff.append(entry.get("applyentryid")).append(",");
|
selectedEntryIdBuff.append(entry.get("applyentryid")).append(",");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -284,10 +297,10 @@ public class MaterialOutApplyPluginExt extends AbstractBillPlugIn implements Bef
|
||||||
public void closedCallBack(ClosedCallBackEvent closedCallBackEvent) {
|
public void closedCallBack(ClosedCallBackEvent closedCallBackEvent) {
|
||||||
String actionID = closedCallBackEvent.getActionId();
|
String actionID = closedCallBackEvent.getActionId();
|
||||||
Object returnData = closedCallBackEvent.getReturnData();
|
Object returnData = closedCallBackEvent.getReturnData();
|
||||||
DynamicObject applyBill = (DynamicObject)this.getModel().getValue("applybill");
|
DynamicObject applyBill = (DynamicObject) this.getModel().getValue("applybill");
|
||||||
if (StringUtils.equals(actionID, "applyEntryCallback") && returnData != null) {
|
if (StringUtils.equals(actionID, "applyEntryCallback") && returnData != null) {
|
||||||
Map<String, Object> data = (Map)returnData;
|
Map<String, Object> data = (Map) returnData;
|
||||||
List<Long> applyEntryIdList = (List)data.get("applyEntryIdList");
|
List<Long> applyEntryIdList = (List) data.get("applyEntryIdList");
|
||||||
if (applyBill != null) {
|
if (applyBill != null) {
|
||||||
DynamicObject applyBillData = BusinessDataServiceHelper.loadSingle(applyBill.getPkValue(), "ecma_materialapplybill");
|
DynamicObject applyBillData = BusinessDataServiceHelper.loadSingle(applyBill.getPkValue(), "ecma_materialapplybill");
|
||||||
this.carryEntryDataFromReturnData(applyBillData, applyEntryIdList);
|
this.carryEntryDataFromReturnData(applyBillData, applyEntryIdList);
|
||||||
|
|
Loading…
Reference in New Issue