@worktile/theia 1.2.19 → 2.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/worktile-theia.umd.js +137 -323
- package/bundles/worktile-theia.umd.js.map +1 -1
- package/constants/code.d.ts +3 -3
- package/constants/node-types.d.ts +1 -2
- package/custom-types.d.ts +1 -3
- package/editor.module.d.ts +39 -43
- package/esm2015/components/text/text.component.js +2 -7
- package/esm2015/constants/code.js +2 -2
- package/esm2015/constants/node-types.js +2 -4
- package/esm2015/constants/toolbar.js +1 -2
- package/esm2015/custom-types.js +1 -1
- package/esm2015/editor.module.js +5 -14
- package/esm2015/plugins/code/code.component.js +33 -77
- package/esm2015/plugins/code/code.editor.js +9 -3
- package/esm2015/plugins/index.js +1 -3
- package/fesm2015/worktile-theia.js +106 -284
- package/fesm2015/worktile-theia.js.map +1 -1
- package/package.json +1 -1
- package/plugins/code/code.component.d.ts +5 -17
- package/plugins/code/code.component.scss +7 -46
- package/plugins/code/code.editor.d.ts +2 -3
- package/queries/get-selection-marks.d.ts +0 -1
- package/styles/editor.scss +0 -6
- package/styles/index.scss +0 -1
- package/transforms/set-marks.d.ts +0 -1
- package/esm2015/plugins/font-size/options.js +0 -11
- package/esm2015/plugins/font-size/toolbar-item.component.js +0 -129
- package/plugins/font-size/options.d.ts +0 -3
- package/plugins/font-size/toolbar-item.component.d.ts +0 -35
- package/plugins/font-size/toolbar-item.component.scss +0 -13
package/package.json
CHANGED
|
@@ -2,29 +2,24 @@ import { ElementRef, ChangeDetectorRef, OnInit, AfterViewInit, NgZone } from '@a
|
|
|
2
2
|
import { ThyNotifyService } from 'ngx-tethys/notify';
|
|
3
3
|
import { Editor } from 'slate';
|
|
4
4
|
import { CodeMirrorComponent } from 'ng-codemirror';
|
|
5
|
-
import { DropdownMode,
|
|
5
|
+
import { DropdownMode, CodeMode } from '../../constants';
|
|
6
6
|
import { DefaultToolbarItem, TheBaseElementComponent } from '../../interfaces';
|
|
7
7
|
import { CodeElement } from '../../custom-types';
|
|
8
|
-
import { ThyResizeEvent } from 'ngx-tethys/resizable';
|
|
9
8
|
import * as i0 from "@angular/core";
|
|
10
9
|
export declare class TheCodeComponent extends TheBaseElementComponent<CodeElement, Editor> implements OnInit, AfterViewInit {
|
|
11
10
|
elementRef: ElementRef;
|
|
12
11
|
cdr: ChangeDetectorRef;
|
|
13
12
|
private thyNotifyService;
|
|
14
13
|
private ngZone;
|
|
15
|
-
private
|
|
14
|
+
private mode;
|
|
16
15
|
startRenderCodemirror: boolean;
|
|
17
16
|
dropdownMode: typeof DropdownMode;
|
|
18
|
-
codeMirrorFocused: boolean;
|
|
19
17
|
maxHeight: number;
|
|
18
|
+
codeMirrorFocused: boolean;
|
|
20
19
|
menus: {
|
|
21
20
|
key: string;
|
|
22
21
|
name: string;
|
|
23
22
|
}[];
|
|
24
|
-
ToolbarItemMode: typeof ToolbarItemMode;
|
|
25
|
-
isAutoWrap: boolean;
|
|
26
|
-
isResizing: boolean;
|
|
27
|
-
resizeHeight: number;
|
|
28
23
|
options: {
|
|
29
24
|
mode: string;
|
|
30
25
|
lineNumbers: boolean;
|
|
@@ -37,26 +32,19 @@ export declare class TheCodeComponent extends TheBaseElementComponent<CodeElemen
|
|
|
37
32
|
actives: DefaultToolbarItem;
|
|
38
33
|
get code(): string;
|
|
39
34
|
codemirror: CodeMirrorComponent;
|
|
40
|
-
handleCodeMousedown(event: MouseEvent): void;
|
|
41
35
|
onContextChange(): void;
|
|
42
|
-
constructor(elementRef: ElementRef, cdr: ChangeDetectorRef, thyNotifyService: ThyNotifyService, ngZone: NgZone,
|
|
36
|
+
constructor(elementRef: ElementRef, cdr: ChangeDetectorRef, thyNotifyService: ThyNotifyService, ngZone: NgZone, mode: CodeMode);
|
|
43
37
|
ngOnInit(): void;
|
|
44
38
|
ngAfterViewInit(): void;
|
|
45
|
-
focusChange(codeMirrorFocused: boolean): void;
|
|
46
39
|
renderCodemirror(): void;
|
|
47
40
|
initializeCodemirrorFocus(): void;
|
|
48
41
|
codeChange($event: any): void;
|
|
42
|
+
focusChange(codeMirrorFocused: boolean): void;
|
|
49
43
|
onDelete(event: MouseEvent): void;
|
|
50
44
|
onCopy(event: MouseEvent): void;
|
|
51
45
|
onChangeLangulage: (item: any) => void;
|
|
52
46
|
useMode(): void;
|
|
53
|
-
useAutoWrap(): void;
|
|
54
|
-
useHeight(): void;
|
|
55
47
|
useReadonly(): void;
|
|
56
|
-
onResize({ height }: ThyResizeEvent): void;
|
|
57
|
-
onStartResize(): void;
|
|
58
|
-
onEndResize(): void;
|
|
59
|
-
onChangeWrap(value: boolean): void;
|
|
60
48
|
static ɵfac: i0.ɵɵFactoryDeclaration<TheCodeComponent, never>;
|
|
61
49
|
static ɵcmp: i0.ɵɵComponentDeclaration<TheCodeComponent, "div[theCode]", never, {}, {}, never, never>;
|
|
62
50
|
}
|
|
@@ -1,22 +1,18 @@
|
|
|
1
1
|
@import '~ng-codemirror/index.scss';
|
|
2
2
|
|
|
3
3
|
.the-code-container {
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
4
|
+
display: block;
|
|
5
|
+
font-size: 14px;
|
|
6
|
+
position: relative;
|
|
7
|
+
|
|
8
|
+
.CodeMirror {
|
|
9
|
+
height: auto;
|
|
8
10
|
counter-reset: codeblock-lm;
|
|
9
11
|
border: 1px solid $gray-300;
|
|
10
12
|
border-radius: 2px;
|
|
11
13
|
color: $gray-600;
|
|
12
14
|
background: rgba(243, 243, 243, 0.8);
|
|
13
|
-
}
|
|
14
|
-
.CodeMirror {
|
|
15
|
-
height: 100% !important;
|
|
16
15
|
z-index: 0;
|
|
17
|
-
color: $gray-600;
|
|
18
|
-
background: transparent;
|
|
19
|
-
border: none;
|
|
20
16
|
|
|
21
17
|
.CodeMirror-gutters {
|
|
22
18
|
border-right: none;
|
|
@@ -34,34 +30,7 @@
|
|
|
34
30
|
}
|
|
35
31
|
.ng-codemirror-wrapper {
|
|
36
32
|
display: block;
|
|
37
|
-
overflow:
|
|
38
|
-
position: relative;
|
|
39
|
-
height: 100%;
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
.code-resize-icon.thy-resizable-handle-bottom{
|
|
43
|
-
cursor: row-resize;
|
|
44
|
-
height: 8px;
|
|
45
|
-
width: 45px;
|
|
46
|
-
left: 50%;
|
|
47
|
-
transform: translateX(-50%);
|
|
48
|
-
background: $gray-300;
|
|
49
|
-
bottom: -5px;
|
|
50
|
-
border-radius: 5px;
|
|
51
|
-
position: absolute;
|
|
52
|
-
&::before, &:after{
|
|
53
|
-
content: '';
|
|
54
|
-
position: absolute;
|
|
55
|
-
width: 34px;
|
|
56
|
-
height: 1px;
|
|
57
|
-
background: $white;
|
|
58
|
-
left: 50%;
|
|
59
|
-
transform: translateX(-50%);
|
|
60
|
-
top: 2px;
|
|
61
|
-
}
|
|
62
|
-
&:after{
|
|
63
|
-
top: 5px;
|
|
64
|
-
}
|
|
33
|
+
overflow: hidden;
|
|
65
34
|
}
|
|
66
35
|
|
|
67
36
|
@include the-toolbar-active();
|
|
@@ -70,13 +39,5 @@
|
|
|
70
39
|
padding: 0;
|
|
71
40
|
width: 100px;
|
|
72
41
|
}
|
|
73
|
-
|
|
74
|
-
.auto-wrap{
|
|
75
|
-
padding-left: 8px;
|
|
76
|
-
.auto-wrap-btn{
|
|
77
|
-
margin-left: 5px;
|
|
78
|
-
transform: scale(0.8);
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
42
|
}
|
|
82
43
|
|
|
@@ -1,8 +1,7 @@
|
|
|
1
1
|
import { Editor } from 'slate';
|
|
2
2
|
import { CodeElement } from '../../custom-types';
|
|
3
3
|
export declare const CodeEditor: {
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
}): void;
|
|
4
|
+
setLanguage(editor: Editor, language: string, element: CodeElement): void;
|
|
5
|
+
setCodeContent(editor: Editor, content: string, element: CodeElement): void;
|
|
7
6
|
insertCode(editor: Editor): void;
|
|
8
7
|
};
|
package/styles/editor.scss
CHANGED
|
@@ -126,12 +126,6 @@ $thy-icon-nav-link-margin-right: 5px;
|
|
|
126
126
|
text-indent: 0;
|
|
127
127
|
color: $gray-700;
|
|
128
128
|
}
|
|
129
|
-
|
|
130
|
-
@each $size in 12, 13, 14, 15, 16, 19, 22, 24, 29, 32, 40, 48 {
|
|
131
|
-
[the-font-size="#{$size}"] {
|
|
132
|
-
font-size: #{$size}px;
|
|
133
|
-
}
|
|
134
|
-
}
|
|
135
129
|
}
|
|
136
130
|
|
|
137
131
|
.the-nav-split-line {
|
package/styles/index.scss
CHANGED
|
@@ -18,4 +18,3 @@
|
|
|
18
18
|
@import '../plugins/quick-insert/components/quick-insert.component.scss';
|
|
19
19
|
@import '../plugins/quick-insert/components/quick-toolbar/quick-toolbar.component.scss';
|
|
20
20
|
@import '../plugins/placeholder/placeholder.component.scss';
|
|
21
|
-
@import '../plugins/font-size/toolbar-item.component.scss';
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { MarkTypes } from '../../constants/node-types';
|
|
2
|
-
import { TheFontSizeToolbarItemComponent } from './toolbar-item.component';
|
|
3
|
-
export const FontSizes = [12, 13, 14, 15, 16, 19, 22, 24, 29, 32, 40, 48];
|
|
4
|
-
export const FontSizeOptions = [
|
|
5
|
-
{
|
|
6
|
-
key: MarkTypes.fontSize,
|
|
7
|
-
name: '字号',
|
|
8
|
-
iconComponent: TheFontSizeToolbarItemComponent
|
|
9
|
-
}
|
|
10
|
-
];
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3B0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3NyYy9wbHVnaW5zL2ZvbnQtc2l6ZS9vcHRpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUV2RCxPQUFPLEVBQUUsK0JBQStCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUUzRSxNQUFNLENBQUMsTUFBTSxTQUFTLEdBQUcsQ0FBQyxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUUsQ0FBQyxDQUFDO0FBRTFFLE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBa0I7SUFDMUM7UUFDSSxHQUFHLEVBQUUsU0FBUyxDQUFDLFFBQVE7UUFDdkIsSUFBSSxFQUFFLElBQUk7UUFDVixhQUFhLEVBQUUsK0JBQStCO0tBQ2pEO0NBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1hcmtUeXBlcyB9IGZyb20gJy4uLy4uL2NvbnN0YW50cy9ub2RlLXR5cGVzJztcbmltcG9ydCB7IFRvb2xiYXJJdGVtIH0gZnJvbSAnLi4vLi4vaW50ZXJmYWNlcy90b29sYmFyJztcbmltcG9ydCB7IFRoZUZvbnRTaXplVG9vbGJhckl0ZW1Db21wb25lbnQgfSBmcm9tICcuL3Rvb2xiYXItaXRlbS5jb21wb25lbnQnO1xuXG5leHBvcnQgY29uc3QgRm9udFNpemVzID0gWzEyLCAxMywgMTQsIDE1LCAxNiwgMTksIDIyLCAyNCwgMjksIDMyLCA0MCwgNDhdO1xuXG5leHBvcnQgY29uc3QgRm9udFNpemVPcHRpb25zOiBUb29sYmFySXRlbVtdID0gW1xuICAgIHtcbiAgICAgICAga2V5OiBNYXJrVHlwZXMuZm9udFNpemUsXG4gICAgICAgIG5hbWU6ICflrZflj7cnLFxuICAgICAgICBpY29uQ29tcG9uZW50OiBUaGVGb250U2l6ZVRvb2xiYXJJdGVtQ29tcG9uZW50XG4gICAgfVxuXTtcbiJdfQ==
|
|
@@ -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 }}px</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 }}px</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":"AAAA,OAAO,EAAE,SAAS,EAAc,WAAW,EAAE,YAAY,EAAE,KAAK,EAAuB,SAAS,EAAoB,MAAM,eAAe,CAAC;AAC1I,OAAO,EAAE,MAAM,EAAE,MAAM,OAAO,CAAC;AAE/B,OAAO,EAAE,2BAA2B,EAAE,MAAM,gEAAgE,CAAC;AAG7G,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AACtC,OAAO,KAAK,UAAU,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,aAAa,EAAE,SAAS,EAAE,MAAM,4BAA4B,CAAC;;;;;;;;;AAMtE,MAAM,OAAO,+BAAgC,SAAQ,2BAA2B;IAwC5E,YACW,UAAsB,EACrB,UAAsB,EACtB,gBAAkC,EAClC,OAAgB;QAExB,KAAK,EAAE,CAAC;QALD,eAAU,GAAV,UAAU,CAAY;QACrB,eAAU,GAAV,UAAU,CAAY;QACtB,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,YAAO,GAAP,OAAO,CAAS;QAvC5B,cAAS,GAAG,SAAS,CAAC;QACtB,aAAQ,GAAG,KAAK,CAAC;QACjB,iBAAY,GAAG,aAAa,CAAC;QAUwB,yBAAoB,GAAG,IAAI,CAAC;QAChC,wBAAmB,GAAG,IAAI,CAAC;IA6B5E,CAAC;IArCD,IAAI,MAAM;QACN,OAAO,IAAI,CAAC,kBAAkB,IAAI,IAAI,CAAC,kBAAkB,CAAC,aAAa,EAAE,IAAI,IAAI,CAAC,kBAAkB,CAAC,aAAa,EAAE,CAAC,WAAW,EAAE,CAAC;IACvI,CAAC;IAOD,IAAmC,YAAY;QAC3C,OAAO,IAAI,CAAC,QAAQ,CAAC;IACzB,CAAC;IAGD,cAAc,CAAC,KAAiB;;QAC5B,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAErB,IAAI,CAAA,MAAA,IAAI,CAAC,MAAM,0CAAE,QAAQ,KAAI,IAAI,CAAC,QAAQ,EAAE;YACxC,OAAO;SACV;QACD,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC/B,CAAC;IAGD,uBAAuB,CAAC,KAAiB;QACrC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAqB,CAAC,EAAE;YACtE,IAAI,CAAC,oBAAoB,EAAE,CAAC;SAC/B;IACL,CAAC;IAWD,QAAQ;QACJ,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;IACxC,CAAC;IAEM,YAAY,CAAC,MAAc;QAC9B,IAAI,MAAM,CAAC,SAAS,EAAE;YAClB,MAAM,WAAW,GAAG,UAAU,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;YACnD,IAAI,WAAW,IAAI,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE;gBAC7D,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;gBACvB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;gBACrB,OAAO;aACV;YAED,MAAM,KAAK,GAAG,UAAU,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC;YACnD,MAAM,YAAY,GAAG,KAAK,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;YAC/C,IAAI,CAAC,UAAU,GAAG,YAAY,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;YAClE,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;SACzB;IACL,CAAC;IAED,aAAa,CAAC,KAAiB,EAAE,IAAY;;QACzC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACrB,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAE5B,IAAI,CAAA,MAAA,IAAI,CAAC,MAAM,0CAAE,QAAQ,MAAI,MAAA,IAAI,CAAC,MAAM,0CAAE,QAAQ,CAAA,EAAE;YAChD,OAAO;SACV;QACD,MAAM,WAAW,GAAG,UAAU,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACxD,IAAI,WAAW,IAAI,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE;YAC7D,OAAO;SACV;QAED,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,EAAE,SAAS,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;IAC1D,CAAC;IAED,mBAAmB;;QACf,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE;YAClE,MAAM,EAAE,IAAI,CAAC,UAAU;YACvB,UAAU,EAAE,CAAC,8BAA8B,EAAE,MAAA,IAAI,CAAC,IAAI,0CAAE,GAAG,CAAC;YAC5D,SAAS,EAAE,YAAY;YACvB,cAAc,EAAE,KAAK;YACrB,gBAAgB,EAAE,IAAI;YACtB,WAAW,EAAE,KAAK;YAClB,MAAM,EAAE,EAAE;YACV,gBAAgB,EAAE,IAAI,CAAC,gBAAgB;YACvC,cAAc,EAAE,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,UAAU,EAAE;SAC7D,CAAC,CAAC;IACP,CAAC;IAED,oBAAoB;;QAChB,IAAI,IAAI,CAAC,kBAAkB,EAAE;YACzB,MAAA,IAAI,CAAC,kBAAkB,0CAAE,KAAK,EAAE,CAAC;SACpC;IACL,CAAC;;4HAtGQ,+BAA+B;gHAA/B,+BAA+B,+jBCd5C,qyBAmBA;2FDLa,+BAA+B;kBAJ3C,SAAS;mBAAC;oBACP,QAAQ,EAAE,4BAA4B;oBACtC,WAAW,EAAE,+BAA+B;iBAC/C;+KAEY,MAAM;sBAAd,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBAaN,gBAAgB;sBADf,SAAS;uBAAC,kBAAkB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAGM,oBAAoB;sBAAxE,WAAW;uBAAC,sCAAsC;gBACF,mBAAmB;sBAAnE,WAAW;uBAAC,kCAAkC;gBACZ,YAAY;sBAA9C,WAAW;uBAAC,gBAAgB;gBAK7B,cAAc;sBADb,YAAY;uBAAC,WAAW,EAAE,CAAC,QAAQ,CAAC;gBAWrC,uBAAuB;sBADtB,YAAY;uBAAC,qBAAqB,EAAE,CAAC,QAAQ,CAAC","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 }}px</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 }}px</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
|
-
}
|