tpl_tree_node.js 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. /**
  2. * Created by Tony on 2017/5/31.
  3. */
  4. var mongoose = require('mongoose');
  5. var dbm = require("../../../config/db/db_manager");
  6. var db = dbm.getCfgConnection("Reports");
  7. var async = require("async");
  8. var rptTplDef = require("../../../public/rpt_tpl_def").getUtil();
  9. var Schema = mongoose.Schema;
  10. var TreeNodeSchema = new Schema({
  11. ID:Number,
  12. ParentID:Number,
  13. NextSiblingID:Number,
  14. grpType: Number, //建筑(const : 1)/公路(const 2)/其他 etc...
  15. nodeType: Number,//节点类型:树节点(枝) 或 模板节点(叶)
  16. tplType: Number, //概算、预算、招投标 etc...
  17. userId: String, //用户自定义模板用
  18. refId: Number, //
  19. name: String,
  20. isDeleted: Boolean
  21. });
  22. var TreeNodeModel = db.model("rpt_tpl_tree", TreeNodeSchema, "rpt_tpl_tree");
  23. var counter = require('../../../public/counter/counter');
  24. var RplTplTreeDAO = function(){};
  25. RplTplTreeDAO.prototype.getTplTreeNodes = function(grpType, userId, tplType, callback) {
  26. var filter = {"grpType": grpType, "$or": [{"isDeleted": null}, {"isDeleted": false} ]};
  27. if (userId) {
  28. filter.userId = userId;
  29. }
  30. if ((tplType && tplType !== rptTplDef.TplType.ALL)) {
  31. filter.tplType = tplType;
  32. }
  33. TreeNodeModel.find(filter, '-_id', function(err, data){
  34. if (err) {
  35. callback(true, null);
  36. } else callback(false,data);
  37. });
  38. };
  39. RplTplTreeDAO.prototype.updateTreeNodes = function(nodes, callback) {
  40. var functions = [];
  41. for (var i=0; i < nodes.length; i++) {
  42. functions.push((function(doc) {
  43. return function(cb) {
  44. TreeNodeModel.update({ID: doc.ID}, doc, cb);
  45. };
  46. })(nodes[i]));
  47. }
  48. async.parallel(functions, function(err, results) {
  49. callback(err, results);
  50. });
  51. };
  52. RplTplTreeDAO.prototype.removeNodes = function(nodeIds, preNodeId, preNodeNextId, callback){
  53. var functions = [];
  54. if (preNodeId != -1) {
  55. functions.push((function(nodeId, nextId) {
  56. return function(cb) {
  57. TreeNodeModel.update({ID: nodeId}, {"NextSiblingID": nextId}, cb);
  58. };
  59. })(preNodeId, preNodeNextId));
  60. }
  61. for (var i=0; i < nodeIds.length; i++) {
  62. functions.push((function(nodeId) {
  63. return function(cb) {
  64. TreeNodeModel.update({ID: nodeId}, {"isDeleted": true}, cb);
  65. };
  66. })(nodeIds[i]));
  67. }
  68. async.parallel(functions, function(err, results) {
  69. callback(err, results);
  70. });
  71. }
  72. RplTplTreeDAO.prototype.createTplTreeNode = function(nodeData, lastNodeId, callback) {
  73. counter.counterDAO.getIDAfterCount(counter.moduleName.report, 1, function(err, result){
  74. nodeData.ID = result.value.sequence_value;
  75. var node = new TreeNodeModel(nodeData);
  76. node.save(function (err, result) {
  77. if (err) {
  78. callback("树节点错误!", false);
  79. } else {
  80. if (lastNodeId > 0) {
  81. TreeNodeModel.update({ID: lastNodeId}, {"NextSiblingID": nodeData.ID}, function(err, rst){
  82. if (err) {
  83. callback("树节点错误!", false);
  84. } else {
  85. callback(false, result);
  86. }
  87. });
  88. } else callback(false, result);
  89. }
  90. });
  91. });
  92. };
  93. module.exports = new RplTplTreeDAO();