package tqq9.lc123.cloud.app.plugin.form.im; import com.alibaba.nacos.common.utils.StringUtils; import kd.bos.bill.AbstractBillPlugIn; import kd.bos.dataentity.entity.DynamicObject; import kd.bos.dataentity.entity.DynamicObjectCollection; import kd.bos.entity.datamodel.IDataModel; import kd.bos.entity.datamodel.events.ChangeData; import kd.bos.entity.datamodel.events.PropertyChangedArgs; 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.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.HashSet; /** * 其他出库申请界面插件 */ public class OtherOutApplyBillPlugin extends AbstractBillPlugIn implements BeforeF7SelectListener { @Override public void registerListener(EventObject e) { super.registerListener(e); this.addItemClickListeners("tbmain"); BasedataEdit tqq9_materiel = this.getView().getControl("tqq9_materiel"); tqq9_materiel.addBeforeF7SelectListener(this); } /** * 物料根据所选仓库,组织,是否有库存筛选 */ @Override public void beforeF7Select(BeforeF7SelectEvent beforeF7SelectEvent) { String name = beforeF7SelectEvent.getProperty().getName(); if (StringUtils.equals("tqq9_materiel", name)) { IDataModel model = this.getModel(); int index = model.getEntryCurrentRowIndex("entryentity"); DynamicObjectCollection entryentity = model.getDataEntity(true).getDynamicObjectCollection("entryentity"); DynamicObject dynamicObject = entryentity.get(index); DynamicObject tqq9_dcck = dynamicObject.getDynamicObject("tqq9_dcck"); if (tqq9_dcck != null) { DynamicObject dataEntity = model.getDataEntity(); DynamicObject org = dataEntity.getDynamicObject("org"); QFilter qFilter = new QFilter("org.number", QCP.equals, org.getString("number")); qFilter.and("warehouse.number", QCP.equals, tqq9_dcck.getString("number")); qFilter.and("qty", QCP.not_equals2, 0); DynamicObject[] t_im_inv_realbalances = BusinessDataServiceHelper.load("im_inv_realbalance", "id,warehouse,org,material", qFilter.toArray()); HashSet ids = new HashSet<>(); for (DynamicObject t_im_inv_realbalance : t_im_inv_realbalances) { DynamicObject material = t_im_inv_realbalance.getDynamicObject("material"); if (material != null) { ids.add(material.getLong("id")); } } ListShowParameter param = (ListShowParameter) beforeF7SelectEvent.getFormShowParameter(); QFilter qF1 = new QFilter("masterid", QCP.in, ids); param.getListFilterParameter().getQFilters().add(qF1); } } } /** * 售后单号带出售后信息 */ @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_lotnumber", name)) { ChangeData[] changeSet = e.getChangeSet(); int rowIndex = changeSet[0].getRowIndex(); String lotNumber = (String) changeSet[0].getNewValue(); DynamicObject tqq9_materiel = (DynamicObject) this.getModel().getValue("tqq9_materiel"); if (StringUtils.isNotBlank(lotNumber) && null != tqq9_materiel) { DynamicObject[] objects = BusinessDataServiceHelper.load("im_inv_realbalance", "id,keycol,material,lotnum,producedate,expirydate,tqq9_goods,tqq9_registration" , new QFilter[]{new QFilter("lotnum", QCP.equals, lotNumber), new QFilter("material", QCP.equals, tqq9_materiel.getDynamicObject("masterid").getLong("id"))}); if (null != objects && objects.length > 0) { if (objects.length == 1) { DynamicObject object = objects[0]; Date producedate = object.getDate("producedate"); Date expirydate = object.getDate("expirydate"); DynamicObject tqq9_registration = object.getDynamicObject("tqq9_registration"); StringBuilder tqq9_cs = new StringBuilder(); StringBuilder tqq9_licenseno = new StringBuilder(); if (null != tqq9_registration) { tqq9_registration = BusinessDataServiceHelper.loadSingle("tqq9_registration", "id,number,tqq9_entry.tqq9_e_supplier,tqq9_entry.tqq9_e_supno,tqq9_proxy,tqq9_proxyno" , new QFilter[]{new QFilter("id", QCP.equals, tqq9_registration.getLong("id"))}); DynamicObjectCollection tqq9_entry = tqq9_registration.getDynamicObjectCollection("tqq9_entry"); for (int i = 0; i < tqq9_entry.size(); i++) { DynamicObject dynamicObject = tqq9_entry.get(i); DynamicObject tqq9_e_supplier = dynamicObject.getDynamicObject("tqq9_e_supplier"); if (null != tqq9_e_supplier) { tqq9_cs.append(tqq9_e_supplier.getString("name")); if (i != tqq9_entry.size() - 1) { tqq9_cs.append("#"); } } String tqq9_e_supno = dynamicObject.getString("tqq9_e_supno"); if (StringUtils.isNotBlank(tqq9_e_supno)) { tqq9_licenseno.append(tqq9_e_supno); if (i != tqq9_entry.size() - 1) { tqq9_licenseno.append("#"); } } } } this.getModel().setValue("tqq9_producedate", producedate, rowIndex); this.getModel().setValue("tqq9_expirydate", expirydate, rowIndex); this.getModel().setValue("tqq9_cs", tqq9_cs.toString(), rowIndex); this.getModel().setValue("tqq9_licenseno", tqq9_licenseno.toString(), rowIndex); this.getModel().setValue("tqq9_zczh", tqq9_registration, rowIndex); } } } } } }