@worktile/theia 15.0.15 → 15.0.17
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/esm2020/plugins/align/align.editor.mjs +1 -5
- package/esm2020/plugins/common/move-selection.plugin.mjs +1 -2
- package/esm2020/plugins/table/table.editor.mjs +3 -21
- package/esm2020/plugins/table/table.plugin.mjs +22 -2
- package/esm2020/services/context.service.mjs +11 -8
- package/fesm2015/worktile-theia.mjs +31 -33
- package/fesm2015/worktile-theia.mjs.map +1 -1
- package/fesm2020/worktile-theia.mjs +30 -32
- package/fesm2020/worktile-theia.mjs.map +1 -1
- package/package.json +1 -1
- package/plugins/table/table.editor.d.ts +0 -1
- package/services/context.service.d.ts +1 -1
|
@@ -25,21 +25,23 @@ export class TheContextService {
|
|
|
25
25
|
}
|
|
26
26
|
initialize(options) {
|
|
27
27
|
this.options = options;
|
|
28
|
-
this.containerElement =
|
|
29
|
-
this.options.nativeElement.closest(this.options.theOptions?.scrollContainer) ||
|
|
30
|
-
this.options.nativeElement.querySelector(this.options.theOptions?.scrollContainer);
|
|
31
28
|
this.rebindContainerScroll();
|
|
32
29
|
this.bindContainerResize();
|
|
33
30
|
this.bindTheEditorResize();
|
|
34
31
|
this.bindWindowResize();
|
|
35
32
|
}
|
|
33
|
+
getScrollContainer() {
|
|
34
|
+
return (this.options.nativeElement.closest(this.options.theOptions?.scrollContainer) ||
|
|
35
|
+
this.options.nativeElement.querySelector(this.options.theOptions?.scrollContainer));
|
|
36
|
+
}
|
|
36
37
|
rebindContainerScroll() {
|
|
37
38
|
this.scrollSubscription?.unsubscribe();
|
|
38
39
|
if (this.options.theOptions?.scrollContainer) {
|
|
39
|
-
|
|
40
|
+
const containerElement = this.getScrollContainer();
|
|
41
|
+
if (containerElement) {
|
|
40
42
|
this.ngZone.runOutsideAngular(() => {
|
|
41
43
|
let previousContainerScroll = { x: 0, y: 0 };
|
|
42
|
-
this.scrollSubscription = fromEvent(
|
|
44
|
+
this.scrollSubscription = fromEvent(containerElement, 'scroll').subscribe(event => {
|
|
43
45
|
const entires = { event, direction: ScrollDirection.Y };
|
|
44
46
|
const target = event.target;
|
|
45
47
|
const [x, y] = [target.scrollLeft, target.scrollTop];
|
|
@@ -57,8 +59,9 @@ export class TheContextService {
|
|
|
57
59
|
}
|
|
58
60
|
}
|
|
59
61
|
bindContainerResize() {
|
|
60
|
-
|
|
61
|
-
|
|
62
|
+
const containerElement = this.getScrollContainer();
|
|
63
|
+
if (containerElement) {
|
|
64
|
+
this.containerResizeObserver = this.elementResize(containerElement, this.containerResized$);
|
|
62
65
|
}
|
|
63
66
|
}
|
|
64
67
|
bindTheEditorResize() {
|
|
@@ -129,4 +132,4 @@ TheContextService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", ve
|
|
|
129
132
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.2", ngImport: i0, type: TheContextService, decorators: [{
|
|
130
133
|
type: Injectable
|
|
131
134
|
}], ctorParameters: function () { return [{ type: i0.NgZone }]; } });
|
|
132
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context.service.js","sourceRoot":"","sources":["../../../../packages/src/services/context.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, NgZone, OnDestroy, ViewContainerRef } from '@angular/core';\nimport { fromEvent, Observable, Subject, Subscription } from 'rxjs';\nimport { TheOptions } from '../interfaces/editor';\nimport { FontSizes, MarkTypes, ScrollDirection } from '../constants/node-types';\nimport { takeUntil } from 'rxjs/operators';\n\nexport interface TheContextOptions {\n    theOptions: TheOptions;\n    nativeElement: HTMLElement;\n    viewContainerRef: ViewContainerRef;\n    width?: number;\n}\n\ninterface PaintFormatStatus {\n    isActive: boolean;\n    marks: { [key in MarkTypes]?: any };\n}\n\n@Injectable()\nexport class TheContextService implements OnDestroy {\n    private scrollSubscription?: Subscription;\n\n    private destroy$: Subject<void> = new Subject();\n\n    private options: TheContextOptions;\n\n    private containerElement: HTMLElement;\n\n    public uploadingFiles: { url: string; file: File }[] = [];\n\n    public paintFormatStatus: PaintFormatStatus = {\n        isActive: false,\n        marks: {}\n    };\n\n    public onMouseUp$: Observable<MouseEvent>;\n\n    public onMouseMove$: Observable<MouseEvent>;\n\n    public onMouseDown$: Observable<MouseEvent>;\n\n    public containerScrolled$ = new Subject<{ event: Event; direction: ScrollDirection }>();\n\n    public uploadingStatus$ = new Subject<boolean>();\n\n    public containerResized$ = new Subject<{ entry: ResizeObserverEntry; widthChanged: boolean; heightChanged: boolean }>();\n\n    public theEditorResized$ = new Subject<{ entry: ResizeObserverEntry; widthChanged: boolean; heightChanged: boolean }>();\n\n    public windowResized$ = new Subject<{ entry: ResizeObserverEntry; widthChanged: boolean; heightChanged: boolean }>();\n\n    private containerResizeObserver: ResizeObserver;\n\n    private theEditorResizeObserver: ResizeObserver;\n\n    private windowResizeObserver: ResizeObserver;\n\n    constructor(private ngZone: NgZone) {\n        this.ngZone.runOutsideAngular(() => {\n            this.onMouseUp$ = fromEvent<MouseEvent>(window, `mouseup`).pipe(takeUntil(this.destroy$));\n            this.onMouseMove$ = fromEvent<MouseEvent>(window, `mousemove`).pipe(takeUntil(this.destroy$));\n            this.onMouseDown$ = fromEvent<MouseEvent>(window, `mousedown`).pipe(takeUntil(this.destroy$));\n        });\n    }\n\n    public initialize(options: TheContextOptions) {\n        this.options = options;\n        this.containerElement =\n            this.options.nativeElement.closest(this.options.theOptions?.scrollContainer) ||\n            this.options.nativeElement.querySelector(this.options.theOptions?.scrollContainer);\n        this.rebindContainerScroll();\n        this.bindContainerResize();\n        this.bindTheEditorResize();\n        this.bindWindowResize();\n    }\n\n    rebindContainerScroll() {\n        this.scrollSubscription?.unsubscribe();\n        if (this.options.theOptions?.scrollContainer) {\n            if (this.containerElement) {\n                this.ngZone.runOutsideAngular(() => {\n                    let previousContainerScroll = { x: 0, y: 0 };\n                    this.scrollSubscription = fromEvent<Event>(this.containerElement, 'scroll').subscribe(event => {\n                        const entires = { event, direction: ScrollDirection.Y };\n                        const target = event.target as HTMLElement;\n                        const [x, y] = [target.scrollLeft, target.scrollTop];\n                        if (x !== previousContainerScroll.x) {\n                            entires.direction = ScrollDirection.X;\n                        }\n                        if (y !== previousContainerScroll.y) {\n                            entires.direction = ScrollDirection.Y;\n                        }\n                        previousContainerScroll = { x, y };\n                        this.containerScrolled$.next(entires);\n                    });\n                });\n            }\n        }\n    }\n\n    bindContainerResize() {\n        if (this.containerElement) {\n            this.containerResizeObserver = this.elementResize(this.containerElement, this.containerResized$);\n        }\n    }\n\n    bindTheEditorResize() {\n        this.theEditorResizeObserver = this.elementResize(this.options.nativeElement, this.theEditorResized$);\n    }\n\n    bindWindowResize() {\n        this.windowResizeObserver = this.elementResize(document.documentElement, this.windowResized$);\n    }\n\n    private elementResize(\n        element: HTMLElement,\n        subject: Subject<{ entry: ResizeObserverEntry; widthChanged: boolean; heightChanged: boolean }>\n    ) {\n        let previousContainerRect = element.getBoundingClientRect();\n        const resizeObserver = new ResizeObserver(entires => {\n            const currentRect = entires[0].contentRect;\n            const result = { entry: entires[0], widthChanged: false, heightChanged: false };\n            if (currentRect.width !== previousContainerRect.width) {\n                result.widthChanged = true;\n            }\n            if (currentRect.height !== previousContainerRect.height) {\n                result.heightChanged = true;\n            }\n            previousContainerRect = currentRect;\n            subject.next(result);\n        });\n        resizeObserver.observe(element);\n        return resizeObserver;\n    }\n\n    public getOptions() {\n        if (!this.options.width) {\n            const firstElementChild = this.getFirstElementChild();\n            this.options.width = firstElementChild.offsetWidth;\n        }\n        return this.options;\n    }\n\n    public getTheOptions() {\n        return this.options.theOptions;\n    }\n\n    public getDefaultFontSize() {\n        return this.options.theOptions?.fontSize || FontSizes.fontSize14;\n    }\n\n    public getEditableElement() {\n        return this.options.nativeElement.querySelector('.the-editor-typo');\n    }\n\n    public getFirstElementChild() {\n        const editableElement = this.getEditableElement();\n        return editableElement?.firstElementChild as HTMLElement;\n    }\n\n    addUploadingFiles(file: { url: string; file: File }) {\n        this.uploadingFiles.push(file);\n    }\n\n    removeUploadFile(file: { url: string; file: File }) {\n        this.uploadingFiles.splice(\n            this.uploadingFiles.findIndex(item => item.url === file.url),\n            1\n        );\n    }\n\n    ngOnDestroy(): void {\n        this.uploadingStatus$.complete();\n        this.containerScrolled$?.complete();\n        this.theEditorResized$?.complete();\n        this.containerResized$?.complete();\n        this.containerResizeObserver?.disconnect();\n        this.theEditorResizeObserver?.disconnect();\n        this.windowResized$?.complete();\n        this.windowResizeObserver?.disconnect();\n        this.scrollSubscription?.unsubscribe();\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n}\n"]}
|
|
135
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context.service.js","sourceRoot":"","sources":["../../../../packages/src/services/context.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, NgZone, OnDestroy, ViewContainerRef } from '@angular/core';\nimport { fromEvent, Observable, Subject, Subscription } from 'rxjs';\nimport { TheOptions } from '../interfaces/editor';\nimport { FontSizes, MarkTypes, ScrollDirection } from '../constants/node-types';\nimport { takeUntil } from 'rxjs/operators';\n\nexport interface TheContextOptions {\n    theOptions: TheOptions;\n    nativeElement: HTMLElement;\n    viewContainerRef: ViewContainerRef;\n    width?: number;\n}\n\ninterface PaintFormatStatus {\n    isActive: boolean;\n    marks: { [key in MarkTypes]?: any };\n}\n\n@Injectable()\nexport class TheContextService implements OnDestroy {\n    private scrollSubscription?: Subscription;\n\n    private destroy$: Subject<void> = new Subject();\n\n    private options: TheContextOptions;\n\n    public uploadingFiles: { url: string; file: File }[] = [];\n\n    public paintFormatStatus: PaintFormatStatus = {\n        isActive: false,\n        marks: {}\n    };\n\n    public onMouseUp$: Observable<MouseEvent>;\n\n    public onMouseMove$: Observable<MouseEvent>;\n\n    public onMouseDown$: Observable<MouseEvent>;\n\n    public containerScrolled$ = new Subject<{ event: Event; direction: ScrollDirection }>();\n\n    public uploadingStatus$ = new Subject<boolean>();\n\n    public containerResized$ = new Subject<{ entry: ResizeObserverEntry; widthChanged: boolean; heightChanged: boolean }>();\n\n    public theEditorResized$ = new Subject<{ entry: ResizeObserverEntry; widthChanged: boolean; heightChanged: boolean }>();\n\n    public windowResized$ = new Subject<{ entry: ResizeObserverEntry; widthChanged: boolean; heightChanged: boolean }>();\n\n    private containerResizeObserver: ResizeObserver;\n\n    private theEditorResizeObserver: ResizeObserver;\n\n    private windowResizeObserver: ResizeObserver;\n\n    constructor(private ngZone: NgZone) {\n        this.ngZone.runOutsideAngular(() => {\n            this.onMouseUp$ = fromEvent<MouseEvent>(window, `mouseup`).pipe(takeUntil(this.destroy$));\n            this.onMouseMove$ = fromEvent<MouseEvent>(window, `mousemove`).pipe(takeUntil(this.destroy$));\n            this.onMouseDown$ = fromEvent<MouseEvent>(window, `mousedown`).pipe(takeUntil(this.destroy$));\n        });\n    }\n\n    public initialize(options: TheContextOptions) {\n        this.options = options;\n        this.rebindContainerScroll();\n        this.bindContainerResize();\n        this.bindTheEditorResize();\n        this.bindWindowResize();\n    }\n\n    getScrollContainer(): HTMLElement {\n        return (\n            this.options.nativeElement.closest(this.options.theOptions?.scrollContainer) ||\n            this.options.nativeElement.querySelector(this.options.theOptions?.scrollContainer)\n        );\n    }\n\n    rebindContainerScroll() {\n        this.scrollSubscription?.unsubscribe();\n        if (this.options.theOptions?.scrollContainer) {\n            const containerElement = this.getScrollContainer();\n            if (containerElement) {\n                this.ngZone.runOutsideAngular(() => {\n                    let previousContainerScroll = { x: 0, y: 0 };\n                    this.scrollSubscription = fromEvent<Event>(containerElement, 'scroll').subscribe(event => {\n                        const entires = { event, direction: ScrollDirection.Y };\n                        const target = event.target as HTMLElement;\n                        const [x, y] = [target.scrollLeft, target.scrollTop];\n                        if (x !== previousContainerScroll.x) {\n                            entires.direction = ScrollDirection.X;\n                        }\n                        if (y !== previousContainerScroll.y) {\n                            entires.direction = ScrollDirection.Y;\n                        }\n                        previousContainerScroll = { x, y };\n                        this.containerScrolled$.next(entires);\n                    });\n                });\n            }\n        }\n    }\n\n    bindContainerResize() {\n        const containerElement = this.getScrollContainer();\n        if (containerElement) {\n            this.containerResizeObserver = this.elementResize(containerElement, this.containerResized$);\n        }\n    }\n\n    bindTheEditorResize() {\n        this.theEditorResizeObserver = this.elementResize(this.options.nativeElement, this.theEditorResized$);\n    }\n\n    bindWindowResize() {\n        this.windowResizeObserver = this.elementResize(document.documentElement, this.windowResized$);\n    }\n\n    private elementResize(\n        element: HTMLElement,\n        subject: Subject<{ entry: ResizeObserverEntry; widthChanged: boolean; heightChanged: boolean }>\n    ) {\n        let previousContainerRect = element.getBoundingClientRect();\n        const resizeObserver = new ResizeObserver(entires => {\n            const currentRect = entires[0].contentRect;\n            const result = { entry: entires[0], widthChanged: false, heightChanged: false };\n            if (currentRect.width !== previousContainerRect.width) {\n                result.widthChanged = true;\n            }\n            if (currentRect.height !== previousContainerRect.height) {\n                result.heightChanged = true;\n            }\n            previousContainerRect = currentRect;\n            subject.next(result);\n        });\n        resizeObserver.observe(element);\n        return resizeObserver;\n    }\n\n    public getOptions() {\n        if (!this.options.width) {\n            const firstElementChild = this.getFirstElementChild();\n            this.options.width = firstElementChild.offsetWidth;\n        }\n        return this.options;\n    }\n\n    public getTheOptions() {\n        return this.options.theOptions;\n    }\n\n    public getDefaultFontSize() {\n        return this.options.theOptions?.fontSize || FontSizes.fontSize14;\n    }\n\n    public getEditableElement() {\n        return this.options.nativeElement.querySelector('.the-editor-typo');\n    }\n\n    public getFirstElementChild() {\n        const editableElement = this.getEditableElement();\n        return editableElement?.firstElementChild as HTMLElement;\n    }\n\n    addUploadingFiles(file: { url: string; file: File }) {\n        this.uploadingFiles.push(file);\n    }\n\n    removeUploadFile(file: { url: string; file: File }) {\n        this.uploadingFiles.splice(\n            this.uploadingFiles.findIndex(item => item.url === file.url),\n            1\n        );\n    }\n\n    ngOnDestroy(): void {\n        this.uploadingStatus$.complete();\n        this.containerScrolled$?.complete();\n        this.theEditorResized$?.complete();\n        this.containerResized$?.complete();\n        this.containerResizeObserver?.disconnect();\n        this.theEditorResizeObserver?.disconnect();\n        this.windowResized$?.complete();\n        this.windowResizeObserver?.disconnect();\n        this.scrollSubscription?.unsubscribe();\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n}\n"]}
|
|
@@ -3161,24 +3161,26 @@ class TheContextService {
|
|
|
3161
3161
|
});
|
|
3162
3162
|
}
|
|
3163
3163
|
initialize(options) {
|
|
3164
|
-
var _a, _b;
|
|
3165
3164
|
this.options = options;
|
|
3166
|
-
this.containerElement =
|
|
3167
|
-
this.options.nativeElement.closest((_a = this.options.theOptions) === null || _a === void 0 ? void 0 : _a.scrollContainer) ||
|
|
3168
|
-
this.options.nativeElement.querySelector((_b = this.options.theOptions) === null || _b === void 0 ? void 0 : _b.scrollContainer);
|
|
3169
3165
|
this.rebindContainerScroll();
|
|
3170
3166
|
this.bindContainerResize();
|
|
3171
3167
|
this.bindTheEditorResize();
|
|
3172
3168
|
this.bindWindowResize();
|
|
3173
3169
|
}
|
|
3170
|
+
getScrollContainer() {
|
|
3171
|
+
var _a, _b;
|
|
3172
|
+
return (this.options.nativeElement.closest((_a = this.options.theOptions) === null || _a === void 0 ? void 0 : _a.scrollContainer) ||
|
|
3173
|
+
this.options.nativeElement.querySelector((_b = this.options.theOptions) === null || _b === void 0 ? void 0 : _b.scrollContainer));
|
|
3174
|
+
}
|
|
3174
3175
|
rebindContainerScroll() {
|
|
3175
3176
|
var _a, _b;
|
|
3176
3177
|
(_a = this.scrollSubscription) === null || _a === void 0 ? void 0 : _a.unsubscribe();
|
|
3177
3178
|
if ((_b = this.options.theOptions) === null || _b === void 0 ? void 0 : _b.scrollContainer) {
|
|
3178
|
-
|
|
3179
|
+
const containerElement = this.getScrollContainer();
|
|
3180
|
+
if (containerElement) {
|
|
3179
3181
|
this.ngZone.runOutsideAngular(() => {
|
|
3180
3182
|
let previousContainerScroll = { x: 0, y: 0 };
|
|
3181
|
-
this.scrollSubscription = fromEvent(
|
|
3183
|
+
this.scrollSubscription = fromEvent(containerElement, 'scroll').subscribe(event => {
|
|
3182
3184
|
const entires = { event, direction: ScrollDirection.Y };
|
|
3183
3185
|
const target = event.target;
|
|
3184
3186
|
const [x, y] = [target.scrollLeft, target.scrollTop];
|
|
@@ -3196,8 +3198,9 @@ class TheContextService {
|
|
|
3196
3198
|
}
|
|
3197
3199
|
}
|
|
3198
3200
|
bindContainerResize() {
|
|
3199
|
-
|
|
3200
|
-
|
|
3201
|
+
const containerElement = this.getScrollContainer();
|
|
3202
|
+
if (containerElement) {
|
|
3203
|
+
this.containerResizeObserver = this.elementResize(containerElement, this.containerResized$);
|
|
3201
3204
|
}
|
|
3202
3205
|
}
|
|
3203
3206
|
bindTheEditorResize() {
|
|
@@ -6212,27 +6215,9 @@ const TableEditor = {
|
|
|
6212
6215
|
}
|
|
6213
6216
|
return null;
|
|
6214
6217
|
},
|
|
6215
|
-
isAlignActive(editor, alignment) {
|
|
6216
|
-
const cells = TableEditor.getSelectedCells(editor);
|
|
6217
|
-
if (cells) {
|
|
6218
|
-
const lastCell = cells[cells.length - 1];
|
|
6219
|
-
const tableNode = getAboveByType(editor, ElementKinds.table);
|
|
6220
|
-
const cellPath = [...tableNode[1], lastCell.row, lastCell.col];
|
|
6221
|
-
const cell = Node.get(editor, cellPath);
|
|
6222
|
-
const { align } = cell;
|
|
6223
|
-
if (!align && alignment === Alignment.left) {
|
|
6224
|
-
return true;
|
|
6225
|
-
}
|
|
6226
|
-
return align === alignment;
|
|
6227
|
-
}
|
|
6228
|
-
return null;
|
|
6229
|
-
},
|
|
6230
6218
|
setAlign(editor, alignment) {
|
|
6231
|
-
return TableEditor.handleSelectedCells(editor, (
|
|
6219
|
+
return TableEditor.handleSelectedCells(editor, (_, cellRange) => {
|
|
6232
6220
|
Transforms.setNodes(editor, { align: alignment }, {
|
|
6233
|
-
at: cellPath
|
|
6234
|
-
});
|
|
6235
|
-
Transforms.setNodes(editor, { align: undefined }, {
|
|
6236
6221
|
at: cellRange,
|
|
6237
6222
|
match: (n) => ALIGN_BLOCK_TYPES.includes(n.type)
|
|
6238
6223
|
});
|
|
@@ -6396,10 +6381,6 @@ const AlignEditor = {
|
|
|
6396
6381
|
if (!(editor === null || editor === void 0 ? void 0 : editor.selection)) {
|
|
6397
6382
|
return;
|
|
6398
6383
|
}
|
|
6399
|
-
const tableCellAlign = TableEditor.isAlignActive(editor, alignment);
|
|
6400
|
-
if (tableCellAlign !== null) {
|
|
6401
|
-
return tableCellAlign;
|
|
6402
|
-
}
|
|
6403
6384
|
const blockElement = anchorBlock(editor);
|
|
6404
6385
|
if (blockElement) {
|
|
6405
6386
|
const { align } = blockElement;
|
|
@@ -7785,7 +7766,6 @@ const withMoveSelection = (editor) => {
|
|
|
7785
7766
|
timer(81).subscribe(() => {
|
|
7786
7767
|
Transforms.select(editor, changedRange);
|
|
7787
7768
|
});
|
|
7788
|
-
return;
|
|
7789
7769
|
}
|
|
7790
7770
|
}
|
|
7791
7771
|
onClick(event);
|
|
@@ -14908,7 +14888,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.2", ngImpor
|
|
|
14908
14888
|
}], ctorParameters: function () { return [{ type: i1$1.ThyPopover }, { type: i2$1.Overlay }]; } });
|
|
14909
14889
|
|
|
14910
14890
|
const withTable = (editor) => {
|
|
14911
|
-
const { deleteBackward, deleteForward, onKeydown, setFragmentData, insertData, normalizeNode, isBlockCard, renderElement, deleteCutData, isContainer, onChange } = editor;
|
|
14891
|
+
const { deleteBackward, deleteForward, onKeydown, setFragmentData, insertData, normalizeNode, isBlockCard, renderElement, deleteCutData, isContainer, onChange, onClick } = editor;
|
|
14912
14892
|
editor.deleteBackward = unit => {
|
|
14913
14893
|
const opts = new TableOptions();
|
|
14914
14894
|
if (!isSelectionInTable(opts, editor)) {
|
|
@@ -14941,6 +14921,24 @@ const withTable = (editor) => {
|
|
|
14941
14921
|
}
|
|
14942
14922
|
deleteForward(unit);
|
|
14943
14923
|
};
|
|
14924
|
+
editor.onClick = (event) => {
|
|
14925
|
+
if (event.detail === 3) {
|
|
14926
|
+
const isMergedCell = isSelectedCellMerged(editor);
|
|
14927
|
+
const domSelection = window.getSelection();
|
|
14928
|
+
if (domSelection && !domSelection.isCollapsed && editor.selection) {
|
|
14929
|
+
const slateSelection = AngularEditor.toSlateRange(editor, domSelection);
|
|
14930
|
+
const opts = new TableOptions();
|
|
14931
|
+
const startPosition = TablePosition.create(opts, editor, slateSelection.anchor.path);
|
|
14932
|
+
const endPosition = TablePosition.create(opts, editor, slateSelection.focus.path);
|
|
14933
|
+
if (isMergedCell && startPosition.cell !== endPosition.cell) {
|
|
14934
|
+
timer(81).subscribe(() => {
|
|
14935
|
+
Transforms.select(editor, slateSelection.anchor.path);
|
|
14936
|
+
});
|
|
14937
|
+
}
|
|
14938
|
+
}
|
|
14939
|
+
}
|
|
14940
|
+
onClick(event);
|
|
14941
|
+
};
|
|
14944
14942
|
editor.onKeydown = (event) => {
|
|
14945
14943
|
const opts = new TableOptions();
|
|
14946
14944
|
const isMoveUp = hotkeys.isMoveUp(event);
|