From f528b6e158f7d784ea1e04e4c1f15db2aafc77ff Mon Sep 17 00:00:00 2001 From: "beng%bengoodger.com" Date: Wed, 14 Dec 2005 22:55:17 +0000 Subject: [PATCH] 318823 - Places should not act like web content - disable some menu items when places is showing. r=annie. --- browser/components/places/content/places.js | 40 ++++++++++++++++++++- 1 file changed, 39 insertions(+), 1 deletion(-) diff --git a/browser/components/places/content/places.js b/browser/components/places/content/places.js index 11dca793ec9..c040f84a9f2 100755 --- a/browser/components/places/content/places.js +++ b/browser/components/places/content/places.js @@ -42,6 +42,7 @@ var PlacesUIHook = { _tabbrowser: null, _topWindow: null, _placesURI: "chrome://browser/content/places/places.xul", + _bundle: null, init: function PUIH_init(placesList) { try { @@ -61,6 +62,8 @@ var PlacesUIHook = { catch (e) { } + this._bundle = document.getElementById("placeBundle"); + // Stop the browser from handling certain types of events. function onDragEvent(event) { event.stopPropagation(); @@ -69,6 +72,34 @@ var PlacesUIHook = { window.addEventListener("dragover", onDragEvent, false); window.addEventListener("dragdrop", onDragEvent, false); }, + + this._commands = ["Browser:SavePage", "Browser:SaveFrame", "Browser:SendLink", + "cmd_pageSetup", "cmd_print", "cmd_printPreview", + "cmd_findAgain", "cmd_switchTextDirection", "Browser:Stop", + "Browser:Reload", "viewTextZoomMenu", "pageStyleMenu", + "charsetMenu", "View:PageSource", "View:FullScreen", + "documentDirection-swap", "Browser:AddBookmarkAs", + "Browser:ShowPlaces", "View:PageInfo", "cmd_toggleTaskbar"], + + /** + * Disable commands that are not relevant to the Places page, so that all + * applicable UI becomes inactive. + */ + _disableCommands: function PUIH__disableCommands() { + for (var i = 0; i < this._commands.length; ++i) + this._topWindow.document.getElementById(this._commands[i]). + setAttribute("disabled", true); + }, + + /** + * Enable commands that aren't updated automatically by the command updater + * when we switch away from the Places page. + */ + _enableCommands: function PUIH__enableCommands() { + for (var i = 0; i < this._commands.length; ++i) + this._topWindow.document.getElementById(this._commands[i]). + removeAttribute("disabled"); + }, uninit: function PUIH_uninit() { this._hidePlacesUI(); @@ -88,12 +119,19 @@ var PlacesUIHook = { var statusbar = this._topElement("status-bar"); this._oldStatusBarState = statusbar.hidden; statusbar.hidden = true; + this._disableCommands(); + + var findItem = this._topWindow.document.getElementById("menu_find"); + findItem.setAttribute("label", this._bundle.getString("findPlaceLabel")); }, _hidePlacesUI: function PP__hidePlacesUI() { this._tabbrowser.removeAttribute("places"); - var statusbar = this._topElement("status-bar"); statusbar.hidden = this._oldStatusBarState; + this._enableCommands(); + + var findItem = this._topWindow.document.getElementById("menu_find"); + findItem.setAttribute("label", this._bundle.getString("findPageLabel")); }, };