123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317 |
- /**
- * Created by CSL on 2017-10-22.
- */
- const uuidV1 = require('uuid/v1');
- let logger = require("../../../logs/log_helper").logger;
- let mongoose = require('mongoose');
- let stdCalcProgramsModel = mongoose.model('std_calc_programs');
- let projectCalcProgramsModel = mongoose.model('calc_programs');
- let gatherCalcProgramsModel = mongoose.model('gather_calc_programs');
- let EngineeringLibModel = require("../../users/models/engineering_lib_model");
- let _ = require("lodash");
- let consts = require('../models/project_consts');
- let projectConsts = consts.projectConst;
- module.exports = {
- newProjectCalcProgramFile: newProjectCalcProgramFile,
- getProjectCalcProgramFile: getProjectCalcProgramFile,
- getStdCalcProgramFile: getStdCalcProgramFile,
- getData: getData,
- save: save,
- saveCalcItem: saveCalcItem,
- saveCalcItems: saveCalcItems,
- updateTemplate: updateTemplate,
- updateTemplateFile: updateTemplateFile,
- addTemplate: addTemplate,
- deleteTemplate: deleteTemplate,
- saveGatherCalcPrograms: saveGatherCalcPrograms,
- getGatherFees: getGatherFees
- };
- async function newProjectCalcProgramFile(data) {
- logger.info(`Create new CalcProgram file for project : ${data.ID}`);
- let rst = null;
- // let egnrModel = new EngineeringLibModel();
- // let egnr = await egnrModel.getEngineering(data.property.engineering_id);
- // if(!egnr) return rst;
- // let valid_CP_libs = egnr._doc.program_lib;
- // if (valid_CP_libs == undefined || valid_CP_libs.length == 0) return rst;
- // 绑定多个计算程序标准文件时,默认取第一个作为标准模板。
- // let stdCP = await getStdCalcProgramFile(valid_CP_libs[0].id);
- let stdCP = await getStdCalcProgramFile(data.property.calcProgram.id);
- let doc = {
- ID: uuidV1(),
- projectID: data.ID,
- name: data.name,
- libID: stdCP.ID,
- libName: stdCP.libName,
- templates: stdCP.templates
- };
- await projectCalcProgramsModel.create(doc);
- rst = {ID: doc.ID, name: doc.name};
- return rst;
- };
- async function getProjectCalcProgramFile(ID) {
- let projCP = await projectCalcProgramsModel.findOne({ID: ID});
- return projCP;
- };
- async function getStdCalcProgramFile(libID) {
- let stdCP = await stdCalcProgramsModel.findOne({ID: libID});
- return stdCP;
- };
- // 统一的 getData() 方法供project调用
- function getData(projectID, callback) {
- projectCalcProgramsModel.findOne({projectID: projectID}, '-_id', function (err, datas) {
- if (!err) {
- // 旧项目没有计算程序文件,默认给它生成一个。
- if (!datas) {
- logger.info(`Create a calcProgram file for old project : ${projectID}`);
- getStdCalcProgramFile(1).then(function (stdCP) {
- let doc = {
- ID: uuidV1(),
- projectID: projectID,
- name: '[旧项目补计算程序文件]',
- libID: stdCP.ID,
- libName: stdCP.libName,
- templates: stdCP.templates
- };
- projectCalcProgramsModel.create(doc);
- callback(0, projectConsts.CALC_PROGRAM, stdCP);
- });
- } else {
- callback(0, projectConsts.CALC_PROGRAM, datas);
- }
- ;
- } else {
- callback(1, projectConsts.CALC_PROGRAM, null);
- }
- ;
- });
- };
- // 统一的 save() 方法供project调用
- function save(user_id, datas, callback) {
- let returnData = {
- moduleName: 'calc_program',
- data: {}
- };
- projectCalcProgramsModel.update({"projectID": 553}, {"libName": "goo—test"}, callback(null, returnData));
- }
- // saveCalcItem({projectID: 597, templatesID: 4, calcItem: calcItem})
- function saveCalcItem(dataObj, callback) {
- dataObj = JSON.parse(dataObj);
- projectCalcProgramsModel.findOne({projectID: dataObj.projectID}, function (err, data) {
- if (!err) {
- for (let i = 0; i < data.templates.length; i++) {
- if (data.templates[i].ID == dataObj.templatesID) {
- for (let j = 0; j < data.templates[i].calcItems.length; j++) {
- if (data.templates[i].calcItems[j].ID == dataObj.calcItem.ID) {
- data.templates[i].calcItems[j] = dataObj.calcItem;
- break;
- }
- }
- break;
- }
- }
- data.save(function (err) {
- if (err) {
- callback(1, '本条计算规则保存失败');
- } else {
- callback(0, '本条计算规则保存成功');
- }
- });
- }
- else {
- callback(1, '没有找到计算程序文件');
- }
- });
- };
- // { projectID: projectID, calcItems: [{templatesID, calcItem}] }
- function saveCalcItems(datas, callback) {
- let datasObj = JSON.parse(datas);
- projectCalcProgramsModel.findOne({projectID: datasObj.projectID}, function (err, data) {
- if (!err) {
- for (let cI of datasObj.calcItems) {
- for (let i = 0; i < data.templates.length; i++) {
- if (data.templates[i].ID == cI.templatesID) {
- for (let j = 0; j < data.templates[i].calcItems.length; j++) {
- if (data.templates[i].calcItems[j].ID == cI.calcItem.ID) {
- data.templates[i].calcItems[j] = cI.calcItem;
- break;
- }
- }
- break;
- }
- }
- }
- data.save(function (err) {
- if (err) {
- callback(1, '本条计算规则保存失败');
- } else {
- callback(0, '本条计算规则保存成功');
- }
- });
- }
- else {
- callback(1, '没有找到计算程序文件');
- }
- });
- };
- // { projectID: 3, ID: 5, name: '建筑工程', custom: true, calcItems: [{},{}] } 其中name、custom、calcItems可选,其它必填。
- // 插入一条计算规则、删除一条计算规则,则整套计算规则整个传入更新,仅calcItems指定值。
- // 修改文件名称,则只传入name。
- function updateTemplate(dataObj, callback) {
- dataObj = JSON.parse(dataObj);
- projectCalcProgramsModel.findOne({projectID: dataObj.projectID}, function (err, data) {
- if (!err) {
- for (let i = 0; i < data.templates.length; i++) {
- if (data.templates[i].ID == dataObj.ID) {
- if (dataObj.name)
- data.templates[i].name = dataObj.name;
- if (dataObj.custom)
- data.templates[i].custom = dataObj.custom;
- if (dataObj.calcItems)
- data.templates[i].calcItems = dataObj.calcItems;
- break;
- }
- ;
- }
- ;
- data.save(function (err) {
- if (err) {
- callback(1, '计算模板保存失败');
- } else {
- callback(0, '计算模板保存成功');
- }
- });
- }
- else {
- callback(1, '没有找到计算程序文件');
- }
- });
- };
- // 一次性替换所有模板:用于切换模板文件。(这里实际上只替换了所有模板,基本信息如projectID、name等保留)
- // {projectID: 2706, libID: 2}
- async function updateTemplateFile(dataObj, callback) {
- dataObj = JSON.parse(dataObj);
- let stdCP = await getStdCalcProgramFile(dataObj.libID);
- projectCalcProgramsModel.findOne({projectID: dataObj.projectID}, function (err, data) {
- if (!err) {
- data.templates = stdCP.templates;
- data.save(function (err) {
- if (err) {
- callback(1, '计算模板文件保存失败', null);
- } else {
- callback(0, '计算模板文件保存成功', stdCP.templates);
- }
- });
- }
- else {
- callback(1, '没有找到项目的计算模板文件', null);
- }
- });
- };
- // { projectID: 1233, ID: 19, name: '建筑工程2', custom: true, calcItems: [{},{}] }
- function addTemplate(dataObj, callback) {
- dataObj = JSON.parse(dataObj);
- projectCalcProgramsModel.update({projectID: dataObj.projectID},
- {
- $push: {
- templates: {
- "ID": dataObj.ID,
- "name": dataObj.name,
- "calcItems": dataObj.calcItems,
- "custom": dataObj.custom
- }
- }
- },
- function (err) {
- if (!err) {
- callback(0, '计算模板创建成功');
- }
- else {
- callback(1, '计算模板创建失败');
- }
- }
- );
- };
- // { projectID: 1233, ID: 19}
- function deleteTemplate(dataObj, callback) {
- dataObj = JSON.parse(dataObj);
- projectCalcProgramsModel.update({projectID: dataObj.projectID},
- {
- $pull: {
- templates: {
- "ID": dataObj.ID
- }
- }
- },
- function (err) {
- if (!err) {
- callback(0, '计算模板删除成功');
- }
- else {
- callback(1, '计算模板删除失败');
- }
- }
- );
- };
- async function saveGatherCalcPrograms(dataObj, callback) {
- dataObj = JSON.parse(dataObj);
- await gatherCalcProgramsModel.findOne({projectID: dataObj.projectID}, function (err, data) {
- if (data == null) { // 第一次保存,找不到
- let doc = {
- projectID: dataObj.projectID,
- totalFee: dataObj.totalFee,
- calcPrograms: dataObj.calcPrograms
- };
- gatherCalcProgramsModel.create(doc, function (err) {
- if (err) {
- callback(1, '汇总计算程序创建失败' + err, null);
- } else {
- callback(0, '成功', doc.projectID);
- }
- });
- }
- else {
- data.totalFee = dataObj.totalFee;
- data.calcPrograms = dataObj.calcPrograms;
- data.save(function (err) {
- if (err) {
- callback(1, '汇总计算程序保存失败' + err, null);
- } else {
- callback(0, '成功', data.projectID);
- }
- });
- }
- })
- };
- // 报表用多单位工程的费用汇总数据。
- async function getGatherFees(projectIDsArr) {
- let rst = await gatherCalcProgramsModel.find({projectID: {"$in": projectIDsArr}}, ["-_id"]).lean();
- // console.log(rst);
- return rst;
- }
- // for test
- // getGatherFees([77218, 5097]);
- // getGatherFees([77297, 79097]);
- // let s = '{"projectID":2164,"ID":23,"name":"建筑工程7","custom":true,"calcItems":[]}';
- // addTemplate(s, function(data){console.log('add successfull!')});
- // let s = '{"projectID":2164,"ID":15}';
- // deleteTemplate(s, function(data){console.log('delete successfull!')});
- // let s = '{"projectID":2164, "totalFee": "23", "calcPrograms":[]}';
- // saveGatherCalcPrograms(s, function(data){console.log(data)});
|