rpt_custom.js 44 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040
  1. 'use strict';
  2. /**
  3. *
  4. *
  5. * @author Mai
  6. * @date
  7. * @version
  8. */
  9. const rptCustomObj = (function () {
  10. // 审批人选择
  11. const sAuditSelect = 'audit_select';
  12. let stageFlow = [];
  13. // 汇总表
  14. const sGatherSelect = 'gather_select';
  15. let gsObj = {
  16. setting: null,
  17. gsSheet: null,
  18. grSheet: null,
  19. tenderSourceTree: null,
  20. grArray: [],
  21. orgSelect: null,
  22. };
  23. // 期选择
  24. const sStageSelect = 'stage_select';
  25. const grSpreadSetting = {
  26. baseCols: [
  27. {title: '名称', colSpan: '1', rowSpan: '1', field: 'name', hAlign: 0, width: 240, formatter: '@', readOnly: true},
  28. ],
  29. extraCols: [
  30. {title: '%s', colSpan: '1', rowSpan: '1', field: '%s', hAlign: 1, vAlign: '1', width: 60, cellType: 'checkbox', readOnly: true},
  31. ],
  32. emptyRows: 0,
  33. headRows: 1,
  34. headRowHeight: [32],
  35. defaultRowHeight: 21,
  36. headerFont: '12px 微软雅黑',
  37. font: '12px 微软雅黑',
  38. headColWidth: []
  39. };
  40. const gatherSelectSpreadObj = {
  41. _getStageSelectHtml: function (valid) {
  42. const html = [];
  43. for (let i = 1; i <= valid; i++) {
  44. html.push(`<option value="${i}">第${i}期</option>`);
  45. }
  46. return html.join('');
  47. },
  48. _rebuildStageSelect: function () {
  49. if (gsObj.setting.type === 'stage') {
  50. const validStage = _.min(_.map(gsObj.grArray, 'stageCount'));
  51. $('#gather-stage').html(this._getStageSelectHtml(validStage));
  52. } else if (gsObj.setting.type === 'stage-zone') {
  53. const validStage = _.max(_.map(gsObj.grArray, 'stageCount'));
  54. $('#gather-stage-begin').html(this._getStageSelectHtml(validStage));
  55. $('#gather-stage-end').html(this._getStageSelectHtml(validStage));
  56. }
  57. },
  58. _addTender: function (tender) {
  59. const gr = gsObj.grArray.find(function (x) {
  60. return x.tid === tender.tid;
  61. });
  62. const t = {tid: tender.tid, name: tender.name, stageCount: tender.stageCount};
  63. if (!gr) gsObj.grArray.push(t);
  64. return t;
  65. },
  66. _removeTender: function (tender) {
  67. const gri = gsObj.grArray.findIndex(function (x, i, arr) {
  68. return x.tid === tender.tid;
  69. });
  70. if (gri >= 0) gsObj.grArray.splice(gri, 1);
  71. },
  72. reloadResultData: function () {
  73. SpreadJsObj.reLoadSheetData(gsObj.grSheet);
  74. this._rebuildStageSelect();
  75. },
  76. gsButtonClicked: function (e, info) {
  77. if (!info.sheet.zh_setting) return;
  78. const col = info.sheet.zh_setting.cols[info.col];
  79. if (col.field !== 'selected') return;
  80. const node = SpreadJsObj.getSelectObject(info.sheet);
  81. node.selected = !node.selected;
  82. if (node.children && node.children.length > 0) {
  83. const posterity = gsObj.tenderSourceTree.getPosterity(node);
  84. for (const p of posterity) {
  85. p.selected = node.selected;
  86. if (!p.children || p.children.length === 0){
  87. if (p.selected) {
  88. gatherSelectSpreadObj._addTender(p);
  89. } else {
  90. gatherSelectSpreadObj._removeTender(p);
  91. }
  92. }
  93. }
  94. SpreadJsObj.reLoadRowData(info.sheet, info.row, posterity.length + 1);
  95. } else {
  96. if (node.selected) {
  97. gatherSelectSpreadObj._addTender(node);
  98. } else {
  99. gatherSelectSpreadObj._removeTender(node);
  100. }
  101. SpreadJsObj.reLoadRowData(info.sheet, info.row, 1);
  102. }
  103. gatherSelectSpreadObj.reloadResultData();
  104. },
  105. grButtonClicked: function (e, info) {
  106. if (!info.sheet.zh_setting) return;
  107. const col = info.sheet.zh_setting.cols[info.col];
  108. if (col.field === 'name') return;
  109. const node = SpreadJsObj.getSelectObject(info.sheet);
  110. const refreshRows = [info.row];
  111. node[col.field] = !node[col.field];
  112. for (const rCol of info.sheet.zh_setting.cols) {
  113. if (rCol.field !== 'name' && rCol.field !== col.field) {
  114. node[rCol.field] = false;
  115. }
  116. }
  117. if (node[col.field]) {
  118. for (const [i, gra] of gsObj.grArray.entries()) {
  119. if (gra[col.field] && gra.tid !== node.tid) {
  120. gra[col.field] = false;
  121. refreshRows.push(i);
  122. }
  123. }
  124. }
  125. SpreadJsObj.reLoadRowsData(info.sheet, refreshRows);
  126. },
  127. initSelectTenders: function (tenders) {
  128. if (!tenders) return;
  129. const specCol = gsObj.setting.special ? gsObj.setting.special : [];
  130. const select = [];
  131. for (const node of gsObj.tenderSourceTree.nodes) {
  132. node.selected = false;
  133. }
  134. for (const t of tenders) {
  135. const tender = gsObj.tenderSourceTree.nodes.find(function (x) { return x.tid === t.tid});
  136. if (!tender) continue;
  137. tender.selected = true;
  138. select.push(tender);
  139. const st = this._addTender(tender);
  140. for (const sc of specCol) {
  141. st[sc.key] = t[sc.key];
  142. }
  143. }
  144. SpreadJsObj.reLoadColsData(gsObj.gsSheet, [0]);
  145. if (select.length > 0) SpreadJsObj.locateTreeNode(gsObj.gsSheet, select[0].tmt_id);
  146. this.reloadResultData();
  147. },
  148. };
  149. // 材差 - 期选择
  150. const sMaterialSumSelect = 'material_sum_select';
  151. // 变更令选择
  152. const sChangeSelect = 'change_select';
  153. const changeObj = {
  154. changes: null,
  155. latestPush: null,
  156. loadChanges: async function () {
  157. const self = this;
  158. const result = await postDataAsync(`/tender/${window.location.pathname.split('/')[2]}/load`, { filter: 'change'});
  159. this.changes = result.change;
  160. const html = [];
  161. for (const c of this.changes) {
  162. html.push('<tr>', `<td class="text-center"><input type="checkbox" name="change-select-check" value="${c.cid}"></td>`, `<td>${c.code}</td>`, `<td>${c.name}</td>`, '</tr>');
  163. }
  164. $('#change-select-list').html(html.join(''));
  165. $('[name=change-select-check]').click(function () {
  166. const selectChange = $('[name=change-select-check]:checked');
  167. const selectHtml = [];
  168. for (const sc of selectChange) {
  169. const c = self.changes.find(x => { return x.cid === sc.value });
  170. selectHtml.push(`<tr><td class="text-center">${selectHtml.length + 1}</td><td>${c.code}</td><td>${c.name}</td></tr>`);
  171. }
  172. $('#change-select-result').html(selectHtml.join(''));
  173. });
  174. $('#change-select-all').click(function () {
  175. const change = $('[name=change-select-check]');
  176. const selectHtml = [];
  177. for (const sc of change) {
  178. sc.checked = this.checked;
  179. if (this.checked) {
  180. const c = self.changes.find(x => { return x.cid === sc.value });
  181. selectHtml.push(`<tr><td class="text-center">${selectHtml.length + 1}</td><td>${c.code}</td><td>${c.name}</td></tr>`);
  182. }
  183. }
  184. $('#change-select-result').html(selectHtml.join(''));
  185. });
  186. },
  187. show: async function (title, resolve) {
  188. this.latestPush = null;
  189. $('#change-select-title').html(title);
  190. if (!this.changes) {
  191. await this.loadChanges();
  192. }
  193. if (resolve) {
  194. setTimeout(() => { $("#change-select").modal('show'); }, 1000);
  195. } else {
  196. $('#change-select').modal('show');
  197. }
  198. $('#change-select-ok').unbind('click');
  199. $('#change-select-ok').bind('click', () => {
  200. rptCustomObj.resetChangeSelect(resolve);
  201. });
  202. }
  203. };
  204. const getStageFlowSelectHtml = function (select, id) {
  205. const html = [];
  206. html.push('<select style="width: 80%" id="' + id + '" sf-title="' + select.title + '">');
  207. for (const sf of stageFlow) {
  208. html.push(`<option ${sf.visible ? '' : 'style="display: none"'}>${sf.name}-${sf.role}</option>`);
  209. }
  210. html.push('</select>');
  211. return html.join('');
  212. };
  213. const checkAsSelectValid = function (validFlow, asSelect) {
  214. for (const s of asSelect) {
  215. const f = validFlow.find(function (x) {
  216. return x.aid === s.aid && x.order === s.order;
  217. });
  218. if (!f) {
  219. $('#audit-select-hint').html('本期审批流程发生变动,原审批人选择不适配,需重新选择').show();
  220. return false;
  221. }
  222. }
  223. $('#audit-select-hint').hide();
  224. return true;
  225. };
  226. const initAuditSelect = function (asSetting, asSelect) {
  227. const setting = JSON.parse(asSetting), select = asSelect;
  228. $('#audit-select-title').html(setting.title);
  229. if (setting.hideSign) {
  230. $('#pnl_eSignature').hide();
  231. } else {
  232. $('#pnl_eSignature').show();
  233. }
  234. $('#pnl_audit_select div button').html('<i class="fa fa-pencil"></i><br>' + (setting.caption || '审批人选择'));
  235. const html = [];
  236. for (const [i, s] of setting.select.entries()) {
  237. html.push('<tr>');
  238. html.push('<td>', s.title, '</td>');
  239. html.push('<td>', getStageFlowSelectHtml(s, 'sf-' + i), '</td>');
  240. html.push('</tr>');
  241. }
  242. $('#audit-select-list').html(html.join(''));
  243. for (const [i, s] of setting.select.entries()) {
  244. const obj = $('#sf-' + i);
  245. const s = select[i];
  246. obj[0].selectedIndex = s ? stageFlow.findIndex(function (x) {
  247. return x.order === s.order && x.aid === s.aid;
  248. }) : -1;
  249. }
  250. if (asSelect.length === 0 || !checkAsSelectValid(stageFlow, asSelect)) {
  251. $('#audit-select').modal('show');
  252. }
  253. };
  254. const initGrSpreadSetting = function (gsSetting) {
  255. grSpreadSetting.cols = [];
  256. for (const bc of grSpreadSetting.baseCols) {
  257. grSpreadSetting.cols.push(bc);
  258. if (bc.field === 'name') bc.width = gsSetting.nameColWidth ? gsSetting.nameColWidth : 240;
  259. }
  260. if (gsSetting.special) {
  261. for (const s of gsSetting.special) {
  262. for (const ec of grSpreadSetting.extraCols) {
  263. const c = {};
  264. c.title = ec.title.replace('%s', s.title);
  265. c.colSpan = ec.colSpan;
  266. c.field = ec.field.replace('%s', s.key);
  267. c.hAlign = ec.hAlign;
  268. c.width = s.width ? s.width : ec.width;
  269. c.cellType = ec.cellType;
  270. c.readOnly = ec.readOnly;
  271. grSpreadSetting.cols.push(c);
  272. }
  273. }
  274. }
  275. };
  276. const initGatherSelect = function (gsSetting, gsSelect, rptName, resolve = null) {
  277. gsObj.grArray = [];
  278. gsObj.setting = JSON.parse(gsSetting);
  279. gsObj.orgSelect = gsSelect;
  280. $('#gather-select-count').html(gsSelect ? gsSelect.tenders.length : 0);
  281. $('#gather-select-title').html(gsObj.setting.title + (rptName ? '-' + rptName : ''));
  282. initGrSpreadSetting(gsObj.setting);
  283. SpreadJsObj.initSheet(gsObj.grSheet, grSpreadSetting);
  284. // 初始化选择结果
  285. SpreadJsObj.loadSheetData(gsObj.grSheet, SpreadJsObj.DataType.Data, gsObj.grArray);
  286. gatherSelectSpreadObj.initSelectTenders(gsSelect ? gsSelect.tenders : []);
  287. $('[name=gather-type]').hide();
  288. if (gsObj.setting.type === 'month') $('#gather-by-month').show();
  289. if (gsObj.setting.type === 'zone') $('#gather-by-zone').show();
  290. if (gsObj.setting.type === 'stage') $('#gather-by-stage').show();
  291. if (gsObj.setting.type === 'stage-zone') $('#gather-by-stage-zone').show();
  292. if (gsObj.setting.type === 'checked-zone') $('#gather-by-checked-zone').show();
  293. if (gsSelect) {
  294. if (gsSelect.zone) {
  295. $('#gather-zone').val(gsSelect.zone ? gsSelect.zone : '');
  296. } else if (gsSelect.checked_zone) {
  297. $('#gather-checked-zone').val(gsSelect.checked_zone ? gsSelect.checked_zone : '');
  298. } else if (gsSelect.month) {
  299. $('#gather-month').val(gsSelect.month ? gsSelect.month: '');
  300. } else if (gsSelect.stage) {
  301. $('#gather-stage').val(gsSelect.stage || '');
  302. } else if (gsSelect.stage_zone) {
  303. const [stageBegin, stageEnd] = gsSelect.stage_zone ? gsSelect.stage_zone.split(':') : ['', ''];
  304. $('#gather-stage-begin').val(stageBegin);
  305. $('#gather-stage-end').val(stageEnd);
  306. }
  307. }
  308. // 初始化
  309. if (resolve) {
  310. setTimeout(() => { $("#gather-select").modal('show'); }, 1000);
  311. } else {
  312. $("#gather-select").modal('show');
  313. }
  314. $('#gather-select-ok').unbind('click');
  315. $('#gather-select-ok').bind('click', () => {
  316. rptCustomObj.resetGatherSelect(resolve);
  317. // $("#gather-select").modal('hide');
  318. });
  319. };
  320. const initStageSelect = function (gsSetting, gsSelect, rptName, resolve = null) {
  321. const setting = JSON.parse(gsSetting);
  322. $('#stage-select-count').html(gsSelect && gsSelect.stages ? gsSelect.stages.length : 0);
  323. $('#stage-select-title').html(setting.title + (rptName ? '-' + rptName : ''));
  324. // 初始化选择结果
  325. $('#stage-select-hint').attr('min-select', setting.min).attr('max-select', setting.max).hide();
  326. for (const sc of $('[name=stage-select-check]')) {
  327. sc.checked = false;
  328. }
  329. if (gsSelect && gsSelect.stages) {
  330. for (const s of gsSelect.stages) {
  331. $('#stage-select-' + s)[0].checked = true;
  332. }
  333. }
  334. if (resolve) {
  335. setTimeout(() => { $("#stage-select").modal('show'); }, 1000);
  336. } else {
  337. $("#stage-select").modal('show');
  338. }
  339. $('#stage-select-ok').unbind('click');
  340. $('#stage-select-ok').bind('click', () => {
  341. rptCustomObj.resetStageSelect(resolve);
  342. // $("#stage-select").modal('hide');
  343. });
  344. $('#stage-select-all').unbind('click');
  345. $('#stage-select-all').bind('click', function () {
  346. const material = $('[name=stage-select-check]');
  347. for (const m of material) {
  348. m.checked = this.checked;
  349. }
  350. });
  351. };
  352. const initChangeSelect = function (gsSetting, rptName, resolve = null) {
  353. changeObj.show('选择工程变更' + (rptName ? '-' + rptName : ''), resolve);
  354. };
  355. const initMaterialSumSelect = function (gsSetting, gsSelect, rptName, resolve = null) {
  356. const setting = JSON.parse(gsSetting);
  357. $('#material-sum-select-count').html(gsSelect && gsSelect.materials ? gsSelect.materials.length : 0);
  358. $('#material-sum-select-title').html((setting.title || '请选择材差期') + (rptName ? '-' + rptName : ''));
  359. // 初始化选择结果
  360. $('#material-sum-select-hint').attr('min-select', setting.min).attr('max-select', setting.max).hide();
  361. for (const sc of $('[name=material-sum-select-check]')) {
  362. sc.checked = false;
  363. }
  364. if (gsSelect && gsSelect.materials) {
  365. for (const s of gsSelect.materials) {
  366. $('#material-sum-select-' + s)[0].checked = true;
  367. }
  368. }
  369. if (resolve) {
  370. setTimeout(() => { $("#material-sum-select").modal('show'); }, 1000);
  371. } else {
  372. $("#material-sum-select").modal('show');
  373. }
  374. $('#material-sum-select-ok').unbind('click');
  375. $('#material-sum-select-ok').bind('click', () => {
  376. rptCustomObj.resetMaterialSumSelect(resolve);
  377. // $("#stage-select").modal('hide');
  378. });
  379. $('#material-sum-select-all').unbind('click');
  380. $('#material-sum-select-all').bind('click', function () {
  381. const material = $('[name=material-sum-select-check]');
  382. for (const m of material) {
  383. m.checked = this.checked;
  384. }
  385. });
  386. };
  387. const init = function (cDefine, sfData, cSelect, rptName, resolve = null) {
  388. stageFlow = sfData;
  389. if (cDefine && cDefine[sAuditSelect] && cDefine[sAuditSelect].enable && cDefine[sAuditSelect].setting) {
  390. $('#pnl_audit_select').show();
  391. initAuditSelect(cDefine[sAuditSelect].setting, cSelect ? cSelect[sAuditSelect] : []);
  392. } else {
  393. $('#pnl_eSignature').show();
  394. $('#pnl_audit_select').hide();
  395. }
  396. if (cDefine && cDefine[sGatherSelect] && cDefine[sGatherSelect].enable && cDefine[sGatherSelect].setting) {
  397. $('#pnl_gather_select').show();
  398. initGatherSelect(cDefine[sGatherSelect].setting, cSelect ? cSelect[sGatherSelect] : null, rptName, resolve);
  399. } else {
  400. $('#pnl_gather_select').hide();
  401. }
  402. if (cDefine && cDefine[sStageSelect] && cDefine[sStageSelect].enable && cDefine[sStageSelect].setting) {
  403. $('#pnl_stage_select').show();
  404. initStageSelect(cDefine[sStageSelect].setting, cSelect ? cSelect[sStageSelect] : null, rptName, resolve);
  405. } else {
  406. $('#pnl_stage_select').hide();
  407. }
  408. if (cDefine && cDefine[sMaterialSumSelect] && cDefine[sMaterialSumSelect].enable && cDefine[sMaterialSumSelect].setting) {
  409. $('#pnl_material_sum_select').show();
  410. initMaterialSumSelect(cDefine[sMaterialSumSelect].setting, cSelect ? cSelect[sMaterialSumSelect] : null, rptName, resolve);
  411. } else {
  412. $('#pnl_material_sum_select').hide();
  413. }
  414. if (cDefine && cDefine[sChangeSelect] && cDefine[sChangeSelect].enable) {
  415. initChangeSelect(cDefine[sChangeSelect].setting, rptName, resolve);
  416. }
  417. };
  418. const reloadReportData = function (result) {
  419. let pageRst = result.data;
  420. if (result.signatureRelInfo && result.signatureRelInfo.length > 0) {
  421. CURRENT_ROLE_REL_ID = result.signatureRelInfo[0].id;
  422. ROLE_REL_LIST = zTreeOprObj._parseRoleRelList(result.signatureRelInfo[0].rel_content);
  423. STAGE_AUDIT = result.stageAudit;
  424. rptSignatureHelper.originalRoleRelList = zTreeOprObj._parseRoleRelList(result.signatureRelInfo[0].rel_content);
  425. if (current_stage_status === 3) {
  426. rptSignatureHelper.mergeSignDate(pageRst, ROLE_REL_LIST, true);
  427. rptSignatureHelper.mergeSignature(pageRst, ROLE_REL_LIST);
  428. rptSignatureHelper.mergeSignAudit(pageRst, ROLE_REL_LIST, STAGE_AUDIT);
  429. }
  430. } else {
  431. CURRENT_ROLE_REL_ID = -1;
  432. ROLE_REL_LIST = [];
  433. }
  434. let canvas = zTreeOprObj.canvas;
  435. if (pageRst && pageRst.items && pageRst.items.length > 0) {
  436. zTreeOprObj.resetAfter(pageRst);
  437. zTreeOprObj.currentRptPageRst = pageRst;
  438. zTreeOprObj.maxPages = pageRst.items.length;
  439. zTreeOprObj.currentPage = 1;
  440. zTreeOprObj.displayPageValue();
  441. let size = JpcCanvasOutput.getReportSizeInPixel(zTreeOprObj.currentRptPageRst, getScreenDPI());
  442. canvas.width = size[0] + 20;
  443. if (size[1] > size[0]) {
  444. canvas.height = size[1] + 100;
  445. } else {
  446. canvas.height = size[1] + 50;
  447. }
  448. // zTreeOprObj.resetESignature(zTreeOprObj.currentRptPageRst);
  449. rptSignatureHelper.buildSelectableAccount();
  450. rptSignatureHelper.buildSelectableAccountUsed();
  451. rptSignatureHelper.buildRoleDom(ROLE_LIST);
  452. zTreeOprObj.showPage(1, canvas);
  453. } else {
  454. //返回了无数据表
  455. JpcCanvasOutput.cleanCanvas(canvas);
  456. JpcCanvasOutput.drawPageBorder(zTreeOprObj.currentRptPageRst, canvas, getScreenDPI());
  457. }
  458. rptCustomObj.init(result.customDefine, result.stageFlow, result.customSelect);
  459. try {
  460. if (is_debug && result.debugInfo) {
  461. console.log('含有key的debug信息:');
  462. for (const k in result.debugInfo.key) {
  463. console.log(k + ':', ...result.debugInfo.key[k]);
  464. }
  465. console.log('其他debug信息:');
  466. for (const di of result.debugInfo.other) {
  467. console.log(...di);
  468. }
  469. }
  470. } catch(err) {
  471. }
  472. zTreeOprObj.countChkedRptTpl();
  473. };
  474. const getCommonParams = function (data) {
  475. data.pageSize = rptControlObj.getCurrentPageSize();
  476. data.rpt_tpl_id = zTreeOprObj.currentNode.refId;
  477. data.custCfg = CUST_CFG;
  478. data.project_id = PROJECT_ID;
  479. data.tender_id = TENDER_ID;
  480. data.stage_id = getStageId();
  481. data.stage_status = getStageStatus();
  482. data.stage_order = getStageOrder();
  483. data.stage_times = getStageTimes();
  484. data.material_order = getMaterialOrder();
  485. };
  486. const resetAuditSelect = function () {
  487. const selObj = $('select', '#audit-select-list');
  488. const data = { audit_select: [], closeWatermark: getCloseWatermark() };
  489. getCommonParams(data);
  490. for (const s of selObj) {
  491. const sf = stageFlow[s.selectedIndex];
  492. if (!sf) {
  493. $('#audit-select-hint').html('未选择' + s.attributes['sf-title'].value).show();
  494. return;
  495. }
  496. data.audit_select.push({...sf, sort: s.selectedIndex});
  497. }
  498. $('#audit-select-hint').hide();
  499. postData('/report/cDefine', data, function (result) {
  500. reloadReportData(result);
  501. $('#audit-select').modal('hide');
  502. rptArchiveObj.toggleBtn(true);
  503. if (PAGE_SHOW.showArchive) {
  504. rptArchiveObj.showArchivedItem(zTreeOprObj.currentNode);
  505. }
  506. });
  507. };
  508. const resetGatherSelect = function (resolve = null) {
  509. const data = {}, hintObj = $('#gather-hint');
  510. if (!resolve) getCommonParams(data);
  511. data[sGatherSelect] = {
  512. tenders: [],
  513. type: gsObj.setting.type,
  514. };
  515. const specCol = gsObj.setting.special ? gsObj.setting.special : [];
  516. for (const sc of specCol) {
  517. sc.sCount = 0;
  518. }
  519. for (const gra of gsObj.grArray) {
  520. const ra = {tid: gra.tid};
  521. for (const sc of specCol) {
  522. if (gra[sc.key]) {
  523. ra[sc.key] = true;
  524. sc.sCount += 1;
  525. }
  526. }
  527. data[sGatherSelect].tenders.push(ra);
  528. }
  529. for (const sc of specCol) {
  530. if (sc.sCount === 0) {
  531. hintObj.html('请选择 ' + sc.title).show();
  532. return;
  533. }
  534. }
  535. if (gsObj.setting.onlySpec) {
  536. if (data[sGatherSelect].tenders.length > specCol.length) {
  537. hintObj.html('请勿选择普通汇总项目').show();
  538. return;
  539. }
  540. } else {
  541. if (data[sGatherSelect].tenders.length <= specCol.length) {
  542. hintObj.html('请至少选择1个普通汇总项目').show();
  543. return;
  544. }
  545. }
  546. if (gsObj.setting.type === 'month') {
  547. data[sGatherSelect].month = $('#gather-month').val();
  548. if (data[sGatherSelect].month === '') {
  549. hintObj.html('请选择 汇总年月').show();
  550. return;
  551. }
  552. } else if (gsObj.setting.type === 'zone') {
  553. data[sGatherSelect].zone = $('#gather-zone').val();
  554. if (data[sGatherSelect].zone === '') {
  555. hintObj.html('请选择 汇总周期').show();
  556. return;
  557. } else if(data[sGatherSelect].zone.indexOf(' - ') < 0) {
  558. hintObj.html('请选择 完整汇总周期').show();
  559. return;
  560. }
  561. } else if (gsObj.setting.type === 'stage') {
  562. data[sGatherSelect].stage = _.toInteger($('#gather-stage').val()) || 0;
  563. const validStage = _.min(_.map(gsObj.grArray, 'stageCount'));
  564. if (!data[sGatherSelect].stage) {
  565. hintObj.html('请选择 汇总期').show();
  566. return;
  567. }
  568. if (data[sGatherSelect].stage > validStage) {
  569. hintObj.html('选择的期无效,请重新选择').show();
  570. return;
  571. }
  572. } else if (gsObj.setting.type === 'stage-zone') {
  573. const stageBegin = _.toInteger($('#gather-stage-begin').val()) || 0;
  574. const stageEnd = _.toInteger($('#gather-stage-end').val()) || 0;
  575. const validStage = _.max(_.map(gsObj.grArray, 'stageCount'));
  576. if (!stageBegin || !stageEnd) {
  577. hintObj.html('请选择 汇总开始期与结束期').show();
  578. return;
  579. }
  580. if (stageEnd <= stageBegin) {
  581. hintObj.html('结束期应大于开始期').show();
  582. return;
  583. }
  584. if (stageEnd > validStage) {
  585. hintObj.html('选择的期无效,请重新选择').show();
  586. return;
  587. }
  588. data[sGatherSelect].stage_zone = stageBegin + ':' + stageEnd;
  589. } else if (gsObj.setting.type === 'checked-zone') {
  590. data[sGatherSelect].checked_zone = $('#gather-checked-zone').val();
  591. if (data[sGatherSelect].checked_zone === '') {
  592. hintObj.html('请选择 汇总周期').show();
  593. return;
  594. } else if(data[sGatherSelect].checked_zone.indexOf(' - ') < 0) {
  595. hintObj.html('请选择 完整汇总周期').show();
  596. return;
  597. }
  598. }
  599. hintObj.hide();
  600. if (resolve) {
  601. resolve(data);
  602. rptArchiveObj.toggleBtn(false);
  603. } else {
  604. postData('/report/cDefine', data, function (result) {
  605. reloadReportData(result);
  606. const gather_select = customSelects.gather_select.find(function (x) {
  607. return x.id === zTreeOprObj.currentNode.refId;
  608. });
  609. if (gather_select) {
  610. gather_select.gather_select = data[sGatherSelect];
  611. }
  612. $('#gather-select-count').html(data[sGatherSelect].tenders.length);
  613. $('#gather-select').modal('hide');
  614. rptArchiveObj.toggleBtn(true);
  615. if (PAGE_SHOW.showArchive) {
  616. rptArchiveObj.showArchivedItem(zTreeOprObj.currentNode);
  617. }
  618. });
  619. }
  620. };
  621. const resetStageSelect = function (resolve = null) {
  622. const data = {}, hintObj = $('#stage-select-hint');
  623. if (!resolve) getCommonParams(data);
  624. data[sStageSelect] = {
  625. stages: [],
  626. };
  627. for (const sc of $('[name=stage-select-check]:checked')) {
  628. data[sStageSelect].stages.push(parseInt($(sc).attr('stage-order')));
  629. }
  630. if (data[sStageSelect].stages.length < parseInt(hintObj.attr('min-select'))) {
  631. hintObj.html('请至少选择' + hintObj.attr('min-select') + '期数据').show();
  632. return;
  633. } else if (data[sStageSelect].stages.length > parseInt(hintObj.attr('max-select'))) {
  634. hintObj.html('最多只能选择' + hintObj.attr('max-select') + '期数据').show();
  635. return;
  636. }
  637. hintObj.hide();
  638. if (resolve) {
  639. resolve(data);
  640. } else {
  641. postData('/report/cDefine', data, function (result) {
  642. reloadReportData(result);
  643. const stage_select = customSelects.stage_select.find(function (x) {
  644. return x.id === zTreeOprObj.currentNode.refId;
  645. });
  646. if (stage_select) {
  647. stage_select.stage_select = data[sStageSelect];
  648. }
  649. $('#stage-select-count').html(data[sStageSelect].stages.length);
  650. $('#stage-select').modal('hide');
  651. rptArchiveObj.toggleBtn(true);
  652. if (PAGE_SHOW.showArchive) {
  653. rptArchiveObj.showArchivedItem(zTreeOprObj.currentNode);
  654. }
  655. });
  656. }
  657. };
  658. const resetMaterialSumSelect = function (resolve = null) {
  659. const data = {}, hintObj = $('#material-sum-select-hint');
  660. if (!resolve) getCommonParams(data);
  661. data[sMaterialSumSelect] = {
  662. materials: [],
  663. };
  664. for (const mc of $('[name=material-sum-select-check]:checked')) {
  665. data[sMaterialSumSelect].materials.push(parseInt($(mc).attr('material-order')));
  666. }
  667. if (data[sMaterialSumSelect].materials.length < parseInt(hintObj.attr('min-select'))) {
  668. hintObj.html('请至少选择' + hintObj.attr('min-select') + '期数据').show();
  669. return;
  670. } else if (data[sMaterialSumSelect].materials.length > parseInt(hintObj.attr('max-select'))) {
  671. hintObj.html('最多只能选择' + hintObj.attr('max-select') + '期数据').show();
  672. return;
  673. }
  674. hintObj.hide();
  675. if (resolve) {
  676. resolve(data);
  677. } else {
  678. postData('/report/cDefine', data, function (result) {
  679. reloadReportData(result);
  680. const material_sum_select = customSelects[sMaterialSumSelect].find(function (x) {
  681. return x.id === zTreeOprObj.currentNode.refId;
  682. });
  683. if (material_sum_select) {
  684. material_sum_select.material_sum_select = data[sMaterialSumSelect];
  685. }
  686. $('#material-sum-select-count').html(data[sMaterialSumSelect].materials.length);
  687. $('#material-sum-select').modal('hide');
  688. rptArchiveObj.toggleBtn(true);
  689. if (PAGE_SHOW.showArchive) {
  690. rptArchiveObj.showArchivedItem(zTreeOprObj.currentNode);
  691. }
  692. });
  693. }
  694. };
  695. const resetChangeSelect = function (resolve = null) {
  696. const data = {}, hintObj = $('#change-select-hint');
  697. if (!resolve) getCommonParams(data);
  698. data[sChangeSelect] = [];
  699. for (const sc of $('[name=change-select-check]:checked')) {
  700. data[sChangeSelect].push(sc.value);
  701. }
  702. if (data[sChangeSelect].length === 0) {
  703. hintObj.html('请至少选择一条变更令').show();
  704. return;
  705. } else {
  706. hintObj.hide();
  707. }
  708. if (resolve) {
  709. resolve(data);
  710. } else {
  711. postData('/report/cDefine', data, function (result) {
  712. changeObj.latestSelect = data[sChangeSelect];
  713. reloadReportData(result);
  714. $('#change-select').modal('hide');
  715. rptArchiveObj.toggleBtn(true);
  716. if (PAGE_SHOW.showArchive) {
  717. rptArchiveObj.showArchivedItem(zTreeOprObj.currentNode);
  718. }
  719. });
  720. }
  721. };
  722. const _createTenderTreeForCross = function (tenders, category, rstItems) {
  723. if (rstItems instanceof Array && rstItems.length === 0) {
  724. //1. 先确定category方式(‘年份’、‘姓名’、‘类型’)及顺序
  725. let ctArr = [];
  726. for (let cat of category) {
  727. if (cat.level) {
  728. ctArr.push(cat);
  729. }
  730. }
  731. ctArr.sort(function (item1, item2) {
  732. return parseInt(item1.level) - parseInt(item2.level);
  733. }); //保证顺序
  734. const _buildDeftNodes = function(startIdx, parentItem) {
  735. if (ctArr.length > startIdx) {
  736. let item = {};
  737. if (parentItem instanceof Array) {
  738. parentItem.push(item);
  739. } else {
  740. parentItem.items.push(item);
  741. }
  742. for (let idx = 0; idx < ctArr[startIdx].value.length; idx++) {
  743. item.name = ctArr[startIdx].value[idx].value;
  744. item.id = ctArr[startIdx].id; //这个相当于类型id,如68:年份 69:类型,105:姓名
  745. item.value_id = ctArr[startIdx].value[idx].id; //每个大类下又有小类,如:2018/2019, 土建/房建, 具体用户姓名...
  746. item.cid = ctArr[startIdx].value[idx].cid; //这个值 = item.id
  747. item.pid = ctArr[startIdx].value[idx].pid; //project id?
  748. item.tenderId = -1;
  749. item.selected = false;
  750. item.isParent = true;
  751. item.last_stage = -1;
  752. item.items = [];
  753. _buildDeftNodes(startIdx + 1, item);
  754. }
  755. }
  756. };
  757. // const _get
  758. //2. 创建基本结构
  759. _buildDeftNodes(0, rstItems);
  760. //3. 挂上标段
  761. const _putupTheTender = function (tender) {
  762. const _findType = function (parentItem) {
  763. for (let cat of tender.category) {
  764. if (cat.cid === parentItem.cid && cat.value === parentItem.value_id) {
  765. if (parentItem.items.length === 0) {
  766. // 到底了,挂上
  767. let lastStage = -1;
  768. if (tender.lastStage) {
  769. lastStage = tender.lastStage.times;
  770. }
  771. let item = {
  772. name: tender.name,
  773. id : -1,
  774. value_id: cat.value,
  775. cid : cat.cid,
  776. pid : -1,
  777. tenderId: tender.id,
  778. selected : false,
  779. isParent: true,
  780. last_stage: lastStage,
  781. items : [],
  782. }
  783. parentItem.items.push(item);
  784. } else {
  785. for (let nodeItem of parentItem.items) {
  786. _findType(tender, nodeItem);
  787. }
  788. }
  789. break;
  790. }
  791. }
  792. };
  793. for (let nodeItem of rstItems) {
  794. _findType(nodeItem);
  795. }
  796. };
  797. for (let tender of tenders) {
  798. _putupTheTender(tender);
  799. }
  800. }
  801. };
  802. const initTenderTreeForCross = function (tenders, category) {
  803. //用户跨标段设置电子签名用
  804. let rstItems = [];
  805. _createTenderTreeForCross(tenders, category, rstItems);
  806. _buildTenderRow('batch_projects_individual', rstItems);
  807. };
  808. const _buildTenderRow = function(tbDomId, topTreeNodes) {
  809. let tbDom = $("#" + tbDomId);
  810. tbDom.empty();
  811. tbDom.append('<tr><th>名称</th><th>计量期</th><th>签名</th><th>选择</th></tr>');
  812. let _pushRptLine = function (nodeItem, level) {
  813. if (nodeItem.isParent) {
  814. tbDom.append('<tr><td class="in-'+ (level + 1) + '"><i class="fa fa-folder-o"></i>&nbsp;' + nodeItem.name + '</td><td></td><td></td><td></td></tr>')
  815. //<td class="in-1"><i class="fa fa-folder-o"></i>&nbsp;2019</td>
  816. } else {
  817. //
  818. }
  819. };
  820. for (const topItem of topTreeNodes) {
  821. _pushRptLine(topItem, 0);
  822. }
  823. };
  824. const initTenderTree = function (tenders, category) {
  825. const gsSpread = SpreadJsObj.createNewSpread($('#gather-source-spread')[0]);
  826. gsObj.gsSheet = gsSpread.getActiveSheet();
  827. const spreadSetting = {
  828. cols: [
  829. {title: '选择', field: 'selected', hAlign: 1, width: 40, formatter: '@', cellType: 'checkbox', readOnly: true},
  830. {title: '名称', field: 'name', hAlign: 0, width: 300, formatter: '@', readOnly: true, cellType: 'tree'},
  831. {title: '期数', field: 'phase', hAlign: 1, width: 60, formatter: '@', readOnly: true},
  832. {title: '审批状态', field: 'status', hAlign: 1, width: 60, formatter: '@', readOnly: true}
  833. ],
  834. emptyRows: 0,
  835. headRows: 1,
  836. headRowHeight: [32],
  837. defaultRowHeight: 21,
  838. headerFont: '12px 微软雅黑',
  839. font: '12px 微软雅黑',
  840. headColWidth: [0],
  841. selectedBackColor: '#fffacd',
  842. };
  843. SpreadJsObj.initSheet(gsObj.gsSheet, spreadSetting);
  844. gsObj.tenderSourceTree = Tender2Tree.convert(category, tenders, ledgerAuditConst, auditConst);
  845. SpreadJsObj.loadSheetData(gsObj.gsSheet, SpreadJsObj.DataType.Tree, gsObj.tenderSourceTree);
  846. gsSpread.bind(spreadNS.Events.ButtonClicked, gatherSelectSpreadObj.gsButtonClicked);
  847. const grSpread = SpreadJsObj.createNewSpread($('#gather-result-spread')[0]);
  848. gsObj.grSheet = grSpread.getActiveSheet();
  849. grSpread.bind(spreadNS.Events.ButtonClicked, gatherSelectSpreadObj.grButtonClicked);
  850. $('#gather-hint').hide();
  851. $('#gather-select').bind('shown.bs.modal', function () {
  852. if (gsSpread) gsSpread.refresh();
  853. if (grSpread) grSpread.refresh();
  854. });
  855. $('.datepicker-here').datepicker({
  856. autoClose: true,
  857. });
  858. };
  859. const comfirmSelectPromise = function (rptName, gather_select) {
  860. const promise = new Promise(function (resolve, reject) {
  861. init(gather_select.custom_define, customSelects.stageFlow, gather_select, rptName, resolve, reject);
  862. });
  863. return promise;
  864. };
  865. const getCustomSelect = async function (params) {
  866. if (!params.rpt_ids || params.rpt_ids.length === 0) return;
  867. const currentRptId = zTreeOprObj.currentNode ? zTreeOprObj.currentNode.refId : -1;
  868. params.customSelect = [];
  869. const chkNodes = zTreeOprObj.treeObj.getCheckedNodes(true);
  870. for (const rptId of params.rpt_ids) {
  871. const gather_select = customSelects.gather_select.find(function (x) {
  872. return x.id === rptId;
  873. });
  874. const stage_select = customSelects.stage_select.find(function (x) {
  875. return x.id === rptId;
  876. });
  877. const change_select = customSelects.change_select.find(function (x) {
  878. return x.id === rptId;
  879. });
  880. const material_sum_select = customSelects.material_sum_select.find(function (x) {
  881. return x.id === rptId;
  882. });
  883. if (gather_select && gather_select.custom_define && gather_select.custom_define[sGatherSelect].enable) {
  884. if (rptId === currentRptId) {
  885. const data = {};
  886. data[sGatherSelect] = gather_select[sGatherSelect];
  887. params.customSelect.push(data);
  888. } else {
  889. const chkNode = chkNodes.find(function (x) { return x.refId === rptId});
  890. const select = await comfirmSelectPromise(chkNode ? chkNode.name : '', gather_select);
  891. params.customSelect.push(select);
  892. $('#gather-select').modal('hide');
  893. }
  894. } else if (stage_select && stage_select.custom_define && stage_select.custom_define[sStageSelect].enable) {
  895. if (rptId === currentRptId) {
  896. const data = {};
  897. data[sStageSelect] = stage_select[sStageSelect];
  898. params.customSelect.push(data);
  899. } else {
  900. const chkNode = chkNodes.find(function (x) { return x.refId === rptId});
  901. const select = await comfirmSelectPromise(chkNode ? chkNode.name : '', stage_select);
  902. params.customSelect.push(select);
  903. $('#stage-select').modal('hide');
  904. }
  905. } else if (change_select && change_select.custom_define && change_select.custom_define[sChangeSelect].enable ) {
  906. if (rptId === currentRptId && changeObj.latestPush) {
  907. const data = {};
  908. data[sChangeSelect] = changeObj.latestSelect;
  909. params.customSelect.push(data);
  910. } else {
  911. const chkNode = chkNodes.find(function (x) { return x.refId === rptId});
  912. const select = await comfirmSelectPromise(chkNode ? chkNode.name : '', change_select);
  913. params.customSelect.push(select);
  914. $('#change-select').modal('hide');
  915. }
  916. } else if (material_sum_select && material_sum_select.custom_define && material_sum_select.custom_define[sMaterialSumSelect].enable) {
  917. if (rptId === currentRptId) {
  918. const data = {};
  919. data[sMaterialSumSelect] = material_sum_select[sMaterialSumSelect];
  920. params.customSelect.push(data);
  921. } else {
  922. const chkNode = chkNodes.find(function (x) { return x.refId === rptId});
  923. const select = await comfirmSelectPromise(chkNode ? chkNode.name : '', material_sum_select);
  924. params.customSelect.push(select);
  925. $('#material-sum-select').modal('hide');
  926. }
  927. } else {
  928. params.customSelect.push(null);
  929. }
  930. }
  931. };
  932. const showMaterialSelect = function () {
  933. const needShow = function () {
  934. if (zTreeOprObj.currentNode) {
  935. const ms = dataSelects.material_select.find(function (x) { return x.id === zTreeOprObj.currentNode.refId});
  936. if (ms) return true;
  937. }
  938. const chkNodes = zTreeOprObj.treeObj.getCheckedNodes(true);
  939. for (const node of chkNodes) {
  940. const ms = dataSelects.material_select.find(function (x) { return x.id === node.refId});
  941. if (ms) return true;
  942. }
  943. return false;
  944. };
  945. if (needShow()) {
  946. $('#material').show();
  947. } else {
  948. $('#material').hide();
  949. }
  950. };
  951. const postReportData = function (url, params, successCallback, errorCallBack, showWaiting = true) {
  952. if (showWaiting) showWaitingView();
  953. $.ajax({
  954. type:"POST",
  955. url: url,
  956. data: {'params': JSON.stringify(params)},
  957. dataType: 'json',
  958. cache: false,
  959. timeout: 60000,
  960. beforeSend: function(xhr) {
  961. let csrfToken = Cookies.get('csrfToken_j');
  962. xhr.setRequestHeader('x-csrf-token', csrfToken);
  963. },
  964. success: function(result){
  965. successCallback(result);
  966. if (showWaiting) closeWaitingView();
  967. },
  968. error: function(jqXHR, textStatus, errorThrown){
  969. toastr.error('error: ' + textStatus + " " + errorThrown);
  970. if (errorCallBack) {
  971. errorCallBack();
  972. }
  973. if (showWaiting) closeWaitingView();
  974. }
  975. });
  976. };
  977. const changeMaterial = function (obj) {
  978. $('#material-select').attr('m-order', $(obj).attr('m-order')).html(obj.innerText);
  979. const data = {};
  980. getCommonParams(data);
  981. postReportData('/tender/report_api/getReport', data, reloadReportData);
  982. };
  983. return {
  984. init,
  985. resetAuditSelect, resetGatherSelect, resetStageSelect, resetChangeSelect, resetMaterialSumSelect,
  986. initTenderTree,
  987. initTenderTreeForCross,
  988. getCustomSelect,
  989. showMaterialSelect, changeMaterial,
  990. };
  991. })();