1 |
|
2 |
|
3 |
|
4 |
|
5 |
|
6 |
|
7 |
|
8 |
|
9 |
|
10 |
|
11 |
|
12 |
|
13 |
|
14 |
|
15 |
|
16 |
|
17 | import { inject, injectable } from 'inversify';
|
18 | import { Emitter, Event } from '../../common';
|
19 | import { Tree, TreeNode } from './tree';
|
20 | import { SelectableTreeNode } from './tree-selection';
|
21 |
|
22 | export interface TreeFocusService {
|
23 | readonly focusedNode: SelectableTreeNode | undefined;
|
24 | readonly onDidChangeFocus: Event<SelectableTreeNode | undefined>;
|
25 | setFocus(node?: SelectableTreeNode): void;
|
26 | hasFocus(node?: TreeNode): boolean;
|
27 | }
|
28 | export const TreeFocusService = Symbol('TreeFocusService');
|
29 |
|
30 | @injectable()
|
31 | export class TreeFocusServiceImpl implements TreeFocusService {
|
32 | protected focusedId: string | undefined;
|
33 | protected onDidChangeFocusEmitter = new Emitter<SelectableTreeNode | undefined>();
|
34 | get onDidChangeFocus(): Event<SelectableTreeNode | undefined> { return this.onDidChangeFocusEmitter.event; }
|
35 |
|
36 | @inject(Tree) protected readonly tree: Tree;
|
37 |
|
38 | get focusedNode(): SelectableTreeNode | undefined {
|
39 | const candidate = this.tree.getNode(this.focusedId);
|
40 | if (SelectableTreeNode.is(candidate)) {
|
41 | return candidate;
|
42 | }
|
43 | }
|
44 |
|
45 | setFocus(node?: SelectableTreeNode): void {
|
46 | if (node?.id !== this.focusedId) {
|
47 | this.focusedId = node?.id;
|
48 | this.onDidChangeFocusEmitter.fire(node);
|
49 | }
|
50 | }
|
51 |
|
52 | hasFocus(node?: TreeNode): boolean {
|
53 | return !!node && node?.id === this.focusedId;
|
54 | }
|
55 | }
|