@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.
@@ -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
- if (this.containerElement) {
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(this.containerElement, 'scroll').subscribe(event => {
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
- if (this.containerElement) {
61
- this.containerResizeObserver = this.elementResize(this.containerElement, this.containerResized$);
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
- if (this.containerElement) {
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(this.containerElement, 'scroll').subscribe(event => {
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
- if (this.containerElement) {
3200
- this.containerResizeObserver = this.elementResize(this.containerElement, this.containerResized$);
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, (cellPath, cellRange) => {
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);