@worktile/theia 14.2.8 → 14.2.10

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.
@@ -25,7 +25,7 @@ export declare class ThePluginMenuComponent extends ThePluginMenuComponent_base
25
25
  ThePluginMenuItemType: typeof ThePluginMenuItemType;
26
26
  keyWords: string;
27
27
  thyMessage: string;
28
- scrollContainer: any;
28
+ scrollContainer: HTMLElement;
29
29
  searchGroup: ThePluginMenuGroup;
30
30
  expandPopoverOptions: {
31
31
  placement: string;
@@ -62,10 +62,10 @@ export class ThePluginMenuComponent extends mixinUnsubscribe(MixinBase) {
62
62
  this.initializeSearch();
63
63
  this.initializePluginMenu();
64
64
  this.buildMenus();
65
+ this.scrollContainer = this.elementRef.nativeElement.querySelector('.the-plugin-menu-scroll-container');
65
66
  }
66
67
  initializeSearch() {
67
68
  if (this.theDisplaySearch) {
68
- this.scrollContainer = this.elementRef.nativeElement.querySelector('.the-plugin-menu-scroll-container');
69
69
  this.keyboardContainer = this.elementRef.nativeElement;
70
70
  setTimeout(() => {
71
71
  // 记住位置
@@ -139,7 +139,9 @@ export class ThePluginMenuComponent extends mixinUnsubscribe(MixinBase) {
139
139
  updateKeywords(keywords) {
140
140
  this.keyWords = keywords.toLowerCase().trim();
141
141
  this.buildMenus();
142
- this.scrollContainer.scrollTop = 0;
142
+ if (this.scrollContainer) {
143
+ this.scrollContainer.scrollTop = 0;
144
+ }
143
145
  }
144
146
  theListboxChange(event) {
145
147
  if (event.type === 'select') {
@@ -190,4 +192,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
190
192
  }], thePluginMenu: [{
191
193
  type: Input
192
194
  }] } });
193
- //# 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 { 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';\nimport { ThyPopoverRef } from 'ngx-tethys/popover';\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    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    scrollContainer;\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.initializeSearch();\n        this.initializePluginMenu();\n        this.buildMenus();\n    }\n\n    initializeSearch() {\n        if (this.theDisplaySearch) {\n            this.scrollContainer = this.elementRef.nativeElement.querySelector('.the-plugin-menu-scroll-container');\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        let currentMenu: ThePluginMenuItemConfig[];\n        if (this.thePluginMenu) {\n            currentMenu = this.thePluginMenu;\n        } else {\n            currentMenu = this.editor.options.menu ? this.editor.options.menu : DefaultPluginMenu;\n        }\n        const menuItemsMap = buildPluginMenuItemMap(this.editor);\n        this._pluginMenu = buildPluginMenu(menuItemsMap, currentMenu);\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 && 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.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        if (!this.editor.selection && this.pathRef) {\n            AngularEditor.focus(this.editor);\n            Transforms.select(this.editor, Editor.end(this.editor, this.pathRef.current));\n        }\n        if (!this.editor.selection) {\n            AngularEditor.focus(this.editor);\n            Transforms.select(this.editor, Editor.end(this.editor, [0]));\n        }\n        this.removeKeywords();\n        menuItem.execute(this.editor);\n        this.thyPopoverRef.close();\n        QuickInsertEditor.updatePluginMenuRef(this.editor, null);\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        this.scrollContainer.scrollTop = 0;\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    (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                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=\"ThePluginMenu.isMenuItem(item) && !(item.children?.length > 0) && item.key !== 'table'\">\n                <div\n                    thyDropdownMenuItem\n                    theListboxOption\n                    [theOptionValue]=\"item\"\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                            <span *ngIf=\"!(item.children?.length > 0)\" 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.children?.length > 0\" #hasExpanded>\n                <div\n                    #dropdownTriggers\n                    [thyDropdown]=\"expand\"\n                    thyTrigger=\"hover\"\n                    thyDropdownMenuItem\n                    theListboxOption\n                    [theOptionValue]=\"item\"\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                            <span *ngIf=\"!(item.children?.length > 0)\" 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.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                                (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                    </thy-dropdown-menu>\n                </div>\n            </ng-container>\n            <ng-container *ngIf=\"ThePluginMenu.isMenuItem(item) && 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                    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 class=\"text-muted font-size-sm\">{{ item.description }}</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=\"!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"]}
195
+ //# 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 { 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';\nimport { ThyPopoverRef } from 'ngx-tethys/popover';\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    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    scrollContainer: HTMLElement;\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.initializeSearch();\n        this.initializePluginMenu();\n        this.buildMenus();\n        this.scrollContainer = this.elementRef.nativeElement.querySelector('.the-plugin-menu-scroll-container');\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        let currentMenu: ThePluginMenuItemConfig[];\n        if (this.thePluginMenu) {\n            currentMenu = this.thePluginMenu;\n        } else {\n            currentMenu = this.editor.options.menu ? this.editor.options.menu : DefaultPluginMenu;\n        }\n        const menuItemsMap = buildPluginMenuItemMap(this.editor);\n        this._pluginMenu = buildPluginMenu(menuItemsMap, currentMenu);\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 && 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.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        if (!this.editor.selection && this.pathRef) {\n            AngularEditor.focus(this.editor);\n            Transforms.select(this.editor, Editor.end(this.editor, this.pathRef.current));\n        }\n        if (!this.editor.selection) {\n            AngularEditor.focus(this.editor);\n            Transforms.select(this.editor, Editor.end(this.editor, [0]));\n        }\n        this.removeKeywords();\n        menuItem.execute(this.editor);\n        this.thyPopoverRef.close();\n        QuickInsertEditor.updatePluginMenuRef(this.editor, null);\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        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    (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                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=\"ThePluginMenu.isMenuItem(item) && !(item.children?.length > 0) && item.key !== 'table'\">\n                <div\n                    thyDropdownMenuItem\n                    theListboxOption\n                    [theOptionValue]=\"item\"\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                            <span *ngIf=\"!(item.children?.length > 0)\" 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.children?.length > 0\" #hasExpanded>\n                <div\n                    #dropdownTriggers\n                    [thyDropdown]=\"expand\"\n                    thyTrigger=\"hover\"\n                    thyDropdownMenuItem\n                    theListboxOption\n                    [theOptionValue]=\"item\"\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                            <span *ngIf=\"!(item.children?.length > 0)\" 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.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                                (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                    </thy-dropdown-menu>\n                </div>\n            </ng-container>\n            <ng-container *ngIf=\"ThePluginMenu.isMenuItem(item) && 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                    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 class=\"text-muted font-size-sm\">{{ item.description }}</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=\"!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"]}
@@ -10207,10 +10207,10 @@ class ThePluginMenuComponent extends mixinUnsubscribe(MixinBase) {
10207
10207
  this.initializeSearch();
10208
10208
  this.initializePluginMenu();
10209
10209
  this.buildMenus();
10210
+ this.scrollContainer = this.elementRef.nativeElement.querySelector('.the-plugin-menu-scroll-container');
10210
10211
  }
10211
10212
  initializeSearch() {
10212
10213
  if (this.theDisplaySearch) {
10213
- this.scrollContainer = this.elementRef.nativeElement.querySelector('.the-plugin-menu-scroll-container');
10214
10214
  this.keyboardContainer = this.elementRef.nativeElement;
10215
10215
  setTimeout(() => {
10216
10216
  // 记住位置
@@ -10286,7 +10286,9 @@ class ThePluginMenuComponent extends mixinUnsubscribe(MixinBase) {
10286
10286
  updateKeywords(keywords) {
10287
10287
  this.keyWords = keywords.toLowerCase().trim();
10288
10288
  this.buildMenus();
10289
- this.scrollContainer.scrollTop = 0;
10289
+ if (this.scrollContainer) {
10290
+ this.scrollContainer.scrollTop = 0;
10291
+ }
10290
10292
  }
10291
10293
  theListboxChange(event) {
10292
10294
  if (event.type === 'select') {