rpt_main.js 56 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157
  1. /**
  2. * Created by Tony on 2017/6/26.
  3. */
  4. 'use strict'
  5. const PRE_PAGE_OFFSET = 150;
  6. const NEXT_PAGE_OFFSET = 160;
  7. const FIRST_PAGE_OFFSET = 50;
  8. const LAST_PAGE_OFFSET = 60;
  9. const WAIT_TIME_EXPORT = 12000;
  10. let fontSuffixMapObj = {"表标题": "title", "列标题": "column", "正文内容": "content", "合计": "summary", "表眉/表脚": "header_footer"};
  11. let rptTplObj = {
  12. hasInitialized: false,
  13. pdfFont: {'SmartSimsun': [], 'simhei': [], 'simkai': []},
  14. iniPage: function() {
  15. let me = this;
  16. if (!me.hasInitialized) {
  17. zTreeOprObj.getCustomerCfg();
  18. zTreeOprObj.getReportTemplateTree();
  19. zTreeOprObj.selectedPrjIDs = [];
  20. me.hasInitialized = true;
  21. let canvas = document.getElementById("rptCanvas");
  22. canvas.onclick = canvasOprObj.canvasOnClick;
  23. canvas.onmousemove = canvasOprObj.canvasOnMouseMove;
  24. if (JpcJsPDFHelper.doc === null) {
  25. JpcJsPDFHelper.initialize('p', 'pt', 'a4');
  26. }
  27. dynamicLoadJs('/lib/jspdf/SmartSimsun-normal.js');
  28. dynamicLoadJs('/lib/jspdf/SmartSimsun-bold.js', me.pdfFontSimsunCallBack);
  29. }
  30. },
  31. pdfFontSimsunCallBack: function() {
  32. rptTplObj.pdfFont['SmartSimsun'].push('normal');
  33. rptTplObj.pdfFont['SmartSimsun'].push('bold');
  34. },
  35. pdfFontSimkaiCallBack: function() {
  36. rptTplObj.pdfFont['simkai'].push('normal');
  37. rptTplObj.pdfFont['simkai'].push('bold');
  38. },
  39. pdfFontSimheiCallBack: function() {
  40. rptTplObj.pdfFont['simhei'].push('normal');
  41. rptTplObj.pdfFont['simhei'].push('bold');
  42. }
  43. }
  44. let zTreeOprObj = {
  45. treeObj: null,
  46. prjFolderTreeObj: null,
  47. currentNode: null,
  48. checkedRptTplNodes: null,
  49. currentRptPageRst: null,
  50. reportPageCfg: null,
  51. defReportPageCfg: null,
  52. currentPage: 1,
  53. maxPages: 0,
  54. selectedPrjIDs: [],
  55. countChkedRptTpl: function () {
  56. let me = zTreeOprObj;
  57. if (me.treeObj) {
  58. me.checkedRptTplNodes = [];
  59. let chkNodes = me.treeObj.getCheckedNodes(true), cnt = 0, hasCurrentNode = false;
  60. for (let node of chkNodes) {
  61. if (node.nodeType === TPL_TYPE_TEMPLATE) {
  62. cnt++;
  63. me.checkedRptTplNodes.push(node);
  64. if (me.currentNode === node) hasCurrentNode = true;
  65. }
  66. }
  67. if (!hasCurrentNode && cnt === 0 && me.currentNode !== null) {
  68. //这里根据实际需求再做处理
  69. cnt++;
  70. me.checkedRptTplNodes.push(me.currentNode);
  71. }
  72. $("#export_div").find("span").each(function(cIdx,elementSpan){
  73. elementSpan.innerText = cnt;
  74. });
  75. $("#print_div").find("span").each(function(cIdx,elementSpan){
  76. elementSpan.innerText = cnt;
  77. });
  78. }
  79. },
  80. getReportTemplateTree: function() {
  81. let me = zTreeOprObj, params = {};
  82. params.engineerId = projectObj.project.projectInfo.property.engineering;
  83. let private_chk_hide = function (chkTplItem) {
  84. //考虑未来拓展,统一在此判断报表模板是否显示
  85. let rst = false;
  86. // if (chkTplItem.hasOwnProperty('flags') && chkTplItem.flags.hasOwnProperty('taxType') && chkTplItem.flags['taxType'] !== null &&
  87. // parseInt(chkTplItem.flags['taxType']) !== parseInt(projectObj.project.projectInfo.property.taxType)) {
  88. // rst = true;
  89. // }
  90. //重庆养护系统的判断逻辑有所不同
  91. if (chkTplItem.hasOwnProperty('flags') && chkTplItem.flags.hasOwnProperty('valuationType') && chkTplItem.flags['valuationType'] !== null &&
  92. chkTplItem.flags['valuationType'] !== projectObj.project.projectInfo.property.valuationType) {
  93. rst = true;
  94. }
  95. return rst;
  96. };
  97. // projectObj.project.projectInfo.property.taxType === 1 //1: 一般计税 2: 简易计税
  98. CommonAjax.postEx("report_tpl_api/getRptTplTree", params, 20000, true, function(result){
  99. let private_remove_hide_item = function (items, nlv) {
  100. if (items && items.length > 0) {
  101. for (let i = items.length - 1; i >= 0; i--) {
  102. if (!(items[i].released) && items[i].nodeType === 2) {
  103. items.splice(i, 1);
  104. } else if(private_chk_hide(items[i])) {
  105. items.splice(i, 1);
  106. } else {
  107. if (items[i].items && items[i].items.length > 0) {
  108. private_remove_hide_item(items[i].items, nlv + 1);
  109. if (items[i].items.length === 0 && nlv > 0) {
  110. items.splice(i, 1);
  111. }
  112. }
  113. }
  114. }
  115. }
  116. }
  117. let nodeLv = 0;
  118. private_remove_hide_item(result, nodeLv);
  119. for (let topNode of result) {
  120. if (topNode.userId === "-100") {
  121. topNode.name = topNode.name + " - 标准报表";
  122. } else {
  123. topNode.name = topNode.name + " - 定制报表";
  124. }
  125. }
  126. zTreeHelper.createTreeDirectly(result, rpt_tpl_setting, "rptTplTree", me);
  127. me.refreshNodes();
  128. }, null, null);
  129. },
  130. getCustomerCfg: function() {
  131. let me = zTreeOprObj, params = {};
  132. params.engineerId = projectObj.project.projectInfo.property.engineering;
  133. CommonAjax.postEx("report_tpl_api/getCustomizeCfg", params, 20000, true, function(result){
  134. if (result) {
  135. me.defReportPageCfg = result[0];
  136. me.reportPageCfg = result[1];
  137. me.iniFontCfgDom(me.reportPageCfg);
  138. me.renderRptCfg(result[1]);
  139. } else {
  140. me.reportPageCfg = null;
  141. me.defReportPageCfg = null;
  142. }
  143. }, null, null
  144. );
  145. },
  146. iniFontCfgDom: function (cfg) {
  147. for (let font of cfg.fonts) {
  148. let domArrs = [];
  149. let fontPropSuffix = fontSuffixMapObj[font.CfgDispName];
  150. domArrs.push("<div class='row mb-1'>");
  151. //1. label
  152. domArrs.push("<div class='col-3'>" + font.CfgDispName + "</div>");
  153. //2. font name
  154. domArrs.push("<div class='col-3'>");
  155. domArrs.push("<select class='form-control input-sm' id='fontName_" + fontPropSuffix + "' onchange='rptControlObj.changeFontMain(\"" + font.CfgDispName + "\", \"Name\", this)'>");
  156. domArrs.push("<option>宋体</option><option>楷体</option><option>黑体</option>");
  157. domArrs.push("</select>");
  158. domArrs.push("</div>");
  159. //3. font height
  160. domArrs.push("<div class='col-3'>");
  161. domArrs.push("<input class='form-control input-sm' id='fontHeight_" + fontPropSuffix + "' type='number' value='30' step='1' min='6' max='66' " +
  162. "onchange='rptControlObj.changeFontMain(\"" + font.CfgDispName + "\", \"FontHeight\", this)' " +
  163. "onkeyup='rptControlObj.changeFontMain(\"" + font.CfgDispName + "\", \"FontHeight\", this)'>");
  164. domArrs.push("</div>");
  165. //4. font bold italic underline
  166. domArrs.push("<div class='col-3'>");
  167. domArrs.push("<a id='font_bold_" + fontPropSuffix + "' class='btn btn-sm btn-outline-secondary' title='加粗' onclick='rptControlObj.changeFontAdhoc(\"" + font.CfgDispName + "\", \"FontBold\", this)'><i class='fa fa-bold'></i></a>");
  168. domArrs.push("<a id='font_italic_" + fontPropSuffix + "' class='btn btn-sm btn-outline-secondary' title='斜体' onclick='rptControlObj.changeFontAdhoc(\"" + font.CfgDispName + "\", \"FontItalic\", this)'><i class='fa fa-italic'></i></a>");
  169. domArrs.push("<a id='font_underline_" + fontPropSuffix + "' class='btn btn-sm btn-outline-secondary' title='下划线' onclick='rptControlObj.changeFontAdhoc(\"" + font.CfgDispName + "\", \"FontUnderline\", this)'><i class='fa fa-underline'></i></a>");
  170. domArrs.push("</div>");
  171. //
  172. domArrs.push("</div>");
  173. $(domArrs.join("")).insertBefore($("#font_cfg_blank_flag"));
  174. }
  175. },
  176. renderRptCfg: function (cfg) {
  177. $("#elementMargin_Left").get(0).value = cfg.margins.Left;
  178. $("#elementMargin_Right").get(0).value = cfg.margins.Right;
  179. $("#elementMargin_Top").get(0).value = cfg.margins.Top;
  180. $("#elementMargin_Bottom").get(0).value = cfg.margins.Bottom;
  181. for (let font of cfg.fonts) {
  182. let fontPropSuffix = fontSuffixMapObj[font.CfgDispName];
  183. document.getElementById("fontName_" + fontPropSuffix).value = font.Name;
  184. document.getElementById("fontHeight_" + fontPropSuffix).value = font.FontHeight;
  185. document.getElementById("font_bold_" + fontPropSuffix).className = (font.FontBold === "T")?"btn btn-sm btn-outline-secondary active":"btn btn-sm btn-outline-secondary";
  186. document.getElementById("font_italic_" + fontPropSuffix).className = (font.FontItalic === "T")?"btn btn-sm btn-outline-secondary active":"btn btn-sm btn-outline-secondary";
  187. document.getElementById("font_underline_" + fontPropSuffix).className = (font.FontUnderline === "T")?"btn btn-sm btn-outline-secondary active":"btn btn-sm btn-outline-secondary";
  188. }
  189. document.getElementById("rpt_vertical_line").checked = cfg.showVerticalLine;
  190. document.getElementById("rpt_narrow").checked = cfg.isNarrow;
  191. // document.getElementById("rpt_narrow").checked = false;
  192. document.getElementById("rpt_fill_zero").checked = cfg.fillZero;
  193. },
  194. extractRptCfg: function (cfg) {
  195. cfg.margins.Left = $("#elementMargin_Left").get(0).value;
  196. cfg.margins.Right = $("#elementMargin_Right").get(0).value;
  197. cfg.margins.Top = $("#elementMargin_Top").get(0).value;
  198. cfg.margins.Bottom = $("#elementMargin_Bottom").get(0).value;
  199. for (let font of cfg.fonts) {
  200. let fontPropSuffix = fontSuffixMapObj[font.CfgDispName];
  201. font.Name = document.getElementById("fontName_" + fontPropSuffix).value;
  202. font.FontHeight = document.getElementById("fontHeight_" + fontPropSuffix).value;
  203. font.FontBold = (document.getElementById("font_bold_" + fontPropSuffix).className === "btn btn-sm btn-outline-secondary active")?"T":"F";
  204. font.FontItalic = (document.getElementById("font_italic_" + fontPropSuffix).className === "btn btn-sm btn-outline-secondary active")?"T":"F";
  205. font.FontUnderline = (document.getElementById("font_underline_" + fontPropSuffix).className === "btn btn-sm btn-outline-secondary active")?"T":"F";
  206. }
  207. cfg.showVerticalLine = document.getElementById("rpt_vertical_line").checked;
  208. cfg.isNarrow = document.getElementById("rpt_narrow").checked;
  209. cfg.fillZero = document.getElementById("rpt_fill_zero").checked;
  210. },
  211. refreshNodes: function() {
  212. let me = this;
  213. let private_setupIsParent = function(node){
  214. node.isParent = (node.nodeType === RT.NodeType.NODE || node.level === 0);
  215. if (node.items && node.items.length) {
  216. for (let i = 0; i < node.items.length; i++) {
  217. private_setupIsParent(node.items[i]);
  218. }
  219. }
  220. };
  221. let topNodes = me.treeObj.getNodes();
  222. for (let i = 0; i < topNodes.length; i++) {
  223. private_setupIsParent(topNodes[i]);
  224. }
  225. me.treeObj.refresh();
  226. },
  227. onCheck: function(event, treeId, treeNode) {
  228. zTreeOprObj.countChkedRptTpl();
  229. },
  230. onClick: function(event,treeId,treeNode) {
  231. let me = zTreeOprObj;
  232. if (treeNode.nodeType === TPL_TYPE_TEMPLATE && treeNode.refId > 0) {
  233. me.currentNode = treeNode;
  234. if (treeNode.hasOwnProperty('flags') && treeNode.flags.hasOwnProperty('reportType') && treeNode['flags']['reportType'] !== 'NA') {
  235. if (treeNode['flags']['reportType'] === 'billSummary') {
  236. me.requestPrjFolderForBillsSummary();
  237. } else if (treeNode['flags']['reportType'] === 'gljSummary') {
  238. me.requestPrjFolderForGljSummary();
  239. }
  240. } else {
  241. let params = {};
  242. let pageSize = rptControlObj.getCurrentPageSize();
  243. params.pageSize = pageSize;
  244. params.rpt_tpl_id = treeNode.refId;
  245. params.prj_id = projectObj.project.projectInfo.ID;
  246. params.custCfg = me.reportPageCfg;
  247. me.requestNormalReport(params);
  248. }
  249. me.countChkedRptTpl();
  250. }
  251. },
  252. changePageSize: function(dom) {
  253. let me = zTreeOprObj,
  254. targetDom = document.getElementById("btnRptPageSize");
  255. let tmpStr = targetDom.innerHTML.trim();
  256. targetDom.innerHTML = dom.innerHTML.trim();
  257. dom.innerHTML = tmpStr;
  258. me.changeCfg();
  259. },
  260. changeOrientation: function(dom) {
  261. let me = zTreeOprObj,
  262. targetDom = document.getElementById("btnRptOrientation");
  263. let tmpStr = targetDom.innerHTML.trim();
  264. targetDom.innerHTML = dom.innerHTML.trim();
  265. dom.innerHTML = tmpStr;
  266. me.changeCfg();
  267. },
  268. changeCfg: function() {
  269. let me = zTreeOprObj;
  270. if (me.currentNode) {
  271. if (me.currentNode.hasOwnProperty('flags') && me.currentNode.flags.hasOwnProperty('reportType') && me.currentNode['flags']['reportType'] !== 'NA') {
  272. let refRptTplIds = [], refBillSumPrjsIds = [], refGljSumPrjsIds = [];
  273. if (me.currentNode['flags']['reportType'] === 'billSummary') {
  274. refBillSumPrjsIds.push(me.currentNode.refId);
  275. } else if (me.currentNode['flags']['reportType'] === 'gljSummary') {
  276. refGljSumPrjsIds.push(me.currentNode.refId);
  277. }
  278. if (zTreeOprObj.selectedPrjIDs.length > 0) {
  279. let params = rptControlObj.creatCommonExportParam(refRptTplIds, refBillSumPrjsIds, refGljSumPrjsIds);
  280. params.pageSize = rptControlObj.getCurrentPageSize();
  281. params.orientation = rptControlObj.getCurrentOrientation();
  282. params.rpt_ids = refRptTplIds;
  283. params.rpt_bill_tpl_ids = refBillSumPrjsIds;
  284. params.rpt_glj_tpl_ids = refGljSumPrjsIds;
  285. params.custCfg = me.reportPageCfg;
  286. CommonAjax.postEx("report_api/getMultiReports", params, 10000, true,
  287. function(result){
  288. hintBox.unWaitBox();
  289. let pageRst = result[0];
  290. let canvas = document.getElementById("rptCanvas");
  291. if (pageRst && pageRst.items && pageRst.items.length > 0) {
  292. me.resetAfter(pageRst);
  293. me.currentRptPageRst = pageRst;
  294. me.maxPages = pageRst.items.length;
  295. me.currentPage = 1;
  296. me.displayPageValue();
  297. let size = JpcCanvasOutput.getReportSizeInPixel(me.currentRptPageRst, getScreenDPI());
  298. canvas.width = size[0] + 20;
  299. if (size[1] > size[0]) {
  300. canvas.height = size[1] + 100;
  301. } else {
  302. canvas.height = size[1] + 50;
  303. }
  304. me.showPage(1, canvas);
  305. } else {
  306. //返回了无数据表
  307. JpcCanvasOutput.cleanCanvas(canvas);
  308. JpcCanvasOutput.drawPageBorder(me.currentRptPageRst, canvas, getScreenDPI());
  309. }
  310. }, function(err){
  311. hintBox.unWaitBox();
  312. }, function(ex){
  313. hintBox.unWaitBox();
  314. }
  315. );
  316. } else {
  317. if (me.currentNode['flags']['reportType'] === 'billSummary') {
  318. me.requestPrjFolderForBillsSummary();
  319. } else if (me.currentNode['flags']['reportType'] === 'gljSummary') {
  320. me.requestPrjFolderForGljSummary();
  321. }
  322. }
  323. } else {
  324. let params = {};
  325. params.pageSize = rptControlObj.getCurrentPageSize();
  326. params.orientation = rptControlObj.getCurrentOrientation();
  327. params.rpt_tpl_id = me.currentNode.refId;
  328. params.prj_id = projectObj.project.projectInfo.ID;
  329. params.custCfg = me.reportPageCfg;
  330. me.requestNormalReport(params);
  331. }
  332. }
  333. },
  334. resetAfter: function (pageRst) {
  335. let size = pageRst[JV.NODE_PAGE_INFO][JV.NODE_PAGE_SIZE].slice(0);
  336. if (size[0] > size[1]) {
  337. document.getElementById("btnRptOrientation").innerHTML = "横向";
  338. document.getElementById("hrefRptOrientation").innerHTML = "纵向";
  339. } else {
  340. document.getElementById("btnRptOrientation").innerHTML = "纵向";
  341. document.getElementById("hrefRptOrientation").innerHTML = "横向";
  342. }
  343. },
  344. requestNormalReport: function (params) {
  345. let me = zTreeOprObj;
  346. hintBox.waitBox();
  347. CommonAjax.postEx("report_api/getReport", params, 60000, true,
  348. function(result){
  349. hintBox.unWaitBox();
  350. let pageRst = result;
  351. let canvas = document.getElementById("rptCanvas");
  352. if (pageRst && pageRst.items && pageRst.items.length > 0) {
  353. me.resetAfter(pageRst);
  354. me.currentRptPageRst = pageRst;
  355. me.maxPages = pageRst.items.length;
  356. me.currentPage = 1;
  357. me.displayPageValue();
  358. let size = JpcCanvasOutput.getReportSizeInPixel(me.currentRptPageRst, getScreenDPI());
  359. canvas.width = size[0] + 20;
  360. if (size[1] > size[0]) {
  361. canvas.height = size[1] + 100;
  362. } else {
  363. canvas.height = size[1] + 50;
  364. }
  365. me.showPage(1, canvas);
  366. } else {
  367. //返回了无数据表
  368. JpcCanvasOutput.cleanCanvas(canvas);
  369. JpcCanvasOutput.drawPageBorder(me.currentRptPageRst, canvas, getScreenDPI());
  370. }
  371. }, function(err){
  372. hintBox.unWaitBox();
  373. }, function(ex){
  374. hintBox.unWaitBox();
  375. }
  376. );
  377. },
  378. requestPrjFolderCommon: function () {
  379. let me = zTreeOprObj;
  380. hintBox.waitBox();
  381. $.ajax({
  382. type:"POST",
  383. url: '/pm/api/getProjects',
  384. data: {'data': JSON.stringify({"user_id": userID, "compilation": projectObj.project.projectInfo.compilation})},
  385. dataType: 'json',
  386. cache: false,
  387. timeout: 15000,
  388. success: function(result){
  389. hintBox.unWaitBox();
  390. if (result.error === 0) {
  391. //console.log(result.data);
  392. let currPrjParentID = projectObj.project.projectInfo.ParentID;
  393. let selectedProjects = [];
  394. for (let prj of result.data) {
  395. if (currPrjParentID === prj.ParentID) {
  396. selectedProjects.push({name: prj.name, ID: prj.ID});
  397. }
  398. }
  399. $("#show_project_folder").trigger("click");
  400. me.prjFolderTreeObj = $.fn.zTree.init($("#prjFolderTree"), rpt_prj_folder_setting, selectedProjects);
  401. me.prjFolderTreeObj.expandAll(true);
  402. } else {
  403. alert('error: ' + result.message);
  404. }
  405. },
  406. error: function(jqXHR, textStatus, errorThrown){
  407. hintBox.unWaitBox();
  408. alert('error ' + textStatus + " " + errorThrown);
  409. }
  410. });
  411. },
  412. requestPrjFolderForBillsSummary: function () {
  413. let me = zTreeOprObj;
  414. $("#divReqBillSummary")[0].style.display = "";
  415. $("#divReqGljSummary")[0].style.display = "none";
  416. $("#divReqCommonSummaryExcel")[0].style.display = "none";
  417. $("#divReqCommonSummaryMultiExcel")[0].style.display = "none";
  418. $("#divReqCommonSummaryPDF")[0].style.display = "none";
  419. me.requestPrjFolderCommon();
  420. },
  421. requestPrjFolderForGljSummary: function () {
  422. let me = zTreeOprObj;
  423. $("#divReqBillSummary")[0].style.display = "none";
  424. $("#divReqGljSummary")[0].style.display = "";
  425. $("#divReqCommonSummaryExcel")[0].style.display = "none";
  426. $("#divReqCommonSummaryMultiExcel")[0].style.display = "none";
  427. $("#divReqCommonSummaryPDF")[0].style.display = "none";
  428. me.requestPrjFolderCommon();
  429. },
  430. requestBillsSummaryRpt: function () {
  431. let me = zTreeOprObj;
  432. let nodes = me.prjFolderTreeObj.getCheckedNodes(true);
  433. if (nodes.length > 0) {
  434. hintBox.waitBox();
  435. let params = {};
  436. params.pageSize = rptControlObj.getCurrentPageSize();
  437. params.rpt_tpl_id = me.currentNode.refId;
  438. params.custCfg = me.reportPageCfg;
  439. params.prjIds = [];
  440. me.selectedPrjIDs = [];
  441. for (let node of nodes) {
  442. params.prjIds.push(node.ID);
  443. me.selectedPrjIDs.push(node.ID);
  444. }
  445. CommonAjax.postEx("report_api/getBillsSummaryReport", params, 26000, true,
  446. function(result){
  447. hintBox.unWaitBox();
  448. let pageRst = result;
  449. let canvas = document.getElementById("rptCanvas");
  450. if (pageRst && pageRst.items && pageRst.items.length > 0) {
  451. me.resetAfter(pageRst);
  452. me.currentRptPageRst = pageRst;
  453. me.maxPages = pageRst.items.length;
  454. me.currentPage = 1;
  455. me.displayPageValue();
  456. let size = JpcCanvasOutput.getReportSizeInPixel(me.currentRptPageRst, getScreenDPI());
  457. canvas.width = size[0] + 20;
  458. if (size[1] > size[0]) {
  459. canvas.height = size[1] + 100;
  460. } else {
  461. canvas.height = size[1] + 50;
  462. }
  463. me.showPage(1, canvas);
  464. } else {
  465. //返回了无数据表
  466. JpcCanvasOutput.cleanCanvas(canvas);
  467. JpcCanvasOutput.drawPageBorder(me.currentRptPageRst, canvas, getScreenDPI());
  468. }
  469. }, function(err){
  470. hintBox.unWaitBox();
  471. }, function(ex){
  472. hintBox.unWaitBox();
  473. }
  474. );
  475. }
  476. },
  477. requestGljSummaryRpt: function () {
  478. let me = zTreeOprObj;
  479. let nodes = me.prjFolderTreeObj.getCheckedNodes(true);
  480. if (nodes.length > 0) {
  481. hintBox.waitBox();
  482. let params = {};
  483. params.pageSize = rptControlObj.getCurrentPageSize();
  484. params.rpt_tpl_id = me.currentNode.refId;
  485. params.custCfg = me.reportPageCfg;
  486. params.prjIds = [];
  487. zTreeOprObj.selectedPrjIDs = [];
  488. for (let node of nodes) {
  489. params.prjIds.push(node.ID);
  490. zTreeOprObj.selectedPrjIDs.push(node.ID);
  491. }
  492. CommonAjax.postEx("report_api/getGljSummaryReport", params, 26000, true,
  493. function(result){
  494. hintBox.unWaitBox();
  495. let pageRst = result;
  496. let canvas = document.getElementById("rptCanvas");
  497. if (pageRst && pageRst.items && pageRst.items.length > 0) {
  498. me.resetAfter(pageRst);
  499. me.currentRptPageRst = pageRst;
  500. me.maxPages = pageRst.items.length;
  501. me.currentPage = 1;
  502. me.displayPageValue();
  503. let size = JpcCanvasOutput.getReportSizeInPixel(me.currentRptPageRst, getScreenDPI());
  504. canvas.width = size[0] + 20;
  505. if (size[1] > size[0]) {
  506. canvas.height = size[1] + 100;
  507. } else {
  508. canvas.height = size[1] + 50;
  509. }
  510. me.showPage(1, canvas);
  511. } else {
  512. //返回了无数据表
  513. JpcCanvasOutput.cleanCanvas(canvas);
  514. JpcCanvasOutput.drawPageBorder(me.currentRptPageRst, canvas, getScreenDPI());
  515. }
  516. }, function(err){
  517. hintBox.unWaitBox();
  518. }, function(ex){
  519. hintBox.unWaitBox();
  520. }
  521. );
  522. }
  523. },
  524. requestSumAndNormalRptForPDF: function () {
  525. let rpt_names = [], bill_rpt_names = [], glj_rpt_names = [];
  526. let refRptTplIds = [], refBillSumPrjsIds = [], refGljSumPrjsIds = [];
  527. rptControlObj.getTplIdsCommon(refRptTplIds, refBillSumPrjsIds, refGljSumPrjsIds, rpt_names, bill_rpt_names, glj_rpt_names);
  528. let params = rptControlObj.creatCommonExportParam(refRptTplIds, refBillSumPrjsIds, refGljSumPrjsIds);
  529. params.sum_rpt_names = bill_rpt_names.concat(glj_rpt_names);
  530. params.rpt_names = rpt_names;
  531. params.isOneSheet = true;
  532. CommonAjax.postEx("report_api/createPdfFiles", params, WAIT_TIME_EXPORT, true, function(result){
  533. if (result) {
  534. let uuIdUrls = [];
  535. for (let uuIdObj of result) {
  536. let uuIdUrl = "/report_api/getFileByUUID/" + uuIdObj.uuid + "/" + stringUtil.replaceAll(uuIdObj.reportName, "#", "_") + "/pdf";
  537. uuIdUrls.push(uuIdUrl);
  538. }
  539. downloadReport(uuIdUrls);
  540. } else {
  541. //
  542. }
  543. }, null, null
  544. );
  545. },
  546. requestSumAndNormalRptForPDF_Ex: function () {
  547. let rpt_names = [], bill_rpt_names = [], glj_rpt_names = [];
  548. let refRptTplIds = [], refBillSumPrjsIds = [], refGljSumPrjsIds = [];
  549. rptControlObj.getTplIdsCommon(refRptTplIds, refBillSumPrjsIds, refGljSumPrjsIds, rpt_names, bill_rpt_names, glj_rpt_names);
  550. let params = rptControlObj.creatCommonExportParam(refRptTplIds, refBillSumPrjsIds, refGljSumPrjsIds);
  551. params.sum_rpt_names = bill_rpt_names.concat(glj_rpt_names);
  552. params.rpt_names = rpt_names;
  553. params.isOneSheet = true;
  554. CommonAjax.postEx("report_api/getMultiReports", params, 30000, true,
  555. function(result){
  556. let pageSize = rptControlObj.getCurrentPageSize();
  557. for (let idx = 0; idx < result.length; idx++) {
  558. let pageData = result[idx];
  559. JpcJsPDFHelper.outputAsPdf(pageData, pageSize, result[idx][JV.NODE_PAGE_INFO][JV.NODE_MAIN_INFO_RPT_NAME]);
  560. }
  561. },
  562. function(failRst){
  563. console.log(failRst);
  564. },
  565. function(exceptionRst){
  566. console.log(exceptionRst);
  567. }
  568. );
  569. },
  570. requestSumAndNormalRptForMultiExcel: function () {
  571. let rpt_names = [], bill_rpt_names = [], glj_rpt_names = [];
  572. let refRptTplIds = [], refBillSumPrjsIds = [], refGljSumPrjsIds = [];
  573. rptControlObj.getTplIdsCommon(refRptTplIds, refBillSumPrjsIds, refGljSumPrjsIds, rpt_names, bill_rpt_names, glj_rpt_names);
  574. let params = rptControlObj.creatCommonExportParam(refRptTplIds, refBillSumPrjsIds, refGljSumPrjsIds);
  575. params.sum_rpt_names = bill_rpt_names.concat(glj_rpt_names);
  576. params.rpt_names = rpt_names;
  577. params.isOneSheet = true;
  578. CommonAjax.postEx("report_api/createExcelFiles", params, WAIT_TIME_EXPORT, true, function(result){
  579. if (result) {
  580. let uuIdUrls = [];
  581. for (let uuIdObj of result) {
  582. let uuIdUrl = "/report_api/getFileByUUID/" + uuIdObj.uuid + "/" + stringUtil.replaceAll(uuIdObj.reportName, "#", "_") + "/xlsx";
  583. uuIdUrls.push(uuIdUrl);
  584. }
  585. downloadReport(uuIdUrls);
  586. } else {
  587. //
  588. }
  589. }, null, null
  590. );
  591. },
  592. requestSumAndNormalRptForAllInOneExcel: function () {
  593. let orgRptName = projectObj.project.projectInfo.name;
  594. let refRptTplIds = [], refBillSumPrjsIds = [], refGljSumPrjsIds = [];
  595. rptControlObj.getTplIdsCommon(refRptTplIds, refBillSumPrjsIds, refGljSumPrjsIds, null, null, null);
  596. let params = rptControlObj.creatCommonExportParam(refRptTplIds, refBillSumPrjsIds, refGljSumPrjsIds);
  597. params.rptName = orgRptName;
  598. CommonAjax.postEx("report_api/createExcelFilesInOneBook", params, WAIT_TIME_EXPORT, true, function(result){
  599. if (result) {
  600. let uuIdUrls = [];
  601. let uuIdUrl = "/report_api/getFileByUUID/" + result.uuid + "/" + stringUtil.replaceAll(result.reportName, "#", "_") + "/xlsx";
  602. uuIdUrls.push(uuIdUrl);
  603. downloadReport(uuIdUrls);
  604. } else {
  605. //
  606. }
  607. }, null, null
  608. );
  609. },
  610. showPage: function (pageNum, canvas) {
  611. let me = zTreeOprObj;
  612. if (pageNum >= 1 && pageNum <= me.maxPages) {
  613. me.currentPage = pageNum;
  614. JpcCanvasOutput.cleanCanvas(canvas);
  615. JpcCanvasOutput.drawPageBorder(me.currentRptPageRst, canvas, getScreenDPI());
  616. JpcCanvasOutput.drawToCanvas(me.currentRptPageRst, canvas, me.currentPage);
  617. }
  618. me.displayPageValue();
  619. },
  620. displayPageValue: function() {
  621. let me = zTreeOprObj;
  622. $("#rpt_page_num").get(0).value = me.currentPage + "/" + me.maxPages;
  623. }
  624. };
  625. let canvasOprObj = {
  626. canvasOnMouseMove: function (event) {
  627. if (zTreeOprObj.currentNode) {
  628. let x = event.offsetX - JpcCanvasOutput.offsetX, canvas = event.originalTarget;
  629. if (!(canvas)) canvas = event.target; //chrome浏览器不认event.originalTarget,只认event.target或event.currentTarget
  630. if (x < PRE_PAGE_OFFSET) {
  631. canvas.style.cursor = "url(/web/building_saas/img/PreviousPage.cur), auto";
  632. } else if ((canvas.width - x) < NEXT_PAGE_OFFSET) {
  633. canvas.style.cursor = "url(/web/building_saas/img/NextPage.cur), auto";
  634. } else {
  635. canvas.style.cursor = "";
  636. }
  637. }
  638. },
  639. canvasOnClick: function(event){
  640. if (zTreeOprObj.currentNode) {
  641. let x = event.offsetX - JpcCanvasOutput.offsetX, canvas = event.originalTarget;
  642. if (!(canvas)) canvas = event.target; //chrome浏览器不认event.originalTarget,只认event.target或event.currentTarget
  643. if (x < FIRST_PAGE_OFFSET) {
  644. zTreeOprObj.showPage(1, canvas);
  645. } else if (x < PRE_PAGE_OFFSET) {
  646. zTreeOprObj.showPage(zTreeOprObj.currentPage - 1, canvas);
  647. } else if ((canvas.width - x) < LAST_PAGE_OFFSET) {
  648. zTreeOprObj.showPage(zTreeOprObj.maxPages, canvas);
  649. } else if ((canvas.width - x) < NEXT_PAGE_OFFSET) {
  650. zTreeOprObj.showPage(zTreeOprObj.currentPage + 1, canvas);
  651. }
  652. }
  653. }
  654. };
  655. let rptControlObj = {
  656. currentOutputType: "Excel",
  657. currentDownloadUrl: null,
  658. currentDownloadIdx: 0,
  659. getCurrentPageSize: function() {
  660. // let rst = "A4";
  661. let rst = document.getElementById("btnRptPageSize").innerHTML.trim();
  662. //btnRptPageSize
  663. return rst;
  664. },
  665. getCurrentOrientation: function() {
  666. // let rst = "横向";
  667. let rst = document.getElementById("btnRptOrientation").innerHTML.trim();
  668. return rst;
  669. },
  670. getCurrentReportOption: function() {
  671. //
  672. },
  673. changeType: function(newType) {
  674. let me = rptControlObj;
  675. let excelDom = document.getElementById("EXCEL_TYPE");
  676. let pdfDom = document.getElementById("PDF_TYPE");
  677. if (newType === "Excel") {
  678. excelDom.className = "btn btn-block btn-primary";
  679. pdfDom.className = "btn btn-block btn-outline-secondary";
  680. me.currentOutputType = newType;
  681. } else if (newType === "PDF") {
  682. excelDom.className = "btn btn-block btn-outline-secondary";
  683. pdfDom.className = "btn btn-block btn-primary";
  684. me.currentOutputType = newType;
  685. } else {
  686. //me.currentOutputType = newType;
  687. }
  688. },
  689. outputRpt: function() {
  690. let me = rptControlObj;
  691. if (me.currentOutputType === "Excel") {
  692. me.getExcel();
  693. } else if (me.currentOutputType === "PDF") {
  694. me.getPDF();
  695. } else {
  696. //other types if needed.
  697. }
  698. },
  699. getTplIdsCommon: function (refRptTplIds, refBillSumPrjsIds, refGljSumPrjsIds, rpt_names, bill_rpt_names, glj_rpt_names) {
  700. for (let node of zTreeOprObj.checkedRptTplNodes) {
  701. if (node.hasOwnProperty('flags') && node.flags.hasOwnProperty('reportType') && node['flags']['reportType'] !== 'NA') {
  702. if (node['flags']['reportType'] === 'billSummary') {
  703. refBillSumPrjsIds.push(node.refId);
  704. if (bill_rpt_names) bill_rpt_names.push(node.name);
  705. } else if (node['flags']['reportType'] === 'gljSummary') {
  706. refGljSumPrjsIds.push(node.refId);
  707. if (glj_rpt_names) glj_rpt_names.push(node.name);
  708. }
  709. } else {
  710. refRptTplIds.push(node.refId);
  711. if (rpt_names) rpt_names.push(node.name);
  712. }
  713. }
  714. },
  715. creatCommonExportParam: function (refRptTplIds, refBillSumPrjsIds, refGljSumPrjsIds) {
  716. let nodes = (zTreeOprObj.prjFolderTreeObj === null)?[]:zTreeOprObj.prjFolderTreeObj.getCheckedNodes(true);
  717. let rst = {};
  718. rst.prj_id = projectObj.project.projectInfo.ID;
  719. rst.rpt_ids = refRptTplIds;
  720. rst.rpt_bill_tpl_ids = refBillSumPrjsIds;
  721. rst.rpt_glj_tpl_ids = refGljSumPrjsIds;
  722. rst.prjIds = [];
  723. zTreeOprObj.selectedPrjIDs = [];
  724. for (let node of nodes) {
  725. rst.prjIds.push(node.ID);
  726. zTreeOprObj.selectedPrjIDs.push(node.ID);
  727. }
  728. // rst.sum_rpt_names = bill_rpt_names.concat(glj_rpt_names);
  729. // rst.rpt_names = rpt_names;
  730. // rst.isOneSheet = true;
  731. rst.pageSize = rptControlObj.getCurrentPageSize();
  732. rst.orientation = ((zTreeOprObj.checkedRptTplNodes.length > 1)?null:rptControlObj.getCurrentOrientation());
  733. rst.custCfg = zTreeOprObj.reportPageCfg;
  734. rst.option = "normal";
  735. return rst;
  736. },
  737. getAllInOneBook: function () {
  738. if (zTreeOprObj.checkedRptTplNodes && zTreeOprObj.checkedRptTplNodes.length > 0) {
  739. let me = rptControlObj;
  740. let orgRptName = projectObj.project.projectInfo.name;
  741. let refRptTplIds = [], refBillSumPrjsIds = [], refGljSumPrjsIds = [];
  742. rptControlObj.getTplIdsCommon(refRptTplIds, refBillSumPrjsIds, refGljSumPrjsIds);
  743. if (zTreeOprObj.selectedPrjIDs.length > 0 && (refBillSumPrjsIds.length > 0 || refGljSumPrjsIds.length > 0)) {
  744. let params = rptControlObj.creatCommonExportParam(refRptTplIds, refBillSumPrjsIds, refGljSumPrjsIds);
  745. params.rptName = orgRptName;
  746. CommonAjax.postEx("report_api/createExcelFilesInOneBook", params, WAIT_TIME_EXPORT, true, function(result){
  747. if (result) {
  748. let uuIdUrls = [];
  749. let uuIdUrl = "/report_api/getFileByUUID/" + result.uuid + "/" + stringUtil.replaceAll(result.reportName, "#", "_") + "/xlsx";
  750. uuIdUrls.push(uuIdUrl);
  751. downloadReport(uuIdUrls);
  752. } else {
  753. //
  754. }
  755. }, null, null
  756. );
  757. } else {
  758. if (refBillSumPrjsIds.length > 0 || refGljSumPrjsIds.length > 0) {
  759. $("#divReqBillSummary")[0].style.display = "none";
  760. $("#divReqGljSummary")[0].style.display = "none";
  761. $("#divReqCommonSummaryExcel")[0].style.display = "";
  762. $("#divReqCommonSummaryMultiExcel")[0].style.display = "none";
  763. $("#divReqCommonSummaryPDF")[0].style.display = "none";
  764. zTreeOprObj.requestPrjFolderCommon(); //先处理需要汇总的报表,走另外一个分支
  765. } else if (refRptTplIds.length > 0) {
  766. let params = {};
  767. params.prj_id = projectObj.project.projectInfo.ID;
  768. params.rpt_ids = refRptTplIds;
  769. params.rptName = orgRptName;
  770. params.pageSize = me.getCurrentPageSize();
  771. params.orientation = ((zTreeOprObj.checkedRptTplNodes.length > 1)?null:me.getCurrentOrientation());
  772. params.custCfg = zTreeOprObj.reportPageCfg;
  773. params.option = "normal";
  774. CommonAjax.postEx("report_api/createExcelFilesInOneBook", params, WAIT_TIME_EXPORT, true, function(result){
  775. if (result) {
  776. let uuIdUrls = [];
  777. let uuIdUrl = "/report_api/getFileByUUID/" + result.uuid + "/" + stringUtil.replaceAll(result.reportName, "#", "_") + "/xlsx";
  778. uuIdUrls.push(uuIdUrl);
  779. downloadReport(uuIdUrls);
  780. } else {
  781. //
  782. }
  783. }, null, null
  784. );
  785. }
  786. }
  787. }
  788. },
  789. getAllIndividualExcelBook: function () {
  790. let me = rptControlObj;
  791. if (zTreeOprObj.checkedRptTplNodes && zTreeOprObj.checkedRptTplNodes.length > 0) {
  792. let refRptTplIds = [], refBillSumPrjsIds = [], refGljSumPrjsIds = [];
  793. let rpt_names = [], bill_rpt_names = [], glj_rpt_names = [];
  794. rptControlObj.getTplIdsCommon(refRptTplIds, refBillSumPrjsIds, refGljSumPrjsIds, rpt_names, bill_rpt_names, glj_rpt_names);
  795. if (zTreeOprObj.selectedPrjIDs.length > 0 && (glj_rpt_names.length > 0 || bill_rpt_names.length > 0)) {
  796. let params = rptControlObj.creatCommonExportParam(refRptTplIds, refBillSumPrjsIds, refGljSumPrjsIds);
  797. params.prj_id = projectObj.project.projectInfo.ID;
  798. params.sum_rpt_names = bill_rpt_names.concat(glj_rpt_names);
  799. params.rpt_names = rpt_names;
  800. params.isOneSheet = true;
  801. params.rptName = projectObj.project.projectInfo.name;
  802. CommonAjax.postEx("report_api/createExcelFiles", params, WAIT_TIME_EXPORT, true, function(result){
  803. if (result) {
  804. let uuIdUrls = [];
  805. for (let uuIdObj of result) {
  806. let uuIdUrl = "/report_api/getFileByUUID/" + uuIdObj.uuid + "/" + stringUtil.replaceAll(uuIdObj.reportName, "#", "_") + "/xlsx";
  807. uuIdUrls.push(uuIdUrl);
  808. }
  809. downloadReport(uuIdUrls);
  810. } else {
  811. //
  812. }
  813. }, null, null
  814. );
  815. } else {
  816. if (refBillSumPrjsIds.length > 0 || refGljSumPrjsIds.length > 0) {
  817. $("#divReqBillSummary")[0].style.display = "none";
  818. $("#divReqGljSummary")[0].style.display = "none";
  819. $("#divReqCommonSummaryExcel")[0].style.display = "none";
  820. $("#divReqCommonSummaryMultiExcel")[0].style.display = "";
  821. $("#divReqCommonSummaryPDF")[0].style.display = "none";
  822. zTreeOprObj.requestPrjFolderCommon(); //先处理需要汇总的报表,走另外一个分支
  823. } else if (refRptTplIds.length > 0) {
  824. let params = {};
  825. params.prj_id = projectObj.project.projectInfo.ID;
  826. params.rpt_ids = refRptTplIds;
  827. params.rpt_names = rpt_names;
  828. params.pageSize = me.getCurrentPageSize();
  829. params.orientation = ((zTreeOprObj.checkedRptTplNodes.length > 1)?null:me.getCurrentOrientation());
  830. params.isOneSheet = true;
  831. params.custCfg = zTreeOprObj.reportPageCfg;
  832. params.option = "normal";
  833. CommonAjax.postEx("report_api/createExcelFiles", params, WAIT_TIME_EXPORT, true, function(result){
  834. if (result) {
  835. let uuIdUrls = [];
  836. for (let uuIdObj of result) {
  837. let uuIdUrl = "/report_api/getFileByUUID/" + uuIdObj.uuid + "/" + stringUtil.replaceAll(uuIdObj.reportName, "#", "_") + "/xlsx";
  838. uuIdUrls.push(uuIdUrl);
  839. }
  840. downloadReport(uuIdUrls);
  841. } else {
  842. //
  843. }
  844. }, null, null
  845. );
  846. }
  847. }
  848. }
  849. },
  850. checkAndGetExcel: function () {
  851. if (zTreeOprObj.treeObj) {
  852. let chkNodes = zTreeOprObj.treeObj.getCheckedNodes(true);
  853. if (chkNodes.length > 0) {
  854. $("#show_excel_output_cfg").trigger("click");
  855. } else {
  856. rptControlObj.getAllIndividualExcelBook();
  857. }
  858. }
  859. },
  860. getExcel: function () {
  861. let me = rptControlObj;
  862. if ($("#excelExportType_AllInOneBook").get(0).checked) {
  863. me.getAllInOneBook();
  864. } else if ($("#excelExportType_IndividualBook").get(0).checked) {
  865. me.getAllIndividualExcelBook();
  866. }
  867. },
  868. getPDF: function () {
  869. let me = rptControlObj;
  870. if (zTreeOprObj.checkedRptTplNodes && zTreeOprObj.checkedRptTplNodes.length > 0) {
  871. let refRptTplIds = [], refBillSumPrjsIds = [], refGljSumPrjsIds = [];
  872. let rpt_names = [], bill_rpt_names = [], glj_rpt_names = [];
  873. rptControlObj.getTplIdsCommon(refRptTplIds, refBillSumPrjsIds, refGljSumPrjsIds, rpt_names, bill_rpt_names, glj_rpt_names);
  874. if (zTreeOprObj.selectedPrjIDs.length > 0 && (glj_rpt_names.length > 0 || bill_rpt_names.length > 0)) {
  875. let params = rptControlObj.creatCommonExportParam();
  876. params.prj_id = projectObj.project.projectInfo.ID;
  877. params.sum_rpt_names = bill_rpt_names.concat(glj_rpt_names);
  878. params.rpt_ids = refRptTplIds;
  879. params.rpt_bill_tpl_ids = refBillSumPrjsIds;
  880. params.rpt_glj_tpl_ids = refGljSumPrjsIds;
  881. params.rpt_names = rpt_names;
  882. params.isOneSheet = true;
  883. params.rptName = projectObj.project.projectInfo.name;
  884. CommonAjax.postEx("report_api/createPdfFiles", params, WAIT_TIME_EXPORT, true, function(result){
  885. if (result) {
  886. let uuIdUrls = [];
  887. for (let uuIdObj of result) {
  888. let uuIdUrl = "/report_api/getFileByUUID/" + uuIdObj.uuid + "/" + stringUtil.replaceAll(uuIdObj.reportName, "#", "_") + "/pdf";
  889. uuIdUrls.push(uuIdUrl);
  890. }
  891. downloadReport(uuIdUrls);
  892. } else {
  893. //
  894. }
  895. }, null, null
  896. );
  897. } else {
  898. if (refBillSumPrjsIds.length > 0 || refGljSumPrjsIds.length > 0) {
  899. $("#divReqBillSummary")[0].style.display = "none";
  900. $("#divReqGljSummary")[0].style.display = "none";
  901. $("#divReqCommonSummaryExcel")[0].style.display = "none";
  902. $("#divReqCommonSummaryMultiExcel")[0].style.display = "none";
  903. $("#divReqCommonSummaryPDF")[0].style.display = "";
  904. zTreeOprObj.requestPrjFolderCommon(); //先处理需要汇总的报表,走另外一个分支
  905. } else if (refRptTplIds.length > 0) {
  906. let params = {};
  907. params.prj_id = projectObj.project.projectInfo.ID;
  908. params.rpt_ids = refRptTplIds;
  909. params.rpt_names = rpt_names;
  910. params.pageSize = me.getCurrentPageSize();
  911. params.orientation = ((zTreeOprObj.checkedRptTplNodes.length > 1)?null:me.getCurrentOrientation());
  912. params.custCfg = zTreeOprObj.reportPageCfg;
  913. params.option = "normal";
  914. CommonAjax.postEx("report_api/createPdfFiles", params, WAIT_TIME_EXPORT, true, function(result){
  915. if (result) {
  916. let uuIdUrls = [];
  917. for (let uuIdObj of result) {
  918. let uuIdUrl = "/report_api/getFileByUUID/" + uuIdObj.uuid + "/" + stringUtil.replaceAll(uuIdObj.reportName, "#", "_") + "/pdf";
  919. uuIdUrls.push(uuIdUrl);
  920. }
  921. downloadReport(uuIdUrls);
  922. } else {
  923. //
  924. }
  925. }, null, null
  926. );
  927. }
  928. }
  929. }
  930. },
  931. getPDFEx: function () {
  932. let me = rptControlObj;
  933. if (zTreeOprObj.checkedRptTplNodes && zTreeOprObj.checkedRptTplNodes.length > 0) {
  934. let refRptTplIds = [], refBillSumPrjsIds = [], refGljSumPrjsIds = [];
  935. let rpt_names = [], bill_rpt_names = [], glj_rpt_names = [];
  936. rptControlObj.getTplIdsCommon(refRptTplIds, refBillSumPrjsIds, refGljSumPrjsIds, rpt_names, bill_rpt_names, glj_rpt_names);
  937. if (zTreeOprObj.selectedPrjIDs.length > 0 && (glj_rpt_names.length > 0 || bill_rpt_names.length > 0)) {
  938. let params = rptControlObj.creatCommonExportParam();
  939. params.prj_id = projectObj.project.projectInfo.ID;
  940. params.sum_rpt_names = bill_rpt_names.concat(glj_rpt_names);
  941. params.rpt_ids = refRptTplIds;
  942. params.rpt_bill_tpl_ids = refBillSumPrjsIds;
  943. params.rpt_glj_tpl_ids = refGljSumPrjsIds;
  944. params.rpt_names = rpt_names;
  945. params.isOneSheet = true;
  946. params.rptName = projectObj.project.projectInfo.name;
  947. CommonAjax.postEx("report_api/getMultiReports", params, 30000, true,
  948. function(result){
  949. let pageSize = rptControlObj.getCurrentPageSize();
  950. for (let idx = 0; idx < result.length; idx++) {
  951. let pageData = result[idx];
  952. JpcJsPDFHelper.outputAsPdf(pageData, pageSize, result[idx][JV.NODE_PAGE_INFO][JV.NODE_MAIN_INFO_RPT_NAME]);
  953. }
  954. },
  955. function(failRst){
  956. console.log(failRst);
  957. },
  958. function(exceptionRst){
  959. console.log(exceptionRst);
  960. }
  961. );
  962. } else {
  963. if (refBillSumPrjsIds.length > 0 || refGljSumPrjsIds.length > 0) {
  964. $("#divReqBillSummary")[0].style.display = "none";
  965. $("#divReqGljSummary")[0].style.display = "none";
  966. $("#divReqCommonSummaryExcel")[0].style.display = "none";
  967. $("#divReqCommonSummaryMultiExcel")[0].style.display = "none";
  968. $("#divReqCommonSummaryPDF")[0].style.display = "";
  969. zTreeOprObj.requestPrjFolderCommon(); //先处理需要汇总的报表,走另外一个分支
  970. } else if (refRptTplIds.length > 0) {
  971. if (refRptTplIds.length > 1) {
  972. let params = {};
  973. params.prj_id = projectObj.project.projectInfo.ID;
  974. params.rpt_ids = refRptTplIds;
  975. params.rpt_names = rpt_names;
  976. params.pageSize = me.getCurrentPageSize();
  977. params.orientation = ((zTreeOprObj.checkedRptTplNodes.length > 1)?null:me.getCurrentOrientation());
  978. params.custCfg = zTreeOprObj.reportPageCfg;
  979. params.option = "normal";
  980. CommonAjax.postEx("report_api/getMultiReports", params, 30000, true,
  981. function(result){
  982. let pageSize = rptControlObj.getCurrentPageSize();
  983. for (let idx = 0; idx < result.length; idx++) {
  984. let pageData = result[idx];
  985. JpcJsPDFHelper.outputAsPdf(pageData, pageSize, rpt_names[idx]);
  986. }
  987. },
  988. function(failRst){
  989. console.log(failRst);
  990. },
  991. function(exceptionRst){
  992. console.log(exceptionRst);
  993. }
  994. );
  995. } else {
  996. //这个分支是为了减少请求,用户已经点过的表,又没有勾选,那么就直接导出成PDF
  997. let pageSize = rptControlObj.getCurrentPageSize();
  998. let pageData = zTreeOprObj.currentRptPageRst;
  999. JpcJsPDFHelper.outputAsPdf(pageData, pageSize, rpt_names[0]);
  1000. }
  1001. }
  1002. }
  1003. }
  1004. },
  1005. firstPage: function(dom) {
  1006. let canvas = document.getElementById("rptCanvas");
  1007. zTreeOprObj.showPage(1, canvas);
  1008. },
  1009. prePage: function(dom) {
  1010. let canvas = document.getElementById("rptCanvas");
  1011. zTreeOprObj.showPage(zTreeOprObj.currentPage - 1, canvas);
  1012. },
  1013. nextPage: function(dom) {
  1014. let canvas = document.getElementById("rptCanvas");
  1015. zTreeOprObj.showPage(zTreeOprObj.currentPage + 1, canvas);
  1016. },
  1017. lastPage: function(dom) {
  1018. let me = zTreeOprObj;
  1019. let canvas = document.getElementById("rptCanvas");
  1020. zTreeOprObj.showPage(me.maxPages, canvas);
  1021. },
  1022. onKeydown: function (event, dom) {
  1023. let me = zTreeOprObj, keyPressed = null;
  1024. if (window.event) {
  1025. keyPressed = window.event.keyCode; // IE/Chrome
  1026. } else {
  1027. keyPressed = event.which; // Firefox
  1028. }
  1029. if (keyPressed === 13) {
  1030. let pageNum = 1;
  1031. try {
  1032. pageNum = parseInt(dom.value);
  1033. } catch (e) {
  1034. pageNum = 1;
  1035. }
  1036. let canvas = document.getElementById("rptCanvas");
  1037. if (pageNum < 1) {
  1038. pageNum = 1;
  1039. } else if (pageNum > me.maxPages) {
  1040. pageNum = me.maxPages;
  1041. }
  1042. zTreeOprObj.showPage(pageNum, canvas);
  1043. return false;
  1044. }
  1045. },
  1046. changeMargin: function(marginPropStr, marginDom) {
  1047. zTreeOprObj.reportPageCfg.margins[marginPropStr] = marginDom.value;
  1048. },
  1049. changeFontMain: function(CfgDispName, fontProperty, fontDom) {
  1050. for (let font of zTreeOprObj.reportPageCfg.fonts) {
  1051. if (font["CfgDispName"] === CfgDispName) {
  1052. font[fontProperty] = fontDom.value;
  1053. break;
  1054. }
  1055. }
  1056. },
  1057. changeCfgOption: function (optStr, dom) {
  1058. zTreeOprObj.reportPageCfg[optStr] = dom.checked;
  1059. },
  1060. changeFontAdhoc: function(CfgDispName, fontProperty, fontDom) {
  1061. for (let font of zTreeOprObj.reportPageCfg.fonts) {
  1062. if (font["CfgDispName"] === CfgDispName) {
  1063. if (font[fontProperty] === 'T') {
  1064. font[fontProperty] = 'F';
  1065. fontDom.className = "btn btn-sm btn-outline-secondary";
  1066. } else {
  1067. font[fontProperty] = 'T';
  1068. fontDom.className = "btn btn-sm btn-outline-secondary active";
  1069. }
  1070. break;
  1071. }
  1072. }
  1073. },
  1074. restoreCustCFG: function () {
  1075. let me = this;
  1076. zTreeOprObj.renderRptCfg(zTreeOprObj.defReportPageCfg);
  1077. zTreeOprObj.extractRptCfg(zTreeOprObj.reportPageCfg);
  1078. me.saveCustCfg();
  1079. },
  1080. saveCustCfg: function() {
  1081. let params = {};
  1082. params.custCfg = zTreeOprObj.reportPageCfg;
  1083. CommonAjax.postEx("report_tpl_api/saveCustomerCfg", params, 20000, true, function(result){
  1084. // alert("Save successfully!");
  1085. $("#update_msg_response")[0].style.color = "green";
  1086. $("#update_msg_response")[0].innerHTML = " (保存成功!)";
  1087. setTimeout(function(){
  1088. $("#update_msg_response")[0].innerHTML = "";
  1089. }, 1000);
  1090. }, function (failRst) {
  1091. $("#update_msg_response")[0].style.color = "red";
  1092. $("#update_msg_response")[0].innerHTML = " (保存失败!)";
  1093. setTimeout(function(){
  1094. $("#update_msg_response")[0].innerHTML = "";
  1095. }, 1000);
  1096. }, null
  1097. );
  1098. },
  1099. confirmCfgChange: function() {
  1100. zTreeOprObj.changeCfg();
  1101. }
  1102. };
  1103. function downloadReport(urls) {
  1104. //考虑到多个报表下载,一些浏览器(如chrome)不允许一下子下载多个文件,得缓缓处理,统一在这处理
  1105. rptControlObj.currentDownloadUrl = null;
  1106. rptControlObj.currentDownloadIdx = 0;
  1107. let private_download = function() {
  1108. if (rptControlObj.currentDownloadIdx >= 0 && rptControlObj.currentDownloadIdx < urls.length) {
  1109. rptControlObj.currentDownloadUrl = urls[rptControlObj.currentDownloadIdx];
  1110. rptControlObj.currentDownloadIdx++;
  1111. window.location = rptControlObj.currentDownloadUrl;
  1112. setTimeout(private_download, 2000);
  1113. }
  1114. }
  1115. private_download();
  1116. }
  1117. function dynamicLoadJs(url, callback) {
  1118. let head = document.getElementsByTagName('head')[0];
  1119. let script = document.createElement('script');
  1120. script.type = 'text/javascript';
  1121. script.src = url;
  1122. if(callback) {
  1123. script.onload = script.onreadystatechange = function () {
  1124. if (!this.readyState || this.readyState === "loaded" || this.readyState === "complete"){
  1125. callback();
  1126. script.onload = script.onreadystatechange = null;
  1127. }
  1128. };
  1129. }
  1130. head.appendChild(script);
  1131. }
  1132. function dynamicLoadCss(url) {
  1133. let head = document.getElementsByTagName('head')[0];
  1134. let link = document.createElement('link');
  1135. link.type='text/css';
  1136. link.rel = 'stylesheet';
  1137. link.href = url;
  1138. head.appendChild(link);
  1139. }