@worktile/theia 17.4.7 → 17.4.8
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/components/listbox/listbox.d.ts +26 -31
- package/components/plugin-menu/plugin-menu.component.d.ts +18 -17
- package/constants/default.d.ts +1 -0
- package/esm2022/components/listbox/listbox.mjs +44 -42
- package/esm2022/components/plugin-menu/plugin-menu.component.mjs +61 -42
- package/esm2022/constants/default.mjs +2 -1
- package/esm2022/plugins/quick-insert/quick-insert.plugin.mjs +3 -3
- package/fesm2022/worktile-theia.mjs +107 -84
- package/fesm2022/worktile-theia.mjs.map +1 -1
- package/interfaces/editor.d.ts +2 -2
- package/package.json +1 -1
- package/plugins/table/components/table.component.d.ts +1 -1
- package/queries/is-range-across-blocks.d.ts +1 -1
|
@@ -1,39 +1,40 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
1
|
+
import { AfterContentInit, ElementRef, EventEmitter, QueryList } from '@angular/core';
|
|
2
|
+
import { ThePluginMenuItem, ThePluginMenuItemKey } from '../../interfaces';
|
|
3
3
|
import { TheListboxChangeEventType } from './listbox.type';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
|
-
export declare class TheListboxOptionDirective
|
|
5
|
+
export declare class TheListboxOptionDirective {
|
|
6
6
|
parentOption: TheListboxOptionDirective;
|
|
7
7
|
parentGroup: TheListboxGroupDirective;
|
|
8
8
|
elementRef: ElementRef<HTMLElement>;
|
|
9
|
-
|
|
9
|
+
theOptionValue: ThePluginMenuItem;
|
|
10
|
+
theOptionDisabled: boolean;
|
|
10
11
|
className: string;
|
|
11
12
|
_options: QueryList<TheListboxOptionDirective>;
|
|
13
|
+
private _active;
|
|
12
14
|
get hasChild(): boolean;
|
|
13
15
|
get firstChild(): TheListboxOptionDirective;
|
|
14
|
-
theOptionValue: unknown;
|
|
15
|
-
theOptionDisabled: boolean;
|
|
16
16
|
constructor(parentOption: TheListboxOptionDirective, parentGroup: TheListboxGroupDirective, elementRef: ElementRef<HTMLElement>);
|
|
17
|
-
ngOnInit(): void;
|
|
18
|
-
ngAfterContentInit(): void;
|
|
19
17
|
getGroups(): TheListboxGroupDirective[];
|
|
20
18
|
setActive(active: boolean): void;
|
|
21
19
|
getActive(): boolean;
|
|
22
20
|
static ɵfac: i0.ɵɵFactoryDeclaration<TheListboxOptionDirective, [{ optional: true; skipSelf: true; }, null, null]>;
|
|
23
21
|
static ɵdir: i0.ɵɵDirectiveDeclaration<TheListboxOptionDirective, "[theListboxOption]", ["theListboxOption"], { "theOptionValue": { "alias": "theOptionValue"; "required": false; }; "theOptionDisabled": { "alias": "theOptionDisabled"; "required": false; }; }, {}, ["_options"], never, true, never>;
|
|
24
22
|
}
|
|
25
|
-
export
|
|
23
|
+
export interface TheListboxChangeEvent {
|
|
24
|
+
option: TheListboxOptionDirective;
|
|
25
|
+
type: TheListboxChangeEventType;
|
|
26
|
+
}
|
|
27
|
+
export declare class TheListboxGroupDirective implements AfterContentInit {
|
|
26
28
|
parentOption: TheListboxOptionDirective;
|
|
27
29
|
theListBox: TheListboxDirective;
|
|
28
|
-
className: string;
|
|
29
|
-
options: TheListboxOptionDirective[];
|
|
30
|
-
_options: QueryList<TheListboxOptionDirective>;
|
|
31
30
|
/**
|
|
32
31
|
* 大于 1 表示水平分组,小于等于 1 表示垂直分组
|
|
33
32
|
*/
|
|
34
33
|
horizontalColumn: number;
|
|
34
|
+
className: string;
|
|
35
|
+
_options: QueryList<TheListboxOptionDirective>;
|
|
36
|
+
options: TheListboxOptionDirective[];
|
|
35
37
|
constructor(parentOption: TheListboxOptionDirective, theListBox: TheListboxDirective);
|
|
36
|
-
ngOnInit(): void;
|
|
37
38
|
ngAfterContentInit(): void;
|
|
38
39
|
filterOptions(): void;
|
|
39
40
|
getSiblingGroups(): TheListboxGroupDirective[];
|
|
@@ -43,21 +44,18 @@ export declare class TheListboxGroupDirective implements OnInit, AfterContentIni
|
|
|
43
44
|
static ɵfac: i0.ɵɵFactoryDeclaration<TheListboxGroupDirective, [{ optional: true; skipSelf: true; }, null]>;
|
|
44
45
|
static ɵdir: i0.ɵɵDirectiveDeclaration<TheListboxGroupDirective, "[theListboxGroup]", ["theListboxGroup"], { "horizontalColumn": { "alias": "horizontalColumn"; "required": false; }; }, {}, ["_options"], never, true, never>;
|
|
45
46
|
}
|
|
46
|
-
export declare class TheListboxDirective implements
|
|
47
|
-
private ngZone;
|
|
48
|
-
private elementRef;
|
|
49
|
-
className: string;
|
|
50
|
-
private _optionChangesSubscription;
|
|
51
|
-
private _keyboardSubscription;
|
|
52
|
-
activeOption: TheListboxOptionDirective;
|
|
53
|
-
groups: TheListboxGroupDirective[];
|
|
54
|
-
protected _groups: QueryList<TheListboxGroupDirective>;
|
|
55
|
-
protected _options: QueryList<TheListboxOptionDirective>;
|
|
47
|
+
export declare class TheListboxDirective implements AfterContentInit {
|
|
56
48
|
keyboardContainer: HTMLElement;
|
|
57
49
|
autoActiveFirstItem: boolean;
|
|
58
50
|
theListboxChange: EventEmitter<TheListboxChangeEvent>;
|
|
59
|
-
|
|
60
|
-
|
|
51
|
+
className: string;
|
|
52
|
+
protected _options: QueryList<TheListboxOptionDirective>;
|
|
53
|
+
protected _groups: QueryList<TheListboxGroupDirective>;
|
|
54
|
+
activeOption: TheListboxOptionDirective;
|
|
55
|
+
groups: TheListboxGroupDirective[];
|
|
56
|
+
private ngZone;
|
|
57
|
+
private elementRef;
|
|
58
|
+
private destroyRef;
|
|
61
59
|
ngAfterContentInit(): void;
|
|
62
60
|
filterGroups(): void;
|
|
63
61
|
handleKeydown(event: KeyboardEvent): void;
|
|
@@ -80,11 +78,8 @@ export declare class TheListboxDirective implements OnInit, AfterContentInit, On
|
|
|
80
78
|
enterNextGroup(): void;
|
|
81
79
|
enterPreviousGroup(): void;
|
|
82
80
|
setActiveItem(previous: TheListboxOptionDirective | null, option: TheListboxOptionDirective, type: TheListboxChangeEventType): void;
|
|
83
|
-
|
|
81
|
+
getOption(key: ThePluginMenuItemKey): TheListboxOptionDirective;
|
|
82
|
+
clearActiveItem(): void;
|
|
84
83
|
static ɵfac: i0.ɵɵFactoryDeclaration<TheListboxDirective, never>;
|
|
85
|
-
static ɵdir: i0.ɵɵDirectiveDeclaration<TheListboxDirective, "[theListBox]", ["theListBox"], { "keyboardContainer": { "alias": "keyboardContainer"; "required": false; }; "autoActiveFirstItem": { "alias": "autoActiveFirstItem"; "required": false; }; }, { "theListboxChange": "theListboxChange"; }, ["
|
|
86
|
-
}
|
|
87
|
-
export interface TheListboxChangeEvent {
|
|
88
|
-
option: TheListboxOptionDirective;
|
|
89
|
-
type: TheListboxChangeEventType;
|
|
84
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<TheListboxDirective, "[theListBox]", ["theListBox"], { "keyboardContainer": { "alias": "keyboardContainer"; "required": false; }; "autoActiveFirstItem": { "alias": "autoActiveFirstItem"; "required": false; }; }, { "theListboxChange": "theListboxChange"; }, ["_options", "_groups"], never, true, never>;
|
|
90
85
|
}
|
|
@@ -1,16 +1,20 @@
|
|
|
1
|
-
import { ChangeDetectorRef, ElementRef,
|
|
1
|
+
import { ChangeDetectorRef, ElementRef, OnInit } from '@angular/core';
|
|
2
2
|
import { ThyDropdownDirective } from 'ngx-tethys/dropdown';
|
|
3
|
-
import { ThyPopoverRef } from 'ngx-tethys/popover';
|
|
4
3
|
import { Editor, PathRef } from 'slate';
|
|
5
4
|
import { ThePluginMenuItemType } from '../../constants';
|
|
6
5
|
import { ThePluginMenu, ThePluginMenuGroup, ThePluginMenuItem, ThePluginMenuItemConfig } from '../../interfaces';
|
|
7
|
-
import { TheListboxChangeEvent, TheListboxOptionDirective } from '../listbox/listbox';
|
|
6
|
+
import { TheListboxChangeEvent, TheListboxDirective, TheListboxOptionDirective } from '../listbox/listbox';
|
|
8
7
|
import * as i0 from "@angular/core";
|
|
9
8
|
export declare class ThePluginMenuComponent implements OnInit {
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
9
|
+
editor: Editor;
|
|
10
|
+
theDisplaySearch: boolean;
|
|
11
|
+
thePluginMenu: ThePluginMenuItemConfig[];
|
|
12
|
+
sceneKey?: string;
|
|
13
|
+
subPanelClass: string | string[];
|
|
14
|
+
autoActiveFirstItem: boolean;
|
|
15
|
+
containerClassName: string;
|
|
16
|
+
dropdownTriggers: ThyDropdownDirective[];
|
|
17
|
+
listBox: import("@angular/core").Signal<TheListboxDirective>;
|
|
14
18
|
listBoxAutoActiveFirstItem: boolean;
|
|
15
19
|
pathRef: PathRef;
|
|
16
20
|
keyboardContainer: HTMLElement;
|
|
@@ -33,24 +37,21 @@ export declare class ThePluginMenuComponent implements OnInit {
|
|
|
33
37
|
originActiveClass: string;
|
|
34
38
|
};
|
|
35
39
|
originKeywords: string;
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
thePluginMenu: ThePluginMenuItemConfig[];
|
|
41
|
-
sceneKey?: string;
|
|
42
|
-
subPanelClass: string | string[];
|
|
43
|
-
autoActiveFirstItem: boolean;
|
|
44
|
-
constructor(elementRef: ElementRef<HTMLElement>, cdr: ChangeDetectorRef, ngZone: NgZone, thyPopoverRef: ThyPopoverRef<ThePluginMenuComponent>);
|
|
40
|
+
elementRef: ElementRef<any>;
|
|
41
|
+
private ngZone;
|
|
42
|
+
cdr: ChangeDetectorRef;
|
|
43
|
+
private thyPopoverRef;
|
|
45
44
|
ngOnInit(): void;
|
|
46
45
|
initializeSearch(): void;
|
|
47
46
|
initializePluginMenu(): void;
|
|
48
47
|
buildMenus(): void;
|
|
48
|
+
listBoxOptionMouseenter(e: MouseEvent, menu: ThePluginMenuItem): void;
|
|
49
|
+
listBoxOptionMouseleave(e: MouseEvent, menu: ThePluginMenuItem): void;
|
|
49
50
|
handleItemSelection(menuItem: ThePluginMenuItem): void;
|
|
50
51
|
removeBlock: () => void;
|
|
51
52
|
removeCharacter: () => void;
|
|
52
53
|
updateKeywords(keywords: string): void;
|
|
53
|
-
|
|
54
|
+
listBoxChange(event: TheListboxChangeEvent): void;
|
|
54
55
|
findDropdownTrigger(option: TheListboxOptionDirective): ThyDropdownDirective;
|
|
55
56
|
trackByFn(index: ThePluginMenuItem, item: any): any;
|
|
56
57
|
static ɵfac: i0.ɵɵFactoryDeclaration<ThePluginMenuComponent, never>;
|
package/constants/default.d.ts
CHANGED
|
@@ -7,3 +7,4 @@ export declare const CLIPBOARD_FORMAT_KEY = "x-theia-fragment";
|
|
|
7
7
|
export declare const DEFAULT_SCROLL_CONTAINER = ".the-editable-container";
|
|
8
8
|
export declare const ELEMENT_UNIQUE_ID = "key";
|
|
9
9
|
export declare const ZERO_WIDTH_CHAR = "\u200B";
|
|
10
|
+
export declare const QUICK_INSERT_HOTKEY = "/";
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import { DOWN_ARROW,
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
1
|
+
import { DOWN_ARROW, ENTER, LEFT_ARROW, RIGHT_ARROW, UP_ARROW } from '@angular/cdk/keycodes';
|
|
2
|
+
import { ContentChildren, DestroyRef, Directive, ElementRef, EventEmitter, HostBinding, Inject, Input, NgZone, Optional, Output, SkipSelf, forwardRef, inject } from '@angular/core';
|
|
3
|
+
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
4
4
|
import { fromEvent } from 'rxjs';
|
|
5
5
|
import { debounceTime } from 'rxjs/operators';
|
|
6
|
-
import {
|
|
6
|
+
import { THE_LISTBOX_PARENT_GROUP_TOKEN, THE_LISTBOX_PARENT_OPTION_TOKEN, THE_LISTBOX_TOKEN } from './listbox.type';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
8
8
|
export class TheListboxOptionDirective {
|
|
9
9
|
get hasChild() {
|
|
@@ -16,11 +16,9 @@ export class TheListboxOptionDirective {
|
|
|
16
16
|
this.parentOption = parentOption;
|
|
17
17
|
this.parentGroup = parentGroup;
|
|
18
18
|
this.elementRef = elementRef;
|
|
19
|
-
this._active = false;
|
|
20
19
|
this.className = 'the-listbox-option';
|
|
20
|
+
this._active = false;
|
|
21
21
|
}
|
|
22
|
-
ngOnInit() { }
|
|
23
|
-
ngAfterContentInit() { }
|
|
24
22
|
getGroups() {
|
|
25
23
|
const groups = [];
|
|
26
24
|
this._options.forEach(option => {
|
|
@@ -73,29 +71,28 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
|
|
|
73
71
|
}] }, { type: TheListboxGroupDirective, decorators: [{
|
|
74
72
|
type: Inject,
|
|
75
73
|
args: [THE_LISTBOX_PARENT_GROUP_TOKEN]
|
|
76
|
-
}] }, { type: i0.ElementRef }], propDecorators: {
|
|
74
|
+
}] }, { type: i0.ElementRef }], propDecorators: { theOptionValue: [{
|
|
75
|
+
type: Input
|
|
76
|
+
}], theOptionDisabled: [{
|
|
77
|
+
type: Input
|
|
78
|
+
}], className: [{
|
|
77
79
|
type: HostBinding,
|
|
78
80
|
args: ['class']
|
|
79
81
|
}], _options: [{
|
|
80
82
|
type: ContentChildren,
|
|
81
83
|
args: [forwardRef(() => TheListboxOptionDirective), { descendants: true }]
|
|
82
|
-
}], theOptionValue: [{
|
|
83
|
-
type: Input
|
|
84
|
-
}], theOptionDisabled: [{
|
|
85
|
-
type: Input
|
|
86
84
|
}] } });
|
|
87
85
|
export class TheListboxGroupDirective {
|
|
88
86
|
constructor(parentOption, theListBox) {
|
|
89
87
|
this.parentOption = parentOption;
|
|
90
88
|
this.theListBox = theListBox;
|
|
91
|
-
this.className = 'the-listbox-group';
|
|
92
|
-
this.options = [];
|
|
93
89
|
/**
|
|
94
90
|
* 大于 1 表示水平分组,小于等于 1 表示垂直分组
|
|
95
91
|
*/
|
|
96
92
|
this.horizontalColumn = 1;
|
|
93
|
+
this.className = 'the-listbox-group';
|
|
94
|
+
this.options = [];
|
|
97
95
|
}
|
|
98
|
-
ngOnInit() { }
|
|
99
96
|
ngAfterContentInit() {
|
|
100
97
|
this.filterOptions();
|
|
101
98
|
}
|
|
@@ -157,36 +154,38 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
|
|
|
157
154
|
}] }, { type: TheListboxDirective, decorators: [{
|
|
158
155
|
type: Inject,
|
|
159
156
|
args: [THE_LISTBOX_TOKEN]
|
|
160
|
-
}] }], propDecorators: {
|
|
157
|
+
}] }], propDecorators: { horizontalColumn: [{
|
|
158
|
+
type: Input
|
|
159
|
+
}], className: [{
|
|
161
160
|
type: HostBinding,
|
|
162
161
|
args: ['class']
|
|
163
162
|
}], _options: [{
|
|
164
163
|
type: ContentChildren,
|
|
165
164
|
args: [TheListboxOptionDirective, { descendants: true }]
|
|
166
|
-
}], horizontalColumn: [{
|
|
167
|
-
type: Input
|
|
168
165
|
}] } });
|
|
169
166
|
export class TheListboxDirective {
|
|
170
|
-
constructor(
|
|
171
|
-
this.ngZone = ngZone;
|
|
172
|
-
this.elementRef = elementRef;
|
|
173
|
-
this.className = 'the-listbox-container';
|
|
174
|
-
this.groups = [];
|
|
167
|
+
constructor() {
|
|
175
168
|
this.autoActiveFirstItem = true;
|
|
176
169
|
this.theListboxChange = new EventEmitter();
|
|
170
|
+
this.className = 'the-listbox-container';
|
|
171
|
+
this.groups = [];
|
|
172
|
+
this.ngZone = inject(NgZone);
|
|
173
|
+
this.elementRef = inject(ElementRef);
|
|
174
|
+
this.destroyRef = inject(DestroyRef);
|
|
177
175
|
}
|
|
178
|
-
ngOnInit() { }
|
|
179
176
|
ngAfterContentInit() {
|
|
180
177
|
this.filterGroups();
|
|
181
178
|
if (this.groups.length > 0 && this.autoActiveFirstItem) {
|
|
182
179
|
this.setActiveItem(null, this.groups[0].getFirst(), 'init');
|
|
183
180
|
}
|
|
184
|
-
this.
|
|
181
|
+
this._options.changes.pipe(debounceTime(20), takeUntilDestroyed(this.destroyRef)).subscribe(() => {
|
|
185
182
|
this.filterGroups();
|
|
186
183
|
this.setActiveItem(this.activeOption, this.groups[0].getFirst(), 'init');
|
|
187
184
|
});
|
|
188
185
|
this.ngZone.runOutsideAngular(() => {
|
|
189
|
-
|
|
186
|
+
fromEvent(this.keyboardContainer || this.elementRef.nativeElement, 'keydown')
|
|
187
|
+
.pipe(takeUntilDestroyed(this.destroyRef))
|
|
188
|
+
.subscribe(event => {
|
|
190
189
|
this.handleKeydown(event);
|
|
191
190
|
});
|
|
192
191
|
});
|
|
@@ -334,17 +333,20 @@ export class TheListboxDirective {
|
|
|
334
333
|
this.activeOption = option;
|
|
335
334
|
this.theListboxChange.emit({ option, type });
|
|
336
335
|
}
|
|
337
|
-
|
|
338
|
-
this.
|
|
339
|
-
|
|
336
|
+
getOption(key) {
|
|
337
|
+
return this._options.find(option => option.theOptionValue?.key === key);
|
|
338
|
+
}
|
|
339
|
+
clearActiveItem() {
|
|
340
|
+
this.activeOption.setActive(false);
|
|
341
|
+
this.activeOption = null;
|
|
340
342
|
}
|
|
341
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: TheListboxDirective, deps: [
|
|
343
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: TheListboxDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
342
344
|
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.0", type: TheListboxDirective, isStandalone: true, selector: "[theListBox]", inputs: { keyboardContainer: "keyboardContainer", autoActiveFirstItem: "autoActiveFirstItem" }, outputs: { theListboxChange: "theListboxChange" }, host: { properties: { "class": "this.className" } }, providers: [
|
|
343
345
|
{
|
|
344
346
|
provide: THE_LISTBOX_TOKEN,
|
|
345
347
|
useExisting: TheListboxDirective
|
|
346
348
|
}
|
|
347
|
-
], queries: [{ propertyName: "
|
|
349
|
+
], queries: [{ propertyName: "_options", predicate: TheListboxOptionDirective, descendants: true }, { propertyName: "_groups", predicate: TheListboxGroupDirective, descendants: true }], exportAs: ["theListBox"], ngImport: i0 }); }
|
|
348
350
|
}
|
|
349
351
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: TheListboxDirective, decorators: [{
|
|
350
352
|
type: Directive,
|
|
@@ -359,20 +361,20 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
|
|
|
359
361
|
],
|
|
360
362
|
standalone: true
|
|
361
363
|
}]
|
|
362
|
-
}],
|
|
363
|
-
type: HostBinding,
|
|
364
|
-
args: ['class']
|
|
365
|
-
}], _groups: [{
|
|
366
|
-
type: ContentChildren,
|
|
367
|
-
args: [TheListboxGroupDirective, { descendants: true }]
|
|
368
|
-
}], _options: [{
|
|
369
|
-
type: ContentChildren,
|
|
370
|
-
args: [TheListboxOptionDirective, { descendants: true }]
|
|
371
|
-
}], keyboardContainer: [{
|
|
364
|
+
}], propDecorators: { keyboardContainer: [{
|
|
372
365
|
type: Input
|
|
373
366
|
}], autoActiveFirstItem: [{
|
|
374
367
|
type: Input
|
|
375
368
|
}], theListboxChange: [{
|
|
376
369
|
type: Output
|
|
370
|
+
}], className: [{
|
|
371
|
+
type: HostBinding,
|
|
372
|
+
args: ['class']
|
|
373
|
+
}], _options: [{
|
|
374
|
+
type: ContentChildren,
|
|
375
|
+
args: [TheListboxOptionDirective, { descendants: true }]
|
|
376
|
+
}], _groups: [{
|
|
377
|
+
type: ContentChildren,
|
|
378
|
+
args: [TheListboxGroupDirective, { descendants: true }]
|
|
377
379
|
}] } });
|
|
378
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"listbox.js","sourceRoot":"","sources":["../../../../../packages/src/components/listbox/listbox.ts"],"names":[],"mappings":"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","sourcesContent":["import { DOWN_ARROW, LEFT_ARROW, ENTER, RIGHT_ARROW, UP_ARROW, T } from '@angular/cdk/keycodes';\nimport { forwardRef, NgZone, Optional, SkipSelf } from '@angular/core';\nimport {\n    AfterContentInit,\n    ContentChildren,\n    Directive,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    Inject,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output,\n    QueryList\n} from '@angular/core';\nimport { fromEvent } from 'rxjs';\nimport { Subscription } from 'rxjs/internal/Subscription';\nimport { debounceTime } from 'rxjs/operators';\nimport {\n    TheListboxChangeEventType,\n    THE_LISTBOX_TOKEN,\n    THE_LISTBOX_PARENT_OPTION_TOKEN,\n    THE_LISTBOX_PARENT_GROUP_TOKEN\n} from './listbox.type';\n\n@Directive({\n    selector: '[theListboxOption]',\n    exportAs: 'theListboxOption',\n    providers: [\n        {\n            provide: THE_LISTBOX_PARENT_OPTION_TOKEN,\n            useExisting: TheListboxOptionDirective\n        }\n    ],\n    standalone: true\n})\nexport class TheListboxOptionDirective implements OnInit, AfterContentInit {\n    private _active = false;\n\n    @HostBinding('class') className = 'the-listbox-option';\n\n    @ContentChildren(forwardRef(() => TheListboxOptionDirective), { descendants: true })\n    public _options: QueryList<TheListboxOptionDirective>;\n\n    get hasChild() {\n        return this._options.length > 0;\n    }\n\n    get firstChild() {\n        return this._options.first;\n    }\n\n    @Input() theOptionValue: unknown;\n\n    @Input() theOptionDisabled: boolean;\n\n    constructor(\n        @Inject(THE_LISTBOX_PARENT_OPTION_TOKEN) @Optional() @SkipSelf() public parentOption: TheListboxOptionDirective,\n        @Inject(THE_LISTBOX_PARENT_GROUP_TOKEN) public parentGroup: TheListboxGroupDirective,\n        public elementRef: ElementRef<HTMLElement>\n    ) {}\n\n    ngOnInit(): void {}\n\n    ngAfterContentInit(): void {}\n\n    getGroups() {\n        const groups: TheListboxGroupDirective[] = [];\n        this._options.forEach(option => {\n            if (option.parentOption && option.parentOption === this && !groups.includes(option.parentGroup)) {\n                groups.push(option.parentGroup);\n            }\n        });\n        return groups;\n    }\n\n    setActive(active: boolean) {\n        this._active = active;\n        if (active) {\n            this.elementRef.nativeElement.classList.add('focus');\n        } else {\n            this.elementRef.nativeElement.classList.remove('focus');\n        }\n    }\n\n    getActive() {\n        return this._active;\n    }\n}\n\n@Directive({\n    selector: '[theListboxGroup]',\n    exportAs: 'theListboxGroup',\n    providers: [\n        {\n            provide: THE_LISTBOX_PARENT_GROUP_TOKEN,\n            useExisting: TheListboxGroupDirective\n        }\n    ],\n    standalone: true\n})\nexport class TheListboxGroupDirective implements OnInit, AfterContentInit {\n    @HostBinding('class') className = 'the-listbox-group';\n\n    options: TheListboxOptionDirective[] = [];\n\n    @ContentChildren(TheListboxOptionDirective, { descendants: true }) public _options: QueryList<TheListboxOptionDirective>;\n\n    /**\n     * 大于 1 表示水平分组，小于等于 1 表示垂直分组\n     */\n    @Input() horizontalColumn = 1;\n\n    constructor(\n        @Inject(THE_LISTBOX_PARENT_OPTION_TOKEN) @Optional() @SkipSelf() public parentOption: TheListboxOptionDirective,\n        @Inject(THE_LISTBOX_TOKEN) public theListBox: TheListboxDirective\n    ) {}\n\n    ngOnInit(): void {}\n\n    ngAfterContentInit(): void {\n        this.filterOptions();\n    }\n\n    filterOptions() {\n        this.options = this._options.filter(_option => {\n            if (_option.parentGroup && _option.parentGroup === this) {\n                return true;\n            } else {\n                return false;\n            }\n        });\n    }\n\n    getSiblingGroups() {\n        if (this.parentOption) {\n            return this.parentOption.getGroups();\n        } else {\n            return this.theListBox.groups;\n        }\n    }\n\n    hasChild() {\n        return this.options.length > 0;\n    }\n\n    getFirst() {\n        return this.options[0];\n    }\n\n    getLast() {\n        return this.options[this.options.length - 1];\n    }\n}\n\n@Directive({\n    selector: '[theListBox]',\n    exportAs: 'theListBox',\n    providers: [\n        {\n            provide: THE_LISTBOX_TOKEN,\n            useExisting: TheListboxDirective\n        }\n    ],\n    standalone: true\n})\nexport class TheListboxDirective implements OnInit, AfterContentInit, OnDestroy {\n    @HostBinding('class') className = 'the-listbox-container';\n\n    private _optionChangesSubscription: Subscription;\n\n    private _keyboardSubscription: Subscription;\n\n    public activeOption: TheListboxOptionDirective;\n\n    public groups: TheListboxGroupDirective[] = [];\n\n    @ContentChildren(TheListboxGroupDirective, { descendants: true }) protected _groups: QueryList<TheListboxGroupDirective>;\n\n    @ContentChildren(TheListboxOptionDirective, { descendants: true }) protected _options: QueryList<TheListboxOptionDirective>;\n\n    @Input() keyboardContainer: HTMLElement;\n\n    @Input() autoActiveFirstItem = true;\n\n    @Output() theListboxChange = new EventEmitter<TheListboxChangeEvent>();\n\n    constructor(\n        private ngZone: NgZone,\n        private elementRef: ElementRef<HTMLElement>\n    ) {}\n\n    ngOnInit(): void {}\n\n    ngAfterContentInit(): void {\n        this.filterGroups();\n        if (this.groups.length > 0 && this.autoActiveFirstItem) {\n            this.setActiveItem(null, this.groups[0].getFirst(), 'init');\n        }\n        this._optionChangesSubscription = this._options.changes.pipe(debounceTime(20)).subscribe(() => {\n            this.filterGroups();\n            this.setActiveItem(this.activeOption, this.groups[0].getFirst(), 'init');\n        });\n        this.ngZone.runOutsideAngular(() => {\n            this._keyboardSubscription = fromEvent<KeyboardEvent>(\n                this.keyboardContainer || this.elementRef.nativeElement,\n                'keydown'\n            ).subscribe(event => {\n                this.handleKeydown(event);\n            });\n        });\n    }\n\n    filterGroups() {\n        this.groups = this._groups.filter(group => {\n            group.filterOptions();\n            if (!group.parentOption && group.hasChild()) {\n                return true;\n            } else {\n                return false;\n            }\n        });\n    }\n\n    handleKeydown(event: KeyboardEvent) {\n        const { keyCode } = event;\n        if (!this.activeOption && (keyCode === DOWN_ARROW || keyCode === UP_ARROW || keyCode === RIGHT_ARROW || keyCode === LEFT_ARROW)) {\n            this.setActiveItem(null, this.groups[0].getFirst(), 'init');\n            return;\n        }\n\n        switch (keyCode) {\n            case DOWN_ARROW:\n                this.setNextLineActive();\n                event.preventDefault();\n                break;\n            case UP_ARROW:\n                this.setPreviousLineActive();\n                event.preventDefault();\n                break;\n            case RIGHT_ARROW:\n                this.setNextItemActive();\n                event.preventDefault();\n                break;\n            case LEFT_ARROW:\n                this.setPreviousItemActive();\n                event.preventDefault();\n                break;\n            case ENTER:\n                this.theListboxChange.emit({ option: this.activeOption, type: 'select' });\n                event.preventDefault();\n                break;\n        }\n    }\n\n    /**\n     * ←\n     */\n    setPreviousItemActive() {\n        if (this.activeOption.parentOption) {\n            this.setActiveItem(this.activeOption, this.activeOption.parentOption, 'parent');\n        } else {\n            const groupOptions = this.activeOption.parentGroup.options;\n            let optionIndex = groupOptions.indexOf(this.activeOption);\n            let newOptionIndex = optionIndex - 1;\n            if (newOptionIndex >= 0) {\n                this.setActiveItem(this.activeOption, groupOptions[newOptionIndex], 'turn');\n            } else {\n                this.enterPreviousGroup();\n            }\n        }\n    }\n\n    /**\n     * ↓ 键\n     */\n    setNextLineActive(activeOption?: TheListboxOptionDirective) {\n        const _activeOption = activeOption ? activeOption : this.activeOption;\n        const groupOptions = _activeOption.parentGroup.options;\n        let optionIndex = groupOptions.indexOf(_activeOption);\n        let newOptionIndex = optionIndex + _activeOption.parentGroup.horizontalColumn;\n        const lastLineLength = groupOptions.length % _activeOption.parentGroup.horizontalColumn;\n        const lastLineStartIndex = groupOptions.length - (lastLineLength > 0 ? lastLineLength : 1);\n        let newOption = null;\n        if (newOptionIndex <= groupOptions.length - 1) {\n            newOption = groupOptions[newOptionIndex];\n        } else if (optionIndex < lastLineStartIndex) {\n            newOptionIndex = groupOptions.length - 1;\n            newOption = groupOptions[newOptionIndex];\n        }\n        if (newOption) {\n            this.setActiveItem(this.activeOption, newOption, 'turn');\n        } else {\n            this.enterNextGroup();\n        }\n    }\n\n    /**\n     * → 键\n     */\n    setNextItemActive() {\n        if (this.activeOption.hasChild) {\n            this.setActiveItem(this.activeOption, this.activeOption.firstChild, 'child');\n        } else {\n            const groupOptions = this.activeOption.parentGroup.options;\n            let optionIndex = groupOptions.indexOf(this.activeOption);\n            let newOptionIndex = optionIndex + 1;\n            if (newOptionIndex <= groupOptions.length - 1) {\n                this.setActiveItem(this.activeOption, groupOptions[newOptionIndex], 'turn');\n            } else {\n                this.enterNextGroup();\n            }\n        }\n    }\n\n    /**\n     * ↑ 键\n     */\n    setPreviousLineActive() {\n        const groupOptions = this.activeOption.parentGroup.options;\n        let optionIndex = groupOptions.indexOf(this.activeOption);\n        let newOptionIndex = optionIndex - this.activeOption.parentGroup.horizontalColumn;\n        if (newOptionIndex >= 0) {\n            this.setActiveItem(this.activeOption, groupOptions[newOptionIndex], 'turn');\n        } else {\n            this.enterPreviousGroup();\n        }\n    }\n\n    enterNextGroup() {\n        const groups = this.activeOption.parentGroup.getSiblingGroups();\n        const groupIndex = groups.indexOf(this.activeOption.parentGroup);\n        let newGroupIndex = groupIndex + 1;\n        if (newGroupIndex > groups.length - 1) {\n            newGroupIndex = 0;\n        }\n        this.setActiveItem(this.activeOption, groups[newGroupIndex].getFirst(), 'turn');\n    }\n\n    enterPreviousGroup() {\n        const groups = this.activeOption.parentGroup.getSiblingGroups();\n        const groupIndex = groups.indexOf(this.activeOption.parentGroup);\n        let newGroupIndex = groupIndex - 1;\n        if (newGroupIndex < 0) {\n            newGroupIndex = groups.length - 1;\n        }\n        this.setActiveItem(this.activeOption, groups[newGroupIndex].getLast(), 'turn');\n    }\n\n    setActiveItem(previous: TheListboxOptionDirective | null, option: TheListboxOptionDirective, type: TheListboxChangeEventType) {\n        if (previous) {\n            previous.setActive(false);\n        }\n        option.setActive(true);\n        this.activeOption = option;\n        this.theListboxChange.emit({ option, type });\n    }\n\n    ngOnDestroy(): void {\n        this._optionChangesSubscription.unsubscribe();\n        this._keyboardSubscription.unsubscribe();\n    }\n}\n\nexport interface TheListboxChangeEvent {\n    option: TheListboxOptionDirective;\n    type: TheListboxChangeEventType;\n}\n"]}
|
|
380
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"listbox.js","sourceRoot":"","sources":["../../../../../packages/src/components/listbox/listbox.ts"],"names":[],"mappings":"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","sourcesContent":["import { DOWN_ARROW, ENTER, LEFT_ARROW, RIGHT_ARROW, UP_ARROW } from '@angular/cdk/keycodes';\nimport {\n    AfterContentInit,\n    ContentChildren,\n    DestroyRef,\n    Directive,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    Inject,\n    Input,\n    NgZone,\n    Optional,\n    Output,\n    QueryList,\n    SkipSelf,\n    forwardRef,\n    inject\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { fromEvent } from 'rxjs';\nimport { debounceTime } from 'rxjs/operators';\nimport { ThePluginMenuItem, ThePluginMenuItemKey } from '../../interfaces';\nimport {\n    THE_LISTBOX_PARENT_GROUP_TOKEN,\n    THE_LISTBOX_PARENT_OPTION_TOKEN,\n    THE_LISTBOX_TOKEN,\n    TheListboxChangeEventType\n} from './listbox.type';\n\n@Directive({\n    selector: '[theListboxOption]',\n    exportAs: 'theListboxOption',\n    providers: [\n        {\n            provide: THE_LISTBOX_PARENT_OPTION_TOKEN,\n            useExisting: TheListboxOptionDirective\n        }\n    ],\n    standalone: true\n})\nexport class TheListboxOptionDirective {\n    @Input() theOptionValue: ThePluginMenuItem;\n\n    @Input() theOptionDisabled: boolean;\n\n    @HostBinding('class') className = 'the-listbox-option';\n\n    @ContentChildren(forwardRef(() => TheListboxOptionDirective), { descendants: true })\n    public _options: QueryList<TheListboxOptionDirective>;\n\n    private _active = false;\n\n    get hasChild() {\n        return this._options.length > 0;\n    }\n\n    get firstChild() {\n        return this._options.first;\n    }\n\n    constructor(\n        @Inject(THE_LISTBOX_PARENT_OPTION_TOKEN) @Optional() @SkipSelf() public parentOption: TheListboxOptionDirective,\n        @Inject(THE_LISTBOX_PARENT_GROUP_TOKEN) public parentGroup: TheListboxGroupDirective,\n        public elementRef: ElementRef<HTMLElement>\n    ) {}\n\n    getGroups() {\n        const groups: TheListboxGroupDirective[] = [];\n        this._options.forEach(option => {\n            if (option.parentOption && option.parentOption === this && !groups.includes(option.parentGroup)) {\n                groups.push(option.parentGroup);\n            }\n        });\n        return groups;\n    }\n\n    setActive(active: boolean) {\n        this._active = active;\n        if (active) {\n            this.elementRef.nativeElement.classList.add('focus');\n        } else {\n            this.elementRef.nativeElement.classList.remove('focus');\n        }\n    }\n\n    getActive() {\n        return this._active;\n    }\n}\n\nexport interface TheListboxChangeEvent {\n    option: TheListboxOptionDirective;\n    type: TheListboxChangeEventType;\n}\n\n@Directive({\n    selector: '[theListboxGroup]',\n    exportAs: 'theListboxGroup',\n    providers: [\n        {\n            provide: THE_LISTBOX_PARENT_GROUP_TOKEN,\n            useExisting: TheListboxGroupDirective\n        }\n    ],\n    standalone: true\n})\nexport class TheListboxGroupDirective implements AfterContentInit {\n    /**\n     * 大于 1 表示水平分组，小于等于 1 表示垂直分组\n     */\n    @Input() horizontalColumn = 1;\n\n    @HostBinding('class') className = 'the-listbox-group';\n\n    @ContentChildren(TheListboxOptionDirective, { descendants: true }) public _options: QueryList<TheListboxOptionDirective>;\n\n    options: TheListboxOptionDirective[] = [];\n\n    constructor(\n        @Inject(THE_LISTBOX_PARENT_OPTION_TOKEN) @Optional() @SkipSelf() public parentOption: TheListboxOptionDirective,\n        @Inject(THE_LISTBOX_TOKEN) public theListBox: TheListboxDirective\n    ) {}\n\n    ngAfterContentInit(): void {\n        this.filterOptions();\n    }\n\n    filterOptions() {\n        this.options = this._options.filter(_option => {\n            if (_option.parentGroup && _option.parentGroup === this) {\n                return true;\n            } else {\n                return false;\n            }\n        });\n    }\n\n    getSiblingGroups() {\n        if (this.parentOption) {\n            return this.parentOption.getGroups();\n        } else {\n            return this.theListBox.groups;\n        }\n    }\n\n    hasChild() {\n        return this.options.length > 0;\n    }\n\n    getFirst() {\n        return this.options[0];\n    }\n\n    getLast() {\n        return this.options[this.options.length - 1];\n    }\n}\n\n@Directive({\n    selector: '[theListBox]',\n    exportAs: 'theListBox',\n    providers: [\n        {\n            provide: THE_LISTBOX_TOKEN,\n            useExisting: TheListboxDirective\n        }\n    ],\n    standalone: true\n})\nexport class TheListboxDirective implements AfterContentInit {\n    @Input() keyboardContainer: HTMLElement;\n\n    @Input() autoActiveFirstItem = true;\n\n    @Output() theListboxChange = new EventEmitter<TheListboxChangeEvent>();\n\n    @HostBinding('class') className = 'the-listbox-container';\n\n    @ContentChildren(TheListboxOptionDirective, { descendants: true })\n    protected _options: QueryList<TheListboxOptionDirective>;\n\n    @ContentChildren(TheListboxGroupDirective, { descendants: true })\n    protected _groups: QueryList<TheListboxGroupDirective>;\n\n    public activeOption: TheListboxOptionDirective;\n\n    public groups: TheListboxGroupDirective[] = [];\n\n    private ngZone = inject(NgZone);\n\n    private elementRef = inject(ElementRef);\n\n    private destroyRef = inject(DestroyRef);\n\n    ngAfterContentInit(): void {\n        this.filterGroups();\n        if (this.groups.length > 0 && this.autoActiveFirstItem) {\n            this.setActiveItem(null, this.groups[0].getFirst(), 'init');\n        }\n        this._options.changes.pipe(debounceTime(20), takeUntilDestroyed(this.destroyRef)).subscribe(() => {\n            this.filterGroups();\n            this.setActiveItem(this.activeOption, this.groups[0].getFirst(), 'init');\n        });\n        this.ngZone.runOutsideAngular(() => {\n            fromEvent<KeyboardEvent>(this.keyboardContainer || this.elementRef.nativeElement, 'keydown')\n                .pipe(takeUntilDestroyed(this.destroyRef))\n                .subscribe(event => {\n                    this.handleKeydown(event);\n                });\n        });\n    }\n\n    filterGroups() {\n        this.groups = this._groups.filter(group => {\n            group.filterOptions();\n            if (!group.parentOption && group.hasChild()) {\n                return true;\n            } else {\n                return false;\n            }\n        });\n    }\n\n    handleKeydown(event: KeyboardEvent) {\n        const { keyCode } = event;\n        if (!this.activeOption && (keyCode === DOWN_ARROW || keyCode === UP_ARROW || keyCode === RIGHT_ARROW || keyCode === LEFT_ARROW)) {\n            this.setActiveItem(null, this.groups[0].getFirst(), 'init');\n            return;\n        }\n\n        switch (keyCode) {\n            case DOWN_ARROW:\n                this.setNextLineActive();\n                event.preventDefault();\n                break;\n            case UP_ARROW:\n                this.setPreviousLineActive();\n                event.preventDefault();\n                break;\n            case RIGHT_ARROW:\n                this.setNextItemActive();\n                event.preventDefault();\n                break;\n            case LEFT_ARROW:\n                this.setPreviousItemActive();\n                event.preventDefault();\n                break;\n            case ENTER:\n                this.theListboxChange.emit({ option: this.activeOption, type: 'select' });\n                event.preventDefault();\n                break;\n        }\n    }\n\n    /**\n     * ←\n     */\n    setPreviousItemActive() {\n        if (this.activeOption.parentOption) {\n            this.setActiveItem(this.activeOption, this.activeOption.parentOption, 'parent');\n        } else {\n            const groupOptions = this.activeOption.parentGroup.options;\n            let optionIndex = groupOptions.indexOf(this.activeOption);\n            let newOptionIndex = optionIndex - 1;\n            if (newOptionIndex >= 0) {\n                this.setActiveItem(this.activeOption, groupOptions[newOptionIndex], 'turn');\n            } else {\n                this.enterPreviousGroup();\n            }\n        }\n    }\n\n    /**\n     * ↓ 键\n     */\n    setNextLineActive(activeOption?: TheListboxOptionDirective) {\n        const _activeOption = activeOption ? activeOption : this.activeOption;\n        const groupOptions = _activeOption.parentGroup.options;\n        let optionIndex = groupOptions.indexOf(_activeOption);\n        let newOptionIndex = optionIndex + _activeOption.parentGroup.horizontalColumn;\n        const lastLineLength = groupOptions.length % _activeOption.parentGroup.horizontalColumn;\n        const lastLineStartIndex = groupOptions.length - (lastLineLength > 0 ? lastLineLength : 1);\n        let newOption = null;\n        if (newOptionIndex <= groupOptions.length - 1) {\n            newOption = groupOptions[newOptionIndex];\n        } else if (optionIndex < lastLineStartIndex) {\n            newOptionIndex = groupOptions.length - 1;\n            newOption = groupOptions[newOptionIndex];\n        }\n        if (newOption) {\n            this.setActiveItem(this.activeOption, newOption, 'turn');\n        } else {\n            this.enterNextGroup();\n        }\n    }\n\n    /**\n     * → 键\n     */\n    setNextItemActive() {\n        if (this.activeOption.hasChild) {\n            this.setActiveItem(this.activeOption, this.activeOption.firstChild, 'child');\n        } else {\n            const groupOptions = this.activeOption.parentGroup.options;\n            let optionIndex = groupOptions.indexOf(this.activeOption);\n            let newOptionIndex = optionIndex + 1;\n            if (newOptionIndex <= groupOptions.length - 1) {\n                this.setActiveItem(this.activeOption, groupOptions[newOptionIndex], 'turn');\n            } else {\n                this.enterNextGroup();\n            }\n        }\n    }\n\n    /**\n     * ↑ 键\n     */\n    setPreviousLineActive() {\n        const groupOptions = this.activeOption.parentGroup.options;\n        let optionIndex = groupOptions.indexOf(this.activeOption);\n        let newOptionIndex = optionIndex - this.activeOption.parentGroup.horizontalColumn;\n        if (newOptionIndex >= 0) {\n            this.setActiveItem(this.activeOption, groupOptions[newOptionIndex], 'turn');\n        } else {\n            this.enterPreviousGroup();\n        }\n    }\n\n    enterNextGroup() {\n        const groups = this.activeOption.parentGroup.getSiblingGroups();\n        const groupIndex = groups.indexOf(this.activeOption.parentGroup);\n        let newGroupIndex = groupIndex + 1;\n        if (newGroupIndex > groups.length - 1) {\n            newGroupIndex = 0;\n        }\n        this.setActiveItem(this.activeOption, groups[newGroupIndex].getFirst(), 'turn');\n    }\n\n    enterPreviousGroup() {\n        const groups = this.activeOption.parentGroup.getSiblingGroups();\n        const groupIndex = groups.indexOf(this.activeOption.parentGroup);\n        let newGroupIndex = groupIndex - 1;\n        if (newGroupIndex < 0) {\n            newGroupIndex = groups.length - 1;\n        }\n        this.setActiveItem(this.activeOption, groups[newGroupIndex].getLast(), 'turn');\n    }\n\n    setActiveItem(previous: TheListboxOptionDirective | null, option: TheListboxOptionDirective, type: TheListboxChangeEventType) {\n        if (previous) {\n            previous.setActive(false);\n        }\n        option.setActive(true);\n        this.activeOption = option;\n        this.theListboxChange.emit({ option, type });\n    }\n\n    getOption(key: ThePluginMenuItemKey) {\n        return this._options.find(option => option.theOptionValue?.key === key);\n    }\n\n    clearActiveItem() {\n        this.activeOption.setActive(false);\n        this.activeOption = null;\n    }\n}\n"]}
|