123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228 |
- /*
- * Copyright (C) 2008 Apple Inc. All Rights Reserved.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions
- * are met:
- * 1. Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * 2. Redistributions in binary form must reproduce the above copyright
- * notice, this list of conditions and the following disclaimer in the
- * documentation and/or other materials provided with the distribution.
- *
- * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
- * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
- * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
- * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR
- * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
- * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
- * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
- * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
- * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
- * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- */
- /**
- * @constructor
- * @extends {TreeElement}
- */
- WebInspector.SidebarSectionTreeElement = function(title, representedObject, hasChildren)
- {
- TreeElement.call(this, title.escapeHTML(), representedObject || {}, hasChildren);
- this.expand();
- }
- WebInspector.SidebarSectionTreeElement.prototype = {
- selectable: false,
- collapse: function()
- {
- // Should not collapse as it is not selectable.
- },
- get smallChildren()
- {
- return this._smallChildren;
- },
- set smallChildren(x)
- {
- if (this._smallChildren === x)
- return;
- this._smallChildren = x;
- if (this._smallChildren)
- this._childrenListNode.addStyleClass("small");
- else
- this._childrenListNode.removeStyleClass("small");
- },
- onattach: function()
- {
- this._listItemNode.addStyleClass("sidebar-tree-section");
- },
- onreveal: function()
- {
- if (this.listItemElement)
- this.listItemElement.scrollIntoViewIfNeeded(false);
- },
- __proto__: TreeElement.prototype
- }
- /**
- * @constructor
- * @extends {TreeElement}
- * @param {string=} subtitle
- * @param {Object=} representedObject
- * @param {boolean=} hasChildren
- */
- WebInspector.SidebarTreeElement = function(className, title, subtitle, representedObject, hasChildren)
- {
- TreeElement.call(this, "", representedObject, hasChildren);
- if (hasChildren) {
- this.disclosureButton = document.createElement("button");
- this.disclosureButton.className = "disclosure-button";
- }
- if (!this.iconElement) {
- this.iconElement = document.createElement("img");
- this.iconElement.className = "icon";
- }
- this.statusElement = document.createElement("div");
- this.statusElement.className = "status";
- this.titlesElement = document.createElement("div");
- this.titlesElement.className = "titles";
- this.titleElement = document.createElement("span");
- this.titleElement.className = "title";
- this.titlesElement.appendChild(this.titleElement);
- this.subtitleElement = document.createElement("span");
- this.subtitleElement.className = "subtitle";
- this.titlesElement.appendChild(this.subtitleElement);
- this.className = className;
- this.mainTitle = title;
- this.subtitle = subtitle;
- }
- WebInspector.SidebarTreeElement.prototype = {
- get small()
- {
- return this._small;
- },
- set small(x)
- {
- this._small = x;
- if (this._listItemNode) {
- if (this._small)
- this._listItemNode.addStyleClass("small");
- else
- this._listItemNode.removeStyleClass("small");
- }
- },
- get mainTitle()
- {
- return this._mainTitle;
- },
- set mainTitle(x)
- {
- this._mainTitle = x;
- this.refreshTitles();
- },
- get subtitle()
- {
- return this._subtitle;
- },
- set subtitle(x)
- {
- this._subtitle = x;
- this.refreshTitles();
- },
- get bubbleText()
- {
- return this._bubbleText;
- },
- set bubbleText(x)
- {
- if (!this.bubbleElement) {
- this.bubbleElement = document.createElement("div");
- this.bubbleElement.className = "bubble";
- this.statusElement.appendChild(this.bubbleElement);
- }
- this._bubbleText = x;
- this.bubbleElement.textContent = x;
- },
- set wait(x)
- {
- if (x)
- this._listItemNode.addStyleClass("wait");
- else
- this._listItemNode.removeStyleClass("wait");
- },
- refreshTitles: function()
- {
- var mainTitle = this.mainTitle;
- if (this.titleElement.textContent !== mainTitle)
- this.titleElement.textContent = mainTitle;
- var subtitle = this.subtitle;
- if (subtitle) {
- if (this.subtitleElement.textContent !== subtitle)
- this.subtitleElement.textContent = subtitle;
- this.titlesElement.removeStyleClass("no-subtitle");
- } else {
- this.subtitleElement.textContent = "";
- this.titlesElement.addStyleClass("no-subtitle");
- }
- },
- isEventWithinDisclosureTriangle: function(event)
- {
- return event.target === this.disclosureButton;
- },
- onattach: function()
- {
- this._listItemNode.addStyleClass("sidebar-tree-item");
- if (this.className)
- this._listItemNode.addStyleClass(this.className);
- if (this.small)
- this._listItemNode.addStyleClass("small");
- if (this.hasChildren && this.disclosureButton)
- this._listItemNode.appendChild(this.disclosureButton);
- this._listItemNode.appendChild(this.iconElement);
- this._listItemNode.appendChild(this.statusElement);
- this._listItemNode.appendChild(this.titlesElement);
- },
- onreveal: function()
- {
- if (this._listItemNode)
- this._listItemNode.scrollIntoViewIfNeeded(false);
- },
- __proto__: TreeElement.prototype
- }
|