From 8a91ee98190db0ce07e8d4aaacbfed1bc769ef62 Mon Sep 17 00:00:00 2001 From: "blakeross%telocity.com" Date: Thu, 8 Aug 2002 01:55:38 +0000 Subject: [PATCH] Removing unnecessary attributes, collapsing full screen js into browser.js. --- browser/base/content/browser.js | 56 ++++++++++++++++++++++++++++++++ browser/base/content/browser.xul | 19 ++++------- 2 files changed, 62 insertions(+), 13 deletions(-) diff --git a/browser/base/content/browser.js b/browser/base/content/browser.js index 711d2af78fdd..53cdf2f0b168 100644 --- a/browser/base/content/browser.js +++ b/browser/base/content/browser.js @@ -27,6 +27,7 @@ * Ben Goodger * Pierre Chanial * Jason Eager + * Joe Hewitt * * Alternatively, the contents of this file may be used under the terms of * either the GNU General Public License Version 2 or later (the "GPL"), or @@ -3459,3 +3460,58 @@ function BrowserCustomizeToolbar() { window.openDialog("chrome://browser/content/customizeToolbar.xul", "Customize Toolbar", "modal,chrome,resizable=yes"); } + +var FullScreen = +{ + toggle: function() + { + // show/hide all menubars, toolbars, and statusbars (except the full screen toolbar) + this.showXULChrome("menubar", window.fullScreen); + this.showXULChrome("toolbar", window.fullScreen); + this.showXULChrome("statusbar", window.fullScreen); + }, + + showXULChrome: function(aTag, aShow) + { + var XULNS = "http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul"; + var els = document.getElementsByTagNameNS(XULNS, aTag); + + var i; + for (i = 0; i < els.length; ++i) { + // XXX don't interfere with previously collapsed toolbars + if (els[i].getAttribute("fullscreentoolbar") == "true") { + this.setToolbarButtonMode(els[i], aShow ? "" : "small"); + } else { + // use moz-collapsed so it doesn't persist hidden/collapsed, + // so that new windows don't have missing toolbars + if (aShow) + els[i].removeAttribute("moz-collapsed"); + else + els[i].setAttribute("moz-collapsed", "true"); + } + } + + var controls = document.getElementsByAttribute("fullscreencontrol", "true"); + for (i = 0; i < controls.length; ++i) + controls[i].hidden = aShow; + }, + + setToolbarButtonMode: function(aToolbar, aMode) + { + aToolbar.setAttribute("toolbarmode", aMode); + this.setToolbarButtonModeFor(aToolbar, "toolbarbutton", aMode); + this.setToolbarButtonModeFor(aToolbar, "button", aMode); + this.setToolbarButtonModeFor(aToolbar, "textbox", aMode); + }, + + setToolbarButtonModeFor: function(aToolbar, aTag, aMode) + { + var XULNS = "http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul"; + var els = aToolbar.getElementsByTagNameNS(XULNS, aTag); + + for (var i = 0; i < els.length; ++i) { + els[i].setAttribute("toolbarmode", aMode); + } + } + +}; diff --git a/browser/base/content/browser.xul b/browser/base/content/browser.xul index 96f50f1c1389..8708b203fcc1 100644 --- a/browser/base/content/browser.xul +++ b/browser/base/content/browser.xul @@ -60,7 +60,6 @@ Contributor(s):