@worktile/theia 17.2.2 → 17.3.0

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.
Files changed (63) hide show
  1. package/components/column-resize/column-resize.directive.d.ts +5 -3
  2. package/components/column-resize/column-resize.scss +0 -7
  3. package/components/column-resize/overlay-handle.component.d.ts +4 -6
  4. package/components/column-resize/resizing.store.d.ts +0 -8
  5. package/components/inline-toolbar/inline-toolbar.component.d.ts +1 -1
  6. package/components/toolbar/toolbar.component.d.ts +0 -1
  7. package/constants/node-types.d.ts +0 -1
  8. package/core/utils/plugin-menu.d.ts +8 -0
  9. package/editor.component.d.ts +1 -1
  10. package/esm2022/components/column-resize/column-resize.directive.mjs +28 -9
  11. package/esm2022/components/column-resize/overlay-handle.component.mjs +12 -16
  12. package/esm2022/components/column-resize/resizing.store.mjs +3 -66
  13. package/esm2022/components/inline-toolbar/inline-toolbar.component.mjs +13 -22
  14. package/esm2022/components/plugin-menu/plugin-menu.component.mjs +6 -5
  15. package/esm2022/components/toolbar/toolbar.component.mjs +2 -7
  16. package/esm2022/constants/default.mjs +2 -2
  17. package/esm2022/constants/node-types.mjs +1 -2
  18. package/esm2022/core/utils/plugin-menu.mjs +34 -1
  19. package/esm2022/editor.component.mjs +13 -5
  20. package/esm2022/interfaces/plugins/plugin-menu.mjs +2 -2
  21. package/esm2022/interfaces/plugins/plugins.mjs +1 -1
  22. package/esm2022/plugins/common/block-card.plugin.mjs +12 -2
  23. package/esm2022/plugins/image/image.component.mjs +2 -2
  24. package/esm2022/plugins/image/image.editor.mjs +2 -3
  25. package/esm2022/plugins/image/image.plugin.mjs +2 -2
  26. package/esm2022/plugins/inline-code/inline-code.plugin.mjs +3 -2
  27. package/esm2022/plugins/link/link.plugin.mjs +4 -3
  28. package/esm2022/plugins/quick-insert/quick-insert.editor.mjs +4 -2
  29. package/esm2022/plugins/table/components/insert-mark/insert-mark.component.mjs +41 -17
  30. package/esm2022/plugins/table/components/row/row.component.mjs +2 -2
  31. package/esm2022/plugins/table/components/table.component.mjs +22 -26
  32. package/esm2022/plugins/table/components/td/td.component.mjs +47 -125
  33. package/esm2022/plugins/table/table.editor.mjs +2 -2
  34. package/esm2022/plugins/table/table.types.mjs +1 -1
  35. package/esm2022/plugins/table/utils/get-grid-columns.mjs +2 -2
  36. package/esm2022/plugins/table/utils/table-viewport.mjs +41 -0
  37. package/esm2022/plugins/vertical-align/toolbar-item.component.mjs +3 -5
  38. package/esm2022/queries/anchor-block-entry.mjs +3 -3
  39. package/esm2022/queries/anchor-block.mjs +3 -3
  40. package/esm2022/queries/get-block-card-cursor.mjs +6 -2
  41. package/esm2022/queries/is-block-card-cursor.mjs +7 -2
  42. package/esm2022/utils/index.mjs +2 -2
  43. package/esm2022/utils/scrolling.mjs +43 -0
  44. package/fesm2022/worktile-theia.mjs +294 -314
  45. package/fesm2022/worktile-theia.mjs.map +1 -1
  46. package/interfaces/editor.d.ts +2 -2
  47. package/interfaces/plugins/plugins.d.ts +2 -1
  48. package/package.json +1 -1
  49. package/plugins/table/components/insert-mark/insert-mark.component.d.ts +12 -4
  50. package/plugins/table/components/table.component.d.ts +1 -2
  51. package/plugins/table/components/table.component.scss +4 -18
  52. package/plugins/table/components/td/td.component.d.ts +9 -10
  53. package/plugins/table/table.types.d.ts +2 -2
  54. package/plugins/table/utils/table-viewport.d.ts +8 -0
  55. package/plugins/vertical-align/toolbar-item.component.d.ts +2 -3
  56. package/queries/anchor-block-entry.d.ts +2 -2
  57. package/queries/anchor-block.d.ts +2 -2
  58. package/queries/get-block-card-cursor.d.ts +2 -2
  59. package/queries/is-block-card-cursor.d.ts +2 -2
  60. package/styles/editor.scss +7 -0
  61. package/utils/index.d.ts +1 -1
  62. package/utils/{scroll-into-view.d.ts → scrolling.d.ts} +1 -0
  63. package/esm2022/utils/scroll-into-view.mjs +0 -38
@@ -1,11 +1,10 @@
1
- import { Injectable } from '@angular/core';
2
- import { getElementWidth, coercePixelsFromCssValue, getColsTotalWidth, getElementHeight, getRowsTotalHeight } from '../../utils/dom';
3
1
  import { coerceCssPixelValue } from '@angular/cdk/coercion';
2
+ import { Injectable } from '@angular/core';
3
+ import { coercePixelsFromCssValue, getColsTotalWidth, getElementWidth } from '../../utils/dom';
4
4
  import * as i0 from "@angular/core";
5
5
  export class ColumnResizingStore {
6
6
  constructor() {
7
7
  this.resizeCols = [];
8
- this.resizeRows = [];
9
8
  }
10
9
  storeResizingCol(colElement) {
11
10
  if (this.resizeCols.some(cache => cache.colElement === colElement)) {
@@ -13,27 +12,14 @@ export class ColumnResizingStore {
13
12
  }
14
13
  this.resizeCols.push({ colElement, baseWidth: getElementWidth(colElement) });
15
14
  }
16
- storeResizingRow(rowElement) {
17
- if (this.resizeRows.some(cache => cache.rowElement === rowElement)) {
18
- return;
19
- }
20
- this.resizeRows.push({ rowElement, baseHeight: getElementHeight(rowElement) });
21
- }
22
15
  storeTableWidth(cols) {
23
16
  if (!this.tableCols) {
24
17
  this.tableCols = { cols, baseWidth: getColsTotalWidth(cols) };
25
18
  }
26
19
  }
27
- storeTableHeight(rows) {
28
- if (!this.tableRows) {
29
- this.tableRows = { rows, baseHeight: getRowsTotalHeight(rows) };
30
- }
31
- }
32
20
  cleanResizing() {
33
21
  this.tableCols = null;
34
- this.tableRows = null;
35
22
  this.resizeCols = [];
36
- this.resizeRows = [];
37
23
  this.direction = null;
38
24
  }
39
25
  restoreLeftCols(deltaX) {
@@ -55,44 +41,6 @@ export class ColumnResizingStore {
55
41
  }
56
42
  return deltaX;
57
43
  }
58
- restoreTopRows(deltaY) {
59
- let index = this.resizeRows.length - 1;
60
- while (index >= 0 && deltaY > 0) {
61
- const currentHeight = this.resizeRows[index].rowElement.getBoundingClientRect().height;
62
- if (this.resizeRows[index].baseHeight > currentHeight) {
63
- if (this.resizeRows[index].baseHeight > currentHeight + deltaY) {
64
- this.resizeRows[index].rowElement.style.height = coerceCssPixelValue(currentHeight + deltaY);
65
- deltaY = 0;
66
- }
67
- else {
68
- deltaY -= this.resizeRows[index].baseHeight - currentHeight;
69
- this.resizeRows[index].rowElement.style.height = coerceCssPixelValue(this.resizeRows[index].baseHeight);
70
- this.popRow();
71
- }
72
- }
73
- index--;
74
- }
75
- return deltaY;
76
- }
77
- restoreBottomRows(deltaY) {
78
- let index = this.resizeRows.length - 1;
79
- while (index >= 0 && deltaY < 0) {
80
- const currentHeight = coercePixelsFromCssValue(this.resizeRows[index].rowElement.style.height);
81
- if (this.resizeRows[index].baseHeight > currentHeight) {
82
- if (this.resizeRows[index].baseHeight > currentHeight + Math.abs(deltaY)) {
83
- this.resizeRows[index].rowElement.style.height = coerceCssPixelValue(currentHeight + Math.abs(deltaY));
84
- deltaY = 0;
85
- }
86
- else {
87
- deltaY += this.resizeRows[index].baseHeight - currentHeight;
88
- this.resizeRows[index].rowElement.style.height = coerceCssPixelValue(this.resizeRows[index].baseHeight);
89
- this.popRow();
90
- }
91
- }
92
- index--;
93
- }
94
- return deltaY;
95
- }
96
44
  restoreRightCols(deltaX) {
97
45
  let index = this.resizeCols.length - 1;
98
46
  while (index >= 0 && deltaX < 0) {
@@ -117,11 +65,6 @@ export class ColumnResizingStore {
117
65
  return getColsTotalWidth(this.tableCols.cols) - this.tableCols.baseWidth - Math.abs(deltaX);
118
66
  }
119
67
  }
120
- getAddTableHeight(deltaY) {
121
- if (this.tableRows) {
122
- return getRowsTotalHeight(this.tableRows.rows) - this.tableRows.baseHeight - Math.abs(deltaY);
123
- }
124
- }
125
68
  isRestoring(deltaValue, isXAxis = true) {
126
69
  return !this.isResizing(deltaValue, isXAxis);
127
70
  }
@@ -132,9 +75,6 @@ export class ColumnResizingStore {
132
75
  if (this.resizeCols.length > 0) {
133
76
  return;
134
77
  }
135
- if (this.resizeRows.length > 0) {
136
- return;
137
- }
138
78
  this.direction = this.getDirection(deltaValue, isXAxis);
139
79
  }
140
80
  getDirection(deltaValue, isXAxis = true) {
@@ -143,13 +83,10 @@ export class ColumnResizingStore {
143
83
  popCol() {
144
84
  this.resizeCols.pop();
145
85
  }
146
- popRow() {
147
- this.resizeRows.pop();
148
- }
149
86
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: ColumnResizingStore, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
150
87
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: ColumnResizingStore }); }
151
88
  }
152
89
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: ColumnResizingStore, decorators: [{
153
90
  type: Injectable
154
91
  }], ctorParameters: () => [] });
155
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resizing.store.js","sourceRoot":"","sources":["../../../../../packages/src/components/column-resize/resizing.store.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { getElementWidth, coercePixelsFromCssValue, getColsTotalWidth, getElementHeight, getRowsTotalHeight } from '../../utils/dom';\nimport { coerceCssPixelValue } from '@angular/cdk/coercion';\n\n@Injectable()\nexport class ColumnResizingStore {\n    constructor() {\n        this.resizeCols = [];\n        this.resizeRows = [];\n    }\n    private direction: 'left' | 'right' | 'top' | 'bottom';\n    private resizeCols: { colElement: HTMLTableColElement; baseWidth: number }[];\n    private resizeRows: { rowElement: HTMLTableRowElement; baseHeight: number }[];\n    private tableCols: { cols: HTMLTableColElement[]; baseWidth: number };\n    private tableRows: { rows: HTMLTableRowElement[]; baseHeight: number };\n\n    storeResizingCol(colElement: HTMLTableColElement) {\n        if (this.resizeCols.some(cache => cache.colElement === colElement)) {\n            return;\n        }\n        this.resizeCols.push({ colElement, baseWidth: getElementWidth(colElement) });\n    }\n\n    storeResizingRow(rowElement: HTMLTableRowElement) {\n        if (this.resizeRows.some(cache => cache.rowElement === rowElement)) {\n            return;\n        }\n        this.resizeRows.push({ rowElement, baseHeight: getElementHeight(rowElement) });\n    }\n\n    storeTableWidth(cols: HTMLTableColElement[]) {\n        if (!this.tableCols) {\n            this.tableCols = { cols, baseWidth: getColsTotalWidth(cols) };\n        }\n    }\n\n    storeTableHeight(rows: HTMLTableRowElement[]) {\n        if (!this.tableRows) {\n            this.tableRows = { rows, baseHeight: getRowsTotalHeight(rows) };\n        }\n    }\n\n    cleanResizing() {\n        this.tableCols = null;\n        this.tableRows = null;\n        this.resizeCols = [];\n        this.resizeRows = [];\n        this.direction = null;\n    }\n\n    restoreLeftCols(deltaX: number) {\n        let index = this.resizeCols.length - 1;\n        while (index >= 0 && deltaX > 0) {\n            const currentWidth = coercePixelsFromCssValue(this.resizeCols[index].colElement.style.width);\n            if (this.resizeCols[index].baseWidth > currentWidth) {\n                if (this.resizeCols[index].baseWidth > currentWidth + deltaX) {\n                    this.resizeCols[index].colElement.style.width = coerceCssPixelValue(currentWidth + deltaX);\n                    deltaX = 0;\n                } else {\n                    deltaX -= this.resizeCols[index].baseWidth - currentWidth;\n                    this.resizeCols[index].colElement.style.width = coerceCssPixelValue(this.resizeCols[index].baseWidth);\n                    this.popCol();\n                }\n            }\n            index--;\n        }\n        return deltaX;\n    }\n\n    restoreTopRows(deltaY: number) {\n        let index = this.resizeRows.length - 1;\n        while (index >= 0 && deltaY > 0) {\n            const currentHeight = this.resizeRows[index].rowElement.getBoundingClientRect().height;\n            if (this.resizeRows[index].baseHeight > currentHeight) {\n                if (this.resizeRows[index].baseHeight > currentHeight + deltaY) {\n                    this.resizeRows[index].rowElement.style.height = coerceCssPixelValue(currentHeight + deltaY);\n                    deltaY = 0;\n                } else {\n                    deltaY -= this.resizeRows[index].baseHeight - currentHeight;\n                    this.resizeRows[index].rowElement.style.height = coerceCssPixelValue(this.resizeRows[index].baseHeight);\n                    this.popRow();\n                }\n            }\n            index--;\n        }\n        return deltaY;\n    }\n\n    restoreBottomRows(deltaY: number) {\n        let index = this.resizeRows.length - 1;\n        while (index >= 0 && deltaY < 0) {\n            const currentHeight = coercePixelsFromCssValue(this.resizeRows[index].rowElement.style.height);\n            if (this.resizeRows[index].baseHeight > currentHeight) {\n                if (this.resizeRows[index].baseHeight > currentHeight + Math.abs(deltaY)) {\n                    this.resizeRows[index].rowElement.style.height = coerceCssPixelValue(currentHeight + Math.abs(deltaY));\n                    deltaY = 0;\n                } else {\n                    deltaY += this.resizeRows[index].baseHeight - currentHeight;\n                    this.resizeRows[index].rowElement.style.height = coerceCssPixelValue(this.resizeRows[index].baseHeight);\n                    this.popRow();\n                }\n            }\n            index--;\n        }\n        return deltaY;\n    }\n\n    restoreRightCols(deltaX: number) {\n        let index = this.resizeCols.length - 1;\n        while (index >= 0 && deltaX < 0) {\n            const currentWidth = coercePixelsFromCssValue(this.resizeCols[index].colElement.style.width);\n            if (this.resizeCols[index].baseWidth > currentWidth) {\n                if (this.resizeCols[index].baseWidth > currentWidth + Math.abs(deltaX)) {\n                    this.resizeCols[index].colElement.style.width = coerceCssPixelValue(currentWidth + Math.abs(deltaX));\n                    deltaX = 0;\n                } else {\n                    deltaX += this.resizeCols[index].baseWidth - currentWidth;\n                    this.resizeCols[index].colElement.style.width = coerceCssPixelValue(this.resizeCols[index].baseWidth);\n                    this.popCol();\n                }\n            }\n            index--;\n        }\n        return deltaX;\n    }\n\n    getScrollWidth(deltaX: number) {\n        if (this.tableCols) {\n            return getColsTotalWidth(this.tableCols.cols) - this.tableCols.baseWidth - Math.abs(deltaX);\n        }\n    }\n\n    getAddTableHeight(deltaY: number) {\n        if (this.tableRows) {\n            return getRowsTotalHeight(this.tableRows.rows) - this.tableRows.baseHeight - Math.abs(deltaY);\n        }\n    }\n\n    isRestoring(deltaValue, isXAxis = true) {\n        return !this.isResizing(deltaValue, isXAxis);\n    }\n\n    isResizing(deltaValue, isXAxis = true) {\n        return this.direction === this.getDirection(deltaValue, isXAxis);\n    }\n\n    initDirection(deltaValue: number, isXAxis = true) {\n        if (this.resizeCols.length > 0) {\n            return;\n        }\n        if (this.resizeRows.length > 0) {\n            return;\n        }\n        this.direction = this.getDirection(deltaValue, isXAxis);\n    }\n\n    private getDirection(deltaValue, isXAxis = true) {\n        return isXAxis ? (deltaValue > 0 ? 'right' : 'left') : deltaValue > 0 ? 'bottom' : 'top';\n    }\n\n    private popCol() {\n        this.resizeCols.pop();\n    }\n\n    private popRow() {\n        this.resizeRows.pop();\n    }\n}\n"]}
92
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resizing.store.js","sourceRoot":"","sources":["../../../../../packages/src/components/column-resize/resizing.store.ts"],"names":[],"mappings":"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","sourcesContent":["import { coerceCssPixelValue } from '@angular/cdk/coercion';\nimport { Injectable } from '@angular/core';\nimport { coercePixelsFromCssValue, getColsTotalWidth, getElementWidth } from '../../utils/dom';\n\n@Injectable()\nexport class ColumnResizingStore {\n    constructor() {\n        this.resizeCols = [];\n    }\n    private direction: 'left' | 'right' | 'top' | 'bottom';\n    private resizeCols: { colElement: HTMLTableColElement; baseWidth: number }[];\n    private tableCols: { cols: HTMLTableColElement[]; baseWidth: number };\n\n    storeResizingCol(colElement: HTMLTableColElement) {\n        if (this.resizeCols.some(cache => cache.colElement === colElement)) {\n            return;\n        }\n        this.resizeCols.push({ colElement, baseWidth: getElementWidth(colElement) });\n    }\n\n    storeTableWidth(cols: HTMLTableColElement[]) {\n        if (!this.tableCols) {\n            this.tableCols = { cols, baseWidth: getColsTotalWidth(cols) };\n        }\n    }\n\n    cleanResizing() {\n        this.tableCols = null;\n        this.resizeCols = [];\n        this.direction = null;\n    }\n\n    restoreLeftCols(deltaX: number) {\n        let index = this.resizeCols.length - 1;\n        while (index >= 0 && deltaX > 0) {\n            const currentWidth = coercePixelsFromCssValue(this.resizeCols[index].colElement.style.width);\n            if (this.resizeCols[index].baseWidth > currentWidth) {\n                if (this.resizeCols[index].baseWidth > currentWidth + deltaX) {\n                    this.resizeCols[index].colElement.style.width = coerceCssPixelValue(currentWidth + deltaX);\n                    deltaX = 0;\n                } else {\n                    deltaX -= this.resizeCols[index].baseWidth - currentWidth;\n                    this.resizeCols[index].colElement.style.width = coerceCssPixelValue(this.resizeCols[index].baseWidth);\n                    this.popCol();\n                }\n            }\n            index--;\n        }\n        return deltaX;\n    }\n\n    restoreRightCols(deltaX: number) {\n        let index = this.resizeCols.length - 1;\n        while (index >= 0 && deltaX < 0) {\n            const currentWidth = coercePixelsFromCssValue(this.resizeCols[index].colElement.style.width);\n            if (this.resizeCols[index].baseWidth > currentWidth) {\n                if (this.resizeCols[index].baseWidth > currentWidth + Math.abs(deltaX)) {\n                    this.resizeCols[index].colElement.style.width = coerceCssPixelValue(currentWidth + Math.abs(deltaX));\n                    deltaX = 0;\n                } else {\n                    deltaX += this.resizeCols[index].baseWidth - currentWidth;\n                    this.resizeCols[index].colElement.style.width = coerceCssPixelValue(this.resizeCols[index].baseWidth);\n                    this.popCol();\n                }\n            }\n            index--;\n        }\n        return deltaX;\n    }\n\n    getScrollWidth(deltaX: number) {\n        if (this.tableCols) {\n            return getColsTotalWidth(this.tableCols.cols) - this.tableCols.baseWidth - Math.abs(deltaX);\n        }\n    }\n\n    isRestoring(deltaValue, isXAxis = true) {\n        return !this.isResizing(deltaValue, isXAxis);\n    }\n\n    isResizing(deltaValue, isXAxis = true) {\n        return this.direction === this.getDirection(deltaValue, isXAxis);\n    }\n\n    initDirection(deltaValue: number, isXAxis = true) {\n        if (this.resizeCols.length > 0) {\n            return;\n        }\n        this.direction = this.getDirection(deltaValue, isXAxis);\n    }\n\n    private getDirection(deltaValue, isXAxis = true) {\n        return isXAxis ? (deltaValue > 0 ? 'right' : 'left') : deltaValue > 0 ? 'bottom' : 'top';\n    }\n\n    private popCol() {\n        this.resizeCols.pop();\n    }\n}\n"]}
@@ -3,8 +3,6 @@ import { Subject, fromEvent, merge } from 'rxjs';
3
3
  import { debounceTime, filter, takeUntil } from 'rxjs/operators';
4
4
  import { Editor, Range as slateRange } from 'slate';
5
5
  import { AngularEditor } from 'slate-angular';
6
- import { THE_INLINE_TOOLBAR_TYPES } from '../../constants';
7
- import * as TheQueries from '../../queries';
8
6
  import { TheToolbarComponent } from '../toolbar/toolbar.component';
9
7
  import * as i0 from "@angular/core";
10
8
  import * as i1 from "@angular/cdk/overlay";
@@ -36,42 +34,35 @@ export class TheInlineToolbar {
36
34
  }
37
35
  updateInlineToolbar() {
38
36
  const inlineToolbar = this.elementRef.nativeElement.firstElementChild;
39
- if (!this.editor.selection) {
40
- inlineToolbar.removeAttribute('style');
41
- return;
42
- }
43
- const anchorBlock = TheQueries.anchorBlock(this.editor);
44
- if (!inlineToolbar || !anchorBlock) {
37
+ if (!inlineToolbar) {
45
38
  return;
46
39
  }
47
- const { editor } = this;
48
- const { selection } = editor;
40
+ const { selection } = this.editor;
49
41
  if (!selection ||
50
- !AngularEditor.isFocused(editor) ||
51
- slateRange.isCollapsed(selection) ||
52
- Editor.string(editor, selection) === '') {
42
+ (selection &&
43
+ (!AngularEditor.isFocused(this.editor) ||
44
+ slateRange.isCollapsed(selection) ||
45
+ Editor.string(this.editor, selection) === ''))) {
53
46
  inlineToolbar.removeAttribute('style');
54
47
  return;
55
48
  }
56
- if (!THE_INLINE_TOOLBAR_TYPES.includes(anchorBlock.type)) {
57
- return;
58
- }
59
49
  const native = window.getSelection();
60
50
  if (native.type !== 'None') {
61
51
  const range = native.getRangeAt(0);
62
52
  this.updatePosition(inlineToolbar, range);
63
53
  this.inlineToolbar?.selectionChange(this.editor);
54
+ this.cdr.markForCheck();
64
55
  }
65
- this.cdr.detectChanges();
66
56
  }
67
57
  updatePosition(toolbarElement, range) {
68
58
  let boundary = range.getBoundingClientRect();
69
- if (!boundary || (boundary.height === 0 && boundary.width === 0 && range.startContainer === range.endContainer)) {
70
- if (range.startContainer.nodeType === 1 && range.startContainer.querySelector('img')) {
71
- boundary = range.startContainer.querySelector('img').getBoundingClientRect();
59
+ const startContainer = range.startContainer;
60
+ if (!boundary || (boundary.height === 0 && boundary.width === 0 && startContainer === range.endContainer)) {
61
+ if (startContainer.nodeType === 1 && startContainer.querySelector('img')) {
62
+ boundary = startContainer.querySelector('img').getBoundingClientRect();
72
63
  }
73
64
  else {
74
- boundary = range.startContainer.getBoundingClientRect();
65
+ boundary = startContainer.getBoundingClientRect();
75
66
  }
76
67
  }
77
68
  const editableElement = this.contextService.getEditableElement();
@@ -137,4 +128,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
137
128
  type: ViewChild,
138
129
  args: ['inlineToolbar']
139
130
  }] } });
140
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"inline-toolbar.component.js","sourceRoot":"","sources":["../../../../../packages/src/components/inline-toolbar/inline-toolbar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ScrollDispatcher } from '@angular/cdk/overlay';\nimport {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    Input,\n    NgZone,\n    OnDestroy,\n    OnInit,\n    ViewChild\n} from '@angular/core';\nimport { Subject, fromEvent, merge } from 'rxjs';\nimport { debounceTime, filter, takeUntil } from 'rxjs/operators';\nimport { Editor, Range as slateRange } from 'slate';\nimport { AngularEditor } from 'slate-angular';\nimport { THE_INLINE_TOOLBAR_TYPES } from '../../constants';\nimport { ToolbarItem } from '../../interfaces';\nimport * as TheQueries from '../../queries';\nimport { TheContextService } from '../../services/context.service';\nimport { TheToolbarComponent } from '../toolbar/toolbar.component';\n\n@Component({\n    selector: 'the-inline-toolbar',\n    template: `<the-toolbar\n        #inlineToolbar\n        class=\"the-inline-toolbar\"\n        [editor]=\"editor\"\n        [toolbarItems]=\"toolbarItems\"\n        [isMore]=\"false\"\n    ></the-toolbar> `,\n    host: {\n        '[class.hide]': 'toolbarItems.length === 0'\n    },\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    standalone: true,\n    imports: [TheToolbarComponent]\n})\nexport class TheInlineToolbar implements OnInit, OnDestroy {\n    @Input() editor: Editor;\n    @Input() toolbarItems: ToolbarItem[];\n    @ViewChild('inlineToolbar') inlineToolbar: TheToolbarComponent;\n\n    destroy$ = new Subject<void>();\n\n    constructor(\n        private elementRef: ElementRef<any>,\n        private scrollDispatcher: ScrollDispatcher,\n        private cdr: ChangeDetectorRef,\n        private ngZone: NgZone,\n        private contextService: TheContextService\n    ) {}\n\n    ngOnInit() {\n        this.scrollDispatcher\n            .scrolled()\n            .pipe(takeUntil(this.destroy$))\n            .subscribe(() => {\n                this.updateInlineToolbar();\n                this.cdr.detectChanges();\n            });\n        this.ngZone.runOutsideAngular(() => {\n            merge(\n                fromEvent(document, 'mouseup').pipe(filter((e: MouseEvent) => e.button !== 2)),\n                fromEvent(document, 'keyup').pipe(filter((e: KeyboardEvent) => !e.shiftKey))\n            )\n                .pipe(debounceTime(200), takeUntil(this.destroy$))\n                .subscribe(() => {\n                    this.updateInlineToolbar();\n                });\n        });\n    }\n\n    updateInlineToolbar() {\n        const inlineToolbar = this.elementRef.nativeElement.firstElementChild;\n\n        if (!this.editor.selection) {\n            inlineToolbar.removeAttribute('style');\n            return;\n        }\n        const anchorBlock = TheQueries.anchorBlock(this.editor);\n        if (!inlineToolbar || !anchorBlock) {\n            return;\n        }\n        const { editor } = this;\n        const { selection } = editor;\n\n        if (\n            !selection ||\n            !AngularEditor.isFocused(editor) ||\n            slateRange.isCollapsed(selection) ||\n            Editor.string(editor, selection) === ''\n        ) {\n            inlineToolbar.removeAttribute('style');\n            return;\n        }\n\n        if (!THE_INLINE_TOOLBAR_TYPES.includes(anchorBlock.type)) {\n            return;\n        }\n        const native = window.getSelection();\n        if (native.type !== 'None') {\n            const range = native.getRangeAt(0);\n            this.updatePosition(inlineToolbar, range);\n            this.inlineToolbar?.selectionChange(this.editor);\n        }\n        this.cdr.detectChanges();\n    }\n\n    updatePosition(toolbarElement: HTMLElement, range) {\n        let boundary = range.getBoundingClientRect();\n\n        if (!boundary || (boundary.height === 0 && boundary.width === 0 && range.startContainer === range.endContainer)) {\n            if (range.startContainer.nodeType === 1 && range.startContainer.querySelector('img')) {\n                boundary = range.startContainer.querySelector('img').getBoundingClientRect();\n            } else {\n                boundary = range.startContainer.getBoundingClientRect();\n            }\n        }\n        const editableElement = this.contextService.getEditableElement();\n        const editableRect = editableElement.getBoundingClientRect();\n        const toolbarHeight = toolbarElement.offsetHeight;\n        const toolbarWidth = toolbarElement.offsetWidth;\n        const halfOffsetWidth = toolbarWidth / 2;\n        const defaultLeft = -halfOffsetWidth;\n        const offsetLeft = boundary.left - editableRect.left;\n        const isTopLeft = offsetLeft - 30 > halfOffsetWidth; // 30: editable padding left\n        const isTopRight = editableRect.width - offsetLeft - boundary.width / 2 < halfOffsetWidth;\n        const positions: any = {};\n\n        positions.top = boundary.top - toolbarHeight;\n        positions.right = 'initial';\n        positions.left = boundary.left;\n\n        if (isTopLeft) {\n            positions.left = boundary.left + boundary.width / 2 + defaultLeft;\n        }\n\n        if (isTopRight) {\n            positions.left = boundary.right - toolbarWidth;\n        }\n\n        for (let key of Object.keys(positions)) {\n            toolbarElement.style[key] = positions[key] + (isNaN(positions[key]) ? '' : 'px');\n        }\n        toolbarElement.style.opacity = '1';\n    }\n\n    ngOnDestroy() {\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n}\n"]}
131
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"inline-toolbar.component.js","sourceRoot":"","sources":["../../../../../packages/src/components/inline-toolbar/inline-toolbar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ScrollDispatcher } from '@angular/cdk/overlay';\nimport {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    Input,\n    NgZone,\n    OnDestroy,\n    OnInit,\n    ViewChild\n} from '@angular/core';\nimport { Subject, fromEvent, merge } from 'rxjs';\nimport { debounceTime, filter, takeUntil } from 'rxjs/operators';\nimport { Editor, Range as slateRange } from 'slate';\nimport { AngularEditor } from 'slate-angular';\nimport { ToolbarItem } from '../../interfaces';\nimport { TheContextService } from '../../services/context.service';\nimport { TheToolbarComponent } from '../toolbar/toolbar.component';\n\n@Component({\n    selector: 'the-inline-toolbar',\n    template: `<the-toolbar\n        #inlineToolbar\n        class=\"the-inline-toolbar\"\n        [editor]=\"editor\"\n        [toolbarItems]=\"toolbarItems\"\n        [isMore]=\"false\"\n    ></the-toolbar> `,\n    host: {\n        '[class.hide]': 'toolbarItems.length === 0'\n    },\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    standalone: true,\n    imports: [TheToolbarComponent]\n})\nexport class TheInlineToolbar implements OnInit, OnDestroy {\n    @Input() editor: Editor;\n\n    @Input() toolbarItems: ToolbarItem[];\n\n    @ViewChild('inlineToolbar') inlineToolbar: TheToolbarComponent;\n\n    destroy$ = new Subject<void>();\n\n    constructor(\n        private elementRef: ElementRef<any>,\n        private scrollDispatcher: ScrollDispatcher,\n        private cdr: ChangeDetectorRef,\n        private ngZone: NgZone,\n        private contextService: TheContextService\n    ) {}\n\n    ngOnInit() {\n        this.scrollDispatcher\n            .scrolled()\n            .pipe(takeUntil(this.destroy$))\n            .subscribe(() => {\n                this.updateInlineToolbar();\n                this.cdr.detectChanges();\n            });\n        this.ngZone.runOutsideAngular(() => {\n            merge(\n                fromEvent(document, 'mouseup').pipe(filter((e: MouseEvent) => e.button !== 2)),\n                fromEvent(document, 'keyup').pipe(filter((e: KeyboardEvent) => !e.shiftKey))\n            )\n                .pipe(debounceTime(200), takeUntil(this.destroy$))\n                .subscribe(() => {\n                    this.updateInlineToolbar();\n                });\n        });\n    }\n\n    updateInlineToolbar() {\n        const inlineToolbar = this.elementRef.nativeElement.firstElementChild;\n        if (!inlineToolbar) {\n            return;\n        }\n        const { selection } = this.editor;\n        if (\n            !selection ||\n            (selection &&\n                (!AngularEditor.isFocused(this.editor) ||\n                    slateRange.isCollapsed(selection) ||\n                    Editor.string(this.editor, selection) === ''))\n        ) {\n            inlineToolbar.removeAttribute('style');\n            return;\n        }\n\n        const native = window.getSelection();\n        if (native.type !== 'None') {\n            const range = native.getRangeAt(0);\n            this.updatePosition(inlineToolbar, range);\n            this.inlineToolbar?.selectionChange(this.editor);\n            this.cdr.markForCheck();\n        }\n    }\n\n    updatePosition(toolbarElement: HTMLElement, range: Range) {\n        let boundary = range.getBoundingClientRect();\n        const startContainer = range.startContainer as HTMLElement;\n        if (!boundary || (boundary.height === 0 && boundary.width === 0 && startContainer === range.endContainer)) {\n            if (startContainer.nodeType === 1 && startContainer.querySelector('img')) {\n                boundary = startContainer.querySelector('img').getBoundingClientRect();\n            } else {\n                boundary = startContainer.getBoundingClientRect();\n            }\n        }\n        const editableElement = this.contextService.getEditableElement();\n        const editableRect = editableElement.getBoundingClientRect();\n        const toolbarHeight = toolbarElement.offsetHeight;\n        const toolbarWidth = toolbarElement.offsetWidth;\n        const halfOffsetWidth = toolbarWidth / 2;\n        const defaultLeft = -halfOffsetWidth;\n        const offsetLeft = boundary.left - editableRect.left;\n        const isTopLeft = offsetLeft - 30 > halfOffsetWidth; // 30: editable padding left\n        const isTopRight = editableRect.width - offsetLeft - boundary.width / 2 < halfOffsetWidth;\n        const positions: any = {};\n\n        positions.top = boundary.top - toolbarHeight;\n        positions.right = 'initial';\n        positions.left = boundary.left;\n\n        if (isTopLeft) {\n            positions.left = boundary.left + boundary.width / 2 + defaultLeft;\n        }\n\n        if (isTopRight) {\n            positions.left = boundary.right - toolbarWidth;\n        }\n\n        for (let key of Object.keys(positions)) {\n            toolbarElement.style[key] = positions[key] + (isNaN(positions[key]) ? '' : 'px');\n        }\n        toolbarElement.style.opacity = '1';\n    }\n\n    ngOnDestroy() {\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n}\n"]}
@@ -5,7 +5,7 @@ import { ThyAction } from 'ngx-tethys/action';
5
5
  import { ScrollToService } from 'ngx-tethys/core';
6
6
  import { ThyDivider } from 'ngx-tethys/divider';
7
7
  import { ThyDropdownDirective, ThyDropdownMenuComponent, ThyDropdownMenuGroup, ThyDropdownMenuItemDirective } from 'ngx-tethys/dropdown';
8
- import { ThyEmpty } from 'ngx-tethys/empty';
8
+ import { ThyEmptyModule } from 'ngx-tethys/empty';
9
9
  import { ThyIcon } from 'ngx-tethys/icon';
10
10
  import { ThyInputSearch } from 'ngx-tethys/input';
11
11
  import { ThyPopoverDirective } from 'ngx-tethys/popover';
@@ -24,6 +24,7 @@ import { TheTableSelect } from '../table-select/table-select.component';
24
24
  import * as i0 from "@angular/core";
25
25
  import * as i1 from "ngx-tethys/popover";
26
26
  import * as i2 from "@angular/forms";
27
+ import * as i3 from "ngx-tethys/empty";
27
28
  export class ThePluginMenuComponent {
28
29
  constructor(elementRef, cdr, ngZone, thyPopoverRef) {
29
30
  this.elementRef = elementRef;
@@ -178,7 +179,7 @@ export class ThePluginMenuComponent {
178
179
  return item?.key ?? index;
179
180
  }
180
181
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: ThePluginMenuComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i0.NgZone }, { token: i1.ThyPopoverRef }], target: i0.ɵɵFactoryTarget.Component }); }
181
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.0", type: ThePluginMenuComponent, isStandalone: true, selector: "the-plugin-menu", inputs: { editor: "editor", theDisplaySearch: "theDisplaySearch", thePluginMenu: "thePluginMenu", sceneKey: "sceneKey", subPanelClass: "subPanelClass", autoActiveFirstItem: "autoActiveFirstItem" }, host: { properties: { "class": "this.containerClassName" } }, viewQueries: [{ propertyName: "dropdownTriggers", predicate: ["dropdownTriggers"], descendants: true, read: ThyDropdownDirective }], ngImport: i0, template: "<div *ngIf=\"theDisplaySearch\" class=\"menu-search px-5 pt-5 pb-2\">\n <thy-input-search [(ngModel)]=\"keyWords\" placeholder=\"\u641C\u7D22\" thyIconPosition=\"after\" (ngModelChange)=\"updateKeywords(keyWords)\">\n </thy-input-search>\n</div>\n\n<div\n *ngIf=\"groupMenu.length > 0; else thyEmpty\"\n theListBox\n [keyboardContainer]=\"keyboardContainer\"\n [autoActiveFirstItem]=\"listBoxAutoActiveFirstItem\"\n (theListboxChange)=\"theListboxChange($event)\"\n class=\"thy-dropdown-menu the-plugin-menu-scroll-container pb-2 pt-0\"\n>\n <div *ngIf=\"iconMenu?.length > 0\" theListboxGroup [horizontalColumn]=\"6\" class=\"icon-menu d-flex pl-5 py-1\">\n <ng-container *ngFor=\"let item of iconMenu; trackBy: trackByFn\">\n <a\n *ngIf=\"item.type === ThePluginMenuItemType.icon\"\n href=\"javascript:;\"\n class=\"mt-2\"\n thyAction\n theListboxOption\n [theOptionValue]=\"item\"\n [thyActionIcon]=\"item.icon\"\n [thyTooltip]=\"item?.name\"\n [thyDisabled]=\"item.disabled\"\n [theOptionDisabled]=\"item.disabled\"\n thePreventDefault\n (click)=\"handleItemSelection(item)\"\n ></a>\n </ng-container>\n </div>\n\n <thy-divider *ngIf=\"this.iconMenu?.length\" class=\"my-2\"></thy-divider>\n <div theListboxGroup>\n <ng-container *ngFor=\"let item of groupMenu; trackBy: trackByFn\">\n <ng-container *ngIf=\"item.isMenuItem && !(item.children?.length > 0) && item.key !== 'table'\">\n <div\n thyDropdownMenuItem\n theListboxOption\n [theOptionValue]=\"item\"\n class=\"py-0\"\n thePreventDefault\n [thyDisabled]=\"item.disabled\"\n [theOptionDisabled]=\"item.disabled\"\n (click)=\"handleItemSelection(item)\"\n >\n <div *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 <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 <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\n class=\"plugin-menu-table the-table-selector-panel\"\n [editor]=\"editor\"\n [beforeInsert]=\"removeKeywords\"\n ></table-select>\n </ng-template>\n </div>\n </ng-container>\n <ng-container *ngIf=\"!item.isMenuItem\" #menuGroup>\n <thy-dropdown-menu-group class=\"font-size-sm\" [thyTitle]=\"item.groupName\"></thy-dropdown-menu-group>\n </ng-container>\n </ng-container>\n </div>\n</div>\n\n<ng-template #thyEmpty>\n <div class=\"empty d-flex align-items-center justify-content-center\">\n <thy-empty [thyMessage]=\"thyMessage\"></thy-empty>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: TheTableSelect, selector: "table-select", inputs: ["optionsParam", "editor", "beforeInsert"] }, { kind: "component", type: ThyIcon, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "component", type: ThyEmpty, selector: "thy-empty", inputs: ["thyMessage", "thyTranslationKey", "thyTranslationValues", "thyEntityName", "thyEntityNameTranslateKey", "thyIconName", "thySize", "thyMarginTop", "thyTopAuto", "thyContainer", "thyImageUrl", "thyImageLoading", "thyImageFetchPriority", "thyDescription"] }, { kind: "component", type: ThyAction, selector: "thy-action, [thyAction]", inputs: ["thyType", "thyIcon", "thyActionIcon", "thyActive", "thyActionActive", "thyTheme", "thyHoverIcon", "thyDisabled"] }, { kind: "component", type: ThyDivider, selector: "thy-divider", inputs: ["thyVertical", "thyStyle", "thyColor", "thyText", "thyTextDirection", "thyDeeper"] }, { kind: "component", type: ThyInputSearch, selector: "thy-input-search", inputs: ["name", "placeholder", "thyTheme", "thySearchFocus", "thyIconPosition", "thySize"], outputs: ["clear", "thyClear"] }, { kind: "component", type: ThyDropdownMenuComponent, selector: "thy-dropdown-menu", inputs: ["thyWidth", "thyImmediateRender"] }, { kind: "component", type: ThyDropdownMenuGroup, selector: "thy-dropdown-menu-group", inputs: ["thyTitle"] }, { kind: "pipe", type: PluginMenuPipe, name: "getMenuIcon" }, { kind: "directive", type: ThyTooltipDirective, selector: "[thyTooltip],[thy-tooltip]", inputs: ["thyTooltip", "thyTooltipPlacement", "thyTooltipClass", "thyTooltipShowDelay", "thyTooltipHideDelay", "thyTooltipTrigger", "thyTooltipDisabled", "thyTooltipTemplateContext", "thyTooltipOffset", "thyTooltipPin"], exportAs: ["thyTooltip"] }, { kind: "directive", type: ThyPopoverDirective, selector: "[thyPopover]", inputs: ["thyPopover", "thyTrigger", "thyPlacement", "thyOffset", "thyConfig", "thyShowDelay", "thyHideDelay", "thyAutoAdaptive", "thyDisabled"] }, { kind: "directive", type: TheListboxDirective, selector: "[theListBox]", inputs: ["keyboardContainer", "autoActiveFirstItem"], outputs: ["theListboxChange"], exportAs: ["theListBox"] }, { kind: "directive", type: ThyDropdownDirective, selector: "[thyDropdown]", inputs: ["thyDropdownMenu", "thyDropdown", "thyTrigger", "thyShowDelay", "thyHideDelay", "thyActiveClass", "thyPopoverOptions", "thyPlacement", "thyMenuInsideClosable", "thyPanelClass"], outputs: ["thyActiveChange"] }, { kind: "directive", type: TheListboxGroupDirective, selector: "[theListboxGroup]", inputs: ["horizontalColumn"], exportAs: ["theListboxGroup"] }, { kind: "directive", type: TheListboxOptionDirective, selector: "[theListboxOption]", inputs: ["theOptionValue", "theOptionDisabled"], exportAs: ["theListboxOption"] }, { kind: "directive", type: ThePreventDefaultDirective, selector: "[thePreventDefault]", exportAs: ["thePreventDefault"] }, { kind: "directive", type: ThyDropdownMenuItemDirective, selector: "[thyDropdownMenuItem]", inputs: ["thyType", "thyDisabled"] }] }); }
182
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.0", type: ThePluginMenuComponent, isStandalone: true, selector: "the-plugin-menu", inputs: { editor: "editor", theDisplaySearch: "theDisplaySearch", thePluginMenu: "thePluginMenu", sceneKey: "sceneKey", subPanelClass: "subPanelClass", autoActiveFirstItem: "autoActiveFirstItem" }, host: { properties: { "class": "this.containerClassName" } }, viewQueries: [{ propertyName: "dropdownTriggers", predicate: ["dropdownTriggers"], descendants: true, read: ThyDropdownDirective }], ngImport: i0, template: "<div *ngIf=\"theDisplaySearch\" class=\"menu-search px-5 pt-5 pb-2\">\n <thy-input-search [(ngModel)]=\"keyWords\" placeholder=\"\u641C\u7D22\" 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\n class=\"plugin-menu-table the-table-selector-panel\"\n [editor]=\"editor\"\n [beforeInsert]=\"removeKeywords\"\n ></table-select>\n </ng-template>\n </div>\n </ng-container>\n\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", dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: ThyEmptyModule }, { kind: "component", type: i3.ThyEmpty, selector: "thy-empty", inputs: ["thyMessage", "thyTranslationKey", "thyTranslationValues", "thyEntityName", "thyEntityNameTranslateKey", "thyIconName", "thySize", "thyMarginTop", "thyTopAuto", "thyContainer", "thyImageUrl", "thyImageLoading", "thyImageFetchPriority", "thyDescription"] }, { kind: "component", type: TheTableSelect, selector: "table-select", inputs: ["optionsParam", "editor", "beforeInsert"] }, { kind: "component", type: ThyIcon, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "component", type: ThyAction, selector: "thy-action, [thyAction]", inputs: ["thyType", "thyIcon", "thyActionIcon", "thyActive", "thyActionActive", "thyTheme", "thyHoverIcon", "thyDisabled"] }, { kind: "component", type: ThyDivider, selector: "thy-divider", inputs: ["thyVertical", "thyStyle", "thyColor", "thyText", "thyTextDirection", "thyDeeper"] }, { kind: "component", type: ThyInputSearch, selector: "thy-input-search", inputs: ["name", "placeholder", "thyTheme", "thySearchFocus", "thyIconPosition", "thySize"], outputs: ["clear", "thyClear"] }, { kind: "component", type: ThyDropdownMenuComponent, selector: "thy-dropdown-menu", inputs: ["thyWidth", "thyImmediateRender"] }, { kind: "component", type: ThyDropdownMenuGroup, selector: "thy-dropdown-menu-group", inputs: ["thyTitle"] }, { kind: "pipe", type: PluginMenuPipe, name: "getMenuIcon" }, { kind: "directive", type: ThyTooltipDirective, selector: "[thyTooltip],[thy-tooltip]", inputs: ["thyTooltip", "thyTooltipPlacement", "thyTooltipClass", "thyTooltipShowDelay", "thyTooltipHideDelay", "thyTooltipTrigger", "thyTooltipDisabled", "thyTooltipTemplateContext", "thyTooltipOffset", "thyTooltipPin"], exportAs: ["thyTooltip"] }, { kind: "directive", type: ThyPopoverDirective, selector: "[thyPopover]", inputs: ["thyPopover", "thyTrigger", "thyPlacement", "thyOffset", "thyConfig", "thyShowDelay", "thyHideDelay", "thyAutoAdaptive", "thyDisabled"] }, { kind: "directive", type: TheListboxDirective, selector: "[theListBox]", inputs: ["keyboardContainer", "autoActiveFirstItem"], outputs: ["theListboxChange"], exportAs: ["theListBox"] }, { kind: "directive", type: ThyDropdownDirective, selector: "[thyDropdown]", inputs: ["thyDropdownMenu", "thyDropdown", "thyTrigger", "thyShowDelay", "thyHideDelay", "thyActiveClass", "thyPopoverOptions", "thyPlacement", "thyMenuInsideClosable", "thyPanelClass"], outputs: ["thyActiveChange"] }, { kind: "directive", type: TheListboxGroupDirective, selector: "[theListboxGroup]", inputs: ["horizontalColumn"], exportAs: ["theListboxGroup"] }, { kind: "directive", type: TheListboxOptionDirective, selector: "[theListboxOption]", inputs: ["theOptionValue", "theOptionDisabled"], exportAs: ["theListboxOption"] }, { kind: "directive", type: ThePreventDefaultDirective, selector: "[thePreventDefault]", exportAs: ["thePreventDefault"] }, { kind: "directive", type: ThyDropdownMenuItemDirective, selector: "[thyDropdownMenuItem]", inputs: ["thyType", "thyDisabled"] }] }); }
182
183
  }
183
184
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: ThePluginMenuComponent, decorators: [{
184
185
  type: Component,
@@ -186,9 +187,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
186
187
  NgIf,
187
188
  NgFor,
188
189
  FormsModule,
190
+ ThyEmptyModule,
189
191
  TheTableSelect,
190
192
  ThyIcon,
191
- ThyEmpty,
192
193
  ThyAction,
193
194
  ThyDivider,
194
195
  ThyInputSearch,
@@ -203,7 +204,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
203
204
  TheListboxOptionDirective,
204
205
  ThePreventDefaultDirective,
205
206
  ThyDropdownMenuItemDirective
206
- ], template: "<div *ngIf=\"theDisplaySearch\" class=\"menu-search px-5 pt-5 pb-2\">\n <thy-input-search [(ngModel)]=\"keyWords\" placeholder=\"\u641C\u7D22\" thyIconPosition=\"after\" (ngModelChange)=\"updateKeywords(keyWords)\">\n </thy-input-search>\n</div>\n\n<div\n *ngIf=\"groupMenu.length > 0; else thyEmpty\"\n theListBox\n [keyboardContainer]=\"keyboardContainer\"\n [autoActiveFirstItem]=\"listBoxAutoActiveFirstItem\"\n (theListboxChange)=\"theListboxChange($event)\"\n class=\"thy-dropdown-menu the-plugin-menu-scroll-container pb-2 pt-0\"\n>\n <div *ngIf=\"iconMenu?.length > 0\" theListboxGroup [horizontalColumn]=\"6\" class=\"icon-menu d-flex pl-5 py-1\">\n <ng-container *ngFor=\"let item of iconMenu; trackBy: trackByFn\">\n <a\n *ngIf=\"item.type === ThePluginMenuItemType.icon\"\n href=\"javascript:;\"\n class=\"mt-2\"\n thyAction\n theListboxOption\n [theOptionValue]=\"item\"\n [thyActionIcon]=\"item.icon\"\n [thyTooltip]=\"item?.name\"\n [thyDisabled]=\"item.disabled\"\n [theOptionDisabled]=\"item.disabled\"\n thePreventDefault\n (click)=\"handleItemSelection(item)\"\n ></a>\n </ng-container>\n </div>\n\n <thy-divider *ngIf=\"this.iconMenu?.length\" class=\"my-2\"></thy-divider>\n <div theListboxGroup>\n <ng-container *ngFor=\"let item of groupMenu; trackBy: trackByFn\">\n <ng-container *ngIf=\"item.isMenuItem && !(item.children?.length > 0) && item.key !== 'table'\">\n <div\n thyDropdownMenuItem\n theListboxOption\n [theOptionValue]=\"item\"\n class=\"py-0\"\n thePreventDefault\n [thyDisabled]=\"item.disabled\"\n [theOptionDisabled]=\"item.disabled\"\n (click)=\"handleItemSelection(item)\"\n >\n <div *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 <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 <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\n class=\"plugin-menu-table the-table-selector-panel\"\n [editor]=\"editor\"\n [beforeInsert]=\"removeKeywords\"\n ></table-select>\n </ng-template>\n </div>\n </ng-container>\n <ng-container *ngIf=\"!item.isMenuItem\" #menuGroup>\n <thy-dropdown-menu-group class=\"font-size-sm\" [thyTitle]=\"item.groupName\"></thy-dropdown-menu-group>\n </ng-container>\n </ng-container>\n </div>\n</div>\n\n<ng-template #thyEmpty>\n <div class=\"empty d-flex align-items-center justify-content-center\">\n <thy-empty [thyMessage]=\"thyMessage\"></thy-empty>\n </div>\n</ng-template>\n" }]
207
+ ], template: "<div *ngIf=\"theDisplaySearch\" class=\"menu-search px-5 pt-5 pb-2\">\n <thy-input-search [(ngModel)]=\"keyWords\" placeholder=\"\u641C\u7D22\" 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\n class=\"plugin-menu-table the-table-selector-panel\"\n [editor]=\"editor\"\n [beforeInsert]=\"removeKeywords\"\n ></table-select>\n </ng-template>\n </div>\n </ng-container>\n\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" }]
207
208
  }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i0.NgZone }, { type: i1.ThyPopoverRef }], propDecorators: { dropdownTriggers: [{
208
209
  type: ViewChildren,
209
210
  args: ['dropdownTriggers', { read: ThyDropdownDirective }]
@@ -223,4 +224,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
223
224
  }], autoActiveFirstItem: [{
224
225
  type: Input
225
226
  }] } });
226
- //# 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":"AAAA,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAAqB,SAAS,EAAc,WAAW,EAAE,KAAK,EAAkB,YAAY,EAAE,MAAM,eAAe,CAAC;AAC3H,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAC9C,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAClD,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAChD,OAAO,EAAE,oBAAoB,EAAE,wBAAwB,EAAE,oBAAoB,EAAE,4BAA4B,EAAE,MAAM,qBAAqB,CAAC;AACzI,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAC5C,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAC1C,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,mBAAmB,EAAiB,MAAM,oBAAoB,CAAC;AACxE,OAAO,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AACzD,OAAO,EAAE,MAAM,EAAE,IAAI,EAAiB,MAAM,OAAO,CAAC;AACpD,OAAO,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAC9C,OAAO,EAAE,iBAAiB,EAAE,qBAAqB,EAAE,MAAM,iBAAiB,CAAC;AAC3E,OAAO,EAAE,eAAe,EAAE,sBAAsB,EAAE,MAAM,YAAY,CAAC;AACrE,OAAO,EAAE,aAAa,EAAyF,MAAM,kBAAkB,CAAC;AACxI,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAC7D,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AACtC,OAAO,EAAE,0BAA0B,EAAE,MAAM,2BAA2B,CAAC;AACvE,OAAO,EAAyB,mBAAmB,EAAE,wBAAwB,EAAE,yBAAyB,EAAE,MAAM,oBAAoB,CAAC;AACrI,OAAO,EAAE,cAAc,EAAE,MAAM,wCAAwC,CAAC;;;;AA6BxE,MAAM,OAAO,sBAAsB;IAsD/B,YACW,UAAmC,EACnC,GAAsB,EACrB,MAAc,EACd,aAAoD;QAHrD,eAAU,GAAV,UAAU,CAAyB;QACnC,QAAG,GAAH,GAAG,CAAmB;QACrB,WAAM,GAAN,MAAM,CAAQ;QACd,kBAAa,GAAb,aAAa,CAAuC;QAzDhE,+BAA0B,GAAG,IAAI,CAAC;QAQlC,cAAS,GAAkB,EAAE,CAAC;QAE9B,aAAQ,GAAkB,EAAE,CAAC;QAE7B,0BAAqB,GAAG,qBAAqB,CAAC;QAI9C,eAAU,GAAG,MAAM,CAAC;QAIpB,gBAAW,GAAuB;YAC9B,SAAS,EAAE,MAAM;SACpB,CAAC;QAEF,yBAAoB,GAAG;YACnB,SAAS,EAAE,UAAU;YACrB,KAAK,EAAE,OAAO;YACd,QAAQ,EAAE,OAAO;SACpB,CAAC;QAEF,6BAAwB,GAAG;YACvB,UAAU,EAAE,oCAAoC;YAChD,QAAQ,EAAE,CAAC;YACX,QAAQ;YACR,iBAAiB,EAAE,2BAA2B;SACjD,CAAC;QAIoB,uBAAkB,GAAG,2BAA2B,CAAC;QAI9D,qBAAgB,GAAY,KAAK,CAAC;QAQlC,wBAAmB,GAAY,IAAI,CAAC;QA4F7C,mBAAc,GAAG,GAAG,EAAE;YAClB,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAS,CAAC;YAC9E,MAAM,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;YACrC,MAAM,iBAAiB,GAAG,UAAU,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;YACrD,MAAM,iBAAiB,GAAG,UAAU,CAAC,iBAAiB,EAAE,CAAC,IAAI,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YACxF,IAAI,IAAI,IAAI,UAAU,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,iBAAiB,IAAI,iBAAiB,CAAC,EAAE,CAAC;gBAC5E,MAAM,CAAC,cAAc,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC,CAAC;YAC1D,CAAC;QACL,CAAC,CAAC;IA7FC,CAAC;IAEJ,QAAQ;QACJ,IAAI,CAAC,IAAI,CAAC,mBAAmB,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACrD,IAAI,CAAC,0BAA0B,GAAG,KAAK,CAAC;QAC5C,CAAC;QACD,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACxB,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,UAAU,CAAC,GAAG,EAAE;YACZ,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,aAAa,CAAC,mCAAmC,CAAC,CAAC;QAC5G,CAAC,EAAE,CAAC,CAAC,CAAC;IACV,CAAC;IAED,gBAAgB;QACZ,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACxB,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;YACvD,UAAU,CAAC,GAAG,EAAE;gBACZ,OAAO;gBACP,IAAI,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC;oBACxB,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;gBAClF,CAAC;gBACD,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,CAAC;YACjE,CAAC,EAAE,CAAC,CAAC,CAAC;QACV,CAAC;aAAM,CAAC;YACJ,IAAI,CAAC,iBAAiB,GAAG,aAAa,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;QAC/E,CAAC;IACL,CAAC;IAED,oBAAoB;QAChB,MAAM,WAAW,GAAG,IAAI,CAAC,aAAa,IAAI,iBAAiB,CAAC;QAC5D,MAAM,YAAY,GAAG,sBAAsB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACzD,IAAI,CAAC,WAAW,GAAG,eAAe,CAAC,YAAY,EAAE,WAAW,CAAC,CAAC;IAClE,CAAC;IAED,UAAU;QACN,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;QACnB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;QACpB,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,IAA2B,EAAE,EAAE;YACrD,MAAM,QAAQ,GAAG,IAAI,EAAE,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAC9D,IAAI,aAAa,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;gBACjC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;gBACvB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;gBAChE,IAAI,IAAI,CAAC,QAAQ,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC;oBACxF,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBAC9B,CAAC;gBACD,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBACzD,IAAI,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC,KAAwC,EAAE,EAAE;wBAChE,IAAI,KAAK,KAAK,SAAS;4BAAE,OAAO;wBAChC,KAAK,CAAC,UAAU,GAAG,IAAI,CAAC;wBACxB,KAAK,CAAC,QAAQ,GAAG,KAAK,CAAC,UAAU,IAAI,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;wBACnE,MAAM,YAAY,GAAG,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;wBACjE,IAAI,IAAI,CAAC,QAAQ,IAAI,CAAC,YAAY,IAAI,KAAK,CAAC,QAAQ,IAAI,KAAK,CAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC;4BAC9F,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;wBAC/B,CAAC;oBACL,CAAC,CAAC,CAAC;gBACP,CAAC;YACL,CAAC;YACD,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAC9B,IAAI,EAAE,IAAI,KAAK,qBAAqB,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACrG,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC7C,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAC7C,CAAC;QAED,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC5B,CAAC;IAED,mBAAmB,CAAC,QAA2B;QAC3C,IAAI,QAAQ,CAAC,UAAU,IAAI,QAAQ,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;YAC1D,OAAO;QACX,CAAC;QACD,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC;YACzB,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACzB,CAAC;QACD,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACzB,IAAI,CAAC,cAAc,EAAE,CAAC;QAC1B,CAAC;QACD,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC9B,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;QAC3B,iBAAiB,CAAC,mBAAmB,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;IAC7D,CAAC;IAYD,cAAc,CAAC,QAAgB;QAC3B,IAAI,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAC3B,IAAI,CAAC,0BAA0B,GAAG,IAAI,CAAC;QAC3C,CAAC;QACD,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,WAAW,EAAE,CAAC,IAAI,EAAE,CAAC;QAC9C,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;YACvB,IAAI,CAAC,eAAe,CAAC,SAAS,GAAG,CAAC,CAAC;QACvC,CAAC;IACL,CAAC;IAED,gBAAgB,CAAC,KAA4B;QACzC,IAAI,KAAK,CAAC,IAAI,KAAK,QAAQ,EAAE,CAAC;YAC1B,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,MAAM,CAAC,cAAmC,CAAC,CAAC;QAC/E,CAAC;QACD,IAAI,KAAK,CAAC,IAAI,KAAK,OAAO,EAAE,CAAC;YACzB,MAAM,QAAQ,GAAG,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;YACrE,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE;gBACjB,QAAQ,CAAC,IAAI,EAAE,CAAC;YACpB,CAAC,CAAC,CAAC;QACP,CAAC;QACD,IAAI,KAAK,CAAC,IAAI,KAAK,QAAQ,EAAE,CAAC;YAC1B,MAAM,QAAQ,GAAG,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;YACxD,QAAQ,CAAC,IAAI,EAAE,CAAC;QACpB,CAAC;QACD,IAAI,KAAK,CAAC,IAAI,KAAK,MAAM,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC;YACtD,eAAe,CAAC,eAAe,CAAC,KAAK,CAAC,MAAM,CAAC,UAAU,CAAC,aAAa,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;QACjG,CAAC;IACL,CAAC;IAED,mBAAmB,CAAC,MAAiC;QACjD,MAAM,QAAQ,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;YAChD,OAAO,KAAK,CAAC,YAAY,CAAC,CAAC,aAAa,KAAK,MAAM,CAAC,UAAU,CAAC,aAAa,CAAC;QACjF,CAAC,CAAC,CAAC;QACH,OAAO,QAAQ,CAAC;IACpB,CAAC;IAED,SAAS,CAAC,KAAwB,EAAE,IAAS;QACzC,OAAO,IAAI,EAAE,GAAG,IAAI,KAAK,CAAC;IAC9B,CAAC;8GAjMQ,sBAAsB;kGAAtB,sBAAsB,maAsCW,oBAAoB,6BCzFlE,2yMAiKA,4CDpIQ,IAAI,6FACJ,KAAK,kHACL,WAAW,+VACX,cAAc,6GACd,OAAO,sMACP,QAAQ,8TACR,SAAS,gMACT,UAAU,qJACV,cAAc,0LACd,wBAAwB,0GACxB,oBAAoB,qFACpB,cAAc,oDACd,mBAAmB,8TACnB,mBAAmB,2MACnB,mBAAmB,wKACnB,oBAAoB,mRACpB,wBAAwB,2HACxB,yBAAyB,gJACzB,0BAA0B,iGAC1B,4BAA4B;;2FAGvB,sBAAsB;kBA3BlC,SAAS;+BACI,iBAAiB,cAEf,IAAI,WACP;wBACL,IAAI;wBACJ,KAAK;wBACL,WAAW;wBACX,cAAc;wBACd,OAAO;wBACP,QAAQ;wBACR,SAAS;wBACT,UAAU;wBACV,cAAc;wBACd,wBAAwB;wBACxB,oBAAoB;wBACpB,cAAc;wBACd,mBAAmB;wBACnB,mBAAmB;wBACnB,mBAAmB;wBACnB,oBAAoB;wBACpB,wBAAwB;wBACxB,yBAAyB;wBACzB,0BAA0B;wBAC1B,4BAA4B;qBAC/B;gKAwCiE,gBAAgB;sBAAjF,YAAY;uBAAC,kBAAkB,EAAE,EAAE,IAAI,EAAE,oBAAoB,EAAE;gBAE1C,kBAAkB;sBAAvC,WAAW;uBAAC,OAAO;gBAEX,MAAM;sBAAd,KAAK;gBAEG,gBAAgB;sBAAxB,KAAK;gBAEG,aAAa;sBAArB,KAAK;gBAEG,QAAQ;sBAAhB,KAAK;gBAEG,aAAa;sBAArB,KAAK;gBAEG,mBAAmB;sBAA3B,KAAK","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 { ThyEmpty } 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 } 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        TheTableSelect,\n        ThyIcon,\n        ThyEmpty,\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    @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        this._pluginMenu.forEach((item: ThePluginMenuItemWrap) => {\n            const isHidden = item?.isHidden && item.isHidden(this.editor);\n            if (ThePluginMenu.isMenuItem(item)) {\n                item.isMenuItem = true;\n                item.disabled = item.isDisabled && item.isDisabled(this.editor);\n                if (this.keyWords && !isHidden && item.keywords && item.keywords?.includes(this.keyWords)) {\n                    this.groupMenu.push(item);\n                }\n                if (!isHidden && item.children && item.children.length > 0) {\n                    item.children?.forEach((child: ThePluginMenuItemWrap | 'divider') => {\n                        if (child === 'divider') return;\n                        child.isMenuItem = true;\n                        child.disabled = child.isDisabled && child.isDisabled(this.editor);\n                        const isHiddenChid = item.isHidden && item.isHidden(this.editor);\n                        if (this.keyWords && !isHiddenChid && child.keywords && child.keywords?.includes(this.keyWords)) {\n                            this.groupMenu.push(child);\n                        }\n                    });\n                }\n            }\n            if (!this.keyWords && !isHidden) {\n                item?.type === ThePluginMenuItemType.icon ? this.iconMenu.push(item) : this.groupMenu.push(item);\n            }\n        });\n\n        if (this.keyWords && this.groupMenu.length > 0) {\n            this.groupMenu.unshift(this.searchGroup);\n        }\n\n        this.cdr.markForCheck();\n    }\n\n    handleItemSelection(menuItem: ThePluginMenuItem) {\n        if (menuItem.isDisabled && menuItem.isDisabled(this.editor)) {\n            return;\n        }\n        if (!this.editor.selection) {\n            refocus(this.editor);\n        }\n        if (!this.theDisplaySearch) {\n            this.removeKeywords();\n        }\n        menuItem.execute(this.editor);\n        this.thyPopoverRef.close();\n        QuickInsertEditor.updatePluginMenuRef(this.editor, null);\n    }\n\n    removeKeywords = () => {\n        const node = Node.get(this.editor, this.editor.selection.anchor.path) as Text;\n        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    updateKeywords(keywords: string) {\n        if (this.autoActiveFirstItem) {\n            this.listBoxAutoActiveFirstItem = true;\n        }\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 thyEmpty\"\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  <div *ngIf=\"iconMenu?.length > 0\" theListboxGroup [horizontalColumn]=\"6\" class=\"icon-menu d-flex pl-5 py-1\">\n    <ng-container *ngFor=\"let item of iconMenu; trackBy: trackByFn\">\n      <a\n        *ngIf=\"item.type === ThePluginMenuItemType.icon\"\n        href=\"javascript:;\"\n        class=\"mt-2\"\n        thyAction\n        theListboxOption\n        [theOptionValue]=\"item\"\n        [thyActionIcon]=\"item.icon\"\n        [thyTooltip]=\"item?.name\"\n        [thyDisabled]=\"item.disabled\"\n        [theOptionDisabled]=\"item.disabled\"\n        thePreventDefault\n        (click)=\"handleItemSelection(item)\"\n      ></a>\n    </ng-container>\n  </div>\n\n  <thy-divider *ngIf=\"this.iconMenu?.length\" class=\"my-2\"></thy-divider>\n  <div theListboxGroup>\n    <ng-container *ngFor=\"let item of groupMenu; trackBy: trackByFn\">\n      <ng-container *ngIf=\"item.isMenuItem && !(item.children?.length > 0) && item.key !== 'table'\">\n        <div\n          thyDropdownMenuItem\n          theListboxOption\n          [theOptionValue]=\"item\"\n          class=\"py-0\"\n          thePreventDefault\n          [thyDisabled]=\"item.disabled\"\n          [theOptionDisabled]=\"item.disabled\"\n          (click)=\"handleItemSelection(item)\"\n        >\n          <div *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      <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      <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\n              class=\"plugin-menu-table the-table-selector-panel\"\n              [editor]=\"editor\"\n              [beforeInsert]=\"removeKeywords\"\n            ></table-select>\n          </ng-template>\n        </div>\n      </ng-container>\n      <ng-container *ngIf=\"!item.isMenuItem\" #menuGroup>\n        <thy-dropdown-menu-group class=\"font-size-sm\" [thyTitle]=\"item.groupName\"></thy-dropdown-menu-group>\n      </ng-container>\n    </ng-container>\n  </div>\n</div>\n\n<ng-template #thyEmpty>\n  <div class=\"empty d-flex align-items-center justify-content-center\">\n    <thy-empty [thyMessage]=\"thyMessage\"></thy-empty>\n  </div>\n</ng-template>\n"]}
227
+ //# 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 } 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    @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        this.cdr.markForCheck();\n    }\n\n    handleItemSelection(menuItem: ThePluginMenuItem) {\n        if (menuItem.isDisabled && menuItem.isDisabled(this.editor)) {\n            return;\n        }\n        if (!this.editor.selection) {\n            refocus(this.editor);\n        }\n        if (!this.theDisplaySearch) {\n            this.removeKeywords();\n        }\n        menuItem.execute(this.editor);\n        this.thyPopoverRef.close();\n        QuickInsertEditor.updatePluginMenuRef(this.editor, null);\n    }\n\n    removeKeywords = () => {\n        const node = Node.get(this.editor, this.editor.selection.anchor.path) as Text;\n        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    updateKeywords(keywords: string) {\n        if (this.autoActiveFirstItem) {\n            this.listBoxAutoActiveFirstItem = true;\n        }\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\n              class=\"plugin-menu-table the-table-selector-panel\"\n              [editor]=\"editor\"\n              [beforeInsert]=\"removeKeywords\"\n            ></table-select>\n          </ng-template>\n        </div>\n      </ng-container>\n\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"]}