1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 2 // Use of this source code is governed by a BSD-style license that can be 3 // found in the LICENSE file. 4 5 cr.define('options', function() { 6 /** @const */ var SettingsDialog = options.SettingsDialog; 7 8 /** 9 * A dialog that will pop up when the user attempts to set the value of the 10 * Boolean |pref| to |true|, asking for confirmation. If the user clicks OK, 11 * the new value is committed to Chrome. If the user clicks Cancel or leaves 12 * the settings page, the new value is discarded. 13 * @constructor 14 * @param {string} name See Page constructor. 15 * @param {string} title See Page constructor. 16 * @param {string} pageDivName See Page constructor. 17 * @param {HTMLButtonElement} okButton The confirmation button element. 18 * @param {HTMLButtonElement} cancelButton The cancellation button element. 19 * @param {string} pref The pref that requires confirmation. 20 * @param {string} metric User metrics identifier. 21 * @param {string=} opt_confirmedPref A pref used to remember whether the 22 * user has confirmed the dialog before. This ensures that the user is 23 * presented with the dialog only once. If left |undefined|, the dialog 24 * will pop up every time the user attempts to set |pref| to |true|. 25 * @extends {options.SettingsDialog} 26 */ 27 function ConfirmDialog(name, title, pageDivName, okButton, cancelButton, pref, 28 metric, opt_confirmedPref) { 29 SettingsDialog.call(this, name, title, pageDivName, okButton, cancelButton); 30 31 /** @protected */ 32 this.pref = pref; 33 34 /** @protected */ 35 this.metric = metric; 36 37 /** @private */ 38 this.confirmedPref_ = opt_confirmedPref; 39 40 /** @private */ 41 this.confirmed_ = false; 42 } 43 44 ConfirmDialog.prototype = { 45 // Set up the prototype chain 46 __proto__: SettingsDialog.prototype, 47 48 /** 49 * Handle changes to |pref|. Only uncommitted changes are relevant as these 50 * originate from user and need to be explicitly committed to take effect. 51 * Pop up the dialog or commit the change, depending on whether confirmation 52 * is needed. 53 * @param {Event} event Change event. 54 * @private 55 */ 56 onPrefChanged_: function(event) { 57 if (!event.value.uncommitted) 58 return; 59 60 if (event.value.value && !this.confirmed_) 61 PageManager.showPageByName(this.name, false); 62 else 63 Preferences.getInstance().commitPref(this.pref, this.metric); 64 }, 65 66 /** 67 * Handle changes to |confirmedPref_| by caching them. 68 * @param {Event} event Change event. 69 * @private 70 */ 71 onConfirmedChanged_: function(event) { 72 this.confirmed_ = event.value.value; 73 }, 74 75 /** @override */ 76 initializePage: function() { 77 SettingsDialog.prototype.initializePage.call(this); 78 79 this.okButton.onclick = this.handleConfirm.bind(this); 80 this.cancelButton.onclick = this.handleCancel.bind(this); 81 Preferences.getInstance().addEventListener( 82 this.pref, this.onPrefChanged_.bind(this)); 83 if (this.confirmedPref_) { 84 Preferences.getInstance().addEventListener( 85 this.confirmedPref_, this.onConfirmedChanged_.bind(this)); 86 } 87 }, 88 89 /** 90 * Handle the confirm button by committing the |pref| change. If 91 * |confirmedPref_| has been specified, also remember that the dialog has 92 * been confirmed to avoid bringing it up in the future. 93 * @override 94 */ 95 handleConfirm: function() { 96 SettingsDialog.prototype.handleConfirm.call(this); 97 98 Preferences.getInstance().commitPref(this.pref, this.metric); 99 if (this.confirmedPref_) 100 Preferences.setBooleanPref(this.confirmedPref_, true, true); 101 }, 102 103 /** 104 * Handle the cancel button by rolling back the |pref| change without it 105 * ever taking effect. 106 * @override 107 */ 108 handleCancel: function() { 109 SettingsDialog.prototype.handleCancel.call(this); 110 Preferences.getInstance().rollbackPref(this.pref); 111 }, 112 113 /** 114 * When a user navigates away from a confirm dialog, treat as a cancel. 115 * @protected 116 * @override 117 */ 118 willHidePage: function() { 119 if (this.visible) 120 Preferences.getInstance().rollbackPref(this.pref); 121 }, 122 }; 123 124 return { 125 ConfirmDialog: ConfirmDialog 126 }; 127 }); 128