@worktile/theia 14.3.5 → 14.3.6

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.
@@ -87,41 +87,31 @@ export class ThePluginMenuComponent extends mixinUnsubscribe(MixinBase) {
87
87
  buildMenus() {
88
88
  this.iconMenu = [];
89
89
  this.groupMenu = [];
90
- if (this.keyWords) {
91
- this._pluginMenu.forEach((item) => {
92
- if (ThePluginMenu.isMenuItem(item)) {
93
- item.isMenuItem = true;
94
- item.disabled = item.isDisabled && item.isDisabled(this.editor);
95
- if (item.keywords && item.keywords?.includes(this.keyWords)) {
96
- this.groupMenu.push(item);
97
- }
98
- if (item.children && item.children.length > 0) {
99
- item.children?.forEach((child) => {
100
- child.isMenuItem = true;
101
- child.disabled = child.isDisabled && child.isDisabled(this.editor);
102
- if (child.keywords && child.keywords?.includes(this.keyWords)) {
103
- this.groupMenu.push(child);
104
- }
105
- });
106
- }
90
+ this._pluginMenu.forEach((item) => {
91
+ const isHidden = item?.isHidden && item.isHidden(this.editor);
92
+ if (ThePluginMenu.isMenuItem(item)) {
93
+ item.isMenuItem = true;
94
+ item.disabled = item.isDisabled && item.isDisabled(this.editor);
95
+ if (this.keyWords && !isHidden && item.keywords && item.keywords?.includes(this.keyWords)) {
96
+ this.groupMenu.push(item);
107
97
  }
108
- });
109
- if (this.groupMenu.length > 0) {
110
- this.groupMenu.unshift(this.searchGroup);
111
- }
112
- }
113
- else {
114
- this._pluginMenu.forEach((item) => {
115
- if (ThePluginMenu.isMenuItem(item)) {
116
- item.isMenuItem = true;
117
- item.disabled = item.isDisabled && item.isDisabled(this.editor);
98
+ if (!isHidden && item.children && item.children.length > 0) {
118
99
  item.children?.forEach((child) => {
119
100
  child.isMenuItem = true;
120
101
  child.disabled = child.isDisabled && child.isDisabled(this.editor);
102
+ const isHiddenChid = item.isHidden && item.isHidden(this.editor);
103
+ if (this.keyWords && !isHiddenChid && child.keywords && child.keywords?.includes(this.keyWords)) {
104
+ this.groupMenu.push(child);
105
+ }
121
106
  });
122
107
  }
108
+ }
109
+ if (!this.keyWords && !isHidden) {
123
110
  item?.type === ThePluginMenuItemType.icon ? this.iconMenu.push(item) : this.groupMenu.push(item);
124
- });
111
+ }
112
+ });
113
+ if (this.keyWords && this.groupMenu.length > 0) {
114
+ this.groupMenu.unshift(this.searchGroup);
125
115
  }
126
116
  this.cdr.markForCheck();
127
117
  }
@@ -196,4 +186,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImpo
196
186
  }], thePluginMenu: [{
197
187
  type: Input
198
188
  }] } });
199
- //# 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, ScrollToService } from 'ngx-tethys/core';\nimport { Editor, Node, PathRef, Text, Transforms } from 'slate';\nimport { AngularEditor } from 'slate-angular';\nimport { buildPluginMenu, buildPluginMenuItemMap } from '../../core/utils/plugin-menu';\nimport { DefaultPluginMenu, ThePluginMenuItemType } from '../../constants/plugin-menu';\nimport {\n    ThePluginMenu,\n    ThePluginMenuGroup,\n    ThePluginMenuItem,\n    ThePluginMenuItemConfig,\n    ThePluginMenuItemWrap\n} 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';\nimport { ThyPopoverRef } from 'ngx-tethys/popover';\nimport { refocus } from '../../utils/refocus';\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    pathRef: PathRef;\n\n    keyboardContainer: HTMLElement;\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    scrollContainer: HTMLElement;\n\n    autoActiveFirstItem: boolean;\n\n    searchGroup: ThePluginMenuGroup = {\n        groupName: '搜索结果'\n    };\n\n    expandPopoverOptions = {\n        placement: 'rightTop',\n        width: '266px'\n    };\n\n    tableSelectPopoverConfig = {\n        panelClass: 'plugin-menu-table-select-container',\n        minWidth: 0,\n        //  避免重写\n        originActiveClass: 'thy-popover-origin-active'\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(\n        public elementRef: ElementRef<HTMLElement>,\n        public cdr: ChangeDetectorRef,\n        private ngZone: NgZone,\n        private thyPopoverRef: ThyPopoverRef<ThePluginMenuComponent>\n    ) {\n        super();\n    }\n\n    ngOnInit() {\n        this.autoActiveFirstItem = !this.theDisplaySearch;\n        this.initializeSearch();\n        this.initializePluginMenu();\n        this.buildMenus();\n        setTimeout(() => {\n            this.scrollContainer = this.elementRef.nativeElement.querySelector('.the-plugin-menu-scroll-container');\n        }, 0);\n    }\n\n    initializeSearch() {\n        if (this.theDisplaySearch) {\n            this.keyboardContainer = this.elementRef.nativeElement;\n            setTimeout(() => {\n                // 记住位置\n                if (this.editor.selection) {\n                    this.pathRef = Editor.pathRef(this.editor, this.editor.selection.anchor.path);\n                }\n                this.elementRef.nativeElement.querySelector('input').focus();\n            }, 0);\n        } else {\n            this.keyboardContainer = AngularEditor.toDOMNode(this.editor, this.editor);\n        }\n    }\n\n    initializePluginMenu() {\n        const currentMenu = this.thePluginMenu || DefaultPluginMenu;\n        const menuItemsMap = buildPluginMenuItemMap(this.editor);\n        this._pluginMenu = buildPluginMenu(menuItemsMap, currentMenu);\n    }\n\n    buildMenus() {\n        this.iconMenu = [];\n        this.groupMenu = [];\n        if (this.keyWords) {\n            this._pluginMenu.forEach((item: ThePluginMenuItemWrap) => {\n                if (ThePluginMenu.isMenuItem(item)) {\n                    item.isMenuItem = true;\n                    item.disabled = item.isDisabled && item.isDisabled(this.editor);\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: ThePluginMenuItemWrap) => {\n                            child.isMenuItem = true;\n                            child.disabled = child.isDisabled && child.isDisabled(this.editor);\n                            if (child.keywords && child.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._pluginMenu.forEach((item: ThePluginMenuItemWrap) => {\n                if (ThePluginMenu.isMenuItem(item)) {\n                    item.isMenuItem = true;\n                    item.disabled = item.isDisabled && item.isDisabled(this.editor);\n                    item.children?.forEach((child: ThePluginMenuItemWrap) => {\n                        child.isMenuItem = true;\n                        child.disabled = child.isDisabled && child.isDisabled(this.editor);\n                    });\n                }\n                item?.type === ThePluginMenuItemType.icon ? this.iconMenu.push(item) : this.groupMenu.push(item);\n            });\n        }\n\n        this.cdr.markForCheck();\n    }\n\n    handleItemSelection(menuItem: ThePluginMenuItem) {\n        if (menuItem.isDisabled && menuItem.isDisabled(this.editor)) {\n            return;\n        }\n        if (!this.editor.selection) {\n            refocus(this.editor);\n        }\n        if (!this.theDisplaySearch) {\n            this.removeKeywords();\n        }\n        menuItem.execute(this.editor);\n        this.thyPopoverRef.close();\n        QuickInsertEditor.updatePluginMenuRef(this.editor, null);\n    }\n\n    removeKeywords = () => {\n        const node = Node.get(this.editor, this.editor.selection.anchor.path) as Text;\n        if (node && Node.string(node).length > 0) {\n            Editor.deleteBackward(this.editor, { unit: 'block' });\n        }\n    };\n\n    updateKeywords(keywords: string) {\n        this.autoActiveFirstItem = true;\n        this.keyWords = keywords.toLowerCase().trim();\n        this.buildMenus();\n        if (this.scrollContainer) {\n            this.scrollContainer.scrollTop = 0;\n        }\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' && !event.option.parentOption) {\n            ScrollToService.scrollToElement(event.option.elementRef.nativeElement, this.scrollContainer);\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    trackByFn(index: ThePluginMenuItem, item: any) {\n        return item?.key ?? index;\n    }\n\n    ngOnDestroy() {\n        super.ngOnDestroy();\n    }\n}\n","<div *ngIf=\"theDisplaySearch\" class=\"menu-search px-5 pt-5 pb-2\">\n    <thy-input-search [(ngModel)]=\"keyWords\" placeholder=\"搜索\" thyIconPosition=\"after\" (ngModelChange)=\"updateKeywords(keyWords)\">\n    </thy-input-search>\n</div>\n\n<div\n    *ngIf=\"groupMenu.length > 0; else thyEmpty\"\n    theListBox\n    [keyboardContainer]=\"keyboardContainer\"\n    [autoActiveFirstItem]=\"autoActiveFirstItem\"\n    (theListboxChange)=\"theListboxChange($event)\"\n    class=\"thy-dropdown-menu the-plugin-menu-scroll-container pb-2 pt-0\"\n>\n    <div *ngIf=\"iconMenu?.length > 0\" theListboxGroup [horizontalColumn]=\"6\" class=\"icon-menu d-flex pl-5 py-1\">\n        <ng-container *ngFor=\"let item of iconMenu; trackBy: trackByFn\">\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                [thyDisabled]=\"item.disabled\"\n                [theOptionDisabled]=\"item.disabled\"\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; trackBy: trackByFn\">\n            <ng-container *ngIf=\"item.isMenuItem && !(item.children?.length > 0) && item.key !== 'table'\">\n                <div\n                    thyDropdownMenuItem\n                    theListboxOption\n                    [theOptionValue]=\"item\"\n                    class=\"py-0\"\n                    thePreventDefault\n                    [thyDisabled]=\"item.disabled\"\n                    [theOptionDisabled]=\"item.disabled\"\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                            {{ item.name }}\n                        </div>\n                    </div>\n                </div>\n            </ng-container>\n            <ng-container *ngIf=\"item.isMenuItem && item.children?.length > 0\" #hasExpanded>\n                <div\n                    #dropdownTriggers\n                    [thyDropdown]=\"expand\"\n                    thyTrigger=\"hover\"\n                    thyDropdownMenuItem\n                    [thyDisabled]=\"item.disabled\"\n                    theListboxOption\n                    [theOptionValue]=\"item\"\n                    [theOptionDisabled]=\"item.disabled\"\n                    [thyPopoverOptions]=\"expandPopoverOptions\"\n                    class=\"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                            {{ item.name }}\n                        </div>\n                    </div>\n                    <div *ngIf=\"item.children?.length > 0\">\n                        <thy-icon class=\"text-muted\" thyIconName=\"angle-right\"></thy-icon>\n                    </div>\n                    <thy-dropdown-menu #expand>\n                        <div class=\"the-plugin-menu-container expand-menu\" theListboxGroup>\n                            <div\n                                *ngFor=\"let child of item.children\"\n                                thyDropdownMenuItem\n                                theListboxOption\n                                class=\"py-0\"\n                                thePreventDefault\n                                [theOptionDisabled]=\"item.disabled\"\n                                [thyDisabled]=\"child.disabled\"\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                                        {{ child.name }}\n                                    </div>\n                                </div>\n                            </div>\n                        </div>\n                    </thy-dropdown-menu>\n                </div>\n            </ng-container>\n            <ng-container *ngIf=\"item.isMenuItem && item.key === 'table'\">\n                <div\n                    #dropdownTriggers\n                    [thyPopover]=\"tableSelect\"\n                    thyPlacement=\"rightTop\"\n                    thyTrigger=\"hover\"\n                    thyDropdownMenuItem\n                    theListboxOption\n                    [thyConfig]=\"tableSelectPopoverConfig\"\n                    [theOptionValue]=\"item\"\n                    [theOptionDisabled]=\"item.disabled\"\n                    [thyDisabled]=\"item.disabled\"\n                    class=\"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                            {{ item.name }}\n                        </div>\n                    </div>\n                    <div>\n                        <thy-icon class=\"text-muted\" thyIconName=\"angle-right\"></thy-icon>\n                    </div>\n\n                    <ng-template #tableSelect>\n                        <table-select\n                            class=\"plugin-menu-table the-table-selector-panel\"\n                            [editor]=\"editor\"\n                            [beforeInsert]=\"removeKeywords\"\n                        ></table-select>\n                    </ng-template>\n                </div>\n            </ng-container>\n            <ng-container *ngIf=\"!item.isMenuItem\" #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"]}
189
+ //# 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, ScrollToService } from 'ngx-tethys/core';\nimport { Editor, Node, PathRef, Text } from 'slate';\nimport { AngularEditor } from 'slate-angular';\nimport { buildPluginMenu, buildPluginMenuItemMap } from '../../core/utils/plugin-menu';\nimport { DefaultPluginMenu, ThePluginMenuItemType } from '../../constants/plugin-menu';\nimport {\n    ThePluginMenu,\n    ThePluginMenuGroup,\n    ThePluginMenuItem,\n    ThePluginMenuItemConfig,\n    ThePluginMenuItemWrap\n} from '../../interfaces/plugins/plugin-menu';\nimport { QuickInsertEditor } from '../../plugins/public-api';\nimport { TheListboxChangeEvent, TheListboxOptionDirective } from '../listbox/listbox';\nimport { ThyDropdownDirective } from 'ngx-tethys/dropdown';\nimport { ThyPopoverRef } from 'ngx-tethys/popover';\nimport { refocus } from '../../utils/refocus';\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    pathRef: PathRef;\n\n    keyboardContainer: HTMLElement;\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    scrollContainer: HTMLElement;\n\n    autoActiveFirstItem: boolean;\n\n    searchGroup: ThePluginMenuGroup = {\n        groupName: '搜索结果'\n    };\n\n    expandPopoverOptions = {\n        placement: 'rightTop',\n        width: '266px'\n    };\n\n    tableSelectPopoverConfig = {\n        panelClass: 'plugin-menu-table-select-container',\n        minWidth: 0,\n        //  避免重写\n        originActiveClass: 'thy-popover-origin-active'\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(\n        public elementRef: ElementRef<HTMLElement>,\n        public cdr: ChangeDetectorRef,\n        private ngZone: NgZone,\n        private thyPopoverRef: ThyPopoverRef<ThePluginMenuComponent>\n    ) {\n        super();\n    }\n\n    ngOnInit() {\n        this.autoActiveFirstItem = !this.theDisplaySearch;\n        this.initializeSearch();\n        this.initializePluginMenu();\n        this.buildMenus();\n        setTimeout(() => {\n            this.scrollContainer = this.elementRef.nativeElement.querySelector('.the-plugin-menu-scroll-container');\n        }, 0);\n    }\n\n    initializeSearch() {\n        if (this.theDisplaySearch) {\n            this.keyboardContainer = this.elementRef.nativeElement;\n            setTimeout(() => {\n                // 记住位置\n                if (this.editor.selection) {\n                    this.pathRef = Editor.pathRef(this.editor, this.editor.selection.anchor.path);\n                }\n                this.elementRef.nativeElement.querySelector('input').focus();\n            }, 0);\n        } else {\n            this.keyboardContainer = AngularEditor.toDOMNode(this.editor, this.editor);\n        }\n    }\n\n    initializePluginMenu() {\n        const currentMenu = this.thePluginMenu || DefaultPluginMenu;\n        const menuItemsMap = buildPluginMenuItemMap(this.editor);\n        this._pluginMenu = buildPluginMenu(menuItemsMap, currentMenu);\n    }\n\n    buildMenus() {\n        this.iconMenu = [];\n        this.groupMenu = [];\n        this._pluginMenu.forEach((item: ThePluginMenuItemWrap) => {\n            const isHidden = item?.isHidden && item.isHidden(this.editor);\n            if (ThePluginMenu.isMenuItem(item)) {\n                item.isMenuItem = true;\n                item.disabled = item.isDisabled && item.isDisabled(this.editor);\n                if (this.keyWords && !isHidden && item.keywords && item.keywords?.includes(this.keyWords)) {\n                    this.groupMenu.push(item);\n                }\n                if (!isHidden && item.children && item.children.length > 0) {\n                    item.children?.forEach((child: ThePluginMenuItemWrap) => {\n                        child.isMenuItem = true;\n                        child.disabled = child.isDisabled && child.isDisabled(this.editor);\n                        const isHiddenChid = item.isHidden && item.isHidden(this.editor);\n                        if (this.keyWords && !isHiddenChid && child.keywords && child.keywords?.includes(this.keyWords)) {\n                            this.groupMenu.push(child);\n                        }\n                    });\n                }\n            }\n            if (!this.keyWords && !isHidden) {\n                item?.type === ThePluginMenuItemType.icon ? this.iconMenu.push(item) : this.groupMenu.push(item);\n            }\n        });\n\n        if (this.keyWords && this.groupMenu.length > 0) {\n            this.groupMenu.unshift(this.searchGroup);\n        }\n\n        this.cdr.markForCheck();\n    }\n\n    handleItemSelection(menuItem: ThePluginMenuItem) {\n        if (menuItem.isDisabled && menuItem.isDisabled(this.editor)) {\n            return;\n        }\n        if (!this.editor.selection) {\n            refocus(this.editor);\n        }\n        if (!this.theDisplaySearch) {\n            this.removeKeywords();\n        }\n        menuItem.execute(this.editor);\n        this.thyPopoverRef.close();\n        QuickInsertEditor.updatePluginMenuRef(this.editor, null);\n    }\n\n    removeKeywords = () => {\n        const node = Node.get(this.editor, this.editor.selection.anchor.path) as Text;\n        if (node && Node.string(node).length > 0) {\n            Editor.deleteBackward(this.editor, { unit: 'block' });\n        }\n    };\n\n    updateKeywords(keywords: string) {\n        this.autoActiveFirstItem = true;\n        this.keyWords = keywords.toLowerCase().trim();\n        this.buildMenus();\n        if (this.scrollContainer) {\n            this.scrollContainer.scrollTop = 0;\n        }\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' && !event.option.parentOption) {\n            ScrollToService.scrollToElement(event.option.elementRef.nativeElement, this.scrollContainer);\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    trackByFn(index: ThePluginMenuItem, item: any) {\n        return item?.key ?? index;\n    }\n\n    ngOnDestroy() {\n        super.ngOnDestroy();\n    }\n}\n","<div *ngIf=\"theDisplaySearch\" class=\"menu-search px-5 pt-5 pb-2\">\n    <thy-input-search [(ngModel)]=\"keyWords\" placeholder=\"搜索\" thyIconPosition=\"after\" (ngModelChange)=\"updateKeywords(keyWords)\">\n    </thy-input-search>\n</div>\n\n<div\n    *ngIf=\"groupMenu.length > 0; else thyEmpty\"\n    theListBox\n    [keyboardContainer]=\"keyboardContainer\"\n    [autoActiveFirstItem]=\"autoActiveFirstItem\"\n    (theListboxChange)=\"theListboxChange($event)\"\n    class=\"thy-dropdown-menu the-plugin-menu-scroll-container pb-2 pt-0\"\n>\n    <div *ngIf=\"iconMenu?.length > 0\" theListboxGroup [horizontalColumn]=\"6\" class=\"icon-menu d-flex pl-5 py-1\">\n        <ng-container *ngFor=\"let item of iconMenu; trackBy: trackByFn\">\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                [thyDisabled]=\"item.disabled\"\n                [theOptionDisabled]=\"item.disabled\"\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; trackBy: trackByFn\">\n            <ng-container *ngIf=\"item.isMenuItem && !(item.children?.length > 0) && item.key !== 'table'\">\n                <div\n                    thyDropdownMenuItem\n                    theListboxOption\n                    [theOptionValue]=\"item\"\n                    class=\"py-0\"\n                    thePreventDefault\n                    [thyDisabled]=\"item.disabled\"\n                    [theOptionDisabled]=\"item.disabled\"\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                            {{ item.name }}\n                        </div>\n                    </div>\n                </div>\n            </ng-container>\n            <ng-container *ngIf=\"item.isMenuItem && item.children?.length > 0\" #hasExpanded>\n                <div\n                    #dropdownTriggers\n                    [thyDropdown]=\"expand\"\n                    thyTrigger=\"hover\"\n                    thyDropdownMenuItem\n                    [thyDisabled]=\"item.disabled\"\n                    theListboxOption\n                    [theOptionValue]=\"item\"\n                    [theOptionDisabled]=\"item.disabled\"\n                    [thyPopoverOptions]=\"expandPopoverOptions\"\n                    class=\"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                            {{ item.name }}\n                        </div>\n                    </div>\n                    <div *ngIf=\"item.children?.length > 0\">\n                        <thy-icon class=\"text-muted\" thyIconName=\"angle-right\"></thy-icon>\n                    </div>\n                    <thy-dropdown-menu #expand>\n                        <div class=\"the-plugin-menu-container expand-menu\" theListboxGroup>\n                            <div\n                                *ngFor=\"let child of item.children\"\n                                thyDropdownMenuItem\n                                theListboxOption\n                                class=\"py-0\"\n                                thePreventDefault\n                                [theOptionDisabled]=\"item.disabled\"\n                                [thyDisabled]=\"child.disabled\"\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                                        {{ child.name }}\n                                    </div>\n                                </div>\n                            </div>\n                        </div>\n                    </thy-dropdown-menu>\n                </div>\n            </ng-container>\n            <ng-container *ngIf=\"item.isMenuItem && item.key === 'table'\">\n                <div\n                    #dropdownTriggers\n                    [thyPopover]=\"tableSelect\"\n                    thyPlacement=\"rightTop\"\n                    thyTrigger=\"hover\"\n                    thyDropdownMenuItem\n                    theListboxOption\n                    [thyConfig]=\"tableSelectPopoverConfig\"\n                    [theOptionValue]=\"item\"\n                    [theOptionDisabled]=\"item.disabled\"\n                    [thyDisabled]=\"item.disabled\"\n                    class=\"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                            {{ item.name }}\n                        </div>\n                    </div>\n                    <div>\n                        <thy-icon class=\"text-muted\" thyIconName=\"angle-right\"></thy-icon>\n                    </div>\n\n                    <ng-template #tableSelect>\n                        <table-select\n                            class=\"plugin-menu-table the-table-selector-panel\"\n                            [editor]=\"editor\"\n                            [beforeInsert]=\"removeKeywords\"\n                        ></table-select>\n                    </ng-template>\n                </div>\n            </ng-container>\n            <ng-container *ngIf=\"!item.isMenuItem\" #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"]}
@@ -16,4 +16,4 @@ export const ThePluginMenu = {
16
16
  }
17
17
  }
18
18
  };
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGx1Z2luLW1lbnUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9zcmMvaW50ZXJmYWNlcy9wbHVnaW5zL3BsdWdpbi1tZW51LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQThCQSxNQUFNLENBQUMsTUFBTSxhQUFhLEdBQUc7SUFDekIsV0FBVyxDQUFDLEtBQVU7UUFDbEIsSUFBSSxLQUFLLFlBQVksTUFBTSxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsRUFBRTtZQUN2QyxPQUFPLElBQUksQ0FBQztTQUNmO2FBQU07WUFDSCxPQUFPLEtBQUssQ0FBQztTQUNoQjtJQUNMLENBQUM7SUFDRCxVQUFVLENBQUMsS0FBVTtRQUNqQixJQUFJLEtBQUssQ0FBQyxHQUFHLEVBQUU7WUFDWCxPQUFPLElBQUksQ0FBQztTQUNmO2FBQU07WUFDSCxPQUFPLEtBQUssQ0FBQztTQUNoQjtJQUNMLENBQUM7Q0FDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRWRpdG9yIH0gZnJvbSAnc2xhdGUnO1xuaW1wb3J0IHsgVGhlUGx1Z2luTWVudUl0ZW1UeXBlIH0gZnJvbSAnLi4vLi4vY29uc3RhbnRzJztcblxuZXhwb3J0IHR5cGUgVGhlUGx1Z2luTWVudUl0ZW1LZXkgPSBzdHJpbmc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVGhlUGx1Z2luTWVudUl0ZW0ge1xuICAgIGtleTogVGhlUGx1Z2luTWVudUl0ZW1LZXk7XG4gICAgbmFtZTogc3RyaW5nO1xuICAgIGV4ZWN1dGU/OiAoZWRpdG9yOiBFZGl0b3IpID0+IHZvaWQ7XG4gICAgYWN0aXZlPzogKGVkaXRvcjogRWRpdG9yKSA9PiBib29sZWFuIHwgc3RyaW5nO1xuICAgIHR5cGU6IFRoZVBsdWdpbk1lbnVJdGVtVHlwZTtcbiAgICBkZXNjcmlwdGlvbj86IHN0cmluZztcbiAgICBpY29uPzogc3RyaW5nO1xuICAgIG1lbnVJY29uPzogc3RyaW5nO1xuICAgIGtleXdvcmRzPzogc3RyaW5nO1xuICAgIGNoaWxkcmVuPzogVGhlUGx1Z2luTWVudUl0ZW1bXTtcbiAgICBkaXNwbGF5S2V5Pzogc3RyaW5nO1xuICAgIGlzRGlzYWJsZWQ/OiAoZWRpdG9yOiBFZGl0b3IpID0+IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVGhlUGx1Z2luTWVudUdyb3VwIHtcbiAgICBncm91cE5hbWU6IHN0cmluZztcbn1cblxuZXhwb3J0IHR5cGUgVGhlUGx1Z2luTWVudUl0ZW1Db25maWcgPSBUaGVQbHVnaW5NZW51R3JvdXAgfCBUaGVQbHVnaW5NZW51SXRlbUtleTtcblxuZXhwb3J0IHR5cGUgVGhlUGx1Z2luTWVudSA9IChUaGVQbHVnaW5NZW51R3JvdXAgfCBUaGVQbHVnaW5NZW51SXRlbSlbXTtcblxuZXhwb3J0IHR5cGUgVGhlUGx1Z2luTWVudUl0ZW1XcmFwID0gVGhlUGx1Z2luTWVudUl0ZW0gJiB7IGRpc2FibGVkPzogYm9vbGVhbjsgaXNNZW51SXRlbT86IGJvb2xlYW4gfTtcblxuZXhwb3J0IGNvbnN0IFRoZVBsdWdpbk1lbnUgPSB7XG4gICAgaXNNZW51R3JvdXAodmFsdWU6IGFueSk6IHZhbHVlIGlzIFRoZVBsdWdpbk1lbnVHcm91cCB7XG4gICAgICAgIGlmICh2YWx1ZSBpbnN0YW5jZW9mIE9iamVjdCAmJiAhdmFsdWUua2V5KSB7XG4gICAgICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHJldHVybiBmYWxzZTtcbiAgICAgICAgfVxuICAgIH0sXG4gICAgaXNNZW51SXRlbSh2YWx1ZTogYW55KTogdmFsdWUgaXMgVGhlUGx1Z2luTWVudUl0ZW0ge1xuICAgICAgICBpZiAodmFsdWUua2V5KSB7XG4gICAgICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHJldHVybiBmYWxzZTtcbiAgICAgICAgfVxuICAgIH1cbn07XG4iXX0=
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGx1Z2luLW1lbnUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9zcmMvaW50ZXJmYWNlcy9wbHVnaW5zL3BsdWdpbi1tZW51LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQStCQSxNQUFNLENBQUMsTUFBTSxhQUFhLEdBQUc7SUFDekIsV0FBVyxDQUFDLEtBQVU7UUFDbEIsSUFBSSxLQUFLLFlBQVksTUFBTSxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsRUFBRTtZQUN2QyxPQUFPLElBQUksQ0FBQztTQUNmO2FBQU07WUFDSCxPQUFPLEtBQUssQ0FBQztTQUNoQjtJQUNMLENBQUM7SUFDRCxVQUFVLENBQUMsS0FBVTtRQUNqQixJQUFJLEtBQUssQ0FBQyxHQUFHLEVBQUU7WUFDWCxPQUFPLElBQUksQ0FBQztTQUNmO2FBQU07WUFDSCxPQUFPLEtBQUssQ0FBQztTQUNoQjtJQUNMLENBQUM7Q0FDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRWRpdG9yIH0gZnJvbSAnc2xhdGUnO1xuaW1wb3J0IHsgVGhlUGx1Z2luTWVudUl0ZW1UeXBlIH0gZnJvbSAnLi4vLi4vY29uc3RhbnRzJztcblxuZXhwb3J0IHR5cGUgVGhlUGx1Z2luTWVudUl0ZW1LZXkgPSBzdHJpbmc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVGhlUGx1Z2luTWVudUl0ZW0ge1xuICAgIGtleTogVGhlUGx1Z2luTWVudUl0ZW1LZXk7XG4gICAgbmFtZTogc3RyaW5nO1xuICAgIHR5cGU6IFRoZVBsdWdpbk1lbnVJdGVtVHlwZTtcbiAgICBkZXNjcmlwdGlvbj86IHN0cmluZztcbiAgICBpY29uPzogc3RyaW5nO1xuICAgIG1lbnVJY29uPzogc3RyaW5nO1xuICAgIGtleXdvcmRzPzogc3RyaW5nO1xuICAgIGNoaWxkcmVuPzogVGhlUGx1Z2luTWVudUl0ZW1bXTtcbiAgICBkaXNwbGF5S2V5Pzogc3RyaW5nO1xuICAgIGV4ZWN1dGU/OiAoZWRpdG9yOiBFZGl0b3IpID0+IHZvaWQ7XG4gICAgYWN0aXZlPzogKGVkaXRvcjogRWRpdG9yKSA9PiBib29sZWFuIHwgc3RyaW5nO1xuICAgIGlzRGlzYWJsZWQ/OiAoZWRpdG9yOiBFZGl0b3IpID0+IGJvb2xlYW47XG4gICAgaXNIaWRkZW4/OiAoZWRpdG9yOiBFZGl0b3IpID0+IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVGhlUGx1Z2luTWVudUdyb3VwIHtcbiAgICBncm91cE5hbWU6IHN0cmluZztcbn1cblxuZXhwb3J0IHR5cGUgVGhlUGx1Z2luTWVudUl0ZW1Db25maWcgPSBUaGVQbHVnaW5NZW51R3JvdXAgfCBUaGVQbHVnaW5NZW51SXRlbUtleTtcblxuZXhwb3J0IHR5cGUgVGhlUGx1Z2luTWVudSA9IChUaGVQbHVnaW5NZW51R3JvdXAgfCBUaGVQbHVnaW5NZW51SXRlbSlbXTtcblxuZXhwb3J0IHR5cGUgVGhlUGx1Z2luTWVudUl0ZW1XcmFwID0gVGhlUGx1Z2luTWVudUl0ZW0gJiB7IGRpc2FibGVkPzogYm9vbGVhbjsgaXNNZW51SXRlbT86IGJvb2xlYW4gfTtcblxuZXhwb3J0IGNvbnN0IFRoZVBsdWdpbk1lbnUgPSB7XG4gICAgaXNNZW51R3JvdXAodmFsdWU6IGFueSk6IHZhbHVlIGlzIFRoZVBsdWdpbk1lbnVHcm91cCB7XG4gICAgICAgIGlmICh2YWx1ZSBpbnN0YW5jZW9mIE9iamVjdCAmJiAhdmFsdWUua2V5KSB7XG4gICAgICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHJldHVybiBmYWxzZTtcbiAgICAgICAgfVxuICAgIH0sXG4gICAgaXNNZW51SXRlbSh2YWx1ZTogYW55KTogdmFsdWUgaXMgVGhlUGx1Z2luTWVudUl0ZW0ge1xuICAgICAgICBpZiAodmFsdWUua2V5KSB7XG4gICAgICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHJldHVybiBmYWxzZTtcbiAgICAgICAgfVxuICAgIH1cbn07XG4iXX0=
@@ -10387,44 +10387,33 @@ class ThePluginMenuComponent extends mixinUnsubscribe(MixinBase) {
10387
10387
  buildMenus() {
10388
10388
  this.iconMenu = [];
10389
10389
  this.groupMenu = [];
10390
- if (this.keyWords) {
10391
- this._pluginMenu.forEach((item) => {
10392
- var _a, _b;
10393
- if (ThePluginMenu.isMenuItem(item)) {
10394
- item.isMenuItem = true;
10395
- item.disabled = item.isDisabled && item.isDisabled(this.editor);
10396
- if (item.keywords && ((_a = item.keywords) === null || _a === void 0 ? void 0 : _a.includes(this.keyWords))) {
10397
- this.groupMenu.push(item);
10398
- }
10399
- if (item.children && item.children.length > 0) {
10400
- (_b = item.children) === null || _b === void 0 ? void 0 : _b.forEach((child) => {
10401
- var _a;
10402
- child.isMenuItem = true;
10403
- child.disabled = child.isDisabled && child.isDisabled(this.editor);
10404
- if (child.keywords && ((_a = child.keywords) === null || _a === void 0 ? void 0 : _a.includes(this.keyWords))) {
10405
- this.groupMenu.push(child);
10406
- }
10407
- });
10408
- }
10409
- }
10410
- });
10411
- if (this.groupMenu.length > 0) {
10412
- this.groupMenu.unshift(this.searchGroup);
10413
- }
10414
- }
10415
- else {
10416
- this._pluginMenu.forEach((item) => {
10417
- var _a;
10418
- if (ThePluginMenu.isMenuItem(item)) {
10419
- item.isMenuItem = true;
10420
- item.disabled = item.isDisabled && item.isDisabled(this.editor);
10421
- (_a = item.children) === null || _a === void 0 ? void 0 : _a.forEach((child) => {
10390
+ this._pluginMenu.forEach((item) => {
10391
+ var _a, _b;
10392
+ const isHidden = (item === null || item === void 0 ? void 0 : item.isHidden) && item.isHidden(this.editor);
10393
+ if (ThePluginMenu.isMenuItem(item)) {
10394
+ item.isMenuItem = true;
10395
+ item.disabled = item.isDisabled && item.isDisabled(this.editor);
10396
+ if (this.keyWords && !isHidden && item.keywords && ((_a = item.keywords) === null || _a === void 0 ? void 0 : _a.includes(this.keyWords))) {
10397
+ this.groupMenu.push(item);
10398
+ }
10399
+ if (!isHidden && item.children && item.children.length > 0) {
10400
+ (_b = item.children) === null || _b === void 0 ? void 0 : _b.forEach((child) => {
10401
+ var _a;
10422
10402
  child.isMenuItem = true;
10423
10403
  child.disabled = child.isDisabled && child.isDisabled(this.editor);
10404
+ const isHiddenChid = item.isHidden && item.isHidden(this.editor);
10405
+ if (this.keyWords && !isHiddenChid && child.keywords && ((_a = child.keywords) === null || _a === void 0 ? void 0 : _a.includes(this.keyWords))) {
10406
+ this.groupMenu.push(child);
10407
+ }
10424
10408
  });
10425
10409
  }
10410
+ }
10411
+ if (!this.keyWords && !isHidden) {
10426
10412
  (item === null || item === void 0 ? void 0 : item.type) === ThePluginMenuItemType.icon ? this.iconMenu.push(item) : this.groupMenu.push(item);
10427
- });
10413
+ }
10414
+ });
10415
+ if (this.keyWords && this.groupMenu.length > 0) {
10416
+ this.groupMenu.unshift(this.searchGroup);
10428
10417
  }
10429
10418
  this.cdr.markForCheck();
10430
10419
  }