bills.js 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  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.getBills = function(projectId, callback){
  44. Projects.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.updateBills = function(datas, callback){
  53. var data, errList = [], updateLength = 0;
  54. var updateFunc = function (err, errData) {
  55. if (err){
  56. errList.push(errData);
  57. };
  58. };
  59. if (datas){
  60. for (var i = 0; i < datas.length; i++){
  61. data = datas[i];
  62. if (data.updateType === 'update') {
  63. delete data.updateType;
  64. data.save(updateFunc);
  65. } else if (data.updateType === 'create') {
  66. delete data.updateType;
  67. data.save(updateFunc);
  68. } else if (data.updateType === 'delete') {
  69. delete data.updateType;
  70. data.remove(updateFunc);
  71. };
  72. };
  73. if (errList.length > 0){
  74. callback(1, 'update error.', errList);
  75. } else {
  76. callback(0, '', null);
  77. };
  78. };
  79. };
  80. billsDAO.prototype.getBillsItemTemplate = function(callback){
  81. var data = new bills;
  82. /* to do: 需要根据标准配置库填充fees和flags字段,是否需要更多的参数? */
  83. callback(0, '', data);
  84. };
  85. const
  86. IDStep = 50, IDModule = 'bills';
  87. billsDAO.prototype.allocIDs = function(callback){
  88. var lowID, highID;
  89. counter.getIDAfterCount(IDModule, IDStep, function(highID, err){});
  90. lowID = highID - IDStep + 1;
  91. callback(0, '', {lowID, highID});
  92. };
  93. module.exports = new billsDAO();