bills.js 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  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(datas, callback){
  78. var functions = [];
  79. var data;
  80. function saveOne(doc) {
  81. return function (cb) {
  82. switch (doc.updateType) {
  83. case commonConsts.UT_UPDATE:
  84. bills.update({ID: doc.ID}, doc, cb);
  85. break;
  86. case commonConsts.UT_CREATE:
  87. bills.create(doc, cb);
  88. break;
  89. case commonConsts.UT_DELETE:
  90. /* 假删除
  91. var item = new bills(doc);
  92. item.remove(cb);
  93. */
  94. }
  95. }
  96. }
  97. for (var i = 0; i < datas.length; i++){
  98. data = datas[i];
  99. functions.push(saveOne(data));
  100. }
  101. async.parallel(functions, callback);
  102. };
  103. billsDAO.prototype.getItemTemplate = function(callback){
  104. var data = new bills;
  105. /* to do: 需要根据标准配置库填充fees和flags字段,是否需要更多的参数? */
  106. callback(0, '', data);
  107. };
  108. billsDAO.prototype.allocIDs = function(IDStep, callback){
  109. counter.counterDAO.getIDAfterCount(counter.moduleName.bills, IDStep, function(err, highID){
  110. var lowID = highID - IDStep + 1;
  111. callback(0, '', {lowID: lowID, highID: highID});
  112. });
  113. };
  114. module.exports = new billsDAO();