engineering_lib_model.js 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346
  1. /**
  2. * 计价规则标准库业务逻辑
  3. *
  4. * @author CaiAoLin
  5. * @date 2017/8/31
  6. * @version
  7. */
  8. import mongoose from "mongoose";
  9. import BaseModel from "../../common/base/base_model";
  10. import CompilationModel from "./compilation_model";
  11. let stdRationLibModel = mongoose.model("std_ration_lib_map");
  12. import { default as EngineeringConst, List as EngineeringList } from "../../common/const/engineering";
  13. const billsGuidanceLibModel = mongoose.model('std_billsGuidance_lib');
  14. const billsLibListsModel = mongoose.model('std_bills_lib_lists');
  15. class EngineeringLibModel extends BaseModel {
  16. /**
  17. * 构造函数
  18. *
  19. * @return {void}
  20. */
  21. constructor() {
  22. let parent = super();
  23. parent.model = mongoose.model("engineering_lib");
  24. parent.init();
  25. }
  26. /**
  27. * 获取标准库数据
  28. *
  29. * @param {Object} data
  30. * @param {Number} engineering
  31. * @return {Promise}
  32. */
  33. async getLib(data, engineering) {
  34. let result = {};
  35. if (data.length <= 0) {
  36. return result;
  37. }
  38. let id = '';
  39. for (let tmp of data) {
  40. if (tmp.engineering === engineering) {
  41. id = tmp.engineering_id;
  42. break;
  43. }
  44. }
  45. if (id === '') {
  46. return result;
  47. }
  48. let condition = { _id: id };
  49. return this.findDataByCondition(condition);
  50. }
  51. async getLibsByValuationID(valuationID) {
  52. return this.findDataByCondition({ valuationID: valuationID }, null, false);
  53. }
  54. async deleteByValuationID(valuationID) {
  55. return await this.db.delete({ valuationID: valuationID });
  56. }
  57. //添加空的默认的所有标准库
  58. /**
  59. * @param valuationID
  60. * @returns {Promise.<*>}
  61. */
  62. async addStdLib(valuationID) {
  63. let stdLibs = [];
  64. for (let eng of EngineeringList) {
  65. let tem = {
  66. glj_col: { showAdjustPrice: false },
  67. valuationID: valuationID,
  68. name: eng.name,
  69. engineering: eng.value
  70. };
  71. stdLibs.push(tem);
  72. }
  73. let result = await this.db.create(stdLibs);
  74. return result;
  75. }
  76. async addEngineer(data) {
  77. data.glj_col = { showAdjustPrice: false };
  78. if (data.compilationId && data.compilationId != "") {
  79. data.ration_lib = [];
  80. let rationList = await stdRationLibModel.find({ compilationId: data.compilationId }, ['ID', 'dispName']);
  81. for (let i = 0; i < rationList.length; i++) {
  82. let tem = {
  83. id: rationList[i].ID,
  84. name: rationList[i].dispName,
  85. isDefault: false
  86. };
  87. if (i == 0) tem.isDefault = true;
  88. data.ration_lib.push(tem);
  89. }
  90. }
  91. let result = await this.db.create(data);
  92. return result;
  93. }
  94. // 拷贝工程专业
  95. async copyEngineer(sourceID) {
  96. const engineering = await this.db.findOne({ _id: sourceID });
  97. const newEngineering = engineering._doc;
  98. delete newEngineering._id;
  99. newEngineering.visible = false;
  100. await this.db.create(newEngineering);
  101. }
  102. /**
  103. * 新增标准库
  104. *
  105. * @param {String} valuationId
  106. * @param {Object} data
  107. * @return {Promise}
  108. */
  109. async addLib(engineerId, data) {
  110. if (data.glj_col) {
  111. data.glj_col = JSON.parse(data.glj_col);
  112. }
  113. data.isInstall == 'true' ? data.isInstall = true : data.isInstall = false;
  114. data.isItemIncrease == 'true' ? data.isItemIncrease = true : data.isItemIncrease = false;
  115. data.isAreaIncrease == 'true' ? data.isAreaIncrease = true : data.isAreaIncrease = false;
  116. let result = false;
  117. data = this.filterLibData(data);
  118. try {
  119. // 处理清单指引
  120. if (data.billsGuidance_lib && data.billsGuidance_lib.length) {
  121. const billsGuidanceLibIDs = data.billsGuidance_lib.map(item => item.id);
  122. const billsGuidanceLibs = await billsGuidanceLibModel.find({ ID: { $in: billsGuidanceLibIDs } }, '-_id ID type').lean();
  123. const libTypeMap = {};
  124. billsGuidanceLibs.forEach(lib => libTypeMap[lib.ID] = lib.type);
  125. data.billsGuidance_lib.forEach(lib => {
  126. lib.type = libTypeMap[lib.id] || 1;
  127. });
  128. }
  129. // 标准清单新增清单类型
  130. if (data.bill_lib && data.bill_lib.length) {
  131. const billLibIDs = data.bill_lib.map(item => +item.id);
  132. const billLibs = await billsLibListsModel.find({ billsLibId: { $in: billLibIDs } }, '-_id billsLibId libType').lean();
  133. const libTypeMap = {};
  134. billLibs.forEach(lib => libTypeMap[lib.billsLibId] = lib.libType);
  135. data.bill_lib.forEach(lib => {
  136. lib.libType = libTypeMap[lib.id] || '1';
  137. });
  138. }
  139. let engineeringLib = await this.findDataByCondition({ _id: engineerId });
  140. if (engineeringLib) {
  141. // 存在则直接更新
  142. delete data.id;
  143. delete data.section;
  144. let condition = { _id: engineerId };
  145. result = await this.db.update(condition, data);
  146. result = result.ok === 1;
  147. } else {
  148. throw new Error("找不到对应的工程专业");
  149. }
  150. } catch (error) {
  151. console.log(error);
  152. result = false;
  153. }
  154. return result;
  155. }
  156. /**
  157. * 过滤计价数据
  158. *
  159. * @param {Object} data
  160. * @return {Object}
  161. */
  162. filterLibData(data) {
  163. if (Object.keys(data).length <= 0 || data.section === undefined) {
  164. console.log('1');
  165. throw '数据有误';
  166. }
  167. data.engineering = parseInt(data.engineering);
  168. //需求修改,工程专业可以随便输入了
  169. //检测专业工程是否合法
  170. /* let match = false;
  171. for(let index in EngineeringConst) {
  172. if (EngineeringConst[index] === data.engineering) {
  173. match = true;
  174. break;
  175. }
  176. }
  177. if (!match) {
  178. throw '工程专业错误';
  179. }*/
  180. // 判断标准清单
  181. data.bill_lib = this._validLib(data.bill_lib);
  182. // 判断定额库
  183. data.ration_lib = this._validLib(data.ration_lib);
  184. //设置默认定额库
  185. this.setDefaultRation(data);
  186. // 判断工料机库
  187. data.glj_lib = this._validLib(data.glj_lib);
  188. // 判断清单指引库
  189. data.billsGuidance_lib = this._validLib(data.billsGuidance_lib);
  190. /*// 判断费率标准
  191. data.fee_lib = this._validLib(data.fee_lib);*/
  192. // 判断人工系数
  193. data.artificial_lib = this._validLib(data.artificial_lib);
  194. //判断工程特征库
  195. data.feature_lib = this._validLib(data.feature_lib);
  196. //判断基本信息
  197. data.info_lib = this._validLib(data.info_lib);
  198. //判断工程信息
  199. data.engineer_info_lib = this._validLib(data.engineer_info_lib);
  200. //判断累进区间库
  201. data.progressive_lib = this._validLib(data.progressive_lib);
  202. //判断工程特征指标信息
  203. data.engineer_feature_lib = this._validLib(data.engineer_feature_lib);
  204. //判断主要工料指标信息
  205. data.material_lib = this._validLib(data.material_lib);
  206. //判断主要工料指标信息
  207. data.main_quantity_lib = this._validLib(data.main_quantity_lib);
  208. //判断主要经济指标信息
  209. data.economic_lib = this._validLib(data.economic_lib);
  210. data.over_height_lib = this._validLib(data.over_height_lib);
  211. //计税方式组合
  212. data.tax_group = this._validLib(data.tax_group);
  213. return data;
  214. }
  215. /**
  216. * 校验库数据
  217. *
  218. * @param {Object} libData
  219. * @return {Object}
  220. */
  221. _validLib(libData) {
  222. let result = [];
  223. // 判断标准库
  224. if (libData === undefined || libData === null || libData === '') {
  225. return result;//throw '标准库不能为空'; 按新需求,标准库等不做非空判断
  226. }
  227. libData = libData instanceof Array ? libData : [libData];
  228. for (let tmp in libData) {
  229. result[tmp] = JSON.parse(libData[tmp]);
  230. }
  231. return result;
  232. }
  233. //设置默认定额库
  234. setDefaultRation(data) {
  235. if (data.ration_lib && data.ration_lib.length > 0) {
  236. if (data.ration_isDefault && data.ration_isDefault != "") {
  237. for (let r of data.ration_lib) {
  238. r.id.toString() == data.ration_isDefault ? r.isDefault = true : r.isDefault = false;
  239. }
  240. } else {
  241. data.ration_lib[0].isDefault = true;
  242. }
  243. }
  244. }
  245. /**
  246. * 获取对应标准库数量
  247. *
  248. * @param {Object} valuationData
  249. * @return {Object}
  250. */
  251. async getLibCount(valuationData) {
  252. let result = {};
  253. if (valuationData.engineering_list === undefined || valuationData.engineering_list.length <= 0) {
  254. return result;
  255. }
  256. // 整理需要查找的数据
  257. let findIdList = [];
  258. for (let engineering of valuationData.engineering_list) {
  259. findIdList.push(engineering.engineering_id);
  260. }
  261. let condition = { _id: { $in: findIdList } };
  262. let libData = await this.findDataByCondition(condition, null, false);
  263. if (libData === null) {
  264. return result;
  265. }
  266. // 整理数据
  267. let countData = {};
  268. for (let tmp of libData) {
  269. countData[tmp._id] = {
  270. bill_count: tmp.bill_lib.length,
  271. ration_count: tmp.ration_lib.length,
  272. glj_count: tmp.glj_lib.length,
  273. fee_count: tmp.fee_lib.length,
  274. artificial_count: tmp.artificial_lib.length,
  275. program_count: tmp.program_lib.length,
  276. };
  277. }
  278. for (let engineering of valuationData.engineering_list) {
  279. if (countData[engineering.engineering_id] !== undefined) {
  280. result[engineering.engineering] = countData[engineering.engineering_id];
  281. }
  282. }
  283. return result;
  284. }
  285. async copyRationLibsToOthers(valuationID, engineeringID) {
  286. const compilationModel = new CompilationModel();
  287. const compilation = await compilationModel.model.findOne({ $or: [{ 'bill_valuation.id': valuationID }, { 'ration_valuation.id': valuationID }] });
  288. if (!compilation) {
  289. return;
  290. }
  291. const valuationIDList = [];
  292. const allValuation = compilation.ration_valuation.concat(compilation.bill_valuation);
  293. for (const valuation of allValuation) {
  294. valuationIDList.push(valuation.id);
  295. }
  296. const engineering = await this.findDataByCondition({ _id: engineeringID });
  297. if (!engineering) {
  298. return;
  299. }
  300. await this.model.updateMany({ valuationID: { $in: valuationIDList } }, { $set: { ration_lib: engineering.ration_lib } });
  301. }
  302. }
  303. export default EngineeringLibModel;