@datalayer/jupyter-react 0.0.8 → 0.0.11

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 (216) hide show
  1. package/lib/JupyterExample.d.ts +1 -0
  2. package/lib/JupyterExample.js +56 -0
  3. package/lib/JupyterExample.js.map +1 -0
  4. package/lib/JupyterLiteExample.d.ts +1 -0
  5. package/lib/JupyterLiteExample.js +10 -0
  6. package/lib/JupyterLiteExample.js.map +1 -0
  7. package/lib/components/cell/Cell.css +12 -3
  8. package/lib/components/cell/Cell.d.ts +16 -0
  9. package/lib/components/cell/Cell.js +56 -0
  10. package/lib/components/cell/Cell.js.map +1 -0
  11. package/lib/components/cell/CellAdapter.d.ts +15 -0
  12. package/lib/components/cell/CellAdapter.js +133 -0
  13. package/lib/components/cell/CellAdapter.js.map +1 -0
  14. package/lib/components/cell/CellCommands.d.ts +6 -0
  15. package/lib/components/cell/CellCommands.js +38 -0
  16. package/lib/components/cell/CellCommands.js.map +1 -0
  17. package/lib/components/cell/CellState.d.ts +22 -0
  18. package/lib/components/cell/CellState.js +46 -0
  19. package/lib/components/cell/CellState.js.map +1 -0
  20. package/lib/components/codemirror/CodeMirrorEditor.d.ts +14 -0
  21. package/lib/components/codemirror/CodeMirrorEditor.js +110 -0
  22. package/lib/components/codemirror/CodeMirrorEditor.js.map +1 -0
  23. package/lib/components/codemirror/CodeMirrorTheme.d.ts +3 -0
  24. package/lib/components/codemirror/CodeMirrorTheme.js +21 -0
  25. package/lib/components/codemirror/CodeMirrorTheme.js.map +1 -0
  26. package/lib/components/commands/Commands.d.ts +2 -0
  27. package/lib/components/commands/Commands.js +9 -0
  28. package/lib/components/commands/Commands.js.map +1 -0
  29. package/lib/components/commands/CommandsAdapter.d.ts +9 -0
  30. package/lib/components/commands/CommandsAdapter.js +36 -0
  31. package/lib/components/commands/CommandsAdapter.js.map +1 -0
  32. package/lib/components/commands/CommandsState.d.ts +15 -0
  33. package/lib/components/commands/CommandsState.js +30 -0
  34. package/lib/components/commands/CommandsState.js.map +1 -0
  35. package/lib/components/console/{ConsoleAdapter.css → Console.css} +4 -0
  36. package/lib/components/console/Console.d.ts +3 -0
  37. package/lib/components/console/Console.js +15 -0
  38. package/lib/components/console/Console.js.map +1 -0
  39. package/lib/components/console/ConsoleAdapter.d.ts +13 -0
  40. package/lib/components/console/ConsoleAdapter.js +84 -0
  41. package/lib/components/console/ConsoleAdapter.js.map +1 -0
  42. package/lib/components/console/ConsoleState.d.ts +15 -0
  43. package/lib/components/console/ConsoleState.js +30 -0
  44. package/lib/components/console/ConsoleState.js.map +1 -0
  45. package/lib/components/dialog/Dialog.d.ts +2 -0
  46. package/lib/components/dialog/Dialog.js +13 -0
  47. package/lib/components/dialog/Dialog.js.map +1 -0
  48. package/lib/components/dialog/DialogAdapter.d.ts +10 -0
  49. package/lib/components/dialog/DialogAdapter.js +19 -0
  50. package/lib/components/dialog/DialogAdapter.js.map +1 -0
  51. package/lib/components/filebrowser/FileBrowser.d.ts +2 -0
  52. package/lib/components/filebrowser/FileBrowser.js +9 -0
  53. package/lib/components/filebrowser/FileBrowser.js.map +1 -0
  54. package/lib/components/filebrowser/FileBrowserAdapter.d.ts +13 -0
  55. package/lib/components/filebrowser/FileBrowserAdapter.js +267 -0
  56. package/lib/components/filebrowser/FileBrowserAdapter.js.map +1 -0
  57. package/lib/components/filebrowser/FileBrowserState.d.ts +15 -0
  58. package/lib/components/filebrowser/FileBrowserState.js +30 -0
  59. package/lib/components/filebrowser/FileBrowserState.js.map +1 -0
  60. package/lib/components/ipywidgets/IpyWidgetsComponent.d.ts +5 -0
  61. package/lib/components/ipywidgets/IpyWidgetsComponent.js +9 -0
  62. package/lib/components/ipywidgets/IpyWidgetsComponent.js.map +1 -0
  63. package/lib/components/notebook/Notebook.css +2 -26
  64. package/lib/components/notebook/Notebook.d.ts +36 -0
  65. package/lib/components/notebook/Notebook.js +138 -0
  66. package/lib/components/notebook/Notebook.js.map +1 -0
  67. package/lib/components/notebook/NotebookAdapter.d.ts +38 -0
  68. package/lib/components/notebook/NotebookAdapter.js +301 -0
  69. package/lib/components/notebook/NotebookAdapter.js.map +1 -0
  70. package/lib/components/notebook/NotebookCommands.d.ts +43 -0
  71. package/lib/components/notebook/NotebookCommands.js +380 -0
  72. package/lib/components/notebook/NotebookCommands.js.map +1 -0
  73. package/lib/components/notebook/NotebookState.d.ts +69 -0
  74. package/lib/components/notebook/NotebookState.js +184 -0
  75. package/lib/components/notebook/NotebookState.js.map +1 -0
  76. package/lib/components/notebook/cell/metadata/CellMetadataEditor.d.ts +7 -0
  77. package/lib/components/notebook/cell/metadata/CellMetadataEditor.js +43 -0
  78. package/lib/components/notebook/cell/metadata/CellMetadataEditor.js.map +1 -0
  79. package/lib/components/notebook/cell/metadata/NbGraderCells.d.ts +12 -0
  80. package/lib/components/notebook/cell/metadata/NbGraderCells.js +138 -0
  81. package/lib/components/notebook/cell/metadata/NbGraderCells.js.map +1 -0
  82. package/lib/components/notebook/cell/prompt/InputPrompt.d.ts +18 -0
  83. package/lib/components/notebook/cell/prompt/InputPrompt.js +69 -0
  84. package/lib/components/notebook/cell/prompt/InputPrompt.js.map +1 -0
  85. package/lib/components/notebook/cell/sidebar/CellSidebarDefault.d.ts +3 -0
  86. package/lib/components/notebook/cell/sidebar/CellSidebarDefault.js +63 -0
  87. package/lib/components/notebook/cell/sidebar/CellSidebarDefault.js.map +1 -0
  88. package/lib/components/notebook/cell/sidebar/CellSidebarRun.d.ts +3 -0
  89. package/lib/components/notebook/cell/sidebar/CellSidebarRun.js +38 -0
  90. package/lib/components/notebook/cell/sidebar/CellSidebarRun.js.map +1 -0
  91. package/lib/components/notebook/cell/sidebar/base/CellSidebarContentFactory.d.ts +19 -0
  92. package/lib/components/notebook/cell/sidebar/base/CellSidebarContentFactory.js +22 -0
  93. package/lib/components/notebook/cell/sidebar/base/CellSidebarContentFactory.js.map +1 -0
  94. package/lib/components/notebook/cell/sidebar/base/CellSidebarWidget.d.ts +16 -0
  95. package/lib/components/notebook/cell/sidebar/base/CellSidebarWidget.js +25 -0
  96. package/lib/components/notebook/cell/sidebar/base/CellSidebarWidget.js.map +1 -0
  97. package/lib/components/notebook/marked/marked.d.ts +3 -0
  98. package/lib/components/notebook/marked/marked.js +72 -0
  99. package/lib/components/notebook/marked/marked.js.map +1 -0
  100. package/lib/components/notebook/model/CustomNotebookModelFactory.d.ts +9 -0
  101. package/lib/components/notebook/model/CustomNotebookModelFactory.js +14 -0
  102. package/lib/components/notebook/model/CustomNotebookModelFactory.js.map +1 -0
  103. package/lib/components/outputs/Output.css +8 -0
  104. package/lib/components/outputs/Output.d.ts +25 -0
  105. package/lib/components/outputs/Output.js +126 -0
  106. package/lib/components/outputs/Output.js.map +1 -0
  107. package/lib/components/outputs/OutputAdapter.d.ts +19 -0
  108. package/lib/components/outputs/OutputAdapter.js +81 -0
  109. package/lib/components/outputs/OutputAdapter.js.map +1 -0
  110. package/lib/components/outputs/OutputState.d.ts +54 -0
  111. package/lib/components/outputs/OutputState.js +122 -0
  112. package/lib/components/outputs/OutputState.js.map +1 -0
  113. package/lib/components/outputs/OutputToolbar.d.ts +12 -0
  114. package/lib/components/outputs/OutputToolbar.js +42 -0
  115. package/lib/components/outputs/OutputToolbar.js.map +1 -0
  116. package/lib/components/settings/Settings.d.ts +2 -0
  117. package/lib/components/settings/Settings.js +9 -0
  118. package/lib/components/settings/Settings.js.map +1 -0
  119. package/lib/components/settings/SettingsAdapter.d.ts +10 -0
  120. package/lib/components/settings/SettingsAdapter.js +16 -0
  121. package/lib/components/settings/SettingsAdapter.js.map +1 -0
  122. package/lib/components/settings/SettingsState.d.ts +15 -0
  123. package/lib/components/settings/SettingsState.js +30 -0
  124. package/lib/components/settings/SettingsState.js.map +1 -0
  125. package/lib/components/terminal/Terminal.d.ts +2 -0
  126. package/lib/components/terminal/Terminal.js +16 -0
  127. package/lib/components/terminal/Terminal.js.map +1 -0
  128. package/lib/components/terminal/TerminalAdapter.d.ts +13 -0
  129. package/lib/components/terminal/TerminalAdapter.js +28 -0
  130. package/lib/components/terminal/TerminalAdapter.js.map +1 -0
  131. package/lib/components/terminal/TerminalState.d.ts +15 -0
  132. package/lib/components/terminal/TerminalState.js +38 -0
  133. package/lib/components/terminal/TerminalState.js.map +1 -0
  134. package/lib/index.d.ts +43 -0
  135. package/lib/index.js +58 -0
  136. package/lib/index.js.map +1 -0
  137. package/lib/jupyter/Jupyter.d.ts +31 -0
  138. package/lib/jupyter/Jupyter.js +30 -0
  139. package/lib/jupyter/Jupyter.js.map +1 -0
  140. package/lib/jupyter/JupyterAuthError.d.ts +7 -0
  141. package/lib/jupyter/JupyterAuthError.js +8 -0
  142. package/lib/jupyter/JupyterAuthError.js.map +1 -0
  143. package/lib/jupyter/JupyterConfig.d.ts +38 -0
  144. package/lib/jupyter/JupyterConfig.js +83 -0
  145. package/lib/jupyter/JupyterConfig.js.map +1 -0
  146. package/lib/jupyter/JupyterContext.d.ts +39 -0
  147. package/lib/jupyter/JupyterContext.js +89 -0
  148. package/lib/jupyter/JupyterContext.js.map +1 -0
  149. package/lib/jupyter/JupyterHandlers.d.ts +8 -0
  150. package/lib/jupyter/JupyterHandlers.js +50 -0
  151. package/lib/jupyter/JupyterHandlers.js.map +1 -0
  152. package/lib/jupyter/ipywidgets/IPyWidgetsAttached.d.ts +8 -0
  153. package/lib/jupyter/ipywidgets/IPyWidgetsAttached.js +15 -0
  154. package/lib/jupyter/ipywidgets/IPyWidgetsAttached.js.map +1 -0
  155. package/lib/jupyter/ipywidgets/IPyWidgetsClassicManager.d.ts +18 -0
  156. package/lib/jupyter/ipywidgets/IPyWidgetsClassicManager.js +76 -0
  157. package/lib/jupyter/ipywidgets/IPyWidgetsClassicManager.js.map +1 -0
  158. package/lib/jupyter/ipywidgets/IPyWidgetsJupyterLabPlugin.d.ts +15 -0
  159. package/lib/jupyter/ipywidgets/IPyWidgetsJupyterLabPlugin.js +178 -0
  160. package/lib/jupyter/ipywidgets/IPyWidgetsJupyterLabPlugin.js.map +1 -0
  161. package/lib/jupyter/ipywidgets/IpyWidgetsManager.d.ts +11 -0
  162. package/lib/jupyter/ipywidgets/IpyWidgetsManager.js +71 -0
  163. package/lib/jupyter/ipywidgets/IpyWidgetsManager.js.map +1 -0
  164. package/lib/jupyter/ipywidgets/plotly/Figure.d.ts +587 -0
  165. package/lib/jupyter/ipywidgets/plotly/Figure.js +1697 -0
  166. package/lib/jupyter/ipywidgets/plotly/Figure.js.map +1 -0
  167. package/lib/jupyter/ipywidgets/plotly/JupyterlabPlugin.d.ts +5 -0
  168. package/lib/jupyter/ipywidgets/plotly/JupyterlabPlugin.js +12 -0
  169. package/lib/jupyter/ipywidgets/plotly/JupyterlabPlugin.js.map +1 -0
  170. package/lib/jupyter/ipywidgets/plotly/Version.d.ts +8 -0
  171. package/lib/jupyter/ipywidgets/plotly/Version.js +16 -0
  172. package/lib/jupyter/ipywidgets/plotly/Version.js.map +1 -0
  173. package/lib/jupyter/ipywidgets/plotly/index.d.ts +2 -0
  174. package/lib/jupyter/ipywidgets/plotly/index.js +4 -0
  175. package/lib/jupyter/ipywidgets/plotly/index.js.map +1 -0
  176. package/lib/jupyter/lite/LiteServer.d.ts +2 -0
  177. package/lib/jupyter/lite/LiteServer.js +87 -0
  178. package/lib/jupyter/lite/LiteServer.js.map +1 -0
  179. package/lib/jupyter/lumino/LuminoAttached.d.ts +3 -0
  180. package/lib/jupyter/lumino/LuminoAttached.js +21 -0
  181. package/lib/jupyter/lumino/LuminoAttached.js.map +1 -0
  182. package/lib/jupyter/lumino/LuminoDetached.d.ts +9 -0
  183. package/lib/jupyter/lumino/LuminoDetached.js +13 -0
  184. package/lib/jupyter/lumino/LuminoDetached.js.map +1 -0
  185. package/lib/jupyter/lumino/LuminoNotebook.d.ts +5 -0
  186. package/lib/jupyter/lumino/LuminoNotebook.js +28 -0
  187. package/lib/jupyter/lumino/LuminoNotebook.js.map +1 -0
  188. package/lib/jupyter/lumino/LuminoObservable.d.ts +6 -0
  189. package/lib/jupyter/lumino/LuminoObservable.js +16 -0
  190. package/lib/jupyter/lumino/LuminoObservable.js.map +1 -0
  191. package/lib/jupyter/lumino/LuminoReactPortal.d.ts +180 -0
  192. package/lib/jupyter/lumino/LuminoReactPortal.js +195 -0
  193. package/lib/jupyter/lumino/LuminoReactPortal.js.map +1 -0
  194. package/lib/jupyter/lumino/LuminoRedux.d.ts +8 -0
  195. package/lib/jupyter/lumino/LuminoRedux.js +2 -0
  196. package/lib/jupyter/lumino/LuminoRedux.js.map +1 -0
  197. package/lib/jupyter/services/Services.d.ts +16 -0
  198. package/lib/jupyter/services/Services.js +41 -0
  199. package/lib/jupyter/services/Services.js.map +1 -0
  200. package/lib/jupyter/services/kernel/Kernel.d.ts +15 -0
  201. package/lib/jupyter/services/kernel/Kernel.js +65 -0
  202. package/lib/jupyter/services/kernel/Kernel.js.map +1 -0
  203. package/lib/jupyter/services/kernel/KernelModel.d.ts +18 -0
  204. package/lib/jupyter/services/kernel/KernelModel.js +52 -0
  205. package/lib/jupyter/services/kernel/KernelModel.js.map +1 -0
  206. package/lib/state/State.d.ts +14 -0
  207. package/lib/state/State.js +32 -0
  208. package/lib/state/State.js.map +1 -0
  209. package/lib/state/Store.d.ts +6 -0
  210. package/lib/state/Store.js +35 -0
  211. package/lib/state/Store.js.map +1 -0
  212. package/lib/utils/Ids.d.ts +2 -0
  213. package/lib/utils/Ids.js +11 -0
  214. package/lib/utils/Ids.js.map +1 -0
  215. package/package.json +41 -39
  216. package/lib/components/outputs/OutputAdapter.css +0 -3
@@ -0,0 +1 @@
1
+ import "./../style/index.css";
@@ -0,0 +1,56 @@
1
+ import { jsxs as _jsxs, Fragment as _Fragment, jsx as _jsx } from "@emotion/react/jsx-runtime";
2
+ import { useState } from "react";
3
+ import { useDispatch } from "react-redux";
4
+ import { createRoot } from 'react-dom/client';
5
+ import { Box, Button, ButtonGroup } from '@primer/react';
6
+ import Jupyter from './jupyter/Jupyter';
7
+ import { useJupyter } from './jupyter/JupyterContext';
8
+ import Kernel from './jupyter/services/kernel/Kernel';
9
+ import Cell from './components/cell/Cell';
10
+ import { selectCell, cellActions } from './components/cell/CellState';
11
+ import Notebook from './components/notebook/Notebook';
12
+ import { notebookActions } from './components/notebook/NotebookState';
13
+ import CellSidebarDefault from './components/notebook/cell/sidebar/CellSidebarDefault';
14
+ import Output from "./components/outputs/Output";
15
+ import "./../style/index.css";
16
+ const SOURCE_IPYWIDGET = `import ipywidgets as widgets
17
+ widgets.IntSlider(
18
+ value=7,
19
+ min=0,
20
+ max=10,
21
+ step=1
22
+ )`;
23
+ const CellPreview = () => {
24
+ const cell = selectCell();
25
+ return (_jsxs(_Fragment, { children: [_jsxs("div", { children: ["source: ", cell.source] }, void 0),
26
+ _jsxs("div", { children: ["kernel available: ", String(cell.kernelAvailable)] }, void 0)] }, void 0));
27
+ };
28
+ const CellToolbar = () => {
29
+ const cell = selectCell();
30
+ const dispatch = useDispatch();
31
+ return (_jsxs(_Fragment, { children: [_jsx(Box, Object.assign({ display: "flex" }, { children: _jsxs(ButtonGroup, { children: [_jsx(Button, Object.assign({ variant: "default", size: "small", onClick: () => dispatch(cellActions.execute()) }, { children: "Run the cell" }), void 0),
32
+ _jsx(Button, Object.assign({ variant: "outline", size: "small", onClick: () => dispatch(cellActions.outputsCount(0)) }, { children: "Reset outputs count" }), void 0)] }, void 0) }), void 0),
33
+ _jsxs(Box, { children: ["Outputs count: ", cell.outputsCount] }, void 0)] }, void 0));
34
+ };
35
+ const NotebookToolbar = () => {
36
+ const dispatch = useDispatch();
37
+ return (_jsx(_Fragment, { children: _jsx(Box, Object.assign({ display: "flex" }, { children: _jsxs(ButtonGroup, { children: [_jsx(Button, Object.assign({ variant: "default", size: "small", onClick: () => dispatch(notebookActions.save.started(undefined)) }, { children: "Save the notebook" }), void 0),
38
+ _jsx(Button, Object.assign({ variant: "default", size: "small", onClick: () => dispatch(notebookActions.runAll.started()) }, { children: "Run all" }), void 0)] }, void 0) }), void 0) }, void 0));
39
+ };
40
+ const OutputExample = () => {
41
+ const { baseUrl, wsUrl } = useJupyter();
42
+ const [kernel,] = useState(new Kernel({ baseUrl, wsUrl }));
43
+ return (_jsx(Output, { showEditor: true, autoRun: true, kernel: kernel, code: SOURCE_IPYWIDGET }, void 0));
44
+ };
45
+ const div = document.createElement('div');
46
+ document.body.appendChild(div);
47
+ const root = createRoot(div);
48
+ root.render(_jsxs(Jupyter, { children: [_jsx(CellPreview, {}, void 0),
49
+ _jsx(CellToolbar, {}, void 0),
50
+ _jsx(Cell, {}, void 0),
51
+ _jsx("hr", {}, void 0),
52
+ _jsx(OutputExample, {}, void 0),
53
+ _jsx("hr", {}, void 0),
54
+ _jsx(NotebookToolbar, {}, void 0),
55
+ _jsx(Notebook, { path: "test.ipynb", CellSidebar: CellSidebarDefault }, void 0)] }, void 0));
56
+ //# sourceMappingURL=JupyterExample.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"JupyterExample.js","sourceRoot":"","sources":["../src/JupyterExample.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ import "./../style/index.css";
@@ -0,0 +1,10 @@
1
+ import { jsx as _jsx } from "@emotion/react/jsx-runtime";
2
+ import { createRoot } from 'react-dom/client';
3
+ import Jupyter from './jupyter/Jupyter';
4
+ import Console from './components/console/Console';
5
+ import "./../style/index.css";
6
+ const div = document.createElement('div');
7
+ document.body.appendChild(div);
8
+ const root = createRoot(div);
9
+ root.render(_jsx(Jupyter, Object.assign({ lite: true }, { children: _jsx(Console, {}, void 0) }), void 0));
10
+ //# sourceMappingURL=JupyterLiteExample.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"JupyterLiteExample.js","sourceRoot":"","sources":["../src/JupyterLiteExample.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,OAAO,MAAM,mBAAmB,CAAC;AACxC,OAAO,OAAO,MAAM,8BAA8B,CAAC;AAEnD,OAAO,sBAAsB,CAAC;AAE9B,MAAM,GAAG,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;AAC1C,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;AAC/B,MAAM,IAAI,GAAG,UAAU,CAAC,GAAG,CAAC,CAAA;AAE5B,IAAI,CAAC,MAAM,CACT,KAAC,OAAO,kBAAC,IAAI,EAAE,IAAI,gBACjB,KAAC,OAAO,aAAE,YACF,CACX,CAAC"}
@@ -1,10 +1,15 @@
1
+ /*
1
2
  .jp-Toolbar {
3
+ height: auto !important;
4
+ height: 0px !important;
2
5
  display: none;
3
6
  position: relative !important;
4
- /* height: auto !important; */
5
- height: 0px !important;
6
7
  }
7
-
8
+ */
9
+ .dla-JupyterCell {
10
+ margin-top: 30px;
11
+ }
12
+
8
13
  .jp-Cell {
9
14
  width: 100%;
10
15
  }
@@ -18,3 +23,7 @@
18
23
  .jp-Completer-Cell {
19
24
  position: fixed;
20
25
  }
26
+
27
+ .jp-CodeMirrorEditor {
28
+ cursor: text !important;
29
+ }
@@ -0,0 +1,16 @@
1
+ import '@jupyterlab/application/style/index.css';
2
+ import '@jupyterlab/codemirror/style/index.css';
3
+ import '@jupyterlab/cells/style/index.css';
4
+ import '@jupyterlab/theme-light-extension/style/theme.css';
5
+ import '@jupyterlab/theme-light-extension/style/variables.css';
6
+ import '@jupyterlab/completer/style/index.css';
7
+ import './Cell.css';
8
+ export declare type ICellProps = {
9
+ source?: string;
10
+ autoStart?: boolean;
11
+ };
12
+ export declare const Cell: {
13
+ (props: ICellProps): import("@emotion/react/jsx-runtime").JSX.Element;
14
+ defaultProps: Partial<ICellProps>;
15
+ };
16
+ export default Cell;
@@ -0,0 +1,56 @@
1
+ import { jsx as _jsx, Fragment as _Fragment } from "@emotion/react/jsx-runtime";
2
+ import { useState, useEffect } from 'react';
3
+ import { useDispatch } from "react-redux";
4
+ import { CodeCell } from '@jupyterlab/cells';
5
+ import { useJupyter } from './../../jupyter/JupyterContext';
6
+ import LuminoAttached from '../../jupyter/lumino/LuminoAttached';
7
+ import { cellActions } from './CellState';
8
+ import CellAdapter from './CellAdapter';
9
+ import '@jupyterlab/application/style/index.css';
10
+ import '@jupyterlab/codemirror/style/index.css';
11
+ import '@jupyterlab/cells/style/index.css';
12
+ import '@jupyterlab/theme-light-extension/style/theme.css'; // This should be only index.css, looks like jupyterlab has a regression here...
13
+ import '@jupyterlab/theme-light-extension/style/variables.css';
14
+ import '@jupyterlab/completer/style/index.css';
15
+ import './Cell.css';
16
+ const DEFAULT_SOURCE = `from IPython.display import display
17
+
18
+ for i in range(10):
19
+ display('String {} added to the DOM in separated DIV.'.format(i))`;
20
+ export const Cell = (props) => {
21
+ const { source, autoStart } = props;
22
+ const { serviceManager } = useJupyter();
23
+ const dispatch = useDispatch();
24
+ const [adapter, setAdapter] = useState();
25
+ useEffect(() => {
26
+ if (serviceManager) {
27
+ const adapter = new CellAdapter(source, serviceManager);
28
+ dispatch(cellActions.update({ adapter }));
29
+ dispatch(cellActions.source(props.source));
30
+ adapter.codeCell.model.value.changed.connect((sender, changedArgs) => {
31
+ dispatch(cellActions.source(sender.text));
32
+ });
33
+ adapter.codeCell.outputArea.outputLengthChanged.connect((outputArea, outputsCount) => {
34
+ dispatch(cellActions.outputsCount(outputsCount));
35
+ });
36
+ adapter.sessionContext.initialize().then(() => {
37
+ if (autoStart) {
38
+ const execute = CodeCell.execute(adapter.codeCell, adapter.sessionContext);
39
+ execute.then((msg) => {
40
+ dispatch(cellActions.update({
41
+ kernelAvailable: true,
42
+ }));
43
+ });
44
+ }
45
+ });
46
+ setAdapter(adapter);
47
+ }
48
+ }, [source, serviceManager]);
49
+ return adapter ? _jsx(LuminoAttached, { children: adapter.panel }, void 0) : _jsx(_Fragment, { children: "Loading..." }, void 0);
50
+ };
51
+ Cell.defaultProps = {
52
+ source: DEFAULT_SOURCE,
53
+ autoStart: true,
54
+ };
55
+ export default Cell;
56
+ //# sourceMappingURL=Cell.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Cell.js","sourceRoot":"","sources":["../../../src/components/cell/Cell.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAC5C,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAC1C,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAE7C,OAAO,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAC;AAC5D,OAAO,cAAc,MAAM,qCAAqC,CAAC;AACjE,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAC1C,OAAO,WAAW,MAAM,eAAe,CAAC;AAExC,OAAO,yCAAyC,CAAC;AACjD,OAAO,wCAAwC,CAAC;AAChD,OAAO,mCAAmC,CAAC;AAC3C,OAAO,mDAAmD,CAAC,CAAC,gFAAgF;AAC5I,OAAO,uDAAuD,CAAC;AAC/D,OAAO,uCAAuC,CAAC;AAE/C,OAAO,YAAY,CAAC;AAEpB,MAAM,cAAc,GAAG;;;sEAG+C,CAAA;AAOtE,MAAM,CAAC,MAAM,IAAI,GAAG,CAAC,KAAiB,EAAE,EAAE;IACxC,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,GAAG,KAAK,CAAC;IACpC,MAAM,EAAE,cAAc,EAAE,GAAG,UAAU,EAAE,CAAC;IACxC,MAAM,QAAQ,GAAG,WAAW,EAAE,CAAC;IAC/B,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,QAAQ,EAAe,CAAC;IACtD,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,cAAc,EAAE;YAClB,MAAM,OAAO,GAAG,IAAI,WAAW,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC;YACxD,QAAQ,CAAC,WAAW,CAAC,MAAM,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC;YAC1C,QAAQ,CAAC,WAAW,CAAC,MAAM,CAAC,KAAK,CAAC,MAAO,CAAC,CAAC,CAAC;YAC5C,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,WAAW,EAAE,EAAE;gBACnE,QAAQ,CAAC,WAAW,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;YAC5C,CAAC,CAAC,CAAC;YACH,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAC,mBAAmB,CAAC,OAAO,CAAC,CAAC,UAAU,EAAE,YAAY,EAAE,EAAE;gBACnF,QAAQ,CAAC,WAAW,CAAC,YAAY,CAAC,YAAY,CAAC,CAAC,CAAC;YACnD,CAAC,CAAC,CAAC;YACH,OAAO,CAAC,cAAc,CAAC,UAAU,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;gBAC5C,IAAI,SAAS,EAAE;oBACb,MAAM,OAAO,GAAG,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,EAAE,OAAO,CAAC,cAAc,CAAC,CAAC;oBAC3E,OAAO,CAAC,IAAI,CAAC,CAAC,GAA0C,EAAE,EAAE;wBAC1D,QAAQ,CAAC,WAAW,CAAC,MAAM,CAAC;4BAC1B,eAAe,EAAE,IAAI;yBACtB,CAAC,CAAC,CAAC;oBACN,CAAC,CAAC,CAAC;iBACJ;YACH,CAAC,CAAC,CAAC;YACH,UAAU,CAAC,OAAO,CAAC,CAAC;SACrB;IACH,CAAC,EAAE,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC,CAAC;IAC7B,OAAO,OAAO,CAAC,CAAC,CAAC,KAAC,cAAc,cAAE,OAAO,CAAC,KAAK,WAAkB,CAAC,CAAC,CAAC,mDAAe,CAAA;AACrF,CAAC,CAAA;AAED,IAAI,CAAC,YAAY,GAAG;IAClB,MAAM,EAAE,cAAc;IACtB,SAAS,EAAE,IAAI;CACO,CAAC;AAEzB,eAAe,IAAI,CAAC"}
@@ -0,0 +1,15 @@
1
+ import { BoxPanel } from '@lumino/widgets';
2
+ import { SessionContext } from '@jupyterlab/apputils';
3
+ import { CodeCell } from '@jupyterlab/cells';
4
+ import { ServiceManager } from '@jupyterlab/services';
5
+ export declare class CellAdapter {
6
+ private _codeCell;
7
+ private _cellPanel;
8
+ private _sessionContext;
9
+ constructor(source?: string, serviceManager?: ServiceManager);
10
+ get panel(): BoxPanel;
11
+ get codeCell(): CodeCell;
12
+ get sessionContext(): SessionContext;
13
+ execute: () => void;
14
+ }
15
+ export default CellAdapter;
@@ -0,0 +1,133 @@
1
+ import { BoxPanel, Widget } from '@lumino/widgets';
2
+ import { SessionContext, Toolbar, ToolbarButton } from '@jupyterlab/apputils';
3
+ import { CodeCellModel, CodeCell } from '@jupyterlab/cells';
4
+ import { CodeMirrorMimeTypeService } from '@jupyterlab/codemirror';
5
+ import { runIcon } from '@jupyterlab/ui-components';
6
+ import { Completer, CompleterModel, CompletionHandler, ConnectorProxy, KernelCompleterProvider } from '@jupyterlab/completer';
7
+ import { RenderMimeRegistry, standardRendererFactories as initialFactories } from '@jupyterlab/rendermime';
8
+ import { SessionManager, KernelManager, KernelSpecManager } from '@jupyterlab/services';
9
+ import { CommandRegistry } from '@lumino/commands';
10
+ import { IPyWidgetsClassicManager } from "../../jupyter/ipywidgets/IPyWidgetsClassicManager";
11
+ import { requireLoader } from "@jupyter-widgets/html-manager";
12
+ import { WIDGET_MIMETYPE, WidgetRenderer } from "@jupyter-widgets/html-manager/lib/output_renderers";
13
+ import CellCommands from './CellCommands';
14
+ export class CellAdapter {
15
+ constructor(source, serviceManager) {
16
+ this.execute = () => {
17
+ CodeCell.execute(this._codeCell, this._sessionContext);
18
+ };
19
+ if (serviceManager === undefined || source === undefined) {
20
+ return;
21
+ }
22
+ this._cellPanel = new BoxPanel();
23
+ this._cellPanel.direction = 'top-to-bottom';
24
+ this._cellPanel.spacing = 0;
25
+ const serverSettings = serviceManager.serverSettings;
26
+ const kernelManager = new KernelManager({
27
+ serverSettings
28
+ });
29
+ const specsManager = new KernelSpecManager({
30
+ serverSettings
31
+ });
32
+ const sessionManager = new SessionManager({
33
+ serverSettings,
34
+ kernelManager
35
+ });
36
+ this._sessionContext = new SessionContext({
37
+ sessionManager,
38
+ specsManager,
39
+ name: 'Jupyter React'
40
+ });
41
+ const mimeService = new CodeMirrorMimeTypeService();
42
+ const commands = new CommandRegistry();
43
+ const useCapture = true;
44
+ document.addEventListener('keydown', event => {
45
+ commands.processKeydownEvent(event);
46
+ }, useCapture);
47
+ const rendermime = new RenderMimeRegistry({ initialFactories });
48
+ const iPyWidgetsClassicManager = new IPyWidgetsClassicManager({ loader: requireLoader });
49
+ rendermime.addFactory({
50
+ safe: false,
51
+ mimeTypes: [WIDGET_MIMETYPE],
52
+ createRenderer: (options) => new WidgetRenderer(options, iPyWidgetsClassicManager),
53
+ }, 0);
54
+ const codeCell = new CodeCell({
55
+ rendermime,
56
+ model: new CodeCellModel({
57
+ cell: {
58
+ cell_type: 'code',
59
+ source: source,
60
+ metadata: {}
61
+ }
62
+ })
63
+ });
64
+ this._sessionContext.kernelChanged.connect((sender, arg) => {
65
+ const kernelConnection = arg.newValue;
66
+ iPyWidgetsClassicManager.registerWithKernel(kernelConnection);
67
+ });
68
+ this._codeCell = codeCell.initializeState();
69
+ this._codeCell.addClass('dla-JupyterCell');
70
+ this._sessionContext.kernelChanged.connect(() => {
71
+ var _a, _b;
72
+ void ((_b = (_a = this._sessionContext.session) === null || _a === void 0 ? void 0 : _a.kernel) === null || _b === void 0 ? void 0 : _b.info.then(info => {
73
+ const lang = info.language_info;
74
+ const mimeType = mimeService.getMimeTypeByLanguage(lang);
75
+ this._codeCell.model.mimeType = mimeType;
76
+ }));
77
+ });
78
+ this._sessionContext.kernelPreference = {
79
+ autoStartDefault: true,
80
+ name: 'python3',
81
+ };
82
+ const editor = this._codeCell.editor;
83
+ const model = new CompleterModel();
84
+ const completer = new Completer({ editor, model });
85
+ const timeout = 1000;
86
+ const provider = new KernelCompleterProvider();
87
+ const connector = new ConnectorProxy({ widget: this._codeCell, editor, session: this._sessionContext.session }, [provider], timeout);
88
+ const handler = new CompletionHandler({ completer, connector });
89
+ void this._sessionContext.ready.then(() => {
90
+ const provider = new KernelCompleterProvider();
91
+ handler.connector = new ConnectorProxy({ widget: this._codeCell, editor, session: this._sessionContext.session }, [provider], timeout);
92
+ });
93
+ handler.editor = editor;
94
+ CellCommands(commands, this._codeCell, this._sessionContext, handler);
95
+ completer.hide();
96
+ completer.addClass('jp-Completer-Cell');
97
+ Widget.attach(completer, document.body);
98
+ const toolbar = new Toolbar();
99
+ toolbar.addItem('spacer', Toolbar.createSpacerItem());
100
+ const runButton = new ToolbarButton({
101
+ icon: runIcon,
102
+ onClick: () => {
103
+ CodeCell.execute(this._codeCell, this._sessionContext);
104
+ },
105
+ tooltip: 'Run'
106
+ });
107
+ toolbar.addItem('run', runButton);
108
+ toolbar.addItem('interrupt', Toolbar.createInterruptButton(this._sessionContext));
109
+ toolbar.addItem('restart', Toolbar.createRestartButton(this._sessionContext));
110
+ // toolbar.addItem('name', Toolbar.createKernelNameItem(this._sessionContext));
111
+ toolbar.addItem('status', Toolbar.createKernelStatusItem(this._sessionContext));
112
+ this._cellPanel.addWidget(toolbar);
113
+ BoxPanel.setStretch(toolbar, 0);
114
+ this._cellPanel.addWidget(this._codeCell);
115
+ BoxPanel.setStretch(this._codeCell, 1);
116
+ window.addEventListener('resize', () => {
117
+ this._cellPanel.update();
118
+ });
119
+ this._codeCell.outputsScrolled = false;
120
+ this._codeCell.activate();
121
+ }
122
+ get panel() {
123
+ return this._cellPanel;
124
+ }
125
+ get codeCell() {
126
+ return this._codeCell;
127
+ }
128
+ get sessionContext() {
129
+ return this._sessionContext;
130
+ }
131
+ }
132
+ export default CellAdapter;
133
+ //# sourceMappingURL=CellAdapter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CellAdapter.js","sourceRoot":"","sources":["../../../src/components/cell/CellAdapter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EAAE,cAAc,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAC9E,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC5D,OAAO,EAAE,yBAAyB,EAAE,MAAM,wBAAwB,CAAC;AACnE,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;AACpD,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,iBAAiB,EAAE,cAAc,EAAE,uBAAuB,EAAE,MAAM,uBAAuB,CAAC;AAC9H,OAAO,EAAE,kBAAkB,EAAE,yBAAyB,IAAI,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAE3G,OAAO,EAAE,cAAc,EAAE,aAAa,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AACxF,OAAO,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AACnD,OAAO,EAAE,wBAAwB,EAAE,MAAM,mDAAmD,CAAC;AAC7F,OAAO,EAAE,aAAa,EAAE,MAAM,+BAA+B,CAAC;AAC9D,OAAO,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,oDAAoD,CAAC;AACrG,OAAO,YAAY,MAAM,gBAAgB,CAAC;AAE1C,MAAM,OAAO,WAAW;IAKtB,YAAY,MAAe,EAAE,cAA+B;QAoI5D,YAAO,GAAG,GAAG,EAAE;YACb,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;QACzD,CAAC,CAAA;QArIC,IAAI,cAAc,KAAK,SAAS,IAAI,MAAM,KAAK,SAAS,EAAE;YACxD,OAAO;SACR;QACD,IAAI,CAAC,UAAU,GAAG,IAAI,QAAQ,EAAE,CAAC;QACjC,IAAI,CAAC,UAAU,CAAC,SAAS,GAAG,eAAe,CAAC;QAC5C,IAAI,CAAC,UAAU,CAAC,OAAO,GAAG,CAAC,CAAC;QAC5B,MAAM,cAAc,GAAG,cAAc,CAAC,cAAc,CAAC;QACrD,MAAM,aAAa,GAAG,IAAI,aAAa,CAAC;YACtC,cAAc;SACf,CAAC,CAAC;QACH,MAAM,YAAY,GAAG,IAAI,iBAAiB,CAAC;YACzC,cAAc;SACf,CAAC,CAAC;QACH,MAAM,cAAc,GAAG,IAAI,cAAc,CAAC;YACxC,cAAc;YACd,aAAa;SACd,CAAC,CAAC;QACH,IAAI,CAAC,eAAe,GAAG,IAAI,cAAc,CAAC;YACxC,cAAc;YACd,YAAY;YACZ,IAAI,EAAE,eAAe;SACtB,CAAC,CAAC;QACH,MAAM,WAAW,GAAG,IAAI,yBAAyB,EAAE,CAAC;QACpD,MAAM,QAAQ,GAAG,IAAI,eAAe,EAAE,CAAC;QACvC,MAAM,UAAU,GAAG,IAAI,CAAC;QACxB,QAAQ,CAAC,gBAAgB,CACvB,SAAS,EACT,KAAK,CAAC,EAAE;YACN,QAAQ,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC;QACtC,CAAC,EACD,UAAU,CACX,CAAC;QACF,MAAM,UAAU,GAAG,IAAI,kBAAkB,CAAC,EAAE,gBAAgB,EAAE,CAAC,CAAC;QAChE,MAAM,wBAAwB,GAAG,IAAI,wBAAwB,CAAC,EAAE,MAAM,EAAE,aAAa,EAAE,CAAC,CAAC;QACzF,UAAU,CAAC,UAAU,CACnB;YACE,IAAI,EAAE,KAAK;YACX,SAAS,EAAE,CAAC,eAAe,CAAC;YAC5B,cAAc,EAAE,CAAC,OAAO,EAAE,EAAE,CAAC,IAAI,cAAc,CAAC,OAAO,EAAE,wBAAwB,CAAC;SACnF,EACD,CAAC,CACF,CAAC;QACF,MAAM,QAAQ,GAAG,IAAI,QAAQ,CAAC;YAC5B,UAAU;YACV,KAAK,EAAE,IAAI,aAAa,CAAC;gBACvB,IAAI,EAAE;oBACJ,SAAS,EAAE,MAAM;oBACjB,MAAM,EAAE,MAAM;oBACd,QAAQ,EAAE,EACT;iBACF;aACF,CAAC;SACH,CAAC,CAAC;QACH,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,MAAsB,EAAE,GAAkD,EAAE,EAAE;YACxH,MAAM,gBAAgB,GAAG,GAAG,CAAC,QAAQ,CAAC;YACtC,wBAAwB,CAAC,kBAAkB,CAAC,gBAAgB,CAAC,CAAA;QAC/D,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC,eAAe,EAAE,CAAC;QAC5C,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,iBAAiB,CAAC,CAAC;QAC3C,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,OAAO,CAAC,GAAG,EAAE;;YAC9C,KAAK,CAAA,MAAA,MAAA,IAAI,CAAC,eAAe,CAAC,OAAO,0CAAE,MAAM,0CAAE,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;gBAC1D,MAAM,IAAI,GAAG,IAAI,CAAC,aAAa,CAAC;gBAChC,MAAM,QAAQ,GAAG,WAAW,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC;gBACzD,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,QAAQ,GAAG,QAAQ,CAAC;YAC3C,CAAC,CAAC,CAAA,CAAC;QACL,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,eAAe,CAAC,gBAAgB,GAAG;YACtC,gBAAgB,EAAE,IAAI;YACtB,IAAI,EAAE,SAAS;SAChB,CAAC;QACF,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC;QACrC,MAAM,KAAK,GAAG,IAAI,cAAc,EAAE,CAAC;QACnC,MAAM,SAAS,GAAG,IAAI,SAAS,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC;QACnD,MAAM,OAAO,GAAG,IAAI,CAAC;QACrB,MAAM,QAAQ,GAAG,IAAI,uBAAuB,EAAE,CAAC;QAC/C,MAAM,SAAS,GAAG,IAAI,cAAc,CAClC,EAAE,MAAM,EAAE,IAAI,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,EACzE,CAAC,QAAQ,CAAC,EACV,OAAO,CACR,CAAC;QACF,MAAM,OAAO,GAAG,IAAI,iBAAiB,CAAC,EAAE,SAAS,EAAE,SAAS,EAAE,CAAC,CAAC;QAChE,KAAK,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE;YACxC,MAAM,QAAQ,GAAG,IAAI,uBAAuB,EAAE,CAAC;YAC/C,OAAO,CAAC,SAAS,GAAG,IAAI,cAAc,CACpC,EAAE,MAAM,EAAE,IAAI,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,EACzE,CAAC,QAAQ,CAAC,EACV,OAAO,CACR,CAAC;QACJ,CAAC,CAAC,CAAC;QACH,OAAO,CAAC,MAAM,GAAG,MAAM,CAAC;QACxB,YAAY,CAAC,QAAQ,EAAE,IAAI,CAAC,SAAU,EAAE,IAAI,CAAC,eAAe,EAAE,OAAO,CAAC,CAAC;QACvE,SAAS,CAAC,IAAI,EAAE,CAAC;QACjB,SAAS,CAAC,QAAQ,CAAC,mBAAmB,CAAC,CAAC;QACxC,MAAM,CAAC,MAAM,CAAC,SAAS,EAAE,QAAQ,CAAC,IAAI,CAAC,CAAC;QACxC,MAAM,OAAO,GAAG,IAAI,OAAO,EAAE,CAAC;QAC9B,OAAO,CAAC,OAAO,CAAC,QAAQ,EAAE,OAAO,CAAC,gBAAgB,EAAE,CAAC,CAAC;QACtD,MAAM,SAAS,GAAG,IAAI,aAAa,CAAC;YAClC,IAAI,EAAE,OAAO;YACb,OAAO,EAAE,GAAG,EAAE;gBACZ,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;YACzD,CAAC;YACD,OAAO,EAAE,KAAK;SACf,CAAC,CAAC;QACH,OAAO,CAAC,OAAO,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;QAClC,OAAO,CAAC,OAAO,CAAC,WAAW,EAAE,OAAO,CAAC,qBAAqB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC;QAClF,OAAO,CAAC,OAAO,CAAC,SAAS,EAAE,OAAO,CAAC,mBAAmB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC;QAC9E,+EAA+E;QAC/E,OAAO,CAAC,OAAO,CAAC,QAAQ,EAAE,OAAO,CAAC,sBAAsB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC;QAChF,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;QACnC,QAAQ,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;QAChC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC1C,QAAQ,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;QACvC,MAAM,CAAC,gBAAgB,CAAC,QAAQ,EAAE,GAAG,EAAE;YACrC,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC;QAC3B,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,SAAS,CAAC,eAAe,GAAG,KAAK,CAAC;QACvC,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;IAC5B,CAAC;IAED,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAED,IAAI,cAAc;QAChB,OAAO,IAAI,CAAC,eAAe,CAAC;IAC9B,CAAC;CAMF;AAED,eAAe,WAAW,CAAC"}
@@ -0,0 +1,6 @@
1
+ import { CommandRegistry } from "@lumino/commands";
2
+ import { CompletionHandler } from "@jupyterlab/completer";
3
+ import { CodeCell } from '@jupyterlab/cells';
4
+ import { SessionContext } from '@jupyterlab/apputils';
5
+ export declare const CellCommands: (commandRegistry: CommandRegistry, codeCell: CodeCell, sessionContext: SessionContext, completerHandler: CompletionHandler) => void;
6
+ export default CellCommands;
@@ -0,0 +1,38 @@
1
+ import { CodeCell } from '@jupyterlab/cells';
2
+ const cmdIds = {
3
+ invoke: "completer:invoke",
4
+ select: "completer:select",
5
+ };
6
+ export const CellCommands = (commandRegistry, codeCell, sessionContext, completerHandler) => {
7
+ commandRegistry.addCommand(cmdIds.invoke, {
8
+ label: "Completer: Invoke",
9
+ execute: () => completerHandler.invoke(),
10
+ });
11
+ commandRegistry.addCommand(cmdIds.select, {
12
+ label: "Completer: Select",
13
+ execute: () => completerHandler.completer.selectActive(),
14
+ });
15
+ commandRegistry.addCommand('run:cell', {
16
+ execute: () => CodeCell.execute(codeCell, sessionContext)
17
+ });
18
+ commandRegistry.addKeyBinding({
19
+ selector: '.jp-InputArea-editor.jp-mod-completer-enabled',
20
+ keys: ['Tab'],
21
+ command: cmdIds.invoke
22
+ });
23
+ commandRegistry.addKeyBinding({
24
+ selector: '.jp-InputArea-editor',
25
+ keys: ['Shift Enter'],
26
+ command: 'run:cell'
27
+ });
28
+ const bindings = [
29
+ {
30
+ selector: `.jp-InputArea-editor.jp-mod-completer-active`,
31
+ keys: ["Enter"],
32
+ command: cmdIds.select,
33
+ },
34
+ ];
35
+ bindings.map((binding) => commandRegistry.addKeyBinding(binding));
36
+ };
37
+ export default CellCommands;
38
+ //# sourceMappingURL=CellCommands.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CellCommands.js","sourceRoot":"","sources":["../../../src/components/cell/CellCommands.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAG7C,MAAM,MAAM,GAAG;IACb,MAAM,EAAE,kBAAkB;IAC1B,MAAM,EAAE,kBAAkB;CAC3B,CAAC;AAEF,MAAM,CAAC,MAAM,YAAY,GAAG,CAC1B,eAAgC,EAChC,QAAkB,EAClB,cAA8B,EAC9B,gBAAmC,EAC7B,EAAE;IACR,eAAe,CAAC,UAAU,CAAC,MAAM,CAAC,MAAM,EAAE;QACxC,KAAK,EAAE,mBAAmB;QAC1B,OAAO,EAAE,GAAG,EAAE,CAAC,gBAAgB,CAAC,MAAM,EAAE;KACzC,CAAC,CAAC;IACH,eAAe,CAAC,UAAU,CAAC,MAAM,CAAC,MAAM,EAAE;QACxC,KAAK,EAAE,mBAAmB;QAC1B,OAAO,EAAE,GAAG,EAAE,CAAC,gBAAgB,CAAC,SAAS,CAAC,YAAY,EAAE;KACzD,CAAC,CAAC;IACH,eAAe,CAAC,UAAU,CAAC,UAAU,EAAE;QACrC,OAAO,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC,OAAO,CAAC,QAAQ,EAAE,cAAc,CAAC;KAC1D,CAAC,CAAC;IACH,eAAe,CAAC,aAAa,CAAC;QAC5B,QAAQ,EAAE,+CAA+C;QACzD,IAAI,EAAE,CAAC,KAAK,CAAC;QACb,OAAO,EAAE,MAAM,CAAC,MAAM;KACvB,CAAC,CAAC;IACH,eAAe,CAAC,aAAa,CAAC;QAC5B,QAAQ,EAAE,sBAAsB;QAChC,IAAI,EAAE,CAAC,aAAa,CAAC;QACrB,OAAO,EAAE,UAAU;KACpB,CAAC,CAAC;IACH,MAAM,QAAQ,GAAG;QACf;YACE,QAAQ,EAAE,8CAA8C;YACxD,IAAI,EAAE,CAAC,OAAO,CAAC;YACf,OAAO,EAAE,MAAM,CAAC,MAAM;SACvB;KACF,CAAC;IACF,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,eAAe,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,CAAC;AACpE,CAAC,CAAC;AAEF,eAAe,YAAY,CAAC"}
@@ -0,0 +1,22 @@
1
+ import CellAdapter from "./CellAdapter";
2
+ export interface ICellState {
3
+ source: string;
4
+ outputsCount: number;
5
+ kernelAvailable: boolean;
6
+ adapter?: CellAdapter;
7
+ }
8
+ export declare const cellInitialState: ICellState;
9
+ export declare const selectCell: () => ICellState;
10
+ export declare enum CellActionType {
11
+ SOURCE = "cell/SOURCE",
12
+ OUTPUTS_COUNT = "cell/OUTPUTS_COUNT",
13
+ EXECUTE = "cell/EXECUTE",
14
+ UPDATE = "cell/UPDATE"
15
+ }
16
+ export declare const cellActions: {
17
+ source: import("typescript-fsa").ActionCreator<string>;
18
+ outputsCount: import("typescript-fsa").ActionCreator<number>;
19
+ execute: import("typescript-fsa").ActionCreator<void>;
20
+ update: import("typescript-fsa").ActionCreator<Partial<ICellState>>;
21
+ };
22
+ export declare const cellReducer: import("typescript-fsa-reducers").ReducerBuilder<ICellState, ICellState>;
@@ -0,0 +1,46 @@
1
+ import actionCreatorFactory from "typescript-fsa";
2
+ import { useSelector } from "react-redux";
3
+ import { reducerWithInitialState } from "typescript-fsa-reducers";
4
+ export const cellInitialState = {
5
+ source: '',
6
+ outputsCount: -1,
7
+ kernelAvailable: false,
8
+ };
9
+ /* Selectors */
10
+ export const selectCell = () => useSelector((state) => {
11
+ if (state.cell) {
12
+ return state.cell;
13
+ }
14
+ return cellInitialState;
15
+ });
16
+ /* Actions */
17
+ export var CellActionType;
18
+ (function (CellActionType) {
19
+ CellActionType["SOURCE"] = "cell/SOURCE";
20
+ CellActionType["OUTPUTS_COUNT"] = "cell/OUTPUTS_COUNT";
21
+ CellActionType["EXECUTE"] = "cell/EXECUTE";
22
+ CellActionType["UPDATE"] = "cell/UPDATE";
23
+ })(CellActionType || (CellActionType = {}));
24
+ const actionCreator = actionCreatorFactory('jupyterReact');
25
+ export const cellActions = {
26
+ source: actionCreator(CellActionType.SOURCE),
27
+ outputsCount: actionCreator(CellActionType.OUTPUTS_COUNT),
28
+ execute: actionCreator(CellActionType.EXECUTE),
29
+ update: actionCreator(CellActionType.UPDATE),
30
+ };
31
+ /* Reducers */
32
+ export const cellReducer = reducerWithInitialState(cellInitialState)
33
+ .case(cellActions.execute, (state, payload) => {
34
+ if (state.adapter) {
35
+ state.adapter.execute();
36
+ }
37
+ return Object.assign({}, state);
38
+ })
39
+ .case(cellActions.source, (state, source) => {
40
+ return Object.assign(Object.assign({}, state), { source });
41
+ })
42
+ .case(cellActions.update, (state, partial) => (Object.assign(Object.assign({}, state), partial)))
43
+ .case(cellActions.outputsCount, (state, outputsCount) => {
44
+ return Object.assign(Object.assign({}, state), { outputsCount });
45
+ });
46
+ //# sourceMappingURL=CellState.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CellState.js","sourceRoot":"","sources":["../../../src/components/cell/CellState.ts"],"names":[],"mappings":"AAAA,OAAO,oBAAoB,MAAM,gBAAgB,CAAC;AAClD,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAC1C,OAAO,EAAE,uBAAuB,EAAE,MAAM,yBAAyB,CAAC;AAYlE,MAAM,CAAC,MAAM,gBAAgB,GAAe;IAC1C,MAAM,EAAE,EAAE;IACV,YAAY,EAAE,CAAC,CAAC;IAChB,eAAe,EAAE,KAAK;CACvB,CAAA;AAED,eAAe;AAEf,MAAM,CAAC,MAAM,UAAU,GAAG,GAAe,EAAE,CACzC,WAAW,CAAC,CAAC,KAAiB,EAAE,EAAE;IAChC,IAAK,KAAa,CAAC,IAAI,EAAE;QACvB,OAAQ,KAAa,CAAC,IAAI,CAAC;KAC5B;IACD,OAAO,gBAAgB,CAAC;AAC1B,CAAC,CACF,CAAC;AAEF,aAAa;AAEb,MAAM,CAAN,IAAY,cAKX;AALD,WAAY,cAAc;IACxB,wCAAsB,CAAA;IACtB,sDAAoC,CAAA;IACpC,0CAAwB,CAAA;IACxB,wCAAsB,CAAA;AACxB,CAAC,EALW,cAAc,KAAd,cAAc,QAKzB;AAED,MAAM,aAAa,GAAG,oBAAoB,CAAC,cAAc,CAAC,CAAC;AAE3D,MAAM,CAAC,MAAM,WAAW,GAAG;IACzB,MAAM,EAAE,aAAa,CACnB,cAAc,CAAC,MAAM,CACtB;IACD,YAAY,EAAE,aAAa,CACzB,cAAc,CAAC,aAAa,CAC7B;IACD,OAAO,EAAE,aAAa,CACpB,cAAc,CAAC,OAAO,CACvB;IACD,MAAM,EAAE,aAAa,CACnB,cAAc,CAAC,MAAM,CACtB;CACF,CAAA;AAED,cAAc;AAEd,MAAM,CAAC,MAAM,WAAW,GAAG,uBAAuB,CAAC,gBAAgB,CAAC;KACjE,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC,KAAiB,EAAE,OAAa,EAAE,EAAE;IAC9D,IAAI,KAAK,CAAC,OAAO,EAAE;QACjB,KAAK,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;KACzB;IACD,yBACK,KAAK,EACT;AACH,CAAC,CAAC;KACD,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC,KAAiB,EAAE,MAAc,EAAE,EAAE;IAC9D,uCACK,KAAK,KACR,MAAM,IACP;AACH,CAAC,CAAC;KACD,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC,KAAiB,EAAE,OAA4B,EAAE,EAAE,CAAC,iCAC1E,KAAK,GACL,OAAO,EACV,CAAC;KACF,IAAI,CAAC,WAAW,CAAC,YAAY,EAAE,CAAC,KAAiB,EAAE,YAAoB,EAAE,EAAE;IAC1E,uCACK,KAAK,KACR,YAAY,IACb;AACH,CAAC,CACF,CAAC"}
@@ -0,0 +1,14 @@
1
+ import Kernel from './../../jupyter/services/kernel/Kernel';
2
+ import OutputAdapter from './../outputs/OutputAdapter';
3
+ export declare const CodeMirrorEditor: (props: {
4
+ code: string;
5
+ codePre?: string | undefined;
6
+ outputAdapter: OutputAdapter;
7
+ kernel: Kernel;
8
+ autoRun: boolean;
9
+ disableRun: boolean;
10
+ sourceId: string;
11
+ toolbarPosition: 'up' | 'middle' | 'none';
12
+ insertText?: ((payload?: any) => string) | undefined;
13
+ }) => import("@emotion/react/jsx-runtime").JSX.Element;
14
+ export default CodeMirrorEditor;
@@ -0,0 +1,110 @@
1
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "@emotion/react/jsx-runtime";
2
+ import { useState, useRef, useEffect } from 'react';
3
+ import { useDispatch } from 'react-redux';
4
+ import { basicSetup } from 'codemirror';
5
+ import { EditorState, Compartment } from '@codemirror/state';
6
+ import { keymap, EditorView } from '@codemirror/view';
7
+ import { python } from '@codemirror/lang-python';
8
+ import codeMirrorTheme from './CodeMirrorTheme';
9
+ import OutputToolbar from './../outputs/OutputToolbar';
10
+ import { selectDataset, selectJupyterSetSource, outputActions } from './../outputs/OutputState';
11
+ export const CodeMirrorEditor = (props) => {
12
+ const { code, codePre, outputAdapter, autoRun, disableRun, sourceId, toolbarPosition, insertText, kernel } = props;
13
+ const dispatch = useDispatch();
14
+ const [view, setView] = useState();
15
+ const dataset = selectDataset(sourceId);
16
+ const setSource = selectJupyterSetSource(sourceId);
17
+ const editorDiv = useRef();
18
+ const setEditorSource = (source) => {
19
+ if (view && source) {
20
+ view.dispatch({
21
+ changes: {
22
+ from: 0,
23
+ to: view.state.doc.length,
24
+ insert: source
25
+ }
26
+ });
27
+ }
28
+ };
29
+ const doInsertText = (payload) => {
30
+ if (view && insertText) {
31
+ view.dispatch({
32
+ changes: {
33
+ from: 0,
34
+ insert: insertText(payload)
35
+ }
36
+ });
37
+ }
38
+ };
39
+ const executeCode = (editorView, code) => {
40
+ if (disableRun) {
41
+ alert('Code execution is disabled for this snippet editor. There should be a button on the page to run this snippet editor.');
42
+ return true;
43
+ }
44
+ if (code) {
45
+ outputAdapter.execute(code);
46
+ }
47
+ else {
48
+ outputAdapter.execute(editorView.state.doc.toString());
49
+ }
50
+ return true;
51
+ };
52
+ useEffect(() => {
53
+ dispatch(outputActions.source({
54
+ sourceId,
55
+ source: code,
56
+ }));
57
+ let editorView;
58
+ const language = new Compartment();
59
+ const keyBinding = [
60
+ {
61
+ key: 'Shift-Enter',
62
+ run: () => executeCode(editorView),
63
+ preventDefault: true,
64
+ },
65
+ ];
66
+ const state = EditorState.create({
67
+ doc: code,
68
+ extensions: [
69
+ basicSetup,
70
+ language.of(python()),
71
+ EditorView.lineWrapping,
72
+ keymap.of([...keyBinding]),
73
+ codeMirrorTheme,
74
+ EditorView.updateListener.of((viewUpdate) => {
75
+ if (viewUpdate.docChanged) {
76
+ const source = viewUpdate.state.doc.toString();
77
+ dispatch(outputActions.source({
78
+ sourceId,
79
+ source,
80
+ }));
81
+ }
82
+ })
83
+ ],
84
+ });
85
+ editorView = new EditorView({
86
+ state: state,
87
+ parent: editorDiv.current,
88
+ });
89
+ setView(editorView);
90
+ if (autoRun) {
91
+ executeCode(editorView);
92
+ }
93
+ return () => {
94
+ editorView.destroy();
95
+ };
96
+ }, [code]);
97
+ useEffect(() => {
98
+ doInsertText(dataset === null || dataset === void 0 ? void 0 : dataset.dataset);
99
+ }, [dataset]);
100
+ useEffect(() => {
101
+ setEditorSource(setSource === null || setSource === void 0 ? void 0 : setSource.source);
102
+ }, [setSource]);
103
+ return (_jsxs(_Fragment, { children: [toolbarPosition === 'up' &&
104
+ _jsx(OutputToolbar, { editorView: view, codePre: codePre, kernel: kernel, outputAdapter: outputAdapter, executeCode: executeCode }, void 0),
105
+ _jsx("div", { ref: editorDiv }, void 0),
106
+ toolbarPosition === 'middle' &&
107
+ _jsx(OutputToolbar, { editorView: view, codePre: codePre, kernel: kernel, outputAdapter: outputAdapter, executeCode: executeCode }, void 0)] }, void 0));
108
+ };
109
+ export default CodeMirrorEditor;
110
+ //# sourceMappingURL=CodeMirrorEditor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CodeMirrorEditor.js","sourceRoot":"","sources":["../../../src/components/codemirror/CodeMirrorEditor.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AACpD,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAC1C,OAAO,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AACxC,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAC7D,OAAO,EAAE,MAAM,EAAE,UAAU,EAAc,MAAM,kBAAkB,CAAC;AAClE,OAAO,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAC;AAEjD,OAAO,eAAe,MAAM,mBAAmB,CAAC;AAEhD,OAAO,aAAa,MAAM,4BAA4B,CAAC;AACvD,OAAO,EAAE,aAAa,EAAE,sBAAsB,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AAEhG,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,KAUhC,EAAE,EAAE;IACH,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,aAAa,EAAE,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,eAAe,EAAE,UAAU,EAAE,MAAM,EAAE,GAAG,KAAK,CAAC;IACnH,MAAM,QAAQ,GAAG,WAAW,EAAE,CAAC;IAC/B,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,QAAQ,EAAc,CAAC;IAC/C,MAAM,OAAO,GAAG,aAAa,CAAC,QAAQ,CAAC,CAAC;IACxC,MAAM,SAAS,GAAG,sBAAsB,CAAC,QAAQ,CAAC,CAAC;IACnD,MAAM,SAAS,GAAG,MAAM,EAAkB,CAAC;IAC3C,MAAM,eAAe,GAAG,CAAC,MAA0B,EAAE,EAAE;QACrD,IAAI,IAAI,IAAI,MAAM,EAAE;YAClB,IAAI,CAAC,QAAQ,CAAC;gBACZ,OAAO,EAAE;oBACP,IAAI,EAAE,CAAC;oBACP,EAAE,EAAE,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,MAAM;oBACzB,MAAM,EAAE,MAAM;iBACf;aACF,CAAC,CAAA;SACH;IACH,CAAC,CAAA;IACD,MAAM,YAAY,GAAG,CAAC,OAAa,EAAE,EAAE;QACrC,IAAI,IAAI,IAAI,UAAU,EAAE;YACtB,IAAI,CAAC,QAAQ,CAAC;gBACZ,OAAO,EAAE;oBACP,IAAI,EAAE,CAAC;oBACP,MAAM,EAAE,UAAU,CAAC,OAAO,CAAC;iBAC5B;aACF,CAAC,CAAA;SACH;IACH,CAAC,CAAA;IACD,MAAM,WAAW,GAAG,CAAC,UAAsB,EAAE,IAAa,EAAE,EAAE;QAC5D,IAAI,UAAU,EAAE;YACd,KAAK,CAAC,sHAAsH,CAAC,CAAC;YAC9H,OAAO,IAAI,CAAC;SACb;QACD,IAAI,IAAI,EAAE;YACR,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;SAC7B;aACI;YACH,aAAa,CAAC,OAAO,CAAC,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,CAAC;SACxD;QACD,OAAO,IAAI,CAAC;IACd,CAAC,CAAC;IACF,SAAS,CAAC,GAAG,EAAE;QACb,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC;YAC5B,QAAQ;YACR,MAAM,EAAE,IAAI;SACb,CAAC,CAAC,CAAC;QACJ,IAAI,UAAsB,CAAC;QAC3B,MAAM,QAAQ,GAAG,IAAI,WAAW,EAAE,CAAC;QACnC,MAAM,UAAU,GAAG;YACjB;gBACE,GAAG,EAAE,aAAa;gBAClB,GAAG,EAAE,GAAG,EAAE,CAAC,WAAW,CAAC,UAAU,CAAC;gBAClC,cAAc,EAAE,IAAI;aACrB;SACF,CAAC;QACF,MAAM,KAAK,GAAG,WAAW,CAAC,MAAM,CAAC;YAC/B,GAAG,EAAE,IAAI;YACT,UAAU,EAAE;gBACV,UAAU;gBACV,QAAQ,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC;gBACrB,UAAU,CAAC,YAAY;gBACvB,MAAM,CAAC,EAAE,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC;gBAC1B,eAAe;gBACf,UAAU,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC,UAAsB,EAAE,EAAE;oBACtD,IAAI,UAAU,CAAC,UAAU,EAAE;wBACzB,MAAM,MAAM,GAAG,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;wBAC/C,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC;4BAC5B,QAAQ;4BACR,MAAM;yBACP,CAAC,CAAC,CAAC;qBACL;gBACH,CAAC,CAAC;aACH;SACF,CAAC,CAAC;QACH,UAAU,GAAG,IAAI,UAAU,CAAC;YAC1B,KAAK,EAAE,KAAK;YACZ,MAAM,EAAE,SAAS,CAAC,OAAO;SAC1B,CAAC,CAAC;QACH,OAAO,CAAC,UAAU,CAAC,CAAC;QACpB,IAAI,OAAO,EAAE;YACX,WAAW,CAAC,UAAU,CAAC,CAAC;SACzB;QACD,OAAO,GAAG,EAAE;YACV,UAAU,CAAC,OAAO,EAAE,CAAC;QACvB,CAAC,CAAA;IACH,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAA;IACV,SAAS,CAAC,GAAG,EAAE;QACb,YAAY,CAAC,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,OAAO,CAAC,CAAC;IACjC,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC;IACd,SAAS,CAAC,GAAG,EAAE;QACb,eAAe,CAAC,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,MAAM,CAAC,CAAC;IACrC,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC;IAChB,OAAO,CACL,8BACI,eAAe,KAAK,IAAI;gBACxB,KAAC,aAAa,IACZ,UAAU,EAAE,IAAI,EAChB,OAAO,EAAE,OAAO,EAChB,MAAM,EAAE,MAAM,EACd,aAAa,EAAE,aAAa,EAC5B,WAAW,EAAE,WAAW,WACxB;YAEJ,cAAK,GAAG,EAAE,SAAgB,WAAQ;YAChC,eAAe,KAAK,QAAQ;gBAC5B,KAAC,aAAa,IACZ,UAAU,EAAE,IAAI,EAChB,OAAO,EAAE,OAAO,EAChB,MAAM,EAAE,MAAM,EACd,aAAa,EAAE,aAAa,EAC5B,WAAW,EAAE,WAAW,WACxB,YAEH,CACJ,CAAA;AACH,CAAC,CAAA;AAED,eAAe,gBAAgB,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Extension } from "@codemirror/state";
2
+ export declare const codeMirrorTheme: Extension;
3
+ export default codeMirrorTheme;
@@ -0,0 +1,21 @@
1
+ import { EditorView } from '@codemirror/view';
2
+ const theme = EditorView.theme({
3
+ "&": {
4
+ fontSize: "9pt",
5
+ border: "1px solid #c0c0c0"
6
+ },
7
+ ".cm-content": {
8
+ fontFamily: "Menlo, Monaco, Lucida Console, monospace",
9
+ minHeight: "10px"
10
+ },
11
+ ".cm-gutters": {
12
+ minHeight: "10px"
13
+ },
14
+ ".cm-scroller": {
15
+ overflow: "auto",
16
+ // maxHeight: "600px"
17
+ }
18
+ }, { dark: false });
19
+ export const codeMirrorTheme = [theme];
20
+ export default codeMirrorTheme;
21
+ //# sourceMappingURL=CodeMirrorTheme.js.map