installation_facade.js 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  1. /**
  2. * Created by zhang on 2018/1/31.
  3. */
  4. import {installSectionModel,installFeeItemModel} from "../../complementary_ration_lib/models/schemas";
  5. import installationFeeModel from "../models/installation_fee";
  6. import engineeringModel from "../../users/models/schema/engineering_lib";
  7. const uuidV1 = require('uuid/v1');
  8. let consts = require('../../main/models/project_consts')
  9. module.exports={
  10. copyInstallationFeeFromLib:copyInstallationFeeFromLib,
  11. updateInstallationFee:updateInstallationFee,
  12. getData:getData
  13. };
  14. async function updateInstallationFee(projectID,updateData) {
  15. let result = {};
  16. let tasks = generateUpdateTask(projectID,updateData);
  17. if(tasks.length>0){
  18. result =await installationFeeModel.bulkWrite(tasks);
  19. }
  20. return result;
  21. }
  22. function generateUpdateTask(projectID,updateData) {
  23. let tasks = [];
  24. if(updateData instanceof Array){
  25. for(let ud of updateData){
  26. let [uquery,udoc] = createUpdateQuery(projectID,ud);
  27. let task={
  28. updateOne:{
  29. filter:uquery,
  30. update :udoc
  31. }
  32. };
  33. tasks.push(task);
  34. }
  35. } else {
  36. let [query,doc] = createUpdateQuery(projectID,updateData);
  37. let task={
  38. updateOne:{
  39. filter:query,
  40. update :doc
  41. }
  42. };
  43. tasks.push(task);
  44. }
  45. return tasks;
  46. }
  47. function createUpdateQuery(projectID,data) {
  48. let updateKey = data.type+'.ID';
  49. let query = {
  50. projectID:projectID,
  51. ID:data.ID,
  52. };
  53. query[updateKey] = data.itemID;
  54. let udoc = {};
  55. for(let property in data.doc){
  56. udoc[data.type+'.$.'+property] = data.doc[property];
  57. }
  58. return [query,udoc];
  59. }
  60. async function copyInstallationFeeFromLib(projectID,engineering_id) {
  61. //安装增加费用内嵌文档的方式
  62. let engineering = await engineeringModel.findById(engineering_id);
  63. let ration_lib = engineering.ration_lib;
  64. let installationFeeList = [];
  65. for(let rl of ration_lib){
  66. let installFeeItems = await installFeeItemModel.find({'rationRepId':rl.id});
  67. let installSections = await installSectionModel.find({'rationRepId':rl.id});
  68. let positionMap = {};
  69. let newInstallationFee = {
  70. libID:rl.id,
  71. libName:rl.name,
  72. projectID:projectID
  73. };
  74. newInstallationFee.ID = uuidV1();
  75. let create = false;
  76. if(installFeeItems && installFeeItems.length > 0) {//费用项
  77. create = true;
  78. let tem_installFeeItem = [];
  79. for(let ifee of installFeeItems){
  80. let tem_fee ={
  81. feeItem:ifee.feeItem,
  82. feeType:ifee.feeType,
  83. position:ifee.position,
  84. ID:ifee.ID
  85. };
  86. positionMap[ifee.ID] = ifee.position;//设置选取位置对应表,为给规项赋值
  87. tem_installFeeItem.push(tem_fee);
  88. }
  89. newInstallationFee.installFeeItem = tem_installFeeItem;
  90. }
  91. if(installSections && installSections.length > 0){//章节项
  92. create = true;
  93. let tem_installSections = [];
  94. let tem_feeRules = [];
  95. for(let isect of installSections){
  96. let tem_sec={
  97. ID:isect.ID,
  98. name:isect.name,
  99. feeItemId:isect.feeItemId
  100. };
  101. if(isect.feeRule && isect.feeRule.length > 0){//规则项
  102. tem_sec.feeRuleId = isect.feeRule[0].ID; //选中第一个
  103. for(let ifeeR of isect.feeRule){
  104. let tem_feeRule = {
  105. ID: ifeeR.ID,
  106. code: ifeeR.code,
  107. rule: ifeeR.rule,
  108. base: ifeeR.base,
  109. feeRate: ifeeR.feeRate,
  110. labour: ifeeR.labour,
  111. material: ifeeR.material,
  112. machine: ifeeR.machine,
  113. sectionId:isect.ID,
  114. feeItemId:isect.feeItemId,
  115. position:positionMap[isect.feeItemId]
  116. };
  117. tem_feeRules.push(tem_feeRule);
  118. }
  119. }else {
  120. tem_sec.feeRuleId = "";
  121. }
  122. tem_installSections.push(tem_sec);
  123. }
  124. newInstallationFee.installSection = tem_installSections;
  125. newInstallationFee.feeRule = tem_feeRules;
  126. }
  127. if(create==true){
  128. installationFeeList.push(newInstallationFee);
  129. }
  130. }
  131. console.log(installationFeeList);
  132. if(installationFeeList.length > 0){
  133. await installationFeeModel.insertMany(installationFeeList);
  134. }
  135. }
  136. function getData(projectID, callback) {
  137. installationFeeModel.find({'projectID': projectID}, (err, datas) => {
  138. if (err) {
  139. callback(1, '', null);
  140. } else {
  141. callback(0, consts.projectConst.INSTALLATION_FEE, datas);
  142. }
  143. })
  144. }