@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.
- package/lib/JupyterExample.d.ts +1 -0
- package/lib/JupyterExample.js +56 -0
- package/lib/JupyterExample.js.map +1 -0
- package/lib/JupyterLiteExample.d.ts +1 -0
- package/lib/JupyterLiteExample.js +10 -0
- package/lib/JupyterLiteExample.js.map +1 -0
- package/lib/components/cell/Cell.css +12 -3
- package/lib/components/cell/Cell.d.ts +16 -0
- package/lib/components/cell/Cell.js +56 -0
- package/lib/components/cell/Cell.js.map +1 -0
- package/lib/components/cell/CellAdapter.d.ts +15 -0
- package/lib/components/cell/CellAdapter.js +133 -0
- package/lib/components/cell/CellAdapter.js.map +1 -0
- package/lib/components/cell/CellCommands.d.ts +6 -0
- package/lib/components/cell/CellCommands.js +38 -0
- package/lib/components/cell/CellCommands.js.map +1 -0
- package/lib/components/cell/CellState.d.ts +22 -0
- package/lib/components/cell/CellState.js +46 -0
- package/lib/components/cell/CellState.js.map +1 -0
- package/lib/components/codemirror/CodeMirrorEditor.d.ts +14 -0
- package/lib/components/codemirror/CodeMirrorEditor.js +110 -0
- package/lib/components/codemirror/CodeMirrorEditor.js.map +1 -0
- package/lib/components/codemirror/CodeMirrorTheme.d.ts +3 -0
- package/lib/components/codemirror/CodeMirrorTheme.js +21 -0
- package/lib/components/codemirror/CodeMirrorTheme.js.map +1 -0
- package/lib/components/commands/Commands.d.ts +2 -0
- package/lib/components/commands/Commands.js +9 -0
- package/lib/components/commands/Commands.js.map +1 -0
- package/lib/components/commands/CommandsAdapter.d.ts +9 -0
- package/lib/components/commands/CommandsAdapter.js +36 -0
- package/lib/components/commands/CommandsAdapter.js.map +1 -0
- package/lib/components/commands/CommandsState.d.ts +15 -0
- package/lib/components/commands/CommandsState.js +30 -0
- package/lib/components/commands/CommandsState.js.map +1 -0
- package/lib/components/console/{ConsoleAdapter.css → Console.css} +4 -0
- package/lib/components/console/Console.d.ts +3 -0
- package/lib/components/console/Console.js +15 -0
- package/lib/components/console/Console.js.map +1 -0
- package/lib/components/console/ConsoleAdapter.d.ts +13 -0
- package/lib/components/console/ConsoleAdapter.js +84 -0
- package/lib/components/console/ConsoleAdapter.js.map +1 -0
- package/lib/components/console/ConsoleState.d.ts +15 -0
- package/lib/components/console/ConsoleState.js +30 -0
- package/lib/components/console/ConsoleState.js.map +1 -0
- package/lib/components/dialog/Dialog.d.ts +2 -0
- package/lib/components/dialog/Dialog.js +13 -0
- package/lib/components/dialog/Dialog.js.map +1 -0
- package/lib/components/dialog/DialogAdapter.d.ts +10 -0
- package/lib/components/dialog/DialogAdapter.js +19 -0
- package/lib/components/dialog/DialogAdapter.js.map +1 -0
- package/lib/components/filebrowser/FileBrowser.d.ts +2 -0
- package/lib/components/filebrowser/FileBrowser.js +9 -0
- package/lib/components/filebrowser/FileBrowser.js.map +1 -0
- package/lib/components/filebrowser/FileBrowserAdapter.d.ts +13 -0
- package/lib/components/filebrowser/FileBrowserAdapter.js +267 -0
- package/lib/components/filebrowser/FileBrowserAdapter.js.map +1 -0
- package/lib/components/filebrowser/FileBrowserState.d.ts +15 -0
- package/lib/components/filebrowser/FileBrowserState.js +30 -0
- package/lib/components/filebrowser/FileBrowserState.js.map +1 -0
- package/lib/components/ipywidgets/IpyWidgetsComponent.d.ts +5 -0
- package/lib/components/ipywidgets/IpyWidgetsComponent.js +9 -0
- package/lib/components/ipywidgets/IpyWidgetsComponent.js.map +1 -0
- package/lib/components/notebook/Notebook.css +2 -26
- package/lib/components/notebook/Notebook.d.ts +36 -0
- package/lib/components/notebook/Notebook.js +138 -0
- package/lib/components/notebook/Notebook.js.map +1 -0
- package/lib/components/notebook/NotebookAdapter.d.ts +38 -0
- package/lib/components/notebook/NotebookAdapter.js +301 -0
- package/lib/components/notebook/NotebookAdapter.js.map +1 -0
- package/lib/components/notebook/NotebookCommands.d.ts +43 -0
- package/lib/components/notebook/NotebookCommands.js +380 -0
- package/lib/components/notebook/NotebookCommands.js.map +1 -0
- package/lib/components/notebook/NotebookState.d.ts +69 -0
- package/lib/components/notebook/NotebookState.js +184 -0
- package/lib/components/notebook/NotebookState.js.map +1 -0
- package/lib/components/notebook/cell/metadata/CellMetadataEditor.d.ts +7 -0
- package/lib/components/notebook/cell/metadata/CellMetadataEditor.js +43 -0
- package/lib/components/notebook/cell/metadata/CellMetadataEditor.js.map +1 -0
- package/lib/components/notebook/cell/metadata/NbGraderCells.d.ts +12 -0
- package/lib/components/notebook/cell/metadata/NbGraderCells.js +138 -0
- package/lib/components/notebook/cell/metadata/NbGraderCells.js.map +1 -0
- package/lib/components/notebook/cell/prompt/InputPrompt.d.ts +18 -0
- package/lib/components/notebook/cell/prompt/InputPrompt.js +69 -0
- package/lib/components/notebook/cell/prompt/InputPrompt.js.map +1 -0
- package/lib/components/notebook/cell/sidebar/CellSidebarDefault.d.ts +3 -0
- package/lib/components/notebook/cell/sidebar/CellSidebarDefault.js +63 -0
- package/lib/components/notebook/cell/sidebar/CellSidebarDefault.js.map +1 -0
- package/lib/components/notebook/cell/sidebar/CellSidebarRun.d.ts +3 -0
- package/lib/components/notebook/cell/sidebar/CellSidebarRun.js +38 -0
- package/lib/components/notebook/cell/sidebar/CellSidebarRun.js.map +1 -0
- package/lib/components/notebook/cell/sidebar/base/CellSidebarContentFactory.d.ts +19 -0
- package/lib/components/notebook/cell/sidebar/base/CellSidebarContentFactory.js +22 -0
- package/lib/components/notebook/cell/sidebar/base/CellSidebarContentFactory.js.map +1 -0
- package/lib/components/notebook/cell/sidebar/base/CellSidebarWidget.d.ts +16 -0
- package/lib/components/notebook/cell/sidebar/base/CellSidebarWidget.js +25 -0
- package/lib/components/notebook/cell/sidebar/base/CellSidebarWidget.js.map +1 -0
- package/lib/components/notebook/marked/marked.d.ts +3 -0
- package/lib/components/notebook/marked/marked.js +72 -0
- package/lib/components/notebook/marked/marked.js.map +1 -0
- package/lib/components/notebook/model/CustomNotebookModelFactory.d.ts +9 -0
- package/lib/components/notebook/model/CustomNotebookModelFactory.js +14 -0
- package/lib/components/notebook/model/CustomNotebookModelFactory.js.map +1 -0
- package/lib/components/outputs/Output.css +8 -0
- package/lib/components/outputs/Output.d.ts +25 -0
- package/lib/components/outputs/Output.js +126 -0
- package/lib/components/outputs/Output.js.map +1 -0
- package/lib/components/outputs/OutputAdapter.d.ts +19 -0
- package/lib/components/outputs/OutputAdapter.js +81 -0
- package/lib/components/outputs/OutputAdapter.js.map +1 -0
- package/lib/components/outputs/OutputState.d.ts +54 -0
- package/lib/components/outputs/OutputState.js +122 -0
- package/lib/components/outputs/OutputState.js.map +1 -0
- package/lib/components/outputs/OutputToolbar.d.ts +12 -0
- package/lib/components/outputs/OutputToolbar.js +42 -0
- package/lib/components/outputs/OutputToolbar.js.map +1 -0
- package/lib/components/settings/Settings.d.ts +2 -0
- package/lib/components/settings/Settings.js +9 -0
- package/lib/components/settings/Settings.js.map +1 -0
- package/lib/components/settings/SettingsAdapter.d.ts +10 -0
- package/lib/components/settings/SettingsAdapter.js +16 -0
- package/lib/components/settings/SettingsAdapter.js.map +1 -0
- package/lib/components/settings/SettingsState.d.ts +15 -0
- package/lib/components/settings/SettingsState.js +30 -0
- package/lib/components/settings/SettingsState.js.map +1 -0
- package/lib/components/terminal/Terminal.d.ts +2 -0
- package/lib/components/terminal/Terminal.js +16 -0
- package/lib/components/terminal/Terminal.js.map +1 -0
- package/lib/components/terminal/TerminalAdapter.d.ts +13 -0
- package/lib/components/terminal/TerminalAdapter.js +28 -0
- package/lib/components/terminal/TerminalAdapter.js.map +1 -0
- package/lib/components/terminal/TerminalState.d.ts +15 -0
- package/lib/components/terminal/TerminalState.js +38 -0
- package/lib/components/terminal/TerminalState.js.map +1 -0
- package/lib/index.d.ts +43 -0
- package/lib/index.js +58 -0
- package/lib/index.js.map +1 -0
- package/lib/jupyter/Jupyter.d.ts +31 -0
- package/lib/jupyter/Jupyter.js +30 -0
- package/lib/jupyter/Jupyter.js.map +1 -0
- package/lib/jupyter/JupyterAuthError.d.ts +7 -0
- package/lib/jupyter/JupyterAuthError.js +8 -0
- package/lib/jupyter/JupyterAuthError.js.map +1 -0
- package/lib/jupyter/JupyterConfig.d.ts +38 -0
- package/lib/jupyter/JupyterConfig.js +83 -0
- package/lib/jupyter/JupyterConfig.js.map +1 -0
- package/lib/jupyter/JupyterContext.d.ts +39 -0
- package/lib/jupyter/JupyterContext.js +89 -0
- package/lib/jupyter/JupyterContext.js.map +1 -0
- package/lib/jupyter/JupyterHandlers.d.ts +8 -0
- package/lib/jupyter/JupyterHandlers.js +50 -0
- package/lib/jupyter/JupyterHandlers.js.map +1 -0
- package/lib/jupyter/ipywidgets/IPyWidgetsAttached.d.ts +8 -0
- package/lib/jupyter/ipywidgets/IPyWidgetsAttached.js +15 -0
- package/lib/jupyter/ipywidgets/IPyWidgetsAttached.js.map +1 -0
- package/lib/jupyter/ipywidgets/IPyWidgetsClassicManager.d.ts +18 -0
- package/lib/jupyter/ipywidgets/IPyWidgetsClassicManager.js +76 -0
- package/lib/jupyter/ipywidgets/IPyWidgetsClassicManager.js.map +1 -0
- package/lib/jupyter/ipywidgets/IPyWidgetsJupyterLabPlugin.d.ts +15 -0
- package/lib/jupyter/ipywidgets/IPyWidgetsJupyterLabPlugin.js +178 -0
- package/lib/jupyter/ipywidgets/IPyWidgetsJupyterLabPlugin.js.map +1 -0
- package/lib/jupyter/ipywidgets/IpyWidgetsManager.d.ts +11 -0
- package/lib/jupyter/ipywidgets/IpyWidgetsManager.js +71 -0
- package/lib/jupyter/ipywidgets/IpyWidgetsManager.js.map +1 -0
- package/lib/jupyter/ipywidgets/plotly/Figure.d.ts +587 -0
- package/lib/jupyter/ipywidgets/plotly/Figure.js +1697 -0
- package/lib/jupyter/ipywidgets/plotly/Figure.js.map +1 -0
- package/lib/jupyter/ipywidgets/plotly/JupyterlabPlugin.d.ts +5 -0
- package/lib/jupyter/ipywidgets/plotly/JupyterlabPlugin.js +12 -0
- package/lib/jupyter/ipywidgets/plotly/JupyterlabPlugin.js.map +1 -0
- package/lib/jupyter/ipywidgets/plotly/Version.d.ts +8 -0
- package/lib/jupyter/ipywidgets/plotly/Version.js +16 -0
- package/lib/jupyter/ipywidgets/plotly/Version.js.map +1 -0
- package/lib/jupyter/ipywidgets/plotly/index.d.ts +2 -0
- package/lib/jupyter/ipywidgets/plotly/index.js +4 -0
- package/lib/jupyter/ipywidgets/plotly/index.js.map +1 -0
- package/lib/jupyter/lite/LiteServer.d.ts +2 -0
- package/lib/jupyter/lite/LiteServer.js +87 -0
- package/lib/jupyter/lite/LiteServer.js.map +1 -0
- package/lib/jupyter/lumino/LuminoAttached.d.ts +3 -0
- package/lib/jupyter/lumino/LuminoAttached.js +21 -0
- package/lib/jupyter/lumino/LuminoAttached.js.map +1 -0
- package/lib/jupyter/lumino/LuminoDetached.d.ts +9 -0
- package/lib/jupyter/lumino/LuminoDetached.js +13 -0
- package/lib/jupyter/lumino/LuminoDetached.js.map +1 -0
- package/lib/jupyter/lumino/LuminoNotebook.d.ts +5 -0
- package/lib/jupyter/lumino/LuminoNotebook.js +28 -0
- package/lib/jupyter/lumino/LuminoNotebook.js.map +1 -0
- package/lib/jupyter/lumino/LuminoObservable.d.ts +6 -0
- package/lib/jupyter/lumino/LuminoObservable.js +16 -0
- package/lib/jupyter/lumino/LuminoObservable.js.map +1 -0
- package/lib/jupyter/lumino/LuminoReactPortal.d.ts +180 -0
- package/lib/jupyter/lumino/LuminoReactPortal.js +195 -0
- package/lib/jupyter/lumino/LuminoReactPortal.js.map +1 -0
- package/lib/jupyter/lumino/LuminoRedux.d.ts +8 -0
- package/lib/jupyter/lumino/LuminoRedux.js +2 -0
- package/lib/jupyter/lumino/LuminoRedux.js.map +1 -0
- package/lib/jupyter/services/Services.d.ts +16 -0
- package/lib/jupyter/services/Services.js +41 -0
- package/lib/jupyter/services/Services.js.map +1 -0
- package/lib/jupyter/services/kernel/Kernel.d.ts +15 -0
- package/lib/jupyter/services/kernel/Kernel.js +65 -0
- package/lib/jupyter/services/kernel/Kernel.js.map +1 -0
- package/lib/jupyter/services/kernel/KernelModel.d.ts +18 -0
- package/lib/jupyter/services/kernel/KernelModel.js +52 -0
- package/lib/jupyter/services/kernel/KernelModel.js.map +1 -0
- package/lib/state/State.d.ts +14 -0
- package/lib/state/State.js +32 -0
- package/lib/state/State.js.map +1 -0
- package/lib/state/Store.d.ts +6 -0
- package/lib/state/Store.js +35 -0
- package/lib/state/Store.js.map +1 -0
- package/lib/utils/Ids.d.ts +2 -0
- package/lib/utils/Ids.js +11 -0
- package/lib/utils/Ids.js.map +1 -0
- package/package.json +41 -39
- 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":"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"}
|
|
@@ -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":"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"}
|
|
@@ -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
|