Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright (c) 2011 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('new_tab', function() { | |
| 6 /** | |
| 7 * NewTabSyncPromo class | |
| 8 * Subclass of options.SyncSetupOverlay that customizes the sync setup | |
| 9 * overlay for use in the new tab page. | |
| 10 * @class | |
| 11 */ | |
| 12 function NewTabSyncPromo() { | |
| 13 options.SyncSetupOverlay.call(this, 'syncSetup', | |
| 14 templateData.syncSetupOverlayTitle, | |
| 15 'sync-setup-overlay'); | |
| 16 } | |
| 17 | |
| 18 cr.addSingletonGetter(NewTabSyncPromo); | |
| 19 | |
| 20 NewTabSyncPromo.prototype = { | |
| 21 __proto__: options.SyncSetupOverlay.prototype, | |
| 22 | |
| 23 // Variable to track if the promo is expanded or collapsed. | |
| 24 isSyncPromoExpanded_: false, | |
| 25 | |
| 26 showOverlay_: function() { | |
| 27 this.expandSyncPromo_(true); | |
| 28 }, | |
| 29 | |
| 30 // Initializes the page. | |
| 31 initializePage: function() { | |
| 32 options.SyncSetupOverlay.prototype.initializePage.call(this); | |
| 33 var self = this; | |
| 34 $('sync-promo-toggle-button').onclick = function() { | |
|
sail
2011/07/20 19:40:25
I needed to change the handler back to an anonymou
| |
| 35 self.onTogglePromo(); | |
| 36 } | |
| 37 chrome.send('InitializeSyncPromo'); | |
| 38 }, | |
| 39 | |
| 40 // Handler for the toggle button to show or hide the sync promo. | |
| 41 onTogglePromo: function() { | |
| 42 if (this.isSyncPromoExpanded_) { | |
| 43 this.expandSyncPromo_(false); | |
| 44 chrome.send('CollapseSyncPromo'); | |
| 45 } else { | |
| 46 chrome.send('ExpandSyncPromo'); | |
| 47 } | |
| 48 }, | |
| 49 | |
| 50 // Shows or hides the sync promo. | |
| 51 expandSyncPromo_: function(shouldExpand) { | |
| 52 this.isSyncPromoExpanded_ = shouldExpand; | |
| 53 if (shouldExpand) { | |
| 54 $('sync-promo-login-status').hidden = true; | |
| 55 $('sync-setup-overlay').hidden = false; | |
| 56 $('sync-promo').classList.remove('collapsed'); | |
| 57 } else { | |
| 58 $('sync-promo-login-status').hidden = false; | |
| 59 $('sync-setup-overlay').hidden = true; | |
| 60 $('sync-promo').classList.add('collapsed'); | |
| 61 } | |
| 62 layoutSections(); | |
| 63 }, | |
| 64 | |
| 65 // Sets the sync login name. If there's no login name then makes the | |
| 66 // 'not connected' UI visible and shows the sync promo toggle button. | |
| 67 updateLogin_: function(user_name) { | |
| 68 if (user_name) { | |
| 69 $('sync-promo-toggle').hidden = true; | |
| 70 $('sync-promo-user-name').textContent = user_name; | |
| 71 $('sync-promo-not-connected').hidden = true; | |
| 72 } else { | |
| 73 $('sync-promo-toggle').hidden = false; | |
| 74 $('sync-promo-user-name').hidden = true; | |
| 75 $('sync-promo-not-connected').hidden = false; | |
| 76 } | |
| 77 layoutSections(); | |
| 78 }, | |
| 79 | |
| 80 // Shows the sync promo. | |
| 81 showSyncPromo_: function() { | |
| 82 $('sync-promo').hidden = false; | |
| 83 }, | |
| 84 }; | |
| 85 | |
| 86 NewTabSyncPromo.showErrorUI = function() { | |
| 87 NewTabSyncPromo.getInstance().showErrorUI_(); | |
| 88 }; | |
| 89 | |
| 90 NewTabSyncPromo.showSetupUI = function() { | |
| 91 NewTabSyncPromo.getInstance().showSetupUI_(); | |
| 92 }; | |
| 93 | |
| 94 NewTabSyncPromo.showSyncSetupPage = function(page, args) { | |
| 95 NewTabSyncPromo.getInstance().showSyncSetupPage_(page, args); | |
| 96 }; | |
| 97 | |
| 98 NewTabSyncPromo.showSuccessAndClose = function() { | |
| 99 NewTabSyncPromo.getInstance().showSuccessAndClose_(); | |
| 100 }; | |
| 101 | |
| 102 NewTabSyncPromo.showSuccessAndSettingUp = function() { | |
| 103 NewTabSyncPromo.getInstance().showSuccessAndSettingUp_(); | |
| 104 }; | |
| 105 | |
| 106 NewTabSyncPromo.showStopSyncingUI = function() { | |
| 107 NewTabSyncPromo.getInstance().showStopSyncingUI_(); | |
| 108 }; | |
| 109 | |
| 110 NewTabSyncPromo.initialize = function() { | |
| 111 NewTabSyncPromo.getInstance().initializePage(); | |
| 112 } | |
| 113 | |
| 114 NewTabSyncPromo.showSyncPromo = function() { | |
| 115 NewTabSyncPromo.getInstance().showSyncPromo_(); | |
| 116 } | |
| 117 | |
| 118 NewTabSyncPromo.updateLogin = function(user_name) { | |
| 119 NewTabSyncPromo.getInstance().updateLogin_(user_name); | |
| 120 } | |
| 121 | |
| 122 // Export | |
| 123 return { | |
| 124 NewTabSyncPromo : NewTabSyncPromo | |
| 125 }; | |
| 126 }); | |
| 127 | |
| 128 var OptionsPage = options.OptionsPage; | |
| 129 var SyncSetupOverlay = new_tab.NewTabSyncPromo; | |
| 130 window.addEventListener('DOMContentLoaded', new_tab.NewTabSyncPromo.initialize); | |
| OLD | NEW |