Index: chrome/browser/resources/print_preview/settings/other_options_settings.js |
diff --git a/chrome/browser/resources/print_preview/settings/other_options_settings.js b/chrome/browser/resources/print_preview/settings/other_options_settings.js |
new file mode 100644 |
index 0000000000000000000000000000000000000000..621b62b950d5aa9cc0763ffcd394df683976f0ca |
--- /dev/null |
+++ b/chrome/browser/resources/print_preview/settings/other_options_settings.js |
@@ -0,0 +1,172 @@ |
+// 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'; |
+ |
+ /** |
+ * UI component that renders checkboxes for various print options. |
+ * @param {!print_preview.PrintTicketStore} printTicketStore Used to monitor |
+ * the state of the print ticket. |
+ * @constructor |
+ * @extends {print_preview.Component} |
+ */ |
+ function OtherOptionsSettings(printTicketStore) { |
+ print_preview.Component.call(this); |
+ |
+ /** |
+ * Used to monitor the state of the print ticket. |
+ * @type {!print_preview.PrintTicketStore} |
+ * @private |
+ */ |
+ this.printTicketStore_ = printTicketStore; |
+ |
+ /** |
+ * Header footer container element. |
+ * @type {HTMLElement} |
+ * @private |
+ */ |
+ this.headerFooterEl_ = null; |
+ |
+ /** |
+ * Header footer checkbox. |
+ * @type {HTMLInputElement} |
+ * @private |
+ */ |
+ this.headerFooterCheckbox_ = null; |
+ |
+ /** |
+ * Fit-to-page container element. |
+ * @type {HTMLElement} |
+ * @private |
+ */ |
+ this.fitToPageEl_ = null; |
+ |
+ /** |
+ * Fit-to-page checkbox. |
+ * @type {HTMLInputElement} |
+ * @private |
+ */ |
+ this.fitToPageCheckbox_ = null; |
+ }; |
+ |
+ /** |
+ * CSS classes used by the other options component. |
+ * @enum {string} |
+ * @private |
+ */ |
+ OtherOptionsSettings.Classes_ = { |
+ FIT_TO_PAGE: 'other-options-settings-fit-to-page', |
+ FIT_TO_PAGE_CHECKBOX: 'other-options-settings-fit-to-page-checkbox', |
+ HEADER_FOOTER: 'other-options-settings-header-footer', |
+ HEADER_FOOTER_CHECKBOX: 'other-options-settings-header-footer-checkbox' |
+ }; |
+ |
+ OtherOptionsSettings.prototype = { |
+ __proto__: print_preview.Component.prototype, |
+ |
+ set isEnabled(isEnabled) { |
+ this.headerFooterCheckbox_.disabled = !isEnabled; |
+ this.fitToPageCheckbox_.disabled = !isEnabled; |
+ }, |
+ |
+ /** @override */ |
+ enterDocument: function() { |
+ print_preview.Component.prototype.enterDocument.call(this); |
+ this.tracker.add( |
+ this.headerFooterCheckbox_, |
+ 'click', |
+ this.onHeaderFooterCheckboxClick_.bind(this)); |
+ this.tracker.add( |
+ this.fitToPageCheckbox_, |
+ 'click', |
+ this.onFitToPageCheckboxClick_.bind(this)); |
+ this.tracker.add( |
+ this.printTicketStore_, |
+ print_preview.PrintTicketStore.EventType.INITIALIZE, |
+ this.onPrintTicketStoreChange_.bind(this)); |
+ this.tracker.add( |
+ this.printTicketStore_, |
+ print_preview.PrintTicketStore.EventType.DOCUMENT_CHANGE, |
+ this.onPrintTicketStoreChange_.bind(this)); |
+ this.tracker.add( |
+ this.printTicketStore_, |
+ print_preview.PrintTicketStore.EventType.CAPABILITIES_CHANGE, |
+ this.onPrintTicketStoreChange_.bind(this)); |
+ this.tracker.add( |
+ this.printTicketStore_, |
+ print_preview.PrintTicketStore.EventType.TICKET_CHANGE, |
+ this.onPrintTicketStoreChange_.bind(this)); |
+ }, |
+ |
+ /** @override */ |
+ exitDocument: function() { |
+ print_preview.Component.prototype.exitDocument.call(this); |
+ this.headerFooterEl_ = null; |
+ this.headerFooterCheckbox_ = null; |
+ this.fitToPageEl_ = null; |
+ this.fitToPageCheckbox_ = null; |
+ }, |
+ |
+ /** @override */ |
+ decorateInternal: function() { |
+ this.headerFooterEl_ = this.getElement().getElementsByClassName( |
+ OtherOptionsSettings.Classes_.HEADER_FOOTER)[0]; |
+ this.headerFooterCheckbox_ = this.getElement().getElementsByClassName( |
+ OtherOptionsSettings.Classes_.HEADER_FOOTER_CHECKBOX)[0]; |
+ this.fitToPageEl_ = this.getElement().getElementsByClassName( |
+ OtherOptionsSettings.Classes_.FIT_TO_PAGE)[0]; |
+ this.fitToPageCheckbox_ = this.getElement().getElementsByClassName( |
+ OtherOptionsSettings.Classes_.FIT_TO_PAGE_CHECKBOX)[0]; |
+ }, |
+ |
+ /** |
+ * Called when the header-footer checkbox is clicked. Updates the print |
+ * ticket. |
+ * @private |
+ */ |
+ onHeaderFooterCheckboxClick_: function() { |
+ this.printTicketStore_.updateHeaderFooter( |
+ this.headerFooterCheckbox_.checked); |
+ }, |
+ |
+ /** |
+ * Called when the fit-to-page checkbox is clicked. Updates the print |
+ * ticket. |
+ * @private |
+ */ |
+ onFitToPageCheckboxClick_: function() { |
+ this.printTicketStore_.updateFitToPage( |
+ this.fitToPageCheckbox_.checked); |
+ }, |
+ |
+ /** |
+ * Called when the print ticket store has changed. Hides or shows the |
+ * setting. |
+ * @private |
+ */ |
+ onPrintTicketStoreChange_: function() { |
+ setIsVisible(this.headerFooterEl_, |
+ this.printTicketStore_.hasHeaderFooterCapability()); |
+ this.headerFooterCheckbox_.checked = |
+ this.printTicketStore_.isHeaderFooterEnabled(); |
+ setIsVisible(this.fitToPageEl_, |
+ this.printTicketStore_.hasFitToPageCapability()); |
+ this.fitToPageCheckbox_.checked = |
+ this.printTicketStore_.isFitToPageEnabled(); |
+ |
+ if (this.printTicketStore_.hasHeaderFooterCapability() || |
+ this.printTicketStore_.hasFitToPageCapability()) { |
+ fadeInOption(this.getElement()); |
+ } else { |
+ fadeOutOption(this.getElement()); |
+ } |
+ } |
+ }; |
+ |
+ // Export |
+ return { |
+ OtherOptionsSettings: OtherOptionsSettings |
+ }; |
+}); |