@worktile/theia 17.4.6 → 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.
@@ -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
- handleMousedownNativeElement(event) {
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.markForCheck();
87
+ this.cdr.detectChanges();
88
88
  }
89
89
  mouseLeave(event) {
90
90
  this.displayIconName = this.defaultIconName;
91
- this.cdr.markForCheck();
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: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], 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 [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", dependencies: [{ kind: "component", type: ThyIcon, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }] }); }
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 [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" }]
112
- }], ctorParameters: () => [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }], propDecorators: { className: [{
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
- let isEmpty = Editor.isEmpty(editor, anchorBlock);
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
- const nextPath = Path.next([anchorBlockPath[0]]);
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5zZXJ0LWVsZW1lbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvc3JjL3RyYW5zZm9ybXMvaW5zZXJ0LWVsZW1lbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMxQyxPQUFPLEVBQUUsTUFBTSxFQUFXLElBQUksRUFBRSxLQUFLLEVBQUUsVUFBVSxFQUFFLE1BQU0sT0FBTyxDQUFDO0FBQ2pFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBRXBFLE9BQU8sS0FBSyxVQUFVLE1BQU0sWUFBWSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFFbkMsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUFHLENBQUMsTUFBYyxFQUFFLFFBQTZCLEVBQUUsRUFBRTtJQUM1RSxJQUFJLENBQUMsTUFBTSxDQUFDLFNBQVMsRUFBRSxDQUFDO1FBQ3BCLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUNwQixDQUFDO0lBQ0QsSUFBSSxLQUFLLENBQUMsVUFBVSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsRUFBRSxDQUFDO1FBQ3JDLE1BQU0sQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDbEMsQ0FBQztJQUNELE1BQU0sSUFBSSxHQUFHLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsZUFBZTtJQUNuRixNQUFNLGdCQUFnQixHQUFHLGdCQUFnQixDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsRUFBRSxnQkFBZ0IsSUFBSSxFQUFFLENBQUM7SUFDaEYsTUFBTSxjQUFjLEdBQUcsVUFBVSxDQUFDLHFCQUFxQixDQUFDLE1BQU0sRUFBRSxnQkFBd0MsQ0FBQyxDQUFDO0lBQzFHLE1BQU0sQ0FBQyxXQUFXLEVBQUUsZUFBZSxDQUFDLEdBQUcsVUFBVSxDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzNFLElBQUksT0FBTyxHQUFHLE1BQU0sQ0FBQyxPQUFPLENBQUMsTUFBTSxFQUFFLFdBQVcsQ0FBQyxDQUFDO0lBQ2xELElBQUksY0FBYyxFQUFFLENBQUM7UUFDakIsTUFBTSxDQUFDLGtCQUFrQixDQUFDLE1BQU0sRUFBRSxHQUFHLEVBQUU7WUFDbkMsVUFBVSxDQUFDLFdBQVcsQ0FBQyxNQUFNLEVBQUUsUUFBUSxFQUFFLEVBQUUsRUFBRSxFQUFFLGNBQWMsRUFBRSxDQUFDLENBQUM7WUFDakUsVUFBVSxDQUFDLE1BQU0sQ0FBQyxNQUFNLEVBQUUsTUFBTSxDQUFDLEtBQUssQ0FBQyxNQUFNLEVBQUUsY0FBYyxDQUFDLENBQUMsQ0FBQztZQUNoRSxJQUFJLE9BQU8sRUFBRSxDQUFDO2dCQUNWLFVBQVUsQ0FBQyxXQUFXLENBQUMsTUFBTSxFQUFFLEVBQUUsRUFBRSxFQUFFLGVBQWUsRUFBRSxDQUFDLENBQUM7WUFDNUQsQ0FBQztRQUNMLENBQUMsQ0FBQyxDQUFDO1FBQ0gsT0FBTztJQUNYLENBQUM7SUFFRCxNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsZUFBZSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNqRCxVQUFVLENBQUMsV0FBVyxDQUFDLE1BQU0sRUFBRSxRQUFRLEVBQUUsRUFBRSxFQUFFLEVBQUUsUUFBUSxFQUFFLENBQUMsQ0FBQztJQUUzRCxJQUFJLE9BQU8sSUFBSSxlQUFlLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRSxDQUFDO1FBQzFDLFVBQVUsQ0FBQyxNQUFNLENBQUMsTUFBTSxFQUFFLEVBQUUsRUFBRSxFQUFFLGVBQWUsRUFBRSxDQUFDLENBQUM7UUFDbkQsVUFBVSxDQUFDLE1BQU0sQ0FBQyxNQUFNLEVBQUUsTUFBTSxDQUFDLEtBQUssQ0FBQyxNQUFNLEVBQUUsZUFBZSxDQUFDLENBQUMsQ0FBQztJQUNyRSxDQUFDO1NBQU0sQ0FBQztRQUNKLFVBQVUsQ0FBQyxNQUFNLENBQUMsTUFBTSxFQUFFLE1BQU0sQ0FBQyxLQUFLLENBQUMsTUFBTSxFQUFFLFFBQVEsQ0FBQyxDQUFDLENBQUM7SUFDOUQsQ0FBQztBQUNMLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGlzQXJyYXkgfSBmcm9tICduZ3gtdGV0aHlzL3V0aWwnO1xuaW1wb3J0IHsgRWRpdG9yLCBFbGVtZW50LCBQYXRoLCBSYW5nZSwgVHJhbnNmb3JtcyB9IGZyb20gJ3NsYXRlJztcbmltcG9ydCB7IGdldFBsdWdpbk9wdGlvbnMgfSBmcm9tICcuLi9jb3JlL3V0aWxzL2dldC1wbHVnaW4tb3B0aW9ucyc7XG5pbXBvcnQgeyBDdXN0b21FbGVtZW50S2luZHMgfSBmcm9tICcuLi9jdXN0b20tdHlwZXMnO1xuaW1wb3J0ICogYXMgVGhlUXVlcmllcyBmcm9tICcuLi9xdWVyaWVzJztcbmltcG9ydCB7IHJlZm9jdXMgfSBmcm9tICcuLi91dGlscyc7XG5cbmV4cG9ydCBjb25zdCBpbnNlcnRFbGVtZW50cyA9IChlZGl0b3I6IEVkaXRvciwgZWxlbWVudHM6IEVsZW1lbnQgfCBFbGVtZW50W10pID0+IHtcbiAgICBpZiAoIWVkaXRvci5zZWxlY3Rpb24pIHtcbiAgICAgICAgcmVmb2N1cyhlZGl0b3IpO1xuICAgIH1cbiAgICBpZiAoUmFuZ2UuaXNFeHBhbmRlZChlZGl0b3Iuc2VsZWN0aW9uKSkge1xuICAgICAgICBFZGl0b3IuZGVsZXRlRnJhZ21lbnQoZWRpdG9yKTtcbiAgICB9XG4gICAgY29uc3QgdHlwZSA9ICFpc0FycmF5KGVsZW1lbnRzKSA/IGVsZW1lbnRzLnR5cGUgOiBlbGVtZW50c1swXS50eXBlOyAvLyDlkI7mnJ/lpITnkIblpI3liLbnspjotLTpnIDopoHkv67mlLlcbiAgICBjb25zdCBhbGxvd1BhcmVudFR5cGVzID0gZ2V0UGx1Z2luT3B0aW9ucyhlZGl0b3IsIHR5cGUpPy5hbGxvd1BhcmVudFR5cGVzIHx8IFtdO1xuICAgIGNvbnN0IGluc2VydE5vZGVQYXRoID0gVGhlUXVlcmllcy5nZXRJbnNlcnRFbGVtZW50c1BhdGgoZWRpdG9yLCBhbGxvd1BhcmVudFR5cGVzIGFzIEN1c3RvbUVsZW1lbnRLaW5kc1tdKTtcbiAgICBjb25zdCBbYW5jaG9yQmxvY2ssIGFuY2hvckJsb2NrUGF0aF0gPSBUaGVRdWVyaWVzLmFuY2hvckJsb2NrRW50cnkoZWRpdG9yKTtcbiAgICBsZXQgaXNFbXB0eSA9IEVkaXRvci5pc0VtcHR5KGVkaXRvciwgYW5jaG9yQmxvY2spO1xuICAgIGlmIChpbnNlcnROb2RlUGF0aCkge1xuICAgICAgICBFZGl0b3Iud2l0aG91dE5vcm1hbGl6aW5nKGVkaXRvciwgKCkgPT4ge1xuICAgICAgICAgICAgVHJhbnNmb3Jtcy5pbnNlcnROb2RlcyhlZGl0b3IsIGVsZW1lbnRzLCB7IGF0OiBpbnNlcnROb2RlUGF0aCB9KTtcbiAgICAgICAgICAgIFRyYW5zZm9ybXMuc2VsZWN0KGVkaXRvciwgRWRpdG9yLnN0YXJ0KGVkaXRvciwgaW5zZXJ0Tm9kZVBhdGgpKTtcbiAgICAgICAgICAgIGlmIChpc0VtcHR5KSB7XG4gICAgICAgICAgICAgICAgVHJhbnNmb3Jtcy5yZW1vdmVOb2RlcyhlZGl0b3IsIHsgYXQ6IGFuY2hvckJsb2NrUGF0aCB9KTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfSk7XG4gICAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBjb25zdCBuZXh0UGF0aCA9IFBhdGgubmV4dChbYW5jaG9yQmxvY2tQYXRoWzBdXSk7XG4gICAgVHJhbnNmb3Jtcy5pbnNlcnROb2RlcyhlZGl0b3IsIGVsZW1lbnRzLCB7IGF0OiBuZXh0UGF0aCB9KTtcblxuICAgIGlmIChpc0VtcHR5ICYmIGFuY2hvckJsb2NrUGF0aC5sZW5ndGggPT09IDEpIHtcbiAgICAgICAgVHJhbnNmb3Jtcy5kZWxldGUoZWRpdG9yLCB7IGF0OiBhbmNob3JCbG9ja1BhdGggfSk7XG4gICAgICAgIFRyYW5zZm9ybXMuc2VsZWN0KGVkaXRvciwgRWRpdG9yLnN0YXJ0KGVkaXRvciwgYW5jaG9yQmxvY2tQYXRoKSk7XG4gICAgfSBlbHNlIHtcbiAgICAgICAgVHJhbnNmb3Jtcy5zZWxlY3QoZWRpdG9yLCBFZGl0b3Iuc3RhcnQoZWRpdG9yLCBuZXh0UGF0aCkpO1xuICAgIH1cbn07XG4iXX0=
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
- let isEmpty = Editor.isEmpty(editor, anchorBlock);
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
- const nextPath = Path.next([anchorBlockPath[0]]);
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
- handleMousedownNativeElement(event) {
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.markForCheck();
6941
+ this.cdr.detectChanges();
6948
6942
  }
6949
6943
  mouseLeave(event) {
6950
6944
  this.displayIconName = this.defaultIconName;
6951
- this.cdr.markForCheck();
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: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
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 [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", dependencies: [{ kind: "component", type: ThyIcon, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }] }); }
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 [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" }]
6972
- }], ctorParameters: () => [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }], propDecorators: { className: [{
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: [{