@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.
@@ -1,39 +1,40 @@
1
- import { NgZone } from '@angular/core';
2
- import { AfterContentInit, ElementRef, EventEmitter, OnDestroy, OnInit, QueryList } from '@angular/core';
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 implements OnInit, AfterContentInit {
5
+ export declare class TheListboxOptionDirective {
6
6
  parentOption: TheListboxOptionDirective;
7
7
  parentGroup: TheListboxGroupDirective;
8
8
  elementRef: ElementRef<HTMLElement>;
9
- private _active;
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 declare class TheListboxGroupDirective implements OnInit, AfterContentInit {
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 OnInit, AfterContentInit, OnDestroy {
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
- constructor(ngZone: NgZone, elementRef: ElementRef<HTMLElement>);
60
- ngOnInit(): void;
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
- ngOnDestroy(): void;
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"; }, ["_groups", "_options"], never, true, never>;
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, NgZone, OnInit } from '@angular/core';
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
- elementRef: ElementRef<HTMLElement>;
11
- cdr: ChangeDetectorRef;
12
- private ngZone;
13
- private thyPopoverRef;
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
- dropdownTriggers: ThyDropdownDirective[];
37
- containerClassName: string;
38
- editor: Editor;
39
- theDisplaySearch: boolean;
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
- theListboxChange(event: TheListboxChangeEvent): void;
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>;
@@ -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, LEFT_ARROW, ENTER, RIGHT_ARROW, UP_ARROW } from '@angular/cdk/keycodes';
2
- import { forwardRef, Optional, SkipSelf } from '@angular/core';
3
- import { ContentChildren, Directive, EventEmitter, HostBinding, Inject, Input, Output } from '@angular/core';
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 { THE_LISTBOX_TOKEN, THE_LISTBOX_PARENT_OPTION_TOKEN, THE_LISTBOX_PARENT_GROUP_TOKEN } from './listbox.type';
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: { className: [{
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: { className: [{
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(ngZone, elementRef) {
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._optionChangesSubscription = this._options.changes.pipe(debounceTime(20)).subscribe(() => {
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
- this._keyboardSubscription = fromEvent(this.keyboardContainer || this.elementRef.nativeElement, 'keydown').subscribe(event => {
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
- ngOnDestroy() {
338
- this._optionChangesSubscription.unsubscribe();
339
- this._keyboardSubscription.unsubscribe();
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: [{ token: i0.NgZone }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
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: "_groups", predicate: TheListboxGroupDirective, descendants: true }, { propertyName: "_options", predicate: TheListboxOptionDirective, descendants: true }], exportAs: ["theListBox"], ngImport: i0 }); }
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
- }], ctorParameters: () => [{ type: i0.NgZone }, { type: i0.ElementRef }], propDecorators: { className: [{
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":"AAAA,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,KAAK,EAAE,WAAW,EAAE,QAAQ,EAAK,MAAM,uBAAuB,CAAC;AAChG,OAAO,EAAE,UAAU,EAAU,QAAQ,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACvE,OAAO,EAEH,eAAe,EACf,SAAS,EAET,YAAY,EACZ,WAAW,EACX,MAAM,EACN,KAAK,EAGL,MAAM,EAET,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAEjC,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAEH,iBAAiB,EACjB,+BAA+B,EAC/B,8BAA8B,EACjC,MAAM,gBAAgB,CAAC;;AAaxB,MAAM,OAAO,yBAAyB;IAQlC,IAAI,QAAQ;QACR,OAAO,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC;IACpC,CAAC;IAED,IAAI,UAAU;QACV,OAAO,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC;IAC/B,CAAC;IAMD,YAC4E,YAAuC,EAChE,WAAqC,EAC7E,UAAmC;QAF8B,iBAAY,GAAZ,YAAY,CAA2B;QAChE,gBAAW,GAAX,WAAW,CAA0B;QAC7E,eAAU,GAAV,UAAU,CAAyB;QAtBtC,YAAO,GAAG,KAAK,CAAC;QAEF,cAAS,GAAG,oBAAoB,CAAC;IAqBpD,CAAC;IAEJ,QAAQ,KAAU,CAAC;IAEnB,kBAAkB,KAAU,CAAC;IAE7B,SAAS;QACL,MAAM,MAAM,GAA+B,EAAE,CAAC;QAC9C,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;YAC3B,IAAI,MAAM,CAAC,YAAY,IAAI,MAAM,CAAC,YAAY,KAAK,IAAI,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,WAAW,CAAC,EAAE,CAAC;gBAC9F,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC;YACpC,CAAC;QACL,CAAC,CAAC,CAAC;QACH,OAAO,MAAM,CAAC;IAClB,CAAC;IAED,SAAS,CAAC,MAAe;QACrB,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC;QACtB,IAAI,MAAM,EAAE,CAAC;YACT,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,SAAS,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;QACzD,CAAC;aAAM,CAAC;YACJ,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,SAAS,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;QAC5D,CAAC;IACL,CAAC;IAED,SAAS;QACL,OAAO,IAAI,CAAC,OAAO,CAAC;IACxB,CAAC;8GAnDQ,yBAAyB,kBAqBtB,+BAA+B,6CAC/B,8BAA8B;kGAtBjC,yBAAyB,4MARvB;YACP;gBACI,OAAO,EAAE,+BAA+B;gBACxC,WAAW,EAAE,yBAAyB;aACzC;SACJ,uEAQiC,yBAAyB;;2FALlD,yBAAyB;kBAXrC,SAAS;mBAAC;oBACP,QAAQ,EAAE,oBAAoB;oBAC9B,QAAQ,EAAE,kBAAkB;oBAC5B,SAAS,EAAE;wBACP;4BACI,OAAO,EAAE,+BAA+B;4BACxC,WAAW,2BAA2B;yBACzC;qBACJ;oBACD,UAAU,EAAE,IAAI;iBACnB;;0BAsBQ,MAAM;2BAAC,+BAA+B;;0BAAG,QAAQ;;0BAAI,QAAQ;;0BAC7D,MAAM;2BAAC,8BAA8B;kEAnBpB,SAAS;sBAA9B,WAAW;uBAAC,OAAO;gBAGb,QAAQ;sBADd,eAAe;uBAAC,UAAU,CAAC,GAAG,EAAE,CAAC,yBAAyB,CAAC,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE;gBAW1E,cAAc;sBAAtB,KAAK;gBAEG,iBAAiB;sBAAzB,KAAK;;AA+CV,MAAM,OAAO,wBAAwB;IAYjC,YAC4E,YAAuC,EAC7E,UAA+B;QADO,iBAAY,GAAZ,YAAY,CAA2B;QAC7E,eAAU,GAAV,UAAU,CAAqB;QAb/C,cAAS,GAAG,mBAAmB,CAAC;QAEtD,YAAO,GAAgC,EAAE,CAAC;QAI1C;;WAEG;QACM,qBAAgB,GAAG,CAAC,CAAC;IAK3B,CAAC;IAEJ,QAAQ,KAAU,CAAC;IAEnB,kBAAkB;QACd,IAAI,CAAC,aAAa,EAAE,CAAC;IACzB,CAAC;IAED,aAAa;QACT,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE;YAC1C,IAAI,OAAO,CAAC,WAAW,IAAI,OAAO,CAAC,WAAW,KAAK,IAAI,EAAE,CAAC;gBACtD,OAAO,IAAI,CAAC;YAChB,CAAC;iBAAM,CAAC;gBACJ,OAAO,KAAK,CAAC;YACjB,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAED,gBAAgB;QACZ,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,OAAO,IAAI,CAAC,YAAY,CAAC,SAAS,EAAE,CAAC;QACzC,CAAC;aAAM,CAAC;YACJ,OAAO,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC;QAClC,CAAC;IACL,CAAC;IAED,QAAQ;QACJ,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC;IACnC,CAAC;IAED,QAAQ;QACJ,OAAO,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IAC3B,CAAC;IAED,OAAO;QACH,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;IACjD,CAAC;8GAnDQ,wBAAwB,kBAarB,+BAA+B,6CAC/B,iBAAiB;kGAdpB,wBAAwB,uKARtB;YACP;gBACI,OAAO,EAAE,8BAA8B;gBACvC,WAAW,EAAE,wBAAwB;aACxC;SACJ,mDAQgB,yBAAyB;;2FALjC,wBAAwB;kBAXpC,SAAS;mBAAC;oBACP,QAAQ,EAAE,mBAAmB;oBAC7B,QAAQ,EAAE,iBAAiB;oBAC3B,SAAS,EAAE;wBACP;4BACI,OAAO,EAAE,8BAA8B;4BACvC,WAAW,0BAA0B;yBACxC;qBACJ;oBACD,UAAU,EAAE,IAAI;iBACnB;;0BAcQ,MAAM;2BAAC,+BAA+B;;0BAAG,QAAQ;;0BAAI,QAAQ;;0BAC7D,MAAM;2BAAC,iBAAiB;yCAbP,SAAS;sBAA9B,WAAW;uBAAC,OAAO;gBAIsD,QAAQ;sBAAjF,eAAe;uBAAC,yBAAyB,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE;gBAKxD,gBAAgB;sBAAxB,KAAK;;AAuDV,MAAM,OAAO,mBAAmB;IAqB5B,YACY,MAAc,EACd,UAAmC;QADnC,WAAM,GAAN,MAAM,CAAQ;QACd,eAAU,GAAV,UAAU,CAAyB;QAtBzB,cAAS,GAAG,uBAAuB,CAAC;QAQnD,WAAM,GAA+B,EAAE,CAAC;QAQtC,wBAAmB,GAAG,IAAI,CAAC;QAE1B,qBAAgB,GAAG,IAAI,YAAY,EAAyB,CAAC;IAKpE,CAAC;IAEJ,QAAQ,KAAU,CAAC;IAEnB,kBAAkB;QACd,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,mBAAmB,EAAE,CAAC;YACrD,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,EAAE,MAAM,CAAC,CAAC;QAChE,CAAC;QACD,IAAI,CAAC,0BAA0B,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YAC1F,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,EAAE,MAAM,CAAC,CAAC;QAC7E,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,GAAG,EAAE;YAC/B,IAAI,CAAC,qBAAqB,GAAG,SAAS,CAClC,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,UAAU,CAAC,aAAa,EACvD,SAAS,CACZ,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;gBAChB,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YAC9B,CAAC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACP,CAAC;IAED,YAAY;QACR,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE;YACtC,KAAK,CAAC,aAAa,EAAE,CAAC;YACtB,IAAI,CAAC,KAAK,CAAC,YAAY,IAAI,KAAK,CAAC,QAAQ,EAAE,EAAE,CAAC;gBAC1C,OAAO,IAAI,CAAC;YAChB,CAAC;iBAAM,CAAC;gBACJ,OAAO,KAAK,CAAC;YACjB,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAED,aAAa,CAAC,KAAoB;QAC9B,MAAM,EAAE,OAAO,EAAE,GAAG,KAAK,CAAC;QAC1B,IAAI,CAAC,IAAI,CAAC,YAAY,IAAI,CAAC,OAAO,KAAK,UAAU,IAAI,OAAO,KAAK,QAAQ,IAAI,OAAO,KAAK,WAAW,IAAI,OAAO,KAAK,UAAU,CAAC,EAAE,CAAC;YAC9H,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,EAAE,MAAM,CAAC,CAAC;YAC5D,OAAO;QACX,CAAC;QAED,QAAQ,OAAO,EAAE,CAAC;YACd,KAAK,UAAU;gBACX,IAAI,CAAC,iBAAiB,EAAE,CAAC;gBACzB,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,MAAM;YACV,KAAK,QAAQ;gBACT,IAAI,CAAC,qBAAqB,EAAE,CAAC;gBAC7B,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,MAAM;YACV,KAAK,WAAW;gBACZ,IAAI,CAAC,iBAAiB,EAAE,CAAC;gBACzB,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,MAAM;YACV,KAAK,UAAU;gBACX,IAAI,CAAC,qBAAqB,EAAE,CAAC;gBAC7B,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,MAAM;YACV,KAAK,KAAK;gBACN,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,YAAY,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC,CAAC;gBAC1E,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,MAAM;QACd,CAAC;IACL,CAAC;IAED;;OAEG;IACH,qBAAqB;QACjB,IAAI,IAAI,CAAC,YAAY,CAAC,YAAY,EAAE,CAAC;YACjC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,YAAY,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;QACpF,CAAC;aAAM,CAAC;YACJ,MAAM,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,OAAO,CAAC;YAC3D,IAAI,WAAW,GAAG,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YAC1D,IAAI,cAAc,GAAG,WAAW,GAAG,CAAC,CAAC;YACrC,IAAI,cAAc,IAAI,CAAC,EAAE,CAAC;gBACtB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,YAAY,EAAE,YAAY,CAAC,cAAc,CAAC,EAAE,MAAM,CAAC,CAAC;YAChF,CAAC;iBAAM,CAAC;gBACJ,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC9B,CAAC;QACL,CAAC;IACL,CAAC;IAED;;OAEG;IACH,iBAAiB,CAAC,YAAwC;QACtD,MAAM,aAAa,GAAG,YAAY,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC;QACtE,MAAM,YAAY,GAAG,aAAa,CAAC,WAAW,CAAC,OAAO,CAAC;QACvD,IAAI,WAAW,GAAG,YAAY,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;QACtD,IAAI,cAAc,GAAG,WAAW,GAAG,aAAa,CAAC,WAAW,CAAC,gBAAgB,CAAC;QAC9E,MAAM,cAAc,GAAG,YAAY,CAAC,MAAM,GAAG,aAAa,CAAC,WAAW,CAAC,gBAAgB,CAAC;QACxF,MAAM,kBAAkB,GAAG,YAAY,CAAC,MAAM,GAAG,CAAC,cAAc,GAAG,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC3F,IAAI,SAAS,GAAG,IAAI,CAAC;QACrB,IAAI,cAAc,IAAI,YAAY,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC5C,SAAS,GAAG,YAAY,CAAC,cAAc,CAAC,CAAC;QAC7C,CAAC;aAAM,IAAI,WAAW,GAAG,kBAAkB,EAAE,CAAC;YAC1C,cAAc,GAAG,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC;YACzC,SAAS,GAAG,YAAY,CAAC,cAAc,CAAC,CAAC;QAC7C,CAAC;QACD,IAAI,SAAS,EAAE,CAAC;YACZ,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,YAAY,EAAE,SAAS,EAAE,MAAM,CAAC,CAAC;QAC7D,CAAC;aAAM,CAAC;YACJ,IAAI,CAAC,cAAc,EAAE,CAAC;QAC1B,CAAC;IACL,CAAC;IAED;;OAEG;IACH,iBAAiB;QACb,IAAI,IAAI,CAAC,YAAY,CAAC,QAAQ,EAAE,CAAC;YAC7B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;QACjF,CAAC;aAAM,CAAC;YACJ,MAAM,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,OAAO,CAAC;YAC3D,IAAI,WAAW,GAAG,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YAC1D,IAAI,cAAc,GAAG,WAAW,GAAG,CAAC,CAAC;YACrC,IAAI,cAAc,IAAI,YAAY,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAC5C,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,YAAY,EAAE,YAAY,CAAC,cAAc,CAAC,EAAE,MAAM,CAAC,CAAC;YAChF,CAAC;iBAAM,CAAC;gBACJ,IAAI,CAAC,cAAc,EAAE,CAAC;YAC1B,CAAC;QACL,CAAC;IACL,CAAC;IAED;;OAEG;IACH,qBAAqB;QACjB,MAAM,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,OAAO,CAAC;QAC3D,IAAI,WAAW,GAAG,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QAC1D,IAAI,cAAc,GAAG,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,gBAAgB,CAAC;QAClF,IAAI,cAAc,IAAI,CAAC,EAAE,CAAC;YACtB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,YAAY,EAAE,YAAY,CAAC,cAAc,CAAC,EAAE,MAAM,CAAC,CAAC;QAChF,CAAC;aAAM,CAAC;YACJ,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC9B,CAAC;IACL,CAAC;IAED,cAAc;QACV,MAAM,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,gBAAgB,EAAE,CAAC;QAChE,MAAM,UAAU,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC;QACjE,IAAI,aAAa,GAAG,UAAU,GAAG,CAAC,CAAC;QACnC,IAAI,aAAa,GAAG,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACpC,aAAa,GAAG,CAAC,CAAC;QACtB,CAAC;QACD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,YAAY,EAAE,MAAM,CAAC,aAAa,CAAC,CAAC,QAAQ,EAAE,EAAE,MAAM,CAAC,CAAC;IACpF,CAAC;IAED,kBAAkB;QACd,MAAM,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,gBAAgB,EAAE,CAAC;QAChE,MAAM,UAAU,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC;QACjE,IAAI,aAAa,GAAG,UAAU,GAAG,CAAC,CAAC;QACnC,IAAI,aAAa,GAAG,CAAC,EAAE,CAAC;YACpB,aAAa,GAAG,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC;QACtC,CAAC;QACD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,YAAY,EAAE,MAAM,CAAC,aAAa,CAAC,CAAC,OAAO,EAAE,EAAE,MAAM,CAAC,CAAC;IACnF,CAAC;IAED,aAAa,CAAC,QAA0C,EAAE,MAAiC,EAAE,IAA+B;QACxH,IAAI,QAAQ,EAAE,CAAC;YACX,QAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QAC9B,CAAC;QACD,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QACvB,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC;QAC3B,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC;IACjD,CAAC;IAED,WAAW;QACP,IAAI,CAAC,0BAA0B,CAAC,WAAW,EAAE,CAAC;QAC9C,IAAI,CAAC,qBAAqB,CAAC,WAAW,EAAE,CAAC;IAC7C,CAAC;8GAnMQ,mBAAmB;kGAAnB,mBAAmB,mQARjB;YACP;gBACI,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,mBAAmB;aACnC;SACJ,kDAcgB,wBAAwB,8DAExB,yBAAyB;;2FAbjC,mBAAmB;kBAX/B,SAAS;mBAAC;oBACP,QAAQ,EAAE,cAAc;oBACxB,QAAQ,EAAE,YAAY;oBACtB,SAAS,EAAE;wBACP;4BACI,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,qBAAqB;yBACnC;qBACJ;oBACD,UAAU,EAAE,IAAI;iBACnB;oGAEyB,SAAS;sBAA9B,WAAW;uBAAC,OAAO;gBAUwD,OAAO;sBAAlF,eAAe;uBAAC,wBAAwB,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE;gBAEa,QAAQ;sBAApF,eAAe;uBAAC,yBAAyB,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE;gBAExD,iBAAiB;sBAAzB,KAAK;gBAEG,mBAAmB;sBAA3B,KAAK;gBAEI,gBAAgB;sBAAzB,MAAM","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"]}