ration.js 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. /**
  2. * Created by jimiz on 2017/4/1.
  3. */
  4. let mongoose = require("mongoose");
  5. let async = require("async");
  6. let counter = require("../../../public/counter/counter.js");
  7. let consts = require('./project_consts');
  8. let projectConsts = consts.projectConst;
  9. let commonConsts = consts.commonConst;
  10. let quantity_detial = require('../facade/quantity_detail_facade');
  11. let ration = mongoose.model("ration");
  12. let baseModel = require('./base_model');
  13. class rationModel extends baseModel {
  14. constructor () {
  15. super(ration);
  16. }
  17. getQuery(projectID){
  18. return {'$or': [{projectID: projectID, deleteInfo: null}, {projectID: projectID, 'deleteInfo.deleted': {$in: [null, false]}}]}
  19. }
  20. getData (projectID, callback, isReport = false) {
  21. // console.log('ration projectID: ' + projectID);
  22. ration.find(this.getQuery(projectID), '-_id', function(err, datas){
  23. if (!err) {
  24. // console.log('result datas.length: ' + datas.length);
  25. if (isReport){ // 调价中间件机制
  26. for (let i = 0; i < datas.length; i++) {
  27. let coe = datas[i]._doc.rationQuantityCoe;
  28. if ((!coe) || (coe == '0')) coe = 1;
  29. //如有调价,则需要改动
  30. datas[i]._doc.quantity = parseFloat(datas[i]._doc.quantity) * parseFloat(coe);
  31. datas[i]._doc.contain = parseFloat(datas[i]._doc.contain) * parseFloat(coe);
  32. let fees = datas[i]._doc.fees;
  33. if (fees){
  34. for (let i = 0; i < fees.length; i++) {
  35. let doc = fees[i]._doc;
  36. if (doc){
  37. if (doc.tenderTotalFee) doc.totalFee = doc.tenderTotalFee;
  38. if (doc.tenderUnitFee) doc.unitFee = doc.tenderUnitFee;
  39. }
  40. }
  41. }
  42. }
  43. };
  44. callback(0, projectConsts.RATION, datas);
  45. } else {
  46. callback(1, '', null);
  47. }
  48. });
  49. };
  50. async getDataSync(projectID){
  51. return await ration.find(this.getQuery(projectID), '-_id');
  52. }
  53. save (user_id, datas, callback) {
  54. let functions = [];
  55. let data;
  56. function saveOne(doc) {
  57. return function (cb) {
  58. switch (doc.updateType) {
  59. case commonConsts.UT_UPDATE:
  60. ration.update({projectID: doc.updateData.projectID, ID: doc.updateData.ID, deleteInfo: null}, doc.updateData, cb);
  61. break;
  62. case commonConsts.UT_CREATE:
  63. ration.create(doc.updateData, cb);
  64. break;
  65. case commonConsts.UT_DELETE:
  66. doc.updateData.deleteInfo = {deleted: true, deleteDateTime: new Date(), deleteBy: user_id};
  67. ration.update({projectID: doc.updateData.projectID, ID: doc.updateData.ID}, doc.updateData,{multi: true},cb);
  68. break;
  69. }
  70. }
  71. }
  72. for (let i = 0; i < datas.length; i++){
  73. data = datas[i];
  74. functions.push(saveOne(data));
  75. quantity_detial.quantityEditChecking(data,'ration',functions);
  76. }
  77. async.parallel(functions, callback);
  78. };
  79. getItemTemplate (callback) {
  80. let data = new ration;
  81. /* to do: 需要根据标准配置库填充fees和flags字段,是否需要更多的参数? */
  82. callback(0, '', data);
  83. };
  84. allocIDs (IDstep, callback) {
  85. counter.counterDAO.getIDAfterCount(counter.moduleName.ration, IDStep, function(err, highID){
  86. let lowID = highID - IDStep + 1;
  87. callback(0, '', {lowID: lowID, highID: highID});
  88. });
  89. };
  90. };
  91. module.exports = new rationModel();