123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142 |
- <!DOCTYPE html>
- <html lang="zh-CN">
- <head>
- <meta charset="UTF-8">
- <title></title>
- </head>
- <style type="text/css">
- .pageBreakOrg {
- page-break-before: auto;
- page-break-after: always;
- }
- .pageBreak {
- page-break-before: auto;
- page-break-after: auto;
- }
- @page {size: A4 portrait;}
- body {page: page}
- div {page: page}
- </style>
- <!--
- .printPage {
- page: page
- }
- @page {size: A4 landscape;}
- div { page: page }
- @page {margin: auto;}
- @page horizon {size: A4 landscape;}
- @page vertical1 {size: A4 portrait;}
- @page horizon1 {size: A4 landscape;}
- @page vertical1 {size: A4 portrait;}
- -->
- <script type="text/javascript" src="/web/building_saas/report/js/jpc_output_value_define.js"></script>
- <body onload="loading()" onbeforeunload="closing()">
- <canvas id="chkCanvas" style="display:none"></canvas>
- </body>
- <script src="/lib/jquery/jquery-3.2.1.min.js"></script>
- <script type="text/javascript" src="/web/building_saas/report/js/jpc_output.js"></script>
- <script type="text/javascript" src="/web/building_saas/report/js/rpt_print.js"></script>
- <SCRIPT type="text/javascript">
- let G_OFFSET_X = 0, G_OFFSET_Y = 0;
- function loading() {
- if (sessionStorage.multiRptsData) {
- let multiRptData = JSON.parse(sessionStorage.multiRptsData);
- let scaleFactor = parseInt(sessionStorage.scaleFactor);
- for (let idx = 0; idx < multiRptData.length; idx++) {
- let pageData = multiRptData[idx];
- if (idx === 0) {
- $(document).attr("title", pageData[JV.NODE_PAGE_INFO][JV.NODE_MAIN_INFO_RPT_NAME]);
- }
- let orgPixelSize = getPixelSize(pageData);
- let actArea = getActualArea(pageData);
- let svgArr = rptPrintHelper.buildSvgArr(pageData, actArea, G_OFFSET_X, G_OFFSET_Y);
- //let orientation = (pageData[JV.NODE_PAGE_INFO][JV.NODE_PAGE_SIZE][0] < pageData[JV.NODE_PAGE_INFO][JV.NODE_PAGE_SIZE][1])?"纵向":"横向";
- let orientation = "纵向";
- showPreviewData(svgArr, actArea, scaleFactor, sessionStorage.pageSize, orientation, orgPixelSize);
- }
- window.print();
- } else if (sessionStorage.currentPageData) {
- let pageData = JSON.parse(sessionStorage.currentPageData);
- let scaleFactor = parseInt(sessionStorage.scaleFactor);
- let orgPixelSize = getPixelSize(pageData);
- let actArea = getActualArea(pageData);
- let svgArr = rptPrintHelper.buildSvgArr(pageData, actArea, G_OFFSET_X, G_OFFSET_Y);
- $(document).attr("title", pageData[JV.NODE_PAGE_INFO][JV.NODE_MAIN_INFO_RPT_NAME]);
- //showPreviewData(svgArr, scaleFactor, sessionStorage.pageSize, sessionStorage.orientation);
- showPreviewData(svgArr, actArea, scaleFactor, sessionStorage.pageSize, "纵向", orgPixelSize);
- window.print();
- } else if (sessionStorage.currentPageSvgData) {
- let svgArr = JSON.parse(sessionStorage.currentPageSvgData);
- let scaleFactor = 1;
- //showPreviewData(svgArr, scaleFactor, sessionStorage.pageSize, sessionStorage.orientation);
- showPreviewData(svgArr, null, scaleFactor, sessionStorage.pageSize, "纵向", null);
- window.print();
- } else {
- //alert("没有报表数据!");
- }
- }
- function showPreviewData(svgArr, actAreaArr, scaleFactor, pageSize, orientation, orgPixelSize) {
- let orgHeight = 793, orgWidth = 1122;
- if (pageSize === 'A3') {
- orgHeight = 1122;
- orgWidth = 793 * 2;
- } else if (pageSize.indexOf('自定义') >= 0) {
- //自定义
- } else {
- //其他size(LEGAL, 16K etc.)
- }
- let pageHeight = orgHeight * scaleFactor, pageWidth = orgWidth * scaleFactor;
- if (orientation === "纵向") {
- pageHeight = orgWidth * scaleFactor;
- pageWidth = orgHeight * scaleFactor;
- }
- for (let i = 0; i < svgArr.length; i++) {
- let offsetHeight = 0, offsetWidth = 0;
- if (actAreaArr) {
- offsetWidth = actAreaArr[i].Left + (pageWidth - actAreaArr[i].Right) - 5;
- offsetHeight = actAreaArr[i].Top + (pageHeight - actAreaArr[i].Bottom) - 5;
- if (orgPixelSize[0] > orgPixelSize[1]) {
- //横向强制改纵向(系统是以纵向为准),那么计算offset的方式会有所不同
- offsetWidth = actAreaArr[i].Top + (pageWidth - actAreaArr[i].Bottom) - 5;
- offsetHeight = actAreaArr[i].Left + (pageHeight - actAreaArr[i].Right) - 5;
- }
- }
- let div = $('<div class="pageBreak"></div>');
- div.append($(svgArr[i].join("")));
- $(div).find("svg").each(function(cIdx,elementSvg){
- elementSvg.setAttribute('height', pageHeight - offsetHeight);
- elementSvg.setAttribute('width', pageWidth - offsetWidth);
- });
- $("body").append(div);
- }
- }
- function getActualArea(pageData) {
- let rst = [];
- for (let item of pageData.items) {
- let area = {Left: 10000, Right: 0, Top: 10000, Bottom: 0};
- for (let cell of item.cells) {
- if (cell.area.Left < area.Left) {
- area.Left = cell.area.Left;
- }
- if (cell.area.Right > area.Right) {
- area.Right = cell.area.Right;
- }
- if (cell.area.Top < area.Top) {
- area.Top = cell.area.Top;
- }
- if (cell.area.Bottom > area.Bottom) {
- area.Bottom = cell.area.Bottom;
- }
- }
- rst.push(area);
- }
- return rst;
- }
- function closing() {
- //
- }
- </SCRIPT>
- </html>
|