/** * Created by Tony on 2017/5/4. * 工料机的总库,根据不同定额库分类,参考原gljList表 */ var mongoose = require("mongoose"); var dbm = require("../../../config/db/db_manager"); var db = dbm.getCfgConnection("scConstruct"); var async = require("async"); var Schema = mongoose.Schema; var gljClassSchema = mongoose.Schema({ repositoryId: Number, ID: Number, ParentID: Number, NextSiblingID: Number, Name: String, isDeleted: Boolean }); var gljSchema = mongoose.Schema({ repositoryId: Number, ID:Number, //以下是基于已有access库 code: String, name: String, specs: String, unit: String, shortName: String, basePrice: Number, gljClass: Number, //这个是UI显示上的详细分类,对应gljTypeSchema gljType: Number //人工,材料,机械 }); var gljTypeModel = db.model("std_ration_lib_glj_type",gljClassSchema, "std_ration_lib_glj_type"); var gljItemModel = db.model("std_ration_lib_glj_list",gljSchema, "std_ration_lib_glj_list"); var repositoryMap = require('./repository_map'); var counter = require('../../../public/counter/counter'); let moment = require('moment'); import {gljModel, gljClassModel} from "../../std_glj_lib/models/schemas"; var gljItemDAO = function(){}; gljItemDAO.prototype.getGljTypes = function(gljLibID, callback){ gljClassModel.find({"repositoryId": gljLibID, "$or": [{"isDeleted": null}, {"isDeleted": false} ]},function(err,data){ if(data.length) callback(false,data); else if(err) callback("获取工料机类型错误!",false) else callback(false,false); }) }; gljItemDAO.prototype.getGljItemsByRep = function(repositoryId,callback){ gljModel.find({"repositoryId": repositoryId},function(err,data){ if(err) callback(true, "") else callback(false,data); }) }; gljItemDAO.prototype.getGljItemByType = function(repositoryId, type, callback){ gljModel.find({"repositoryId": repositoryId, "gljType": type},function(err,data){ if(err) callback(true, "") else callback(false, data); }) }; gljItemDAO.prototype.getGljItem = function(repositoryId, code, callback){ gljModel.find({"repositoryId": repositoryId, "code": code},function(err,data){ if(err) callback(true, "") else callback(false, data); }) }; gljItemDAO.prototype.getGljItems = function(gljIds, callback){ gljModel.find({"ID": {"$in": gljIds}},function(err,data){ if(err) callback(true, "") else callback(false, data); }) }; gljItemDAO.prototype.getGljItemsByCode = function(repositoryId, codes, callback){ gljModel.find({"repositoryId": repositoryId,"code": {"$in": codes}},function(err,data){ if(err) callback(true, "") else callback(false, data); }) }; gljItemDAO.prototype.mixUpdateGljItems = function(repId, lastOpr, updateItems, addItems, rIds, callback) { var me = this; if (updateItems.length == 0 && rIds.length == 0) { me.addGljItems(repId, lastOpr, addItems, callback); } else { me.removeGljItems(repId, lastOpr, rIds, function(err, message, docs) { me.updateGljItems(repId, lastOpr, updateItems, function(err, results){ if (err) { callback(true, "Fail to update", false); } else { if (addItems && addItems.length > 0) { me.addGljItems(repId, lastOpr, addItems, callback); } else { callback(false, "Save successfully", results); } } }); }); } }; gljItemDAO.prototype.removeGljItems = function(repId, lastOpr, rIds, callback) { if (rIds && rIds.length > 0) { gljItemModel.collection.remove({ID: {$in: rIds}}, null, function(err, docs){ if (err) { callback(true, "Fail to remove", false); } else { repositoryMap.updateOprArr({ID: repId}, lastOpr, moment(Date.now()).format('YYYY-MM-DD HH:mm:ss'), function (err) { if(err){ callback(true, "Fail to update operator", false); } else{ callback(false, "Remove successfully", docs); } }); } }) } else { callback(false, "No records were deleted!", null); } }; gljItemDAO.prototype.addGljItems = function(repId, lastOpr, items, callback) { if (items && items.length > 0) { counter.counterDAO.getIDAfterCount(counter.moduleName.GLJ, items.length, function(err, result){ var maxId = result.value.sequence_value; var arr = []; for (var i = 0; i < items.length; i++) { var obj = new gljItemModel(items[i]); obj.ID = (maxId - (items.length - 1) + i); obj.repositoryId = repId; arr.push(obj); } gljItemModel.collection.insert(arr, null, function(err, docs){ if (err) { callback(true, "Fail to add", false); } else { repositoryMap.updateOprArr({ID: repId}, lastOpr, moment(Date.now()).format('YYYY-MM-DD HH:mm:ss'), function (err) { if(err){ callback(true, "Fail to update Operator", false); } else{ callback(false, "Add successfully", docs); } }); } }) }); } else { callback(true, "No source", false); } }; gljItemDAO.prototype.updateGljItems = function(repId, lastOpr, items, callback) { var functions = []; for (var i=0; i < items.length; i++) { functions.push((function(doc) { return function(cb) { var filter = {}; if (doc.ID) { filter.ID = doc.ID; } else { filter.repositoryId = repId; filter.code = doc.code; } gljItemModel.update(filter, doc, cb); }; })(items[i])); } functions.push((function () { return function (cb) { repositoryMap.updateOprArr({ID: repId}, lastOpr, moment(Date.now()).format('YYYY-MM-DD HH:mm:ss'), function (err) { if(err){ cb(err); } else{ cb(null); } }) } })()); async.parallel(functions, function(err, results) { callback(err, results); }); }; gljItemDAO.prototype.updateNodes = function(repId, lastOpr, nodes, callback) { var functions = []; for (var i=0; i < nodes.length; i++) { functions.push((function(doc) { return function(cb) { gljTypeModel.update({ID: doc.ID}, doc, cb); }; })(nodes[i])); } functions.push((function () { return function (cb) { repositoryMap.updateOprArr({ID: repId}, lastOpr, moment(Date.now()).format('YYYY-MM-DD HH:mm:ss'), function (err) { if(err){ cb(err); } else{ cb(null); } }) } })()); async.parallel(functions, function(err, results) { callback(err, results); }); }; gljItemDAO.prototype.removeNodes = function(repId, lastOpr, nodeIds, preNodeId, preNodeNextId, callback){ var functions = []; if (preNodeId != -1) { functions.push((function(nodeId, nextId) { return function(cb) { gljTypeModel.update({ID: nodeId}, {"NextSiblingID": nextId}, cb); }; })(preNodeId, preNodeNextId)); } for (var i=0; i < nodeIds.length; i++) { functions.push((function(nodeId) { return function(cb) { gljTypeModel.update({ID: nodeId}, {"isDeleted": true}, cb); }; })(nodeIds[i])); } functions.push((function () { return function (cb) { repositoryMap.updateOprArr({ID: repId}, lastOpr, moment(Date.now()).format('YYYY-MM-DD HH:mm:ss'), function (err) { if(err){ cb(err); } else{ cb(null); } }) } })()); async.parallel(functions, function(err, results) { callback(err, results); }); }; gljItemDAO.prototype.createNewNode = function(repId, lastOpr, lastNodeId, nodeData, callback) { return counter.counterDAO.getIDAfterCount(counter.moduleName.GLJ, 1, function(err, result){ nodeData.repositoryId = repId; nodeData.ID = result.value.sequence_value; var node = new gljTypeModel(nodeData); async.parallel([ function (cb) { node.save(function (err, result) { if (err) { cb("章节树ID错误!", false); } else { if (lastNodeId > 0) { gljTypeModel.update({ID: lastNodeId}, {"NextSiblingID": nodeData.ID}, function(err, rst){ if (err) { cb("章节树ID错误!", false); } else { cb(false, result); } }); } else cb(false, result); } }); }, function (cb) { repositoryMap.updateOprArr({ID: repId}, lastOpr, moment(Date.now()).format('YYYY-MM-DD HH:mm:ss'), function (err) { if(err){ cb(err); } else{ cb(null); } }) } ], function (err, result) { if(err){ callback(true, "章节树错误!", false); } else{ callback(false, '', result[0]); } }) }); }; module.exports = new gljItemDAO();