199 lines
14 KiB
Java
199 lines
14 KiB
Java
package tqq9.lc123.cloud.app.plugin.operate.im;
|
|
|
|
import kd.bos.dataentity.entity.DynamicObject;
|
|
import kd.bos.dataentity.entity.DynamicObjectCollection;
|
|
import kd.bos.entity.ExtendedDataEntity;
|
|
import kd.bos.entity.ExtendedDataEntitySet;
|
|
import kd.bos.entity.botp.plugin.AbstractConvertPlugIn;
|
|
import kd.bos.entity.botp.plugin.args.AfterConvertEventArgs;
|
|
import kd.bos.logging.Log;
|
|
import kd.bos.logging.LogFactory;
|
|
import kd.bos.orm.query.QCP;
|
|
import kd.bos.orm.query.QFilter;
|
|
import kd.bos.servicehelper.BusinessDataServiceHelper;
|
|
import kd.sdk.plugin.Plugin;
|
|
|
|
import java.math.BigDecimal;
|
|
import java.util.Date;
|
|
|
|
/**
|
|
* 单据转换插件
|
|
*/
|
|
public class PurOrderPushPurRefundConverPlugin extends AbstractConvertPlugIn implements Plugin {
|
|
private final static Log logger = LogFactory.getLog(PurOrderPushPurRefundConverPlugin.class);
|
|
private static String PM_PURREFUNDAPPLYBILL = "pm_purrefundapplybill";
|
|
|
|
|
|
/**
|
|
* 采购订单下推采购退货申请
|
|
*/
|
|
@Override
|
|
public void afterConvert(AfterConvertEventArgs e) {
|
|
super.afterConvert(e);
|
|
ExtendedDataEntitySet targetExtDataEntitySet = e.getTargetExtDataEntitySet();
|
|
ExtendedDataEntity[] extendedDataEntities = targetExtDataEntitySet.FindByEntityKey(PM_PURREFUNDAPPLYBILL);
|
|
for (ExtendedDataEntity extendedDataEntity : extendedDataEntities) {
|
|
//采购退货申请
|
|
DynamicObject dataEntity = extendedDataEntity.getDataEntity();
|
|
DynamicObjectCollection dynamicObjectCollection = dataEntity.getDynamicObjectCollection("billentry");
|
|
DynamicObject[] im_purinblil = null;
|
|
for (DynamicObject entry : dynamicObjectCollection) {
|
|
String mainbillnumber = entry.getString("mainbillnumber");
|
|
//采购订单
|
|
im_purinblil = BusinessDataServiceHelper.load("im_purinbill", "id,name,billentry.material,billentry.entryreqorg," +
|
|
"billentry.taxrateid,billentry.discounttype,billentry.mainbillentity,billentry.mainbillid,billentry.mainbillnumber,billentry.mainbillentryid," +
|
|
"billentry.mainbillentryseq,billentry.entrycreator,billentry.entrycreatetime,billentry.entrymodifier," +
|
|
"billentry.entrymodifytime,billentry.linetype,billentry.tqq9_registration,billentry.tqq9_licenseno," +
|
|
"billentry.tqq9_brand,billentry.warehouse,billentry.qty,billentry.ispresent," +
|
|
"billentry.ownertype,billentry.mversion,billentry.unit2nd,billentry.qtyunit2nd," +
|
|
"billentry.auxpty,billentry.discountrate,billentry.price,billentry.priceandtax," +
|
|
"billentry.amount,billentry.curamount,billentry.taxamount,billentry.curtaxamount," +
|
|
"billentry.discountamount,billentry.amountandtax,billentry.curamountandtax,billentry.returnqty," +
|
|
"billentry.returnbaseqty,billentry.tqq9_yyhyflje,billentry.tqq9_yyhwflje,billentry.lotnumber," +
|
|
"billentry.tqq9_goods,billentry.tqq9_wmsdetailid,billentry.producedate,billentry.expirydate,creator,createtime,modifier,modifytime,billentry.owner", new QFilter[]{new QFilter("billentry.mainbillnumber", QCP.equals, mainbillnumber).and("billstatus",QCP.equals,"C")});
|
|
|
|
|
|
}
|
|
BigDecimal zero = BigDecimal.ZERO;
|
|
dynamicObjectCollection.clear();
|
|
if(im_purinblil!=null){
|
|
for (DynamicObject dynamicObject : im_purinblil) {
|
|
DynamicObjectCollection billentry = dynamicObject.getDynamicObjectCollection("billentry");
|
|
String billid = dynamicObject.getString("id");
|
|
for (DynamicObject object : billentry) {
|
|
String billentryid = object.getString("id");
|
|
DynamicObject material = object.getDynamicObject("material");//物料库存信息
|
|
DynamicObject masterid = material.getDynamicObject("masterid");//物料信息
|
|
//物料采购信息
|
|
DynamicObject bd_materialpurchaseinfo = BusinessDataServiceHelper.loadSingle("bd_materialpurchaseinfo", new QFilter[]{new QFilter("masterid", QCP.equals, masterid.getLong("id"))});
|
|
masterid = BusinessDataServiceHelper.loadSingle("bd_material", new QFilter[]{new QFilter("id", QCP.equals, masterid.getLong("id"))});
|
|
String materialname = bd_materialpurchaseinfo.getString("masterid.name");//物料名称
|
|
DynamicObject baseunit = masterid.getDynamicObject("baseunit");//计量单位
|
|
DynamicObject entryreqorg = object.getDynamicObject("entryreqorg");//需求组织
|
|
DynamicObject taxrateid = object.getDynamicObject("taxrateid");//税率
|
|
String discounttype = object.getString("discounttype");//折扣方式
|
|
String mainbillentity = object.getString("mainbillentity");//核心单据实体
|
|
String mainbillid = object.getString("mainbillid");//核心单据ID
|
|
String mainbillnumber = object.getString("mainbillnumber");//核心单据编号
|
|
String mainbillentryid = object.getString("mainbillentryid");//核心单据行ID
|
|
String mainbillentryseq = object.getString("mainbillentryseq");//核心单据分录序号
|
|
DynamicObject creator = dynamicObject.getDynamicObject("creator");//创建人
|
|
Date createtime = dynamicObject.getDate("createtime");//创建时间
|
|
DynamicObject modifier = dynamicObject.getDynamicObject("modifier");//修改人
|
|
Date modifytime = dynamicObject.getDate("modifytime");//修改时间
|
|
DynamicObject linetype = object.getDynamicObject("linetype");//行类型
|
|
DynamicObject tqq9_registration = object.getDynamicObject("tqq9_registration");//注册证
|
|
String tqq9_licenseno = object.getString("tqq9_licenseno");//许可证
|
|
DynamicObject tqq9_brand = masterid.getDynamicObject("tqq9_brand");//品牌
|
|
DynamicObject warehouse = object.getDynamicObject("warehouse");//入库仓库
|
|
BigDecimal qty = object.getBigDecimal("qty");//数量
|
|
Boolean ispresent = object.getBoolean("ispresent");//是否赠品
|
|
String ownertype = object.getString("ownertype");//货主类型
|
|
DynamicObject owner = object.getDynamicObject("owner");//货主
|
|
DynamicObject version = object.getDynamicObject("mversion");//物料版本
|
|
DynamicObject unit2nd = object.getDynamicObject("unit2nd");//辅助单位
|
|
BigDecimal qtyunit2nd = object.getBigDecimal("qtyunit2nd");//辅助数量
|
|
Object auxpty = object.get("auxpty");//辅助属性
|
|
BigDecimal discountrate = object.getBigDecimal("discountrate");//单位折扣(率)
|
|
BigDecimal price = object.getBigDecimal("price");//单价
|
|
BigDecimal priceandtax = object.getBigDecimal("priceandtax");//含税单价
|
|
BigDecimal amount = object.getBigDecimal("amount");//金额
|
|
BigDecimal curamount = object.getBigDecimal("curamount");//金额(本位币)
|
|
BigDecimal taxamount = object.getBigDecimal("taxamount");//税额
|
|
BigDecimal curtaxamount = object.getBigDecimal("curtaxamount");//税额(本位币)
|
|
BigDecimal discountamount = object.getBigDecimal("discountamount");//优惠(折扣)金额
|
|
BigDecimal amountandtax = object.getBigDecimal("amountandtax");//折扣后价税合计
|
|
BigDecimal curamountandtax = object.getBigDecimal("curamountandtax");//价税合计(本位币)
|
|
BigDecimal returnqty = object.getBigDecimal("returnqty");//退库数量
|
|
BigDecimal returnbaseqty = object.getBigDecimal("returnbaseqty");//退库数量
|
|
BigDecimal tqq9_yyhyflje = object.getBigDecimal("tqq9_yyhyflje");//有优惠有返利含税单价
|
|
BigDecimal tqq9_yyhwflje = object.getBigDecimal("tqq9_yyhwflje");//有优惠无返利含税单价
|
|
String lotnumber = object.getString("lotnumber");//批号
|
|
DynamicObject tqq9_goods = object.getDynamicObject("tqq9_goods");//商品
|
|
String tqq9_wmsdetailid = object.getString("tqq9_wmsdetailid");//WMS分录id
|
|
Date producedate = object.getDate("producedate");//生产日期
|
|
Date expirydate = object.getDate("expirydate");//生产日期
|
|
|
|
|
|
DynamicObject dynamicObject1 = dynamicObjectCollection.addNew();
|
|
dynamicObject1.set("material",bd_materialpurchaseinfo);
|
|
dynamicObject1.set("materialname",materialname);
|
|
dynamicObject1.set("unit",baseunit);
|
|
dynamicObject1.set("baseunit",baseunit);
|
|
dynamicObject1.set("rowclosestatus","A");
|
|
dynamicObject1.set("rowterminatestatus","A");
|
|
dynamicObject1.set("entryreqorg","A");
|
|
dynamicObject1.set("entryreqorg",entryreqorg);
|
|
dynamicObject1.set("entryinvcorg",entryreqorg);
|
|
dynamicObject1.set("entrysettleorg",entryreqorg);
|
|
dynamicObject1.set("taxrateid",taxrateid);
|
|
dynamicObject1.set("discounttype",discounttype);
|
|
dynamicObject1.set("entrypayorg",entryreqorg);
|
|
dynamicObject1.set("mainbillentity",mainbillentity);
|
|
dynamicObject1.set("mainbillid",mainbillid);
|
|
dynamicObject1.set("mainbillnumber",mainbillnumber);
|
|
dynamicObject1.set("mainbillentryid",mainbillentryid);
|
|
dynamicObject1.set("mainbillentryseq",mainbillentryseq);
|
|
dynamicObject1.set("srcbillentity",mainbillentity);
|
|
dynamicObject1.set("srcbillid",mainbillid);
|
|
dynamicObject1.set("srcbillnumber",mainbillnumber);
|
|
dynamicObject1.set("srcbillentryid",mainbillentryid);
|
|
dynamicObject1.set("srcbillentryseq",mainbillentryseq);
|
|
dynamicObject1.set("entrycreator",creator);
|
|
dynamicObject1.set("entrycreatetime",createtime);
|
|
dynamicObject1.set("entrymodifier",modifier);
|
|
dynamicObject1.set("entrymodifytime",modifytime);
|
|
dynamicObject1.set("linetype",linetype);
|
|
dynamicObject1.set("tqq9_registration",tqq9_registration);
|
|
dynamicObject1.set("tqq9_licenseno",tqq9_licenseno);
|
|
dynamicObject1.set("tqq9_brand",tqq9_brand);
|
|
dynamicObject1.set("tqq9_thck",warehouse);
|
|
dynamicObject1.set("tqq9_kclx","ZP");
|
|
dynamicObject1.set("tqq9_maxqty",qty);
|
|
dynamicObject1.set("qty",qty);
|
|
dynamicObject1.set("baseqty",qty);
|
|
dynamicObject1.set("ispresent",ispresent);
|
|
dynamicObject1.set("ownertype",ownertype);
|
|
dynamicObject1.set("owner",owner);
|
|
dynamicObject1.set("materialversion",version);
|
|
dynamicObject1.set("auxunit",unit2nd);
|
|
dynamicObject1.set("auxqty",qtyunit2nd);
|
|
dynamicObject1.set("auxpty",auxpty);
|
|
dynamicObject1.set("discountrate",discountrate);
|
|
dynamicObject1.set("price",price);
|
|
dynamicObject1.set("priceandtax",priceandtax);
|
|
dynamicObject1.set("amount",amount);
|
|
dynamicObject1.set("curamount",curamount);
|
|
dynamicObject1.set("taxamount",taxamount);
|
|
dynamicObject1.set("curtaxamount",curtaxamount);
|
|
dynamicObject1.set("discountamount",discountamount);
|
|
dynamicObject1.set("amountandtax",amountandtax);
|
|
dynamicObject1.set("curamountandtax",curamountandtax);
|
|
dynamicObject1.set("joinqty",zero);
|
|
dynamicObject1.set("joinbaseqty",zero);
|
|
dynamicObject1.set("returnqty",returnqty);
|
|
dynamicObject1.set("returnbaseqty",returnbaseqty);
|
|
dynamicObject1.set("tqq9_yyhyflje",tqq9_yyhyflje);
|
|
dynamicObject1.set("tqq9_yyhwflje",tqq9_yyhwflje);
|
|
dynamicObject1.set("tqq9_ph",lotnumber);
|
|
dynamicObject1.set("tqq9_goods",tqq9_goods);
|
|
dynamicObject1.set("tqq9_inwarebill",dynamicObject);
|
|
dynamicObject1.set("tqq9_inwarebillid",billid);
|
|
dynamicObject1.set("tqq9_inwarebillentryid",billentryid);
|
|
dynamicObject1.set("tqq9_inwarebillentryqty",qty);
|
|
dynamicObject1.set("tqq9_wmsdetailid",tqq9_wmsdetailid);
|
|
dynamicObject1.set("tqq9_productdate",producedate);
|
|
dynamicObject1.set("tqq9_expiredate",expirydate);
|
|
}
|
|
|
|
|
|
}
|
|
}
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
} |