@worktile/theia 1.2.18 → 2.0.1

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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@worktile/theia",
3
- "version": "1.2.18",
3
+ "version": "2.0.1",
4
4
  "description": "theia editor",
5
5
  "author": "YanDong <nanianqiumo@foxmail.com>",
6
6
  "homepage": "https://github.com/atinc/theia#readme",
@@ -2,10 +2,9 @@ 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, TheCodeConfig, ToolbarItemMode } from '../../constants';
5
+ import { DropdownMode, TheCodeMode } 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;
@@ -15,16 +14,12 @@ export declare class TheCodeComponent extends TheBaseElementComponent<CodeElemen
15
14
  private config;
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, config: TheCodeConfig);
36
+ constructor(elementRef: ElementRef, cdr: ChangeDetectorRef, thyNotifyService: ThyNotifyService, ngZone: NgZone, config: TheCodeMode);
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
- .resize-code-container{
5
- display: block;
6
- font-size: 14px;
7
- position: relative;
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: scroll;
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
- setCodeAttribute(editor: Editor, element: CodeElement, value: {
5
- [key: string]: unknown;
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
  };
@@ -8,5 +8,4 @@ export declare const getSelectionMarks: (editor: Editor) => {
8
8
  color?: any;
9
9
  "background-color"?: any;
10
10
  "code-line"?: any;
11
- "font-size"?: any;
12
11
  };
@@ -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';
@@ -8,5 +8,4 @@ export declare const setMarks: (editor: Editor, marks: {
8
8
  color?: any;
9
9
  "background-color"?: any;
10
10
  "code-line"?: any;
11
- "font-size"?: any;
12
11
  }, at?: Path | Point | Range) => void;
@@ -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,3 +0,0 @@
1
- import { ToolbarItem } from '../../interfaces/toolbar';
2
- export declare const FontSizes: number[];
3
- export declare const FontSizeOptions: ToolbarItem[];
@@ -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
- }
@@ -1,13 +0,0 @@
1
- .the-font-size-toolbar-item {
2
- width: 60px;
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
- }