bills.js 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205
  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('../../common/const/bills_fixed');
  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) {
  33. this.model.find({'$or': [{projectID: projectID, deleteInfo: null}, {projectID: projectID, 'deleteInfo.deleted': {$in: [null, false]}}]}, '-_id', function(err, datas){
  34. if (!err) {
  35. callback(0, projectConsts.BILLS, datas);
  36. } else {
  37. callback(1, projectConsts.BILLS, null);
  38. };
  39. });
  40. };
  41. save (user_id, datas, callback) {
  42. let functions = [];
  43. let data;
  44. function saveOne(doc) {
  45. return function (cb) {
  46. switch (doc.updateType) {
  47. case commonConsts.UT_UPDATE:
  48. async.parallel([ // CSL,2018.01.10 如果是总造价清单,要将4个汇总金额写到projects表中
  49. function (asyncCB) {
  50. bills.update({projectID: doc.updateData.projectID, ID: doc.updateData.ID,deleteInfo: null}, doc.updateData, asyncCB);
  51. },
  52. function (asyncCB) {
  53. if (doc.updateData.summaryFees){
  54. // console.log('%%%%%%%%%%%%%%%%%%% ' + doc.updateData.projectID + ' | ' + JSON.stringify(doc.updateData.summaryFees));
  55. projectModel.update({ID: doc.updateData.projectID}, {"summaryFees": doc.updateData.summaryFees}, asyncCB);
  56. }else {
  57. asyncCB(null, {});
  58. };
  59. }
  60. ], function(err,result){
  61. cb(err, {});
  62. });
  63. break;
  64. case commonConsts.UT_CREATE:
  65. bills.create(doc.updateData, cb);
  66. break;
  67. case commonConsts.UT_DELETE:
  68. doc.updateData.deleteInfo = {deleted: true, deleteDateTime: new Date(), deleteBy: user_id};
  69. //bills.update({projectID: doc.updateData.projectID, ID: doc.updateData.ID}, doc.updateData, cb);
  70. bills.deleteOne({projectID: doc.updateData.projectID, ID: doc.updateData.ID},cb);
  71. break;
  72. }
  73. }
  74. }
  75. for (let i = 0; i < datas.length; i++){
  76. data = datas[i];
  77. functions.push(saveOne(data));
  78. quantity_detial.quantityEditChecking(data,'bills',functions);
  79. }
  80. async.parallel(functions, function(err,result){
  81. let returnData = {
  82. moduleName:'bills',
  83. data:result
  84. };
  85. callback(err, returnData);
  86. });
  87. };
  88. getItemTemplate (callback) {
  89. let data = new bills;
  90. /* to do: 需要根据标准配置库填充fees和flags字段,是否需要更多的参数? */
  91. callback(0, '', data);
  92. };
  93. allocIDs (IDStep, callback) {
  94. counter.counterDAO.getIDAfterCount(counter.moduleName.bills, IDStep, function(err, highID){
  95. let lowID = highID - IDStep + 1;
  96. callback(0, '', {lowID: lowID, highID: highID});
  97. });
  98. };
  99. //zhong 2017-9-1
  100. updateCharacterContent(findSet, updateObj, txtObj, callback) {
  101. let updateSet = {};
  102. updateSet[updateObj.field] = updateObj.updateArr;
  103. if(txtObj && typeof txtObj !== 'undefined'){
  104. updateSet[txtObj.field] = txtObj.text;
  105. }
  106. bills.update(findSet, updateSet, function (err) {
  107. if(err){
  108. callback(1, '更新失败');
  109. }
  110. else{
  111. callback(0, '更新成功');
  112. }
  113. });
  114. };
  115. async updateBills(updateDatas){
  116. let bulk = [];
  117. for(let updateData of updateDatas){
  118. bulk.push({updateOne: {filter: updateData.findSet, update: {$set: updateData.updateData}}});
  119. }
  120. await bills.bulkWrite(bulk);
  121. };
  122. async updateBill(findSet, updateData) {
  123. let update = {};
  124. if (!updateData instanceof Array) {
  125. return false;
  126. }
  127. for (const tmp of updateData) {
  128. if (tmp === undefined) {
  129. continue;
  130. }
  131. update[tmp.field] = tmp.value;
  132. }
  133. if (Object.keys(update).length <= 0) {
  134. return false;
  135. }
  136. return bills.update(findSet, update);
  137. };
  138. async importBills(bills){
  139. let operations = [];
  140. for(let bill of bills){
  141. operations.push({insertOne: {document: bill}});
  142. }
  143. return await this.model.bulkWrite(operations);
  144. }
  145. //删除清单节点的所有子节点及其他附带数据
  146. async deepDeleteBill(bills, userID){
  147. let bill_ids = [],
  148. ration_ids = [];
  149. let me = this;
  150. async function findBillsChildren(bills){
  151. if(bills.length > 0){
  152. let ids = getIDs(bills);
  153. bill_ids = bill_ids.concat(ids);
  154. let findBills = await me.model.find({ParentID: {$in: ids}, deleteInfo: null});
  155. await findBillsChildren(findBills);
  156. }
  157. }
  158. function getIDs(datas){
  159. let ids = [];
  160. for(let data of datas){
  161. ids.push(data.ID);
  162. }
  163. return ids;
  164. }
  165. await findBillsChildren(bills);
  166. //剔除第一个节点
  167. bill_ids = bill_ids.slice(1);
  168. //获取删除清单下的所有定额
  169. let rations = await rationModel.find({billsItemID: {$in: bill_ids}, deleteInfo: null}, 'ID');
  170. ration_ids = ration_ids.concat(getIDs(rations));
  171. //deep delete datas
  172. let deleteInfo = {deleted: true, deleteDateTime: new Date(), deleteBy: userID};
  173. if(bill_ids.length > 0){
  174. //删除bills
  175. await me.model.updateMany({ID: {$in: bill_ids}, deleteInfo: null}, {$set: {deleteInfo: deleteInfo}});
  176. //删除bill-quantity_detail
  177. await quantityDelModel.deleteMany({billID: {$in: bill_ids}});
  178. }
  179. if(ration_ids.length > 0){
  180. //删除rations
  181. await rationModel.updateMany({ID: {$in: ration_ids}, deleteInfo: null}, {$set: {deleteInfo: deleteInfo}});
  182. //删除ration-glj
  183. await rationGljModel.deleteMany({rationID: {$in: ration_ids}});
  184. //删除ration-coe
  185. await rationCoeModel.deleteMany({rationID: {$in: ration_ids}});
  186. //删除ration-installation
  187. await rationInstModel.deleteMany({rationID: {$in: ration_ids}});
  188. //删除ration-quantity_detail
  189. await quantityDelModel.deleteMany({rationID: {$in: ration_ids}});
  190. }
  191. return {bill: bill_ids, ration: ration_ids};
  192. }
  193. }
  194. module.exports = new billsModel();