bills.js 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187
  1. /**
  2. * Created by jimiz on 2017/4/1.
  3. */
  4. let mongoose = require("mongoose");
  5. let db = require("../db/project_db");
  6. let subSchema = require("./bills_sub_schemas");
  7. let deleteSchema = require('../../../public/models/delete_schema');
  8. let Schema = mongoose.Schema;
  9. let async = require("async");
  10. let counter = require("../../../public/counter/counter.js");
  11. let consts = require('./project_consts');
  12. let projectConsts = consts.projectConst;
  13. let commonConsts = consts.commonConst;
  14. let quantity_detial = require('../facade/quantity_detail_facade');
  15. let projectModel = require('../../pm/models/project_schema');
  16. let billsSchema = new Schema({
  17. ID: String,
  18. ParentID: String,
  19. NextSiblingID: String,
  20. projectID: Number,
  21. serialNo: Number,
  22. chapterID: Number,
  23. billsLibId: Number,
  24. code: String,
  25. fullCode: String,
  26. type:{type: Number,default:4},//1 :大项费用 2:分部 3分项 4清单;5补项
  27. isAdd:{type: Number,default:0},//1 true 0 false是否新增
  28. name: String,
  29. unit: String,
  30. quantity: String, // Decimal
  31. quantityEXP:String,//工程量表达式
  32. feeRateID:Number,
  33. feeRate:String,
  34. isFromDetail:{type: Number,default:0},//1 true 0 false
  35. programID: Number,
  36. calcBase: String,
  37. calcBaseValue: String, // 计算基数表达式的值
  38. // 工程量计算规则
  39. ruleText: String,
  40. // 说明
  41. comments: String,
  42. // 调价
  43. xs_Labour: String, // Decimal
  44. xs_Material: String, // Decimal
  45. xs_Machine: String, // Decimal
  46. xs_FeeRate: String, // Decimal
  47. xs_LabourPrice: String, // Decimal
  48. xs_MaterialPrice: String, // Decimal
  49. xs_MachinePrice: String, // Decimal
  50. isTender_Labour: Boolean,
  51. isTender_Material: Boolean,
  52. isTender_Machine: Boolean,
  53. tenderTargetPrice: String, // Decimal
  54. tenderTargetUnitPrice: String, // Decimal
  55. tenderTargetUnitPrice: String, // Decimal
  56. //工作内容//zhong 2017-8-31
  57. jobContentText: String, //清单工作内容列显示文本, 减少第一次拉数据时的循环次数
  58. jobContent: [subSchema.jobContentSchema],
  59. //项目特征
  60. itemCharacterText: String,//清单项目特征列显示文本
  61. itemCharacter: [subSchema.itemCharacterSchema],
  62. // 费用字段
  63. fees: [subSchema.feesSchema],
  64. // 标记字段
  65. flags: [subSchema.flagsSchema],
  66. installationKey:String,//用来记录安装增加费的关联字段
  67. deleteInfo: deleteSchema,
  68. });
  69. let bills = db.model("bills", billsSchema);
  70. let baseModel = require('./base_model');
  71. class billsModel extends baseModel {
  72. constructor () {
  73. super(bills);
  74. };
  75. getData (projectID, callback) {
  76. this.model.find({'$or': [{projectID: projectID, deleteInfo: null}, {projectID: projectID, 'deleteInfo.deleted': {$in: [null, false]}}]}, '-_id', function(err, datas){
  77. if (!err) {
  78. callback(0, projectConsts.BILLS, datas);
  79. } else {
  80. callback(1, projectConsts.BILLS, null);
  81. };
  82. });
  83. };
  84. save (user_id, datas, callback) {
  85. let functions = [];
  86. let data;
  87. function saveOne(doc) {
  88. return function (cb) {
  89. switch (doc.updateType) {
  90. case commonConsts.UT_UPDATE:
  91. async.parallel([ // CSL,2018.01.10 如果是总造价清单,要将4个汇总金额写到projects表中
  92. function (asyncCB) {
  93. bills.update({projectID: doc.updateData.projectID, ID: doc.updateData.ID,deleteInfo: null}, doc.updateData, asyncCB);
  94. },
  95. function (asyncCB) {
  96. if (doc.updateData.summaryFees){
  97. // console.log('%%%%%%%%%%%%%%%%%%% ' + doc.updateData.projectID + ' | ' + JSON.stringify(doc.updateData.summaryFees));
  98. projectModel.update({ID: doc.updateData.projectID}, {"summaryFees": doc.updateData.summaryFees}, asyncCB);
  99. }else {
  100. asyncCB(null, {});
  101. };
  102. }
  103. ], function(err,result){
  104. cb(err, {});
  105. });
  106. break;
  107. case commonConsts.UT_CREATE:
  108. bills.create(doc.updateData, cb);
  109. break;
  110. case commonConsts.UT_DELETE:
  111. doc.updateData.deleteInfo = {deleted: true, deleteDateTime: new Date(), deleteBy: user_id};
  112. bills.update({projectID: doc.updateData.projectID, ID: doc.updateData.ID}, doc.updateData, cb);
  113. break;
  114. }
  115. }
  116. }
  117. for (let i = 0; i < datas.length; i++){
  118. data = datas[i];
  119. functions.push(saveOne(data));
  120. quantity_detial.quantityEditChecking(data,'bills',functions);
  121. }
  122. async.parallel(functions, function(err,result){
  123. let returnData = {
  124. moduleName:'bills',
  125. data:result
  126. };
  127. callback(err, returnData);
  128. });
  129. };
  130. getItemTemplate (callback) {
  131. let data = new bills;
  132. /* to do: 需要根据标准配置库填充fees和flags字段,是否需要更多的参数? */
  133. callback(0, '', data);
  134. };
  135. allocIDs (IDStep, callback) {
  136. counter.counterDAO.getIDAfterCount(counter.moduleName.bills, IDStep, function(err, highID){
  137. let lowID = highID - IDStep + 1;
  138. callback(0, '', {lowID: lowID, highID: highID});
  139. });
  140. };
  141. //zhong 2017-9-1
  142. updateCharacterContent(findSet, updateObj, txtObj, callback) {
  143. let updateSet = {};
  144. updateSet[updateObj.field] = updateObj.updateArr;
  145. if(txtObj && typeof txtObj !== 'undefined'){
  146. updateSet[txtObj.field] = txtObj.text;
  147. }
  148. bills.update(findSet, updateSet, function (err) {
  149. if(err){
  150. callback(1, '更新失败');
  151. }
  152. else{
  153. callback(0, '更新成功');
  154. }
  155. });
  156. };
  157. async updateBill(findSet, updateData) {
  158. let update = {};
  159. if (!updateData instanceof Array) {
  160. return false;
  161. }
  162. for (const tmp of updateData) {
  163. if (tmp === undefined) {
  164. continue;
  165. }
  166. update[tmp.field] = tmp.value;
  167. }
  168. if (Object.keys(update).length <= 0) {
  169. return false;
  170. }
  171. return bills.update(findSet, update);
  172. };
  173. }
  174. module.exports = new billsModel();