@worktile/theia 2.1.1 → 2.1.2
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/bundles/worktile-theia.umd.js +166 -157
- package/bundles/worktile-theia.umd.js.map +1 -1
- package/components/toolbar/toolbar.component.d.ts +4 -1
- package/components/toolbar/toolbar.component.scss +2 -0
- package/components/toolbar-dropdown/toolbar-dropdown.component.d.ts +7 -5
- package/components/toolbar-dropdown/toolbar-dropdown.component.scss +2 -0
- package/components/toolbar-item/toolbar-item.component.d.ts +3 -0
- package/constants/node-types.d.ts +15 -0
- package/editor.module.d.ts +41 -43
- package/esm2015/components/inline-toolbar/inline-toolbar.component.js +1 -1
- package/esm2015/components/toolbar/toolbar.component.js +18 -6
- package/esm2015/components/toolbar-dropdown/toolbar-dropdown.component.js +14 -5
- package/esm2015/components/toolbar-group/toolbar-group.component.js +1 -1
- package/esm2015/components/toolbar-item/toolbar-item.component.js +20 -6
- package/esm2015/constants/node-types.js +29 -1
- package/esm2015/editor.component.js +2 -2
- package/esm2015/editor.module.js +3 -6
- package/esm2015/interfaces/editor.js +1 -1
- package/esm2015/interfaces/toolbar.js +1 -1
- package/esm2015/plugins/align/options.js +2 -1
- package/esm2015/plugins/code/code.component.js +2 -2
- package/esm2015/plugins/font-size/font-size.editor.js +47 -0
- package/esm2015/plugins/font-size/options.js +20 -6
- package/esm2015/plugins/heading/heading.editor.js +11 -2
- package/esm2015/plugins/heading/options.js +2 -1
- package/esm2015/plugins/table/table.editor.js +1 -1
- package/esm2015/services/toolbar.service.js +2 -2
- package/fesm2015/worktile-theia.js +141 -130
- package/fesm2015/worktile-theia.js.map +1 -1
- package/interfaces/editor.d.ts +3 -1
- package/interfaces/toolbar.d.ts +2 -1
- package/package.json +1 -1
- package/plugins/code/code.component.scss +0 -1
- package/plugins/font-size/font-size.editor.d.ts +8 -0
- package/plugins/font-size/options.d.ts +0 -1
- package/plugins/font-size/toolbar-item.component.scss +1 -11
- package/plugins/heading/heading.editor.d.ts +1 -1
- package/plugins/table/table.editor.d.ts +1 -1
- package/styles/editor.scss +13 -1
- package/styles/typo.scss +2 -1
- package/esm2015/plugins/font-size/toolbar-item.component.js +0 -129
- package/plugins/font-size/toolbar-item.component.d.ts +0 -35
package/interfaces/editor.d.ts
CHANGED
|
@@ -1,9 +1,10 @@
|
|
|
1
|
-
import { ElementOptionsInfo } from './valid-children-types';
|
|
2
1
|
import { Ancestor, Range, Path, Point, Node, Span, NodeEntry, Editor, Element, Text } from 'slate';
|
|
3
2
|
import { AngularEditor, ViewType } from 'slate-angular';
|
|
4
3
|
import { HistoryEditor } from 'slate-history';
|
|
4
|
+
import { ElementOptionsInfo } from './valid-children-types';
|
|
5
5
|
import { Predicate } from '../utils/match';
|
|
6
6
|
import { ToolbarOption } from './toolbar';
|
|
7
|
+
import { FontSizes } from '../constants/node-types';
|
|
7
8
|
export interface TheEditor extends AngularEditor, HistoryEditor {
|
|
8
9
|
renderElement: (element: Element) => ViewType;
|
|
9
10
|
renderLeaf: (text: Text) => ViewType;
|
|
@@ -72,6 +73,7 @@ export interface TheOptions {
|
|
|
72
73
|
isMustShowPlaceholder?: boolean;
|
|
73
74
|
scrollContainer?: string;
|
|
74
75
|
maxHeight?: number;
|
|
76
|
+
fontSize?: FontSizes;
|
|
75
77
|
toolbar?: ToolbarOption;
|
|
76
78
|
disablePlugins?: string[];
|
|
77
79
|
extraElementOptions?: ElementOptionsInfo[];
|
package/interfaces/toolbar.d.ts
CHANGED
|
@@ -20,7 +20,7 @@ interface ToolbarItemBase {
|
|
|
20
20
|
key: ToolbarKey;
|
|
21
21
|
execute?: (editor: Editor) => void;
|
|
22
22
|
active?: (editor: Editor) => boolean | string;
|
|
23
|
-
disable?: (editor: Editor) => boolean
|
|
23
|
+
disable?: (editor: Editor) => boolean;
|
|
24
24
|
transformToolbar?: (editor: Editor) => ToolbarDefinition | void;
|
|
25
25
|
styles?: {
|
|
26
26
|
[key: string]: string;
|
|
@@ -32,6 +32,7 @@ export interface CustomizeToolbarItem extends ToolbarItemBase {
|
|
|
32
32
|
quickItemComponent?: ComponentType<any>;
|
|
33
33
|
type?: ToolbarItemType;
|
|
34
34
|
dropdownMode?: DropdownMode;
|
|
35
|
+
dropdownItemKey?: ToolbarKey;
|
|
35
36
|
}
|
|
36
37
|
export interface DefaultToolbarItem extends ToolbarItemBase {
|
|
37
38
|
icon?: string;
|
package/package.json
CHANGED
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { Editor } from 'slate';
|
|
2
|
+
import { TheEditor } from '../../interfaces/editor';
|
|
3
|
+
import { FontSizes } from '../../constants/node-types';
|
|
4
|
+
export declare const FontSizeEditor: {
|
|
5
|
+
setFontSize(editor: TheEditor, size: FontSizes): void;
|
|
6
|
+
isFontSizeActive(editor: Editor, size: FontSizes): boolean;
|
|
7
|
+
isDisabled(editor: TheEditor): boolean;
|
|
8
|
+
};
|
|
@@ -1,15 +1,5 @@
|
|
|
1
|
-
.the-font-size
|
|
1
|
+
.the-toolbar-dropdown-container.font-size {
|
|
2
2
|
width: 45px;
|
|
3
|
-
|
|
4
|
-
&.disabled {
|
|
5
|
-
cursor: not-allowed;
|
|
6
|
-
opacity: 0.25;
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
.thy-icon-nav-link {
|
|
10
|
-
pointer-events: none;
|
|
11
|
-
}
|
|
12
|
-
}
|
|
13
3
|
}
|
|
14
4
|
.the-toolbar-dropdown-popover.font-size {
|
|
15
5
|
.thy-popover-container {
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Editor } from 'slate';
|
|
2
|
-
import { HeadingElementKinds } from '../../
|
|
2
|
+
import { HeadingElementKinds } from '../../interfaces/element';
|
|
3
3
|
export declare const HeadingEditor: {
|
|
4
4
|
setHeading(editor: Editor, heading: HeadingElementKinds): void;
|
|
5
5
|
isHeadingActive(editor: Editor, heading: HeadingElementKinds): boolean;
|
|
@@ -17,7 +17,7 @@ export declare const TableEditor: {
|
|
|
17
17
|
setAlign(editor: Editor, alignment: Alignment): boolean;
|
|
18
18
|
setVerticalAlign(editor: TheEditor, alignment: VerticalAlignment): boolean;
|
|
19
19
|
isVerticalAlignActive(editor: TheEditor, alignment: VerticalAlignment): boolean;
|
|
20
|
-
toggleMark(editor: TheEditor, isActive: boolean, format: string | string[], value?: string | boolean): boolean;
|
|
20
|
+
toggleMark(editor: TheEditor, isActive: boolean, format: string | string[], value?: string | number | boolean): boolean;
|
|
21
21
|
clearMark(editor: TheEditor): boolean;
|
|
22
22
|
handleSelectedCells(editor: TheEditor, handle: (cellPath: Path, cellRange: Range) => void): boolean;
|
|
23
23
|
isActiveHeader(editor: TheEditor): boolean;
|
package/styles/editor.scss
CHANGED
|
@@ -127,9 +127,10 @@ $thy-icon-nav-link-margin-right: 5px;
|
|
|
127
127
|
color: $gray-700;
|
|
128
128
|
}
|
|
129
129
|
|
|
130
|
-
@each $size in 12, 13, 14, 15, 16,
|
|
130
|
+
@each $size in 12, 13, 14, 15, 16, 18, 20, 24, 28, 32, 40, 48 {
|
|
131
131
|
[the-font-size="#{$size}"] {
|
|
132
132
|
font-size: #{$size}px;
|
|
133
|
+
line-height: $font-size-line-height;
|
|
133
134
|
}
|
|
134
135
|
}
|
|
135
136
|
}
|
|
@@ -182,6 +183,17 @@ $thy-icon-nav-link-margin-right: 5px;
|
|
|
182
183
|
}
|
|
183
184
|
}
|
|
184
185
|
|
|
186
|
+
@mixin the-toolbar-disabled {
|
|
187
|
+
&.disabled {
|
|
188
|
+
cursor: not-allowed;
|
|
189
|
+
opacity: 0.25;
|
|
190
|
+
|
|
191
|
+
.thy-icon-nav-link {
|
|
192
|
+
pointer-events: none;
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
|
|
185
197
|
@mixin the-toolbar-layout {
|
|
186
198
|
position: absolute;
|
|
187
199
|
padding: 5px 10px;
|
package/styles/typo.scss
CHANGED
|
@@ -16,6 +16,7 @@ $block-mb: 8px;
|
|
|
16
16
|
$block-line-heith: 24px;
|
|
17
17
|
$nav-item-margin: 5px;
|
|
18
18
|
$selection-background: rgba($color: $primary, $alpha: 0.3);
|
|
19
|
+
$font-size-line-height: 1.5;
|
|
19
20
|
.the-editor-typo {
|
|
20
21
|
font-size: $the-font-size-base;
|
|
21
22
|
min-height: 140px;
|
|
@@ -171,4 +172,4 @@ $selection-background: rgba($color: $primary, $alpha: 0.3);
|
|
|
171
172
|
margin-left: 2em * $i;
|
|
172
173
|
}
|
|
173
174
|
}
|
|
174
|
-
}
|
|
175
|
+
}
|
|
@@ -1,129 +0,0 @@
|
|
|
1
|
-
import { Component, HostBinding, HostListener, Input, ViewChild } from '@angular/core';
|
|
2
|
-
import { Editor } from 'slate';
|
|
3
|
-
import { TheToolbarBaseItemComponent } from '../../components/toolbar-base-item/toolbar-base-item.component';
|
|
4
|
-
import { FontSizes } from './options';
|
|
5
|
-
import * as TheQueries from '../../queries';
|
|
6
|
-
import { HEADING_TYPES, MarkTypes } from '../../constants/node-types';
|
|
7
|
-
import * as i0 from "@angular/core";
|
|
8
|
-
import * as i1 from "ngx-tethys/popover";
|
|
9
|
-
import * as i2 from "@angular/cdk/overlay";
|
|
10
|
-
import * as i3 from "ngx-tethys/nav";
|
|
11
|
-
import * as i4 from "ngx-tethys/icon";
|
|
12
|
-
import * as i5 from "ngx-tethys/action-menu";
|
|
13
|
-
import * as i6 from "ngx-tethys/tooltip";
|
|
14
|
-
import * as i7 from "@angular/common";
|
|
15
|
-
export class TheFontSizeToolbarItemComponent extends TheToolbarBaseItemComponent {
|
|
16
|
-
constructor(elementRef, thyPopover, viewContainerRef, overlay) {
|
|
17
|
-
super();
|
|
18
|
-
this.elementRef = elementRef;
|
|
19
|
-
this.thyPopover = thyPopover;
|
|
20
|
-
this.viewContainerRef = viewContainerRef;
|
|
21
|
-
this.overlay = overlay;
|
|
22
|
-
this.fontSizes = FontSizes;
|
|
23
|
-
this.disabled = false;
|
|
24
|
-
this.disableGroup = HEADING_TYPES;
|
|
25
|
-
this.toolbarItemContainer = true;
|
|
26
|
-
this.fontSizeToolbarItem = true;
|
|
27
|
-
}
|
|
28
|
-
get isOpen() {
|
|
29
|
-
return this.dropdownPopoverRef && this.dropdownPopoverRef.getOverlayRef() && this.dropdownPopoverRef.getOverlayRef().hasAttached();
|
|
30
|
-
}
|
|
31
|
-
get disableClass() {
|
|
32
|
-
return this.disabled;
|
|
33
|
-
}
|
|
34
|
-
toggleDropdown(event) {
|
|
35
|
-
var _a;
|
|
36
|
-
super.execute(event);
|
|
37
|
-
if (((_a = this.editor) === null || _a === void 0 ? void 0 : _a.disabled) || this.disabled) {
|
|
38
|
-
return;
|
|
39
|
-
}
|
|
40
|
-
this.openDropdownPopover();
|
|
41
|
-
}
|
|
42
|
-
handleDocumentMouseDown(event) {
|
|
43
|
-
if (!this.elementRef.nativeElement.contains(event.target)) {
|
|
44
|
-
this.closeDropdownPopover();
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
ngOnInit() {
|
|
48
|
-
this.activeSize = this.fontSizes[2];
|
|
49
|
-
}
|
|
50
|
-
statusChange(editor) {
|
|
51
|
-
if (editor.selection) {
|
|
52
|
-
const anchorBlock = TheQueries.anchorBlock(editor);
|
|
53
|
-
if (anchorBlock && this.disableGroup.includes(anchorBlock.type)) {
|
|
54
|
-
this.activeSize = null;
|
|
55
|
-
this.disabled = true;
|
|
56
|
-
return;
|
|
57
|
-
}
|
|
58
|
-
const marks = TheQueries.getSelectionMarks(editor);
|
|
59
|
-
const fontSizeMark = marks[MarkTypes.fontSize];
|
|
60
|
-
this.activeSize = fontSizeMark ? fontSizeMark : this.fontSizes[2];
|
|
61
|
-
this.disabled = false;
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
itemMousedown(event, size) {
|
|
65
|
-
var _a, _b;
|
|
66
|
-
super.execute(event);
|
|
67
|
-
this.closeDropdownPopover();
|
|
68
|
-
if (((_a = this.editor) === null || _a === void 0 ? void 0 : _a.disabled) || ((_b = this.editor) === null || _b === void 0 ? void 0 : _b.readOnly)) {
|
|
69
|
-
return;
|
|
70
|
-
}
|
|
71
|
-
const anchorBlock = TheQueries.anchorBlock(this.editor);
|
|
72
|
-
if (anchorBlock && this.disableGroup.includes(anchorBlock.type)) {
|
|
73
|
-
return;
|
|
74
|
-
}
|
|
75
|
-
Editor.addMark(this.editor, MarkTypes.fontSize, size);
|
|
76
|
-
}
|
|
77
|
-
openDropdownPopover() {
|
|
78
|
-
var _a;
|
|
79
|
-
this.dropdownPopoverRef = this.thyPopover.open(this.dropdownTemplate, {
|
|
80
|
-
origin: this.elementRef,
|
|
81
|
-
panelClass: ['the-toolbar-dropdown-popover', (_a = this.item) === null || _a === void 0 ? void 0 : _a.key],
|
|
82
|
-
placement: 'bottomLeft',
|
|
83
|
-
insideClosable: false,
|
|
84
|
-
backdropClosable: true,
|
|
85
|
-
hasBackdrop: false,
|
|
86
|
-
offset: 10,
|
|
87
|
-
viewContainerRef: this.viewContainerRef,
|
|
88
|
-
scrollStrategy: this.overlay.scrollStrategies.reposition()
|
|
89
|
-
});
|
|
90
|
-
}
|
|
91
|
-
closeDropdownPopover() {
|
|
92
|
-
var _a;
|
|
93
|
-
if (this.dropdownPopoverRef) {
|
|
94
|
-
(_a = this.dropdownPopoverRef) === null || _a === void 0 ? void 0 : _a.close();
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
TheFontSizeToolbarItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.7", ngImport: i0, type: TheFontSizeToolbarItemComponent, deps: [{ token: i0.ElementRef }, { token: i1.ThyPopover }, { token: i0.ViewContainerRef }, { token: i2.Overlay }], target: i0.ɵɵFactoryTarget.Component });
|
|
99
|
-
TheFontSizeToolbarItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.7", type: TheFontSizeToolbarItemComponent, selector: "the-font-size-toolbar-item", inputs: { editor: "editor", item: "item" }, host: { listeners: { "mousedown": "toggleDropdown($event)", "document: mousedown": "handleDocumentMouseDown($event)" }, properties: { "class.the-toolbar-dropdown-container": "this.toolbarItemContainer", "class.the-font-size-toolbar-item": "this.fontSizeToolbarItem", "class.disabled": "this.disableClass" } }, viewQueries: [{ propertyName: "dropdownTemplate", first: true, predicate: ["dropdownTemplate"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<a thyIconNavLink class=\"text-mode\" [thyTooltip]=\"item?.name\" thyTooltipPlacement=\"top\">\n <span *ngIf=\"activeSize\" class=\"show-text\">{{ activeSize }}</span>\n <thy-icon class=\"text-caret-down-icon font-size-sm text-desc\" thyIconName=\"caret-down\"></thy-icon>\n</a>\n\n<ng-template #dropdownTemplate>\n <thy-action-menu class=\"dropdown\">\n <ng-container *ngFor=\"let size of fontSizes\">\n <a\n thyActionMenuItem\n href=\"javascript:;\"\n [thyActionMenuItemActive]=\"size === activeSize\"\n (mousedown)=\"itemMousedown($event, size)\"\n >\n <span thyActionMenuItemName>{{ size }}</span>\n </a>\n </ng-container>\n </thy-action-menu>\n</ng-template>\n", components: [{ type: i3.ThyIconNavLinkComponent, selector: "[thyIconNavLink]", inputs: ["thyIconNavLinkIcon", "thyIconNavLinkActive"] }, { type: i4.ThyIconComponent, selector: "thy-icon", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { type: i5.ThyActionMenuComponent, selector: "thy-action-menu", inputs: ["thyTheme", "thyWidth"] }], directives: [{ type: i6.ThyTooltipDirective, selector: "[thyTooltip],[thy-tooltip]", inputs: ["thyTooltip", "thyTooltipPlacement", "thyTooltipClass", "thyTooltipShowDelay", "thyTooltipHideDelay", "thyTooltipTrigger", "thyTooltipDisabled", "thyTooltipTemplateContext", "thyTooltipOffset", "thyTooltipPin"], exportAs: ["thyTooltip"] }, { type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i5.ThyActionMenuItemDirective, selector: "[thyActionMenuItem]", inputs: ["thyDisabled", "thyType"] }, { type: i5.ThyActionMenuItemActiveDirective, selector: "[thyActionMenuItemActive]", inputs: ["thyActionMenuItemActive"] }, { type: i5.ThyActionMenuItemNameDirective, selector: "[thyActionMenuItemName]" }] });
|
|
100
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.7", ngImport: i0, type: TheFontSizeToolbarItemComponent, decorators: [{
|
|
101
|
-
type: Component,
|
|
102
|
-
args: [{
|
|
103
|
-
selector: 'the-font-size-toolbar-item',
|
|
104
|
-
templateUrl: './toolbar-item.component.html'
|
|
105
|
-
}]
|
|
106
|
-
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.ThyPopover }, { type: i0.ViewContainerRef }, { type: i2.Overlay }]; }, propDecorators: { editor: [{
|
|
107
|
-
type: Input
|
|
108
|
-
}], item: [{
|
|
109
|
-
type: Input
|
|
110
|
-
}], dropdownTemplate: [{
|
|
111
|
-
type: ViewChild,
|
|
112
|
-
args: ['dropdownTemplate', { static: true }]
|
|
113
|
-
}], toolbarItemContainer: [{
|
|
114
|
-
type: HostBinding,
|
|
115
|
-
args: ['class.the-toolbar-dropdown-container']
|
|
116
|
-
}], fontSizeToolbarItem: [{
|
|
117
|
-
type: HostBinding,
|
|
118
|
-
args: ['class.the-font-size-toolbar-item']
|
|
119
|
-
}], disableClass: [{
|
|
120
|
-
type: HostBinding,
|
|
121
|
-
args: ['class.disabled']
|
|
122
|
-
}], toggleDropdown: [{
|
|
123
|
-
type: HostListener,
|
|
124
|
-
args: ['mousedown', ['$event']]
|
|
125
|
-
}], handleDocumentMouseDown: [{
|
|
126
|
-
type: HostListener,
|
|
127
|
-
args: ['document: mousedown', ['$event']]
|
|
128
|
-
}] } });
|
|
129
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolbar-item.component.js","sourceRoot":"","sources":["../../../../../packages/src/plugins/font-size/toolbar-item.component.ts","../../../../../packages/src/plugins/font-size/toolbar-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, HostBinding, HostListener, Input, OnInit, TemplateRef, ViewChild, ViewContainerRef } from '@angular/core';\nimport { Editor } from 'slate';\nimport { ToolbarItem } from '../../interfaces/toolbar';\nimport { TheToolbarBaseItemComponent } from '../../components/toolbar-base-item/toolbar-base-item.component';\nimport { ThyPopover, ThyPopoverRef } from 'ngx-tethys/popover';\nimport { Overlay } from '@angular/cdk/overlay';\nimport { FontSizes } from './options';\nimport * as TheQueries from '../../queries';\nimport { HEADING_TYPES, MarkTypes } from '../../constants/node-types';\n\n@Component({\n    selector: 'the-font-size-toolbar-item',\n    templateUrl: './toolbar-item.component.html'\n})\nexport class TheFontSizeToolbarItemComponent extends TheToolbarBaseItemComponent implements OnInit {\n    @Input() editor: Editor;\n    @Input() item: ToolbarItem;\n\n    activeSize: number | string;\n    fontSizes = FontSizes;\n    disabled = false;\n    disableGroup = HEADING_TYPES;\n    dropdownPopoverRef: ThyPopoverRef<any>;\n\n    get isOpen() {\n        return this.dropdownPopoverRef && this.dropdownPopoverRef.getOverlayRef() && this.dropdownPopoverRef.getOverlayRef().hasAttached();\n    }\n\n    @ViewChild('dropdownTemplate', { static: true })\n    dropdownTemplate: TemplateRef<any>;\n\n    @HostBinding('class.the-toolbar-dropdown-container') toolbarItemContainer = true;\n    @HostBinding('class.the-font-size-toolbar-item') fontSizeToolbarItem = true;\n    @HostBinding('class.disabled') get disableClass() {\n        return this.disabled;\n    }\n\n    @HostListener('mousedown', ['$event'])\n    toggleDropdown(event: MouseEvent) {\n        super.execute(event);\n\n        if (this.editor?.disabled || this.disabled) {\n            return;\n        }\n        this.openDropdownPopover();\n    }\n\n    @HostListener('document: mousedown', ['$event'])\n    handleDocumentMouseDown(event: MouseEvent) {\n        if (!this.elementRef.nativeElement.contains(event.target as HTMLElement)) {\n            this.closeDropdownPopover();\n        }\n    }\n\n    constructor(\n        public elementRef: ElementRef,\n        private thyPopover: ThyPopover,\n        private viewContainerRef: ViewContainerRef,\n        private overlay: Overlay\n    ) {\n        super();\n    }\n\n    ngOnInit() {\n        this.activeSize = this.fontSizes[2];\n    }\n\n    public statusChange(editor: Editor) {\n        if (editor.selection) {\n            const anchorBlock = TheQueries.anchorBlock(editor);\n            if (anchorBlock && this.disableGroup.includes(anchorBlock.type)) {\n                this.activeSize = null;\n                this.disabled = true;\n                return;\n            }\n\n            const marks = TheQueries.getSelectionMarks(editor);\n            const fontSizeMark = marks[MarkTypes.fontSize];\n            this.activeSize = fontSizeMark ? fontSizeMark : this.fontSizes[2];\n            this.disabled = false;\n        }\n    }\n\n    itemMousedown(event: MouseEvent, size: number): void {\n        super.execute(event);\n        this.closeDropdownPopover();\n\n        if (this.editor?.disabled || this.editor?.readOnly) {\n            return;\n        }\n        const anchorBlock = TheQueries.anchorBlock(this.editor);\n        if (anchorBlock && this.disableGroup.includes(anchorBlock.type)) {\n            return;\n        }\n\n        Editor.addMark(this.editor, MarkTypes.fontSize, size);\n    }\n\n    openDropdownPopover() {\n        this.dropdownPopoverRef = this.thyPopover.open(this.dropdownTemplate, {\n            origin: this.elementRef,\n            panelClass: ['the-toolbar-dropdown-popover', this.item?.key],\n            placement: 'bottomLeft',\n            insideClosable: false,\n            backdropClosable: true,\n            hasBackdrop: false,\n            offset: 10,\n            viewContainerRef: this.viewContainerRef,\n            scrollStrategy: this.overlay.scrollStrategies.reposition()\n        });\n    }\n\n    closeDropdownPopover() {\n        if (this.dropdownPopoverRef) {\n            this.dropdownPopoverRef?.close();\n        }\n    }\n}\n","<a thyIconNavLink class=\"text-mode\" [thyTooltip]=\"item?.name\" thyTooltipPlacement=\"top\">\n    <span *ngIf=\"activeSize\" class=\"show-text\">{{ activeSize }}</span>\n    <thy-icon class=\"text-caret-down-icon font-size-sm text-desc\" thyIconName=\"caret-down\"></thy-icon>\n</a>\n\n<ng-template #dropdownTemplate>\n    <thy-action-menu class=\"dropdown\">\n        <ng-container *ngFor=\"let size of fontSizes\">\n            <a\n                thyActionMenuItem\n                href=\"javascript:;\"\n                [thyActionMenuItemActive]=\"size === activeSize\"\n                (mousedown)=\"itemMousedown($event, size)\"\n            >\n                <span thyActionMenuItemName>{{ size }}</span>\n            </a>\n        </ng-container>\n    </thy-action-menu>\n</ng-template>\n"]}
|
|
@@ -1,35 +0,0 @@
|
|
|
1
|
-
import { ElementRef, OnInit, TemplateRef, ViewContainerRef } from '@angular/core';
|
|
2
|
-
import { Editor } from 'slate';
|
|
3
|
-
import { ToolbarItem } from '../../interfaces/toolbar';
|
|
4
|
-
import { TheToolbarBaseItemComponent } from '../../components/toolbar-base-item/toolbar-base-item.component';
|
|
5
|
-
import { ThyPopover, ThyPopoverRef } from 'ngx-tethys/popover';
|
|
6
|
-
import { Overlay } from '@angular/cdk/overlay';
|
|
7
|
-
import * as i0 from "@angular/core";
|
|
8
|
-
export declare class TheFontSizeToolbarItemComponent extends TheToolbarBaseItemComponent implements OnInit {
|
|
9
|
-
elementRef: ElementRef;
|
|
10
|
-
private thyPopover;
|
|
11
|
-
private viewContainerRef;
|
|
12
|
-
private overlay;
|
|
13
|
-
editor: Editor;
|
|
14
|
-
item: ToolbarItem;
|
|
15
|
-
activeSize: number | string;
|
|
16
|
-
fontSizes: number[];
|
|
17
|
-
disabled: boolean;
|
|
18
|
-
disableGroup: (import("../../constants/node-types").ElementKinds.image | import("../../constants/node-types").ElementKinds.paragraph | import("../../constants/node-types").ElementKinds.heading_1 | import("../../constants/node-types").ElementKinds.heading_2 | import("../../constants/node-types").ElementKinds.heading_3 | import("../../constants/node-types").ElementKinds.heading_4 | import("../../constants/node-types").ElementKinds.heading_5 | import("../../constants/node-types").ElementKinds.heading_6 | import("../../constants/node-types").ElementKinds.numberedList | import("../../constants/node-types").ElementKinds.bulletedList | import("../../constants/node-types").ElementKinds.listItem | import("../../constants/node-types").ElementKinds.checkItem | import("../../constants/node-types").ElementKinds.table | import("../../constants/node-types").ElementKinds.tableRow | import("../../constants/node-types").ElementKinds.tableCell | import("../../constants/node-types").ElementKinds.code | import("../../constants/node-types").ElementKinds.blockquote | import("../../constants/node-types").ElementKinds.hr | import("../../constants/node-types").ElementKinds.link)[];
|
|
19
|
-
dropdownPopoverRef: ThyPopoverRef<any>;
|
|
20
|
-
get isOpen(): boolean;
|
|
21
|
-
dropdownTemplate: TemplateRef<any>;
|
|
22
|
-
toolbarItemContainer: boolean;
|
|
23
|
-
fontSizeToolbarItem: boolean;
|
|
24
|
-
get disableClass(): boolean;
|
|
25
|
-
toggleDropdown(event: MouseEvent): void;
|
|
26
|
-
handleDocumentMouseDown(event: MouseEvent): void;
|
|
27
|
-
constructor(elementRef: ElementRef, thyPopover: ThyPopover, viewContainerRef: ViewContainerRef, overlay: Overlay);
|
|
28
|
-
ngOnInit(): void;
|
|
29
|
-
statusChange(editor: Editor): void;
|
|
30
|
-
itemMousedown(event: MouseEvent, size: number): void;
|
|
31
|
-
openDropdownPopover(): void;
|
|
32
|
-
closeDropdownPopover(): void;
|
|
33
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<TheFontSizeToolbarItemComponent, never>;
|
|
34
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<TheFontSizeToolbarItemComponent, "the-font-size-toolbar-item", never, { "editor": "editor"; "item": "item"; }, {}, never, never>;
|
|
35
|
-
}
|