UNPKG

@syncfusion/ej2-pdfviewer

Version:
729 lines (727 loc) 45.6 kB
import { PdfFormFieldBase } from '../index'; import { createElement, Browser, isNullOrUndefined } from '@syncfusion/ej2-base'; import { AjaxHandler } from '../index'; import { Size } from '@syncfusion/ej2-drawings'; import { TaskPriorityLevel } from '../base/pdfviewer-utlis'; /** * Print module */ var Print = /** @class */ (function () { /** * @param {PdfViewer} viewer - It describes about the viewer * @param {PdfViewerBase} base - It describes about the base * @private * @returns {void} */ function Print(viewer, base) { this.printHeight = 1056; this.printWidth = 816; this.maximumPixels = 16777216; this.pdfViewer = viewer; this.pdfViewerBase = base; } /** * Print the PDF document being loaded in the ejPdfViewer control. * * @returns {void} */ Print.prototype.print = function () { var _this = this; var pageIndex; if (this.pdfViewerBase.pageCount > 0) { this.printViewerContainer = createElement('div', { id: this.pdfViewer.element.id + '_print_viewer_container', className: 'e-pv-print-viewer-container' }); if (this.pdfViewer.printMode === 'Default') { this.pdfViewerBase.showPrintLoadingIndicator(true); this.iframe = document.createElement('iframe'); this.iframe.className = 'iframeprint'; this.iframe.id = 'iframePrint'; this.iframe.style.position = 'fixed'; this.iframe.style.top = '-100000000px'; document.body.appendChild(this.iframe); this.frameDoc = this.iframe.contentWindow ? this.iframe.contentWindow : this.iframe.contentDocument; this.frameDoc.document.open(); } else { this.printWindow = window.open('', 'print', 'height=' + window.outerHeight + ',width=' + window.outerWidth + ',tabbar=no'); this.printWindow.moveTo(0, 0); this.printWindow.resizeTo(screen.availWidth, screen.availHeight); this.createPrintLoadingIndicator(this.printWindow.document.body); } setTimeout(function () { for (pageIndex = 0; pageIndex < _this.pdfViewerBase.pageCount; pageIndex++) { var pageWidth = _this.pdfViewerBase.pageSize[parseInt(pageIndex.toString(), 10)].width; var pageHeight = _this.pdfViewerBase.pageSize[parseInt(pageIndex.toString(), 10)].height; // Check if the document is A4 by comparing the A4 standard values with the buffer value var a4StdWidth = 793; var a4StdHeight = 1122; var bufferWidth = 10; var bufferHeight = 10; //Reduced the A4 standard width and height to prevent blank pages while printing var a4PrintWidth = 783; var a4PrintHeight = 1110; _this.printWidth = 816; _this.printHeight = 1056; // Check if the A4 document is protrait or landscape if (pageWidth > pageHeight) { a4StdWidth = 1122; a4StdHeight = 793; } if (!(pageWidth >= (a4StdWidth + bufferWidth) || pageWidth <= (a4StdWidth - bufferWidth)) && !(pageHeight >= (a4StdHeight + bufferHeight) || pageHeight <= (a4StdHeight - bufferHeight))) { _this.printWidth = a4PrintWidth; _this.printHeight = a4PrintHeight; } _this.pdfViewer.printModule.createRequestForPrint(pageIndex, pageWidth, pageHeight, _this.pdfViewerBase.pageCount, _this.pdfViewer.printScaleFactor); } _this.pdfViewer.firePrintEnd(_this.pdfViewer.downloadFileName); }, 100); } }; Print.prototype.createRequestForPrint = function (pageIndex, pageWidth, pageHeight, pageCount, printScaleFactor) { // eslint-disable-next-line var proxy = this; var jsonObject = { pageNumber: pageIndex.toString(), documentId: this.pdfViewerBase.documentId, hashId: this.pdfViewerBase.hashId, zoomFactor: '1', action: 'PrintImages', elementId: this.pdfViewer.element.id, uniqueId: this.pdfViewerBase.documentId, digitalSignaturePresent: this.pdfViewerBase.digitalSignaturePresent(pageIndex), printScaleFactor: printScaleFactor >= 0.5 && printScaleFactor <= 5 ? printScaleFactor : printScaleFactor > 5 ? 5 : 1 }; if (this.pdfViewerBase.jsonDocumentId) { jsonObject.documentId = this.pdfViewerBase.jsonDocumentId; } proxy.pdfViewerBase.createFormfieldsJsonData(); proxy.printRequestHandler = new AjaxHandler(proxy.pdfViewer); proxy.printRequestHandler.url = proxy.pdfViewer.serviceUrl + '/' + proxy.pdfViewer.serverActionSettings.print; proxy.printRequestHandler.responseType = null; proxy.printRequestHandler.mode = false; if (this.pdfViewerBase.validateForm && this.pdfViewer.enableFormFieldsValidation) { this.pdfViewer.fireValidatedFailed(proxy.pdfViewer.serverActionSettings.download); this.pdfViewerBase.validateForm = false; this.pdfViewerBase.showPrintLoadingIndicator(false); } else { if (proxy.pdfViewerBase.clientSideRendering) { this.pdfViewerBase.pdfViewerRunner.addTask({ pageIndex: pageIndex, message: 'printImage', printScaleFactor: printScaleFactor >= 0.5 && printScaleFactor <= 5 ? printScaleFactor : printScaleFactor > 5 ? 5 : 1 }, TaskPriorityLevel.High); } else { proxy.printRequestHandler.send(jsonObject); } } proxy.printRequestHandler.onSuccess = function (result) { proxy.printSuccess(result, pageWidth, pageHeight, pageIndex); }; this.printRequestHandler.onFailure = function (result) { proxy.pdfViewer.fireAjaxRequestFailed(result.status, result.statusText, proxy.pdfViewer.serverActionSettings.print); }; this.printRequestHandler.onError = function (result) { proxy.pdfViewerBase.openNotificationPopup(); proxy.pdfViewer.fireAjaxRequestFailed(result.status, result.statusText, proxy.pdfViewer.serverActionSettings.print); }; }; /** * @param {any} event - It describes about the event * @private * @returns {void} */ Print.prototype.printOnMessage = function (event) { var canvas = document.createElement('canvas'); var _a = event.data, value = _a.value, width = _a.width, height = _a.height, pageIndex = _a.pageIndex, pageWidth = _a.pageWidth, pageHeight = _a.pageHeight; canvas.width = width; canvas.height = height; var canvasContext = canvas.getContext('2d'); var imageData = canvasContext.createImageData(width, height); imageData.data.set(value); canvasContext.putImageData(imageData, 0, 0); var imageUrl = canvas.toDataURL(); this.pdfViewerBase.releaseCanvas(canvas); var data = ({ image: imageUrl, pageNumber: pageIndex, uniqueId: this.pdfViewerBase.documentId, pageWidth: width }); this.printSuccess(data, pageWidth, pageHeight, pageIndex); }; Print.prototype.printSuccess = function (result, pageWidth, pageHeight, pageIndex) { var _this = this; this.pdfViewerBase.isPrint = true; var printImage = this.pdfViewerBase.clientSideRendering ? result : result.data; var redirect = this.pdfViewerBase.checkRedirection(printImage); if (redirect) { this.pdfViewerBase.showPrintLoadingIndicator(false); } else { if (printImage) { if (typeof printImage !== 'object') { try { printImage = JSON.parse(printImage); if (typeof printImage !== 'object') { this.pdfViewerBase.onControlError(500, printImage, this.pdfViewer.serverActionSettings.print); printImage = null; } } catch (error) { this.pdfViewerBase.onControlError(500, printImage, this.pdfViewer.serverActionSettings.print); printImage = null; } } } if (printImage && printImage.uniqueId === this.pdfViewerBase.documentId) { this.pdfViewer.fireAjaxRequestSuccess(this.pdfViewer.serverActionSettings.print, printImage); var annotationSource_1; if (!this.pdfViewer.annotationSettings.skipPrint) { var annotationCollections = this.pdfViewerBase.documentAnnotationCollections; if (annotationCollections && annotationCollections[printImage.pageNumber] && this.pdfViewerBase.isTextMarkupAnnotationModule()) { var printCollection = annotationCollections[printImage.pageNumber]; if (this.pdfViewerBase.isImportAction) { var textMarkupAnnotation = printCollection.textMarkupAnnotation; var shapeAnnotation = printCollection.shapeAnnotation; var measureShapeAnnotation = printCollection.measureShapeAnnotation; var stampAnnotation = printCollection.stampAnnotations; var freeTextAnnotation = printCollection.freeTextAnnotation; var inkAnnotation = printCollection.signatureInkAnnotation; var stickyNoteAnnotation = printCollection.stickyNotesAnnotation; annotationSource_1 = this.pdfViewer.annotationModule.textMarkupAnnotationModule. printAnnotationsInCanvas(textMarkupAnnotation, printImage.pageNumber, stampAnnotation, shapeAnnotation, measureShapeAnnotation, stickyNoteAnnotation, freeTextAnnotation, inkAnnotation); } else { annotationSource_1 = this.pdfViewer.annotationModule.textMarkupAnnotationModule. printAnnotationsInCanvas(printCollection.textMarkupAnnotation, printImage.pageNumber, printCollection.stampAnnotations, printCollection.shapeAnnotation, printCollection.measureShapeAnnotation, printCollection.stickyNotesAnnotation, printCollection.freeTextAnnotation, printCollection.signatureInkAnnotation); } } if (this.pdfViewerBase.isAnnotationCollectionRemoved) { annotationSource_1 = this.pdfViewer.annotationModule.textMarkupAnnotationModule. printAnnotationsInCanvas(null, printImage.pageNumber, null, null, null, null, null, null); } } var currentPageNumber_1 = printImage.pageNumber; this.printCanvas = createElement('canvas', { id: this.pdfViewer.element.id + '_printCanvas_' + pageIndex, className: 'e-pv-print-canvas' }); this.printCanvas.style.width = pageWidth + 'px'; this.printCanvas.style.height = pageHeight + 'px'; var printScaleValue = this.pdfViewer.printScaleFactor > 1 && this.pdfViewer.printScaleFactor <= 5 ? this.pdfViewer.printScaleFactor : this.pdfViewer.printScaleFactor > 5 ? 5 : 2; if (this.pdfViewerBase.clientSideRendering) { //An A0 piece of paper measures 33.1 × 46.8 inches, with 46.8 inches being the greater dimension. The pixel value of 46.8 inches is 4493px. If the document size is too large, we may not be able to display the image. Therefore, we should consider the maximum size of A0 paper if the page size is greater than 4493 pixels. var maxPageSize = 4493; var whichIsBigger = (pageWidth > pageHeight) ? 'Width' : 'Height'; var maxWidth = pageWidth; var maxHeight = pageHeight; if (whichIsBigger === 'Width') { maxWidth = (pageWidth > maxPageSize) ? maxPageSize : pageWidth; if (maxWidth === maxPageSize) { maxHeight = pageHeight / (pageWidth / maxPageSize); } } else { maxHeight = (pageHeight > maxPageSize) ? maxPageSize : pageHeight; if (maxHeight === maxPageSize) { maxWidth = pageWidth / (pageHeight / maxPageSize); } } if ((pageHeight < pageWidth) && this.pdfViewer.enablePrintRotation) { this.printCanvas.height = pageWidth * printScaleValue * window.devicePixelRatio; this.printCanvas.width = pageHeight * printScaleValue * window.devicePixelRatio; } else { this.printCanvas.height = maxHeight * printScaleValue * window.devicePixelRatio; this.printCanvas.width = maxWidth * printScaleValue * window.devicePixelRatio; } } else { this.printCanvas.height = this.printHeight * printScaleValue * window.devicePixelRatio; this.printCanvas.width = this.printWidth * printScaleValue * window.devicePixelRatio; } if (this.pdfViewerBase.isDeviceiOS) { var size = new Size(this.printCanvas.width, this.printCanvas.height); var newSize = this.limitSize(size, this.maximumPixels); this.printCanvas.width = newSize.width; this.printCanvas.height = newSize.height; } var context_1 = this.printCanvas.getContext('2d'); var pageImage_1 = new Image(); var annotationImage_1 = new Image(); var annotationImage1_1 = new Image(); pageImage_1.onload = function () { _this.pdfViewerBase.isPrint = true; if ((pageHeight > pageWidth) || !_this.pdfViewer.enablePrintRotation) { context_1.drawImage(pageImage_1, 0, 0, _this.printCanvas.width, _this.printCanvas.height); if (annotationSource_1 && annotationSource_1.annotImg) { context_1.drawImage(annotationImage_1, 0, 0, _this.printCanvas.width, _this.printCanvas.height); } if (annotationSource_1 && annotationSource_1.highlightImg) { context_1.save(); context_1.globalCompositeOperation = 'multiply'; context_1.drawImage(annotationImage1_1, 0, 0, _this.printCanvas.width, _this.printCanvas.height); context_1.restore(); } } else { // translate to center canvas context_1.translate(_this.printCanvas.width * 0.5, _this.printCanvas.height * 0.5); // rotate the canvas to - 90 degree context_1.rotate(-0.5 * Math.PI); // un translate the canvas back to origin context_1.translate(-_this.printCanvas.height * 0.5, -_this.printCanvas.width * 0.5); // draw the image context_1.drawImage(pageImage_1, 0, 0, _this.printCanvas.height, _this.printCanvas.width); if (annotationSource_1 && annotationSource_1.annotImg) { context_1.drawImage(annotationImage_1, 0, 0, _this.printCanvas.height, _this.printCanvas.width); } if (annotationSource_1 && annotationSource_1.highlightImg) { context_1.save(); context_1.globalCompositeOperation = 'multiply'; context_1.drawImage(annotationImage1_1, 0, 0, _this.printCanvas.height, _this.printCanvas.width); context_1.restore(); } } if (currentPageNumber_1 === (_this.pdfViewerBase.pageCount - 1)) { _this.printWindowOpen(); } _this.pdfViewer.renderDrawing(null, pageIndex); _this.pdfViewerBase.isPrint = false; }; pageImage_1.src = printImage.image; if (annotationSource_1 && !isNullOrUndefined(annotationSource_1.annotImg)) { annotationImage_1.src = annotationSource_1.annotImg; } if (annotationSource_1 && !isNullOrUndefined(annotationSource_1.highlightImg)) { annotationImage1_1.src = annotationSource_1.highlightImg; } this.printViewerContainer.appendChild(this.printCanvas); } } this.pdfViewerBase.isPrint = false; }; Print.prototype.limitSize = function (size, maximumPixels) { var width = size.width, height = size.height; var requiredPixels = width * height; if (requiredPixels <= maximumPixels) { return new Size(size.width, size.height); } var scalar = Math.sqrt(maximumPixels) / Math.sqrt(requiredPixels); return new Size(Math.floor(width * scalar), Math.floor(height * scalar)); }; Print.prototype.renderFieldsForPrint = function (pageIndex, heightRatio, widthRatio) { var data = null; var targetField; if (this.pdfViewer.printMode === 'Default') { targetField = this.frameDoc.document.getElementById('fields_' + pageIndex); } else { targetField = this.printWindow.document.getElementById('fields_' + pageIndex); } if (this.pdfViewer.formFieldsModule) { data = this.pdfViewerBase.getItemFromSessionStorage('_formfields'); } if (!this.pdfViewer.formDesignerModule) { if (data) { var formFieldsData = JSON.parse(data); for (var i = 0; i < formFieldsData.length; i++) { var currentData = formFieldsData[parseInt(i.toString(), 10)]; if (parseFloat(currentData['PageIndex']) === pageIndex) { var field = this.pdfViewer.formFieldsModule.createFormFields(currentData, pageIndex, i, targetField); var inputField = field.currentField; if (inputField) { var bounds = currentData['LineBounds']; var font = currentData['Font']; this.applyPosition(inputField, bounds, font, heightRatio, widthRatio); inputField.InsertSpaces = currentData.InsertSpaces; if (inputField.InsertSpaces) { var font_1 = ((parseInt(inputField.style.width, 10) / inputField.maxLength) - (parseFloat(inputField.style.fontSize) / 2)) - 0.6; inputField.style.letterSpacing = '' + font_1 + 'px'; inputField.style.fontFamily = 'monospace'; } var pageDetails = this.pdfViewerBase.pageSize[parseInt(pageIndex.toString(), 10)]; if ((pageDetails.width > pageDetails.height) && this.pdfViewer.enablePrintRotation) { /* The below logig have been modified for the bug https://syncfusion.atlassian.net/browse/EJ2-57986 This code changes is specific for form field elements. inputField.style.transform = 'rotate(-90deg)'; let previousLeft: number = parseFloat(inputField.style.left); let currentWidthPosition: number = parseFloat(inputField.style.width) / 2; let currentHeightPosition: number = parseFloat(inputField.style.height) / 2; let currentTop: number = parseFloat(inputField.style.top); let currentHeight: number = parseFloat(inputField.style.height); inputField.style.left = (currentHeightPosition - currentWidthPosition + currentTop) + 'px'; inputField.style.top = (pageDetails.width / widthRatio) - (currentHeight / heightRatio) - ((currentWidthPosition / heightRatio) - (currentHeightPosition / heightRatio) + previousLeft) + 'px'; */ var x = this.pdfViewer.formFieldsModule.ConvertPointToPixel(bounds.X); var y = this.pdfViewer.formFieldsModule.ConvertPointToPixel(bounds.Y); var width = this.pdfViewer.formFieldsModule.ConvertPointToPixel(bounds.Width); var height = this.pdfViewer.formFieldsModule.ConvertPointToPixel(bounds.Height); var pageHeight = pageDetails.width; var top_1 = pageHeight - x - height; var left = (y + height); inputField.style.transform = 'rotate(-90deg)'; inputField.style.transformOrigin = 'left bottom'; inputField.style.left = left + 'px'; inputField.style.top = top_1 + 'px'; inputField.style.height = height + 'px'; inputField.style.width = width + 'px'; } inputField.style.backgroundColor = 'transparent'; if (!currentData.IsSignatureField) { inputField.style.borderColor = 'transparent'; } targetField.appendChild(inputField); } } } } } else { var formDesignerData = null; if (this.pdfViewer.formDesignerModule) { formDesignerData = this.pdfViewerBase.getItemFromSessionStorage('_formDesigner'); } if (formDesignerData || this.pdfViewer.formFieldCollections.length > 0) { var formFieldsData = !isNullOrUndefined(formDesignerData) ? JSON.parse(formDesignerData) : []; this.pdfViewer.formDesignerModule.updateMissingFormFields(formFieldsData); var formDesignerFieldsData = formFieldsData; for (var i = 0; i < formDesignerFieldsData.length; i++) { var currentData = formDesignerFieldsData[parseInt(i.toString(), 10)].FormField; if (currentData.pageNumber - 1 === pageIndex && currentData.isPrint) { var signatureField = this.pdfViewer.nameTable[formDesignerFieldsData[parseInt(i.toString(), 10)].Key.split('_')[0]]; var element = null; if (!isNullOrUndefined(signatureField)) { element = signatureField.wrapper.children[0]; } else { signatureField = this.createSignatureField(currentData); element = signatureField.wrapper.children[0]; } var htmlElement = void 0; if (element) { if (currentData.formFieldAnnotationType === 'RadioButton') { for (var j = 0; j < currentData.radiobuttonItem.length; j++) { signatureField = this.pdfViewer.nameTable[currentData.radiobuttonItem[parseInt(j.toString(), 10)].id.split('_')[0]]; if (isNullOrUndefined(signatureField)) { signatureField = this.createSignatureField(currentData.radiobuttonItem[parseInt(j.toString(), 10)]); } htmlElement = this.createFormDesignerFields(currentData.radiobuttonItem[parseInt(j.toString(), 10)], element, signatureField); if (htmlElement) { var bounds = currentData.radiobuttonItem[parseInt(j.toString(), 10)].lineBound; var font = currentData.radiobuttonItem[parseInt(j.toString(), 10)].fontFamily; this.applyPosition(htmlElement, bounds, font, heightRatio, widthRatio, true, currentData.radiobuttonItem[parseInt(j.toString(), 10)].zoomValue, currentData.pageNumber - 1); targetField.appendChild(htmlElement); } } } else { htmlElement = this.createFormDesignerFields(currentData, element, signatureField); if (htmlElement) { var bounds = currentData.lineBound; var font = currentData.fontFamily; this.applyPosition(htmlElement, bounds, font, heightRatio, widthRatio, true, currentData.zoomValue, currentData.pageNumber - 1); if (!isNullOrUndefined(bounds) && bounds.Width > 0 && bounds.Height > 0) { targetField.appendChild(htmlElement); } } } } } } } } }; Print.prototype.createSignatureField = function (data) { var cloneCurrentData = JSON.parse(JSON.stringify(data)); if (data.lineBound) { var _a = data.lineBound, x = _a.X, y = _a.Y, width = _a.Width, height = _a.Height; cloneCurrentData.bounds = { x: x, y: y, width: width, height: height }; delete cloneCurrentData.lineBound; } if (data.option && (data.formFieldAnnotationType === 'DropdownList' || data.formFieldAnnotationType === 'ListBox')) { cloneCurrentData.options = cloneCurrentData.option; delete cloneCurrentData.option; } var signatureField = new PdfFormFieldBase(this.pdfViewer, 'formFields', cloneCurrentData, true); this.pdfViewer.drawing.initNode(signatureField); signatureField.backgroundColor = typeof signatureField.backgroundColor === 'string' ? signatureField.backgroundColor : this.pdfViewer.formDesignerModule.getRgbToHex(signatureField.backgroundColor); signatureField.borderColor = typeof signatureField.borderColor === 'string' ? signatureField.borderColor : this.pdfViewer.formDesignerModule.getRgbToHex(signatureField.borderColor); return signatureField; }; Print.prototype.createFormDesignerFields = function (currentData, element, signatureField) { var parentHtmlElementAttribute = { 'id': 'form_field_' + element.id + '_html_element', 'class': 'foreign-object' }; var parentHtmlElement = this.pdfViewer.formDesignerModule.createHtmlElement('div', parentHtmlElementAttribute); var HtmlElementAttribute = { 'id': element.id + '_html_element', 'class': 'foreign-object' }; var htmlElement = this.pdfViewer.formDesignerModule.createHtmlElement('div', HtmlElementAttribute); if (currentData.formFieldAnnotationType === 'SignatureField' || currentData.formFieldAnnotationType === 'InitialField') { this.pdfViewer.formDesignerModule.disableSignatureClickEvent = true; element.template = htmlElement.appendChild(this.pdfViewer.formDesignerModule. createSignatureDialog(this.pdfViewer, signatureField, null, true)); this.pdfViewer.formDesignerModule.disableSignatureClickEvent = false; } else if (currentData.formFieldAnnotationType === 'DropdownList') { element.template = htmlElement.appendChild(this.pdfViewer.formDesignerModule.createDropDownList(element, signatureField, true)); } else if (currentData.formFieldAnnotationType === 'ListBox') { element.template = htmlElement.appendChild(this.pdfViewer.formDesignerModule.createListBox(element, signatureField, true)); } else { element.template = htmlElement.appendChild(this.pdfViewer.formDesignerModule. createInputElement(currentData.formFieldAnnotationType, signatureField, null, true)); } parentHtmlElement.appendChild(htmlElement); return htmlElement; }; /** * @param {any} inputField - It describes about the input field * @param {any} bounds - It describes about the bounds * @param {any} font - It describes about the font * @param {number} heightRatio - It describes about the height ratio * @param {number} widthRatio - It describes about the width ratio * @param {boolean} isFormDesignerField - It describes about the isFormDesignerField * @param {number} zoomValue - It describes about the zoom value * @param {number} pageIndex - It describes about the page index value * @private * @returns {void} */ Print.prototype.applyPosition = function (inputField, bounds, font, heightRatio, widthRatio, isFormDesignerField, zoomValue, pageIndex) { if (bounds) { var pageHeight = void 0; var left = void 0; var top_2; var width = void 0; var height = void 0; // This code changes is specific for form designer elements. https://syncfusion.atlassian.net/browse/EJ2-57986 // eslint-disable-next-line var pageDetails = this.pdfViewerBase.pageSize[pageIndex]; var actualWidth = pageDetails ? pageDetails.width : 0; var actualHeight = pageDetails ? pageDetails.height : 0; if (isFormDesignerField && actualHeight < actualWidth && this.pdfViewer.enablePrintRotation) { /* The below logig have been modified for the bug https://syncfusion.atlassian.net/browse/EJ2-57986 This code changes is specific for form designer elements. pageHeight = actualWidth; top= pageHeight - bounds.X / zoomValue; left = bounds.Y / zoomValue; width = (bounds.Width / zoomValue); height = (bounds.Height / zoomValue); inputField.style.transform = "rotate(-90deg)"; inputField.style.transformOrigin = "top left"; */ // need to set inverse page height and width pageHeight = actualWidth; top_2 = pageHeight - bounds.X / zoomValue - bounds.Height / zoomValue; left = (bounds.Y + bounds.Height) / zoomValue; width = (bounds.Width / zoomValue); height = (bounds.Height / zoomValue); inputField.style.transform = 'rotate(-90deg)'; inputField.style.transformOrigin = 'left bottom'; } else { left = isFormDesignerField ? (bounds.X / zoomValue) / widthRatio : (this.pdfViewer.formFieldsModule.ConvertPointToPixel(bounds.X)) / widthRatio; top_2 = isFormDesignerField ? (bounds.Y / zoomValue) / heightRatio : (this.pdfViewer.formFieldsModule.ConvertPointToPixel(bounds.Y)) / heightRatio; width = isFormDesignerField ? (bounds.Width / zoomValue) / widthRatio : (this.pdfViewer.formFieldsModule.ConvertPointToPixel(bounds.Width)) / widthRatio; height = isFormDesignerField ? (bounds.Height / zoomValue) / heightRatio : (this.pdfViewer.formFieldsModule.ConvertPointToPixel(bounds.Height)) / heightRatio; } var fontHeight = 0; if (font !== null && font.Height) { inputField.style.fontFamily = font.Name; if (font.Italic) { inputField.style.fontStyle = 'italic'; } if (font.Bold) { inputField.style.fontWeight = 'Bold'; } fontHeight = this.pdfViewerBase.ConvertPointToPixel(font.Size); } if (Browser.isIE) { top_2 = top_2 - 1; } this.pdfViewerBase.setStyleToTextDiv(inputField, left, top_2, fontHeight, width, height, true); } }; /** * @param {any} printDocument - It describes printdocument element * @param {string} styleContent - It describes styles text content * @private * @returns {void} */ Print.prototype.createStyleSheet = function (printDocument, styleContent) { var blob = new Blob([styleContent], { type: 'text/css' }); var linkElement = printDocument.createElement('link'); linkElement.rel = 'stylesheet'; linkElement.href = URL.createObjectURL(blob); printDocument.head.appendChild(linkElement); }; Print.prototype.printWindowOpen = function () { var _this = this; var browserUserAgent = navigator.userAgent; var printDocument; if (this.pdfViewer.printMode === 'Default') { printDocument = this.frameDoc.document; } else { printDocument = this.printWindow.document; } for (var i = 0; i < this.printViewerContainer.children.length; i++) { /* Create a new Base64-encoded image with increased quality Also help to reduce the file size while save as pdf */ if (i === 0) { printDocument.write('<!DOCTYPE html>'); printDocument.write('<html moznomarginboxes mozdisallowselectionprint><head></head><body>'); } var canvasUrl = this.printViewerContainer.children[parseInt(i.toString(), 10)].toDataURL('image/jpeg'); printDocument.write('<div id="' + 'imageElementPdf_' + i + '"><img src="' + canvasUrl + '" id="' + 'image_' + i + '" /><div id="' + 'fields_' + i + '"></div></div>'); var imageElement = printDocument.getElementById('imageElementPdf_' + i); imageElement.style.cssText = "margin:0mm;width:" + this.printWidth + "px;height:" + this.printHeight + "px;position:relative"; var fieldElement = printDocument.getElementById('fields_' + i); fieldElement.style.cssText = "margin:0px;top:0px;left:0px;position:absolute;width:" + this.printWidth + "px;height:" + this.printHeight + "px;z-index:2"; if (this.pdfViewer.formFieldsModule || this.pdfViewer.formDesignerModule) { var pageWidth = this.pdfViewerBase.pageSize[parseInt(i.toString(), 10)].width; var pageHeight = this.pdfViewerBase.pageSize[parseInt(i.toString(), 10)].height; var heightRatio = void 0; var widthRatio = void 0; if ((pageHeight < pageWidth) && this.pdfViewer.enablePrintRotation) { heightRatio = pageHeight / this.printWidth; widthRatio = pageWidth / this.printHeight; } else { heightRatio = pageHeight / this.printHeight; widthRatio = pageWidth / this.printWidth; } this.renderFieldsForPrint(i, heightRatio, widthRatio); } if (i === 0) { if ((browserUserAgent.indexOf('Chrome') !== -1) || (browserUserAgent.indexOf('Safari') !== -1) || (browserUserAgent.indexOf('Firefox')) !== -1) { var styleContent = "\n html, body { height: 100%; width: 100%; }\n img { height: 100%; width: 100%; display: block; }\n @media print { \n body { margin: 0cm; }\n img { width: 100%; box-sizing: border-box; }\n br, button { display: none; }\n div { page-break-inside: avoid; }\n }\n @page { margin: 0mm; size: " + this.printWidth.toString() + "px " + this.printHeight.toString() + "px; }\n "; this.createStyleSheet(printDocument, styleContent); } else { var styleContent = "\n html, body { height: 100%; }\n img { height: 100%; width: 100%; }\n @media print { \n body { margin: 0cm; }\n img { width: 100%; box-sizing: border-box; }\n br, button { display: none; }\n div { page-break-inside: avoid; }\n }\n @page { margin: 0mm; size: " + this.printWidth.toString() + "px " + this.printHeight.toString() + "px; }\n "; this.createStyleSheet(printDocument, styleContent); } } } if (Browser.isIE || Browser.info.name === 'edge') { try { if (this.pdfViewer.printMode === 'Default') { this.pdfViewerBase.showPrintLoadingIndicator(false); this.iframe.contentWindow.document.execCommand('print', false, null); } else { this.printWindow.document.execCommand('print', false, null); } } catch (e) { if (this.pdfViewer.printMode === 'Default') { this.pdfViewerBase.showPrintLoadingIndicator(false); this.iframe.contentWindow.print(); } else { this.printWindow.print(); } } } else { setTimeout(function () { if (_this.pdfViewer.printMode === 'Default') { _this.pdfViewerBase.showPrintLoadingIndicator(false); _this.iframe.contentWindow.print(); _this.iframe.contentWindow.focus(); if (_this.pdfViewerBase.isDeviceiOS || Browser.isDevice) { // eslint-disable-next-line var proxy_1 = _this; window.onafterprint = function () { document.body.removeChild(proxy_1.iframe); }; } else { document.body.removeChild(_this.iframe); } } else { if (_this.printWindow) { _this.printWindow.print(); _this.printWindow.focus(); if (!Browser.isDevice || _this.pdfViewerBase.isDeviceiOS) { _this.printWindow.close(); } } } }, 200); } }; Print.prototype.createPrintLoadingIndicator = function (element) { var printWindowContainer = createElement('div', { id: this.pdfViewer.element.id + '_printWindowcontainer' }); printWindowContainer.style.height = '100%'; printWindowContainer.style.width = '100%'; printWindowContainer.style.position = 'absolute'; printWindowContainer.style.zIndex = 2000; printWindowContainer.style.left = 0; printWindowContainer.style.top = 0; printWindowContainer.style.overflow = 'auto'; printWindowContainer.style.backgroundColor = 'rgba(0, 0, 0, 0.3)'; element.appendChild(printWindowContainer); var printWaitingPopup = createElement('div', { id: this.pdfViewer.element.id + '_printLoadingContainer' }); printWaitingPopup.style.position = 'absolute'; printWaitingPopup.style.width = '50px'; printWaitingPopup.style.height = '50px'; printWaitingPopup.style.left = '46%'; printWaitingPopup.style.top = '45%'; printWindowContainer.style.zIndex = 3000; printWindowContainer.appendChild(printWaitingPopup); var printImageContainer = new Image(); printImageContainer.src = ''; printImageContainer.style.width = '50px'; printImageContainer.style.height = '50px'; printWaitingPopup.appendChild(printImageContainer); var printLabelContainer = createElement('div', { id: this.pdfViewer.element.id + '_printLabelContainer' }); printLabelContainer.style.position = 'absolute'; printLabelContainer.textContent = 'Loading ...'; printLabelContainer.style.fontWeight = 'Bold'; printLabelContainer.style.left = '46%'; printLabelContainer.style.top = '54.5%'; printLabelContainer.style.zIndex = '3000'; printWindowContainer.appendChild(printLabelContainer); }; /** * @private * @returns {void} */ Print.prototype.destroy = function () { this.printViewerContainer = undefined; this.frameDoc = undefined; this.printWindow = undefined; }; /** * @private * @returns {string} - string */ Print.prototype.getModuleName = function () { return 'Print'; }; return Print; }()); export { Print };