FinapbillBeforeF7SelectSample.java 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244
  1. package fi.er.opplugin;
  2. import com.alibaba.druid.util.StringUtils;
  3. import kd.bos.dataentity.entity.DynamicObject;
  4. import kd.bos.dataentity.entity.DynamicObjectCollection;
  5. import kd.bos.entity.datamodel.events.ChangeData;
  6. import kd.bos.entity.datamodel.events.PropertyChangedArgs;
  7. import kd.bos.form.field.RefBillEdit;
  8. import kd.bos.form.field.events.BeforeF7SelectEvent;
  9. import kd.bos.form.field.events.BeforeF7SelectListener;
  10. import kd.bos.form.plugin.AbstractFormPlugin;
  11. import kd.bos.list.ListShowParameter;
  12. import kd.bos.orm.query.QCP;
  13. import kd.bos.orm.query.QFilter;
  14. import kd.bos.servicehelper.BusinessDataServiceHelper;
  15. import java.math.BigDecimal;
  16. import java.math.RoundingMode;
  17. import java.util.ArrayList;
  18. import java.util.Date;
  19. import java.util.EventObject;
  20. import java.util.List;
  21. public class FinapbillBeforeF7SelectSample extends AbstractFormPlugin implements BeforeF7SelectListener {
  22. private static String nckd_apfinapbill = "nckd_apfinapbill"; //应付挂账单字段
  23. private static String nckd_real_card = "assetentry.nckd_real_card"; //应付挂账单字段
  24. private static String nckd_ap_finapbill_gz = "ap_finapbill"; //应付挂账单标识
  25. private static String nckd_er_publicreimbur_ext = "er_publicreimbursebill"; //报销单标识
  26. @Override
  27. public void registerListener(EventObject e) {
  28. //监听单据字段
  29. super.registerListener(e);
  30. RefBillEdit bill = this.getView().getControl(nckd_apfinapbill);
  31. bill.addBeforeF7SelectListener(this);
  32. }
  33. @Override
  34. public void beforeF7Select(BeforeF7SelectEvent arg0) {
  35. String fieldKey = arg0.getProperty().getName();
  36. if (StringUtils.equals(fieldKey, nckd_apfinapbill)){
  37. // 生成过滤条件对象QFilter
  38. Object nckd_sourcebillid = this.getModel().getValue("nckd_sourcebillid");
  39. if (nckd_sourcebillid != null) {
  40. //查询暂估报销单
  41. String sourcebillid = String.valueOf(nckd_sourcebillid);
  42. QFilter filter = new QFilter("nckd_sourcebillid", QCP.equals,sourcebillid);
  43. filter.and("nckd_ywlx", QCP.equals, "2");
  44. DynamicObject[] bxDynamicObjects = BusinessDataServiceHelper.load(nckd_er_publicreimbur_ext,"id",new QFilter[] {filter});
  45. if (bxDynamicObjects.length > 0) {
  46. DynamicObject bxInfo = BusinessDataServiceHelper.loadSingle(bxDynamicObjects[0].getPkValue(), bxDynamicObjects[0].getDynamicObjectType().getName());
  47. Long id = bxInfo.getLong("id");
  48. QFilter qFilter = new QFilter("sourcebillid", QCP.equals,id);
  49. // 表过滤条件
  50. ListShowParameter showParameter = (ListShowParameter)arg0.getFormShowParameter();
  51. showParameter.getListFilterParameter().setFilter(qFilter);
  52. }
  53. }else {
  54. //选取不到应付挂账单
  55. QFilter qFilter = new QFilter("id", QCP.equals,null);
  56. // 表过滤条件
  57. ListShowParameter showParameter = (ListShowParameter)arg0.getFormShowParameter();
  58. showParameter.getListFilterParameter().setFilter(qFilter);
  59. }
  60. }
  61. }
  62. @Override
  63. public void propertyChanged(PropertyChangedArgs e) {
  64. String fieldKey = e.getProperty().getName();
  65. if (StringUtils.equals("nckd_real_card", fieldKey)){
  66. ChangeData changeData = e.getChangeSet()[0];
  67. DynamicObjectCollection dynamicObjectCollection = (DynamicObjectCollection) changeData.getNewValue();
  68. int parentIndex = changeData.getRowIndex();
  69. this.getModel().deleteEntryData("nckd_realcard_list2");
  70. for (int i = 0; i < dynamicObjectCollection.size(); i++) {
  71. DynamicObject object = dynamicObjectCollection.get(i);
  72. this.getModel().setValue("nckd_card_list_str","1");
  73. //实物卡片清单分录赋值
  74. DynamicObject cardInfo = BusinessDataServiceHelper.loadSingle(object.get(2), "nckd_fa_card_real_list");
  75. int rowIndex = this.getModel().createNewEntryRow("nckd_realcard_list2");
  76. this.getModel().setValue("nckd_card_code2",cardInfo,rowIndex,parentIndex);
  77. if (i == 0) {
  78. String name = cardInfo.getString("name");//资产名称
  79. DynamicObject nckd_dept = cardInfo.getDynamicObject("nckd_dept");//归属部门
  80. String nckd_use_name = cardInfo.getString("nckd_use_name");//使用人
  81. String nckd_local = cardInfo.getString("nckd_local");//存放地点
  82. String nckd_card_model = cardInfo.getString("nckd_card_model");//型号
  83. //资产信息分录赋值
  84. this.getModel().setValue("asset_name", name, parentIndex);
  85. //资产类别赋值
  86. //规格型号
  87. this.getModel().setValue("asset_model",nckd_card_model, parentIndex);
  88. //使用部门
  89. this.getModel().setValue("asset_costdept",nckd_dept, parentIndex);
  90. //使用人
  91. QFilter userFilter = new QFilter("number", QCP.equals,nckd_use_name);
  92. DynamicObject[] userDynamicObjects = BusinessDataServiceHelper.load("bos_user","id",new QFilter[] {userFilter});
  93. for (int d=0;d<userDynamicObjects.length;d++) {
  94. DynamicObject userInfo = BusinessDataServiceHelper.loadSingle(userDynamicObjects[i].getPkValue(), userDynamicObjects[i].getDynamicObjectType().getName());
  95. this.getModel().setValue("asset_user",userInfo, parentIndex);
  96. }
  97. //存放地点
  98. this.getModel().setValue("nckd_storeplace",nckd_local, parentIndex);
  99. }
  100. }
  101. //刷新实物卡片清单分录
  102. this.getView().updateView("assetentry");
  103. } else if (StringUtils.equals("nckd_apfinapbill", fieldKey)) {
  104. ChangeData changeData = e.getChangeSet()[0];
  105. DynamicObject dynamicObject = (DynamicObject) changeData.getNewValue();
  106. if (dynamicObject != null) {
  107. Long id = dynamicObject.getLong("id");
  108. //查询应付挂账
  109. QFilter filter = new QFilter("id", QCP.equals,id);
  110. DynamicObject[] yfgzDynamicObjects = BusinessDataServiceHelper.load(nckd_ap_finapbill_gz,"id",new QFilter[] {filter});
  111. DynamicObject gzInfo = BusinessDataServiceHelper.loadSingle(yfgzDynamicObjects[0].getPkValue(), yfgzDynamicObjects[0].getDynamicObjectType().getName());
  112. String billno = gzInfo.getString("billno");//单据编号
  113. DynamicObject org = gzInfo.getDynamicObject("org");//结算组织
  114. DynamicObject detailentry = gzInfo.getDynamicObjectCollection("detailentry").get(0);
  115. DynamicObject expenseitem = detailentry.getDynamicObject("expenseitem");//费用项目
  116. DynamicObject receivingsupplierid = gzInfo.getDynamicObject("receivingsupplierid");//供应商
  117. Date bookdate = gzInfo.getDate("bookdate");
  118. String remark = gzInfo.getString("remark");
  119. BigDecimal pricetaxtotal = gzInfo.getBigDecimal("pricetaxtotal");
  120. //给冲预付借款赋值
  121. int rowIndex = this.getModel().createNewEntryRow("writeoffmoney");
  122. this.getModel().setValue("loanbillnov1",billno,rowIndex);
  123. this.getModel().setValue("sourceentrycostdept",org,rowIndex);
  124. this.getModel().setValue("sourceentrycostcompany",org,rowIndex);
  125. this.getModel().setValue("sourceexpenseitem",expenseitem,rowIndex);
  126. this.getModel().setValue("srcentrywlunit",receivingsupplierid,rowIndex);
  127. this.getModel().setValue("loanapplydatev1",bookdate,rowIndex);
  128. this.getModel().setValue("loandescriptionv1",remark,rowIndex);
  129. this.getModel().setValue("loanamount",pricetaxtotal,rowIndex);
  130. this.getModel().setValue("accloanamount",pricetaxtotal,rowIndex);
  131. this.getModel().setValue("currloanamount",pricetaxtotal,rowIndex);
  132. this.getModel().setValue("curraccloanamount",pricetaxtotal,rowIndex);
  133. //刷新冲预付借款分录
  134. this.getView().updateView("writeoffmoney");
  135. }
  136. }//资产组织变更
  137. else if (StringUtils.equals("assetorg", fieldKey)) {
  138. ChangeData changeData = e.getChangeSet()[0];
  139. DynamicObject dynamicObject = (DynamicObject) changeData.getNewValue();
  140. Long id = dynamicObject.getLong("id");
  141. //查询组织
  142. QFilter filter = new QFilter("id", QCP.equals,id);
  143. DynamicObject[] orgDynamicObjects = BusinessDataServiceHelper.load("bos_org","id",new QFilter[] {filter});
  144. DynamicObject orgInfo = BusinessDataServiceHelper.loadSingle(orgDynamicObjects[0].getPkValue(), orgDynamicObjects[0].getDynamicObjectType().getName());
  145. //获取资产信息分录
  146. DynamicObjectCollection assetentry = this.getModel().getEntryEntity("assetentry");
  147. for (int i = 0; i < assetentry.size(); i++) {
  148. //给分录核算组织,使用部门赋值
  149. this.getModel().setValue("nckd_orgfield1", orgInfo, i);
  150. this.getModel().setValue("asset_costdept", orgInfo, i);
  151. }
  152. //刷新资产信息分录
  153. this.getView().updateView("assetentry");
  154. } //资产信息分录-核算组织变更
  155. else if (StringUtils.equals("nckd_orgfield1", fieldKey)) {
  156. ChangeData changeData = e.getChangeSet()[0];
  157. DynamicObject dynamicObject = (DynamicObject) changeData.getNewValue();
  158. Long id = dynamicObject.getLong("id");
  159. //查询组织
  160. QFilter filter = new QFilter("id", QCP.equals,id);
  161. DynamicObject[] orgDynamicObjects = BusinessDataServiceHelper.load("bos_org","id",new QFilter[] {filter});
  162. DynamicObject orgInfo = BusinessDataServiceHelper.loadSingle(orgDynamicObjects[0].getPkValue(), orgDynamicObjects[0].getDynamicObjectType().getName());
  163. //获取资产信息分录
  164. DynamicObjectCollection assetentry = this.getModel().getEntryEntity("assetentry");
  165. //给分录核算组织,使用部门赋值
  166. this.getModel().setValue("nckd_orgfield1", orgInfo, e.getChangeSet()[0].getRowIndex());
  167. this.getModel().setValue("asset_costdept", orgInfo, e.getChangeSet()[0].getRowIndex());
  168. //刷新资产信息分录
  169. this.getView().updateView("assetentry");
  170. } else if (StringUtils.equals("expenseamount", fieldKey) || StringUtils.equals("nckd_amountfield3", fieldKey)) {
  171. String reimbursetype = (String) this.getModel().getValue("reimbursetype");
  172. if("asset".equals(reimbursetype)) {
  173. ChangeData changeData = e.getChangeSet()[0];
  174. BigDecimal expenseamount = (BigDecimal) changeData.getNewValue();
  175. this.getModel().setValue("nckd_amountfield3", expenseamount);//含税单价
  176. //含税金额 = 含税单价*数量
  177. BigDecimal asset_quantity = (BigDecimal) this.getModel().getValue("asset_quantity");
  178. BigDecimal assetexpenseamount = expenseamount.multiply(asset_quantity);
  179. this.getModel().setValue("assetexpenseamount", assetexpenseamount);
  180. //不含税单价 = 含税单价/(1+税率)
  181. BigDecimal assettaxrate = (BigDecimal) this.getModel().getValue("assettaxrate");
  182. assettaxrate = assettaxrate.divide(new BigDecimal(100), 2, RoundingMode.HALF_UP);
  183. BigDecimal rate = assettaxrate.add(BigDecimal.ONE);
  184. BigDecimal assetpricewithouttax = expenseamount.divide(rate, 2 , RoundingMode.HALF_UP);
  185. this.getModel().setValue("assetpricewithouttax", assetpricewithouttax);
  186. //不含税金额 = 不含税单价*数量
  187. BigDecimal assetorientryamount = assetpricewithouttax.multiply(asset_quantity);
  188. this.getModel().setValue("assetorientryamount", assetorientryamount);
  189. //税额 = 含税金额-不含税金额
  190. BigDecimal assettaxamount = assetexpenseamount.subtract(assetorientryamount);
  191. this.getModel().setValue("assettaxamount", assettaxamount);
  192. }
  193. } else if (StringUtils.equals("taxrate", fieldKey) || StringUtils.equals("assettaxrate", fieldKey)) {
  194. ChangeData changeData = e.getChangeSet()[0];
  195. BigDecimal assettaxrate = (BigDecimal) changeData.getNewValue();
  196. this.getModel().setValue("assettaxrate", assettaxrate);//税率
  197. //含税金额 = 含税单价 * 数量
  198. BigDecimal nckd_amountfield3 = (BigDecimal) this.getModel().getValue("nckd_amountfield3");
  199. BigDecimal asset_quantity = (BigDecimal) this.getModel().getValue("asset_quantity");
  200. BigDecimal assetexpenseamount = nckd_amountfield3.multiply(asset_quantity);
  201. this.getModel().setValue("assetexpenseamount", assetexpenseamount);
  202. //不含税单价 = 含税单价/(1+税率)
  203. assettaxrate = assettaxrate.divide(new BigDecimal(100), 2, RoundingMode.HALF_UP);
  204. BigDecimal rate = assettaxrate.add(BigDecimal.ONE);
  205. BigDecimal assetpricewithouttax = nckd_amountfield3.divide(rate, 2 , RoundingMode.HALF_UP);
  206. this.getModel().setValue("assetpricewithouttax", assetpricewithouttax);
  207. //不含税金额 = 不含税单价*数量
  208. BigDecimal assetorientryamount = assetpricewithouttax.multiply(asset_quantity);
  209. this.getModel().setValue("assetorientryamount", assetorientryamount);
  210. //税额 = 含税金额-不含税金额
  211. BigDecimal assettaxamount = assetexpenseamount.subtract(assetorientryamount);
  212. this.getModel().setValue("assettaxamount", assettaxamount);
  213. }
  214. }
  215. @Override
  216. public void afterCreateNewData(EventObject e) {
  217. //报账类型
  218. String reimbursetype = (String) this.getModel().getValue("reimbursetype");
  219. int rowIndex = this.getModel().createNewEntryRow("assetentry");
  220. if("asset".equals(reimbursetype)){
  221. //获取费用明细分录
  222. DynamicObjectCollection assetentry = this.getModel().getEntryEntity("expenseentryentity");
  223. //查询费用明细
  224. QFilter filter = new QFilter("name", QCP.equals,"资产报账");
  225. DynamicObject[] dynamicObjects = BusinessDataServiceHelper.load("er_expenseitemedit","id",new QFilter[] {filter});
  226. DynamicObject info = BusinessDataServiceHelper.loadSingle(dynamicObjects[0].getPkValue(), dynamicObjects[0].getDynamicObjectType().getName());
  227. this.getModel().setValue("expenseitem", info, 0);
  228. }
  229. }
  230. }