rpt_main.js 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482
  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. let rptTplObj = {
  10. hasInitialized: false,
  11. iniPage: function() {
  12. let me = this;
  13. if (!me.hasInitialized) {
  14. zTreeOprObj.getCustomerCfg();
  15. zTreeOprObj.getReportTemplateTree();
  16. me.hasInitialized = true;
  17. let canvas = document.getElementById("rptCanvas");
  18. canvas.onclick = canvasOprObj.canvasOnClick;
  19. canvas.onmousemove = canvasOprObj.canvasOnMouseMove;
  20. }
  21. }
  22. }
  23. let zTreeOprObj = {
  24. treeObj: null,
  25. currentNode: null,
  26. checkedRptTplNodes: null,
  27. currentRptPageRst: null,
  28. reportPageCfg: null,
  29. defReportPageCfg: null,
  30. currentPage: 1,
  31. maxPages: 0,
  32. countChkedRptTpl: function () {
  33. let me = zTreeOprObj;
  34. if (me.treeObj) {
  35. me.checkedRptTplNodes = [];
  36. let chkNodes = me.treeObj.getCheckedNodes(true), cnt = 0, hasCurrentNode = false;
  37. for (let node of chkNodes) {
  38. if (node.nodeType === TPL_TYPE_TEMPLATE) {
  39. cnt++;
  40. me.checkedRptTplNodes.push(node);
  41. if (me.currentNode === node) hasCurrentNode = true;
  42. }
  43. }
  44. if (!hasCurrentNode && cnt === 0 && me.currentNode !== null) {
  45. //这里根据实际需求再做处理
  46. cnt++;
  47. me.checkedRptTplNodes.push(me.currentNode);
  48. }
  49. $("#export_div").find("span").each(function(cIdx,elementSpan){
  50. elementSpan.innerText = cnt;
  51. });
  52. $("#print_div").find("span").each(function(cIdx,elementSpan){
  53. elementSpan.innerText = cnt;
  54. });
  55. }
  56. },
  57. getReportTemplateTree: function() {
  58. let me = zTreeOprObj, params = {};
  59. params.engineerId = projectInfoObj.projectInfo.property.engineering;
  60. CommonAjax.postEx("report_tpl_api/getRptTplTree", params, 20000, true, function(result){
  61. let private_remove_hide_item = function (items) {
  62. if (items && items.length > 0) {
  63. for (let i = items.length - 1; i >= 0; i--) {
  64. if (!(items[i].released) && items[i].nodeType === 2) {
  65. items.splice(i, 1);
  66. } else {
  67. if (items[i].items && items[i].items.length > 0) {
  68. private_remove_hide_item(items[i].items);
  69. }
  70. }
  71. }
  72. }
  73. }
  74. private_remove_hide_item(result);
  75. for (let topNode of result) {
  76. if (topNode.userId === "-100") {
  77. topNode.name = topNode.name + " - 标准报表";
  78. } else {
  79. topNode.name = topNode.name + " - 定制报表";
  80. }
  81. }
  82. zTreeHelper.createTreeDirectly(result, rpt_tpl_setting, "rptTplTree", me);
  83. me.refreshNodes();
  84. }, null, null);
  85. },
  86. getCustomerCfg: function() {
  87. let me = zTreeOprObj, params = {};
  88. params.engineerId = projectInfoObj.projectInfo.property.engineering;
  89. CommonAjax.postEx("report_tpl_api/getCustomizeCfg", params, 20000, true, function(result){
  90. if (result) {
  91. me.defReportPageCfg = result[0];
  92. me.reportPageCfg = result[1];
  93. me.renderRptCfg(result[1]);
  94. } else {
  95. me.reportPageCfg = null;
  96. me.defReportPageCfg = null;
  97. }
  98. }, null, null
  99. );
  100. },
  101. renderRptCfg: function (cfg) {
  102. $("#elementMargin_Left").get(0).value = cfg.margins.Left;
  103. $("#elementMargin_Right").get(0).value = cfg.margins.Right;
  104. $("#elementMargin_Top").get(0).value = cfg.margins.Top;
  105. $("#elementMargin_Bottom").get(0).value = cfg.margins.Bottom;
  106. for (let font of cfg.fonts) {
  107. let fontPropSuffix = "title";
  108. if (font.CfgDispName === "表标题") {
  109. fontPropSuffix = "title";
  110. } else if (font.CfgDispName === "列标题") {
  111. fontPropSuffix = "column";
  112. } else if (font.CfgDispName === "正文内容") {
  113. fontPropSuffix = "content";
  114. } else if (font.CfgDispName === "合计") {
  115. fontPropSuffix = "summary";
  116. } else if (font.CfgDispName === "表眉/表脚") {
  117. fontPropSuffix = "header_footer";
  118. }
  119. document.getElementById("fontName_" + fontPropSuffix).value = font.Name;
  120. document.getElementById("fontHeight_" + fontPropSuffix).value = font.FontHeight;
  121. document.getElementById("font_bold_" + fontPropSuffix).className = (font.FontBold === "T")?"btn btn-sm btn-outline-secondary active":"btn btn-sm btn-outline-secondary";
  122. document.getElementById("font_italic_" + fontPropSuffix).className = (font.FontItalic === "T")?"btn btn-sm btn-outline-secondary active":"btn btn-sm btn-outline-secondary";
  123. document.getElementById("font_underline_" + fontPropSuffix).className = (font.FontUnderline === "T")?"btn btn-sm btn-outline-secondary active":"btn btn-sm btn-outline-secondary";
  124. }
  125. document.getElementById("rpt_vertical_line").checked = cfg.showVerticalLine;
  126. document.getElementById("rpt_narrow").checked = cfg.isNarrow;
  127. document.getElementById("rpt_fill_zero").checked = cfg.fillZero;
  128. },
  129. refreshNodes: function() {
  130. let me = this;
  131. let private_setupIsParent = function(node){
  132. node.isParent = (node.nodeType === RT.NodeType.NODE || node.level === 0);
  133. if (node.items && node.items.length) {
  134. for (let i = 0; i < node.items.length; i++) {
  135. private_setupIsParent(node.items[i]);
  136. }
  137. }
  138. };
  139. let topNodes = me.treeObj.getNodes();
  140. for (let i = 0; i < topNodes.length; i++) {
  141. private_setupIsParent(topNodes[i]);
  142. }
  143. me.treeObj.refresh();
  144. },
  145. onCheck: function(event, treeId, treeNode) {
  146. zTreeOprObj.countChkedRptTpl();
  147. },
  148. onClick: function(event,treeId,treeNode) {
  149. let me = zTreeOprObj;
  150. if (treeNode.nodeType === TPL_TYPE_TEMPLATE && treeNode.refId > 0) {
  151. let params = {};
  152. let pageSize = rptControlObj.getCurrentPageSize();
  153. params.pageSize = pageSize;
  154. params.rpt_tpl_id = treeNode.refId;
  155. params.prj_id = projectInfoObj.projectInfo.ID;
  156. params.custCfg = me.reportPageCfg;
  157. me.currentNode = treeNode;
  158. me.requestReport(params);
  159. me.countChkedRptTpl();
  160. }
  161. },
  162. changePageSize: function(dom) {
  163. let me = zTreeOprObj,
  164. targetDom = document.getElementById("btnRptPageSize");
  165. let tmpStr = targetDom.innerHTML.trim();
  166. targetDom.innerHTML = dom.innerHTML.trim();
  167. dom.innerHTML = tmpStr;
  168. me.changeCfg();
  169. },
  170. changeOrientation: function(dom) {
  171. let me = zTreeOprObj,
  172. targetDom = document.getElementById("btnRptOrientation");
  173. let tmpStr = targetDom.innerHTML.trim();
  174. targetDom.innerHTML = dom.innerHTML.trim();
  175. dom.innerHTML = tmpStr;
  176. me.changeCfg();
  177. },
  178. changeCfg: function() {
  179. let me = zTreeOprObj;
  180. let params = {};
  181. params.pageSize = rptControlObj.getCurrentPageSize();
  182. params.orientation = rptControlObj.getCurrentOrientation();
  183. params.rpt_tpl_id = me.currentNode.refId;
  184. params.prj_id = projectInfoObj.projectInfo.ID;
  185. params.custCfg = me.reportPageCfg;
  186. me.requestReport(params);
  187. },
  188. resetAfter: function (pageRst) {
  189. let size = pageRst[JV.NODE_PAGE_INFO][JV.NODE_PAGE_SIZE].slice(0);
  190. if (size[0] > size[1]) {
  191. document.getElementById("btnRptOrientation").innerHTML = "横向";
  192. document.getElementById("hrefRptOrientation").innerHTML = "纵向";
  193. } else {
  194. document.getElementById("btnRptOrientation").innerHTML = "纵向";
  195. document.getElementById("hrefRptOrientation").innerHTML = "横向";
  196. }
  197. },
  198. requestReport: function (params) {
  199. let me = zTreeOprObj;
  200. CommonAjax.postEx("report_api/getReport", params, 5000, true,
  201. function(result){
  202. let pageRst = result;
  203. if (pageRst) {
  204. me.resetAfter(pageRst);
  205. let canvas = document.getElementById("rptCanvas");
  206. me.currentRptPageRst = pageRst;
  207. me.maxPages = pageRst.items.length;
  208. me.currentPage = 1;
  209. me.displayPageValue();
  210. let size = JpcCanvasOutput.getReportSizeInPixel(me.currentRptPageRst, getScreenDPI());
  211. canvas.width = size[0] + 20;
  212. if (size[1] > size[0]) {
  213. canvas.height = size[1] + 100;
  214. } else {
  215. canvas.height = size[1] + 50;
  216. }
  217. me.showPage(1, canvas);
  218. }
  219. }, null, null
  220. );
  221. },
  222. showPage: function (pageNum, canvas) {
  223. let me = zTreeOprObj;
  224. if (pageNum >= 1 && pageNum <= me.maxPages) {
  225. me.currentPage = pageNum;
  226. JpcCanvasOutput.cleanCanvas(canvas);
  227. JpcCanvasOutput.drawPageBorder(me.currentRptPageRst, canvas, getScreenDPI());
  228. JpcCanvasOutput.drawToCanvas(me.currentRptPageRst, canvas, me.currentPage);
  229. }
  230. me.displayPageValue();
  231. },
  232. displayPageValue: function() {
  233. let me = zTreeOprObj;
  234. $("#rpt_page_num").get(0).value = me.currentPage + "/" + me.maxPages;
  235. }
  236. };
  237. let canvasOprObj = {
  238. canvasOnMouseMove: function (event) {
  239. if (zTreeOprObj.currentNode) {
  240. let x = event.offsetX - JpcCanvasOutput.offsetX, canvas = event.originalTarget;
  241. if (!(canvas)) canvas = event.target; //chrome浏览器不认event.originalTarget,只认event.target或event.currentTarget
  242. if (x < FIRST_PAGE_OFFSET) {
  243. canvas.style.cursor = "url(/web/building_saas/img/FirstPageSimple.cur), auto";
  244. } else if (x < PRE_PAGE_OFFSET) {
  245. canvas.style.cursor = "url(/web/building_saas/img/PreviousPageSimple.cur), auto";
  246. } else if ((canvas.width - x) < LAST_PAGE_OFFSET) {
  247. canvas.style.cursor = "url(/web/building_saas/img/LastPageSimple.cur), auto";
  248. } else if ((canvas.width - x) < NEXT_PAGE_OFFSET) {
  249. canvas.style.cursor = "url(/web/building_saas/img/NextPageSimple.cur), auto";
  250. } else {
  251. canvas.style.cursor = "";
  252. }
  253. }
  254. },
  255. canvasOnClick: function(event){
  256. if (zTreeOprObj.currentNode) {
  257. let x = event.offsetX - JpcCanvasOutput.offsetX, canvas = event.originalTarget;
  258. if (!(canvas)) canvas = event.target; //chrome浏览器不认event.originalTarget,只认event.target或event.currentTarget
  259. if (x < FIRST_PAGE_OFFSET) {
  260. zTreeOprObj.showPage(1, canvas);
  261. } else if (x < PRE_PAGE_OFFSET) {
  262. zTreeOprObj.showPage(zTreeOprObj.currentPage - 1, canvas);
  263. } else if ((canvas.width - x) < LAST_PAGE_OFFSET) {
  264. zTreeOprObj.showPage(zTreeOprObj.maxPages, canvas);
  265. } else if ((canvas.width - x) < NEXT_PAGE_OFFSET) {
  266. zTreeOprObj.showPage(zTreeOprObj.currentPage + 1, canvas);
  267. }
  268. }
  269. }
  270. };
  271. let rptControlObj = {
  272. currentOutputType: "Excel",
  273. currentDownloadUrl: null,
  274. currentDownloadIdx: 0,
  275. getCurrentPageSize: function() {
  276. // let rst = "A4";
  277. let rst = document.getElementById("btnRptPageSize").innerHTML.trim();
  278. //btnRptPageSize
  279. return rst;
  280. },
  281. getCurrentOrientation: function() {
  282. // let rst = "横向";
  283. let rst = document.getElementById("btnRptOrientation").innerHTML.trim();
  284. return rst;
  285. },
  286. getCurrentReportOption: function() {
  287. //
  288. },
  289. changeType: function(newType) {
  290. let me = rptControlObj;
  291. let excelDom = document.getElementById("EXCEL_TYPE");
  292. let pdfDom = document.getElementById("PDF_TYPE");
  293. if (newType === "Excel") {
  294. excelDom.className = "btn btn-block btn-primary";
  295. pdfDom.className = "btn btn-block btn-outline-secondary";
  296. me.currentOutputType = newType;
  297. } else if (newType === "PDF") {
  298. excelDom.className = "btn btn-block btn-outline-secondary";
  299. pdfDom.className = "btn btn-block btn-primary";
  300. me.currentOutputType = newType;
  301. } else {
  302. //me.currentOutputType = newType;
  303. }
  304. },
  305. outputRpt: function() {
  306. let me = rptControlObj;
  307. if (me.currentOutputType === "Excel") {
  308. me.getExcel();
  309. } else if (me.currentOutputType === "PDF") {
  310. me.getPDF();
  311. } else {
  312. //other types if needed.
  313. }
  314. },
  315. getAllInOneBook: function () {
  316. let me = rptControlObj;
  317. if (zTreeOprObj.checkedRptTplNodes && zTreeOprObj.checkedRptTplNodes.length > 0) {
  318. let orgRptName = zTreeOprObj.checkedRptTplNodes[0].name;
  319. let refRptTplIds = [];
  320. for (let node of zTreeOprObj.checkedRptTplNodes) {
  321. refRptTplIds.push(node.refId);
  322. }
  323. let url = "/report_api/getExcelInOneBook/" + projectInfoObj.projectInfo.ID + "/" + refRptTplIds.join(",") + "/" +
  324. me.getCurrentPageSize() + "/" + orgRptName + "/" + 'normal';
  325. window.location = url;
  326. }
  327. },
  328. getExcel: function () {
  329. let me = rptControlObj;
  330. if ($("#excelExportType_AllInOneBook").get(0).checked) {
  331. me.getAllInOneBook();
  332. } else if ($("#excelExportType_IndividualBook").get(0).checked) {
  333. if (zTreeOprObj.checkedRptTplNodes && zTreeOprObj.checkedRptTplNodes.length > 0) {
  334. let urls = [];
  335. let orientation = ((zTreeOprObj.checkedRptTplNodes.length > 1)?null:me.getCurrentOrientation());
  336. for (let tplNode of zTreeOprObj.checkedRptTplNodes) {
  337. let orgRptName = tplNode.name;
  338. let url = "/report_api/getExcel/" + projectInfoObj.projectInfo.ID + "/" + tplNode.refId + "/" +
  339. me.getCurrentPageSize() + "/" + orientation + "/" + orgRptName + "/" + true + "/" + 'normal';
  340. urls.push(url);
  341. }
  342. downloadReport(urls);
  343. }
  344. }
  345. },
  346. getPDF: function() {
  347. let me = rptControlObj;
  348. if (zTreeOprObj.checkedRptTplNodes && zTreeOprObj.checkedRptTplNodes.length > 0) {
  349. let urls = [];
  350. let orientation = ((zTreeOprObj.checkedRptTplNodes.length > 1)?null:me.getCurrentOrientation());
  351. for (let tplNode of zTreeOprObj.checkedRptTplNodes) {
  352. let orgRptName = tplNode.name;
  353. let url = "/report_api/getPDF/" + projectInfoObj.projectInfo.ID + "/" + tplNode.refId + "/" +
  354. me.getCurrentPageSize() + "/" + orientation + "/" + orgRptName;
  355. urls.push(url);
  356. }
  357. downloadReport(urls);
  358. }
  359. },
  360. firstPage: function(dom) {
  361. let canvas = document.getElementById("rptCanvas");
  362. zTreeOprObj.showPage(1, canvas);
  363. },
  364. prePage: function(dom) {
  365. let canvas = document.getElementById("rptCanvas");
  366. zTreeOprObj.showPage(zTreeOprObj.currentPage - 1, canvas);
  367. },
  368. nextPage: function(dom) {
  369. let canvas = document.getElementById("rptCanvas");
  370. zTreeOprObj.showPage(zTreeOprObj.currentPage + 1, canvas);
  371. },
  372. lastPage: function(dom) {
  373. let me = zTreeOprObj;
  374. let canvas = document.getElementById("rptCanvas");
  375. zTreeOprObj.showPage(me.maxPages, canvas);
  376. },
  377. onKeydown: function (event, dom) {
  378. let me = zTreeOprObj, keyPressed = null;
  379. if (window.event) {
  380. keyPressed = window.event.keyCode; // IE/Chrome
  381. } else {
  382. keyPressed = event.which; // Firefox
  383. }
  384. if (keyPressed === 13) {
  385. let pageNum = 1;
  386. try {
  387. pageNum = parseInt(dom.value);
  388. } catch (e) {
  389. pageNum = 1;
  390. }
  391. let canvas = document.getElementById("rptCanvas");
  392. if (pageNum < 1) {
  393. pageNum = 1;
  394. } else if (pageNum > me.maxPages) {
  395. pageNum = me.maxPages;
  396. }
  397. zTreeOprObj.showPage(pageNum, canvas);
  398. return false;
  399. }
  400. },
  401. changeMargin: function(marginPropStr, marginDom) {
  402. zTreeOprObj.reportPageCfg.margins[marginPropStr] = marginDom.value;
  403. },
  404. changeFontMain: function(CfgDispName, fontProperty, fontDom) {
  405. for (let font of zTreeOprObj.reportPageCfg.fonts) {
  406. if (font["CfgDispName"] === CfgDispName) {
  407. font[fontProperty] = fontDom.value;
  408. break;
  409. }
  410. }
  411. },
  412. changeCfgOption: function (optStr, dom) {
  413. zTreeOprObj.reportPageCfg[optStr] = dom.checked;
  414. },
  415. changeFontAdhoc: function(CfgDispName, fontProperty, fontDom) {
  416. for (let font of zTreeOprObj.reportPageCfg.fonts) {
  417. if (font["CfgDispName"] === CfgDispName) {
  418. if (font[fontProperty] === 'T') {
  419. font[fontProperty] = 'F';
  420. fontDom.className = "btn btn-sm btn-outline-secondary";
  421. } else {
  422. font[fontProperty] = 'T';
  423. fontDom.className = "btn btn-sm btn-outline-secondary active";
  424. }
  425. break;
  426. }
  427. }
  428. },
  429. saveCustCfg: function() {
  430. let params = {};
  431. params.custCfg = zTreeOprObj.reportPageCfg;
  432. CommonAjax.postEx("report_tpl_api/saveCustomerCfg", params, 20000, true, function(result){
  433. // alert("Save successfully!");
  434. $("#update_msg_response")[0].style.color = "green";
  435. $("#update_msg_response")[0].innerHTML = " (保存成功!)";
  436. setTimeout(function(){
  437. $("#update_msg_response")[0].innerHTML = "";
  438. }, 1000);
  439. }, function (failRst) {
  440. $("#update_msg_response")[0].style.color = "red";
  441. $("#update_msg_response")[0].innerHTML = " (保存失败!)";
  442. setTimeout(function(){
  443. $("#update_msg_response")[0].innerHTML = "";
  444. }, 1000);
  445. }, null
  446. );
  447. },
  448. confirmCfgChange: function() {
  449. let treeNode = zTreeOprObj.currentNode;
  450. if (treeNode.nodeType === TPL_TYPE_TEMPLATE && treeNode.refId > 0) {
  451. let params = {};
  452. params.pageSize = rptControlObj.getCurrentPageSize();
  453. params.rpt_tpl_id = treeNode.refId;
  454. params.prj_id = projectInfoObj.projectInfo.ID;
  455. params.custCfg = zTreeOprObj.reportPageCfg;
  456. zTreeOprObj.requestReport(params);
  457. }
  458. }
  459. };
  460. function downloadReport(urls) {
  461. //考虑到多个报表下载,一些浏览器(如chrome)不允许一下子下载多个文件,得缓缓处理,统一在这处理
  462. rptControlObj.currentDownloadUrl = null;
  463. rptControlObj.currentDownloadIdx = 0;
  464. let private_download = function() {
  465. if (rptControlObj.currentDownloadIdx >= 0 && rptControlObj.currentDownloadIdx < urls.length) {
  466. rptControlObj.currentDownloadUrl = urls[rptControlObj.currentDownloadIdx];
  467. rptControlObj.currentDownloadIdx++;
  468. window.location = rptControlObj.currentDownloadUrl;
  469. setTimeout(private_download, 2000);
  470. }
  471. }
  472. private_download();
  473. }