bills.js 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  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("./billsSubSchemas");
  7. var Schema = mongoose.Schema;
  8. var counter = require("../../../public/counter/counter.js");
  9. var billsSchema = new Schema({
  10. ID: Number,
  11. ParentID: Number,
  12. NextSiblingID: Number,
  13. projectID: Number,
  14. serialNo: Number,
  15. chapterID: Number,
  16. code: String,
  17. fullCode: String,
  18. name: String,
  19. unit: String,
  20. quantity: String, // Decimal
  21. programID: Number,
  22. comments: String,
  23. // 调价
  24. xs_Labour: String, // Decimal
  25. xs_Material: String, // Decimal
  26. xs_Machine: String, // Decimal
  27. xs_FeeRate: String, // Decimal
  28. xs_LabourPrice: String, // Decimal
  29. xs_MaterialPrice: String, // Decimal
  30. xs_MachinePrice: String, // Decimal
  31. isTender_Labour: Boolean,
  32. isTender_Material: Boolean,
  33. isTender_Machine: Boolean,
  34. tenderTargetPrice: String, // Decimal
  35. tenderTargetUnitPrice: String, // Decimal
  36. // 费用字段
  37. fees: [subSchema.feesSchema],
  38. // 标记字段
  39. flags: [subSchema.flagsSchema]
  40. });
  41. var bills = db.model("bills", billsSchema);
  42. var billsDAO = function(){};
  43. billsDAO.prototype.getData = function(projectID, callback){
  44. bills.find({projectID: projectID}, function(err, datas){
  45. if (!err) {
  46. callback(0, '', datas);
  47. } else {
  48. callback(1, '', null);
  49. };
  50. });
  51. };
  52. billsDAO.prototype.AddBillsFromTemplate = function (datas, callback) {
  53. bills.collection.insert(datas, callback);
  54. };
  55. billsDAO.prototype.save = function(datas, callback){
  56. var data, errList = [], updateLength = 0;
  57. var updateFunc = function (err, errData) {
  58. if (err){
  59. errList.push(errData);
  60. };
  61. };
  62. if (datas){
  63. for (var i = 0; i < datas.length; i++){
  64. data = datas[i];
  65. if (data.updateType === 'update') {
  66. delete data.updateType;
  67. data.save(updateFunc);
  68. } else if (data.updateType === 'create') {
  69. delete data.updateType;
  70. data.save(updateFunc);
  71. } else if (data.updateType === 'delete') {
  72. delete data.updateType;
  73. data.remove(updateFunc);
  74. };
  75. };
  76. if (errList.length > 0){
  77. callback(1, errList);
  78. } else {
  79. callback(0, null);
  80. };
  81. };
  82. };
  83. billsDAO.prototype.getItemTemplate = function(callback){
  84. var data = new bills;
  85. /* to do: 需要根据标准配置库填充fees和flags字段,是否需要更多的参数? */
  86. callback(0, '', data);
  87. };
  88. billsDAO.prototype.allocIDs = function(IDStep, callback){
  89. counter.counterDAO.getIDAfterCount(counter.moduleName.bills, IDStep, function(err, highID){
  90. var lowID = highID - IDStep + 1;
  91. callback(0, '', {lowID: lowID, highID: highID});
  92. });
  93. };
  94. module.exports = new billsDAO();