package tqq9.lc123.cloud.app.plugin.form.im; import kd.bos.algo.DataSet; import kd.bos.bill.AbstractBillPlugIn; import kd.bos.dataentity.entity.DynamicObject; import kd.bos.dataentity.entity.DynamicObjectCollection; import kd.bos.dataentity.utils.StringUtils; import kd.bos.db.DB; import kd.bos.db.DBRoute; import kd.bos.entity.datamodel.IDataModel; import kd.bos.entity.datamodel.events.ChangeData; import kd.bos.entity.datamodel.events.PropertyChangedArgs; import kd.bos.form.FormShowParameter; import kd.bos.form.events.AfterDoOperationEventArgs; import kd.bos.form.field.BasedataEdit; import kd.bos.form.field.events.BeforeF7SelectEvent; import kd.bos.form.field.events.BeforeF7SelectListener; import kd.bos.list.ListShowParameter; import kd.bos.orm.ORM; import kd.bos.orm.query.QCP; import kd.bos.orm.query.QFilter; import kd.bos.servicehelper.BusinessDataServiceHelper; import java.math.BigDecimal; import java.util.Date; import java.util.EventObject; import java.util.HashMap; /** * 其他出库申请界面插件 */ public class OtherOutApplyBillPlugin extends AbstractBillPlugIn implements BeforeF7SelectListener { @Override public void registerListener(EventObject e) { super.registerListener(e); this.addItemClickListeners("tbmain"); BasedataEdit control = this.getControl("tqq9_lot"); control.addBeforeF7SelectListener(this); // this.addClickListeners("tqq9_xsddh"); } /** * 出库批号根据了做筛选 */ @Override public void beforeF7Select(BeforeF7SelectEvent beforeF7SelectEvent) { int index = this.getModel().getEntryCurrentRowIndex("entryentity"); DynamicObjectCollection entryentity = this.getModel().getDataEntity(true).getDynamicObjectCollection("entryentity"); DynamicObject dynamicObject = entryentity.get(index); DynamicObject tqq9_materiel = dynamicObject.getDynamicObject("tqq9_materiel"); if (tqq9_materiel == null) { beforeF7SelectEvent.setCancel(true); this.getView().showMessage("请先填物料信息"); } else { DynamicObject materiel = tqq9_materiel.getDynamicObject("masterid");//物料 Boolean enablelot = tqq9_materiel.getBoolean("enablelot");//是否启用批号管理 if (enablelot) { ListShowParameter param = (ListShowParameter) beforeF7SelectEvent.getFormShowParameter(); QFilter qF1 = new QFilter("material.number", QCP.equals, materiel.getString("number")); param.getListFilterParameter().getQFilters().add(qF1); } else { beforeF7SelectEvent.setCancel(true); this.getView().showMessage("该物料未启用批号管理"); } } } /** * 售后单号带出售后信息 */ @Override public void propertyChanged(PropertyChangedArgs e) { super.propertyChanged(e); String name = e.getProperty().getName(); IDataModel model = this.getModel(); if (StringUtils.equals("tqq9_returnapply", name)) { ChangeData[] changeSet = e.getChangeSet(); DynamicObject newValue = (DynamicObject) changeSet[0].getNewValue();//销售退货申请单 DynamicObject dynamicObject = BusinessDataServiceHelper.loadSingle("sm_returnapply", new QFilter[]{new QFilter("billno", QCP.equals, newValue.getString("billno"))}); DynamicObjectCollection billentry = dynamicObject.getDynamicObjectCollection("billentry"); if (billentry.size() > 0) { DynamicObject entry = billentry.get(0); String mainbillnumber = entry.getString("mainbillnumber");//核心单据编号 String tqq9_kddh = dynamicObject.getString("tqq9_kddh");//快递单号 DynamicObject tqq9_sskf = dynamicObject.getDynamicObject("tqq9_sskf");//所属客服 DynamicObject operator = dynamicObject.getDynamicObject("operator");//所属销售 DynamicObject customer = dynamicObject.getDynamicObject("customer");//订货客户 DynamicObject sm_salorder = BusinessDataServiceHelper.loadSingle("sm_salorder", new QFilter[]{new QFilter("billno", QCP.equals, mainbillnumber)}); model.setValue("tqq9_saleorderbill", sm_salorder);//对应销售订单号 model.setValue("tqq9_dpdh", tqq9_kddh);//DP单号 model.setValue("tqq9_sskf", tqq9_sskf);//所属客服 model.setValue("tqq9_ssxs", operator);//所属销售 model.setValue("tqq9_kufptt", customer);//客户发票抬头 } } //物料带出最近价格 if (StringUtils.equals("tqq9_materiel", name)) { ChangeData[] changeSet = e.getChangeSet(); DynamicObject newValue = (DynamicObject) changeSet[0].getNewValue();//物料库存信息 if(newValue != null){ DynamicObject masterid = newValue.getDynamicObject("masterid");//物料 if(masterid != null){ QFilter purinbillF = new QFilter("billentry.material.id", QCP.equals, newValue.getLong("id")); purinbillF = purinbillF.and("billstatus", QCP.equals, "C"); //price DynamicObject[] purinbills = BusinessDataServiceHelper.load("im_purinbill", "id,billno,billentry.material,billentry.price", purinbillF.toArray(), "auditdate desc"); if(purinbills != null && purinbills.length > 0){ DynamicObject purinbill = purinbills[0]; DynamicObjectCollection billentry = purinbill.getDynamicObjectCollection("billentry"); for (DynamicObject dynamicObject : billentry) { String number = dynamicObject.getString("material.masterid.number"); if (StringUtils.equals(number, masterid.getString("number"))) { BigDecimal price = dynamicObject.getBigDecimal("price"); this.getModel().setValue("tqq9_price", price); } break; } } } } } //批号带出批次可用量 if (StringUtils.equals("tqq9_lot", name)) { ChangeData changeData = e.getChangeSet()[0]; int rowIndex = changeData.getRowIndex(); DynamicObject material = (DynamicObject)model.getValue("tqq9_materiel", rowIndex);//物料库存信息 DynamicObject tqq9_lot = (DynamicObject)model.getValue("tqq9_lot", rowIndex);//批号 if(material!=null){ DynamicObject masterid = material.getDynamicObject("masterid");//物料 if(masterid!=null&&tqq9_lot!=null){ String id = masterid.getString("id"); String tqq9_phno = tqq9_lot.getString("number");//批号 String sql = "/*dialect*/ select sum(fbaseqty) useqty from t_im_inv_realbalance where fmaterialid ='"+id+"' and flotnum ='"+tqq9_phno+"'" ; DataSet pzDataSet = DB.queryDataSet(this.getClass().getName(), DBRoute.of("scm"), sql); DataSet copy = pzDataSet.copy(); DynamicObjectCollection dynamicObjects = ORM.create().toPlainDynamicObjectCollection(copy); if(dynamicObjects.size()>0){ BigDecimal useqty = dynamicObjects.get(0).getBigDecimal("useqty"); model.setValue("tqq9_pckyamount",useqty,rowIndex); this.getView().updateView(); } } } } } /** * 点击退出回传其他出库单编号 * * @param afterDoOperationEventArgs */ @Override public void afterDoOperation(AfterDoOperationEventArgs afterDoOperationEventArgs) { super.afterDoOperation(afterDoOperationEventArgs); String itemKey = afterDoOperationEventArgs.getOperateKey(); if (StringUtils.equals("donothing", itemKey)) { Object billno = this.getModel().getValue("billno"); HashMap map = new HashMap<>(); map.put("billno", billno); this.getView().returnDataToParent(map); this.getView().close(); } } /** * 采购退货未异地退货保存跳转到其他出库申请 */ @Override public void afterCreateNewData(EventObject e) { super.afterCreateNewData(e); FormShowParameter formShowParameter = this.getView().getFormShowParameter(); String billno = formShowParameter.getCustomParam("tqq9_otheroutapplybillno"); if (StringUtils.isNotBlank(billno)) { DynamicObject pm_purrefundapplybill = BusinessDataServiceHelper.loadSingle("pm_purrefundapplybill", new QFilter[]{new QFilter("billno", QCP.equals, billno)}); DynamicObject org = pm_purrefundapplybill.getDynamicObject("org");//采购组织 DynamicObjectCollection billentry = pm_purrefundapplybill.getDynamicObjectCollection("billentry");//采购退货分录 DynamicObject dataEntity = this.getModel().getDataEntity(true); //业务类型 DynamicObject bd_biztype = BusinessDataServiceHelper.loadSingle("bd_biztype", new QFilter[]{new QFilter("number", QCP.equals, "612")}); dataEntity.set("tqq9_biztype", bd_biztype); //库存事务 DynamicObject im_invscheme = BusinessDataServiceHelper.loadSingle("im_invscheme", new QFilter[]{new QFilter("number", QCP.equals, "612.1")}); dataEntity.set("tqq9_kcsw", im_invscheme); //业务日期 Date date = new Date(); dataEntity.set("tqq9_bizdate", date); dataEntity.set("tqq9_dblx", "A");//调拨类型 dataEntity.set("tqq9_dbckfl", "G");//调拨出库分类 dataEntity.set("org", org);//组织 dataEntity.set("tqq9_dczz1", org);//调出组织 dataEntity.set("tqq9_drck2", org);//调入组织 DynamicObjectCollection entryentity = dataEntity.getDynamicObjectCollection("entryentity"); entryentity.clear(); //库存类型-普通 DynamicObject bd_invtype = BusinessDataServiceHelper.loadSingle("bd_invtype", new QFilter[]{new QFilter("number", QCP.equals, "110")}); //库存类型-普通 DynamicObject bd_invstatus = BusinessDataServiceHelper.loadSingle("bd_invstatus", new QFilter[]{new QFilter("number", QCP.equals, "110")}); //出库货主类型 String tqq9_outownertype = "bos_org"; //出库保管者类型 String tqq9_outkeepertype = "bos_org"; for (DynamicObject entry : billentry) { DynamicObject dynamicObject = entryentity.addNew(); dynamicObject.set("tqq9_linetype", entry.getDynamicObject("linetype"));//行类型 DynamicObject material = entry.getDynamicObject("material");//物料采购信息 if (material != null) { DynamicObject masterid = material.getDynamicObject("masterid");//物料信息 //物料库存信息 DynamicObject bd_materialinventoryinfo = BusinessDataServiceHelper.loadSingle("bd_materialinventoryinfo", new QFilter[]{new QFilter("masterid", QCP.equals, masterid.getLong("id"))}); //商城商品 DynamicObject tqq9_goodspackage = BusinessDataServiceHelper.loadSingle("tqq9_goodspackage", new QFilter[]{new QFilter("tqq9_mater.id", QCP.equals, masterid.getLong("id"))}); dynamicObject.set("tqq9_materiel", bd_materialinventoryinfo);//物料库存信息 dynamicObject.set("tqq9_goods", tqq9_goodspackage);//商城商品 dynamicObject.set("tqq9_materialname", masterid.getString("name"));//物料名称 dynamicObject.set("tqq9_unit", masterid.getDynamicObject("baseunit"));//计量单位 dynamicObject.set("tqq9_baseunit", masterid.getDynamicObject("baseunit"));//基本单位 } dynamicObject.set("tqq9_dczz", org);//调出组织 dynamicObject.set("tqq9_drzz", org);//调入组织 dynamicObject.set("tqq9_zczh", entry.getDynamicObject("tqq9_registration"));//注册证号 dynamicObject.set("tqq9_licenseno", entry.getString("tqq9_licenseno"));//许可证号 dynamicObject.set("tqq9_producedate", entry.getDate("tqq9_createdate"));//生产日期 dynamicObject.set("tqq9_expirydate", entry.getDate("tqq9_deadline"));//到期日期 dynamicObject.set("tqq9_drck", entry.getDynamicObject("tqq9_thck"));//退货仓库 dataEntity.set("tqq9_basedatafield1", entry.getDynamicObject("tqq9_thck"));//退货仓库 dynamicObject.set("tqq9_lot", entry.getDynamicObject("tqq9_ph"));//批号 dynamicObject.set("tqq9_qty", entry.getBigDecimal("qty"));//数量 dynamicObject.set("tqq9_baseqty", entry.getBigDecimal("qty"));//数量 dynamicObject.set("tqq9_price", entry.getBigDecimal("price"));//单价 dynamicObject.set("tqq9_amount", entry.getBigDecimal("amount"));//金额 dynamicObject.set("tqq9_outinvtype", bd_invtype);//出库库存类型 dynamicObject.set("tqq9_outinvstatus", bd_invstatus);//出库库存状态 dynamicObject.set("tqq9_outownertype", tqq9_outownertype);//出库货主类型 dynamicObject.set("tqq9_outkeepertype", tqq9_outkeepertype);//出库保管者类型 dynamicObject.set("tqq9_outowner", org);//出库货主 dynamicObject.set("tqq9_outkeeper", org);//出库保管者 } this.getView().setVisible(true, "tqq9_confirm"); this.getView().setVisible(false, "bar_close"); } } }