Web Inspector: Elements: Styles: add icons for various CSS rule types
[WebKit-https.git] / Source / WebInspectorUI / UserInterface / Views / CodeMirrorEditor.js
1 /*
2  * Copyright (C) 2015-2017 Apple Inc. All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions
6  * are met:
7  * 1. Redistributions of source code must retain the above copyright
8  *    notice, this list of conditions and the following disclaimer.
9  * 2. Redistributions in binary form must reproduce the above copyright
10  *    notice, this list of conditions and the following disclaimer in the
11  *    documentation and/or other materials provided with the distribution.
12  *
13  * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS''
14  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
15  * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16  * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS
17  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
18  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
19  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
20  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
21  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
22  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
23  * THE POSSIBILITY OF SUCH DAMAGE.
24  */
25
26 WI.CodeMirrorEditor = class CodeMirrorEditor
27 {
28     static create(element, options)
29     {
30         // CodeMirror's manual scrollbar positioning results in double scrollbars,
31         // nor does it handle braces and brackets well, so default to using LTR.
32         // Clients can override this if custom layout for RTL is available.
33         element.setAttribute("dir", "ltr");
34         element.classList.toggle("read-only", options.readOnly);
35
36         let codeMirror = new CodeMirror(element, {
37             // These values will be overridden by any value with the same key in `options`.
38             indentWithTabs: WI.settings.indentWithTabs.value,
39             indentUnit: WI.settings.indentUnit.value,
40             tabSize: WI.settings.tabSize.value,
41             lineWrapping: WI.settings.enableLineWrapping.value,
42             showWhitespaceCharacters: WI.settings.showWhitespaceCharacters.value,
43             ...options,
44         });
45
46         function listenForChange(setting, codeMirrorOption) {
47             if (options[codeMirrorOption] !== undefined)
48                 return;
49
50             setting.addEventListener(WI.Setting.Event.Changed, (event) => {
51                 codeMirror.setOption(codeMirrorOption, setting.value);
52             });
53         }
54         listenForChange(WI.settings.indentWithTabs, "indentWithTabs");
55         listenForChange(WI.settings.indentUnit, "indentUnit");
56         listenForChange(WI.settings.tabSize, "tabSize");
57         listenForChange(WI.settings.enableLineWrapping, "lineWrapping");
58         listenForChange(WI.settings.showWhitespaceCharacters, "showWhitespaceCharacters");
59
60         // Override some Mac specific keybindings.
61         if (WI.Platform.name === "mac") {
62             codeMirror.addKeyMap({
63                 "Home": () => { codeMirror.scrollIntoView({line: 0, ch: 0}); },
64                 "End": () => { codeMirror.scrollIntoView({line: codeMirror.lineCount() - 1, ch: null}); },
65             });
66         }
67
68         // Set up default controllers that should be present for
69         // all CodeMirror editor instances.
70         new WI.CodeMirrorTextKillController(codeMirror);
71
72         return codeMirror;
73     }
74 };