ration.js 3.1 KB

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