diff --git a/sys/shkd-sys-sys/src/main/java/shkd/sys/sys/midservice/backlogTack/ToDoResendTack.java b/sys/shkd-sys-sys/src/main/java/shkd/sys/sys/midservice/backlogTack/ToDoResendTack.java index 0656324..0ba958a 100644 --- a/sys/shkd-sys-sys/src/main/java/shkd/sys/sys/midservice/backlogTack/ToDoResendTack.java +++ b/sys/shkd-sys-sys/src/main/java/shkd/sys/sys/midservice/backlogTack/ToDoResendTack.java @@ -220,8 +220,14 @@ public class ToDoResendTack extends AbstractTask { form.append("\"").append(pcUrl).append("&userName=").append(userName).append("\","); form.append("\"appHandleUrl\":"); form.append("\"").append(pcUrl).append("&userName=").append(userName).append("\","); + // appUrl移动端查看模式 + form.append("\"appViewUrl\":"); + form.append("\"").append(pcUrl).append("&userName=").append(userName).append("&ado=view").append("\","); form.append("\"appName\":"); form.append("\"").append(next.getString("fentityname")).append("\","); + //pc端查看模式 + form.append("\"viewUrl\":"); + form.append("\"").append(pcUrl).append("&userName=").append(userName).append("&ado=view").append("\","); form.append("\"pendingId\":"); form.append("\"").append(next.getLong("fid")).append("\","); form.append("\"pendingAttr\":"); diff --git a/sys/shkd-sys-sys/src/main/java/shkd/sys/sys/midservice/servicehandler/BacklogServiceHandle.java b/sys/shkd-sys-sys/src/main/java/shkd/sys/sys/midservice/servicehandler/BacklogServiceHandle.java index 04dca3f..d84fd06 100644 --- a/sys/shkd-sys-sys/src/main/java/shkd/sys/sys/midservice/servicehandler/BacklogServiceHandle.java +++ b/sys/shkd-sys-sys/src/main/java/shkd/sys/sys/midservice/servicehandler/BacklogServiceHandle.java @@ -201,8 +201,14 @@ public class BacklogServiceHandle extends AbstractServiceHandler { form.append("\"").append(url).append("&userName=").append(userName).append("\","); form.append("\"appHandleUrl\":"); form.append("\"").append(url).append("&userName=").append(userName).append("\","); + // appUrl移动端查看模式 + form.append("\"appViewUrl\":"); + form.append("\"").append(url).append("&userName=").append(userName).append("&ado=view").append("\","); form.append("\"appName\":"); form.append("\"").append(ctx.getEntityName()).append("\","); + //pc端查看模式 + form.append("\"viewUrl\":"); + form.append("\"").append(url).append("&userName=").append(userName).append("&ado=view").append("\","); form.append("\"pendingId\":"); form.append("\"").append(todoInfo.getTaskId()).append("\","); form.append("\"pendingAttr\":"); @@ -295,8 +301,14 @@ public class BacklogServiceHandle extends AbstractServiceHandler { form.append("\"").append(url).append("&userName=").append(userName).append("\","); form.append("\"appHandleUrl\":"); form.append("\"").append(url).append("&userName=").append(userName).append("\","); + // appUrl移动端查看模式 + form.append("\"appViewUrl\":"); + form.append("\"").append(url).append("&userName=").append(userName).append("&ado=view").append("\","); form.append("\"appName\":"); form.append("\"").append(ctx.getEntityName()).append("\","); + //pc端查看模式 + form.append("\"viewUrl\":"); + form.append("\"").append(url).append("&userName=").append(userName).append("&ado=view").append("\","); form.append("\"pendingId\":"); form.append("\"").append(todoInfo.getTaskId()).append("\","); form.append("\"pendingAttr\":"); diff --git a/sys/shkd-sys-sys/src/main/java/shkd/sys/sys/mservice/ApiService.java b/sys/shkd-sys-sys/src/main/java/shkd/sys/sys/mservice/ApiService.java index 319c76c..5606bf6 100644 --- a/sys/shkd-sys-sys/src/main/java/shkd/sys/sys/mservice/ApiService.java +++ b/sys/shkd-sys-sys/src/main/java/shkd/sys/sys/mservice/ApiService.java @@ -16,9 +16,6 @@ import kd.bos.dataentity.resource.ResManager; import kd.bos.dataentity.utils.StringUtils; import kd.bos.entity.MainEntityType; import kd.bos.exception.KDBizException; -import kd.bos.fileservice.FileItem; -import kd.bos.fileservice.FileService; -import kd.bos.fileservice.FileServiceFactory; import kd.bos.form.IFormView; import kd.bos.logging.Log; import kd.bos.logging.LogFactory; @@ -30,16 +27,13 @@ import kd.bos.orm.query.QFilter; import kd.bos.print.core.service.PrtAttach; import kd.bos.print.matchtpl.MatcherTpl; import kd.bos.print.matchtpl.ViewType; -import kd.bos.print.service.BosPrintServiceHelper; import kd.bos.servicehelper.*; -import kd.bos.servicehelper.operation.SaveServiceHelper; import kd.bos.servicehelper.print.NotePrintService; -import kd.bos.util.FileNameUtils; +import kd.bos.util.ExceptionUtils; import kd.tmc.bei.business.ocr.impl.ScanServiceImpl; import kd.tmc.bei.business.ocr.invoke.ScanSystemFactory; import kd.tmc.bei.common.helper.BeiHelper; import kd.tmc.bei.common.helper.ReceiptPrintHelper; -import kd.bos.util.ExceptionUtils; import kd.tmc.bei.common.resource.BeiBizResource; import kd.tmc.fbp.common.ofd.OfdConvertUtil; import kd.tmc.fbp.common.util.EmptyUtil; @@ -48,12 +42,6 @@ import org.springframework.http.HttpHeaders; import org.springframework.http.MediaType; import org.springframework.http.ResponseEntity; import org.springframework.web.client.RestTemplate; -import shkd.sys.sys.common.PaymentRequest; - -import java.net.URLConnection; -import java.nio.file.Path; -import java.nio.file.Paths; -import java.nio.file.Files; import javax.crypto.Mac; import javax.crypto.spec.SecretKeySpec; @@ -62,8 +50,12 @@ import java.io.*; import java.math.BigDecimal; import java.net.HttpURLConnection; import java.net.URL; +import java.net.URLConnection; import java.net.URLEncoder; import java.nio.charset.StandardCharsets; +import java.nio.file.Files; +import java.nio.file.Path; +import java.nio.file.Paths; import java.security.cert.X509Certificate; import java.text.SimpleDateFormat; import java.util.*; @@ -251,7 +243,6 @@ public class ApiService { jsonObject = JSON.parseObject(saveResponseBody); code = jsonObject.getString("code"); if ("200".equals(code)) { -// LogService.newLog("INFO", "付款单", dynamic.getString("billno"), "付款处理 → BIP保存接口 → 成功", "请求数据:" + saveRequestBody + "\n推送成功接口返回数据:" + saveResponseBody); logger.info("付款处理 → BIP保存接口 → 成功\n失败单据编号:{}\n推送失败接口返回数据:{}", dynamic.getString("billno"), saveResponseBody); data = jsonObject.getJSONObject("data"); dynamic.set("shkd_businessnumber", data.getString("code")); @@ -268,7 +259,6 @@ public class ApiService { logger.info("付款处理 → BIP提交接口 → 返回结果:{}", submitResponseBody); result = "推送 → 付款处理单 → 成功"; } else { -// LogService.newLog("ERROR", "付款单", dynamic.getString("billno"), "付款处理 → BIP保存接口 → 失败", "请求数据:" + saveRequestBody + "\n推送失败接口返回数据:" + saveResponseBody); logger.info("付款处理 → BIP保存接口 → 失败\n失败单据编号:{}\n推送失败接口返回数据:{}", dynamic.getString("billno"), saveResponseBody); result = "推送 → 付款处理单 → 失败"; } @@ -281,8 +271,6 @@ public class ApiService { jsonObject = JSON.parseObject(saveResponseBody); code = jsonObject.getString("code"); if ("200".equals(code)) { -// LogService.newLog("INFO", "收款单", dynamic.getString("billno"), "收款处理 → BIP保存接口 → 成功", "请求数据:" + saveRequestBody + "\n推送成功接口返回数据:" + saveResponseBody); - logger.info("收款处理 → BIP保存接口 → 成功\n失败单据编号:{}\n推送失败接口返回数据:{}", dynamic.getString("billno"), saveResponseBody); data = jsonObject.getJSONObject("data"); dynamic.set("shkd_businessnumber", data.getString("code")); @@ -298,8 +286,6 @@ public class ApiService { logger.info("收款处理 → BIP提交接口 → 返回结果:{}", submitResponseBody); result = "推送 → 收款处理 → 成功"; } else { -// LogService.newLog("ERROR", "收款单", dynamic.getString("billno"), "收款处理 → BIP保存接口 → 失败", "请求数据:" + saveRequestBody + "\n推送失败接口返回数据:" + saveResponseBody); - logger.info("收款处理 → BIP保存接口 → 失败\n失败单据编号:{}\n推送失败接口返回数据:{}", dynamic.getString("billno"), saveResponseBody); result = "推送 → 收款处理 → 失败"; } @@ -309,18 +295,14 @@ public class ApiService { case "https://10.1.9.43/iuap-api-auth/yonbip/ctm/cmp/bankReconciliationBatchSave": saveResponseBody = pushBill(token, saveUrl, saveRequestBody); jsonObject = JSON.parseObject(saveResponseBody); - code = jsonObject.getString("code"); - if ("200".equals(code)) { + int successnum = jsonObject.getJSONObject("data").getIntValue("successnum"); + if (successnum > 0) { dynamic.set("shkd_pushstatus", "已推送"); dynamic.set("shkd_businessname", "共享系统"); dynamicObjects.add(dynamic); -// LogService.newLog("INFO", "银行收付处理", dynamic.getString("billno"), "银行收付处理 → BIP推送接口 → 成功", "请求数据:" + saveRequestBody + "\n推送成功接口返回数据:" + saveResponseBody); - logger.info("银行收付处理 → BIP推送接口 → 成功\n成功单据编号:{}\n成功请求体:{}\n推送成功接口返回数据:{}", dynamic.getString("billno"), saveRequestBody, saveResponseBody); result = "推送 → 银行收付处理 → 成功"; } else { -// LogService.newLog("ERROR", "银行收付处理", dynamic.getString("billno"), "银行收付处理 → BIP推送接口 → 失败", "请求数据:" + saveRequestBody + "\n推送失败接口返回数据:" + saveResponseBody); - logger.info("银行收付处理 → BIP推送接口 → 失败\n失败单据编号:{}\n失败请求体:{}\n推送失败接口返回数据:{}", dynamic.getString("billno"), saveRequestBody, saveResponseBody); result = "推送 → 银行收付处理 → 失败"; } diff --git a/sys/shkd-sys-sys/src/main/java/shkd/sys/sys/plugin/Exp/BalanceExpansion.java b/sys/shkd-sys-sys/src/main/java/shkd/sys/sys/plugin/Exp/BalanceExpansion.java index 46a2880..bb1327e 100644 --- a/sys/shkd-sys-sys/src/main/java/shkd/sys/sys/plugin/Exp/BalanceExpansion.java +++ b/sys/shkd-sys-sys/src/main/java/shkd/sys/sys/plugin/Exp/BalanceExpansion.java @@ -5,6 +5,9 @@ import com.alibaba.fastjson.JSONObject; import kd.bos.dataentity.entity.DynamicObject; 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.bos.servicehelper.operation.SaveServiceHelper; import kd.sdk.tmc.bei.extpoint.balance.IFillBankBalance; @@ -17,16 +20,27 @@ import java.math.BigDecimal; */ public class BalanceExpansion implements IFillBankBalance { private static final Log logger = LogFactory.getLog(BalanceExpansion.class); + @Override public void fillExtBankBalance(DynamicObject bankBalance, String balanceString) { + DynamicObject dynamicObject = BusinessDataServiceHelper.loadSingle(bankBalance.getDynamicObjectType().getName(), "id,billno,shkd_depositbalance", new QFilter("id", QCP.equals, bankBalance.getPkValue()).toArray()); JSONObject jsonObject = JSON.parseObject(balanceString); logger.info("bankBalance数据:{},balanceString数据:{}", bankBalance, jsonObject); + Object balance = jsonObject.get("depositBalance"); - if (balance != null && !"".equals(balance)) { - bankBalance.set("shkd_depositbalance", new BigDecimal(String.valueOf(balance))); - } else { - bankBalance.set("shkd_depositbalance", BigDecimal.ZERO); + BigDecimal depositBalance = BigDecimal.ZERO; + + if (balance != null) { + if (!"".equals(balance.toString())) { + depositBalance = new BigDecimal(balance.toString()); + } + } + + // 只有当新值与旧值不同时才设置并更新 + BigDecimal currentBalance = dynamicObject.getBigDecimal("shkd_depositbalance"); + if (depositBalance.compareTo(currentBalance) != 0) { + bankBalance.set("shkd_depositbalance", depositBalance); + logger.info("新值与旧值不同,新值上存余额为:{},旧值上存余额为:{}", depositBalance, currentBalance); } - SaveServiceHelper.save(new DynamicObject[]{bankBalance}); } } diff --git a/sys/shkd-sys-sys/src/main/java/shkd/sys/sys/plugin/api/InterfacePracticePlug.java b/sys/shkd-sys-sys/src/main/java/shkd/sys/sys/plugin/api/InterfacePracticePlug.java index 3b65c08..de19ee1 100644 --- a/sys/shkd-sys-sys/src/main/java/shkd/sys/sys/plugin/api/InterfacePracticePlug.java +++ b/sys/shkd-sys-sys/src/main/java/shkd/sys/sys/plugin/api/InterfacePracticePlug.java @@ -36,6 +36,7 @@ public class InterfacePracticePlug extends AbstractListPlugin implements Seriali /** * 计划编制写入 + * * @param arrHashMap * @return */ @@ -49,12 +50,12 @@ public class InterfacePracticePlug extends AbstractListPlugin implements Seriali jsonObject.getString("orgCode");// 编报主体 jsonObject.getString("subjectCode");// 计划科目 jsonObject.getString("entryPeriodCode");// 主维度数据分录期间code - jsonObject.getString("amount");//金额 + jsonObject.getString("amount");// 金额 FpmResponse voidFpmResponse = planningWrite(jsonObject.getString("periodCode"), jsonObject.getString("orgCode"), jsonObject.getString("subjectCode"), jsonObject.getString("entryPeriodCode"), jsonObject.getString("amount")); stringBuffer.append("第").append(i + 1).append("条数据写入").append(voidFpmResponse.isSuccess() ? "成功" : "失败") .append(",返回信息:").append(voidFpmResponse.getMessage()).append("\n"); } - return CustomApiResult.success(stringBuffer.toString()); + return CustomApiResult.fail("404", stringBuffer.toString()); } /** @@ -63,7 +64,7 @@ public class InterfacePracticePlug extends AbstractListPlugin implements Seriali * @param arrHashMap * @return */ - @ApiPostMapping(value = "planAdjustment_save", desc = "计划编制写入") + @ApiPostMapping(value = "planAdjustment_save", desc = "计划编制调整写入") public CustomApiResult<@ApiResponseBody("返回参数") String> planAdjustment_save(@ApiParam(value = "查询字段值") ArrayList> arrHashMap) { logger.info("planAdjustment_save,请求参数:{}", arrHashMap.get(0)); StringBuilder stringBuffer = new StringBuilder(); @@ -92,7 +93,7 @@ public class InterfacePracticePlug extends AbstractListPlugin implements Seriali stringBuffer.append("第").append(i + 1).append("条数据写入").append("成功,").append("单据编号:").append(adjustBillNoList).append("\n"); } } - return CustomApiResult.success(stringBuffer.toString()); + return CustomApiResult.fail("404", stringBuffer.toString()); } @@ -102,11 +103,11 @@ public class InterfacePracticePlug extends AbstractListPlugin implements Seriali * @param hashMap * @return */ - @ApiPostMapping(value = "planAdjustment_save", desc = "计划编制查询") + @ApiPostMapping(value = "planAdjustment_query", desc = "计划编制查询") public CustomApiResult<@ApiResponseBody("返回参数") String> planAdjustment_query(@ApiParam(value = "查询字段值") HashMap hashMap) { String reportPeriodName = hashMap.get("reportPeriodName").toString();// 编报期间ID String reportOrgName = hashMap.get("reportOrgName").toString();// 编报主体ID String queryPlanning = queryPlanning(reportPeriodName, reportOrgName); - return CustomApiResult.success(queryPlanning); + return CustomApiResult.fail("404", queryPlanning); } } diff --git a/sys/shkd-sys-sys/src/main/java/shkd/sys/sys/plugin/api/TicketRegistration.java b/sys/shkd-sys-sys/src/main/java/shkd/sys/sys/plugin/api/TicketRegistration.java index fdd9f40..e86e7f9 100644 --- a/sys/shkd-sys-sys/src/main/java/shkd/sys/sys/plugin/api/TicketRegistration.java +++ b/sys/shkd-sys-sys/src/main/java/shkd/sys/sys/plugin/api/TicketRegistration.java @@ -25,6 +25,7 @@ public class TicketRegistration implements Serializable, ApiSavePlugin { @Override public List> preHandleRequestData(List> reqData) { + logger.info("进入TicketRegistration"); for (Map map : reqData) { String payeetype = map.get("payeetype").toString(); /** @@ -35,15 +36,28 @@ public class TicketRegistration implements Serializable, ApiSavePlugin { * other */ if ("bd_supplier".equals(payeetype) || "bd_customer".equals(payeetype)) { + logger.info("进入判断客商if方法"); if (map.get("deliver") != null) { logger.info("进入收票登记"); Map deliver = (Map) map.get("deliver"); + String deliveraccountbase = map.get("deliveraccountbase").toString();// 交票人账号 String deliver_number = deliver.get("number").toString(); DynamicObject[] objects = BusinessDataServiceHelper.load(payeetype, "id,number," + "name,societycreditcode,entry_bank,entry_bank.bankaccount,entry_bank.accountname,entry_bank.bank", new QFilter("societycreditcode", QCP.equals, deliver_number).toArray()); if (objects.length > 0) { logger.info("进入收票登记→objects.length > 0"); + DynamicObjectCollection dynamicObjectCollection = objects[0].getDynamicObjectCollection("entry_bank"); + dynamicObjectCollection.forEach(dynamicObject -> { + if (dynamicObject.getString("bankaccount").equals(deliveraccountbase)) { + Object bank = dynamicObject.get("bank"); + DynamicObject[] dynamicObjects = BusinessDataServiceHelper.load("bd_bebank", "id,number", new QFilter("id", QCP.equals, bank).toArray()); + Map deliveropenbank = new HashMap<>(); + deliveropenbank.put("number", dynamicObjects[0].getString("number")); + map.put("deliveropenbank", deliveropenbank); + map.put("deliveropenbanknum", dynamicObjects[0].getString("number")); + } + }); Map societycreditcode = new HashMap<>(); societycreditcode.put("number", objects[0].getString("number")); map.put("deliver", societycreditcode); @@ -53,12 +67,24 @@ public class TicketRegistration implements Serializable, ApiSavePlugin { if (map.get("receiver") != null) {//receiver_number logger.info("进入开票登记"); Map deliver = (Map) map.get("receiver"); + String receiveraccount = map.get("receiveraccount").toString();// 收款人账号 String receiver_number = deliver.get("number").toString(); DynamicObject[] objects = BusinessDataServiceHelper.load(payeetype, "id,number," + "name,societycreditcode,entry_bank,entry_bank.bankaccount,entry_bank.accountname,entry_bank.bank", new QFilter("societycreditcode", QCP.equals, receiver_number).toArray()); if (objects.length > 0) { logger.info("进入开票登记→objects.length > 0"); + DynamicObjectCollection dynamicObjectCollection = objects[0].getDynamicObjectCollection("entry_bank"); + dynamicObjectCollection.forEach(dynamicObject -> { + if (dynamicObject.getString("bankaccount").equals(receiveraccount)) { + Object bank = dynamicObject.get("bank"); + DynamicObject[] dynamicObjects = BusinessDataServiceHelper.load("bd_bebank", "id,number", new QFilter("id", QCP.equals, bank).toArray()); + Map receiverbank = new HashMap<>(); + receiverbank.put("number", dynamicObjects[0].getString("number")); + map.put("receiverbank", receiverbank); + map.put("receiverbankno", dynamicObjects[0].getString("number")); + } + }); Map societycreditcode = new HashMap<>(); societycreditcode.put("number", objects[0].getString("number")); map.put("receiver", societycreditcode); diff --git a/sys/shkd-sys-sys/src/main/java/shkd/sys/sys/plugin/task/PushTaskPlugin.java b/sys/shkd-sys-sys/src/main/java/shkd/sys/sys/plugin/task/PushTaskPlugin.java index 8c7bb83..838ffb5 100644 --- a/sys/shkd-sys-sys/src/main/java/shkd/sys/sys/plugin/task/PushTaskPlugin.java +++ b/sys/shkd-sys-sys/src/main/java/shkd/sys/sys/plugin/task/PushTaskPlugin.java @@ -24,6 +24,7 @@ import java.nio.file.Path; import java.nio.file.Paths; import java.text.ParseException; import java.time.LocalDate; +import java.time.Month; import java.time.ZoneId; import java.time.format.DateTimeFormatter; import java.util.*; @@ -72,6 +73,13 @@ public class PushTaskPlugin extends AbstractTask implements Plugin { * 供应链融资 SCF */ case "cas_paybill": + ArrayList bizdates = new ArrayList<>(); + bizdates.add("FCA");//1 + bizdates.add("CFM");//2 + bizdates.add("CIM");//3 + bizdates.add("LC");//4 + bizdates.add("CDM");//5 + bizdates.add("FL");//6 DynamicObject[] objects1 = BusinessDataServiceHelper.load("cas_paybill", "id,billno,actpayamt,entry,entry.e_expenseitem,entry.e_remark,entry.e_actamt,settletype," + "payeebanknum,payeetype,payeenumber,payeracctbank,payeebank,payeebankname,paymenttype," + @@ -79,7 +87,7 @@ public class PushTaskPlugin extends AbstractTask implements Plugin { "billstatus,bankpaystatus,sourcetype" , new QFilter("bizdate", QCP.large_equals, getFirstDayOfMonth(3)) .and("billstatus", QCP.equals, "D") - .and("sourcetype", QCP.in, "FCA,CFM,CIM,LC,CDM,FL").toArray()); + .and("sourcetype", QCP.in, bizdates).toArray()); Arrays.stream(objects1).forEach(dynamicObject -> { DynamicObject org = dynamicObject.getDynamicObject("org"); @@ -142,8 +150,7 @@ public class PushTaskPlugin extends AbstractTask implements Plugin { */ case "bei_transdetail_cas": DynamicObject[] objects3 = BusinessDataServiceHelper.load("bei_transdetail_cas", "id,bizdate,billno,detailid,oppbank,oppunit,accountbank,description,company,oppbanknumber,bankdetailno,transbalance,description,debitamount,creditamount,shkd_pushstatus,shkd_businessnumber,shkd_businessid,shkd_businessname,recedbillentry,receiptno,recedbillentry.e_recedbilltype,recedbillentry.e_recedbillnumber,recedbillentry.e_recedbillid" - , new QFilter("bizdate", QCP.large_equals, getFirstDayOfMonth(3)) - .and("bizdate", QCP.less_equals, calculateTheDate(1)) + , new QFilter("bizdate", QCP.large_equals, getFirstDayOfCurrentMonth()) .and("shkd_pushstatus", QCP.not_equals, "已推送").toArray()); Arrays.stream(objects3).forEach(dynamicObject -> { @@ -379,6 +386,11 @@ public class PushTaskPlugin extends AbstractTask implements Plugin { return date; } + /** + * 获取指定月份的第一天 + * @param month + * @return + */ private static Date getFirstDayOfMonth(int month) { // 获取当前年份 int currentYear = LocalDate.now().getYear(); @@ -389,4 +401,19 @@ public class PushTaskPlugin extends AbstractTask implements Plugin { // 将LocalDate转换为Date return Date.from(firstDayOfMonth.atStartOfDay(ZoneId.systemDefault()).toInstant()); } + + /** + * 获取当前月份的第一天 + * @return + */ + private static Date getFirstDayOfCurrentMonth() { + // 获取当前日期 + LocalDate currentDate = LocalDate.now(); + + // 获取当前月份的第一天 + LocalDate firstDayOfMonth = currentDate.withDayOfMonth(1); + + // 将LocalDate转换为Date + return Date.from(firstDayOfMonth.atStartOfDay(ZoneId.systemDefault()).toInstant()); + } } \ No newline at end of file diff --git a/sys/shkd-sys-sys/src/main/java/shkd/sys/sys/plugin/tmc/LoancontractF7Plugin.java b/sys/shkd-sys-sys/src/main/java/shkd/sys/sys/plugin/tmc/LoancontractF7Plugin.java index 70f54b6..39c960e 100644 --- a/sys/shkd-sys-sys/src/main/java/shkd/sys/sys/plugin/tmc/LoancontractF7Plugin.java +++ b/sys/shkd-sys-sys/src/main/java/shkd/sys/sys/plugin/tmc/LoancontractF7Plugin.java @@ -17,6 +17,7 @@ import kd.bos.orm.query.QCP; import kd.bos.orm.query.QFilter; import kd.bos.servicehelper.BusinessDataServiceHelper; import kd.fi.bcm.common.util.CollectionUtil; +import kd.fi.cal.business.datacheck.ExceptionObj; import kd.sdk.plugin.Plugin; import java.util.*; @@ -36,9 +37,8 @@ public class LoancontractF7Plugin extends AbstractBillPlugIn implements Plugin, e_underwriter.addBeforeF7SelectListener(this); //监听占用注册额度F7数据选择 BasedataEdit shkd_occupybondlimit; - try{ - shkd_occupybondlimit = view.getControl("shkd_occupybondlimit"); - }catch (Exception ept){ + shkd_occupybondlimit = view.getControl("shkd_occupybondlimit"); + if(shkd_occupybondlimit == null){ shkd_occupybondlimit = view.getControl("occupybondlimit"); } shkd_occupybondlimit.addBeforeF7SelectListener(this); @@ -62,11 +62,11 @@ public class LoancontractF7Plugin extends AbstractBillPlugIn implements Plugin, shkd_bondlimit= (DynamicObject)this.getModel().getValue("occupybondlimit"); }catch(Exception e){ shkd_bondlimit= (DynamicObject)this.getModel().getValue("shkd_occupybondlimit"); - if(shkd_bondlimit == null){ - evt.setCancel(true); - this.getView().showTipNotification("请先选择占用注册额度。"); - return; - } + } + if(shkd_bondlimit == null){ + evt.setCancel(true); + this.getView().showTipNotification("请先选择占用注册额度。"); + return; } DynamicObject bdim_bond_limit = BusinessDataServiceHelper.loadSingle(shkd_bondlimit.get("id"), "bdim_bond_limit"); @@ -94,7 +94,12 @@ public class LoancontractF7Plugin extends AbstractBillPlugIn implements Plugin, } Long finproductID = (Long)finproduct.get("id"); //发行日期 - Date startdate = (Date)this.getModel().getValue("startdate"); + Date startdate; + try { + startdate = (Date)this.getModel().getValue("startdate"); + }catch (Exception e){ + startdate = (Date)this.getModel().getValue("bizdate"); + } if(startdate == null){ this.getView().showTipNotification("请先选择发行日期。"); evt.setCancel(true); @@ -138,11 +143,11 @@ public class LoancontractF7Plugin extends AbstractBillPlugIn implements Plugin, shkd_bondlimit= (DynamicObject)this.getModel().getValue("occupybondlimit"); }catch(Exception e){ shkd_bondlimit= (DynamicObject)this.getModel().getValue("shkd_occupybondlimit"); - if(shkd_bondlimit == null){ - evt.setCancel(true); - this.getView().showTipNotification("请先选择占用注册额度。"); - return; - } + } + if(shkd_bondlimit == null){ + evt.setCancel(true); + this.getView().showTipNotification("请先选择占用注册额度。"); + return; } Long occupybondlimitId = (Long) shkd_bondlimit.getPkValue(); //找到注册额度中的招标遴选ID