|
@@ -1,18 +1,18 @@
|
|
|
/**
|
|
|
* Created by jimiz on 2017/4/1.
|
|
|
*/
|
|
|
-var mongoose = require("mongoose");
|
|
|
-var db = require("../db/project_db");
|
|
|
-var subSchema = require("./bills_sub_schemas");
|
|
|
-var deleteSchema = require('../../../public/models/delete_schema');
|
|
|
-var Schema = mongoose.Schema;
|
|
|
-var async = require("async");
|
|
|
-var counter = require("../../../public/counter/counter.js");
|
|
|
-var consts = require('./project_consts');
|
|
|
-var projectConsts = consts.projectConst;
|
|
|
-var commonConsts = consts.commonConst;
|
|
|
+let mongoose = require("mongoose");
|
|
|
+let db = require("../db/project_db");
|
|
|
+let subSchema = require("./bills_sub_schemas");
|
|
|
+let deleteSchema = require('../../../public/models/delete_schema');
|
|
|
+let Schema = mongoose.Schema;
|
|
|
+let async = require("async");
|
|
|
+let counter = require("../../../public/counter/counter.js");
|
|
|
+let consts = require('./project_consts');
|
|
|
+let projectConsts = consts.projectConst;
|
|
|
+let commonConsts = consts.commonConst;
|
|
|
|
|
|
-var billsSchema = new Schema({
|
|
|
+let billsSchema = new Schema({
|
|
|
ID: Number,
|
|
|
ParentID: Number,
|
|
|
NextSiblingID: Number,
|
|
@@ -39,6 +39,7 @@ var billsSchema = new Schema({
|
|
|
isTender_Machine: Boolean,
|
|
|
tenderTargetPrice: String, // Decimal
|
|
|
tenderTargetUnitPrice: String, // Decimal
|
|
|
+ tenderTargetUnitPrice: String, // Decimal
|
|
|
// 费用字段
|
|
|
fees: [subSchema.feesSchema],
|
|
|
// 标记字段
|
|
@@ -46,98 +47,73 @@ var billsSchema = new Schema({
|
|
|
deleteInfo: deleteSchema
|
|
|
});
|
|
|
|
|
|
-var bills = db.model("bills", billsSchema);
|
|
|
-
|
|
|
-var billsDAO = function(){};
|
|
|
+let bills = db.model("bills", billsSchema);
|
|
|
+let baseModel = require('./base_model');
|
|
|
|
|
|
-billsDAO.prototype.getData = function(projectID, callback){
|
|
|
- bills.find({'$or': [{projectID: projectID, deleteInfo: null}, {projectID: projectID, 'deleteInfo.deleted': {$in: [null, false]}}]}, '-_id', function(err, datas){
|
|
|
- if (!err) {
|
|
|
- callback(0, projectConsts.BILLS, datas);
|
|
|
- } else {
|
|
|
- callback(1, projectConsts.BILLS, null);
|
|
|
- };
|
|
|
- });
|
|
|
-};
|
|
|
+class billsModel extends baseModel {
|
|
|
+ constructor () {
|
|
|
+ super(bills);
|
|
|
+ };
|
|
|
|
|
|
-// get All Project Bills, include deleted
|
|
|
-billsDAO.prototype.getProjectBills = function (projectId, callback) {
|
|
|
- if (callback) {
|
|
|
- bills.find({projectID: projectId}, '-_id').exec()
|
|
|
- .then(function (result, err) {
|
|
|
- if (err) {
|
|
|
- callback(1, '找不到模板', null);
|
|
|
- } else {
|
|
|
- callback(0, '', result);
|
|
|
- }
|
|
|
- });
|
|
|
- return null;
|
|
|
- } else {
|
|
|
- return bills.find({projectID: projectId}, '-_id').exec();
|
|
|
- }
|
|
|
-}
|
|
|
+ /**
|
|
|
+ *
|
|
|
+ * @param {Number} projectId
|
|
|
+ * @returns {Promise}
|
|
|
+ */
|
|
|
+ getProjectData (projectId) {
|
|
|
+ return this.getQueryData({"projectID": projectId}, '-_id');
|
|
|
+ };
|
|
|
|
|
|
-billsDAO.prototype.AddBillsFromTemplate = function (datas, callback) {
|
|
|
- bills.collection.insert(datas, callback);
|
|
|
-};
|
|
|
+ getData (projectID, callback) {
|
|
|
+ this.model.find({'$or': [{projectID: projectID, deleteInfo: null}, {projectID: projectID, 'deleteInfo.deleted': {$in: [null, false]}}]}, '-_id', function(err, datas){
|
|
|
+ if (!err) {
|
|
|
+ callback(0, projectConsts.BILLS, datas);
|
|
|
+ } else {
|
|
|
+ callback(1, projectConsts.BILLS, null);
|
|
|
+ };
|
|
|
+ });
|
|
|
+ };
|
|
|
|
|
|
-billsDAO.prototype.save = function(user_id, datas, callback){
|
|
|
- var functions = [];
|
|
|
- var data;
|
|
|
+ save (user_id, datas, callback) {
|
|
|
+ let functions = [];
|
|
|
+ let data;
|
|
|
|
|
|
- function saveOne(doc) {
|
|
|
-/* switch (doc.type) {
|
|
|
- case commonConsts.UT_CREATE:
|
|
|
- return function (callback) {
|
|
|
- bills.update({projectID: doc.data.projectID, ID: doc.data.ID}, doc.data, callback);
|
|
|
- };
|
|
|
- break;
|
|
|
- case commonConsts.UT_CREATE:
|
|
|
- return function (callback) {
|
|
|
- bills.create(doc.data, callback);
|
|
|
- };
|
|
|
- break;
|
|
|
- case commonConsts.UT_DELETE:
|
|
|
- return function (callback) {
|
|
|
- doc.data.deleteInfo = {deleted: true, deleteDateTime: new Date(), deleteBy: user_id};
|
|
|
- bills.update({projectID: doc.data.projectID, ID: doc.data.ID}, doc.data, callback);
|
|
|
+ function saveOne(doc) {
|
|
|
+ return function (cb) {
|
|
|
+ switch (doc.updateType) {
|
|
|
+ case commonConsts.UT_UPDATE:
|
|
|
+ bills.update({projectID: doc.updateData.projectID, ID: doc.updateData.ID}, doc.updateData, cb);
|
|
|
+ break;
|
|
|
+ case commonConsts.UT_CREATE:
|
|
|
+ bills.create(doc.updateData, cb);
|
|
|
+ break;
|
|
|
+ case commonConsts.UT_DELETE:
|
|
|
+ doc.updateData.deleteInfo = {deleted: true, deleteDateTime: new Date(), deleteBy: user_id};
|
|
|
+ bills.update({projectID: doc.updateData.projectID, ID: doc.updateData.ID}, doc.updateData, cb);
|
|
|
+ break;
|
|
|
}
|
|
|
- break;
|
|
|
- }*/
|
|
|
- return function (cb) {
|
|
|
- switch (doc.updateType) {
|
|
|
- case commonConsts.UT_UPDATE:
|
|
|
- bills.update({projectID: doc.updateData.projectID, ID: doc.updateData.ID}, doc.updateData, cb);
|
|
|
- break;
|
|
|
- case commonConsts.UT_CREATE:
|
|
|
- bills.create(doc.updateData, cb);
|
|
|
- break;
|
|
|
- case commonConsts.UT_DELETE:
|
|
|
- doc.updateData.deleteInfo = {deleted: true, deleteDateTime: new Date(), deleteBy: user_id};
|
|
|
- bills.update({projectID: doc.updateData.projectID, ID: doc.updateData.ID}, doc.updateData, cb);
|
|
|
- break;
|
|
|
}
|
|
|
}
|
|
|
- }
|
|
|
- for (var i = 0; i < datas.length; i++){
|
|
|
- data = datas[i];
|
|
|
- functions.push(saveOne(data));
|
|
|
- }
|
|
|
+ for (let i = 0; i < datas.length; i++){
|
|
|
+ data = datas[i];
|
|
|
+ functions.push(saveOne(data));
|
|
|
+ }
|
|
|
|
|
|
- async.parallel(functions, callback);
|
|
|
-};
|
|
|
+ async.parallel(functions, callback);
|
|
|
+ };
|
|
|
|
|
|
-billsDAO.prototype.getItemTemplate = function(callback){
|
|
|
- var data = new bills;
|
|
|
- /* to do: 需要根据标准配置库填充fees和flags字段,是否需要更多的参数? */
|
|
|
- callback(0, '', data);
|
|
|
-};
|
|
|
+ getItemTemplate (callback) {
|
|
|
+ let data = new bills;
|
|
|
+ /* to do: 需要根据标准配置库填充fees和flags字段,是否需要更多的参数? */
|
|
|
+ callback(0, '', data);
|
|
|
+ };
|
|
|
|
|
|
-billsDAO.prototype.allocIDs = function(IDStep, callback){
|
|
|
- counter.counterDAO.getIDAfterCount(counter.moduleName.bills, IDStep, function(err, highID){
|
|
|
- var lowID = highID - IDStep + 1;
|
|
|
- callback(0, '', {lowID: lowID, highID: highID});
|
|
|
- });
|
|
|
+ allocIDs (IDStep, callback) {
|
|
|
+ counter.counterDAO.getIDAfterCount(counter.moduleName.bills, IDStep, function(err, highID){
|
|
|
+ let lowID = highID - IDStep + 1;
|
|
|
+ callback(0, '', {lowID: lowID, highID: highID});
|
|
|
+ });
|
|
|
+ };
|
|
|
};
|
|
|
|
|
|
-module.exports = new billsDAO();
|
|
|
+module.exports = new billsModel();
|