"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.assemblePageBreak = assemblePageBreak; exports.createPrintFrame = createPrintFrame; exports.destroyPageBreak = destroyPageBreak; exports.printHtml = void 0; exports.trimHtml = trimHtml; var _xeUtils = _interopRequireDefault(require("xe-utils")); var _dom = require("../../ui/src/dom"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } const browseObj = _xeUtils.default.browse(); // 打印 let printFrame; // 默认导出或打印的 HTML 样式 const defaultHtmlStyle = 'body{padding:0;font-family:"Microsoft YaHei",微软雅黑,"MicrosoftJhengHei",华文细黑,STHeiti,MingLiu}body *{-webkit-box-sizing:border-box;box-sizing:border-box}.vxe-table{border-collapse:collapse;text-align:left;border-spacing:0}.vxe-table:not(.is--print){table-layout:fixed}.vxe-table,.vxe-table th,.vxe-table td,.vxe-table td{border-color:#D0D0D0;border-style:solid;border-width:0}.vxe-table.is--print{width:100%}.border--default,.border--full,.border--outer{border-top-width:1px}.border--default,.border--full,.border--outer{border-left-width:1px}.border--outer,.border--default th,.border--default td,.border--full th,.border--full td,.border--outer th,.border--inner th,.border--inner td{border-bottom-width:1px}.border--default,.border--outer,.border--full th,.border--full td{border-right-width:1px}.border--default th,.border--full th,.border--outer th{background-color:#f8f8f9}.vxe-table td>div,.vxe-table th>div{padding:.5em .4em}.col--center{text-align:center}.col--right{text-align:right}.vxe-table:not(.is--print) .col--ellipsis>div{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;word-break:break-all}.vxe-table--tree-node{text-align:left}.vxe-table--tree-node-wrapper{position:relative}.vxe-table--tree-icon-wrapper{position:absolute;top:50%;width:1em;height:1em;text-align:center;-webkit-transform:translateY(-50%);transform:translateY(-50%);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;cursor:pointer}.vxe-table--tree-unfold-icon,.vxe-table--tree-fold-icon{position:absolute;width:0;height:0;border-style:solid;border-width:.5em;border-right-color:transparent;border-bottom-color:transparent}.vxe-table--tree-unfold-icon{left:.3em;top:0;border-left-color:#939599;border-top-color:transparent}.vxe-table--tree-fold-icon{left:0;top:.3em;border-left-color:transparent;border-top-color:#939599}.vxe-table--tree-cell{display:block;padding-left:1.5em}.vxe-table input[type="checkbox"]{margin:0}.vxe-table input[type="checkbox"],.vxe-table input[type="radio"],.vxe-table input[type="checkbox"]+span,.vxe-table input[type="radio"]+span{vertical-align:middle;padding-left:0.4em}'; function trimHtml(html) { return `${html}`.replace(/()/, ''); } function createPrintFrame() { const frame = document.createElement('iframe'); frame.className = 'vxe-table--print-frame'; return frame; } function appendPrintFrame() { if (!printFrame.parentNode) { document.body.appendChild(printFrame); } } function afterPrintEvent() { requestAnimationFrame(removeFrame); } function removeFrame() { if (printFrame) { if (printFrame.parentNode) { try { printFrame.contentDocument.write(''); } catch (e) {} printFrame.parentNode.removeChild(printFrame); } printFrame = null; } } function getExportBlobByString(str, type) { return new Blob([str], { type: `text/${type};charset=utf-8;` }); } const defaultPrintMargin = 50; const defaultFontColor = '#000000'; function parsePageStyle(val) { const styOpts = Object.assign({}, val); const headStyOpts = Object.assign({}, styOpts.header); const titStyOpts = Object.assign({}, styOpts.title); const footStyOpts = Object.assign({}, styOpts.footer); const pnStyOpts = Object.assign({}, styOpts.pageNumber); let mVal = defaultPrintMargin; let marginTop = mVal; let marginBottom = mVal; let marginLeft = mVal; let marginRight = mVal; if (_xeUtils.default.isNumber(styOpts.margin) || _xeUtils.default.isString(styOpts.margin)) { mVal = styOpts.margin; marginTop = mVal; marginBottom = mVal; marginLeft = mVal; marginRight = mVal; } return { marginTop: (0, _dom.toCssUnit)(styOpts.marginTop || marginTop), marginBottom: (0, _dom.toCssUnit)(styOpts.marginBottom || marginBottom), marginLeft: (0, _dom.toCssUnit)(styOpts.marginLeft || marginLeft), marginRight: (0, _dom.toCssUnit)(styOpts.marginRight || marginRight), fontSize: (0, _dom.toCssUnit)(styOpts.fontSize), color: styOpts.color, textAlign: styOpts.textAlign, header: { height: (0, _dom.toCssUnit)(headStyOpts.height), textAlign: headStyOpts.textAlign }, title: { color: titStyOpts.color, fontSize: (0, _dom.toCssUnit)(titStyOpts.fontSize), textAlign: titStyOpts.textAlign }, footer: { height: (0, _dom.toCssUnit)(footStyOpts.height), textAlign: footStyOpts.textAlign }, pageNumber: { color: pnStyOpts.color, fontSize: (0, _dom.toCssUnit)(pnStyOpts.fontSize), textAlign: pnStyOpts.textAlign } }; } function createHtmlPage(opts, printHtml) { const { pageStyle, customStyle } = opts; const pageStyObj = parsePageStyle(pageStyle); const headStyOpts = pageStyObj.header; const titStyOpts = pageStyObj.title; const footStyOpts = pageStyObj.header; const pnStyOpts = pageStyObj.pageNumber; const isPbMode = opts._pageBreaks || opts.pageBreaks && opts.pageBreaks.length; return ['', '
', '', `