@worktile/theia 2.1.1 → 2.1.5

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 (77) hide show
  1. package/bundles/worktile-theia.umd.js +505 -210
  2. package/bundles/worktile-theia.umd.js.map +1 -1
  3. package/components/toolbar/toolbar.component.d.ts +1 -0
  4. package/components/toolbar/toolbar.component.scss +2 -0
  5. package/components/toolbar-dropdown/toolbar-dropdown.component.d.ts +7 -5
  6. package/components/toolbar-dropdown/toolbar-dropdown.component.scss +2 -0
  7. package/components/toolbar-item/toolbar-item.component.d.ts +3 -0
  8. package/constants/default.d.ts +1 -1
  9. package/constants/node-types.d.ts +19 -3
  10. package/custom-types.d.ts +4 -1
  11. package/editor.module.d.ts +22 -23
  12. package/esm2015/components/toolbar/toolbar.component.js +18 -5
  13. package/esm2015/components/toolbar-dropdown/toolbar-dropdown.component.js +14 -5
  14. package/esm2015/components/toolbar-item/toolbar-item.component.js +20 -6
  15. package/esm2015/constants/auto-format-rules.js +8 -3
  16. package/esm2015/constants/default.js +2 -2
  17. package/esm2015/constants/node-types.js +33 -4
  18. package/esm2015/constants/toolbar.js +5 -5
  19. package/esm2015/custom-types.js +1 -1
  20. package/esm2015/editor.component.js +12 -7
  21. package/esm2015/editor.module.js +8 -8
  22. package/esm2015/interfaces/auto-format.js +1 -1
  23. package/esm2015/interfaces/editor.js +1 -1
  24. package/esm2015/interfaces/element.js +1 -1
  25. package/esm2015/interfaces/toolbar.js +1 -1
  26. package/esm2015/plugins/align/options.js +2 -1
  27. package/esm2015/plugins/autoformat/autoformat.plugin.js +2 -1
  28. package/esm2015/plugins/autoformat/transforms/auto-format-inline.js +27 -14
  29. package/esm2015/plugins/code/code.component.js +26 -10
  30. package/esm2015/plugins/deserializers/deserialize-md.plugin.js +2 -2
  31. package/esm2015/plugins/font-size/font-size.editor.js +81 -0
  32. package/esm2015/plugins/font-size/options.js +20 -6
  33. package/esm2015/plugins/heading/heading.editor.js +13 -2
  34. package/esm2015/plugins/heading/options.js +2 -1
  35. package/esm2015/plugins/index.js +7 -3
  36. package/esm2015/plugins/inline-code/inline-code.component.js +27 -0
  37. package/esm2015/plugins/inline-code/inline-code.editor.js +45 -0
  38. package/esm2015/plugins/inline-code/inline-code.plugin.js +46 -0
  39. package/esm2015/plugins/inline-code/options.js +14 -0
  40. package/esm2015/plugins/link/link.component.js +4 -2
  41. package/esm2015/plugins/list/components/list-item.component.js +69 -1
  42. package/esm2015/plugins/mark/mark.plugin.js +15 -10
  43. package/esm2015/plugins/mark/options.js +1 -9
  44. package/esm2015/plugins/table/table.editor.js +1 -1
  45. package/esm2015/services/context.service.js +9 -1
  46. package/esm2015/services/toolbar.service.js +2 -2
  47. package/esm2015/shortcuts/mark.js +10 -4
  48. package/fesm2015/worktile-theia.js +465 -184
  49. package/fesm2015/worktile-theia.js.map +1 -1
  50. package/interfaces/auto-format.d.ts +1 -1
  51. package/interfaces/editor.d.ts +3 -1
  52. package/interfaces/element.d.ts +1 -1
  53. package/interfaces/toolbar.d.ts +2 -1
  54. package/package.json +1 -1
  55. package/plugins/autoformat/transforms/auto-format-inline.d.ts +3 -1
  56. package/plugins/code/code.component.d.ts +6 -3
  57. package/plugins/code/code.component.scss +17 -1
  58. package/plugins/font-size/font-size.editor.d.ts +10 -0
  59. package/plugins/font-size/options.d.ts +0 -1
  60. package/plugins/font-size/toolbar-item.component.scss +1 -11
  61. package/plugins/heading/heading.editor.d.ts +1 -1
  62. package/plugins/inline-code/inline-code.component.d.ts +14 -0
  63. package/plugins/inline-code/inline-code.component.scss +13 -0
  64. package/plugins/inline-code/inline-code.editor.d.ts +7 -0
  65. package/plugins/inline-code/inline-code.plugin.d.ts +2 -0
  66. package/plugins/inline-code/options.d.ts +2 -0
  67. package/plugins/list/components/list-item.component.d.ts +7 -0
  68. package/plugins/table/table.editor.d.ts +1 -1
  69. package/queries/get-container-blocks.d.ts +1 -1
  70. package/queries/get-selection-marks.d.ts +1 -1
  71. package/services/context.service.d.ts +5 -1
  72. package/styles/editor.scss +32 -1
  73. package/styles/index.scss +1 -0
  74. package/styles/typo.scss +2 -1
  75. package/transforms/set-marks.d.ts +1 -1
  76. package/esm2015/plugins/font-size/toolbar-item.component.js +0 -129
  77. package/plugins/font-size/toolbar-item.component.d.ts +0 -35
@@ -59,6 +59,7 @@ export declare class TheToolbarComponent implements OnInit, OnChanges, OnDestroy
59
59
  private createToolbarSplit;
60
60
  private createMoreGroup;
61
61
  private viewComponentType;
62
+ private getDropdownItem;
62
63
  static ɵfac: i0.ɵɵFactoryDeclaration<TheToolbarComponent, never>;
63
64
  static ɵcmp: i0.ɵɵComponentDeclaration<TheToolbarComponent, "the-toolbar", never, { "editor": "editor"; "toolbarItems": "toolbarItems"; "align": "align"; "containerClass": "containerClass"; "isMore": "isMore"; "afterTemplate": "afterTemplate"; }, {}, never, ["*"]>;
64
65
  }
@@ -30,6 +30,8 @@
30
30
 
31
31
  .the-toolbar-item {
32
32
  padding-right: 5px;
33
+
34
+ @include the-toolbar-disabled();
33
35
  }
34
36
 
35
37
  @include custom-thy-icon-nav();
@@ -3,7 +3,7 @@ import { Overlay } from '@angular/cdk/overlay';
3
3
  import { ThyPopover, ThyPopoverRef } from 'ngx-tethys/popover';
4
4
  import { Editor } from 'slate';
5
5
  import { DropdownMode } from '../../constants/toolbar';
6
- import { DefaultToolbarItem, ToolbarItem } from '../../interfaces/toolbar';
6
+ import { ToolbarItem } from '../../interfaces/toolbar';
7
7
  import { TheToolbarBaseItemComponent } from '../toolbar-base-item/toolbar-base-item.component';
8
8
  import * as i0 from "@angular/core";
9
9
  export declare class TheToolbarDropdownComponent extends TheToolbarBaseItemComponent implements OnInit {
@@ -13,15 +13,16 @@ export declare class TheToolbarDropdownComponent extends TheToolbarBaseItemCompo
13
13
  private overlay;
14
14
  private _item;
15
15
  toolbarItem: ToolbarItem;
16
- menus: DefaultToolbarItem[];
16
+ menus: ToolbarItem[];
17
17
  mode: DropdownMode;
18
- set item(i: DefaultToolbarItem);
19
- get item(): DefaultToolbarItem;
18
+ set item(i: ToolbarItem);
19
+ get item(): ToolbarItem;
20
20
  itemMousedownHandle: (item: ToolbarItem) => void;
21
21
  editor: Editor;
22
22
  template: TemplateRef<any>;
23
23
  dropdownMode: typeof DropdownMode;
24
- activeMenu: DefaultToolbarItem;
24
+ activeMenu: ToolbarItem;
25
+ disabled: boolean;
25
26
  dropdownPopoverRef: ThyPopoverRef<any>;
26
27
  get isOpen(): boolean;
27
28
  iconModeTemplate: TemplateRef<any>;
@@ -29,6 +30,7 @@ export declare class TheToolbarDropdownComponent extends TheToolbarBaseItemCompo
29
30
  dropdownTemplate: TemplateRef<any>;
30
31
  toggleDropdown(event: MouseEvent): void;
31
32
  handleDocumentMouseDown(event: MouseEvent): void;
33
+ get disabledState(): boolean;
32
34
  constructor(elementRef: ElementRef, thyPopover: ThyPopover, viewContainerRef: ViewContainerRef, overlay: Overlay);
33
35
  ngOnInit(): void;
34
36
  statusChange(editor: Editor): void;
@@ -5,6 +5,8 @@
5
5
  position: relative;
6
6
  cursor: pointer;
7
7
 
8
+ @include the-toolbar-disabled();
9
+
8
10
  &.heading-list {
9
11
  width: 70px;
10
12
  padding: 0;
@@ -13,7 +13,10 @@ export declare class TheToolbarItemComponent extends TheToolbarBaseItemComponent
13
13
  itemMode: ToolbarItemMode;
14
14
  ToolbarItemMode: typeof ToolbarItemMode;
15
15
  active: string | boolean;
16
+ disabled: boolean;
16
17
  toolbarContainer: ViewContainerRef;
18
+ toggleDropdown(event: MouseEvent): void;
19
+ get disabledState(): boolean;
17
20
  constructor(ngZone: NgZone, cfr: ComponentFactoryResolver);
18
21
  ngOnInit(): void;
19
22
  statusChange(editor: Editor): void;
@@ -3,10 +3,10 @@ export declare const PICTURE_ACCEPTED_UPLOAD_SIZE = 20;
3
3
  export declare const A_TAG_REL_ATTR = "noopener noreferrer nofollow external ugc";
4
4
  export declare const LINK_DEFAULT_TEXT = "\u94FE\u63A5";
5
5
  export declare const TAB_SPACE = " ";
6
- export declare const ZERO_WIDTH_CHAR = "\u200B";
7
6
  export declare const CLIPBOARD_FORMAT_KEY = "x-theia-fragment";
8
7
  export declare const DEFAULT_SCROLL_CONTAINER = ".the-editable-container";
9
8
  export declare const ELEMENT_UNIQUE_ID = "key";
9
+ export declare const ZERO_WIDTH_CHAR = "\u200B";
10
10
  export declare enum TheMode {
11
11
  fullMode = "full",
12
12
  liteMode = "lite"
@@ -21,7 +21,8 @@ export declare enum ElementKinds {
21
21
  blockquote = "block-quote",
22
22
  hr = "hr",
23
23
  link = "link",
24
- default = "paragraph"
24
+ default = "paragraph",
25
+ inlineCode = "inline-code"
25
26
  }
26
27
  export declare enum Alignment {
27
28
  left = "left",
@@ -33,6 +34,21 @@ export declare enum VerticalAlignment {
33
34
  middle = "middle",
34
35
  bottom = "bottom"
35
36
  }
37
+ export declare enum FontSizes {
38
+ 'fontSize12' = "12",
39
+ 'fontSize13' = "13",
40
+ 'fontSize14' = "14",
41
+ 'fontSize15' = "15",
42
+ 'fontSize16' = "16",
43
+ 'fontSize18' = "18",
44
+ 'fontSize20' = "20",
45
+ 'fontSize24' = "24",
46
+ 'fontSize28' = "28",
47
+ 'fontSize32' = "32",
48
+ 'fontSize40' = "40",
49
+ 'fontSize48' = "48"
50
+ }
51
+ export declare const FontSizeTypes: FontSizes[];
36
52
  export declare enum MarkTypes {
37
53
  bold = "bold",
38
54
  italic = "italic",
@@ -40,8 +56,8 @@ export declare enum MarkTypes {
40
56
  strike = "strike",
41
57
  color = "color",
42
58
  backgroundColor = "background-color",
43
- codeLine = "code-line",
44
- fontSize = "font-size"
59
+ fontSize = "font-size",
60
+ codeLine = "code-line"
45
61
  }
46
62
  export declare enum ToolbarActionTypes {
47
63
  split = "split",
package/custom-types.d.ts CHANGED
@@ -105,7 +105,10 @@ export interface EditableVoidElement {
105
105
  type: 'editable-void';
106
106
  children: EmptyText[];
107
107
  }
108
- export declare type CustomElement = BlockQuoteElement | NumberedListElement | BulletedListElement | TodoItemElement | HeadingOneElement | HeadingTwoElement | HeadingThreeElement | HeadingFourElement | HeadingFiveElement | HeadingSixElement | ImageElement | LinkElement | ListItemElement | ParagraphElement | TableElement | TableRowElement | TableCellElement | HrElement | CodeElement;
108
+ export interface InlineCodeElement extends TheElement {
109
+ type: ElementKinds.inlineCode;
110
+ }
111
+ export declare type CustomElement = BlockQuoteElement | NumberedListElement | BulletedListElement | TodoItemElement | HeadingOneElement | HeadingTwoElement | HeadingThreeElement | HeadingFourElement | HeadingFiveElement | HeadingSixElement | ImageElement | LinkElement | ListItemElement | ParagraphElement | TableElement | TableRowElement | TableCellElement | HrElement | InlineCodeElement | CodeElement;
109
112
  export declare type CustomText = {
110
113
  bold?: boolean;
111
114
  italic?: boolean;
@@ -6,7 +6,7 @@ import { TheToolbarDropdownComponent } from './components/toolbar-dropdown/toolb
6
6
  import { TheToolbarItemComponent } from './components/toolbar-item/toolbar-item.component';
7
7
  import { NavSplitLineComponent } from './components/nav-split-line/nav-split-line.component';
8
8
  import { TheTemplateComponent } from './components/template/template.component';
9
- import { TheListItemComponent } from './plugins/list/components/list-item.component';
9
+ import { TheBlockquoteComponent } from './plugins/blockquote/blockquote.component';
10
10
  import { TheBulletedListComponent } from './plugins/list/components/bulleted-list.component';
11
11
  import { TheNumberedListComponent } from './plugins/list/components/numbered-list.component';
12
12
  import { TheColorSelectComponent } from './components/color-select/color-select.component';
@@ -29,7 +29,6 @@ import { TheInlineToolbarComponent } from './components/inline-toolbar/inline-to
29
29
  import { TheQuickToolbarComponent } from './plugins/quick-insert/components/quick-toolbar/quick-toolbar.component';
30
30
  import { TheQuickInsertComponent } from './plugins/quick-insert/components/quick-insert.component';
31
31
  import { ThePlaceholderComponent } from './plugins/placeholder/placeholder.component';
32
- import { TheFontSizeToolbarItemComponent } from './plugins/font-size/toolbar-item.component';
33
32
  import * as i0 from "@angular/core";
34
33
  import * as i1 from "./editor.component";
35
34
  import * as i2 from "./pipes";
@@ -51,24 +50,24 @@ import * as i17 from "./components/table-select/table-select.component";
51
50
  import * as i18 from "./plugins/table/toolbar-item.component";
52
51
  import * as i19 from "./components/conversion-hint/conversion-hint.component";
53
52
  import * as i20 from "./plugins/vertical-align/toolbar-item.component";
54
- import * as i21 from "./plugins/font-size/toolbar-item.component";
55
- import * as i22 from "./plugins/image/image.component";
56
- import * as i23 from "./components/template/template.component";
57
- import * as i24 from "./plugins/hr/hr.component";
58
- import * as i25 from "./plugins/blockquote/blockquote.component";
59
- import * as i26 from "./plugins/todo-item/todo-item.component";
60
- import * as i27 from "./plugins/list/components/list-item.component";
61
- import * as i28 from "./plugins/list/components/bulleted-list.component";
62
- import * as i29 from "./plugins/list/components/numbered-list.component";
63
- import * as i30 from "./plugins/code/code.component";
64
- import * as i31 from "./plugins/link/link.component";
65
- import * as i32 from "./plugins/link/edit/link-edit.component";
66
- import * as i33 from "./plugins/link/hover/link-hover.component";
67
- import * as i34 from "./plugins/table/components/toolbar/table-toolbar.component";
68
- import * as i35 from "./plugins/table/components/table.component";
69
- import * as i36 from "./plugins/table/components/row/row.component";
70
- import * as i37 from "./plugins/table/components/td/td.component";
71
- import * as i38 from "./plugins/placeholder/placeholder.component";
53
+ import * as i21 from "./plugins/image/image.component";
54
+ import * as i22 from "./components/template/template.component";
55
+ import * as i23 from "./plugins/hr/hr.component";
56
+ import * as i24 from "./plugins/blockquote/blockquote.component";
57
+ import * as i25 from "./plugins/todo-item/todo-item.component";
58
+ import * as i26 from "./plugins/list/components/list-item.component";
59
+ import * as i27 from "./plugins/list/components/bulleted-list.component";
60
+ import * as i28 from "./plugins/list/components/numbered-list.component";
61
+ import * as i29 from "./plugins/code/code.component";
62
+ import * as i30 from "./plugins/link/link.component";
63
+ import * as i31 from "./plugins/link/edit/link-edit.component";
64
+ import * as i32 from "./plugins/link/hover/link-hover.component";
65
+ import * as i33 from "./plugins/table/components/toolbar/table-toolbar.component";
66
+ import * as i34 from "./plugins/table/components/table.component";
67
+ import * as i35 from "./plugins/table/components/row/row.component";
68
+ import * as i36 from "./plugins/table/components/td/td.component";
69
+ import * as i37 from "./plugins/placeholder/placeholder.component";
70
+ import * as i38 from "./plugins/inline-code/inline-code.component";
72
71
  import * as i39 from "@angular/common";
73
72
  import * as i40 from "slate-angular";
74
73
  import * as i41 from "@angular/forms";
@@ -91,10 +90,10 @@ import * as i57 from "ngx-tethys/resizable";
91
90
  import * as i58 from "ngx-tethys/switch";
92
91
  import * as i59 from "ng-codemirror";
93
92
  import * as i60 from "./components/column-resize/column-resize.module";
94
- export declare const COMPONENTS: (typeof TheColorSelectComponent | typeof TheContextMenuComponent | typeof TheToolbarGroupComponent | typeof TheTextComponent | typeof TheDefaultElementComponent | typeof TheConversionHintComponent | typeof TheColorToolbarItemComponent | typeof TheTableSelectComponent | typeof TheTableToolbarItemComponent | typeof TheVerticalToolbarItemComponent | typeof TheQuickToolbarComponent | typeof TheFontSizeToolbarItemComponent | typeof TheToolbarItemComponent | typeof NavSplitLineComponent | typeof TheToolbarDropdownComponent | typeof TheToolbarComponent | typeof TheQuickInsertComponent | typeof TheInsertMarkComponent | typeof TheInlineToolbarComponent)[];
95
- export declare const PLUGIN_COMPONENTS: (typeof TheTableToolbarComponent | typeof TheTableComponent | typeof TheImageComponent | typeof TheNumberedListComponent | typeof TheBulletedListComponent | typeof TheListItemComponent | typeof TheCodeComponent | typeof TheLinkHoverComponent | typeof TheLinkEditComponent | typeof TheLinkComponent | typeof TheTdComponent | typeof TheTemplateComponent | typeof ThePlaceholderComponent)[];
93
+ export declare const COMPONENTS: (typeof TheColorSelectComponent | typeof TheContextMenuComponent | typeof TheToolbarGroupComponent | typeof TheTextComponent | typeof TheDefaultElementComponent | typeof TheConversionHintComponent | typeof TheColorToolbarItemComponent | typeof TheTableSelectComponent | typeof TheTableToolbarItemComponent | typeof TheVerticalToolbarItemComponent | typeof TheQuickToolbarComponent | typeof TheToolbarItemComponent | typeof NavSplitLineComponent | typeof TheToolbarDropdownComponent | typeof TheToolbarComponent | typeof TheQuickInsertComponent | typeof TheInsertMarkComponent | typeof TheInlineToolbarComponent)[];
94
+ export declare const PLUGIN_COMPONENTS: (typeof TheTableToolbarComponent | typeof TheTableComponent | typeof TheImageComponent | typeof TheNumberedListComponent | typeof TheBulletedListComponent | typeof TheBlockquoteComponent | typeof TheCodeComponent | typeof TheLinkHoverComponent | typeof TheLinkEditComponent | typeof TheLinkComponent | typeof TheTdComponent | typeof TheTemplateComponent | typeof ThePlaceholderComponent)[];
96
95
  export declare class TheEditorModule {
97
96
  static ɵfac: i0.ɵɵFactoryDeclaration<TheEditorModule, never>;
98
- static ɵmod: i0.ɵɵNgModuleDeclaration<TheEditorModule, [typeof i1.TheEditorComponent, typeof i2.ElementStylePipe, typeof i2.ElementClassPipe, typeof i3.TheToolbarComponent, typeof i4.TheToolbarDropdownComponent, typeof i5.TheToolbarGroupComponent, typeof i6.TheToolbarItemComponent, typeof i7.TheInlineToolbarComponent, typeof i8.NavSplitLineComponent, typeof i9.TheTextComponent, typeof i10.TheDefaultElementComponent, typeof i11.TheQuickInsertComponent, typeof i12.TheQuickToolbarComponent, typeof i13.TheColorSelectComponent, typeof i14.TheColorToolbarItemComponent, typeof i15.TheContextMenuComponent, typeof i16.TheInsertMarkComponent, typeof i17.TheTableSelectComponent, typeof i18.TheTableToolbarItemComponent, typeof i19.TheConversionHintComponent, typeof i20.TheVerticalToolbarItemComponent, typeof i21.TheFontSizeToolbarItemComponent, typeof i22.TheImageComponent, typeof i23.TheTemplateComponent, typeof i24.TheHrComponent, typeof i25.TheBlockquoteComponent, typeof i26.TheTodoItemComponent, typeof i27.TheListItemComponent, typeof i28.TheBulletedListComponent, typeof i29.TheNumberedListComponent, typeof i30.TheCodeComponent, typeof i31.TheLinkComponent, typeof i31.TheReadonlyLinkComponent, typeof i32.TheLinkEditComponent, typeof i33.TheLinkHoverComponent, typeof i34.TheTableToolbarComponent, typeof i35.TheTableComponent, typeof i36.TheTableRowComponent, typeof i37.TheTdComponent, typeof i38.ThePlaceholderComponent], [typeof i39.CommonModule, typeof i40.SlateModule, typeof i41.FormsModule, typeof i42.ThyIconModule, typeof i43.ThyAvatarModule, typeof i44.ThyNavModule, typeof i45.ThyFormModule, typeof i46.ThySharedModule, typeof i47.ThyListModule, typeof i48.ThyTooltipModule, typeof i49.ThyProgressModule, typeof i50.ThyAutocompleteModule, typeof i51.ThyActionMenuModule, typeof i52.ThyInputModule, typeof i53.ThySelectModule, typeof i54.ThyButtonModule, typeof i55.ThyNotifyModule, typeof i56.ThyAlertModule, typeof i57.ThyResizableModule, typeof i58.ThySwitchModule, typeof i59.CodemirrorModule, typeof i60.TheColumnSizeModule], [typeof i1.TheEditorComponent, typeof i3.TheToolbarComponent, typeof i4.TheToolbarDropdownComponent, typeof i6.TheToolbarItemComponent, typeof i10.TheDefaultElementComponent]>;
97
+ static ɵmod: i0.ɵɵNgModuleDeclaration<TheEditorModule, [typeof i1.TheEditorComponent, typeof i2.ElementStylePipe, typeof i2.ElementClassPipe, typeof i3.TheToolbarComponent, typeof i4.TheToolbarDropdownComponent, typeof i5.TheToolbarGroupComponent, typeof i6.TheToolbarItemComponent, typeof i7.TheInlineToolbarComponent, typeof i8.NavSplitLineComponent, typeof i9.TheTextComponent, typeof i10.TheDefaultElementComponent, typeof i11.TheQuickInsertComponent, typeof i12.TheQuickToolbarComponent, typeof i13.TheColorSelectComponent, typeof i14.TheColorToolbarItemComponent, typeof i15.TheContextMenuComponent, typeof i16.TheInsertMarkComponent, typeof i17.TheTableSelectComponent, typeof i18.TheTableToolbarItemComponent, typeof i19.TheConversionHintComponent, typeof i20.TheVerticalToolbarItemComponent, typeof i21.TheImageComponent, typeof i22.TheTemplateComponent, typeof i23.TheHrComponent, typeof i24.TheBlockquoteComponent, typeof i25.TheTodoItemComponent, typeof i26.TheListItemComponent, typeof i27.TheBulletedListComponent, typeof i28.TheNumberedListComponent, typeof i29.TheCodeComponent, typeof i30.TheLinkComponent, typeof i30.TheReadonlyLinkComponent, typeof i31.TheLinkEditComponent, typeof i32.TheLinkHoverComponent, typeof i33.TheTableToolbarComponent, typeof i34.TheTableComponent, typeof i35.TheTableRowComponent, typeof i36.TheTdComponent, typeof i37.ThePlaceholderComponent, typeof i38.TheInlineCodeComponent], [typeof i39.CommonModule, typeof i40.SlateModule, typeof i41.FormsModule, typeof i42.ThyIconModule, typeof i43.ThyAvatarModule, typeof i44.ThyNavModule, typeof i45.ThyFormModule, typeof i46.ThySharedModule, typeof i47.ThyListModule, typeof i48.ThyTooltipModule, typeof i49.ThyProgressModule, typeof i50.ThyAutocompleteModule, typeof i51.ThyActionMenuModule, typeof i52.ThyInputModule, typeof i53.ThySelectModule, typeof i54.ThyButtonModule, typeof i55.ThyNotifyModule, typeof i56.ThyAlertModule, typeof i57.ThyResizableModule, typeof i58.ThySwitchModule, typeof i59.CodemirrorModule, typeof i60.TheColumnSizeModule], [typeof i1.TheEditorComponent, typeof i3.TheToolbarComponent, typeof i4.TheToolbarDropdownComponent, typeof i6.TheToolbarItemComponent, typeof i10.TheDefaultElementComponent]>;
99
98
  static ɵinj: i0.ɵɵInjectorDeclaration<TheEditorModule>;
100
99
  }
@@ -2,10 +2,11 @@ import { __rest } from "tslib";
2
2
  import { Component, Input, ViewChild, ViewContainerRef, Inject } from '@angular/core';
3
3
  import { ToolbarItemType } from '../../interfaces/toolbar';
4
4
  import { TheToolbarGroupToken, ToolbarMoreGroup } from '../../constants/toolbar';
5
- import { ElementKinds, ToolbarActionTypes } from '../../constants/node-types';
5
+ import { ElementKinds, MarkTypes, ToolbarActionTypes } from '../../constants/node-types';
6
6
  import { TheToolbarItemComponent } from '../toolbar-item/toolbar-item.component';
7
7
  import { NavSplitLineComponent } from '../nav-split-line/nav-split-line.component';
8
8
  import { TheToolbarDropdownComponent } from '../toolbar-dropdown/toolbar-dropdown.component';
9
+ import { TheContextService } from '../../services/context.service';
9
10
  import * as i0 from "@angular/core";
10
11
  import * as i1 from "ngx-tethys/nav";
11
12
  import * as i2 from "@angular/common";
@@ -177,14 +178,15 @@ export class TheToolbarComponent {
177
178
  });
178
179
  }
179
180
  createToolbarItem(item) {
180
- const { iconComponent, type, dropdownMode } = item, args = __rest(item, ["iconComponent", "type", "dropdownMode"]);
181
+ const { iconComponent, type, dropdownMode, dropdownItemKey, includes } = item, args = __rest(item, ["iconComponent", "type", "dropdownMode", "dropdownItemKey", "includes"]);
181
182
  const viewComponent = this.viewComponentType(type);
183
+ const dropdownItem = this.getDropdownItem(item);
182
184
  const factory = this.cfr.resolveComponentFactory(iconComponent ? iconComponent : viewComponent);
183
185
  const compRef = this.toolbarContainer.createComponent(factory);
184
186
  compRef.instance.editor = this.editor;
185
187
  compRef.instance.toolbarItem = item;
186
- compRef.instance.menus = args.includes;
187
- compRef.instance.item = (args === null || args === void 0 ? void 0 : args.includes) && args.includes.length > 0 ? args.includes[0] : args;
188
+ compRef.instance.menus = includes;
189
+ compRef.instance.item = includes && dropdownItem ? dropdownItem : args;
188
190
  compRef.instance.mode = dropdownMode;
189
191
  this.components.set(item.key, compRef);
190
192
  }
@@ -211,6 +213,17 @@ export class TheToolbarComponent {
211
213
  }
212
214
  return TheToolbarItemComponent;
213
215
  }
216
+ getDropdownItem(item) {
217
+ var _a;
218
+ let dropdownKey = item === null || item === void 0 ? void 0 : item.dropdownItemKey;
219
+ // modify the fontsize option externally
220
+ const contextService = this.editor.injector.get(TheContextService);
221
+ const fontSize = contextService.getDefaultFontSize();
222
+ if (item.key === MarkTypes.fontSize && fontSize) {
223
+ dropdownKey = fontSize;
224
+ }
225
+ return (_a = item === null || item === void 0 ? void 0 : item.includes) === null || _a === void 0 ? void 0 : _a.find((item) => item.key === dropdownKey);
226
+ }
214
227
  }
215
228
  TheToolbarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.7", ngImport: i0, type: TheToolbarComponent, deps: [{ token: i0.ComponentFactoryResolver }, { token: i0.ElementRef }, { token: i0.NgZone }, { token: TheToolbarGroupToken }], target: i0.ɵɵFactoryTarget.Component });
216
229
  TheToolbarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.7", type: TheToolbarComponent, selector: "the-toolbar", inputs: { editor: "editor", toolbarItems: "toolbarItems", align: "align", containerClass: "containerClass", isMore: "isMore", afterTemplate: "afterTemplate" }, host: { classAttribute: "the-toolbar-container" }, viewQueries: [{ propertyName: "toolbarContainer", first: true, predicate: ["toolbarContainer"], descendants: true, read: ViewContainerRef, static: true }], usesOnChanges: true, ngImport: i0, template: "<thy-icon-nav [style.justifyContent]=\"align\">\n <ng-container #toolbarContainer></ng-container>\n <ng-content></ng-content>\n <ng-template *ngIf=\"afterTemplate\" [ngTemplateOutlet]=\"afterTemplate\"></ng-template>\n</thy-icon-nav>\n", components: [{ type: i1.ThyIconNavComponent, selector: "thy-icon-nav", inputs: ["thyType"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }] });
@@ -242,4 +255,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.7", ngImpor
242
255
  type: ViewChild,
243
256
  args: ['toolbarContainer', { read: ViewContainerRef, static: true }]
244
257
  }] } });
245
- //# 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    Component,\n    Input,\n    OnInit,\n    ViewChild,\n    ViewContainerRef,\n    ComponentFactoryResolver,\n    OnChanges,\n    SimpleChanges,\n    ComponentRef,\n    ElementRef,\n    OnDestroy,\n    NgZone,\n    Inject,\n    TemplateRef\n} from '@angular/core';\nimport { Editor } from 'slate';\nimport { ComponentType } from 'slate-angular';\nimport { ToolbarAlignment, ToolbarItem, ToolbarItemsComposeReturn, ToolbarItemType } from '../../interfaces/toolbar';\nimport { TheToolbarGroupToken, ToolbarMoreGroup } from '../../constants/toolbar';\nimport { ElementKinds, ToolbarActionTypes } from '../../constants/node-types';\nimport { TheToolbarItemComponent } from '../toolbar-item/toolbar-item.component';\nimport { NavSplitLineComponent } from '../nav-split-line/nav-split-line.component';\nimport { TheToolbarDropdownComponent } from '../toolbar-dropdown/toolbar-dropdown.component';\nimport type { TheToolbarGroupComponent } from '../toolbar-group/toolbar-group.component';\n\n@Component({\n    selector: 'the-toolbar',\n    templateUrl: 'toolbar.component.html',\n    host: {\n        class: 'the-toolbar-container'\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    components: Map<string, ComponentRef<any>> = new Map<string, ComponentRef<any>>();\n    moreGroupMenu = ToolbarMoreGroup;\n    resizeObserver;\n    elementWidth = 0;\n\n    constructor(\n        private cfr: ComponentFactoryResolver,\n        private elementRef: ElementRef,\n        private ngZone: NgZone,\n        @Inject(TheToolbarGroupToken) private toolbarGroupComponent: ComponentType<TheToolbarGroupComponent>\n    ) {}\n\n    ngOnInit(): void {\n        this.setToolbarClass();\n        this.renderToolbarView();\n        this.statusChange(this.editor);\n\n        if (this.isMore) {\n            this.resizeElement();\n        }\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    public statusChange(editor: Editor) {\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) {\n                    itemComponent.instance.statusChange(editor);\n                }\n            }\n        }\n    }\n\n    public renderToolbarView(): void {\n        this.components.clear();\n        this.toolbarContainer.clear();\n        const toolbarItems = this.toolbarItemsCompose();\n        const { items, group } = toolbarItems;\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        });\n    }\n\n    /**\n     * calculation display toolbar and more grouped toolbars\n     *\n     *\t┌──────────────────────────────────────── GoolbarToolbarView ───────────────────────────────────┐\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: 6px\n     * item width: default item: 35px; dropdown item: 50px\n     * set aside 50px\n     */\n    private toolbarItemsCompose(): ToolbarItemsComposeReturn {\n        let elementWidth = this.isMore ? this.elementWidth : null;\n        const maxItemWidth = 50;\n        const defaultItemWidth = 35;\n        const splitWidth = 6;\n        // special type\n        const headingWidth = 70;\n        const items: ToolbarItem[] = [];\n        const group: ToolbarItem[] = [];\n\n        for (const item of this.toolbarItems) {\n            if (!this.isMore) {\n                items.push(item);\n                continue;\n            }\n\n            // not enough free space\n            const allowRender = elementWidth && elementWidth > maxItemWidth;\n            if (allowRender && item.key === ToolbarActionTypes.split) {\n                items.push(item);\n                elementWidth -= splitWidth;\n                continue;\n            }\n\n            if (allowRender) {\n                items.push(item);\n            } else {\n                group.push(item);\n            }\n\n            if (item.key === ElementKinds.headingList) {\n                elementWidth -= headingWidth;\n                continue;\n            }\n            const isCustomComponent = item?.type === ToolbarItemType.toolDropdown || !!item?.iconComponent;\n            elementWidth -= isCustomComponent ? maxItemWidth : defaultItemWidth;\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, ...args } = item;\n        const viewComponent = this.viewComponentType(type);\n        const factory = this.cfr.resolveComponentFactory(iconComponent ? iconComponent : viewComponent);\n        const compRef = this.toolbarContainer.createComponent(factory);\n        compRef.instance.editor = this.editor;\n        compRef.instance.toolbarItem = item;\n        compRef.instance.menus = args.includes;\n        compRef.instance.item = args?.includes && args.includes.length > 0 ? args.includes[0] : args;\n        compRef.instance.mode = dropdownMode;\n        this.components.set(item.key, compRef);\n    }\n\n    private createToolbarSplit() {\n        const navSplitLineFactory = this.cfr.resolveComponentFactory(NavSplitLineComponent);\n        this.toolbarContainer.createComponent(navSplitLineFactory);\n    }\n\n    private createMoreGroup(group: ToolbarItem[]) {\n        if (group.length > 0) {\n            const moreGroupFactory = this.cfr.resolveComponentFactory(this.toolbarGroupComponent);\n            const compRef = this.toolbarContainer.createComponent(moreGroupFactory);\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.toolDropdown) {\n            return TheToolbarDropdownComponent;\n        }\n        return TheToolbarItemComponent;\n    }\n}\n","<thy-icon-nav [style.justifyContent]=\"align\">\n    <ng-container #toolbarContainer></ng-container>\n    <ng-content></ng-content>\n    <ng-template *ngIf=\"afterTemplate\" [ngTemplateOutlet]=\"afterTemplate\"></ng-template>\n</thy-icon-nav>\n"]}
258
+ //# 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    Component,\n    Input,\n    OnInit,\n    ViewChild,\n    ViewContainerRef,\n    ComponentFactoryResolver,\n    OnChanges,\n    SimpleChanges,\n    ComponentRef,\n    ElementRef,\n    OnDestroy,\n    NgZone,\n    Inject,\n    TemplateRef\n} from '@angular/core';\nimport { Editor } from 'slate';\nimport { ComponentType } from 'slate-angular';\nimport { ToolbarAlignment, ToolbarItem, ToolbarItemsComposeReturn, ToolbarItemType, ToolbarKey } from '../../interfaces/toolbar';\nimport { TheToolbarGroupToken, ToolbarMoreGroup } from '../../constants/toolbar';\nimport { ElementKinds, MarkTypes, ToolbarActionTypes } from '../../constants/node-types';\nimport { TheToolbarItemComponent } from '../toolbar-item/toolbar-item.component';\nimport { NavSplitLineComponent } from '../nav-split-line/nav-split-line.component';\nimport { TheToolbarDropdownComponent } from '../toolbar-dropdown/toolbar-dropdown.component';\nimport type { TheToolbarGroupComponent } from '../toolbar-group/toolbar-group.component';\nimport { TheContextService } from '../../services/context.service';\n\n@Component({\n    selector: 'the-toolbar',\n    templateUrl: 'toolbar.component.html',\n    host: {\n        class: 'the-toolbar-container'\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    components: Map<string, ComponentRef<any>> = new Map<string, ComponentRef<any>>();\n    moreGroupMenu = ToolbarMoreGroup;\n    resizeObserver;\n    elementWidth = 0;\n\n    constructor(\n        private cfr: ComponentFactoryResolver,\n        private elementRef: ElementRef,\n        private ngZone: NgZone,\n        @Inject(TheToolbarGroupToken) private toolbarGroupComponent: ComponentType<TheToolbarGroupComponent>\n    ) {}\n\n    ngOnInit(): void {\n        this.setToolbarClass();\n        this.renderToolbarView();\n        this.statusChange(this.editor);\n\n        if (this.isMore) {\n            this.resizeElement();\n        }\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    public statusChange(editor: Editor) {\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) {\n                    itemComponent.instance.statusChange(editor);\n                }\n            }\n        }\n    }\n\n    public renderToolbarView(): void {\n        this.components.clear();\n        this.toolbarContainer.clear();\n        const toolbarItems = this.toolbarItemsCompose();\n        const { items, group } = toolbarItems;\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        });\n    }\n\n    /**\n     * calculation display toolbar and more grouped toolbars\n     *\n     *\t┌──────────────────────────────────────── GoolbarToolbarView ───────────────────────────────────┐\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: 6px\n     * item width: default item: 35px; dropdown item: 50px\n     * set aside 50px\n     */\n    private toolbarItemsCompose(): ToolbarItemsComposeReturn {\n        let elementWidth = this.isMore ? this.elementWidth : null;\n        const maxItemWidth = 50;\n        const defaultItemWidth = 35;\n        const splitWidth = 6;\n        // special type\n        const headingWidth = 70;\n        const items: ToolbarItem[] = [];\n        const group: ToolbarItem[] = [];\n\n        for (const item of this.toolbarItems) {\n            if (!this.isMore) {\n                items.push(item);\n                continue;\n            }\n\n            // not enough free space\n            const allowRender = elementWidth && elementWidth > maxItemWidth;\n            if (allowRender && item.key === ToolbarActionTypes.split) {\n                items.push(item);\n                elementWidth -= splitWidth;\n                continue;\n            }\n\n            if (allowRender) {\n                items.push(item);\n            } else {\n                group.push(item);\n            }\n\n            if (item.key === ElementKinds.headingList) {\n                elementWidth -= headingWidth;\n                continue;\n            }\n            const isCustomComponent = item?.type === ToolbarItemType.toolDropdown || !!item?.iconComponent;\n            elementWidth -= isCustomComponent ? maxItemWidth : defaultItemWidth;\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 dropdownItem = this.getDropdownItem(item);\n        const factory = this.cfr.resolveComponentFactory(iconComponent ? iconComponent : viewComponent);\n        const compRef = this.toolbarContainer.createComponent(factory);\n\n        compRef.instance.editor = this.editor;\n        compRef.instance.toolbarItem = item;\n        compRef.instance.menus = includes;\n        compRef.instance.item = includes && dropdownItem ? dropdownItem : args;\n        compRef.instance.mode = dropdownMode;\n        this.components.set(item.key, compRef);\n    }\n\n    private createToolbarSplit() {\n        const navSplitLineFactory = this.cfr.resolveComponentFactory(NavSplitLineComponent);\n        this.toolbarContainer.createComponent(navSplitLineFactory);\n    }\n\n    private createMoreGroup(group: ToolbarItem[]) {\n        if (group.length > 0) {\n            const moreGroupFactory = this.cfr.resolveComponentFactory(this.toolbarGroupComponent);\n            const compRef = this.toolbarContainer.createComponent(moreGroupFactory);\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.toolDropdown) {\n            return TheToolbarDropdownComponent;\n        }\n        return TheToolbarItemComponent;\n    }\n\n    private getDropdownItem(item: ToolbarItem) {\n        let dropdownKey: ToolbarKey | string = item?.dropdownItemKey;\n        // modify the fontsize option externally\n        const contextService = this.editor.injector.get(TheContextService);\n        const fontSize = contextService.getDefaultFontSize();\n        if (item.key === MarkTypes.fontSize && fontSize) {\n            dropdownKey = fontSize;\n        }\n        return item?.includes?.find((item: ToolbarItem) => item.key === dropdownKey);\n    }\n}\n","<thy-icon-nav [style.justifyContent]=\"align\">\n    <ng-container #toolbarContainer></ng-container>\n    <ng-content></ng-content>\n    <ng-template *ngIf=\"afterTemplate\" [ngTemplateOutlet]=\"afterTemplate\"></ng-template>\n</thy-icon-nav>\n"]}
@@ -1,4 +1,4 @@
1
- import { Component, Input, HostListener, ViewChild } from '@angular/core';
1
+ import { Component, Input, HostListener, ViewChild, HostBinding } from '@angular/core';
2
2
  import { DropdownMode } from '../../constants/toolbar';
3
3
  import { TheToolbarBaseItemComponent } from '../toolbar-base-item/toolbar-base-item.component';
4
4
  import * as i0 from "@angular/core";
@@ -18,6 +18,7 @@ export class TheToolbarDropdownComponent extends TheToolbarBaseItemComponent {
18
18
  this.overlay = overlay;
19
19
  this.mode = DropdownMode.text;
20
20
  this.dropdownMode = DropdownMode;
21
+ this.disabled = false;
21
22
  }
22
23
  set item(i) {
23
24
  this._item = i;
@@ -32,7 +33,7 @@ export class TheToolbarDropdownComponent extends TheToolbarBaseItemComponent {
32
33
  toggleDropdown(event) {
33
34
  var _a;
34
35
  super.execute(event);
35
- if ((_a = this.editor) === null || _a === void 0 ? void 0 : _a.disabled) {
36
+ if (((_a = this.editor) === null || _a === void 0 ? void 0 : _a.disabled) || this.disabled) {
36
37
  return;
37
38
  }
38
39
  this.openDropdownPopover();
@@ -42,6 +43,9 @@ export class TheToolbarDropdownComponent extends TheToolbarBaseItemComponent {
42
43
  this.closeDropdownPopover();
43
44
  }
44
45
  }
46
+ get disabledState() {
47
+ return this.disabled;
48
+ }
45
49
  ngOnInit() {
46
50
  var _a;
47
51
  if (!this.template) {
@@ -55,12 +59,14 @@ export class TheToolbarDropdownComponent extends TheToolbarBaseItemComponent {
55
59
  }
56
60
  }
57
61
  statusChange(editor) {
62
+ var _a, _b;
63
+ this.disabled = ((_a = this.toolbarItem) === null || _a === void 0 ? void 0 : _a.disable) ? (_b = this.toolbarItem) === null || _b === void 0 ? void 0 : _b.disable(editor) : false;
58
64
  const activeItem = this.menus.find(i => {
59
65
  if (i === null || i === void 0 ? void 0 : i.active) {
60
66
  return i === null || i === void 0 ? void 0 : i.active(editor);
61
67
  }
62
68
  });
63
- this.activeMenu = activeItem ? activeItem : this.menus[0];
69
+ this.activeMenu = activeItem ? activeItem : this.item;
64
70
  }
65
71
  itemMousedown(event, item) {
66
72
  super.execute(event);
@@ -114,7 +120,7 @@ export class TheToolbarDropdownComponent extends TheToolbarBaseItemComponent {
114
120
  }
115
121
  }
116
122
  TheToolbarDropdownComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.7", ngImport: i0, type: TheToolbarDropdownComponent, deps: [{ token: i0.ElementRef }, { token: i1.ThyPopover }, { token: i0.ViewContainerRef }, { token: i2.Overlay }], target: i0.ɵɵFactoryTarget.Component });
117
- TheToolbarDropdownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.7", type: TheToolbarDropdownComponent, selector: "the-toolbar-dropdown", inputs: { toolbarItem: "toolbarItem", menus: "menus", mode: "mode", item: "item", itemMousedownHandle: "itemMousedownHandle" }, host: { listeners: { "mousedown": "toggleDropdown($event)", "document: mousedown": "handleDocumentMouseDown($event)" }, classAttribute: "the-toolbar-dropdown-container" }, viewQueries: [{ propertyName: "iconModeTemplate", first: true, predicate: ["iconModeTemplate"], descendants: true, static: true }, { propertyName: "textModeTemplate", first: true, predicate: ["textModeTemplate"], descendants: true, static: true }, { propertyName: "dropdownTemplate", first: true, predicate: ["dropdownTemplate"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<ng-template [ngTemplateOutlet]=\"template\"></ng-template>\n\n<ng-template #iconModeTemplate>\n <a thyIconNavLink class=\"icon-mode link-with-down\" [thyTooltip]=\"activeMenu?.name\" thyTooltipPlacement=\"top\">\n <thy-icon [thyIconName]=\"activeMenu?.icon\"></thy-icon>\n <thy-icon class=\"caret-down-icon font-size-sm text-desc\" thyIconName=\"caret-down\"></thy-icon>\n </a>\n</ng-template>\n\n<ng-template #textModeTemplate>\n <a thyIconNavLink class=\"text-mode\" [thyTooltip]=\"activeMenu?.name\" thyTooltipPlacement=\"top\">\n <span class=\"show-text\">{{ activeMenu?.name }}</span>\n <thy-icon class=\"text-caret-down-icon font-size-sm text-desc\" thyIconName=\"caret-down\"></thy-icon>\n </a>\n</ng-template>\n\n<ng-template #dropdownTemplate>\n <thy-action-menu class=\"dropdown\">\n <ng-container *ngFor=\"let menu of menus\">\n <a\n *ngIf=\"menu.key !== 'split'\"\n thyActionMenuItem\n href=\"javascript:;\"\n [thyActionMenuItemActive]=\"menu.key === activeMenu.key\"\n (mousedown)=\"itemMousedown($event, menu)\"\n [ngStyle]=\"menu?.styles\"\n >\n <span *ngIf=\"menu.icon && mode === dropdownMode.icon\" thyActionMenuItemIcon>\n <thy-icon [thyIconName]=\"menu.icon\"></thy-icon>\n </span>\n <span *ngIf=\"menu.name\" thyActionMenuItemName>{{ menu.name }}</span>\n </a>\n <thy-action-menu-divider *ngIf=\"menu.key === 'split'\"></thy-action-menu-divider>\n </ng-container>\n </thy-action-menu>\n</ng-template>\n", components: [{ type: i3.ThyIconNavLinkComponent, selector: "[thyIconNavLink]", inputs: ["thyIconNavLinkIcon", "thyIconNavLinkActive"] }, { type: i4.ThyIconComponent, selector: "thy-icon", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { type: i5.ThyActionMenuComponent, selector: "thy-action-menu", inputs: ["thyTheme", "thyWidth"] }, { type: i5.ThyActionMenuDividerComponent, selector: "thy-action-menu-divider", inputs: ["thyTitle", "thyType"] }], directives: [{ type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i7.ThyTooltipDirective, selector: "[thyTooltip],[thy-tooltip]", inputs: ["thyTooltip", "thyTooltipPlacement", "thyTooltipClass", "thyTooltipShowDelay", "thyTooltipHideDelay", "thyTooltipTrigger", "thyTooltipDisabled", "thyTooltipTemplateContext", "thyTooltipOffset", "thyTooltipPin"], exportAs: ["thyTooltip"] }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.ThyActionMenuItemDirective, selector: "[thyActionMenuItem]", inputs: ["thyDisabled", "thyType"] }, { type: i5.ThyActionMenuItemActiveDirective, selector: "[thyActionMenuItemActive]", inputs: ["thyActionMenuItemActive"] }, { type: i6.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i5.ThyActionMenuItemIconDirective, selector: "[thyActionMenuItemIcon]" }, { type: i5.ThyActionMenuItemNameDirective, selector: "[thyActionMenuItemName]" }] });
123
+ TheToolbarDropdownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.7", type: TheToolbarDropdownComponent, selector: "the-toolbar-dropdown", inputs: { toolbarItem: "toolbarItem", menus: "menus", mode: "mode", item: "item", itemMousedownHandle: "itemMousedownHandle" }, host: { listeners: { "mousedown": "toggleDropdown($event)", "document: mousedown": "handleDocumentMouseDown($event)" }, properties: { "class.disabled": "this.disabledState" }, classAttribute: "the-toolbar-dropdown-container" }, viewQueries: [{ propertyName: "iconModeTemplate", first: true, predicate: ["iconModeTemplate"], descendants: true, static: true }, { propertyName: "textModeTemplate", first: true, predicate: ["textModeTemplate"], descendants: true, static: true }, { propertyName: "dropdownTemplate", first: true, predicate: ["dropdownTemplate"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<ng-template [ngTemplateOutlet]=\"template\"></ng-template>\n\n<ng-template #iconModeTemplate>\n <a thyIconNavLink class=\"icon-mode link-with-down\" [thyTooltip]=\"activeMenu?.name\" thyTooltipPlacement=\"top\">\n <thy-icon [thyIconName]=\"activeMenu?.icon\"></thy-icon>\n <thy-icon class=\"caret-down-icon font-size-sm text-desc\" thyIconName=\"caret-down\"></thy-icon>\n </a>\n</ng-template>\n\n<ng-template #textModeTemplate>\n <a thyIconNavLink class=\"text-mode\" [thyTooltip]=\"activeMenu?.name\" thyTooltipPlacement=\"top\">\n <span class=\"show-text\">{{ activeMenu?.name }}</span>\n <thy-icon class=\"text-caret-down-icon font-size-sm text-desc\" thyIconName=\"caret-down\"></thy-icon>\n </a>\n</ng-template>\n\n<ng-template #dropdownTemplate>\n <thy-action-menu class=\"dropdown\">\n <ng-container *ngFor=\"let menu of menus\">\n <a\n *ngIf=\"menu.key !== 'split'\"\n thyActionMenuItem\n href=\"javascript:;\"\n [thyActionMenuItemActive]=\"menu.key === activeMenu.key\"\n (mousedown)=\"itemMousedown($event, menu)\"\n [ngStyle]=\"menu?.styles\"\n >\n <span *ngIf=\"menu.icon && mode === dropdownMode.icon\" thyActionMenuItemIcon>\n <thy-icon [thyIconName]=\"menu.icon\"></thy-icon>\n </span>\n <span *ngIf=\"menu.name\" thyActionMenuItemName>{{ menu.name }}</span>\n </a>\n <thy-action-menu-divider *ngIf=\"menu.key === 'split'\"></thy-action-menu-divider>\n </ng-container>\n </thy-action-menu>\n</ng-template>\n", components: [{ type: i3.ThyIconNavLinkComponent, selector: "[thyIconNavLink]", inputs: ["thyIconNavLinkIcon", "thyIconNavLinkActive"] }, { type: i4.ThyIconComponent, selector: "thy-icon", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { type: i5.ThyActionMenuComponent, selector: "thy-action-menu", inputs: ["thyTheme", "thyWidth"] }, { type: i5.ThyActionMenuDividerComponent, selector: "thy-action-menu-divider", inputs: ["thyTitle", "thyType"] }], directives: [{ type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i7.ThyTooltipDirective, selector: "[thyTooltip],[thy-tooltip]", inputs: ["thyTooltip", "thyTooltipPlacement", "thyTooltipClass", "thyTooltipShowDelay", "thyTooltipHideDelay", "thyTooltipTrigger", "thyTooltipDisabled", "thyTooltipTemplateContext", "thyTooltipOffset", "thyTooltipPin"], exportAs: ["thyTooltip"] }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.ThyActionMenuItemDirective, selector: "[thyActionMenuItem]", inputs: ["thyDisabled", "thyType"] }, { type: i5.ThyActionMenuItemActiveDirective, selector: "[thyActionMenuItemActive]", inputs: ["thyActionMenuItemActive"] }, { type: i6.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i5.ThyActionMenuItemIconDirective, selector: "[thyActionMenuItemIcon]" }, { type: i5.ThyActionMenuItemNameDirective, selector: "[thyActionMenuItemName]" }] });
118
124
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.7", ngImport: i0, type: TheToolbarDropdownComponent, decorators: [{
119
125
  type: Component,
120
126
  args: [{
@@ -149,5 +155,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.7", ngImpor
149
155
  }], handleDocumentMouseDown: [{
150
156
  type: HostListener,
151
157
  args: ['document: mousedown', ['$event']]
158
+ }], disabledState: [{
159
+ type: HostBinding,
160
+ args: ['class.disabled']
152
161
  }] } });
153
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolbar-dropdown.component.js","sourceRoot":"","sources":["../../../../../packages/src/components/toolbar-dropdown/toolbar-dropdown.component.ts","../../../../../packages/src/components/toolbar-dropdown/toolbar-dropdown.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAsB,KAAK,EAAE,YAAY,EAAe,SAAS,EAAoB,MAAM,eAAe,CAAC;AAI7H,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAEvD,OAAO,EAAE,2BAA2B,EAAE,MAAM,kDAAkD,CAAC;;;;;;;;;AAS/F,MAAM,OAAO,2BAA4B,SAAQ,2BAA2B;IAwDxE,YACW,UAAsB,EACrB,UAAsB,EACtB,gBAAkC,EAClC,OAAgB;QAExB,KAAK,EAAE,CAAC;QALD,eAAU,GAAV,UAAU,CAAY;QACrB,eAAU,GAAV,UAAU,CAAY;QACtB,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,YAAO,GAAP,OAAO,CAAS;QArDnB,SAAI,GAAiB,YAAY,CAAC,IAAI,CAAC;QAehD,iBAAY,GAAG,YAAY,CAAC;IAyC5B,CAAC;IAtDD,IACI,IAAI,CAAC,CAAqB;QAC1B,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;QACf,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC;IACxB,CAAC;IACD,IAAI,IAAI;QACJ,OAAO,IAAI,CAAC,KAAK,CAAC;IACtB,CAAC;IAUD,IAAI,MAAM;QACN,OAAO,IAAI,CAAC,kBAAkB,IAAI,IAAI,CAAC,kBAAkB,CAAC,aAAa,EAAE,IAAI,IAAI,CAAC,kBAAkB,CAAC,aAAa,EAAE,CAAC,WAAW,EAAE,CAAC;IACvI,CAAC;IAYD,cAAc,CAAC,KAAiB;;QAC5B,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAErB,IAAI,MAAA,IAAI,CAAC,MAAM,0CAAE,QAAQ,EAAE;YACvB,OAAO;SACV;QACD,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC/B,CAAC;IAGD,uBAAuB,CAAC,KAAiB;QACrC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAqB,CAAC,EAAE;YACtE,IAAI,CAAC,oBAAoB,EAAE,CAAC;SAC/B;IACL,CAAC;IAWD,QAAQ;;QACJ,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAChB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC;SACxG;QAED,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;YAClB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;SACnC;QACD,IAAI,IAAI,CAAC,WAAW,EAAE;YAClB,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,SAAS,CAAC,GAAG,CAAC,GAAG,MAAA,IAAI,CAAC,WAAW,0CAAE,GAAG,EAAE,CAAC,CAAC;SAC3E;IACL,CAAC;IAEM,YAAY,CAAC,MAAc;QAC9B,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE;YACnC,IAAI,CAAC,aAAD,CAAC,uBAAD,CAAC,CAAE,MAAM,EAAE;gBACX,OAAO,CAAC,aAAD,CAAC,uBAAD,CAAC,CAAE,MAAM,CAAC,MAAM,CAAC,CAAC;aAC5B;QACL,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IAC9D,CAAC;IAED,aAAa,CAAC,KAAiB,EAAE,IAAiB;QAC9C,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAErB,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAE5B,IAAI,IAAI,CAAC,mBAAmB,EAAE;YAC1B,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;YAC/B,OAAO;SACV;QAED,IAAI,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,OAAO,EAAE;YACf,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SAC9B;IACL,CAAC;IAED,mBAAmB;;QACf,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE;YAClE,MAAM,EAAE,IAAI,CAAC,UAAU;YACvB,UAAU,EAAE,CAAC,8BAA8B,EAAE,MAAA,IAAI,CAAC,WAAW,0CAAE,GAAG,CAAC;YACnE,SAAS,EAAE,YAAY;YACvB,cAAc,EAAE,KAAK;YACrB,gBAAgB,EAAE,IAAI;YACtB,WAAW,EAAE,KAAK;YAClB,MAAM,EAAE,EAAE;YACV,gBAAgB,EAAE,IAAI,CAAC,gBAAgB;YACvC,cAAc,EAAE,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,UAAU,EAAE;SAC7D,CAAC,CAAC;QACH,MAAA,IAAI,CAAC,kBAAkB,0CAAE,aAAa,GAAG,sBAAsB,CAAC,IAAI,CAAC,sBAAsB,EAAE,CAAC,CAAC;IACnG,CAAC;IAED,oBAAoB;;QAChB,IAAI,IAAI,CAAC,kBAAkB,EAAE;YACzB,MAAA,IAAI,CAAC,kBAAkB,0CAAE,KAAK,EAAE,CAAC;SACpC;IACL,CAAC;IAED,sBAAsB;QAClB,MAAM,WAAW,GAAsB;YACnC,OAAO,EAAE,OAAO;YAChB,OAAO,EAAE,KAAK;YACd,QAAQ,EAAE,OAAO;YACjB,QAAQ,EAAE,QAAQ;YAClB,OAAO,EAAE,CAAC;YACV,OAAO,EAAE,CAAC,EAAE;SACf,CAAC;QACF,MAAM,cAAc,mCACb,WAAW,KACd,QAAQ,EAAE,KAAK,EACf,OAAO,EAAE,EAAE,GACd,CAAC;QACF,OAAO,IAAI,CAAC,OAAO;aACd,QAAQ,EAAE;aACV,mBAAmB,CAAC,IAAI,CAAC,UAAU,CAAC;aACpC,sBAAsB,CAAC,KAAK,CAAC;aAC7B,iBAAiB,CAAC,KAAK,CAAC;aACxB,QAAQ,CAAC,KAAK,CAAC;aACf,aAAa,CAAC,CAAC,cAAc,EAAE,WAAW,CAAC,CAAC,CAAC;IACtD,CAAC;;wHAhJQ,2BAA2B;4GAA3B,2BAA2B,6uBCfxC,opDAoCA;2FDrBa,2BAA2B;kBAPvC,SAAS;mBAAC;oBACP,QAAQ,EAAE,sBAAsB;oBAChC,WAAW,EAAE,mCAAmC;oBAChD,IAAI,EAAE;wBACF,KAAK,EAAE,gCAAgC;qBAC1C;iBACJ;+KAIY,WAAW;sBAAnB,KAAK;gBAEG,KAAK;sBAAb,KAAK;gBAEG,IAAI;sBAAZ,KAAK;gBAGF,IAAI;sBADP,KAAK;gBASG,mBAAmB;sBAA3B,KAAK;gBAaN,gBAAgB;sBADf,SAAS;uBAAC,kBAAkB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAI/C,gBAAgB;sBADf,SAAS;uBAAC,kBAAkB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAI/C,gBAAgB;sBADf,SAAS;uBAAC,kBAAkB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAI/C,cAAc;sBADb,YAAY;uBAAC,WAAW,EAAE,CAAC,QAAQ,CAAC;gBAWrC,uBAAuB;sBADtB,YAAY;uBAAC,qBAAqB,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import { Component, OnInit, ElementRef, Input, HostListener, TemplateRef, ViewChild, ViewContainerRef } from '@angular/core';\nimport { ConnectedPosition, Overlay } from '@angular/cdk/overlay';\nimport { ThyPopover, ThyPopoverRef } from 'ngx-tethys/popover';\nimport { Editor } from 'slate';\nimport { DropdownMode } from '../../constants/toolbar';\nimport { DefaultToolbarItem, ToolbarItem } from '../../interfaces/toolbar';\nimport { TheToolbarBaseItemComponent } from '../toolbar-base-item/toolbar-base-item.component';\n\n@Component({\n    selector: 'the-toolbar-dropdown',\n    templateUrl: './toolbar-dropdown.component.html',\n    host: {\n        class: 'the-toolbar-dropdown-container'\n    }\n})\nexport class TheToolbarDropdownComponent extends TheToolbarBaseItemComponent implements OnInit {\n    private _item: DefaultToolbarItem;\n\n    @Input() toolbarItem: ToolbarItem;\n\n    @Input() menus: DefaultToolbarItem[];\n\n    @Input() mode: DropdownMode = DropdownMode.text;\n\n    @Input()\n    set item(i: DefaultToolbarItem) {\n        this._item = i;\n        this.activeMenu = i;\n    }\n    get item() {\n        return this._item;\n    }\n\n    @Input() itemMousedownHandle: (item: ToolbarItem) => void;\n\n    editor: Editor;\n    template: TemplateRef<any>;\n    dropdownMode = DropdownMode;\n    activeMenu: DefaultToolbarItem;\n    dropdownPopoverRef: ThyPopoverRef<any>;\n\n    get isOpen() {\n        return this.dropdownPopoverRef && this.dropdownPopoverRef.getOverlayRef() && this.dropdownPopoverRef.getOverlayRef().hasAttached();\n    }\n\n    @ViewChild('iconModeTemplate', { static: true })\n    iconModeTemplate: TemplateRef<any>;\n\n    @ViewChild('textModeTemplate', { static: true })\n    textModeTemplate: TemplateRef<any>;\n\n    @ViewChild('dropdownTemplate', { static: true })\n    dropdownTemplate: TemplateRef<any>;\n\n    @HostListener('mousedown', ['$event'])\n    toggleDropdown(event: MouseEvent) {\n        super.execute(event);\n\n        if (this.editor?.disabled) {\n            return;\n        }\n        this.openDropdownPopover();\n    }\n\n    @HostListener('document: mousedown', ['$event'])\n    handleDocumentMouseDown(event: MouseEvent) {\n        if (!this.elementRef.nativeElement.contains(event.target as HTMLElement)) {\n            this.closeDropdownPopover();\n        }\n    }\n\n    constructor(\n        public elementRef: ElementRef,\n        private thyPopover: ThyPopover,\n        private viewContainerRef: ViewContainerRef,\n        private overlay: Overlay\n    ) {\n        super();\n    }\n\n    ngOnInit() {\n        if (!this.template) {\n            this.template = this.mode === this.dropdownMode.icon ? this.iconModeTemplate : this.textModeTemplate;\n        }\n\n        if (!this.activeMenu) {\n            this.activeMenu = this.menus[0];\n        }\n        if (this.toolbarItem) {\n            this.elementRef.nativeElement.classList.add(`${this.toolbarItem?.key}`);\n        }\n    }\n\n    public statusChange(editor: Editor) {\n        const activeItem = this.menus.find(i => {\n            if (i?.active) {\n                return i?.active(editor);\n            }\n        });\n        this.activeMenu = activeItem ? activeItem : this.menus[0];\n    }\n\n    itemMousedown(event: MouseEvent, item: ToolbarItem) {\n        super.execute(event);\n\n        this.closeDropdownPopover();\n\n        if (this.itemMousedownHandle) {\n            this.itemMousedownHandle(item);\n            return;\n        }\n\n        if (item?.execute) {\n            item?.execute(this.editor);\n        }\n    }\n\n    openDropdownPopover() {\n        this.dropdownPopoverRef = this.thyPopover.open(this.dropdownTemplate, {\n            origin: this.elementRef,\n            panelClass: ['the-toolbar-dropdown-popover', this.toolbarItem?.key],\n            placement: 'bottomLeft',\n            insideClosable: false,\n            backdropClosable: true,\n            hasBackdrop: false,\n            offset: 10,\n            viewContainerRef: this.viewContainerRef,\n            scrollStrategy: this.overlay.scrollStrategies.reposition()\n        });\n        this.dropdownPopoverRef?.getOverlayRef().updatePositionStrategy(this.createPositionStrategy());\n    }\n\n    closeDropdownPopover() {\n        if (this.dropdownPopoverRef) {\n            this.dropdownPopoverRef?.close();\n        }\n    }\n\n    createPositionStrategy() {\n        const topPosition: ConnectedPosition = {\n            originX: 'start',\n            originY: 'top',\n            overlayX: 'start',\n            overlayY: 'bottom',\n            offsetX: 0,\n            offsetY: -15\n        };\n        const bottomPosition: ConnectedPosition = {\n            ...topPosition,\n            overlayY: 'top',\n            offsetY: 42\n        };\n        return this.overlay\n            .position()\n            .flexibleConnectedTo(this.elementRef)\n            .withFlexibleDimensions(false)\n            .withGrowAfterOpen(false)\n            .withPush(false)\n            .withPositions([bottomPosition, topPosition]);\n    }\n}\n","<ng-template [ngTemplateOutlet]=\"template\"></ng-template>\n\n<ng-template #iconModeTemplate>\n    <a thyIconNavLink class=\"icon-mode link-with-down\" [thyTooltip]=\"activeMenu?.name\" thyTooltipPlacement=\"top\">\n        <thy-icon [thyIconName]=\"activeMenu?.icon\"></thy-icon>\n        <thy-icon class=\"caret-down-icon font-size-sm text-desc\" thyIconName=\"caret-down\"></thy-icon>\n    </a>\n</ng-template>\n\n<ng-template #textModeTemplate>\n    <a thyIconNavLink class=\"text-mode\" [thyTooltip]=\"activeMenu?.name\" thyTooltipPlacement=\"top\">\n        <span class=\"show-text\">{{ activeMenu?.name }}</span>\n        <thy-icon class=\"text-caret-down-icon font-size-sm text-desc\" thyIconName=\"caret-down\"></thy-icon>\n    </a>\n</ng-template>\n\n<ng-template #dropdownTemplate>\n    <thy-action-menu class=\"dropdown\">\n        <ng-container *ngFor=\"let menu of menus\">\n            <a\n                *ngIf=\"menu.key !== 'split'\"\n                thyActionMenuItem\n                href=\"javascript:;\"\n                [thyActionMenuItemActive]=\"menu.key === activeMenu.key\"\n                (mousedown)=\"itemMousedown($event, menu)\"\n                [ngStyle]=\"menu?.styles\"\n            >\n                <span *ngIf=\"menu.icon && mode === dropdownMode.icon\" thyActionMenuItemIcon>\n                    <thy-icon [thyIconName]=\"menu.icon\"></thy-icon>\n                </span>\n                <span *ngIf=\"menu.name\" thyActionMenuItemName>{{ menu.name }}</span>\n            </a>\n            <thy-action-menu-divider *ngIf=\"menu.key === 'split'\"></thy-action-menu-divider>\n        </ng-container>\n    </thy-action-menu>\n</ng-template>\n"]}
162
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolbar-dropdown.component.js","sourceRoot":"","sources":["../../../../../packages/src/components/toolbar-dropdown/toolbar-dropdown.component.ts","../../../../../packages/src/components/toolbar-dropdown/toolbar-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ElementRef, Input, HostListener, TemplateRef, ViewChild, ViewContainerRef, HostBinding } from '@angular/core';\nimport { ConnectedPosition, Overlay } from '@angular/cdk/overlay';\nimport { ThyPopover, ThyPopoverRef } from 'ngx-tethys/popover';\nimport { Editor } from 'slate';\nimport { DropdownMode } from '../../constants/toolbar';\nimport { ToolbarItem } from '../../interfaces/toolbar';\nimport { TheToolbarBaseItemComponent } from '../toolbar-base-item/toolbar-base-item.component';\n\n@Component({\n    selector: 'the-toolbar-dropdown',\n    templateUrl: './toolbar-dropdown.component.html',\n    host: {\n        class: 'the-toolbar-dropdown-container'\n    }\n})\nexport class TheToolbarDropdownComponent extends TheToolbarBaseItemComponent implements OnInit {\n    private _item: ToolbarItem;\n\n    @Input() toolbarItem: ToolbarItem;\n\n    @Input() menus: ToolbarItem[];\n\n    @Input() mode: DropdownMode = DropdownMode.text;\n\n    @Input()\n    set item(i: ToolbarItem) {\n        this._item = i;\n        this.activeMenu = i;\n    }\n    get item() {\n        return this._item;\n    }\n\n    @Input() itemMousedownHandle: (item: ToolbarItem) => void;\n\n    editor: Editor;\n    template: TemplateRef<any>;\n    dropdownMode = DropdownMode;\n    activeMenu: ToolbarItem;\n    disabled = false;\n    dropdownPopoverRef: ThyPopoverRef<any>;\n\n    get isOpen() {\n        return this.dropdownPopoverRef && this.dropdownPopoverRef.getOverlayRef() && this.dropdownPopoverRef.getOverlayRef().hasAttached();\n    }\n\n    @ViewChild('iconModeTemplate', { static: true })\n    iconModeTemplate: TemplateRef<any>;\n\n    @ViewChild('textModeTemplate', { static: true })\n    textModeTemplate: TemplateRef<any>;\n\n    @ViewChild('dropdownTemplate', { static: true })\n    dropdownTemplate: TemplateRef<any>;\n\n    @HostListener('mousedown', ['$event'])\n    toggleDropdown(event: MouseEvent) {\n        super.execute(event);\n\n        if (this.editor?.disabled || this.disabled) {\n            return;\n        }\n        this.openDropdownPopover();\n    }\n\n    @HostListener('document: mousedown', ['$event'])\n    handleDocumentMouseDown(event: MouseEvent) {\n        if (!this.elementRef.nativeElement.contains(event.target as HTMLElement)) {\n            this.closeDropdownPopover();\n        }\n    }\n\n    @HostBinding('class.disabled') get disabledState() {\n        return this.disabled;\n    }\n\n    constructor(\n        public elementRef: ElementRef,\n        private thyPopover: ThyPopover,\n        private viewContainerRef: ViewContainerRef,\n        private overlay: Overlay\n    ) {\n        super();\n    }\n\n    ngOnInit() {\n        if (!this.template) {\n            this.template = this.mode === this.dropdownMode.icon ? this.iconModeTemplate : this.textModeTemplate;\n        }\n\n        if (!this.activeMenu) {\n            this.activeMenu = this.menus[0];\n        }\n        if (this.toolbarItem) {\n            this.elementRef.nativeElement.classList.add(`${this.toolbarItem?.key}`);\n        }\n    }\n\n    public statusChange(editor: Editor) {\n        this.disabled = this.toolbarItem?.disable ? this.toolbarItem?.disable(editor) : false;\n        const activeItem = this.menus.find(i => {\n            if (i?.active) {\n                return i?.active(editor);\n            }\n        });\n        this.activeMenu = activeItem ? activeItem : this.item;\n    }\n\n    itemMousedown(event: MouseEvent, item: ToolbarItem) {\n        super.execute(event);\n\n        this.closeDropdownPopover();\n\n        if (this.itemMousedownHandle) {\n            this.itemMousedownHandle(item);\n            return;\n        }\n\n        if (item?.execute) {\n            item?.execute(this.editor);\n        }\n    }\n\n    openDropdownPopover() {\n        this.dropdownPopoverRef = this.thyPopover.open(this.dropdownTemplate, {\n            origin: this.elementRef,\n            panelClass: ['the-toolbar-dropdown-popover', this.toolbarItem?.key],\n            placement: 'bottomLeft',\n            insideClosable: false,\n            backdropClosable: true,\n            hasBackdrop: false,\n            offset: 10,\n            viewContainerRef: this.viewContainerRef,\n            scrollStrategy: this.overlay.scrollStrategies.reposition()\n        });\n        this.dropdownPopoverRef?.getOverlayRef().updatePositionStrategy(this.createPositionStrategy());\n    }\n\n    closeDropdownPopover() {\n        if (this.dropdownPopoverRef) {\n            this.dropdownPopoverRef?.close();\n        }\n    }\n\n    createPositionStrategy() {\n        const topPosition: ConnectedPosition = {\n            originX: 'start',\n            originY: 'top',\n            overlayX: 'start',\n            overlayY: 'bottom',\n            offsetX: 0,\n            offsetY: -15\n        };\n        const bottomPosition: ConnectedPosition = {\n            ...topPosition,\n            overlayY: 'top',\n            offsetY: 42\n        };\n        return this.overlay\n            .position()\n            .flexibleConnectedTo(this.elementRef)\n            .withFlexibleDimensions(false)\n            .withGrowAfterOpen(false)\n            .withPush(false)\n            .withPositions([bottomPosition, topPosition]);\n    }\n}\n","<ng-template [ngTemplateOutlet]=\"template\"></ng-template>\n\n<ng-template #iconModeTemplate>\n    <a thyIconNavLink class=\"icon-mode link-with-down\" [thyTooltip]=\"activeMenu?.name\" thyTooltipPlacement=\"top\">\n        <thy-icon [thyIconName]=\"activeMenu?.icon\"></thy-icon>\n        <thy-icon class=\"caret-down-icon font-size-sm text-desc\" thyIconName=\"caret-down\"></thy-icon>\n    </a>\n</ng-template>\n\n<ng-template #textModeTemplate>\n    <a thyIconNavLink class=\"text-mode\" [thyTooltip]=\"activeMenu?.name\" thyTooltipPlacement=\"top\">\n        <span class=\"show-text\">{{ activeMenu?.name }}</span>\n        <thy-icon class=\"text-caret-down-icon font-size-sm text-desc\" thyIconName=\"caret-down\"></thy-icon>\n    </a>\n</ng-template>\n\n<ng-template #dropdownTemplate>\n    <thy-action-menu class=\"dropdown\">\n        <ng-container *ngFor=\"let menu of menus\">\n            <a\n                *ngIf=\"menu.key !== 'split'\"\n                thyActionMenuItem\n                href=\"javascript:;\"\n                [thyActionMenuItemActive]=\"menu.key === activeMenu.key\"\n                (mousedown)=\"itemMousedown($event, menu)\"\n                [ngStyle]=\"menu?.styles\"\n            >\n                <span *ngIf=\"menu.icon && mode === dropdownMode.icon\" thyActionMenuItemIcon>\n                    <thy-icon [thyIconName]=\"menu.icon\"></thy-icon>\n                </span>\n                <span *ngIf=\"menu.name\" thyActionMenuItemName>{{ menu.name }}</span>\n            </a>\n            <thy-action-menu-divider *ngIf=\"menu.key === 'split'\"></thy-action-menu-divider>\n        </ng-container>\n    </thy-action-menu>\n</ng-template>\n"]}