engineering_lib_model.js 8.7 KB

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