-
Notifications
You must be signed in to change notification settings - Fork 2.5k
/
workspace-uri-contribution.ts
81 lines (71 loc) · 3.22 KB
/
workspace-uri-contribution.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
/********************************************************************************
* Copyright (C) 2017 TypeFox and others.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v. 2.0 which is available at
* http://www.eclipse.org/legal/epl-2.0.
*
* This Source Code may also be made available under the following Secondary
* Licenses when the conditions for such availability set forth in the Eclipse
* Public License v. 2.0 are satisfied: GNU General Public License, version 2
* with the GNU Classpath Exception which is available at
* https://www.gnu.org/software/classpath/license.html.
*
* SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
********************************************************************************/
import { DefaultUriLabelProviderContribution, URIIconReference } from '@theia/core/lib/browser/label-provider';
import URI from '@theia/core/lib/common/uri';
import { injectable, inject, postConstruct } from '@theia/core/shared/inversify';
import { FileStat } from '@theia/filesystem/lib/common/files';
import { WorkspaceVariableContribution } from './workspace-variable-contribution';
@injectable()
export class WorkspaceUriLabelProviderContribution extends DefaultUriLabelProviderContribution {
@inject(WorkspaceVariableContribution)
protected readonly workspaceVariable: WorkspaceVariableContribution;
@postConstruct()
async init(): Promise<void> {
// no-op, backward compatibility
}
canHandle(element: object): number {
if ((element instanceof URI && element.scheme === 'file' || URIIconReference.is(element) || FileStat.is(element))) {
return 10;
}
return 0;
}
getIcon(element: URI | URIIconReference | FileStat): string {
const uri = this.getUri(element);
if (uri && this.workspaceVariable.getWorkspaceRootUri(uri)?.isEqual(uri)) {
return 'rootfolder-icon';
}
return super.getIcon(this.asURIIconReference(element));
}
getName(element: URI | URIIconReference | FileStat): string | undefined {
return super.getName(this.asURIIconReference(element));
}
/**
* trims the workspace root from a file uri, if it is a child.
*/
getLongName(element: URI | URIIconReference | FileStat): string | undefined {
const uri = this.getUri(element);
if (uri) {
const formatting = this.findFormatting(uri);
if (formatting) {
return this.formatUri(uri, formatting);
}
}
const relativePath = uri && this.workspaceVariable.getWorkspaceRelativePath(uri);
return relativePath || super.getLongName(this.asURIIconReference(element));
}
protected asURIIconReference(element: URI | URIIconReference | FileStat): URI | URIIconReference {
if (FileStat.is(element)) {
return URIIconReference.create(element.isDirectory ? 'folder' : 'file', element.resource);
}
return element;
}
protected getUri(element: URI | URIIconReference | FileStat): URI | undefined {
if (FileStat.is(element)) {
return element.resource;
}
return super.getUri(element);
}
}