@dodona/papyros 3.0.2 → 4.0.0-beta.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.
Files changed (233) hide show
  1. package/README.md +133 -72
  2. package/dist/Components.d.ts +4 -0
  3. package/dist/Components.js +5 -0
  4. package/dist/Components.js.map +1 -0
  5. package/dist/Papyros.d.ts +18 -127
  6. package/dist/Papyros.js +39 -211
  7. package/dist/Papyros.js.map +1 -1
  8. package/dist/{Backend.d.ts → backend/Backend.d.ts} +3 -12
  9. package/dist/{Backend.js → backend/Backend.js} +4 -17
  10. package/dist/backend/Backend.js.map +1 -0
  11. package/dist/{workers → backend/workers}/javascript/JavaScriptWorker.js +1 -1
  12. package/dist/backend/workers/javascript/JavaScriptWorker.js.map +1 -0
  13. package/dist/backend/workers/javascript/worker.js.map +1 -0
  14. package/dist/{workers → backend/workers}/python/PythonWorker.d.ts +2 -2
  15. package/dist/{workers → backend/workers}/python/PythonWorker.js +2 -2
  16. package/dist/backend/workers/python/PythonWorker.js.map +1 -0
  17. package/dist/backend/workers/python/python_package.tar.gz.load_by_url +0 -0
  18. package/dist/backend/workers/python/worker.js.map +1 -0
  19. package/dist/communication/BackendEvent.js.map +1 -0
  20. package/dist/{BackendEventQueue.d.ts → communication/BackendEventQueue.d.ts} +1 -36
  21. package/dist/{BackendEventQueue.js → communication/BackendEventQueue.js} +2 -45
  22. package/dist/communication/BackendEventQueue.js.map +1 -0
  23. package/dist/{BackendManager.d.ts → communication/BackendManager.d.ts} +2 -2
  24. package/dist/{BackendManager.js → communication/BackendManager.js} +4 -4
  25. package/dist/communication/BackendManager.js.map +1 -0
  26. package/dist/communication/InputServiceWorker.js +37 -0
  27. package/dist/communication/InputServiceWorker.js.map +1 -0
  28. package/dist/communication/InputWorker.js.map +1 -0
  29. package/dist/frontend/components/CodeRunner.d.ts +9 -0
  30. package/dist/frontend/components/CodeRunner.js +60 -0
  31. package/dist/frontend/components/CodeRunner.js.map +1 -0
  32. package/dist/frontend/components/Debugger.d.ts +7 -0
  33. package/dist/frontend/components/Debugger.js +62 -0
  34. package/dist/frontend/components/Debugger.js.map +1 -0
  35. package/dist/frontend/components/Input.d.ts +17 -0
  36. package/dist/frontend/components/Input.js +73 -0
  37. package/dist/frontend/components/Input.js.map +1 -0
  38. package/dist/frontend/components/Output.d.ts +14 -0
  39. package/dist/frontend/components/Output.js +154 -0
  40. package/dist/frontend/components/Output.js.map +1 -0
  41. package/dist/frontend/components/PapyrosElement.d.ts +8 -0
  42. package/dist/frontend/components/PapyrosElement.js +24 -0
  43. package/dist/frontend/components/PapyrosElement.js.map +1 -0
  44. package/dist/frontend/components/app/App.d.ts +24 -0
  45. package/dist/frontend/components/app/App.js +204 -0
  46. package/dist/frontend/components/app/App.js.map +1 -0
  47. package/dist/frontend/components/app/ExamplePicker.d.ts +7 -0
  48. package/dist/frontend/components/app/ExamplePicker.js +35 -0
  49. package/dist/frontend/components/app/ExamplePicker.js.map +1 -0
  50. package/dist/frontend/components/app/LanguagePicker.d.ts +7 -0
  51. package/dist/frontend/components/app/LanguagePicker.js +35 -0
  52. package/dist/frontend/components/app/LanguagePicker.js.map +1 -0
  53. package/dist/frontend/components/app/ProgrammingLanguagePicker.d.ts +7 -0
  54. package/dist/frontend/components/app/ProgrammingLanguagePicker.js +39 -0
  55. package/dist/frontend/components/app/ProgrammingLanguagePicker.js.map +1 -0
  56. package/dist/frontend/components/app/examples/JavaScriptExamples.js.map +1 -0
  57. package/dist/frontend/components/app/examples/PythonExamples.js.map +1 -0
  58. package/dist/frontend/components/app/themes/ThemePicker.d.ts +11 -0
  59. package/dist/frontend/components/app/themes/ThemePicker.js +47 -0
  60. package/dist/frontend/components/app/themes/ThemePicker.js.map +1 -0
  61. package/dist/frontend/components/app/themes/ThemedButton.d.ts +9 -0
  62. package/dist/frontend/components/app/themes/ThemedButton.js +43 -0
  63. package/dist/frontend/components/app/themes/ThemedButton.js.map +1 -0
  64. package/dist/frontend/components/code_mirror/BatchInputEditor.d.ts +8 -0
  65. package/dist/frontend/components/code_mirror/BatchInputEditor.js +54 -0
  66. package/dist/frontend/components/code_mirror/BatchInputEditor.js.map +1 -0
  67. package/dist/frontend/components/code_mirror/CodeEditor.d.ts +24 -0
  68. package/dist/frontend/components/code_mirror/CodeEditor.js +206 -0
  69. package/dist/frontend/components/code_mirror/CodeEditor.js.map +1 -0
  70. package/dist/frontend/components/code_mirror/CodeMirrorEditor.d.ts +20 -0
  71. package/dist/frontend/components/code_mirror/CodeMirrorEditor.js +99 -0
  72. package/dist/frontend/components/code_mirror/CodeMirrorEditor.js.map +1 -0
  73. package/dist/frontend/components/code_mirror/Extensions.d.ts +15 -0
  74. package/dist/frontend/components/code_mirror/Extensions.js +169 -0
  75. package/dist/frontend/components/code_mirror/Extensions.js.map +1 -0
  76. package/dist/frontend/components/code_mirror/MaterialTheme.d.ts +5 -0
  77. package/dist/frontend/components/code_mirror/MaterialTheme.js +109 -0
  78. package/dist/frontend/components/code_mirror/MaterialTheme.js.map +1 -0
  79. package/dist/frontend/components/code_runner/ButtonLint.d.ts +9 -0
  80. package/dist/frontend/components/code_runner/ButtonLint.js +76 -0
  81. package/dist/frontend/components/code_runner/ButtonLint.js.map +1 -0
  82. package/dist/frontend/components/code_runner/Code.d.ts +7 -0
  83. package/dist/frontend/components/code_runner/Code.js +46 -0
  84. package/dist/frontend/components/code_runner/Code.js.map +1 -0
  85. package/dist/frontend/components/code_runner/RunState.d.ts +7 -0
  86. package/dist/frontend/components/code_runner/RunState.js +41 -0
  87. package/dist/frontend/components/code_runner/RunState.js.map +1 -0
  88. package/dist/frontend/components/input/BatchInput.d.ts +19 -0
  89. package/dist/frontend/components/input/BatchInput.js +92 -0
  90. package/dist/frontend/components/input/BatchInput.js.map +1 -0
  91. package/dist/frontend/components/input/InteractiveInput.d.ts +13 -0
  92. package/dist/frontend/components/input/InteractiveInput.js +73 -0
  93. package/dist/frontend/components/input/InteractiveInput.js.map +1 -0
  94. package/dist/frontend/state/Constants.d.ts +38 -0
  95. package/dist/frontend/state/Constants.js +108 -0
  96. package/dist/frontend/state/Constants.js.map +1 -0
  97. package/dist/frontend/state/Debugger.d.ts +23 -0
  98. package/dist/frontend/state/Debugger.js +80 -0
  99. package/dist/frontend/state/Debugger.js.map +1 -0
  100. package/dist/frontend/state/Examples.d.ts +11 -0
  101. package/dist/frontend/state/Examples.js +36 -0
  102. package/dist/frontend/state/Examples.js.map +1 -0
  103. package/dist/frontend/state/I18n.d.ts +16 -0
  104. package/dist/frontend/state/I18n.js +75 -0
  105. package/dist/frontend/state/I18n.js.map +1 -0
  106. package/dist/frontend/state/InputOutput.d.ts +55 -0
  107. package/dist/frontend/state/InputOutput.js +93 -0
  108. package/dist/frontend/state/InputOutput.js.map +1 -0
  109. package/dist/frontend/state/Runner.d.ts +118 -0
  110. package/dist/frontend/state/Runner.js +334 -0
  111. package/dist/frontend/state/Runner.js.map +1 -0
  112. package/dist/frontend/state/Test.d.ts +11 -0
  113. package/dist/frontend/state/Test.js +59 -0
  114. package/dist/frontend/state/Test.js.map +1 -0
  115. package/dist/frontend/state/Translations.d.ts +178 -0
  116. package/dist/frontend/state/Translations.js +188 -0
  117. package/dist/frontend/state/Translations.js.map +1 -0
  118. package/dist/frontend/state/themes/blue-dark.d.ts +2 -0
  119. package/dist/frontend/state/themes/blue-dark.js +55 -0
  120. package/dist/frontend/state/themes/blue-dark.js.map +1 -0
  121. package/dist/frontend/state/themes/blue-light.d.ts +2 -0
  122. package/dist/frontend/state/themes/blue-light.js +55 -0
  123. package/dist/frontend/state/themes/blue-light.js.map +1 -0
  124. package/dist/frontend/state/themes/green-dark.d.ts +2 -0
  125. package/dist/frontend/state/themes/green-dark.js +55 -0
  126. package/dist/frontend/state/themes/green-dark.js.map +1 -0
  127. package/dist/frontend/state/themes/green-light.d.ts +2 -0
  128. package/dist/frontend/state/themes/green-light.js +55 -0
  129. package/dist/frontend/state/themes/green-light.js.map +1 -0
  130. package/dist/frontend/state/themes/red-dark.d.ts +2 -0
  131. package/dist/frontend/state/themes/red-dark.js +55 -0
  132. package/dist/frontend/state/themes/red-dark.js.map +1 -0
  133. package/dist/frontend/state/themes/red-light.d.ts +2 -0
  134. package/dist/frontend/state/themes/red-light.js +55 -0
  135. package/dist/frontend/state/themes/red-light.js.map +1 -0
  136. package/dist/util/Util.d.ts +1 -4
  137. package/dist/util/Util.js +7 -8
  138. package/dist/util/Util.js.map +1 -1
  139. package/package.json +13 -21
  140. package/dist/App.d.ts +0 -1
  141. package/dist/App.js +0 -76
  142. package/dist/App.js.map +0 -1
  143. package/dist/Backend.js.map +0 -1
  144. package/dist/BackendEvent.js.map +0 -1
  145. package/dist/BackendEventQueue.js.map +0 -1
  146. package/dist/BackendManager.js.map +0 -1
  147. package/dist/CodeRunner.d.ts +0 -188
  148. package/dist/CodeRunner.js +0 -548
  149. package/dist/CodeRunner.js.map +0 -1
  150. package/dist/Constants.d.ts +0 -31
  151. package/dist/Constants.js +0 -36
  152. package/dist/Constants.js.map +0 -1
  153. package/dist/Debugger.d.ts +0 -18
  154. package/dist/Debugger.js +0 -86
  155. package/dist/Debugger.js.map +0 -1
  156. package/dist/InputManager.d.ts +0 -38
  157. package/dist/InputManager.js +0 -101
  158. package/dist/InputManager.js.map +0 -1
  159. package/dist/InputServiceWorker.js.map +0 -1
  160. package/dist/Library.d.ts +0 -12
  161. package/dist/Library.js +0 -9
  162. package/dist/Library.js.map +0 -1
  163. package/dist/OutputManager.d.ts +0 -90
  164. package/dist/OutputManager.js +0 -172
  165. package/dist/OutputManager.js.map +0 -1
  166. package/dist/Papyros.css +0 -657
  167. package/dist/Translations.d.ts +0 -180
  168. package/dist/Translations.js +0 -191
  169. package/dist/Translations.js.map +0 -1
  170. package/dist/editor/BatchInputEditor.d.ts +0 -41
  171. package/dist/editor/BatchInputEditor.js +0 -80
  172. package/dist/editor/BatchInputEditor.js.map +0 -1
  173. package/dist/editor/CodeEditor.d.ts +0 -81
  174. package/dist/editor/CodeEditor.js +0 -213
  175. package/dist/editor/CodeEditor.js.map +0 -1
  176. package/dist/editor/CodeMirrorEditor.d.ts +0 -133
  177. package/dist/editor/CodeMirrorEditor.js +0 -169
  178. package/dist/editor/CodeMirrorEditor.js.map +0 -1
  179. package/dist/editor/DarkTheme.d.ts +0 -1
  180. package/dist/editor/DarkTheme.js +0 -72
  181. package/dist/editor/DarkTheme.js.map +0 -1
  182. package/dist/editor/DebugExtension.d.ts +0 -11
  183. package/dist/editor/DebugExtension.js +0 -70
  184. package/dist/editor/DebugExtension.js.map +0 -1
  185. package/dist/editor/Gutters.d.ts +0 -109
  186. package/dist/editor/Gutters.js +0 -201
  187. package/dist/editor/Gutters.js.map +0 -1
  188. package/dist/editor/LineEffectExtension.d.ts +0 -13
  189. package/dist/editor/LineEffectExtension.js +0 -48
  190. package/dist/editor/LineEffectExtension.js.map +0 -1
  191. package/dist/editor/TestCodeExtension.d.ts +0 -21
  192. package/dist/editor/TestCodeExtension.js +0 -134
  193. package/dist/editor/TestCodeExtension.js.map +0 -1
  194. package/dist/examples/Examples.d.ts +0 -6
  195. package/dist/examples/Examples.js +0 -23
  196. package/dist/examples/Examples.js.map +0 -1
  197. package/dist/examples/JavaScriptExamples.js.map +0 -1
  198. package/dist/examples/PythonExamples.js.map +0 -1
  199. package/dist/input/BatchInputHandler.d.ts +0 -55
  200. package/dist/input/BatchInputHandler.js +0 -131
  201. package/dist/input/BatchInputHandler.js.map +0 -1
  202. package/dist/input/InteractiveInputHandler.d.ts +0 -27
  203. package/dist/input/InteractiveInputHandler.js +0 -89
  204. package/dist/input/InteractiveInputHandler.js.map +0 -1
  205. package/dist/input/UserInputHandler.d.ts +0 -68
  206. package/dist/input/UserInputHandler.js +0 -39
  207. package/dist/input/UserInputHandler.js.map +0 -1
  208. package/dist/util/HTMLShapes.d.ts +0 -15
  209. package/dist/util/HTMLShapes.js +0 -25
  210. package/dist/util/HTMLShapes.js.map +0 -1
  211. package/dist/util/Rendering.d.ts +0 -120
  212. package/dist/util/Rendering.js +0 -142
  213. package/dist/util/Rendering.js.map +0 -1
  214. package/dist/workers/input/InputWorker.js.map +0 -1
  215. package/dist/workers/javascript/JavaScriptWorker.js.map +0 -1
  216. package/dist/workers/javascript/worker.js.map +0 -1
  217. package/dist/workers/python/PythonWorker.js.map +0 -1
  218. package/dist/workers/python/python_package.tar.gz.load_by_url +0 -0
  219. package/dist/workers/python/worker.js.map +0 -1
  220. /package/dist/{workers → backend/workers}/javascript/JavaScriptWorker.d.ts +0 -0
  221. /package/dist/{workers → backend/workers}/javascript/worker.d.ts +0 -0
  222. /package/dist/{workers → backend/workers}/javascript/worker.js +0 -0
  223. /package/dist/{workers → backend/workers}/python/worker.d.ts +0 -0
  224. /package/dist/{workers → backend/workers}/python/worker.js +0 -0
  225. /package/dist/{BackendEvent.d.ts → communication/BackendEvent.d.ts} +0 -0
  226. /package/dist/{BackendEvent.js → communication/BackendEvent.js} +0 -0
  227. /package/dist/{InputServiceWorker.d.ts → communication/InputServiceWorker.d.ts} +0 -0
  228. /package/dist/{workers/input → communication}/InputWorker.d.ts +0 -0
  229. /package/dist/{workers/input → communication}/InputWorker.js +0 -0
  230. /package/dist/{examples → frontend/components/app/examples}/JavaScriptExamples.d.ts +0 -0
  231. /package/dist/{examples → frontend/components/app/examples}/JavaScriptExamples.js +0 -0
  232. /package/dist/{examples → frontend/components/app/examples}/PythonExamples.d.ts +0 -0
  233. /package/dist/{examples → frontend/components/app/examples}/PythonExamples.js +0 -0
@@ -0,0 +1,206 @@
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, 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
+ background-color: var(--md-sys-color-surface-variant);
56
+ position: absolute;
57
+ top: 0;
58
+ left: -50px;
59
+ z-index: 220;
60
+ width: 50px;
61
+ padding-left: 4px;
62
+ }
63
+
64
+ .papyros-icon-link {
65
+ font-size: 16px;
66
+ padding: 0 4px;
67
+ cursor: pointer;
68
+ }
69
+
70
+ .papyros-icon-link:hover {
71
+ color: var(--md-sys-color-primary);
72
+ }
73
+ `;
74
+ }
75
+ set debug(value) {
76
+ this.configure({
77
+ debugging: value ? debugLineExtension : [
78
+ highlightActiveLineGutter(),
79
+ lintGutter(),
80
+ highlightActiveLine()
81
+ ]
82
+ });
83
+ }
84
+ set debugLine(value) {
85
+ var _a;
86
+ (_a = this.view) === null || _a === void 0 ? void 0 : _a.dispatch({
87
+ effects: setDebugLines.of(value ? [value] : []),
88
+ });
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 ? readOnlyRangesExtension(state => {
113
+ const line = state.doc.lines - value + 1;
114
+ return [{ from: state.doc.line(line).from, to: state.doc.length }];
115
+ }) : [],
116
+ });
117
+ }
118
+ set testTranslations(value) {
119
+ this.configure({
120
+ test: [
121
+ testLineExtension,
122
+ testCodeWidgetExtension(value, () => {
123
+ this.dispatchEvent(new CustomEvent("edit-test-code"));
124
+ }, () => {
125
+ this.dispatchEvent(new CustomEvent("remove-test-code"));
126
+ }),
127
+ ]
128
+ });
129
+ }
130
+ set programmingLanguage(value) {
131
+ if (!(value in languageExtensions)) {
132
+ console.warn(`Language ${value} not supported, defaulting to javascript`);
133
+ this.configure({
134
+ language: languageExtensions.JavaScript,
135
+ });
136
+ return;
137
+ }
138
+ this.configure({
139
+ language: languageExtensions[value],
140
+ });
141
+ }
142
+ set lintingSource(lintSource) {
143
+ this.configure({
144
+ linting: linter((view) => __awaiter(this, void 0, void 0, function* () {
145
+ const workerDiagnostics = yield lintSource();
146
+ if (workerDiagnostics.some(d => d.lineNr > view.state.doc.lines || d.endLineNr > view.state.doc.lines)) {
147
+ // if the diagnostics are out of range, the document has changed since the linting was requested
148
+ // these diagnostics are no longer valid
149
+ return [];
150
+ }
151
+ return workerDiagnostics.map(d => {
152
+ const fromline = view.state.doc.line(d.lineNr);
153
+ const toLine = view.state.doc.line(d.endLineNr);
154
+ const from = Math.min(fromline.from + d.columnNr, fromline.to);
155
+ const to = Math.min(toLine.from + d.endColumnNr, toLine.to);
156
+ return Object.assign(Object.assign({}, d), { from: from, to: to });
157
+ });
158
+ }))
159
+ });
160
+ }
161
+ set indentLength(length) {
162
+ this.configure({
163
+ indentUnit: indentUnit.of(" ".repeat(length))
164
+ });
165
+ }
166
+ constructor() {
167
+ super();
168
+ this.configure({
169
+ language: [],
170
+ codingExtensions: [
171
+ lineNumbers(),
172
+ highlightSpecialChars(),
173
+ history(),
174
+ foldGutter(),
175
+ drawSelection(),
176
+ EditorState.allowMultipleSelections.of(true),
177
+ indentOnInput(),
178
+ bracketMatching(),
179
+ closeBrackets(),
180
+ autocompletion(),
181
+ rectangularSelection(),
182
+ highlightSelectionMatches(),
183
+ keymap.of([
184
+ ...closeBracketsKeymap,
185
+ ...defaultKeymap,
186
+ ...searchKeymap,
187
+ ...historyKeymap,
188
+ ...completionKeymap,
189
+ ...tabCompletionKeyMap,
190
+ ...lintKeymap,
191
+ indentWithTab
192
+ ]),
193
+ ],
194
+ debugging: [
195
+ highlightActiveLineGutter(),
196
+ lintGutter(),
197
+ highlightActiveLine()
198
+ ],
199
+ });
200
+ }
201
+ };
202
+ CodeEditor = __decorate([
203
+ customElement("p-code-editor")
204
+ ], CodeEditor);
205
+ export { CodeEditor };
206
+ //# 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,20 @@
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
+ protected view: EditorView | undefined;
7
+ protected readonly compartments: Map<string, Compartment>;
8
+ protected readonly extensions: Map<string, Extension>;
9
+ set value(value: string);
10
+ protected dispatchChange(): void;
11
+ get value(): string;
12
+ set placeholder(value: string);
13
+ set theme(theme: Extension);
14
+ set translations(translations: Record<string, string>);
15
+ private initView;
16
+ private onViewUpdate;
17
+ connectedCallback(): void;
18
+ disconnectedCallback(): void;
19
+ protected configure(extensions: Record<string, Extension>): void;
20
+ }
@@ -0,0 +1,99 @@
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.compartments = new Map();
16
+ this.extensions = new Map();
17
+ }
18
+ set value(value) {
19
+ if (this.__value === value)
20
+ return;
21
+ this.__value = value;
22
+ if (!this.view)
23
+ return;
24
+ this.dispatchChange();
25
+ }
26
+ dispatchChange() {
27
+ if (!this.view)
28
+ return;
29
+ this.view.dispatch({
30
+ changes: {
31
+ from: 0,
32
+ to: this.view.state.doc.length,
33
+ insert: this.__value
34
+ }
35
+ });
36
+ }
37
+ get value() {
38
+ return this.__value;
39
+ }
40
+ set placeholder(value) {
41
+ this.configure({
42
+ placeholder: placeholder(value),
43
+ });
44
+ }
45
+ set theme(theme) {
46
+ this.configure({ theme: theme });
47
+ }
48
+ set translations(translations) {
49
+ this.configure({ translations: EditorState.phrases.of(translations) });
50
+ }
51
+ initView() {
52
+ this.view = new EditorView({
53
+ parent: this.shadowRoot,
54
+ state: EditorState.create({ doc: this.__value, extensions: [
55
+ EditorView.updateListener.of(this.onViewUpdate.bind(this)),
56
+ [...this.compartments.keys().map(k => this.compartments.get(k).of([]))],
57
+ ] })
58
+ });
59
+ this.configure(Object.fromEntries(this.extensions));
60
+ }
61
+ onViewUpdate(v) {
62
+ if (v.docChanged) {
63
+ this.__value = v.state.doc.toString();
64
+ this.dispatchEvent(new CustomEvent("change", { detail: this.value }));
65
+ }
66
+ }
67
+ connectedCallback() {
68
+ super.connectedCallback();
69
+ this.initView();
70
+ }
71
+ disconnectedCallback() {
72
+ var _a;
73
+ super.disconnectedCallback();
74
+ (_a = this.view) === null || _a === void 0 ? void 0 : _a.destroy();
75
+ this.view = undefined;
76
+ }
77
+ configure(extensions) {
78
+ Object.entries(extensions).forEach(([key, ext]) => {
79
+ this.extensions.set(key, ext);
80
+ });
81
+ const effects = Object.keys(extensions).map(key => {
82
+ const extension = extensions[key];
83
+ if (this.compartments.has(key)) {
84
+ return this.compartments.get(key).reconfigure(extension);
85
+ }
86
+ const compartment = new Compartment();
87
+ this.compartments.set(key, compartment);
88
+ return StateEffect.appendConfig.of(compartment.of(extension));
89
+ });
90
+ if (this.view) {
91
+ this.view.dispatch({ effects });
92
+ }
93
+ }
94
+ };
95
+ CodeMirrorEditor = __decorate([
96
+ customElement("p-code-mirror-editor")
97
+ ], CodeMirrorEditor);
98
+ export { CodeMirrorEditor };
99
+ //# 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,169 @@
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 = [
68
+ stateField,
69
+ gutterHighlighter,
70
+ lineDecorationPlugin,
71
+ ];
72
+ if (config.marker !== undefined) {
73
+ class CustomMarker extends GutterMarker {
74
+ toDOM() {
75
+ const element = document.createElement("div");
76
+ element.textContent = config.marker;
77
+ return element;
78
+ }
79
+ }
80
+ const customMarker = new CustomMarker();
81
+ const customGutter = gutter({
82
+ class: "cm-custom-gutter",
83
+ markers: () => {
84
+ return RangeSet.empty;
85
+ },
86
+ lineMarker: (view, line) => {
87
+ const lines = view.state.field(stateField);
88
+ if (lines === undefined || lines.length === 0) {
89
+ return null;
90
+ }
91
+ for (const lineNum of lines) {
92
+ if (lineNum <= view.state.doc.lines && line.from === view.state.doc.line(lineNum).from) {
93
+ return customMarker;
94
+ }
95
+ }
96
+ return null;
97
+ },
98
+ });
99
+ extensions.push(customGutter);
100
+ extensions.push(EditorView.baseTheme({
101
+ ".cm-custom-gutter": {
102
+ width: "17px",
103
+ textAlign: "center",
104
+ },
105
+ }));
106
+ }
107
+ return [
108
+ extensions,
109
+ setLines,
110
+ stateField,
111
+ ];
112
+ }
113
+ export const [usedLineExtension, setUsedLines, usedLineState] = lineEffectExtension({ marker: "✔" });
114
+ export const [debugLineExtension, setDebugLines, debugLineState] = lineEffectExtension({ marker: "▶" });
115
+ export const [testLineExtension, setTestLines, testLineState] = lineEffectExtension({ lineClass: "papyros-test-line", gutterClass: "papyros-test-line" });
116
+ export function testCodeWidgetExtension(translations, handleEdit, handleRemove) {
117
+ class TestCodeWidget extends WidgetType {
118
+ toDOM() {
119
+ const element = document.createElement("div");
120
+ element.classList.add("papyros-test-code-widget");
121
+ const span = document.createElement("span");
122
+ span.innerText = translations.description;
123
+ element.appendChild(span);
124
+ const buttons = document.createElement("div");
125
+ buttons.classList.add("papyros-test-code-buttons");
126
+ const editButton = document.createElement("a");
127
+ editButton.classList.add("papyros-icon-link");
128
+ editButton.innerHTML = "🖉";
129
+ editButton.addEventListener("click", handleEdit);
130
+ editButton.title = translations.edit;
131
+ buttons.appendChild(editButton);
132
+ const deleteButton = document.createElement("a");
133
+ deleteButton.classList.add("papyros-icon-link");
134
+ deleteButton.innerHTML = "⨯";
135
+ deleteButton.addEventListener("click", handleRemove);
136
+ deleteButton.title = translations.remove;
137
+ buttons.appendChild(deleteButton);
138
+ element.appendChild(buttons);
139
+ return element;
140
+ }
141
+ ignoreEvent() {
142
+ return false;
143
+ }
144
+ }
145
+ const testCodeDecoration = Decoration.widget({ widget: new TestCodeWidget(), side: -1, block: true });
146
+ function getDecorations(state) {
147
+ const lines = state.field(testLineState);
148
+ if (!lines || lines.length === 0)
149
+ return Decoration.none;
150
+ const minLine = Math.min(...lines);
151
+ if (minLine > state.doc.lines)
152
+ return Decoration.none;
153
+ return Decoration.set([testCodeDecoration.range(state.doc.line(minLine).from)]);
154
+ }
155
+ return StateField.define({
156
+ create(state) {
157
+ return getDecorations(state);
158
+ },
159
+ update(deco, tr) {
160
+ for (const effect of tr.effects) {
161
+ if (effect.is(setTestLines) || tr.docChanged)
162
+ return getDecorations(tr.state);
163
+ }
164
+ return deco.map(tr.changes);
165
+ },
166
+ provide: f => EditorView.decorations.from(f),
167
+ });
168
+ }
169
+ //# sourceMappingURL=Extensions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Extensions.js","sourceRoot":"","sources":["../../../../src/frontend/components/code_mirror/Extensions.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ import { HighlightStyle } from "@codemirror/language";
2
+ import { Extension } from "@codemirror/state";
3
+ export declare const materialTheme: Extension;
4
+ export declare const materialHighlight: HighlightStyle;
5
+ export declare const material: Extension;
@@ -0,0 +1,109 @@
1
+ import { EditorView } from "@codemirror/view";
2
+ import { HighlightStyle, syntaxHighlighting } from "@codemirror/language";
3
+ import { tags } from "@lezer/highlight";
4
+ export const materialTheme = EditorView.theme({
5
+ ".cm-scroller": { overflow: "auto" },
6
+ "&": {
7
+ height: "100%", // use full height of host
8
+ width: "100%", // use full width of host
9
+ "font-size": "14px", // use proper size to align gutters with editor
10
+ backgroundColor: "var(--md-sys-color-surface-container-highest)",
11
+ color: "var(--md-sys-color-on-background)",
12
+ },
13
+ ".cm-gutters": {
14
+ backgroundColor: "var(--md-sys-color-surface-container)",
15
+ color: "var(--md-sys-color-on-surface-variant)",
16
+ border: "none",
17
+ fontSize: "12px",
18
+ },
19
+ ".cm-content": {
20
+ color: "var(--md-sys-color-on-background)",
21
+ },
22
+ ".cm-activeLine, .cm-activeLineGutter": {
23
+ backgroundColor: "color-mix(in srgb, var(--md-sys-color-primary) 10%, transparent) !important",
24
+ },
25
+ "&.cm-focused": {
26
+ outline: "none",
27
+ },
28
+ ".cm-selectionBackground": {
29
+ backgroundColor: "color-mix(in srgb, var(--md-sys-color-primary) 30%, transparent) !important",
30
+ },
31
+ ".cm-cursor, .cm-dropCursor": {
32
+ borderLeft: "1.2px solid var(--md-sys-color-secondary) !important",
33
+ },
34
+ ".cm-tooltip": {
35
+ backgroundColor: "var(--md-sys-color-surface)",
36
+ border: "none",
37
+ boxShadow: "0px 2px 6px rgba(0,0,0,0.2)",
38
+ "& li[aria-selected]": {
39
+ backgroundColor: "var(--md-sys-color-secondary)",
40
+ color: "var(--md-sys-color-on-secondary)",
41
+ },
42
+ },
43
+ ".cm-panels": {
44
+ backgroundColor: "var(--md-sys-color-surface-container)",
45
+ color: "var(--md-sys-color-on-surface)",
46
+ border: "none",
47
+ },
48
+ ".cm-searchMatch": {
49
+ backgroundColor: "color-mix(in srgb, var(--md-sys-color-secondary) 30%, transparent)",
50
+ },
51
+ ".cm-searchMatch.cm-searchMatch-selected": {
52
+ backgroundColor: "color-mix(in srgb, var(--md-sys-color-surface-variant) 30%, transparent)",
53
+ outline: "1px solid var(--md-sys-color-outline)",
54
+ },
55
+ ".cm-selectionMatch": {
56
+ backgroundColor: "color-mix(in srgb, var(--md-sys-color-secondary) 30%, transparent)",
57
+ },
58
+ ".cm-button": {
59
+ background: "var(--md-sys-color-surface-variant)",
60
+ color: "var(--md-sys-color-on-surface-variant)",
61
+ border: "none",
62
+ },
63
+ ".cm-button:hover": {
64
+ background: "var(--md-sys-color-secondary)",
65
+ color: "var(--md-sys-color-on-secondary)",
66
+ },
67
+ ".cm-textfield": {
68
+ background: "var(--md-sys-color-surface-variant)",
69
+ color: "var(--md-sys-color-on-surface-variant)",
70
+ border: "none",
71
+ },
72
+ ".cm-textfield:focus": {
73
+ outline: "none",
74
+ border: "none",
75
+ boxShadow: "0 0 0 2px var(--md-sys-color-primary)",
76
+ },
77
+ }, { dark: false });
78
+ export const materialHighlight = HighlightStyle.define([
79
+ // Comments
80
+ { tag: [tags.comment, tags.lineComment, tags.blockComment, tags.docComment], color: "var(--md-sys-color-on-surface-variant)" },
81
+ // Keywords & operators
82
+ { tag: [tags.keyword, tags.self, tags.controlKeyword, tags.operatorKeyword, tags.operator], color: "var(--md-sys-color-primary)" },
83
+ { tag: [tags.definitionKeyword, tags.moduleKeyword], color: "var(--md-sys-color-primary)", fontStyle: "italic" },
84
+ // Names
85
+ { tag: [tags.variableName, tags.className, tags.namespace], color: "var(--md-sys-color-on-background)" },
86
+ { tag: tags.standard(tags.variableName), color: "var(--md-sys-color-tertiary)", fontStyle: "italic" },
87
+ { tag: [tags.function(tags.variableName), tags.attributeName], color: "var(--md-sys-color-tertiary)" },
88
+ { tag: tags.typeName, color: "var(--md-sys-color-primary)" },
89
+ { tag: tags.labelName, color: "var(--md-sys-color-primary)", fontStyle: "italic" },
90
+ // Literals
91
+ { tag: tags.string, color: "var(--md-sys-color-secondary)" },
92
+ { tag: tags.number, color: "var(--md-sys-color-secondary)" },
93
+ { tag: tags.regexp, color: "var(--md-sys-color-secondary)" },
94
+ { tag: tags.atom, color: "var(--md-sys-color-secondary)" },
95
+ { tag: tags.bool, color: "var(--md-sys-color-secondary)" },
96
+ // Emphasis / headings
97
+ { tag: tags.emphasis, textDecoration: "underline" },
98
+ { tag: tags.strong, fontWeight: "bold" },
99
+ { tag: tags.strikethrough, textDecoration: "line-through" },
100
+ { tag: tags.heading, fontWeight: "bold", color: "var(--md-sys-color-on-background)" },
101
+ // Errors / diffs
102
+ { tag: tags.invalid, color: "var(--md-sys-color-error)" },
103
+ { tag: tags.deleted, color: "var(--md-sys-color-error)" },
104
+ { tag: tags.inserted, color: "var(--md-sys-color-on-background)", fontWeight: "bold" },
105
+ // Punctuation
106
+ { tag: [tags.punctuation, tags.separator, tags.bracket], color: "var(--md-sys-color-on-background)" },
107
+ ]);
108
+ export const material = [materialTheme, syntaxHighlighting(materialHighlight)];
109
+ //# sourceMappingURL=MaterialTheme.js.map