coe.js 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  1. /**
  2. * Created by CSL on 2017/5/3.
  3. * 系数表。
  4. */
  5. var mongoose = require("mongoose");
  6. var dbm = require("../../../config/db/db_manager");
  7. var db = dbm.getCfgConnection("scConstruct");
  8. var counter = require('../../../public/counter/counter');
  9. var coeSchema = mongoose.Schema({
  10. coeType: String, // 系数类型,指作用范围:
  11. // 单个(如:111量0.001)、人工类、材料类、机械类、全部(如:定额×0.925)。
  12. gljID: Number, // 要调整的工料机ID(当coeType=0时有效)
  13. operator: String, // 运算符(*、+、-、=)
  14. amount: String, // 调整的量
  15. _id: false
  16. });
  17. var coeListSchema = mongoose.Schema({
  18. libID: Number, // 所属定额定ID
  19. ID: Number, // 系数ID(流水号ID)
  20. serialNo: Number, //编号
  21. name: String, // 名称
  22. content: String, // 说明
  23. coes: [coeSchema]
  24. }, {versionKey: false});
  25. var coeListModel = db.model("std_ration_lib_coe_list",coeListSchema, "std_ration_lib_coe_list")
  26. var coeListDAO = function(){};
  27. coeListDAO.prototype.getCoe = function (data, callback) {
  28. coeListModel.findOne({
  29. "libID": data.libID,
  30. "ID": data.ID,
  31. "$or": [{"isDeleted": null}, {"isDeleted": false}]
  32. },
  33. function (err, doc) {
  34. if (err) callback("获取系数明细错误!", null)
  35. else callback(null, doc);
  36. })
  37. };
  38. coeListDAO.prototype.getCoeItemsByIDs = function (data, callback) {
  39. coeListModel.find({
  40. "libID": data.libID,
  41. "ID": {"$in":data.coeIDs}
  42. }, ["libID","ID", "serialNo","name","content","-_id"],
  43. function (err, doc) {
  44. if (err) callback("批量获取系数明细错误!", null)
  45. else callback(0, doc);
  46. })
  47. };
  48. coeListDAO.prototype.getCoeItemsByNos = function (data, callback) {
  49. coeListModel.find({
  50. "libID": data.libID,
  51. "serialNo": {"$in":data.coeNos}
  52. }, ["libID","ID","serialNo","name","content","-_id"],
  53. function (err, doc) {
  54. if (err) callback("批量获取系数明细错误!", null)
  55. else callback(0, doc);
  56. })
  57. };
  58. coeListDAO.prototype.getCoesByLibID = function (libID, callback) {
  59. coeListModel.find({ "libID": libID },
  60. function (err, doc) {
  61. if (err) callback("获取定额库系数表错误", null)
  62. else callback(0, doc);
  63. })
  64. };
  65. coeListDAO.prototype.saveToCoeList = function(data, callback) {
  66. var me = this;
  67. if (data.addArr.length > 0) {
  68. me.addItems(data.addArr, callback);
  69. };
  70. if (data.deleteArr.length > 0) {
  71. me.deleteItems(data.deleteArr, callback);
  72. };
  73. if (data.updateArr.length > 0) {
  74. me.updateItems(data.updateArr, callback);
  75. };
  76. };
  77. coeListDAO.prototype.addItems = function(addArr, callback) {
  78. if (addArr && addArr.length > 0) {
  79. counter.counterDAO.getIDAfterCount(counter.moduleName.coeList, addArr.length, function(err, result){
  80. var maxId = result.value.sequence_value;
  81. for (var i = 0; i < addArr.length; i++) {
  82. var obj = new coeListModel(addArr[i]);
  83. obj.ID = (maxId - (addArr.length - 1) + i);
  84. coeListModel.create(obj, function(err) {
  85. if (err) {
  86. callback(true, "add fail", null);
  87. } else {
  88. callback(false, "add success", obj.ID);
  89. };
  90. });
  91. };
  92. });
  93. } else {
  94. callback(true, "no source", null);
  95. };
  96. };
  97. coeListDAO.prototype.updateItems = function(updateArr, callback) {
  98. if (updateArr && updateArr.length > 0) {
  99. for (var i = 0; i < updateArr.length; i++) {
  100. var obj = updateArr[i];
  101. coeListModel.update({"libID": obj.libID, "ID": obj.ID}, updateArr[i], function(err) {
  102. if (err) {
  103. callback(true, "update fail", null);
  104. } else {
  105. callback(false, "update success", obj.ID);
  106. };
  107. });
  108. };
  109. } else {
  110. callback(true, "no source", null);
  111. };
  112. };
  113. coeListDAO.prototype.deleteItems = function(deleteArr, callback) {
  114. if (deleteArr && deleteArr.length > 0) {
  115. for (var i = 0; i < deleteArr.length; i++) {
  116. var obj = deleteArr[i];
  117. coeListModel.remove({"libID": obj.libID, "ID": obj.ID}, function(err) {
  118. if (err) {
  119. callback(true, "delete fail", null);
  120. } else {
  121. callback(false, "delete success", obj.ID);
  122. };
  123. });
  124. };
  125. } else {
  126. callback(true, "no source", null);
  127. };
  128. };
  129. module.exports = new coeListDAO();