aboutsummaryrefslogtreecommitdiff
path: root/contexts/data/lib/closure-library/closure/goog/debug/fancywindow.js
diff options
context:
space:
mode:
Diffstat (limited to 'contexts/data/lib/closure-library/closure/goog/debug/fancywindow.js')
-rw-r--r--contexts/data/lib/closure-library/closure/goog/debug/fancywindow.js363
1 files changed, 0 insertions, 363 deletions
diff --git a/contexts/data/lib/closure-library/closure/goog/debug/fancywindow.js b/contexts/data/lib/closure-library/closure/goog/debug/fancywindow.js
deleted file mode 100644
index 79a6ba1..0000000
--- a/contexts/data/lib/closure-library/closure/goog/debug/fancywindow.js
+++ /dev/null
@@ -1,363 +0,0 @@
-// Copyright 2006 The Closure Library Authors. All Rights Reserved.
-//
-// Licensed under the Apache License, Version 2.0 (the "License");
-// you may not use this file except in compliance with the License.
-// You may obtain a copy of the License at
-//
-// http://www.apache.org/licenses/LICENSE-2.0
-//
-// Unless required by applicable law or agreed to in writing, software
-// distributed under the License is distributed on an "AS-IS" BASIS,
-// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-// See the License for the specific language governing permissions and
-// limitations under the License.
-
-/**
- * @fileoverview Definition of the FancyWindow class. Please minimize
- * dependencies this file has on other closure classes as any dependency it
- * takes won't be able to use the logging infrastructure.
- *
- * This is a pretty hacky implementation, aimed at making debugging of large
- * applications more manageable.
- *
- * @see ../demos/debug.html
- */
-
-
-goog.provide('goog.debug.FancyWindow');
-
-goog.require('goog.debug.DebugWindow');
-goog.require('goog.debug.LogManager');
-goog.require('goog.debug.Logger');
-goog.require('goog.debug.Logger.Level');
-goog.require('goog.dom.DomHelper');
-goog.require('goog.object');
-goog.require('goog.string');
-goog.require('goog.userAgent');
-
-
-
-/**
- * Provides a Fancy extension to the DebugWindow class. Allows filtering based
- * on loggers and levels.
- *
- * @param {string=} opt_identifier Idenitifier for this logging class.
- * @param {string=} opt_prefix Prefix pre-pended to messages.
- * @constructor
- * @extends {goog.debug.DebugWindow}
- */
-goog.debug.FancyWindow = function(opt_identifier, opt_prefix) {
- this.readOptionsFromLocalStorage_();
- goog.base(this, opt_identifier, opt_prefix);
-};
-goog.inherits(goog.debug.FancyWindow, goog.debug.DebugWindow);
-
-
-/**
- * Constant indicating if we are able to use localStorage to persist filters
- * @type {boolean}
- */
-goog.debug.FancyWindow.HAS_LOCAL_STORE = (function() {
- /** @preserveTry */
- try {
- return !!window['localStorage'].getItem;
- } catch (e) {}
- return false;
-})();
-
-
-/**
- * Constant defining the prefix to use when storing log levels
- * @type {string}
- */
-goog.debug.FancyWindow.LOCAL_STORE_PREFIX = 'fancywindow.sel.';
-
-
-/** @override */
-goog.debug.FancyWindow.prototype.writeBufferToLog = function() {
- this.lastCall_ = goog.now();
- if (this.hasActiveWindow()) {
- var logel = this.dh_.getElement('log');
-
- // Work out if scrolling is needed before we add the content
- var scroll =
- logel.scrollHeight - (logel.scrollTop + logel.offsetHeight) <= 100;
-
- for (var i = 0; i < this.outputBuffer_.length; i++) {
- var div = this.dh_.createDom('div', 'logmsg');
- div.innerHTML = this.outputBuffer_[i];
- logel.appendChild(div);
- }
- this.outputBuffer_.length = 0;
- this.resizeStuff_();
-
- if (scroll) {
- logel.scrollTop = logel.scrollHeight;
- }
- }
-};
-
-
-/** @override */
-goog.debug.FancyWindow.prototype.writeInitialDocument = function() {
- if (!this.hasActiveWindow()) {
- return;
- }
-
- var doc = this.win_.document;
- doc.open();
- doc.write(this.getHtml_());
- doc.close();
-
- (goog.userAgent.IE ? doc.body : this.win_).onresize =
- goog.bind(this.resizeStuff_, this);
-
- // Create a dom helper for the logging window
- this.dh_ = new goog.dom.DomHelper(doc);
-
- // Don't use events system to reduce dependencies
- this.dh_.getElement('openbutton').onclick =
- goog.bind(this.openOptions_, this);
- this.dh_.getElement('closebutton').onclick =
- goog.bind(this.closeOptions_, this);
- this.dh_.getElement('clearbutton').onclick =
- goog.bind(this.clear_, this);
- this.dh_.getElement('exitbutton').onclick =
- goog.bind(this.exit_, this);
-
- this.writeSavedMessages_();
-};
-
-
-/**
- * Show the options menu.
- * @return {boolean} false.
- * @private
- */
-goog.debug.FancyWindow.prototype.openOptions_ = function() {
- var el = this.dh_.getElement('optionsarea');
- el.innerHTML = '';
-
- var loggers = goog.debug.FancyWindow.getLoggers_();
- var dh = this.dh_;
- for (var i = 0; i < loggers.length; i++) {
- var logger = goog.debug.Logger.getLogger(loggers[i]);
- var curlevel = logger.getLevel() ? logger.getLevel().name : 'INHERIT';
- var div = dh.createDom('div', {},
- this.getDropDown_('sel' + loggers[i], curlevel),
- dh.createDom('span', {}, loggers[i] || '(root)'));
- el.appendChild(div);
- }
-
- this.dh_.getElement('options').style.display = 'block';
- return false;
-};
-
-
-/**
- * Make a drop down for the log levels.
- * @param {string} id Logger id.
- * @param {string} selected What log level is currently selected.
- * @return {Element} The newly created 'select' DOM element.
- * @private
- */
-goog.debug.FancyWindow.prototype.getDropDown_ = function(id, selected) {
- var dh = this.dh_;
- var sel = dh.createDom('select', {'id': id});
- var levels = goog.debug.Logger.Level.PREDEFINED_LEVELS;
- for (var i = 0; i < levels.length; i++) {
- var level = levels[i];
- var option = dh.createDom('option', {}, level.name);
- if (selected == level.name) {
- option.selected = true;
- }
- sel.appendChild(option);
- }
- sel.appendChild(dh.createDom('option',
- {'selected': selected == 'INHERIT'}, 'INHERIT'));
- return sel;
-};
-
-
-/**
- * Close the options menu.
- * @return {boolean} The value false.
- * @private
- */
-goog.debug.FancyWindow.prototype.closeOptions_ = function() {
- this.dh_.getElement('options').style.display = 'none';
- var loggers = goog.debug.FancyWindow.getLoggers_();
- var dh = this.dh_;
- for (var i = 0; i < loggers.length; i++) {
- var logger = goog.debug.Logger.getLogger(loggers[i]);
- var sel = dh.getElement('sel' + loggers[i]);
- var level = sel.options[sel.selectedIndex].text;
- if (level == 'INHERIT') {
- logger.setLevel(null);
- } else {
- logger.setLevel(goog.debug.Logger.Level.getPredefinedLevel(level));
- }
- }
- this.writeOptionsToLocalStorage_();
- return false;
-};
-
-
-/**
- * Resize the lof elements
- * @private
- */
-goog.debug.FancyWindow.prototype.resizeStuff_ = function() {
- var dh = this.dh_;
- var logel = dh.getElement('log');
- var headel = dh.getElement('head');
- logel.style.top = headel.offsetHeight + 'px';
- logel.style.height = (dh.getDocument().body.offsetHeight -
- headel.offsetHeight - (goog.userAgent.IE ? 4 : 0)) + 'px';
-};
-
-
-/**
- * Handles the user clicking the exit button, disabled the debug window and
- * closes the popup.
- * @param {Event} e Event object.
- * @private
- */
-goog.debug.FancyWindow.prototype.exit_ = function(e) {
- this.setEnabled(false);
- if (this.win_) {
- this.win_.close();
- }
-};
-
-
-/** @override */
-goog.debug.FancyWindow.prototype.getStyleRules = function() {
- return goog.base(this, 'getStyleRules') +
- 'html,body{height:100%;width:100%;margin:0px;padding:0px;' +
- 'background-color:#FFF;overflow:hidden}' +
- '*{}' +
- '.logmsg{border-bottom:1px solid #CCC;padding:2px;font:90% monospace}' +
- '#head{position:absolute;width:100%;font:x-small arial;' +
- 'border-bottom:2px solid #999;background-color:#EEE;}' +
- '#head p{margin:0px 5px;}' +
- '#log{position:absolute;width:100%;background-color:#FFF;}' +
- '#options{position:absolute;right:0px;width:50%;height:100%;' +
- 'border-left:1px solid #999;background-color:#DDD;display:none;' +
- 'padding-left: 5px;font:normal small arial;overflow:auto;}' +
- '#openbutton,#closebutton{text-decoration:underline;color:#00F;cursor:' +
- 'pointer;position:absolute;top:0px;right:5px;font:x-small arial;}' +
- '#clearbutton{text-decoration:underline;color:#00F;cursor:' +
- 'pointer;position:absolute;top:0px;right:80px;font:x-small arial;}' +
- '#exitbutton{text-decoration:underline;color:#00F;cursor:' +
- 'pointer;position:absolute;top:0px;right:50px;font:x-small arial;}' +
- 'select{font:x-small arial;margin-right:10px;}' +
- 'hr{border:0;height:5px;background-color:#8c8;color:#8c8;}';
-};
-
-
-/**
- * Return the default HTML for the debug window
- * @return {string} Html.
- * @private
- */
-goog.debug.FancyWindow.prototype.getHtml_ = function() {
- return '' +
- '<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"' +
- '"http://www.w3.org/TR/html4/loose.dtd">' +
- '<html><head><title>Logging: ' + this.identifier_ + '</title>' +
- '<style>' + this.getStyleRules() + '</style>' +
- '</head><body>' +
- '<div id="log" style="overflow:auto"></div>' +
- '<div id="head">' +
- '<p><b>Logging: ' + this.identifier_ + '</b></p><p>' +
- this.welcomeMessage + '</p>' +
- '<span id="clearbutton">clear</span>' +
- '<span id="exitbutton">exit</span>' +
- '<span id="openbutton">options</span>' +
- '</div>' +
- '<div id="options">' +
- '<big><b>Options:</b></big>' +
- '<div id="optionsarea"></div>' +
- '<span id="closebutton">save and close</span>' +
- '</div>' +
- '</body></html>';
-};
-
-
-/**
- * Write logger levels to localStorage if possible.
- * @private
- */
-goog.debug.FancyWindow.prototype.writeOptionsToLocalStorage_ = function() {
- if (!goog.debug.FancyWindow.HAS_LOCAL_STORE) {
- return;
- }
- var loggers = goog.debug.FancyWindow.getLoggers_();
- var storedKeys = goog.debug.FancyWindow.getStoredKeys_();
- for (var i = 0; i < loggers.length; i++) {
- var key = goog.debug.FancyWindow.LOCAL_STORE_PREFIX + loggers[i];
- var level = goog.debug.Logger.getLogger(loggers[i]).getLevel();
- if (key in storedKeys) {
- if (!level) {
- window.localStorage.removeItem(key);
- } else if (window.localStorage.getItem(key) != level.name) {
- window.localStorage.setItem(key, level.name);
- }
- } else if (level) {
- window.localStorage.setItem(key, level.name);
- }
- }
-};
-
-
-/**
- * Sync logger levels with any values stored in localStorage.
- * @private
- */
-goog.debug.FancyWindow.prototype.readOptionsFromLocalStorage_ = function() {
- if (!goog.debug.FancyWindow.HAS_LOCAL_STORE) {
- return;
- }
- var storedKeys = goog.debug.FancyWindow.getStoredKeys_();
- for (var key in storedKeys) {
- var loggerName = key.replace(goog.debug.FancyWindow.LOCAL_STORE_PREFIX, '');
- var logger = goog.debug.Logger.getLogger(loggerName);
- var curLevel = logger.getLevel();
- var storedLevel = window.localStorage.getItem(key).toString();
- if (!curLevel || curLevel.toString() != storedLevel) {
- logger.setLevel(goog.debug.Logger.Level.getPredefinedLevel(storedLevel));
- }
- }
-};
-
-
-/**
- * Helper function to create a list of locally stored keys. Used to avoid
- * expensive localStorage.getItem() calls.
- * @return {Object} List of keys.
- * @private
- */
-goog.debug.FancyWindow.getStoredKeys_ = function() {
- var storedKeys = {};
- for (var i = 0, len = window.localStorage.length; i < len; i++) {
- var key = window.localStorage.key(i);
- if (key != null && goog.string.startsWith(
- key, goog.debug.FancyWindow.LOCAL_STORE_PREFIX)) {
- storedKeys[key] = true;
- }
- }
- return storedKeys;
-};
-
-
-/**
- * Gets a sorted array of all the loggers registered
- * @return {Array} Array of logger idents, e.g. goog.net.XhrIo.
- * @private
- */
-goog.debug.FancyWindow.getLoggers_ = function() {
- var loggers = goog.object.getKeys(goog.debug.LogManager.getLoggers());
- loggers.sort();
- return loggers;
-};