@theia/notebook 1.53.0-next.4 → 1.53.0-next.55
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 +30 -30
- package/lib/browser/contributions/cell-operations.d.ts.map +1 -1
- package/lib/browser/contributions/cell-operations.js +8 -1
- package/lib/browser/contributions/cell-operations.js.map +1 -1
- package/lib/browser/contributions/notebook-actions-contribution.d.ts +1 -0
- package/lib/browser/contributions/notebook-actions-contribution.d.ts.map +1 -1
- package/lib/browser/contributions/notebook-actions-contribution.js +31 -6
- package/lib/browser/contributions/notebook-actions-contribution.js.map +1 -1
- package/lib/browser/contributions/notebook-cell-actions-contribution.d.ts +4 -0
- package/lib/browser/contributions/notebook-cell-actions-contribution.d.ts.map +1 -1
- package/lib/browser/contributions/notebook-cell-actions-contribution.js +49 -12
- package/lib/browser/contributions/notebook-cell-actions-contribution.js.map +1 -1
- package/lib/browser/contributions/notebook-status-bar-contribution.d.ts +14 -0
- package/lib/browser/contributions/notebook-status-bar-contribution.d.ts.map +1 -0
- package/lib/browser/contributions/notebook-status-bar-contribution.js +75 -0
- package/lib/browser/contributions/notebook-status-bar-contribution.js.map +1 -0
- package/lib/browser/notebook-editor-widget.d.ts.map +1 -1
- package/lib/browser/notebook-editor-widget.js +3 -5
- package/lib/browser/notebook-editor-widget.js.map +1 -1
- package/lib/browser/notebook-frontend-module.d.ts.map +1 -1
- package/lib/browser/notebook-frontend-module.js +3 -0
- package/lib/browser/notebook-frontend-module.js.map +1 -1
- package/lib/browser/notebook-open-handler.d.ts +3 -2
- package/lib/browser/notebook-open-handler.d.ts.map +1 -1
- package/lib/browser/notebook-open-handler.js +12 -5
- package/lib/browser/notebook-open-handler.js.map +1 -1
- package/lib/browser/service/notebook-options.d.ts +1 -0
- package/lib/browser/service/notebook-options.d.ts.map +1 -1
- package/lib/browser/service/notebook-options.js +1 -0
- package/lib/browser/service/notebook-options.js.map +1 -1
- package/lib/browser/service/notebook-service.d.ts +1 -0
- package/lib/browser/service/notebook-service.d.ts.map +1 -1
- package/lib/browser/service/notebook-service.js +7 -0
- package/lib/browser/service/notebook-service.js.map +1 -1
- package/lib/browser/view/notebook-cell-editor.d.ts +1 -0
- package/lib/browser/view/notebook-cell-editor.d.ts.map +1 -1
- package/lib/browser/view/notebook-cell-editor.js +30 -16
- package/lib/browser/view/notebook-cell-editor.js.map +1 -1
- package/lib/browser/view/notebook-cell-list-view.d.ts +7 -4
- package/lib/browser/view/notebook-cell-list-view.d.ts.map +1 -1
- package/lib/browser/view/notebook-cell-list-view.js +39 -29
- package/lib/browser/view/notebook-cell-list-view.js.map +1 -1
- package/lib/browser/view-model/notebook-cell-model.d.ts +3 -0
- package/lib/browser/view-model/notebook-cell-model.d.ts.map +1 -1
- package/lib/browser/view-model/notebook-cell-model.js +5 -0
- package/lib/browser/view-model/notebook-cell-model.js.map +1 -1
- package/package.json +8 -8
- package/src/browser/contributions/cell-operations.ts +44 -39
- package/src/browser/contributions/notebook-actions-contribution.ts +379 -351
- package/src/browser/contributions/notebook-cell-actions-contribution.ts +525 -485
- package/src/browser/contributions/notebook-color-contribution.ts +268 -268
- package/src/browser/contributions/notebook-context-keys.ts +113 -113
- package/src/browser/contributions/notebook-label-provider-contribution.ts +85 -85
- package/src/browser/contributions/notebook-outline-contribution.ts +114 -114
- package/src/browser/contributions/notebook-output-action-contribution.ts +82 -82
- package/src/browser/contributions/notebook-preferences.ts +92 -92
- package/src/browser/contributions/notebook-status-bar-contribution.ts +77 -0
- package/src/browser/contributions/notebook-undo-redo-handler.ts +41 -41
- package/src/browser/index.ts +27 -27
- package/src/browser/notebook-cell-resource-resolver.ts +130 -130
- package/src/browser/notebook-editor-widget-factory.ts +82 -82
- package/src/browser/notebook-editor-widget.tsx +330 -331
- package/src/browser/notebook-frontend-module.ts +119 -115
- package/src/browser/notebook-open-handler.ts +120 -114
- package/src/browser/notebook-output-utils.ts +119 -119
- package/src/browser/notebook-renderer-registry.ts +85 -85
- package/src/browser/notebook-type-registry.ts +54 -54
- package/src/browser/notebook-types.ts +186 -186
- package/src/browser/renderers/cell-output-webview.ts +33 -33
- package/src/browser/service/notebook-clipboard-service.ts +43 -43
- package/src/browser/service/notebook-context-manager.ts +162 -162
- package/src/browser/service/notebook-editor-widget-service.ts +101 -101
- package/src/browser/service/notebook-execution-service.ts +139 -139
- package/src/browser/service/notebook-execution-state-service.ts +311 -311
- package/src/browser/service/notebook-kernel-history-service.ts +124 -124
- package/src/browser/service/notebook-kernel-quick-pick-service.ts +479 -479
- package/src/browser/service/notebook-kernel-service.ts +357 -357
- package/src/browser/service/notebook-model-resolver-service.ts +160 -160
- package/src/browser/service/notebook-monaco-text-model-service.ts +48 -48
- package/src/browser/service/notebook-options.ts +155 -154
- package/src/browser/service/notebook-renderer-messaging-service.ts +121 -121
- package/src/browser/service/notebook-service.ts +215 -209
- package/src/browser/style/index.css +483 -467
- package/src/browser/view/notebook-cell-editor.tsx +263 -247
- package/src/browser/view/notebook-cell-list-view.tsx +279 -259
- package/src/browser/view/notebook-cell-toolbar-factory.tsx +102 -102
- package/src/browser/view/notebook-cell-toolbar.tsx +74 -74
- package/src/browser/view/notebook-code-cell-view.tsx +350 -350
- package/src/browser/view/notebook-find-widget.tsx +335 -335
- package/src/browser/view/notebook-main-toolbar.tsx +235 -235
- package/src/browser/view/notebook-markdown-cell-view.tsx +208 -208
- package/src/browser/view/notebook-viewport-service.ts +61 -61
- package/src/browser/view-model/notebook-cell-model.ts +473 -466
- package/src/browser/view-model/notebook-cell-output-model.ts +100 -100
- package/src/browser/view-model/notebook-model.ts +550 -550
- package/src/common/index.ts +18 -18
- package/src/common/notebook-common.ts +337 -337
- package/src/common/notebook-protocol.ts +35 -35
- package/src/common/notebook-range.ts +30 -30
|
@@ -1,124 +1,124 @@
|
|
|
1
|
-
// *****************************************************************************
|
|
2
|
-
// Copyright (C) 2023 TypeFox and others.
|
|
3
|
-
//
|
|
4
|
-
// This program and the accompanying materials are made available under the
|
|
5
|
-
// terms of the Eclipse Public License v. 2.0 which is available at
|
|
6
|
-
// http://www.eclipse.org/legal/epl-2.0.
|
|
7
|
-
//
|
|
8
|
-
// This Source Code may also be made available under the following Secondary
|
|
9
|
-
// Licenses when the conditions for such availability set forth in the Eclipse
|
|
10
|
-
// Public License v. 2.0 are satisfied: GNU General Public License, version 2
|
|
11
|
-
// with the GNU Classpath Exception which is available at
|
|
12
|
-
// https://www.gnu.org/software/classpath/license.html.
|
|
13
|
-
//
|
|
14
|
-
// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
|
|
15
|
-
// *****************************************************************************
|
|
16
|
-
/*---------------------------------------------------------------------------------------------
|
|
17
|
-
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
18
|
-
* Licensed under the MIT License. See License.txt in the project root for license information.
|
|
19
|
-
*--------------------------------------------------------------------------------------------*/
|
|
20
|
-
|
|
21
|
-
import { inject, injectable, postConstruct } from '@theia/core/shared/inversify';
|
|
22
|
-
import { StorageService } from '@theia/core/lib/browser';
|
|
23
|
-
import { NotebookKernel, NotebookTextModelLike, NotebookKernelService } from './notebook-kernel-service';
|
|
24
|
-
import { CommandService, Disposable } from '@theia/core';
|
|
25
|
-
import { NotebookModel } from '../view-model/notebook-model';
|
|
26
|
-
import { NotebookCommands } from '../contributions/notebook-actions-contribution';
|
|
27
|
-
|
|
28
|
-
interface KernelsList {
|
|
29
|
-
[viewType: string]: string[];
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
interface MostRecentKernelsResult {
|
|
33
|
-
selected?: NotebookKernel,
|
|
34
|
-
all: NotebookKernel[]
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
const MAX_KERNELS_IN_HISTORY = 5;
|
|
38
|
-
|
|
39
|
-
@injectable()
|
|
40
|
-
export class NotebookKernelHistoryService implements Disposable {
|
|
41
|
-
|
|
42
|
-
@inject(StorageService)
|
|
43
|
-
protected storageService: StorageService;
|
|
44
|
-
|
|
45
|
-
@inject(NotebookKernelService)
|
|
46
|
-
protected notebookKernelService: NotebookKernelService;
|
|
47
|
-
|
|
48
|
-
@inject(CommandService)
|
|
49
|
-
protected commandService: CommandService;
|
|
50
|
-
|
|
51
|
-
protected static STORAGE_KEY = 'notebook.kernelHistory';
|
|
52
|
-
protected mostRecentKernelsMap: KernelsList = {};
|
|
53
|
-
|
|
54
|
-
@postConstruct()
|
|
55
|
-
protected init(): void {
|
|
56
|
-
this.loadState();
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
getKernels(notebook: NotebookTextModelLike): MostRecentKernelsResult {
|
|
60
|
-
const allAvailableKernels = this.notebookKernelService.getMatchingKernel(notebook);
|
|
61
|
-
const allKernels = allAvailableKernels.all;
|
|
62
|
-
const selectedKernel = allAvailableKernels.selected;
|
|
63
|
-
// We will suggest the only kernel
|
|
64
|
-
const suggested = allAvailableKernels.all.length === 1 ? allAvailableKernels.all[0] : undefined;
|
|
65
|
-
const mostRecentKernelIds = this.mostRecentKernelsMap[notebook.viewType] ? this.mostRecentKernelsMap[notebook.viewType].map(kernel => kernel[1]) : [];
|
|
66
|
-
const all = mostRecentKernelIds.map(kernelId => allKernels.find(kernel => kernel.id === kernelId)).filter(kernel => !!kernel) as NotebookKernel[];
|
|
67
|
-
|
|
68
|
-
return {
|
|
69
|
-
selected: selectedKernel ?? suggested,
|
|
70
|
-
all
|
|
71
|
-
};
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
async resolveSelectedKernel(notebook: NotebookModel): Promise<NotebookKernel | undefined> {
|
|
75
|
-
const alreadySelected = this.getKernels(notebook);
|
|
76
|
-
|
|
77
|
-
if (alreadySelected.selected) {
|
|
78
|
-
return alreadySelected.selected;
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
await this.commandService.executeCommand(NotebookCommands.SELECT_KERNEL_COMMAND.id, notebook);
|
|
82
|
-
const { selected } = this.getKernels(notebook);
|
|
83
|
-
return selected;
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
addMostRecentKernel(kernel: NotebookKernel): void {
|
|
87
|
-
const viewType = kernel.viewType;
|
|
88
|
-
const recentKernels = this.mostRecentKernelsMap[viewType] ?? [kernel.id];
|
|
89
|
-
|
|
90
|
-
if (recentKernels.length > MAX_KERNELS_IN_HISTORY) {
|
|
91
|
-
recentKernels.splice(MAX_KERNELS_IN_HISTORY);
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
this.mostRecentKernelsMap[viewType] = recentKernels;
|
|
95
|
-
this.saveState();
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
protected saveState(): void {
|
|
99
|
-
let notEmpty = false;
|
|
100
|
-
for (const kernels of Object.values(this.mostRecentKernelsMap)) {
|
|
101
|
-
notEmpty = notEmpty || Object.entries(kernels).length > 0;
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
this.storageService.setData(NotebookKernelHistoryService.STORAGE_KEY, notEmpty ? this.mostRecentKernelsMap : undefined);
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
protected async loadState(): Promise<void> {
|
|
108
|
-
const kernelMap = await this.storageService.getData(NotebookKernelHistoryService.STORAGE_KEY);
|
|
109
|
-
if (kernelMap) {
|
|
110
|
-
this.mostRecentKernelsMap = kernelMap as KernelsList;
|
|
111
|
-
} else {
|
|
112
|
-
this.mostRecentKernelsMap = {};
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
clear(): void {
|
|
117
|
-
this.mostRecentKernelsMap = {};
|
|
118
|
-
this.saveState();
|
|
119
|
-
}
|
|
120
|
-
|
|
121
|
-
dispose(): void {
|
|
122
|
-
|
|
123
|
-
}
|
|
124
|
-
}
|
|
1
|
+
// *****************************************************************************
|
|
2
|
+
// Copyright (C) 2023 TypeFox and others.
|
|
3
|
+
//
|
|
4
|
+
// This program and the accompanying materials are made available under the
|
|
5
|
+
// terms of the Eclipse Public License v. 2.0 which is available at
|
|
6
|
+
// http://www.eclipse.org/legal/epl-2.0.
|
|
7
|
+
//
|
|
8
|
+
// This Source Code may also be made available under the following Secondary
|
|
9
|
+
// Licenses when the conditions for such availability set forth in the Eclipse
|
|
10
|
+
// Public License v. 2.0 are satisfied: GNU General Public License, version 2
|
|
11
|
+
// with the GNU Classpath Exception which is available at
|
|
12
|
+
// https://www.gnu.org/software/classpath/license.html.
|
|
13
|
+
//
|
|
14
|
+
// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
|
|
15
|
+
// *****************************************************************************
|
|
16
|
+
/*---------------------------------------------------------------------------------------------
|
|
17
|
+
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
18
|
+
* Licensed under the MIT License. See License.txt in the project root for license information.
|
|
19
|
+
*--------------------------------------------------------------------------------------------*/
|
|
20
|
+
|
|
21
|
+
import { inject, injectable, postConstruct } from '@theia/core/shared/inversify';
|
|
22
|
+
import { StorageService } from '@theia/core/lib/browser';
|
|
23
|
+
import { NotebookKernel, NotebookTextModelLike, NotebookKernelService } from './notebook-kernel-service';
|
|
24
|
+
import { CommandService, Disposable } from '@theia/core';
|
|
25
|
+
import { NotebookModel } from '../view-model/notebook-model';
|
|
26
|
+
import { NotebookCommands } from '../contributions/notebook-actions-contribution';
|
|
27
|
+
|
|
28
|
+
interface KernelsList {
|
|
29
|
+
[viewType: string]: string[];
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
interface MostRecentKernelsResult {
|
|
33
|
+
selected?: NotebookKernel,
|
|
34
|
+
all: NotebookKernel[]
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
const MAX_KERNELS_IN_HISTORY = 5;
|
|
38
|
+
|
|
39
|
+
@injectable()
|
|
40
|
+
export class NotebookKernelHistoryService implements Disposable {
|
|
41
|
+
|
|
42
|
+
@inject(StorageService)
|
|
43
|
+
protected storageService: StorageService;
|
|
44
|
+
|
|
45
|
+
@inject(NotebookKernelService)
|
|
46
|
+
protected notebookKernelService: NotebookKernelService;
|
|
47
|
+
|
|
48
|
+
@inject(CommandService)
|
|
49
|
+
protected commandService: CommandService;
|
|
50
|
+
|
|
51
|
+
protected static STORAGE_KEY = 'notebook.kernelHistory';
|
|
52
|
+
protected mostRecentKernelsMap: KernelsList = {};
|
|
53
|
+
|
|
54
|
+
@postConstruct()
|
|
55
|
+
protected init(): void {
|
|
56
|
+
this.loadState();
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
getKernels(notebook: NotebookTextModelLike): MostRecentKernelsResult {
|
|
60
|
+
const allAvailableKernels = this.notebookKernelService.getMatchingKernel(notebook);
|
|
61
|
+
const allKernels = allAvailableKernels.all;
|
|
62
|
+
const selectedKernel = allAvailableKernels.selected;
|
|
63
|
+
// We will suggest the only kernel
|
|
64
|
+
const suggested = allAvailableKernels.all.length === 1 ? allAvailableKernels.all[0] : undefined;
|
|
65
|
+
const mostRecentKernelIds = this.mostRecentKernelsMap[notebook.viewType] ? this.mostRecentKernelsMap[notebook.viewType].map(kernel => kernel[1]) : [];
|
|
66
|
+
const all = mostRecentKernelIds.map(kernelId => allKernels.find(kernel => kernel.id === kernelId)).filter(kernel => !!kernel) as NotebookKernel[];
|
|
67
|
+
|
|
68
|
+
return {
|
|
69
|
+
selected: selectedKernel ?? suggested,
|
|
70
|
+
all
|
|
71
|
+
};
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
async resolveSelectedKernel(notebook: NotebookModel): Promise<NotebookKernel | undefined> {
|
|
75
|
+
const alreadySelected = this.getKernels(notebook);
|
|
76
|
+
|
|
77
|
+
if (alreadySelected.selected) {
|
|
78
|
+
return alreadySelected.selected;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
await this.commandService.executeCommand(NotebookCommands.SELECT_KERNEL_COMMAND.id, notebook);
|
|
82
|
+
const { selected } = this.getKernels(notebook);
|
|
83
|
+
return selected;
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
addMostRecentKernel(kernel: NotebookKernel): void {
|
|
87
|
+
const viewType = kernel.viewType;
|
|
88
|
+
const recentKernels = this.mostRecentKernelsMap[viewType] ?? [kernel.id];
|
|
89
|
+
|
|
90
|
+
if (recentKernels.length > MAX_KERNELS_IN_HISTORY) {
|
|
91
|
+
recentKernels.splice(MAX_KERNELS_IN_HISTORY);
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
this.mostRecentKernelsMap[viewType] = recentKernels;
|
|
95
|
+
this.saveState();
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
protected saveState(): void {
|
|
99
|
+
let notEmpty = false;
|
|
100
|
+
for (const kernels of Object.values(this.mostRecentKernelsMap)) {
|
|
101
|
+
notEmpty = notEmpty || Object.entries(kernels).length > 0;
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
this.storageService.setData(NotebookKernelHistoryService.STORAGE_KEY, notEmpty ? this.mostRecentKernelsMap : undefined);
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
protected async loadState(): Promise<void> {
|
|
108
|
+
const kernelMap = await this.storageService.getData(NotebookKernelHistoryService.STORAGE_KEY);
|
|
109
|
+
if (kernelMap) {
|
|
110
|
+
this.mostRecentKernelsMap = kernelMap as KernelsList;
|
|
111
|
+
} else {
|
|
112
|
+
this.mostRecentKernelsMap = {};
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
clear(): void {
|
|
117
|
+
this.mostRecentKernelsMap = {};
|
|
118
|
+
this.saveState();
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
dispose(): void {
|
|
122
|
+
|
|
123
|
+
}
|
|
124
|
+
}
|