@worktile/theia 16.4.0-next.1 → 16.4.0-next.11

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 (162) hide show
  1. package/components/contextmenu/contextmenu.component.d.ts +3 -2
  2. package/components/toolbar/toolbar.component.d.ts +5 -6
  3. package/components/toolbar-dropdown/toolbar-dropdown.component.d.ts +5 -5
  4. package/components/toolbar-item/toolbar-item.component.d.ts +0 -1
  5. package/core/create-toolbar.d.ts +2 -2
  6. package/core/index.d.ts +2 -1
  7. package/core/toolbar-item/base-toolbar-item.d.ts +1 -0
  8. package/custom-types.d.ts +1 -1
  9. package/editor.component.d.ts +33 -31
  10. package/editor.module.d.ts +1 -1
  11. package/esm2022/components/contextmenu/contextmenu.component.mjs +6 -5
  12. package/esm2022/components/toolbar/toolbar.component.mjs +44 -44
  13. package/esm2022/components/toolbar-dropdown/toolbar-dropdown.component.mjs +11 -29
  14. package/esm2022/components/toolbar-item/toolbar-item.component.mjs +4 -8
  15. package/esm2022/core/create-toolbar.mjs +19 -19
  16. package/esm2022/core/index.mjs +3 -2
  17. package/esm2022/core/toolbar-item/base-toolbar-item.mjs +8 -2
  18. package/esm2022/core/with-theia.mjs +2 -1
  19. package/esm2022/custom-types.mjs +1 -1
  20. package/esm2022/editor.component.mjs +132 -114
  21. package/esm2022/interfaces/editor.mjs +1 -1
  22. package/esm2022/interfaces/image.mjs +1 -1
  23. package/esm2022/interfaces/index.mjs +6 -4
  24. package/esm2022/interfaces/preset.mjs +3 -0
  25. package/esm2022/interfaces/toolbar.mjs +1 -1
  26. package/esm2022/interfaces/upload.mjs +1 -1
  27. package/esm2022/plugins/align/align.editor.mjs +5 -7
  28. package/esm2022/plugins/align/align.plugin.mjs +3 -3
  29. package/esm2022/plugins/autoformat/autoformat.plugin.mjs +3 -3
  30. package/esm2022/plugins/autoformat/transforms/auto-format-block.mjs +3 -3
  31. package/esm2022/plugins/blockquote/blockquote.component.mjs +3 -4
  32. package/esm2022/plugins/blockquote/blockquote.plugin.mjs +4 -4
  33. package/esm2022/plugins/code/code.component.mjs +20 -30
  34. package/esm2022/plugins/code/code.editor.mjs +20 -9
  35. package/esm2022/plugins/color/color.plugin.mjs +7 -3
  36. package/esm2022/plugins/color/toolbar-item.component.mjs +49 -21
  37. package/esm2022/plugins/common/block-card.plugin.mjs +35 -2
  38. package/esm2022/plugins/common/common.plugin.mjs +3 -3
  39. package/esm2022/plugins/common/move-selection.plugin.mjs +6 -4
  40. package/esm2022/plugins/common/remove-empty.plugin.mjs +9 -8
  41. package/esm2022/plugins/common/remove-void.plugin.mjs +7 -4
  42. package/esm2022/plugins/deserialize/deserialize-html.plugin.mjs +2 -2
  43. package/esm2022/plugins/deserialize/deserialize-md.plugin.mjs +2 -2
  44. package/esm2022/plugins/heading/heading.plugin.mjs +4 -4
  45. package/esm2022/plugins/hr/hr.component.mjs +4 -4
  46. package/esm2022/plugins/image/image.component.mjs +99 -84
  47. package/esm2022/plugins/image/image.editor.mjs +34 -16
  48. package/esm2022/plugins/image/image.plugin.mjs +21 -4
  49. package/esm2022/plugins/index.mjs +1 -3
  50. package/esm2022/plugins/inline-code/inline-code.component.mjs +4 -4
  51. package/esm2022/plugins/link/edit/link-edit.component.mjs +4 -15
  52. package/esm2022/plugins/link/link.component.mjs +16 -11
  53. package/esm2022/plugins/link/link.editor.mjs +21 -4
  54. package/esm2022/plugins/link/link.plugin.mjs +3 -3
  55. package/esm2022/plugins/list/components/bulleted-list.component.mjs +3 -4
  56. package/esm2022/plugins/list/components/list-item.component.mjs +3 -4
  57. package/esm2022/plugins/list/components/numbered-list.component.mjs +3 -4
  58. package/esm2022/plugins/list/list.editor.mjs +5 -3
  59. package/esm2022/plugins/list/list.plugin.mjs +4 -4
  60. package/esm2022/plugins/mention/mention.editor.mjs +7 -13
  61. package/esm2022/plugins/normalizers/insert-paragraph-nodes.mjs +1 -1
  62. package/esm2022/plugins/normalizers/trailing-node.plugin.mjs +3 -3
  63. package/esm2022/plugins/public-api.mjs +2 -1
  64. package/esm2022/plugins/quick-insert/components/quick-insert.component.mjs +3 -3
  65. package/esm2022/plugins/quick-insert/quick-insert.editor.mjs +4 -4
  66. package/esm2022/plugins/soft-break/soft-break.plugin.mjs +1 -1
  67. package/esm2022/plugins/table/components/insert-mark/insert-mark.component.mjs +9 -8
  68. package/esm2022/plugins/table/components/row/row.component.mjs +3 -3
  69. package/esm2022/plugins/table/components/table.component.mjs +117 -101
  70. package/esm2022/plugins/table/components/td/td.component.mjs +24 -15
  71. package/esm2022/plugins/table/table.editor.mjs +43 -40
  72. package/esm2022/plugins/table/table.pipe.mjs +1 -1
  73. package/esm2022/plugins/table/table.plugin.mjs +7 -4
  74. package/esm2022/plugins/table/table.service.mjs +9 -34
  75. package/esm2022/plugins/table/table.store.mjs +29 -29
  76. package/esm2022/plugins/table/utils/cell-position.mjs +1 -4
  77. package/esm2022/plugins/table/utils/get-grid-columns.mjs +6 -6
  78. package/esm2022/plugins/table/utils/get-select-cell-node.mjs +1 -8
  79. package/esm2022/plugins/table/utils/merge-cell.mjs +21 -19
  80. package/esm2022/plugins/table/utils/table-position.mjs +1 -1
  81. package/esm2022/plugins/todo-item/todo-item.component.mjs +12 -7
  82. package/esm2022/plugins/vertical-align/toolbar-item.component.mjs +3 -5
  83. package/esm2022/plugins/vertical-align/vertical-align.editor.mjs +2 -2
  84. package/esm2022/public-api.mjs +11 -12
  85. package/esm2022/queries/anchor-block-entry.mjs +3 -3
  86. package/esm2022/queries/anchor-inline-entry.mjs +3 -3
  87. package/esm2022/queries/find-descendant.mjs +3 -3
  88. package/esm2022/queries/find-node.mjs +3 -3
  89. package/esm2022/queries/get-anchor-block-entry.mjs +3 -3
  90. package/esm2022/queries/get-block-above.mjs +3 -3
  91. package/esm2022/queries/get-insert-elements-path.mjs +5 -3
  92. package/esm2022/services/context.service.mjs +11 -10
  93. package/esm2022/services/table-contextmenu.service.mjs +8 -1
  94. package/esm2022/transforms/delete-node-by-type.mjs +10 -0
  95. package/esm2022/transforms/handle-continual-insert-break.mjs +3 -3
  96. package/esm2022/transforms/index.mjs +4 -2
  97. package/esm2022/transforms/move-children.mjs +3 -3
  98. package/esm2022/transforms/set-node-by-type.mjs +10 -0
  99. package/esm2022/utils/data-transform.mjs +1 -1
  100. package/esm2022/utils/fragment.mjs +11 -3
  101. package/esm2022/utils/index.mjs +16 -15
  102. package/esm2022/utils/insert-data-by-invalid-type.mjs +11 -3
  103. package/esm2022/utils/match.mjs +3 -3
  104. package/esm2022/utils/update-popover-position.mjs +26 -0
  105. package/esm2022/utils/weak-maps.mjs +3 -1
  106. package/fesm2022/worktile-theia.mjs +5576 -5390
  107. package/fesm2022/worktile-theia.mjs.map +1 -1
  108. package/interfaces/editor.d.ts +21 -11
  109. package/interfaces/image.d.ts +2 -2
  110. package/interfaces/index.d.ts +5 -3
  111. package/interfaces/preset.d.ts +8 -0
  112. package/interfaces/toolbar.d.ts +2 -1
  113. package/interfaces/upload.d.ts +3 -0
  114. package/package.json +4 -3
  115. package/plugins/code/code.component.d.ts +1 -1
  116. package/plugins/code/code.editor.d.ts +2 -3
  117. package/plugins/color/toolbar-item.component.d.ts +7 -5
  118. package/plugins/color/toolbar-item.component.scss +18 -0
  119. package/plugins/image/image.component.d.ts +17 -15
  120. package/plugins/image/image.component.scss +2 -2
  121. package/plugins/image/image.editor.d.ts +5 -13
  122. package/plugins/link/edit/link-edit.component.d.ts +3 -2
  123. package/plugins/link/link.component.d.ts +2 -0
  124. package/plugins/link/link.editor.d.ts +3 -1
  125. package/plugins/mention/mention.editor.d.ts +1 -1
  126. package/plugins/normalizers/insert-paragraph-nodes.d.ts +1 -2
  127. package/plugins/normalizers/trailing-node.plugin.d.ts +1 -2
  128. package/plugins/public-api.d.ts +1 -0
  129. package/plugins/quick-insert/components/quick-insert.component.d.ts +1 -1
  130. package/plugins/soft-break/soft-break.plugin.d.ts +1 -2
  131. package/plugins/table/components/insert-mark/insert-mark.component.d.ts +1 -0
  132. package/plugins/table/components/row/row.component.d.ts +1 -1
  133. package/plugins/table/components/table.component.d.ts +11 -5
  134. package/plugins/table/components/table.component.scss +9 -3
  135. package/plugins/table/components/td/td.component.d.ts +1 -1
  136. package/plugins/table/table.editor.d.ts +10 -10
  137. package/plugins/table/table.pipe.d.ts +1 -1
  138. package/plugins/table/table.service.d.ts +0 -2
  139. package/plugins/table/table.store.d.ts +10 -11
  140. package/plugins/table/utils/get-grid-columns.d.ts +2 -2
  141. package/plugins/table/utils/get-select-cell-node.d.ts +0 -1
  142. package/plugins/todo-item/todo-item.component.d.ts +2 -0
  143. package/plugins/todo-item/todo-item.component.scss +8 -0
  144. package/plugins/vertical-align/toolbar-item.component.d.ts +0 -1
  145. package/plugins/vertical-align/vertical-align.scss +11 -0
  146. package/public-api.d.ts +10 -11
  147. package/queries/is-range-across-blocks.d.ts +1 -1
  148. package/services/context.service.d.ts +5 -6
  149. package/styles/index.scss +1 -0
  150. package/transforms/delete-node-by-type.d.ts +3 -0
  151. package/transforms/index.d.ts +3 -1
  152. package/transforms/set-node-by-type.d.ts +3 -0
  153. package/utils/index.d.ts +15 -14
  154. package/utils/insert-data-by-invalid-type.d.ts +2 -1
  155. package/utils/update-popover-position.d.ts +4 -0
  156. package/utils/weak-maps.d.ts +2 -0
  157. package/esm2022/plugins/common/transforms.plugin.mjs +0 -18
  158. package/esm2022/test/index.mjs +0 -2
  159. package/esm2022/test/utils/with-plugin.mjs +0 -11
  160. package/plugins/common/transforms.plugin.d.ts +0 -8
  161. package/test/index.d.ts +0 -1
  162. package/test/utils/with-plugin.d.ts +0 -3
@@ -1,9 +1,10 @@
1
- import { OnInit, ElementRef } from '@angular/core';
1
+ import { OnInit, ElementRef, ChangeDetectorRef } from '@angular/core';
2
2
  import { ThyPopoverRef } from 'ngx-tethys/popover';
3
3
  import { MenuEntity } from '../../plugins/table/table.types';
4
4
  import * as i0 from "@angular/core";
5
5
  export declare class TheContextMenuComponent implements OnInit {
6
6
  elementRef: ElementRef;
7
+ cdr: ChangeDetectorRef;
7
8
  private thyPopoverRef;
8
9
  menuEntities: MenuEntity[];
9
10
  actionHandle: (entity: MenuEntity) => void;
@@ -18,7 +19,7 @@ export declare class TheContextMenuComponent implements OnInit {
18
19
  inputNumberFocus(e: Event): void;
19
20
  itemEnterHandle(e: MouseEvent, entity: MenuEntity): void;
20
21
  changeColor(color: string, item: MenuEntity): void;
21
- constructor(elementRef: ElementRef, thyPopoverRef: ThyPopoverRef<TheContextMenuComponent>);
22
+ constructor(elementRef: ElementRef, cdr: ChangeDetectorRef, thyPopoverRef: ThyPopoverRef<TheContextMenuComponent>);
22
23
  ngOnInit(): void;
23
24
  static ɵfac: i0.ɵɵFactoryDeclaration<TheContextMenuComponent, never>;
24
25
  static ɵcmp: i0.ɵɵComponentDeclaration<TheContextMenuComponent, "the-contextmenu", never, { "menuEntities": { "alias": "menuEntities"; "required": false; }; "actionHandle": { "alias": "actionHandle"; "required": false; }; "activeHandle": { "alias": "activeHandle"; "required": false; }; "deactivateHandle": { "alias": "deactivateHandle"; "required": false; }; }, {}, never, never, false, never>;
@@ -42,16 +42,15 @@ export declare class TheToolbarComponent implements OnInit, OnChanges, OnDestroy
42
42
  * | | \---------- only when toolbar items overflow --------/ | |
43
43
  * | └───────────────────────────────────────────────────────────────────────────────────────────┘ |
44
44
  * └───────────────────────────────────────────────────────────────────────────────────────────────┘
45
- * split width: 13px
46
- * item width: default item: 32px; dropdown item: 48px
47
- * default paddingRight: 4px
48
- * set aside 50px
49
45
  */
50
46
  private toolbarItemsCompose;
51
47
  /**
52
- * externally designated more group
48
+ * split width: 13px
49
+ * item width: default item: 32px
50
+ * dropdown item: 48px
51
+ * default paddingRight: 4px
53
52
  */
54
- private toolbarItemsAndMoreCompose;
53
+ private getItemWidth;
55
54
  /**
56
55
  * filter adjacent repeated dividers
57
56
  * @param {ToolbarItem[]} items
@@ -1,10 +1,10 @@
1
- import { OnInit, ElementRef, TemplateRef, ViewContainerRef } from '@angular/core';
2
1
  import { Overlay } from '@angular/cdk/overlay';
2
+ import { ElementRef, OnInit, TemplateRef, ViewContainerRef } from '@angular/core';
3
3
  import { ThyPopover, ThyPopoverRef } from 'ngx-tethys/popover';
4
4
  import { Editor } from 'slate';
5
- import { DropdownMode } from '../../constants/toolbar';
6
- import { ToolbarItem, ToolbarKey } from '../../interfaces/toolbar';
7
- import { TheBaseToolbarDropdown } from '../../core/toolbar-item/base-toolbar-item';
5
+ import { DropdownMode } from '../../constants';
6
+ import { TheBaseToolbarDropdown } from '../../core';
7
+ import { ToolbarItem, ToolbarKey } from '../../interfaces';
8
8
  import * as i0 from "@angular/core";
9
9
  export declare class TheToolbarDropdownComponent extends TheBaseToolbarDropdown implements OnInit {
10
10
  elementRef: ElementRef;
@@ -28,8 +28,8 @@ export declare class TheToolbarDropdownComponent extends TheBaseToolbarDropdown
28
28
  itemMousedown(event: MouseEvent, item: ToolbarItem): void;
29
29
  preventDefault(event: Event): void;
30
30
  openDropdownPopover(event: MouseEvent): void;
31
+ updatePopoverPosition(): void;
31
32
  closeDropdownPopover(): void;
32
- createPositionStrategy(): import("@angular/cdk/overlay").FlexibleConnectedPositionStrategy;
33
33
  static ɵfac: i0.ɵɵFactoryDeclaration<TheToolbarDropdownComponent, never>;
34
34
  static ɵcmp: i0.ɵɵComponentDeclaration<TheToolbarDropdownComponent, "the-toolbar-dropdown", never, {}, {}, never, never, false, never>;
35
35
  }
@@ -2,7 +2,6 @@ import { OnInit } from '@angular/core';
2
2
  import { TheBaseToolbarItem } from '../../core/toolbar-item/base-toolbar-item';
3
3
  import * as i0 from "@angular/core";
4
4
  export declare class TheToolbarItemComponent extends TheBaseToolbarItem implements OnInit {
5
- className: string;
6
5
  toggleDropdown(event: MouseEvent): void;
7
6
  constructor();
8
7
  ngOnInit(): void;
@@ -1,5 +1,5 @@
1
- import { TheEditor, ToolbarEntity, ToolbarOption } from '../interfaces';
2
- export declare const createToolbar: (editor: TheEditor, toolbar: ToolbarOption) => {
1
+ import { TheEditor, ToolbarEntity } from '../interfaces';
2
+ export declare const createToolbar: (editor: TheEditor, global?: string[], inline?: string[]) => {
3
3
  globalToolbarClass: string[];
4
4
  toolbarEntity: ToolbarEntity;
5
5
  };
package/core/index.d.ts CHANGED
@@ -1,4 +1,5 @@
1
- export * from './with-theia';
2
1
  export * from './create-plugin';
3
2
  export * from './create-toolbar';
3
+ export * from './toolbar-item/base-toolbar-item';
4
4
  export * from './utils/index';
5
+ export * from './with-theia';
@@ -10,6 +10,7 @@ export declare abstract class TheBaseToolbarItem {
10
10
  disabled: boolean;
11
11
  active: string | boolean;
12
12
  _toolbarItem: ToolbarItem;
13
+ class: boolean;
13
14
  get disabledState(): boolean;
14
15
  get activeState(): string | boolean;
15
16
  execute(event: MouseEvent): void;
package/custom-types.d.ts CHANGED
@@ -72,7 +72,7 @@ export interface ImageElement extends TheElement {
72
72
  layout?: LayoutTypes;
73
73
  reSized?: boolean;
74
74
  size?: number;
75
- externalSource?: boolean;
75
+ externalUrl?: string;
76
76
  }
77
77
  export interface TableElement extends TheElement {
78
78
  type: ElementKinds.table;
@@ -1,25 +1,24 @@
1
- import { OnInit, OnDestroy, ViewContainerRef, ElementRef, EventEmitter, OnChanges, SimpleChanges, NgZone, ChangeDetectorRef, Injector } from '@angular/core';
2
- import { MixinBase } from 'ngx-tethys/core';
3
- import { Editor, Text, Element, Descendant, Range, NodeEntry } from 'slate';
1
+ import { ChangeDetectorRef, DestroyRef, ElementRef, EventEmitter, Injector, NgZone, OnChanges, OnDestroy, OnInit, SimpleChanges, ViewContainerRef } from '@angular/core';
2
+ import { ThyIconRegistry } from 'ngx-tethys/icon';
3
+ import { Descendant, Editor, Element, NodeEntry, Range, Text } from 'slate';
4
4
  import { DOMRange, SlateError } from 'slate-angular';
5
- import { TheOptions, DomEventDataInfo, TheEditor, ToolbarEntity } from './interfaces';
6
5
  import { TheTemplateComponent } from './components/template/template.component';
7
- import { TheToolbarComponent } from './components/toolbar/toolbar.component';
8
6
  import { TheTextComponent } from './components/text/text.component';
9
- import { TheContextService } from './services/context.service';
7
+ import { TheToolbarComponent } from './components/toolbar/toolbar.component';
8
+ import { DomEventDataInfo, TheEditor, TheOptions, ThePresetConfig, ToolbarEntity } from './interfaces';
10
9
  import { ThePlugin } from './interfaces/plugins/plugins';
11
- import { ThyIconRegistry } from 'ngx-tethys/icon';
10
+ import { TheContextService } from './services/context.service';
12
11
  import * as i0 from "@angular/core";
13
- declare const TheEditorComponent_base: import("ngx-tethys/core").Constructor<import("ngx-tethys/core").ThyUnsubscribe> & typeof MixinBase;
14
- export declare class TheEditorComponent extends TheEditorComponent_base implements OnInit, OnChanges, OnDestroy {
15
- private injector;
16
- private theContextService;
17
- private viewContainerRef;
12
+ export declare class TheEditorComponent implements OnInit, OnChanges, OnDestroy {
13
+ private cdr;
14
+ private destroyRef;
18
15
  private elementRef;
16
+ private injector;
19
17
  private ngZone;
20
- private cdr;
18
+ private viewContainerRef;
19
+ private theContextService;
21
20
  private iconRegistry;
22
- visibleQuickInsertPlus: boolean;
21
+ private presetConfig;
23
22
  theOptions: TheOptions;
24
23
  thePlugins: ThePlugin[];
25
24
  theGlobalToolbar?: TheToolbarComponent;
@@ -40,33 +39,40 @@ export declare class TheEditorComponent extends TheEditorComponent_base implemen
40
39
  editorValue: Descendant[];
41
40
  globalToolbarClass: string[];
42
41
  isMobileMode: boolean;
42
+ visibleQuickInsertPlus: boolean;
43
+ elementToHtml: WeakMap<Element, string>;
43
44
  decorate: (nodeEntry: NodeEntry) => Range[];
45
+ get options(): TheOptions;
44
46
  get theGlobalToolbarInstance(): TheToolbarComponent;
45
47
  get maxHeight(): string;
46
- elementToHtml: WeakMap<Element, string>;
47
48
  private onChangeCallback;
48
49
  private onTouchedCallback;
49
- constructor(injector: Injector, theContextService: TheContextService, viewContainerRef: ViewContainerRef, elementRef: ElementRef, ngZone: NgZone, cdr: ChangeDetectorRef, iconRegistry: ThyIconRegistry);
50
+ constructor(cdr: ChangeDetectorRef, destroyRef: DestroyRef, elementRef: ElementRef, injector: Injector, ngZone: NgZone, viewContainerRef: ViewContainerRef, theContextService: TheContextService, iconRegistry: ThyIconRegistry, presetConfig: ThePresetConfig);
50
51
  ngOnInit(): void;
51
52
  ngOnChanges(changes: SimpleChanges): void;
52
53
  ngOnDestroy(): void;
53
- initialize(): void;
54
- initializeOptions(): void;
55
- initializeEvents(): void;
56
- applyAutoFocus(): void;
57
- toolbarCalculate(): void;
58
- globalToolbarInit(): void;
54
+ private initialize;
55
+ private initializeOptions;
56
+ private initializeContext;
57
+ private getPlugins;
58
+ private initializeMobileMode;
59
+ private toolbarCalculate;
60
+ private initializeGlobalToolbar;
61
+ private initializeQuickInsert;
62
+ private initializeEvents;
63
+ private subscribeUploadingStatus;
64
+ private applyAutoFocus;
59
65
  writeValue(value: string | Descendant[]): void;
60
66
  registerOnChange(fn: any): void;
61
67
  registerOnTouched(fn: any): void;
62
68
  scrollSelectionIntoView: (e: TheEditor, domRange: DOMRange) => void;
63
69
  valueChange(value: Descendant[]): void;
64
- serializingValue(value: Descendant[]): string | Descendant[];
65
- onErrorHandler(): void;
70
+ private serializingValue;
71
+ private onErrorHandler;
66
72
  renderElement: (element: Element) => import("slate-angular").ViewType;
67
73
  renderLeaf: (text: Text) => import("slate-angular").ViewType;
68
74
  renderText: (text: Text) => typeof TheTextComponent;
69
- generateDecorate(): void;
75
+ private generateDecorate;
70
76
  onKeyDown: (event: KeyboardEvent) => void;
71
77
  mousedown(event: MouseEvent): void;
72
78
  handleSelectAll(): void;
@@ -86,11 +92,7 @@ export declare class TheEditorComponent extends TheEditorComponent_base implemen
86
92
  onSlaDragStart: (event: DragEvent) => void;
87
93
  onSlaDragOver: (event: DragEvent) => void;
88
94
  onDrop: (event: DragEvent) => void;
89
- getTextAndJSON(data: DataTransfer): {
90
- json: any[];
91
- text: string;
92
- };
93
- static ɵfac: i0.ɵɵFactoryDeclaration<TheEditorComponent, never>;
95
+ private getTextAndJSON;
96
+ static ɵfac: i0.ɵɵFactoryDeclaration<TheEditorComponent, [null, null, null, null, null, null, null, null, { optional: true; }]>;
94
97
  static ɵcmp: i0.ɵɵComponentDeclaration<TheEditorComponent, "the-editor, theEditor", never, { "theOptions": { "alias": "theOptions"; "required": false; }; "thePlugins": { "alias": "thePlugins"; "required": false; }; "theGlobalToolbar": { "alias": "theGlobalToolbar"; "required": false; }; "theDecorate": { "alias": "theDecorate"; "required": false; }; "theOnError": { "alias": "theOnError"; "required": false; }; }, { "theOnSave": "theOnSave"; "theOnDOMEvent": "theOnDOMEvent"; "theEditorCreated": "theEditorCreated"; "theUploadingStatus": "theUploadingStatus"; }, never, never, false, never>;
95
98
  }
96
- export {};
@@ -101,7 +101,7 @@ import * as i68 from "ngx-tethys/input-number";
101
101
  import * as i69 from "ngx-tethys/color-picker";
102
102
  import * as i70 from "ng-codemirror";
103
103
  import * as i71 from "./components/column-resize/column-resize.module";
104
- export declare const COMPONENTS: (typeof TheDefaultElementComponent | typeof TheToolbarGroupComponent | typeof TheToolbarDropdownComponent | typeof TheToolbarItemComponent | typeof TheToolbarComponent | typeof TheListboxOptionDirective | typeof TheListboxGroupDirective | typeof TheListboxDirective | typeof ThePreventDefaultDirective | typeof ThePluginMenuComponent | typeof TheVerticalToolbarItemComponent | typeof TheContextMenuComponent | typeof TheTableOptionsComponent | typeof TheTextComponent | typeof TheColorToolbarItemComponent | typeof TheConversionHintComponent | typeof TheTableSelectComponent | typeof TheTableToolbarItemComponent | typeof TheInlineToolbarComponent | typeof TheQuickInsertComponent | typeof TheInsertMarkComponent)[];
104
+ export declare const COMPONENTS: (typeof TheToolbarGroupComponent | typeof TheContextMenuComponent | typeof TheListboxOptionDirective | typeof TheListboxGroupDirective | typeof TheListboxDirective | typeof ThePluginMenuComponent | typeof TheVerticalToolbarItemComponent | typeof TheTableOptionsComponent | typeof TheToolbarDropdownComponent | typeof TheToolbarItemComponent | typeof TheToolbarComponent | typeof TheDefaultElementComponent | typeof ThePreventDefaultDirective | typeof TheTextComponent | typeof TheColorToolbarItemComponent | typeof TheConversionHintComponent | typeof TheTableSelectComponent | typeof TheTableToolbarItemComponent | typeof TheInlineToolbarComponent | typeof TheQuickInsertComponent | typeof TheInsertMarkComponent)[];
105
105
  export declare const PLUGIN_COMPONENTS: (typeof TheLinkHoverComponent | typeof TheLinkEditComponent | typeof TheLinkComponent | typeof TheTableToolbarComponent | typeof TheTableComponent | typeof TheTemplateComponent | typeof TheBlockquoteComponent | typeof TheCodeComponent | typeof TheImageComponent | typeof TheTableRowComponent | typeof TheTdComponent | typeof TheTodoItemComponent)[];
106
106
  export declare class TheEditorModule {
107
107
  static ɵfac: i0.ɵɵFactoryDeclaration<TheEditorModule, never>;
@@ -48,20 +48,21 @@ export class TheContextMenuComponent {
48
48
  item.backgroundColor = color;
49
49
  item.activeHandle(undefined, item);
50
50
  }
51
- constructor(elementRef, thyPopoverRef) {
51
+ constructor(elementRef, cdr, thyPopoverRef) {
52
52
  this.elementRef = elementRef;
53
+ this.cdr = cdr;
53
54
  this.thyPopoverRef = thyPopoverRef;
54
55
  this.menuEntities = [];
55
56
  this.wrap = true;
56
57
  }
57
58
  ngOnInit() { }
58
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.4", ngImport: i0, type: TheContextMenuComponent, deps: [{ token: i0.ElementRef }, { token: i1.ThyPopoverRef }], target: i0.ɵɵFactoryTarget.Component }); }
59
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.4", type: TheContextMenuComponent, selector: "the-contextmenu", inputs: { menuEntities: "menuEntities", actionHandle: "actionHandle", activeHandle: "activeHandle", deactivateHandle: "deactivateHandle" }, host: { listeners: { "document: mousedown": "handleDocumentMouseDown($event)", "mousedown": "handleMouseDown($event)" }, properties: { "class.the-overlay-menu-wrap": "this.wrap" } }, ngImport: i0, template: "<div class=\"thy-dropdown-menu\">\n <ng-container *ngFor=\"let menuItem of menuEntities\">\n <ng-container *ngIf=\"menuItem.visibility && !menuItem?.isInputNumber && menuItem.key !== 'background-color'\">\n <ng-template [ngTemplateOutlet]=\"defaultMenuTemplate\" [ngTemplateOutletContext]=\"{ $implicit: menuItem }\"></ng-template>\n </ng-container>\n <ng-container *ngIf=\"menuItem.visibility && menuItem.key === 'background-color'\">\n <ng-template [ngTemplateOutlet]=\"backgroundColorTemplate\" [ngTemplateOutletContext]=\"{ $implicit: menuItem }\"></ng-template>\n </ng-container>\n <ng-container *ngIf=\"menuItem.visibility && menuItem?.isInputNumber\">\n <ng-template [ngTemplateOutlet]=\"inputNumberMenuTemplate\" [ngTemplateOutletContext]=\"{ $implicit: menuItem }\"></ng-template>\n </ng-container>\n <thy-dropdown-menu-divider *ngIf=\"menuItem.divider && menuItem.visibility\"></thy-dropdown-menu-divider>\n </ng-container>\n</div>\n\n<ng-template #defaultMenuTemplate let-item>\n <a\n href=\"javascript:;\"\n thyDropdownMenuItem\n (mousedown)=\"itemMousedown($event, item)\"\n (mouseenter)=\"itemMouseenter($event, item)\"\n (mouseleave)=\"itemMouseleave($event, item)\"\n >\n <span thyDropdownMenuItemIcon>\n <thy-icon [thyIconName]=\"item.icon\"></thy-icon>\n </span>\n <span thyDropdownMenuItemName>{{ item.name }}</span>\n <span *ngIf=\"item.extendIcon\" thyDropdownMenuItemExtendIcon>\n <thy-icon thyIconName=\"{{ item.extendIcon }}\"></thy-icon>\n </span>\n </a>\n</ng-template>\n\n<ng-template #backgroundColorTemplate let-item>\n <a\n href=\"javascript:;\"\n thyDropdownMenuItem\n thyColorPicker\n thyTrigger=\"hover\"\n thyPlacement=\"rightTop\"\n [(ngModel)]=\"item.backgroundColor\"\n (ngModelChange)=\"changeColor($event, item)\"\n [thyHasBackdrop]=\"false\"\n >\n <span thyDropdownMenuItemIcon>\n <thy-icon [thyIconName]=\"item.icon\" thyIconType=\"twotone\" [thyTwotoneColor]=\"item.backgroundColor\"></thy-icon>\n </span>\n <span thyDropdownMenuItemName>{{ item.name }}</span>\n <span *ngIf=\"item.extendIcon\" thyDropdownMenuItemExtendIcon>\n <thy-icon thyIconName=\"{{ item.extendIcon }}\"></thy-icon>\n </span>\n </a>\n</ng-template>\n\n<ng-template #inputNumberMenuTemplate let-item>\n <a href=\"javascript:;\" class=\"the-input-number-menu\" thyDropdownMenuItem (click)=\"itemMousedown($event, item)\">\n <span thyDropdownMenuItemIcon>\n <thy-icon [thyIconName]=\"item.icon\"></thy-icon>\n </span>\n <span thyDropdownMenuItemName class=\"d-flex align-items-center\">\n {{ item.name }}\n <thy-input-number\n #inputNumber\n class=\"mx-2\"\n thySize=\"sm\"\n [(ngModel)]=\"item.count\"\n [thyStep]=\"1\"\n [thyMin]=\"1\"\n (click)=\"inputNumberFocus($event)\"\n (thyEnter)=\"itemEnterHandle($event, item)\"\n thyStopPropagation\n ></thy-input-number>\n {{ item.nameSuffix }}\n </span>\n </a>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.ThyIconComponent, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "directive", type: i5.ThyEnterDirective, selector: "[thyEnter]", outputs: ["thyEnter"] }, { kind: "directive", type: i5.ThyStopPropagationDirective, selector: "[thyStopPropagation]", inputs: ["thyStopPropagation"] }, { kind: "component", type: i6.ThyDropdownMenuDividerComponent, selector: "thy-dropdown-menu-divider" }, { kind: "directive", type: i6.ThyDropdownMenuItemDirective, selector: "[thyDropdownMenuItem]", inputs: ["thyType", "thyDisabled"] }, { kind: "directive", type: i6.ThyDropdownMenuItemNameDirective, selector: "[thyDropdownMenuItemName]" }, { kind: "directive", type: i6.ThyDropdownMenuItemIconDirective, selector: "[thyDropdownMenuItemIcon]" }, { kind: "directive", type: i6.ThyDropdownMenuItemExtendIconDirective, selector: "[thyDropdownMenuItemExtendIcon]" }, { kind: "component", type: i7.ThyInputNumberComponent, selector: "thy-input-number", inputs: ["thyAutoFocus", "thyPlaceholder", "thyDisabled", "thyMax", "thyMin", "thyStep", "thySize", "thyPrecision", "thySuffix"], outputs: ["thyBlur", "thyFocus"] }, { kind: "directive", type: i8.ThyColorPickerDirective, selector: "[thyColorPicker]", inputs: ["thyOffset", "thyHasBackdrop", "thyDefaultColor", "thyTransparentColorSelectable", "thyPresetColors", "thyPlacement", "thyTrigger", "thyShowDelay", "thyHideDelay", "thyDisabled"], outputs: ["thyPanelOpen", "thyPanelClose"] }] }); }
59
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.4", ngImport: i0, type: TheContextMenuComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i1.ThyPopoverRef }], target: i0.ɵɵFactoryTarget.Component }); }
60
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.4", type: TheContextMenuComponent, selector: "the-contextmenu", inputs: { menuEntities: "menuEntities", actionHandle: "actionHandle", activeHandle: "activeHandle", deactivateHandle: "deactivateHandle" }, host: { listeners: { "document: mousedown": "handleDocumentMouseDown($event)", "mousedown": "handleMouseDown($event)" }, properties: { "class.the-overlay-menu-wrap": "this.wrap" } }, ngImport: i0, template: "<div class=\"thy-dropdown-menu\">\n <ng-container *ngFor=\"let menuItem of menuEntities\">\n <ng-container *ngIf=\"menuItem.visibility && !menuItem?.isInputNumber && menuItem.key !== 'background-color'\">\n <ng-template [ngTemplateOutlet]=\"defaultMenuTemplate\" [ngTemplateOutletContext]=\"{ $implicit: menuItem }\"></ng-template>\n </ng-container>\n <ng-container *ngIf=\"menuItem.visibility && menuItem.key === 'background-color'\">\n <ng-template [ngTemplateOutlet]=\"backgroundColorTemplate\" [ngTemplateOutletContext]=\"{ $implicit: menuItem }\"></ng-template>\n </ng-container>\n <ng-container *ngIf=\"menuItem.visibility && menuItem?.isInputNumber\">\n <ng-template [ngTemplateOutlet]=\"inputNumberMenuTemplate\" [ngTemplateOutletContext]=\"{ $implicit: menuItem }\"></ng-template>\n </ng-container>\n <thy-dropdown-menu-divider *ngIf=\"menuItem.divider && menuItem.visibility\"></thy-dropdown-menu-divider>\n </ng-container>\n</div>\n\n<ng-template #defaultMenuTemplate let-item>\n <a\n href=\"javascript:;\"\n thyDropdownMenuItem\n (mousedown)=\"itemMousedown($event, item)\"\n (mouseenter)=\"itemMouseenter($event, item)\"\n (mouseleave)=\"itemMouseleave($event, item)\"\n >\n <span thyDropdownMenuItemIcon>\n <thy-icon [thyIconName]=\"item.icon\"></thy-icon>\n </span>\n <span thyDropdownMenuItemName>{{ item.name }}</span>\n <span *ngIf=\"item.extendIcon\" thyDropdownMenuItemExtendIcon>\n <thy-icon thyIconName=\"{{ item.extendIcon }}\"></thy-icon>\n </span>\n </a>\n</ng-template>\n\n<ng-template #backgroundColorTemplate let-item>\n <a\n href=\"javascript:;\"\n thyDropdownMenuItem\n thyColorPicker\n thyTrigger=\"hover\"\n thyPlacement=\"rightTop\"\n [(ngModel)]=\"item.backgroundColor\"\n (ngModelChange)=\"changeColor($event, item)\"\n [thyHasBackdrop]=\"false\"\n >\n <span thyDropdownMenuItemIcon>\n <thy-icon [thyIconName]=\"item.icon\" thyIconType=\"twotone\" [thyTwotoneColor]=\"item.backgroundColor\"></thy-icon>\n </span>\n <span thyDropdownMenuItemName>{{ item.name }}</span>\n <span *ngIf=\"item.extendIcon\" thyDropdownMenuItemExtendIcon>\n <thy-icon thyIconName=\"{{ item.extendIcon }}\"></thy-icon>\n </span>\n </a>\n</ng-template>\n\n<ng-template #inputNumberMenuTemplate let-item>\n <a href=\"javascript:;\" class=\"the-input-number-menu\" thyDropdownMenuItem (click)=\"itemMousedown($event, item)\">\n <span thyDropdownMenuItemIcon>\n <thy-icon [thyIconName]=\"item.icon\"></thy-icon>\n </span>\n <span thyDropdownMenuItemName class=\"d-flex align-items-center\">\n {{ item.name }}\n <thy-input-number\n #inputNumber\n class=\"mx-2\"\n thySize=\"sm\"\n [(ngModel)]=\"item.count\"\n [thyStep]=\"1\"\n [thyMin]=\"1\"\n (click)=\"inputNumberFocus($event)\"\n (thyEnter)=\"itemEnterHandle($event, item)\"\n thyStopPropagation\n ></thy-input-number>\n {{ item.nameSuffix }}\n </span>\n </a>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.ThyIconComponent, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "directive", type: i5.ThyEnterDirective, selector: "[thyEnter]", outputs: ["thyEnter"] }, { kind: "directive", type: i5.ThyStopPropagationDirective, selector: "[thyStopPropagation]", inputs: ["thyStopPropagation"] }, { kind: "component", type: i6.ThyDropdownMenuDividerComponent, selector: "thy-dropdown-menu-divider" }, { kind: "directive", type: i6.ThyDropdownMenuItemDirective, selector: "[thyDropdownMenuItem]", inputs: ["thyType", "thyDisabled"] }, { kind: "directive", type: i6.ThyDropdownMenuItemNameDirective, selector: "[thyDropdownMenuItemName]" }, { kind: "directive", type: i6.ThyDropdownMenuItemIconDirective, selector: "[thyDropdownMenuItemIcon]" }, { kind: "directive", type: i6.ThyDropdownMenuItemExtendIconDirective, selector: "[thyDropdownMenuItemExtendIcon]" }, { kind: "component", type: i7.ThyInputNumberComponent, selector: "thy-input-number", inputs: ["thyAutoFocus", "thyPlaceholder", "thyDisabled", "thyMax", "thyMin", "thyStep", "thyStepDelay", "thySize", "thyPrecision", "thySuffix"], outputs: ["thyBlur", "thyFocus"] }, { kind: "directive", type: i8.ThyColorPickerDirective, selector: "[thyColorPicker]", inputs: ["thyOffset", "thyHasBackdrop", "thyDefaultColor", "thyTransparentColorSelectable", "thyPresetColors", "thyPlacement", "thyTrigger", "thyShowDelay", "thyHideDelay", "thyDisabled"], outputs: ["thyPanelOpen", "thyPanelClose"] }] }); }
60
61
  }
61
62
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.4", ngImport: i0, type: TheContextMenuComponent, decorators: [{
62
63
  type: Component,
63
64
  args: [{ selector: 'the-contextmenu', template: "<div class=\"thy-dropdown-menu\">\n <ng-container *ngFor=\"let menuItem of menuEntities\">\n <ng-container *ngIf=\"menuItem.visibility && !menuItem?.isInputNumber && menuItem.key !== 'background-color'\">\n <ng-template [ngTemplateOutlet]=\"defaultMenuTemplate\" [ngTemplateOutletContext]=\"{ $implicit: menuItem }\"></ng-template>\n </ng-container>\n <ng-container *ngIf=\"menuItem.visibility && menuItem.key === 'background-color'\">\n <ng-template [ngTemplateOutlet]=\"backgroundColorTemplate\" [ngTemplateOutletContext]=\"{ $implicit: menuItem }\"></ng-template>\n </ng-container>\n <ng-container *ngIf=\"menuItem.visibility && menuItem?.isInputNumber\">\n <ng-template [ngTemplateOutlet]=\"inputNumberMenuTemplate\" [ngTemplateOutletContext]=\"{ $implicit: menuItem }\"></ng-template>\n </ng-container>\n <thy-dropdown-menu-divider *ngIf=\"menuItem.divider && menuItem.visibility\"></thy-dropdown-menu-divider>\n </ng-container>\n</div>\n\n<ng-template #defaultMenuTemplate let-item>\n <a\n href=\"javascript:;\"\n thyDropdownMenuItem\n (mousedown)=\"itemMousedown($event, item)\"\n (mouseenter)=\"itemMouseenter($event, item)\"\n (mouseleave)=\"itemMouseleave($event, item)\"\n >\n <span thyDropdownMenuItemIcon>\n <thy-icon [thyIconName]=\"item.icon\"></thy-icon>\n </span>\n <span thyDropdownMenuItemName>{{ item.name }}</span>\n <span *ngIf=\"item.extendIcon\" thyDropdownMenuItemExtendIcon>\n <thy-icon thyIconName=\"{{ item.extendIcon }}\"></thy-icon>\n </span>\n </a>\n</ng-template>\n\n<ng-template #backgroundColorTemplate let-item>\n <a\n href=\"javascript:;\"\n thyDropdownMenuItem\n thyColorPicker\n thyTrigger=\"hover\"\n thyPlacement=\"rightTop\"\n [(ngModel)]=\"item.backgroundColor\"\n (ngModelChange)=\"changeColor($event, item)\"\n [thyHasBackdrop]=\"false\"\n >\n <span thyDropdownMenuItemIcon>\n <thy-icon [thyIconName]=\"item.icon\" thyIconType=\"twotone\" [thyTwotoneColor]=\"item.backgroundColor\"></thy-icon>\n </span>\n <span thyDropdownMenuItemName>{{ item.name }}</span>\n <span *ngIf=\"item.extendIcon\" thyDropdownMenuItemExtendIcon>\n <thy-icon thyIconName=\"{{ item.extendIcon }}\"></thy-icon>\n </span>\n </a>\n</ng-template>\n\n<ng-template #inputNumberMenuTemplate let-item>\n <a href=\"javascript:;\" class=\"the-input-number-menu\" thyDropdownMenuItem (click)=\"itemMousedown($event, item)\">\n <span thyDropdownMenuItemIcon>\n <thy-icon [thyIconName]=\"item.icon\"></thy-icon>\n </span>\n <span thyDropdownMenuItemName class=\"d-flex align-items-center\">\n {{ item.name }}\n <thy-input-number\n #inputNumber\n class=\"mx-2\"\n thySize=\"sm\"\n [(ngModel)]=\"item.count\"\n [thyStep]=\"1\"\n [thyMin]=\"1\"\n (click)=\"inputNumberFocus($event)\"\n (thyEnter)=\"itemEnterHandle($event, item)\"\n thyStopPropagation\n ></thy-input-number>\n {{ item.nameSuffix }}\n </span>\n </a>\n</ng-template>\n" }]
64
- }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.ThyPopoverRef }]; }, propDecorators: { menuEntities: [{
65
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i1.ThyPopoverRef }]; }, propDecorators: { menuEntities: [{
65
66
  type: Input
66
67
  }], actionHandle: [{
67
68
  type: Input
@@ -79,4 +80,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.4", ngImpor
79
80
  type: HostListener,
80
81
  args: ['mousedown', ['$event']]
81
82
  }] } });
82
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"contextmenu.component.js","sourceRoot":"","sources":["../../../../../packages/src/components/contextmenu/contextmenu.component.ts","../../../../../packages/src/components/contextmenu/contextmenu.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAU,SAAS,EAAE,KAAK,EAAE,WAAW,EAAE,YAAY,EAAc,MAAM,eAAe,CAAC;AAEhG,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;;;;;;;;;;AAOxD,MAAM,OAAO,uBAAuB;IAiBhC,uBAAuB,CAAC,KAAiB;QACrC,IAAI,YAAY,CAAC,KAAK,CAAC,MAAqB,CAAC,EAAE;YAC3C,OAAO;SACV;QACD,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAqB,CAAC,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE;YAC5F,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;SAC9B;IACL,CAAC;IAGD,eAAe,CAAC,KAAiB;QAC7B,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;IAC5B,CAAC;IAED,aAAa,CAAC,KAAiB,EAAE,MAAkB;QAC/C,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;QAC1B,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IAC/B,CAAC;IAED,cAAc,CAAC,KAAiB,EAAE,MAAkB;QAChD,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;IACzC,CAAC;IAED,cAAc,CAAC,KAAiB,EAAE,MAAkB;QAChD,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;IACrC,CAAC;IAED,gBAAgB,CAAC,CAAQ;QACpB,CAAC,CAAC,MAAsB,CAAC,KAAK,EAAE,CAAC;IACtC,CAAC;IAED,eAAe,CAAC,CAAa,EAAE,MAAkB;QAC7C,CAAC,CAAC,cAAc,EAAE,CAAC;QACnB,CAAC,CAAC,eAAe,EAAE,CAAC;QACpB,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;QAC1B,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IAC/B,CAAC;IAED,WAAW,CAAC,KAAa,EAAE,IAAgB;QACvC,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;QAC7B,IAAI,CAAC,YAAY,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;IACvC,CAAC;IAED,YAAmB,UAAsB,EAAU,aAAqD;QAArF,eAAU,GAAV,UAAU,CAAY;QAAU,kBAAa,GAAb,aAAa,CAAwC;QA9DxG,iBAAY,GAAiB,EAAE,CAAC;QAYhC,SAAI,GAAG,IAAI,CAAC;IAkD+F,CAAC;IAE5G,QAAQ,KAAI,CAAC;8GAlEJ,uBAAuB;kGAAvB,uBAAuB,0XCTpC,kgGA4EA;;2FDnEa,uBAAuB;kBAJnC,SAAS;+BACI,iBAAiB;6HAK3B,YAAY;sBADX,KAAK;gBAIN,YAAY;sBADX,KAAK;gBAIN,YAAY;sBADX,KAAK;gBAIN,gBAAgB;sBADf,KAAK;gBAIN,IAAI;sBADH,WAAW;uBAAC,6BAA6B;gBAI1C,uBAAuB;sBADtB,YAAY;uBAAC,qBAAqB,EAAE,CAAC,QAAQ,CAAC;gBAW/C,eAAe;sBADd,YAAY;uBAAC,WAAW,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import { OnInit, Component, Input, HostBinding, HostListener, ElementRef } from '@angular/core';\nimport { ThyPopoverRef } from 'ngx-tethys/popover';\nimport { isColorPanel } from '../../utils/color-picker';\nimport { MenuEntity } from '../../plugins/table/table.types';\n\n@Component({\n    selector: 'the-contextmenu',\n    templateUrl: 'contextmenu.component.html'\n})\nexport class TheContextMenuComponent implements OnInit {\n    @Input()\n    menuEntities: MenuEntity[] = [];\n\n    @Input()\n    actionHandle: (entity: MenuEntity) => void;\n\n    @Input()\n    activeHandle: (event: MouseEvent, entity: MenuEntity) => void;\n\n    @Input()\n    deactivateHandle: (event: MouseEvent, entity: MenuEntity) => void;\n\n    @HostBinding('class.the-overlay-menu-wrap')\n    wrap = true;\n\n    @HostListener('document: mousedown', ['$event'])\n    handleDocumentMouseDown(event: MouseEvent) {\n        if (isColorPanel(event.target as HTMLElement)) {\n            return;\n        }\n        if (!this.elementRef.nativeElement.contains(event.target as HTMLElement) && event.button !== 2) {\n            this.thyPopoverRef.close();\n        }\n    }\n\n    @HostListener('mousedown', ['$event'])\n    handleMouseDown(event: MouseEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n    }\n\n    itemMousedown(event: MouseEvent, entity: MenuEntity) {\n        event.preventDefault();\n        this.actionHandle(entity);\n        this.thyPopoverRef.close();\n    }\n\n    itemMouseleave(event: MouseEvent, entity: MenuEntity) {\n        event.preventDefault();\n        this.deactivateHandle(event, entity);\n    }\n\n    itemMouseenter(event: MouseEvent, entity: MenuEntity) {\n        event.preventDefault();\n        this.activeHandle(event, entity);\n    }\n\n    inputNumberFocus(e: Event) {\n        (e.target as HTMLElement).focus();\n    }\n\n    itemEnterHandle(e: MouseEvent, entity: MenuEntity) {\n        e.preventDefault();\n        e.stopPropagation();\n        this.actionHandle(entity);\n        this.thyPopoverRef.close();\n    }\n\n    changeColor(color: string, item: MenuEntity) {\n        item.backgroundColor = color;\n        item.activeHandle(undefined, item);\n    }\n\n    constructor(public elementRef: ElementRef, private thyPopoverRef: ThyPopoverRef<TheContextMenuComponent>) {}\n\n    ngOnInit() {}\n}\n","<div class=\"thy-dropdown-menu\">\n  <ng-container *ngFor=\"let menuItem of menuEntities\">\n    <ng-container *ngIf=\"menuItem.visibility && !menuItem?.isInputNumber && menuItem.key !== 'background-color'\">\n      <ng-template [ngTemplateOutlet]=\"defaultMenuTemplate\" [ngTemplateOutletContext]=\"{ $implicit: menuItem }\"></ng-template>\n    </ng-container>\n    <ng-container *ngIf=\"menuItem.visibility && menuItem.key === 'background-color'\">\n      <ng-template [ngTemplateOutlet]=\"backgroundColorTemplate\" [ngTemplateOutletContext]=\"{ $implicit: menuItem }\"></ng-template>\n    </ng-container>\n    <ng-container *ngIf=\"menuItem.visibility && menuItem?.isInputNumber\">\n      <ng-template [ngTemplateOutlet]=\"inputNumberMenuTemplate\" [ngTemplateOutletContext]=\"{ $implicit: menuItem }\"></ng-template>\n    </ng-container>\n    <thy-dropdown-menu-divider *ngIf=\"menuItem.divider && menuItem.visibility\"></thy-dropdown-menu-divider>\n  </ng-container>\n</div>\n\n<ng-template #defaultMenuTemplate let-item>\n  <a\n    href=\"javascript:;\"\n    thyDropdownMenuItem\n    (mousedown)=\"itemMousedown($event, item)\"\n    (mouseenter)=\"itemMouseenter($event, item)\"\n    (mouseleave)=\"itemMouseleave($event, item)\"\n  >\n    <span thyDropdownMenuItemIcon>\n      <thy-icon [thyIconName]=\"item.icon\"></thy-icon>\n    </span>\n    <span thyDropdownMenuItemName>{{ item.name }}</span>\n    <span *ngIf=\"item.extendIcon\" thyDropdownMenuItemExtendIcon>\n      <thy-icon thyIconName=\"{{ item.extendIcon }}\"></thy-icon>\n    </span>\n  </a>\n</ng-template>\n\n<ng-template #backgroundColorTemplate let-item>\n  <a\n    href=\"javascript:;\"\n    thyDropdownMenuItem\n    thyColorPicker\n    thyTrigger=\"hover\"\n    thyPlacement=\"rightTop\"\n    [(ngModel)]=\"item.backgroundColor\"\n    (ngModelChange)=\"changeColor($event, item)\"\n    [thyHasBackdrop]=\"false\"\n  >\n    <span thyDropdownMenuItemIcon>\n      <thy-icon [thyIconName]=\"item.icon\" thyIconType=\"twotone\" [thyTwotoneColor]=\"item.backgroundColor\"></thy-icon>\n    </span>\n    <span thyDropdownMenuItemName>{{ item.name }}</span>\n    <span *ngIf=\"item.extendIcon\" thyDropdownMenuItemExtendIcon>\n      <thy-icon thyIconName=\"{{ item.extendIcon }}\"></thy-icon>\n    </span>\n  </a>\n</ng-template>\n\n<ng-template #inputNumberMenuTemplate let-item>\n  <a href=\"javascript:;\" class=\"the-input-number-menu\" thyDropdownMenuItem (click)=\"itemMousedown($event, item)\">\n    <span thyDropdownMenuItemIcon>\n      <thy-icon [thyIconName]=\"item.icon\"></thy-icon>\n    </span>\n    <span thyDropdownMenuItemName class=\"d-flex align-items-center\">\n      {{ item.name }}\n      <thy-input-number\n        #inputNumber\n        class=\"mx-2\"\n        thySize=\"sm\"\n        [(ngModel)]=\"item.count\"\n        [thyStep]=\"1\"\n        [thyMin]=\"1\"\n        (click)=\"inputNumberFocus($event)\"\n        (thyEnter)=\"itemEnterHandle($event, item)\"\n        thyStopPropagation\n      ></thy-input-number>\n      {{ item.nameSuffix }}\n    </span>\n  </a>\n</ng-template>\n"]}
83
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"contextmenu.component.js","sourceRoot":"","sources":["../../../../../packages/src/components/contextmenu/contextmenu.component.ts","../../../../../packages/src/components/contextmenu/contextmenu.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAU,SAAS,EAAE,KAAK,EAAE,WAAW,EAAE,YAAY,EAAiC,MAAM,eAAe,CAAC;AAEnH,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;;;;;;;;;;AAOxD,MAAM,OAAO,uBAAuB;IAgBhC,uBAAuB,CAAC,KAAiB;QACrC,IAAI,YAAY,CAAC,KAAK,CAAC,MAAqB,CAAC,EAAE;YAC3C,OAAO;SACV;QACD,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAqB,CAAC,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE;YAC5F,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;SAC9B;IACL,CAAC;IAGD,eAAe,CAAC,KAAiB;QAC7B,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;IAC5B,CAAC;IAED,aAAa,CAAC,KAAiB,EAAE,MAAkB;QAC/C,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;QAC1B,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IAC/B,CAAC;IAED,cAAc,CAAC,KAAiB,EAAE,MAAkB;QAChD,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;IACzC,CAAC;IAED,cAAc,CAAC,KAAiB,EAAE,MAAkB;QAChD,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;IACrC,CAAC;IAED,gBAAgB,CAAC,CAAQ;QACpB,CAAC,CAAC,MAAsB,CAAC,KAAK,EAAE,CAAC;IACtC,CAAC;IAED,eAAe,CAAC,CAAa,EAAE,MAAkB;QAC7C,CAAC,CAAC,cAAc,EAAE,CAAC;QACnB,CAAC,CAAC,eAAe,EAAE,CAAC;QACpB,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;QAC1B,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IAC/B,CAAC;IAED,WAAW,CAAC,KAAa,EAAE,IAAgB;QACvC,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;QAC7B,IAAI,CAAC,YAAY,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;IACvC,CAAC;IAED,YACW,UAAsB,EACtB,GAAsB,EACrB,aAAqD;QAFtD,eAAU,GAAV,UAAU,CAAY;QACtB,QAAG,GAAH,GAAG,CAAmB;QACrB,kBAAa,GAAb,aAAa,CAAwC;QAjExD,iBAAY,GAAiB,EAAE,CAAC;QAYzC,SAAI,GAAG,IAAI,CAAC;IAsDT,CAAC;IAEJ,QAAQ,KAAI,CAAC;8GArEJ,uBAAuB;kGAAvB,uBAAuB,0XCTpC,kgGA4EA;;2FDnEa,uBAAuB;kBAJnC,SAAS;+BACI,iBAAiB;6JAIlB,YAAY;sBAApB,KAAK;gBAGN,YAAY;sBADX,KAAK;gBAIN,YAAY;sBADX,KAAK;gBAIN,gBAAgB;sBADf,KAAK;gBAIN,IAAI;sBADH,WAAW;uBAAC,6BAA6B;gBAI1C,uBAAuB;sBADtB,YAAY;uBAAC,qBAAqB,EAAE,CAAC,QAAQ,CAAC;gBAW/C,eAAe;sBADd,YAAY;uBAAC,WAAW,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import { OnInit, Component, Input, HostBinding, HostListener, ElementRef, ChangeDetectorRef } from '@angular/core';\nimport { ThyPopoverRef } from 'ngx-tethys/popover';\nimport { isColorPanel } from '../../utils/color-picker';\nimport { MenuEntity } from '../../plugins/table/table.types';\n\n@Component({\n    selector: 'the-contextmenu',\n    templateUrl: 'contextmenu.component.html'\n})\nexport class TheContextMenuComponent implements OnInit {\n    @Input() menuEntities: MenuEntity[] = [];\n\n    @Input()\n    actionHandle: (entity: MenuEntity) => void;\n\n    @Input()\n    activeHandle: (event: MouseEvent, entity: MenuEntity) => void;\n\n    @Input()\n    deactivateHandle: (event: MouseEvent, entity: MenuEntity) => void;\n\n    @HostBinding('class.the-overlay-menu-wrap')\n    wrap = true;\n\n    @HostListener('document: mousedown', ['$event'])\n    handleDocumentMouseDown(event: MouseEvent) {\n        if (isColorPanel(event.target as HTMLElement)) {\n            return;\n        }\n        if (!this.elementRef.nativeElement.contains(event.target as HTMLElement) && event.button !== 2) {\n            this.thyPopoverRef.close();\n        }\n    }\n\n    @HostListener('mousedown', ['$event'])\n    handleMouseDown(event: MouseEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n    }\n\n    itemMousedown(event: MouseEvent, entity: MenuEntity) {\n        event.preventDefault();\n        this.actionHandle(entity);\n        this.thyPopoverRef.close();\n    }\n\n    itemMouseleave(event: MouseEvent, entity: MenuEntity) {\n        event.preventDefault();\n        this.deactivateHandle(event, entity);\n    }\n\n    itemMouseenter(event: MouseEvent, entity: MenuEntity) {\n        event.preventDefault();\n        this.activeHandle(event, entity);\n    }\n\n    inputNumberFocus(e: Event) {\n        (e.target as HTMLElement).focus();\n    }\n\n    itemEnterHandle(e: MouseEvent, entity: MenuEntity) {\n        e.preventDefault();\n        e.stopPropagation();\n        this.actionHandle(entity);\n        this.thyPopoverRef.close();\n    }\n\n    changeColor(color: string, item: MenuEntity) {\n        item.backgroundColor = color;\n        item.activeHandle(undefined, item);\n    }\n\n    constructor(\n        public elementRef: ElementRef,\n        public cdr: ChangeDetectorRef,\n        private thyPopoverRef: ThyPopoverRef<TheContextMenuComponent>\n    ) {}\n\n    ngOnInit() {}\n}\n","<div class=\"thy-dropdown-menu\">\n  <ng-container *ngFor=\"let menuItem of menuEntities\">\n    <ng-container *ngIf=\"menuItem.visibility && !menuItem?.isInputNumber && menuItem.key !== 'background-color'\">\n      <ng-template [ngTemplateOutlet]=\"defaultMenuTemplate\" [ngTemplateOutletContext]=\"{ $implicit: menuItem }\"></ng-template>\n    </ng-container>\n    <ng-container *ngIf=\"menuItem.visibility && menuItem.key === 'background-color'\">\n      <ng-template [ngTemplateOutlet]=\"backgroundColorTemplate\" [ngTemplateOutletContext]=\"{ $implicit: menuItem }\"></ng-template>\n    </ng-container>\n    <ng-container *ngIf=\"menuItem.visibility && menuItem?.isInputNumber\">\n      <ng-template [ngTemplateOutlet]=\"inputNumberMenuTemplate\" [ngTemplateOutletContext]=\"{ $implicit: menuItem }\"></ng-template>\n    </ng-container>\n    <thy-dropdown-menu-divider *ngIf=\"menuItem.divider && menuItem.visibility\"></thy-dropdown-menu-divider>\n  </ng-container>\n</div>\n\n<ng-template #defaultMenuTemplate let-item>\n  <a\n    href=\"javascript:;\"\n    thyDropdownMenuItem\n    (mousedown)=\"itemMousedown($event, item)\"\n    (mouseenter)=\"itemMouseenter($event, item)\"\n    (mouseleave)=\"itemMouseleave($event, item)\"\n  >\n    <span thyDropdownMenuItemIcon>\n      <thy-icon [thyIconName]=\"item.icon\"></thy-icon>\n    </span>\n    <span thyDropdownMenuItemName>{{ item.name }}</span>\n    <span *ngIf=\"item.extendIcon\" thyDropdownMenuItemExtendIcon>\n      <thy-icon thyIconName=\"{{ item.extendIcon }}\"></thy-icon>\n    </span>\n  </a>\n</ng-template>\n\n<ng-template #backgroundColorTemplate let-item>\n  <a\n    href=\"javascript:;\"\n    thyDropdownMenuItem\n    thyColorPicker\n    thyTrigger=\"hover\"\n    thyPlacement=\"rightTop\"\n    [(ngModel)]=\"item.backgroundColor\"\n    (ngModelChange)=\"changeColor($event, item)\"\n    [thyHasBackdrop]=\"false\"\n  >\n    <span thyDropdownMenuItemIcon>\n      <thy-icon [thyIconName]=\"item.icon\" thyIconType=\"twotone\" [thyTwotoneColor]=\"item.backgroundColor\"></thy-icon>\n    </span>\n    <span thyDropdownMenuItemName>{{ item.name }}</span>\n    <span *ngIf=\"item.extendIcon\" thyDropdownMenuItemExtendIcon>\n      <thy-icon thyIconName=\"{{ item.extendIcon }}\"></thy-icon>\n    </span>\n  </a>\n</ng-template>\n\n<ng-template #inputNumberMenuTemplate let-item>\n  <a href=\"javascript:;\" class=\"the-input-number-menu\" thyDropdownMenuItem (click)=\"itemMousedown($event, item)\">\n    <span thyDropdownMenuItemIcon>\n      <thy-icon [thyIconName]=\"item.icon\"></thy-icon>\n    </span>\n    <span thyDropdownMenuItemName class=\"d-flex align-items-center\">\n      {{ item.name }}\n      <thy-input-number\n        #inputNumber\n        class=\"mx-2\"\n        thySize=\"sm\"\n        [(ngModel)]=\"item.count\"\n        [thyStep]=\"1\"\n        [thyMin]=\"1\"\n        (click)=\"inputNumberFocus($event)\"\n        (thyEnter)=\"itemEnterHandle($event, item)\"\n        thyStopPropagation\n      ></thy-input-number>\n      {{ item.nameSuffix }}\n    </span>\n  </a>\n</ng-template>\n"]}
@@ -1,8 +1,7 @@
1
1
  import { Component, HostBinding, Inject, Input, ViewChild, ViewContainerRef } from '@angular/core';
2
2
  import { ThyDividerComponent } from 'ngx-tethys/divider';
3
3
  import { Editor, Element } from 'slate';
4
- import { ElementKinds, ToolbarActionTypes } from '../../constants/node-types';
5
- import { TheToolbarGroupToken, ToolbarMoreGroup } from '../../constants/toolbar';
4
+ import { DropdownMode, ElementKinds, TheToolbarGroupToken, ToolbarActionTypes, ToolbarMoreGroup } from '../../constants';
6
5
  import { ToolbarItemType } from '../../interfaces/toolbar';
7
6
  import { TheToolbarDropdownComponent } from '../toolbar-dropdown/toolbar-dropdown.component';
8
7
  import { TheToolbarItemComponent } from '../toolbar-item/toolbar-item.component';
@@ -110,50 +109,36 @@ export class TheToolbarComponent {
110
109
  * | | \---------- only when toolbar items overflow --------/ | |
111
110
  * | └───────────────────────────────────────────────────────────────────────────────────────────┘ |
112
111
  * └───────────────────────────────────────────────────────────────────────────────────────────────┘
113
- * split width: 13px
114
- * item width: default item: 32px; dropdown item: 48px
115
- * default paddingRight: 4px
116
- * set aside 50px
117
112
  */
118
113
  toolbarItemsCompose() {
119
- let elementWidth = this.isMore ? this.elementWidth : null;
120
- // dropdown item + paddingRight
121
- const maxItemWidth = 52;
122
- // default item + paddingRight
123
- const defaultItemWidth = 36;
124
- const splitWidth = 13;
114
+ const groupWidth = 32;
125
115
  const items = [];
126
116
  const group = [];
117
+ let elementWidth = this.isMore ? this.elementWidth : null;
118
+ let isSpaceRemaining = true;
127
119
  for (let i = 0; i < this.toolbarItems.length; i++) {
128
120
  const item = this.toolbarItems[i];
129
121
  if (!this.isMore) {
130
122
  items.push(item);
131
123
  continue;
132
124
  }
133
- let itemWidth = defaultItemWidth;
134
- switch (item.key) {
135
- case ElementKinds.headingList:
136
- itemWidth = 74;
137
- break;
138
- case ToolbarActionTypes.split:
139
- itemWidth = splitWidth;
140
- break;
141
- case ToolbarActionTypes.verticalAlign:
142
- itemWidth = this.isTableActive() ? maxItemWidth : 0;
143
- break;
144
- default:
145
- const isCustomComponent = item?.type === ToolbarItemType.dropdown || !!item?.iconComponent;
146
- itemWidth = isCustomComponent ? maxItemWidth : defaultItemWidth;
125
+ if (!isSpaceRemaining) {
126
+ group.push(item);
127
+ continue;
147
128
  }
148
- const remainingWidth = i === this.toolbarItems.length - 1 ? itemWidth : itemWidth + splitWidth;
149
- const allowRender = elementWidth && elementWidth >= remainingWidth;
150
- elementWidth -= itemWidth;
129
+ const itemWidth = this.getItemWidth(item);
130
+ const occupyWidth = i === this.toolbarItems.length - 1 ? itemWidth : itemWidth + groupWidth;
131
+ const allowRender = elementWidth && elementWidth >= occupyWidth;
151
132
  if (allowRender) {
152
133
  items.push(item);
134
+ elementWidth -= itemWidth;
153
135
  }
154
136
  else {
155
137
  const isFirstSplit = group.length === 0 && item.key === ToolbarActionTypes.split;
156
- !isFirstSplit && group.push(item);
138
+ if (!isFirstSplit) {
139
+ isSpaceRemaining = false;
140
+ group.push(item);
141
+ }
157
142
  }
158
143
  }
159
144
  return {
@@ -162,22 +147,37 @@ export class TheToolbarComponent {
162
147
  };
163
148
  }
164
149
  /**
165
- * externally designated more group
150
+ * split width: 13px
151
+ * item width: default item: 32px
152
+ * dropdown item: 48px
153
+ * default paddingRight: 4px
166
154
  */
167
- toolbarItemsAndMoreCompose() {
168
- const items = [];
169
- const group = [];
170
- for (const item of this.toolbarItems) {
171
- if (item.key === ToolbarActionTypes.split) {
172
- items.push(item);
173
- continue;
155
+ getItemWidth(item) {
156
+ const paddingRight = 4;
157
+ const defaultItemWidth = 32;
158
+ const iconDropdownItemWidth = 48;
159
+ const textDropdownItemWidth = 70;
160
+ const dropdownActionIconWidth = 16;
161
+ const splitWidth = 9;
162
+ const isDropdownComponent = item?.type === ToolbarItemType.dropdown;
163
+ const isUpdateDropdownItemWidth = !item?.width && isDropdownComponent;
164
+ let itemWidth = item?.width ?? defaultItemWidth;
165
+ if (isUpdateDropdownItemWidth) {
166
+ if (item?.dropdownMode === DropdownMode.icon) {
167
+ itemWidth = iconDropdownItemWidth;
168
+ }
169
+ if (!item?.dropdownMode || item?.dropdownMode === DropdownMode.text) {
170
+ itemWidth = textDropdownItemWidth;
171
+ }
172
+ if (item?.isHideDropdownActionIcon) {
173
+ itemWidth -= dropdownActionIconWidth;
174
174
  }
175
- items.push(item);
176
175
  }
177
- return {
178
- items: this.pureToolbarItems(items),
179
- group
180
- };
176
+ if (item.key === ToolbarActionTypes.split) {
177
+ itemWidth = splitWidth;
178
+ }
179
+ itemWidth += paddingRight;
180
+ return itemWidth;
181
181
  }
182
182
  /**
183
183
  * filter adjacent repeated dividers
@@ -264,4 +264,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.4", ngImpor
264
264
  type: HostBinding,
265
265
  args: ['style.justifyContent']
266
266
  }] } });
267
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolbar.component.js","sourceRoot":"","sources":["../../../../../packages/src/components/toolbar/toolbar.component.ts","../../../../../packages/src/components/toolbar/toolbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectorRef,\n    Component,\n    ComponentRef,\n    ElementRef,\n    HostBinding,\n    Inject,\n    Input,\n    NgZone,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    SimpleChanges,\n    TemplateRef,\n    ViewChild,\n    ViewContainerRef\n} from '@angular/core';\nimport { ThyDividerComponent } from 'ngx-tethys/divider';\nimport { Editor, Element } from 'slate';\nimport { ComponentType } from 'slate-angular';\nimport { ElementKinds, ToolbarActionTypes } from '../../constants/node-types';\nimport { TheToolbarGroupToken, ToolbarMoreGroup } from '../../constants/toolbar';\nimport { TheBaseToolbarDropdown, TheBaseToolbarItem } from '../../core/toolbar-item/base-toolbar-item';\nimport { ToolbarAlignment, ToolbarItem, ToolbarItemType, ToolbarItemsComposeReturn } from '../../interfaces/toolbar';\nimport { TheToolbarDropdownComponent } from '../toolbar-dropdown/toolbar-dropdown.component';\nimport type { TheToolbarGroupComponent } from '../toolbar-group/toolbar-group.component';\nimport { TheToolbarItemComponent } from '../toolbar-item/toolbar-item.component';\n\n@Component({\n    selector: 'the-toolbar',\n    templateUrl: 'toolbar.component.html',\n    host: {\n        class: 'the-toolbar-container d-flex align-items-center'\n    }\n})\nexport class TheToolbarComponent implements OnInit, OnChanges, OnDestroy {\n    @Input() editor: Editor;\n\n    @Input() toolbarItems: ToolbarItem[] = [];\n\n    @Input() align: ToolbarAlignment;\n\n    @Input() containerClass: string[] = [];\n\n    @Input() isMore = true;\n\n    @Input() afterTemplate: TemplateRef<any>;\n\n    @ViewChild('toolbarContainer', { read: ViewContainerRef, static: true }) toolbarContainer: ViewContainerRef;\n\n    @HostBinding('style.justifyContent') get justifyContent() {\n        return this.align;\n    }\n\n    components: Map<string, ComponentRef<any>> = new Map<string, ComponentRef<any>>();\n\n    composeToolbarItems: ToolbarItemsComposeReturn;\n\n    moreGroupMenu = ToolbarMoreGroup;\n\n    resizeObserver: ResizeObserver;\n\n    elementWidth = 0;\n\n    constructor(\n        private cdr: ChangeDetectorRef,\n        private elementRef: ElementRef,\n        private ngZone: NgZone,\n        @Inject(TheToolbarGroupToken) private toolbarGroupComponent: ComponentType<TheToolbarGroupComponent>\n    ) {}\n\n    ngOnInit() {\n        this.setToolbarClass();\n        this.renderToolbarView();\n        this.selectionChange(this.editor);\n        this.isMore && this.resizeElement();\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        const toolbarItems = changes.toolbarItems;\n        if (toolbarItems && !toolbarItems.firstChange) {\n            this.renderToolbarView();\n        }\n    }\n\n    ngOnDestroy(): void {\n        if (this.resizeObserver) {\n            this.resizeObserver.disconnect();\n        }\n    }\n\n    public setToolbarClass() {\n        if (this.editor && !!this.containerClass.length) {\n            this.elementRef.nativeElement.classList.add(...this.containerClass);\n        }\n    }\n\n    private resizeElement() {\n        const editableElement = this.elementRef.nativeElement;\n        // @ts-ignore\n        this.resizeObserver = new ResizeObserver(entries => {\n            for (let entry of entries) {\n                const { width } = entry.contentRect;\n                if (this.isMore && this.elementWidth !== width) {\n                    this.elementWidth = width;\n                    this.renderToolbarView();\n                }\n            }\n        });\n        this.resizeObserver.observe(editableElement);\n    }\n\n    private isTableActive() {\n        const [table] = Editor.nodes(this.editor, { match: n => Element.isElement(n) && n.type === ElementKinds.table });\n        return !!table;\n    }\n\n    public selectionChange(editor: Editor) {\n        if (this.isMore) {\n            this.renderToolbarView();\n        }\n\n        const toolbarItems = [...this.toolbarItems, this.moreGroupMenu];\n        for (const item of toolbarItems) {\n            if (item.key !== ToolbarActionTypes.split) {\n                const itemComponent = this.components.get(item.key);\n                if (itemComponent && itemComponent.instance.selectionChange) {\n                    itemComponent.instance.selectionChange(editor);\n                }\n            }\n        }\n    }\n\n    public renderToolbarView(): void {\n        const toolbarItems = this.toolbarItemsCompose();\n        const { items, group } = toolbarItems;\n\n        if (items.length === this.composeToolbarItems?.items?.length && group?.length === this.composeToolbarItems?.group?.length) {\n            return;\n        }\n        this.composeToolbarItems = toolbarItems;\n        this.components.clear();\n        this.toolbarContainer.clear();\n\n        this.ngZone.run(() => {\n            for (const item of items) {\n                if (item.key === ToolbarActionTypes.split) {\n                    this.createToolbarSplit();\n                    continue;\n                }\n                this.createToolbarItem(item);\n            }\n            this.createMoreGroup(group);\n            this.cdr.markForCheck();\n        });\n    }\n\n    /**\n     * calculation display toolbar and more grouped toolbars\n     *\n     *\t┌────────────────────────────────────────  GlobalToolbarView ───────────────────────────────────┐\n     *\t| ┌─────────────────────────────────────── #children ─────────────────────────────────────────┐ |\n     *\t| |   ┌─────── #itemsView ────────┐ ┌──────────────────────┐ ┌── #groupedItemsDropdown ───┐   | |\n     *\t| |   |       #ungroupedItems     | | ToolbarSeparatorView | |        #groupedItems       |   | |\n     *\t| |   └──────────────────────────-┘ └──────────────────────┘ └────────────────────────────┘   | |\n     *\t| |                                  \\---------- only when toolbar items overflow --------/   | |\n     *\t| └───────────────────────────────────────────────────────────────────────────────────────────┘ |\n     *\t└───────────────────────────────────────────────────────────────────────────────────────────────┘\n     * split width: 13px\n     * item width: default item: 32px; dropdown item: 48px\n     * default paddingRight: 4px\n     * set aside 50px\n     */\n    private toolbarItemsCompose(): ToolbarItemsComposeReturn {\n        let elementWidth = this.isMore ? this.elementWidth : null;\n        // dropdown item + paddingRight\n        const maxItemWidth = 52;\n        // default item + paddingRight\n        const defaultItemWidth = 36;\n        const splitWidth = 13;\n        const items: ToolbarItem[] = [];\n        const group: ToolbarItem[] = [];\n\n        for (let i = 0; i < this.toolbarItems.length; i++) {\n            const item = this.toolbarItems[i];\n            if (!this.isMore) {\n                items.push(item);\n                continue;\n            }\n\n            let itemWidth = defaultItemWidth;\n\n            switch (item.key) {\n                case ElementKinds.headingList:\n                    itemWidth = 74;\n                    break;\n                case ToolbarActionTypes.split:\n                    itemWidth = splitWidth;\n                    break;\n                case ToolbarActionTypes.verticalAlign:\n                    itemWidth = this.isTableActive() ? maxItemWidth : 0;\n                    break;\n                default:\n                    const isCustomComponent = item?.type === ToolbarItemType.dropdown || !!item?.iconComponent;\n                    itemWidth = isCustomComponent ? maxItemWidth : defaultItemWidth;\n            }\n\n            const remainingWidth = i === this.toolbarItems.length - 1 ? itemWidth : itemWidth + splitWidth;\n            const allowRender = elementWidth && elementWidth >= remainingWidth;\n            elementWidth -= itemWidth;\n\n            if (allowRender) {\n                items.push(item);\n            } else {\n                const isFirstSplit = group.length === 0 && item.key === ToolbarActionTypes.split;\n                !isFirstSplit && group.push(item);\n            }\n        }\n\n        return {\n            items: this.pureToolbarItems(items),\n            group\n        };\n    }\n\n    /**\n     * externally designated more group\n     */\n    private toolbarItemsAndMoreCompose() {\n        const items = [];\n        const group = [];\n\n        for (const item of this.toolbarItems) {\n            if (item.key === ToolbarActionTypes.split) {\n                items.push(item);\n                continue;\n            }\n            items.push(item);\n        }\n\n        return {\n            items: this.pureToolbarItems(items),\n            group\n        };\n    }\n\n    /**\n     * filter adjacent repeated dividers\n     * @param {ToolbarItem[]} items\n     * @returns\n     * @memberof TheToolbarComponent\n     */\n    pureToolbarItems(items: ToolbarItem[]) {\n        if (!Array.isArray(items)) {\n            return [];\n        }\n        return items.filter((a, i) => {\n            if (i > 0 && items[i - 1].key !== ToolbarActionTypes.split) {\n                return true;\n            }\n            return a.key !== ToolbarActionTypes.split;\n        });\n    }\n\n    private createToolbarItem(item: ToolbarItem) {\n        const { iconComponent, type, dropdownMode, dropdownItemKey, includes, ...args } = item;\n        const viewComponent = this.viewComponentType(type);\n        const compRef = this.toolbarContainer.createComponent<TheBaseToolbarItem>(iconComponent ? iconComponent : viewComponent);\n\n        compRef.instance.editor = this.editor;\n        compRef.instance.toolbarItem = item;\n        this.components.set(item.key, compRef);\n        if (item.type === ToolbarItemType.dropdown) {\n            const dropdownRef = compRef as unknown as ComponentRef<TheBaseToolbarDropdown>;\n            dropdownRef.instance.dropdownItemKey = item.dropdownItemKey;\n            dropdownRef.instance.menus = includes as ToolbarItem[];\n            dropdownRef.instance.mode = dropdownMode;\n        }\n    }\n\n    private createToolbarSplit() {\n        const compRef = this.toolbarContainer.createComponent(ThyDividerComponent);\n        compRef.instance.thyVertical = true;\n        compRef.instance.thyColor = 'light';\n        compRef.location.nativeElement.classList.add('mx-2');\n    }\n\n    private createMoreGroup(group: ToolbarItem[]) {\n        if (group.length > 0) {\n            const compRef = this.toolbarContainer.createComponent(this.toolbarGroupComponent);\n            compRef.instance.editor = this.editor;\n            compRef.instance.menus = group;\n            compRef.instance.item = this.moreGroupMenu;\n            this.components.set(this.moreGroupMenu.key, compRef);\n        }\n    }\n\n    private viewComponentType(type: ToolbarItemType) {\n        if (type === ToolbarItemType.default) {\n            return TheToolbarItemComponent;\n        }\n        if (type === ToolbarItemType.dropdown) {\n            return TheToolbarDropdownComponent;\n        }\n        return TheToolbarItemComponent;\n    }\n}\n","<ng-container #toolbarContainer></ng-container>\n<ng-content></ng-content>\n<ng-template *ngIf=\"afterTemplate\" [ngTemplateOutlet]=\"afterTemplate\"></ng-template>\n"]}
267
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolbar.component.js","sourceRoot":"","sources":["../../../../../packages/src/components/toolbar/toolbar.component.ts","../../../../../packages/src/components/toolbar/toolbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectorRef,\n    Component,\n    ComponentRef,\n    ElementRef,\n    HostBinding,\n    Inject,\n    Input,\n    NgZone,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    SimpleChanges,\n    TemplateRef,\n    ViewChild,\n    ViewContainerRef\n} from '@angular/core';\nimport { ThyDividerComponent } from 'ngx-tethys/divider';\nimport { Editor, Element } from 'slate';\nimport { ComponentType } from 'slate-angular';\nimport { DropdownMode, ElementKinds, TheToolbarGroupToken, ToolbarActionTypes, ToolbarMoreGroup } from '../../constants';\nimport { TheBaseToolbarDropdown, TheBaseToolbarItem } from '../../core/toolbar-item/base-toolbar-item';\nimport { ToolbarAlignment, ToolbarItem, ToolbarItemType, ToolbarItemsComposeReturn } from '../../interfaces/toolbar';\nimport { TheToolbarDropdownComponent } from '../toolbar-dropdown/toolbar-dropdown.component';\nimport type { TheToolbarGroupComponent } from '../toolbar-group/toolbar-group.component';\nimport { TheToolbarItemComponent } from '../toolbar-item/toolbar-item.component';\n\n@Component({\n    selector: 'the-toolbar',\n    templateUrl: 'toolbar.component.html',\n    host: {\n        class: 'the-toolbar-container d-flex align-items-center'\n    }\n})\nexport class TheToolbarComponent implements OnInit, OnChanges, OnDestroy {\n    @Input() editor: Editor;\n\n    @Input() toolbarItems: ToolbarItem[] = [];\n\n    @Input() align: ToolbarAlignment;\n\n    @Input() containerClass: string[] = [];\n\n    @Input() isMore = true;\n\n    @Input() afterTemplate: TemplateRef<any>;\n\n    @ViewChild('toolbarContainer', { read: ViewContainerRef, static: true }) toolbarContainer: ViewContainerRef;\n\n    @HostBinding('style.justifyContent') get justifyContent() {\n        return this.align;\n    }\n\n    components: Map<string, ComponentRef<any>> = new Map<string, ComponentRef<any>>();\n\n    composeToolbarItems: ToolbarItemsComposeReturn;\n\n    moreGroupMenu = ToolbarMoreGroup;\n\n    resizeObserver: ResizeObserver;\n\n    elementWidth = 0;\n\n    constructor(\n        private cdr: ChangeDetectorRef,\n        private elementRef: ElementRef,\n        private ngZone: NgZone,\n        @Inject(TheToolbarGroupToken) private toolbarGroupComponent: ComponentType<TheToolbarGroupComponent>\n    ) {}\n\n    ngOnInit() {\n        this.setToolbarClass();\n        this.renderToolbarView();\n        this.selectionChange(this.editor);\n        this.isMore && this.resizeElement();\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        const toolbarItems = changes.toolbarItems;\n        if (toolbarItems && !toolbarItems.firstChange) {\n            this.renderToolbarView();\n        }\n    }\n\n    ngOnDestroy(): void {\n        if (this.resizeObserver) {\n            this.resizeObserver.disconnect();\n        }\n    }\n\n    public setToolbarClass() {\n        if (this.editor && !!this.containerClass.length) {\n            this.elementRef.nativeElement.classList.add(...this.containerClass);\n        }\n    }\n\n    private resizeElement() {\n        const editableElement = this.elementRef.nativeElement;\n        // @ts-ignore\n        this.resizeObserver = new ResizeObserver(entries => {\n            for (let entry of entries) {\n                const { width } = entry.contentRect;\n                if (this.isMore && this.elementWidth !== width) {\n                    this.elementWidth = width;\n                    this.renderToolbarView();\n                }\n            }\n        });\n        this.resizeObserver.observe(editableElement);\n    }\n\n    private isTableActive() {\n        const [table] = Editor.nodes(this.editor, { match: n => Element.isElement(n) && n.type === ElementKinds.table });\n        return !!table;\n    }\n\n    public selectionChange(editor: Editor) {\n        if (this.isMore) {\n            this.renderToolbarView();\n        }\n\n        const toolbarItems = [...this.toolbarItems, this.moreGroupMenu];\n        for (const item of toolbarItems) {\n            if (item.key !== ToolbarActionTypes.split) {\n                const itemComponent = this.components.get(item.key);\n                if (itemComponent && itemComponent.instance.selectionChange) {\n                    itemComponent.instance.selectionChange(editor);\n                }\n            }\n        }\n    }\n\n    public renderToolbarView(): void {\n        const toolbarItems = this.toolbarItemsCompose();\n        const { items, group } = toolbarItems;\n\n        if (items.length === this.composeToolbarItems?.items?.length && group?.length === this.composeToolbarItems?.group?.length) {\n            return;\n        }\n        this.composeToolbarItems = toolbarItems;\n        this.components.clear();\n        this.toolbarContainer.clear();\n\n        this.ngZone.run(() => {\n            for (const item of items) {\n                if (item.key === ToolbarActionTypes.split) {\n                    this.createToolbarSplit();\n                    continue;\n                }\n                this.createToolbarItem(item);\n            }\n            this.createMoreGroup(group);\n            this.cdr.markForCheck();\n        });\n    }\n\n    /**\n     * calculation display toolbar and more grouped toolbars\n     *\n     *\t┌────────────────────────────────────────  GlobalToolbarView ───────────────────────────────────┐\n     *\t| ┌─────────────────────────────────────── #children ─────────────────────────────────────────┐ |\n     *\t| |   ┌─────── #itemsView ────────┐ ┌──────────────────────┐ ┌── #groupedItemsDropdown ───┐   | |\n     *\t| |   |       #ungroupedItems     | | ToolbarSeparatorView | |        #groupedItems       |   | |\n     *\t| |   └──────────────────────────-┘ └──────────────────────┘ └────────────────────────────┘   | |\n     *\t| |                                  \\---------- only when toolbar items overflow --------/   | |\n     *\t| └───────────────────────────────────────────────────────────────────────────────────────────┘ |\n     *\t└───────────────────────────────────────────────────────────────────────────────────────────────┘\n     */\n    private toolbarItemsCompose(): ToolbarItemsComposeReturn {\n        const groupWidth = 32;\n        const items: ToolbarItem[] = [];\n        const group: ToolbarItem[] = [];\n        let elementWidth = this.isMore ? this.elementWidth : null;\n        let isSpaceRemaining = true;\n\n        for (let i = 0; i < this.toolbarItems.length; i++) {\n            const item = this.toolbarItems[i];\n            if (!this.isMore) {\n                items.push(item);\n                continue;\n            }\n\n            if (!isSpaceRemaining) {\n                group.push(item);\n                continue;\n            }\n\n            const itemWidth = this.getItemWidth(item);\n            const occupyWidth = i === this.toolbarItems.length - 1 ? itemWidth : itemWidth + groupWidth;\n            const allowRender = elementWidth && elementWidth >= occupyWidth;\n\n            if (allowRender) {\n                items.push(item);\n                elementWidth -= itemWidth;\n            } else {\n                const isFirstSplit = group.length === 0 && item.key === ToolbarActionTypes.split;\n                if (!isFirstSplit) {\n                    isSpaceRemaining = false;\n                    group.push(item);\n                }\n            }\n        }\n\n        return {\n            items: this.pureToolbarItems(items),\n            group\n        };\n    }\n\n    /**\n     * split width: 13px\n     * item width: default item: 32px\n     * dropdown item: 48px\n     * default paddingRight: 4px\n     */\n    private getItemWidth(item: ToolbarItem) {\n        const paddingRight = 4;\n        const defaultItemWidth = 32;\n        const iconDropdownItemWidth = 48;\n        const textDropdownItemWidth = 70;\n        const dropdownActionIconWidth = 16;\n        const splitWidth = 9;\n        const isDropdownComponent = item?.type === ToolbarItemType.dropdown;\n        const isUpdateDropdownItemWidth = !item?.width && isDropdownComponent;\n\n        let itemWidth = item?.width ?? defaultItemWidth;\n\n        if (isUpdateDropdownItemWidth) {\n            if (item?.dropdownMode === DropdownMode.icon) {\n                itemWidth = iconDropdownItemWidth;\n            }\n            if (!item?.dropdownMode || item?.dropdownMode === DropdownMode.text) {\n                itemWidth = textDropdownItemWidth;\n            }\n            if (item?.isHideDropdownActionIcon) {\n                itemWidth -= dropdownActionIconWidth;\n            }\n        }\n        if (item.key === ToolbarActionTypes.split) {\n            itemWidth = splitWidth;\n        }\n\n        itemWidth += paddingRight;\n\n        return itemWidth;\n    }\n\n    /**\n     * filter adjacent repeated dividers\n     * @param {ToolbarItem[]} items\n     * @returns\n     * @memberof TheToolbarComponent\n     */\n    pureToolbarItems(items: ToolbarItem[]) {\n        if (!Array.isArray(items)) {\n            return [];\n        }\n        return items.filter((a, i) => {\n            if (i > 0 && items[i - 1].key !== ToolbarActionTypes.split) {\n                return true;\n            }\n            return a.key !== ToolbarActionTypes.split;\n        });\n    }\n\n    private createToolbarItem(item: ToolbarItem) {\n        const { iconComponent, type, dropdownMode, dropdownItemKey, includes, ...args } = item;\n        const viewComponent = this.viewComponentType(type);\n        const compRef = this.toolbarContainer.createComponent<TheBaseToolbarItem>(iconComponent ? iconComponent : viewComponent);\n\n        compRef.instance.editor = this.editor;\n        compRef.instance.toolbarItem = item;\n        this.components.set(item.key, compRef);\n        if (item.type === ToolbarItemType.dropdown) {\n            const dropdownRef = compRef as unknown as ComponentRef<TheBaseToolbarDropdown>;\n            dropdownRef.instance.dropdownItemKey = item.dropdownItemKey;\n            dropdownRef.instance.menus = includes as ToolbarItem[];\n            dropdownRef.instance.mode = dropdownMode;\n        }\n    }\n\n    private createToolbarSplit() {\n        const compRef = this.toolbarContainer.createComponent(ThyDividerComponent);\n        compRef.instance.thyVertical = true;\n        compRef.instance.thyColor = 'light';\n        compRef.location.nativeElement.classList.add('mx-2');\n    }\n\n    private createMoreGroup(group: ToolbarItem[]) {\n        if (group.length > 0) {\n            const compRef = this.toolbarContainer.createComponent(this.toolbarGroupComponent);\n            compRef.instance.editor = this.editor;\n            compRef.instance.menus = group;\n            compRef.instance.item = this.moreGroupMenu;\n            this.components.set(this.moreGroupMenu.key, compRef);\n        }\n    }\n\n    private viewComponentType(type: ToolbarItemType) {\n        if (type === ToolbarItemType.default) {\n            return TheToolbarItemComponent;\n        }\n        if (type === ToolbarItemType.dropdown) {\n            return TheToolbarDropdownComponent;\n        }\n        return TheToolbarItemComponent;\n    }\n}\n","<ng-container #toolbarContainer></ng-container>\n<ng-content></ng-content>\n<ng-template *ngIf=\"afterTemplate\" [ngTemplateOutlet]=\"afterTemplate\"></ng-template>\n"]}