Chromium Code Reviews| Index: chrome/browser/resources/print_preview/native_layer.js |
| diff --git a/chrome/browser/resources/print_preview/native_layer.js b/chrome/browser/resources/print_preview/native_layer.js |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..32d9c0bd73be98dba616ff298816c4191c44bab8 |
| --- /dev/null |
| +++ b/chrome/browser/resources/print_preview/native_layer.js |
| @@ -0,0 +1,714 @@ |
| +// Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +cr.define('print_preview', function() { |
| + 'use strict'; |
| + |
| + /** |
| + * An interface to the native Chromium printing system layer. |
| + * @constructor |
| + * @extends {cr.EventTarget} |
| + */ |
| + function NativeLayer() { |
| + cr.EventTarget.call(this); |
| + |
| + // Bind global handlers |
| + global['setInitialSettings'] = this.onSetInitialSettings_.bind(this); |
| + global['setUseCloudPrint'] = this.onSetUseCloudPrint_.bind(this); |
| + global['setPrinters'] = this.onSetPrinters_.bind(this); |
| + global['updateWithPrinterCapabilities'] = |
| + this.onUpdateWithPrinterCapabilities_.bind(this); |
| + global['reloadPrintersList'] = this.onReloadPrintersList_.bind(this); |
| + global['printToCloud'] = this.onPrintToCloud_.bind(this); |
| + global['fileSelectionCancelled'] = |
| + this.onFileSelectionCancelled_.bind(this); |
| + global['fileSelectionCompleted'] = |
| + this.onFileSelectionCompleted_.bind(this); |
| + global['printPreviewFailed'] = this.onPrintPreviewFailed_.bind(this); |
| + global['invalidPrinterSettings'] = |
| + this.onInvalidPrinterSettings_.bind(this); |
| + global['onDidGetDefaultPageLayout'] = |
| + this.onDidGetDefaultPageLayout_.bind(this); |
| + global['onDidGetPreviewPageCount'] = |
| + this.onDidGetPreviewPageCount_.bind(this); |
| + global['reloadPreviewPages'] = this.onReloadPreviewPages_.bind(this); |
| + global['onDidPreviewPage'] = this.onDidPreviewPage_.bind(this); |
| + global['updatePrintPreview'] = this.onUpdatePrintPreview_.bind(this); |
| + }; |
| + |
| + /** |
| + * Event types dispatched from the Chromium native layer. |
| + * @enum {string} |
| + * @const |
| + */ |
| + NativeLayer.EventType = { |
| + CAPABILITIES_SET: 'print_preview.NativeLayer.CAPABILITIES_SET', |
| + CLOUD_PRINT_ENABLE: 'print_preview.NativeLayer.CLOUD_PRINT_ENABLE', |
| + DESTINATIONS_RELOAD: 'print_preview.NativeLayer.DESTINATIONS_RELOAD', |
| + FILE_SELECTION_CANCEL: 'print_preview.NativeLayer.FILE_SELECTION_CANCEL', |
| + FILE_SELECTION_COMPLETE: |
| + 'print_preview.NativeLayer.FILE_SELECTION_COMPLETE', |
| + INITIAL_SETTINGS_SET: 'print_preview.NativeLayer.INITIAL_SETTINGS_SET', |
| + LOCAL_DESTINATIONS_SET: 'print_preview.NativeLayer.LOCAL_DESTINATIONS_SET', |
| + PAGE_COUNT_READY: 'print_preview.NativeLayer.PAGE_COUNT_READY', |
| + PAGE_LAYOUT_READY: 'print_preview.NativeLayer.PAGE_LAYOUT_READY', |
| + PAGE_PREVIEW_READY: 'print_preview.NativeLayer.PAGE_PREVIEW_READY', |
| + PREVIEW_GENERATION_DONE: |
| + 'print_preview.NativeLayer.PREVIEW_GENERATION_DONE', |
| + PREVIEW_GENERATION_FAIL: |
| + 'print_preview.NativeLayer.PREVIEW_GENERATION_FAIL', |
| + PREVIEW_RELOAD: 'print_preview.NativeLayer.PREVIEW_RELOAD', |
| + PRINT_TO_CLOUD: 'print_preview.NativeLayer.PRINT_TO_CLOUD', |
| + SETTINGS_INVALID: 'print_preview.NativeLayer.SETTINGS_INVALID' |
| + }; |
| + |
| + /** |
| + * Constant values matching printing::DuplexMode enum. |
| + * @enum {number} |
| + */ |
| + NativeLayer.DuplexMode = { |
| + SIMPLEX: 0, |
| + LONG_EDGE: 1, |
| + UNKNOWN_DUPLEX_MODE: -1 |
| + }; |
| + |
| + /** |
| + * Enumeration of color modes used by Chromium. |
| + * @enum {number} |
| + * @private |
| + */ |
| + NativeLayer.ColorMode_ = { |
| + GRAY: 1, |
| + COLOR: 2 |
| + }; |
| + |
| + NativeLayer.prototype = { |
| + __proto__: cr.EventTarget.prototype, |
| + |
| + /** Gets the initial settings to initialize the print preview with. */ |
| + startGetInitialSettings: function() { |
| + chrome.send('getInitialSettings'); |
| + }, |
| + |
| + /** |
| + * Requests the system's local print destinations. A LOCAL_DESTINATIONS_SET |
| + * event will be dispatched in response. |
| + */ |
| + startGetLocalDestinations: function() { |
| + chrome.send('getPrinters'); |
| + }, |
| + |
| + /** |
| + * Requests the destination's printing capabilities. A CAPABILITIES_SET |
| + * event will be dispatched in response. |
| + * @param {string} destinationId ID of the destination. |
| + */ |
| + startGetLocalDestinationCapabilities: function(destinationId) { |
| + chrome.send('getPrinterCapabilities', [destinationId]); |
| + }, |
| + |
| + /** |
| + * Requests that a preview be generated. The following events may be |
| + * dispatched in response: |
| + * - PAGE_COUNT_READY |
| + * - PAGE_LAYOUT_READY |
| + * - PAGE_PREVIEW_READY |
| + * - PREVIEW_GENERATION_DONE |
| + * - PREVIEW_GENERATION_FAIL |
| + * - PREVIEW_RELOAD |
| + * @param {print_preview.Destination} destination Destination to print to. |
| + * @param {!print_preview.PrintTicketStore} printTicketStore Used to get the |
| + * state of the print ticket. |
| + * @param {number} ID of the preview request. |
| + */ |
| + startGetPreview: function(destination, printTicketStore, requestId) { |
| + if (!printTicketStore.isTicketValid()) { |
| + throw Error('Trying to generate preview when ticket is not valid'); |
| + } |
| + |
| + var pageRanges = []; |
| + if (requestId > 0 && |
| + !printTicketStore.isDocumentModifiable && |
| + printTicketStore.hasPageRangeCapability()) { |
| + pageRanges = printTicketStore.getPageNumberSet().getPageRanges(); |
| + } |
| + |
| + var ticket = { |
| + 'pageRange': pageRanges, // pageRanges, |
| + 'landscape': printTicketStore.isLandscapeEnabled(), |
| + 'color': printTicketStore.isColorEnabled() ? |
| + NativeLayer.ColorMode_.COLOR : NativeLayer.ColorMode_.GRAY, |
| + 'headerFooterEnabled': printTicketStore.isHeaderFooterEnabled(), |
| + 'marginsType': printTicketStore.getMarginsType(), |
| + 'isFirstRequest': requestId == 0, |
| + 'requestID': requestId, |
| + 'previewModifiable': printTicketStore.isDocumentModifiable, |
| + 'printToPDF': destination != null && destination.isPrintToPdf, |
| + 'printWithCloudPrint': destination != null && !destination.isLocal, |
| + 'deviceName': destination == null ? 'foo' : destination.id, |
| + 'cloudPrintID': destination == null ? 'foo' : destination.id, |
| + 'generateDraftData': printTicketStore.isDocumentModifiable, |
| + |
| + // NOTE: Even though the following fields don't directly relate to the |
| + // preview, they still need to be included. |
| + 'duplex': printTicketStore.isDuplexEnabled() ? |
| + NativeLayer.DuplexMode.LONG_EDGE : NativeLayer.DuplexMode.SIMPLEX, |
| + 'copies': printTicketStore.getCopies(), |
| + 'collate': printTicketStore.isCollateEnabled() |
| + }; |
| + |
| + if (printTicketStore.hasMarginsCapability() && |
| + printTicketStore.getMarginsType() == |
| + print_preview.ticket_items.MarginsType.Value.CUSTOM) { |
| + var customMarginsInPts = printTicketStore.getCustomMarginsInPts(); |
| + var orientationEnum = |
| + print_preview.ticket_items.CustomMargins.Orientation; |
| + ticket['marginsCustom'] = { |
| + 'marginTop': customMarginsInPts.get(orientationEnum.TOP), |
| + 'marginRight': customMarginsInPts.get(orientationEnum.RIGHT), |
| + 'marginBottom': customMarginsInPts.get(orientationEnum.BOTTOM), |
| + 'marginLeft': customMarginsInPts.get(orientationEnum.LEFT) |
| + }; |
| + } |
| + |
| + chrome.send( |
| + 'getPreview', |
| + [JSON.stringify(ticket), -1, printTicketStore.isDocumentModifiable]); |
| + }, |
| + |
| + /** |
| + * Persists the selected destination and print ticket for the next print |
| + * session. |
| + * @param {!print_preview.Destination} destination Destination to save. |
| + * @param {!print_preview.PrintTicketStore} printTicketStore Used for |
| + * generating the serialized print ticket to persist. |
| + */ |
| + startSaveDestinationAndTicket: function(destination, printTicketStore) { |
| + chrome.send('saveLastPrinter', [destination.id, '' /*TODO*/); |
|
dpapad
2012/05/10 02:15:03
Closing bracket missing, causing uncaught js error
Robert Toscano
2012/05/10 03:37:41
Done.
dpapad
2012/05/10 15:49:27
Does not seem fixed. Is the latest patch uploaded
|
| + }, |
| + |
| + /** |
| + * Requests that the document be printed. |
| + * @param {!print_preview.Destination} destination Destination to print to. |
| + * @param {!print_preview.PrintTicketStore} printTicketStore Used to get the |
| + * state of the print ticket. |
| + * @param {print_preview.CloudPrintInterface} cloudPrintInterface Interface |
| + * to Google Cloud Print. |
| + */ |
| + startPrint: function(destination, printTicketStore, cloudPrintInterface) { |
| + if (!printTicketStore.isTicketValid()) { |
| + throw Error( |
| + 'Requesting ticket for preview generator when ticket is not valid'); |
| + } |
| + |
| + var ticket = { |
| + 'pageRange': printTicketStore.hasPageRangeCapability() ? |
| + printTicketStore.getPageNumberSet().getPageRanges() : [], |
| + 'landscape': printTicketStore.isLandscapeEnabled(), |
| + 'color': printTicketStore.isColorEnabled() ? |
| + NativeLayer.ColorMode_.COLOR : NativeLayer.ColorMode_.GRAY, |
| + 'headerFooterEnabled': printTicketStore.isHeaderFooterEnabled(), |
| + 'marginsType': printTicketStore.getMarginsType(), |
| + 'generateDraftData': true, // TODO What should this value be? |
| + 'duplex': printTicketStore.isDuplexEnabled() ? |
| + NativeLayer.DuplexMode.LONG_EDGE : NativeLayer.DuplexMode.SIMPLEX, |
| + 'copies': printTicketStore.getCopies(), |
| + 'collate': printTicketStore.isCollateEnabled(), |
| + 'previewModifiable': printTicketStore.isDocumentModifiable, |
| + 'printToPDF': destination.isPrintToPdf, |
| + 'printWithCloudPrint': !destination.isLocal, |
| + 'deviceName': destination.id, |
| + 'isFirstRequest': false, |
| + 'requestID': -1 |
| + }; |
| + |
| + if (!destination.isLocal && !destination.isPrintWithCloudPrint) { |
| + // We can't set cloudPrintID if the destination is "Print with Cloud |
| + // Print" because the native system will try to print to Google Cloud |
| + // Print with this ID instead of opening a Google Cloud Print dialog. |
| + ticket['cloudPrintID'] = destination.id; |
| + } |
| + |
| + if (printTicketStore.hasMarginsCapability() && |
| + printTicketStore.getMarginsType() == |
| + print_preview.ticket_items.MarginsType.Value.CUSTOM) { |
| + var customMarginsInPts = printTicketStore.getCustomMargins(); |
| + var orientationEnum = |
| + print_preview.ticket_items.CustomMargins.Orientation; |
| + ticket['marginsCustom'] = { |
| + 'marginTop': customMarginsInPts.get(orientationEnum.TOP), |
| + 'marginRight': customMarginsInPts.get(orientationEnum.RIGHT), |
| + 'marginBottom': customMarginsInPts.get(orientationEnum.BOTTOM), |
| + 'marginLeft': customMarginsInPts.get(orientationEnum.LEFT) |
| + }; |
| + } |
| + |
| + var cloudTicket = null; |
| + if (!destination.isLocal) { |
| + if (!cloudPrintInterface) { |
| + throw Error( |
| + 'Trying to print to a cloud destination but Google Cloud Print ' + |
| + 'integration is disabled'); |
| + } |
| + cloudTicket = cloudPrintInterface.createPrintTicket( |
| + destination, printTicketStore); |
| + cloudTicket = JSON.stringify(cloudTicket); |
| + } |
| + |
| + chrome.send('print', [JSON.stringify(ticket), cloudTicket]); |
| + }, |
| + |
| + /** Requests that the current pending print request be cancelled. */ |
| + startCancelPendingPrint: function() { |
| + chrome.send('cancelPendingPrintRequest'); |
| + }, |
| + |
| + /** Shows the system's native printing dialog. */ |
| + startShowSystemDialog: function() { |
| + chrome.send('showSystemDialog'); |
| + }, |
| + |
| + /** Closes the print preview dialog. */ |
| + startCloseDialog: function() { |
| + chrome.send('closePrintPreviewTab'); |
| + chrome.send('DialogClose'); |
| + }, |
| + |
| + /** Hide the print preview dialog and allow the native layer to close it. */ |
| + startHideDialog: function() { |
| + chrome.send('hidePreview'); |
| + }, |
| + |
| + /** |
| + * Opens the Google Cloud Print sign-in dialog. The DESTINATIONS_RELOAD |
| + * event will be dispatched in response. |
| + */ |
| + startCloudPrintSignIn: function() { |
| + chrome.send('signIn'); |
| + }, |
| + |
| + /** Navigates the user to the system printer settings interface. */ |
| + startManageLocalPrinters: function() { |
| + chrome.send('manageLocalPrinters'); |
| + }, |
| + |
| + /** Navigates the user to the Google Cloud Print management page. */ |
| + startManageCloudPrinters: function() { |
| + chrome.send('manageCloudPrinters'); |
| + }, |
| + |
| + /** |
| + * @param {object} initialSettings Object containing all initial settings. |
| + */ |
| + onSetInitialSettings_: function(initialSettings) { |
| + // Not using initialSettings['initiatorTabTitle'] since the print preview |
| + // no longer opens in a new tab. And because of this, |
| + // localStrings.getStringF('printPreviewTitleFormat', initiatorTabTitle) |
| + // is also not used. |
| + // TODO Remove those unused local strings. |
| + |
| + // TODO Use initialSettings['cloudPrintData'] to prepopulate destination |
| + // and initial print ticket. |
| + var numberFormatSymbols = |
| + print_preview.MeasurementSystem.parseNumberFormat( |
| + initialSettings['numberFormat']); |
| + var unitType = print_preview.MeasurementSystem.UnitType.IMPERIAL; |
| + if (initialSettings['measurementSystem'] != null) { |
| + unitType = initialSettings['measurementSystem']; |
| + } |
| + var measurementSystem = new print_preview.MeasurementSystem( |
| + numberFormatSymbols[0], |
| + numberFormatSymbols[1], |
| + unitType); |
| + |
| + var customMargins = null; |
| + if (initialSettings.hasOwnProperty('marginTop') && |
| + initialSettings.hasOwnProperty('marginRight') && |
| + initialSettings.hasOwnProperty('marginBottom') && |
| + initialSettings.hasOwnProperty('marginLeft')) { |
| + customMargins = new print_preview.Margins( |
| + initialSettings['marginTop'] || 0, |
| + initialSettings['marginRight'] || 0, |
| + initialSettings['marginBottom'] || 0, |
| + initialSettings['marginLeft'] || 0); |
| + } |
| + |
| + var marginsType = null; |
| + if (initialSettings.hasOwnProperty('marginsType')) { |
| + marginsType = initialSettings['marginsType']; |
| + } |
| + |
| + var nativeInitialSettings = new print_preview.NativeInitialSettings( |
| + initialSettings['printAutomaticallyInKioskMode'] || false, |
| + numberFormatSymbols[0] || ',', |
| + numberFormatSymbols[1] || '.', |
| + unitType, |
| + initialSettings['previewModifiable'] || false, |
| + marginsType, |
| + customMargins, |
| + initialSettings['duplex'] || false, |
| + initialSettings['headerFooterEnabled'] || false, |
| + initialSettings['printerName'] || null); |
| + |
| + var initialSettingsSetEvent = new cr.Event( |
| + print_preview.NativeLayer.EventType.INITIAL_SETTINGS_SET); |
| + initialSettingsSetEvent.initialSettings = nativeInitialSettings; |
| + this.dispatchEvent(initialSettingsSetEvent); |
| + }, |
| + |
| + /** |
| + * Turn on the integration of Cloud Print. |
| + * @param {string} cloudPrintURL The URL to use for cloud print servers. |
| + * @private |
| + */ |
| + onSetUseCloudPrint_: function(cloudPrintURL) { |
| + var cloudPrintEnableEvent = new cr.Event( |
| + print_preview.NativeLayer.EventType.CLOUD_PRINT_ENABLE); |
| + cloudPrintEnableEvent.baseCloudPrintUrl = cloudPrintURL; |
| + this.dispatchEvent(cloudPrintEnableEvent); |
| + }, |
| + |
| + /** |
| + * Updates the print preview with local printers. |
| + * Called from PrintPreviewHandler::SetupPrinterList(). |
| + * @param {Array} printers Array of printer info objects. |
| + * @private |
| + */ |
| + onSetPrinters_: function(printers) { |
| + var localDestsSetEvent = new cr.Event( |
| + print_preview.NativeLayer.EventType.LOCAL_DESTINATIONS_SET); |
| + localDestsSetEvent.destinationInfos = printers; |
| + this.dispatchEvent(localDestsSetEvent); |
| + }, |
| + |
| + /** |
| + * Called when native layer gets settings information for a requested local |
| + * destination. |
| + * @param {Object} settingsInfo printer setting information. |
| + * @private |
| + */ |
| + onUpdateWithPrinterCapabilities_: function(settingsInfo) { |
| + var capsSetEvent = new cr.Event( |
| + print_preview.NativeLayer.EventType.CAPABILITIES_SET); |
| + capsSetEvent.settingsInfo = settingsInfo; |
| + this.dispatchEvent(capsSetEvent); |
| + }, |
| + |
| + /** Reloads the printer list. */ |
| + onReloadPrintersList_: function() { |
| + cr.dispatchSimpleEvent( |
| + this, print_preview.NativeLayer.EventType.DESTINATIONS_RELOAD); |
| + }, |
| + |
| + /** |
| + * Called from the C++ layer. |
| + * Take the PDF data handed to us and submit it to the cloud, closing the |
| + * print preview tab once the upload is successful. |
| + * @param {string} data Data to send as the print job. |
| + * @private |
| + */ |
| + onPrintToCloud_: function(data) { |
| + var printToCloudEvent = new cr.Event( |
| + print_preview.NativeLayer.EventType.PRINT_TO_CLOUD); |
| + printToCloudEvent.data = data; |
| + this.dispatchEvent(printToCloudEvent); |
| + }, |
| + |
| + /** |
| + * Called from PrintPreviewUI::OnFileSelectionCancelled to notify the print |
| + * preview tab regarding the file selection cancel event. |
| + * @private |
| + */ |
| + onFileSelectionCancelled_: function() { |
| + cr.dispatchSimpleEvent( |
| + this, print_preview.NativeLayer.EventType.FILE_SELECTION_CANCEL); |
| + }, |
| + |
| + /** |
| + * Called from PrintPreviewUI::OnFileSelectionCompleted to notify the print |
| + * preview tab regarding the file selection completed event. |
| + * @private |
| + */ |
| + onFileSelectionCompleted_: function() { |
| + // If the file selection is completed and the tab is not already closed it |
| + // means that a pending print to pdf request exists. |
| + cr.dispatchSimpleEvent( |
| + this, print_preview.NativeLayer.EventType.FILE_SELECTION_COMPLETE); |
| + }, |
| + |
| + /** |
| + * Display an error message when print preview fails. |
| + * Called from PrintPreviewMessageHandler::OnPrintPreviewFailed(). |
| + * @private |
| + */ |
| + onPrintPreviewFailed_: function() { |
| + cr.dispatchSimpleEvent( |
| + this, print_preview.NativeLayer.EventType.PREVIEW_GENERATION_FAIL); |
| + }, |
| + |
| + /** |
| + * Display an error message when encountered invalid printer settings. |
| + * Called from PrintPreviewMessageHandler::OnInvalidPrinterSettings(). |
| + * @private |
| + */ |
| + onInvalidPrinterSettings_: function() { |
| + cr.dispatchSimpleEvent( |
| + this, print_preview.NativeLayer.EventType.SETTINGS_INVALID); |
| + }, |
| + |
| + /** |
| + * @param {{contentWidth: number, contentHeight: number, marginLeft: number, |
| + * marginRight: number, marginTop: number, marginBottom: number, |
| + * printableAreaX: number, printableAreaY: number, |
| + * printableAreaWidth: number, printableAreaHeight: number}} |
| + * pageLayout Specifies default page layout details in points. |
| + * @param {boolean} hasCustomPageSizeStyle Indicates whether the previewed |
| + * document has a custom page size style. |
| + * @private |
| + */ |
| + onDidGetDefaultPageLayout_: function(pageLayout, hasCustomPageSizeStyle) { |
| + var pageLayoutChangeEvent = new cr.Event( |
| + print_preview.NativeLayer.EventType.PAGE_LAYOUT_READY); |
| + pageLayoutChangeEvent.pageLayout = pageLayout; |
| + pageLayoutChangeEvent.hasCustomPageSizeStyle = hasCustomPageSizeStyle; |
| + this.dispatchEvent(pageLayoutChangeEvent); |
| + }, |
| + |
| + /** |
| + * Update the page count and check the page range. |
| + * Called from PrintPreviewUI::OnDidGetPreviewPageCount(). |
| + * @param {number} pageCount The number of pages. |
| + * @param {number} previewResponseId The preview request id that resulted in |
| + * this response. |
| + * @private |
| + */ |
| + onDidGetPreviewPageCount_: function(pageCount, previewResponseId) { |
| + var pageCountChangeEvent = new cr.Event( |
| + print_preview.NativeLayer.EventType.PAGE_COUNT_READY); |
| + pageCountChangeEvent.pageCount = pageCount; |
| + pageCountChangeEvent.previewResponseId = previewResponseId; |
| + this.dispatchEvent(pageCountChangeEvent); |
| + }, |
| + |
| + /** |
| + * Called when no pipelining previewed pages. |
| + * @param {string} previewUid Preview unique identifier. |
| + * @param {number} previewResponseId The preview request id that resulted in |
| + * this response. |
| + * @private |
| + */ |
| + onReloadPreviewPages_: function(previewUid, previewResponseId) { |
| + var previewReloadEvent = new cr.Event( |
| + print_preview.NativeLayer.EventType.PREVIEW_RELOAD); |
| + previewReloadEvent.previewUid = previewUid; |
| + previewReloadEvent.previewResponseId = previewResponseId; |
| + this.dispatchEvent(previewReloadEvent); |
| + }, |
| + |
| + /** |
| + * Notification that a print preview page has been rendered. |
| + * Check if the settings have changed and request a regeneration if needed. |
| + * Called from PrintPreviewUI::OnDidPreviewPage(). |
| + * @param {number} pageNumber The page number, 0-based. |
| + * @param {string} previewUid Preview unique identifier. |
| + * @param {number} previewResponseId The preview request id that resulted in |
| + * this response. |
| + * @private |
| + */ |
| + onDidPreviewPage_: function(pageNumber, previewUid, previewResponseId) { |
| + var pagePreviewGenEvent = new cr.Event( |
| + print_preview.NativeLayer.EventType.PAGE_PREVIEW_READY); |
| + pagePreviewGenEvent.pageIndex = pageNumber; |
| + pagePreviewGenEvent.previewUid = previewUid; |
| + pagePreviewGenEvent.previewResponseId = previewResponseId; |
| + this.dispatchEvent(pagePreviewGenEvent); |
| + }, |
| + |
| + /** |
| + * Update the print preview when new preview data is available. |
| + * Create the PDF plugin as needed. |
| + * Called from PrintPreviewUI::PreviewDataIsAvailable(). |
| + * @param {string} previewUid Preview unique identifier. |
| + * @param {number} previewResponseId The preview request id that resulted in |
| + * this response. |
| + * @private |
| + */ |
| + onUpdatePrintPreview_: function(previewUid, previewResponseId) { |
| + var previewGenDoneEvent = new cr.Event( |
| + print_preview.NativeLayer.EventType.PREVIEW_GENERATION_DONE); |
| + previewGenDoneEvent.previewUid = previewUid; |
| + previewGenDoneEvent.previewResponseId = previewResponseId; |
| + this.dispatchEvent(previewGenDoneEvent); |
| + } |
| + }; |
| + |
| + /** |
| + * Initial settings retrieved from the native layer. |
| + * @param {boolean} isInKioskAutoPrintMode Whether the print preview should be |
| + * in auto-print mode. |
| + * @param {string} thousandsDelimeter Character delimeter of thousands digits. |
| + * @param {string} decimalDelimeter Character delimeter of the decimal point. |
| + * @param {print_preview.MeasurementSystem.UnitType} unitType Unit type of |
| + * local machine's measurement system. |
| + * @param {boolean} isDocumentModifiable Whether the document to print is |
| + * modifiable. |
| + * @param {?print_preview.ticket_items.MarginsType.Value} marginsType Initial |
| + * margins type. |
| + * @param {print_preview.Margins} customMargins Initial custom margins. |
| + * @param {boolean} isDuplexEnabled Whether duplexing is initially enabled. |
| + * @param {boolean} isHeaderFooterEnabled Whether the header-footer is |
| + * initially enabled. |
| + * @param {?string} initialDestinationId ID of the destination to initially |
| + * select. |
| + * @constructor |
| + */ |
| + function NativeInitialSettings( |
| + isInKioskAutoPrintMode, |
| + thousandsDelimeter, |
| + decimalDelimeter, |
| + unitType, |
| + isDocumentModifiable, |
| + marginsType, |
| + customMargins, |
| + isDuplexEnabled, |
| + isHeaderFooterEnabled, |
| + initialDestinationId) { |
| + |
| + /** |
| + * Whether the print preview should be in auto-print mode. |
| + * @type {boolean} |
| + * @private |
| + */ |
| + this.isInKioskAutoPrintMode_ = isInKioskAutoPrintMode; |
| + |
| + /** |
| + * Character delimeter of thousands digits. |
| + * @type {string} |
| + * @private |
| + */ |
| + this.thousandsDelimeter_ = thousandsDelimeter; |
| + |
| + /** |
| + * Character delimeter of the decimal point. |
| + * @type {string} |
| + * @private |
| + */ |
| + this.decimalDelimeter_ = decimalDelimeter; |
| + |
| + /** |
| + * Unit type of local machine's measurement system. |
| + * @type {string} |
| + * @private |
| + */ |
| + this.unitType_ = unitType; |
| + |
| + /** |
| + * Whether the document to print is modifiable. |
| + * @type {boolean} |
| + * @private |
| + */ |
| + this.isDocumentModifiable_ = isDocumentModifiable; |
| + |
| + /** |
| + * Initial margins type. |
| + * @type {?print_preview.ticket_items.MarginsType.Value} |
| + * @private |
| + */ |
| + this.marginsType_ = marginsType; |
| + |
| + /** |
| + * Initial custom margins. |
| + * @type {print_preview.Margins} |
| + * @private |
| + */ |
| + this.customMargins_ = customMargins; |
| + |
| + /** |
| + * Whether duplexing is initially enabled. |
| + * @type {boolean} |
| + * @private |
| + */ |
| + this.isDuplexEnabled_ = isDuplexEnabled; |
| + |
| + /** |
| + * Whether the header-footer is initially enabled. |
| + * @type {boolean} |
| + * @private |
| + */ |
| + this.isHeaderFooterEnabled_ = isHeaderFooterEnabled; |
| + |
| + /** |
| + * ID of the initially selected destination. |
| + * @type {?string} |
| + * @private |
| + */ |
| + this.initialDestinationId_ = initialDestinationId; |
| + }; |
| + |
| + NativeInitialSettings.prototype = { |
| + /** |
| + * @return {boolean} Whether the print preview should be in auto-print mode. |
| + */ |
| + get isInKioskAutoPrintMode() { |
| + return this.isInKioskAutoPrintMode_; |
| + }, |
| + |
| + /** @return {string} Character delimeter of thousands digits. */ |
| + get thousandsDelimeter() { |
| + return this.thousandsDelimeter_; |
| + }, |
| + |
| + /** @return {string} Character delimeter of the decimal point. */ |
| + get decimalDelimeter() { |
| + return this.decimalDelimeter_; |
| + }, |
| + |
| + /** |
| + * @return {print_preview.MeasurementSystem.UnitType} Unit type of local |
| + * machine's measurement system. |
| + */ |
| + get unitType() { |
| + return this.unitType_; |
| + }, |
| + |
| + /** @return {boolean} Whether the document to print is modifiable. */ |
| + get isDocumentModifiable() { |
| + return this.isDocumentModifiable_; |
| + }, |
| + |
| + /** |
| + * @return {?print_preview.ticket_items.MarginsType.Value} Initial margins |
| + * type or {@code null} if not initially set. |
| + */ |
| + get marginsType() { |
| + return this.marginsType_; |
| + }, |
| + |
| + /** @return {print_preview.Margins} Initial custom margins. */ |
| + get customMargins() { |
| + return this.customMargins_; |
| + }, |
| + |
| + /** @return {boolean} Whether duplexing is initially enabled. */ |
| + get isDuplexEnabled() { |
| + return this.isDuplexEnabled_; |
| + }, |
| + |
| + /** @return {boolean} Whether the header-footer is initially enabled. */ |
| + get isHeaderFooterEnabled() { |
| + this.isHeaderFooterEnabled_; |
| + }, |
| + |
| + /** @return {?string} ID of the initially selected destination. */ |
| + get initialDestinationId() { |
| + return this.initialDestinationId_; |
| + } |
| + }; |
| + |
| + // Export |
| + return { |
| + NativeInitialSettings: NativeInitialSettings, |
| + NativeLayer: NativeLayer |
| + }; |
| +}); |