@worktile/theia 14.0.3 → 14.0.5
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/editor.module.d.ts +1 -1
- package/esm2020/plugins/code/code.component.mjs +83 -26
- package/esm2020/plugins/hr/hr.editor.mjs +9 -1
- package/esm2020/plugins/image/image.component.mjs +20 -16
- package/esm2020/plugins/table/components/td/td.component.mjs +2 -2
- package/esm2020/plugins/table/components/toolbar/table-toolbar.component.mjs +3 -3
- package/esm2020/plugins/table/table.service.mjs +2 -2
- package/fesm2015/worktile-theia.mjs +91 -24
- package/fesm2015/worktile-theia.mjs.map +1 -1
- package/fesm2020/worktile-theia.mjs +88 -23
- package/fesm2020/worktile-theia.mjs.map +1 -1
- package/package.json +1 -1
- package/plugins/code/code.component.d.ts +18 -7
- package/plugins/code/code.component.scss +0 -19
- package/plugins/hr/hr.editor.d.ts +1 -0
- package/plugins/image/image.component.d.ts +8 -8
- package/plugins/table/table.service.d.ts +4 -4
- package/styles/editor.scss +2 -3
package/editor.module.d.ts
CHANGED
|
@@ -92,7 +92,7 @@ import * as i61 from "ngx-tethys/divider";
|
|
|
92
92
|
import * as i62 from "ngx-tethys/dropdown";
|
|
93
93
|
import * as i63 from "ng-codemirror";
|
|
94
94
|
import * as i64 from "./components/column-resize/column-resize.module";
|
|
95
|
-
export declare const COMPONENTS: (typeof TheToolbarGroupComponent | typeof TheColorSelectComponent | typeof
|
|
95
|
+
export declare const COMPONENTS: (typeof TheToolbarGroupComponent | typeof TheColorSelectComponent | typeof TheContextMenuComponent | typeof TheTableOptionsComponent | typeof TheTextComponent | typeof TheDefaultElementComponent | typeof TheToolbarItemComponent | typeof TheToolbarDropdownComponent | typeof TheToolbarComponent | typeof TheQuickToolbarComponent | typeof TheQuickInsertComponent | typeof TheConversionHintComponent | typeof TheTableSelectComponent | typeof TheTableToolbarItemComponent | typeof TheVerticalToolbarItemComponent | typeof TheColorToolbarItemComponent | typeof TheInsertMarkComponent | typeof TheInlineToolbarComponent)[];
|
|
96
96
|
export declare const PLUGIN_COMPONENTS: (typeof TheTableToolbarComponent | typeof TheTableComponent | typeof TheTemplateComponent | typeof TheImageComponent | typeof TheTodoItemComponent | typeof TheBlockquoteComponent | typeof TheCodeComponent | typeof TheLinkHoverComponent | typeof TheLinkEditComponent | typeof TheLinkComponent | typeof TheTdComponent)[];
|
|
97
97
|
export declare class TheEditorModule {
|
|
98
98
|
static ɵfac: i0.ɵɵFactoryDeclaration<TheEditorModule, never>;
|
|
@@ -1,30 +1,33 @@
|
|
|
1
|
-
import { Component,
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Inject, TemplateRef, ViewChild } from '@angular/core';
|
|
2
|
+
import { CodeMirrorComponent } from 'ng-codemirror';
|
|
3
|
+
import { fromEvent, Subject } from 'rxjs';
|
|
4
|
+
import { delay, take, takeUntil } from 'rxjs/operators';
|
|
2
5
|
import { Transforms } from 'slate';
|
|
3
6
|
import { AngularEditor, IS_SAFARI } from 'slate-angular';
|
|
4
|
-
import {
|
|
7
|
+
import { TheToolbarDropdownComponent } from '../../components/toolbar-dropdown/toolbar-dropdown.component';
|
|
5
8
|
import { CODEMIRROR_PADDING_TOP, CODE_MODES, DropdownMode, ToolbarItemMode } from '../../constants';
|
|
6
9
|
import { TheBaseElementComponent, TheMode, THE_MODE_TOKEN } from '../../interfaces';
|
|
7
|
-
import
|
|
10
|
+
import * as TheQueries from '../../queries';
|
|
8
11
|
import * as TheTransforms from '../../transforms';
|
|
9
|
-
import {
|
|
10
|
-
import { fromEvent, Subject } from 'rxjs';
|
|
11
|
-
import { TheToolbarDropdownComponent } from '../../components/toolbar-dropdown/toolbar-dropdown.component';
|
|
12
|
+
import { CodeEditor } from './code.editor';
|
|
12
13
|
import * as i0 from "@angular/core";
|
|
13
14
|
import * as i1 from "ngx-tethys/notify";
|
|
14
15
|
import * as i2 from "../../services/context.service";
|
|
15
|
-
import * as i3 from "
|
|
16
|
-
import * as i4 from "
|
|
17
|
-
import * as i5 from "@angular/
|
|
18
|
-
import * as i6 from "
|
|
19
|
-
import * as i7 from "
|
|
20
|
-
import * as i8 from "ngx-tethys/
|
|
21
|
-
import * as i9 from "ngx-tethys/
|
|
22
|
-
import * as i10 from "ngx-tethys/
|
|
23
|
-
import * as i11 from "
|
|
24
|
-
import * as i12 from "
|
|
25
|
-
import * as i13 from "
|
|
16
|
+
import * as i3 from "ngx-tethys/popover";
|
|
17
|
+
import * as i4 from "@angular/cdk/overlay";
|
|
18
|
+
import * as i5 from "@angular/common";
|
|
19
|
+
import * as i6 from "slate-angular";
|
|
20
|
+
import * as i7 from "@angular/forms";
|
|
21
|
+
import * as i8 from "ngx-tethys/tooltip";
|
|
22
|
+
import * as i9 from "ngx-tethys/resizable";
|
|
23
|
+
import * as i10 from "ngx-tethys/switch";
|
|
24
|
+
import * as i11 from "ngx-tethys/action";
|
|
25
|
+
import * as i12 from "ngx-tethys/divider";
|
|
26
|
+
import * as i13 from "ng-codemirror";
|
|
27
|
+
import * as i14 from "../../components/toolbar-dropdown/toolbar-dropdown.component";
|
|
28
|
+
import * as i15 from "../../interfaces";
|
|
26
29
|
export class TheCodeComponent extends TheBaseElementComponent {
|
|
27
|
-
constructor(elementRef, cdr, thyNotifyService, contextService, ngZone, config) {
|
|
30
|
+
constructor(elementRef, cdr, thyNotifyService, contextService, ngZone, config, thyPopover, viewContainerRef, overlay) {
|
|
28
31
|
super(elementRef, cdr);
|
|
29
32
|
this.elementRef = elementRef;
|
|
30
33
|
this.cdr = cdr;
|
|
@@ -32,6 +35,9 @@ export class TheCodeComponent extends TheBaseElementComponent {
|
|
|
32
35
|
this.contextService = contextService;
|
|
33
36
|
this.ngZone = ngZone;
|
|
34
37
|
this.config = config;
|
|
38
|
+
this.thyPopover = thyPopover;
|
|
39
|
+
this.viewContainerRef = viewContainerRef;
|
|
40
|
+
this.overlay = overlay;
|
|
35
41
|
this.startRenderCodemirror = false;
|
|
36
42
|
this.dropdownMode = DropdownMode;
|
|
37
43
|
this.maxHeight = this.config.mode === TheMode.print ? 0 : 350 - CODEMIRROR_PADDING_TOP * 2;
|
|
@@ -62,8 +68,17 @@ export class TheCodeComponent extends TheBaseElementComponent {
|
|
|
62
68
|
get code() {
|
|
63
69
|
return this.element.content;
|
|
64
70
|
}
|
|
71
|
+
get isToolbarOpen() {
|
|
72
|
+
return this.toolbarPopoverRef && this.toolbarPopoverRef.getOverlayRef() && this.toolbarPopoverRef.getOverlayRef().hasAttached();
|
|
73
|
+
}
|
|
65
74
|
onContextChange() {
|
|
66
75
|
super.onContextChange();
|
|
76
|
+
if (this.isCollapsedAndNonReadonly) {
|
|
77
|
+
this.openToolbar();
|
|
78
|
+
}
|
|
79
|
+
else {
|
|
80
|
+
this.closeToolbar();
|
|
81
|
+
}
|
|
67
82
|
if (this.initialized) {
|
|
68
83
|
if (this.options.readOnly !== this.readonly) {
|
|
69
84
|
this.useReadonly();
|
|
@@ -87,8 +102,8 @@ export class TheCodeComponent extends TheBaseElementComponent {
|
|
|
87
102
|
.subscribe(event => {
|
|
88
103
|
event.stopPropagation();
|
|
89
104
|
const isBlockOperation = this.isCollapsedAndNonReadonly &&
|
|
90
|
-
this.nativeElement.querySelector('.the-code-block-operation')
|
|
91
|
-
const isCodemirror = this.nativeElement.querySelector('.ng-codemirror')
|
|
105
|
+
this.nativeElement.querySelector('.the-code-block-operation')?.contains(event.target);
|
|
106
|
+
const isCodemirror = this.nativeElement.querySelector('.ng-codemirror')?.contains(event.target);
|
|
92
107
|
this.isHightLight = !isCodemirror && !isBlockOperation;
|
|
93
108
|
});
|
|
94
109
|
});
|
|
@@ -113,6 +128,45 @@ export class TheCodeComponent extends TheBaseElementComponent {
|
|
|
113
128
|
});
|
|
114
129
|
}
|
|
115
130
|
}
|
|
131
|
+
openToolbar() {
|
|
132
|
+
if (!TheQueries.isGlobalCollapsed(this.editor) || this.isToolbarOpen) {
|
|
133
|
+
return;
|
|
134
|
+
}
|
|
135
|
+
this.toolbarPopoverRef = this.thyPopover.open(this.toolbar, {
|
|
136
|
+
origin: this.elementRef.nativeElement,
|
|
137
|
+
viewContainerRef: this.viewContainerRef,
|
|
138
|
+
panelClass: 'the-plugin-toolbar-popover',
|
|
139
|
+
minWidth: 0,
|
|
140
|
+
manualClosure: true,
|
|
141
|
+
hasBackdrop: false,
|
|
142
|
+
insideClosable: false,
|
|
143
|
+
outsideClosable: false,
|
|
144
|
+
scrollStrategy: this.overlay.scrollStrategies.reposition()
|
|
145
|
+
});
|
|
146
|
+
this.toolbarPopoverRef?.getOverlayRef().updatePositionStrategy(this.createPositionStrategy());
|
|
147
|
+
}
|
|
148
|
+
closeToolbar() {
|
|
149
|
+
if (this.isToolbarOpen) {
|
|
150
|
+
this.toolbarPopoverRef.close();
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
createPositionStrategy() {
|
|
154
|
+
const topLeftPosition = {
|
|
155
|
+
originX: 'start',
|
|
156
|
+
originY: 'top',
|
|
157
|
+
overlayX: 'start',
|
|
158
|
+
overlayY: 'bottom',
|
|
159
|
+
offsetX: 0,
|
|
160
|
+
offsetY: -4
|
|
161
|
+
};
|
|
162
|
+
return this.overlay
|
|
163
|
+
.position()
|
|
164
|
+
.flexibleConnectedTo(this.elementRef.nativeElement)
|
|
165
|
+
.withFlexibleDimensions(false)
|
|
166
|
+
.withGrowAfterOpen(false)
|
|
167
|
+
.withPush(false)
|
|
168
|
+
.withPositions([topLeftPosition]);
|
|
169
|
+
}
|
|
116
170
|
renderCodemirror() {
|
|
117
171
|
this.startRenderCodemirror = true;
|
|
118
172
|
this.useReadonly();
|
|
@@ -227,19 +281,22 @@ export class TheCodeComponent extends TheBaseElementComponent {
|
|
|
227
281
|
this.destroy$.complete();
|
|
228
282
|
}
|
|
229
283
|
}
|
|
230
|
-
TheCodeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: TheCodeComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i1.ThyNotifyService }, { token: i2.TheContextService }, { token: i0.NgZone }, { token: THE_MODE_TOKEN }], target: i0.ɵɵFactoryTarget.Component });
|
|
231
|
-
TheCodeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: TheCodeComponent, selector: "div[theCode]", viewQueries: [{ propertyName: "codemirror", first: true, predicate: ["codemirror"], descendants: true, read: CodeMirrorComponent }, { propertyName: "toolbarDropdownComponent", first: true, predicate: TheToolbarDropdownComponent, descendants: true, read: TheToolbarDropdownComponent }], usesInheritance: true, ngImport: i0, template: "<
|
|
284
|
+
TheCodeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: TheCodeComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i1.ThyNotifyService }, { token: i2.TheContextService }, { token: i0.NgZone }, { token: THE_MODE_TOKEN }, { token: i3.ThyPopover }, { token: i0.ViewContainerRef }, { token: i4.Overlay }], target: i0.ɵɵFactoryTarget.Component });
|
|
285
|
+
TheCodeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: TheCodeComponent, selector: "div[theCode]", viewQueries: [{ propertyName: "toolbar", first: true, predicate: ["toolbar"], descendants: true, read: TemplateRef, static: true }, { propertyName: "codemirror", first: true, predicate: ["codemirror"], descendants: true, read: CodeMirrorComponent }, { propertyName: "toolbarDropdownComponent", first: true, predicate: TheToolbarDropdownComponent, descendants: true, read: TheToolbarDropdownComponent }], usesInheritance: true, ngImport: i0, template: "<slate-children [children]=\"children\" [context]=\"childrenContext\" [viewContext]=\"viewContext\"></slate-children>\n\n<!-- \u53EA\u8BFB\u6A21\u5F0F\u4E0BCodeMirror-sizer\u9AD8\u5EA6\u6BD4\u7F16\u8F91\u6A21\u5F0F\u4E0B\u591A2px\uFF0C\u8BBE\u7F6EthyMinHeight\u4E3A46px\u9632\u6B62\u62D6\u62FD\u5230\u6700\u5C0F\u9AD8\u5EA6\u65F6\u53EA\u8BFB\u6A21\u5F0F\u4E0B\u51FA\u73B0\u6EDA\u52A8\u6761 -->\n<div\n thyResizable\n [thyMinHeight]=\"46\"\n [thyBounds]=\"resizeBounds\"\n [style.height.px]=\"resizeHeight\"\n (thyResize)=\"onResize($event)\"\n (thyResizeEnd)=\"onEndResize()\"\n class=\"resize-code-container\"\n [ngClass]=\"{ focus: isCollapsedAndNonReadonly, readonly: options.readOnly, active: isHightLight && isCollapsedAndNonReadonly }\"\n>\n <ng-codemirror\n *ngIf=\"startRenderCodemirror\"\n #codemirror\n contenteditable=\"false\"\n class=\"ng-codemirror-wrapper\"\n [ngStyle]=\"{ maxHeight: maxHeight > 0 ? maxHeight + 'px' : 'auto' }\"\n [options]=\"options\"\n [ngModel]=\"code\"\n [delayRefreshTime]=\"300\"\n (ngModelChange)=\"codeChange($event)\"\n (focusChange)=\"focusChange($event)\"\n [autoMaxHeight]=\"maxHeight\"\n >\n </ng-codemirror>\n <thy-resize-handle thyDirection=\"bottom\" class=\"code-resize-icon\" *ngIf=\"isCollapsedAndNonReadonly\"></thy-resize-handle>\n</div>\n\n<ng-template #toolbar>\n <thy-actions thySize=\"xxs\">\n <the-toolbar-dropdown\n [menus]=\"menus\"\n [toolbarItem]=\"activeLanguage\"\n [dropdownItemKey]=\"activeLanguage?.key\"\n [itemMousedownHandle]=\"onChangeLanguage\"\n >\n </the-toolbar-dropdown>\n <span class=\"auto-wrap d-flex align-items-center px-2 text-secondary\">\n <span>\u81EA\u52A8\u6362\u884C</span>\n <thy-switch\n class=\"auto-wrap-btn d-flex ml-1\"\n [(ngModel)]=\"options.lineWrapping\"\n (ngModelChange)=\"onChangeWrap($event)\"\n thySize=\"sm\"\n ></thy-switch>\n </span>\n <a href=\"javascript:;\" thyAction thyActionIcon=\"copy\" thyTooltip=\"\u590D\u5236\" thyTooltipPlacement=\"top\" (mousedown)=\"onCopy($event)\"></a>\n <thy-divider class=\"mr-2 ml-1 align-self-center\" [thyVertical]=\"true\"></thy-divider>\n <a\n href=\"javascript:;\"\n thyAction\n thyType=\"danger\"\n thyActionIcon=\"trash\"\n thyTooltip=\"\u5220\u9664\"\n thyTooltipPlacement=\"top\"\n (mousedown)=\"onDelete($event)\"\n ></a>\n </thy-actions>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i6.SlateChildrenComponent, selector: "slate-children", inputs: ["children", "context", "viewContext"] }, { kind: "directive", type: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i7.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i8.ThyTooltipDirective, selector: "[thyTooltip],[thy-tooltip]", inputs: ["thyTooltip", "thyTooltipPlacement", "thyTooltipClass", "thyTooltipShowDelay", "thyTooltipHideDelay", "thyTooltipTrigger", "thyTooltipDisabled", "thyTooltipTemplateContext", "thyTooltipOffset", "thyTooltipPin"], exportAs: ["thyTooltip"] }, { kind: "directive", type: i9.ThyResizableDirective, selector: "[thyResizable]", inputs: ["thyBounds", "thyMaxHeight", "thyMaxWidth", "thyMinHeight", "thyMinWidth", "thyGridColumnCount", "thyMaxColumn", "thyMinColumn", "thyLockAspectRatio", "thyPreview", "thyDisabled"], outputs: ["thyResize", "thyResizeEnd", "thyResizeStart"] }, { kind: "component", type: i9.ThyResizeHandleComponent, selector: "thy-resize-handle, [thy-resize-handle]", inputs: ["thyDirection"], outputs: ["thyMouseDown"], exportAs: ["thyResizeHandle"] }, { kind: "component", type: i10.ThySwitchComponent, selector: "thy-switch", inputs: ["thyType", "thySize", "thyDisabled"], outputs: ["thyChange"] }, { kind: "component", type: i11.ThyActionComponent, selector: "thy-action, [thyAction]", inputs: ["thyType", "thyIcon", "thyActionIcon", "thyActive", "thyActionActive", "thyTheme", "thyHoverIcon", "thyDisabled"] }, { kind: "component", type: i11.ThyActionsComponent, selector: "thy-actions", inputs: ["thySize"] }, { kind: "component", type: i12.ThyDividerComponent, selector: "thy-divider", inputs: ["thyVertical", "thyStyle", "thyColor", "thyText", "thyTextDirection", "thyDeeper"] }, { kind: "component", type: i13.CodeMirrorComponent, selector: "ng-codemirror, [ngCodeMirror]", inputs: ["autoMaxHeight", "options", "delayRefreshTime"], outputs: ["focusChange"] }, { kind: "component", type: i14.TheToolbarDropdownComponent, selector: "the-toolbar-dropdown", inputs: ["itemMousedownHandle"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
232
286
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: TheCodeComponent, decorators: [{
|
|
233
287
|
type: Component,
|
|
234
|
-
args: [{ selector: 'div[theCode]', changeDetection: ChangeDetectionStrategy.OnPush, template: "<
|
|
235
|
-
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i1.ThyNotifyService }, { type: i2.TheContextService }, { type: i0.NgZone }, { type:
|
|
288
|
+
args: [{ selector: 'div[theCode]', changeDetection: ChangeDetectionStrategy.OnPush, template: "<slate-children [children]=\"children\" [context]=\"childrenContext\" [viewContext]=\"viewContext\"></slate-children>\n\n<!-- \u53EA\u8BFB\u6A21\u5F0F\u4E0BCodeMirror-sizer\u9AD8\u5EA6\u6BD4\u7F16\u8F91\u6A21\u5F0F\u4E0B\u591A2px\uFF0C\u8BBE\u7F6EthyMinHeight\u4E3A46px\u9632\u6B62\u62D6\u62FD\u5230\u6700\u5C0F\u9AD8\u5EA6\u65F6\u53EA\u8BFB\u6A21\u5F0F\u4E0B\u51FA\u73B0\u6EDA\u52A8\u6761 -->\n<div\n thyResizable\n [thyMinHeight]=\"46\"\n [thyBounds]=\"resizeBounds\"\n [style.height.px]=\"resizeHeight\"\n (thyResize)=\"onResize($event)\"\n (thyResizeEnd)=\"onEndResize()\"\n class=\"resize-code-container\"\n [ngClass]=\"{ focus: isCollapsedAndNonReadonly, readonly: options.readOnly, active: isHightLight && isCollapsedAndNonReadonly }\"\n>\n <ng-codemirror\n *ngIf=\"startRenderCodemirror\"\n #codemirror\n contenteditable=\"false\"\n class=\"ng-codemirror-wrapper\"\n [ngStyle]=\"{ maxHeight: maxHeight > 0 ? maxHeight + 'px' : 'auto' }\"\n [options]=\"options\"\n [ngModel]=\"code\"\n [delayRefreshTime]=\"300\"\n (ngModelChange)=\"codeChange($event)\"\n (focusChange)=\"focusChange($event)\"\n [autoMaxHeight]=\"maxHeight\"\n >\n </ng-codemirror>\n <thy-resize-handle thyDirection=\"bottom\" class=\"code-resize-icon\" *ngIf=\"isCollapsedAndNonReadonly\"></thy-resize-handle>\n</div>\n\n<ng-template #toolbar>\n <thy-actions thySize=\"xxs\">\n <the-toolbar-dropdown\n [menus]=\"menus\"\n [toolbarItem]=\"activeLanguage\"\n [dropdownItemKey]=\"activeLanguage?.key\"\n [itemMousedownHandle]=\"onChangeLanguage\"\n >\n </the-toolbar-dropdown>\n <span class=\"auto-wrap d-flex align-items-center px-2 text-secondary\">\n <span>\u81EA\u52A8\u6362\u884C</span>\n <thy-switch\n class=\"auto-wrap-btn d-flex ml-1\"\n [(ngModel)]=\"options.lineWrapping\"\n (ngModelChange)=\"onChangeWrap($event)\"\n thySize=\"sm\"\n ></thy-switch>\n </span>\n <a href=\"javascript:;\" thyAction thyActionIcon=\"copy\" thyTooltip=\"\u590D\u5236\" thyTooltipPlacement=\"top\" (mousedown)=\"onCopy($event)\"></a>\n <thy-divider class=\"mr-2 ml-1 align-self-center\" [thyVertical]=\"true\"></thy-divider>\n <a\n href=\"javascript:;\"\n thyAction\n thyType=\"danger\"\n thyActionIcon=\"trash\"\n thyTooltip=\"\u5220\u9664\"\n thyTooltipPlacement=\"top\"\n (mousedown)=\"onDelete($event)\"\n ></a>\n </thy-actions>\n</ng-template>\n" }]
|
|
289
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i1.ThyNotifyService }, { type: i2.TheContextService }, { type: i0.NgZone }, { type: i15.TheModeConfig, decorators: [{
|
|
236
290
|
type: Inject,
|
|
237
291
|
args: [THE_MODE_TOKEN]
|
|
238
|
-
}] }]; }, propDecorators: {
|
|
292
|
+
}] }, { type: i3.ThyPopover }, { type: i0.ViewContainerRef }, { type: i4.Overlay }]; }, propDecorators: { toolbar: [{
|
|
293
|
+
type: ViewChild,
|
|
294
|
+
args: ['toolbar', { read: TemplateRef, static: true }]
|
|
295
|
+
}], codemirror: [{
|
|
239
296
|
type: ViewChild,
|
|
240
297
|
args: ['codemirror', { read: CodeMirrorComponent, static: false }]
|
|
241
298
|
}], toolbarDropdownComponent: [{
|
|
242
299
|
type: ViewChild,
|
|
243
300
|
args: [TheToolbarDropdownComponent, { read: TheToolbarDropdownComponent, static: false }]
|
|
244
301
|
}] } });
|
|
245
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"code.component.js","sourceRoot":"","sources":["../../../../../packages/src/plugins/code/code.component.ts","../../../../../packages/src/plugins/code/code.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ElementRef,\n    ChangeDetectorRef,\n    ChangeDetectionStrategy,\n    OnInit,\n    ViewChild,\n    AfterViewInit,\n    NgZone,\n    Inject,\n    OnDestroy\n} from '@angular/core';\nimport { ThyNotifyService } from 'ngx-tethys/notify';\nimport { Editor, Transforms } from 'slate';\nimport { AngularEditor, IS_SAFARI } from 'slate-angular';\nimport { CodeMirrorComponent } from 'ng-codemirror';\nimport { CODEMIRROR_PADDING_TOP, CODE_MODES, DropdownMode, ToolbarItemMode } from '../../constants';\nimport { DefaultToolbarItem, TheBaseElementComponent, TheMode, TheModeConfig, THE_MODE_TOKEN } from '../../interfaces';\nimport { CodeElement } from '../../custom-types';\nimport { CodeEditor } from './code.editor';\nimport * as TheTransforms from '../../transforms';\nimport { delay, take, takeUntil } from 'rxjs/operators';\nimport { ThyResizeEvent } from 'ngx-tethys/resizable';\nimport { TheContextService } from '../../services/context.service';\nimport { fromEvent, Subject } from 'rxjs';\nimport { TheToolbarDropdownComponent } from '../../components/toolbar-dropdown/toolbar-dropdown.component';\n\n@Component({\n    selector: 'div[theCode]',\n    templateUrl: './code.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TheCodeComponent extends TheBaseElementComponent<CodeElement, Editor> implements OnInit, AfterViewInit, OnDestroy {\n    startRenderCodemirror = false;\n    dropdownMode = DropdownMode;\n    maxHeight = this.config.mode === TheMode.print ? 0 : 350 - CODEMIRROR_PADDING_TOP * 2;\n    menus = CODE_MODES.map(item => {\n        return { key: item.value, name: item.showName };\n    });\n    destroy$ = new Subject<void>();\n    ToolbarItemMode = ToolbarItemMode;\n    isHightLight = false;\n    resizeHeight: number = null;\n\n    options = {\n        mode: this.menus[0].key,\n        lineNumbers: false,\n        readOnly: false,\n        autofocus: false,\n        lineWiseCopyCut: true,\n        lineWrapping: this.config.mode === TheMode.print,\n        cursorBlinkRate: 500\n    };\n\n    activeLanguage: DefaultToolbarItem = this.menus[0];\n\n    resizeBounds = null;\n\n    @ViewChild('codemirror', { read: CodeMirrorComponent, static: false })\n    codemirror: CodeMirrorComponent;\n\n    @ViewChild(TheToolbarDropdownComponent, { read: TheToolbarDropdownComponent, static: false })\n    toolbarDropdownComponent: TheToolbarDropdownComponent;\n\n    get code() {\n        return this.element.content;\n    }\n\n    onContextChange() {\n        super.onContextChange();\n        if (this.initialized) {\n            if (this.options.readOnly !== this.readonly) {\n                this.useReadonly();\n            }\n            if (this.options.mode !== this.element.language) {\n                this.useMode();\n            }\n            if (this.options.lineWrapping !== this.element.autoWrap) {\n                this.useAutoWrap();\n            }\n            if (this.resizeHeight !== this.element.height) {\n                this.useHeight();\n            }\n        }\n    }\n\n    constructor(\n        public elementRef: ElementRef,\n        public cdr: ChangeDetectorRef,\n        private thyNotifyService: ThyNotifyService,\n        private contextService: TheContextService,\n        private ngZone: NgZone,\n        @Inject(THE_MODE_TOKEN)\n        private config: TheModeConfig\n    ) {\n        super(elementRef, cdr);\n    }\n\n    ngOnInit() {\n        super.ngOnInit();\n        this.ngZone.runOutsideAngular(() => {\n            fromEvent(this.nativeElement, 'mousedown')\n                .pipe(takeUntil(this.destroy$))\n                .subscribe(event => {\n                    event.stopPropagation();\n                    const isBlockOperation =\n                        this.isCollapsedAndNonReadonly &&\n                        this.nativeElement.querySelector('.the-code-block-operation').contains(event.target as HTMLElement);\n                    const isCodemirror = this.nativeElement.querySelector('.ng-codemirror').contains(event.target as HTMLElement);\n                    this.isHightLight = !isCodemirror && !isBlockOperation;\n                });\n        });\n        this.elementRef.nativeElement.classList.add('the-code-container');\n    }\n\n    ngAfterViewInit() {\n        if (this.readonly) {\n            // delay 20ms\n            // ccodemirror is too slow\n            this.ngZone.onStable.pipe(take(1), delay(20)).subscribe(() => {\n                this.renderCodemirror();\n            });\n        } else {\n            // edit mode can not delay\n            this.ngZone.onStable.pipe(take(1)).subscribe(() => {\n                this.renderCodemirror();\n                this.initializeCodemirrorFocus();\n                this.resizeBounds = {\n                    nativeElement: this.contextService.getEditableElement()\n                };\n            });\n        }\n    }\n\n    renderCodemirror() {\n        this.startRenderCodemirror = true;\n        this.useReadonly();\n        this.useMode();\n        this.useAutoWrap();\n        this.useHeight();\n        this.cdr.detectChanges();\n    }\n\n    initializeCodemirrorFocus() {\n        if (this.isCollapsedAndNonReadonly) {\n            setTimeout(() => {\n                if (this.isCollapsedAndNonReadonly && this.codemirror && this.codemirror.editor && !this.codemirror.editor.hasFocus()) {\n                    AngularEditor.blur(this.editor);\n                    this.codemirror.editor.focus();\n                    this.codemirror.editor.refresh();\n                }\n            }, 200);\n        }\n    }\n\n    codeChange($event) {\n        this.isHightLight = false;\n        CodeEditor.setCodeAttribute(this.editor, this.element, { content: $event });\n    }\n\n    onDelete(event: MouseEvent) {\n        event.preventDefault();\n        TheTransforms.deleteElement(this.editor, this.element);\n    }\n\n    onCopy(event: MouseEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n        // remove codemorrir selection\n        const selection = window.getSelection();\n        if (selection.rangeCount > 0) {\n            selection.removeAllRanges();\n        }\n        AngularEditor.focus(this.editor);\n        Transforms.select(this.editor, AngularEditor.findPath(this.editor, this.element));\n\n        if (IS_SAFARI) {\n            this.safariCopy();\n            return;\n        }\n\n        document.execCommand('copy') ? this.thyNotifyService.success('复制成功') : this.thyNotifyService.error('复制失败');\n        AngularEditor.deselect(this.editor);\n    }\n\n    safariCopy() {\n        const currentElement = AngularEditor.toDOMNode(this.editor, this.element);\n        const blockCard = currentElement.closest('.slate-block-card');\n        const span = document.createElement('pre');\n\n        span.appendChild(blockCard.cloneNode(true));\n        span.textContent = this.element.content;\n        if (this.element.language) {\n            span.setAttribute('data-language', this.element.language);\n        }\n        if (this.element.autoWrap) {\n            span.setAttribute('data-auto-wrap', String(this.element.autoWrap));\n        }\n        if (this.element.height) {\n            span.setAttribute('data-height', String(this.element.height));\n        }\n        document.body.appendChild(span);\n\n        const selection = window.getSelection();\n        const range = document.createRange();\n        if (selection) {\n            selection.removeAllRanges();\n            range.selectNode(span);\n            selection.addRange(range);\n\n            document.execCommand('copy') ? this.thyNotifyService.success('复制成功') : this.thyNotifyService.error('复制失败');\n            selection.removeAllRanges();\n            document.body.removeChild(span);\n            AngularEditor.deselect(this.editor);\n        }\n    }\n\n    focusChange(codeMirrorFocused: boolean) {\n        if (codeMirrorFocused) {\n            this.isHightLight = false;\n        }\n    }\n\n    onChangeLanguage = item => {\n        this.options = { ...this.options, mode: item.key };\n        this.activeLanguage = item;\n        CodeEditor.setCodeAttribute(this.editor, this.element, { language: item.key });\n    };\n\n    useMode() {\n        this.options = { ...this.options, mode: this.element.language };\n        const menuItem = this.menus.find(i => i.key === this.element.language);\n        if (menuItem) {\n            this.activeLanguage = menuItem;\n        }\n    }\n\n    useAutoWrap() {\n        this.options = { ...this.options, lineWrapping: this.element.autoWrap || false };\n    }\n\n    useHeight() {\n        if (this.element.height && this.config.mode !== TheMode.print) {\n            this.resizeHeight = this.element.height;\n            this.maxHeight = this.element.height;\n        }\n    }\n\n    useReadonly() {\n        this.options = { ...this.options, readOnly: this.readonly, cursorBlinkRate: this.readonly ? -1 : 500 };\n    }\n\n    onResize({ height }: ThyResizeEvent) {\n        this.resizeHeight = height;\n        this.maxHeight = height;\n    }\n\n    onEndResize() {\n        Transforms.select(this.editor, AngularEditor.findPath(this.editor, this.element));\n        CodeEditor.setCodeAttribute(this.editor, this.element, { height: this.resizeHeight });\n    }\n\n    onChangeWrap(value: boolean) {\n        this.isHightLight = false;\n        this.options = { ...this.options, lineWrapping: value || false };\n        CodeEditor.setCodeAttribute(this.editor, this.element, { autoWrap: value ? value : null });\n    }\n\n    ngOnDestroy() {\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n}\n","<thy-actions\n    *ngIf=\"(isCollapsedAndNonReadonly && codemirror) || toolbarDropdownComponent?.isOpen\"\n    contenteditable=\"false\"\n    class=\"the-code-block-operation\"\n    thySize=\"xxs\"\n>\n    <the-toolbar-dropdown\n        [menus]=\"menus\"\n        [toolbarItem]=\"activeLanguage\"\n        [dropdownItemKey]=\"activeLanguage?.key\"\n        [itemMousedownHandle]=\"onChangeLanguage\"\n    >\n    </the-toolbar-dropdown>\n    <span class=\"auto-wrap d-flex align-items-center px-2 text-secondary\">\n        <span>自动换行</span>\n        <thy-switch\n            class=\"auto-wrap-btn d-flex ml-1\"\n            [(ngModel)]=\"options.lineWrapping\"\n            (ngModelChange)=\"onChangeWrap($event)\"\n            thySize=\"sm\"\n        ></thy-switch>\n    </span>\n    <a href=\"javascript:;\" thyAction thyActionIcon=\"copy\" thyTooltip=\"复制\" thyTooltipPlacement=\"top\" (mousedown)=\"onCopy($event)\"></a>\n    <thy-divider class=\"mx-2 align-self-center\" [thyVertical]=\"true\"></thy-divider>\n    <a\n        href=\"javascript:;\"\n        thyAction\n        thyType=\"danger\"\n        thyActionIcon=\"trash\"\n        thyTooltip=\"删除\"\n        thyTooltipPlacement=\"top\"\n        (mousedown)=\"onDelete($event)\"\n    ></a>\n</thy-actions>\n\n<slate-children [children]=\"children\" [context]=\"childrenContext\" [viewContext]=\"viewContext\"></slate-children>\n\n<!-- 只读模式下CodeMirror-sizer高度比编辑模式下多2px，设置thyMinHeight为46px防止拖拽到最小高度时只读模式下出现滚动条  -->\n<div\n    thyResizable\n    [thyMinHeight]=\"46\"\n    [thyBounds]=\"resizeBounds\"\n    [style.height.px]=\"resizeHeight\"\n    (thyResize)=\"onResize($event)\"\n    (thyResizeEnd)=\"onEndResize()\"\n    class=\"resize-code-container\"\n    [ngClass]=\"{ focus: isCollapsedAndNonReadonly, readonly: options.readOnly, active: isHightLight && isCollapsedAndNonReadonly }\"\n>\n    <ng-codemirror\n        *ngIf=\"startRenderCodemirror\"\n        #codemirror\n        contenteditable=\"false\"\n        class=\"ng-codemirror-wrapper\"\n        [ngStyle]=\"{ maxHeight: maxHeight > 0 ? maxHeight + 'px' : 'auto' }\"\n        [options]=\"options\"\n        [ngModel]=\"code\"\n        [delayRefreshTime]=\"300\"\n        (ngModelChange)=\"codeChange($event)\"\n        (focusChange)=\"focusChange($event)\"\n        [autoMaxHeight]=\"maxHeight\"\n    >\n    </ng-codemirror>\n    <thy-resize-handle thyDirection=\"bottom\" class=\"code-resize-icon\" *ngIf=\"isCollapsedAndNonReadonly\"></thy-resize-handle>\n</div>\n"]}
|
|
302
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"code.component.js","sourceRoot":"","sources":["../../../../../packages/src/plugins/code/code.component.ts","../../../../../packages/src/plugins/code/code.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ConnectedPosition, Overlay } from '@angular/cdk/overlay';\nimport {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    Inject,\n    NgZone,\n    OnDestroy,\n    OnInit,\n    TemplateRef,\n    ViewChild,\n    ViewContainerRef\n} from '@angular/core';\nimport { CodeMirrorComponent } from 'ng-codemirror';\nimport { ThyNotifyService } from 'ngx-tethys/notify';\nimport { ThyPopover, ThyPopoverRef } from 'ngx-tethys/popover';\nimport { ThyResizeEvent } from 'ngx-tethys/resizable';\nimport { fromEvent, Subject } from 'rxjs';\nimport { delay, take, takeUntil } from 'rxjs/operators';\nimport { Editor, Transforms } from 'slate';\nimport { AngularEditor, IS_SAFARI } from 'slate-angular';\nimport { TheToolbarDropdownComponent } from '../../components/toolbar-dropdown/toolbar-dropdown.component';\nimport { CODEMIRROR_PADDING_TOP, CODE_MODES, DropdownMode, ToolbarItemMode } from '../../constants';\nimport { CodeElement } from '../../custom-types';\nimport { DefaultToolbarItem, TheBaseElementComponent, TheMode, TheModeConfig, THE_MODE_TOKEN } from '../../interfaces';\nimport * as TheQueries from '../../queries';\nimport { TheContextService } from '../../services/context.service';\nimport * as TheTransforms from '../../transforms';\nimport { CodeEditor } from './code.editor';\n\n@Component({\n    selector: 'div[theCode]',\n    templateUrl: './code.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TheCodeComponent extends TheBaseElementComponent<CodeElement, Editor> implements OnInit, AfterViewInit, OnDestroy {\n    startRenderCodemirror = false;\n\n    dropdownMode = DropdownMode;\n\n    maxHeight = this.config.mode === TheMode.print ? 0 : 350 - CODEMIRROR_PADDING_TOP * 2;\n\n    menus = CODE_MODES.map(item => {\n        return { key: item.value, name: item.showName };\n    });\n\n    destroy$ = new Subject<void>();\n\n    ToolbarItemMode = ToolbarItemMode;\n\n    isHightLight = false;\n\n    resizeHeight: number = null;\n\n    options = {\n        mode: this.menus[0].key,\n        lineNumbers: false,\n        readOnly: false,\n        autofocus: false,\n        lineWiseCopyCut: true,\n        lineWrapping: this.config.mode === TheMode.print,\n        cursorBlinkRate: 500\n    };\n\n    activeLanguage: DefaultToolbarItem = this.menus[0];\n\n    resizeBounds = null;\n\n    toolbarPopoverRef: ThyPopoverRef<any>;\n\n    @ViewChild('toolbar', { read: TemplateRef, static: true })\n    toolbar: TemplateRef<any>;\n\n    @ViewChild('codemirror', { read: CodeMirrorComponent, static: false })\n    codemirror: CodeMirrorComponent;\n\n    @ViewChild(TheToolbarDropdownComponent, { read: TheToolbarDropdownComponent, static: false })\n    toolbarDropdownComponent: TheToolbarDropdownComponent;\n\n    get code() {\n        return this.element.content;\n    }\n\n    get isToolbarOpen() {\n        return this.toolbarPopoverRef && this.toolbarPopoverRef.getOverlayRef() && this.toolbarPopoverRef.getOverlayRef().hasAttached();\n    }\n\n    constructor(\n        public elementRef: ElementRef,\n        public cdr: ChangeDetectorRef,\n        private thyNotifyService: ThyNotifyService,\n        private contextService: TheContextService,\n        private ngZone: NgZone,\n        @Inject(THE_MODE_TOKEN)\n        private config: TheModeConfig,\n        private thyPopover: ThyPopover,\n        private viewContainerRef: ViewContainerRef,\n        private overlay: Overlay\n    ) {\n        super(elementRef, cdr);\n    }\n\n    onContextChange() {\n        super.onContextChange();\n\n        if (this.isCollapsedAndNonReadonly) {\n            this.openToolbar();\n        } else {\n            this.closeToolbar();\n        }\n\n        if (this.initialized) {\n            if (this.options.readOnly !== this.readonly) {\n                this.useReadonly();\n            }\n            if (this.options.mode !== this.element.language) {\n                this.useMode();\n            }\n            if (this.options.lineWrapping !== this.element.autoWrap) {\n                this.useAutoWrap();\n            }\n            if (this.resizeHeight !== this.element.height) {\n                this.useHeight();\n            }\n        }\n    }\n\n    ngOnInit() {\n        super.ngOnInit();\n        this.ngZone.runOutsideAngular(() => {\n            fromEvent(this.nativeElement, 'mousedown')\n                .pipe(takeUntil(this.destroy$))\n                .subscribe(event => {\n                    event.stopPropagation();\n                    const isBlockOperation =\n                        this.isCollapsedAndNonReadonly &&\n                        this.nativeElement.querySelector('.the-code-block-operation')?.contains(event.target as HTMLElement);\n                    const isCodemirror = this.nativeElement.querySelector('.ng-codemirror')?.contains(event.target as HTMLElement);\n                    this.isHightLight = !isCodemirror && !isBlockOperation;\n                });\n        });\n        this.elementRef.nativeElement.classList.add('the-code-container');\n    }\n\n    ngAfterViewInit() {\n        if (this.readonly) {\n            // delay 20ms\n            // ccodemirror is too slow\n            this.ngZone.onStable.pipe(take(1), delay(20)).subscribe(() => {\n                this.renderCodemirror();\n            });\n        } else {\n            // edit mode can not delay\n            this.ngZone.onStable.pipe(take(1)).subscribe(() => {\n                this.renderCodemirror();\n                this.initializeCodemirrorFocus();\n                this.resizeBounds = {\n                    nativeElement: this.contextService.getEditableElement()\n                };\n            });\n        }\n    }\n\n    openToolbar() {\n        if (!TheQueries.isGlobalCollapsed(this.editor) || this.isToolbarOpen) {\n            return;\n        }\n        this.toolbarPopoverRef = this.thyPopover.open(this.toolbar, {\n            origin: this.elementRef.nativeElement,\n            viewContainerRef: this.viewContainerRef,\n            panelClass: 'the-plugin-toolbar-popover',\n            minWidth: 0,\n            manualClosure: true,\n            hasBackdrop: false,\n            insideClosable: false,\n            outsideClosable: false,\n            scrollStrategy: this.overlay.scrollStrategies.reposition()\n        });\n        this.toolbarPopoverRef?.getOverlayRef().updatePositionStrategy(this.createPositionStrategy());\n    }\n\n    closeToolbar() {\n        if (this.isToolbarOpen) {\n            this.toolbarPopoverRef.close();\n        }\n    }\n\n    createPositionStrategy() {\n        const topLeftPosition: ConnectedPosition = {\n            originX: 'start',\n            originY: 'top',\n            overlayX: 'start',\n            overlayY: 'bottom',\n            offsetX: 0,\n            offsetY: -4\n        };\n        return this.overlay\n            .position()\n            .flexibleConnectedTo(this.elementRef.nativeElement)\n            .withFlexibleDimensions(false)\n            .withGrowAfterOpen(false)\n            .withPush(false)\n            .withPositions([topLeftPosition]);\n    }\n\n    renderCodemirror() {\n        this.startRenderCodemirror = true;\n        this.useReadonly();\n        this.useMode();\n        this.useAutoWrap();\n        this.useHeight();\n        this.cdr.detectChanges();\n    }\n\n    initializeCodemirrorFocus() {\n        if (this.isCollapsedAndNonReadonly) {\n            setTimeout(() => {\n                if (this.isCollapsedAndNonReadonly && this.codemirror && this.codemirror.editor && !this.codemirror.editor.hasFocus()) {\n                    AngularEditor.blur(this.editor);\n                    this.codemirror.editor.focus();\n                    this.codemirror.editor.refresh();\n                }\n            }, 200);\n        }\n    }\n\n    codeChange($event) {\n        this.isHightLight = false;\n        CodeEditor.setCodeAttribute(this.editor, this.element, { content: $event });\n    }\n\n    onDelete(event: MouseEvent) {\n        event.preventDefault();\n        TheTransforms.deleteElement(this.editor, this.element);\n    }\n\n    onCopy(event: MouseEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n        // remove codemorrir selection\n        const selection = window.getSelection();\n        if (selection.rangeCount > 0) {\n            selection.removeAllRanges();\n        }\n        AngularEditor.focus(this.editor);\n        Transforms.select(this.editor, AngularEditor.findPath(this.editor, this.element));\n\n        if (IS_SAFARI) {\n            this.safariCopy();\n            return;\n        }\n\n        document.execCommand('copy') ? this.thyNotifyService.success('复制成功') : this.thyNotifyService.error('复制失败');\n        AngularEditor.deselect(this.editor);\n    }\n\n    safariCopy() {\n        const currentElement = AngularEditor.toDOMNode(this.editor, this.element);\n        const blockCard = currentElement.closest('.slate-block-card');\n        const span = document.createElement('pre');\n\n        span.appendChild(blockCard.cloneNode(true));\n        span.textContent = this.element.content;\n        if (this.element.language) {\n            span.setAttribute('data-language', this.element.language);\n        }\n        if (this.element.autoWrap) {\n            span.setAttribute('data-auto-wrap', String(this.element.autoWrap));\n        }\n        if (this.element.height) {\n            span.setAttribute('data-height', String(this.element.height));\n        }\n        document.body.appendChild(span);\n\n        const selection = window.getSelection();\n        const range = document.createRange();\n        if (selection) {\n            selection.removeAllRanges();\n            range.selectNode(span);\n            selection.addRange(range);\n\n            document.execCommand('copy') ? this.thyNotifyService.success('复制成功') : this.thyNotifyService.error('复制失败');\n            selection.removeAllRanges();\n            document.body.removeChild(span);\n            AngularEditor.deselect(this.editor);\n        }\n    }\n\n    focusChange(codeMirrorFocused: boolean) {\n        if (codeMirrorFocused) {\n            this.isHightLight = false;\n        }\n    }\n\n    onChangeLanguage = item => {\n        this.options = { ...this.options, mode: item.key };\n        this.activeLanguage = item;\n        CodeEditor.setCodeAttribute(this.editor, this.element, { language: item.key });\n    };\n\n    useMode() {\n        this.options = { ...this.options, mode: this.element.language };\n        const menuItem = this.menus.find(i => i.key === this.element.language);\n        if (menuItem) {\n            this.activeLanguage = menuItem;\n        }\n    }\n\n    useAutoWrap() {\n        this.options = { ...this.options, lineWrapping: this.element.autoWrap || false };\n    }\n\n    useHeight() {\n        if (this.element.height && this.config.mode !== TheMode.print) {\n            this.resizeHeight = this.element.height;\n            this.maxHeight = this.element.height;\n        }\n    }\n\n    useReadonly() {\n        this.options = { ...this.options, readOnly: this.readonly, cursorBlinkRate: this.readonly ? -1 : 500 };\n    }\n\n    onResize({ height }: ThyResizeEvent) {\n        this.resizeHeight = height;\n        this.maxHeight = height;\n    }\n\n    onEndResize() {\n        Transforms.select(this.editor, AngularEditor.findPath(this.editor, this.element));\n        CodeEditor.setCodeAttribute(this.editor, this.element, { height: this.resizeHeight });\n    }\n\n    onChangeWrap(value: boolean) {\n        this.isHightLight = false;\n        this.options = { ...this.options, lineWrapping: value || false };\n        CodeEditor.setCodeAttribute(this.editor, this.element, { autoWrap: value ? value : null });\n    }\n\n    ngOnDestroy() {\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n}\n","<slate-children [children]=\"children\" [context]=\"childrenContext\" [viewContext]=\"viewContext\"></slate-children>\n\n<!-- 只读模式下CodeMirror-sizer高度比编辑模式下多2px，设置thyMinHeight为46px防止拖拽到最小高度时只读模式下出现滚动条  -->\n<div\n    thyResizable\n    [thyMinHeight]=\"46\"\n    [thyBounds]=\"resizeBounds\"\n    [style.height.px]=\"resizeHeight\"\n    (thyResize)=\"onResize($event)\"\n    (thyResizeEnd)=\"onEndResize()\"\n    class=\"resize-code-container\"\n    [ngClass]=\"{ focus: isCollapsedAndNonReadonly, readonly: options.readOnly, active: isHightLight && isCollapsedAndNonReadonly }\"\n>\n    <ng-codemirror\n        *ngIf=\"startRenderCodemirror\"\n        #codemirror\n        contenteditable=\"false\"\n        class=\"ng-codemirror-wrapper\"\n        [ngStyle]=\"{ maxHeight: maxHeight > 0 ? maxHeight + 'px' : 'auto' }\"\n        [options]=\"options\"\n        [ngModel]=\"code\"\n        [delayRefreshTime]=\"300\"\n        (ngModelChange)=\"codeChange($event)\"\n        (focusChange)=\"focusChange($event)\"\n        [autoMaxHeight]=\"maxHeight\"\n    >\n    </ng-codemirror>\n    <thy-resize-handle thyDirection=\"bottom\" class=\"code-resize-icon\" *ngIf=\"isCollapsedAndNonReadonly\"></thy-resize-handle>\n</div>\n\n<ng-template #toolbar>\n    <thy-actions thySize=\"xxs\">\n        <the-toolbar-dropdown\n            [menus]=\"menus\"\n            [toolbarItem]=\"activeLanguage\"\n            [dropdownItemKey]=\"activeLanguage?.key\"\n            [itemMousedownHandle]=\"onChangeLanguage\"\n        >\n        </the-toolbar-dropdown>\n        <span class=\"auto-wrap d-flex align-items-center px-2 text-secondary\">\n            <span>自动换行</span>\n            <thy-switch\n                class=\"auto-wrap-btn d-flex ml-1\"\n                [(ngModel)]=\"options.lineWrapping\"\n                (ngModelChange)=\"onChangeWrap($event)\"\n                thySize=\"sm\"\n            ></thy-switch>\n        </span>\n        <a href=\"javascript:;\" thyAction thyActionIcon=\"copy\" thyTooltip=\"复制\" thyTooltipPlacement=\"top\" (mousedown)=\"onCopy($event)\"></a>\n        <thy-divider class=\"mr-2 ml-1 align-self-center\" [thyVertical]=\"true\"></thy-divider>\n        <a\n            href=\"javascript:;\"\n            thyAction\n            thyType=\"danger\"\n            thyActionIcon=\"trash\"\n            thyTooltip=\"删除\"\n            thyTooltipPlacement=\"top\"\n            (mousedown)=\"onDelete($event)\"\n        ></a>\n    </thy-actions>\n</ng-template>\n"]}
|
|
@@ -1,8 +1,16 @@
|
|
|
1
|
+
import { Editor, Element } from 'slate';
|
|
1
2
|
import { ElementKinds } from '../../constants/node-types';
|
|
2
3
|
import * as TheTransforms from '../../transforms';
|
|
3
4
|
export const HrEditor = {
|
|
4
5
|
insertHr(editor) {
|
|
5
6
|
TheTransforms.insertElements(editor, { type: ElementKinds.hr, children: [{ text: '' }] });
|
|
7
|
+
},
|
|
8
|
+
isHrActive(editor) {
|
|
9
|
+
const [match] = Editor.nodes(editor, {
|
|
10
|
+
match: n => Element.isElement(n) && n.type === ElementKinds.hr,
|
|
11
|
+
universal: true
|
|
12
|
+
});
|
|
13
|
+
return !!match;
|
|
6
14
|
}
|
|
7
15
|
};
|
|
8
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaHIuZWRpdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvc3JjL3BsdWdpbnMvaHIvaHIuZWRpdG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxNQUFNLEVBQUUsT0FBTyxFQUFFLE1BQU0sT0FBTyxDQUFDO0FBQ3hDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUMxRCxPQUFPLEtBQUssYUFBYSxNQUFNLGtCQUFrQixDQUFDO0FBRWxELE1BQU0sQ0FBQyxNQUFNLFFBQVEsR0FBRztJQUNwQixRQUFRLENBQUMsTUFBYztRQUNuQixhQUFhLENBQUMsY0FBYyxDQUFDLE1BQU0sRUFBRSxFQUFFLElBQUksRUFBRSxZQUFZLENBQUMsRUFBRSxFQUFFLFFBQVEsRUFBRSxDQUFDLEVBQUUsSUFBSSxFQUFFLEVBQUUsRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQzlGLENBQUM7SUFDRCxVQUFVLENBQUMsTUFBYztRQUNyQixNQUFNLENBQUMsS0FBSyxDQUFDLEdBQUcsTUFBTSxDQUFDLEtBQUssQ0FBQyxNQUFNLEVBQUU7WUFDakMsS0FBSyxFQUFFLENBQUMsQ0FBQyxFQUFFLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsSUFBSSxLQUFLLFlBQVksQ0FBQyxFQUFFO1lBQzlELFNBQVMsRUFBRSxJQUFJO1NBQ2xCLENBQUMsQ0FBQztRQUNILE9BQU8sQ0FBQyxDQUFDLEtBQUssQ0FBQztJQUNuQixDQUFDO0NBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEVkaXRvciwgRWxlbWVudCB9IGZyb20gJ3NsYXRlJztcbmltcG9ydCB7IEVsZW1lbnRLaW5kcyB9IGZyb20gJy4uLy4uL2NvbnN0YW50cy9ub2RlLXR5cGVzJztcbmltcG9ydCAqIGFzIFRoZVRyYW5zZm9ybXMgZnJvbSAnLi4vLi4vdHJhbnNmb3Jtcyc7XG5cbmV4cG9ydCBjb25zdCBIckVkaXRvciA9IHtcbiAgICBpbnNlcnRIcihlZGl0b3I6IEVkaXRvcikge1xuICAgICAgICBUaGVUcmFuc2Zvcm1zLmluc2VydEVsZW1lbnRzKGVkaXRvciwgeyB0eXBlOiBFbGVtZW50S2luZHMuaHIsIGNoaWxkcmVuOiBbeyB0ZXh0OiAnJyB9XSB9KTtcbiAgICB9LFxuICAgIGlzSHJBY3RpdmUoZWRpdG9yOiBFZGl0b3IpIHtcbiAgICAgICAgY29uc3QgW21hdGNoXSA9IEVkaXRvci5ub2RlcyhlZGl0b3IsIHtcbiAgICAgICAgICAgIG1hdGNoOiBuID0+IEVsZW1lbnQuaXNFbGVtZW50KG4pICYmIG4udHlwZSA9PT0gRWxlbWVudEtpbmRzLmhyLFxuICAgICAgICAgICAgdW5pdmVyc2FsOiB0cnVlXG4gICAgICAgIH0pO1xuICAgICAgICByZXR1cm4gISFtYXRjaDtcbiAgICB9XG59O1xuIl19
|