183 lines
10 KiB
Java
183 lines
10 KiB
Java
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<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)) {
|
|
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);
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
} |