bills.js 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. /**
  2. * Created by jimiz on 2017/4/1.
  3. */
  4. var mongoose = require("mongoose");
  5. var db = require("../db/project_db");
  6. var subSchema = require("./bills_sub_schemas");
  7. var deleteSchema = require('../../../public/models/delete_schema');
  8. var Schema = mongoose.Schema;
  9. var async = require("async");
  10. var counter = require("../../../public/counter/counter.js");
  11. var consts = require('./project_consts');
  12. var projectConsts = consts.projectConst;
  13. var commonConsts = consts.commonConst;
  14. var billsSchema = new Schema({
  15. ID: Number,
  16. ParentID: Number,
  17. NextSiblingID: Number,
  18. projectID: Number,
  19. serialNo: Number,
  20. chapterID: Number,
  21. code: String,
  22. fullCode: String,
  23. name: String,
  24. unit: String,
  25. quantity: String, // Decimal
  26. programID: Number,
  27. comments: String,
  28. // 调价
  29. xs_Labour: String, // Decimal
  30. xs_Material: String, // Decimal
  31. xs_Machine: String, // Decimal
  32. xs_FeeRate: String, // Decimal
  33. xs_LabourPrice: String, // Decimal
  34. xs_MaterialPrice: String, // Decimal
  35. xs_MachinePrice: String, // Decimal
  36. isTender_Labour: Boolean,
  37. isTender_Material: Boolean,
  38. isTender_Machine: Boolean,
  39. tenderTargetPrice: String, // Decimal
  40. tenderTargetUnitPrice: String, // Decimal
  41. // 费用字段
  42. fees: [subSchema.feesSchema],
  43. // 标记字段
  44. flags: [subSchema.flagsSchema],
  45. deleteInfo: deleteSchema
  46. });
  47. var bills = db.model("bills", billsSchema);
  48. var billsDAO = function(){};
  49. billsDAO.prototype.getData = function(projectID, callback){
  50. bills.find({'$or': [{projectID: projectID, deleteInfo: null}, {projectID: projectID, 'deleteInfo.deleted': {$in: [null, false]}}]}, '-_id', function(err, datas){
  51. if (!err) {
  52. callback(0, projectConsts.BILLS, datas);
  53. } else {
  54. callback(1, projectConsts.BILLS, null);
  55. };
  56. });
  57. };
  58. // get All Project Bills, include deleted
  59. billsDAO.prototype.getProjectBills = function (projectId, callback) {
  60. if (callback) {
  61. bills.find({projectID: projectId}, '-_id').exec()
  62. .then(function (result, err) {
  63. if (err) {
  64. callback(1, '找不到模板', null);
  65. } else {
  66. callback(0, '', template);
  67. }
  68. });
  69. return null;
  70. } else {
  71. return bills.find({projectID: projectId}, '-_id').exec();
  72. }
  73. }
  74. billsDAO.prototype.AddBillsFromTemplate = function (datas, callback) {
  75. bills.collection.insert(datas, callback);
  76. };
  77. billsDAO.prototype.save = function(user_id, datas, callback){
  78. var functions = [];
  79. var data;
  80. function saveOne(doc) {
  81. /* switch (doc.type) {
  82. case commonConsts.UT_CREATE:
  83. return function (callback) {
  84. bills.update({projectID: doc.data.projectID, ID: doc.data.ID}, doc.data, callback);
  85. };
  86. break;
  87. case commonConsts.UT_CREATE:
  88. return function (callback) {
  89. bills.create(doc.data, callback);
  90. };
  91. break;
  92. case commonConsts.UT_DELETE:
  93. return function (callback) {
  94. doc.data.deleteInfo = {deleted: true, deleteDateTime: new Date(), deleteBy: user_id};
  95. bills.update({projectID: doc.data.projectID, ID: doc.data.ID}, doc.data, callback);
  96. }
  97. break;
  98. }*/
  99. return function (cb) {
  100. switch (doc.updateType) {
  101. case commonConsts.UT_UPDATE:
  102. bills.update({projectID: doc.updateData.projectID, ID: doc.updateData.ID}, doc.updateData, cb);
  103. break;
  104. case commonConsts.UT_CREATE:
  105. bills.create(doc.updateData, cb);
  106. break;
  107. case commonConsts.UT_DELETE:
  108. doc.updateData.deleteInfo = {deleted: true, deleteDateTime: new Date(), deleteBy: user_id};
  109. bills.update({projectID: doc.updateData.projectID, ID: doc.updateData.ID}, doc.updateData, cb);
  110. break;
  111. }
  112. }
  113. }
  114. for (var i = 0; i < datas.length; i++){
  115. data = datas[i];
  116. functions.push(saveOne(data));
  117. }
  118. async.parallel(functions, callback);
  119. };
  120. billsDAO.prototype.getItemTemplate = function(callback){
  121. var data = new bills;
  122. /* to do: 需要根据标准配置库填充fees和flags字段,是否需要更多的参数? */
  123. callback(0, '', data);
  124. };
  125. billsDAO.prototype.allocIDs = function(IDStep, callback){
  126. counter.counterDAO.getIDAfterCount(counter.moduleName.bills, IDStep, function(err, highID){
  127. var lowID = highID - IDStep + 1;
  128. callback(0, '', {lowID: lowID, highID: highID});
  129. });
  130. };
  131. module.exports = new billsDAO();