ration.js 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  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 Schema = mongoose.Schema;
  8. let deleteSchema = require('../../../public/models/delete_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. var rationAssItemSchema = mongoose.Schema({
  15. name: String,
  16. assistID: Number,
  17. assistCode: String,
  18. stdValue: Number,
  19. actualValue:Number,
  20. stepValue: String,
  21. decimal: Number,
  22. carryBit: String,
  23. minValue: String,
  24. maxValue: String
  25. }, { _id: false });
  26. let rationSchema = new Schema({
  27. ID: Number,
  28. projectID: Number,
  29. billsItemID: Number,
  30. serialNo: Number,
  31. libID: Number,
  32. code: String,
  33. name: String,
  34. maskName: String,
  35. caption: String,
  36. unit: String,
  37. quantity: String, // Decimal
  38. programID: Number,
  39. adjustState: String,
  40. content: String,
  41. rationProjName: String,
  42. comments: String,
  43. // 费用字段
  44. fees: [subSchema.feesSchema],
  45. // 标记字段
  46. flags: [subSchema.flagsSchema],
  47. deleteInfo: deleteSchema,
  48. rationAssList: [rationAssItemSchema]
  49. });
  50. let ration = db.model("ration", rationSchema, "ration");
  51. let baseModel = require('./base_model');
  52. class rationModel extends baseModel {
  53. constructor () {
  54. super(ration);
  55. }
  56. getData (projectID, callback) {
  57. ration.find({'$or': [{projectID: projectID, deleteInfo: null}, {projectID: projectID, 'deleteInfo.deleted': {$in: [null, false]}}]}, '-_id', function(err, datas){
  58. if (!err) {
  59. callback(0, projectConsts.RATION, datas);
  60. } else {
  61. callback(1, '', null);
  62. }
  63. });
  64. };
  65. save (user_id, datas, callback) {
  66. let functions = [];
  67. let data;
  68. function saveOne(doc) {
  69. return function (cb) {
  70. switch (doc.updateType) {
  71. case commonConsts.UT_UPDATE:
  72. ration.update({projectID: doc.updateData.projectID, ID: doc.updateData.ID}, doc.updateData, cb);
  73. break;
  74. case commonConsts.UT_CREATE:
  75. ration.create(doc.updateData, cb);
  76. break;
  77. case commonConsts.UT_DELETE:
  78. doc.updateData.deleteInfo = {deleted: true, deleteDateTime: new Date(), deleteBy: user_id};
  79. ration.update({projectID: doc.updateData.projectID, ID: doc.updateData.ID}, doc.updateData,{multi: true},cb);
  80. break;
  81. }
  82. }
  83. }
  84. for (let i = 0; i < datas.length; i++){
  85. data = datas[i];
  86. functions.push(saveOne(data));
  87. }
  88. async.parallel(functions, callback);
  89. };
  90. getItemTemplate (callback) {
  91. let data = new ration;
  92. /* to do: 需要根据标准配置库填充fees和flags字段,是否需要更多的参数? */
  93. callback(0, '', data);
  94. };
  95. allocIDs (IDstep, callback) {
  96. counter.counterDAO.getIDAfterCount(counter.moduleName.ration, IDStep, function(err, highID){
  97. let lowID = highID - IDStep + 1;
  98. callback(0, '', {lowID: lowID, highID: highID});
  99. });
  100. };
  101. };
  102. module.exports = new rationModel();