-
Notifications
You must be signed in to change notification settings - Fork 2.5k
/
Copy pathnavigator-container.ts
48 lines (43 loc) · 2.03 KB
/
navigator-container.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
// *****************************************************************************
// 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-only WITH Classpath-exception-2.0
// *****************************************************************************
import { Container, interfaces } from '@theia/core/shared/inversify';
import { TreeProps, defaultTreeProps } from '@theia/core/lib/browser';
import { createFileTreeContainer } from '@theia/filesystem/lib/browser';
import { FileNavigatorTree } from './navigator-tree';
import { FileNavigatorModel } from './navigator-model';
import { FileNavigatorWidget } from './navigator-widget';
import { NAVIGATOR_CONTEXT_MENU } from './navigator-contribution';
import { NavigatorDecoratorService } from './navigator-decorator-service';
export const FILE_NAVIGATOR_PROPS = <TreeProps>{
...defaultTreeProps,
contextMenuPath: NAVIGATOR_CONTEXT_MENU,
multiSelect: true,
search: true,
globalSelection: true
};
export function createFileNavigatorContainer(parent: interfaces.Container): Container {
const child = createFileTreeContainer(parent, {
tree: FileNavigatorTree,
model: FileNavigatorModel,
widget: FileNavigatorWidget,
decoratorService: NavigatorDecoratorService,
props: FILE_NAVIGATOR_PROPS,
});
return child;
}
export function createFileNavigatorWidget(parent: interfaces.Container): FileNavigatorWidget {
return createFileNavigatorContainer(parent).get(FileNavigatorWidget);
}