123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212 |
- /*
- * Copyright (C) 2010 Google 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:
- *
- * * Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * * 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.
- * * Neither the name of Google Inc. nor the names of its
- * contributors may be used to endorse or promote products derived from
- * this software without specific prior written permission.
- *
- * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND 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 THE COPYRIGHT
- * OWNER 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
- */
- WebInspector.ShortcutsScreen = function()
- {
- this._sections = /** @type {Object.<string, !WebInspector.ShortcutsSection>} */ ({});
- }
- WebInspector.ShortcutsScreen.prototype = {
- /**
- * @param {string} name
- * @return {!WebInspector.ShortcutsSection}
- */
- section: function(name)
- {
- var section = this._sections[name];
- if (!section)
- this._sections[name] = section = new WebInspector.ShortcutsSection(name);
- return section;
- },
- /**
- * @return {!WebInspector.View}
- */
- createShortcutsTabView: function()
- {
- var orderedSections = [];
- for (var section in this._sections)
- orderedSections.push(this._sections[section]);
- function compareSections(a, b)
- {
- return a.order - b.order;
- }
- orderedSections.sort(compareSections);
- var view = new WebInspector.View();
- view.element.className = "settings-tab-container";
- view.element.createChild("header").createChild("h3").appendChild(document.createTextNode(WebInspector.UIString("Shortcuts")));
- var scrollPane = view.element.createChild("div", "help-container-wrapper");
- var container = scrollPane.createChild("div");
- container.className = "help-content help-container";
- for (var i = 0; i < orderedSections.length; ++i)
- orderedSections[i].renderSection(container);
- var note = scrollPane.createChild("p", "help-footnote");
- var noteLink = note.createChild("a");
- noteLink.href = "https://developers.google.com/chrome-developer-tools/docs/shortcuts";
- noteLink.target = "_blank";
- noteLink.createTextChild(WebInspector.UIString("Full list of keyboard shortcuts and gestures"));
- return view;
- }
- }
- /**
- * We cannot initialize it here as localized strings are not loaded yet.
- * @type {?WebInspector.ShortcutsScreen}
- */
- WebInspector.shortcutsScreen = null;
- /**
- * @constructor
- * @param {string} name
- */
- WebInspector.ShortcutsSection = function(name)
- {
- this.name = name;
- this._lines = /** @type {!Array.<{key: !Node, text: string}>} */ ([]);
- this.order = ++WebInspector.ShortcutsSection._sequenceNumber;
- };
- WebInspector.ShortcutsSection._sequenceNumber = 0;
- WebInspector.ShortcutsSection.prototype = {
- /**
- * @param {!WebInspector.KeyboardShortcut.Descriptor} key
- * @param {string} description
- */
- addKey: function(key, description)
- {
- this._addLine(this._renderKey(key), description);
- },
- /**
- * @param {!Array.<!WebInspector.KeyboardShortcut.Descriptor>} keys
- * @param {string} description
- */
- addRelatedKeys: function(keys, description)
- {
- this._addLine(this._renderSequence(keys, "/"), description);
- },
- /**
- * @param {!Array.<!WebInspector.KeyboardShortcut.Descriptor>} keys
- * @param {string} description
- */
- addAlternateKeys: function(keys, description)
- {
- this._addLine(this._renderSequence(keys, WebInspector.UIString("or")), description);
- },
- /**
- * @param {!Node} keyElement
- * @param {string} description
- */
- _addLine: function(keyElement, description)
- {
- this._lines.push({ key: keyElement, text: description })
- },
- /**
- * @param {!Element} container
- */
- renderSection: function(container)
- {
- var parent = container.createChild("div", "help-block");
- var headLine = parent.createChild("div", "help-line");
- headLine.createChild("div", "help-key-cell");
- headLine.createChild("div", "help-section-title help-cell").textContent = this.name;
- for (var i = 0; i < this._lines.length; ++i) {
- var line = parent.createChild("div", "help-line");
- var keyCell = line.createChild("div", "help-key-cell");
- keyCell.appendChild(this._lines[i].key);
- keyCell.appendChild(this._createSpan("help-key-delimiter", ":"));
- line.createChild("div", "help-cell").textContent = this._lines[i].text;
- }
- },
- /**
- * @param {!Array.<!WebInspector.KeyboardShortcut.Descriptor>} sequence
- * @param {string} delimiter
- * @return {!Node}
- */
- _renderSequence: function(sequence, delimiter)
- {
- var delimiterSpan = this._createSpan("help-key-delimiter", delimiter);
- return this._joinNodes(sequence.map(this._renderKey.bind(this)), delimiterSpan);
- },
- /**
- * @param {!WebInspector.KeyboardShortcut.Descriptor} key
- * @return {!Node}
- */
- _renderKey: function(key)
- {
- var keyName = key.name;
- var plus = this._createSpan("help-combine-keys", "+");
- return this._joinNodes(keyName.split(" + ").map(this._createSpan.bind(this, "help-key")), plus);
- },
- /**
- * @param {string} className
- * @param {string} textContent
- * @return {!Element}
- */
- _createSpan: function(className, textContent)
- {
- var node = document.createElement("span");
- node.className = className;
- node.textContent = textContent;
- return node;
- },
- /**
- * @param {!Array.<!Element>} nodes
- * @param {!Element} delimiter
- * @return {!Node}
- */
- _joinNodes: function(nodes, delimiter)
- {
- var result = document.createDocumentFragment();
- for (var i = 0; i < nodes.length; ++i) {
- if (i > 0)
- result.appendChild(delimiter.cloneNode(true));
- result.appendChild(nodes[i]);
- }
- return result;
- }
- }
|