engineering_lib_model.js 10 KB

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