From abe0a85d9a57f064b8110f574bb97234ae2096fe Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E7=A8=8B=E5=B0=8F=E4=BC=9F?= Date: Wed, 7 May 2025 15:52:48 +0800 Subject: [PATCH] =?UTF-8?q?=E4=BB=98=E6=AC=BE=E7=94=B3=E8=AF=B7=E5=8D=95?= =?UTF-8?q?=E5=B7=B2=E5=AE=A1=E6=A0=B8=20=E9=87=8D=E6=96=B0=E6=B7=BB?= =?UTF-8?q?=E5=8A=A0=E5=8F=91=E7=A5=A8?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../form/SupplementInvoiceBillPlugin.java | 216 ++++++++++++++++++ 1 file changed, 216 insertions(+) create mode 100644 code/zcdev/zcgj-zcdev-zcdev-pr/src/main/java/zcgj/zcdev/zcdev/pr/plugin/form/SupplementInvoiceBillPlugin.java diff --git a/code/zcdev/zcgj-zcdev-zcdev-pr/src/main/java/zcgj/zcdev/zcdev/pr/plugin/form/SupplementInvoiceBillPlugin.java b/code/zcdev/zcgj-zcdev-zcdev-pr/src/main/java/zcgj/zcdev/zcdev/pr/plugin/form/SupplementInvoiceBillPlugin.java new file mode 100644 index 0000000..78b2515 --- /dev/null +++ b/code/zcdev/zcgj-zcdev-zcdev-pr/src/main/java/zcgj/zcdev/zcdev/pr/plugin/form/SupplementInvoiceBillPlugin.java @@ -0,0 +1,216 @@ +package zcgj.zcdev.zcdev.pr.plugin.form; + +import dm.jdbc.util.StringUtil; +import kd.bos.bill.AbstractBillPlugIn; +import kd.bos.dataentity.entity.DynamicObject; +import kd.bos.dataentity.entity.DynamicObjectCollection; +import kd.bos.dataentity.resource.ResManager; +import kd.bos.entity.datamodel.ListSelectedRow; +import kd.bos.entity.datamodel.ListSelectedRowCollection; +import kd.bos.entity.datamodel.events.PropertyChangedArgs; +import kd.bos.form.CloseCallBack; +import kd.bos.form.ShowFormHelper; +import kd.bos.form.ShowType; +import kd.bos.form.control.EntryGrid; +import kd.bos.form.events.BeforeDoOperationEventArgs; +import kd.bos.form.events.ClosedCallBackEvent; +import kd.bos.form.operate.FormOperate; +import kd.bos.list.ListShowParameter; +import kd.bos.logging.Log; +import kd.bos.logging.LogFactory; +import kd.bos.orm.query.QFilter; +import kd.bos.servicehelper.BusinessDataServiceHelper; +import kd.bos.servicehelper.operation.SaveServiceHelper; +import kd.ec.contract.formplugin.PaymentApplyEditUI; +import kd.sdk.plugin.Plugin; + + +import java.math.BigDecimal; +import java.util.ArrayList; +import java.util.List; + +public class SupplementInvoiceBillPlugin extends PaymentApplyEditUI { + private static final Log log = LogFactory.getLog(SupplementInvoiceBillPlugin.class); + @Override + public void beforeDoOperation(BeforeDoOperationEventArgs args) { + super.beforeDoOperation(args); + FormOperate operate = (FormOperate)args.getSource(); + String key = operate.getOperateKey();//获取操作码 + if(StringUtil.equals("supplementInvoice", key)) {//候补发票 + log.info("SupplementInvoiceBillPlugin:点击候补发票"); + this.beforeNewSubEntry(args); + } + } + + @Override + public void propertyChanged(PropertyChangedArgs e) { + super.propertyChanged(e); + + String billId = this.getModel().getDataEntity().getPkValue().toString(); + if (!billId.equals("0") && "C".equals(this.getModel().getValue("billstatus"))){//单据为已审核情况下 + String key = e.getProperty().getName(); +// int rowIndex = e.getChangeSet()[0].getRowIndex(); + log.info("SupplementInvoiceBillPlugin:发票申请金额发生变动,与合同的申请金额进行比较"); + if(StringUtil.equals("applyinvoftaxamt", key)) { + this.compareApplyInvoftaxamt(); + } + } + + } + + private void compareApplyInvoftaxamt() { + int rowIndex = this.getModel().getEntryCurrentRowIndex("entryentity"); + DynamicObject rowEntity = this.getModel().getEntryRowEntity("entryentity", rowIndex);//获取对应行的单据体 + BigDecimal applyoftaxamount = rowEntity.getBigDecimal("applyoftaxamount");//获取单据体对应的 本次应付金额字段 + BigDecimal totalAmount = this.getSum("subentryentity", "applyinvoftaxamt");//算出子单据申请金额总和 + if(applyoftaxamount.compareTo(totalAmount)!=0){ + this.getView().showTipNotification( + "合同付款信息 第"+(rowIndex+1)+"行的 本次申请金额\n" + + " 不等于 合同进项发票的 本次申请金额总和 ,请重写填写合同进项发票的申请金额",5000); + } + } + + protected void beforeNewSubEntry(BeforeDoOperationEventArgs args) { + String billId = this.getModel().getDataEntity().getPkValue().toString(); + + if (!billId.equals("0") && "C".equals(this.getModel().getValue("billstatus"))) {//单据状态是否为审核 + log.info("SupplementInvoiceBillPlugin:单据已审核"); + EntryGrid grid = (EntryGrid)this.getView().getControl("entryentity");//获取单据体控件-合同付款信息 + int[] rows = grid.getEntryState().getSelectedRows();//获取选择行号 + if (rows.length != 1) {//只能选择一条 + this.getView().showMessage(ResManager.loadKDString("必须选中一条合同付款信息记录。", "PaymentApplyEditUI_2", "ec-contract-formplugin", new Object[0])); + args.setCancel(true); + }else if(!this.hasInvoice(rows[0])) {//没有对应的发票,进项发票候补 + log.info("SupplementInvoiceBillPlugin:单据已审核,已选择一条合同付款信息记录,没有对应的发票,可以进项发票候补"); + this.showInvoice("subentryentity"); + } + + } else { + this.getView().showMessage(ResManager.loadKDString("单据不是审核状态,请先审核单据。", "PaymentApplyEditUI_1", "ec-contract-formplugin", new Object[0])); + args.setCancel(true); + } + } + private void showInvoice(String entryType) { + log.info("SupplementInvoiceBillPlugin:在进项发票基础资料中进项筛选"); + Object currencyId = this.getModel().getValue("currency_id"); + long orgId = ((DynamicObject)this.getModel().getValue("org")).getLong("id"); + QFilter filter = new QFilter("org", "=", orgId); + filter.and(new QFilter("isclaimed", "=", false)); + filter.and(new QFilter("billstatus", "=", "C")); + filter.and(new QFilter("currency", "=", currencyId)); + filter.and(new QFilter("invoicestatus", "!=", "2")); + filter.and(new QFilter("unapplyamount", ">", BigDecimal.ZERO)); + QFilter filter1 = new QFilter("isclaimed", "=", true); + filter1.and(new QFilter("billstatus", "=", "C")); + int contEntryIndex = this.getModel().getEntryCurrentRowIndex("entryentity"); + DynamicObject contract = (DynamicObject)this.getModel().getValue("contract", contEntryIndex); + if (contract != null) { + long contractId = contract.getLong("id"); + filter1.and(new QFilter("contract", "=", contractId)); + filter1.and(new QFilter("unapplyamount", ">", BigDecimal.ZERO)); + DynamicObjectCollection contInvEntryCol = this.getModel().getEntryEntity("subentryentity"); + if (contInvEntryCol.size() > 0) { + List selectedInvIds = new ArrayList(8); + + for(DynamicObject contInvEntryObj : contInvEntryCol) { + DynamicObject invoice = contInvEntryObj.getDynamicObject("invoice"); + selectedInvIds.add(invoice.getLong("id")); + } + + filter1.and(new QFilter("id", "not in", selectedInvIds));//已选发票,不再出现 + } + + ListShowParameter param = ShowFormHelper.createShowListForm("ec_in_invoice_f7", true); + param.getListFilterParameter().setFilter(filter.or(filter1)); + param.setMultiSelect(true); + param.setCloseCallBack(new CloseCallBack(this, entryType)); + log.info("SupplementInvoiceBillPlugin:返回关闭标识:"+entryType); + param.getOpenStyle().setShowType(ShowType.Modal); + this.getView().showForm(param); + } + } + + @Override + public void closedCallBack(ClosedCallBackEvent event) { + super.closedCallBack(event); + String actionId = event.getActionId();//获取回调标识 + Object returnData = event.getReturnData();//获取子页面返回的数据 + log.info("SupplementInvoiceBillPlugin:获取回调标识:"+actionId); + if (actionId.equals("subentryentity") && returnData != null) { + this.invoiceCloseCallBack(event); + } + } + + protected void invoiceCloseCallBack(ClosedCallBackEvent event) { + ListSelectedRowCollection rows = (ListSelectedRowCollection)event.getReturnData(); + DynamicObject[] invArr = new DynamicObject[rows.size()]; + int index = 0; + log.info("SupplementInvoiceBillPlugin:进项发票资料带下来"); + for(ListSelectedRow row : rows) { + Object invoicePk = row.getPrimaryKeyValue().toString(); + int rowIndex = this.getModel().createNewEntryRow("subentryentity"); + this.getModel().setValue("invoice", invoicePk.toString(), rowIndex); + DynamicObject invoice = BusinessDataServiceHelper.loadSingle(invoicePk, "ec_in_invoice", "unapplyinvtax,unapplyamount,isClaimed,contract,project,connecttype,currency,totalamount,totaltax,totaloftaxamount"); + this.getModel().setValue("invoicecurrency", invoice.getDynamicObject("currency") == null ? Long.valueOf("0") : invoice.getDynamicObject("currency").getPkValue(), rowIndex); + this.getModel().setValue("invoiceamount", invoice.getBigDecimal("totalamount"), rowIndex); + this.getModel().setValue("invoicetax", invoice.getBigDecimal("totaltax"), rowIndex); + this.getModel().setValue("oftaxinvoiceamount", invoice.getBigDecimal("totaloftaxamount"), rowIndex); + this.getModel().setValue("unapplyinvoftaxamt", invoice.getBigDecimal("unapplyamount"), rowIndex); + this.getModel().setValue("unapplyinvtax", invoice.getBigDecimal("unapplyinvtax"), rowIndex); + this.getModel().setValue("applyinvoftaxamt", invoice.getBigDecimal("unapplyamount"), rowIndex); + invArr[index++] = invoice; + invoice.set("isclaimed", true); + int upCurIndex = this.getModel().getEntryCurrentRowIndex("entryentity"); + DynamicObject upContract = (DynamicObject)this.getModel().getValue("contract", upCurIndex); + invoice.set("contract", upContract); + invoice.set("project", upContract.getDynamicObject("project")); + invoice.set("connecttype", "contract"); + } + +// this.setApplyAmtByInvoice(this.getModel().getEntryCurrentRowIndex("entryentity")); + + log.info("SupplementInvoiceBillPlugin:发票保存"); + SaveServiceHelper.save(invArr);//发票保存 + this.getView().invokeOperation("invoicesave"); + this.setEnableByInvoice(); + } + + protected void setEnableByInvoice() { + int entryRowCount = this.getModel().getEntryRowCount("entryentity"); + log.info("SupplementInvoiceBillPlugin:有发票,合同记录锁定 thisapplyoftax thisapplyamout 字段"); + for(int i = 0; i < entryRowCount; ++i) {//有发票锁定 "thisapplyoftax", "thisapplyamount" 字段 + this.getView().setEnable(!this.hasInvoice(i), i, new String[]{"thisapplyoftax", "thisapplyamount"}); + } + + } + + protected boolean hasInvoice(int rowIndex) { + DynamicObject rowEntity = this.getModel().getEntryRowEntity("entryentity", rowIndex);//获取对应的单据体 + DynamicObjectCollection subEntries = rowEntity.getDynamicObjectCollection("subentryentity");//获取单据体对应的子单据体 + return subEntries != null && !subEntries.isEmpty();//子单据体不为null且有数据 + } + + protected void setApplyAmtByInvoice(String subColumnId, String contractColumnId, int rowIndex) { + BigDecimal totalAmount = this.getSum("subentryentity", subColumnId); +// this.getModel().setValue(contractColumnId, totalAmount, rowIndex); + } + + protected void setApplyAmtByInvoice(int rowIndex) { + this.setApplyAmtByInvoice("applyinvoftaxamt", "applyoftaxamount", rowIndex); +// this.setApplyAmtByInvoice("applyinvamt", "applyamount", rowIndex); +// this.setApplyAmtByInvoice("applyinvtax", "applytaxamount", rowIndex); + } + + protected BigDecimal getSum(String entryId, String columnId) { + int rowCount = this.getModel().getEntryRowCount(entryId); + BigDecimal totalAmount = BigDecimal.ZERO; + + for(int i = 0; i < rowCount; ++i) { + BigDecimal amount = (BigDecimal)this.getModel().getValue(columnId, i); + amount = amount == null ? BigDecimal.ZERO : amount; + totalAmount = totalAmount.add(amount); + } + + return totalAmount; + } +}