engineering_lib_model.js 9.3 KB

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