ration.js 3.4 KB

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