lc/lc123/cloud/app/plugin/form/im/OtherOutApplyBillPlugin.java

261 lines
15 KiB
Java
Raw Normal View History

package tqq9.lc123.cloud.app.plugin.form.im;
import com.alibaba.nacos.common.utils.StringUtils;
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.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.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.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);
}
/**
* 物料根据所选仓库,组织是否有库存筛选
*/
2025-11-24 03:46:18 +00:00
@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<Long> 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)||StringUtils.equals("tqq9_dcck", name)||StringUtils.equals("tqq9_materiel", name)) {
ChangeData[] changeSet = e.getChangeSet();
int rowIndex = changeSet[0].getRowIndex();
Object tqq9_materiel = model.getValue("tqq9_materiel");
DynamicObject materiel = (tqq9_materiel != null) ? (DynamicObject) tqq9_materiel : null;//物料
Object tqq9_dcck = model.getValue("tqq9_dcck");
DynamicObject dcck = (tqq9_dcck != null) ? (DynamicObject) tqq9_dcck : null;//仓库
Object tqq9_lotnumber = model.getValue("tqq9_lotnumber");
String lotNumber = (tqq9_lotnumber != null) ? (String) tqq9_lotnumber : null;//批号
//物料仓库均不为空
if (materiel != null && dcck != null && StringUtils.isNotBlank(lotNumber)) {
QFilter materielF = new QFilter("material", QCP.equals, materiel.getDynamicObject("masterid").getLong("id"));
QFilter warehouseF = new QFilter("warehouse", QCP.equals, dcck.getLong("id"));
QFilter lotNumberF= new QFilter("lotnum", QCP.equals, lotNumber);
DynamicObject[] objects = BusinessDataServiceHelper.load("im_inv_realbalance",
"id,keycol,material,lotnum,producedate,expirydate,tqq9_goods,tqq9_registration"
, new QFilter[]{materielF.and(warehouseF).and(lotNumberF)});
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");//注册证
DynamicObject tqq9_goods = object.getDynamicObject("tqq9_goods");//商品
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_goods", tqq9_goods, 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);
}else{
this.getModel().setValue("tqq9_producedate", null, rowIndex);
this.getModel().setValue("tqq9_goods", null, rowIndex);
this.getModel().setValue("tqq9_expirydate", null, rowIndex);
this.getModel().setValue("tqq9_cs", null, rowIndex);
this.getModel().setValue("tqq9_licenseno", null, rowIndex);
this.getModel().setValue("tqq9_zczh", null, rowIndex);
}
}
String sql="/*dialect*/SELECT \n" +
" t1.fmaterialid, \n" +
" t1.fwarehouseid,\n" +
" t1.flotnum,\n" +
" SUM(t1.fqty) - COALESCE(SUM(t2.f_qty), 0) AS qty_difference\n" +
"FROM \n" +
" (SELECT fmaterialid, fwarehouseid, flotnum, SUM(fqty) AS fqty\n" +
" FROM t_im_inv_realbalance\n" +
" GROUP BY fmaterialid, fwarehouseid, flotnum) t1\n" +
"LEFT JOIN \n" +
" (SELECT f_s_materiel, f_s_warehouse, f_s_lotnum, SUM(f_qty) AS f_qty\n" +
" FROM t_msmod_reserverecord\n" +
" GROUP BY f_s_materiel, f_s_warehouse, f_s_lotnum) t2\n" +
"ON t1.fmaterialid = t2.f_s_materiel \n" +
" AND t1.fwarehouseid = t2.f_s_warehouse\n" +
" AND t1.flotnum = t2.f_s_lotnum\n" +
" WHERE \n" +
" t1.fmaterialid = "+materiel.getDynamicObject("masterid").getString("id")+"\n" +
" AND t1.fwarehouseid = "+dcck.getString("id")+" \n" +
" AND t1.flotnum = '"+lotNumber+"' \n" +
"GROUP BY t1.fmaterialid, t1.fwarehouseid, t1.flotnum;\n";
DataSet materialDataSet = DB.queryDataSet(this.getClass().getName(), DBRoute.of("scm"), sql);
DataSet copy1 = materialDataSet.copy();
DynamicObjectCollection dynamicObjects = ORM.create().toPlainDynamicObjectCollection(copy1);
if (dynamicObjects.size()>0) {
BigDecimal total_qty = dynamicObjects.get(0).getBigDecimal("qty_difference");
this.getModel().setValue("tqq9_pckyamount", total_qty, rowIndex);
}
}else if(materiel != null && dcck != null && StringUtils.isBlank(lotNumber)){
String sql="/*dialect*/SELECT \n" +
" t1.fmaterialid, \n" +
" t1.fwarehouseid,\n" +
" SUM(t1.fqty) - COALESCE(SUM(t2.f_qty), 0) AS qty_difference\n" +
"FROM \n" +
" (SELECT fmaterialid, fwarehouseid, SUM(fqty) AS fqty\n" +
" FROM t_im_inv_realbalance\n" +
" GROUP BY fmaterialid, fwarehouseid) t1\n" +
"LEFT JOIN \n" +
" (SELECT f_s_materiel, f_s_warehouse, SUM(f_qty) AS f_qty\n" +
" FROM t_msmod_reserverecord\n" +
" GROUP BY f_s_materiel, f_s_warehouse) t2\n" +
"ON t1.fmaterialid = t2.f_s_materiel \n" +
" AND t1.fwarehouseid = t2.f_s_warehouse\n" +
" WHERE \n" +
" t1.fmaterialid = "+materiel.getDynamicObject("masterid").getString("id")+"\n" +
" AND t1.fwarehouseid = "+dcck.getString("id")+" \n" +
"GROUP BY t1.fmaterialid, t1.fwarehouseid;\n";
DataSet materialDataSet = DB.queryDataSet(this.getClass().getName(), DBRoute.of("scm"), sql);
DataSet copy1 = materialDataSet.copy();
DynamicObjectCollection dynamicObjects = ORM.create().toPlainDynamicObjectCollection(copy1);
if (dynamicObjects.size()>0) {
BigDecimal total_qty = dynamicObjects.get(0).getBigDecimal("qty_difference");
this.getModel().setValue("tqq9_pckyamount", total_qty, rowIndex);
}
}
}
}
}