@worktile/theia 2.2.7 → 2.3.0-next.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (64) hide show
  1. package/bundles/worktile-theia.umd.js +852 -249
  2. package/bundles/worktile-theia.umd.js.map +1 -1
  3. package/components/toolbar/toolbar.component.d.ts +3 -2
  4. package/components/toolbar-item/toolbar-item.component.d.ts +3 -4
  5. package/constants/default.d.ts +3 -0
  6. package/constants/node-types.d.ts +4 -0
  7. package/custom-types.d.ts +3 -1
  8. package/editor.component.d.ts +3 -1
  9. package/editor.module.d.ts +26 -24
  10. package/esm2015/components/toolbar/toolbar.component.js +6 -4
  11. package/esm2015/components/toolbar-item/toolbar-item.component.js +4 -4
  12. package/esm2015/constants/auto-format-rules.js +26 -7
  13. package/esm2015/constants/default.js +2 -1
  14. package/esm2015/constants/node-types.js +6 -1
  15. package/esm2015/custom-types.js +1 -1
  16. package/esm2015/editor.component.js +12 -6
  17. package/esm2015/editor.module.js +6 -3
  18. package/esm2015/interfaces/editor.js +1 -1
  19. package/esm2015/interfaces/image.js +1 -1
  20. package/esm2015/interfaces/valid-children-types.js +2 -1
  21. package/esm2015/plugins/align/align.editor.js +10 -2
  22. package/esm2015/plugins/align/options.js +3 -2
  23. package/esm2015/plugins/common/auto-insert-data..js +2 -18
  24. package/esm2015/plugins/dnd/component/dnd.component.js +260 -0
  25. package/esm2015/plugins/dnd/utils/get-current-target.js +19 -0
  26. package/esm2015/plugins/dnd/utils/get-hover-direction.js +13 -0
  27. package/esm2015/plugins/dnd/utils/is-valid-drag.js +38 -0
  28. package/esm2015/plugins/dnd/utils/move-drag-node.js +30 -0
  29. package/esm2015/plugins/dnd/utils/remove-drop-thumb-line.js +10 -0
  30. package/esm2015/plugins/image/image.component.js +167 -14
  31. package/esm2015/plugins/image/image.editor.js +4 -1
  32. package/esm2015/plugins/indent/on-keydown-indent.js +2 -3
  33. package/esm2015/plugins/list/list.editor.js +2 -2
  34. package/esm2015/plugins/quick-insert/components/quick-insert.component.js +13 -2
  35. package/esm2015/plugins/quick-insert/components/quick-toolbar/quick-toolbar.component.js +1 -1
  36. package/esm2015/services/context.service.js +5 -1
  37. package/esm2015/utils/dom.js +39 -1
  38. package/esm2015/utils/is-clean-empty-paragraph.js +4 -4
  39. package/esm2015/utils/merge-element-options.js +20 -0
  40. package/fesm2015/worktile-theia.js +786 -201
  41. package/fesm2015/worktile-theia.js.map +1 -1
  42. package/interfaces/editor.d.ts +9 -1
  43. package/interfaces/image.d.ts +7 -1
  44. package/interfaces/valid-children-types.d.ts +1 -0
  45. package/package.json +1 -1
  46. package/plugins/align/align.editor.d.ts +1 -0
  47. package/plugins/dnd/component/dnd.component.d.ts +42 -0
  48. package/plugins/dnd/component/dnd.component.scss +61 -0
  49. package/plugins/dnd/utils/get-current-target.d.ts +2 -0
  50. package/plugins/dnd/utils/get-hover-direction.d.ts +3 -0
  51. package/plugins/dnd/utils/is-valid-drag.d.ts +3 -0
  52. package/plugins/dnd/utils/move-drag-node.d.ts +2 -0
  53. package/plugins/dnd/utils/remove-drop-thumb-line.d.ts +2 -0
  54. package/plugins/image/image.component.d.ts +27 -3
  55. package/plugins/image/image.component.scss +9 -2
  56. package/plugins/image/image.editor.d.ts +6 -1
  57. package/plugins/quick-insert/components/quick-insert.component.d.ts +1 -0
  58. package/plugins/table/components/table.component.scss +1 -0
  59. package/services/context.service.d.ts +1 -0
  60. package/styles/editor.scss +4 -0
  61. package/styles/index.scss +1 -0
  62. package/styles/typo.scss +44 -0
  63. package/utils/dom.d.ts +5 -1
  64. package/utils/merge-element-options.d.ts +2 -0
@@ -1,4 +1,4 @@
1
- import { OnInit, ViewContainerRef, ComponentFactoryResolver, OnChanges, SimpleChanges, ComponentRef, ElementRef, OnDestroy, NgZone, TemplateRef } from '@angular/core';
1
+ import { OnInit, ViewContainerRef, ComponentFactoryResolver, OnChanges, SimpleChanges, ComponentRef, ElementRef, OnDestroy, NgZone, TemplateRef, ChangeDetectorRef } from '@angular/core';
2
2
  import { Editor } from 'slate';
3
3
  import { ComponentType } from 'slate-angular';
4
4
  import { ToolbarAlignment, ToolbarItem } from '../../interfaces/toolbar';
@@ -6,6 +6,7 @@ import type { TheToolbarGroupComponent } from '../toolbar-group/toolbar-group.co
6
6
  import * as i0 from "@angular/core";
7
7
  export declare class TheToolbarComponent implements OnInit, OnChanges, OnDestroy {
8
8
  private cfr;
9
+ private cdr;
9
10
  private elementRef;
10
11
  private ngZone;
11
12
  private toolbarGroupComponent;
@@ -20,7 +21,7 @@ export declare class TheToolbarComponent implements OnInit, OnChanges, OnDestroy
20
21
  moreGroupMenu: ToolbarItem;
21
22
  resizeObserver: any;
22
23
  elementWidth: number;
23
- constructor(cfr: ComponentFactoryResolver, elementRef: ElementRef, ngZone: NgZone, toolbarGroupComponent: ComponentType<TheToolbarGroupComponent>);
24
+ constructor(cfr: ComponentFactoryResolver, cdr: ChangeDetectorRef, elementRef: ElementRef, ngZone: NgZone, toolbarGroupComponent: ComponentType<TheToolbarGroupComponent>);
24
25
  ngOnInit(): void;
25
26
  ngOnChanges(changes: SimpleChanges): void;
26
27
  ngOnDestroy(): void;
@@ -1,15 +1,14 @@
1
1
  import { ComponentFactoryResolver, NgZone, OnInit, ViewContainerRef } from '@angular/core';
2
2
  import { Editor } from 'slate';
3
- import { ToolbarItem } from '../../interfaces';
4
- import { CustomEditor } from '../../custom-types';
3
+ import { TheEditor, ToolbarItem } from '../../interfaces';
5
4
  import { TheToolbarBaseItemComponent } from '../toolbar-base-item/toolbar-base-item.component';
6
5
  import { ToolbarItemMode } from '../../constants/toolbar';
7
6
  import * as i0 from "@angular/core";
8
7
  export declare class TheToolbarItemComponent extends TheToolbarBaseItemComponent implements OnInit {
9
8
  private ngZone;
10
9
  private cfr;
10
+ editor: TheEditor;
11
11
  item: ToolbarItem;
12
- editor: CustomEditor;
13
12
  itemMode: ToolbarItemMode;
14
13
  ToolbarItemMode: typeof ToolbarItemMode;
15
14
  active: string | boolean;
@@ -23,5 +22,5 @@ export declare class TheToolbarItemComponent extends TheToolbarBaseItemComponent
23
22
  execute(event: MouseEvent): void;
24
23
  renderToolbarItem(): void;
25
24
  static ɵfac: i0.ɵɵFactoryDeclaration<TheToolbarItemComponent, never>;
26
- static ɵcmp: i0.ɵɵComponentDeclaration<TheToolbarItemComponent, "the-toolbar-item", never, { "item": "item"; "editor": "editor"; "itemMode": "itemMode"; }, {}, never, never>;
25
+ static ɵcmp: i0.ɵɵComponentDeclaration<TheToolbarItemComponent, "the-toolbar-item", never, { "editor": "editor"; "item": "item"; "itemMode": "itemMode"; }, {}, never, never>;
27
26
  }
@@ -7,7 +7,10 @@ export declare const CLIPBOARD_FORMAT_KEY = "x-theia-fragment";
7
7
  export declare const DEFAULT_SCROLL_CONTAINER = ".the-editable-container";
8
8
  export declare const ELEMENT_UNIQUE_ID = "key";
9
9
  export declare const ZERO_WIDTH_CHAR = "\u200B";
10
+ export declare const DROP_THUMB_LINE = "drop-thumb-line";
10
11
  export declare enum TheMode {
11
12
  fullMode = "full",
12
13
  liteMode = "lite"
13
14
  }
15
+ export declare type DropDirection = 'top' | 'bottom' | undefined;
16
+ export declare type NodeLevel = 'highest' | undefined;
@@ -35,6 +35,10 @@ export declare enum VerticalAlignment {
35
35
  middle = "middle",
36
36
  bottom = "bottom"
37
37
  }
38
+ export declare enum LayoutTypes {
39
+ wrapLeft = "wrap-left",
40
+ wrapRight = "wrap-right"
41
+ }
38
42
  export declare enum FontSizes {
39
43
  'fontSize12' = "12",
40
44
  'fontSize13' = "13",
package/custom-types.d.ts CHANGED
@@ -1,7 +1,7 @@
1
1
  import { SafeUrl } from '@angular/platform-browser';
2
2
  import { Descendant, Element } from 'slate';
3
3
  import { TheEditor, BlockElementKinds, InlineElementKinds } from './interfaces';
4
- import { Alignment, ElementKinds, VerticalAlignment } from './constants';
4
+ import { Alignment, ElementKinds, LayoutTypes, VerticalAlignment } from './constants';
5
5
  import { TheTableColumn } from './plugins/table/table.types';
6
6
  export interface TheElement<T = BlockElementKinds | InlineElementKinds> {
7
7
  type: T;
@@ -70,6 +70,8 @@ export interface ImageElement extends TheElement {
70
70
  thumbUrl?: SafeUrl | string;
71
71
  originUrl?: SafeUrl | string;
72
72
  align?: Alignment;
73
+ layout?: LayoutTypes;
74
+ reSized?: boolean;
73
75
  }
74
76
  export interface TableElement extends TheElement {
75
77
  type: ElementKinds.table;
@@ -37,6 +37,7 @@ export declare class TheEditorComponent extends TheEditorComponent_base implemen
37
37
  editor: TheEditor;
38
38
  editorValue: Descendant[];
39
39
  globalToolbarClass: string[];
40
+ isDraging: boolean;
40
41
  decorate: (nodeEntry: NodeEntry) => Range[];
41
42
  get theGlobalToolbarInstance(): TheToolbarComponent;
42
43
  get maxHeight(): string;
@@ -82,7 +83,8 @@ export declare class TheEditorComponent extends TheEditorComponent_base implemen
82
83
  onSlaCompositionEnd: (event: CompositionEvent) => void;
83
84
  onSlaDragStart: (event: DragEvent) => void;
84
85
  onSlaDragOver: (event: DragEvent) => void;
85
- onDrop: (event: Event) => void;
86
+ onDrop: (event: DragEvent) => void;
87
+ onDragChange: (isDraging: any) => void;
86
88
  getTextAndJSON(data: DataTransfer): {
87
89
  json: any[];
88
90
  text: string;
@@ -27,6 +27,7 @@ import { TheInlineToolbarComponent } from './components/inline-toolbar/inline-to
27
27
  import { TheQuickToolbarComponent } from './plugins/quick-insert/components/quick-toolbar/quick-toolbar.component';
28
28
  import { TheQuickInsertComponent } from './plugins/quick-insert/components/quick-insert.component';
29
29
  import { TheIndentToolbarComponent } from './plugins/indent/toolbar-item.component';
30
+ import { TheDndComponent } from './plugins/dnd/component/dnd.component';
30
31
  import * as i0 from "@angular/core";
31
32
  import * as i1 from "./editor.component";
32
33
  import * as i2 from "./pipes";
@@ -66,32 +67,33 @@ import * as i35 from "./plugins/table/components/table.component";
66
67
  import * as i36 from "./plugins/table/components/row/row.component";
67
68
  import * as i37 from "./plugins/table/components/td/td.component";
68
69
  import * as i38 from "./plugins/inline-code/inline-code.component";
69
- import * as i39 from "@angular/common";
70
- import * as i40 from "slate-angular";
71
- import * as i41 from "@angular/forms";
72
- import * as i42 from "ngx-tethys/icon";
73
- import * as i43 from "ngx-tethys/avatar";
74
- import * as i44 from "ngx-tethys/nav";
75
- import * as i45 from "ngx-tethys/form";
76
- import * as i46 from "ngx-tethys/shared";
77
- import * as i47 from "ngx-tethys/list";
78
- import * as i48 from "ngx-tethys/tooltip";
79
- import * as i49 from "ngx-tethys/progress";
80
- import * as i50 from "ngx-tethys/autocomplete";
81
- import * as i51 from "ngx-tethys/action-menu";
82
- import * as i52 from "ngx-tethys/input";
83
- import * as i53 from "ngx-tethys/select";
84
- import * as i54 from "ngx-tethys/button";
85
- import * as i55 from "ngx-tethys/notify";
86
- import * as i56 from "ngx-tethys/alert";
87
- import * as i57 from "ngx-tethys/resizable";
88
- import * as i58 from "ngx-tethys/switch";
89
- import * as i59 from "ng-codemirror";
90
- import * as i60 from "./components/column-resize/column-resize.module";
70
+ import * as i39 from "./plugins/dnd/component/dnd.component";
71
+ import * as i40 from "@angular/common";
72
+ import * as i41 from "slate-angular";
73
+ import * as i42 from "@angular/forms";
74
+ import * as i43 from "ngx-tethys/icon";
75
+ import * as i44 from "ngx-tethys/avatar";
76
+ import * as i45 from "ngx-tethys/nav";
77
+ import * as i46 from "ngx-tethys/form";
78
+ import * as i47 from "ngx-tethys/shared";
79
+ import * as i48 from "ngx-tethys/list";
80
+ import * as i49 from "ngx-tethys/tooltip";
81
+ import * as i50 from "ngx-tethys/progress";
82
+ import * as i51 from "ngx-tethys/autocomplete";
83
+ import * as i52 from "ngx-tethys/action-menu";
84
+ import * as i53 from "ngx-tethys/input";
85
+ import * as i54 from "ngx-tethys/select";
86
+ import * as i55 from "ngx-tethys/button";
87
+ import * as i56 from "ngx-tethys/notify";
88
+ import * as i57 from "ngx-tethys/alert";
89
+ import * as i58 from "ngx-tethys/resizable";
90
+ import * as i59 from "ngx-tethys/switch";
91
+ import * as i60 from "ng-codemirror";
92
+ import * as i61 from "./components/column-resize/column-resize.module";
91
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 TheIndentToolbarComponent | typeof TheToolbarItemComponent | typeof NavSplitLineComponent | typeof TheToolbarDropdownComponent | typeof TheToolbarComponent | typeof TheQuickInsertComponent | typeof TheInsertMarkComponent | typeof TheInlineToolbarComponent)[];
92
- export declare const PLUGIN_COMPONENTS: (typeof TheTableToolbarComponent | typeof TheTableComponent | typeof TheImageComponent | typeof TheBlockquoteComponent | typeof TheCodeComponent | typeof TheLinkHoverComponent | typeof TheLinkEditComponent | typeof TheReadonlyLinkComponent | typeof TheTdComponent | typeof TheTemplateComponent)[];
94
+ export declare const PLUGIN_COMPONENTS: (typeof TheTableToolbarComponent | typeof TheTableComponent | typeof TheImageComponent | typeof TheBlockquoteComponent | typeof TheCodeComponent | typeof TheLinkHoverComponent | typeof TheLinkEditComponent | typeof TheReadonlyLinkComponent | typeof TheTdComponent | typeof TheTemplateComponent | typeof TheDndComponent)[];
93
95
  export declare class TheEditorModule {
94
96
  static ɵfac: i0.ɵɵFactoryDeclaration<TheEditorModule, never>;
95
- 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.TheIndentToolbarComponent, 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.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]>;
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.TheIndentToolbarComponent, 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.TheInlineCodeComponent, typeof i39.TheDndComponent], [typeof i40.CommonModule, typeof i41.SlateModule, typeof i42.FormsModule, typeof i43.ThyIconModule, typeof i44.ThyAvatarModule, typeof i45.ThyNavModule, typeof i46.ThyFormModule, typeof i47.ThySharedModule, typeof i48.ThyListModule, typeof i49.ThyTooltipModule, typeof i50.ThyProgressModule, typeof i51.ThyAutocompleteModule, typeof i52.ThyActionMenuModule, typeof i53.ThyInputModule, typeof i54.ThySelectModule, typeof i55.ThyButtonModule, typeof i56.ThyNotifyModule, typeof i57.ThyAlertModule, typeof i58.ThyResizableModule, typeof i59.ThySwitchModule, typeof i60.CodemirrorModule, typeof i61.TheColumnSizeModule], [typeof i1.TheEditorComponent, typeof i3.TheToolbarComponent, typeof i4.TheToolbarDropdownComponent, typeof i6.TheToolbarItemComponent, typeof i10.TheDefaultElementComponent]>;
96
98
  static ɵinj: i0.ɵɵInjectorDeclaration<TheEditorModule>;
97
99
  }
@@ -11,8 +11,9 @@ import * as i0 from "@angular/core";
11
11
  import * as i1 from "ngx-tethys/nav";
12
12
  import * as i2 from "@angular/common";
13
13
  export class TheToolbarComponent {
14
- constructor(cfr, elementRef, ngZone, toolbarGroupComponent) {
14
+ constructor(cfr, cdr, elementRef, ngZone, toolbarGroupComponent) {
15
15
  this.cfr = cfr;
16
+ this.cdr = cdr;
16
17
  this.elementRef = elementRef;
17
18
  this.ngZone = ngZone;
18
19
  this.toolbarGroupComponent = toolbarGroupComponent;
@@ -87,6 +88,7 @@ export class TheToolbarComponent {
87
88
  }
88
89
  this.createMoreGroup(group);
89
90
  });
91
+ this.cdr.markForCheck();
90
92
  }
91
93
  /**
92
94
  * calculation display toolbar and more grouped toolbars
@@ -225,7 +227,7 @@ export class TheToolbarComponent {
225
227
  return (_c = item === null || item === void 0 ? void 0 : item.includes) === null || _c === void 0 ? void 0 : _c.find((item) => item.key === dropdownKey);
226
228
  }
227
229
  }
228
- TheToolbarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheToolbarComponent, deps: [{ token: i0.ComponentFactoryResolver }, { token: i0.ElementRef }, { token: i0.NgZone }, { token: TheToolbarGroupToken }], target: i0.ɵɵFactoryTarget.Component });
230
+ TheToolbarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheToolbarComponent, deps: [{ token: i0.ComponentFactoryResolver }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i0.NgZone }, { token: TheToolbarGroupToken }], target: i0.ɵɵFactoryTarget.Component });
229
231
  TheToolbarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.15", 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"] }] });
230
232
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheToolbarComponent, decorators: [{
231
233
  type: Component,
@@ -236,7 +238,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImpo
236
238
  class: 'the-toolbar-container'
237
239
  }
238
240
  }]
239
- }], ctorParameters: function () { return [{ type: i0.ComponentFactoryResolver }, { type: i0.ElementRef }, { type: i0.NgZone }, { type: undefined, decorators: [{
241
+ }], ctorParameters: function () { return [{ type: i0.ComponentFactoryResolver }, { type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: i0.NgZone }, { type: undefined, decorators: [{
240
242
  type: Inject,
241
243
  args: [TheToolbarGroupToken]
242
244
  }] }]; }, propDecorators: { editor: [{
@@ -255,4 +257,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImpo
255
257
  type: ViewChild,
256
258
  args: ['toolbarContainer', { read: ViewContainerRef, static: true }]
257
259
  }] } });
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, FontSizes, 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 (contextService && 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"]}
260
+ //# 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    ChangeDetectorRef\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 cdr: ChangeDetectorRef,\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        this.cdr.markForCheck();\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 (contextService && 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"]}
@@ -53,7 +53,7 @@ export class TheToolbarItemComponent extends TheToolbarBaseItemComponent {
53
53
  }
54
54
  }
55
55
  TheToolbarItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheToolbarItemComponent, deps: [{ token: i0.NgZone }, { token: i0.ComponentFactoryResolver }], target: i0.ɵɵFactoryTarget.Component });
56
- TheToolbarItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.15", type: TheToolbarItemComponent, selector: "the-toolbar-item", inputs: { item: "item", editor: "editor", itemMode: "itemMode" }, host: { listeners: { "mousedown": "toggleDropdown($event)" }, properties: { "class.disabled": "this.disabledState" }, classAttribute: "the-toolbar-item" }, viewQueries: [{ propertyName: "toolbarContainer", first: true, predicate: ["toolbarContainer"], descendants: true, read: ViewContainerRef, static: true }], usesInheritance: true, ngImport: i0, template: `
56
+ TheToolbarItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.15", type: TheToolbarItemComponent, selector: "the-toolbar-item", inputs: { editor: "editor", item: "item", itemMode: "itemMode" }, host: { listeners: { "mousedown": "toggleDropdown($event)" }, properties: { "class.disabled": "this.disabledState" }, classAttribute: "the-toolbar-item" }, viewQueries: [{ propertyName: "toolbarContainer", first: true, predicate: ["toolbarContainer"], descendants: true, read: ViewContainerRef, static: true }], usesInheritance: true, ngImport: i0, template: `
57
57
  <ng-container *ngIf="itemMode === ToolbarItemMode.horizontal; else selectionItem">
58
58
  <a
59
59
  thyIconNavLink
@@ -103,9 +103,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImpo
103
103
  class: 'the-toolbar-item'
104
104
  }
105
105
  }]
106
- }], ctorParameters: function () { return [{ type: i0.NgZone }, { type: i0.ComponentFactoryResolver }]; }, propDecorators: { item: [{
106
+ }], ctorParameters: function () { return [{ type: i0.NgZone }, { type: i0.ComponentFactoryResolver }]; }, propDecorators: { editor: [{
107
107
  type: Input
108
- }], editor: [{
108
+ }], item: [{
109
109
  type: Input
110
110
  }], itemMode: [{
111
111
  type: Input
@@ -119,4 +119,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImpo
119
119
  type: HostBinding,
120
120
  args: ['class.disabled']
121
121
  }] } });
122
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolbar-item.component.js","sourceRoot":"","sources":["../../../../../packages/src/components/toolbar-item/toolbar-item.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ComponentFactoryResolver,\n    HostBinding,\n    HostListener,\n    Input,\n    NgZone,\n    OnInit,\n    ViewChild,\n    ViewContainerRef\n} from '@angular/core';\nimport { Editor } from 'slate';\nimport { ToolbarItem } from '../../interfaces';\nimport { CustomEditor } from '../../custom-types';\nimport { TheToolbarBaseItemComponent } from '../toolbar-base-item/toolbar-base-item.component';\nimport { ToolbarItemMode } from '../../constants/toolbar';\nimport { isComponentType } from 'slate-angular';\n\n@Component({\n    selector: 'the-toolbar-item',\n    template: `\n        <ng-container *ngIf=\"itemMode === ToolbarItemMode.horizontal; else selectionItem\">\n            <a\n                thyIconNavLink\n                [thyIconNavLinkIcon]=\"item.icon\"\n                [thyTooltip]=\"tooltip\"\n                [thyTooltipTemplateContext]=\"{ name: item.name, shortcutKey: item.shortcutKey }\"\n                thyTooltipPlacement=\"top\"\n                [thyIconNavLinkActive]=\"active\"\n                (mousedown)=\"execute($event)\"\n            ></a>\n        </ng-container>\n        <ng-template #selectionItem>\n            <ng-container *ngIf=\"!item?.quickItemComponent\">\n                <thy-icon [thyIconName]=\"item?.icon\" [thyIconRotate]=\"0\" class=\"quick-toolbar-icon\"></thy-icon>\n                <span class=\"quick-toolbar-name\">{{ item?.name }}</span>\n            </ng-container>\n        </ng-template>\n        <ng-template #tooltip let-data> {{ data.name }} {{ data.shortcutKey }} </ng-template>\n        <ng-container #toolbarContainer></ng-container>\n    `,\n    host: {\n        class: 'the-toolbar-item'\n    }\n})\nexport class TheToolbarItemComponent extends TheToolbarBaseItemComponent implements OnInit {\n    @Input() item: ToolbarItem;\n\n    @Input() editor: CustomEditor;\n\n    @Input() itemMode: ToolbarItemMode = ToolbarItemMode.horizontal;\n\n    ToolbarItemMode = ToolbarItemMode;\n\n    active: string | boolean = false;\n\n    disabled = false;\n\n    @ViewChild('toolbarContainer', { read: ViewContainerRef, static: true })\n    toolbarContainer: ViewContainerRef;\n\n    @HostListener('mousedown', ['$event'])\n    toggleDropdown(event: MouseEvent) {\n        super.execute(event);\n    }\n\n    @HostBinding('class.disabled') get disabledState() {\n        return this.disabled;\n    }\n\n    constructor(private ngZone: NgZone, private cfr: ComponentFactoryResolver) {\n        super();\n    }\n\n    ngOnInit() {\n        if (this.item?.quickItemComponent && isComponentType(this.item?.quickItemComponent)) {\n            this.renderToolbarItem();\n        }\n    }\n\n    public statusChange(editor: Editor) {\n        this.disabled = this.item?.disable ? this.item?.disable(editor) : false;\n        this.active = this.item?.active ? this.item?.active(editor) : false;\n    }\n\n    execute(event: MouseEvent) {\n        super.execute(event);\n\n        if (this.editor?.disabled || this.disabled || !this.item?.execute) {\n            return;\n        }\n\n        this.item?.execute(this.editor);\n    }\n\n    renderToolbarItem() {\n        this.ngZone.run(() => {\n            const toolbarItemFactory = this.cfr.resolveComponentFactory(this.item.quickItemComponent);\n            const tollbarItemRef = this.toolbarContainer.createComponent(toolbarItemFactory);\n            tollbarItemRef.instance.editor = this.editor;\n            tollbarItemRef.instance.item = this.item;\n            tollbarItemRef.instance.itemMode = ToolbarItemMode.vertical;\n        });\n    }\n}\n"]}
122
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolbar-item.component.js","sourceRoot":"","sources":["../../../../../packages/src/components/toolbar-item/toolbar-item.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ComponentFactoryResolver,\n    HostBinding,\n    HostListener,\n    Input,\n    NgZone,\n    OnInit,\n    ViewChild,\n    ViewContainerRef\n} from '@angular/core';\nimport { Editor } from 'slate';\nimport { TheEditor, ToolbarItem } from '../../interfaces';\nimport { CustomEditor } from '../../custom-types';\nimport { TheToolbarBaseItemComponent } from '../toolbar-base-item/toolbar-base-item.component';\nimport { ToolbarItemMode } from '../../constants/toolbar';\nimport { isComponentType } from 'slate-angular';\n\n@Component({\n    selector: 'the-toolbar-item',\n    template: `\n        <ng-container *ngIf=\"itemMode === ToolbarItemMode.horizontal; else selectionItem\">\n            <a\n                thyIconNavLink\n                [thyIconNavLinkIcon]=\"item.icon\"\n                [thyTooltip]=\"tooltip\"\n                [thyTooltipTemplateContext]=\"{ name: item.name, shortcutKey: item.shortcutKey }\"\n                thyTooltipPlacement=\"top\"\n                [thyIconNavLinkActive]=\"active\"\n                (mousedown)=\"execute($event)\"\n            ></a>\n        </ng-container>\n        <ng-template #selectionItem>\n            <ng-container *ngIf=\"!item?.quickItemComponent\">\n                <thy-icon [thyIconName]=\"item?.icon\" [thyIconRotate]=\"0\" class=\"quick-toolbar-icon\"></thy-icon>\n                <span class=\"quick-toolbar-name\">{{ item?.name }}</span>\n            </ng-container>\n        </ng-template>\n        <ng-template #tooltip let-data> {{ data.name }} {{ data.shortcutKey }} </ng-template>\n        <ng-container #toolbarContainer></ng-container>\n    `,\n    host: {\n        class: 'the-toolbar-item'\n    }\n})\nexport class TheToolbarItemComponent extends TheToolbarBaseItemComponent implements OnInit {\n    @Input() editor: TheEditor;\n\n    @Input() item: ToolbarItem;\n\n    @Input() itemMode: ToolbarItemMode = ToolbarItemMode.horizontal;\n\n    ToolbarItemMode = ToolbarItemMode;\n\n    active: string | boolean = false;\n\n    disabled = false;\n\n    @ViewChild('toolbarContainer', { read: ViewContainerRef, static: true })\n    toolbarContainer: ViewContainerRef;\n\n    @HostListener('mousedown', ['$event'])\n    toggleDropdown(event: MouseEvent) {\n        super.execute(event);\n    }\n\n    @HostBinding('class.disabled') get disabledState() {\n        return this.disabled;\n    }\n\n    constructor(private ngZone: NgZone, private cfr: ComponentFactoryResolver) {\n        super();\n    }\n\n    ngOnInit() {\n        if (this.item?.quickItemComponent && isComponentType(this.item?.quickItemComponent)) {\n            this.renderToolbarItem();\n        }\n    }\n\n    public statusChange(editor: Editor) {\n        this.disabled = this.item?.disable ? this.item?.disable(editor) : false;\n        this.active = this.item?.active ? this.item?.active(editor) : false;\n    }\n\n    execute(event: MouseEvent) {\n        super.execute(event);\n\n        if (this.editor?.disabled || this.disabled || !this.item?.execute) {\n            return;\n        }\n\n        this.item?.execute(this.editor);\n    }\n\n    renderToolbarItem() {\n        this.ngZone.run(() => {\n            const toolbarItemFactory = this.cfr.resolveComponentFactory(this.item.quickItemComponent);\n            const tollbarItemRef = this.toolbarContainer.createComponent(toolbarItemFactory);\n            tollbarItemRef.instance.editor = this.editor;\n            tollbarItemRef.instance.item = this.item;\n            tollbarItemRef.instance.itemMode = ToolbarItemMode.vertical;\n        });\n    }\n}\n"]}
@@ -5,30 +5,49 @@ import { ListEditor } from '../plugins/list/list.editor';
5
5
  import { TodoItemEditor } from '../plugins/todo-item/todo-item.editor';
6
6
  import { BlockquoteEditor } from '../plugins/blockquote/blockquote.editor';
7
7
  import { InlineCodeEditor } from '../plugins/inline-code/inline-code.editor';
8
+ import { HeadingEditor } from '../plugins/heading/heading.editor';
8
9
  export const autoFormatRules = [
9
10
  {
10
11
  type: ElementKinds.heading_1,
11
- markup: '#'
12
+ markup: '#',
13
+ format: (editor) => {
14
+ HeadingEditor.setHeading(editor, ElementKinds.heading_1);
15
+ }
12
16
  },
13
17
  {
14
18
  type: ElementKinds.heading_2,
15
- markup: '##'
19
+ markup: '##',
20
+ format: (editor) => {
21
+ HeadingEditor.setHeading(editor, ElementKinds.heading_2);
22
+ }
16
23
  },
17
24
  {
18
25
  type: ElementKinds.heading_3,
19
- markup: '###'
26
+ markup: '###',
27
+ format: (editor) => {
28
+ HeadingEditor.setHeading(editor, ElementKinds.heading_3);
29
+ }
20
30
  },
21
31
  {
22
32
  type: ElementKinds.heading_4,
23
- markup: '####'
33
+ markup: '####',
34
+ format: (editor) => {
35
+ HeadingEditor.setHeading(editor, ElementKinds.heading_4);
36
+ }
24
37
  },
25
38
  {
26
39
  type: ElementKinds.heading_5,
27
- markup: '#####'
40
+ markup: '#####',
41
+ format: (editor) => {
42
+ HeadingEditor.setHeading(editor, ElementKinds.heading_5);
43
+ }
28
44
  },
29
45
  {
30
46
  type: ElementKinds.heading_6,
31
- markup: '######'
47
+ markup: '######',
48
+ format: (editor) => {
49
+ HeadingEditor.setHeading(editor, ElementKinds.heading_6);
50
+ }
32
51
  },
33
52
  {
34
53
  type: ElementKinds.blockquote,
@@ -124,4 +143,4 @@ export const autoFormatRules = [
124
143
  insertTrigger: true
125
144
  }
126
145
  ];
127
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auto-format-rules.js","sourceRoot":"","sources":["../../../../packages/src/constants/auto-format-rules.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAE3C,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AACvD,OAAO,KAAK,UAAU,MAAM,YAAY,CAAC;AACzC,OAAO,EAAE,UAAU,EAAE,MAAM,6BAA6B,CAAC;AACzD,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAC;AACvE,OAAO,EAAE,gBAAgB,EAAE,MAAM,yCAAyC,CAAC;AAC3E,OAAO,EAAE,gBAAgB,EAAE,MAAM,2CAA2C,CAAC;AAE7E,MAAM,CAAC,MAAM,eAAe,GAAqB;IAC7C;QACI,IAAI,EAAE,YAAY,CAAC,SAAS;QAC5B,MAAM,EAAE,GAAG;KACd;IACD;QACI,IAAI,EAAE,YAAY,CAAC,SAAS;QAC5B,MAAM,EAAE,IAAI;KACf;IACD;QACI,IAAI,EAAE,YAAY,CAAC,SAAS;QAC5B,MAAM,EAAE,KAAK;KAChB;IACD;QACI,IAAI,EAAE,YAAY,CAAC,SAAS;QAC5B,MAAM,EAAE,MAAM;KACjB;IACD;QACI,IAAI,EAAE,YAAY,CAAC,SAAS;QAC5B,MAAM,EAAE,OAAO;KAClB;IACD;QACI,IAAI,EAAE,YAAY,CAAC,SAAS;QAC5B,MAAM,EAAE,QAAQ;KACnB;IACD;QACI,IAAI,EAAE,YAAY,CAAC,UAAU;QAC7B,MAAM,EAAE,CAAC,GAAG,CAAC;QACb,MAAM,EAAE,CAAC,MAAc,EAAE,EAAE;YACvB,gBAAgB,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;QAC9C,CAAC;KACJ;IACD;QACI,IAAI,EAAE,SAAS,CAAC,IAAI;QACpB,OAAO,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC;QACrB,IAAI,EAAE,QAAQ;QACd,aAAa,EAAE,IAAI;KACtB;IACD;QACI,IAAI,EAAE,SAAS,CAAC,IAAI;QACpB,OAAO,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC;QACrB,IAAI,EAAE,QAAQ;QACd,aAAa,EAAE,IAAI;KACtB;IACD;QACI,IAAI,EAAE,SAAS,CAAC,MAAM;QACtB,OAAO,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC;QACnB,IAAI,EAAE,QAAQ;QACd,aAAa,EAAE,IAAI;KACtB;IACD;QACI,IAAI,EAAE,SAAS,CAAC,MAAM;QACtB,OAAO,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC;QACnB,IAAI,EAAE,QAAQ;QACd,aAAa,EAAE,IAAI;KACtB;IACD;QACI,IAAI,EAAE,YAAY,CAAC,UAAU;QAC7B,OAAO,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC;QACnB,IAAI,EAAE,QAAQ;QACd,MAAM,EAAE,CAAC,MAAc,EAAE,IAAY,EAAE,EAAE;YACrC,gBAAgB,CAAC,gBAAgB,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;YAChD,UAAU,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,KAAK,CAAC,MAAM,EAAE,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC;QACtE,CAAC;KACJ;IACD;QACI,IAAI,EAAE,SAAS,CAAC,MAAM;QACtB,OAAO,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC;QACrB,IAAI,EAAE,QAAQ;QACd,aAAa,EAAE,IAAI;KACtB;IACD;QACI,IAAI,EAAE,YAAY,CAAC,IAAI;QACvB,MAAM,EAAE,KAAK;QACb,aAAa,EAAE,IAAI;KACtB;IACD;QACI,IAAI,EAAE,YAAY,CAAC,QAAQ;QAC3B,MAAM,EAAE,EAAE;QACV,KAAK,EAAE,CAAC,MAAc,EAAE,EAAE;YACtB,OAAO,UAAU,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QACjE,CAAC;QACD,MAAM,EAAE,CAAC,MAAc,EAAE,EAAE;YACvB,UAAU,CAAC,UAAU,CAAC,MAAM,EAAE,YAAY,CAAC,YAAY,CAAC,CAAC;QAC7D,CAAC;KACJ;IACD;QACI,IAAI,EAAE,YAAY,CAAC,QAAQ;QAC3B,MAAM,EAAE,EAAE;QACV,KAAK,EAAE,CAAC,MAAc,EAAE,kBAA0B,EAAE,EAAE;YAClD,OAAO,UAAU,CAAC,WAAW,CAAC,MAAM,CAAC,IAAI,gBAAgB,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QACnH,CAAC;QACD,MAAM,EAAE,CAAC,MAAc,EAAE,MAAiB,EAAE,EAAE;YAC1C,IAAI,UAAU,GAAG,CAAC,CAAC;YACnB,IAAI,MAAM,EAAE;gBACR,UAAU,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAsB,CAAC;gBAC1D,IAAI,UAAU,KAAK,CAAC,EAAE;oBAClB,UAAU,GAAG,CAAC,CAAC;iBAClB;aACJ;YACD,UAAU,CAAC,UAAU,CAAC,MAAM,EAAE,YAAY,CAAC,YAAY,EAAE,UAAU,CAAC,CAAC;QACzE,CAAC;KACJ;IACD;QACI,IAAI,EAAE,YAAY,CAAC,SAAS;QAC5B,MAAM,EAAE,EAAE;QACV,KAAK,EAAE,CAAC,MAAc,EAAE,EAAE;YACtB,OAAO,UAAU,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QACxD,CAAC;QACD,MAAM,EAAE,CAAC,MAAc,EAAE,EAAE;YACvB,cAAc,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;QAC1C,CAAC;KACJ;IACD;QACI,IAAI,EAAE,YAAY,CAAC,EAAE;QACrB,MAAM,EAAE,KAAK;QACb,aAAa,EAAE,IAAI;KACtB;CACJ,CAAC","sourcesContent":["import { Editor, Transforms } from 'slate';\nimport { AutoFormatRule } from '../interfaces/auto-format';\nimport { MarkTypes, ElementKinds } from './node-types';\nimport * as TheQueries from '../queries';\nimport { ListEditor } from '../plugins/list/list.editor';\nimport { TodoItemEditor } from '../plugins/todo-item/todo-item.editor';\nimport { BlockquoteEditor } from '../plugins/blockquote/blockquote.editor';\nimport { InlineCodeEditor } from '../plugins/inline-code/inline-code.editor';\n\nexport const autoFormatRules: AutoFormatRule[] = [\n    {\n        type: ElementKinds.heading_1,\n        markup: '#'\n    },\n    {\n        type: ElementKinds.heading_2,\n        markup: '##'\n    },\n    {\n        type: ElementKinds.heading_3,\n        markup: '###'\n    },\n    {\n        type: ElementKinds.heading_4,\n        markup: '####'\n    },\n    {\n        type: ElementKinds.heading_5,\n        markup: '#####'\n    },\n    {\n        type: ElementKinds.heading_6,\n        markup: '######'\n    },\n    {\n        type: ElementKinds.blockquote,\n        markup: ['>'],\n        format: (editor: Editor) => {\n            BlockquoteEditor.toggleBlockquote(editor);\n        }\n    },\n    {\n        type: MarkTypes.bold,\n        between: ['**', '**'],\n        mode: 'inline',\n        insertTrigger: true\n    },\n    {\n        type: MarkTypes.bold,\n        between: ['__', '__'],\n        mode: 'inline',\n        insertTrigger: true\n    },\n    {\n        type: MarkTypes.italic,\n        between: ['*', '*'],\n        mode: 'inline',\n        insertTrigger: true\n    },\n    {\n        type: MarkTypes.italic,\n        between: ['_', '_'],\n        mode: 'inline',\n        insertTrigger: true\n    },\n    {\n        type: ElementKinds.inlineCode,\n        between: ['`', '`'],\n        mode: 'inline',\n        format: (editor: Editor, text: string) => {\n            InlineCodeEditor.toggleInlineCode(editor, text);\n            Transforms.select(editor, Editor.after(editor, editor.selection));\n        }\n    },\n    {\n        type: MarkTypes.strike,\n        between: ['~~', '~~'],\n        mode: 'inline',\n        insertTrigger: true\n    },\n    {\n        type: ElementKinds.code,\n        markup: '```',\n        insertTrigger: true\n    },\n    {\n        type: ElementKinds.listItem,\n        markup: [],\n        match: (editor: Editor) => {\n            return TheQueries.isParagraph(editor) ? ['*', '-', '+'] : [];\n        },\n        format: (editor: Editor) => {\n            ListEditor.toggleList(editor, ElementKinds.bulletedList);\n        }\n    },\n    {\n        type: ElementKinds.listItem,\n        markup: [],\n        match: (editor: Editor, textFromBlockStart: string) => {\n            return TheQueries.isParagraph(editor) && /^-?\\d+(\\.|\\))$/.test(textFromBlockStart) ? [textFromBlockStart] : [];\n        },\n        format: (editor: Editor, markup?: string[]) => {\n            let startIndex = 1;\n            if (markup) {\n                startIndex = markup[0].split('.')[0] as unknown as number;\n                if (startIndex === 0) {\n                    startIndex = 1;\n                }\n            }\n            ListEditor.toggleList(editor, ElementKinds.numberedList, startIndex);\n        }\n    },\n    {\n        type: ElementKinds.checkItem,\n        markup: [],\n        match: (editor: Editor) => {\n            return TheQueries.isParagraph(editor) ? ['[]'] : [];\n        },\n        format: (editor: Editor) => {\n            TodoItemEditor.insertTodoItem(editor);\n        }\n    },\n    {\n        type: ElementKinds.hr,\n        markup: '---',\n        insertTrigger: true\n    }\n];\n"]}
146
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auto-format-rules.js","sourceRoot":"","sources":["../../../../packages/src/constants/auto-format-rules.ts"],"names":[],"mappings":"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","sourcesContent":["import { Editor, Transforms } from 'slate';\nimport { AutoFormatRule } from '../interfaces/auto-format';\nimport { MarkTypes, ElementKinds } from './node-types';\nimport * as TheQueries from '../queries';\nimport { ListEditor } from '../plugins/list/list.editor';\nimport { TodoItemEditor } from '../plugins/todo-item/todo-item.editor';\nimport { BlockquoteEditor } from '../plugins/blockquote/blockquote.editor';\nimport { InlineCodeEditor } from '../plugins/inline-code/inline-code.editor';\nimport { HeadingEditor } from '../plugins/heading/heading.editor';\n\nexport const autoFormatRules: AutoFormatRule[] = [\n    {\n        type: ElementKinds.heading_1,\n        markup: '#',\n        format: (editor: Editor) => {\n            HeadingEditor.setHeading(editor, ElementKinds.heading_1);\n        }\n    },\n    {\n        type: ElementKinds.heading_2,\n        markup: '##',\n        format: (editor: Editor) => {\n            HeadingEditor.setHeading(editor, ElementKinds.heading_2);\n        }\n    },\n    {\n        type: ElementKinds.heading_3,\n        markup: '###',\n        format: (editor: Editor) => {\n            HeadingEditor.setHeading(editor, ElementKinds.heading_3);\n        }\n    },\n    {\n        type: ElementKinds.heading_4,\n        markup: '####',\n        format: (editor: Editor) => {\n            HeadingEditor.setHeading(editor, ElementKinds.heading_4);\n        }\n    },\n    {\n        type: ElementKinds.heading_5,\n        markup: '#####',\n        format: (editor: Editor) => {\n            HeadingEditor.setHeading(editor, ElementKinds.heading_5);\n        }\n    },\n    {\n        type: ElementKinds.heading_6,\n        markup: '######',\n        format: (editor: Editor) => {\n            HeadingEditor.setHeading(editor, ElementKinds.heading_6);\n        }\n    },\n    {\n        type: ElementKinds.blockquote,\n        markup: ['>'],\n        format: (editor: Editor) => {\n            BlockquoteEditor.toggleBlockquote(editor);\n        }\n    },\n    {\n        type: MarkTypes.bold,\n        between: ['**', '**'],\n        mode: 'inline',\n        insertTrigger: true\n    },\n    {\n        type: MarkTypes.bold,\n        between: ['__', '__'],\n        mode: 'inline',\n        insertTrigger: true\n    },\n    {\n        type: MarkTypes.italic,\n        between: ['*', '*'],\n        mode: 'inline',\n        insertTrigger: true\n    },\n    {\n        type: MarkTypes.italic,\n        between: ['_', '_'],\n        mode: 'inline',\n        insertTrigger: true\n    },\n    {\n        type: ElementKinds.inlineCode,\n        between: ['`', '`'],\n        mode: 'inline',\n        format: (editor: Editor, text: string) => {\n            InlineCodeEditor.toggleInlineCode(editor, text);\n            Transforms.select(editor, Editor.after(editor, editor.selection));\n        }\n    },\n    {\n        type: MarkTypes.strike,\n        between: ['~~', '~~'],\n        mode: 'inline',\n        insertTrigger: true\n    },\n    {\n        type: ElementKinds.code,\n        markup: '```',\n        insertTrigger: true\n    },\n    {\n        type: ElementKinds.listItem,\n        markup: [],\n        match: (editor: Editor) => {\n            return TheQueries.isParagraph(editor) ? ['*', '-', '+'] : [];\n        },\n        format: (editor: Editor) => {\n            ListEditor.toggleList(editor, ElementKinds.bulletedList);\n        }\n    },\n    {\n        type: ElementKinds.listItem,\n        markup: [],\n        match: (editor: Editor, textFromBlockStart: string) => {\n            return TheQueries.isParagraph(editor) && /^-?\\d+(\\.|\\))$/.test(textFromBlockStart) ? [textFromBlockStart] : [];\n        },\n        format: (editor: Editor, markup?: string[]) => {\n            let startIndex = 1;\n            if (markup) {\n                startIndex = markup[0].split('.')[0] as unknown as number;\n                if (startIndex === 0) {\n                    startIndex = 1;\n                }\n            }\n            ListEditor.toggleList(editor, ElementKinds.numberedList, startIndex);\n        }\n    },\n    {\n        type: ElementKinds.checkItem,\n        markup: [],\n        match: (editor: Editor) => {\n            return TheQueries.isParagraph(editor) ? ['[]'] : [];\n        },\n        format: (editor: Editor) => {\n            TodoItemEditor.insertTodoItem(editor);\n        }\n    },\n    {\n        type: ElementKinds.hr,\n        markup: '---',\n        insertTrigger: true\n    }\n];\n"]}
@@ -7,9 +7,10 @@ export const CLIPBOARD_FORMAT_KEY = 'x-theia-fragment';
7
7
  export const DEFAULT_SCROLL_CONTAINER = '.the-editable-container';
8
8
  export const ELEMENT_UNIQUE_ID = 'key';
9
9
  export const ZERO_WIDTH_CHAR = '\u200B';
10
+ export const DROP_THUMB_LINE = 'drop-thumb-line';
10
11
  export var TheMode;
11
12
  (function (TheMode) {
12
13
  TheMode["fullMode"] = "full";
13
14
  TheMode["liteMode"] = "lite";
14
15
  })(TheMode || (TheMode = {}));
15
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVmYXVsdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL3NyYy9jb25zdGFudHMvZGVmYXVsdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSw0QkFBNEIsR0FBRyxDQUFDLFdBQVcsRUFBRSxZQUFZLEVBQUUsV0FBVyxFQUFFLFdBQVcsQ0FBQyxDQUFDO0FBQ2xHLE1BQU0sQ0FBQyxNQUFNLDRCQUE0QixHQUFHLEVBQUUsQ0FBQztBQUMvQyxNQUFNLENBQUMsTUFBTSxjQUFjLEdBQUcsMkNBQTJDLENBQUM7QUFDMUUsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsSUFBSSxDQUFDO0FBQ3RDLE1BQU0sQ0FBQyxNQUFNLFNBQVMsR0FBRyxNQUFNLENBQUM7QUFDaEMsTUFBTSxDQUFDLE1BQU0sb0JBQW9CLEdBQUcsa0JBQWtCLENBQUM7QUFDdkQsTUFBTSxDQUFDLE1BQU0sd0JBQXdCLEdBQUcseUJBQXlCLENBQUM7QUFDbEUsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsS0FBSyxDQUFDO0FBQ3ZDLE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBRyxRQUFRLENBQUM7QUFFeEMsTUFBTSxDQUFOLElBQVksT0FHWDtBQUhELFdBQVksT0FBTztJQUNmLDRCQUFpQixDQUFBO0lBQ2pCLDRCQUFpQixDQUFBO0FBQ3JCLENBQUMsRUFIVyxPQUFPLEtBQVAsT0FBTyxRQUdsQiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBQSUNUVVJFX0FDQ0VQVEVEX1VQTE9BRF9NSU1FID0gWydpbWFnZS9wbmcnLCAnaW1hZ2UvanBlZycsICdpbWFnZS9naWYnLCAnaW1hZ2UvYm1wJ107XG5leHBvcnQgY29uc3QgUElDVFVSRV9BQ0NFUFRFRF9VUExPQURfU0laRSA9IDIwO1xuZXhwb3J0IGNvbnN0IEFfVEFHX1JFTF9BVFRSID0gJ25vb3BlbmVyIG5vcmVmZXJyZXIgbm9mb2xsb3cgZXh0ZXJuYWwgdWdjJztcbmV4cG9ydCBjb25zdCBMSU5LX0RFRkFVTFRfVEVYVCA9ICfpk77mjqUnO1xuZXhwb3J0IGNvbnN0IFRBQl9TUEFDRSA9ICcgICAgJztcbmV4cG9ydCBjb25zdCBDTElQQk9BUkRfRk9STUFUX0tFWSA9ICd4LXRoZWlhLWZyYWdtZW50JztcbmV4cG9ydCBjb25zdCBERUZBVUxUX1NDUk9MTF9DT05UQUlORVIgPSAnLnRoZS1lZGl0YWJsZS1jb250YWluZXInO1xuZXhwb3J0IGNvbnN0IEVMRU1FTlRfVU5JUVVFX0lEID0gJ2tleSc7XG5leHBvcnQgY29uc3QgWkVST19XSURUSF9DSEFSID0gJ1xcdTIwMEInO1xuXG5leHBvcnQgZW51bSBUaGVNb2RlIHtcbiAgICBmdWxsTW9kZSA9ICdmdWxsJyxcbiAgICBsaXRlTW9kZSA9ICdsaXRlJ1xufVxuIl19
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVmYXVsdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL3NyYy9jb25zdGFudHMvZGVmYXVsdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSw0QkFBNEIsR0FBRyxDQUFDLFdBQVcsRUFBRSxZQUFZLEVBQUUsV0FBVyxFQUFFLFdBQVcsQ0FBQyxDQUFDO0FBQ2xHLE1BQU0sQ0FBQyxNQUFNLDRCQUE0QixHQUFHLEVBQUUsQ0FBQztBQUMvQyxNQUFNLENBQUMsTUFBTSxjQUFjLEdBQUcsMkNBQTJDLENBQUM7QUFDMUUsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsSUFBSSxDQUFDO0FBQ3RDLE1BQU0sQ0FBQyxNQUFNLFNBQVMsR0FBRyxNQUFNLENBQUM7QUFDaEMsTUFBTSxDQUFDLE1BQU0sb0JBQW9CLEdBQUcsa0JBQWtCLENBQUM7QUFDdkQsTUFBTSxDQUFDLE1BQU0sd0JBQXdCLEdBQUcseUJBQXlCLENBQUM7QUFDbEUsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsS0FBSyxDQUFDO0FBQ3ZDLE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBRyxRQUFRLENBQUM7QUFDeEMsTUFBTSxDQUFDLE1BQU0sZUFBZSxHQUFHLGlCQUFpQixDQUFDO0FBRWpELE1BQU0sQ0FBTixJQUFZLE9BR1g7QUFIRCxXQUFZLE9BQU87SUFDZiw0QkFBaUIsQ0FBQTtJQUNqQiw0QkFBaUIsQ0FBQTtBQUNyQixDQUFDLEVBSFcsT0FBTyxLQUFQLE9BQU8sUUFHbEIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgUElDVFVSRV9BQ0NFUFRFRF9VUExPQURfTUlNRSA9IFsnaW1hZ2UvcG5nJywgJ2ltYWdlL2pwZWcnLCAnaW1hZ2UvZ2lmJywgJ2ltYWdlL2JtcCddO1xuZXhwb3J0IGNvbnN0IFBJQ1RVUkVfQUNDRVBURURfVVBMT0FEX1NJWkUgPSAyMDtcbmV4cG9ydCBjb25zdCBBX1RBR19SRUxfQVRUUiA9ICdub29wZW5lciBub3JlZmVycmVyIG5vZm9sbG93IGV4dGVybmFsIHVnYyc7XG5leHBvcnQgY29uc3QgTElOS19ERUZBVUxUX1RFWFQgPSAn6ZO+5o6lJztcbmV4cG9ydCBjb25zdCBUQUJfU1BBQ0UgPSAnICAgICc7XG5leHBvcnQgY29uc3QgQ0xJUEJPQVJEX0ZPUk1BVF9LRVkgPSAneC10aGVpYS1mcmFnbWVudCc7XG5leHBvcnQgY29uc3QgREVGQVVMVF9TQ1JPTExfQ09OVEFJTkVSID0gJy50aGUtZWRpdGFibGUtY29udGFpbmVyJztcbmV4cG9ydCBjb25zdCBFTEVNRU5UX1VOSVFVRV9JRCA9ICdrZXknO1xuZXhwb3J0IGNvbnN0IFpFUk9fV0lEVEhfQ0hBUiA9ICdcXHUyMDBCJztcbmV4cG9ydCBjb25zdCBEUk9QX1RIVU1CX0xJTkUgPSAnZHJvcC10aHVtYi1saW5lJztcblxuZXhwb3J0IGVudW0gVGhlTW9kZSB7XG4gICAgZnVsbE1vZGUgPSAnZnVsbCcsXG4gICAgbGl0ZU1vZGUgPSAnbGl0ZSdcbn1cblxuZXhwb3J0IHR5cGUgRHJvcERpcmVjdGlvbiA9ICd0b3AnIHwgJ2JvdHRvbScgfCB1bmRlZmluZWQ7XG5cbmV4cG9ydCB0eXBlIE5vZGVMZXZlbCA9ICdoaWdoZXN0JyB8IHVuZGVmaW5lZDtcbiJdfQ==
@@ -37,6 +37,11 @@ export var VerticalAlignment;
37
37
  VerticalAlignment["middle"] = "middle";
38
38
  VerticalAlignment["bottom"] = "bottom";
39
39
  })(VerticalAlignment || (VerticalAlignment = {}));
40
+ export var LayoutTypes;
41
+ (function (LayoutTypes) {
42
+ LayoutTypes["wrapLeft"] = "wrap-left";
43
+ LayoutTypes["wrapRight"] = "wrap-right";
44
+ })(LayoutTypes || (LayoutTypes = {}));
40
45
  export var FontSizes;
41
46
  (function (FontSizes) {
42
47
  FontSizes["fontSize12"] = "12";
@@ -124,4 +129,4 @@ export const CONTAINER_BLOCKS = [ElementKinds.blockquote, ElementKinds.tableCell
124
129
  export const LIST_BLOCK_TYPES = [ElementKinds.numberedList, ElementKinds.bulletedList];
125
130
  export const VOID_BLOCK_TYPES = [ElementKinds.image, ElementKinds.hr];
126
131
  export const BLOCK_DELETEBACKWARD_TYPES = [ElementKinds.tableCell];
127
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-types.js","sourceRoot":"","sources":["../../../../packages/src/constants/node-types.ts"],"names":[],"mappings":"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","sourcesContent":["import { CustomElementKinds } from '../custom-types';\n\nexport enum ElementKinds {\n    image = 'image',\n    paragraph = 'paragraph',\n    headingList = 'heading-list',\n    heading_1 = 'heading-one',\n    heading_2 = 'heading-two',\n    heading_3 = 'heading-three',\n    heading_4 = 'heading-four',\n    heading_5 = 'heading-five',\n    heading_6 = 'heading-six',\n    numberedList = 'numbered-list',\n    bulletedList = 'bulleted-list',\n    listItem = 'list-item',\n    checkItem = 'check-item',\n    table = 'table',\n    tableRow = 'table-row',\n    tableCell = 'table-cell',\n    tableContent = 'paragraph',\n    code = 'code',\n    blockquote = 'block-quote',\n    hr = 'hr',\n    link = 'link',\n    default = 'paragraph',\n    inlineCode = 'inline-code',\n    indent = 'indent'\n}\n\nexport enum Alignment {\n    left = 'left',\n    center = 'center',\n    right = 'right'\n}\n\nexport enum VerticalAlignment {\n    top = 'top',\n    middle = 'middle',\n    bottom = 'bottom'\n}\n\nexport enum FontSizes {\n    'fontSize12' = '12',\n    'fontSize13' = '13',\n    'fontSize14' = '14',\n    'fontSize15' = '15',\n    'fontSize16' = '16',\n    'fontSize18' = '18',\n    'fontSize20' = '20',\n    'fontSize24' = '24',\n    'fontSize28' = '28',\n    'fontSize32' = '32',\n    'fontSize40' = '40',\n    'fontSize48' = '48'\n}\n\nexport const FontSizeTypes = [\n    FontSizes.fontSize12,\n    FontSizes.fontSize13,\n    FontSizes.fontSize14,\n    FontSizes.fontSize15,\n    FontSizes.fontSize16,\n    FontSizes.fontSize20,\n    FontSizes.fontSize24,\n    FontSizes.fontSize28,\n    FontSizes.fontSize32,\n    FontSizes.fontSize40,\n    FontSizes.fontSize48\n];\n\nexport enum Indents {\n    indentRight = 'indent-right',\n    indentLeft = 'indent-left'\n}\n\nexport enum MarkTypes {\n    bold = 'bold',\n    italic = 'italic',\n    underline = 'underlined',\n    strike = 'strike',\n    color = 'color',\n    backgroundColor = 'background-color',\n    fontSize = 'font-size',\n    codeLine = 'code-line'\n}\n\nexport enum ToolbarActionTypes {\n    split = 'split',\n    undo = 'undo',\n    redo = 'redo',\n    paintformat = 'paintformat',\n    clean = 'clean',\n    alignType = 'align-type',\n    alignLeft = 'align-left',\n    alignCenter = 'align-center',\n    alignRight = 'align-right',\n    verticalAlign = 'vertical-align',\n    verticalAlignTop = 'vertical-align-top',\n    verticalAlignMiddle = 'vertical-align-middle',\n    verticalAlignBottom = 'vertical-align-bottom',\n    headingList = 'heading-list',\n    tableRemove = 'table-remove',\n    tableDeleteRows = 'table-delete-rows',\n    tableDeleteColumns = 'table-delete-columns'\n}\n\nexport const MarkProps: Array<MarkTypes> = [\n    MarkTypes.backgroundColor,\n    MarkTypes.bold,\n    MarkTypes.color,\n    MarkTypes.italic,\n    MarkTypes.strike,\n    MarkTypes.underline,\n    MarkTypes.fontSize,\n    MarkTypes.codeLine\n];\n\nexport const THE_INLINE_TOOLBAR_TYPES: Array<ElementKinds> = [ElementKinds.default, ElementKinds.listItem, ElementKinds.checkItem];\n\nexport const STANDARD_HEADING_TYPES: CustomElementKinds[] = [\n    ElementKinds.heading_1,\n    ElementKinds.heading_2,\n    ElementKinds.heading_3,\n    ElementKinds.heading_4\n];\n\nexport const HEADING_TYPES: CustomElementKinds[] = [...STANDARD_HEADING_TYPES, ElementKinds.heading_5, ElementKinds.heading_6];\n\nexport const ALIGN_BLOCK_TYPES: CustomElementKinds[] = [ElementKinds.default, ElementKinds.listItem, ElementKinds.image, ...HEADING_TYPES];\n\nexport const CONTAINER_BLOCKS: CustomElementKinds[] = [ElementKinds.blockquote, ElementKinds.tableCell];\n\nexport const LIST_BLOCK_TYPES: CustomElementKinds[] = [ElementKinds.numberedList, ElementKinds.bulletedList];\n\nexport const VOID_BLOCK_TYPES: CustomElementKinds[] = [ElementKinds.image, ElementKinds.hr];\n\nexport const BLOCK_DELETEBACKWARD_TYPES: CustomElementKinds[] = [ElementKinds.tableCell];\n"]}
132
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-types.js","sourceRoot":"","sources":["../../../../packages/src/constants/node-types.ts"],"names":[],"mappings":"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","sourcesContent":["import { CustomElementKinds } from '../custom-types';\n\nexport enum ElementKinds {\n    image = 'image',\n    paragraph = 'paragraph',\n    headingList = 'heading-list',\n    heading_1 = 'heading-one',\n    heading_2 = 'heading-two',\n    heading_3 = 'heading-three',\n    heading_4 = 'heading-four',\n    heading_5 = 'heading-five',\n    heading_6 = 'heading-six',\n    numberedList = 'numbered-list',\n    bulletedList = 'bulleted-list',\n    listItem = 'list-item',\n    checkItem = 'check-item',\n    table = 'table',\n    tableRow = 'table-row',\n    tableCell = 'table-cell',\n    tableContent = 'paragraph',\n    code = 'code',\n    blockquote = 'block-quote',\n    hr = 'hr',\n    link = 'link',\n    default = 'paragraph',\n    inlineCode = 'inline-code',\n    indent = 'indent'\n}\n\nexport enum Alignment {\n    left = 'left',\n    center = 'center',\n    right = 'right'\n}\n\nexport enum VerticalAlignment {\n    top = 'top',\n    middle = 'middle',\n    bottom = 'bottom'\n}\n\nexport enum LayoutTypes {\n    wrapLeft = 'wrap-left',\n    wrapRight = 'wrap-right'\n}\n\nexport enum FontSizes {\n    'fontSize12' = '12',\n    'fontSize13' = '13',\n    'fontSize14' = '14',\n    'fontSize15' = '15',\n    'fontSize16' = '16',\n    'fontSize18' = '18',\n    'fontSize20' = '20',\n    'fontSize24' = '24',\n    'fontSize28' = '28',\n    'fontSize32' = '32',\n    'fontSize40' = '40',\n    'fontSize48' = '48'\n}\n\nexport const FontSizeTypes = [\n    FontSizes.fontSize12,\n    FontSizes.fontSize13,\n    FontSizes.fontSize14,\n    FontSizes.fontSize15,\n    FontSizes.fontSize16,\n    FontSizes.fontSize20,\n    FontSizes.fontSize24,\n    FontSizes.fontSize28,\n    FontSizes.fontSize32,\n    FontSizes.fontSize40,\n    FontSizes.fontSize48\n];\n\nexport enum Indents {\n    indentRight = 'indent-right',\n    indentLeft = 'indent-left'\n}\n\nexport enum MarkTypes {\n    bold = 'bold',\n    italic = 'italic',\n    underline = 'underlined',\n    strike = 'strike',\n    color = 'color',\n    backgroundColor = 'background-color',\n    fontSize = 'font-size',\n    codeLine = 'code-line'\n}\n\nexport enum ToolbarActionTypes {\n    split = 'split',\n    undo = 'undo',\n    redo = 'redo',\n    paintformat = 'paintformat',\n    clean = 'clean',\n    alignType = 'align-type',\n    alignLeft = 'align-left',\n    alignCenter = 'align-center',\n    alignRight = 'align-right',\n    verticalAlign = 'vertical-align',\n    verticalAlignTop = 'vertical-align-top',\n    verticalAlignMiddle = 'vertical-align-middle',\n    verticalAlignBottom = 'vertical-align-bottom',\n    headingList = 'heading-list',\n    tableRemove = 'table-remove',\n    tableDeleteRows = 'table-delete-rows',\n    tableDeleteColumns = 'table-delete-columns'\n}\n\nexport const MarkProps: Array<MarkTypes> = [\n    MarkTypes.backgroundColor,\n    MarkTypes.bold,\n    MarkTypes.color,\n    MarkTypes.italic,\n    MarkTypes.strike,\n    MarkTypes.underline,\n    MarkTypes.fontSize,\n    MarkTypes.codeLine\n];\n\nexport const THE_INLINE_TOOLBAR_TYPES: Array<ElementKinds> = [ElementKinds.default, ElementKinds.listItem, ElementKinds.checkItem];\n\nexport const STANDARD_HEADING_TYPES: CustomElementKinds[] = [\n    ElementKinds.heading_1,\n    ElementKinds.heading_2,\n    ElementKinds.heading_3,\n    ElementKinds.heading_4\n];\n\nexport const HEADING_TYPES: CustomElementKinds[] = [...STANDARD_HEADING_TYPES, ElementKinds.heading_5, ElementKinds.heading_6];\n\nexport const ALIGN_BLOCK_TYPES: CustomElementKinds[] = [ElementKinds.default, ElementKinds.listItem, ElementKinds.image, ...HEADING_TYPES];\n\nexport const CONTAINER_BLOCKS: CustomElementKinds[] = [ElementKinds.blockquote, ElementKinds.tableCell];\n\nexport const LIST_BLOCK_TYPES: CustomElementKinds[] = [ElementKinds.numberedList, ElementKinds.bulletedList];\n\nexport const VOID_BLOCK_TYPES: CustomElementKinds[] = [ElementKinds.image, ElementKinds.hr];\n\nexport const BLOCK_DELETEBACKWARD_TYPES: CustomElementKinds[] = [ElementKinds.tableCell];\n"]}