installation_facade.js 6.1 KB

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