// 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('options', function() { var Page = cr.ui.pageManager.Page; var PageManager = cr.ui.pageManager.PageManager; ///////////////////////////////////////////////////////////////////////////// // CookiesView class: /** * Encapsulated handling of the cookies and other site data page. * @constructor * @extends {cr.ui.pageManager.Page} */ function CookiesView(model) { Page.call(this, 'cookies', loadTimeData.getString('cookiesViewPageTabTitle'), 'cookies-view-page'); } cr.addSingletonGetter(CookiesView); CookiesView.prototype = { __proto__: Page.prototype, /** * The timer id of the timer set on search query change events. * @type {number} * @private */ queryDelayTimerId_: 0, /** * The most recent search query, empty string if the query is empty. * @type {string} * @private */ lastQuery_: '', /** @override */ initializePage: function() { Page.prototype.initializePage.call(this); var searchBox = this.pageDiv.querySelector('.cookies-search-box'); searchBox.addEventListener( 'search', this.handleSearchQueryChange_.bind(this)); searchBox.onkeydown = function(e) { // Prevent the overlay from handling this event. if (e.keyIdentifier == 'Enter') e.stopPropagation(); }; this.pageDiv.querySelector('.remove-all-cookies-button').onclick = function(e) { chrome.send('removeAllCookies'); }; var cookiesList = this.pageDiv.querySelector('.cookies-list'); options.CookiesList.decorate(cookiesList); this.addEventListener('visibleChange', this.handleVisibleChange_); this.pageDiv.querySelector('.cookies-view-overlay-confirm').onclick = PageManager.closeOverlay.bind(PageManager); }, /** @override */ didShowPage: function() { this.pageDiv.querySelector('.cookies-search-box').value = ''; this.lastQuery_ = ''; }, /** * Search cookie using text in |cookies-search-box|. */ searchCookie: function() { this.queryDelayTimerId_ = 0; var filter = this.pageDiv.querySelector('.cookies-search-box').value; if (this.lastQuery_ != filter) { this.lastQuery_ = filter; chrome.send('updateCookieSearchResults', [filter]); } }, /** * Handles search query changes. * @param {!Event} e The event object. * @private */ handleSearchQueryChange_: function(e) { var stringId = document.querySelector('.cookies-search-box').value ? 'remove_all_shown_cookie' : 'remove_all_cookie'; document.querySelector('.remove-all-cookies-button').innerHTML = loadTimeData.getString(stringId); if (this.queryDelayTimerId_) window.clearTimeout(this.queryDelayTimerId_); this.queryDelayTimerId_ = window.setTimeout( this.searchCookie.bind(this), 500); }, initialized_: false, /** * Handler for Page's visible property change event. * @param {Event} e Property change event. * @private */ handleVisibleChange_: function(e) { if (!this.visible) return; chrome.send('reloadCookies'); if (!this.initialized_) { this.initialized_ = true; this.searchCookie(); } else { this.pageDiv.querySelector('.cookies-list').redraw(); } this.pageDiv.querySelector('.cookies-search-box').focus(); }, }; // CookiesViewHandler callbacks. CookiesView.onTreeItemAdded = function(args) { $('cookies-list').addByParentId(args[0], args[1], args[2]); }; CookiesView.onTreeItemRemoved = function(args) { $('cookies-list').removeByParentId(args[0], args[1], args[2]); }; CookiesView.loadChildren = function(args) { $('cookies-list').loadChildren(args[0], args[1]); }; // Export return { CookiesView: CookiesView }; });