bills.js 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272
  1. /**
  2. * Created by jimiz on 2017/4/1.
  3. */
  4. let mongoose = require("mongoose");
  5. let async = require("async");
  6. let counter = require("../../../public/counter/counter.js");
  7. let consts = require('./project_consts');
  8. let projectConsts = consts.projectConst;
  9. let commonConsts = consts.commonConst;
  10. let quantity_detial = require('../facade/quantity_detail_facade');
  11. let projectModel = mongoose.model('projects');
  12. let rationModel = mongoose.model('ration');
  13. let rationGljModel = mongoose.model('ration_glj');
  14. let rationCoeModel = mongoose.model('ration_coe');
  15. let rationInstModel = mongoose.model('ration_installation');
  16. let quantityDelModel = mongoose.model('quantity_detail');
  17. const { fixedFlag } = require('../../../public/common_constants');
  18. let bills = mongoose.model("bills");
  19. let baseModel = require('./base_model');
  20. const uuidV1 = require('uuid/v1');
  21. const billType = {
  22. DXFY: 1,//大项费用
  23. FB: 2,//分部
  24. FX: 3,//分项
  25. BILL: 4,//清单
  26. BX: 5//补项
  27. };
  28. class billsModel extends baseModel {
  29. constructor() {
  30. super(bills);
  31. };
  32. getData(projectID, callback, isReport = false) {
  33. //已经改成真删除了 {'$or': [{projectID: projectID, deleteInfo: null}, {projectID: projectID, 'deleteInfo.deleted': {$in: [null, false]}}]}
  34. this.model.find({ projectID: projectID }, '-_id', function (err, datas) {
  35. if (!err) {
  36. if (isReport) { // 调价中间件机制
  37. for (let i = 0; i < datas.length; i++) {
  38. let fees = datas[i]._doc.fees;
  39. if (fees) {
  40. for (let i = 0; i < fees.length; i++) {
  41. let doc = fees[i]._doc;
  42. if (doc) {
  43. if (doc.tenderTotalFee) doc.totalFee = doc.tenderTotalFee;
  44. if (doc.tenderUnitFee) doc.unitFee = doc.tenderUnitFee;
  45. }
  46. }
  47. }
  48. }
  49. };
  50. callback(0, projectConsts.BILLS, datas);
  51. } else {
  52. callback(1, projectConsts.BILLS, null);
  53. };
  54. });
  55. };
  56. save(user_id, datas, callback) {
  57. let functions = [];
  58. let data;
  59. function saveOne(doc) {
  60. return function (cb) {
  61. switch (doc.updateType) {
  62. case commonConsts.UT_UPDATE:
  63. async.parallel([ // CSL,2018.01.10 如果是总造价清单,要将4个汇总金额写到projects表中
  64. function (asyncCB) {
  65. bills.update({ projectID: doc.updateData.projectID, ID: doc.updateData.ID, deleteInfo: null }, doc.updateData, asyncCB);
  66. },
  67. function (asyncCB) {
  68. if (doc.updateData.summaryFees) {
  69. // console.log('%%%%%%%%%%%%%%%%%%% ' + doc.updateData.projectID + ' | ' + JSON.stringify(doc.updateData.summaryFees));
  70. projectModel.update({ ID: doc.updateData.projectID }, { "summaryFees": doc.updateData.summaryFees }, asyncCB);
  71. } else {
  72. asyncCB(null, {});
  73. };
  74. }
  75. ], function (err, result) {
  76. cb(err, {});
  77. });
  78. break;
  79. case commonConsts.UT_CREATE:
  80. bills.create(doc.updateData, cb);
  81. break;
  82. case commonConsts.UT_DELETE:
  83. doc.updateData.deleteInfo = { deleted: true, deleteDateTime: new Date(), deleteBy: user_id };
  84. //bills.update({projectID: doc.updateData.projectID, ID: doc.updateData.ID}, doc.updateData, cb);
  85. bills.deleteOne({ projectID: doc.updateData.projectID, ID: doc.updateData.ID }, cb);
  86. break;
  87. }
  88. }
  89. }
  90. for (let i = 0; i < datas.length; i++) {
  91. data = datas[i];
  92. functions.push(saveOne(data));
  93. quantity_detial.quantityEditChecking(data, 'bills', functions);
  94. }
  95. async.parallel(functions, function (err, result) {
  96. let returnData = {
  97. moduleName: 'bills',
  98. data: result
  99. };
  100. callback(err, returnData);
  101. });
  102. };
  103. getItemTemplate(callback) {
  104. let data = new bills;
  105. /* to do: 需要根据标准配置库填充fees和flags字段,是否需要更多的参数? */
  106. callback(0, '', data);
  107. };
  108. allocIDs(IDStep, callback) {
  109. counter.counterDAO.getIDAfterCount(counter.moduleName.bills, IDStep, function (err, highID) {
  110. let lowID = highID - IDStep + 1;
  111. callback(0, '', { lowID: lowID, highID: highID });
  112. });
  113. };
  114. //zhong 2017-9-1
  115. updateCharacterContent(findSet, updateObj, txtObj, callback) {
  116. let updateSet = {};
  117. updateSet[updateObj.field] = updateObj.updateArr;
  118. if (txtObj && typeof txtObj !== 'undefined') {
  119. updateSet[txtObj.field] = txtObj.text;
  120. }
  121. bills.update(findSet, updateSet, function (err) {
  122. if (err) {
  123. callback(1, '更新失败');
  124. }
  125. else {
  126. callback(0, '更新成功');
  127. }
  128. });
  129. };
  130. async updateBills(updateDatas) {
  131. let bulk = [];
  132. for (let updateData of updateDatas) {
  133. bulk.push({ updateOne: { filter: updateData.findSet, update: { $set: updateData.updateData } } });
  134. }
  135. await bills.bulkWrite(bulk);
  136. };
  137. async updateBill(findSet, updateData) {
  138. let update = {};
  139. if (!updateData instanceof Array) {
  140. return false;
  141. }
  142. for (const tmp of updateData) {
  143. if (tmp === undefined) {
  144. continue;
  145. }
  146. update[tmp.field] = tmp.value;
  147. }
  148. if (Object.keys(update).length <= 0) {
  149. return false;
  150. }
  151. return bills.update(findSet, update);
  152. };
  153. async importBills(bills) {
  154. let operations = [];
  155. for (let bill of bills) {
  156. operations.push({ insertOne: { document: bill } });
  157. }
  158. return await this.model.bulkWrite(operations);
  159. }
  160. //删除清单节点的所有子节点及其他附带数据
  161. async deepDeleteBill(bills, userID, projectID) {
  162. let bill_ids = [],
  163. ration_ids = [];
  164. let me = this;
  165. function getIDs(datas) {
  166. let ids = [];
  167. for (let data of datas) {
  168. ids.push(data.ID);
  169. }
  170. return ids;
  171. }
  172. /*
  173. async function findBillsChildren(bills){
  174. if(bills.length > 0){
  175. let ids = getIDs(bills);
  176. bill_ids = bill_ids.concat(ids);
  177. let findBills = await me.model.find({ParentID: {$in: ids}, deleteInfo: null});
  178. await findBillsChildren(findBills);
  179. }
  180. }
  181. await findBillsChildren(bills);
  182. /*/
  183. // 优化:一次性获取所有清单,再一个个剔除,剩下bills下所有的子清单,省的递归查询
  184. const allBills = await me.model.find({ projectID: projectID }, '-_id');
  185. function getAllSubIDs(topDatas) {
  186. bill_ids = bill_ids.concat(getIDs(topDatas));
  187. function _getSubs(datas, rstBills) {
  188. let subIDs = []
  189. for (let bill of allBills) {
  190. for (let data of datas) {
  191. if (data.ID === bill.ParentID) {
  192. subIDs.push(bill.ID);
  193. rstBills.push(bill);
  194. }
  195. }
  196. }
  197. return subIDs;
  198. }
  199. let chkBills = [];
  200. let chkIds = _getSubs(topDatas, chkBills);
  201. while (chkIds.length > 0) {
  202. bill_ids = bill_ids.concat(chkIds);
  203. let subBills = [];
  204. chkIds = _getSubs(chkBills, subBills);
  205. chkBills = subBills;
  206. }
  207. }
  208. getAllSubIDs(bills);
  209. //*/
  210. //剔除第一个节点
  211. bill_ids = bill_ids.slice(1);
  212. //获取删除清单下的所有定额
  213. let rations = await rationModel.find({ billsItemID: { $in: bill_ids }, deleteInfo: null }, 'ID');
  214. ration_ids = ration_ids.concat(getIDs(rations));
  215. //deep delete datas
  216. let deleteInfo = { deleted: true, deleteDateTime: new Date(), deleteBy: userID };
  217. if (bill_ids.length > 0) {
  218. //删除bills
  219. await me.model.deleteMany({ ID: { $in: bill_ids } });
  220. //删除bill-quantity_detail
  221. await quantityDelModel.deleteMany({ billID: { $in: bill_ids } });
  222. }
  223. if (ration_ids.length > 0) {
  224. //删除rations
  225. await rationModel.deleteMany({ ID: { $in: ration_ids } });
  226. //删除ration-glj
  227. await rationGljModel.deleteMany({ rationID: { $in: ration_ids } });
  228. //删除ration-coe
  229. await rationCoeModel.deleteMany({ rationID: { $in: ration_ids } });
  230. //删除ration-quantity_detail
  231. await quantityDelModel.deleteMany({ rationID: { $in: ration_ids } });
  232. }
  233. return { bill: bill_ids, ration: ration_ids };
  234. }
  235. async newDeepDeleteBill(bill_ids, ration_ids) {
  236. let me = this;
  237. //deep delete datas
  238. if (bill_ids.length > 0) {
  239. //删除bills
  240. await me.model.deleteMany({ ID: { $in: bill_ids } });
  241. //删除bill-quantity_detail
  242. await quantityDelModel.deleteMany({ billID: { $in: bill_ids } });
  243. }
  244. if (ration_ids.length > 0) {
  245. //删除rations
  246. await rationModel.deleteMany({ ID: { $in: ration_ids } });
  247. //删除ration-glj
  248. await rationGljModel.deleteMany({ rationID: { $in: ration_ids } });
  249. //删除ration-coe
  250. await rationCoeModel.deleteMany({ rationID: { $in: ration_ids } });
  251. //删除ration-installation
  252. await rationInstModel.deleteMany({ rationID: { $in: ration_ids } });
  253. //删除ration-quantity_detail
  254. await quantityDelModel.deleteMany({ rationID: { $in: ration_ids } });
  255. }
  256. return { bill: bill_ids, ration: ration_ids };
  257. }
  258. }
  259. module.exports = new billsModel();