@theia/workspace 1.34.1 → 1.34.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (105) hide show
  1. package/LICENSE +641 -641
  2. package/README.md +30 -30
  3. package/lib/browser/diff-service.d.ts +10 -10
  4. package/lib/browser/diff-service.js +85 -85
  5. package/lib/browser/index.d.ts +6 -6
  6. package/lib/browser/index.js +33 -33
  7. package/lib/browser/quick-open-workspace.d.ts +25 -25
  8. package/lib/browser/quick-open-workspace.js +137 -137
  9. package/lib/browser/untitled-workspace-exit-dialog.d.ts +19 -19
  10. package/lib/browser/untitled-workspace-exit-dialog.js +74 -74
  11. package/lib/browser/workspace-breadcrumbs-contribution.d.ts +10 -10
  12. package/lib/browser/workspace-breadcrumbs-contribution.js +66 -66
  13. package/lib/browser/workspace-commands.d.ts +117 -117
  14. package/lib/browser/workspace-commands.js +593 -593
  15. package/lib/browser/workspace-commands.spec.d.ts +1 -1
  16. package/lib/browser/workspace-commands.spec.js +127 -127
  17. package/lib/browser/workspace-compare-handler.d.ts +26 -26
  18. package/lib/browser/workspace-compare-handler.js +66 -66
  19. package/lib/browser/workspace-delete-handler.d.ts +75 -75
  20. package/lib/browser/workspace-delete-handler.js +214 -214
  21. package/lib/browser/workspace-duplicate-handler.d.ts +30 -30
  22. package/lib/browser/workspace-duplicate-handler.js +86 -86
  23. package/lib/browser/workspace-frontend-contribution.d.ts +135 -135
  24. package/lib/browser/workspace-frontend-contribution.js +568 -568
  25. package/lib/browser/workspace-frontend-contribution.spec.d.ts +1 -1
  26. package/lib/browser/workspace-frontend-contribution.spec.js +53 -53
  27. package/lib/browser/workspace-frontend-module.d.ts +3 -3
  28. package/lib/browser/workspace-frontend-module.js +88 -88
  29. package/lib/browser/workspace-input-dialog.d.ts +19 -19
  30. package/lib/browser/workspace-input-dialog.js +73 -73
  31. package/lib/browser/workspace-preferences.d.ts +11 -11
  32. package/lib/browser/workspace-preferences.js +46 -46
  33. package/lib/browser/workspace-schema-updater.d.ts +32 -32
  34. package/lib/browser/workspace-schema-updater.js +148 -148
  35. package/lib/browser/workspace-service.d.ts +182 -182
  36. package/lib/browser/workspace-service.js +729 -729
  37. package/lib/browser/workspace-storage-service.d.ts +15 -15
  38. package/lib/browser/workspace-storage-service.js +80 -80
  39. package/lib/browser/workspace-trust-preferences.d.ts +21 -21
  40. package/lib/browser/workspace-trust-preferences.js +65 -65
  41. package/lib/browser/workspace-trust-service.d.ts +26 -26
  42. package/lib/browser/workspace-trust-service.js +149 -149
  43. package/lib/browser/workspace-uri-contribution.d.ts +20 -20
  44. package/lib/browser/workspace-uri-contribution.js +113 -113
  45. package/lib/browser/workspace-uri-contribution.spec.d.ts +1 -1
  46. package/lib/browser/workspace-uri-contribution.spec.js +169 -169
  47. package/lib/browser/workspace-user-working-directory-provider.d.ts +12 -12
  48. package/lib/browser/workspace-user-working-directory-provider.js +62 -62
  49. package/lib/browser/workspace-utils.d.ts +15 -15
  50. package/lib/browser/workspace-utils.js +54 -54
  51. package/lib/browser/workspace-variable-contribution.d.ts +23 -23
  52. package/lib/browser/workspace-variable-contribution.js +237 -237
  53. package/lib/browser/workspace-window-title-updater.d.ts +7 -7
  54. package/lib/browser/workspace-window-title-updater.js +57 -57
  55. package/lib/common/index.d.ts +2 -2
  56. package/lib/common/index.js +29 -29
  57. package/lib/common/test/mock-workspace-server.d.ts +7 -7
  58. package/lib/common/test/mock-workspace-server.js +35 -35
  59. package/lib/common/utils.d.ts +21 -21
  60. package/lib/common/utils.js +73 -73
  61. package/lib/common/workspace-protocol.d.ts +26 -26
  62. package/lib/common/workspace-protocol.js +23 -23
  63. package/lib/node/default-workspace-server.d.ts +64 -64
  64. package/lib/node/default-workspace-server.js +248 -248
  65. package/lib/node/default-workspace-server.spec.d.ts +1 -1
  66. package/lib/node/default-workspace-server.spec.js +84 -84
  67. package/lib/node/index.d.ts +2 -2
  68. package/lib/node/index.js +29 -29
  69. package/lib/node/workspace-backend-module.d.ts +3 -3
  70. package/lib/node/workspace-backend-module.js +32 -32
  71. package/package.json +6 -6
  72. package/src/browser/diff-service.ts +62 -62
  73. package/src/browser/index.ts +22 -22
  74. package/src/browser/quick-open-workspace.ts +112 -112
  75. package/src/browser/untitled-workspace-exit-dialog.ts +70 -70
  76. package/src/browser/workspace-breadcrumbs-contribution.ts +56 -56
  77. package/src/browser/workspace-commands.spec.ts +153 -153
  78. package/src/browser/workspace-commands.ts +586 -586
  79. package/src/browser/workspace-compare-handler.ts +56 -56
  80. package/src/browser/workspace-delete-handler.ts +212 -212
  81. package/src/browser/workspace-duplicate-handler.ts +75 -75
  82. package/src/browser/workspace-frontend-contribution.spec.ts +63 -63
  83. package/src/browser/workspace-frontend-contribution.ts +558 -558
  84. package/src/browser/workspace-frontend-module.ts +115 -115
  85. package/src/browser/workspace-input-dialog.ts +60 -60
  86. package/src/browser/workspace-preferences.ts +58 -58
  87. package/src/browser/workspace-schema-updater.ts +148 -148
  88. package/src/browser/workspace-service.ts +772 -772
  89. package/src/browser/workspace-storage-service.ts +67 -67
  90. package/src/browser/workspace-trust-preferences.ts +76 -76
  91. package/src/browser/workspace-trust-service.ts +143 -143
  92. package/src/browser/workspace-uri-contribution.spec.ts +191 -191
  93. package/src/browser/workspace-uri-contribution.ts +97 -97
  94. package/src/browser/workspace-user-working-directory-provider.ts +48 -48
  95. package/src/browser/workspace-utils.ts +45 -45
  96. package/src/browser/workspace-variable-contribution.ts +222 -222
  97. package/src/browser/workspace-window-title-updater.ts +45 -45
  98. package/src/common/index.ts +18 -18
  99. package/src/common/test/mock-workspace-server.ts +29 -29
  100. package/src/common/utils.ts +69 -69
  101. package/src/common/workspace-protocol.ts +47 -47
  102. package/src/node/default-workspace-server.spec.ts +99 -99
  103. package/src/node/default-workspace-server.ts +242 -242
  104. package/src/node/index.ts +18 -18
  105. package/src/node/workspace-backend-module.ts +37 -37
@@ -1,87 +1,87 @@
1
- "use strict";
2
- // *****************************************************************************
3
- // Copyright (C) 2018 Ericsson and others.
4
- //
5
- // This program and the accompanying materials are made available under the
6
- // terms of the Eclipse Public License v. 2.0 which is available at
7
- // http://www.eclipse.org/legal/epl-2.0.
8
- //
9
- // This Source Code may also be made available under the following Secondary
10
- // Licenses when the conditions for such availability set forth in the Eclipse
11
- // Public License v. 2.0 are satisfied: GNU General Public License, version 2
12
- // with the GNU Classpath Exception which is available at
13
- // https://www.gnu.org/software/classpath/license.html.
14
- //
15
- // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
16
- // *****************************************************************************
17
- var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
18
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
19
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
20
- else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
21
- return c > 3 && r && Object.defineProperty(target, key, r), r;
22
- };
23
- var __metadata = (this && this.__metadata) || function (k, v) {
24
- if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
25
- };
26
- Object.defineProperty(exports, "__esModule", { value: true });
27
- exports.WorkspaceDuplicateHandler = void 0;
28
- const inversify_1 = require("@theia/core/shared/inversify");
29
- const workspace_utils_1 = require("./workspace-utils");
30
- const workspace_service_1 = require("./workspace-service");
31
- const filesystem_utils_1 = require("@theia/filesystem/lib/common/filesystem-utils");
32
- const file_service_1 = require("@theia/filesystem/lib/browser/file-service");
33
- let WorkspaceDuplicateHandler = class WorkspaceDuplicateHandler {
34
- /**
35
- * Determine if the command is visible.
36
- *
37
- * @param uris URIs of selected resources.
38
- * @returns `true` if the command is visible.
39
- */
40
- isVisible(uris) {
41
- return !!uris.length && !this.workspaceUtils.containsRootDirectory(uris);
42
- }
43
- /**
44
- * Determine if the command is enabled.
45
- *
46
- * @param uris URIs of selected resources.
47
- * @returns `true` if the command is enabled.
48
- */
49
- isEnabled(uris) {
50
- return !!uris.length && !this.workspaceUtils.containsRootDirectory(uris);
51
- }
52
- /**
53
- * Execute the command.
54
- *
55
- * @param uris URIs of selected resources.
56
- */
57
- async execute(uris) {
58
- await Promise.all(uris.map(async (uri) => {
59
- try {
60
- const parent = await this.fileService.resolve(uri.parent);
61
- const targetFileStat = await this.fileService.resolve(uri);
62
- const target = filesystem_utils_1.FileSystemUtils.generateUniqueResourceURI(parent, uri, targetFileStat.isDirectory, 'copy');
63
- await this.fileService.copy(uri, target);
64
- }
65
- catch (e) {
66
- console.error(e);
67
- }
68
- }));
69
- }
70
- };
71
- __decorate([
72
- (0, inversify_1.inject)(file_service_1.FileService),
73
- __metadata("design:type", file_service_1.FileService)
74
- ], WorkspaceDuplicateHandler.prototype, "fileService", void 0);
75
- __decorate([
76
- (0, inversify_1.inject)(workspace_utils_1.WorkspaceUtils),
77
- __metadata("design:type", workspace_utils_1.WorkspaceUtils)
78
- ], WorkspaceDuplicateHandler.prototype, "workspaceUtils", void 0);
79
- __decorate([
80
- (0, inversify_1.inject)(workspace_service_1.WorkspaceService),
81
- __metadata("design:type", workspace_service_1.WorkspaceService)
82
- ], WorkspaceDuplicateHandler.prototype, "workspaceService", void 0);
83
- WorkspaceDuplicateHandler = __decorate([
84
- (0, inversify_1.injectable)()
85
- ], WorkspaceDuplicateHandler);
86
- exports.WorkspaceDuplicateHandler = WorkspaceDuplicateHandler;
1
+ "use strict";
2
+ // *****************************************************************************
3
+ // Copyright (C) 2018 Ericsson and others.
4
+ //
5
+ // This program and the accompanying materials are made available under the
6
+ // terms of the Eclipse Public License v. 2.0 which is available at
7
+ // http://www.eclipse.org/legal/epl-2.0.
8
+ //
9
+ // This Source Code may also be made available under the following Secondary
10
+ // Licenses when the conditions for such availability set forth in the Eclipse
11
+ // Public License v. 2.0 are satisfied: GNU General Public License, version 2
12
+ // with the GNU Classpath Exception which is available at
13
+ // https://www.gnu.org/software/classpath/license.html.
14
+ //
15
+ // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
16
+ // *****************************************************************************
17
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
18
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
19
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
20
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
21
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
22
+ };
23
+ var __metadata = (this && this.__metadata) || function (k, v) {
24
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
25
+ };
26
+ Object.defineProperty(exports, "__esModule", { value: true });
27
+ exports.WorkspaceDuplicateHandler = void 0;
28
+ const inversify_1 = require("@theia/core/shared/inversify");
29
+ const workspace_utils_1 = require("./workspace-utils");
30
+ const workspace_service_1 = require("./workspace-service");
31
+ const filesystem_utils_1 = require("@theia/filesystem/lib/common/filesystem-utils");
32
+ const file_service_1 = require("@theia/filesystem/lib/browser/file-service");
33
+ let WorkspaceDuplicateHandler = class WorkspaceDuplicateHandler {
34
+ /**
35
+ * Determine if the command is visible.
36
+ *
37
+ * @param uris URIs of selected resources.
38
+ * @returns `true` if the command is visible.
39
+ */
40
+ isVisible(uris) {
41
+ return !!uris.length && !this.workspaceUtils.containsRootDirectory(uris);
42
+ }
43
+ /**
44
+ * Determine if the command is enabled.
45
+ *
46
+ * @param uris URIs of selected resources.
47
+ * @returns `true` if the command is enabled.
48
+ */
49
+ isEnabled(uris) {
50
+ return !!uris.length && !this.workspaceUtils.containsRootDirectory(uris);
51
+ }
52
+ /**
53
+ * Execute the command.
54
+ *
55
+ * @param uris URIs of selected resources.
56
+ */
57
+ async execute(uris) {
58
+ await Promise.all(uris.map(async (uri) => {
59
+ try {
60
+ const parent = await this.fileService.resolve(uri.parent);
61
+ const targetFileStat = await this.fileService.resolve(uri);
62
+ const target = filesystem_utils_1.FileSystemUtils.generateUniqueResourceURI(parent, uri, targetFileStat.isDirectory, 'copy');
63
+ await this.fileService.copy(uri, target);
64
+ }
65
+ catch (e) {
66
+ console.error(e);
67
+ }
68
+ }));
69
+ }
70
+ };
71
+ __decorate([
72
+ (0, inversify_1.inject)(file_service_1.FileService),
73
+ __metadata("design:type", file_service_1.FileService)
74
+ ], WorkspaceDuplicateHandler.prototype, "fileService", void 0);
75
+ __decorate([
76
+ (0, inversify_1.inject)(workspace_utils_1.WorkspaceUtils),
77
+ __metadata("design:type", workspace_utils_1.WorkspaceUtils)
78
+ ], WorkspaceDuplicateHandler.prototype, "workspaceUtils", void 0);
79
+ __decorate([
80
+ (0, inversify_1.inject)(workspace_service_1.WorkspaceService),
81
+ __metadata("design:type", workspace_service_1.WorkspaceService)
82
+ ], WorkspaceDuplicateHandler.prototype, "workspaceService", void 0);
83
+ WorkspaceDuplicateHandler = __decorate([
84
+ (0, inversify_1.injectable)()
85
+ ], WorkspaceDuplicateHandler);
86
+ exports.WorkspaceDuplicateHandler = WorkspaceDuplicateHandler;
87
87
  //# sourceMappingURL=workspace-duplicate-handler.js.map
@@ -1,136 +1,136 @@
1
- import { CommandContribution, CommandRegistry, MenuContribution, MenuModelRegistry, MessageService, MaybeArray } from '@theia/core/lib/common';
2
- import { OS } from '@theia/core';
3
- import { OpenerService, KeybindingRegistry, KeybindingContribution, FrontendApplicationContribution, OnWillStopAction, Navigatable, SaveableSource, Widget } from '@theia/core/lib/browser';
4
- import { FileDialogService, OpenFileDialogProps, FileDialogTreeFilters } from '@theia/filesystem/lib/browser';
5
- import { ContextKeyService } from '@theia/core/lib/browser/context-key-service';
6
- import { WorkspaceService } from './workspace-service';
7
- import { QuickOpenWorkspace } from './quick-open-workspace';
8
- import { WorkspacePreferences } from './workspace-preferences';
9
- import URI from '@theia/core/lib/common/uri';
10
- import { FileService } from '@theia/filesystem/lib/browser/file-service';
11
- import { EncodingRegistry } from '@theia/core/lib/browser/encoding-registry';
12
- import { DisposableCollection } from '@theia/core/lib/common/disposable';
13
- import { PreferenceConfigurations } from '@theia/core/lib/browser/preferences/preference-configurations';
14
- import { FileStat } from '@theia/filesystem/lib/common/files';
15
- import { FilesystemSaveResourceService } from '@theia/filesystem/lib/browser/filesystem-save-resource-service';
16
- export declare enum WorkspaceStates {
17
- /**
18
- * The state is `empty` when no workspace is opened.
19
- */
20
- empty = "empty",
21
- /**
22
- * The state is `workspace` when a workspace is opened.
23
- */
24
- workspace = "workspace",
25
- /**
26
- * The state is `folder` when a folder is opened. (1 folder)
27
- */
28
- folder = "folder"
29
- }
30
- export declare type WorkspaceState = keyof typeof WorkspaceStates;
31
- export declare type WorkbenchState = keyof typeof WorkspaceStates;
32
- /** Create the workspace section after open {@link CommonMenus.FILE_OPEN}. */
33
- export declare const FILE_WORKSPACE: string[];
34
- export declare class WorkspaceFrontendContribution implements CommandContribution, KeybindingContribution, MenuContribution, FrontendApplicationContribution {
35
- protected readonly messageService: MessageService;
36
- protected readonly fileService: FileService;
37
- protected readonly openerService: OpenerService;
38
- protected readonly workspaceService: WorkspaceService;
39
- protected readonly quickOpenWorkspace: QuickOpenWorkspace;
40
- protected readonly fileDialogService: FileDialogService;
41
- protected preferences: WorkspacePreferences;
42
- protected readonly contextKeyService: ContextKeyService;
43
- protected readonly encodingRegistry: EncodingRegistry;
44
- protected readonly preferenceConfigurations: PreferenceConfigurations;
45
- protected readonly saveService: FilesystemSaveResourceService;
46
- configure(): void;
47
- protected readonly toDisposeOnUpdateEncodingOverrides: DisposableCollection;
48
- protected updateEncodingOverrides(): void;
49
- protected updateStyles(): void;
50
- registerCommands(commands: CommandRegistry): void;
51
- registerMenus(menus: MenuModelRegistry): void;
52
- registerKeybindings(keybindings: KeybindingRegistry): void;
53
- /**
54
- * This is the generic `Open` method. Opens files and directories too. Resolves to the opened URI.
55
- * Except when you are on either Windows or Linux `AND` running in electron. If so, it opens a file.
56
- */
57
- protected doOpen(): Promise<URI | undefined>;
58
- /**
59
- * Opens a file after prompting the `Open File` dialog. Resolves to `undefined`, if
60
- * - the workspace root is not set,
61
- * - the file to open does not exist, or
62
- * - it was not a file, but a directory.
63
- *
64
- * Otherwise, resolves to the URI of the file.
65
- */
66
- protected doOpenFile(): Promise<URI | undefined>;
67
- /**
68
- * Opens one or more folders after prompting the `Open Folder` dialog. Resolves to `undefined`, if
69
- * - the user's selection is empty or contains only files.
70
- * - the new workspace is equal to the old workspace.
71
- *
72
- * Otherwise, resolves to the URI of the new workspace:
73
- * - a single folder if a single folder was selected.
74
- * - a new, untitled workspace file if multiple folders were selected.
75
- */
76
- protected doOpenFolder(): Promise<URI | undefined>;
77
- protected getOpenableWorkspaceUri(uris: MaybeArray<URI>): Promise<URI | undefined>;
78
- protected createMultiRootWorkspace(roots: FileStat[]): Promise<URI>;
79
- /**
80
- * Opens a workspace after raising the `Open Workspace` dialog. Resolves to the URI of the recently opened workspace,
81
- * if it was successful. Otherwise, resolves to `undefined`.
82
- *
83
- * **Caveat**: this behaves differently on different platforms
84
- * and `electron`/`browser` version has impact too. See [here](https://github.com/eclipse-theia/theia/pull/3202#issuecomment-430884195) for more details.
85
- *
86
- * Legend:
87
- * - Folders only: => `F`
88
- * - Workspace files only: => `W`
89
- * - Folders and workspace files: => `FW`
90
- *
91
- * -----
92
- *
93
- * |---------|-----------|-----------|------------|------------|
94
- * | | browser Y | browser N | electron Y | electron N |
95
- * |---------|-----------|-----------|------------|------------|
96
- * | Linux | FW | F | W | F |
97
- * | Windows | FW | F | W | F |
98
- * | OS X | FW | F | FW | FW |
99
- * |---------|-----------|-----------|------------|------------|
100
- *
101
- */
102
- protected doOpenWorkspace(): Promise<URI | undefined>;
103
- protected openWorkspaceOpenFileDialogProps(): Promise<OpenFileDialogProps>;
104
- protected closeWorkspace(): Promise<void>;
105
- /**
106
- * @returns whether the file was successfully saved.
107
- */
108
- protected saveWorkspaceAs(): Promise<boolean>;
109
- canBeSavedAs(widget: Widget | undefined): widget is Widget & SaveableSource & Navigatable;
110
- saveAs(widget: Widget & SaveableSource & Navigatable): Promise<void>;
111
- protected updateWorkspaceStateKey(): WorkspaceState;
112
- protected updateWorkbenchStateKey(): WorkbenchState;
113
- protected doUpdateState(): WorkspaceState | WorkbenchState;
114
- private isElectron;
115
- /**
116
- * Get the current workspace URI.
117
- *
118
- * @returns the current workspace URI.
119
- */
120
- private getCurrentWorkspaceUri;
121
- onWillStop(): OnWillStopAction<boolean> | undefined;
122
- }
123
- export declare namespace WorkspaceFrontendContribution {
124
- /**
125
- * File filter for all Theia and VS Code workspace file types.
126
- */
127
- const DEFAULT_FILE_FILTER: FileDialogTreeFilters;
128
- /**
129
- * Returns with an `OpenFileDialogProps` for opening the `Open Workspace` dialog.
130
- */
131
- function createOpenWorkspaceOpenFileDialogProps(options: Readonly<{
132
- type: OS.Type;
133
- electron: boolean;
134
- }>): OpenFileDialogProps;
135
- }
1
+ import { CommandContribution, CommandRegistry, MenuContribution, MenuModelRegistry, MessageService, MaybeArray } from '@theia/core/lib/common';
2
+ import { OS } from '@theia/core';
3
+ import { OpenerService, KeybindingRegistry, KeybindingContribution, FrontendApplicationContribution, OnWillStopAction, Navigatable, SaveableSource, Widget } from '@theia/core/lib/browser';
4
+ import { FileDialogService, OpenFileDialogProps, FileDialogTreeFilters } from '@theia/filesystem/lib/browser';
5
+ import { ContextKeyService } from '@theia/core/lib/browser/context-key-service';
6
+ import { WorkspaceService } from './workspace-service';
7
+ import { QuickOpenWorkspace } from './quick-open-workspace';
8
+ import { WorkspacePreferences } from './workspace-preferences';
9
+ import URI from '@theia/core/lib/common/uri';
10
+ import { FileService } from '@theia/filesystem/lib/browser/file-service';
11
+ import { EncodingRegistry } from '@theia/core/lib/browser/encoding-registry';
12
+ import { DisposableCollection } from '@theia/core/lib/common/disposable';
13
+ import { PreferenceConfigurations } from '@theia/core/lib/browser/preferences/preference-configurations';
14
+ import { FileStat } from '@theia/filesystem/lib/common/files';
15
+ import { FilesystemSaveResourceService } from '@theia/filesystem/lib/browser/filesystem-save-resource-service';
16
+ export declare enum WorkspaceStates {
17
+ /**
18
+ * The state is `empty` when no workspace is opened.
19
+ */
20
+ empty = "empty",
21
+ /**
22
+ * The state is `workspace` when a workspace is opened.
23
+ */
24
+ workspace = "workspace",
25
+ /**
26
+ * The state is `folder` when a folder is opened. (1 folder)
27
+ */
28
+ folder = "folder"
29
+ }
30
+ export declare type WorkspaceState = keyof typeof WorkspaceStates;
31
+ export declare type WorkbenchState = keyof typeof WorkspaceStates;
32
+ /** Create the workspace section after open {@link CommonMenus.FILE_OPEN}. */
33
+ export declare const FILE_WORKSPACE: string[];
34
+ export declare class WorkspaceFrontendContribution implements CommandContribution, KeybindingContribution, MenuContribution, FrontendApplicationContribution {
35
+ protected readonly messageService: MessageService;
36
+ protected readonly fileService: FileService;
37
+ protected readonly openerService: OpenerService;
38
+ protected readonly workspaceService: WorkspaceService;
39
+ protected readonly quickOpenWorkspace: QuickOpenWorkspace;
40
+ protected readonly fileDialogService: FileDialogService;
41
+ protected preferences: WorkspacePreferences;
42
+ protected readonly contextKeyService: ContextKeyService;
43
+ protected readonly encodingRegistry: EncodingRegistry;
44
+ protected readonly preferenceConfigurations: PreferenceConfigurations;
45
+ protected readonly saveService: FilesystemSaveResourceService;
46
+ configure(): void;
47
+ protected readonly toDisposeOnUpdateEncodingOverrides: DisposableCollection;
48
+ protected updateEncodingOverrides(): void;
49
+ protected updateStyles(): void;
50
+ registerCommands(commands: CommandRegistry): void;
51
+ registerMenus(menus: MenuModelRegistry): void;
52
+ registerKeybindings(keybindings: KeybindingRegistry): void;
53
+ /**
54
+ * This is the generic `Open` method. Opens files and directories too. Resolves to the opened URI.
55
+ * Except when you are on either Windows or Linux `AND` running in electron. If so, it opens a file.
56
+ */
57
+ protected doOpen(): Promise<URI | undefined>;
58
+ /**
59
+ * Opens a file after prompting the `Open File` dialog. Resolves to `undefined`, if
60
+ * - the workspace root is not set,
61
+ * - the file to open does not exist, or
62
+ * - it was not a file, but a directory.
63
+ *
64
+ * Otherwise, resolves to the URI of the file.
65
+ */
66
+ protected doOpenFile(): Promise<URI | undefined>;
67
+ /**
68
+ * Opens one or more folders after prompting the `Open Folder` dialog. Resolves to `undefined`, if
69
+ * - the user's selection is empty or contains only files.
70
+ * - the new workspace is equal to the old workspace.
71
+ *
72
+ * Otherwise, resolves to the URI of the new workspace:
73
+ * - a single folder if a single folder was selected.
74
+ * - a new, untitled workspace file if multiple folders were selected.
75
+ */
76
+ protected doOpenFolder(): Promise<URI | undefined>;
77
+ protected getOpenableWorkspaceUri(uris: MaybeArray<URI>): Promise<URI | undefined>;
78
+ protected createMultiRootWorkspace(roots: FileStat[]): Promise<URI>;
79
+ /**
80
+ * Opens a workspace after raising the `Open Workspace` dialog. Resolves to the URI of the recently opened workspace,
81
+ * if it was successful. Otherwise, resolves to `undefined`.
82
+ *
83
+ * **Caveat**: this behaves differently on different platforms
84
+ * and `electron`/`browser` version has impact too. See [here](https://github.com/eclipse-theia/theia/pull/3202#issuecomment-430884195) for more details.
85
+ *
86
+ * Legend:
87
+ * - Folders only: => `F`
88
+ * - Workspace files only: => `W`
89
+ * - Folders and workspace files: => `FW`
90
+ *
91
+ * -----
92
+ *
93
+ * |---------|-----------|-----------|------------|------------|
94
+ * | | browser Y | browser N | electron Y | electron N |
95
+ * |---------|-----------|-----------|------------|------------|
96
+ * | Linux | FW | F | W | F |
97
+ * | Windows | FW | F | W | F |
98
+ * | OS X | FW | F | FW | FW |
99
+ * |---------|-----------|-----------|------------|------------|
100
+ *
101
+ */
102
+ protected doOpenWorkspace(): Promise<URI | undefined>;
103
+ protected openWorkspaceOpenFileDialogProps(): Promise<OpenFileDialogProps>;
104
+ protected closeWorkspace(): Promise<void>;
105
+ /**
106
+ * @returns whether the file was successfully saved.
107
+ */
108
+ protected saveWorkspaceAs(): Promise<boolean>;
109
+ canBeSavedAs(widget: Widget | undefined): widget is Widget & SaveableSource & Navigatable;
110
+ saveAs(widget: Widget & SaveableSource & Navigatable): Promise<void>;
111
+ protected updateWorkspaceStateKey(): WorkspaceState;
112
+ protected updateWorkbenchStateKey(): WorkbenchState;
113
+ protected doUpdateState(): WorkspaceState | WorkbenchState;
114
+ private isElectron;
115
+ /**
116
+ * Get the current workspace URI.
117
+ *
118
+ * @returns the current workspace URI.
119
+ */
120
+ private getCurrentWorkspaceUri;
121
+ onWillStop(): OnWillStopAction<boolean> | undefined;
122
+ }
123
+ export declare namespace WorkspaceFrontendContribution {
124
+ /**
125
+ * File filter for all Theia and VS Code workspace file types.
126
+ */
127
+ const DEFAULT_FILE_FILTER: FileDialogTreeFilters;
128
+ /**
129
+ * Returns with an `OpenFileDialogProps` for opening the `Open Workspace` dialog.
130
+ */
131
+ function createOpenWorkspaceOpenFileDialogProps(options: Readonly<{
132
+ type: OS.Type;
133
+ electron: boolean;
134
+ }>): OpenFileDialogProps;
135
+ }
136
136
  //# sourceMappingURL=workspace-frontend-contribution.d.ts.map