diff options
Diffstat (limited to 'js')
39 files changed, 1062 insertions, 322 deletions
diff --git a/js/code-editor/codemirror-ninja/lib/ninja-simple-hint.js b/js/code-editor/codemirror-ninja/lib/ninja-simple-hint.js new file mode 100644 index 00000000..4787b4f8 --- /dev/null +++ b/js/code-editor/codemirror-ninja/lib/ninja-simple-hint.js | |||
@@ -0,0 +1,86 @@ | |||
1 | /* <copyright> | ||
2 | This file contains proprietary software owned by Motorola Mobility, Inc.<br/> | ||
3 | No rights, expressed or implied, whatsoever to this software are provided by Motorola Mobility, Inc. hereunder.<br/> | ||
4 | (c) Copyright 2011 Motorola Mobility, Inc. All Rights Reserved. | ||
5 | </copyright> */ | ||
6 | |||
7 | /* adopted from CodeMirror 2.23 (http://codemirror.net/) */ | ||
8 | |||
9 | (function() { | ||
10 | CodeMirror.simpleHint = function(editor, getHints) { | ||
11 | // We want a single cursor position. | ||
12 | if (editor.somethingSelected()) return; | ||
13 | |||
14 | // Ninja override: don't show code hinting if the token is empty | ||
15 | var tempToken = editor.getTokenAt(editor.getCursor()); | ||
16 | if(tempToken && ((tempToken.string === "") || !(/[\S]/gi.test(tempToken.string)))) return;//check that token has only spaces | ||
17 | |||
18 | |||
19 | var result = getHints(editor); | ||
20 | if (!result || !result.list.length) return; | ||
21 | var completions = result.list; | ||
22 | function insert(str) { | ||
23 | editor.replaceRange(str, result.from, result.to); | ||
24 | } | ||
25 | // Ninja override: don't autocomplete to reduce user's typing errors | ||
26 | // if (completions.length == 1) {insert(completions[0]); return true;} | ||
27 | |||
28 | // Build the select widget | ||
29 | var complete = document.createElement("div"); | ||
30 | complete.className = "CodeMirror-completions"; | ||
31 | var sel = complete.appendChild(document.createElement("select")); | ||
32 | // Opera doesn't move the selection when pressing up/down in a | ||
33 | // multi-select, but it does properly support the size property on | ||
34 | // single-selects, so no multi-select is necessary. | ||
35 | if (!window.opera) sel.multiple = true; | ||
36 | for (var i = 0; i < completions.length; ++i) { | ||
37 | var opt = sel.appendChild(document.createElement("option")); | ||
38 | opt.appendChild(document.createTextNode(completions[i])); | ||
39 | } | ||
40 | sel.firstChild.selected = true; | ||
41 | sel.size = Math.min(10, completions.length); | ||
42 | var pos = editor.cursorCoords(); | ||
43 | complete.style.left = pos.x + "px"; | ||
44 | complete.style.top = pos.yBot + "px"; | ||
45 | document.body.appendChild(complete); | ||
46 | // If we're at the edge of the screen, then we want the menu to appear on the left of the cursor. | ||
47 | var winW = window.innerWidth || Math.max(document.body.offsetWidth, document.documentElement.offsetWidth); | ||
48 | if(winW - pos.x < sel.clientWidth) | ||
49 | complete.style.left = (pos.x - sel.clientWidth) + "px"; | ||
50 | // Hack to hide the scrollbar. | ||
51 | if (completions.length <= 10) | ||
52 | complete.style.width = (sel.clientWidth - 1) + "px"; | ||
53 | |||
54 | var done = false; | ||
55 | function close() { | ||
56 | if (done) return; | ||
57 | done = true; | ||
58 | complete.parentNode.removeChild(complete); | ||
59 | } | ||
60 | function pick() { | ||
61 | insert(completions[sel.selectedIndex]); | ||
62 | close(); | ||
63 | setTimeout(function(){editor.focus();}, 50); | ||
64 | } | ||
65 | CodeMirror.connect(sel, "blur", close); | ||
66 | CodeMirror.connect(sel, "keydown", function(event) { | ||
67 | var code = event.keyCode; | ||
68 | // Enter | ||
69 | if (code == 13) {CodeMirror.e_stop(event); pick();} | ||
70 | // Escape | ||
71 | else if (code == 27) {CodeMirror.e_stop(event); close(); editor.focus();} | ||
72 | else if (code != 38 && code != 40) { | ||
73 | close(); editor.focus(); | ||
74 | // Pass the event to the CodeMirror instance so that it can handle things like backspace properly. | ||
75 | editor.triggerOnKeyDown(event); | ||
76 | setTimeout(function(){CodeMirror.simpleHint(editor, getHints);}, 50); | ||
77 | } | ||
78 | }); | ||
79 | CodeMirror.connect(sel, "dblclick", pick); | ||
80 | |||
81 | sel.focus(); | ||
82 | // Opera sometimes ignores focusing a freshly created node | ||
83 | if (window.opera) setTimeout(function(){if (!done) sel.focus();}, 100); | ||
84 | return true; | ||
85 | }; | ||
86 | })(); | ||
diff --git a/js/code-editor/codemirror-ninja/theme/lesser-dark-ninja.css b/js/code-editor/codemirror-ninja/theme/lesser-dark-ninja.css new file mode 100644 index 00000000..fe0e353b --- /dev/null +++ b/js/code-editor/codemirror-ninja/theme/lesser-dark-ninja.css | |||
@@ -0,0 +1,54 @@ | |||
1 | /* <copyright> | ||
2 | This file contains proprietary software owned by Motorola Mobility, Inc.<br/> | ||
3 | No rights, expressed or implied, whatsoever to this software are provided by Motorola Mobility, Inc. hereunder.<br/> | ||
4 | (c) Copyright 2011 Motorola Mobility, Inc. All Rights Reserved. | ||
5 | </copyright> */ | ||
6 | |||
7 | /* adopted from CodeMirror 2.23 (http://codemirror.net/) */ | ||
8 | |||
9 | /* | ||
10 | http://lesscss.org/ dark theme | ||
11 | Ported to CodeMirror by Peter Kroon | ||
12 | */ | ||
13 | |||
14 | .CodeMirror{ | ||
15 | line-height: 15px; | ||
16 | } | ||
17 | .cm-s-lesser-dark { | ||
18 | font-family: 'Bitstream Vera Sans Mono', 'DejaVu Sans Mono', 'Monaco', Courier, monospace !important; | ||
19 | /*font-size:12px;*/ | ||
20 | } | ||
21 | |||
22 | .cm-s-lesser-dark { background: #262626; color: #EBEFE7; text-shadow: 0 -1px 1px #262626; } | ||
23 | .cm-s-lesser-dark div.CodeMirror-selected {background: #45443B !important;} /* 33322B*/ | ||
24 | .cm-s-lesser-dark .CodeMirror-cursor { border-left: 1px solid white !important; } | ||
25 | .cm-s-lesser-dark .CodeMirror-lines { margin-left:3px; margin-right:3px; }/*editable code holder*/ | ||
26 | |||
27 | div.CodeMirror span.CodeMirror-matchingbracket { color: #7EFC7E; }/*65FC65*/ | ||
28 | |||
29 | .cm-s-lesser-dark .CodeMirror-gutter { background: #262626; border-right:1px solid #aaa; padding-right:3px; min-width:2.5em; } | ||
30 | .cm-s-lesser-dark .CodeMirror-gutter-text { color: #777; } | ||
31 | |||
32 | .cm-s-lesser-dark span.cm-keyword { color: #599eff; } | ||
33 | .cm-s-lesser-dark span.cm-atom { color: #C2B470; } | ||
34 | .cm-s-lesser-dark span.cm-number { color: #B35E4D; } | ||
35 | .cm-s-lesser-dark span.cm-def {color: color: white;} | ||
36 | .cm-s-lesser-dark span.cm-variable { color:#D9BF8C; } | ||
37 | .cm-s-lesser-dark span.cm-variable-2 { color: #669199; } | ||
38 | .cm-s-lesser-dark span.cm-variable-3 { color: white; } | ||
39 | .cm-s-lesser-dark span.cm-property {color: #92A75C;} | ||
40 | .cm-s-lesser-dark span.cm-operator {color: #92A75C;} | ||
41 | .cm-s-lesser-dark span.cm-comment { color: #666; } | ||
42 | .cm-s-lesser-dark span.cm-string { color: #BCD279; } | ||
43 | .cm-s-lesser-dark span.cm-string-2 {color: #f50;} | ||
44 | .cm-s-lesser-dark span.cm-meta { color: #738C73; } | ||
45 | .cm-s-lesser-dark span.cm-error { color: #9d1e15; } | ||
46 | .cm-s-lesser-dark span.cm-qualifier {color: #555;} | ||
47 | .cm-s-lesser-dark span.cm-builtin { color: #ff9e59; } | ||
48 | .cm-s-lesser-dark span.cm-bracket { color: #EBEFE7; } | ||
49 | .cm-s-lesser-dark span.cm-tag { color: #669199; } | ||
50 | .cm-s-lesser-dark span.cm-attribute {color: #00c;} | ||
51 | .cm-s-lesser-dark span.cm-header {color: #a0a;} | ||
52 | .cm-s-lesser-dark span.cm-quote {color: #090;} | ||
53 | .cm-s-lesser-dark span.cm-hr {color: #999;} | ||
54 | .cm-s-lesser-dark span.cm-link {color: #00c;} | ||