diff --git a/bin/backend/controls/OutputDialog.js b/bin/backend/controls/OutputDialog.js index c830101607c06100177cbee521642c22284438f0..51d5dfd1e8781c4e68fd6414324432615715d7ef 100644 --- a/bin/backend/controls/OutputDialog.js +++ b/bin/backend/controls/OutputDialog.js @@ -4,887 +4,855 @@ * * @event onOuput [FormData, this] - Fires if the user submits the popup with a chosen output format */ -define( - 'package/quiqqer/erp/bin/backend/controls/OutputDialog', - [ - - 'qui/QUI', - 'qui/controls/windows/Confirm', - 'qui/controls/buttons/Select', - 'qui/controls/elements/Sandbox', - 'qui/controls/buttons/Switch', - - 'package/quiqqer/erp/bin/backend/controls/Comments', - 'package/quiqqer/erp/bin/backend/utils/ERPEntities', - - 'qui/utils/Form', - - 'Ajax', - 'Locale', - 'Mustache', - - 'text!package/quiqqer/erp/bin/backend/controls/OutputDialog.html', - 'css!package/quiqqer/erp/bin/backend/controls/OutputDialog.css' - - ], - function( - QUI, - QUIConfirm, - QUISelect, - QUISandbox, - QUISwitch, - ERPComments, - ERPEntities, - QUIFormUtils, - QUIAjax, - QUILocale, - Mustache, - template - ) { - 'use strict'; - - const lg = 'quiqqer/erp'; - let PDF_SUPPORT = null; - let CURRENT_VIEW = null; - - return new Class({ - - Extends: QUIConfirm, - type: 'package/quiqqer/erp/bin/backend/controls/OutputDialog', - - Binds: [ - '$onOpen', - '$onOutputChange', - '$onPrintFinish', - '$getPreview', - '$onChangeToEmail', - '$onChangeToPDF', - '$onChangeToPrint', - '$resizeCommentsBox', - '$onChangeMailRecipient' - ], - - options: { - entityId: false, // Clean entity ID WITHOUT prefix and suffix - entityType: false, // Entity type (e.g. "Invoice") - entityPlugin: false, - - comments: false, // Comments as array [must be readble by package/quiqqer/erp/bin/backend/controls/Comments] - - showMarkAsSentOption: false, // show checkbox for "Mark as sent" - mailEditor: true, // shows editable subject and body for mail output - - maxHeight: 800, - maxWidth: 1500 - }, - - initialize: function(options) { - this.parent(options); - - this.setAttributes({ - icon: 'fa fa-print', - title: QUILocale.get(lg, 'controls.OutputDialog.title'), - autoclose: false, - cancel_button: { - textimage: 'fa fa-close', - text: QUILocale.get('quiqqer/system', 'close') +define('package/quiqqer/erp/bin/backend/controls/OutputDialog', [ + 'qui/QUI', + 'qui/controls/windows/Confirm', + 'qui/controls/buttons/Select', + 'qui/controls/elements/Sandbox', + 'qui/controls/buttons/Switch', + + 'package/quiqqer/erp/bin/backend/controls/Comments', + 'package/quiqqer/erp/bin/backend/utils/ERPEntities', + + 'qui/utils/Form', + + 'Ajax', + 'Locale', + 'Mustache', + + 'text!package/quiqqer/erp/bin/backend/controls/OutputDialog.html', + 'css!package/quiqqer/erp/bin/backend/controls/OutputDialog.css' +], function( + QUI, + QUIConfirm, + QUISelect, + QUISandbox, + QUISwitch, + ERPComments, + ERPEntities, + QUIFormUtils, + QUIAjax, + QUILocale, + Mustache, + template +) { + 'use strict'; + + const lg = 'quiqqer/erp'; + let PDF_SUPPORT = null; + let CURRENT_VIEW = null; + + return new Class({ + + Extends: QUIConfirm, + type: 'package/quiqqer/erp/bin/backend/controls/OutputDialog', + + Binds: [ + '$onOpen', + '$onOutputChange', + '$onPrintFinish', + '$getPreview', + '$onChangeToEmail', + '$onChangeToPDF', + '$onChangeToPrint', + '$resizeCommentsBox', + '$onChangeMailRecipient' + ], + + options: { + entityId: false, // Clean entity ID WITHOUT prefix and suffix + entityType: false, // Entity type (e.g. "Invoice") + entityPlugin: false, + + comments: false, // Comments as array [must be readble by package/quiqqer/erp/bin/backend/controls/Comments] + + showMarkAsSentOption: false, // show checkbox for "Mark as sent" + mailEditor: true, // shows editable subject and body for mail output + + maxHeight: 800, + maxWidth: 1500 + }, + + initialize: function(options) { + this.parent(options); + + this.setAttributes({ + icon: 'fa fa-print', + title: QUILocale.get(lg, 'controls.OutputDialog.title'), + autoclose: false, + cancel_button: { + textimage: 'fa fa-close', + text: QUILocale.get('quiqqer/system', 'close') + } + }); + + this.$Output = null; + this.$PDFView = null; + this.$Preview = null; + this.$customerMail = null; + this.$Template = null; + + this.$CommentsBox = null; + this.$Form = null; + this.$MessagesBox = null; + + this.$mailSent = false; + + this.$Mail = { + subject: false, + content: false, + attachedMediaFileIds: [] + }; + + this.addEvents({ + onOpen: this.$onOpen, + onSubmit: this.$onSubmit, + onOpenBegin: function() { + const winSize = QUI.getWindowSize(); + let height = 800; + let width = 1400; + + if (winSize.y * 0.9 < height) { + height = winSize.y * 0.9; } - }); - - this.$Output = null; - this.$PDFView = null; - this.$Preview = null; - this.$customerMail = null; - this.$Template = null; - - this.$CommentsBox = null; - this.$Form = null; - this.$MessagesBox = null; - - this.$mailSent = false; - - this.$Mail = { - subject: false, - content: false, - attachedMediaFileIds: [] - }; - this.addEvents({ - onOpen: this.$onOpen, - onSubmit: this.$onSubmit, - onOpenBegin: function() { - const winSize = QUI.getWindowSize(); - let height = 800; - let width = 1400; + if (winSize.x * 0.9 < width) { + width = winSize.x * 0.9; + } - if (winSize.y * 0.9 < height) { - height = winSize.y * 0.9; - } + this.setAttribute('maxHeight', height); + this.setAttribute('maxWidth', width); + }.bind(this) + }); + }, + + /** + * event: on open + */ + $onOpen: function() { + const self = this, + Content = this.getContent(); + + this.Loader.show(); + this.getContent().set('html', ''); + + const onError = function(error) { + self.close().then(function() { + self.destroy(); + }); - if (winSize.x * 0.9 < width) { - width = winSize.x * 0.9; - } + QUI.getMessageHandler().then(function(MH) { + if (typeof error === 'object' && typeof error.getMessage !== 'undefined') { + MH.addError(error.getMessage()); + return; + } - this.setAttribute('maxHeight', height); - this.setAttribute('maxWidth', width); - }.bind(this) + MH.addError(error); }); - }, - - /** - * event: on open - */ - $onOpen: function() { - const self = this, - Content = this.getContent(); - - this.Loader.show(); - this.getContent().set('html', ''); - - const onError = function(error) { - self.close().then(function() { - self.destroy(); - }); - - QUI.getMessageHandler().then(function(MH) { - if (typeof error === 'object' && typeof error.getMessage !== 'undefined') { - MH.addError(error.getMessage()); - return; + }; + + Content.set({ + html: Mustache.render(template, { + entityId: this.getAttribute('entityId'), + labelEntityId: QUILocale.get(lg, 'controls.OutputDialog.labelEntityId'), + labelTemplate: QUILocale.get(lg, 'controls.OutputDialog.labelTemplate'), + labelOutputType: QUILocale.get(lg, 'controls.OutputDialog.labelOutputType'), + labelPDFView: QUILocale.get(lg, 'controls.OutputDialog.labelPDFView'), + labelEmail: QUILocale.get('quiqqer/core', 'recipient'), + showMarkAsSentOption: !!this.getAttribute('showMarkAsSentOption'), + mailEditor: !!this.getAttribute('mailEditor'), + labelOpenMailEditor: QUILocale.get(lg, 'controls.OutputDialog.labelOpenMailEditor'), + labelMarkAsSent: QUILocale.get(lg, 'controls.OutputDialog.labelMarkAsSent'), + descMarkAsSent: QUILocale.get(lg, 'controls.OutputDialog.descMarkAsSent') + }) + }); + + Content.addClass('quiqqer-erp-outputDialog'); + + self.$MessagesBox = Content.getElement('.quiqqer-erp-outputDialog-messages'); + + // "To mail editor" button + if (this.getAttribute('mailEditor')) { + Content.getElement('.quiqqer-erp-outputDialog-openMailEditor').addEvent('click', function() { + require( + ['package/quiqqer/erp/bin/backend/controls/OutputMailEditor'], + function(OutputMailEditor) { + new OutputMailEditor({ + entityId: self.getAttribute('entityId'), + entityType: self.getAttribute('entityType'), + entityPlugin: self.getAttribute('entityPlugin'), + + mailSubject: self.$Mail.subject, + mailContent: self.$Mail.content, + attachedMediaFileIds: self.$Mail.attachedMediaFileIds, + + events: { + onMailSubmit: function(MailData) { + self.$Mail = MailData; + } + } + }).open(); } - - MH.addError(error); - }); - }; - - Content.set({ - html: Mustache.render(template, { - entityId: this.getAttribute('entityId'), - labelEntityId: QUILocale.get(lg, 'controls.OutputDialog.labelEntityId'), - labelTemplate: QUILocale.get(lg, 'controls.OutputDialog.labelTemplate'), - labelOutputType: QUILocale.get(lg, 'controls.OutputDialog.labelOutputType'), - labelPDFView: QUILocale.get(lg, 'controls.OutputDialog.labelPDFView'), - labelEmail: QUILocale.get('quiqqer/core', 'recipient'), - showMarkAsSentOption: !!this.getAttribute('showMarkAsSentOption'), - mailEditor: !!this.getAttribute('mailEditor'), - labelOpenMailEditor: QUILocale.get(lg, 'controls.OutputDialog.labelOpenMailEditor'), - labelMarkAsSent: QUILocale.get(lg, 'controls.OutputDialog.labelMarkAsSent'), - descMarkAsSent: QUILocale.get(lg, 'controls.OutputDialog.descMarkAsSent') - }) + ); }); + } - Content.addClass('quiqqer-erp-outputDialog'); - - self.$MessagesBox = Content.getElement('.quiqqer-erp-outputDialog-messages'); - - // "To mail editor" button - if (this.getAttribute('mailEditor')) { - Content.getElement('.quiqqer-erp-outputDialog-openMailEditor').addEvent('click', function() { - require( - ['package/quiqqer/erp/bin/backend/controls/OutputMailEditor'], - function(OutputMailEditor) { - new OutputMailEditor({ - entityId: self.getAttribute('entityId'), - entityType: self.getAttribute('entityType'), - entityPlugin: self.getAttribute('entityPlugin'), - - mailSubject: self.$Mail.subject, - mailContent: self.$Mail.content, - attachedMediaFileIds: self.$Mail.attachedMediaFileIds, - - events: { - onMailSubmit: function(MailData) { - self.$Mail = MailData; - } - } - }).open(); - } - ); - }); + this.$Output = new QUISelect({ + localeStorage: 'quiqqer-erp-output-dialog', + name: 'output', + styles: { + border: 'none', + width: '100%' + }, + events: { + onChange: self.$onOutputChange } - - this.$Output = new QUISelect({ - localeStorage: 'quiqqer-erp-output-dialog', - name: 'output', - styles: { - border: 'none', - width: '100%' - }, - events: { - onChange: self.$onOutputChange + }); + + this.$Output.appendChild( + QUILocale.get(lg, 'controls.OutputDialog.data.output.print'), + 'print', + 'fa fa-print' + ); + + this.$Output.appendChild( + QUILocale.get(lg, 'controls.OutputDialog.data.output.pdf'), + 'pdf', + 'fa fa-file-pdf-o' + ); + + this.$Output.appendChild( + QUILocale.get(lg, 'controls.OutputDialog.data.output.email'), + 'email', + 'fa fa-envelope-o' + ); + + this.$Output.inject(Content.getElement('.field-output')); + + Promise.all([ + this.$getTemplates(), + this.$getEntityData(), + this.checkPdfSupport() + ]).then((result) => { + const templates = result[0]; + const EntityData = result[1]; + const pdfSupport = result[2]; + + if (!pdfSupport) { + if (typeof window.QUIQQER_OUTPUT_PDF === 'undefined') { + window.QUIQQER_OUTPUT_PDF = false; } - }); - - this.$Output.appendChild( - QUILocale.get(lg, 'controls.OutputDialog.data.output.print'), - 'print', - 'fa fa-print' - ); - - this.$Output.appendChild( - QUILocale.get(lg, 'controls.OutputDialog.data.output.pdf'), - 'pdf', - 'fa fa-file-pdf-o' - ); - - this.$Output.appendChild( - QUILocale.get(lg, 'controls.OutputDialog.data.output.email'), - 'email', - 'fa fa-envelope-o' - ); - this.$Output.inject(Content.getElement('.field-output')); + const PdfView = this.getElm().getElement('.quiqqer-erp-outputDialog-pdfView'); + const Cell = PdfView.getParent('.field-container-field'); + PdfView.setStyle('display', 'none'); - Promise.all([ - this.$getTemplates(), - this.$getEntityData(), - this.checkPdfSupport() - ]).then((result) => { - const templates = result[0]; - const EntityData = result[1]; - const pdfSupport = result[2]; + Cell.set( + 'html', + QUILocale.get(lg, 'controls.OutputDialog.no_pdf_preview_support') + ); + } else { + if (typeof window.QUIQQER_OUTPUT_PDF === 'undefined') { + window.QUIQQER_OUTPUT_PDF = true; + } - if (!pdfSupport) { - if (typeof window.QUIQQER_OUTPUT_PDF === 'undefined') { - window.QUIQQER_OUTPUT_PDF = false; + self.$PDFView = new QUISwitch({ + name: 'pdfView', + status: window.QUIQQER_OUTPUT_PDF, + events: { + onChange: () => { + window.QUIQQER_OUTPUT_PDF = self.$PDFView.getStatus(); + self.$renderPreview(); + } } + }).inject(self.getElm().getElement('.quiqqer-erp-outputDialog-pdfView')); + } - const PdfView = this.getElm().getElement('.quiqqer-erp-outputDialog-pdfView'); - const Cell = PdfView.getParent('.field-container-field'); - PdfView.setStyle('display', 'none'); - - Cell.set( - 'html', - QUILocale.get(lg, 'controls.OutputDialog.no_pdf_preview_support') - ); - } else { - if (typeof window.QUIQQER_OUTPUT_PDF === 'undefined') { - window.QUIQQER_OUTPUT_PDF = true; - } + const Form = Content.getElement('form'); + let Selected = false; - self.$PDFView = new QUISwitch({ - name: 'pdfView', - status: window.QUIQQER_OUTPUT_PDF, - events: { - onChange: () => { - window.QUIQQER_OUTPUT_PDF = self.$PDFView.getStatus(); - self.$renderPreview(); - } - } - }).inject(self.getElm().getElement('.quiqqer-erp-outputDialog-pdfView')); - } + Content.getElement('.quiqqer-erp-outputDialog-options-entityId').set( + 'html', + EntityData.prefixedNumber + ); - const Form = Content.getElement('form'); - let Selected = false; + if (!templates.length) { + new Element('option', { + value: '#', + html: QUILocale.get(lg, 'controls.OutputDialog.no_templates_found') + }).inject(Form.elements.template); - Content.getElement('.quiqqer-erp-outputDialog-options-entityId').set( - 'html', - EntityData.prefixedNumber - ); + Form.elements.template.disabled = true; - if (!templates.length) { - new Element('option', { - value: '#', - html: QUILocale.get(lg, 'controls.OutputDialog.no_templates_found') - }).inject(Form.elements.template); + const PreviewContent = self.getContent().getElement('.quiqqer-erp-outputDialog-preview'); - Form.elements.template.disabled = true; + new Element('div', { + 'class': 'quiqqer-erp-outputDialog-nopreview', + html: QUILocale.get(lg, 'controls.OutputDialog.no_preview') + }).inject(PreviewContent); - const PreviewContent = self.getContent().getElement('.quiqqer-erp-outputDialog-preview'); + self.$Output.disable(); + self.getButton('submit').disable(); - new Element('div', { - 'class': 'quiqqer-erp-outputDialog-nopreview', - html: QUILocale.get(lg, 'controls.OutputDialog.no_preview') - }).inject(PreviewContent); + self.Loader.hide(); + return; + } - self.$Output.disable(); - self.getButton('submit').disable(); + for (let i = 0, len = templates.length; i < len; i++) { + let Template = templates[i]; - self.Loader.hide(); - return; + if (Template.isSystemDefault && EntityData.hideSystemDefaultTemplate) { + continue; } - for (let i = 0, len = templates.length; i < len; i++) { - let Template = templates[i]; - - if (Template.isSystemDefault && EntityData.hideSystemDefaultTemplate) { - continue; - } + new Element('option', { + value: Template.id, + html: Template.title, + 'data-provider': Template.provider + }).inject(Form.elements.template); - new Element('option', { - value: Template.id, - html: Template.title, - 'data-provider': Template.provider - }).inject(Form.elements.template); - - if (!Selected && Template.isDefault) { - Selected = Template; - } + if (!Selected && Template.isDefault) { + Selected = Template; } + } - Form.elements.template.addEvent('change', function(event) { - self.$Template = { - id: event.target.value, - provider: event.target.getElement('option[value="' + event.target.value + '"]').get( - 'data-provider') - }; - - self.$renderPreview(); - }); - - // Set initial template and render preview - Form.elements.template.value = Selected.id; + Form.elements.template.addEvent('change', function(event) { self.$Template = { - id: Selected.id, - provider: Selected.provider + id: event.target.value, + provider: event.target.getElement('option[value="' + event.target.value + '"]').get( + 'data-provider') }; self.$renderPreview(); + }); - // Customer data - self.$customerMail = EntityData.email; - CURRENT_VIEW = null; - self.$onOutputChange(); + // Set initial template and render preview + Form.elements.template.value = Selected.id; + self.$Template = { + id: Selected.id, + provider: Selected.provider + }; - self.Loader.hide(); + self.$renderPreview(); - // Load comments - self.$CommentsBox = Content.getElement('.quiqqer-erp-outputDialog-comments'); - self.$Form = Form; + // Customer data + self.$customerMail = EntityData.email; + CURRENT_VIEW = null; + self.$onOutputChange(); - if (!self.getAttribute('comments') || !self.getAttribute('comments').length) { - if (self.$CommentsBox) { - self.$CommentsBox.destroy(); - } + self.Loader.hide(); - self.$CommentsBox = null; - return; + // Load comments + self.$CommentsBox = Content.getElement('.quiqqer-erp-outputDialog-comments'); + self.$Form = Form; + + if (!self.getAttribute('comments') || !self.getAttribute('comments').length) { + if (self.$CommentsBox) { + self.$CommentsBox.destroy(); } - new ERPComments({ - comments: self.getAttribute('comments') - }).inject(self.$CommentsBox); + self.$CommentsBox = null; + return; + } - self.$resizeCommentsBox(); - }).catch(function(e) { - onError(e); - }); - }, + new ERPComments({ + comments: self.getAttribute('comments') + }).inject(self.$CommentsBox); - /** - * Render preview with selected template - */ - $renderPreview: function() { - const self = this; - const PreviewContent = this.getContent().getElement('.quiqqer-erp-outputDialog-preview'); + self.$resizeCommentsBox(); + }).catch(function(e) { + onError(e); + }); + }, - this.Loader.show(); + /** + * Render preview with selected template + */ + $renderPreview: function() { + const self = this; + const PreviewContent = this.getContent().getElement('.quiqqer-erp-outputDialog-preview'); - const showPreviewError = function() { - PreviewContent.set('html', ''); + this.Loader.show(); - new Element('div', { - 'class': 'quiqqer-erp-outputDialog-nopreview', - html: QUILocale.get(lg, 'controls.OutputDialog.preview_error'), - styles: { - padding: 20 - } - }).inject(PreviewContent); - }; + const showPreviewError = function() { + PreviewContent.set('html', ''); - if (this.$PDFView && this.$PDFView.getStatus()) { - this.showAsPDF(); - return; - } + new Element('div', { + 'class': 'quiqqer-erp-outputDialog-nopreview', + html: QUILocale.get(lg, 'controls.OutputDialog.preview_error'), + styles: { + padding: 20 + } + }).inject(PreviewContent); + }; - this.$getPreview().then(function(previewHtml) { - self.Loader.hide(); + if (this.$PDFView && this.$PDFView.getStatus()) { + this.showAsPDF(); + return; + } - if (!previewHtml) { - showPreviewError(); - return; - } + this.$getPreview().then(function(previewHtml) { + self.Loader.hide(); - PreviewContent.set('html', ''); + if (!previewHtml) { + showPreviewError(); + return; + } - new QUISandbox({ - content: previewHtml, - styles: { - height: '100%', - padding: 20, - width: '100%' - }, - events: { - onLoad: function(Box) { - Box.getElm().addClass('quiqqer-erp-outputDialog-preview'); - } + PreviewContent.set('html', ''); + + new QUISandbox({ + content: previewHtml, + styles: { + height: '100%', + padding: 20, + width: '100%' + }, + events: { + onLoad: function(Box) { + Box.getElm().addClass('quiqqer-erp-outputDialog-preview'); } - }).inject(PreviewContent); - }).catch(function() { - self.Loader.hide(); - showPreviewError(); - }); - }, + } + }).inject(PreviewContent); + }).catch(function() { + self.Loader.hide(); + showPreviewError(); + }); + }, + + /** + * event: on submit + */ + $onSubmit: function() { + const self = this; + let Run = Promise.resolve(); + + this.Loader.show(); + + const action = this.$Output.getValue(); + + switch (action) { + case 'print': + Run = this.print(); + break; + + case 'pdf': + Run = this.saveAsPdf(); + break; + + case 'email': + Run = this.$sendMail(); + break; + } - /** - * event: on submit - */ - $onSubmit: function() { - const self = this; - let Run = Promise.resolve(); + Run.then(function() { + const Form = self.getContent().getElement('form'); - this.Loader.show(); + self.fireEvent('output', [ + QUIFormUtils.getFormData(Form), + self + ]); - const action = this.$Output.getValue(); + const Submit = self.getButton('submit'); switch (action) { case 'print': - Run = this.print(); + self.$addMessage(QUILocale.get(lg, 'controls.OutputDialog.msg.output_print')); break; case 'pdf': - Run = this.saveAsPdf(); + self.$addMessage(QUILocale.get(lg, 'controls.OutputDialog.msg.output_pdf')); break; case 'email': - Run = this.$sendMail(); + self.$mailSent = true; + Submit.disable(); + + self.$addMessage(QUILocale.get(lg, 'controls.OutputDialog.msg.mail_sent', { + recipient: Form.elements.recipient.value + })); break; } - Run.then(function() { - const Form = self.getContent().getElement('form'); - - self.fireEvent('output', [ - QUIFormUtils.getFormData(Form), - self - ]); - - const Submit = self.getButton('submit'); - - switch (action) { - case 'print': - self.$addMessage(QUILocale.get(lg, 'controls.OutputDialog.msg.output_print')); - break; - - case 'pdf': - self.$addMessage(QUILocale.get(lg, 'controls.OutputDialog.msg.output_pdf')); - break; - - case 'email': - self.$mailSent = true; - Submit.disable(); - - self.$addMessage(QUILocale.get(lg, 'controls.OutputDialog.msg.mail_sent', { - recipient: Form.elements.recipient.value - })); - break; + self.$resizeCommentsBox(); + self.Loader.hide(); + }, function() { + self.Loader.hide(); + }); + }, + + /** + * Add message to log + * + * @param {String} msg + */ + $addMessage: function(msg) { + const Now = new Date(); + + new Element('div', { + 'class': 'quiqqer-erp-outputDialog-messages-entry box message-success', + html: '<b>' + Now.format('%H:%M:%S') + '</b> ' + msg + }).inject(this.$MessagesBox, 'top'); + }, + + /** + * Print the document + * + * @return {Promise} + */ + print: function() { + const self = this, + entityId = this.getAttribute('entityId'); + + return new Promise(function(resolve) { + const id = 'print-document-' + entityId; + + self.Loader.show(); + + new Element('iframe', { + src: URL_OPT_DIR + 'quiqqer/erp/bin/output/backend/print.php?' + Object.toQueryString({ + id: entityId, + t: self.getAttribute('entityType'), + ep: self.getAttribute('entityPlugin'), + oid: self.getId(), + tpl: self.$Template.id, + tplpr: self.$Template.provider + }), + id: id, + styles: { + position: 'absolute', + top: -200, + left: -200, + width: 50, + height: 50 } + }).inject(document.body); - self.$resizeCommentsBox(); - self.Loader.hide(); - }, function() { - self.Loader.hide(); - }); - }, - - /** - * Add message to log - * - * @param {String} msg - */ - $addMessage: function(msg) { - const Now = new Date(); - - new Element('div', { - 'class': 'quiqqer-erp-outputDialog-messages-entry box message-success', - html: '<b>' + Now.format('%H:%M:%S') + '</b> ' + msg - }).inject(this.$MessagesBox, 'top'); - }, - - /** - * Print the document - * - * @return {Promise} - */ - print: function() { - const self = this, - entityId = this.getAttribute('entityId'); - - return new Promise(function(resolve) { - const id = 'print-document-' + entityId; - - self.Loader.show(); - - new Element('iframe', { - src: URL_OPT_DIR + 'quiqqer/erp/bin/output/backend/print.php?' + Object.toQueryString({ - id: entityId, - t: self.getAttribute('entityType'), - ep: self.getAttribute('entityPlugin'), - oid: self.getId(), - tpl: self.$Template.id, - tplpr: self.$Template.provider - }), - id: id, - styles: { - position: 'absolute', - top: -200, - left: -200, - width: 50, - height: 50 - } - }).inject(document.body); - - self.addEvent('onPrintFinish', function(self, pId) { - if (pId === entityId) { - resolve(); - } - }); - }); - }, - - /** - * event: on print finish - * - * @param {String|Number} id - */ - $onPrintFinish: function(id) { - this.fireEvent('printFinish', [ - this, - id - ]); - - (function() { - document.getElements('#print-document-' + id).destroy(); - this.Loader.hide(); - }).delay(1000, this); - }, - - /** - * Export the document as PDF - * - * @return {Promise} - */ - saveAsPdf: function() { - const self = this, - entityId = this.getAttribute('entityId'); - - return new Promise(function(resolve) { - const id = 'download-document-' + entityId, - Content = self.getContent(), - Form = Content.getElement('form'); - - new Element('iframe', { - src: URL_OPT_DIR + 'quiqqer/erp/bin/output/backend/download.php?' + Object.toQueryString({ - id: entityId, - t: self.getAttribute('entityType'), - ep: self.getAttribute('entityPlugin'), - oid: self.getId(), - tpl: self.$Template.id, - tplpr: self.$Template.provider - }), - id: id, - styles: { - position: 'absolute', - top: -200, - left: -200, - width: 50, - height: 50 - } - }).inject(document.body); - - (function() { + self.addEvent('onPrintFinish', function(self, pId) { + if (pId === entityId) { resolve(); - }).delay(2000, this); - - (function() { - document.getElements('#' + id).destroy(); - }).delay(20000, this); + } }); - }, - - showAsPDF: function() { - this.Loader.show(); - - const PreviewContent = this.getContent().getElement('.quiqqer-erp-outputDialog-preview'); - const entityId = this.getAttribute('entityId'); - - PreviewContent.set('html', ''); - - return new Promise((resolve) => { - const id = 'download-document-' + entityId; - - new Element('iframe', { - src: URL_OPT_DIR + 'quiqqer/erp/bin/output/backend/download.php?' + Object.toQueryString({ - id: entityId, - t: this.getAttribute('entityType'), - ep: this.getAttribute('entityPlugin'), - oid: this.getId(), - tpl: this.$Template.id, - tplpr: this.$Template.provider, - show: 1 - }), - id: id, - styles: { - height: 'calc(100% - 5px)', - width: '100%', - border: 'none', - padding: 0 - } - }).inject(PreviewContent); - - (function() { - resolve(); - }).delay(2000, this); + }); + }, + + /** + * event: on print finish + * + * @param {String|Number} id + */ + $onPrintFinish: function(id) { + this.fireEvent('printFinish', [ + this, + id + ]); + + (function() { + document.getElements('#print-document-' + id).destroy(); + this.Loader.hide(); + }).delay(1000, this); + }, + + /** + * Export the document as PDF + * + * @return {Promise} + */ + saveAsPdf: function() { + const self = this, + entityId = this.getAttribute('entityId'); + + return new Promise(function(resolve) { + const id = 'download-document-' + entityId, + Content = self.getContent(), + Form = Content.getElement('form'); + + new Element('iframe', { + src: URL_OPT_DIR + 'quiqqer/erp/bin/output/backend/download.php?' + Object.toQueryString({ + id: entityId, + t: self.getAttribute('entityType'), + ep: self.getAttribute('entityPlugin'), + oid: self.getId(), + tpl: self.$Template.id, + tplpr: self.$Template.provider + }), + id: id, + styles: { + position: 'absolute', + top: -200, + left: -200, + width: 50, + height: 50 + } + }).inject(document.body); - this.Loader.hide(); - }); - }, + (function() { + resolve(); + }).delay(2000, this); - /** - * event : on output change - */ - $onOutputChange: function() { - if (CURRENT_VIEW === this.$Output.getValue()) { - return; - } + (function() { + document.getElements('#' + id).destroy(); + }).delay(20000, this); + }); + }, + + showAsPDF: function() { + this.Loader.show(); + + const PreviewContent = this.getContent().getElement('.quiqqer-erp-outputDialog-preview'); + const entityId = this.getAttribute('entityId'); + const pdfUrl = URL_OPT_DIR + 'quiqqer/erp/bin/output/backend/download.php?' + Object.toQueryString({ + id: entityId, + t: this.getAttribute('entityType'), + ep: this.getAttribute('entityPlugin'), + oid: this.getId(), + tpl: this.$Template.id, + tplpr: this.$Template.provider, + show: 1 + }); + + PreviewContent.set('html', ''); + + return new Promise((resolve, reject) => { + (async () => { + try { + const module = await import(URL_OPT_DIR + 'bin/quiqqer-asset/pdfjs-dist/pdfjs-dist/build/pdf.mjs'); + console.log(module); + + PreviewContent.set('html', '<canvas id="pdf-canvas"></canvas>'); + module.GlobalWorkerOptions.workerSrc = URL_OPT_DIR + 'bin/quiqqer-asset/pdfjs-dist/pdfjs-dist/build/pdf.worker.min.mjs'; + + module.getDocument(pdfUrl).promise.then((pdf) => { + pdf.getPage(1).then(page => { + const scale = 1.5; + const viewport = page.getViewport({scale}); + const canvas = document.getElementById('pdf-canvas'); + const context = canvas.getContext('2d'); + canvas.height = viewport.height; + canvas.width = viewport.width; + + page.render({ + canvasContext: context, + viewport: viewport + }); + + this.Loader.hide(); + resolve(); + }); + }); + + } catch (error) { + console.error('Fehler beim Laden des Moduls:', error); + this.Loader.hide(); + reject(); + } + })(); + }); + }, + + /** + * event : on output change + */ + $onOutputChange: function() { + if (CURRENT_VIEW === this.$Output.getValue()) { + return; + } - const Recipient = this.getElm().getElement('[name="recipient"]'); - Recipient.getParent('tr').setStyle('display', 'none'); + const Recipient = this.getElm().getElement('[name="recipient"]'); + Recipient.getParent('tr').setStyle('display', 'none'); - /* - if (this.$PDFView && this.$PDFView.getStatus() === 1) { - if (this.$Output.getValue() === 'pdf') { - this.$PDFView.setSilentOff(); - } else { - this.$PDFView.off(); - } + /* + if (this.$PDFView && this.$PDFView.getStatus() === 1) { + if (this.$Output.getValue() === 'pdf') { + this.$PDFView.setSilentOff(); } else { - (() => { - this.$PDFView.setSilentOff(); - }).delay(100); + this.$PDFView.off(); } - */ + } else { + (() => { + this.$PDFView.setSilentOff(); + }).delay(100); + } + */ - switch (this.$Output.getValue()) { - case 'print': - this.$onChangeToPrint(); - break; + switch (this.$Output.getValue()) { + case 'print': + this.$onChangeToPrint(); + break; - case 'pdf': - this.$onChangeToPDF(); - break; + case 'pdf': + this.$onChangeToPDF(); + break; - case 'email': - this.$onChangeToEmail(); - break; - } + case 'email': + this.$onChangeToEmail(); + break; + } - this.$resizeCommentsBox(); - this.getButton('submit').enable(); - CURRENT_VIEW = this.$Output.getValue(); - }, - - /** - * event: on output change -> to print - */ - $onChangeToPrint: function() { - const Submit = this.getButton('submit'); - - Submit.setAttribute('text', QUILocale.get(lg, 'controls.OutputDialog.data.output.print.btn')); - Submit.setAttribute('textimage', 'fa fa-print'); - }, - - /** - * event: on output change -> to pdf - */ - $onChangeToPDF: function() { - const Submit = this.getButton('submit'); - - Submit.setAttribute('text', QUILocale.get(lg, 'controls.OutputDialog.data.output.pdf.btn')); - Submit.setAttribute('textimage', 'fa fa-file-pdf-o'); - }, - - /** - * event: on output change -> to Email - */ - $onChangeToEmail: function() { - const Submit = this.getButton('submit'); - const Recipient = this.getElm().getElement('[name="recipient"]'); - - Recipient.getParent('tr').setStyle('display', null); - - Submit.setAttribute('text', QUILocale.get(lg, 'controls.OutputDialog.data.output.email.btn')); - Submit.setAttribute('textimage', 'fa fa-envelope-o'); - - if (this.$customerMail && Recipient.value === '') { - Recipient.value = this.$customerMail; - } + this.$resizeCommentsBox(); + this.getButton('submit').enable(); + CURRENT_VIEW = this.$Output.getValue(); + }, + + /** + * event: on output change -> to print + */ + $onChangeToPrint: function() { + const Submit = this.getButton('submit'); + + Submit.setAttribute('text', QUILocale.get(lg, 'controls.OutputDialog.data.output.print.btn')); + Submit.setAttribute('textimage', 'fa fa-print'); + }, + + /** + * event: on output change -> to pdf + */ + $onChangeToPDF: function() { + const Submit = this.getButton('submit'); + + Submit.setAttribute('text', QUILocale.get(lg, 'controls.OutputDialog.data.output.pdf.btn')); + Submit.setAttribute('textimage', 'fa fa-file-pdf-o'); + }, + + /** + * event: on output change -> to Email + */ + $onChangeToEmail: function() { + const Submit = this.getButton('submit'); + const Recipient = this.getElm().getElement('[name="recipient"]'); + + Recipient.getParent('tr').setStyle('display', null); + + Submit.setAttribute('text', QUILocale.get(lg, 'controls.OutputDialog.data.output.email.btn')); + Submit.setAttribute('textimage', 'fa fa-envelope-o'); + + if (this.$customerMail && Recipient.value === '') { + Recipient.value = this.$customerMail; + } - Recipient.removeEvent('keyup', this.$onChangeMailRecipient); - Recipient.addEvent('keyup', this.$onChangeMailRecipient); + Recipient.removeEvent('keyup', this.$onChangeMailRecipient); + Recipient.addEvent('keyup', this.$onChangeMailRecipient); - Recipient.focus(); + Recipient.focus(); - if (this.$mailSent) { - Submit.disable(); - } - }, - - /** - * If e-mail recipient changes - */ - $onChangeMailRecipient: function() { - this.getButton('submit').enable(); - this.$mailSent = false; - }, - - /** - * Get data of the entity that is outputted - * - * @return {Promise} - */ - $getEntityData: function() { - const self = this; - - return new Promise(function(resolve, reject) { - QUIAjax.get('package_quiqqer_erp_ajax_output_getEntityData', resolve, { - 'package': 'quiqqer/erp', - entityId: self.getAttribute('entityId'), - entityType: self.getAttribute('entityType'), - entityPlugin: self.getAttribute('entityPlugin'), - onError: reject - }); - }); - }, - - /** - * Fetch available templates based on entity type - * - * @return {Promise} - */ - $getTemplates: function() { - const self = this; - - return new Promise(function(resolve, reject) { - QUIAjax.get('package_quiqqer_erp_ajax_output_getTemplates', resolve, { - 'package': 'quiqqer/erp', - entityType: self.getAttribute('entityType'), - entityPlugin: self.getAttribute('entityPlugin'), - onError: reject - }); + if (this.$mailSent) { + Submit.disable(); + } + }, + + /** + * If e-mail recipient changes + */ + $onChangeMailRecipient: function() { + this.getButton('submit').enable(); + this.$mailSent = false; + }, + + /** + * Get data of the entity that is outputted + * + * @return {Promise} + */ + $getEntityData: function() { + const self = this; + + return new Promise(function(resolve, reject) { + QUIAjax.get('package_quiqqer_erp_ajax_output_getEntityData', resolve, { + 'package': 'quiqqer/erp', + entityId: self.getAttribute('entityId'), + entityType: self.getAttribute('entityType'), + entityPlugin: self.getAttribute('entityPlugin'), + onError: reject }); - }, - - /** - * Fetch available templates based on entity type - * - * @return {Promise} - */ - $getPreview: function() { - const self = this; - - return new Promise(function(resolve, reject) { - QUIAjax.get('package_quiqqer_erp_ajax_output_getPreview', resolve, { - 'package': 'quiqqer/erp', - entity: JSON.encode({ - id: self.getAttribute('entityId'), - type: self.getAttribute('entityType'), - plugin: self.getAttribute('entityPlugin') - }), - template: JSON.encode(self.$Template), - onError: reject - }); + }); + }, + + /** + * Fetch available templates based on entity type + * + * @return {Promise} + */ + $getTemplates: function() { + const self = this; + + return new Promise(function(resolve, reject) { + QUIAjax.get('package_quiqqer_erp_ajax_output_getTemplates', resolve, { + 'package': 'quiqqer/erp', + entityType: self.getAttribute('entityType'), + entityPlugin: self.getAttribute('entityPlugin'), + onError: reject }); - }, - - /** - * Get data of the entity that is outputted - * - * @return {Promise} - */ - $sendMail: function() { - const self = this, - Form = this.getContent().getElement('form'); - - return new Promise(function(resolve, reject) { - QUIAjax.post('package_quiqqer_erp_ajax_output_sendMail', resolve, { - 'package': 'quiqqer/erp', - entityId: self.getAttribute('entityId'), - entityType: self.getAttribute('entityType'), - entityPlugin: self.getAttribute('entityPlugin'), - template: self.$Template.id, - templateProvider: self.$Template.provider, - mailSubject: self.$Mail.subject, - mailContent: self.$Mail.content, - mailAttachmentMediaFileIds: JSON.encode(self.$Mail.attachedMediaFileIds), - mailRecipient: Form.elements.recipient.value, - onError: reject - }); + }); + }, + + /** + * Fetch available templates based on entity type + * + * @return {Promise} + */ + $getPreview: function() { + const self = this; + + return new Promise(function(resolve, reject) { + QUIAjax.get('package_quiqqer_erp_ajax_output_getPreview', resolve, { + 'package': 'quiqqer/erp', + entity: JSON.encode({ + id: self.getAttribute('entityId'), + type: self.getAttribute('entityType'), + plugin: self.getAttribute('entityPlugin') + }), + template: JSON.encode(self.$Template), + onError: reject }); - }, - - /** - * Resize the erp entity comments container - */ - $resizeCommentsBox: function() { - if (!this.$Form || !this.$CommentsBox || !this.$MessagesBox) { - return; - } - - const maxHeight = 685 - (710 - this.getContent().getSize().y); - const height = this.$Form.getSize().y + this.$MessagesBox.getSize().y; - - this.$CommentsBox.setStyle('height', (maxHeight - height)); - }, - - checkPdfSupport: function() { - return new Promise((resolve) => { - if (PDF_SUPPORT !== null) { - resolve(PDF_SUPPORT); - return; - } - - const PDFFrame = new Element('iframe', { - src: URL_OPT_DIR + 'quiqqer/erp/bin/output/backend/test.pdf', - styles: { - position: 'absolute', - top: -200, - left: -200, - width: 50, - height: 50 - } - }).inject(document.body); - - PDFFrame.onload = function() { - try { - const pdfDoc = PDFFrame.contentDocument || PDFFrame.contentWindow.document; - - if (pdfDoc && pdfDoc.body && pdfDoc.body.innerHTML.includes('PDF') === false) { - PDF_SUPPORT = true; - } else { - // PDF kann nicht angezeigt werden, Fallback anzeigen - // pdfFrame.style.display = 'none'; - // document.getElementById('pdfFallback').style.display = 'block'; - PDF_SUPPORT = false; - } - } catch (error) { - // Möglicher Cross-Origin-Fehler oder PDF nicht unterstützt - // pdfFrame.style.display = 'none'; - // document.getElementById('pdfFallback').style.display = 'block'; - PDF_SUPPORT = false; - } - - resolve(PDF_SUPPORT); - }; - - PDFFrame.onerror = function() { - // Fehler beim Laden des PDFs im iframe - // pdfFrame.style.display = 'none'; - // document.getElementById('pdfFallback').style.display = 'block'; - PDF_SUPPORT = false; - resolve(PDF_SUPPORT); - }; + }); + }, + + /** + * Get data of the entity that is outputted + * + * @return {Promise} + */ + $sendMail: function() { + const self = this, + Form = this.getContent().getElement('form'); + + return new Promise(function(resolve, reject) { + QUIAjax.post('package_quiqqer_erp_ajax_output_sendMail', resolve, { + 'package': 'quiqqer/erp', + entityId: self.getAttribute('entityId'), + entityType: self.getAttribute('entityType'), + entityPlugin: self.getAttribute('entityPlugin'), + template: self.$Template.id, + templateProvider: self.$Template.provider, + mailSubject: self.$Mail.subject, + mailContent: self.$Mail.content, + mailAttachmentMediaFileIds: JSON.encode(self.$Mail.attachedMediaFileIds), + mailRecipient: Form.elements.recipient.value, + onError: reject }); + }); + }, + + /** + * Resize the erp entity comments container + */ + $resizeCommentsBox: function() { + if (!this.$Form || !this.$CommentsBox || !this.$MessagesBox) { + return; } - }); - } -); + + const maxHeight = 685 - (710 - this.getContent().getSize().y); + const height = this.$Form.getSize().y + this.$MessagesBox.getSize().y; + + this.$CommentsBox.setStyle('height', (maxHeight - height)); + }, + + checkPdfSupport: function() { + // da pdf.js integriert ist, ist unterstützung immer vorhanden + return new Promise((resolve) => { + PDF_SUPPORT = true; + resolve(true); + }); + } + }); +}); diff --git a/composer.json b/composer.json index b46b73d20f7afe9fe99cf575a59c16ec05a30d51..dd54d38de0fc251c49c5c6a7fedbf79984391ac9 100644 --- a/composer.json +++ b/composer.json @@ -29,7 +29,8 @@ "quiqqer/countries": "^2", "quiqqer/frontend-users": "^2", "quiqqer/erp-accounting-templates": "^2", - "quiqqer/areas": "^2" + "quiqqer/areas": "^2", + "quiqqer-asset/pdfjs-dist": "^4.8" }, "suggest": { "quiqqer/watcher": "QUIQQER Watcher module (kind of logger)"