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