@opensumi/ide-notebook 3.4.5-next-1730119322.0
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/README.md +33 -0
- package/lib/browser/index.d.ts +12 -0
- package/lib/browser/index.d.ts.map +1 -0
- package/lib/browser/index.js +49 -0
- package/lib/browser/index.js.map +1 -0
- package/lib/browser/kernel-panel/collapse/collapse-content.d.ts +10 -0
- package/lib/browser/kernel-panel/collapse/collapse-content.d.ts.map +1 -0
- package/lib/browser/kernel-panel/collapse/collapse-content.js +27 -0
- package/lib/browser/kernel-panel/collapse/collapse-content.js.map +1 -0
- package/lib/browser/kernel-panel/collapse/icon.d.ts +7 -0
- package/lib/browser/kernel-panel/collapse/icon.d.ts.map +1 -0
- package/lib/browser/kernel-panel/collapse/icon.js +64 -0
- package/lib/browser/kernel-panel/collapse/icon.js.map +1 -0
- package/lib/browser/kernel-panel/collapse/index.d.ts +5 -0
- package/lib/browser/kernel-panel/collapse/index.d.ts.map +1 -0
- package/lib/browser/kernel-panel/collapse/index.js +66 -0
- package/lib/browser/kernel-panel/collapse/index.js.map +1 -0
- package/lib/browser/kernel-panel/collapse/index.less +95 -0
- package/lib/browser/kernel-panel/collapse/kernel-collapse-content-item.d.ts +9 -0
- package/lib/browser/kernel-panel/collapse/kernel-collapse-content-item.d.ts.map +1 -0
- package/lib/browser/kernel-panel/collapse/kernel-collapse-content-item.js +41 -0
- package/lib/browser/kernel-panel/collapse/kernel-collapse-content-item.js.map +1 -0
- package/lib/browser/kernel-panel/collapse/kernel-collapse-content.d.ts +10 -0
- package/lib/browser/kernel-panel/collapse/kernel-collapse-content.d.ts.map +1 -0
- package/lib/browser/kernel-panel/collapse/kernel-collapse-content.js +4 -0
- package/lib/browser/kernel-panel/collapse/kernel-collapse-content.js.map +1 -0
- package/lib/browser/kernel-panel/collapse/page-collapse-content.d.ts +10 -0
- package/lib/browser/kernel-panel/collapse/page-collapse-content.d.ts.map +1 -0
- package/lib/browser/kernel-panel/collapse/page-collapse-content.js +32 -0
- package/lib/browser/kernel-panel/collapse/page-collapse-content.js.map +1 -0
- package/lib/browser/kernel-panel/index.d.ts +5 -0
- package/lib/browser/kernel-panel/index.d.ts.map +1 -0
- package/lib/browser/kernel-panel/index.js +5 -0
- package/lib/browser/kernel-panel/index.js.map +1 -0
- package/lib/browser/kernel-panel/index.less +20 -0
- package/lib/browser/kernel-panel/kernel-panel-view.d.ts +4 -0
- package/lib/browser/kernel-panel/kernel-panel-view.d.ts.map +1 -0
- package/lib/browser/kernel-panel/kernel-panel-view.js +72 -0
- package/lib/browser/kernel-panel/kernel-panel-view.js.map +1 -0
- package/lib/browser/kernel-panel/kernel.panel.color.tokens.d.ts +2 -0
- package/lib/browser/kernel-panel/kernel.panel.color.tokens.d.ts.map +1 -0
- package/lib/browser/kernel-panel/kernel.panel.color.tokens.js +10 -0
- package/lib/browser/kernel-panel/kernel.panel.color.tokens.js.map +1 -0
- package/lib/browser/kernel-panel/kernel.panel.contribution.d.ts +7 -0
- package/lib/browser/kernel-panel/kernel.panel.contribution.d.ts.map +1 -0
- package/lib/browser/kernel-panel/kernel.panel.contribution.js +32 -0
- package/lib/browser/kernel-panel/kernel.panel.contribution.js.map +1 -0
- package/lib/browser/kernel-panel/kernel.panel.protocol.d.ts +25 -0
- package/lib/browser/kernel-panel/kernel.panel.protocol.d.ts.map +1 -0
- package/lib/browser/kernel-panel/kernel.panel.protocol.js +7 -0
- package/lib/browser/kernel-panel/kernel.panel.protocol.js.map +1 -0
- package/lib/browser/libro/editor/editor-contribution.d.ts +13 -0
- package/lib/browser/libro/editor/editor-contribution.d.ts.map +1 -0
- package/lib/browser/libro/editor/editor-contribution.js +30 -0
- package/lib/browser/libro/editor/editor-contribution.js.map +1 -0
- package/lib/browser/libro/editor/index.less +48 -0
- package/lib/browser/libro/editor/keybind-handler.d.ts +14 -0
- package/lib/browser/libro/editor/keybind-handler.d.ts.map +1 -0
- package/lib/browser/libro/editor/keybind-handler.js +132 -0
- package/lib/browser/libro/editor/keybind-handler.js.map +1 -0
- package/lib/browser/libro/editor/module.d.ts +3 -0
- package/lib/browser/libro/editor/module.d.ts.map +1 -0
- package/lib/browser/libro/editor/module.js +22 -0
- package/lib/browser/libro/editor/module.js.map +1 -0
- package/lib/browser/libro/editor/opensumi-editor.d.ts +251 -0
- package/lib/browser/libro/editor/opensumi-editor.d.ts.map +1 -0
- package/lib/browser/libro/editor/opensumi-editor.js +567 -0
- package/lib/browser/libro/editor/opensumi-editor.js.map +1 -0
- package/lib/browser/libro/index.d.ts +4 -0
- package/lib/browser/libro/index.d.ts.map +1 -0
- package/lib/browser/libro/index.js +4 -0
- package/lib/browser/libro/index.js.map +1 -0
- package/lib/browser/libro/libro-opensumi-content-contribution.d.ts +9 -0
- package/lib/browser/libro/libro-opensumi-content-contribution.d.ts.map +1 -0
- package/lib/browser/libro/libro-opensumi-content-contribution.js +71 -0
- package/lib/browser/libro/libro-opensumi-content-contribution.js.map +1 -0
- package/lib/browser/libro/libro-opensumi-save-content-contribution.d.ts +10 -0
- package/lib/browser/libro/libro-opensumi-save-content-contribution.d.ts.map +1 -0
- package/lib/browser/libro/libro-opensumi-save-content-contribution.js +51 -0
- package/lib/browser/libro/libro-opensumi-save-content-contribution.js.map +1 -0
- package/lib/browser/libro/mana-module.d.ts +3 -0
- package/lib/browser/libro/mana-module.d.ts.map +1 -0
- package/lib/browser/libro/mana-module.js +8 -0
- package/lib/browser/libro/mana-module.js.map +1 -0
- package/lib/browser/libro-keybind-contribution.d.ts +19 -0
- package/lib/browser/libro-keybind-contribution.d.ts.map +1 -0
- package/lib/browser/libro-keybind-contribution.js +142 -0
- package/lib/browser/libro-keybind-contribution.js.map +1 -0
- package/lib/browser/libro-opener.d.ts +12 -0
- package/lib/browser/libro-opener.d.ts.map +1 -0
- package/lib/browser/libro-opener.js +83 -0
- package/lib/browser/libro-opener.js.map +1 -0
- package/lib/browser/libro.color.tokens.d.ts +2 -0
- package/lib/browser/libro.color.tokens.d.ts.map +1 -0
- package/lib/browser/libro.color.tokens.js +9 -0
- package/lib/browser/libro.color.tokens.js.map +1 -0
- package/lib/browser/libro.command.d.ts +6 -0
- package/lib/browser/libro.command.d.ts.map +1 -0
- package/lib/browser/libro.command.js +66 -0
- package/lib/browser/libro.command.js.map +1 -0
- package/lib/browser/libro.contribution.d.ts +29 -0
- package/lib/browser/libro.contribution.d.ts.map +1 -0
- package/lib/browser/libro.contribution.js +140 -0
- package/lib/browser/libro.contribution.js.map +1 -0
- package/lib/browser/libro.module.less +40 -0
- package/lib/browser/libro.protocol.d.ts +3 -0
- package/lib/browser/libro.protocol.d.ts.map +1 -0
- package/lib/browser/libro.protocol.js +3 -0
- package/lib/browser/libro.protocol.js.map +1 -0
- package/lib/browser/libro.service.d.ts +24 -0
- package/lib/browser/libro.service.d.ts.map +1 -0
- package/lib/browser/libro.service.js +68 -0
- package/lib/browser/libro.service.js.map +1 -0
- package/lib/browser/libro.view.d.ts +3 -0
- package/lib/browser/libro.view.d.ts.map +1 -0
- package/lib/browser/libro.view.js +54 -0
- package/lib/browser/libro.view.js.map +1 -0
- package/lib/browser/libro.view.tracker.d.ts +6 -0
- package/lib/browser/libro.view.tracker.d.ts.map +1 -0
- package/lib/browser/libro.view.tracker.js +28 -0
- package/lib/browser/libro.view.tracker.js.map +1 -0
- package/lib/browser/mana/index.d.ts +8 -0
- package/lib/browser/mana/index.d.ts.map +1 -0
- package/lib/browser/mana/index.js +15 -0
- package/lib/browser/mana/index.js.map +1 -0
- package/lib/browser/notebook-document-content-provider.d.ts +22 -0
- package/lib/browser/notebook-document-content-provider.d.ts.map +1 -0
- package/lib/browser/notebook-document-content-provider.js +80 -0
- package/lib/browser/notebook-document-content-provider.js.map +1 -0
- package/lib/browser/notebook.service.d.ts +27 -0
- package/lib/browser/notebook.service.d.ts.map +1 -0
- package/lib/browser/notebook.service.js +186 -0
- package/lib/browser/notebook.service.js.map +1 -0
- package/lib/browser/toc/index.d.ts +4 -0
- package/lib/browser/toc/index.d.ts.map +1 -0
- package/lib/browser/toc/index.js +4 -0
- package/lib/browser/toc/index.js.map +1 -0
- package/lib/browser/toc/toc.contribution.d.ts +6 -0
- package/lib/browser/toc/toc.contribution.d.ts.map +1 -0
- package/lib/browser/toc/toc.contribution.js +25 -0
- package/lib/browser/toc/toc.contribution.js.map +1 -0
- package/lib/browser/toc/toc.module.less +23 -0
- package/lib/browser/toc/toc.panel.color.tokens.d.ts +2 -0
- package/lib/browser/toc/toc.panel.color.tokens.d.ts.map +1 -0
- package/lib/browser/toc/toc.panel.color.tokens.js +6 -0
- package/lib/browser/toc/toc.panel.color.tokens.js.map +1 -0
- package/lib/browser/toc/toc.panel.d.ts +6 -0
- package/lib/browser/toc/toc.panel.d.ts.map +1 -0
- package/lib/browser/toc/toc.panel.js +61 -0
- package/lib/browser/toc/toc.panel.js.map +1 -0
- package/lib/index.d.ts +2 -0
- package/lib/index.d.ts.map +1 -0
- package/lib/index.js +2 -0
- package/lib/index.js.map +1 -0
- package/package.json +42 -0
- package/src/browser/index.ts +44 -0
- package/src/browser/kernel-panel/collapse/collapse-content.tsx +46 -0
- package/src/browser/kernel-panel/collapse/icon.tsx +171 -0
- package/src/browser/kernel-panel/collapse/index.less +95 -0
- package/src/browser/kernel-panel/collapse/index.tsx +111 -0
- package/src/browser/kernel-panel/collapse/kernel-collapse-content-item.tsx +77 -0
- package/src/browser/kernel-panel/collapse/kernel-collapse-content.tsx +17 -0
- package/src/browser/kernel-panel/collapse/page-collapse-content.tsx +53 -0
- package/src/browser/kernel-panel/index.less +20 -0
- package/src/browser/kernel-panel/index.ts +4 -0
- package/src/browser/kernel-panel/kernel-panel-view.tsx +104 -0
- package/src/browser/kernel-panel/kernel.panel.color.tokens.ts +39 -0
- package/src/browser/kernel-panel/kernel.panel.contribution.ts +32 -0
- package/src/browser/kernel-panel/kernel.panel.protocol.ts +24 -0
- package/src/browser/libro/editor/editor-contribution.ts +41 -0
- package/src/browser/libro/editor/index.less +48 -0
- package/src/browser/libro/editor/keybind-handler.ts +133 -0
- package/src/browser/libro/editor/module.ts +30 -0
- package/src/browser/libro/editor/opensumi-editor.ts +826 -0
- package/src/browser/libro/index.ts +3 -0
- package/src/browser/libro/libro-opensumi-content-contribution.ts +63 -0
- package/src/browser/libro/libro-opensumi-save-content-contribution.ts +43 -0
- package/src/browser/libro/mana-module.ts +9 -0
- package/src/browser/libro-keybind-contribution.ts +147 -0
- package/src/browser/libro-opener.ts +96 -0
- package/src/browser/libro.color.tokens.ts +32 -0
- package/src/browser/libro.command.ts +63 -0
- package/src/browser/libro.contribution.tsx +189 -0
- package/src/browser/libro.module.less +40 -0
- package/src/browser/libro.protocol.ts +2 -0
- package/src/browser/libro.service.ts +85 -0
- package/src/browser/libro.view.tracker.ts +18 -0
- package/src/browser/libro.view.tsx +62 -0
- package/src/browser/mana/index.ts +20 -0
- package/src/browser/notebook-document-content-provider.ts +100 -0
- package/src/browser/notebook.service.ts +195 -0
- package/src/browser/toc/index.ts +3 -0
- package/src/browser/toc/toc.contribution.ts +24 -0
- package/src/browser/toc/toc.module.less +23 -0
- package/src/browser/toc/toc.panel.color.tokens.ts +11 -0
- package/src/browser/toc/toc.panel.tsx +66 -0
- package/src/index.ts +1 -0
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
import { CellUri, CellView, LanguageSpecRegistry, LibroService, LibroView } from '@difizen/libro-jupyter/noeditor';
|
|
2
|
+
import { Container, URI as ManaURI, getOrigin } from '@difizen/mana-app';
|
|
3
|
+
import { makeObservable } from 'mobx';
|
|
4
|
+
|
|
5
|
+
import { Autowired, Injectable } from '@opensumi/di';
|
|
6
|
+
import { URI, WithEventBus, path } from '@opensumi/ide-core-browser';
|
|
7
|
+
import { ResourceDecorationNeedChangeEvent, WorkbenchEditorService } from '@opensumi/ide-editor';
|
|
8
|
+
|
|
9
|
+
import { LibroTracker } from './libro.view.tracker';
|
|
10
|
+
import { ContentLoaderType, ManaContainer } from './mana';
|
|
11
|
+
|
|
12
|
+
export const ILibroOpensumiService = Symbol('ILibroOpensumiService');
|
|
13
|
+
|
|
14
|
+
// eslint-disable-next-line @typescript-eslint/no-redeclare
|
|
15
|
+
export interface ILibroOpensumiService {
|
|
16
|
+
// manaContainer: Container;
|
|
17
|
+
libroTrackerMap: Map<string, LibroTracker>;
|
|
18
|
+
// editorService: WorkbenchEditorService;
|
|
19
|
+
getOrCreatLibroView: (uri: URI) => Promise<LibroView>;
|
|
20
|
+
updateDirtyStatus: (uri: URI, dirty: boolean) => void;
|
|
21
|
+
getCellViewByUri: (uri: URI) => Promise<CellView | undefined>;
|
|
22
|
+
getCellLangauge: (cell: CellView) => string | undefined;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
@Injectable()
|
|
26
|
+
export class LibroOpensumiService extends WithEventBus implements ILibroOpensumiService {
|
|
27
|
+
@Autowired(ManaContainer)
|
|
28
|
+
private readonly manaContainer: Container;
|
|
29
|
+
|
|
30
|
+
@Autowired(WorkbenchEditorService)
|
|
31
|
+
protected readonly editorService: WorkbenchEditorService;
|
|
32
|
+
|
|
33
|
+
constructor() {
|
|
34
|
+
super();
|
|
35
|
+
makeObservable(this);
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
get libroService() {
|
|
39
|
+
const libroService = this.manaContainer.get(LibroService);
|
|
40
|
+
return libroService;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
getOrCreatLibroView = async (uri: URI) => {
|
|
44
|
+
const libroOption = {
|
|
45
|
+
modelId: uri.toString(),
|
|
46
|
+
resource: uri.toString(),
|
|
47
|
+
loadType: ContentLoaderType,
|
|
48
|
+
};
|
|
49
|
+
return await this.libroService.getOrCreateView(libroOption);
|
|
50
|
+
};
|
|
51
|
+
|
|
52
|
+
getCellViewByUri = async (uri: URI) => {
|
|
53
|
+
const parsed = CellUri.parse(new ManaURI(uri.toString(), { simpleMode: false }));
|
|
54
|
+
if (!parsed) {
|
|
55
|
+
return;
|
|
56
|
+
}
|
|
57
|
+
const { notebookId, cellId } = parsed;
|
|
58
|
+
// const notebookUri = URI.file(notebookId);
|
|
59
|
+
/**
|
|
60
|
+
* 这里需要兼容各种不同的 content contribution 加载数据的方式,采取匹配model id的方式来找到libroview, 因为model id是会被编码进uri的
|
|
61
|
+
*/
|
|
62
|
+
const libroView = Array.from(this.libroService.getViewCache().values()).find(
|
|
63
|
+
(item) => path.join('/', String(item.model.id)) === notebookId,
|
|
64
|
+
);
|
|
65
|
+
return libroView?.model.cells.find((cell) => cell.model.id === cellId);
|
|
66
|
+
};
|
|
67
|
+
|
|
68
|
+
getCellLangauge = (cell: CellView) => {
|
|
69
|
+
const languageSpecRegistry = this.manaContainer.get(LanguageSpecRegistry);
|
|
70
|
+
return getOrigin(languageSpecRegistry.languageSpecs).find((item) => item.mime === cell.model.mimeType)?.language;
|
|
71
|
+
};
|
|
72
|
+
|
|
73
|
+
updateDirtyStatus(uri: URI, dirty: boolean) {
|
|
74
|
+
this.eventBus.fire(
|
|
75
|
+
new ResourceDecorationNeedChangeEvent({
|
|
76
|
+
uri,
|
|
77
|
+
decoration: {
|
|
78
|
+
dirty,
|
|
79
|
+
},
|
|
80
|
+
}),
|
|
81
|
+
);
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
libroTrackerMap: Map<string, LibroTracker> = new Map();
|
|
85
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { action, makeObservable, observable } from 'mobx';
|
|
2
|
+
|
|
3
|
+
import { Injectable } from '@opensumi/di';
|
|
4
|
+
|
|
5
|
+
@Injectable({ multiple: true })
|
|
6
|
+
export class LibroTracker {
|
|
7
|
+
constructor() {
|
|
8
|
+
makeObservable(this);
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
@observable
|
|
12
|
+
refreshTimer: number | undefined = undefined;
|
|
13
|
+
|
|
14
|
+
@action
|
|
15
|
+
refresh(refreshTimer: number | undefined) {
|
|
16
|
+
this.refreshTimer = refreshTimer;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
|
|
2
|
+
import { DocumentCommands, LibroView } from '@difizen/libro-jupyter/noeditor';
|
|
3
|
+
import { CommandRegistry, Container, ViewRender } from '@difizen/mana-app';
|
|
4
|
+
import * as React from 'react';
|
|
5
|
+
|
|
6
|
+
import { INJECTOR_TOKEN, Injector } from '@opensumi/di';
|
|
7
|
+
import { URI, useInjectable } from '@opensumi/ide-core-browser';
|
|
8
|
+
import { ReactEditorComponent } from '@opensumi/ide-editor/lib/browser/types';
|
|
9
|
+
|
|
10
|
+
import styles from './libro.module.less';
|
|
11
|
+
import { ILibroOpensumiService } from './libro.service';
|
|
12
|
+
import { LibroTracker } from './libro.view.tracker';
|
|
13
|
+
import { ManaContainer } from './mana';
|
|
14
|
+
|
|
15
|
+
export const OpensumiLibroView: ReactEditorComponent = (...params) => {
|
|
16
|
+
const libroOpensumiService = useInjectable<ILibroOpensumiService>(ILibroOpensumiService);
|
|
17
|
+
const manaContainer = useInjectable<Container>(ManaContainer);
|
|
18
|
+
const commandRegistry = manaContainer.get(CommandRegistry);
|
|
19
|
+
const injector: Injector = useInjectable(INJECTOR_TOKEN);
|
|
20
|
+
|
|
21
|
+
const [libroTracker, setLibroTracker] = React.useState<LibroTracker>();
|
|
22
|
+
|
|
23
|
+
const [libroView, setLibroView] = React.useState<LibroView | undefined>(undefined);
|
|
24
|
+
|
|
25
|
+
React.useEffect(() => {
|
|
26
|
+
if (libroTracker?.refreshTimer) {
|
|
27
|
+
libroView?.dispose();
|
|
28
|
+
}
|
|
29
|
+
let autoSaveHandle: undefined | number;
|
|
30
|
+
libroOpensumiService.getOrCreatLibroView(params[0].resource.uri).then((libro) => {
|
|
31
|
+
setLibroView(libro);
|
|
32
|
+
if (!libroOpensumiService.libroTrackerMap.has((params[0].resource.uri as URI).toString())) {
|
|
33
|
+
const tracker = injector.get(LibroTracker);
|
|
34
|
+
setLibroTracker(tracker);
|
|
35
|
+
libroOpensumiService.libroTrackerMap.set((params[0].resource.uri as URI).toString(), tracker);
|
|
36
|
+
}
|
|
37
|
+
libro.model.onChanged(() => {
|
|
38
|
+
libroOpensumiService.updateDirtyStatus(params[0].resource.uri, true);
|
|
39
|
+
if (autoSaveHandle) {
|
|
40
|
+
window.clearTimeout(autoSaveHandle);
|
|
41
|
+
}
|
|
42
|
+
autoSaveHandle = window.setTimeout(() => {
|
|
43
|
+
commandRegistry
|
|
44
|
+
.executeCommand(DocumentCommands.Save.id, undefined, libro, undefined, { reason: 'autoSave' })
|
|
45
|
+
.then(() => {
|
|
46
|
+
if (libro) {
|
|
47
|
+
libro.model.dirty = false;
|
|
48
|
+
}
|
|
49
|
+
});
|
|
50
|
+
}, 1000);
|
|
51
|
+
});
|
|
52
|
+
libro.onSave(() => {
|
|
53
|
+
libroOpensumiService.updateDirtyStatus(params[0].resource.uri, false);
|
|
54
|
+
});
|
|
55
|
+
});
|
|
56
|
+
return () => {
|
|
57
|
+
window.clearTimeout(autoSaveHandle);
|
|
58
|
+
};
|
|
59
|
+
}, [libroTracker?.refreshTimer]);
|
|
60
|
+
|
|
61
|
+
return <div className={styles.libroView}>{libroView && <ViewRender view={libroView}></ViewRender>}</div>;
|
|
62
|
+
};
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { GlobalContainer, Syringe } from '@difizen/mana-app';
|
|
2
|
+
|
|
3
|
+
import { Injector } from '@opensumi/di';
|
|
4
|
+
|
|
5
|
+
export const OpensumiInjector = Syringe.defineToken('OpensumiInjector');
|
|
6
|
+
export const ManaContainer = Symbol('ManaContainer');
|
|
7
|
+
|
|
8
|
+
export const initLibroOpensumi = (injector: Injector, container?: Syringe.Container) => {
|
|
9
|
+
const initInjector = injector;
|
|
10
|
+
const initContainer = container || GlobalContainer;
|
|
11
|
+
initInjector.addProviders({
|
|
12
|
+
token: ManaContainer,
|
|
13
|
+
useValue: initContainer,
|
|
14
|
+
});
|
|
15
|
+
initContainer?.register({ token: OpensumiInjector, useValue: initInjector });
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
export const manaContainer = GlobalContainer.createChild();
|
|
19
|
+
|
|
20
|
+
export const ContentLoaderType = 'libro-opensumi-loader';
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
import { LibroCellURIScheme } from '@difizen/libro-common';
|
|
2
|
+
|
|
3
|
+
import { Autowired, Injectable } from '@opensumi/di';
|
|
4
|
+
import { PreferenceService, getLanguageIdFromMonaco } from '@opensumi/ide-core-browser';
|
|
5
|
+
import {
|
|
6
|
+
Emitter,
|
|
7
|
+
Event,
|
|
8
|
+
IApplicationService,
|
|
9
|
+
IEditorDocumentChange,
|
|
10
|
+
IEditorDocumentModelSaveResult,
|
|
11
|
+
MaybePromise,
|
|
12
|
+
SaveTaskResponseState,
|
|
13
|
+
URI,
|
|
14
|
+
} from '@opensumi/ide-core-common';
|
|
15
|
+
import { IEditorDocumentModelContentProvider } from '@opensumi/ide-editor/lib/browser/doc-model/types';
|
|
16
|
+
import { EOL } from '@opensumi/ide-monaco';
|
|
17
|
+
|
|
18
|
+
import { ILibroOpensumiService } from './libro.service';
|
|
19
|
+
|
|
20
|
+
@Injectable()
|
|
21
|
+
export class NotebookDocumentContentProvider implements IEditorDocumentModelContentProvider {
|
|
22
|
+
@Autowired(IApplicationService)
|
|
23
|
+
protected readonly applicationService: IApplicationService;
|
|
24
|
+
|
|
25
|
+
@Autowired(PreferenceService)
|
|
26
|
+
protected readonly preferenceService: PreferenceService;
|
|
27
|
+
|
|
28
|
+
@Autowired(ILibroOpensumiService)
|
|
29
|
+
protected readonly libroOpensumiService: ILibroOpensumiService;
|
|
30
|
+
|
|
31
|
+
private _onDidChangeContent: Emitter<URI> = new Emitter();
|
|
32
|
+
|
|
33
|
+
public onDidChangeContent: Event<URI> = this._onDidChangeContent.event;
|
|
34
|
+
|
|
35
|
+
handlesScheme?(scheme: string): MaybePromise<boolean> {
|
|
36
|
+
return scheme === LibroCellURIScheme;
|
|
37
|
+
}
|
|
38
|
+
// handlesUri?(uri: URI): MaybePromise<number> {
|
|
39
|
+
// throw new Error("Method not implemented.");
|
|
40
|
+
// }
|
|
41
|
+
|
|
42
|
+
async provideEditorDocumentModelContent(uri: URI, encoding?: string | undefined): Promise<string> {
|
|
43
|
+
const cell = await this.libroOpensumiService.getCellViewByUri(uri);
|
|
44
|
+
return cell?.model.value ?? '';
|
|
45
|
+
}
|
|
46
|
+
isReadonly(uri: URI): MaybePromise<boolean> {
|
|
47
|
+
return false;
|
|
48
|
+
}
|
|
49
|
+
saveDocumentModel?(
|
|
50
|
+
uri: URI,
|
|
51
|
+
content: string,
|
|
52
|
+
baseContent: string,
|
|
53
|
+
changes: IEditorDocumentChange[],
|
|
54
|
+
encoding?: string | undefined,
|
|
55
|
+
ignoreDiff?: boolean | undefined,
|
|
56
|
+
eol?: EOL | undefined,
|
|
57
|
+
): MaybePromise<IEditorDocumentModelSaveResult> {
|
|
58
|
+
return {
|
|
59
|
+
state: SaveTaskResponseState.SUCCESS,
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
async preferLanguageForUri?(uri: URI): Promise<string | undefined> {
|
|
63
|
+
const cell = await this.libroOpensumiService.getCellViewByUri(uri);
|
|
64
|
+
if (!cell) {
|
|
65
|
+
return;
|
|
66
|
+
}
|
|
67
|
+
return this.libroOpensumiService.getCellLangauge(cell);
|
|
68
|
+
}
|
|
69
|
+
// async provideEOL?(uri: URI): Promise<EOL> {
|
|
70
|
+
// return '\n'
|
|
71
|
+
// }
|
|
72
|
+
provideEncoding?(uri: URI): MaybePromise<string> {
|
|
73
|
+
const encoding = this.preferenceService.get<string>(
|
|
74
|
+
'files.encoding',
|
|
75
|
+
undefined,
|
|
76
|
+
uri.toString(),
|
|
77
|
+
getLanguageIdFromMonaco(uri)!,
|
|
78
|
+
);
|
|
79
|
+
return encoding || 'utf8';
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
// provideEditorDocumentModelContentMd5?(uri: URI, encoding?: string | undefined): MaybePromise<string | undefined> {
|
|
83
|
+
// throw new Error("Method not implemented.");
|
|
84
|
+
// }
|
|
85
|
+
// onDidDisposeModel?(uri: URI): void {
|
|
86
|
+
// throw new Error("Method not implemented.");
|
|
87
|
+
// }
|
|
88
|
+
isAlwaysDirty?(uri: URI): MaybePromise<boolean> {
|
|
89
|
+
return false;
|
|
90
|
+
}
|
|
91
|
+
closeAutoSave?(uri: URI): MaybePromise<boolean> {
|
|
92
|
+
return true;
|
|
93
|
+
}
|
|
94
|
+
// guessEncoding?(uri: URI): Promise<string | undefined> {
|
|
95
|
+
// throw new Error("Method not implemented.");
|
|
96
|
+
// }
|
|
97
|
+
disposeEvenDirty?(uri: URI): MaybePromise<boolean> {
|
|
98
|
+
return false;
|
|
99
|
+
}
|
|
100
|
+
}
|
|
@@ -0,0 +1,195 @@
|
|
|
1
|
+
import { CellUri, CellView, LibroJupyterView, LibroService, LibroView, MIME } from '@difizen/libro-jupyter/noeditor';
|
|
2
|
+
import { Container, getOrigin } from '@difizen/mana-app';
|
|
3
|
+
|
|
4
|
+
import { Autowired, Injectable } from '@opensumi/di';
|
|
5
|
+
import { ClientAppContribution, URI } from '@opensumi/ide-core-browser';
|
|
6
|
+
import { Domain, MaybePromise, Uri } from '@opensumi/ide-core-common';
|
|
7
|
+
import {
|
|
8
|
+
CellKind,
|
|
9
|
+
INotebookModelAddedData,
|
|
10
|
+
NotebookCellDto,
|
|
11
|
+
NotebookCellsChangeType,
|
|
12
|
+
NotebookRawContentEventDto,
|
|
13
|
+
WorkbenchEditorService,
|
|
14
|
+
} from '@opensumi/ide-editor';
|
|
15
|
+
import { IEditorDocumentModelService } from '@opensumi/ide-editor/lib/browser/doc-model/types';
|
|
16
|
+
import { NotebookService } from '@opensumi/ide-editor/lib/browser/notebook.service';
|
|
17
|
+
|
|
18
|
+
import { LIBRO_COMPONENTS_SCHEME_ID } from './libro.protocol';
|
|
19
|
+
import { ILibroOpensumiService } from './libro.service';
|
|
20
|
+
import { ManaContainer } from './mana';
|
|
21
|
+
|
|
22
|
+
@Injectable()
|
|
23
|
+
@Domain(ClientAppContribution)
|
|
24
|
+
export class NotebookServiceOverride extends NotebookService implements ClientAppContribution {
|
|
25
|
+
@Autowired(ManaContainer)
|
|
26
|
+
private readonly manaContainer: Container;
|
|
27
|
+
@Autowired(IEditorDocumentModelService)
|
|
28
|
+
private readonly editorModelService: IEditorDocumentModelService;
|
|
29
|
+
@Autowired(WorkbenchEditorService)
|
|
30
|
+
private readonly workbenchEditorService: WorkbenchEditorService;
|
|
31
|
+
@Autowired(ILibroOpensumiService)
|
|
32
|
+
private readonly libroOpensumiService: ILibroOpensumiService;
|
|
33
|
+
|
|
34
|
+
onDidStart(): MaybePromise<void> {
|
|
35
|
+
this.listenLibro();
|
|
36
|
+
this.listenEditor();
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
listenEditor() {
|
|
40
|
+
this.workbenchEditorService.onActiveResourceChange((e) => {
|
|
41
|
+
if (e?.uri?.path.ext === `.${LIBRO_COMPONENTS_SCHEME_ID}`) {
|
|
42
|
+
this.libroOpensumiService.getOrCreatLibroView(e.uri).then((libroView) => {
|
|
43
|
+
this.handleOpenNotebook(libroView);
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
protected notebookVersions = new Map<string, number>();
|
|
50
|
+
|
|
51
|
+
protected getNotebookVersion(libroView: LibroView) {
|
|
52
|
+
const uri = this.getNotebookUri(libroView as LibroJupyterView).toString();
|
|
53
|
+
return this.notebookVersions.get(uri) ?? 1;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
protected deleteNotebookVersion(libroView: LibroView) {
|
|
57
|
+
const uri = this.getNotebookUri(libroView as LibroJupyterView).toString();
|
|
58
|
+
return this.notebookVersions.delete(uri);
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
protected updateNotebookVersion(libroView: LibroView) {
|
|
62
|
+
const uri = this.getNotebookUri(libroView as LibroJupyterView).toString();
|
|
63
|
+
const versionId = this.notebookVersions.get(uri) ?? 1;
|
|
64
|
+
this.notebookVersions.set(uri, versionId + 1);
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
protected isValidNotebook(view: LibroView): boolean {
|
|
68
|
+
if (view instanceof LibroJupyterView) {
|
|
69
|
+
return true;
|
|
70
|
+
}
|
|
71
|
+
return false;
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
isCodeCell(mime: string) {
|
|
75
|
+
return ([MIME.odpssql, MIME.python] as string[]).includes(mime);
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
getCellURI(cell: CellView) {
|
|
79
|
+
return CellUri.from(cell.parent.model.id, cell.model.id);
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
getCellModelRef(cell: CellView) {
|
|
83
|
+
return this.editorModelService.getModelReference(URI.parse(this.getCellURI(cell).toString()));
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
asNotebookCell(cell: CellView): NotebookCellDto {
|
|
87
|
+
return {
|
|
88
|
+
cellKind: this.isCodeCell(cell.model.mimeType) ? CellKind.Code : CellKind.Markup,
|
|
89
|
+
eol: '\n',
|
|
90
|
+
handle: 1,
|
|
91
|
+
language: this.libroOpensumiService.getCellLangauge(cell) ?? 'plaintext',
|
|
92
|
+
mime: cell.model.mimeType,
|
|
93
|
+
outputs: [],
|
|
94
|
+
source: cell.model.value.split('\n'),
|
|
95
|
+
uri: Uri.parse(this.getCellURI(cell).toString()),
|
|
96
|
+
};
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
getNotebookUri(notebook: LibroJupyterView) {
|
|
100
|
+
return Uri.parse(notebook.model.filePath);
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
asNotebook(notebook: LibroJupyterView): INotebookModelAddedData {
|
|
104
|
+
return {
|
|
105
|
+
uri: this.getNotebookUri(notebook),
|
|
106
|
+
viewType: 'jupyter-notebook',
|
|
107
|
+
versionId: this.getNotebookVersion(notebook),
|
|
108
|
+
cells: notebook.model.cells.map((item) => this.asNotebookCell(item)),
|
|
109
|
+
};
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
listenLibro() {
|
|
113
|
+
const libroService = this.manaContainer.get(LibroService);
|
|
114
|
+
libroService.onNotebookViewCreated(this.handleOpenNotebook);
|
|
115
|
+
libroService.onNotebookViewClosed((libroView) => {
|
|
116
|
+
if (!this.isValidNotebook(libroView)) {
|
|
117
|
+
return;
|
|
118
|
+
}
|
|
119
|
+
this.deleteNotebookVersion(libroView);
|
|
120
|
+
this._onDidCloseNotebookDocument.fire(this.getNotebookUri(libroView as LibroJupyterView));
|
|
121
|
+
});
|
|
122
|
+
libroService.onNotebookViewSaved((libroView) => {
|
|
123
|
+
if (!this.isValidNotebook(libroView)) {
|
|
124
|
+
return;
|
|
125
|
+
}
|
|
126
|
+
this.updateNotebookVersion(libroView);
|
|
127
|
+
this._onDidSaveNotebookDocument.fire(this.getNotebookUri(libroView as LibroJupyterView));
|
|
128
|
+
});
|
|
129
|
+
libroService.onNotebookViewChanged((event) => {
|
|
130
|
+
if (!this.isValidNotebook(event.libroView)) {
|
|
131
|
+
return;
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
if (!event.libroView.model.isInitialized) {
|
|
135
|
+
return;
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
const events: NotebookRawContentEventDto[] = [];
|
|
139
|
+
|
|
140
|
+
if (event.contentChanges) {
|
|
141
|
+
event.contentChanges.forEach((item) => {
|
|
142
|
+
if (item.addedCells.length > 0) {
|
|
143
|
+
events.push({
|
|
144
|
+
kind: NotebookCellsChangeType.ModelChange,
|
|
145
|
+
changes: [[item.range.start, 0, item.addedCells.map((cell) => this.asNotebookCell(cell))]],
|
|
146
|
+
});
|
|
147
|
+
}
|
|
148
|
+
if (item.removedCells.length > 0) {
|
|
149
|
+
events.push({
|
|
150
|
+
kind: NotebookCellsChangeType.ModelChange,
|
|
151
|
+
changes: [[item.range.start, item.range.end - item.range.start, []]],
|
|
152
|
+
});
|
|
153
|
+
}
|
|
154
|
+
});
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
this.updateNotebookVersion(event.libroView);
|
|
158
|
+
this._onDidChangeNotebookDocument.fire({
|
|
159
|
+
uri: this.getNotebookUri(event.libroView as LibroJupyterView),
|
|
160
|
+
event: {
|
|
161
|
+
rawEvents: events,
|
|
162
|
+
versionId: 1,
|
|
163
|
+
},
|
|
164
|
+
isDirty: getOrigin(event.libroView.model.dirty),
|
|
165
|
+
});
|
|
166
|
+
});
|
|
167
|
+
|
|
168
|
+
libroService.onNotebookCellChanged((event) => {
|
|
169
|
+
const events: NotebookRawContentEventDto[] = [];
|
|
170
|
+
const index = event.cell.parent.findCellIndex(event.cell);
|
|
171
|
+
const modelRef = this.getCellModelRef(event.cell);
|
|
172
|
+
events.push({
|
|
173
|
+
kind: NotebookCellsChangeType.ChangeCellContent,
|
|
174
|
+
index,
|
|
175
|
+
});
|
|
176
|
+
this._onDidChangeNotebookDocument.fire({
|
|
177
|
+
uri: this.getNotebookUri(event.cell.parent as LibroJupyterView),
|
|
178
|
+
event: {
|
|
179
|
+
rawEvents: events,
|
|
180
|
+
versionId: modelRef?.instance.getMonacoModel().getVersionId() ?? 1,
|
|
181
|
+
},
|
|
182
|
+
isDirty: getOrigin(event.cell.parent.model.dirty),
|
|
183
|
+
});
|
|
184
|
+
});
|
|
185
|
+
}
|
|
186
|
+
|
|
187
|
+
protected handleOpenNotebook = async (libroView: LibroView) => {
|
|
188
|
+
if (!this.isValidNotebook(libroView)) {
|
|
189
|
+
return;
|
|
190
|
+
}
|
|
191
|
+
await libroView.initialized;
|
|
192
|
+
this.updateNotebookVersion(libroView);
|
|
193
|
+
this._onDidOpenNotebookDocument.fire(this.asNotebook(libroView as LibroJupyterView));
|
|
194
|
+
};
|
|
195
|
+
}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { Autowired } from '@opensumi/di';
|
|
2
|
+
import { Domain, localize } from '@opensumi/ide-core-browser';
|
|
3
|
+
import { EXPLORER_CONTAINER_ID } from '@opensumi/ide-explorer/lib/browser/explorer-contribution';
|
|
4
|
+
import { IMainLayoutService, MainLayoutContribution } from '@opensumi/ide-main-layout';
|
|
5
|
+
|
|
6
|
+
import { TocPanel } from './toc.panel';
|
|
7
|
+
|
|
8
|
+
@Domain(MainLayoutContribution)
|
|
9
|
+
export class TocContribution implements MainLayoutContribution {
|
|
10
|
+
@Autowired(IMainLayoutService)
|
|
11
|
+
private mainLayoutService: IMainLayoutService;
|
|
12
|
+
|
|
13
|
+
onDidRender() {
|
|
14
|
+
this.mainLayoutService.collectViewComponent(
|
|
15
|
+
{
|
|
16
|
+
component: TocPanel,
|
|
17
|
+
collapsed: true,
|
|
18
|
+
id: 'outline-view',
|
|
19
|
+
name: localize('outline.title'),
|
|
20
|
+
},
|
|
21
|
+
EXPLORER_CONTAINER_ID,
|
|
22
|
+
);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
.toc {
|
|
2
|
+
:global {
|
|
3
|
+
.libro-toc-collapsed {
|
|
4
|
+
svg {
|
|
5
|
+
vertical-align: sub;
|
|
6
|
+
}
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
.markdown-toc-container {
|
|
10
|
+
width: 100%;
|
|
11
|
+
|
|
12
|
+
.markdown-toc-container-anchor {
|
|
13
|
+
color: var(--toc-panel-text-color);
|
|
14
|
+
font-size: 12px;
|
|
15
|
+
line-height: 20px;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
.markdown-toc-container-title {
|
|
19
|
+
display: none;
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { localize } from '@opensumi/ide-core-browser';
|
|
2
|
+
import { registerColor } from '@opensumi/ide-theme/lib/common';
|
|
3
|
+
|
|
4
|
+
export const initTocPanelColorToken = () => {
|
|
5
|
+
registerColor(
|
|
6
|
+
'toc.panel.text.color',
|
|
7
|
+
{ dark: '#A6AAAD', light: '#363C42', hcDark: null, hcLight: null },
|
|
8
|
+
localize('toc.panel.text.color', 'the text color of toc panel'),
|
|
9
|
+
true,
|
|
10
|
+
);
|
|
11
|
+
};
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { TOCView } from '@difizen/libro-toc';
|
|
2
|
+
import { Container, ViewManager, ViewRender } from '@difizen/mana-app';
|
|
3
|
+
import React, { PropsWithChildren, useEffect, useState } from 'react';
|
|
4
|
+
|
|
5
|
+
import { URI, ViewState, useInjectable } from '@opensumi/ide-core-browser';
|
|
6
|
+
import { WorkbenchEditorService } from '@opensumi/ide-editor';
|
|
7
|
+
import { WorkbenchEditorServiceImpl } from '@opensumi/ide-editor/lib/browser/workbench-editor.service';
|
|
8
|
+
import { OutlinePanel } from '@opensumi/ide-outline/lib/browser/outline';
|
|
9
|
+
|
|
10
|
+
import { LIBRO_COMPONENTS_SCHEME_ID } from '../libro.protocol';
|
|
11
|
+
import { ILibroOpensumiService } from '../libro.service';
|
|
12
|
+
import { ManaContainer } from '../mana';
|
|
13
|
+
|
|
14
|
+
import styles from './toc.module.less';
|
|
15
|
+
|
|
16
|
+
export const TocPanel = ({ viewState }: PropsWithChildren<{ viewState: ViewState }>) => {
|
|
17
|
+
const editorService = useInjectable<WorkbenchEditorServiceImpl>(WorkbenchEditorService);
|
|
18
|
+
const libroOpensumiService = useInjectable<ILibroOpensumiService>(ILibroOpensumiService);
|
|
19
|
+
const manaContainer = useInjectable<Container>(ManaContainer);
|
|
20
|
+
|
|
21
|
+
const [libroTocView, setLibroTocView] = useState<TOCView | undefined>();
|
|
22
|
+
|
|
23
|
+
useEffect(() => {
|
|
24
|
+
if (editorService.currentResource?.uri.path.ext === `.${LIBRO_COMPONENTS_SCHEME_ID}`) {
|
|
25
|
+
libroOpensumiService.getOrCreatLibroView(editorService.currentResource.uri).then((libro) => {
|
|
26
|
+
const viewManager = manaContainer.get(ViewManager);
|
|
27
|
+
viewManager
|
|
28
|
+
.getOrCreateView<TOCView>(TOCView, {
|
|
29
|
+
id: (editorService.currentResource?.uri as URI).toString(),
|
|
30
|
+
})
|
|
31
|
+
.then((libroTocView) => {
|
|
32
|
+
libroTocView.parent = libro;
|
|
33
|
+
setLibroTocView(libroTocView);
|
|
34
|
+
return;
|
|
35
|
+
});
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
editorService.onActiveResourceChange((e) => {
|
|
39
|
+
if (e?.uri.path.ext === `.${LIBRO_COMPONENTS_SCHEME_ID}`) {
|
|
40
|
+
libroOpensumiService.getOrCreatLibroView(e.uri).then((libro) => {
|
|
41
|
+
const viewManager = manaContainer.get(ViewManager);
|
|
42
|
+
viewManager
|
|
43
|
+
.getOrCreateView<TOCView>(TOCView, {
|
|
44
|
+
id: (e.uri as URI).toString(),
|
|
45
|
+
})
|
|
46
|
+
.then((libroTocView) => {
|
|
47
|
+
libroTocView.parent = libro;
|
|
48
|
+
setLibroTocView(libroTocView);
|
|
49
|
+
return;
|
|
50
|
+
});
|
|
51
|
+
});
|
|
52
|
+
} else {
|
|
53
|
+
setLibroTocView(undefined);
|
|
54
|
+
}
|
|
55
|
+
});
|
|
56
|
+
});
|
|
57
|
+
if (libroTocView) {
|
|
58
|
+
return (
|
|
59
|
+
<div className={styles.toc}>
|
|
60
|
+
<ViewRender view={libroTocView}></ViewRender>
|
|
61
|
+
</div>
|
|
62
|
+
);
|
|
63
|
+
} else {
|
|
64
|
+
return <OutlinePanel viewState={viewState}></OutlinePanel>;
|
|
65
|
+
}
|
|
66
|
+
};
|
package/src/index.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './browser';
|