ration.js 3.5 KB

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