@worktile/theia 14.2.1 → 14.2.4

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,7 +1,8 @@
1
- import { DOWN_ARROW, LEFT_ARROW, RIGHT_ARROW, UP_ARROW } from '@angular/cdk/keycodes';
1
+ import { DOWN_ARROW, LEFT_ARROW, ENTER, RIGHT_ARROW, UP_ARROW } from '@angular/cdk/keycodes';
2
2
  import { Optional, SkipSelf } from '@angular/core';
3
3
  import { ContentChildren, Directive, EventEmitter, HostBinding, Inject, Input, Output } from '@angular/core';
4
4
  import { fromEvent } from 'rxjs';
5
+ import { debounceTime } from 'rxjs/operators';
5
6
  import { THE_LISTBOX_TOKEN, THE_LISTBOX_PARENT_OPTION_TOKEN, THE_LISTBOX_PARENT_GROUP_TOKEN } from './listbox.type';
6
7
  import * as i0 from "@angular/core";
7
8
  export class TheListboxOptionDirective {
@@ -32,10 +33,10 @@ export class TheListboxOptionDirective {
32
33
  setActive(active) {
33
34
  this._active = active;
34
35
  if (active) {
35
- this.elementRef.nativeElement.classList.add('active');
36
+ this.elementRef.nativeElement.classList.add('focus');
36
37
  }
37
38
  else {
38
- this.elementRef.nativeElement.classList.remove('active');
39
+ this.elementRef.nativeElement.classList.remove('focus');
39
40
  }
40
41
  }
41
42
  getActive() {
@@ -43,17 +44,17 @@ export class TheListboxOptionDirective {
43
44
  }
44
45
  }
45
46
  TheListboxOptionDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: TheListboxOptionDirective, deps: [{ token: THE_LISTBOX_PARENT_OPTION_TOKEN, optional: true, skipSelf: true }, { token: THE_LISTBOX_PARENT_GROUP_TOKEN }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
46
- TheListboxOptionDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.0", type: TheListboxOptionDirective, selector: "[theListboxOpton]", host: { properties: { "class": "this.className" } }, providers: [
47
+ TheListboxOptionDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.0", type: TheListboxOptionDirective, selector: "[theListboxOption]", inputs: { theOptionValue: "theOptionValue" }, host: { properties: { "class": "this.className" } }, providers: [
47
48
  {
48
49
  provide: THE_LISTBOX_PARENT_OPTION_TOKEN,
49
50
  useExisting: TheListboxOptionDirective
50
51
  }
51
- ], queries: [{ propertyName: "_options", predicate: TheListboxOptionDirective, descendants: true }], exportAs: ["theListboxOpton"], ngImport: i0 });
52
+ ], queries: [{ propertyName: "_options", predicate: TheListboxOptionDirective, descendants: true }], exportAs: ["theListboxOption"], ngImport: i0 });
52
53
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: TheListboxOptionDirective, decorators: [{
53
54
  type: Directive,
54
55
  args: [{
55
- selector: '[theListboxOpton]',
56
- exportAs: 'theListboxOpton',
56
+ selector: '[theListboxOption]',
57
+ exportAs: 'theListboxOption',
57
58
  providers: [
58
59
  {
59
60
  provide: THE_LISTBOX_PARENT_OPTION_TOKEN,
@@ -77,6 +78,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
77
78
  }], _options: [{
78
79
  type: ContentChildren,
79
80
  args: [TheListboxOptionDirective, { descendants: true }]
81
+ }], theOptionValue: [{
82
+ type: Input
80
83
  }] } });
81
84
  export class TheListboxGroupDirective {
82
85
  constructor(parentOption, theListBox) {
@@ -111,6 +114,9 @@ export class TheListboxGroupDirective {
111
114
  return this.theListBox.groups;
112
115
  }
113
116
  }
117
+ hasChild() {
118
+ return this.options.length > 0;
119
+ }
114
120
  getFirst() {
115
121
  return this.options[0];
116
122
  }
@@ -162,7 +168,7 @@ export class TheListboxDirective {
162
168
  this.elementRef = elementRef;
163
169
  this.className = 'the-listbox-container';
164
170
  this.groups = [];
165
- this.theActiveOptionChange = new EventEmitter();
171
+ this.theListboxChange = new EventEmitter();
166
172
  }
167
173
  ngOnInit() { }
168
174
  ngAfterContentInit() {
@@ -170,9 +176,9 @@ export class TheListboxDirective {
170
176
  if (this.groups.length > 0) {
171
177
  this.setActiveItem(null, this.groups[0].getFirst(), 'init');
172
178
  }
173
- this._optionChangesSubscription = this._groups.changes.subscribe(() => {
179
+ this._optionChangesSubscription = this._options.changes.pipe(debounceTime(20)).subscribe(() => {
174
180
  this.filterGroups();
175
- this.setActiveItem(null, this.groups[0].getFirst(), 'init');
181
+ this.setActiveItem(this.activeOption, this.groups[0].getFirst(), 'init');
176
182
  });
177
183
  this.ngZone.runOutsideAngular(() => {
178
184
  this._keyboardSubscription = fromEvent(this.keyboardContainer || this.elementRef.nativeElement, 'keydown').subscribe(event => {
@@ -182,7 +188,8 @@ export class TheListboxDirective {
182
188
  }
183
189
  filterGroups() {
184
190
  this.groups = this._groups.filter(group => {
185
- if (!group.parentOption) {
191
+ group.filterOptions();
192
+ if (!group.parentOption && group.hasChild()) {
186
193
  return true;
187
194
  }
188
195
  else {
@@ -209,6 +216,10 @@ export class TheListboxDirective {
209
216
  this.setPreviousItemActive();
210
217
  event.preventDefault();
211
218
  break;
219
+ case ENTER:
220
+ this.theListboxChange.emit({ option: this.activeOption, type: 'select' });
221
+ event.preventDefault();
222
+ break;
212
223
  }
213
224
  }
214
225
  /**
@@ -301,7 +312,7 @@ export class TheListboxDirective {
301
312
  }
302
313
  option.setActive(true);
303
314
  this.activeOption = option;
304
- this.theActiveOptionChange.emit({ option, type });
315
+ this.theListboxChange.emit({ option, type });
305
316
  }
306
317
  ngOnDestroy() {
307
318
  this._optionChangesSubscription.unsubscribe();
@@ -309,12 +320,12 @@ export class TheListboxDirective {
309
320
  }
310
321
  }
311
322
  TheListboxDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: TheListboxDirective, deps: [{ token: i0.NgZone }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
312
- TheListboxDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.0", type: TheListboxDirective, selector: "[theListBox]", inputs: { keyboardContainer: "keyboardContainer" }, outputs: { theActiveOptionChange: "theActiveOptionChange" }, host: { properties: { "class": "this.className" } }, providers: [
323
+ TheListboxDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.0", type: TheListboxDirective, selector: "[theListBox]", inputs: { keyboardContainer: "keyboardContainer" }, outputs: { theListboxChange: "theListboxChange" }, host: { properties: { "class": "this.className" } }, providers: [
313
324
  {
314
325
  provide: THE_LISTBOX_TOKEN,
315
326
  useExisting: TheListboxDirective
316
327
  }
317
- ], queries: [{ propertyName: "_groups", predicate: TheListboxGroupDirective, descendants: true }], exportAs: ["theListBox"], ngImport: i0 });
328
+ ], queries: [{ propertyName: "_groups", predicate: TheListboxGroupDirective, descendants: true }, { propertyName: "_options", predicate: TheListboxOptionDirective, descendants: true }], exportAs: ["theListBox"], ngImport: i0 });
318
329
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: TheListboxDirective, decorators: [{
319
330
  type: Directive,
320
331
  args: [{
@@ -333,9 +344,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
333
344
  }], _groups: [{
334
345
  type: ContentChildren,
335
346
  args: [TheListboxGroupDirective, { descendants: true }]
347
+ }], _options: [{
348
+ type: ContentChildren,
349
+ args: [TheListboxOptionDirective, { descendants: true }]
336
350
  }], keyboardContainer: [{
337
351
  type: Input
338
- }], theActiveOptionChange: [{
352
+ }], theListboxChange: [{
339
353
  type: Output
340
354
  }] } });
341
- //# 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, RIGHT_ARROW, UP_ARROW } from '@angular/cdk/keycodes';\nimport { 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 {\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: '[theListboxOpton]',\n    exportAs: 'theListboxOpton',\n    providers: [\n        {\n            provide: THE_LISTBOX_PARENT_OPTION_TOKEN,\n            useExisting: TheListboxOptionDirective\n        }\n    ]\n})\nexport class TheListboxOptionDirective implements OnInit, AfterContentInit {\n    private _active = false;\n\n    @HostBinding('class') className = 'the-listbox-option';\n\n    @ContentChildren(TheListboxOptionDirective, { descendants: true }) 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    constructor(\n        @Inject(THE_LISTBOX_PARENT_OPTION_TOKEN) @Optional() @SkipSelf() public parentOption: TheListboxOptionDirective,\n        @Inject(THE_LISTBOX_PARENT_GROUP_TOKEN) public parentGroup: TheListboxGroupDirective,\n        private 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('active');\n        } else {\n            this.elementRef.nativeElement.classList.remove('active');\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})\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    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})\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    @Input() keyboardContainer: HTMLElement;\n\n    @Output() theActiveOptionChange = new EventEmitter<TheListboxChangeEvent>();\n\n    constructor(private ngZone: NgZone, private elementRef: ElementRef<HTMLElement>) {}\n\n    ngOnInit(): void {}\n\n    ngAfterContentInit(): void {\n        this.filterGroups();\n        if (this.groups.length > 0) {\n            this.setActiveItem(null, this.groups[0].getFirst(), 'init');\n        }\n        this._optionChangesSubscription = this._groups.changes.subscribe(() => {\n            this.filterGroups();\n            this.setActiveItem(null, 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            if (!group.parentOption) {\n                return true;\n            } else {\n                return false;\n            }\n        });\n    }\n\n    handleKeydown(event: KeyboardEvent) {\n        const { keyCode } = event;\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        }\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() {\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 <= groupOptions.length - 1) {\n            this.setActiveItem(this.activeOption, groupOptions[newOptionIndex], '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.theActiveOptionChange.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"]}
355
+ //# 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 } from '@angular/cdk/keycodes';\nimport { 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})\nexport class TheListboxOptionDirective implements OnInit, AfterContentInit {\n    private _active = false;\n\n    @HostBinding('class') className = 'the-listbox-option';\n\n    @ContentChildren(TheListboxOptionDirective, { descendants: true }) 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    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})\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})\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    @Output() theListboxChange = new EventEmitter<TheListboxChangeEvent>();\n\n    constructor(private ngZone: NgZone, private elementRef: ElementRef<HTMLElement>) {}\n\n    ngOnInit(): void {}\n\n    ngAfterContentInit(): void {\n        this.filterGroups();\n        if (this.groups.length > 0) {\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        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() {\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 <= groupOptions.length - 1) {\n            this.setActiveItem(this.activeOption, groupOptions[newOptionIndex], '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"]}
@@ -2,4 +2,4 @@ import { InjectionToken } from '@angular/core';
2
2
  export const THE_LISTBOX_PARENT_OPTION_TOKEN = new InjectionToken('THE_LISTBOX_PARENT_OPTION_TOKEN');
3
3
  export const THE_LISTBOX_PARENT_GROUP_TOKEN = new InjectionToken('THE_LISTBOX_PARENT_GROUP_TOKEN');
4
4
  export const THE_LISTBOX_TOKEN = new InjectionToken('THE_LISTBOX_TOKEN');
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdGJveC50eXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvc3JjL2NvbXBvbmVudHMvbGlzdGJveC9saXN0Ym94LnR5cGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUvQyxNQUFNLENBQUMsTUFBTSwrQkFBK0IsR0FBRyxJQUFJLGNBQWMsQ0FBQyxpQ0FBaUMsQ0FBQyxDQUFDO0FBRXJHLE1BQU0sQ0FBQyxNQUFNLDhCQUE4QixHQUFHLElBQUksY0FBYyxDQUFDLGdDQUFnQyxDQUFDLENBQUM7QUFFbkcsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsSUFBSSxjQUFjLENBQUMsbUJBQW1CLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGlvblRva2VuIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCBjb25zdCBUSEVfTElTVEJPWF9QQVJFTlRfT1BUSU9OX1RPS0VOID0gbmV3IEluamVjdGlvblRva2VuKCdUSEVfTElTVEJPWF9QQVJFTlRfT1BUSU9OX1RPS0VOJyk7XG5cbmV4cG9ydCBjb25zdCBUSEVfTElTVEJPWF9QQVJFTlRfR1JPVVBfVE9LRU4gPSBuZXcgSW5qZWN0aW9uVG9rZW4oJ1RIRV9MSVNUQk9YX1BBUkVOVF9HUk9VUF9UT0tFTicpO1xuXG5leHBvcnQgY29uc3QgVEhFX0xJU1RCT1hfVE9LRU4gPSBuZXcgSW5qZWN0aW9uVG9rZW4oJ1RIRV9MSVNUQk9YX1RPS0VOJyk7XG5cbmV4cG9ydCB0eXBlIFRoZUxpc3Rib3hDaGFuZ2VFdmVudFR5cGUgPSAndHVybicgfCAnY2hpbGQnIHwgJ3BhcmVudCcgfCAnaW5pdCc7XG4iXX0=
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdGJveC50eXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvc3JjL2NvbXBvbmVudHMvbGlzdGJveC9saXN0Ym94LnR5cGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUvQyxNQUFNLENBQUMsTUFBTSwrQkFBK0IsR0FBRyxJQUFJLGNBQWMsQ0FBQyxpQ0FBaUMsQ0FBQyxDQUFDO0FBRXJHLE1BQU0sQ0FBQyxNQUFNLDhCQUE4QixHQUFHLElBQUksY0FBYyxDQUFDLGdDQUFnQyxDQUFDLENBQUM7QUFFbkcsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsSUFBSSxjQUFjLENBQUMsbUJBQW1CLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGlvblRva2VuIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCBjb25zdCBUSEVfTElTVEJPWF9QQVJFTlRfT1BUSU9OX1RPS0VOID0gbmV3IEluamVjdGlvblRva2VuKCdUSEVfTElTVEJPWF9QQVJFTlRfT1BUSU9OX1RPS0VOJyk7XG5cbmV4cG9ydCBjb25zdCBUSEVfTElTVEJPWF9QQVJFTlRfR1JPVVBfVE9LRU4gPSBuZXcgSW5qZWN0aW9uVG9rZW4oJ1RIRV9MSVNUQk9YX1BBUkVOVF9HUk9VUF9UT0tFTicpO1xuXG5leHBvcnQgY29uc3QgVEhFX0xJU1RCT1hfVE9LRU4gPSBuZXcgSW5qZWN0aW9uVG9rZW4oJ1RIRV9MSVNUQk9YX1RPS0VOJyk7XG5cbmV4cG9ydCB0eXBlIFRoZUxpc3Rib3hDaGFuZ2VFdmVudFR5cGUgPSAndHVybicgfCAnY2hpbGQnIHwgJ3BhcmVudCcgfCAnaW5pdCcgfCAnc2VsZWN0JztcbiJdfQ==
@@ -1,5 +1,5 @@
1
- import { Component, Input, HostBinding } from '@angular/core';
2
- import { mixinUnsubscribe, MixinBase } from 'ngx-tethys/core';
1
+ import { Component, Input, HostBinding, ViewChildren } from '@angular/core';
2
+ import { mixinUnsubscribe, MixinBase, ScrollToService } from 'ngx-tethys/core';
3
3
  import { Editor, Node } from 'slate';
4
4
  import { AngularEditor } from 'slate-angular';
5
5
  import { buildPluginMenu, buildPluginMenuItemMap } from '../../core/utils/plugin-menu';
@@ -8,20 +8,26 @@ import { ThePluginMenu } from '../../interfaces/plugins/plugin-menu';
8
8
  import { getPluginOptions } from '../../core';
9
9
  import { PluginKeys } from '../../interfaces';
10
10
  import { QuickInsertEditor } from '../../plugins/public-api';
11
+ import { ThyDropdownDirective } from 'ngx-tethys/dropdown';
11
12
  import * as i0 from "@angular/core";
12
13
  import * as i1 from "@angular/common";
13
- import * as i2 from "ngx-tethys/icon";
14
- import * as i3 from "ngx-tethys/tooltip";
15
- import * as i4 from "ngx-tethys/action";
16
- import * as i5 from "ngx-tethys/divider";
17
- import * as i6 from "ngx-tethys/dropdown";
18
- import * as i7 from "ngx-tethys/empty";
19
- import * as i8 from "../table-select/table-select.component";
14
+ import * as i2 from "@angular/forms";
15
+ import * as i3 from "ngx-tethys/icon";
16
+ import * as i4 from "ngx-tethys/tooltip";
17
+ import * as i5 from "ngx-tethys/input";
18
+ import * as i6 from "ngx-tethys/action";
19
+ import * as i7 from "ngx-tethys/divider";
20
+ import * as i8 from "ngx-tethys/dropdown";
21
+ import * as i9 from "ngx-tethys/empty";
22
+ import * as i10 from "../table-select/table-select.component";
23
+ import * as i11 from "../listbox/listbox";
24
+ import * as i12 from "../action/prevent-default";
20
25
  export class ThePluginMenuComponent extends mixinUnsubscribe(MixinBase) {
21
- constructor(elementRef, cdr) {
26
+ constructor(elementRef, cdr, ngZone) {
22
27
  super();
23
28
  this.elementRef = elementRef;
24
29
  this.cdr = cdr;
30
+ this.ngZone = ngZone;
25
31
  this.ThePluginMenu = ThePluginMenu;
26
32
  this.groupMenu = [];
27
33
  this.iconMenu = [];
@@ -35,6 +41,7 @@ export class ThePluginMenuComponent extends mixinUnsubscribe(MixinBase) {
35
41
  width: '266px'
36
42
  };
37
43
  this.containerClassName = `the-plugin-menu-container`;
44
+ this.theDisplaySearch = false;
38
45
  this.removeKeywords = () => {
39
46
  const hotkey = getPluginOptions(this.editor, PluginKeys.quickInsert)?.hotkey;
40
47
  const node = Node.get(this.editor, this.editor.selection.anchor.path);
@@ -47,56 +54,94 @@ export class ThePluginMenuComponent extends mixinUnsubscribe(MixinBase) {
47
54
  this.editorElement = AngularEditor.toDOMNode(this.editor, this.editor);
48
55
  let currentMenu = this.editor.options.menu ? this.editor.options.menu : DefaultPluginMenu;
49
56
  const menuItemsMap = buildPluginMenuItemMap(this.editor);
50
- this.pluginMenu = buildPluginMenu(menuItemsMap, currentMenu);
57
+ this._pluginMenu = buildPluginMenu(menuItemsMap, currentMenu);
51
58
  this.buildMenus();
52
59
  }
53
60
  buildMenus() {
54
61
  if (this.keyWords) {
55
62
  this.iconMenu = [];
56
- this.groupMenu = this.pluginMenu.filter((item) => {
57
- return item?.keywords && item?.keywords.includes(this.keyWords);
63
+ this.groupMenu = [];
64
+ this._pluginMenu.forEach((item) => {
65
+ if (ThePluginMenu.isMenuItem(item)) {
66
+ if (item.keywords && item.keywords?.includes(this.keyWords)) {
67
+ this.groupMenu.push(item);
68
+ }
69
+ if (item.children && item.children.length > 0) {
70
+ item.children.forEach((child) => {
71
+ if (child.keywords && item.keywords?.includes(this.keyWords)) {
72
+ this.groupMenu.push(child);
73
+ }
74
+ });
75
+ }
76
+ }
58
77
  });
59
78
  if (this.groupMenu.length > 0) {
60
79
  this.groupMenu.unshift(this.searchGroup);
61
80
  }
62
81
  }
63
82
  else {
64
- this.iconMenu = this.pluginMenu.filter((item) => {
83
+ this.iconMenu = this._pluginMenu.filter((item) => {
65
84
  return item?.type === ThePluginMenuItemType.icon;
66
85
  });
67
- this.groupMenu = this.pluginMenu.filter((item) => {
86
+ this.groupMenu = this._pluginMenu.filter((item) => {
68
87
  return item?.type !== ThePluginMenuItemType.icon;
69
88
  });
70
89
  }
71
90
  this.cdr.detectChanges();
72
91
  }
73
- executeItem(event, menuItem) {
74
- event.preventDefault();
75
- event.stopPropagation();
92
+ handleItemSelection(menuItem) {
76
93
  this.removeKeywords();
77
- const toolbarItem = this.pluginMenu.find((item) => item.key === menuItem.key);
78
- if (toolbarItem.execute) {
79
- toolbarItem.execute(this.editor);
80
- }
94
+ menuItem.execute(this.editor);
81
95
  QuickInsertEditor.closeMenu(this.editor);
82
96
  }
83
97
  updateKeywords(keywords) {
84
98
  this.keyWords = keywords.toLowerCase().trim();
85
99
  this.buildMenus();
86
100
  }
101
+ theListboxChange(event) {
102
+ if (event.type === 'select') {
103
+ this.handleItemSelection(event.option.theOptionValue);
104
+ }
105
+ if (event.type === 'child') {
106
+ const dropdown = this.findDropdownTrigger(event.option.parentOption);
107
+ this.ngZone.run(() => {
108
+ dropdown.show();
109
+ });
110
+ }
111
+ if (event.type === 'parent') {
112
+ const dropdown = this.findDropdownTrigger(event.option);
113
+ dropdown.hide();
114
+ }
115
+ if (event.type === 'turn') {
116
+ ScrollToService.scrollToElement(event.option.elementRef.nativeElement, this.elementRef.nativeElement);
117
+ }
118
+ }
119
+ findDropdownTrigger(option) {
120
+ const dropdown = this.dropdownTriggers.find(value => {
121
+ return value['elementRef'].nativeElement === option.elementRef.nativeElement;
122
+ });
123
+ return dropdown;
124
+ }
87
125
  ngOnDestroy() {
88
126
  super.ngOnDestroy();
89
127
  }
90
128
  }
91
- ThePluginMenuComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ThePluginMenuComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
92
- ThePluginMenuComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: ThePluginMenuComponent, selector: "the-plugin-menu", inputs: { editor: "editor" }, host: { properties: { "class": "this.containerClassName" } }, usesInheritance: true, ngImport: i0, template: "<div *ngIf=\"groupMenu.length > 0; else thyEmpty\" class=\"thy-dropdown-menu py-2\">\n <div class=\"icon-menu d-flex px-5 py-1\">\n <ng-container *ngFor=\"let item of iconMenu\">\n <a\n *ngIf=\"item.type === ThePluginMenuItemType.icon\"\n href=\"javascript:;\"\n class=\"mt-2\"\n thyAction\n [thyActionIcon]=\"item.icon\"\n [thyTooltip]=\"item.name\"\n (mousedown)=\"executeItem($event, item)\"\n ></a>\n </ng-container>\n </div>\n\n <thy-divider *ngIf=\"this.iconMenu?.length\" class=\"my-2\"></thy-divider>\n\n <ng-container *ngFor=\"let item of groupMenu\">\n <ng-container *ngIf=\"ThePluginMenu.isMenuItem(item) && !item.isExpanded\">\n <div thyDropdownMenuItem class=\"insert-menu-item mb-1 py-0\" (mousedown)=\"executeItem($event, item)\">\n <div class=\"menu-icon mr-2\">\n <thy-icon [thyIconName]=\"item.menuIcon\"></thy-icon>\n </div>\n <div class=\"menu-content d-flex align-items-center\">\n <div class=\"menu-item-title w-100\">\n <span *ngIf=\"!item?.isExpanded\" class=\"menu-item-display-key font-size-sm text-placeholder\">\n {{ item.displayKey }}</span\n >\n {{ item.name }}\n </div>\n <div class=\"text-muted font-size-sm\">{{ item.description }}</div>\n </div>\n </div>\n </ng-container>\n <ng-container *ngIf=\"ThePluginMenu.isMenuItem(item) && item.isExpanded\" #hasExpanded>\n <div\n [thyDropdown]=\"expand\"\n thyTrigger=\"hover\"\n thyDropdownMenuItem\n [thyPopoverOptions]=\"expandPopoverOptions\"\n class=\"insert-menu-item mb-1 py-0\"\n (mousedown)=\"executeItem($event, item)\"\n >\n <div class=\"menu-icon mr-2\">\n <thy-icon [thyIconName]=\"item.menuIcon\"></thy-icon>\n </div>\n <div class=\"menu-content d-flex align-items-center\">\n <div class=\"menu-item-title w-100\">\n <span *ngIf=\"!item?.isExpanded\" class=\"menu-item-display-key font-size-sm text-placeholder\">\n {{ item.displayKey }}</span\n >\n {{ item.name }}\n </div>\n <div class=\"text-muted font-size-sm\">{{ item.description }}</div>\n </div>\n <div *ngIf=\"item?.isExpanded\">\n <thy-icon class=\"text-muted\" thyIconName=\"angle-right\"></thy-icon>\n </div>\n </div>\n <thy-dropdown-menu class=\"expand-menu\" #expand>\n <div class=\"the-plugin-menu-container\">\n <div *ngFor=\"let child of item.children\" thyDropdownMenuItem class=\"insert-menu-item mb-1 py-0\">\n <div class=\"menu-icon mr-2\">\n <thy-icon [thyIconName]=\"child.menuIcon\"></thy-icon>\n </div>\n <div class=\"menu-content d-flex align-items-center\">\n <div class=\"menu-item-title w-100\">\n <span class=\"menu-item-display-key font-size-sm text-placeholder\"> {{ child.displayKey }}</span>\n {{ child.name }}\n </div>\n <div class=\"text-muted font-size-sm\">{{ child.description }}</div>\n </div>\n </div>\n </div>\n <table-select\n *ngIf=\"item.key === 'table'\"\n class=\"plugin-menu-table the-table-selector-panel\"\n [editor]=\"editor\"\n [beforeInsert]=\"removeKeywords\"\n ></table-select>\n </thy-dropdown-menu>\n </ng-container>\n\n <ng-container *ngIf=\"!ThePluginMenu.isMenuItem(item)\" #menuGroup>\n <thy-dropdown-menu-group class=\"font-size-sm\" [thyTitle]=\"item.groupName\"></thy-dropdown-menu-group>\n </ng-container>\n </ng-container>\n</div>\n\n<ng-template #thyEmpty>\n <div class=\"empty d-flex align-items-center justify-content-center\">\n <thy-empty [thyMessage]=\"thyMessage\"></thy-empty>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.ThyIconComponent, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "directive", type: i3.ThyTooltipDirective, selector: "[thyTooltip],[thy-tooltip]", inputs: ["thyTooltip", "thyTooltipPlacement", "thyTooltipClass", "thyTooltipShowDelay", "thyTooltipHideDelay", "thyTooltipTrigger", "thyTooltipDisabled", "thyTooltipTemplateContext", "thyTooltipOffset", "thyTooltipPin"], exportAs: ["thyTooltip"] }, { kind: "component", type: i4.ThyActionComponent, selector: "thy-action, [thyAction]", inputs: ["thyType", "thyIcon", "thyActionIcon", "thyActive", "thyActionActive", "thyTheme", "thyHoverIcon", "thyDisabled"] }, { kind: "component", type: i5.ThyDividerComponent, selector: "thy-divider", inputs: ["thyVertical", "thyStyle", "thyColor", "thyText", "thyTextDirection", "thyDeeper"] }, { kind: "directive", type: i6.ThyDropdownDirective, selector: "[thyDropdown]", inputs: ["thyDropdownMenu", "thyDropdown", "thyTrigger", "thyActiveClass", "thyPopoverOptions"], outputs: ["thyActiveChange"] }, { kind: "component", type: i6.ThyDropdownMenuComponent, selector: "thy-dropdown-menu", inputs: ["thyWidth"] }, { kind: "component", type: i6.ThyDropdownMenuGroupComponent, selector: "thy-dropdown-menu-group", inputs: ["thyTitle"] }, { kind: "directive", type: i6.ThyDropdownMenuItemDirective, selector: "[thyDropdownMenuItem]", inputs: ["thyType", "thyDisabled"] }, { kind: "component", type: i7.ThyEmptyComponent, selector: "thy-empty", inputs: ["thyMessage", "thyTranslationKey", "thyTranslationValues", "thyEntityName", "thyEntityNameTranslateKey", "thyIconName", "thySize", "thyMarginTop", "thyTopAuto", "thyContainer", "thyImageUrl", "thyImageLoading", "thyImageFetchPriority", "thyDescription"] }, { kind: "component", type: i8.TheTableSelectComponent, selector: "table-select", inputs: ["optionsParam", "editor", "beforeInsert"] }] });
129
+ ThePluginMenuComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ThePluginMenuComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
130
+ ThePluginMenuComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: ThePluginMenuComponent, selector: "the-plugin-menu", inputs: { editor: "editor", theDisplaySearch: "theDisplaySearch", thePluginMenu: "thePluginMenu" }, host: { properties: { "class": "this.containerClassName" } }, viewQueries: [{ propertyName: "dropdownTriggers", predicate: ["dropdownTriggers"], descendants: true, read: ThyDropdownDirective }], usesInheritance: true, ngImport: i0, template: "<div *ngIf=\"theDisplaySearch\" class=\"menu-search px-5 pt-5\">\n <thy-input-search [(ngModel)]=\"keyWords\" placeholder=\"\u641C\u7D22\" thyIconPosition=\"after\" (ngModelChange)=\"buildMenus()\"> </thy-input-search>\n</div>\n\n<div\n *ngIf=\"groupMenu.length > 0; else thyEmpty\"\n theListBox\n [keyboardContainer]=\"editorElement\"\n (theListboxChange)=\"theListboxChange($event)\"\n class=\"thy-dropdown-menu py-2\"\n>\n <div *ngIf=\"iconMenu?.length > 0\" theListboxGroup [horizontalColumn]=\"6\" class=\"icon-menu d-flex px-5 py-1\">\n <ng-container *ngFor=\"let item of iconMenu\">\n <a\n *ngIf=\"item.type === ThePluginMenuItemType.icon\"\n href=\"javascript:;\"\n class=\"mt-2\"\n thyAction\n theListboxOption\n [theOptionValue]=\"item\"\n [thyActionIcon]=\"item.icon\"\n [thyTooltip]=\"item.name\"\n thePreventDefault\n (click)=\"handleItemSelection(item)\"\n ></a>\n </ng-container>\n </div>\n\n <thy-divider *ngIf=\"this.iconMenu?.length\" class=\"my-2\"></thy-divider>\n <div theListboxGroup>\n <ng-container *ngFor=\"let item of groupMenu\">\n <ng-container *ngIf=\"ThePluginMenu.isMenuItem(item) && !item.isExpanded\">\n <div\n thyDropdownMenuItem\n theListboxOption\n [theOptionValue]=\"item\"\n class=\"insert-menu-item mb-1 py-0\"\n thePreventDefault\n (click)=\"handleItemSelection(item)\"\n >\n <div class=\"menu-icon mr-2\">\n <thy-icon [thyIconName]=\"item.menuIcon\"></thy-icon>\n </div>\n <div class=\"menu-content d-flex align-items-center\">\n <div class=\"menu-item-title w-100\">\n <span *ngIf=\"!item?.isExpanded\" class=\"menu-item-display-key font-size-sm text-placeholder\">\n {{ item.displayKey }}</span\n >\n {{ item.name }}\n </div>\n <div class=\"text-muted font-size-sm\">{{ item.description }}</div>\n </div>\n </div>\n </ng-container>\n <ng-container *ngIf=\"ThePluginMenu.isMenuItem(item) && item.isExpanded\" #hasExpanded>\n <div\n #dropdownTriggers\n [thyDropdown]=\"expand\"\n thyTrigger=\"hover\"\n thyDropdownMenuItem\n theListboxOption\n [theOptionValue]=\"item\"\n [thyPopoverOptions]=\"expandPopoverOptions\"\n class=\"insert-menu-item mb-1 py-0\"\n thePreventDefault\n (click)=\"handleItemSelection(item)\"\n >\n <div class=\"menu-icon mr-2\">\n <thy-icon [thyIconName]=\"item.menuIcon\"></thy-icon>\n </div>\n <div class=\"menu-content d-flex align-items-center\">\n <div class=\"menu-item-title w-100\">\n <span *ngIf=\"!item?.isExpanded\" class=\"menu-item-display-key font-size-sm text-placeholder\">\n {{ item.displayKey }}</span\n >\n {{ item.name }}\n </div>\n <div class=\"text-muted font-size-sm\">{{ item.description }}</div>\n </div>\n <div *ngIf=\"item?.isExpanded\">\n <thy-icon class=\"text-muted\" thyIconName=\"angle-right\"></thy-icon>\n </div>\n <thy-dropdown-menu class=\"expand-menu\" #expand>\n <div class=\"the-plugin-menu-container\" theListboxGroup>\n <div\n *ngFor=\"let child of item.children\"\n thyDropdownMenuItem\n theListboxOption\n class=\"insert-menu-item mb-1 py-0\"\n thePreventDefault\n (click)=\"handleItemSelection(child)\"\n [theOptionValue]=\"child\"\n >\n <div class=\"menu-icon mr-2\">\n <thy-icon [thyIconName]=\"child.menuIcon\"></thy-icon>\n </div>\n <div class=\"menu-content d-flex align-items-center\">\n <div class=\"menu-item-title w-100\">\n <span class=\"menu-item-display-key font-size-sm text-placeholder\"> {{ child.displayKey }}</span>\n {{ child.name }}\n </div>\n <div class=\"text-muted font-size-sm\">{{ child.description }}</div>\n </div>\n </div>\n </div>\n <table-select\n *ngIf=\"item.key === 'table'\"\n class=\"plugin-menu-table the-table-selector-panel\"\n [editor]=\"editor\"\n [beforeInsert]=\"removeKeywords\"\n ></table-select>\n </thy-dropdown-menu>\n </div>\n </ng-container>\n <ng-container *ngIf=\"!ThePluginMenu.isMenuItem(item)\" #menuGroup>\n <thy-dropdown-menu-group class=\"font-size-sm\" [thyTitle]=\"item.groupName\"></thy-dropdown-menu-group>\n </ng-container>\n </ng-container>\n </div>\n</div>\n\n<ng-template #thyEmpty>\n <div class=\"empty d-flex align-items-center justify-content-center\">\n <thy-empty [thyMessage]=\"thyMessage\"></thy-empty>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.ThyIconComponent, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "directive", type: i4.ThyTooltipDirective, selector: "[thyTooltip],[thy-tooltip]", inputs: ["thyTooltip", "thyTooltipPlacement", "thyTooltipClass", "thyTooltipShowDelay", "thyTooltipHideDelay", "thyTooltipTrigger", "thyTooltipDisabled", "thyTooltipTemplateContext", "thyTooltipOffset", "thyTooltipPin"], exportAs: ["thyTooltip"] }, { kind: "component", type: i5.ThyInputSearchComponent, selector: "thy-input-search", inputs: ["name", "placeholder", "thyTheme", "thySearchFocus", "thyIconPosition", "thySize"], outputs: ["clear", "thyClear"] }, { kind: "component", type: i6.ThyActionComponent, selector: "thy-action, [thyAction]", inputs: ["thyType", "thyIcon", "thyActionIcon", "thyActive", "thyActionActive", "thyTheme", "thyHoverIcon", "thyDisabled"] }, { kind: "component", type: i7.ThyDividerComponent, selector: "thy-divider", inputs: ["thyVertical", "thyStyle", "thyColor", "thyText", "thyTextDirection", "thyDeeper"] }, { kind: "directive", type: i8.ThyDropdownDirective, selector: "[thyDropdown]", inputs: ["thyDropdownMenu", "thyDropdown", "thyTrigger", "thyActiveClass", "thyPopoverOptions"], outputs: ["thyActiveChange"] }, { kind: "component", type: i8.ThyDropdownMenuComponent, selector: "thy-dropdown-menu", inputs: ["thyWidth"] }, { kind: "component", type: i8.ThyDropdownMenuGroupComponent, selector: "thy-dropdown-menu-group", inputs: ["thyTitle"] }, { kind: "directive", type: i8.ThyDropdownMenuItemDirective, selector: "[thyDropdownMenuItem]", inputs: ["thyType", "thyDisabled"] }, { kind: "component", type: i9.ThyEmptyComponent, selector: "thy-empty", inputs: ["thyMessage", "thyTranslationKey", "thyTranslationValues", "thyEntityName", "thyEntityNameTranslateKey", "thyIconName", "thySize", "thyMarginTop", "thyTopAuto", "thyContainer", "thyImageUrl", "thyImageLoading", "thyImageFetchPriority", "thyDescription"] }, { kind: "component", type: i10.TheTableSelectComponent, selector: "table-select", inputs: ["optionsParam", "editor", "beforeInsert"] }, { kind: "directive", type: i11.TheListboxOptionDirective, selector: "[theListboxOption]", inputs: ["theOptionValue"], exportAs: ["theListboxOption"] }, { kind: "directive", type: i11.TheListboxGroupDirective, selector: "[theListboxGroup]", inputs: ["horizontalColumn"], exportAs: ["theListboxGroup"] }, { kind: "directive", type: i11.TheListboxDirective, selector: "[theListBox]", inputs: ["keyboardContainer"], outputs: ["theListboxChange"], exportAs: ["theListBox"] }, { kind: "directive", type: i12.ThePreventDefaultDirective, selector: "[thePreventDefault]", exportAs: ["thePreventDefault"] }] });
93
131
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ThePluginMenuComponent, decorators: [{
94
132
  type: Component,
95
- args: [{ selector: 'the-plugin-menu', template: "<div *ngIf=\"groupMenu.length > 0; else thyEmpty\" class=\"thy-dropdown-menu py-2\">\n <div class=\"icon-menu d-flex px-5 py-1\">\n <ng-container *ngFor=\"let item of iconMenu\">\n <a\n *ngIf=\"item.type === ThePluginMenuItemType.icon\"\n href=\"javascript:;\"\n class=\"mt-2\"\n thyAction\n [thyActionIcon]=\"item.icon\"\n [thyTooltip]=\"item.name\"\n (mousedown)=\"executeItem($event, item)\"\n ></a>\n </ng-container>\n </div>\n\n <thy-divider *ngIf=\"this.iconMenu?.length\" class=\"my-2\"></thy-divider>\n\n <ng-container *ngFor=\"let item of groupMenu\">\n <ng-container *ngIf=\"ThePluginMenu.isMenuItem(item) && !item.isExpanded\">\n <div thyDropdownMenuItem class=\"insert-menu-item mb-1 py-0\" (mousedown)=\"executeItem($event, item)\">\n <div class=\"menu-icon mr-2\">\n <thy-icon [thyIconName]=\"item.menuIcon\"></thy-icon>\n </div>\n <div class=\"menu-content d-flex align-items-center\">\n <div class=\"menu-item-title w-100\">\n <span *ngIf=\"!item?.isExpanded\" class=\"menu-item-display-key font-size-sm text-placeholder\">\n {{ item.displayKey }}</span\n >\n {{ item.name }}\n </div>\n <div class=\"text-muted font-size-sm\">{{ item.description }}</div>\n </div>\n </div>\n </ng-container>\n <ng-container *ngIf=\"ThePluginMenu.isMenuItem(item) && item.isExpanded\" #hasExpanded>\n <div\n [thyDropdown]=\"expand\"\n thyTrigger=\"hover\"\n thyDropdownMenuItem\n [thyPopoverOptions]=\"expandPopoverOptions\"\n class=\"insert-menu-item mb-1 py-0\"\n (mousedown)=\"executeItem($event, item)\"\n >\n <div class=\"menu-icon mr-2\">\n <thy-icon [thyIconName]=\"item.menuIcon\"></thy-icon>\n </div>\n <div class=\"menu-content d-flex align-items-center\">\n <div class=\"menu-item-title w-100\">\n <span *ngIf=\"!item?.isExpanded\" class=\"menu-item-display-key font-size-sm text-placeholder\">\n {{ item.displayKey }}</span\n >\n {{ item.name }}\n </div>\n <div class=\"text-muted font-size-sm\">{{ item.description }}</div>\n </div>\n <div *ngIf=\"item?.isExpanded\">\n <thy-icon class=\"text-muted\" thyIconName=\"angle-right\"></thy-icon>\n </div>\n </div>\n <thy-dropdown-menu class=\"expand-menu\" #expand>\n <div class=\"the-plugin-menu-container\">\n <div *ngFor=\"let child of item.children\" thyDropdownMenuItem class=\"insert-menu-item mb-1 py-0\">\n <div class=\"menu-icon mr-2\">\n <thy-icon [thyIconName]=\"child.menuIcon\"></thy-icon>\n </div>\n <div class=\"menu-content d-flex align-items-center\">\n <div class=\"menu-item-title w-100\">\n <span class=\"menu-item-display-key font-size-sm text-placeholder\"> {{ child.displayKey }}</span>\n {{ child.name }}\n </div>\n <div class=\"text-muted font-size-sm\">{{ child.description }}</div>\n </div>\n </div>\n </div>\n <table-select\n *ngIf=\"item.key === 'table'\"\n class=\"plugin-menu-table the-table-selector-panel\"\n [editor]=\"editor\"\n [beforeInsert]=\"removeKeywords\"\n ></table-select>\n </thy-dropdown-menu>\n </ng-container>\n\n <ng-container *ngIf=\"!ThePluginMenu.isMenuItem(item)\" #menuGroup>\n <thy-dropdown-menu-group class=\"font-size-sm\" [thyTitle]=\"item.groupName\"></thy-dropdown-menu-group>\n </ng-container>\n </ng-container>\n</div>\n\n<ng-template #thyEmpty>\n <div class=\"empty d-flex align-items-center justify-content-center\">\n <thy-empty [thyMessage]=\"thyMessage\"></thy-empty>\n </div>\n</ng-template>\n" }]
96
- }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { containerClassName: [{
133
+ args: [{ selector: 'the-plugin-menu', template: "<div *ngIf=\"theDisplaySearch\" class=\"menu-search px-5 pt-5\">\n <thy-input-search [(ngModel)]=\"keyWords\" placeholder=\"\u641C\u7D22\" thyIconPosition=\"after\" (ngModelChange)=\"buildMenus()\"> </thy-input-search>\n</div>\n\n<div\n *ngIf=\"groupMenu.length > 0; else thyEmpty\"\n theListBox\n [keyboardContainer]=\"editorElement\"\n (theListboxChange)=\"theListboxChange($event)\"\n class=\"thy-dropdown-menu py-2\"\n>\n <div *ngIf=\"iconMenu?.length > 0\" theListboxGroup [horizontalColumn]=\"6\" class=\"icon-menu d-flex px-5 py-1\">\n <ng-container *ngFor=\"let item of iconMenu\">\n <a\n *ngIf=\"item.type === ThePluginMenuItemType.icon\"\n href=\"javascript:;\"\n class=\"mt-2\"\n thyAction\n theListboxOption\n [theOptionValue]=\"item\"\n [thyActionIcon]=\"item.icon\"\n [thyTooltip]=\"item.name\"\n thePreventDefault\n (click)=\"handleItemSelection(item)\"\n ></a>\n </ng-container>\n </div>\n\n <thy-divider *ngIf=\"this.iconMenu?.length\" class=\"my-2\"></thy-divider>\n <div theListboxGroup>\n <ng-container *ngFor=\"let item of groupMenu\">\n <ng-container *ngIf=\"ThePluginMenu.isMenuItem(item) && !item.isExpanded\">\n <div\n thyDropdownMenuItem\n theListboxOption\n [theOptionValue]=\"item\"\n class=\"insert-menu-item mb-1 py-0\"\n thePreventDefault\n (click)=\"handleItemSelection(item)\"\n >\n <div class=\"menu-icon mr-2\">\n <thy-icon [thyIconName]=\"item.menuIcon\"></thy-icon>\n </div>\n <div class=\"menu-content d-flex align-items-center\">\n <div class=\"menu-item-title w-100\">\n <span *ngIf=\"!item?.isExpanded\" class=\"menu-item-display-key font-size-sm text-placeholder\">\n {{ item.displayKey }}</span\n >\n {{ item.name }}\n </div>\n <div class=\"text-muted font-size-sm\">{{ item.description }}</div>\n </div>\n </div>\n </ng-container>\n <ng-container *ngIf=\"ThePluginMenu.isMenuItem(item) && item.isExpanded\" #hasExpanded>\n <div\n #dropdownTriggers\n [thyDropdown]=\"expand\"\n thyTrigger=\"hover\"\n thyDropdownMenuItem\n theListboxOption\n [theOptionValue]=\"item\"\n [thyPopoverOptions]=\"expandPopoverOptions\"\n class=\"insert-menu-item mb-1 py-0\"\n thePreventDefault\n (click)=\"handleItemSelection(item)\"\n >\n <div class=\"menu-icon mr-2\">\n <thy-icon [thyIconName]=\"item.menuIcon\"></thy-icon>\n </div>\n <div class=\"menu-content d-flex align-items-center\">\n <div class=\"menu-item-title w-100\">\n <span *ngIf=\"!item?.isExpanded\" class=\"menu-item-display-key font-size-sm text-placeholder\">\n {{ item.displayKey }}</span\n >\n {{ item.name }}\n </div>\n <div class=\"text-muted font-size-sm\">{{ item.description }}</div>\n </div>\n <div *ngIf=\"item?.isExpanded\">\n <thy-icon class=\"text-muted\" thyIconName=\"angle-right\"></thy-icon>\n </div>\n <thy-dropdown-menu class=\"expand-menu\" #expand>\n <div class=\"the-plugin-menu-container\" theListboxGroup>\n <div\n *ngFor=\"let child of item.children\"\n thyDropdownMenuItem\n theListboxOption\n class=\"insert-menu-item mb-1 py-0\"\n thePreventDefault\n (click)=\"handleItemSelection(child)\"\n [theOptionValue]=\"child\"\n >\n <div class=\"menu-icon mr-2\">\n <thy-icon [thyIconName]=\"child.menuIcon\"></thy-icon>\n </div>\n <div class=\"menu-content d-flex align-items-center\">\n <div class=\"menu-item-title w-100\">\n <span class=\"menu-item-display-key font-size-sm text-placeholder\"> {{ child.displayKey }}</span>\n {{ child.name }}\n </div>\n <div class=\"text-muted font-size-sm\">{{ child.description }}</div>\n </div>\n </div>\n </div>\n <table-select\n *ngIf=\"item.key === 'table'\"\n class=\"plugin-menu-table the-table-selector-panel\"\n [editor]=\"editor\"\n [beforeInsert]=\"removeKeywords\"\n ></table-select>\n </thy-dropdown-menu>\n </div>\n </ng-container>\n <ng-container *ngIf=\"!ThePluginMenu.isMenuItem(item)\" #menuGroup>\n <thy-dropdown-menu-group class=\"font-size-sm\" [thyTitle]=\"item.groupName\"></thy-dropdown-menu-group>\n </ng-container>\n </ng-container>\n </div>\n</div>\n\n<ng-template #thyEmpty>\n <div class=\"empty d-flex align-items-center justify-content-center\">\n <thy-empty [thyMessage]=\"thyMessage\"></thy-empty>\n </div>\n</ng-template>\n" }]
134
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i0.NgZone }]; }, propDecorators: { dropdownTriggers: [{
135
+ type: ViewChildren,
136
+ args: ['dropdownTriggers', { read: ThyDropdownDirective }]
137
+ }], containerClassName: [{
97
138
  type: HostBinding,
98
139
  args: ['class']
99
140
  }], editor: [{
100
141
  type: Input
142
+ }], theDisplaySearch: [{
143
+ type: Input
144
+ }], thePluginMenu: [{
145
+ type: Input
101
146
  }] } });
102
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"plugin-menu.component.js","sourceRoot":"","sources":["../../../../../packages/src/components/plugin-menu/plugin-menu.component.ts","../../../../../packages/src/components/plugin-menu/plugin-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, OnDestroy, ElementRef, ChangeDetectorRef, HostBinding } from '@angular/core';\nimport { mixinUnsubscribe, MixinBase } from 'ngx-tethys/core';\nimport { Editor, Node, Text } from 'slate';\nimport { AngularEditor } from 'slate-angular';\nimport { buildPluginMenu, buildPluginMenuItemMap } from '../../core/utils/plugin-menu';\nimport { DefaultPluginMenu, ThePluginMenuItemType } from '../../constants/plugin-menu';\nimport { ThePluginMenu, ThePluginMenuGroup, ThePluginMenuItem, ThePluginMenuItemConfig } from '../../interfaces/plugins/plugin-menu';\nimport { getPluginOptions } from '../../core';\nimport { QuickInsertPluginOptions } from '../../plugins/quick-insert/quick-insert.plugin';\nimport { PluginKeys } from '../../interfaces';\nimport { QuickInsertEditor } from '../../plugins/public-api';\n\n@Component({\n    selector: 'the-plugin-menu',\n    templateUrl: 'plugin-menu.component.html'\n})\nexport class ThePluginMenuComponent extends mixinUnsubscribe(MixinBase) implements OnInit, OnDestroy {\n    editorElement: HTMLElement;\n\n    ThePluginMenu = ThePluginMenu;\n\n    pluginMenu: ThePluginMenu;\n\n    groupMenu: ThePluginMenu = [];\n\n    iconMenu: ThePluginMenu = [];\n\n    ThePluginMenuItemType = ThePluginMenuItemType;\n\n    keyWords: string;\n\n    thyMessage = '暂无数据';\n\n    searchGroup: ThePluginMenuGroup = {\n        groupName: '搜索结果'\n    };\n\n    expandPopoverOptions = {\n        placement: 'rightTop',\n        width: '266px'\n    };\n\n    @HostBinding('class') containerClassName = `the-plugin-menu-container`;\n\n    @Input() editor: Editor;\n\n    constructor(public elementRef: ElementRef, public cdr: ChangeDetectorRef) {\n        super();\n    }\n\n    ngOnInit() {\n        this.editorElement = AngularEditor.toDOMNode(this.editor, this.editor);\n        let currentMenu =  this.editor.options.menu ? this.editor.options.menu : DefaultPluginMenu;\n        const menuItemsMap = buildPluginMenuItemMap(this.editor);\n        this.pluginMenu = buildPluginMenu(menuItemsMap, currentMenu);\n        this.buildMenus();\n    }\n\n    buildMenus() {\n        if (this.keyWords) {\n            this.iconMenu = [];\n            this.groupMenu = this.pluginMenu.filter((item: any) => {\n                return item?.keywords && item?.keywords.includes(this.keyWords);\n            });\n\n            if (this.groupMenu.length > 0) {\n                this.groupMenu.unshift(this.searchGroup);\n            }\n        } else {\n            this.iconMenu = this.pluginMenu.filter((item: any) => {\n                return item?.type === ThePluginMenuItemType.icon;\n            });\n            this.groupMenu = this.pluginMenu.filter((item: any) => {\n                return item?.type !== ThePluginMenuItemType.icon;\n            });\n        }\n\n        this.cdr.detectChanges();\n    }\n\n    executeItem(event: MouseEvent, menuItem: ThePluginMenuItem) {\n        event.preventDefault();\n        event.stopPropagation();\n        this.removeKeywords();\n        const toolbarItem: any = this.pluginMenu.find((item: ThePluginMenuItem) => item.key === menuItem.key);\n        if (toolbarItem.execute) {\n            toolbarItem.execute(this.editor);\n        }\n        QuickInsertEditor.closeMenu(this.editor);\n    }\n\n    removeKeywords = () => {\n        const hotkey = getPluginOptions<QuickInsertPluginOptions>(this.editor, PluginKeys.quickInsert)?.hotkey;\n        const node = Node.get(this.editor, this.editor.selection.anchor.path) as Text;\n        if (node && node.text.includes(hotkey)) {\n            Editor.deleteBackward(this.editor, { unit: 'block' });\n        }\n    };\n\n    updateKeywords(keywords: string) {\n        this.keyWords = keywords.toLowerCase().trim();\n        this.buildMenus();\n    }\n\n    ngOnDestroy() {\n        super.ngOnDestroy();\n    }\n}\n","<div *ngIf=\"groupMenu.length > 0; else thyEmpty\" class=\"thy-dropdown-menu py-2\">\n    <div class=\"icon-menu d-flex px-5 py-1\">\n        <ng-container *ngFor=\"let item of iconMenu\">\n            <a\n                *ngIf=\"item.type === ThePluginMenuItemType.icon\"\n                href=\"javascript:;\"\n                class=\"mt-2\"\n                thyAction\n                [thyActionIcon]=\"item.icon\"\n                [thyTooltip]=\"item.name\"\n                (mousedown)=\"executeItem($event, item)\"\n            ></a>\n        </ng-container>\n    </div>\n\n    <thy-divider *ngIf=\"this.iconMenu?.length\" class=\"my-2\"></thy-divider>\n\n    <ng-container *ngFor=\"let item of groupMenu\">\n        <ng-container *ngIf=\"ThePluginMenu.isMenuItem(item) && !item.isExpanded\">\n            <div thyDropdownMenuItem class=\"insert-menu-item mb-1 py-0\" (mousedown)=\"executeItem($event, item)\">\n                <div class=\"menu-icon mr-2\">\n                    <thy-icon [thyIconName]=\"item.menuIcon\"></thy-icon>\n                </div>\n                <div class=\"menu-content d-flex align-items-center\">\n                    <div class=\"menu-item-title w-100\">\n                        <span *ngIf=\"!item?.isExpanded\" class=\"menu-item-display-key font-size-sm text-placeholder\">\n                            {{ item.displayKey }}</span\n                        >\n                        {{ item.name }}\n                    </div>\n                    <div class=\"text-muted font-size-sm\">{{ item.description }}</div>\n                </div>\n            </div>\n        </ng-container>\n        <ng-container *ngIf=\"ThePluginMenu.isMenuItem(item) && item.isExpanded\" #hasExpanded>\n            <div\n                [thyDropdown]=\"expand\"\n                thyTrigger=\"hover\"\n                thyDropdownMenuItem\n                [thyPopoverOptions]=\"expandPopoverOptions\"\n                class=\"insert-menu-item mb-1 py-0\"\n                (mousedown)=\"executeItem($event, item)\"\n            >\n                <div class=\"menu-icon mr-2\">\n                    <thy-icon [thyIconName]=\"item.menuIcon\"></thy-icon>\n                </div>\n                <div class=\"menu-content d-flex align-items-center\">\n                    <div class=\"menu-item-title w-100\">\n                        <span *ngIf=\"!item?.isExpanded\" class=\"menu-item-display-key font-size-sm text-placeholder\">\n                            {{ item.displayKey }}</span\n                        >\n                        {{ item.name }}\n                    </div>\n                    <div class=\"text-muted font-size-sm\">{{ item.description }}</div>\n                </div>\n                <div *ngIf=\"item?.isExpanded\">\n                    <thy-icon class=\"text-muted\" thyIconName=\"angle-right\"></thy-icon>\n                </div>\n            </div>\n            <thy-dropdown-menu class=\"expand-menu\" #expand>\n                <div class=\"the-plugin-menu-container\">\n                    <div *ngFor=\"let child of item.children\" thyDropdownMenuItem class=\"insert-menu-item mb-1 py-0\">\n                        <div class=\"menu-icon mr-2\">\n                            <thy-icon [thyIconName]=\"child.menuIcon\"></thy-icon>\n                        </div>\n                        <div class=\"menu-content d-flex align-items-center\">\n                            <div class=\"menu-item-title w-100\">\n                                <span class=\"menu-item-display-key font-size-sm text-placeholder\"> {{ child.displayKey }}</span>\n                                {{ child.name }}\n                            </div>\n                            <div class=\"text-muted font-size-sm\">{{ child.description }}</div>\n                        </div>\n                    </div>\n                </div>\n                <table-select\n                    *ngIf=\"item.key === 'table'\"\n                    class=\"plugin-menu-table the-table-selector-panel\"\n                    [editor]=\"editor\"\n                    [beforeInsert]=\"removeKeywords\"\n                ></table-select>\n            </thy-dropdown-menu>\n        </ng-container>\n\n        <ng-container *ngIf=\"!ThePluginMenu.isMenuItem(item)\" #menuGroup>\n            <thy-dropdown-menu-group class=\"font-size-sm\" [thyTitle]=\"item.groupName\"></thy-dropdown-menu-group>\n        </ng-container>\n    </ng-container>\n</div>\n\n<ng-template #thyEmpty>\n    <div class=\"empty d-flex align-items-center justify-content-center\">\n        <thy-empty [thyMessage]=\"thyMessage\"></thy-empty>\n    </div>\n</ng-template>\n"]}
147
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"plugin-menu.component.js","sourceRoot":"","sources":["../../../../../packages/src/components/plugin-menu/plugin-menu.component.ts","../../../../../packages/src/components/plugin-menu/plugin-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, OnDestroy, ElementRef, ChangeDetectorRef, HostBinding, ViewChildren, NgZone } from '@angular/core';\nimport { mixinUnsubscribe, MixinBase, ThyScrollService, ScrollToService } from 'ngx-tethys/core';\nimport { Editor, Node, Text } from 'slate';\nimport { AngularEditor } from 'slate-angular';\nimport { buildPluginMenu, buildPluginMenuItemMap } from '../../core/utils/plugin-menu';\nimport { DefaultPluginMenu, ThePluginMenuItemType } from '../../constants/plugin-menu';\nimport { ThePluginMenu, ThePluginMenuGroup, ThePluginMenuItem, ThePluginMenuItemConfig } from '../../interfaces/plugins/plugin-menu';\nimport { getPluginOptions } from '../../core';\nimport { QuickInsertPluginOptions } from '../../plugins/quick-insert/quick-insert.plugin';\nimport { PluginKeys } from '../../interfaces';\nimport { QuickInsertEditor } from '../../plugins/public-api';\nimport { TheListboxChangeEvent, TheListboxOptionDirective } from '../listbox/listbox';\nimport { ThyDropdownDirective } from 'ngx-tethys/dropdown';\n\n@Component({\n    selector: 'the-plugin-menu',\n    templateUrl: 'plugin-menu.component.html'\n})\nexport class ThePluginMenuComponent extends mixinUnsubscribe(MixinBase) implements OnInit, OnDestroy {\n    editorElement: HTMLElement;\n\n    ThePluginMenu = ThePluginMenu;\n\n    _pluginMenu: ThePluginMenu;\n\n    groupMenu: ThePluginMenu = [];\n\n    iconMenu: ThePluginMenu = [];\n\n    ThePluginMenuItemType = ThePluginMenuItemType;\n\n    keyWords: string;\n\n    thyMessage = '暂无数据';\n\n    searchGroup: ThePluginMenuGroup = {\n        groupName: '搜索结果'\n    };\n\n    expandPopoverOptions = {\n        placement: 'rightTop',\n        width: '266px'\n    };\n\n    @ViewChildren('dropdownTriggers', { read: ThyDropdownDirective }) dropdownTriggers: ThyDropdownDirective[];\n\n    @HostBinding('class') containerClassName = `the-plugin-menu-container`;\n\n    @Input() editor: Editor;\n\n    @Input() theDisplaySearch: boolean = false;\n\n    @Input() thePluginMenu: ThePluginMenuItemConfig[];\n\n    constructor(public elementRef: ElementRef, public cdr: ChangeDetectorRef, private ngZone: NgZone) {\n        super();\n    }\n\n    ngOnInit() {\n        this.editorElement = AngularEditor.toDOMNode(this.editor, this.editor);\n        let currentMenu = this.editor.options.menu ? this.editor.options.menu : DefaultPluginMenu;\n        const menuItemsMap = buildPluginMenuItemMap(this.editor);\n        this._pluginMenu = buildPluginMenu(menuItemsMap, currentMenu);\n        this.buildMenus();\n    }\n\n    buildMenus() {\n        if (this.keyWords) {\n            this.iconMenu = [];\n            this.groupMenu = [];\n            this._pluginMenu.forEach((item: ThePluginMenuGroup | ThePluginMenuItem) => {\n                if (ThePluginMenu.isMenuItem(item)) {\n                    if (item.keywords && item.keywords?.includes(this.keyWords)) {\n                        this.groupMenu.push(item);\n                    }\n                    if (item.children && item.children.length > 0) {\n                        item.children.forEach((child) => {\n                            if (child.keywords && item.keywords?.includes(this.keyWords)) {\n                                this.groupMenu.push(child);\n                            }\n                        });\n                    }\n                }\n            });\n\n            if (this.groupMenu.length > 0) {\n                this.groupMenu.unshift(this.searchGroup);\n            }\n        } else {\n            this.iconMenu = this._pluginMenu.filter((item: any) => {\n                return item?.type === ThePluginMenuItemType.icon;\n            });\n            this.groupMenu = this._pluginMenu.filter((item: any) => {\n                return item?.type !== ThePluginMenuItemType.icon;\n            });\n        }\n\n        this.cdr.detectChanges();\n    }\n\n    handleItemSelection(menuItem: ThePluginMenuItem) {\n        this.removeKeywords();\n        menuItem.execute(this.editor);\n        QuickInsertEditor.closeMenu(this.editor);\n    }\n\n    removeKeywords = () => {\n        const hotkey = getPluginOptions<QuickInsertPluginOptions>(this.editor, PluginKeys.quickInsert)?.hotkey;\n        const node = Node.get(this.editor, this.editor.selection.anchor.path) as Text;\n        if (node && node.text.includes(hotkey)) {\n            Editor.deleteBackward(this.editor, { unit: 'block' });\n        }\n    };\n\n    updateKeywords(keywords: string) {\n        this.keyWords = keywords.toLowerCase().trim();\n        this.buildMenus();\n    }\n\n    theListboxChange(event: TheListboxChangeEvent) {\n        if (event.type === 'select') {\n            this.handleItemSelection(event.option.theOptionValue as ThePluginMenuItem);\n        }\n        if (event.type === 'child') {\n            const dropdown = this.findDropdownTrigger(event.option.parentOption);\n            this.ngZone.run(() => {\n                dropdown.show();\n            });\n        }\n        if (event.type === 'parent') {\n            const dropdown = this.findDropdownTrigger(event.option);\n            dropdown.hide();\n        }\n        if (event.type === 'turn') {\n            ScrollToService.scrollToElement(event.option.elementRef.nativeElement, this.elementRef.nativeElement);\n        }\n    }\n\n    findDropdownTrigger(option: TheListboxOptionDirective) {\n        const dropdown = this.dropdownTriggers.find(value => {\n            return value['elementRef'].nativeElement === option.elementRef.nativeElement;\n        });\n        return dropdown;\n    }\n\n    ngOnDestroy() {\n        super.ngOnDestroy();\n    }\n}\n","<div *ngIf=\"theDisplaySearch\" class=\"menu-search px-5 pt-5\">\n    <thy-input-search [(ngModel)]=\"keyWords\" placeholder=\"搜索\" thyIconPosition=\"after\" (ngModelChange)=\"buildMenus()\"> </thy-input-search>\n</div>\n\n<div\n    *ngIf=\"groupMenu.length > 0; else thyEmpty\"\n    theListBox\n    [keyboardContainer]=\"editorElement\"\n    (theListboxChange)=\"theListboxChange($event)\"\n    class=\"thy-dropdown-menu py-2\"\n>\n    <div *ngIf=\"iconMenu?.length > 0\" theListboxGroup [horizontalColumn]=\"6\" class=\"icon-menu d-flex px-5 py-1\">\n        <ng-container *ngFor=\"let item of iconMenu\">\n            <a\n                *ngIf=\"item.type === ThePluginMenuItemType.icon\"\n                href=\"javascript:;\"\n                class=\"mt-2\"\n                thyAction\n                theListboxOption\n                [theOptionValue]=\"item\"\n                [thyActionIcon]=\"item.icon\"\n                [thyTooltip]=\"item.name\"\n                thePreventDefault\n                (click)=\"handleItemSelection(item)\"\n            ></a>\n        </ng-container>\n    </div>\n\n    <thy-divider *ngIf=\"this.iconMenu?.length\" class=\"my-2\"></thy-divider>\n    <div theListboxGroup>\n        <ng-container *ngFor=\"let item of groupMenu\">\n            <ng-container *ngIf=\"ThePluginMenu.isMenuItem(item) && !item.isExpanded\">\n                <div\n                    thyDropdownMenuItem\n                    theListboxOption\n                    [theOptionValue]=\"item\"\n                    class=\"insert-menu-item mb-1 py-0\"\n                    thePreventDefault\n                    (click)=\"handleItemSelection(item)\"\n                >\n                    <div class=\"menu-icon mr-2\">\n                        <thy-icon [thyIconName]=\"item.menuIcon\"></thy-icon>\n                    </div>\n                    <div class=\"menu-content d-flex align-items-center\">\n                        <div class=\"menu-item-title w-100\">\n                            <span *ngIf=\"!item?.isExpanded\" class=\"menu-item-display-key font-size-sm text-placeholder\">\n                                {{ item.displayKey }}</span\n                            >\n                            {{ item.name }}\n                        </div>\n                        <div class=\"text-muted font-size-sm\">{{ item.description }}</div>\n                    </div>\n                </div>\n            </ng-container>\n            <ng-container *ngIf=\"ThePluginMenu.isMenuItem(item) && item.isExpanded\" #hasExpanded>\n                <div\n                    #dropdownTriggers\n                    [thyDropdown]=\"expand\"\n                    thyTrigger=\"hover\"\n                    thyDropdownMenuItem\n                    theListboxOption\n                    [theOptionValue]=\"item\"\n                    [thyPopoverOptions]=\"expandPopoverOptions\"\n                    class=\"insert-menu-item mb-1 py-0\"\n                    thePreventDefault\n                    (click)=\"handleItemSelection(item)\"\n                >\n                    <div class=\"menu-icon mr-2\">\n                        <thy-icon [thyIconName]=\"item.menuIcon\"></thy-icon>\n                    </div>\n                    <div class=\"menu-content d-flex align-items-center\">\n                        <div class=\"menu-item-title w-100\">\n                            <span *ngIf=\"!item?.isExpanded\" class=\"menu-item-display-key font-size-sm text-placeholder\">\n                                {{ item.displayKey }}</span\n                            >\n                            {{ item.name }}\n                        </div>\n                        <div class=\"text-muted font-size-sm\">{{ item.description }}</div>\n                    </div>\n                    <div *ngIf=\"item?.isExpanded\">\n                        <thy-icon class=\"text-muted\" thyIconName=\"angle-right\"></thy-icon>\n                    </div>\n                    <thy-dropdown-menu class=\"expand-menu\" #expand>\n                        <div class=\"the-plugin-menu-container\" theListboxGroup>\n                            <div\n                                *ngFor=\"let child of item.children\"\n                                thyDropdownMenuItem\n                                theListboxOption\n                                class=\"insert-menu-item mb-1 py-0\"\n                                thePreventDefault\n                                (click)=\"handleItemSelection(child)\"\n                                [theOptionValue]=\"child\"\n                            >\n                                <div class=\"menu-icon mr-2\">\n                                    <thy-icon [thyIconName]=\"child.menuIcon\"></thy-icon>\n                                </div>\n                                <div class=\"menu-content d-flex align-items-center\">\n                                    <div class=\"menu-item-title w-100\">\n                                        <span class=\"menu-item-display-key font-size-sm text-placeholder\"> {{ child.displayKey }}</span>\n                                        {{ child.name }}\n                                    </div>\n                                    <div class=\"text-muted font-size-sm\">{{ child.description }}</div>\n                                </div>\n                            </div>\n                        </div>\n                        <table-select\n                            *ngIf=\"item.key === 'table'\"\n                            class=\"plugin-menu-table the-table-selector-panel\"\n                            [editor]=\"editor\"\n                            [beforeInsert]=\"removeKeywords\"\n                        ></table-select>\n                    </thy-dropdown-menu>\n                </div>\n            </ng-container>\n            <ng-container *ngIf=\"!ThePluginMenu.isMenuItem(item)\" #menuGroup>\n                <thy-dropdown-menu-group class=\"font-size-sm\" [thyTitle]=\"item.groupName\"></thy-dropdown-menu-group>\n            </ng-container>\n        </ng-container>\n    </div>\n</div>\n\n<ng-template #thyEmpty>\n    <div class=\"empty d-flex align-items-center justify-content-center\">\n        <thy-empty [thyMessage]=\"thyMessage\"></thy-empty>\n    </div>\n</ng-template>\n"]}