@dodona/papyros 4.1.1 → 4.1.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/dist/Library.d.ts +11 -0
- package/dist/Library.js +11 -0
- package/dist/Library.js.map +1 -0
- package/dist/ProgrammingLanguage.d.ts +7 -0
- package/dist/ProgrammingLanguage.js +9 -0
- package/dist/ProgrammingLanguage.js.map +1 -0
- package/dist/backend/Backend.d.ts +92 -0
- package/dist/backend/Backend.js +79 -0
- package/dist/backend/Backend.js.map +1 -0
- package/dist/backend/workers/javascript/JavaScriptWorker.d.ts +39 -0
- package/dist/backend/workers/javascript/JavaScriptWorker.js +158 -0
- package/dist/backend/workers/javascript/JavaScriptWorker.js.map +1 -0
- package/dist/backend/workers/javascript/worker.d.ts +1 -0
- package/dist/backend/workers/javascript/worker.js +5 -0
- package/dist/backend/workers/javascript/worker.js.map +1 -0
- package/dist/backend/workers/python/PythonWorker.d.ts +32 -0
- package/dist/backend/workers/python/PythonWorker.js +117 -0
- package/dist/backend/workers/python/PythonWorker.js.map +1 -0
- package/dist/backend/workers/python/python_package.tar.gz.load_by_url +0 -0
- package/dist/backend/workers/python/worker.d.ts +1 -0
- package/dist/backend/workers/python/worker.js +5 -0
- package/dist/backend/workers/python/worker.js.map +1 -0
- package/dist/communication/BackendEvent.d.ts +33 -0
- package/dist/communication/BackendEvent.js +18 -0
- package/dist/communication/BackendEvent.js.map +1 -0
- package/dist/communication/BackendEventQueue.d.ts +59 -0
- package/dist/communication/BackendEventQueue.js +96 -0
- package/dist/communication/BackendEventQueue.js.map +1 -0
- package/dist/communication/BackendManager.d.ts +68 -0
- package/dist/communication/BackendManager.js +99 -0
- package/dist/communication/BackendManager.js.map +1 -0
- package/dist/communication/InputServiceWorker.d.ts +1 -0
- package/dist/communication/InputServiceWorker.js +37 -0
- package/dist/communication/InputServiceWorker.js.map +1 -0
- package/dist/communication/InputWorker.d.ts +22 -0
- package/dist/communication/InputWorker.js +63 -0
- package/dist/communication/InputWorker.js.map +1 -0
- package/dist/frontend/components/CodeRunner.d.ts +9 -0
- package/dist/frontend/components/CodeRunner.js +60 -0
- package/dist/frontend/components/CodeRunner.js.map +1 -0
- package/dist/frontend/components/Debugger.d.ts +7 -0
- package/dist/frontend/components/Debugger.js +75 -0
- package/dist/frontend/components/Debugger.js.map +1 -0
- package/dist/frontend/components/Input.d.ts +13 -0
- package/dist/frontend/components/Input.js +60 -0
- package/dist/frontend/components/Input.js.map +1 -0
- package/dist/frontend/components/Output.d.ts +14 -0
- package/dist/frontend/components/Output.js +157 -0
- package/dist/frontend/components/Output.js.map +1 -0
- package/dist/frontend/components/PapyrosElement.d.ts +8 -0
- package/dist/frontend/components/PapyrosElement.js +24 -0
- package/dist/frontend/components/PapyrosElement.js.map +1 -0
- package/dist/frontend/components/app/App.d.ts +24 -0
- package/dist/frontend/components/app/App.js +207 -0
- package/dist/frontend/components/app/App.js.map +1 -0
- package/dist/frontend/components/app/ExamplePicker.d.ts +7 -0
- package/dist/frontend/components/app/ExamplePicker.js +36 -0
- package/dist/frontend/components/app/ExamplePicker.js.map +1 -0
- package/dist/frontend/components/app/LanguagePicker.d.ts +7 -0
- package/dist/frontend/components/app/LanguagePicker.js +33 -0
- package/dist/frontend/components/app/LanguagePicker.js.map +1 -0
- package/dist/frontend/components/app/ProgrammingLanguagePicker.d.ts +7 -0
- package/dist/frontend/components/app/ProgrammingLanguagePicker.js +38 -0
- package/dist/frontend/components/app/ProgrammingLanguagePicker.js.map +1 -0
- package/dist/frontend/components/app/examples/JavaScriptExamples.d.ts +5 -0
- package/dist/frontend/components/app/examples/JavaScriptExamples.js +16 -0
- package/dist/frontend/components/app/examples/JavaScriptExamples.js.map +1 -0
- package/dist/frontend/components/app/examples/PythonExamples.d.ts +14 -0
- package/dist/frontend/components/app/examples/PythonExamples.js +163 -0
- package/dist/frontend/components/app/examples/PythonExamples.js.map +1 -0
- package/dist/frontend/components/app/themes/ThemePicker.d.ts +11 -0
- package/dist/frontend/components/app/themes/ThemePicker.js +48 -0
- package/dist/frontend/components/app/themes/ThemePicker.js.map +1 -0
- package/dist/frontend/components/app/themes/ThemedButton.d.ts +9 -0
- package/dist/frontend/components/app/themes/ThemedButton.js +53 -0
- package/dist/frontend/components/app/themes/ThemedButton.js.map +1 -0
- package/dist/frontend/components/code_mirror/BatchInputEditor.d.ts +8 -0
- package/dist/frontend/components/code_mirror/BatchInputEditor.js +51 -0
- package/dist/frontend/components/code_mirror/BatchInputEditor.js.map +1 -0
- package/dist/frontend/components/code_mirror/CodeEditor.d.ts +24 -0
- package/dist/frontend/components/code_mirror/CodeEditor.js +204 -0
- package/dist/frontend/components/code_mirror/CodeEditor.js.map +1 -0
- package/dist/frontend/components/code_mirror/CodeMirrorEditor.d.ts +22 -0
- package/dist/frontend/components/code_mirror/CodeMirrorEditor.js +111 -0
- package/dist/frontend/components/code_mirror/CodeMirrorEditor.js.map +1 -0
- package/dist/frontend/components/code_mirror/Extensions.d.ts +15 -0
- package/dist/frontend/components/code_mirror/Extensions.js +164 -0
- package/dist/frontend/components/code_mirror/Extensions.js.map +1 -0
- package/dist/frontend/components/code_mirror/MaterialTheme.d.ts +5 -0
- package/dist/frontend/components/code_mirror/MaterialTheme.js +115 -0
- package/dist/frontend/components/code_mirror/MaterialTheme.js.map +1 -0
- package/dist/frontend/components/code_runner/ButtonLint.d.ts +9 -0
- package/dist/frontend/components/code_runner/ButtonLint.js +72 -0
- package/dist/frontend/components/code_runner/ButtonLint.js.map +1 -0
- package/dist/frontend/components/code_runner/Code.d.ts +7 -0
- package/dist/frontend/components/code_runner/Code.js +48 -0
- package/dist/frontend/components/code_runner/Code.js.map +1 -0
- package/dist/frontend/components/code_runner/RunState.d.ts +7 -0
- package/dist/frontend/components/code_runner/RunState.js +41 -0
- package/dist/frontend/components/code_runner/RunState.js.map +1 -0
- package/dist/frontend/components/input/BatchInput.d.ts +9 -0
- package/dist/frontend/components/input/BatchInput.js +53 -0
- package/dist/frontend/components/input/BatchInput.js.map +1 -0
- package/dist/frontend/components/input/InteractiveInput.d.ts +13 -0
- package/dist/frontend/components/input/InteractiveInput.js +71 -0
- package/dist/frontend/components/input/InteractiveInput.js.map +1 -0
- package/dist/frontend/state/Constants.d.ts +38 -0
- package/dist/frontend/state/Constants.js +111 -0
- package/dist/frontend/state/Constants.js.map +1 -0
- package/dist/frontend/state/Debugger.d.ts +23 -0
- package/dist/frontend/state/Debugger.js +86 -0
- package/dist/frontend/state/Debugger.js.map +1 -0
- package/dist/frontend/state/Examples.d.ts +11 -0
- package/dist/frontend/state/Examples.js +36 -0
- package/dist/frontend/state/Examples.js.map +1 -0
- package/dist/frontend/state/I18n.d.ts +16 -0
- package/dist/frontend/state/I18n.js +75 -0
- package/dist/frontend/state/I18n.js.map +1 -0
- package/dist/frontend/state/InputOutput.d.ts +64 -0
- package/dist/frontend/state/InputOutput.js +146 -0
- package/dist/frontend/state/InputOutput.js.map +1 -0
- package/dist/frontend/state/Papyros.d.ts +40 -0
- package/dist/frontend/state/Papyros.js +115 -0
- package/dist/frontend/state/Papyros.js.map +1 -0
- package/dist/frontend/state/Runner.d.ts +123 -0
- package/dist/frontend/state/Runner.js +372 -0
- package/dist/frontend/state/Runner.js.map +1 -0
- package/dist/frontend/state/Test.d.ts +10 -0
- package/dist/frontend/state/Test.js +43 -0
- package/dist/frontend/state/Test.js.map +1 -0
- package/dist/frontend/state/Translations.d.ts +178 -0
- package/dist/frontend/state/Translations.js +187 -0
- package/dist/frontend/state/Translations.js.map +1 -0
- package/dist/frontend/state/themes/blue-dark.d.ts +2 -0
- package/dist/frontend/state/themes/blue-dark.js +56 -0
- package/dist/frontend/state/themes/blue-dark.js.map +1 -0
- package/dist/frontend/state/themes/blue-light.d.ts +2 -0
- package/dist/frontend/state/themes/blue-light.js +56 -0
- package/dist/frontend/state/themes/blue-light.js.map +1 -0
- package/dist/frontend/state/themes/green-dark.d.ts +2 -0
- package/dist/frontend/state/themes/green-dark.js +56 -0
- package/dist/frontend/state/themes/green-dark.js.map +1 -0
- package/dist/frontend/state/themes/green-light.d.ts +2 -0
- package/dist/frontend/state/themes/green-light.js +56 -0
- package/dist/frontend/state/themes/green-light.js.map +1 -0
- package/dist/frontend/state/themes/red-dark.d.ts +2 -0
- package/dist/frontend/state/themes/red-dark.js +56 -0
- package/dist/frontend/state/themes/red-dark.js.map +1 -0
- package/dist/frontend/state/themes/red-light.d.ts +2 -0
- package/dist/frontend/state/themes/red-light.js +56 -0
- package/dist/frontend/state/themes/red-light.js.map +1 -0
- package/dist/util/Logging.d.ts +15 -0
- package/dist/util/Logging.js +30 -0
- package/dist/util/Logging.js.map +1 -0
- package/dist/util/Util.d.ts +8 -0
- package/dist/util/Util.js +48 -0
- package/dist/util/Util.js.map +1 -0
- package/package.json +1 -1
- package/dist/assets/__vite-browser-external-9wXp6ZBx.js +0 -1
- package/dist/assets/__vite-browser-external-BIHI7g3E.js +0 -1
- package/dist/assets/index-C1AWjGcU.js +0 -2202
- package/dist/assets/manifest-BaVmi6rC.json +0 -15
- package/dist/assets/python_package.tar.gz-B8aMWvGt.load_by_url +0 -0
- package/dist/assets/worker-BhABRh01.js +0 -5
- package/dist/assets/worker-C2Ju1j5g.js +0 -110
- package/dist/index.html +0 -26
- package/dist/manifest.json +0 -15
- package/dist/robots.txt +0 -3
|
@@ -0,0 +1,204 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
8
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
9
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
10
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
11
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
12
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
13
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
14
|
+
});
|
|
15
|
+
};
|
|
16
|
+
import { customElement } from "lit/decorators.js";
|
|
17
|
+
import { CodeMirrorEditor } from "./CodeMirrorEditor";
|
|
18
|
+
import { drawSelection, EditorView, highlightActiveLine, highlightActiveLineGutter, highlightSpecialChars, keymap, lineNumbers, rectangularSelection, } from "@codemirror/view";
|
|
19
|
+
import { defaultKeymap, history, historyKeymap, indentWithTab } from "@codemirror/commands";
|
|
20
|
+
import { bracketMatching, foldGutter, indentOnInput, indentUnit } from "@codemirror/language";
|
|
21
|
+
import { EditorState } from "@codemirror/state";
|
|
22
|
+
import { acceptCompletion, autocompletion, closeBrackets, closeBracketsKeymap, completionKeymap, } from "@codemirror/autocomplete";
|
|
23
|
+
import { highlightSelectionMatches, searchKeymap } from "@codemirror/search";
|
|
24
|
+
import { linter, lintGutter, lintKeymap } from "@codemirror/lint";
|
|
25
|
+
import { css } from "lit";
|
|
26
|
+
import { javascript } from "@codemirror/lang-javascript";
|
|
27
|
+
import { python } from "@codemirror/lang-python";
|
|
28
|
+
import { debugLineExtension, setDebugLines, setTestLines, testCodeWidgetExtension, testLineExtension, } from "./Extensions";
|
|
29
|
+
import readOnlyRangesExtension from "codemirror-readonly-ranges";
|
|
30
|
+
const tabCompletionKeyMap = [{ key: "Tab", run: acceptCompletion }];
|
|
31
|
+
const languageExtensions = {
|
|
32
|
+
JavaScript: javascript(),
|
|
33
|
+
Python: python(),
|
|
34
|
+
};
|
|
35
|
+
let CodeEditor = class CodeEditor extends CodeMirrorEditor {
|
|
36
|
+
static get styles() {
|
|
37
|
+
return css `
|
|
38
|
+
:host {
|
|
39
|
+
width: 100%;
|
|
40
|
+
height: 100%;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
.papyros-test-line {
|
|
44
|
+
background-color: var(--md-sys-color-surface-variant);
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
.papyros-test-code-widget {
|
|
48
|
+
background-color: var(--md-sys-color-surface-variant);
|
|
49
|
+
color: var(--md-sys-color-on-surface-variant);
|
|
50
|
+
padding: 0 2px 0 6px;
|
|
51
|
+
position: relative;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
.papyros-test-code-buttons {
|
|
55
|
+
position: absolute;
|
|
56
|
+
top: 0;
|
|
57
|
+
left: -50px;
|
|
58
|
+
z-index: 220;
|
|
59
|
+
width: 50px;
|
|
60
|
+
padding-left: 4px;
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
.papyros-icon-link {
|
|
64
|
+
font-size: 16px;
|
|
65
|
+
padding: 0 4px;
|
|
66
|
+
cursor: pointer;
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
.papyros-icon-link:hover {
|
|
70
|
+
color: var(--md-sys-color-primary);
|
|
71
|
+
}
|
|
72
|
+
`;
|
|
73
|
+
}
|
|
74
|
+
set debug(value) {
|
|
75
|
+
this.configure({
|
|
76
|
+
debugging: value ? debugLineExtension : [highlightActiveLineGutter(), lintGutter(), highlightActiveLine()],
|
|
77
|
+
});
|
|
78
|
+
this.readonly = value;
|
|
79
|
+
}
|
|
80
|
+
set debugLine(value) {
|
|
81
|
+
if (!this.view)
|
|
82
|
+
return;
|
|
83
|
+
const effects = [setDebugLines.of(value ? [value] : [])];
|
|
84
|
+
if (value && value >= 1 && value <= this.view.state.doc.lines) {
|
|
85
|
+
const line = this.view.state.doc.line(value);
|
|
86
|
+
effects.push(EditorView.scrollIntoView(line.from, { y: "center" }));
|
|
87
|
+
}
|
|
88
|
+
this.view.dispatch({ effects });
|
|
89
|
+
}
|
|
90
|
+
set testLines(value) {
|
|
91
|
+
var _a;
|
|
92
|
+
(_a = this.view) === null || _a === void 0 ? void 0 : _a.dispatch({
|
|
93
|
+
effects: setTestLines.of(value),
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
/**
|
|
97
|
+
* Override the value setter to temporarily disable read-only ranges
|
|
98
|
+
*/
|
|
99
|
+
dispatchChange() {
|
|
100
|
+
var _a;
|
|
101
|
+
const oldReadOnlyExtensions = (_a = this.extensions.get("testReadOnlyRanges")) !== null && _a !== void 0 ? _a : [];
|
|
102
|
+
this.configure({
|
|
103
|
+
testReadOnlyRanges: [],
|
|
104
|
+
});
|
|
105
|
+
super.dispatchChange();
|
|
106
|
+
this.configure({
|
|
107
|
+
testReadOnlyRanges: oldReadOnlyExtensions,
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
set testLineCount(value) {
|
|
111
|
+
this.configure({
|
|
112
|
+
testReadOnlyRanges: value
|
|
113
|
+
? readOnlyRangesExtension((state) => {
|
|
114
|
+
const line = state.doc.lines - value;
|
|
115
|
+
return [{ from: state.doc.line(line).from, to: state.doc.length }];
|
|
116
|
+
})
|
|
117
|
+
: [],
|
|
118
|
+
});
|
|
119
|
+
}
|
|
120
|
+
set testTranslations(value) {
|
|
121
|
+
this.configure({
|
|
122
|
+
test: [
|
|
123
|
+
testLineExtension,
|
|
124
|
+
testCodeWidgetExtension(value, () => {
|
|
125
|
+
this.dispatchEvent(new CustomEvent("edit-test-code"));
|
|
126
|
+
}, () => {
|
|
127
|
+
this.dispatchEvent(new CustomEvent("remove-test-code"));
|
|
128
|
+
}),
|
|
129
|
+
],
|
|
130
|
+
});
|
|
131
|
+
}
|
|
132
|
+
set programmingLanguage(value) {
|
|
133
|
+
if (!(value in languageExtensions)) {
|
|
134
|
+
console.warn(`Language ${value} not supported, defaulting to javascript`);
|
|
135
|
+
this.configure({
|
|
136
|
+
language: languageExtensions.JavaScript,
|
|
137
|
+
});
|
|
138
|
+
return;
|
|
139
|
+
}
|
|
140
|
+
this.configure({
|
|
141
|
+
language: languageExtensions[value],
|
|
142
|
+
});
|
|
143
|
+
}
|
|
144
|
+
set lintingSource(lintSource) {
|
|
145
|
+
this.configure({
|
|
146
|
+
linting: linter((view) => __awaiter(this, void 0, void 0, function* () {
|
|
147
|
+
const workerDiagnostics = yield lintSource();
|
|
148
|
+
if (workerDiagnostics.some((d) => d.lineNr > view.state.doc.lines || d.endLineNr > view.state.doc.lines)) {
|
|
149
|
+
// if the diagnostics are out of range, the document has changed since the linting was requested
|
|
150
|
+
// these diagnostics are no longer valid
|
|
151
|
+
return [];
|
|
152
|
+
}
|
|
153
|
+
return workerDiagnostics.map((d) => {
|
|
154
|
+
const fromline = view.state.doc.line(d.lineNr);
|
|
155
|
+
const toLine = view.state.doc.line(d.endLineNr);
|
|
156
|
+
const from = Math.min(fromline.from + d.columnNr, fromline.to);
|
|
157
|
+
const to = Math.min(toLine.from + d.endColumnNr, toLine.to);
|
|
158
|
+
return Object.assign(Object.assign({}, d), { from: from, to: to });
|
|
159
|
+
});
|
|
160
|
+
})),
|
|
161
|
+
});
|
|
162
|
+
}
|
|
163
|
+
set indentLength(length) {
|
|
164
|
+
this.configure({
|
|
165
|
+
indentUnit: indentUnit.of(" ".repeat(length)),
|
|
166
|
+
});
|
|
167
|
+
}
|
|
168
|
+
constructor() {
|
|
169
|
+
super();
|
|
170
|
+
this.configure({
|
|
171
|
+
language: [],
|
|
172
|
+
codingExtensions: [
|
|
173
|
+
lineNumbers(),
|
|
174
|
+
highlightSpecialChars(),
|
|
175
|
+
history(),
|
|
176
|
+
foldGutter(),
|
|
177
|
+
drawSelection(),
|
|
178
|
+
EditorState.allowMultipleSelections.of(true),
|
|
179
|
+
indentOnInput(),
|
|
180
|
+
bracketMatching(),
|
|
181
|
+
closeBrackets(),
|
|
182
|
+
autocompletion(),
|
|
183
|
+
rectangularSelection(),
|
|
184
|
+
highlightSelectionMatches(),
|
|
185
|
+
keymap.of([
|
|
186
|
+
...closeBracketsKeymap,
|
|
187
|
+
...defaultKeymap,
|
|
188
|
+
...searchKeymap,
|
|
189
|
+
...historyKeymap,
|
|
190
|
+
...completionKeymap,
|
|
191
|
+
...tabCompletionKeyMap,
|
|
192
|
+
...lintKeymap,
|
|
193
|
+
indentWithTab,
|
|
194
|
+
]),
|
|
195
|
+
],
|
|
196
|
+
debugging: [highlightActiveLineGutter(), lintGutter(), highlightActiveLine()],
|
|
197
|
+
});
|
|
198
|
+
}
|
|
199
|
+
};
|
|
200
|
+
CodeEditor = __decorate([
|
|
201
|
+
customElement("p-code-editor")
|
|
202
|
+
], CodeEditor);
|
|
203
|
+
export { CodeEditor };
|
|
204
|
+
//# sourceMappingURL=CodeEditor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CodeEditor.js","sourceRoot":"","sources":["../../../../src/frontend/components/code_mirror/CodeEditor.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { LitElement } from "lit";
|
|
2
|
+
import { EditorView } from "@codemirror/view";
|
|
3
|
+
import { Compartment, Extension } from "@codemirror/state";
|
|
4
|
+
export declare class CodeMirrorEditor extends LitElement {
|
|
5
|
+
private __value;
|
|
6
|
+
private __readonly;
|
|
7
|
+
protected view: EditorView | undefined;
|
|
8
|
+
protected readonly compartments: Map<string, Compartment>;
|
|
9
|
+
protected readonly extensions: Map<string, Extension>;
|
|
10
|
+
set value(value: string);
|
|
11
|
+
set readonly(readonly: boolean);
|
|
12
|
+
protected dispatchChange(): void;
|
|
13
|
+
get value(): string;
|
|
14
|
+
set placeholder(value: string);
|
|
15
|
+
set theme(theme: Extension);
|
|
16
|
+
set translations(translations: Record<string, string>);
|
|
17
|
+
private initView;
|
|
18
|
+
private onViewUpdate;
|
|
19
|
+
connectedCallback(): void;
|
|
20
|
+
disconnectedCallback(): void;
|
|
21
|
+
protected configure(extensions: Record<string, Extension>): void;
|
|
22
|
+
}
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
import { LitElement } from "lit";
|
|
8
|
+
import { customElement } from "lit/decorators.js";
|
|
9
|
+
import { EditorView, placeholder } from "@codemirror/view";
|
|
10
|
+
import { Compartment, EditorState, StateEffect } from "@codemirror/state";
|
|
11
|
+
let CodeMirrorEditor = class CodeMirrorEditor extends LitElement {
|
|
12
|
+
constructor() {
|
|
13
|
+
super(...arguments);
|
|
14
|
+
this.__value = "";
|
|
15
|
+
this.__readonly = false;
|
|
16
|
+
this.compartments = new Map();
|
|
17
|
+
this.extensions = new Map();
|
|
18
|
+
}
|
|
19
|
+
set value(value) {
|
|
20
|
+
if (this.__value === value)
|
|
21
|
+
return;
|
|
22
|
+
this.__value = value;
|
|
23
|
+
if (!this.view)
|
|
24
|
+
return;
|
|
25
|
+
this.dispatchChange();
|
|
26
|
+
}
|
|
27
|
+
set readonly(readonly) {
|
|
28
|
+
this.configure({
|
|
29
|
+
editable: EditorView.editable.of(!readonly),
|
|
30
|
+
});
|
|
31
|
+
this.__readonly = readonly;
|
|
32
|
+
}
|
|
33
|
+
dispatchChange() {
|
|
34
|
+
if (!this.view)
|
|
35
|
+
return;
|
|
36
|
+
this.configure({ editable: EditorView.editable.of(false) });
|
|
37
|
+
this.view.dispatch({
|
|
38
|
+
changes: {
|
|
39
|
+
from: 0,
|
|
40
|
+
to: this.view.state.doc.length,
|
|
41
|
+
insert: this.__value,
|
|
42
|
+
},
|
|
43
|
+
});
|
|
44
|
+
this.configure({ editable: EditorView.editable.of(!this.__readonly) });
|
|
45
|
+
}
|
|
46
|
+
get value() {
|
|
47
|
+
return this.__value;
|
|
48
|
+
}
|
|
49
|
+
set placeholder(value) {
|
|
50
|
+
this.configure({
|
|
51
|
+
placeholder: placeholder(value),
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
set theme(theme) {
|
|
55
|
+
this.configure({ theme: theme });
|
|
56
|
+
}
|
|
57
|
+
set translations(translations) {
|
|
58
|
+
this.configure({ translations: EditorState.phrases.of(translations) });
|
|
59
|
+
}
|
|
60
|
+
initView() {
|
|
61
|
+
this.view = new EditorView({
|
|
62
|
+
parent: this.shadowRoot,
|
|
63
|
+
state: EditorState.create({
|
|
64
|
+
doc: this.__value,
|
|
65
|
+
extensions: [
|
|
66
|
+
EditorView.updateListener.of(this.onViewUpdate.bind(this)),
|
|
67
|
+
[...this.compartments.keys().map((k) => this.compartments.get(k).of([]))],
|
|
68
|
+
],
|
|
69
|
+
}),
|
|
70
|
+
});
|
|
71
|
+
this.configure(Object.fromEntries(this.extensions));
|
|
72
|
+
}
|
|
73
|
+
onViewUpdate(v) {
|
|
74
|
+
if (v.docChanged) {
|
|
75
|
+
this.__value = v.state.doc.toString();
|
|
76
|
+
this.dispatchEvent(new CustomEvent("change", { detail: this.value }));
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
connectedCallback() {
|
|
80
|
+
super.connectedCallback();
|
|
81
|
+
this.initView();
|
|
82
|
+
}
|
|
83
|
+
disconnectedCallback() {
|
|
84
|
+
var _a;
|
|
85
|
+
super.disconnectedCallback();
|
|
86
|
+
(_a = this.view) === null || _a === void 0 ? void 0 : _a.destroy();
|
|
87
|
+
this.view = undefined;
|
|
88
|
+
}
|
|
89
|
+
configure(extensions) {
|
|
90
|
+
Object.entries(extensions).forEach(([key, ext]) => {
|
|
91
|
+
this.extensions.set(key, ext);
|
|
92
|
+
});
|
|
93
|
+
const effects = Object.keys(extensions).map((key) => {
|
|
94
|
+
const extension = extensions[key];
|
|
95
|
+
if (this.compartments.has(key)) {
|
|
96
|
+
return this.compartments.get(key).reconfigure(extension);
|
|
97
|
+
}
|
|
98
|
+
const compartment = new Compartment();
|
|
99
|
+
this.compartments.set(key, compartment);
|
|
100
|
+
return StateEffect.appendConfig.of(compartment.of(extension));
|
|
101
|
+
});
|
|
102
|
+
if (this.view) {
|
|
103
|
+
this.view.dispatch({ effects });
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
};
|
|
107
|
+
CodeMirrorEditor = __decorate([
|
|
108
|
+
customElement("p-code-mirror-editor")
|
|
109
|
+
], CodeMirrorEditor);
|
|
110
|
+
export { CodeMirrorEditor };
|
|
111
|
+
//# sourceMappingURL=CodeMirrorEditor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CodeMirrorEditor.js","sourceRoot":"","sources":["../../../../src/frontend/components/code_mirror/CodeMirrorEditor.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { Extension, StateEffectType, StateField } from "@codemirror/state";
|
|
2
|
+
export type LineEffectExtensionConfig = {
|
|
3
|
+
lineClass?: string;
|
|
4
|
+
gutterClass?: string;
|
|
5
|
+
marker?: string;
|
|
6
|
+
};
|
|
7
|
+
export declare function lineEffectExtension(config: LineEffectExtensionConfig): [Extension, StateEffectType<number[] | undefined>, StateField<number[] | undefined>];
|
|
8
|
+
export declare const usedLineExtension: Extension, setUsedLines: StateEffectType<number[] | undefined>, usedLineState: StateField<number[] | undefined>;
|
|
9
|
+
export declare const debugLineExtension: Extension, setDebugLines: StateEffectType<number[] | undefined>, debugLineState: StateField<number[] | undefined>;
|
|
10
|
+
export declare const testLineExtension: Extension, setTestLines: StateEffectType<number[] | undefined>, testLineState: StateField<number[] | undefined>;
|
|
11
|
+
export declare function testCodeWidgetExtension(translations: {
|
|
12
|
+
description: string;
|
|
13
|
+
edit: string;
|
|
14
|
+
remove: string;
|
|
15
|
+
}, handleEdit: () => void, handleRemove: () => void): Extension;
|
|
@@ -0,0 +1,164 @@
|
|
|
1
|
+
import { Decoration, EditorView, gutter, gutterLineClass, GutterMarker, ViewPlugin, WidgetType, } from "@codemirror/view";
|
|
2
|
+
import { RangeSet, StateEffect, StateField } from "@codemirror/state";
|
|
3
|
+
export function lineEffectExtension(config) {
|
|
4
|
+
var _a;
|
|
5
|
+
const setLines = StateEffect.define();
|
|
6
|
+
let currentVal = undefined;
|
|
7
|
+
const stateField = StateField.define({
|
|
8
|
+
create: () => undefined,
|
|
9
|
+
update(value, tr) {
|
|
10
|
+
for (const effect of tr.effects) {
|
|
11
|
+
if (effect.is(setLines)) {
|
|
12
|
+
currentVal = effect.value;
|
|
13
|
+
return currentVal;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
if (tr.docChanged && currentVal !== undefined) {
|
|
17
|
+
// only return the lines that still exist
|
|
18
|
+
return currentVal.filter((line) => line <= tr.newDoc.lines);
|
|
19
|
+
}
|
|
20
|
+
return value;
|
|
21
|
+
},
|
|
22
|
+
});
|
|
23
|
+
const lineDecoration = Decoration.line({ class: (_a = config.lineClass) !== null && _a !== void 0 ? _a : "cm-activeLine" });
|
|
24
|
+
const lineGutterMarker = new (class extends GutterMarker {
|
|
25
|
+
constructor() {
|
|
26
|
+
var _a;
|
|
27
|
+
super(...arguments);
|
|
28
|
+
this.elementClass = (_a = config.gutterClass) !== null && _a !== void 0 ? _a : "cm-activeLineGutter";
|
|
29
|
+
}
|
|
30
|
+
})();
|
|
31
|
+
const gutterHighlighter = gutterLineClass.compute([stateField], (state) => {
|
|
32
|
+
const lines = state.field(stateField);
|
|
33
|
+
if (lines === undefined || lines.length === 0)
|
|
34
|
+
return RangeSet.empty;
|
|
35
|
+
const markers = [];
|
|
36
|
+
for (const lineNum of lines) {
|
|
37
|
+
if (lineNum <= state.doc.lines) {
|
|
38
|
+
markers.push(lineGutterMarker.range(state.doc.line(lineNum).from));
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
return RangeSet.of(markers);
|
|
42
|
+
});
|
|
43
|
+
const lineDecorationPlugin = ViewPlugin.fromClass(class {
|
|
44
|
+
constructor(view) {
|
|
45
|
+
this.decorations = this.getDecorations(view.state);
|
|
46
|
+
}
|
|
47
|
+
update(update) {
|
|
48
|
+
if (update.state.field(stateField) !== update.startState.field(stateField)) {
|
|
49
|
+
this.decorations = this.getDecorations(update.state);
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
getDecorations(state) {
|
|
53
|
+
const lines = state.field(stateField);
|
|
54
|
+
if (lines === undefined || lines.length === 0)
|
|
55
|
+
return Decoration.none;
|
|
56
|
+
const decorations = [];
|
|
57
|
+
for (const lineNum of lines) {
|
|
58
|
+
if (lineNum <= state.doc.lines) {
|
|
59
|
+
decorations.push(lineDecoration.range(state.doc.line(lineNum).from));
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
return Decoration.set(decorations);
|
|
63
|
+
}
|
|
64
|
+
}, {
|
|
65
|
+
decorations: (v) => v.decorations,
|
|
66
|
+
});
|
|
67
|
+
const extensions = [stateField, gutterHighlighter, lineDecorationPlugin];
|
|
68
|
+
if (config.marker !== undefined) {
|
|
69
|
+
class CustomMarker extends GutterMarker {
|
|
70
|
+
toDOM() {
|
|
71
|
+
const element = document.createElement("div");
|
|
72
|
+
element.textContent = config.marker;
|
|
73
|
+
return element;
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
const customMarker = new CustomMarker();
|
|
77
|
+
const customGutter = gutter({
|
|
78
|
+
class: "cm-custom-gutter",
|
|
79
|
+
markers: () => {
|
|
80
|
+
return RangeSet.empty;
|
|
81
|
+
},
|
|
82
|
+
lineMarker: (view, line) => {
|
|
83
|
+
const lines = view.state.field(stateField);
|
|
84
|
+
if (lines === undefined || lines.length === 0) {
|
|
85
|
+
return null;
|
|
86
|
+
}
|
|
87
|
+
for (const lineNum of lines) {
|
|
88
|
+
if (lineNum <= view.state.doc.lines && line.from === view.state.doc.line(lineNum).from) {
|
|
89
|
+
return customMarker;
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
return null;
|
|
93
|
+
},
|
|
94
|
+
});
|
|
95
|
+
extensions.push(customGutter);
|
|
96
|
+
extensions.push(EditorView.baseTheme({
|
|
97
|
+
".cm-custom-gutter": {
|
|
98
|
+
width: "17px",
|
|
99
|
+
textAlign: "center",
|
|
100
|
+
},
|
|
101
|
+
}));
|
|
102
|
+
}
|
|
103
|
+
return [extensions, setLines, stateField];
|
|
104
|
+
}
|
|
105
|
+
export const [usedLineExtension, setUsedLines, usedLineState] = lineEffectExtension({ marker: "✔" });
|
|
106
|
+
export const [debugLineExtension, setDebugLines, debugLineState] = lineEffectExtension({ marker: "▶" });
|
|
107
|
+
export const [testLineExtension, setTestLines, testLineState] = lineEffectExtension({
|
|
108
|
+
lineClass: "papyros-test-line",
|
|
109
|
+
gutterClass: "",
|
|
110
|
+
});
|
|
111
|
+
export function testCodeWidgetExtension(translations, handleEdit, handleRemove) {
|
|
112
|
+
class TestCodeWidget extends WidgetType {
|
|
113
|
+
toDOM() {
|
|
114
|
+
const element = document.createElement("div");
|
|
115
|
+
element.classList.add("papyros-test-code-widget");
|
|
116
|
+
const span = document.createElement("span");
|
|
117
|
+
span.innerText = translations.description;
|
|
118
|
+
element.appendChild(span);
|
|
119
|
+
const buttons = document.createElement("div");
|
|
120
|
+
buttons.classList.add("papyros-test-code-buttons");
|
|
121
|
+
const editButton = document.createElement("a");
|
|
122
|
+
editButton.classList.add("papyros-icon-link");
|
|
123
|
+
editButton.innerHTML = "🖉";
|
|
124
|
+
editButton.addEventListener("click", handleEdit);
|
|
125
|
+
editButton.title = translations.edit;
|
|
126
|
+
buttons.appendChild(editButton);
|
|
127
|
+
const deleteButton = document.createElement("a");
|
|
128
|
+
deleteButton.classList.add("papyros-icon-link");
|
|
129
|
+
deleteButton.innerHTML = "⨯";
|
|
130
|
+
deleteButton.addEventListener("click", handleRemove);
|
|
131
|
+
deleteButton.title = translations.remove;
|
|
132
|
+
buttons.appendChild(deleteButton);
|
|
133
|
+
element.appendChild(buttons);
|
|
134
|
+
return element;
|
|
135
|
+
}
|
|
136
|
+
ignoreEvent() {
|
|
137
|
+
return false;
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
const testCodeDecoration = Decoration.widget({ widget: new TestCodeWidget(), side: -1, block: true });
|
|
141
|
+
function getDecorations(state) {
|
|
142
|
+
const lines = state.field(testLineState);
|
|
143
|
+
if (!lines || lines.length === 0)
|
|
144
|
+
return Decoration.none;
|
|
145
|
+
const minLine = Math.min(...lines);
|
|
146
|
+
if (minLine > state.doc.lines)
|
|
147
|
+
return Decoration.none;
|
|
148
|
+
return Decoration.set([testCodeDecoration.range(state.doc.line(minLine).from)]);
|
|
149
|
+
}
|
|
150
|
+
return StateField.define({
|
|
151
|
+
create(state) {
|
|
152
|
+
return getDecorations(state);
|
|
153
|
+
},
|
|
154
|
+
update(deco, tr) {
|
|
155
|
+
for (const effect of tr.effects) {
|
|
156
|
+
if (effect.is(setTestLines) || tr.docChanged)
|
|
157
|
+
return getDecorations(tr.state);
|
|
158
|
+
}
|
|
159
|
+
return deco.map(tr.changes);
|
|
160
|
+
},
|
|
161
|
+
provide: (f) => EditorView.decorations.from(f),
|
|
162
|
+
});
|
|
163
|
+
}
|
|
164
|
+
//# sourceMappingURL=Extensions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Extensions.js","sourceRoot":"","sources":["../../../../src/frontend/components/code_mirror/Extensions.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,UAAU,EAEV,UAAU,EACV,MAAM,EACN,eAAe,EACf,YAAY,EACZ,UAAU,EAEV,UAAU,GACb,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAAa,QAAQ,EAAE,WAAW,EAAmB,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAOlG,MAAM,UAAU,mBAAmB,CAC/B,MAAiC;;IAEjC,MAAM,QAAQ,GAAG,WAAW,CAAC,MAAM,EAAwB,CAAC;IAC5D,IAAI,UAAU,GAAyB,SAAS,CAAC;IACjD,MAAM,UAAU,GAAG,UAAU,CAAC,MAAM,CAAuB;QACvD,MAAM,EAAE,GAAG,EAAE,CAAC,SAAS;QACvB,MAAM,CAAC,KAAK,EAAE,EAAE;YACZ,KAAK,MAAM,MAAM,IAAI,EAAE,CAAC,OAAO,EAAE,CAAC;gBAC9B,IAAI,MAAM,CAAC,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC;oBACtB,UAAU,GAAG,MAAM,CAAC,KAAK,CAAC;oBAC1B,OAAO,UAAU,CAAC;gBACtB,CAAC;YACL,CAAC;YAED,IAAI,EAAE,CAAC,UAAU,IAAI,UAAU,KAAK,SAAS,EAAE,CAAC;gBAC5C,yCAAyC;gBACzC,OAAO,UAAU,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,IAAI,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YAChE,CAAC;YACD,OAAO,KAAK,CAAC;QACjB,CAAC;KACJ,CAAC,CAAC;IAEH,MAAM,cAAc,GAAG,UAAU,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,MAAA,MAAM,CAAC,SAAS,mCAAI,eAAe,EAAE,CAAC,CAAC;IACvF,MAAM,gBAAgB,GAAG,IAAI,CAAC,KAAM,SAAQ,YAAY;QAA1B;;;YAC1B,iBAAY,GAAG,MAAA,MAAM,CAAC,WAAW,mCAAI,qBAAqB,CAAC;QAC/D,CAAC;KAAA,CAAC,EAAE,CAAC;IAEL,MAAM,iBAAiB,GAAG,eAAe,CAAC,OAAO,CAAC,CAAC,UAAU,CAAC,EAAE,CAAC,KAAK,EAAE,EAAE;QACtE,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;QACtC,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO,QAAQ,CAAC,KAAK,CAAC;QACrE,MAAM,OAAO,GAAG,EAAE,CAAC;QACnB,KAAK,MAAM,OAAO,IAAI,KAAK,EAAE,CAAC;YAC1B,IAAI,OAAO,IAAI,KAAK,CAAC,GAAG,CAAC,KAAK,EAAE,CAAC;gBAC7B,OAAO,CAAC,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;YACvE,CAAC;QACL,CAAC;QACD,OAAO,QAAQ,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC;IAChC,CAAC,CAAC,CAAC;IAEH,MAAM,oBAAoB,GAAG,UAAU,CAAC,SAAS,CAC7C;QAGI,YAAY,IAAgB;YACxB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACvD,CAAC;QAED,MAAM,CAAC,MAAkB;YACrB,IAAI,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,KAAK,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,UAAU,CAAC,EAAE,CAAC;gBACzE,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YACzD,CAAC;QACL,CAAC;QAED,cAAc,CAAC,KAA0B;YACrC,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;YACtC,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC;gBAAE,OAAO,UAAU,CAAC,IAAI,CAAC;YACtE,MAAM,WAAW,GAAG,EAAE,CAAC;YACvB,KAAK,MAAM,OAAO,IAAI,KAAK,EAAE,CAAC;gBAC1B,IAAI,OAAO,IAAI,KAAK,CAAC,GAAG,CAAC,KAAK,EAAE,CAAC;oBAC7B,WAAW,CAAC,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;gBACzE,CAAC;YACL,CAAC;YACD,OAAO,UAAU,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;QACvC,CAAC;KACJ,EACD;QACI,WAAW,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW;KACpC,CACJ,CAAC;IAEF,MAAM,UAAU,GAAgB,CAAC,UAAU,EAAE,iBAAiB,EAAE,oBAAoB,CAAC,CAAC;IAEtF,IAAI,MAAM,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;QAC9B,MAAM,YAAa,SAAQ,YAAY;YACnC,KAAK;gBACD,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;gBAC9C,OAAO,CAAC,WAAW,GAAG,MAAM,CAAC,MAAO,CAAC;gBACrC,OAAO,OAAO,CAAC;YACnB,CAAC;SACJ;QACD,MAAM,YAAY,GAAG,IAAI,YAAY,EAAE,CAAC;QAExC,MAAM,YAAY,GAAG,MAAM,CAAC;YACxB,KAAK,EAAE,kBAAkB;YACzB,OAAO,EAAE,GAAG,EAAE;gBACV,OAAO,QAAQ,CAAC,KAAK,CAAC;YAC1B,CAAC;YACD,UAAU,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE;gBACvB,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;gBAC3C,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;oBAC5C,OAAO,IAAI,CAAC;gBAChB,CAAC;gBACD,KAAK,MAAM,OAAO,IAAI,KAAK,EAAE,CAAC;oBAC1B,IAAI,OAAO,IAAI,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,IAAI,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC;wBACrF,OAAO,YAAY,CAAC;oBACxB,CAAC;gBACL,CAAC;gBACD,OAAO,IAAI,CAAC;YAChB,CAAC;SACJ,CAAC,CAAC;QAEH,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QAC9B,UAAU,CAAC,IAAI,CACX,UAAU,CAAC,SAAS,CAAC;YACjB,mBAAmB,EAAE;gBACjB,KAAK,EAAE,MAAM;gBACb,SAAS,EAAE,QAAQ;aACtB;SACJ,CAAC,CACL,CAAC;IACN,CAAC;IACD,OAAO,CAAC,UAAU,EAAE,QAAQ,EAAE,UAAU,CAAC,CAAC;AAC9C,CAAC;AAED,MAAM,CAAC,MAAM,CAAC,iBAAiB,EAAE,YAAY,EAAE,aAAa,CAAC,GAAG,mBAAmB,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,CAAC;AACrG,MAAM,CAAC,MAAM,CAAC,kBAAkB,EAAE,aAAa,EAAE,cAAc,CAAC,GAAG,mBAAmB,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,CAAC;AACxG,MAAM,CAAC,MAAM,CAAC,iBAAiB,EAAE,YAAY,EAAE,aAAa,CAAC,GAAG,mBAAmB,CAAC;IAChF,SAAS,EAAE,mBAAmB;IAC9B,WAAW,EAAE,EAAE;CAClB,CAAC,CAAC;AAEH,MAAM,UAAU,uBAAuB,CACnC,YAAmE,EACnE,UAAsB,EACtB,YAAwB;IAExB,MAAM,cAAe,SAAQ,UAAU;QAC5B,KAAK;YACR,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YAC9C,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,0BAA0B,CAAC,CAAC;YAElD,MAAM,IAAI,GAAG,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;YAC5C,IAAI,CAAC,SAAS,GAAG,YAAY,CAAC,WAAW,CAAC;YAC1C,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;YAE1B,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YAC9C,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAC;YAEnD,MAAM,UAAU,GAAG,QAAQ,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;YAC/C,UAAU,CAAC,SAAS,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC;YAC9C,UAAU,CAAC,SAAS,GAAG,IAAI,CAAC;YAC5B,UAAU,CAAC,gBAAgB,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC;YACjD,UAAU,CAAC,KAAK,GAAG,YAAY,CAAC,IAAI,CAAC;YACrC,OAAO,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;YAEhC,MAAM,YAAY,GAAG,QAAQ,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;YACjD,YAAY,CAAC,SAAS,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC;YAChD,YAAY,CAAC,SAAS,GAAG,GAAG,CAAC;YAC7B,YAAY,CAAC,gBAAgB,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC;YACrD,YAAY,CAAC,KAAK,GAAG,YAAY,CAAC,MAAM,CAAC;YACzC,OAAO,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;YAElC,OAAO,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;YAC7B,OAAO,OAAO,CAAC;QACnB,CAAC;QAED,WAAW;YACP,OAAO,KAAK,CAAC;QACjB,CAAC;KACJ;IAED,MAAM,kBAAkB,GAAG,UAAU,CAAC,MAAM,CAAC,EAAE,MAAM,EAAE,IAAI,cAAc,EAAE,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;IACtG,SAAS,cAAc,CAAC,KAA0B;QAC9C,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;QACzC,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO,UAAU,CAAC,IAAI,CAAC;QACzD,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC,CAAC;QACnC,IAAI,OAAO,GAAG,KAAK,CAAC,GAAG,CAAC,KAAK;YAAE,OAAO,UAAU,CAAC,IAAI,CAAC;QACtD,OAAO,UAAU,CAAC,GAAG,CAAC,CAAC,kBAAkB,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACpF,CAAC;IAED,OAAO,UAAU,CAAC,MAAM,CAAgB;QACpC,MAAM,CAAC,KAAK;YACR,OAAO,cAAc,CAAC,KAAK,CAAC,CAAC;QACjC,CAAC;QACD,MAAM,CAAC,IAAI,EAAE,EAAE;YACX,KAAK,MAAM,MAAM,IAAI,EAAE,CAAC,OAAO,EAAE,CAAC;gBAC9B,IAAI,MAAM,CAAC,EAAE,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC,UAAU;oBAAE,OAAO,cAAc,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC;YAClF,CAAC;YACD,OAAO,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC;QAChC,CAAC;QACD,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,UAAU,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC;KACjD,CAAC,CAAC;AACP,CAAC"}
|