@worktile/theia 17.4.5 → 17.4.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/components/plugin-menu/plugin-menu.component.mjs +2 -2
- package/esm2022/plugins/quick-insert/components/quick-insert.component.mjs +16 -16
- package/esm2022/transforms/insert-elements.mjs +5 -11
- package/fesm2022/worktile-theia.mjs +20 -26
- package/fesm2022/worktile-theia.mjs.map +1 -1
- package/interfaces/editor.d.ts +1 -1
- package/package.json +1 -1
- package/plugins/quick-insert/components/quick-insert.component.d.ts +4 -5
- package/queries/is-range-across-blocks.d.ts +1 -1
- package/transforms/insert-elements.d.ts +1 -1
|
@@ -67,7 +67,7 @@ export class ThePluginMenuComponent {
|
|
|
67
67
|
const nodeString = Node.string(node);
|
|
68
68
|
const isStartWithHotkey = nodeString.startsWith('/') || nodeString.startsWith('#');
|
|
69
69
|
const isIncludeKeywords = nodeString.toLocaleLowerCase().trim().includes(this.keyWords);
|
|
70
|
-
if (
|
|
70
|
+
if (this.originKeywords?.length > 0 && (isStartWithHotkey || isIncludeKeywords)) {
|
|
71
71
|
Transforms.delete(this.editor, { distance: this.originKeywords.length, reverse: true });
|
|
72
72
|
}
|
|
73
73
|
};
|
|
@@ -248,4 +248,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
|
|
|
248
248
|
}], autoActiveFirstItem: [{
|
|
249
249
|
type: Input
|
|
250
250
|
}] } });
|
|
251
|
-
//# 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 { NgFor, NgIf } from '@angular/common';\nimport { ChangeDetectorRef, Component, ElementRef, HostBinding, Input, NgZone, OnInit, ViewChildren } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { ThyAction } from 'ngx-tethys/action';\nimport { ScrollToService } from 'ngx-tethys/core';\nimport { ThyDivider } from 'ngx-tethys/divider';\nimport { ThyDropdownDirective, ThyDropdownMenuComponent, ThyDropdownMenuGroup, ThyDropdownMenuItemDirective } from 'ngx-tethys/dropdown';\nimport { ThyEmptyModule } from 'ngx-tethys/empty';\nimport { ThyIcon } from 'ngx-tethys/icon';\nimport { ThyInputSearch } from 'ngx-tethys/input';\nimport { ThyPopoverDirective, ThyPopoverRef } from 'ngx-tethys/popover';\nimport { ThyTooltipDirective } from 'ngx-tethys/tooltip';\nimport { Editor, Node, PathRef, Text, Transforms } from 'slate';\nimport { AngularEditor } from 'slate-angular';\nimport { DefaultPluginMenu, ThePluginMenuItemType } from '../../constants';\nimport { buildPluginMenu, buildPluginMenuItemMap } from '../../core';\nimport { ThePluginMenu, ThePluginMenuGroup, ThePluginMenuItem, ThePluginMenuItemConfig, ThePluginMenuItemWrap } from '../../interfaces';\nimport { PluginMenuPipe } from '../../pipes';\nimport { QuickInsertEditor } from '../../plugins/public-api';\nimport { refocus } from '../../utils';\nimport { ThePreventDefaultDirective } from '../action/prevent-default';\nimport { TheListboxChangeEvent, TheListboxDirective, TheListboxGroupDirective, TheListboxOptionDirective } from '../listbox/listbox';\nimport { TheTableSelect } from '../table-select/table-select.component';\n\n@Component({\n    selector: 'the-plugin-menu',\n    templateUrl: 'plugin-menu.component.html',\n    standalone: true,\n    imports: [\n        NgIf,\n        NgFor,\n        FormsModule,\n        ThyEmptyModule,\n        TheTableSelect,\n        ThyIcon,\n        ThyAction,\n        ThyDivider,\n        ThyInputSearch,\n        ThyDropdownMenuComponent,\n        ThyDropdownMenuGroup,\n        PluginMenuPipe,\n        ThyTooltipDirective,\n        ThyPopoverDirective,\n        TheListboxDirective,\n        ThyDropdownDirective,\n        TheListboxGroupDirective,\n        TheListboxOptionDirective,\n        ThePreventDefaultDirective,\n        ThyDropdownMenuItemDirective\n    ]\n})\nexport class ThePluginMenuComponent implements OnInit {\n    listBoxAutoActiveFirstItem = true;\n\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    searchGroup: ThePluginMenuGroup = {\n        groupName: '搜索结果'\n    };\n\n    expandPopoverOptions = {\n        placement: 'rightTop',\n        width: '262px',\n        minWidth: '262px'\n    };\n\n    tableSelectPopoverConfig = {\n        panelClass: 'plugin-menu-table-select-container',\n        minWidth: 0,\n        //  避免重写\n        originActiveClass: 'thy-popover-origin-active'\n    };\n\n    originKeywords: string;\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    @Input() sceneKey?: string;\n\n    @Input() subPanelClass: string | string[];\n\n    @Input() autoActiveFirstItem: boolean = true;\n\n    constructor(\n        public elementRef: ElementRef<HTMLElement>,\n        public cdr: ChangeDetectorRef,\n        private ngZone: NgZone,\n        private thyPopoverRef: ThyPopoverRef<ThePluginMenuComponent>\n    ) {}\n\n    ngOnInit() {\n        if (!this.autoActiveFirstItem || this.theDisplaySearch) {\n            this.listBoxAutoActiveFirstItem = false;\n        }\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\n        this._pluginMenu.forEach((item: ThePluginMenuItemWrap) => {\n            const isHidden = item?.isHidden && item.isHidden(this.editor);\n\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 | 'divider') => {\n                        if (child === 'divider') return;\n\n                        child.isMenuItem = true;\n                        child.disabled = child.isDisabled && child.isDisabled(this.editor);\n\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\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        if (!this.keyWords) {\n            const menus = [...this.groupMenu];\n            this.groupMenu = menus.filter((item: ThePluginMenuItemWrap, index: number) => {\n                const isGroupMenu = ThePluginMenu.isMenuGroup(item);\n                const nextMenu = menus[index + 1];\n                const isLastMenu = index === menus.length - 1;\n\n                if (\n                    (nextMenu && isGroupMenu && ThePluginMenu.isMenuGroup(nextMenu)) ||\n                    (isLastMenu && isGroupMenu) ||\n                    (item?.children && item?.children?.length <= 0)\n                ) {\n                    return false;\n                }\n\n                return true;\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            menuItem?.removeKeywordsType === 'character' ? this.removeCharacter() : this.removeBlock();\n        }\n        menuItem.execute(this.editor);\n        this.thyPopoverRef.close();\n        QuickInsertEditor.updatePluginMenuRef(this.editor, null);\n    }\n\n    removeBlock = () => {\n        const node = Node.get(this.editor, this.editor.selection.anchor.path) as Text;\n        const nodeString = Node.string(node);\n        const isStartWithHotkey = nodeString.startsWith('/');\n        const isIncludeKeywords = nodeString.toLocaleLowerCase().trim().includes(this.keyWords);\n        if (node && nodeString.length > 0 && (isStartWithHotkey || isIncludeKeywords)) {\n            Editor.deleteBackward(this.editor, { unit: 'block' });\n        }\n    };\n\n    removeCharacter = () => {\n        const node = Node.get(this.editor, this.editor.selection.anchor.path) as Text;\n        const nodeString = Node.string(node);\n        const isStartWithHotkey = nodeString.startsWith('/') || nodeString.startsWith('#');\n        const isIncludeKeywords = nodeString.toLocaleLowerCase().trim().includes(this.keyWords);\n        if (node && nodeString.length > 1 && (isStartWithHotkey || isIncludeKeywords)) {\n            Transforms.delete(this.editor, { distance: this.originKeywords.length, reverse: true });\n        }\n    };\n\n    updateKeywords(keywords: string) {\n        if (this.autoActiveFirstItem) {\n            this.listBoxAutoActiveFirstItem = true;\n        }\n        this.originKeywords = keywords;\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","<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 empty\"\n  theListBox\n  [keyboardContainer]=\"keyboardContainer\"\n  [autoActiveFirstItem]=\"listBoxAutoActiveFirstItem\"\n  (theListboxChange)=\"theListboxChange($event)\"\n  class=\"thy-dropdown-menu the-plugin-menu-scroll-container pb-2 pt-0\"\n>\n  <ng-container *ngIf=\"iconMenu?.length > 0\">\n    <div 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    <thy-divider class=\"my-2\"></thy-divider>\n  </ng-container>\n\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 *ngIf=\"item.menuIcon\" class=\"menu-icon mr-2\">\n            <thy-icon [thyIconName]=\"item.menuIcon | getMenuIcon: sceneKey\"></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\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          [thyPanelClass]=\"subPanelClass\"\n          (click)=\"handleItemSelection(item)\"\n        >\n          <div *ngIf=\"item.menuIcon\" class=\"menu-icon mr-2\">\n            <thy-icon [thyIconName]=\"item.menuIcon | getMenuIcon: sceneKey\"></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              <ng-container *ngFor=\"let child of item.children\">\n                <div\n                  *ngIf=\"child.type === ThePluginMenuItemType.group\"\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 *ngIf=\"child.menuIcon\" class=\"menu-icon mr-2\">\n                    <thy-icon [thyIconName]=\"child.menuIcon | getMenuIcon: sceneKey\"></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                <thy-divider *ngIf=\"child === 'divider'\" class=\"my-2\"></thy-divider>\n              </ng-container>\n            </div>\n          </thy-dropdown-menu>\n        </div>\n      </ng-container>\n\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 | getMenuIcon: sceneKey\"></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 class=\"plugin-menu-table the-table-selector-panel\" [editor]=\"editor\" [beforeInsert]=\"removeBlock\"></table-select>\n          </ng-template>\n        </div>\n      </ng-container>\n\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 #empty>\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"]}
|
|
251
|
+
//# 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 { NgFor, NgIf } from '@angular/common';\nimport { ChangeDetectorRef, Component, ElementRef, HostBinding, Input, NgZone, OnInit, ViewChildren } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { ThyAction } from 'ngx-tethys/action';\nimport { ScrollToService } from 'ngx-tethys/core';\nimport { ThyDivider } from 'ngx-tethys/divider';\nimport { ThyDropdownDirective, ThyDropdownMenuComponent, ThyDropdownMenuGroup, ThyDropdownMenuItemDirective } from 'ngx-tethys/dropdown';\nimport { ThyEmptyModule } from 'ngx-tethys/empty';\nimport { ThyIcon } from 'ngx-tethys/icon';\nimport { ThyInputSearch } from 'ngx-tethys/input';\nimport { ThyPopoverDirective, ThyPopoverRef } from 'ngx-tethys/popover';\nimport { ThyTooltipDirective } from 'ngx-tethys/tooltip';\nimport { Editor, Node, PathRef, Text, Transforms } from 'slate';\nimport { AngularEditor } from 'slate-angular';\nimport { DefaultPluginMenu, ThePluginMenuItemType } from '../../constants';\nimport { buildPluginMenu, buildPluginMenuItemMap } from '../../core';\nimport { ThePluginMenu, ThePluginMenuGroup, ThePluginMenuItem, ThePluginMenuItemConfig, ThePluginMenuItemWrap } from '../../interfaces';\nimport { PluginMenuPipe } from '../../pipes';\nimport { QuickInsertEditor } from '../../plugins/public-api';\nimport { refocus } from '../../utils';\nimport { ThePreventDefaultDirective } from '../action/prevent-default';\nimport { TheListboxChangeEvent, TheListboxDirective, TheListboxGroupDirective, TheListboxOptionDirective } from '../listbox/listbox';\nimport { TheTableSelect } from '../table-select/table-select.component';\n\n@Component({\n    selector: 'the-plugin-menu',\n    templateUrl: 'plugin-menu.component.html',\n    standalone: true,\n    imports: [\n        NgIf,\n        NgFor,\n        FormsModule,\n        ThyEmptyModule,\n        TheTableSelect,\n        ThyIcon,\n        ThyAction,\n        ThyDivider,\n        ThyInputSearch,\n        ThyDropdownMenuComponent,\n        ThyDropdownMenuGroup,\n        PluginMenuPipe,\n        ThyTooltipDirective,\n        ThyPopoverDirective,\n        TheListboxDirective,\n        ThyDropdownDirective,\n        TheListboxGroupDirective,\n        TheListboxOptionDirective,\n        ThePreventDefaultDirective,\n        ThyDropdownMenuItemDirective\n    ]\n})\nexport class ThePluginMenuComponent implements OnInit {\n    listBoxAutoActiveFirstItem = true;\n\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    searchGroup: ThePluginMenuGroup = {\n        groupName: '搜索结果'\n    };\n\n    expandPopoverOptions = {\n        placement: 'rightTop',\n        width: '262px',\n        minWidth: '262px'\n    };\n\n    tableSelectPopoverConfig = {\n        panelClass: 'plugin-menu-table-select-container',\n        minWidth: 0,\n        //  避免重写\n        originActiveClass: 'thy-popover-origin-active'\n    };\n\n    originKeywords: string;\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    @Input() sceneKey?: string;\n\n    @Input() subPanelClass: string | string[];\n\n    @Input() autoActiveFirstItem: boolean = true;\n\n    constructor(\n        public elementRef: ElementRef<HTMLElement>,\n        public cdr: ChangeDetectorRef,\n        private ngZone: NgZone,\n        private thyPopoverRef: ThyPopoverRef<ThePluginMenuComponent>\n    ) {}\n\n    ngOnInit() {\n        if (!this.autoActiveFirstItem || this.theDisplaySearch) {\n            this.listBoxAutoActiveFirstItem = false;\n        }\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\n        this._pluginMenu.forEach((item: ThePluginMenuItemWrap) => {\n            const isHidden = item?.isHidden && item.isHidden(this.editor);\n\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 | 'divider') => {\n                        if (child === 'divider') return;\n\n                        child.isMenuItem = true;\n                        child.disabled = child.isDisabled && child.isDisabled(this.editor);\n\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\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        if (!this.keyWords) {\n            const menus = [...this.groupMenu];\n            this.groupMenu = menus.filter((item: ThePluginMenuItemWrap, index: number) => {\n                const isGroupMenu = ThePluginMenu.isMenuGroup(item);\n                const nextMenu = menus[index + 1];\n                const isLastMenu = index === menus.length - 1;\n\n                if (\n                    (nextMenu && isGroupMenu && ThePluginMenu.isMenuGroup(nextMenu)) ||\n                    (isLastMenu && isGroupMenu) ||\n                    (item?.children && item?.children?.length <= 0)\n                ) {\n                    return false;\n                }\n\n                return true;\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            menuItem?.removeKeywordsType === 'character' ? this.removeCharacter() : this.removeBlock();\n        }\n        menuItem.execute(this.editor);\n        this.thyPopoverRef.close();\n        QuickInsertEditor.updatePluginMenuRef(this.editor, null);\n    }\n\n    removeBlock = () => {\n        const node = Node.get(this.editor, this.editor.selection.anchor.path) as Text;\n        const nodeString = Node.string(node);\n        const isStartWithHotkey = nodeString.startsWith('/');\n        const isIncludeKeywords = nodeString.toLocaleLowerCase().trim().includes(this.keyWords);\n        if (node && nodeString.length > 0 && (isStartWithHotkey || isIncludeKeywords)) {\n            Editor.deleteBackward(this.editor, { unit: 'block' });\n        }\n    };\n\n    removeCharacter = () => {\n        const node = Node.get(this.editor, this.editor.selection.anchor.path) as Text;\n        const nodeString = Node.string(node);\n        const isStartWithHotkey = nodeString.startsWith('/') || nodeString.startsWith('#');\n        const isIncludeKeywords = nodeString.toLocaleLowerCase().trim().includes(this.keyWords);\n        if (this.originKeywords?.length > 0 && (isStartWithHotkey || isIncludeKeywords)) {\n            Transforms.delete(this.editor, { distance: this.originKeywords.length, reverse: true });\n        }\n    };\n\n    updateKeywords(keywords: string) {\n        if (this.autoActiveFirstItem) {\n            this.listBoxAutoActiveFirstItem = true;\n        }\n        this.originKeywords = keywords;\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","<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 empty\"\n  theListBox\n  [keyboardContainer]=\"keyboardContainer\"\n  [autoActiveFirstItem]=\"listBoxAutoActiveFirstItem\"\n  (theListboxChange)=\"theListboxChange($event)\"\n  class=\"thy-dropdown-menu the-plugin-menu-scroll-container pb-2 pt-0\"\n>\n  <ng-container *ngIf=\"iconMenu?.length > 0\">\n    <div 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    <thy-divider class=\"my-2\"></thy-divider>\n  </ng-container>\n\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 *ngIf=\"item.menuIcon\" class=\"menu-icon mr-2\">\n            <thy-icon [thyIconName]=\"item.menuIcon | getMenuIcon: sceneKey\"></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\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          [thyPanelClass]=\"subPanelClass\"\n          (click)=\"handleItemSelection(item)\"\n        >\n          <div *ngIf=\"item.menuIcon\" class=\"menu-icon mr-2\">\n            <thy-icon [thyIconName]=\"item.menuIcon | getMenuIcon: sceneKey\"></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              <ng-container *ngFor=\"let child of item.children\">\n                <div\n                  *ngIf=\"child.type === ThePluginMenuItemType.group\"\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 *ngIf=\"child.menuIcon\" class=\"menu-icon mr-2\">\n                    <thy-icon [thyIconName]=\"child.menuIcon | getMenuIcon: sceneKey\"></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                <thy-divider *ngIf=\"child === 'divider'\" class=\"my-2\"></thy-divider>\n              </ng-container>\n            </div>\n          </thy-dropdown-menu>\n        </div>\n      </ng-container>\n\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 | getMenuIcon: sceneKey\"></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 class=\"plugin-menu-table the-table-selector-panel\" [editor]=\"editor\" [beforeInsert]=\"removeBlock\"></table-select>\n          </ng-template>\n        </div>\n      </ng-container>\n\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 #empty>\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"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, ElementRef, HostBinding, HostListener, Input, ViewChild } from '@angular/core';
|
|
1
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, HostBinding, HostListener, Input, Renderer2, ViewChild, inject } from '@angular/core';
|
|
2
2
|
import { ThyIcon } from 'ngx-tethys/icon';
|
|
3
3
|
import { Node } from 'slate';
|
|
4
4
|
import { AngularEditor } from 'slate-angular';
|
|
@@ -8,19 +8,19 @@ import { isCleanEmptyParagraph } from '../../../utils/is-clean-empty-paragraph';
|
|
|
8
8
|
import { QuickInsertEditor } from '../quick-insert.editor';
|
|
9
9
|
import * as i0 from "@angular/core";
|
|
10
10
|
export class TheQuickInsert {
|
|
11
|
-
|
|
12
|
-
event.preventDefault();
|
|
13
|
-
event.stopPropagation();
|
|
14
|
-
}
|
|
15
|
-
constructor(renderer, elementRef, cdr) {
|
|
16
|
-
this.renderer = renderer;
|
|
17
|
-
this.elementRef = elementRef;
|
|
18
|
-
this.cdr = cdr;
|
|
11
|
+
constructor() {
|
|
19
12
|
this.className = 'the-quick-insert';
|
|
20
13
|
this.isVisible = false;
|
|
21
14
|
this.defaultIconName = 'plus-circle-thin';
|
|
22
15
|
this.iconNameFill = 'plus-circle-thin-fill';
|
|
23
16
|
this.displayIconName = this.defaultIconName;
|
|
17
|
+
this.cdr = inject(ChangeDetectorRef);
|
|
18
|
+
this.renderer = inject(Renderer2);
|
|
19
|
+
this.elementRef = inject((ElementRef));
|
|
20
|
+
}
|
|
21
|
+
handleMousedownNativeElement(event) {
|
|
22
|
+
event.preventDefault();
|
|
23
|
+
event.stopPropagation();
|
|
24
24
|
}
|
|
25
25
|
ngOnInit() {
|
|
26
26
|
const { onChange } = this.editor;
|
|
@@ -84,11 +84,11 @@ export class TheQuickInsert {
|
|
|
84
84
|
}
|
|
85
85
|
mouseEnter(event) {
|
|
86
86
|
this.displayIconName = this.iconNameFill;
|
|
87
|
-
this.cdr.
|
|
87
|
+
this.cdr.detectChanges();
|
|
88
88
|
}
|
|
89
89
|
mouseLeave(event) {
|
|
90
90
|
this.displayIconName = this.defaultIconName;
|
|
91
|
-
this.cdr.
|
|
91
|
+
this.cdr.detectChanges();
|
|
92
92
|
}
|
|
93
93
|
handleClick(event) {
|
|
94
94
|
event.stopPropagation();
|
|
@@ -103,13 +103,13 @@ export class TheQuickInsert {
|
|
|
103
103
|
this.updateIconDisplay();
|
|
104
104
|
}, 100);
|
|
105
105
|
}
|
|
106
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: TheQuickInsert, deps: [
|
|
107
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.0", type: TheQuickInsert, isStandalone: true, selector: "[theQuickInsert]", inputs: { editor: "editor", isVisible: "isVisible" }, host: { listeners: { "mousedown": "handleMousedownNativeElement($event)" }, properties: { "class": "this.className" } }, viewQueries: [{ propertyName: "iconElement", first: true, predicate: ["iconElement"], descendants: true, read: ElementRef }], usesOnChanges: true, ngImport: i0, template: "<thy-icon\n #iconElement\n
|
|
106
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: TheQuickInsert, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
107
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.0", type: TheQuickInsert, isStandalone: true, selector: "[theQuickInsert]", inputs: { editor: "editor", isVisible: "isVisible" }, host: { listeners: { "mousedown": "handleMousedownNativeElement($event)" }, properties: { "class": "this.className" } }, viewQueries: [{ propertyName: "iconElement", first: true, predicate: ["iconElement"], descendants: true, read: ElementRef }], usesOnChanges: true, ngImport: i0, template: "<thy-icon\n #iconElement\n class=\"quick-insert-icon text-desc font-size-xlg\"\n [thyIconName]=\"displayIconName\"\n (mouseenter)=\"mouseEnter($event)\"\n (mouseleave)=\"mouseLeave($event)\"\n (mouseup)=\"handleClick($event)\"\n></thy-icon>\n", dependencies: [{ kind: "component", type: ThyIcon, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
108
108
|
}
|
|
109
109
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: TheQuickInsert, decorators: [{
|
|
110
110
|
type: Component,
|
|
111
|
-
args: [{ selector: '[theQuickInsert]', standalone: true, imports: [ThyIcon], template: "<thy-icon\n #iconElement\n
|
|
112
|
-
}],
|
|
111
|
+
args: [{ selector: '[theQuickInsert]', standalone: true, imports: [ThyIcon], changeDetection: ChangeDetectionStrategy.OnPush, template: "<thy-icon\n #iconElement\n class=\"quick-insert-icon text-desc font-size-xlg\"\n [thyIconName]=\"displayIconName\"\n (mouseenter)=\"mouseEnter($event)\"\n (mouseleave)=\"mouseLeave($event)\"\n (mouseup)=\"handleClick($event)\"\n></thy-icon>\n" }]
|
|
112
|
+
}], propDecorators: { className: [{
|
|
113
113
|
type: HostBinding,
|
|
114
114
|
args: ['class']
|
|
115
115
|
}], editor: [{
|
|
@@ -123,4 +123,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
|
|
|
123
123
|
type: HostListener,
|
|
124
124
|
args: ['mousedown', ['$event']]
|
|
125
125
|
}] } });
|
|
126
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"quick-insert.component.js","sourceRoot":"","sources":["../../../../../../packages/src/plugins/quick-insert/components/quick-insert.component.ts","../../../../../../packages/src/plugins/quick-insert/components/quick-insert.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    HostBinding,\n    HostListener,\n    Input,\n    OnChanges,\n    OnInit,\n    Renderer2,\n    SimpleChanges,\n    ViewChild\n} from '@angular/core';\nimport { ThyIcon } from 'ngx-tethys/icon';\nimport { Editor, Node } from 'slate';\nimport { AngularEditor } from 'slate-angular';\nimport { MarkTypes } from '../../../constants/node-types';\nimport * as TheQueries from '../../../queries';\nimport { isCleanEmptyParagraph } from '../../../utils/is-clean-empty-paragraph';\nimport { QuickInsertEditor } from '../quick-insert.editor';\n\n@Component({\n    selector: '[theQuickInsert]',\n    templateUrl: './quick-insert.component.html',\n    standalone: true,\n    imports: [ThyIcon]\n})\nexport class TheQuickInsert implements OnInit, OnChanges {\n    @HostBinding('class')\n    className = 'the-quick-insert';\n\n    @Input() editor: Editor;\n\n    @Input() isVisible = false;\n\n    defaultIconName = 'plus-circle-thin';\n\n    iconNameFill = 'plus-circle-thin-fill';\n\n    displayIconName = this.defaultIconName;\n\n    @ViewChild('iconElement', { read: ElementRef, static: false })\n    iconElement: ElementRef<any>;\n\n    @HostListener('mousedown', ['$event'])\n    handleMousedownNativeElement(event) {\n        event.preventDefault();\n        event.stopPropagation();\n    }\n\n    constructor(\n        private renderer: Renderer2,\n        private elementRef: ElementRef<HTMLElement>,\n        private cdr: ChangeDetectorRef\n    ) {}\n\n    ngOnInit(): void {\n        const { onChange } = this.editor;\n        this.editor.onChange = () => {\n            onChange();\n\n            if (this.editor && this.editor.options && !this.editor.options.readonly) {\n                // wait isOpenedMenu is updated\n                setTimeout(() => {\n                    this.updateIconDisplay();\n                }, 0);\n            }\n        };\n        this.updateIconDisplay();\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.isVisible && !changes.isVisible.firstChange) {\n            this.updateIconDisplay();\n        }\n    }\n\n    public updateIconDisplay() {\n        const { editor } = this;\n        if (\n            this.isVisible &&\n            !QuickInsertEditor.isOpenedMenu(editor) &&\n            isCleanEmptyParagraph(editor) &&\n            !this.hasExcludeAttribute() &&\n            !this.isRichMediaScope()\n        ) {\n            const block = Node.ancestor(editor, [editor?.selection?.anchor.path[0]]);\n            const rootNode: HTMLElement = AngularEditor.toDOMNode(editor, block);\n            this.updatePosition(rootNode.offsetLeft, rootNode.offsetTop);\n            return;\n        }\n        this.addHiddenClass();\n    }\n\n    private addHiddenClass() {\n        this.elementRef.nativeElement.classList.add('d-none');\n    }\n\n    private removeHiddenClass() {\n        this.elementRef.nativeElement.classList.remove('d-none');\n    }\n\n    private isRichMediaScope() {\n        const { editor } = this;\n        if (editor?.selection) {\n            const block = Node.ancestor(editor, [editor?.selection?.anchor.path[0]]);\n            const rootElement = AngularEditor.toDOMNode(editor, block);\n            const leafElement = rootElement.querySelector('[data-slate-leaf=\"true\"]');\n            const rootElementRect = rootElement.getBoundingClientRect();\n            const leafElementRect = leafElement.getBoundingClientRect();\n            return leafElementRect?.x !== rootElementRect?.x;\n        }\n        return false;\n    }\n\n    private hasExcludeAttribute() {\n        const marks = TheQueries.getSelectionMarks(this.editor);\n        const fontSizeMark: number = marks[MarkTypes.fontSize];\n\n        return fontSizeMark;\n    }\n\n    private updatePosition(left: number, top?: number) {\n        this.renderer.setStyle(this.elementRef.nativeElement, 'top', `${top}px`);\n        this.renderer.setStyle(this.elementRef.nativeElement, 'left', `${left}px`);\n        this.removeHiddenClass();\n    }\n\n    mouseEnter(event: MouseEvent) {\n        this.displayIconName = this.iconNameFill;\n        this.cdr.markForCheck();\n    }\n\n    mouseLeave(event: MouseEvent) {\n        this.displayIconName = this.defaultIconName;\n        this.cdr.markForCheck();\n    }\n\n    handleClick(event: MouseEvent) {\n        event.stopPropagation();\n        event.preventDefault();\n        // avoid popover is closed immediately\n        setTimeout(() => {\n            QuickInsertEditor.openMenu(this.editor)\n                .afterClosed()\n                .subscribe(() => {\n                    this.updateIconDisplay();\n                });\n            this.updateIconDisplay();\n        }, 100);\n    }\n}\n","<thy-icon\n  #iconElement\n  [thyIconName]=\"displayIconName\"\n  class=\"quick-insert-icon text-desc font-size-xlg\"\n  (mouseenter)=\"mouseEnter($event)\"\n  (mouseleave)=\"mouseLeave($event)\"\n  (mousedown)=\"handleClick($event)\"\n></thy-icon>\n"]}
|
|
126
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"quick-insert.component.js","sourceRoot":"","sources":["../../../../../../packages/src/plugins/quick-insert/components/quick-insert.component.ts","../../../../../../packages/src/plugins/quick-insert/components/quick-insert.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    HostBinding,\n    HostListener,\n    Input,\n    OnChanges,\n    OnInit,\n    Renderer2,\n    SimpleChanges,\n    ViewChild,\n    inject\n} from '@angular/core';\nimport { ThyIcon } from 'ngx-tethys/icon';\nimport { Editor, Node } from 'slate';\nimport { AngularEditor } from 'slate-angular';\nimport { MarkTypes } from '../../../constants/node-types';\nimport * as TheQueries from '../../../queries';\nimport { isCleanEmptyParagraph } from '../../../utils/is-clean-empty-paragraph';\nimport { QuickInsertEditor } from '../quick-insert.editor';\n\n@Component({\n    selector: '[theQuickInsert]',\n    templateUrl: './quick-insert.component.html',\n    standalone: true,\n    imports: [ThyIcon],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TheQuickInsert implements OnInit, OnChanges {\n    @HostBinding('class') className = 'the-quick-insert';\n\n    @Input() editor: Editor;\n\n    @Input() isVisible = false;\n\n    defaultIconName = 'plus-circle-thin';\n\n    iconNameFill = 'plus-circle-thin-fill';\n\n    displayIconName = this.defaultIconName;\n\n    @ViewChild('iconElement', { read: ElementRef, static: false })\n    iconElement: ElementRef<any>;\n\n    @HostListener('mousedown', ['$event'])\n    handleMousedownNativeElement(event) {\n        event.preventDefault();\n        event.stopPropagation();\n    }\n\n    private cdr = inject(ChangeDetectorRef);\n    private renderer = inject(Renderer2);\n    private elementRef = inject(ElementRef<HTMLElement>);\n\n    ngOnInit(): void {\n        const { onChange } = this.editor;\n        this.editor.onChange = () => {\n            onChange();\n\n            if (this.editor && this.editor.options && !this.editor.options.readonly) {\n                // wait isOpenedMenu is updated\n                setTimeout(() => {\n                    this.updateIconDisplay();\n                }, 0);\n            }\n        };\n        this.updateIconDisplay();\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.isVisible && !changes.isVisible.firstChange) {\n            this.updateIconDisplay();\n        }\n    }\n\n    public updateIconDisplay() {\n        const { editor } = this;\n        if (\n            this.isVisible &&\n            !QuickInsertEditor.isOpenedMenu(editor) &&\n            isCleanEmptyParagraph(editor) &&\n            !this.hasExcludeAttribute() &&\n            !this.isRichMediaScope()\n        ) {\n            const block = Node.ancestor(editor, [editor?.selection?.anchor.path[0]]);\n            const rootNode: HTMLElement = AngularEditor.toDOMNode(editor, block);\n            this.updatePosition(rootNode.offsetLeft, rootNode.offsetTop);\n            return;\n        }\n        this.addHiddenClass();\n    }\n\n    private addHiddenClass() {\n        this.elementRef.nativeElement.classList.add('d-none');\n    }\n\n    private removeHiddenClass() {\n        this.elementRef.nativeElement.classList.remove('d-none');\n    }\n\n    private isRichMediaScope() {\n        const { editor } = this;\n        if (editor?.selection) {\n            const block = Node.ancestor(editor, [editor?.selection?.anchor.path[0]]);\n            const rootElement = AngularEditor.toDOMNode(editor, block);\n            const leafElement = rootElement.querySelector('[data-slate-leaf=\"true\"]');\n            const rootElementRect = rootElement.getBoundingClientRect();\n            const leafElementRect = leafElement.getBoundingClientRect();\n            return leafElementRect?.x !== rootElementRect?.x;\n        }\n        return false;\n    }\n\n    private hasExcludeAttribute() {\n        const marks = TheQueries.getSelectionMarks(this.editor);\n        const fontSizeMark: number = marks[MarkTypes.fontSize];\n        return fontSizeMark;\n    }\n\n    private updatePosition(left: number, top?: number) {\n        this.renderer.setStyle(this.elementRef.nativeElement, 'top', `${top}px`);\n        this.renderer.setStyle(this.elementRef.nativeElement, 'left', `${left}px`);\n        this.removeHiddenClass();\n    }\n\n    mouseEnter(event: MouseEvent) {\n        this.displayIconName = this.iconNameFill;\n        this.cdr.detectChanges();\n    }\n\n    mouseLeave(event: MouseEvent) {\n        this.displayIconName = this.defaultIconName;\n        this.cdr.detectChanges();\n    }\n\n    handleClick(event: MouseEvent) {\n        event.stopPropagation();\n        event.preventDefault();\n        // avoid popover is closed immediately\n        setTimeout(() => {\n            QuickInsertEditor.openMenu(this.editor)\n                .afterClosed()\n                .subscribe(() => {\n                    this.updateIconDisplay();\n                });\n            this.updateIconDisplay();\n        }, 100);\n    }\n}\n","<thy-icon\n  #iconElement\n  class=\"quick-insert-icon text-desc font-size-xlg\"\n  [thyIconName]=\"displayIconName\"\n  (mouseenter)=\"mouseEnter($event)\"\n  (mouseleave)=\"mouseLeave($event)\"\n  (mouseup)=\"handleClick($event)\"\n></thy-icon>\n"]}
|
|
@@ -3,7 +3,7 @@ import { Editor, Path, Range, Transforms } from 'slate';
|
|
|
3
3
|
import { getPluginOptions } from '../core/utils/get-plugin-options';
|
|
4
4
|
import * as TheQueries from '../queries';
|
|
5
5
|
import { refocus } from '../utils';
|
|
6
|
-
export const insertElements = (editor, elements) => {
|
|
6
|
+
export const insertElements = (editor, elements, select = true) => {
|
|
7
7
|
if (!editor.selection) {
|
|
8
8
|
refocus(editor);
|
|
9
9
|
}
|
|
@@ -14,25 +14,19 @@ export const insertElements = (editor, elements) => {
|
|
|
14
14
|
const allowParentTypes = getPluginOptions(editor, type)?.allowParentTypes || [];
|
|
15
15
|
const insertNodePath = TheQueries.getInsertElementsPath(editor, allowParentTypes);
|
|
16
16
|
const [anchorBlock, anchorBlockPath] = TheQueries.anchorBlockEntry(editor);
|
|
17
|
-
|
|
17
|
+
const isEmpty = Editor.isEmpty(editor, anchorBlock);
|
|
18
18
|
if (insertNodePath) {
|
|
19
19
|
Editor.withoutNormalizing(editor, () => {
|
|
20
|
-
Transforms.insertNodes(editor, elements, { at: insertNodePath });
|
|
21
|
-
Transforms.select(editor, Editor.start(editor, insertNodePath));
|
|
20
|
+
Transforms.insertNodes(editor, elements, { at: insertNodePath, select });
|
|
22
21
|
if (isEmpty) {
|
|
23
22
|
Transforms.removeNodes(editor, { at: anchorBlockPath });
|
|
24
23
|
}
|
|
25
24
|
});
|
|
26
25
|
return;
|
|
27
26
|
}
|
|
28
|
-
|
|
29
|
-
Transforms.insertNodes(editor, elements, { at: nextPath });
|
|
27
|
+
Transforms.insertNodes(editor, elements, { at: Path.next([anchorBlockPath[0]]), select });
|
|
30
28
|
if (isEmpty && anchorBlockPath.length === 1) {
|
|
31
29
|
Transforms.delete(editor, { at: anchorBlockPath });
|
|
32
|
-
Transforms.select(editor, Editor.start(editor, anchorBlockPath));
|
|
33
|
-
}
|
|
34
|
-
else {
|
|
35
|
-
Transforms.select(editor, Editor.start(editor, nextPath));
|
|
36
30
|
}
|
|
37
31
|
};
|
|
38
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5zZXJ0LWVsZW1lbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvc3JjL3RyYW5zZm9ybXMvaW5zZXJ0LWVsZW1lbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMxQyxPQUFPLEVBQUUsTUFBTSxFQUFXLElBQUksRUFBRSxLQUFLLEVBQUUsVUFBVSxFQUFFLE1BQU0sT0FBTyxDQUFDO0FBQ2pFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBRXBFLE9BQU8sS0FBSyxVQUFVLE1BQU0sWUFBWSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFFbkMsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUFHLENBQUMsTUFBYyxFQUFFLFFBQTZCLEVBQUUsTUFBTSxHQUFHLElBQUksRUFBRSxFQUFFO0lBQzNGLElBQUksQ0FBQyxNQUFNLENBQUMsU0FBUyxFQUFFLENBQUM7UUFDcEIsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ3BCLENBQUM7SUFDRCxJQUFJLEtBQUssQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxFQUFFLENBQUM7UUFDckMsTUFBTSxDQUFDLGNBQWMsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUNsQyxDQUFDO0lBQ0QsTUFBTSxJQUFJLEdBQUcsQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxlQUFlO0lBQ25GLE1BQU0sZ0JBQWdCLEdBQUcsZ0JBQWdCLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxFQUFFLGdCQUFnQixJQUFJLEVBQUUsQ0FBQztJQUNoRixNQUFNLGNBQWMsR0FBRyxVQUFVLENBQUMscUJBQXFCLENBQUMsTUFBTSxFQUFFLGdCQUF3QyxDQUFDLENBQUM7SUFDMUcsTUFBTSxDQUFDLFdBQVcsRUFBRSxlQUFlLENBQUMsR0FBRyxVQUFVLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDM0UsTUFBTSxPQUFPLEdBQUcsTUFBTSxDQUFDLE9BQU8sQ0FBQyxNQUFNLEVBQUUsV0FBVyxDQUFDLENBQUM7SUFFcEQsSUFBSSxjQUFjLEVBQUUsQ0FBQztRQUNqQixNQUFNLENBQUMsa0JBQWtCLENBQUMsTUFBTSxFQUFFLEdBQUcsRUFBRTtZQUNuQyxVQUFVLENBQUMsV0FBVyxDQUFDLE1BQU0sRUFBRSxRQUFRLEVBQUUsRUFBRSxFQUFFLEVBQUUsY0FBYyxFQUFFLE1BQU0sRUFBRSxDQUFDLENBQUM7WUFDekUsSUFBSSxPQUFPLEVBQUUsQ0FBQztnQkFDVixVQUFVLENBQUMsV0FBVyxDQUFDLE1BQU0sRUFBRSxFQUFFLEVBQUUsRUFBRSxlQUFlLEVBQUUsQ0FBQyxDQUFDO1lBQzVELENBQUM7UUFDTCxDQUFDLENBQUMsQ0FBQztRQUNILE9BQU87SUFDWCxDQUFDO0lBRUQsVUFBVSxDQUFDLFdBQVcsQ0FBQyxNQUFNLEVBQUUsUUFBUSxFQUFFLEVBQUUsRUFBRSxFQUFFLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxlQUFlLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLE1BQU0sRUFBRSxDQUFDLENBQUM7SUFDMUYsSUFBSSxPQUFPLElBQUksZUFBZSxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUUsQ0FBQztRQUMxQyxVQUFVLENBQUMsTUFBTSxDQUFDLE1BQU0sRUFBRSxFQUFFLEVBQUUsRUFBRSxlQUFlLEVBQUUsQ0FBQyxDQUFDO0lBQ3ZELENBQUM7QUFDTCxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpc0FycmF5IH0gZnJvbSAnbmd4LXRldGh5cy91dGlsJztcbmltcG9ydCB7IEVkaXRvciwgRWxlbWVudCwgUGF0aCwgUmFuZ2UsIFRyYW5zZm9ybXMgfSBmcm9tICdzbGF0ZSc7XG5pbXBvcnQgeyBnZXRQbHVnaW5PcHRpb25zIH0gZnJvbSAnLi4vY29yZS91dGlscy9nZXQtcGx1Z2luLW9wdGlvbnMnO1xuaW1wb3J0IHsgQ3VzdG9tRWxlbWVudEtpbmRzIH0gZnJvbSAnLi4vY3VzdG9tLXR5cGVzJztcbmltcG9ydCAqIGFzIFRoZVF1ZXJpZXMgZnJvbSAnLi4vcXVlcmllcyc7XG5pbXBvcnQgeyByZWZvY3VzIH0gZnJvbSAnLi4vdXRpbHMnO1xuXG5leHBvcnQgY29uc3QgaW5zZXJ0RWxlbWVudHMgPSAoZWRpdG9yOiBFZGl0b3IsIGVsZW1lbnRzOiBFbGVtZW50IHwgRWxlbWVudFtdLCBzZWxlY3QgPSB0cnVlKSA9PiB7XG4gICAgaWYgKCFlZGl0b3Iuc2VsZWN0aW9uKSB7XG4gICAgICAgIHJlZm9jdXMoZWRpdG9yKTtcbiAgICB9XG4gICAgaWYgKFJhbmdlLmlzRXhwYW5kZWQoZWRpdG9yLnNlbGVjdGlvbikpIHtcbiAgICAgICAgRWRpdG9yLmRlbGV0ZUZyYWdtZW50KGVkaXRvcik7XG4gICAgfVxuICAgIGNvbnN0IHR5cGUgPSAhaXNBcnJheShlbGVtZW50cykgPyBlbGVtZW50cy50eXBlIDogZWxlbWVudHNbMF0udHlwZTsgLy8g5ZCO5pyf5aSE55CG5aSN5Yi257KY6LS06ZyA6KaB5L+u5pS5XG4gICAgY29uc3QgYWxsb3dQYXJlbnRUeXBlcyA9IGdldFBsdWdpbk9wdGlvbnMoZWRpdG9yLCB0eXBlKT8uYWxsb3dQYXJlbnRUeXBlcyB8fCBbXTtcbiAgICBjb25zdCBpbnNlcnROb2RlUGF0aCA9IFRoZVF1ZXJpZXMuZ2V0SW5zZXJ0RWxlbWVudHNQYXRoKGVkaXRvciwgYWxsb3dQYXJlbnRUeXBlcyBhcyBDdXN0b21FbGVtZW50S2luZHNbXSk7XG4gICAgY29uc3QgW2FuY2hvckJsb2NrLCBhbmNob3JCbG9ja1BhdGhdID0gVGhlUXVlcmllcy5hbmNob3JCbG9ja0VudHJ5KGVkaXRvcik7XG4gICAgY29uc3QgaXNFbXB0eSA9IEVkaXRvci5pc0VtcHR5KGVkaXRvciwgYW5jaG9yQmxvY2spO1xuXG4gICAgaWYgKGluc2VydE5vZGVQYXRoKSB7XG4gICAgICAgIEVkaXRvci53aXRob3V0Tm9ybWFsaXppbmcoZWRpdG9yLCAoKSA9PiB7XG4gICAgICAgICAgICBUcmFuc2Zvcm1zLmluc2VydE5vZGVzKGVkaXRvciwgZWxlbWVudHMsIHsgYXQ6IGluc2VydE5vZGVQYXRoLCBzZWxlY3QgfSk7XG4gICAgICAgICAgICBpZiAoaXNFbXB0eSkge1xuICAgICAgICAgICAgICAgIFRyYW5zZm9ybXMucmVtb3ZlTm9kZXMoZWRpdG9yLCB7IGF0OiBhbmNob3JCbG9ja1BhdGggfSk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH0pO1xuICAgICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgVHJhbnNmb3Jtcy5pbnNlcnROb2RlcyhlZGl0b3IsIGVsZW1lbnRzLCB7IGF0OiBQYXRoLm5leHQoW2FuY2hvckJsb2NrUGF0aFswXV0pLCBzZWxlY3QgfSk7XG4gICAgaWYgKGlzRW1wdHkgJiYgYW5jaG9yQmxvY2tQYXRoLmxlbmd0aCA9PT0gMSkge1xuICAgICAgICBUcmFuc2Zvcm1zLmRlbGV0ZShlZGl0b3IsIHsgYXQ6IGFuY2hvckJsb2NrUGF0aCB9KTtcbiAgICB9XG59O1xuIl19
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { NgIf, NgFor, NgStyle, NgTemplateOutlet, NgClass, DOCUMENT } from '@angular/common';
|
|
2
2
|
import * as i0 from '@angular/core';
|
|
3
|
-
import { InjectionToken, Component, Directive, Input, HostBinding, ViewChild, HostListener, ViewContainerRef, Inject, TemplateRef, ChangeDetectionStrategy, Optional, SkipSelf, ContentChildren, forwardRef, EventEmitter, Output, Pipe, Injectable, ElementRef, ChangeDetectorRef, ViewChildren, NgModule } from '@angular/core';
|
|
3
|
+
import { InjectionToken, Component, Directive, Input, HostBinding, ViewChild, HostListener, ViewContainerRef, Inject, TemplateRef, ChangeDetectionStrategy, Optional, SkipSelf, ContentChildren, forwardRef, EventEmitter, Output, Pipe, Injectable, ElementRef, ChangeDetectorRef, inject, Renderer2, ViewChildren, NgModule } from '@angular/core';
|
|
4
4
|
import { ThyDivider } from 'ngx-tethys/divider';
|
|
5
5
|
import { ThyAction, ThyActions } from 'ngx-tethys/action';
|
|
6
6
|
import { ThyDropdownMenuItemDirective, ThyDropdownMenuDivider, ThyDropdownMenuItemNameDirective, ThyDropdownMenuItemIconDirective, ThyDropdownMenuItemActiveDirective, ThyDropdownDirective, ThyDropdownMenuComponent, ThyDropdownMenuGroup, ThyDropdownMenuItemExtendIconDirective } from 'ngx-tethys/dropdown';
|
|
@@ -3826,7 +3826,7 @@ function handleContinualInsertBreak(editor, lowestBlock, type) {
|
|
|
3826
3826
|
return false;
|
|
3827
3827
|
}
|
|
3828
3828
|
|
|
3829
|
-
const insertElements = (editor, elements) => {
|
|
3829
|
+
const insertElements = (editor, elements, select = true) => {
|
|
3830
3830
|
if (!editor.selection) {
|
|
3831
3831
|
refocus(editor);
|
|
3832
3832
|
}
|
|
@@ -3837,25 +3837,19 @@ const insertElements = (editor, elements) => {
|
|
|
3837
3837
|
const allowParentTypes = getPluginOptions(editor, type)?.allowParentTypes || [];
|
|
3838
3838
|
const insertNodePath = getInsertElementsPath(editor, allowParentTypes);
|
|
3839
3839
|
const [anchorBlock, anchorBlockPath] = anchorBlockEntry(editor);
|
|
3840
|
-
|
|
3840
|
+
const isEmpty = Editor.isEmpty(editor, anchorBlock);
|
|
3841
3841
|
if (insertNodePath) {
|
|
3842
3842
|
Editor.withoutNormalizing(editor, () => {
|
|
3843
|
-
Transforms.insertNodes(editor, elements, { at: insertNodePath });
|
|
3844
|
-
Transforms.select(editor, Editor.start(editor, insertNodePath));
|
|
3843
|
+
Transforms.insertNodes(editor, elements, { at: insertNodePath, select });
|
|
3845
3844
|
if (isEmpty) {
|
|
3846
3845
|
Transforms.removeNodes(editor, { at: anchorBlockPath });
|
|
3847
3846
|
}
|
|
3848
3847
|
});
|
|
3849
3848
|
return;
|
|
3850
3849
|
}
|
|
3851
|
-
|
|
3852
|
-
Transforms.insertNodes(editor, elements, { at: nextPath });
|
|
3850
|
+
Transforms.insertNodes(editor, elements, { at: Path.next([anchorBlockPath[0]]), select });
|
|
3853
3851
|
if (isEmpty && anchorBlockPath.length === 1) {
|
|
3854
3852
|
Transforms.delete(editor, { at: anchorBlockPath });
|
|
3855
|
-
Transforms.select(editor, Editor.start(editor, anchorBlockPath));
|
|
3856
|
-
}
|
|
3857
|
-
else {
|
|
3858
|
-
Transforms.select(editor, Editor.start(editor, nextPath));
|
|
3859
3853
|
}
|
|
3860
3854
|
};
|
|
3861
3855
|
|
|
@@ -6868,19 +6862,19 @@ const InlineCodeEditor = {
|
|
|
6868
6862
|
};
|
|
6869
6863
|
|
|
6870
6864
|
class TheQuickInsert {
|
|
6871
|
-
|
|
6872
|
-
event.preventDefault();
|
|
6873
|
-
event.stopPropagation();
|
|
6874
|
-
}
|
|
6875
|
-
constructor(renderer, elementRef, cdr) {
|
|
6876
|
-
this.renderer = renderer;
|
|
6877
|
-
this.elementRef = elementRef;
|
|
6878
|
-
this.cdr = cdr;
|
|
6865
|
+
constructor() {
|
|
6879
6866
|
this.className = 'the-quick-insert';
|
|
6880
6867
|
this.isVisible = false;
|
|
6881
6868
|
this.defaultIconName = 'plus-circle-thin';
|
|
6882
6869
|
this.iconNameFill = 'plus-circle-thin-fill';
|
|
6883
6870
|
this.displayIconName = this.defaultIconName;
|
|
6871
|
+
this.cdr = inject(ChangeDetectorRef);
|
|
6872
|
+
this.renderer = inject(Renderer2);
|
|
6873
|
+
this.elementRef = inject((ElementRef));
|
|
6874
|
+
}
|
|
6875
|
+
handleMousedownNativeElement(event) {
|
|
6876
|
+
event.preventDefault();
|
|
6877
|
+
event.stopPropagation();
|
|
6884
6878
|
}
|
|
6885
6879
|
ngOnInit() {
|
|
6886
6880
|
const { onChange } = this.editor;
|
|
@@ -6944,11 +6938,11 @@ class TheQuickInsert {
|
|
|
6944
6938
|
}
|
|
6945
6939
|
mouseEnter(event) {
|
|
6946
6940
|
this.displayIconName = this.iconNameFill;
|
|
6947
|
-
this.cdr.
|
|
6941
|
+
this.cdr.detectChanges();
|
|
6948
6942
|
}
|
|
6949
6943
|
mouseLeave(event) {
|
|
6950
6944
|
this.displayIconName = this.defaultIconName;
|
|
6951
|
-
this.cdr.
|
|
6945
|
+
this.cdr.detectChanges();
|
|
6952
6946
|
}
|
|
6953
6947
|
handleClick(event) {
|
|
6954
6948
|
event.stopPropagation();
|
|
@@ -6963,13 +6957,13 @@ class TheQuickInsert {
|
|
|
6963
6957
|
this.updateIconDisplay();
|
|
6964
6958
|
}, 100);
|
|
6965
6959
|
}
|
|
6966
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: TheQuickInsert, deps: [
|
|
6967
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.0", type: TheQuickInsert, isStandalone: true, selector: "[theQuickInsert]", inputs: { editor: "editor", isVisible: "isVisible" }, host: { listeners: { "mousedown": "handleMousedownNativeElement($event)" }, properties: { "class": "this.className" } }, viewQueries: [{ propertyName: "iconElement", first: true, predicate: ["iconElement"], descendants: true, read: ElementRef }], usesOnChanges: true, ngImport: i0, template: "<thy-icon\n #iconElement\n
|
|
6960
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: TheQuickInsert, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
6961
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.0", type: TheQuickInsert, isStandalone: true, selector: "[theQuickInsert]", inputs: { editor: "editor", isVisible: "isVisible" }, host: { listeners: { "mousedown": "handleMousedownNativeElement($event)" }, properties: { "class": "this.className" } }, viewQueries: [{ propertyName: "iconElement", first: true, predicate: ["iconElement"], descendants: true, read: ElementRef }], usesOnChanges: true, ngImport: i0, template: "<thy-icon\n #iconElement\n class=\"quick-insert-icon text-desc font-size-xlg\"\n [thyIconName]=\"displayIconName\"\n (mouseenter)=\"mouseEnter($event)\"\n (mouseleave)=\"mouseLeave($event)\"\n (mouseup)=\"handleClick($event)\"\n></thy-icon>\n", dependencies: [{ kind: "component", type: ThyIcon, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
6968
6962
|
}
|
|
6969
6963
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: TheQuickInsert, decorators: [{
|
|
6970
6964
|
type: Component,
|
|
6971
|
-
args: [{ selector: '[theQuickInsert]', standalone: true, imports: [ThyIcon], template: "<thy-icon\n #iconElement\n
|
|
6972
|
-
}],
|
|
6965
|
+
args: [{ selector: '[theQuickInsert]', standalone: true, imports: [ThyIcon], changeDetection: ChangeDetectionStrategy.OnPush, template: "<thy-icon\n #iconElement\n class=\"quick-insert-icon text-desc font-size-xlg\"\n [thyIconName]=\"displayIconName\"\n (mouseenter)=\"mouseEnter($event)\"\n (mouseleave)=\"mouseLeave($event)\"\n (mouseup)=\"handleClick($event)\"\n></thy-icon>\n" }]
|
|
6966
|
+
}], propDecorators: { className: [{
|
|
6973
6967
|
type: HostBinding,
|
|
6974
6968
|
args: ['class']
|
|
6975
6969
|
}], editor: [{
|
|
@@ -7068,7 +7062,7 @@ class ThePluginMenuComponent {
|
|
|
7068
7062
|
const nodeString = Node.string(node);
|
|
7069
7063
|
const isStartWithHotkey = nodeString.startsWith('/') || nodeString.startsWith('#');
|
|
7070
7064
|
const isIncludeKeywords = nodeString.toLocaleLowerCase().trim().includes(this.keyWords);
|
|
7071
|
-
if (
|
|
7065
|
+
if (this.originKeywords?.length > 0 && (isStartWithHotkey || isIncludeKeywords)) {
|
|
7072
7066
|
Transforms.delete(this.editor, { distance: this.originKeywords.length, reverse: true });
|
|
7073
7067
|
}
|
|
7074
7068
|
};
|