rpt_preview_common.js 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. /**
  2. * Created by Tony on 2019/4/10.
  3. */
  4. let G_OFFSET_X = 0, G_OFFSET_Y = 0;
  5. function printPageLoading() {
  6. if (sessionStorage.multiRptsData) {
  7. let multiRptData = JSON.parse(sessionStorage.multiRptsData);
  8. let scaleFactor = parseInt(sessionStorage.scaleFactor);
  9. let closeWaterMark = parseInt(sessionStorage.closeWaterMark);
  10. for (let idx = 0; idx < multiRptData.length; idx++) {
  11. let pageData = multiRptData[idx];
  12. if (idx === 0) {
  13. $(document).attr("title", pageData[JV.NODE_PAGE_INFO][JV.NODE_MAIN_INFO_RPT_NAME]);
  14. }
  15. let orgPixelSize = getPixelSize(pageData);
  16. let actArea = getActualArea(pageData);
  17. let svgArr = rptPrintHelper.buildSvgArr(pageData, actArea, G_OFFSET_X, G_OFFSET_Y, closeWaterMark);
  18. //let orientation = (pageData[JV.NODE_PAGE_INFO][JV.NODE_PAGE_SIZE][0] < pageData[JV.NODE_PAGE_INFO][JV.NODE_PAGE_SIZE][1])?"纵向":"横向";
  19. let orientation = "纵向";
  20. // showPreviewData(svgArr, actArea, scaleFactor, sessionStorage.pageSize, orientation, orgPixelSize);
  21. showPreviewData(svgArr, actArea, scaleFactor, sessionStorage.pageSize, orientation, orgPixelSize);
  22. }
  23. window.print();
  24. } else if (sessionStorage.currentPageData) {
  25. let pageData = JSON.parse(sessionStorage.currentPageData);
  26. let scaleFactor = parseInt(sessionStorage.scaleFactor);
  27. let orgPixelSize = getPixelSize(pageData);
  28. let actArea = getActualArea(pageData);
  29. let svgArr = rptPrintHelper.buildSvgArr(pageData, actArea, G_OFFSET_X, G_OFFSET_Y);
  30. $(document).attr("title", pageData[JV.NODE_PAGE_INFO][JV.NODE_MAIN_INFO_RPT_NAME]);
  31. //showPreviewData(svgArr, scaleFactor, sessionStorage.pageSize, sessionStorage.orientation);
  32. showPreviewData(svgArr, actArea, scaleFactor, sessionStorage.pageSize, "纵向", orgPixelSize);
  33. window.print();
  34. } else if (sessionStorage.currentPageSvgData) {
  35. let svgArr = JSON.parse(sessionStorage.currentPageSvgData);
  36. let scaleFactor = 1;
  37. //showPreviewData(svgArr, scaleFactor, sessionStorage.pageSize, sessionStorage.orientation);
  38. showPreviewData(svgArr, null, scaleFactor, sessionStorage.pageSize, "纵向", null);
  39. window.print();
  40. } else {
  41. //alert("没有报表数据!");
  42. }
  43. }
  44. function showPreviewData(svgArr, actAreaArr, scaleFactor, pageSize, orientation, orgPixelSize) {
  45. let orgHeight = 793, orgWidth = 1122;
  46. let DFT_MARGIN = 2;
  47. if (pageSize === 'A3') {
  48. orgHeight = 1122;
  49. orgWidth = 793 * 2;
  50. } else if (pageSize.indexOf('自定义') >= 0) {
  51. //自定义
  52. } else {
  53. //其他size(LEGAL, 16K etc.)
  54. }
  55. let pageHeight = orgHeight * scaleFactor, pageWidth = orgWidth * scaleFactor;
  56. if (orientation === "纵向") {
  57. pageHeight = orgWidth * scaleFactor;
  58. pageWidth = orgHeight * scaleFactor;
  59. }
  60. for (let i = 0; i < svgArr.length; i++) {
  61. let offsetHeight = 0, offsetWidth = 0;
  62. let paddingStr = '';
  63. if (actAreaArr) {
  64. paddingStr = `padding: ${actAreaArr[i].Top}px 0px 0px ${actAreaArr[i].Left}px`;
  65. if (actAreaArr[i].Right > actAreaArr[i].Bottom) {
  66. //横向,需要重新调整padding
  67. paddingStr = `padding: ${actAreaArr[i].Left}px 0px 0px ${orgHeight - actAreaArr[i].Bottom}px`;
  68. }
  69. offsetWidth = actAreaArr[i].Left + (pageWidth - actAreaArr[i].Right) - DFT_MARGIN;
  70. offsetHeight = actAreaArr[i].Top + (pageHeight - actAreaArr[i].Bottom) - DFT_MARGIN;
  71. if (orgPixelSize[0] > orgPixelSize[1]) {
  72. //横向强制改纵向(系统是以纵向为准),那么计算offset的方式会有所不同
  73. offsetWidth = actAreaArr[i].Top + (pageWidth - actAreaArr[i].Bottom) - DFT_MARGIN;
  74. //横向转纵向时,还得考虑左上角转右上角的Left与Top之间的差,否则坐标还是会有偏差
  75. // offsetHeight = actAreaArr[i].Left + (pageHeight - actAreaArr[i].Right) - (actAreaArr[i].Left - actAreaArr[i].Top) - DFT_MARGIN;
  76. //新方式下,没那么复杂了
  77. offsetHeight = actAreaArr[i].Left + (pageHeight - actAreaArr[i].Right) - DFT_MARGIN;
  78. }
  79. }
  80. // let div = $('<div class="pageBreak"></div>');
  81. let div = $(`<div class="pageBreak" style="${paddingStr}"></div>`);
  82. div.append($(svgArr[i].join("")));
  83. $(div).find("svg").each(function(cIdx,elementSvg){
  84. elementSvg.setAttribute('height', pageHeight - offsetHeight);
  85. elementSvg.setAttribute('width', pageWidth - offsetWidth);
  86. });
  87. $("body").append(div);
  88. }
  89. }
  90. function _chkActArea(area, cells) {
  91. if (cells && cells.length > 0) {
  92. for (let cell of cells) {
  93. if (cell.area.Left < area.Left) {
  94. area.Left = cell.area.Left;
  95. }
  96. if (cell.area.Right > area.Right) {
  97. area.Right = cell.area.Right;
  98. }
  99. if (cell.area.Top < area.Top) {
  100. area.Top = cell.area.Top;
  101. }
  102. if (cell.area.Bottom > area.Bottom) {
  103. area.Bottom = cell.area.Bottom;
  104. }
  105. }
  106. }
  107. }
  108. function getActualArea(pageData) {
  109. let rst = [];
  110. for (let item of pageData.items) {
  111. let area = {Left: 10000, Right: 0, Top: 10000, Bottom: 0};
  112. _chkActArea(area, item.cells);
  113. _chkActArea(area, item.signature_cells);
  114. _chkActArea(area, item.signature_date_cells);
  115. _chkActArea(area, item.signature_audit_cells);
  116. rst.push(area);
  117. }
  118. return rst;
  119. }
  120. function printPageClosing() {
  121. //
  122. }