coe.js 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. /**
  2. * Created by CSL on 2017/5/3.
  3. * 系数表。
  4. */
  5. var mongoose = require("mongoose");
  6. var counter = require('../../../public/counter/counter');
  7. var coeListModel = mongoose.model("std_ration_lib_coe_list");
  8. var coeListDAO = function(){};
  9. coeListDAO.prototype.getCoe = function (data, callback) {
  10. coeListModel.findOne({
  11. "libID": data.libID,
  12. "ID": data.ID,
  13. "$or": [{"isDeleted": null}, {"isDeleted": false}]
  14. },
  15. function (err, doc) {
  16. if (err) callback("获取系数明细错误!", null)
  17. else callback(null, doc);
  18. })
  19. };
  20. coeListDAO.prototype.getCoeItemsByIDs = function (data, callback) {
  21. coeListModel.find({
  22. "libID": data.libID,
  23. "ID": {"$in":data.coeIDs}
  24. }, ["libID","ID", "serialNo","name","content","-_id"],
  25. function (err, doc) {
  26. if (err) callback("批量获取系数明细错误!", null)
  27. else callback(0, doc);
  28. })
  29. };
  30. coeListDAO.prototype.getCoeItemsByNos = function (data, callback) {
  31. coeListModel.find({
  32. "libID": data.libID,
  33. "serialNo": {"$in":data.coeNos}
  34. }, ["libID","ID","serialNo","name","content","-_id"],
  35. function (err, doc) {
  36. if (err) callback("批量获取系数明细错误!", null)
  37. else callback(0, doc);
  38. })
  39. };
  40. coeListDAO.prototype.getCoesByLibID = function (libID, callback) {
  41. coeListModel.find({ "libID": libID },
  42. function (err, doc) {
  43. if (err) callback("获取定额库系数表错误", null)
  44. else callback(0, doc);
  45. })
  46. };
  47. coeListDAO.prototype.saveToCoeList = function(data, callback) {
  48. var me = this;
  49. if (data.addArr.length > 0) {
  50. me.addItems(data.addArr, callback);
  51. };
  52. if (data.deleteArr.length > 0) {
  53. me.deleteItems(data.deleteArr, callback);
  54. };
  55. if (data.updateArr.length > 0) {
  56. me.updateItems(data.updateArr, callback);
  57. };
  58. };
  59. coeListDAO.prototype.addItems = function(addArr, callback) {
  60. if (addArr && addArr.length > 0) {
  61. counter.counterDAO.getIDAfterCount(counter.moduleName.coeList, addArr.length, function(err, result){
  62. var maxId = result.sequence_value;
  63. for (var i = 0; i < addArr.length; i++) {
  64. var obj = new coeListModel(addArr[i]);
  65. obj.ID = (maxId - (addArr.length - 1) + i);
  66. coeListModel.create(obj, function(err) {
  67. if (err) {
  68. callback(true, "add fail", null);
  69. } else {
  70. callback(false, "add success", obj.ID);
  71. };
  72. });
  73. };
  74. });
  75. } else {
  76. callback(true, "no source", null);
  77. };
  78. };
  79. coeListDAO.prototype.updateItems = function(updateArr, callback) {
  80. if (updateArr && updateArr.length > 0) {
  81. for (var i = 0; i < updateArr.length; i++) {
  82. var obj = updateArr[i];
  83. coeListModel.update({"libID": obj.libID, "ID": obj.ID}, updateArr[i], function(err) {
  84. if (err) {
  85. callback(true, "update fail", null);
  86. } else {
  87. callback(false, "update success", obj.ID);
  88. };
  89. });
  90. };
  91. } else {
  92. callback(true, "no source", null);
  93. };
  94. };
  95. coeListDAO.prototype.deleteItems = function(deleteArr, callback) {
  96. if (deleteArr && deleteArr.length > 0) {
  97. for (var i = 0; i < deleteArr.length; i++) {
  98. var obj = deleteArr[i];
  99. coeListModel.remove({"libID": obj.libID, "ID": obj.ID}, function(err) {
  100. if (err) {
  101. callback(true, "delete fail", null);
  102. } else {
  103. callback(false, "delete success", obj.ID);
  104. };
  105. });
  106. };
  107. } else {
  108. callback(true, "no source", null);
  109. };
  110. };
  111. module.exports = new coeListDAO();