/* * Copyright (C) 2013 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. AND ITS CONTRIBUTORS ``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 ITS 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. */ WebInspector.Section = function(title, subtitle) { WebInspector.Object.call(this); this.element = document.createElement("div"); this.element.className = "section"; this.element._section = this; if (typeof title === "string" || title instanceof Node || typeof subtitle === "string") { this.headerElement = document.createElement("div"); this.headerElement.className = "header"; this.titleElement = document.createElement("div"); this.titleElement.className = "title"; this.subtitleElement = document.createElement("div"); this.subtitleElement.className = "subtitle"; this.headerElement.appendChild(this.subtitleElement); this.headerElement.appendChild(this.titleElement); this.headerElement.addEventListener("click", this.handleClick.bind(this), false); this.element.appendChild(this.headerElement); this.title = title; this.subtitle = subtitle; } else this.element.classList.add("no-header"); this._expanded = false; if (!this.headerElement) this.expand(); }; WebInspector.Section.Event = { VisibleContentDidChange: "section-visible-content-did-change" }; WebInspector.Section.prototype = { get title() { return this._title; }, set title(x) { if (this._title === x) return; this._title = x; if (x instanceof Node) { this.titleElement.removeChildren(); this.titleElement.appendChild(x); } else this.titleElement.textContent = x; }, get subtitle() { return this._subtitle; }, set subtitle(x) { if (this._subtitle === x) return; this._subtitle = x; this.subtitleElement.textContent = x; }, get subtitleAsTextForTest() { var result = this.subtitleElement.textContent; var child = this.subtitleElement.querySelector("[data-uncopyable]"); if (child) { var linkData = child.getAttribute("data-uncopyable"); if (linkData) result += linkData; } return result; }, get expanded() { return this._expanded; }, set expanded(x) { if (x) this.expand(); else this.collapse(); }, get populated() { return this._populated; }, set populated(x) { this._populated = x; if (!x && this._expanded) { this.onpopulate(); this._populated = true; } }, onpopulate: function() { // Overriden by subclasses. }, get firstSibling() { var parent = this.element.parentElement; if (!parent) return null; var childElement = parent.firstChild; while (childElement) { if (childElement._section) return childElement._section; childElement = childElement.nextSibling; } return null; }, get lastSibling() { var parent = this.element.parentElement; if (!parent) return null; var childElement = parent.lastChild; while (childElement) { if (childElement._section) return childElement._section; childElement = childElement.previousSibling; } return null; }, get nextSibling() { var curElement = this.element; do { curElement = curElement.nextSibling; } while (curElement && !curElement._section); return curElement ? curElement._section : null; }, get previousSibling() { var curElement = this.element; do { curElement = curElement.previousSibling; } while (curElement && !curElement._section); return curElement ? curElement._section : null; }, expand: function() { if (this._expanded) return; this._expanded = true; this.element.classList.add("expanded"); if (!this._populated) { this.onpopulate(); this._populated = true; } else this.dispatchEventToListeners(WebInspector.Section.Event.VisibleContentDidChange); }, collapse: function() { if (!this._expanded) return; this._expanded = false; this.element.classList.remove("expanded"); }, toggleExpanded: function() { this.expanded = !this.expanded; }, handleClick: function(e) { this.toggleExpanded(); e.stopPropagation(); } }; WebInspector.Section.prototype.__proto__ = WebInspector.Object.prototype;