| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596 | /** * Created by jimiz on 2017/4/1. */let mongoose = require("mongoose");let async = require("async");let counter = require("../../../public/counter/counter.js");let consts = require('./project_consts');let projectConsts = consts.projectConst;let commonConsts = consts.commonConst;let quantity_detial = require('../facade/quantity_detail_facade');let ration = mongoose.model("ration");let baseModel = require('./base_model');class rationModel extends baseModel {    constructor () {        super(ration);    }    getQuery(projectID){        return {'$or': [{projectID: projectID, deleteInfo: null}, {projectID: projectID, 'deleteInfo.deleted': {$in: [null, false]}}]}    }    getData (projectID, callback, isReport = false) {        ration.find(this.getQuery(projectID), '-_id', function(err, datas){            if (!err) {                if (isReport){                    for (let i = 0; i < datas.length; i++) {                        if (datas[i]._doc.rationQuantityCoe !== null && datas[i]._doc.rationQuantityCoe !== undefined && datas[i]._doc.rationQuantityCoe !== '' && datas[i]._doc.rationQuantityCoe !== 0) {                            //如有调价,则需要改动                            datas[i]._doc.quantity = parseFloat(datas[i]._doc.quantity) * parseFloat(datas[i]._doc.rationQuantityCoe);                            datas[i]._doc.contain = parseFloat(datas[i]._doc.contain) * parseFloat(datas[i]._doc.rationQuantityCoe);                        }                        let fees = datas[i]._doc.fees;                        if (fees){                            for (let i = 0; i < fees.length; i++) {                                let doc = fees[i]._doc;                                if (doc){                                    if (doc.tenderTotalFee) doc.totalFee = doc.tenderTotalFee;                                    if (doc.tenderUnitFee) doc.unitFee = doc.tenderUnitFee;                                }                            }                        }                    }                };                callback(0, projectConsts.RATION, datas);            } else {                callback(1, '', null);            }        });    };    async getDataSync(projectID){        return await  ration.find(this.getQuery(projectID), '-_id');    }    save (user_id, datas, callback) {        let functions = [];        let data;        function saveOne(doc) {            return function (cb) {                switch (doc.updateType) {                    case commonConsts.UT_UPDATE:                        ration.update({projectID: doc.updateData.projectID, ID: doc.updateData.ID, deleteInfo: null}, doc.updateData, cb);                        break;                    case commonConsts.UT_CREATE:                        ration.create(doc.updateData, cb);                        break;                    case commonConsts.UT_DELETE:                        doc.updateData.deleteInfo = {deleted: true, deleteDateTime: new Date(), deleteBy: user_id};                        ration.update({projectID: doc.updateData.projectID, ID: doc.updateData.ID}, doc.updateData,{multi: true},cb);                        break;                }            }        }        for (let i = 0; i < datas.length; i++){            data = datas[i];            functions.push(saveOne(data));            quantity_detial.quantityEditChecking(data,'ration',functions);        }        async.parallel(functions, callback);    };    getItemTemplate (callback) {        let data = new ration;        /* to do: 需要根据标准配置库填充fees和flags字段,是否需要更多的参数? */        callback(0, '', data);    };    allocIDs (IDstep, callback) {        counter.counterDAO.getIDAfterCount(counter.moduleName.ration, IDStep, function(err, highID){            let lowID = highID - IDStep + 1;            callback(0, '', {lowID: lowID, highID: highID});        });    };};module.exports = new rationModel();
 |