rpt_main.js 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403
  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. currentRptPageRst: null,
  27. reportPageCfg: null,
  28. currentPage: 1,
  29. maxPages: 0,
  30. getReportTemplateTree: function() {
  31. let me = zTreeOprObj, params = {};
  32. params.engineerId = projectInfoObj.projectInfo.property.engineering;
  33. CommonAjax.postEx("report_tpl_api/getRptTplTree", params, 20000, true, function(result){
  34. let private_remove_hide_item = function (items) {
  35. if (items && items.length > 0) {
  36. for (let i = items.length - 1; i >= 0; i--) {
  37. if (!(items[i].released)) {
  38. items.splice(i, 1);
  39. } else {
  40. private_remove_hide_item(items[i].items);
  41. }
  42. }
  43. }
  44. }
  45. private_remove_hide_item(result);
  46. for (let topNode of result) {
  47. if (topNode.userId === "-100") {
  48. topNode.name = topNode.name + " - 标准报表";
  49. } else {
  50. topNode.name = topNode.name + " - 定制报表";
  51. }
  52. }
  53. zTreeHelper.createTreeDirectly(result, rpt_tpl_setting, "rptTplTree", me);
  54. me.refreshNodes();
  55. }, null, null);
  56. },
  57. getCustomerCfg: function() {
  58. let me = zTreeOprObj, params = {};
  59. params.engineerId = projectInfoObj.projectInfo.property.engineering;
  60. CommonAjax.postEx("report_tpl_api/getCustomizeCfg", params, 20000, true, function(result){
  61. if (result) {
  62. me.reportPageCfg = result;
  63. $("#elementMargin_Left").get(0).value = result.margins.Left;
  64. $("#elementMargin_Right").get(0).value = result.margins.Right;
  65. $("#elementMargin_Top").get(0).value = result.margins.Top;
  66. $("#elementMargin_Bottom").get(0).value = result.margins.Bottom;
  67. for (let font of result.fonts) {
  68. let fontPropSuffix = "title";
  69. if (font.CfgDispName === "表标题") {
  70. fontPropSuffix = "title";
  71. } else if (font.CfgDispName === "列标题") {
  72. fontPropSuffix = "column";
  73. } else if (font.CfgDispName === "正文内容") {
  74. fontPropSuffix = "content";
  75. } else if (font.CfgDispName === "合计") {
  76. fontPropSuffix = "summary";
  77. } else if (font.CfgDispName === "表眉/表脚") {
  78. fontPropSuffix = "header_footer";
  79. }
  80. document.getElementById("fontName_" + fontPropSuffix).value = font.Name;
  81. document.getElementById("fontHeight_" + fontPropSuffix).value = font.FontHeight;
  82. document.getElementById("font_bold_" + fontPropSuffix).className = (font.FontBold === "T")?"btn btn-sm btn-outline-secondary active":"btn btn-sm btn-outline-secondary";
  83. document.getElementById("font_italic_" + fontPropSuffix).className = (font.FontItalic === "T")?"btn btn-sm btn-outline-secondary active":"btn btn-sm btn-outline-secondary";
  84. document.getElementById("font_underline_" + fontPropSuffix).className = (font.FontUnderline === "T")?"btn btn-sm btn-outline-secondary active":"btn btn-sm btn-outline-secondary";
  85. }
  86. document.getElementById("rpt_vertical_line").checked = result.showVerticalLine;
  87. document.getElementById("rpt_narrow").checked = result.isNarrow;
  88. document.getElementById("rpt_fill_zero").checked = result.fillZero;
  89. } else {
  90. me.reportPageCfg = null;
  91. }
  92. }, null, null
  93. );
  94. },
  95. refreshNodes: function() {
  96. let me = this;
  97. let private_setupIsParent = function(node){
  98. node.isParent = (node.nodeType === RT.NodeType.NODE || node.level === 0);
  99. if (node.items && node.items.length) {
  100. for (let i = 0; i < node.items.length; i++) {
  101. private_setupIsParent(node.items[i]);
  102. }
  103. }
  104. };
  105. let topNodes = me.treeObj.getNodes();
  106. for (let i = 0; i < topNodes.length; i++) {
  107. private_setupIsParent(topNodes[i]);
  108. }
  109. me.treeObj.refresh();
  110. },
  111. onCheck: function() {
  112. //count();
  113. //if (clearFlag) {
  114. // clearCheckedOldNodes();
  115. //}
  116. },
  117. onClick: function(event,treeId,treeNode) {
  118. let me = zTreeOprObj;
  119. if (treeNode.nodeType === TPL_TYPE_TEMPLATE && treeNode.refId > 0) {
  120. let params = {};
  121. let pageSize = rptControlObj.getCurrentPageSize();
  122. params.pageSize = pageSize;
  123. params.rpt_tpl_id = treeNode.refId;
  124. params.prj_id = projectInfoObj.projectInfo.ID;
  125. params.custCfg = me.reportPageCfg;
  126. me.currentNode = treeNode;
  127. me.requestReport(params);
  128. }
  129. },
  130. changePageSize: function(dom) {
  131. let me = zTreeOprObj,
  132. targetDom = document.getElementById("btnRptPageSize");
  133. let tmpStr = targetDom.innerHTML.trim();
  134. targetDom.innerHTML = dom.innerHTML.trim();
  135. dom.innerHTML = tmpStr;
  136. me.changeCfg();
  137. },
  138. changeOrientation: function(dom) {
  139. let me = zTreeOprObj,
  140. targetDom = document.getElementById("btnRptOrientation");
  141. let tmpStr = targetDom.innerHTML.trim();
  142. targetDom.innerHTML = dom.innerHTML.trim();
  143. dom.innerHTML = tmpStr;
  144. me.changeCfg();
  145. },
  146. changeCfg: function() {
  147. let me = zTreeOprObj;
  148. let params = {};
  149. params.pageSize = rptControlObj.getCurrentPageSize();
  150. params.orientation = rptControlObj.getCurrentOrientation();
  151. params.rpt_tpl_id = me.currentNode.refId;
  152. params.prj_id = projectInfoObj.projectInfo.ID;
  153. params.custCfg = me.reportPageCfg;
  154. me.requestReport(params);
  155. },
  156. resetAfter: function (pageRst) {
  157. let size = pageRst[JV.NODE_PAGE_INFO][JV.NODE_PAGE_SIZE].slice(0);
  158. if (size[0] > size[1]) {
  159. document.getElementById("btnRptOrientation").innerHTML = "横向";
  160. document.getElementById("hrefRptOrientation").innerHTML = "纵向";
  161. } else {
  162. document.getElementById("btnRptOrientation").innerHTML = "纵向";
  163. document.getElementById("hrefRptOrientation").innerHTML = "横向";
  164. }
  165. },
  166. requestReport: function (params) {
  167. let me = zTreeOprObj;
  168. CommonAjax.postEx("report_api/getReport", params, 5000, true,
  169. function(result){
  170. let pageRst = result;
  171. if (pageRst) {
  172. me.resetAfter(pageRst);
  173. let canvas = document.getElementById("rptCanvas");
  174. me.currentRptPageRst = pageRst;
  175. me.maxPages = pageRst.items.length;
  176. me.currentPage = 1;
  177. me.displayPageValue();
  178. let size = JpcCanvasOutput.getReportSizeInPixel(me.currentRptPageRst, getScreenDPI());
  179. canvas.width = size[0] + 20;
  180. if (size[1] > size[0]) {
  181. canvas.height = size[1] + 100;
  182. } else {
  183. canvas.height = size[1] + 50;
  184. }
  185. me.showPage(1, canvas);
  186. }
  187. }, null, null
  188. );
  189. },
  190. showPage: function (pageNum, canvas) {
  191. let me = zTreeOprObj;
  192. if (pageNum >= 1 && pageNum <= me.maxPages) {
  193. me.currentPage = pageNum;
  194. JpcCanvasOutput.cleanCanvas(canvas);
  195. JpcCanvasOutput.drawPageBorder(me.currentRptPageRst, canvas, getScreenDPI());
  196. JpcCanvasOutput.drawToCanvas(me.currentRptPageRst, canvas, me.currentPage);
  197. }
  198. me.displayPageValue();
  199. },
  200. displayPageValue: function() {
  201. let me = zTreeOprObj;
  202. $("#rpt_page_num").get(0).value = me.currentPage + "/" + me.maxPages;
  203. }
  204. };
  205. let canvasOprObj = {
  206. canvasOnMouseMove: function (event) {
  207. if (zTreeOprObj.currentNode) {
  208. let x = event.offsetX - JpcCanvasOutput.offsetX, canvas = event.originalTarget;
  209. if (!(canvas)) canvas = event.target; //chrome浏览器不认event.originalTarget,只认event.target或event.currentTarget
  210. if (x < FIRST_PAGE_OFFSET) {
  211. canvas.style.cursor = "url(/web/building_saas/img/FirstPageSimple.cur), auto";
  212. } else if (x < PRE_PAGE_OFFSET) {
  213. canvas.style.cursor = "url(/web/building_saas/img/PreviousPageSimple.cur), auto";
  214. } else if ((canvas.width - x) < LAST_PAGE_OFFSET) {
  215. canvas.style.cursor = "url(/web/building_saas/img/LastPageSimple.cur), auto";
  216. } else if ((canvas.width - x) < NEXT_PAGE_OFFSET) {
  217. canvas.style.cursor = "url(/web/building_saas/img/NextPageSimple.cur), auto";
  218. } else {
  219. canvas.style.cursor = "";
  220. }
  221. }
  222. },
  223. canvasOnClick: function(event){
  224. if (zTreeOprObj.currentNode) {
  225. let x = event.offsetX - JpcCanvasOutput.offsetX, canvas = event.originalTarget;
  226. if (!(canvas)) canvas = event.target; //chrome浏览器不认event.originalTarget,只认event.target或event.currentTarget
  227. if (x < FIRST_PAGE_OFFSET) {
  228. zTreeOprObj.showPage(1, canvas);
  229. } else if (x < PRE_PAGE_OFFSET) {
  230. zTreeOprObj.showPage(zTreeOprObj.currentPage - 1, canvas);
  231. } else if ((canvas.width - x) < LAST_PAGE_OFFSET) {
  232. zTreeOprObj.showPage(zTreeOprObj.maxPages, canvas);
  233. } else if ((canvas.width - x) < NEXT_PAGE_OFFSET) {
  234. zTreeOprObj.showPage(zTreeOprObj.currentPage + 1, canvas);
  235. }
  236. }
  237. }
  238. };
  239. let rptControlObj = {
  240. currentOutputType: "Excel",
  241. getCurrentPageSize: function() {
  242. // let rst = "A4";
  243. let rst = document.getElementById("btnRptPageSize").innerHTML.trim();
  244. //btnRptPageSize
  245. return rst;
  246. },
  247. getCurrentOrientation: function() {
  248. // let rst = "横向";
  249. let rst = document.getElementById("btnRptOrientation").innerHTML.trim();
  250. return rst;
  251. },
  252. getCurrentReportOption: function() {
  253. //
  254. },
  255. changeType: function(newType) {
  256. let me = rptControlObj;
  257. let excelDom = document.getElementById("EXCEL_TYPE");
  258. let pdfDom = document.getElementById("PDF_TYPE");
  259. if (newType === "Excel") {
  260. excelDom.className = "btn btn-block btn-primary";
  261. pdfDom.className = "btn btn-block btn-outline-secondary";
  262. me.currentOutputType = newType;
  263. } else if (newType === "PDF") {
  264. excelDom.className = "btn btn-block btn-outline-secondary";
  265. pdfDom.className = "btn btn-block btn-primary";
  266. me.currentOutputType = newType;
  267. } else {
  268. //me.currentOutputType = newType;
  269. }
  270. },
  271. outputRpt: function() {
  272. let me = rptControlObj;
  273. if (me.currentOutputType === "Excel") {
  274. me.getExcel();
  275. } else if (me.currentOutputType === "PDF") {
  276. me.getPDF();
  277. } else {
  278. //other types if needed.
  279. }
  280. },
  281. getExcel: function() {
  282. let me = rptControlObj;
  283. //目前只支持当前打开报表
  284. //zTreeOprObj.currentRptPageRst
  285. if (zTreeOprObj.currentNode && zTreeOprObj.currentNode.refId) {
  286. let orgRptName = zTreeOprObj.currentNode.name;
  287. orgRptName = orgRptName.replace('【', '').replace('】','').replace('-','_').replace(' ','');
  288. let url = "/report_api/getExcel/" + projectInfoObj.projectInfo.ID + "/" + zTreeOprObj.currentNode.refId + "/" +
  289. me.getCurrentPageSize() + "/" + me.getCurrentOrientation() + "/" + orgRptName + "/" + false + "/" + 'normal';
  290. window.location = url;//这里不能使用get方法跳转,否则下载不成功
  291. }
  292. },
  293. getPDF: function() {
  294. let me = rptControlObj;
  295. //目前只支持当前打开报表
  296. //zTreeOprObj.currentRptPageRst
  297. if (zTreeOprObj.currentNode && zTreeOprObj.currentNode.refId) {
  298. let orgRptName = zTreeOprObj.currentNode.name;
  299. orgRptName = orgRptName.replace('【', '').replace('】','').replace('-','_');
  300. let url = "/report_api/getPDF/" + projectInfoObj.projectInfo.ID + "/" + zTreeOprObj.currentNode.refId + "/" +
  301. me.getCurrentPageSize() + "/" + me.getCurrentOrientation() + "/" + orgRptName;
  302. window.location = url;//这里不能使用get方法跳转,否则下载不成功
  303. }
  304. },
  305. firstPage: function(dom) {
  306. let canvas = document.getElementById("rptCanvas");
  307. zTreeOprObj.showPage(1, canvas);
  308. },
  309. prePage: function(dom) {
  310. let canvas = document.getElementById("rptCanvas");
  311. zTreeOprObj.showPage(zTreeOprObj.currentPage - 1, canvas);
  312. },
  313. nextPage: function(dom) {
  314. let canvas = document.getElementById("rptCanvas");
  315. zTreeOprObj.showPage(zTreeOprObj.currentPage + 1, canvas);
  316. },
  317. lastPage: function(dom) {
  318. let me = zTreeOprObj;
  319. let canvas = document.getElementById("rptCanvas");
  320. zTreeOprObj.showPage(me.maxPages, canvas);
  321. },
  322. onKeydown: function (event, dom) {
  323. let me = zTreeOprObj, keyPressed = null;
  324. if (window.event) {
  325. keyPressed = window.event.keyCode; // IE/Chrome
  326. } else {
  327. keyPressed = event.which; // Firefox
  328. }
  329. if (keyPressed == 13) {
  330. let pageNum = 1;
  331. try {
  332. pageNum = parseInt(dom.value);
  333. } catch (e) {
  334. pageNum = 1;
  335. }
  336. let canvas = document.getElementById("rptCanvas");
  337. if (pageNum < 1) {
  338. pageNum = 1;
  339. } else if (pageNum > me.maxPages) {
  340. pageNum = me.maxPages;
  341. }
  342. zTreeOprObj.showPage(pageNum, canvas);
  343. return false;
  344. }
  345. },
  346. changeMargin: function(marginPropStr, marginDom) {
  347. zTreeOprObj.reportPageCfg.margins[marginPropStr] = marginDom.value;
  348. },
  349. changeFontMain: function(CfgDispName, fontProperty, fontDom) {
  350. for (let font of zTreeOprObj.reportPageCfg.fonts) {
  351. if (font["CfgDispName"] === CfgDispName) {
  352. font[fontProperty] = fontDom.value;
  353. break;
  354. }
  355. }
  356. },
  357. changeCfgOption: function (optStr, dom) {
  358. zTreeOprObj.reportPageCfg[optStr] = dom.checked;
  359. },
  360. changeFontAdhoc: function(CfgDispName, fontProperty, fontDom) {
  361. for (let font of zTreeOprObj.reportPageCfg.fonts) {
  362. if (font["CfgDispName"] === CfgDispName) {
  363. if (font[fontProperty] === 'T') {
  364. font[fontProperty] = 'F';
  365. fontDom.className = "btn btn-sm btn-outline-secondary";
  366. } else {
  367. font[fontProperty] = 'T';
  368. fontDom.className = "btn btn-sm btn-outline-secondary active";
  369. }
  370. break;
  371. }
  372. }
  373. },
  374. saveCustCfg: function() {
  375. let params = {};
  376. params.custCfg = zTreeOprObj.reportPageCfg;
  377. CommonAjax.postEx("report_tpl_api/saveCustomerCfg", params, 20000, true, function(result){
  378. alert("Save successfully!");
  379. }, null, null
  380. );
  381. },
  382. confirmCfgChange: function() {
  383. // let me = zTreeOprObj;
  384. let treeNode = zTreeOprObj.currentNode;
  385. if (treeNode.nodeType === TPL_TYPE_TEMPLATE && treeNode.refId > 0) {
  386. let params = {};
  387. let pageSize = rptControlObj.getCurrentPageSize();
  388. params.pageSize = pageSize;
  389. params.rpt_tpl_id = treeNode.refId;
  390. params.prj_id = projectInfoObj.projectInfo.ID;
  391. params.custCfg = zTreeOprObj.reportPageCfg;
  392. zTreeOprObj.requestReport(params);
  393. }
  394. }
  395. };