@theia/filesystem 1.48.1 → 1.48.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.
- package/README.md +30 -30
- package/lib/browser/breadcrumbs/filepath-breadcrumb.d.ts +15 -15
- package/lib/browser/breadcrumbs/filepath-breadcrumb.js +41 -41
- package/lib/browser/breadcrumbs/filepath-breadcrumbs-container.d.ts +13 -13
- package/lib/browser/breadcrumbs/filepath-breadcrumbs-container.js +70 -70
- package/lib/browser/breadcrumbs/filepath-breadcrumbs-contribution.d.ts +27 -27
- package/lib/browser/breadcrumbs/filepath-breadcrumbs-contribution.js +118 -118
- package/lib/browser/download/file-download-command-contribution.d.ts +18 -18
- package/lib/browser/download/file-download-command-contribution.js +75 -75
- package/lib/browser/download/file-download-frontend-module.d.ts +3 -3
- package/lib/browser/download/file-download-frontend-module.js +25 -25
- package/lib/browser/download/file-download-service.d.ts +28 -28
- package/lib/browser/download/file-download-service.js +167 -167
- package/lib/browser/file-dialog/file-dialog-container.d.ts +5 -5
- package/lib/browser/file-dialog/file-dialog-container.js +60 -60
- package/lib/browser/file-dialog/file-dialog-hidden-files-renderer.d.ts +15 -15
- package/lib/browser/file-dialog/file-dialog-hidden-files-renderer.js +59 -59
- package/lib/browser/file-dialog/file-dialog-model.d.ts +25 -25
- package/lib/browser/file-dialog/file-dialog-model.js +100 -100
- package/lib/browser/file-dialog/file-dialog-module.d.ts +3 -3
- package/lib/browser/file-dialog/file-dialog-module.js +45 -45
- package/lib/browser/file-dialog/file-dialog-service.d.ts +32 -32
- package/lib/browser/file-dialog/file-dialog-service.js +101 -101
- package/lib/browser/file-dialog/file-dialog-tree-filters-renderer.d.ts +39 -39
- package/lib/browser/file-dialog/file-dialog-tree-filters-renderer.js +81 -81
- package/lib/browser/file-dialog/file-dialog-tree.d.ts +26 -26
- package/lib/browser/file-dialog/file-dialog-tree.js +83 -83
- package/lib/browser/file-dialog/file-dialog-widget.d.ts +15 -15
- package/lib/browser/file-dialog/file-dialog-widget.js +75 -75
- package/lib/browser/file-dialog/file-dialog.d.ts +129 -129
- package/lib/browser/file-dialog/file-dialog.js +351 -351
- package/lib/browser/file-dialog/index.d.ts +4 -4
- package/lib/browser/file-dialog/index.js +22 -22
- package/lib/browser/file-resource.d.ts +67 -67
- package/lib/browser/file-resource.js +369 -369
- package/lib/browser/file-selection.d.ts +14 -14
- package/lib/browser/file-selection.js +36 -36
- package/lib/browser/file-service.d.ts +425 -425
- package/lib/browser/file-service.js +1366 -1366
- package/lib/browser/file-tree/file-tree-container.d.ts +3 -3
- package/lib/browser/file-tree/file-tree-container.js +35 -35
- package/lib/browser/file-tree/file-tree-decorator-adapter.d.ts +30 -30
- package/lib/browser/file-tree/file-tree-decorator-adapter.js +169 -169
- package/lib/browser/file-tree/file-tree-label-provider.d.ts +12 -12
- package/lib/browser/file-tree/file-tree-label-provider.js +54 -54
- package/lib/browser/file-tree/file-tree-model.d.ts +37 -37
- package/lib/browser/file-tree/file-tree-model.js +217 -217
- package/lib/browser/file-tree/file-tree-widget.d.ts +44 -44
- package/lib/browser/file-tree/file-tree-widget.js +317 -317
- package/lib/browser/file-tree/file-tree.d.ts +46 -46
- package/lib/browser/file-tree/file-tree.js +176 -176
- package/lib/browser/file-tree/index.d.ts +6 -6
- package/lib/browser/file-tree/index.js +24 -24
- package/lib/browser/file-upload-service.d.ts +109 -109
- package/lib/browser/file-upload-service.js +434 -434
- package/lib/browser/filesystem-frontend-contribution.d.ts +74 -74
- package/lib/browser/filesystem-frontend-contribution.js +356 -356
- package/lib/browser/filesystem-frontend-module.d.ts +5 -5
- package/lib/browser/filesystem-frontend-module.js +64 -64
- package/lib/browser/filesystem-preferences.d.ts +29 -29
- package/lib/browser/filesystem-preferences.js +110 -110
- package/lib/browser/filesystem-save-resource-service.d.ts +29 -29
- package/lib/browser/filesystem-save-resource-service.js +135 -135
- package/lib/browser/filesystem-watcher-error-handler.d.ts +10 -10
- package/lib/browser/filesystem-watcher-error-handler.js +61 -61
- package/lib/browser/index.d.ts +5 -5
- package/lib/browser/index.js +23 -23
- package/lib/browser/location/index.d.ts +2 -2
- package/lib/browser/location/index.js +20 -20
- package/lib/browser/location/location-renderer.d.ts +100 -100
- package/lib/browser/location/location-renderer.js +343 -343
- package/lib/browser/location/location-service.d.ts +5 -5
- package/lib/browser/location/location-service.js +17 -17
- package/lib/browser/remote-file-service-contribution.d.ts +6 -6
- package/lib/browser/remote-file-service-contribution.js +39 -39
- package/lib/browser-only/browser-only-filesystem-frontend-module.d.ts +3 -3
- package/lib/browser-only/browser-only-filesystem-frontend-module.js +40 -40
- package/lib/browser-only/browser-only-filesystem-provider-server.d.ts +11 -11
- package/lib/browser-only/browser-only-filesystem-provider-server.js +39 -39
- package/lib/browser-only/browserfs-filesystem-initialization.d.ts +12 -12
- package/lib/browser-only/browserfs-filesystem-initialization.js +54 -54
- package/lib/browser-only/browserfs-filesystem-provider.d.ts +45 -45
- package/lib/browser-only/browserfs-filesystem-provider.js +439 -439
- package/lib/common/delegating-file-system-provider.d.ts +76 -76
- package/lib/common/delegating-file-system-provider.js +168 -168
- package/lib/common/download/file-download-data.d.ts +6 -6
- package/lib/common/download/file-download-data.js +26 -26
- package/lib/common/file-upload.d.ts +1 -1
- package/lib/common/file-upload.js +19 -19
- package/lib/common/files.d.ts +659 -659
- package/lib/common/files.js +355 -355
- package/lib/common/files.spec.d.ts +1 -1
- package/lib/common/files.spec.js +51 -51
- package/lib/common/filesystem-utils.d.ts +14 -14
- package/lib/common/filesystem-utils.js +63 -63
- package/lib/common/filesystem-utils.spec.d.ts +1 -1
- package/lib/common/filesystem-utils.spec.js +378 -378
- package/lib/common/filesystem-watcher-protocol.d.ts +71 -71
- package/lib/common/filesystem-watcher-protocol.js +20 -20
- package/lib/common/filesystem.d.ts +22 -22
- package/lib/common/filesystem.js +42 -42
- package/lib/common/index.d.ts +2 -2
- package/lib/common/index.js +20 -20
- package/lib/common/io.d.ts +19 -19
- package/lib/common/io.js +110 -110
- package/lib/common/remote-file-system-provider.d.ts +173 -173
- package/lib/common/remote-file-system-provider.js +435 -435
- package/lib/electron-browser/file-dialog/electron-file-dialog-module.d.ts +3 -3
- package/lib/electron-browser/file-dialog/electron-file-dialog-module.js +24 -24
- package/lib/electron-browser/file-dialog/electron-file-dialog-service.d.ts +19 -19
- package/lib/electron-browser/file-dialog/electron-file-dialog-service.js +148 -148
- package/lib/electron-browser/preload.d.ts +1 -1
- package/lib/electron-browser/preload.js +30 -30
- package/lib/electron-common/electron-api.d.ts +34 -34
- package/lib/electron-common/electron-api.js +20 -20
- package/lib/electron-main/electron-api-main.d.ts +5 -5
- package/lib/electron-main/electron-api-main.js +73 -73
- package/lib/electron-main/electron-main-module.d.ts +3 -3
- package/lib/electron-main/electron-main-module.js +24 -24
- package/lib/node/disk-file-system-provider.d.ts +72 -72
- package/lib/node/disk-file-system-provider.js +787 -787
- package/lib/node/disk-file-system-provider.spec.d.ts +1 -1
- package/lib/node/disk-file-system-provider.spec.js +122 -122
- package/lib/node/download/directory-archiver.d.ts +9 -9
- package/lib/node/download/directory-archiver.js +127 -127
- package/lib/node/download/directory-archiver.spec.d.ts +1 -1
- package/lib/node/download/directory-archiver.spec.js +97 -97
- package/lib/node/download/file-download-backend-module.d.ts +3 -3
- package/lib/node/download/file-download-backend-module.js +32 -32
- package/lib/node/download/file-download-cache.d.ts +21 -21
- package/lib/node/download/file-download-cache.js +82 -82
- package/lib/node/download/file-download-endpoint.d.ts +11 -11
- package/lib/node/download/file-download-endpoint.js +67 -67
- package/lib/node/download/file-download-handler.d.ts +50 -50
- package/lib/node/download/file-download-handler.js +307 -307
- package/lib/node/download/test/mock-directory-archiver.d.ts +7 -7
- package/lib/node/download/test/mock-directory-archiver.js +29 -29
- package/lib/node/file-change-collection.d.ts +22 -22
- package/lib/node/file-change-collection.js +77 -77
- package/lib/node/file-change-collection.spec.d.ts +1 -1
- package/lib/node/file-change-collection.spec.js +90 -90
- package/lib/node/filesystem-backend-module.d.ts +26 -26
- package/lib/node/filesystem-backend-module.js +120 -120
- package/lib/node/filesystem-watcher-client.d.ts +23 -23
- package/lib/node/filesystem-watcher-client.js +75 -75
- package/lib/node/filesystem-watcher-dispatcher.d.ts +23 -23
- package/lib/node/filesystem-watcher-dispatcher.js +80 -80
- package/lib/node/node-file-upload-service.d.ts +16 -16
- package/lib/node/node-file-upload-service.js +79 -79
- package/lib/node/nsfw-watcher/index.d.ts +3 -3
- package/lib/node/nsfw-watcher/index.js +39 -39
- package/lib/node/nsfw-watcher/nsfw-filesystem-service.d.ts +191 -191
- package/lib/node/nsfw-watcher/nsfw-filesystem-service.js +405 -405
- package/lib/node/nsfw-watcher/nsfw-filesystem-watcher.spec.d.ts +1 -1
- package/lib/node/nsfw-watcher/nsfw-filesystem-watcher.spec.js +151 -151
- package/lib/node/nsfw-watcher/nsfw-options.d.ts +6 -6
- package/lib/node/nsfw-watcher/nsfw-options.js +22 -22
- package/package.json +4 -4
- package/src/browser/breadcrumbs/filepath-breadcrumb.ts +43 -43
- package/src/browser/breadcrumbs/filepath-breadcrumbs-container.ts +65 -65
- package/src/browser/breadcrumbs/filepath-breadcrumbs-contribution.ts +129 -129
- package/src/browser/download/file-download-command-contribution.ts +83 -83
- package/src/browser/download/file-download-frontend-module.ts +25 -25
- package/src/browser/download/file-download-service.ts +179 -179
- package/src/browser/file-dialog/file-dialog-container.ts +67 -67
- package/src/browser/file-dialog/file-dialog-hidden-files-renderer.tsx +59 -59
- package/src/browser/file-dialog/file-dialog-model.ts +96 -96
- package/src/browser/file-dialog/file-dialog-module.ts +44 -44
- package/src/browser/file-dialog/file-dialog-service.ts +99 -99
- package/src/browser/file-dialog/file-dialog-tree-filters-renderer.tsx +100 -100
- package/src/browser/file-dialog/file-dialog-tree.ts +89 -89
- package/src/browser/file-dialog/file-dialog-widget.ts +75 -75
- package/src/browser/file-dialog/file-dialog.ts +434 -434
- package/src/browser/file-dialog/index.ts +20 -20
- package/src/browser/file-resource.ts +390 -390
- package/src/browser/file-selection.ts +44 -44
- package/src/browser/file-service.ts +1841 -1841
- package/src/browser/file-tree/file-tree-container.ts +36 -36
- package/src/browser/file-tree/file-tree-decorator-adapter.ts +159 -159
- package/src/browser/file-tree/file-tree-label-provider.ts +53 -53
- package/src/browser/file-tree/file-tree-model.ts +212 -212
- package/src/browser/file-tree/file-tree-widget.tsx +327 -327
- package/src/browser/file-tree/file-tree.ts +183 -183
- package/src/browser/file-tree/index.ts +22 -22
- package/src/browser/file-upload-service.ts +539 -539
- package/src/browser/filesystem-frontend-contribution.ts +381 -381
- package/src/browser/filesystem-frontend-module.ts +77 -77
- package/src/browser/filesystem-preferences.ts +139 -139
- package/src/browser/filesystem-save-resource-service.ts +125 -125
- package/src/browser/filesystem-watcher-error-handler.ts +60 -60
- package/src/browser/index.ts +21 -21
- package/src/browser/location/index.ts +18 -18
- package/src/browser/location/location-renderer.tsx +404 -404
- package/src/browser/location/location-service.ts +22 -22
- package/src/browser/remote-file-service-contribution.ts +38 -38
- package/src/browser/style/file-dialog.css +208 -208
- package/src/browser/style/file-icons.css +64 -64
- package/src/browser/style/filepath-breadcrumbs.css +20 -20
- package/src/browser/style/index.css +36 -36
- package/src/browser-only/browser-only-filesystem-frontend-module.ts +38 -38
- package/src/browser-only/browser-only-filesystem-provider-server.ts +32 -32
- package/src/browser-only/browserfs-filesystem-initialization.ts +61 -61
- package/src/browser-only/browserfs-filesystem-provider.ts +462 -462
- package/src/common/delegating-file-system-provider.ts +226 -226
- package/src/common/download/README.md +30 -30
- package/src/common/download/file-download-data.ts +27 -27
- package/src/common/file-upload.ts +17 -17
- package/src/common/files.spec.ts +51 -51
- package/src/common/files.ts +996 -996
- package/src/common/filesystem-utils.spec.ts +411 -411
- package/src/common/filesystem-utils.ts +64 -64
- package/src/common/filesystem-watcher-protocol.ts +96 -96
- package/src/common/filesystem.ts +43 -43
- package/src/common/index.ts +18 -18
- package/src/common/io.ts +150 -150
- package/src/common/remote-file-system-provider.ts +549 -549
- package/src/electron-browser/file-dialog/electron-file-dialog-module.ts +24 -24
- package/src/electron-browser/file-dialog/electron-file-dialog-service.ts +165 -165
- package/src/electron-browser/preload.ts +31 -31
- package/src/electron-common/electron-api.ts +55 -55
- package/src/electron-main/electron-api-main.ts +78 -78
- package/src/electron-main/electron-main-module.ts +23 -23
- package/src/node/disk-file-system-provider.spec.ts +142 -142
- package/src/node/disk-file-system-provider.ts +915 -915
- package/src/node/download/directory-archiver.spec.ts +104 -104
- package/src/node/download/directory-archiver.ts +126 -126
- package/src/node/download/file-download-backend-module.ts +32 -32
- package/src/node/download/file-download-cache.ts +88 -88
- package/src/node/download/file-download-endpoint.ts +63 -63
- package/src/node/download/file-download-handler.ts +304 -304
- package/src/node/download/test/mock-directory-archiver.ts +30 -30
- package/src/node/file-change-collection.spec.ts +110 -110
- package/src/node/file-change-collection.ts +78 -78
- package/src/node/filesystem-backend-module.ts +140 -140
- package/src/node/filesystem-watcher-client.ts +72 -72
- package/src/node/filesystem-watcher-dispatcher.ts +82 -82
- package/src/node/node-file-upload-service.ts +80 -80
- package/src/node/nsfw-watcher/index.ts +45 -45
- package/src/node/nsfw-watcher/nsfw-filesystem-service.ts +481 -481
- package/src/node/nsfw-watcher/nsfw-filesystem-watcher.spec.ts +182 -182
- package/src/node/nsfw-watcher/nsfw-options.ts +23 -23
- package/src/typings/dom.webkit.d.ts +77 -77
- package/src/typings/mv/index.d.ts +21 -21
- package/src/typings/nsfw/index.d.ts +18 -18
- package/src/typings/trash/index.d.ts +20 -20
|
@@ -1,38 +1,38 @@
|
|
|
1
|
-
import URI from '@theia/core/lib/common/uri';
|
|
2
|
-
import { CompositeTreeNode, TreeNode, CompressedTreeModel } from '@theia/core/lib/browser';
|
|
3
|
-
import { FileStatNode } from './file-tree';
|
|
4
|
-
import { LocationService } from '../location';
|
|
5
|
-
import { LabelProvider } from '@theia/core/lib/browser/label-provider';
|
|
6
|
-
import { FileService } from '../file-service';
|
|
7
|
-
import { FileChangesEvent, FileChange, FileOperationEvent } from '../../common/files';
|
|
8
|
-
import { MessageService } from '@theia/core/lib/common/message-service';
|
|
9
|
-
import { EnvVariablesServer } from '@theia/core/lib/common/env-variables';
|
|
10
|
-
export declare class FileTreeModel extends CompressedTreeModel implements LocationService {
|
|
11
|
-
protected readonly labelProvider: LabelProvider;
|
|
12
|
-
protected readonly fileService: FileService;
|
|
13
|
-
protected readonly messageService: MessageService;
|
|
14
|
-
protected readonly environments: EnvVariablesServer;
|
|
15
|
-
protected init(): void;
|
|
16
|
-
get location(): URI | undefined;
|
|
17
|
-
set location(uri: URI | undefined);
|
|
18
|
-
drives(): Promise<URI[]>;
|
|
19
|
-
get selectedFileStatNodes(): Readonly<FileStatNode>[];
|
|
20
|
-
getNodesByUri(uri: URI): IterableIterator<TreeNode>;
|
|
21
|
-
/**
|
|
22
|
-
* to workaround https://github.com/Axosoft/nsfw/issues/42
|
|
23
|
-
*/
|
|
24
|
-
protected onDidMove(event: FileOperationEvent): void;
|
|
25
|
-
protected onFilesChanged(changes: FileChangesEvent): void;
|
|
26
|
-
protected isRootAffected(changes: FileChangesEvent): boolean;
|
|
27
|
-
protected getAffectedUris(changes: FileChangesEvent): URI[];
|
|
28
|
-
protected isFileContentChanged(change: FileChange): boolean;
|
|
29
|
-
protected refreshAffectedNodes(uris: URI[]): boolean;
|
|
30
|
-
protected getAffectedNodes(uris: URI[]): Map<string, CompositeTreeNode>;
|
|
31
|
-
copy(source: URI, target: Readonly<FileStatNode>): Promise<URI>;
|
|
32
|
-
/**
|
|
33
|
-
* Move the given source file or directory to the given target directory.
|
|
34
|
-
*/
|
|
35
|
-
move(source: TreeNode, target: TreeNode): Promise<URI | undefined>;
|
|
36
|
-
protected shouldReplace(fileName: string): Promise<boolean>;
|
|
37
|
-
}
|
|
1
|
+
import URI from '@theia/core/lib/common/uri';
|
|
2
|
+
import { CompositeTreeNode, TreeNode, CompressedTreeModel } from '@theia/core/lib/browser';
|
|
3
|
+
import { FileStatNode } from './file-tree';
|
|
4
|
+
import { LocationService } from '../location';
|
|
5
|
+
import { LabelProvider } from '@theia/core/lib/browser/label-provider';
|
|
6
|
+
import { FileService } from '../file-service';
|
|
7
|
+
import { FileChangesEvent, FileChange, FileOperationEvent } from '../../common/files';
|
|
8
|
+
import { MessageService } from '@theia/core/lib/common/message-service';
|
|
9
|
+
import { EnvVariablesServer } from '@theia/core/lib/common/env-variables';
|
|
10
|
+
export declare class FileTreeModel extends CompressedTreeModel implements LocationService {
|
|
11
|
+
protected readonly labelProvider: LabelProvider;
|
|
12
|
+
protected readonly fileService: FileService;
|
|
13
|
+
protected readonly messageService: MessageService;
|
|
14
|
+
protected readonly environments: EnvVariablesServer;
|
|
15
|
+
protected init(): void;
|
|
16
|
+
get location(): URI | undefined;
|
|
17
|
+
set location(uri: URI | undefined);
|
|
18
|
+
drives(): Promise<URI[]>;
|
|
19
|
+
get selectedFileStatNodes(): Readonly<FileStatNode>[];
|
|
20
|
+
getNodesByUri(uri: URI): IterableIterator<TreeNode>;
|
|
21
|
+
/**
|
|
22
|
+
* to workaround https://github.com/Axosoft/nsfw/issues/42
|
|
23
|
+
*/
|
|
24
|
+
protected onDidMove(event: FileOperationEvent): void;
|
|
25
|
+
protected onFilesChanged(changes: FileChangesEvent): void;
|
|
26
|
+
protected isRootAffected(changes: FileChangesEvent): boolean;
|
|
27
|
+
protected getAffectedUris(changes: FileChangesEvent): URI[];
|
|
28
|
+
protected isFileContentChanged(change: FileChange): boolean;
|
|
29
|
+
protected refreshAffectedNodes(uris: URI[]): boolean;
|
|
30
|
+
protected getAffectedNodes(uris: URI[]): Map<string, CompositeTreeNode>;
|
|
31
|
+
copy(source: URI, target: Readonly<FileStatNode>): Promise<URI>;
|
|
32
|
+
/**
|
|
33
|
+
* Move the given source file or directory to the given target directory.
|
|
34
|
+
*/
|
|
35
|
+
move(source: TreeNode, target: TreeNode): Promise<URI | undefined>;
|
|
36
|
+
protected shouldReplace(fileName: string): Promise<boolean>;
|
|
37
|
+
}
|
|
38
38
|
//# sourceMappingURL=file-tree-model.d.ts.map
|
|
@@ -1,218 +1,218 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
// *****************************************************************************
|
|
3
|
-
// Copyright (C) 2017 TypeFox 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-only WITH Classpath-exception-2.0
|
|
16
|
-
// *****************************************************************************
|
|
17
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
-
exports.FileTreeModel = void 0;
|
|
19
|
-
const tslib_1 = require("tslib");
|
|
20
|
-
const inversify_1 = require("@theia/core/shared/inversify");
|
|
21
|
-
const uri_1 = require("@theia/core/lib/common/uri");
|
|
22
|
-
const browser_1 = require("@theia/core/lib/browser");
|
|
23
|
-
const file_tree_1 = require("./file-tree");
|
|
24
|
-
const label_provider_1 = require("@theia/core/lib/browser/label-provider");
|
|
25
|
-
const file_service_1 = require("../file-service");
|
|
26
|
-
const files_1 = require("../../common/files");
|
|
27
|
-
const message_service_1 = require("@theia/core/lib/common/message-service");
|
|
28
|
-
const env_variables_1 = require("@theia/core/lib/common/env-variables");
|
|
29
|
-
const common_1 = require("../../common");
|
|
30
|
-
const core_1 = require("@theia/core");
|
|
31
|
-
let FileTreeModel = class FileTreeModel extends browser_1.CompressedTreeModel {
|
|
32
|
-
init() {
|
|
33
|
-
super.init();
|
|
34
|
-
this.toDispose.push(this.fileService.onDidFilesChange(changes => this.onFilesChanged(changes)));
|
|
35
|
-
this.toDispose.push(this.fileService.onDidRunOperation(event => this.onDidMove(event)));
|
|
36
|
-
}
|
|
37
|
-
get location() {
|
|
38
|
-
const root = this.root;
|
|
39
|
-
if (file_tree_1.FileStatNode.is(root)) {
|
|
40
|
-
return root.uri;
|
|
41
|
-
}
|
|
42
|
-
return undefined;
|
|
43
|
-
}
|
|
44
|
-
set location(uri) {
|
|
45
|
-
if (uri) {
|
|
46
|
-
this.fileService.resolve(uri).then(fileStat => {
|
|
47
|
-
if (fileStat) {
|
|
48
|
-
const node = file_tree_1.DirNode.createRoot(fileStat);
|
|
49
|
-
this.navigateTo(node);
|
|
50
|
-
}
|
|
51
|
-
}).catch(() => {
|
|
52
|
-
// no-op, allow failures for file dialog text input
|
|
53
|
-
});
|
|
54
|
-
}
|
|
55
|
-
else {
|
|
56
|
-
this.navigateTo(undefined);
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
async drives() {
|
|
60
|
-
try {
|
|
61
|
-
const drives = await this.environments.getDrives();
|
|
62
|
-
return drives.map(uri => new uri_1.default(uri));
|
|
63
|
-
}
|
|
64
|
-
catch (e) {
|
|
65
|
-
this.logger.error('Error when loading drives.', e);
|
|
66
|
-
return [];
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
get selectedFileStatNodes() {
|
|
70
|
-
return this.selectedNodes.filter(file_tree_1.FileStatNode.is);
|
|
71
|
-
}
|
|
72
|
-
*getNodesByUri(uri) {
|
|
73
|
-
const node = this.getNode(uri.toString());
|
|
74
|
-
if (node) {
|
|
75
|
-
yield node;
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
/**
|
|
79
|
-
* to workaround https://github.com/Axosoft/nsfw/issues/42
|
|
80
|
-
*/
|
|
81
|
-
onDidMove(event) {
|
|
82
|
-
if (!event.isOperation(2 /* MOVE */)) {
|
|
83
|
-
return;
|
|
84
|
-
}
|
|
85
|
-
if (event.resource.parent.toString() === event.target.resource.parent.toString()) {
|
|
86
|
-
// file rename
|
|
87
|
-
return;
|
|
88
|
-
}
|
|
89
|
-
this.refreshAffectedNodes([
|
|
90
|
-
event.resource,
|
|
91
|
-
event.target.resource
|
|
92
|
-
]);
|
|
93
|
-
}
|
|
94
|
-
onFilesChanged(changes) {
|
|
95
|
-
if (!this.refreshAffectedNodes(this.getAffectedUris(changes)) && this.isRootAffected(changes)) {
|
|
96
|
-
this.refresh();
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
isRootAffected(changes) {
|
|
100
|
-
const root = this.root;
|
|
101
|
-
if (file_tree_1.FileStatNode.is(root)) {
|
|
102
|
-
return changes.contains(root.uri, 1 /* ADDED */) || changes.contains(root.uri, 0 /* UPDATED */);
|
|
103
|
-
}
|
|
104
|
-
return false;
|
|
105
|
-
}
|
|
106
|
-
getAffectedUris(changes) {
|
|
107
|
-
return changes.changes.filter(change => !this.isFileContentChanged(change)).map(change => change.resource);
|
|
108
|
-
}
|
|
109
|
-
isFileContentChanged(change) {
|
|
110
|
-
return change.type === 0 /* UPDATED */ && file_tree_1.FileNode.is(this.getNodesByUri(change.resource).next().value);
|
|
111
|
-
}
|
|
112
|
-
refreshAffectedNodes(uris) {
|
|
113
|
-
const nodes = this.getAffectedNodes(uris);
|
|
114
|
-
for (const node of nodes.values()) {
|
|
115
|
-
this.refresh(node);
|
|
116
|
-
}
|
|
117
|
-
return nodes.size !== 0;
|
|
118
|
-
}
|
|
119
|
-
getAffectedNodes(uris) {
|
|
120
|
-
const nodes = new Map();
|
|
121
|
-
for (const uri of uris) {
|
|
122
|
-
for (const node of this.getNodesByUri(uri.parent)) {
|
|
123
|
-
if (file_tree_1.DirNode.is(node) && (node.expanded || (this.compressionToggle.compress && this.compressionService.isCompressionParticipant(node)))) {
|
|
124
|
-
nodes.set(node.id, node);
|
|
125
|
-
}
|
|
126
|
-
}
|
|
127
|
-
}
|
|
128
|
-
return nodes;
|
|
129
|
-
}
|
|
130
|
-
async copy(source, target) {
|
|
131
|
-
/** If the target is a file or if the target is a directory, but is the same as the source, use the parent of the target as a destination. */
|
|
132
|
-
const parentNode = (target.fileStat.isFile || target.uri.isEqual(source)) ? target.parent : target;
|
|
133
|
-
if (!file_tree_1.FileStatNode.is(parentNode)) {
|
|
134
|
-
throw new Error('Parent of file has to be a FileStatNode');
|
|
135
|
-
}
|
|
136
|
-
let targetUri = parentNode.uri.resolve(source.path.base);
|
|
137
|
-
try {
|
|
138
|
-
const parent = await this.fileService.resolve(parentNode.uri);
|
|
139
|
-
const sourceFileStat = await this.fileService.resolve(source);
|
|
140
|
-
targetUri = common_1.FileSystemUtils.generateUniqueResourceURI(parent, targetUri, sourceFileStat.isDirectory, 'copy');
|
|
141
|
-
await this.fileService.copy(source, targetUri);
|
|
142
|
-
}
|
|
143
|
-
catch (e) {
|
|
144
|
-
this.messageService.error(e.message);
|
|
145
|
-
}
|
|
146
|
-
return targetUri;
|
|
147
|
-
}
|
|
148
|
-
/**
|
|
149
|
-
* Move the given source file or directory to the given target directory.
|
|
150
|
-
*/
|
|
151
|
-
async move(source, target) {
|
|
152
|
-
if (file_tree_1.DirNode.is(target) && file_tree_1.FileStatNode.is(source)) {
|
|
153
|
-
const name = source.fileStat.name;
|
|
154
|
-
const targetUri = target.uri.resolve(name);
|
|
155
|
-
if (source.uri.isEqual(targetUri)) {
|
|
156
|
-
return;
|
|
157
|
-
}
|
|
158
|
-
try {
|
|
159
|
-
await this.fileService.move(source.uri, targetUri);
|
|
160
|
-
return targetUri;
|
|
161
|
-
}
|
|
162
|
-
catch (e) {
|
|
163
|
-
if (e instanceof files_1.FileOperationError && e.fileOperationResult === 4 /* FILE_MOVE_CONFLICT */) {
|
|
164
|
-
const fileName = this.labelProvider.getName(source);
|
|
165
|
-
if (await this.shouldReplace(fileName)) {
|
|
166
|
-
try {
|
|
167
|
-
await this.fileService.move(source.uri, targetUri, { overwrite: true });
|
|
168
|
-
return targetUri;
|
|
169
|
-
}
|
|
170
|
-
catch (e2) {
|
|
171
|
-
this.messageService.error(e2.message);
|
|
172
|
-
}
|
|
173
|
-
}
|
|
174
|
-
}
|
|
175
|
-
else {
|
|
176
|
-
this.messageService.error(e.message);
|
|
177
|
-
}
|
|
178
|
-
}
|
|
179
|
-
}
|
|
180
|
-
return undefined;
|
|
181
|
-
}
|
|
182
|
-
async shouldReplace(fileName) {
|
|
183
|
-
const dialog = new browser_1.ConfirmDialog({
|
|
184
|
-
title: core_1.nls.localize('theia/filesystem/replaceTitle', 'Replace File'),
|
|
185
|
-
msg: core_1.nls.localizeByDefault('{0} already exists. Are you sure you want to overwrite it?', fileName),
|
|
186
|
-
ok: browser_1.Dialog.YES,
|
|
187
|
-
cancel: browser_1.Dialog.NO
|
|
188
|
-
});
|
|
189
|
-
return !!await dialog.open();
|
|
190
|
-
}
|
|
191
|
-
};
|
|
192
|
-
(0, tslib_1.__decorate)([
|
|
193
|
-
(0, inversify_1.inject)(label_provider_1.LabelProvider),
|
|
194
|
-
(0, tslib_1.__metadata)("design:type", label_provider_1.LabelProvider)
|
|
195
|
-
], FileTreeModel.prototype, "labelProvider", void 0);
|
|
196
|
-
(0, tslib_1.__decorate)([
|
|
197
|
-
(0, inversify_1.inject)(file_service_1.FileService),
|
|
198
|
-
(0, tslib_1.__metadata)("design:type", file_service_1.FileService)
|
|
199
|
-
], FileTreeModel.prototype, "fileService", void 0);
|
|
200
|
-
(0, tslib_1.__decorate)([
|
|
201
|
-
(0, inversify_1.inject)(message_service_1.MessageService),
|
|
202
|
-
(0, tslib_1.__metadata)("design:type", message_service_1.MessageService)
|
|
203
|
-
], FileTreeModel.prototype, "messageService", void 0);
|
|
204
|
-
(0, tslib_1.__decorate)([
|
|
205
|
-
(0, inversify_1.inject)(env_variables_1.EnvVariablesServer),
|
|
206
|
-
(0, tslib_1.__metadata)("design:type", Object)
|
|
207
|
-
], FileTreeModel.prototype, "environments", void 0);
|
|
208
|
-
(0, tslib_1.__decorate)([
|
|
209
|
-
(0, inversify_1.postConstruct)(),
|
|
210
|
-
(0, tslib_1.__metadata)("design:type", Function),
|
|
211
|
-
(0, tslib_1.__metadata)("design:paramtypes", []),
|
|
212
|
-
(0, tslib_1.__metadata)("design:returntype", void 0)
|
|
213
|
-
], FileTreeModel.prototype, "init", null);
|
|
214
|
-
FileTreeModel = (0, tslib_1.__decorate)([
|
|
215
|
-
(0, inversify_1.injectable)()
|
|
216
|
-
], FileTreeModel);
|
|
217
|
-
exports.FileTreeModel = FileTreeModel;
|
|
1
|
+
"use strict";
|
|
2
|
+
// *****************************************************************************
|
|
3
|
+
// Copyright (C) 2017 TypeFox 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-only WITH Classpath-exception-2.0
|
|
16
|
+
// *****************************************************************************
|
|
17
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
+
exports.FileTreeModel = void 0;
|
|
19
|
+
const tslib_1 = require("tslib");
|
|
20
|
+
const inversify_1 = require("@theia/core/shared/inversify");
|
|
21
|
+
const uri_1 = require("@theia/core/lib/common/uri");
|
|
22
|
+
const browser_1 = require("@theia/core/lib/browser");
|
|
23
|
+
const file_tree_1 = require("./file-tree");
|
|
24
|
+
const label_provider_1 = require("@theia/core/lib/browser/label-provider");
|
|
25
|
+
const file_service_1 = require("../file-service");
|
|
26
|
+
const files_1 = require("../../common/files");
|
|
27
|
+
const message_service_1 = require("@theia/core/lib/common/message-service");
|
|
28
|
+
const env_variables_1 = require("@theia/core/lib/common/env-variables");
|
|
29
|
+
const common_1 = require("../../common");
|
|
30
|
+
const core_1 = require("@theia/core");
|
|
31
|
+
let FileTreeModel = class FileTreeModel extends browser_1.CompressedTreeModel {
|
|
32
|
+
init() {
|
|
33
|
+
super.init();
|
|
34
|
+
this.toDispose.push(this.fileService.onDidFilesChange(changes => this.onFilesChanged(changes)));
|
|
35
|
+
this.toDispose.push(this.fileService.onDidRunOperation(event => this.onDidMove(event)));
|
|
36
|
+
}
|
|
37
|
+
get location() {
|
|
38
|
+
const root = this.root;
|
|
39
|
+
if (file_tree_1.FileStatNode.is(root)) {
|
|
40
|
+
return root.uri;
|
|
41
|
+
}
|
|
42
|
+
return undefined;
|
|
43
|
+
}
|
|
44
|
+
set location(uri) {
|
|
45
|
+
if (uri) {
|
|
46
|
+
this.fileService.resolve(uri).then(fileStat => {
|
|
47
|
+
if (fileStat) {
|
|
48
|
+
const node = file_tree_1.DirNode.createRoot(fileStat);
|
|
49
|
+
this.navigateTo(node);
|
|
50
|
+
}
|
|
51
|
+
}).catch(() => {
|
|
52
|
+
// no-op, allow failures for file dialog text input
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
else {
|
|
56
|
+
this.navigateTo(undefined);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
async drives() {
|
|
60
|
+
try {
|
|
61
|
+
const drives = await this.environments.getDrives();
|
|
62
|
+
return drives.map(uri => new uri_1.default(uri));
|
|
63
|
+
}
|
|
64
|
+
catch (e) {
|
|
65
|
+
this.logger.error('Error when loading drives.', e);
|
|
66
|
+
return [];
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
get selectedFileStatNodes() {
|
|
70
|
+
return this.selectedNodes.filter(file_tree_1.FileStatNode.is);
|
|
71
|
+
}
|
|
72
|
+
*getNodesByUri(uri) {
|
|
73
|
+
const node = this.getNode(uri.toString());
|
|
74
|
+
if (node) {
|
|
75
|
+
yield node;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
/**
|
|
79
|
+
* to workaround https://github.com/Axosoft/nsfw/issues/42
|
|
80
|
+
*/
|
|
81
|
+
onDidMove(event) {
|
|
82
|
+
if (!event.isOperation(2 /* MOVE */)) {
|
|
83
|
+
return;
|
|
84
|
+
}
|
|
85
|
+
if (event.resource.parent.toString() === event.target.resource.parent.toString()) {
|
|
86
|
+
// file rename
|
|
87
|
+
return;
|
|
88
|
+
}
|
|
89
|
+
this.refreshAffectedNodes([
|
|
90
|
+
event.resource,
|
|
91
|
+
event.target.resource
|
|
92
|
+
]);
|
|
93
|
+
}
|
|
94
|
+
onFilesChanged(changes) {
|
|
95
|
+
if (!this.refreshAffectedNodes(this.getAffectedUris(changes)) && this.isRootAffected(changes)) {
|
|
96
|
+
this.refresh();
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
isRootAffected(changes) {
|
|
100
|
+
const root = this.root;
|
|
101
|
+
if (file_tree_1.FileStatNode.is(root)) {
|
|
102
|
+
return changes.contains(root.uri, 1 /* ADDED */) || changes.contains(root.uri, 0 /* UPDATED */);
|
|
103
|
+
}
|
|
104
|
+
return false;
|
|
105
|
+
}
|
|
106
|
+
getAffectedUris(changes) {
|
|
107
|
+
return changes.changes.filter(change => !this.isFileContentChanged(change)).map(change => change.resource);
|
|
108
|
+
}
|
|
109
|
+
isFileContentChanged(change) {
|
|
110
|
+
return change.type === 0 /* UPDATED */ && file_tree_1.FileNode.is(this.getNodesByUri(change.resource).next().value);
|
|
111
|
+
}
|
|
112
|
+
refreshAffectedNodes(uris) {
|
|
113
|
+
const nodes = this.getAffectedNodes(uris);
|
|
114
|
+
for (const node of nodes.values()) {
|
|
115
|
+
this.refresh(node);
|
|
116
|
+
}
|
|
117
|
+
return nodes.size !== 0;
|
|
118
|
+
}
|
|
119
|
+
getAffectedNodes(uris) {
|
|
120
|
+
const nodes = new Map();
|
|
121
|
+
for (const uri of uris) {
|
|
122
|
+
for (const node of this.getNodesByUri(uri.parent)) {
|
|
123
|
+
if (file_tree_1.DirNode.is(node) && (node.expanded || (this.compressionToggle.compress && this.compressionService.isCompressionParticipant(node)))) {
|
|
124
|
+
nodes.set(node.id, node);
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
return nodes;
|
|
129
|
+
}
|
|
130
|
+
async copy(source, target) {
|
|
131
|
+
/** If the target is a file or if the target is a directory, but is the same as the source, use the parent of the target as a destination. */
|
|
132
|
+
const parentNode = (target.fileStat.isFile || target.uri.isEqual(source)) ? target.parent : target;
|
|
133
|
+
if (!file_tree_1.FileStatNode.is(parentNode)) {
|
|
134
|
+
throw new Error('Parent of file has to be a FileStatNode');
|
|
135
|
+
}
|
|
136
|
+
let targetUri = parentNode.uri.resolve(source.path.base);
|
|
137
|
+
try {
|
|
138
|
+
const parent = await this.fileService.resolve(parentNode.uri);
|
|
139
|
+
const sourceFileStat = await this.fileService.resolve(source);
|
|
140
|
+
targetUri = common_1.FileSystemUtils.generateUniqueResourceURI(parent, targetUri, sourceFileStat.isDirectory, 'copy');
|
|
141
|
+
await this.fileService.copy(source, targetUri);
|
|
142
|
+
}
|
|
143
|
+
catch (e) {
|
|
144
|
+
this.messageService.error(e.message);
|
|
145
|
+
}
|
|
146
|
+
return targetUri;
|
|
147
|
+
}
|
|
148
|
+
/**
|
|
149
|
+
* Move the given source file or directory to the given target directory.
|
|
150
|
+
*/
|
|
151
|
+
async move(source, target) {
|
|
152
|
+
if (file_tree_1.DirNode.is(target) && file_tree_1.FileStatNode.is(source)) {
|
|
153
|
+
const name = source.fileStat.name;
|
|
154
|
+
const targetUri = target.uri.resolve(name);
|
|
155
|
+
if (source.uri.isEqual(targetUri)) {
|
|
156
|
+
return;
|
|
157
|
+
}
|
|
158
|
+
try {
|
|
159
|
+
await this.fileService.move(source.uri, targetUri);
|
|
160
|
+
return targetUri;
|
|
161
|
+
}
|
|
162
|
+
catch (e) {
|
|
163
|
+
if (e instanceof files_1.FileOperationError && e.fileOperationResult === 4 /* FILE_MOVE_CONFLICT */) {
|
|
164
|
+
const fileName = this.labelProvider.getName(source);
|
|
165
|
+
if (await this.shouldReplace(fileName)) {
|
|
166
|
+
try {
|
|
167
|
+
await this.fileService.move(source.uri, targetUri, { overwrite: true });
|
|
168
|
+
return targetUri;
|
|
169
|
+
}
|
|
170
|
+
catch (e2) {
|
|
171
|
+
this.messageService.error(e2.message);
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
else {
|
|
176
|
+
this.messageService.error(e.message);
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
return undefined;
|
|
181
|
+
}
|
|
182
|
+
async shouldReplace(fileName) {
|
|
183
|
+
const dialog = new browser_1.ConfirmDialog({
|
|
184
|
+
title: core_1.nls.localize('theia/filesystem/replaceTitle', 'Replace File'),
|
|
185
|
+
msg: core_1.nls.localizeByDefault('{0} already exists. Are you sure you want to overwrite it?', fileName),
|
|
186
|
+
ok: browser_1.Dialog.YES,
|
|
187
|
+
cancel: browser_1.Dialog.NO
|
|
188
|
+
});
|
|
189
|
+
return !!await dialog.open();
|
|
190
|
+
}
|
|
191
|
+
};
|
|
192
|
+
(0, tslib_1.__decorate)([
|
|
193
|
+
(0, inversify_1.inject)(label_provider_1.LabelProvider),
|
|
194
|
+
(0, tslib_1.__metadata)("design:type", label_provider_1.LabelProvider)
|
|
195
|
+
], FileTreeModel.prototype, "labelProvider", void 0);
|
|
196
|
+
(0, tslib_1.__decorate)([
|
|
197
|
+
(0, inversify_1.inject)(file_service_1.FileService),
|
|
198
|
+
(0, tslib_1.__metadata)("design:type", file_service_1.FileService)
|
|
199
|
+
], FileTreeModel.prototype, "fileService", void 0);
|
|
200
|
+
(0, tslib_1.__decorate)([
|
|
201
|
+
(0, inversify_1.inject)(message_service_1.MessageService),
|
|
202
|
+
(0, tslib_1.__metadata)("design:type", message_service_1.MessageService)
|
|
203
|
+
], FileTreeModel.prototype, "messageService", void 0);
|
|
204
|
+
(0, tslib_1.__decorate)([
|
|
205
|
+
(0, inversify_1.inject)(env_variables_1.EnvVariablesServer),
|
|
206
|
+
(0, tslib_1.__metadata)("design:type", Object)
|
|
207
|
+
], FileTreeModel.prototype, "environments", void 0);
|
|
208
|
+
(0, tslib_1.__decorate)([
|
|
209
|
+
(0, inversify_1.postConstruct)(),
|
|
210
|
+
(0, tslib_1.__metadata)("design:type", Function),
|
|
211
|
+
(0, tslib_1.__metadata)("design:paramtypes", []),
|
|
212
|
+
(0, tslib_1.__metadata)("design:returntype", void 0)
|
|
213
|
+
], FileTreeModel.prototype, "init", null);
|
|
214
|
+
FileTreeModel = (0, tslib_1.__decorate)([
|
|
215
|
+
(0, inversify_1.injectable)()
|
|
216
|
+
], FileTreeModel);
|
|
217
|
+
exports.FileTreeModel = FileTreeModel;
|
|
218
218
|
//# sourceMappingURL=file-tree-model.js.map
|
|
@@ -1,45 +1,45 @@
|
|
|
1
|
-
/// <reference types="react" />
|
|
2
|
-
import * as React from '@theia/core/shared/react';
|
|
3
|
-
import { DisposableCollection } from '@theia/core/lib/common/disposable';
|
|
4
|
-
import { ContextMenuRenderer, NodeProps, TreeProps, TreeNode, CompressedTreeWidget, CompressedNodeProps } from '@theia/core/lib/browser';
|
|
5
|
-
import { FileUploadService } from '../file-upload-service';
|
|
6
|
-
import { DirNode } from './file-tree';
|
|
7
|
-
import { FileTreeModel } from './file-tree-model';
|
|
8
|
-
import { IconThemeService } from '@theia/core/lib/browser/icon-theme-service';
|
|
9
|
-
export declare const FILE_TREE_CLASS = "theia-FileTree";
|
|
10
|
-
export declare const FILE_STAT_NODE_CLASS = "theia-FileStatNode";
|
|
11
|
-
export declare const DIR_NODE_CLASS = "theia-DirNode";
|
|
12
|
-
export declare const FILE_STAT_ICON_CLASS = "theia-FileStatIcon";
|
|
13
|
-
export declare class FileTreeWidget extends CompressedTreeWidget {
|
|
14
|
-
readonly model: FileTreeModel;
|
|
15
|
-
protected readonly toCancelNodeExpansion: DisposableCollection;
|
|
16
|
-
protected readonly uploadService: FileUploadService;
|
|
17
|
-
protected readonly iconThemeService: IconThemeService;
|
|
18
|
-
constructor(props: TreeProps, model: FileTreeModel, contextMenuRenderer: ContextMenuRenderer);
|
|
19
|
-
protected createNodeClassNames(node: TreeNode, props: NodeProps): string[];
|
|
20
|
-
protected renderIcon(node: TreeNode, props: NodeProps): React.ReactNode;
|
|
21
|
-
protected createContainerAttributes(): React.HTMLAttributes<HTMLElement>;
|
|
22
|
-
protected createNodeAttributes(node: TreeNode, props: NodeProps): React.Attributes & React.HTMLAttributes<HTMLElement>;
|
|
23
|
-
protected getNodeTooltip(node: TreeNode): string | undefined;
|
|
24
|
-
protected getCaptionChildEventHandlers(node: TreeNode, props: CompressedNodeProps): React.Attributes & React.HtmlHTMLAttributes<HTMLElement>;
|
|
25
|
-
protected getNodeDragHandlers(node: TreeNode, props: CompressedNodeProps): React.Attributes & React.HtmlHTMLAttributes<HTMLElement>;
|
|
26
|
-
protected handleDragStartEvent(node: TreeNode, event: React.DragEvent): void;
|
|
27
|
-
protected handleDragEnterEvent(node: TreeNode | undefined, event: React.DragEvent): void;
|
|
28
|
-
protected handleDragOverEvent(node: TreeNode | undefined, event: React.DragEvent): void;
|
|
29
|
-
protected handleDragLeaveEvent(node: TreeNode | undefined, event: React.DragEvent): void;
|
|
30
|
-
protected handleDropEvent(node: TreeNode | undefined, event: React.DragEvent): Promise<void>;
|
|
31
|
-
protected getDropTargetDirNode(node: TreeNode | undefined): DirNode | undefined;
|
|
32
|
-
protected getDropEffect(event: React.DragEvent): 'copy' | 'move';
|
|
33
|
-
protected setTreeNodeAsData(data: DataTransfer, node: TreeNode): void;
|
|
34
|
-
protected setSelectedTreeNodesAsData(data: DataTransfer, sourceNode: TreeNode, relatedNodes: TreeNode[]): void;
|
|
35
|
-
protected getTreeNodeFromData(data: DataTransfer): TreeNode | undefined;
|
|
36
|
-
protected getSelectedTreeNodesFromData(data: DataTransfer): TreeNode[];
|
|
37
|
-
protected get hidesExplorerArrows(): boolean;
|
|
38
|
-
protected renderExpansionToggle(node: TreeNode, props: NodeProps): React.ReactNode;
|
|
39
|
-
protected getPaddingLeft(node: TreeNode, props: NodeProps): number;
|
|
40
|
-
protected needsExpansionTogglePadding(node: TreeNode): boolean;
|
|
41
|
-
protected deflateForStorage(node: TreeNode): object;
|
|
42
|
-
protected inflateFromStorage(node: any, parent?: TreeNode): TreeNode;
|
|
43
|
-
protected getDepthPadding(depth: number): number;
|
|
44
|
-
}
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import * as React from '@theia/core/shared/react';
|
|
3
|
+
import { DisposableCollection } from '@theia/core/lib/common/disposable';
|
|
4
|
+
import { ContextMenuRenderer, NodeProps, TreeProps, TreeNode, CompressedTreeWidget, CompressedNodeProps } from '@theia/core/lib/browser';
|
|
5
|
+
import { FileUploadService } from '../file-upload-service';
|
|
6
|
+
import { DirNode } from './file-tree';
|
|
7
|
+
import { FileTreeModel } from './file-tree-model';
|
|
8
|
+
import { IconThemeService } from '@theia/core/lib/browser/icon-theme-service';
|
|
9
|
+
export declare const FILE_TREE_CLASS = "theia-FileTree";
|
|
10
|
+
export declare const FILE_STAT_NODE_CLASS = "theia-FileStatNode";
|
|
11
|
+
export declare const DIR_NODE_CLASS = "theia-DirNode";
|
|
12
|
+
export declare const FILE_STAT_ICON_CLASS = "theia-FileStatIcon";
|
|
13
|
+
export declare class FileTreeWidget extends CompressedTreeWidget {
|
|
14
|
+
readonly model: FileTreeModel;
|
|
15
|
+
protected readonly toCancelNodeExpansion: DisposableCollection;
|
|
16
|
+
protected readonly uploadService: FileUploadService;
|
|
17
|
+
protected readonly iconThemeService: IconThemeService;
|
|
18
|
+
constructor(props: TreeProps, model: FileTreeModel, contextMenuRenderer: ContextMenuRenderer);
|
|
19
|
+
protected createNodeClassNames(node: TreeNode, props: NodeProps): string[];
|
|
20
|
+
protected renderIcon(node: TreeNode, props: NodeProps): React.ReactNode;
|
|
21
|
+
protected createContainerAttributes(): React.HTMLAttributes<HTMLElement>;
|
|
22
|
+
protected createNodeAttributes(node: TreeNode, props: NodeProps): React.Attributes & React.HTMLAttributes<HTMLElement>;
|
|
23
|
+
protected getNodeTooltip(node: TreeNode): string | undefined;
|
|
24
|
+
protected getCaptionChildEventHandlers(node: TreeNode, props: CompressedNodeProps): React.Attributes & React.HtmlHTMLAttributes<HTMLElement>;
|
|
25
|
+
protected getNodeDragHandlers(node: TreeNode, props: CompressedNodeProps): React.Attributes & React.HtmlHTMLAttributes<HTMLElement>;
|
|
26
|
+
protected handleDragStartEvent(node: TreeNode, event: React.DragEvent): void;
|
|
27
|
+
protected handleDragEnterEvent(node: TreeNode | undefined, event: React.DragEvent): void;
|
|
28
|
+
protected handleDragOverEvent(node: TreeNode | undefined, event: React.DragEvent): void;
|
|
29
|
+
protected handleDragLeaveEvent(node: TreeNode | undefined, event: React.DragEvent): void;
|
|
30
|
+
protected handleDropEvent(node: TreeNode | undefined, event: React.DragEvent): Promise<void>;
|
|
31
|
+
protected getDropTargetDirNode(node: TreeNode | undefined): DirNode | undefined;
|
|
32
|
+
protected getDropEffect(event: React.DragEvent): 'copy' | 'move';
|
|
33
|
+
protected setTreeNodeAsData(data: DataTransfer, node: TreeNode): void;
|
|
34
|
+
protected setSelectedTreeNodesAsData(data: DataTransfer, sourceNode: TreeNode, relatedNodes: TreeNode[]): void;
|
|
35
|
+
protected getTreeNodeFromData(data: DataTransfer): TreeNode | undefined;
|
|
36
|
+
protected getSelectedTreeNodesFromData(data: DataTransfer): TreeNode[];
|
|
37
|
+
protected get hidesExplorerArrows(): boolean;
|
|
38
|
+
protected renderExpansionToggle(node: TreeNode, props: NodeProps): React.ReactNode;
|
|
39
|
+
protected getPaddingLeft(node: TreeNode, props: NodeProps): number;
|
|
40
|
+
protected needsExpansionTogglePadding(node: TreeNode): boolean;
|
|
41
|
+
protected deflateForStorage(node: TreeNode): object;
|
|
42
|
+
protected inflateFromStorage(node: any, parent?: TreeNode): TreeNode;
|
|
43
|
+
protected getDepthPadding(depth: number): number;
|
|
44
|
+
}
|
|
45
45
|
//# sourceMappingURL=file-tree-widget.d.ts.map
|