@muze-nl/simplystore 0.4.1 → 0.4.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +1 -1
- package/www/assets/css/style.css +2296 -0
- package/www/assets/feather-sprite.svg +1 -0
- package/www/assets/img/simplystore-narrow-white.svg +138 -0
- package/www/assets/img/simplystore-narrow.svg +138 -0
- package/www/assets/img/simplystore-white.svg +153 -0
- package/www/assets/img/simplystore.svg +153 -0
- package/www/codemirror/LICENSE +21 -0
- package/www/codemirror/README.md +47 -0
- package/www/codemirror/addon/lint/javascript-lint.js +65 -0
- package/www/codemirror/addon/lint/lint.css +79 -0
- package/www/codemirror/addon/lint/lint.js +291 -0
- package/www/codemirror/lib/codemirror.css +344 -0
- package/www/codemirror/lib/codemirror.js +9874 -0
- package/www/codemirror/mode/javascript/javascript.js +960 -0
- package/www/codemirror/package.json +52 -0
- package/www/codemirror/theme/material-ocean.css +141 -0
- package/www/index.html +359 -0
|
@@ -0,0 +1,291 @@
|
|
|
1
|
+
// CodeMirror, copyright (c) by Marijn Haverbeke and others
|
|
2
|
+
// Distributed under an MIT license: https://codemirror.net/5/LICENSE
|
|
3
|
+
|
|
4
|
+
(function(mod) {
|
|
5
|
+
if (typeof exports == "object" && typeof module == "object") // CommonJS
|
|
6
|
+
mod(require("../../lib/codemirror"));
|
|
7
|
+
else if (typeof define == "function" && define.amd) // AMD
|
|
8
|
+
define(["../../lib/codemirror"], mod);
|
|
9
|
+
else // Plain browser env
|
|
10
|
+
mod(CodeMirror);
|
|
11
|
+
})(function(CodeMirror) {
|
|
12
|
+
"use strict";
|
|
13
|
+
var GUTTER_ID = "CodeMirror-lint-markers";
|
|
14
|
+
var LINT_LINE_ID = "CodeMirror-lint-line-";
|
|
15
|
+
|
|
16
|
+
function showTooltip(cm, e, content) {
|
|
17
|
+
var tt = document.createElement("div");
|
|
18
|
+
tt.className = "CodeMirror-lint-tooltip cm-s-" + cm.options.theme;
|
|
19
|
+
tt.appendChild(content.cloneNode(true));
|
|
20
|
+
if (cm.state.lint.options.selfContain)
|
|
21
|
+
cm.getWrapperElement().appendChild(tt);
|
|
22
|
+
else
|
|
23
|
+
document.body.appendChild(tt);
|
|
24
|
+
|
|
25
|
+
function position(e) {
|
|
26
|
+
if (!tt.parentNode) return CodeMirror.off(document, "mousemove", position);
|
|
27
|
+
tt.style.top = Math.max(0, e.clientY - tt.offsetHeight - 5) + "px";
|
|
28
|
+
tt.style.left = (e.clientX + 5) + "px";
|
|
29
|
+
}
|
|
30
|
+
CodeMirror.on(document, "mousemove", position);
|
|
31
|
+
position(e);
|
|
32
|
+
if (tt.style.opacity != null) tt.style.opacity = 1;
|
|
33
|
+
return tt;
|
|
34
|
+
}
|
|
35
|
+
function rm(elt) {
|
|
36
|
+
if (elt.parentNode) elt.parentNode.removeChild(elt);
|
|
37
|
+
}
|
|
38
|
+
function hideTooltip(tt) {
|
|
39
|
+
if (!tt.parentNode) return;
|
|
40
|
+
if (tt.style.opacity == null) rm(tt);
|
|
41
|
+
tt.style.opacity = 0;
|
|
42
|
+
setTimeout(function() { rm(tt); }, 600);
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
function showTooltipFor(cm, e, content, node) {
|
|
46
|
+
var tooltip = showTooltip(cm, e, content);
|
|
47
|
+
function hide() {
|
|
48
|
+
CodeMirror.off(node, "mouseout", hide);
|
|
49
|
+
if (tooltip) { hideTooltip(tooltip); tooltip = null; }
|
|
50
|
+
}
|
|
51
|
+
var poll = setInterval(function() {
|
|
52
|
+
if (tooltip) for (var n = node;; n = n.parentNode) {
|
|
53
|
+
if (n && n.nodeType == 11) n = n.host;
|
|
54
|
+
if (n == document.body) return;
|
|
55
|
+
if (!n) { hide(); break; }
|
|
56
|
+
}
|
|
57
|
+
if (!tooltip) return clearInterval(poll);
|
|
58
|
+
}, 400);
|
|
59
|
+
CodeMirror.on(node, "mouseout", hide);
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
function LintState(cm, conf, hasGutter) {
|
|
63
|
+
this.marked = [];
|
|
64
|
+
if (conf instanceof Function) conf = {getAnnotations: conf};
|
|
65
|
+
if (!conf || conf === true) conf = {};
|
|
66
|
+
this.options = {};
|
|
67
|
+
this.linterOptions = conf.options || {};
|
|
68
|
+
for (var prop in defaults) this.options[prop] = defaults[prop];
|
|
69
|
+
for (var prop in conf) {
|
|
70
|
+
if (defaults.hasOwnProperty(prop)) {
|
|
71
|
+
if (conf[prop] != null) this.options[prop] = conf[prop];
|
|
72
|
+
} else if (!conf.options) {
|
|
73
|
+
this.linterOptions[prop] = conf[prop];
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
this.timeout = null;
|
|
77
|
+
this.hasGutter = hasGutter;
|
|
78
|
+
this.onMouseOver = function(e) { onMouseOver(cm, e); };
|
|
79
|
+
this.waitingFor = 0
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
var defaults = {
|
|
83
|
+
highlightLines: false,
|
|
84
|
+
tooltips: true,
|
|
85
|
+
delay: 500,
|
|
86
|
+
lintOnChange: true,
|
|
87
|
+
getAnnotations: null,
|
|
88
|
+
async: false,
|
|
89
|
+
selfContain: null,
|
|
90
|
+
formatAnnotation: null,
|
|
91
|
+
onUpdateLinting: null
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
function clearMarks(cm) {
|
|
95
|
+
var state = cm.state.lint;
|
|
96
|
+
if (state.hasGutter) cm.clearGutter(GUTTER_ID);
|
|
97
|
+
if (state.options.highlightLines) clearErrorLines(cm);
|
|
98
|
+
for (var i = 0; i < state.marked.length; ++i)
|
|
99
|
+
state.marked[i].clear();
|
|
100
|
+
state.marked.length = 0;
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
function clearErrorLines(cm) {
|
|
104
|
+
cm.eachLine(function(line) {
|
|
105
|
+
var has = line.wrapClass && /\bCodeMirror-lint-line-\w+\b/.exec(line.wrapClass);
|
|
106
|
+
if (has) cm.removeLineClass(line, "wrap", has[0]);
|
|
107
|
+
})
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
function makeMarker(cm, labels, severity, multiple, tooltips) {
|
|
111
|
+
var marker = document.createElement("div"), inner = marker;
|
|
112
|
+
marker.className = "CodeMirror-lint-marker CodeMirror-lint-marker-" + severity;
|
|
113
|
+
if (multiple) {
|
|
114
|
+
inner = marker.appendChild(document.createElement("div"));
|
|
115
|
+
inner.className = "CodeMirror-lint-marker CodeMirror-lint-marker-multiple";
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
if (tooltips != false) CodeMirror.on(inner, "mouseover", function(e) {
|
|
119
|
+
showTooltipFor(cm, e, labels, inner);
|
|
120
|
+
});
|
|
121
|
+
|
|
122
|
+
return marker;
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
function getMaxSeverity(a, b) {
|
|
126
|
+
if (a == "error") return a;
|
|
127
|
+
else return b;
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
function groupByLine(annotations) {
|
|
131
|
+
var lines = [];
|
|
132
|
+
for (var i = 0; i < annotations.length; ++i) {
|
|
133
|
+
var ann = annotations[i], line = ann.from.line;
|
|
134
|
+
(lines[line] || (lines[line] = [])).push(ann);
|
|
135
|
+
}
|
|
136
|
+
return lines;
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
function annotationTooltip(ann) {
|
|
140
|
+
var severity = ann.severity;
|
|
141
|
+
if (!severity) severity = "error";
|
|
142
|
+
var tip = document.createElement("div");
|
|
143
|
+
tip.className = "CodeMirror-lint-message CodeMirror-lint-message-" + severity;
|
|
144
|
+
if (typeof ann.messageHTML != 'undefined') {
|
|
145
|
+
tip.innerHTML = ann.messageHTML;
|
|
146
|
+
} else {
|
|
147
|
+
tip.appendChild(document.createTextNode(ann.message));
|
|
148
|
+
}
|
|
149
|
+
return tip;
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
function lintAsync(cm, getAnnotations) {
|
|
153
|
+
var state = cm.state.lint
|
|
154
|
+
var id = ++state.waitingFor
|
|
155
|
+
function abort() {
|
|
156
|
+
id = -1
|
|
157
|
+
cm.off("change", abort)
|
|
158
|
+
}
|
|
159
|
+
cm.on("change", abort)
|
|
160
|
+
getAnnotations(cm.getValue(), function(annotations, arg2) {
|
|
161
|
+
cm.off("change", abort)
|
|
162
|
+
if (state.waitingFor != id) return
|
|
163
|
+
if (arg2 && annotations instanceof CodeMirror) annotations = arg2
|
|
164
|
+
cm.operation(function() {updateLinting(cm, annotations)})
|
|
165
|
+
}, state.linterOptions, cm);
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
function startLinting(cm) {
|
|
169
|
+
var state = cm.state.lint;
|
|
170
|
+
if (!state) return;
|
|
171
|
+
var options = state.options;
|
|
172
|
+
/*
|
|
173
|
+
* Passing rules in `options` property prevents JSHint (and other linters) from complaining
|
|
174
|
+
* about unrecognized rules like `onUpdateLinting`, `delay`, `lintOnChange`, etc.
|
|
175
|
+
*/
|
|
176
|
+
var getAnnotations = options.getAnnotations || cm.getHelper(CodeMirror.Pos(0, 0), "lint");
|
|
177
|
+
if (!getAnnotations) return;
|
|
178
|
+
if (options.async || getAnnotations.async) {
|
|
179
|
+
lintAsync(cm, getAnnotations)
|
|
180
|
+
} else {
|
|
181
|
+
var annotations = getAnnotations(cm.getValue(), state.linterOptions, cm);
|
|
182
|
+
if (!annotations) return;
|
|
183
|
+
if (annotations.then) annotations.then(function(issues) {
|
|
184
|
+
cm.operation(function() {updateLinting(cm, issues)})
|
|
185
|
+
});
|
|
186
|
+
else cm.operation(function() {updateLinting(cm, annotations)})
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
|
|
190
|
+
function updateLinting(cm, annotationsNotSorted) {
|
|
191
|
+
var state = cm.state.lint;
|
|
192
|
+
if (!state) return;
|
|
193
|
+
var options = state.options;
|
|
194
|
+
clearMarks(cm);
|
|
195
|
+
|
|
196
|
+
var annotations = groupByLine(annotationsNotSorted);
|
|
197
|
+
|
|
198
|
+
for (var line = 0; line < annotations.length; ++line) {
|
|
199
|
+
var anns = annotations[line];
|
|
200
|
+
if (!anns) continue;
|
|
201
|
+
|
|
202
|
+
// filter out duplicate messages
|
|
203
|
+
var message = [];
|
|
204
|
+
anns = anns.filter(function(item) { return message.indexOf(item.message) > -1 ? false : message.push(item.message) });
|
|
205
|
+
|
|
206
|
+
var maxSeverity = null;
|
|
207
|
+
var tipLabel = state.hasGutter && document.createDocumentFragment();
|
|
208
|
+
|
|
209
|
+
for (var i = 0; i < anns.length; ++i) {
|
|
210
|
+
var ann = anns[i];
|
|
211
|
+
var severity = ann.severity;
|
|
212
|
+
if (!severity) severity = "error";
|
|
213
|
+
maxSeverity = getMaxSeverity(maxSeverity, severity);
|
|
214
|
+
|
|
215
|
+
if (options.formatAnnotation) ann = options.formatAnnotation(ann);
|
|
216
|
+
if (state.hasGutter) tipLabel.appendChild(annotationTooltip(ann));
|
|
217
|
+
|
|
218
|
+
if (ann.to) state.marked.push(cm.markText(ann.from, ann.to, {
|
|
219
|
+
className: "CodeMirror-lint-mark CodeMirror-lint-mark-" + severity,
|
|
220
|
+
__annotation: ann
|
|
221
|
+
}));
|
|
222
|
+
}
|
|
223
|
+
// use original annotations[line] to show multiple messages
|
|
224
|
+
if (state.hasGutter)
|
|
225
|
+
cm.setGutterMarker(line, GUTTER_ID, makeMarker(cm, tipLabel, maxSeverity, annotations[line].length > 1,
|
|
226
|
+
options.tooltips));
|
|
227
|
+
|
|
228
|
+
if (options.highlightLines)
|
|
229
|
+
cm.addLineClass(line, "wrap", LINT_LINE_ID + maxSeverity);
|
|
230
|
+
}
|
|
231
|
+
if (options.onUpdateLinting) options.onUpdateLinting(annotationsNotSorted, annotations, cm);
|
|
232
|
+
}
|
|
233
|
+
|
|
234
|
+
function onChange(cm) {
|
|
235
|
+
var state = cm.state.lint;
|
|
236
|
+
if (!state) return;
|
|
237
|
+
clearTimeout(state.timeout);
|
|
238
|
+
state.timeout = setTimeout(function(){startLinting(cm);}, state.options.delay);
|
|
239
|
+
}
|
|
240
|
+
|
|
241
|
+
function popupTooltips(cm, annotations, e) {
|
|
242
|
+
var target = e.target || e.srcElement;
|
|
243
|
+
var tooltip = document.createDocumentFragment();
|
|
244
|
+
for (var i = 0; i < annotations.length; i++) {
|
|
245
|
+
var ann = annotations[i];
|
|
246
|
+
tooltip.appendChild(annotationTooltip(ann));
|
|
247
|
+
}
|
|
248
|
+
showTooltipFor(cm, e, tooltip, target);
|
|
249
|
+
}
|
|
250
|
+
|
|
251
|
+
function onMouseOver(cm, e) {
|
|
252
|
+
var target = e.target || e.srcElement;
|
|
253
|
+
if (!/\bCodeMirror-lint-mark-/.test(target.className)) return;
|
|
254
|
+
var box = target.getBoundingClientRect(), x = (box.left + box.right) / 2, y = (box.top + box.bottom) / 2;
|
|
255
|
+
var spans = cm.findMarksAt(cm.coordsChar({left: x, top: y}, "client"));
|
|
256
|
+
|
|
257
|
+
var annotations = [];
|
|
258
|
+
for (var i = 0; i < spans.length; ++i) {
|
|
259
|
+
var ann = spans[i].__annotation;
|
|
260
|
+
if (ann) annotations.push(ann);
|
|
261
|
+
}
|
|
262
|
+
if (annotations.length) popupTooltips(cm, annotations, e);
|
|
263
|
+
}
|
|
264
|
+
|
|
265
|
+
CodeMirror.defineOption("lint", false, function(cm, val, old) {
|
|
266
|
+
if (old && old != CodeMirror.Init) {
|
|
267
|
+
clearMarks(cm);
|
|
268
|
+
if (cm.state.lint.options.lintOnChange !== false)
|
|
269
|
+
cm.off("change", onChange);
|
|
270
|
+
CodeMirror.off(cm.getWrapperElement(), "mouseover", cm.state.lint.onMouseOver);
|
|
271
|
+
clearTimeout(cm.state.lint.timeout);
|
|
272
|
+
delete cm.state.lint;
|
|
273
|
+
}
|
|
274
|
+
|
|
275
|
+
if (val) {
|
|
276
|
+
var gutters = cm.getOption("gutters"), hasLintGutter = false;
|
|
277
|
+
for (var i = 0; i < gutters.length; ++i) if (gutters[i] == GUTTER_ID) hasLintGutter = true;
|
|
278
|
+
var state = cm.state.lint = new LintState(cm, val, hasLintGutter);
|
|
279
|
+
if (state.options.lintOnChange)
|
|
280
|
+
cm.on("change", onChange);
|
|
281
|
+
if (state.options.tooltips != false && state.options.tooltips != "gutter")
|
|
282
|
+
CodeMirror.on(cm.getWrapperElement(), "mouseover", state.onMouseOver);
|
|
283
|
+
|
|
284
|
+
startLinting(cm);
|
|
285
|
+
}
|
|
286
|
+
});
|
|
287
|
+
|
|
288
|
+
CodeMirror.defineExtension("performLint", function() {
|
|
289
|
+
startLinting(this);
|
|
290
|
+
});
|
|
291
|
+
});
|
|
@@ -0,0 +1,344 @@
|
|
|
1
|
+
/* BASICS */
|
|
2
|
+
|
|
3
|
+
.CodeMirror {
|
|
4
|
+
/* Set height, width, borders, and global font properties here */
|
|
5
|
+
font-family: monospace;
|
|
6
|
+
height: 300px;
|
|
7
|
+
color: black;
|
|
8
|
+
direction: ltr;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
/* PADDING */
|
|
12
|
+
|
|
13
|
+
.CodeMirror-lines {
|
|
14
|
+
padding: 4px 0; /* Vertical padding around content */
|
|
15
|
+
}
|
|
16
|
+
.CodeMirror pre.CodeMirror-line,
|
|
17
|
+
.CodeMirror pre.CodeMirror-line-like {
|
|
18
|
+
padding: 0 4px; /* Horizontal padding of content */
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
.CodeMirror-scrollbar-filler, .CodeMirror-gutter-filler {
|
|
22
|
+
background-color: white; /* The little square between H and V scrollbars */
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
/* GUTTER */
|
|
26
|
+
|
|
27
|
+
.CodeMirror-gutters {
|
|
28
|
+
border-right: 1px solid #ddd;
|
|
29
|
+
background-color: #f7f7f7;
|
|
30
|
+
white-space: nowrap;
|
|
31
|
+
}
|
|
32
|
+
.CodeMirror-linenumbers {}
|
|
33
|
+
.CodeMirror-linenumber {
|
|
34
|
+
padding: 0 3px 0 5px;
|
|
35
|
+
min-width: 20px;
|
|
36
|
+
text-align: right;
|
|
37
|
+
color: #999;
|
|
38
|
+
white-space: nowrap;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
.CodeMirror-guttermarker { color: black; }
|
|
42
|
+
.CodeMirror-guttermarker-subtle { color: #999; }
|
|
43
|
+
|
|
44
|
+
/* CURSOR */
|
|
45
|
+
|
|
46
|
+
.CodeMirror-cursor {
|
|
47
|
+
border-left: 1px solid black;
|
|
48
|
+
border-right: none;
|
|
49
|
+
width: 0;
|
|
50
|
+
}
|
|
51
|
+
/* Shown when moving in bi-directional text */
|
|
52
|
+
.CodeMirror div.CodeMirror-secondarycursor {
|
|
53
|
+
border-left: 1px solid silver;
|
|
54
|
+
}
|
|
55
|
+
.cm-fat-cursor .CodeMirror-cursor {
|
|
56
|
+
width: auto;
|
|
57
|
+
border: 0 !important;
|
|
58
|
+
background: #7e7;
|
|
59
|
+
}
|
|
60
|
+
.cm-fat-cursor div.CodeMirror-cursors {
|
|
61
|
+
z-index: 1;
|
|
62
|
+
}
|
|
63
|
+
.cm-fat-cursor .CodeMirror-line::selection,
|
|
64
|
+
.cm-fat-cursor .CodeMirror-line > span::selection,
|
|
65
|
+
.cm-fat-cursor .CodeMirror-line > span > span::selection { background: transparent; }
|
|
66
|
+
.cm-fat-cursor .CodeMirror-line::-moz-selection,
|
|
67
|
+
.cm-fat-cursor .CodeMirror-line > span::-moz-selection,
|
|
68
|
+
.cm-fat-cursor .CodeMirror-line > span > span::-moz-selection { background: transparent; }
|
|
69
|
+
.cm-fat-cursor { caret-color: transparent; }
|
|
70
|
+
@-moz-keyframes blink {
|
|
71
|
+
0% {}
|
|
72
|
+
50% { background-color: transparent; }
|
|
73
|
+
100% {}
|
|
74
|
+
}
|
|
75
|
+
@-webkit-keyframes blink {
|
|
76
|
+
0% {}
|
|
77
|
+
50% { background-color: transparent; }
|
|
78
|
+
100% {}
|
|
79
|
+
}
|
|
80
|
+
@keyframes blink {
|
|
81
|
+
0% {}
|
|
82
|
+
50% { background-color: transparent; }
|
|
83
|
+
100% {}
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
/* Can style cursor different in overwrite (non-insert) mode */
|
|
87
|
+
.CodeMirror-overwrite .CodeMirror-cursor {}
|
|
88
|
+
|
|
89
|
+
.cm-tab { display: inline-block; text-decoration: inherit; }
|
|
90
|
+
|
|
91
|
+
.CodeMirror-rulers {
|
|
92
|
+
position: absolute;
|
|
93
|
+
left: 0; right: 0; top: -50px; bottom: 0;
|
|
94
|
+
overflow: hidden;
|
|
95
|
+
}
|
|
96
|
+
.CodeMirror-ruler {
|
|
97
|
+
border-left: 1px solid #ccc;
|
|
98
|
+
top: 0; bottom: 0;
|
|
99
|
+
position: absolute;
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
/* DEFAULT THEME */
|
|
103
|
+
|
|
104
|
+
.cm-s-default .cm-header {color: blue;}
|
|
105
|
+
.cm-s-default .cm-quote {color: #090;}
|
|
106
|
+
.cm-negative {color: #d44;}
|
|
107
|
+
.cm-positive {color: #292;}
|
|
108
|
+
.cm-header, .cm-strong {font-weight: bold;}
|
|
109
|
+
.cm-em {font-style: italic;}
|
|
110
|
+
.cm-link {text-decoration: underline;}
|
|
111
|
+
.cm-strikethrough {text-decoration: line-through;}
|
|
112
|
+
|
|
113
|
+
.cm-s-default .cm-keyword {color: #708;}
|
|
114
|
+
.cm-s-default .cm-atom {color: #219;}
|
|
115
|
+
.cm-s-default .cm-number {color: #164;}
|
|
116
|
+
.cm-s-default .cm-def {color: #00f;}
|
|
117
|
+
.cm-s-default .cm-variable,
|
|
118
|
+
.cm-s-default .cm-punctuation,
|
|
119
|
+
.cm-s-default .cm-property,
|
|
120
|
+
.cm-s-default .cm-operator {}
|
|
121
|
+
.cm-s-default .cm-variable-2 {color: #05a;}
|
|
122
|
+
.cm-s-default .cm-variable-3, .cm-s-default .cm-type {color: #085;}
|
|
123
|
+
.cm-s-default .cm-comment {color: #a50;}
|
|
124
|
+
.cm-s-default .cm-string {color: #a11;}
|
|
125
|
+
.cm-s-default .cm-string-2 {color: #f50;}
|
|
126
|
+
.cm-s-default .cm-meta {color: #555;}
|
|
127
|
+
.cm-s-default .cm-qualifier {color: #555;}
|
|
128
|
+
.cm-s-default .cm-builtin {color: #30a;}
|
|
129
|
+
.cm-s-default .cm-bracket {color: #997;}
|
|
130
|
+
.cm-s-default .cm-tag {color: #170;}
|
|
131
|
+
.cm-s-default .cm-attribute {color: #00c;}
|
|
132
|
+
.cm-s-default .cm-hr {color: #999;}
|
|
133
|
+
.cm-s-default .cm-link {color: #00c;}
|
|
134
|
+
|
|
135
|
+
.cm-s-default .cm-error {color: #f00;}
|
|
136
|
+
.cm-invalidchar {color: #f00;}
|
|
137
|
+
|
|
138
|
+
.CodeMirror-composing { border-bottom: 2px solid; }
|
|
139
|
+
|
|
140
|
+
/* Default styles for common addons */
|
|
141
|
+
|
|
142
|
+
div.CodeMirror span.CodeMirror-matchingbracket {color: #0b0;}
|
|
143
|
+
div.CodeMirror span.CodeMirror-nonmatchingbracket {color: #a22;}
|
|
144
|
+
.CodeMirror-matchingtag { background: rgba(255, 150, 0, .3); }
|
|
145
|
+
.CodeMirror-activeline-background {background: #e8f2ff;}
|
|
146
|
+
|
|
147
|
+
/* STOP */
|
|
148
|
+
|
|
149
|
+
/* The rest of this file contains styles related to the mechanics of
|
|
150
|
+
the editor. You probably shouldn't touch them. */
|
|
151
|
+
|
|
152
|
+
.CodeMirror {
|
|
153
|
+
position: relative;
|
|
154
|
+
overflow: hidden;
|
|
155
|
+
background: white;
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
.CodeMirror-scroll {
|
|
159
|
+
overflow: scroll !important; /* Things will break if this is overridden */
|
|
160
|
+
/* 50px is the magic margin used to hide the element's real scrollbars */
|
|
161
|
+
/* See overflow: hidden in .CodeMirror */
|
|
162
|
+
margin-bottom: -50px; margin-right: -50px;
|
|
163
|
+
padding-bottom: 50px;
|
|
164
|
+
height: 100%;
|
|
165
|
+
outline: none; /* Prevent dragging from highlighting the element */
|
|
166
|
+
position: relative;
|
|
167
|
+
z-index: 0;
|
|
168
|
+
}
|
|
169
|
+
.CodeMirror-sizer {
|
|
170
|
+
position: relative;
|
|
171
|
+
border-right: 50px solid transparent;
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
/* The fake, visible scrollbars. Used to force redraw during scrolling
|
|
175
|
+
before actual scrolling happens, thus preventing shaking and
|
|
176
|
+
flickering artifacts. */
|
|
177
|
+
.CodeMirror-vscrollbar, .CodeMirror-hscrollbar, .CodeMirror-scrollbar-filler, .CodeMirror-gutter-filler {
|
|
178
|
+
position: absolute;
|
|
179
|
+
z-index: 6;
|
|
180
|
+
display: none;
|
|
181
|
+
outline: none;
|
|
182
|
+
}
|
|
183
|
+
.CodeMirror-vscrollbar {
|
|
184
|
+
right: 0; top: 0;
|
|
185
|
+
overflow-x: hidden;
|
|
186
|
+
overflow-y: scroll;
|
|
187
|
+
}
|
|
188
|
+
.CodeMirror-hscrollbar {
|
|
189
|
+
bottom: 0; left: 0;
|
|
190
|
+
overflow-y: hidden;
|
|
191
|
+
overflow-x: scroll;
|
|
192
|
+
}
|
|
193
|
+
.CodeMirror-scrollbar-filler {
|
|
194
|
+
right: 0; bottom: 0;
|
|
195
|
+
}
|
|
196
|
+
.CodeMirror-gutter-filler {
|
|
197
|
+
left: 0; bottom: 0;
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
.CodeMirror-gutters {
|
|
201
|
+
position: absolute; left: 0; top: 0;
|
|
202
|
+
min-height: 100%;
|
|
203
|
+
z-index: 3;
|
|
204
|
+
}
|
|
205
|
+
.CodeMirror-gutter {
|
|
206
|
+
white-space: normal;
|
|
207
|
+
height: 100%;
|
|
208
|
+
display: inline-block;
|
|
209
|
+
vertical-align: top;
|
|
210
|
+
margin-bottom: -50px;
|
|
211
|
+
}
|
|
212
|
+
.CodeMirror-gutter-wrapper {
|
|
213
|
+
position: absolute;
|
|
214
|
+
z-index: 4;
|
|
215
|
+
background: none !important;
|
|
216
|
+
border: none !important;
|
|
217
|
+
}
|
|
218
|
+
.CodeMirror-gutter-background {
|
|
219
|
+
position: absolute;
|
|
220
|
+
top: 0; bottom: 0;
|
|
221
|
+
z-index: 4;
|
|
222
|
+
}
|
|
223
|
+
.CodeMirror-gutter-elt {
|
|
224
|
+
position: absolute;
|
|
225
|
+
cursor: default;
|
|
226
|
+
z-index: 4;
|
|
227
|
+
}
|
|
228
|
+
.CodeMirror-gutter-wrapper ::selection { background-color: transparent }
|
|
229
|
+
.CodeMirror-gutter-wrapper ::-moz-selection { background-color: transparent }
|
|
230
|
+
|
|
231
|
+
.CodeMirror-lines {
|
|
232
|
+
cursor: text;
|
|
233
|
+
min-height: 1px; /* prevents collapsing before first draw */
|
|
234
|
+
}
|
|
235
|
+
.CodeMirror pre.CodeMirror-line,
|
|
236
|
+
.CodeMirror pre.CodeMirror-line-like {
|
|
237
|
+
/* Reset some styles that the rest of the page might have set */
|
|
238
|
+
-moz-border-radius: 0; -webkit-border-radius: 0; border-radius: 0;
|
|
239
|
+
border-width: 0;
|
|
240
|
+
background: transparent;
|
|
241
|
+
font-family: inherit;
|
|
242
|
+
font-size: inherit;
|
|
243
|
+
margin: 0;
|
|
244
|
+
white-space: pre;
|
|
245
|
+
word-wrap: normal;
|
|
246
|
+
line-height: inherit;
|
|
247
|
+
color: inherit;
|
|
248
|
+
z-index: 2;
|
|
249
|
+
position: relative;
|
|
250
|
+
overflow: visible;
|
|
251
|
+
-webkit-tap-highlight-color: transparent;
|
|
252
|
+
-webkit-font-variant-ligatures: contextual;
|
|
253
|
+
font-variant-ligatures: contextual;
|
|
254
|
+
}
|
|
255
|
+
.CodeMirror-wrap pre.CodeMirror-line,
|
|
256
|
+
.CodeMirror-wrap pre.CodeMirror-line-like {
|
|
257
|
+
word-wrap: break-word;
|
|
258
|
+
white-space: pre-wrap;
|
|
259
|
+
word-break: normal;
|
|
260
|
+
}
|
|
261
|
+
|
|
262
|
+
.CodeMirror-linebackground {
|
|
263
|
+
position: absolute;
|
|
264
|
+
left: 0; right: 0; top: 0; bottom: 0;
|
|
265
|
+
z-index: 0;
|
|
266
|
+
}
|
|
267
|
+
|
|
268
|
+
.CodeMirror-linewidget {
|
|
269
|
+
position: relative;
|
|
270
|
+
z-index: 2;
|
|
271
|
+
padding: 0.1px; /* Force widget margins to stay inside of the container */
|
|
272
|
+
}
|
|
273
|
+
|
|
274
|
+
.CodeMirror-widget {}
|
|
275
|
+
|
|
276
|
+
.CodeMirror-rtl pre { direction: rtl; }
|
|
277
|
+
|
|
278
|
+
.CodeMirror-code {
|
|
279
|
+
outline: none;
|
|
280
|
+
}
|
|
281
|
+
|
|
282
|
+
/* Force content-box sizing for the elements where we expect it */
|
|
283
|
+
.CodeMirror-scroll,
|
|
284
|
+
.CodeMirror-sizer,
|
|
285
|
+
.CodeMirror-gutter,
|
|
286
|
+
.CodeMirror-gutters,
|
|
287
|
+
.CodeMirror-linenumber {
|
|
288
|
+
-moz-box-sizing: content-box;
|
|
289
|
+
box-sizing: content-box;
|
|
290
|
+
}
|
|
291
|
+
|
|
292
|
+
.CodeMirror-measure {
|
|
293
|
+
position: absolute;
|
|
294
|
+
width: 100%;
|
|
295
|
+
height: 0;
|
|
296
|
+
overflow: hidden;
|
|
297
|
+
visibility: hidden;
|
|
298
|
+
}
|
|
299
|
+
|
|
300
|
+
.CodeMirror-cursor {
|
|
301
|
+
position: absolute;
|
|
302
|
+
pointer-events: none;
|
|
303
|
+
}
|
|
304
|
+
.CodeMirror-measure pre { position: static; }
|
|
305
|
+
|
|
306
|
+
div.CodeMirror-cursors {
|
|
307
|
+
visibility: hidden;
|
|
308
|
+
position: relative;
|
|
309
|
+
z-index: 3;
|
|
310
|
+
}
|
|
311
|
+
div.CodeMirror-dragcursors {
|
|
312
|
+
visibility: visible;
|
|
313
|
+
}
|
|
314
|
+
|
|
315
|
+
.CodeMirror-focused div.CodeMirror-cursors {
|
|
316
|
+
visibility: visible;
|
|
317
|
+
}
|
|
318
|
+
|
|
319
|
+
.CodeMirror-selected { background: #d9d9d9; }
|
|
320
|
+
.CodeMirror-focused .CodeMirror-selected { background: #d7d4f0; }
|
|
321
|
+
.CodeMirror-crosshair { cursor: crosshair; }
|
|
322
|
+
.CodeMirror-line::selection, .CodeMirror-line > span::selection, .CodeMirror-line > span > span::selection { background: #d7d4f0; }
|
|
323
|
+
.CodeMirror-line::-moz-selection, .CodeMirror-line > span::-moz-selection, .CodeMirror-line > span > span::-moz-selection { background: #d7d4f0; }
|
|
324
|
+
|
|
325
|
+
.cm-searching {
|
|
326
|
+
background-color: #ffa;
|
|
327
|
+
background-color: rgba(255, 255, 0, .4);
|
|
328
|
+
}
|
|
329
|
+
|
|
330
|
+
/* Used to force a border model for a node */
|
|
331
|
+
.cm-force-border { padding-right: .1px; }
|
|
332
|
+
|
|
333
|
+
@media print {
|
|
334
|
+
/* Hide the cursor when printing */
|
|
335
|
+
.CodeMirror div.CodeMirror-cursors {
|
|
336
|
+
visibility: hidden;
|
|
337
|
+
}
|
|
338
|
+
}
|
|
339
|
+
|
|
340
|
+
/* See issue #2901 */
|
|
341
|
+
.cm-tab-wrap-hack:after { content: ''; }
|
|
342
|
+
|
|
343
|
+
/* Help users use markselection to safely style text background */
|
|
344
|
+
span.CodeMirror-selectedtext { background: none; }
|