diff options
Diffstat (limited to 'Source/WebInspectorUI/UserInterface/Views/ScopeBarItem.js')
-rw-r--r-- | Source/WebInspectorUI/UserInterface/Views/ScopeBarItem.js | 101 |
1 files changed, 101 insertions, 0 deletions
diff --git a/Source/WebInspectorUI/UserInterface/Views/ScopeBarItem.js b/Source/WebInspectorUI/UserInterface/Views/ScopeBarItem.js new file mode 100644 index 000000000..aff9e1210 --- /dev/null +++ b/Source/WebInspectorUI/UserInterface/Views/ScopeBarItem.js @@ -0,0 +1,101 @@ +/* + * Copyright (C) 2013, 2015 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.ScopeBarItem = class ScopeBarItem extends WebInspector.Object +{ + constructor(id, label, exclusive, className) + { + super(); + + this._element = document.createElement("li"); + this._element.classList.toggle("exclusive", !!exclusive); + if (className) + this._element.classList.add(className); + this._element.textContent = label; + this._element.addEventListener("click", this._clicked.bind(this)); + + this._id = id; + this._label = label; + this._exclusive = exclusive; + + this._selectedSetting = new WebInspector.Setting("scopebaritem-" + id, false); + + this._element.classList.toggle("selected", this._selectedSetting.value); + } + + // Public + + get element() + { + return this._element; + } + + get id() + { + return this._id; + } + + get label() + { + return this._label; + } + + get exclusive() + { + return this._exclusive; + } + + get selected() + { + return this._selectedSetting.value; + } + + set selected(selected) + { + this.setSelected(selected, false); + } + + setSelected(selected, withModifier) + { + if (this._selectedSetting.value === selected) + return; + + this._element.classList.toggle("selected", selected); + this._selectedSetting.value = selected; + + this.dispatchEventToListeners(WebInspector.ScopeBarItem.Event.SelectionChanged, {withModifier}); + } + + // Private + + _clicked(event) + { + this.setSelected(!this.selected, event.metaKey && !event.ctrlKey && !event.altKey && !event.shiftKey); + } +}; + +WebInspector.ScopeBarItem.Event = { + SelectionChanged: "scope-bar-item-selection-did-change" +}; |