measure_controller.js 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391
  1. 'use strict';
  2. /**
  3. * 计量相关控制器
  4. *
  5. * @author olym
  6. * @date 2018/2/11
  7. * @version
  8. */
  9. const spreadConst = require('../const/spread');
  10. const codeRuleConst = require('../const/code_rule');
  11. const moment = require('moment');
  12. module.exports = app => {
  13. class MeasureController extends app.BaseController {
  14. /**
  15. * 构造函数
  16. *
  17. * @param {Object} ctx - egg全局变量
  18. * @return {void}
  19. */
  20. constructor(ctx) {
  21. super(ctx);
  22. ctx.showProject = true;
  23. ctx.showTender = true;
  24. ctx.showTitle = true;
  25. }
  26. /**
  27. * 中间计量--计量编制 页面 (Get)
  28. *
  29. * @param {Object} ctx - egg全局变量
  30. * @return {void}
  31. */
  32. async work(ctx) {
  33. try {
  34. const tenderList = ctx.tenderList;
  35. const tenderData = ctx.tenderData;
  36. const codeRule = tenderData.m_rule ? JSON.parse(tenderData.m_rule) : [];
  37. for (const rule of codeRule) {
  38. switch (rule.rule_type) {
  39. case codeRuleConst.measure.ruleType.tenderName:
  40. rule.preview = tenderData.name;
  41. break;
  42. case codeRuleConst.measure.ruleType.inDate:
  43. rule.preview = moment().format('YYYYMM');
  44. break;
  45. case codeRuleConst.measure.ruleType.text:
  46. rule.preview = rule.text;
  47. break;
  48. case codeRuleConst.measure.ruleType.addNo:
  49. const s = '0000000000';
  50. rule.preview = s.substr(s.length - rule.format);
  51. break;
  52. }
  53. }
  54. const measures = await ctx.service.measure.getAllDataByCondition({
  55. where: {tender_id: tenderData.id}
  56. });
  57. const renderData = {
  58. tenderData,
  59. tenderList,
  60. ruleType: codeRuleConst.ruleType.measure,
  61. ruleConst: codeRuleConst.measure,
  62. codeRule,
  63. measures,
  64. measureSpreadSetting: JSON.stringify(spreadConst.measureSpread),
  65. };
  66. await this.layout('measure/work.ejs', renderData, 'measure/work_modal.ejs');
  67. } catch (err) {
  68. console.log(err);
  69. this.redirect(ctx.menuList.dashboard.url);
  70. }
  71. }
  72. /**
  73. * 中间计量 -- 获取新编号 (Ajax)
  74. *
  75. * @param {Object} ctx - egg全局变量
  76. * @returns {Promise<void>}
  77. */
  78. async newCode(ctx) {
  79. const responseData = {
  80. err: 0,
  81. msg: '',
  82. data: '',
  83. };
  84. try {
  85. const tenderId = ctx.session.sessionUser.tenderId;
  86. if (!tenderId) {
  87. throw '当前未打开标段';
  88. }
  89. const tenderData = await ctx.service.tender.getDataById(tenderId);
  90. const mCodeRule = JSON.parse(tenderData.m_rule);
  91. const code = [];
  92. for (const rule of mCodeRule) {
  93. switch (rule.rule_type) {
  94. case codeRuleConst.measure.ruleType.tenderName:
  95. code.push(tenderData.name);
  96. break;
  97. case codeRuleConst.measure.ruleType.text:
  98. code.push(rule.text);
  99. break;
  100. case codeRuleConst.measure.ruleType.inDate:
  101. code.push(moment().format('YYYYMM'));
  102. break;
  103. case codeRuleConst.measure.ruleType.addNo:
  104. let s = '0000000000';
  105. const count = rule.start + await ctx.service.measure.count();
  106. s = s + count;
  107. code.push(s.substr(s.length - rule.format));
  108. break;
  109. }
  110. }
  111. responseData.data = code.join('');
  112. } catch (err) {
  113. responseData.err = 1;
  114. responseData.msg = err;
  115. }
  116. ctx.body = responseData;
  117. }
  118. /**
  119. * 中间计量 -- 新增中间计量 (Ajax)
  120. *
  121. * @param {Object} ctx - egg全局变量
  122. * @returns {Promise<void>}
  123. */
  124. async addMeasure(ctx) {
  125. const responseData = {
  126. err: 0,
  127. msg: '',
  128. data: '',
  129. };
  130. try {
  131. const tenderId = ctx.session.sessionUser.tenderId;
  132. if (!tenderId) {
  133. throw '当前未打开标段';
  134. }
  135. const tenderData = await ctx.service.tender.getDataById(tenderId);
  136. const data = JSON.parse(ctx.request.body.data);
  137. await ctx.service.measure.add(tenderId, data.code, data.date, data.stage);
  138. responseData.data = await ctx.service.measure.getDataByCondition({
  139. tender_id: tenderId, code: data.code,
  140. });
  141. } catch (err) {
  142. console.log(err);
  143. responseData.err = 1;
  144. responseData.msg = err.toString();
  145. }
  146. ctx.body = responseData;
  147. }
  148. /**
  149. * 获取中间计量详细数据(包括部位和清单) (Ajax)
  150. * @param ctx - egg全局变量
  151. * @returns {Promise<void>}
  152. */
  153. async measureDetail(ctx) {
  154. const responseData = {
  155. err: 0,
  156. msg: '',
  157. data: '',
  158. };
  159. try {
  160. const tenderId = ctx.session.sessionUser.tenderId;
  161. if (!tenderId) {
  162. throw '当前未打开标段';
  163. }
  164. const tenderData = await ctx.service.tender.getDataById(tenderId);
  165. const data = JSON.parse(ctx.request.body.data);
  166. if (!data.mid) {
  167. throw '查询数据有误';
  168. }
  169. const measure = await ctx.service.measure.getDataByCondition({
  170. tender_id: tenderId,
  171. mid: data.mid,
  172. });
  173. measure.pos = await ctx.service.measurePos.getPosDetail(tenderId, data.mid);
  174. measure.bills = await ctx.service.measureBills.getBillsDetail(tenderId, data.mid);
  175. measure.billsTree = await ctx.service.measureBills.getBillsDetailWithParent(tenderId, data.mid);
  176. responseData.data = measure;
  177. } catch (err) {
  178. console.log(err);
  179. responseData.err = 1;
  180. responseData.msg = err.toString();
  181. }
  182. ctx.body = responseData;
  183. }
  184. /**
  185. * 查询部位或者清单 (Ajax)
  186. *
  187. * @param ctx - egg全局变量
  188. * @returns {Promise<void>}
  189. */
  190. async search(ctx) {
  191. const responseData = {
  192. err: 0,
  193. msg: '',
  194. data: '',
  195. };
  196. try {
  197. const tenderId = ctx.session.sessionUser.tenderId;
  198. if (!tenderId) {
  199. throw '当前未打开标段';
  200. }
  201. const tenderData = await ctx.service.tender.getDataById(tenderId);
  202. const data = JSON.parse(ctx.request.body.data);
  203. if (!data.mid || !data.searchType) {
  204. throw '查询数据有误';
  205. }
  206. if (data.searchType === 'pos') {
  207. const key = {
  208. value: app.mysql.escape('%' + data.keyword + '%'),
  209. operate: 'Like',
  210. fields: ['code', 'name'],
  211. };
  212. responseData.data = await ctx.service.ledger.search(tenderId, key);
  213. } else if (data.searchType === 'bills') {
  214. const key = {
  215. value: app.mysql.escape('%' + data.keyword + '%'),
  216. operate: 'Like',
  217. fields: ['b_code', 'name'],
  218. };
  219. const range = [];
  220. const pos = await ctx.service.measurePos.getPosDetail(tenderId, data.mid);
  221. const posFullPath = [];
  222. for (const p of pos) {
  223. posFullPath.push(app.mysql.escape(p.full_path + '.%'));
  224. }
  225. responseData.data = await ctx.service.ledger.searchRange(tenderId, key, [{
  226. value: posFullPath,
  227. operate: 'Like',
  228. fields: ['full_path'],
  229. }, {
  230. value: true,
  231. operate: '=',
  232. fields: ['is_leaf'],
  233. }]);
  234. } else {
  235. throw '查询数据有误';
  236. }
  237. } catch (err) {
  238. console.log(err);
  239. responseData.err = 1;
  240. responseData.msg = err.toString();
  241. }
  242. ctx.body = responseData;
  243. }
  244. /**
  245. * 操作部位 -- 增删 (Ajax)
  246. *
  247. * @param ctx - egg全局变量
  248. * @returns {Promise<void>}
  249. */
  250. async pos(ctx) {
  251. const responseData = {
  252. err: 0,
  253. msg: '',
  254. data: {},
  255. };
  256. try {
  257. const tenderId = ctx.session.sessionUser.tenderId;
  258. if (!tenderId) {
  259. throw '当前未打开标段';
  260. }
  261. const data = JSON.parse(ctx.request.body.data);
  262. if (!data.mid || !data.operate || !data.pid) {
  263. throw '计量范围数据有误';
  264. }
  265. if (data.operate === 'add') {
  266. responseData.data = await ctx.service.measurePos.addPos(tenderId, data.mid, data.pid);
  267. } else if (data.operate === 'remove') {
  268. await ctx.service.measurePos.removePos(tenderId, data.mid, data.pid);
  269. } else {
  270. throw '未知操作';
  271. }
  272. } catch(err) {
  273. console.log(err);
  274. responseData.err = 1;
  275. responseData.msg = err.toString();
  276. }
  277. ctx.body = responseData;
  278. }
  279. /**
  280. * 操作清单 -- 增删 (Ajax)
  281. * @param ctx
  282. * @returns {Promise<void>}
  283. */
  284. async bills(ctx) {
  285. const responseData = {
  286. err: 0,
  287. msg: '',
  288. data: {},
  289. };
  290. try {
  291. const tenderId = ctx.session.sessionUser.tenderId;
  292. if (!tenderId) {
  293. throw '当前未打开标段';
  294. }
  295. const data = JSON.parse(ctx.request.body.data);
  296. if (!data.mid || !data.operate || !data.bid) {
  297. throw '计量清单数据有误';
  298. }
  299. if (data.operate === 'add') {
  300. await ctx.service.measureBills.addBills(tenderId, data.mid, data.bid);
  301. responseData.data = await ctx.service.measureBills.getBillsDataWithParent(tenderId, data.mid, data.bid);
  302. } else if (data.operate === 'remove') {
  303. responseData.data = await ctx.service.measureBills.getBillsDataWithParent(tenderId, data.mid, data.bid);
  304. await ctx.service.measureBills.removeBills(tenderId, data.mid, data.bid);
  305. } else {
  306. throw '未知操作';
  307. }
  308. } catch(err) {
  309. console.log(err);
  310. responseData.err = 1;
  311. responseData.msg = err.toString();
  312. responseData.data = {};
  313. }
  314. ctx.body = responseData;
  315. }
  316. /**
  317. * 清单 -- 计量 (Ajax)
  318. * @param ctx
  319. * @returns {Promise<void>}
  320. */
  321. async billsUpdate (ctx) {
  322. const responseData = { err: 0, msg: '', data: {} };
  323. try {
  324. const tenderId = ctx.session.sessionUser.tenderId;
  325. if (!tenderId) {
  326. throw '当前未打开标段';
  327. }
  328. const data = JSON.parse(ctx.request.body.data);
  329. if (!data.mid || !data.bid || !data.update) {
  330. throw '计量清单数据有误';
  331. }
  332. responseData.data = await ctx.service.measureBills.updateBills(tenderId, data.mid, data.bid, data.update);
  333. } catch(err) {
  334. console.log(err);
  335. responseData.err = 1;
  336. responseData.msg = err.toString();
  337. responseData.data = {};
  338. }
  339. ctx.body = responseData;
  340. }
  341. /**
  342. * 中间计量--计量审批 页面 (Get)
  343. *
  344. * @param {Object} ctx - egg全局变量
  345. * @return {void}
  346. */
  347. async list(ctx) {
  348. const renderData = {};
  349. await this.layout('measure/list.ejs', renderData);
  350. }
  351. }
  352. return MeasureController;
  353. };