@worktile/theia 16.3.13 → 16.3.14

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.
@@ -3,10 +3,10 @@ import { Editor, Element, Transforms } from 'slate';
3
3
  import { ElementKinds, ErrorCodes, PICTURE_ACCEPTED_UPLOAD_MIME, PICTURE_ACCEPTED_UPLOAD_SIZE } from '../../constants';
4
4
  import { getPluginOptions } from '../../core';
5
5
  import { PluginKeys, THE_UPLOAD_SERVICE_TOKEN } from '../../interfaces';
6
+ import * as TheQueries from '../../queries';
6
7
  import { TheContextService } from '../../services/context.service';
7
8
  import * as TheTransforms from '../../transforms';
8
9
  import { base64toBlob } from '../../utils/blob';
9
- import * as TheQueries from '../../queries';
10
10
  export const ImageEditor = {
11
11
  openUpload(editor) {
12
12
  const inputFile = document.createElement('input');
@@ -50,6 +50,23 @@ export const ImageEditor = {
50
50
  file: new File([blob], `${new Date().getTime()}.${ext}`, { type: contentType })
51
51
  });
52
52
  },
53
+ handleExternalImageElement(editor, image) {
54
+ const contextService = editor.injector.get(TheContextService);
55
+ const imageUploaderService = editor.injector.get(THE_UPLOAD_SERVICE_TOKEN);
56
+ const isExternalUrl = image?.hasOwnProperty('externalUrl')
57
+ ? image?.externalUrl
58
+ : imageUploaderService.isExternalUrl?.(image.thumbUrl);
59
+ if (isExternalUrl) {
60
+ const url = image.thumbUrl;
61
+ image.url = url;
62
+ image.externalUrl = url;
63
+ image.thumbUrl = null;
64
+ contextService.addUploadingFiles({
65
+ url: image.url,
66
+ file: image.url
67
+ });
68
+ }
69
+ },
53
70
  verifyImage(editor, image) {
54
71
  if (!PICTURE_ACCEPTED_UPLOAD_MIME.includes(image.type)) {
55
72
  editor.onError({
@@ -85,20 +102,6 @@ export const ImageEditor = {
85
102
  isBase64(url) {
86
103
  return isString(url) && url.includes('base64');
87
104
  },
88
- /**
89
- * 设置图片来源
90
- * @param editor 编辑器对象
91
- * @param image 图片节点
92
- */
93
- setImageSource(editor, image) {
94
- const imageUploaderService = editor.injector.get(THE_UPLOAD_SERVICE_TOKEN);
95
- const externalSource = image?.hasOwnProperty('externalSource')
96
- ? image?.externalSource
97
- : imageUploaderService.isExternalSource?.(image.thumbUrl);
98
- if (externalSource) {
99
- image.externalSource = externalSource;
100
- }
101
- },
102
105
  removeImage(editor, image) {
103
106
  if (image) {
104
107
  TheTransforms.deleteElement(editor, image);
@@ -108,4 +111,4 @@ export const ImageEditor = {
108
111
  }
109
112
  }
110
113
  };
111
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image.editor.js","sourceRoot":"","sources":["../../../../../packages/src/plugins/image/image.editor.ts"],"names":[],"mappings":"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","sourcesContent":["import { isString } from 'ngx-tethys/util';\nimport { Editor, Element, Path, Transforms } from 'slate';\nimport {\n    Alignment,\n    ElementKinds,\n    ErrorCodes,\n    LayoutTypes,\n    PICTURE_ACCEPTED_UPLOAD_MIME,\n    PICTURE_ACCEPTED_UPLOAD_SIZE\n} from '../../constants';\nimport { getPluginOptions } from '../../core';\nimport { ImageElement } from '../../custom-types';\nimport { ImagePluginOptions, PluginKeys, THE_UPLOAD_SERVICE_TOKEN } from '../../interfaces';\nimport { TheContextService } from '../../services/context.service';\nimport * as TheTransforms from '../../transforms';\nimport { base64toBlob } from '../../utils/blob';\nimport * as TheQueries from '../../queries';\n\nexport const ImageEditor = {\n    openUpload(editor: Editor) {\n        const inputFile = document.createElement('input');\n        inputFile.setAttribute('type', 'file');\n        inputFile.setAttribute('accept', 'image/*');\n        inputFile.setAttribute('multiple', 'true');\n        inputFile.onchange = (event: Event) => {\n            ImageEditor.insertImages(editor, (event.target as any).files);\n        };\n        inputFile.click();\n    },\n    insertImages(editor: Editor, imageFiles: FileList | File[]) {\n        const contextService = editor.injector.get(TheContextService);\n        const imageNodes: Element[] = [];\n        const text = { text: '' };\n        for (const image of imageFiles) {\n            const verify = ImageEditor.verifyImage(editor, image);\n            if (verify) {\n                const url = URL.createObjectURL(image);\n                contextService.addUploadingFiles({ url, file: image });\n                imageNodes.push({ type: ElementKinds.image, url, children: [text] });\n            }\n        }\n        if (imageNodes.length > 0) {\n            TheTransforms.insertElements(editor, imageNodes);\n        }\n    },\n    handleBase64ImageElement(editor: Editor, image: ImageElement) {\n        const indexSplit = image.originUrl.indexOf(',');\n        const base64 = image.originUrl.slice(indexSplit + 1);\n        const contentType = image.originUrl.substring(image.originUrl.indexOf(':') + 1, image.originUrl.indexOf(';'));\n        const ext = contentType.substring(contentType.indexOf('/') + 1);\n        const blob = base64toBlob(base64, contentType);\n        const blobUrl = URL.createObjectURL(blob);\n        image.thumbUrl = blobUrl;\n        image.originUrl = blobUrl;\n        image.url = blobUrl;\n        const contextService = editor.injector.get(TheContextService);\n        contextService.addUploadingFiles({\n            url: blobUrl,\n            file: new File([blob], `${new Date().getTime()}.${ext}`, { type: contentType })\n        });\n    },\n    verifyImage(editor: Editor, image: File) {\n        if (!PICTURE_ACCEPTED_UPLOAD_MIME.includes(image.type)) {\n            editor.onError({\n                code: ErrorCodes.IMAGE_ERR_MIME_FORMAT\n            });\n            return false;\n        }\n        const acceptedUploadSize =\n            getPluginOptions<ImagePluginOptions>(editor, PluginKeys.image)?.acceptedUploadSize ?? PICTURE_ACCEPTED_UPLOAD_SIZE;\n        if (image.size / 1000000 >= acceptedUploadSize) {\n            editor.onError({\n                code: ErrorCodes.IMAGE_ERR_SIZE_LIMIT\n            });\n            return false;\n        }\n        return true;\n    },\n    isActive(editor: Editor): boolean {\n        const [match] = Editor.nodes(editor, {\n            match: n => Element.isElement(n) && n.type === ElementKinds.image,\n            universal: true\n        });\n        return !!match;\n    },\n    setImageNode(editor: Editor, props: Partial<ImageElement>, image?: ImageElement) {\n        if (!image) {\n            TheTransforms.setNodeByType(editor, props, ElementKinds.image);\n        } else {\n            const path = TheQueries.findPath(editor, image);\n            Transforms.setNodes(editor, props, { at: path });\n        }\n    },\n    isBase64(url: string) {\n        return isString(url) && url.includes('base64');\n    },\n    /**\n     * 设置图片来源\n     * @param editor 编辑器对象\n     * @param image 图片节点\n     */\n    setImageSource(editor: Editor, image: ImageElement) {\n        const imageUploaderService = editor.injector.get(THE_UPLOAD_SERVICE_TOKEN);\n        const externalSource = image?.hasOwnProperty('externalSource')\n            ? image?.externalSource\n            : imageUploaderService.isExternalSource?.(image.thumbUrl);\n        if (externalSource) {\n            image.externalSource = externalSource;\n        }\n    },\n    removeImage(editor: Editor, image?: ImageElement) {\n        if (image) {\n            TheTransforms.deleteElement(editor, image);\n        } else {\n            TheTransforms.deleteNodeByType(editor, ElementKinds.image);\n        }\n    }\n};\n"]}
114
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image.editor.js","sourceRoot":"","sources":["../../../../../packages/src/plugins/image/image.editor.ts"],"names":[],"mappings":"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","sourcesContent":["import { isString } from 'ngx-tethys/util';\nimport { Editor, Element, Transforms } from 'slate';\nimport { ElementKinds, ErrorCodes, PICTURE_ACCEPTED_UPLOAD_MIME, PICTURE_ACCEPTED_UPLOAD_SIZE } from '../../constants';\nimport { getPluginOptions } from '../../core';\nimport { ImageElement } from '../../custom-types';\nimport { ImagePluginOptions, PluginKeys, THE_UPLOAD_SERVICE_TOKEN } from '../../interfaces';\nimport * as TheQueries from '../../queries';\nimport { TheContextService } from '../../services/context.service';\nimport * as TheTransforms from '../../transforms';\nimport { base64toBlob } from '../../utils/blob';\n\nexport const ImageEditor = {\n    openUpload(editor: Editor) {\n        const inputFile = document.createElement('input');\n        inputFile.setAttribute('type', 'file');\n        inputFile.setAttribute('accept', 'image/*');\n        inputFile.setAttribute('multiple', 'true');\n        inputFile.onchange = (event: Event) => {\n            ImageEditor.insertImages(editor, (event.target as any).files);\n        };\n        inputFile.click();\n    },\n    insertImages(editor: Editor, imageFiles: FileList | File[]) {\n        const contextService = editor.injector.get(TheContextService);\n        const imageNodes: Element[] = [];\n        const text = { text: '' };\n        for (const image of imageFiles) {\n            const verify = ImageEditor.verifyImage(editor, image);\n            if (verify) {\n                const url = URL.createObjectURL(image);\n                contextService.addUploadingFiles({ url, file: image });\n                imageNodes.push({ type: ElementKinds.image, url, children: [text] });\n            }\n        }\n        if (imageNodes.length > 0) {\n            TheTransforms.insertElements(editor, imageNodes);\n        }\n    },\n    handleBase64ImageElement(editor: Editor, image: ImageElement) {\n        const indexSplit = image.originUrl.indexOf(',');\n        const base64 = image.originUrl.slice(indexSplit + 1);\n        const contentType = image.originUrl.substring(image.originUrl.indexOf(':') + 1, image.originUrl.indexOf(';'));\n        const ext = contentType.substring(contentType.indexOf('/') + 1);\n        const blob = base64toBlob(base64, contentType);\n        const blobUrl = URL.createObjectURL(blob);\n        image.thumbUrl = blobUrl;\n        image.originUrl = blobUrl;\n        image.url = blobUrl;\n        const contextService = editor.injector.get(TheContextService);\n        contextService.addUploadingFiles({\n            url: blobUrl,\n            file: new File([blob], `${new Date().getTime()}.${ext}`, { type: contentType })\n        });\n    },\n    handleExternalImageElement(editor: Editor, image: ImageElement) {\n        const contextService = editor.injector.get(TheContextService);\n        const imageUploaderService = editor.injector.get(THE_UPLOAD_SERVICE_TOKEN);\n        const isExternalUrl = image?.hasOwnProperty('externalUrl')\n            ? image?.externalUrl\n            : imageUploaderService.isExternalUrl?.(image.thumbUrl);\n\n        if (isExternalUrl) {\n            const url = image.thumbUrl;\n            image.url = url;\n            image.externalUrl = url;\n            image.thumbUrl = null;\n\n            contextService.addUploadingFiles({\n                url: image.url,\n                file: image.url\n            });\n        }\n    },\n    verifyImage(editor: Editor, image: File) {\n        if (!PICTURE_ACCEPTED_UPLOAD_MIME.includes(image.type)) {\n            editor.onError({\n                code: ErrorCodes.IMAGE_ERR_MIME_FORMAT\n            });\n            return false;\n        }\n        const acceptedUploadSize =\n            getPluginOptions<ImagePluginOptions>(editor, PluginKeys.image)?.acceptedUploadSize ?? PICTURE_ACCEPTED_UPLOAD_SIZE;\n        if (image.size / 1000000 >= acceptedUploadSize) {\n            editor.onError({\n                code: ErrorCodes.IMAGE_ERR_SIZE_LIMIT\n            });\n            return false;\n        }\n        return true;\n    },\n    isActive(editor: Editor): boolean {\n        const [match] = Editor.nodes(editor, {\n            match: n => Element.isElement(n) && n.type === ElementKinds.image,\n            universal: true\n        });\n        return !!match;\n    },\n    setImageNode(editor: Editor, props: Partial<ImageElement>, image?: ImageElement) {\n        if (!image) {\n            TheTransforms.setNodeByType(editor, props, ElementKinds.image);\n        } else {\n            const path = TheQueries.findPath(editor, image);\n            Transforms.setNodes(editor, props, { at: path });\n        }\n    },\n    isBase64(url: string) {\n        return isString(url) && url.includes('base64');\n    },\n    removeImage(editor: Editor, image?: ImageElement) {\n        if (image) {\n            TheTransforms.deleteElement(editor, image);\n        } else {\n            TheTransforms.deleteNodeByType(editor, ElementKinds.image);\n        }\n    }\n};\n"]}
@@ -109,6 +109,9 @@ export class TheContextService {
109
109
  this.uploadingFiles.push(file);
110
110
  }
111
111
  removeUploadFile(file) {
112
+ if (!file) {
113
+ return;
114
+ }
112
115
  this.uploadingFiles.splice(this.uploadingFiles.findIndex(item => item.url === file.url), 1);
113
116
  }
114
117
  ngOnDestroy() {
@@ -130,4 +133,4 @@ export class TheContextService {
130
133
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TheContextService, decorators: [{
131
134
  type: Injectable
132
135
  }], ctorParameters: function () { return [{ type: i0.NgZone }]; } });
133
- //# 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 { Observable, Subject, Subscription, fromEvent } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { FontSizes, MarkTypes, ScrollDirection } from '../constants/node-types';\nimport { TheEditor } from '../interfaces';\n\nexport interface TheContextOptions {\n    editor: TheEditor;\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        const { scrollContainer } = this.options.editor?.options;\n        return this.options.nativeElement.closest(scrollContainer) || this.options.nativeElement.querySelector(scrollContainer);\n    }\n\n    rebindContainerScroll() {\n        this.scrollSubscription?.unsubscribe();\n        const { scrollContainer } = this.options.editor?.options;\n        if (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 getDefaultFontSize() {\n        return this.options.editor?.options?.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"]}
136
+ //# 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 { Observable, Subject, Subscription, fromEvent } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { FontSizes, MarkTypes, ScrollDirection } from '../constants/node-types';\nimport { TheEditor } from '../interfaces';\n\nexport interface TheContextOptions {\n    editor: TheEditor;\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 | string }[] = [];\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        const { scrollContainer } = this.options.editor?.options;\n        return this.options.nativeElement.closest(scrollContainer) || this.options.nativeElement.querySelector(scrollContainer);\n    }\n\n    rebindContainerScroll() {\n        this.scrollSubscription?.unsubscribe();\n        const { scrollContainer } = this.options.editor?.options;\n        if (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 getDefaultFontSize() {\n        return this.options.editor?.options?.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 | string }) {\n        this.uploadingFiles.push(file);\n    }\n\n    removeUploadFile(file: { url: string; file: File | string }) {\n        if (!file) {\n            return;\n        }\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"]}
@@ -45,4 +45,4 @@ export function dataSerializing(mode, value) {
45
45
  }
46
46
  return value;
47
47
  }
48
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS10cmFuc2Zvcm0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9zcmMvdXRpbHMvZGF0YS10cmFuc2Zvcm0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMvQyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sY0FBYyxDQUFDO0FBQzVDLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDNUMsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFFaEUsTUFBTSxVQUFVLFlBQVksQ0FBQyxJQUFZO0lBQ3JDLElBQUksT0FBTyxJQUFJLEtBQUssUUFBUSxFQUFFO1FBQzFCLE9BQU8sSUFBSSxDQUFDO0tBQ2Y7SUFDRCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFO1FBQzVCLE9BQU87WUFDSCxJQUFJLEVBQUUsWUFBWSxDQUFDLFNBQVM7WUFDNUIsUUFBUSxFQUFFO2dCQUNOO29CQUNJLElBQUksRUFBRSxDQUFDO2lCQUNWO2FBQ0o7U0FDSixDQUFDO0lBQ04sQ0FBQyxDQUFDLENBQUM7QUFDUCxDQUFDO0FBRUQsTUFBTSxVQUFVLFdBQVcsQ0FBQyxLQUFhO0lBQ3JDLElBQUksT0FBTyxLQUFLLEtBQUssUUFBUSxFQUFFO1FBQzNCLE1BQU0sT0FBTyxHQUFHLElBQUksU0FBUyxFQUFFLENBQUMsZUFBZSxDQUFDLEtBQUssRUFBRSxXQUFXLENBQUMsQ0FBQztRQUNwRSxPQUFPLGNBQWMsQ0FBQyxjQUFjLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUM7S0FDM0U7SUFDRCxPQUFPLEtBQUssQ0FBQztBQUNqQixDQUFDO0FBRUQsTUFBTSxVQUFVLGVBQWUsQ0FBQyxJQUFpQixFQUFFLEtBQTRCO0lBQzNFLElBQUksQ0FBQyxLQUFLLEVBQUU7UUFDUixPQUFPLENBQUMsb0JBQW9CLEVBQUUsQ0FBQyxDQUFDO0tBQ25DO0lBQ0QsSUFBSSxJQUFJLEtBQUssV0FBVyxDQUFDLElBQUksRUFBRTtRQUMzQixJQUFJLE9BQU8sS0FBSyxLQUFLLFFBQVEsRUFBRTtZQUMzQixPQUFPLEtBQUssQ0FBQztTQUNoQjtRQUNELElBQUksU0FBUyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUN2QixPQUFPLFdBQVcsQ0FBQyxLQUFLLENBQUMsQ0FBQztTQUM3QjtRQUNELE9BQU8sWUFBWSxDQUFDLEtBQUssQ0FBQyxDQUFDO0tBQzlCO0lBQ0QsT0FBUSxLQUFzQixJQUFJLENBQUMsb0JBQW9CLEVBQUUsQ0FBQyxDQUFDO0FBQy9ELENBQUM7QUFFRCxNQUFNLFVBQVUsZUFBZSxDQUFDLElBQWlCLEVBQUUsS0FBbUI7SUFDbEUsSUFBSSxJQUFJLEtBQUssV0FBVyxDQUFDLElBQUksRUFBRTtRQUMzQixPQUFPLGNBQWMsQ0FBQyxhQUFhLENBQUMsS0FBWSxDQUFDLENBQUM7S0FDckQ7SUFDRCxPQUFPLEtBQUssQ0FBQztBQUNqQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGVzY2VuZGFudCB9IGZyb20gJ3NsYXRlJztcbmltcG9ydCB7IFRoZWlhQ29udmVydGVyIH0gZnJvbSAnQGF0aW5jL3NlbGVuZSc7XG5pbXBvcnQgeyBFbGVtZW50S2luZHMgfSBmcm9tICcuLi9jb25zdGFudHMnO1xuaW1wb3J0IHsgVGhlRGF0YU1vZGUgfSBmcm9tICcuLi9pbnRlcmZhY2VzJztcbmltcG9ydCB7IGNyZWF0ZUVtcHR5UGFyYWdyYXBoIH0gZnJvbSAnLi9jcmVhdGUtZW1wdHktcGFyYWdyYXBoJztcblxuZXhwb3J0IGZ1bmN0aW9uIHBsYWluVG9UaGVpYSh0ZXh0OiBzdHJpbmcpOiBEZXNjZW5kYW50W10ge1xuICAgIGlmICh0eXBlb2YgdGV4dCAhPT0gJ3N0cmluZycpIHtcbiAgICAgICAgcmV0dXJuIHRleHQ7XG4gICAgfVxuICAgIHJldHVybiB0ZXh0LnNwbGl0KCdcXG4nKS5tYXAoaSA9PiB7XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICB0eXBlOiBFbGVtZW50S2luZHMucGFyYWdyYXBoLFxuICAgICAgICAgICAgY2hpbGRyZW46IFtcbiAgICAgICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgICAgIHRleHQ6IGlcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICBdXG4gICAgICAgIH07XG4gICAgfSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBodG1sVG9UaGVpYSh2YWx1ZTogc3RyaW5nKTogRGVzY2VuZGFudFtdIHtcbiAgICBpZiAodHlwZW9mIHZhbHVlID09PSAnc3RyaW5nJykge1xuICAgICAgICBjb25zdCBodG1sRG9tID0gbmV3IERPTVBhcnNlcigpLnBhcnNlRnJvbVN0cmluZyh2YWx1ZSwgJ3RleHQvaHRtbCcpO1xuICAgICAgICByZXR1cm4gVGhlaWFDb252ZXJ0ZXIuY29udmVydFRvVGhlaWEoQXJyYXkuZnJvbShodG1sRG9tLmJvZHkuY2hpbGRyZW4pKTtcbiAgICB9XG4gICAgcmV0dXJuIHZhbHVlO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZGF0YURlc2VyaWFsaXplKG1vZGU6IFRoZURhdGFNb2RlLCB2YWx1ZTogRGVzY2VuZGFudFtdIHwgc3RyaW5nKTogRGVzY2VuZGFudFtdIHtcbiAgICBpZiAoIXZhbHVlKSB7XG4gICAgICAgIHJldHVybiBbY3JlYXRlRW1wdHlQYXJhZ3JhcGgoKV07XG4gICAgfVxuICAgIGlmIChtb2RlID09PSBUaGVEYXRhTW9kZS5odG1sKSB7XG4gICAgICAgIGlmICh0eXBlb2YgdmFsdWUgIT09ICdzdHJpbmcnKSB7XG4gICAgICAgICAgICByZXR1cm4gdmFsdWU7XG4gICAgICAgIH1cbiAgICAgICAgaWYgKC88W14+XSs+Ly50ZXN0KHZhbHVlKSkge1xuICAgICAgICAgICAgcmV0dXJuIGh0bWxUb1RoZWlhKHZhbHVlKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gcGxhaW5Ub1RoZWlhKHZhbHVlKTtcbiAgICB9XG4gICAgcmV0dXJuICh2YWx1ZSBhcyBEZXNjZW5kYW50W10pIHx8IFtjcmVhdGVFbXB0eVBhcmFncmFwaCgpXTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGRhdGFTZXJpYWxpemluZyhtb2RlOiBUaGVEYXRhTW9kZSwgdmFsdWU6IERlc2NlbmRhbnRbXSk6IHN0cmluZyB8IERlc2NlbmRhbnRbXSB7XG4gICAgaWYgKG1vZGUgPT09IFRoZURhdGFNb2RlLmh0bWwpIHtcbiAgICAgICAgcmV0dXJuIFRoZWlhQ29udmVydGVyLmNvbnZlcnRUb0h0bWwodmFsdWUgYXMgYW55KTtcbiAgICB9XG4gICAgcmV0dXJuIHZhbHVlO1xufVxuIl19
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS10cmFuc2Zvcm0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9zcmMvdXRpbHMvZGF0YS10cmFuc2Zvcm0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUvQyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sY0FBYyxDQUFDO0FBQzVDLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDNUMsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFFaEUsTUFBTSxVQUFVLFlBQVksQ0FBQyxJQUFZO0lBQ3JDLElBQUksT0FBTyxJQUFJLEtBQUssUUFBUSxFQUFFO1FBQzFCLE9BQU8sSUFBSSxDQUFDO0tBQ2Y7SUFDRCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFO1FBQzVCLE9BQU87WUFDSCxJQUFJLEVBQUUsWUFBWSxDQUFDLFNBQVM7WUFDNUIsUUFBUSxFQUFFO2dCQUNOO29CQUNJLElBQUksRUFBRSxDQUFDO2lCQUNWO2FBQ0o7U0FDSixDQUFDO0lBQ04sQ0FBQyxDQUFDLENBQUM7QUFDUCxDQUFDO0FBRUQsTUFBTSxVQUFVLFdBQVcsQ0FBQyxLQUFhO0lBQ3JDLElBQUksT0FBTyxLQUFLLEtBQUssUUFBUSxFQUFFO1FBQzNCLE1BQU0sT0FBTyxHQUFHLElBQUksU0FBUyxFQUFFLENBQUMsZUFBZSxDQUFDLEtBQUssRUFBRSxXQUFXLENBQUMsQ0FBQztRQUNwRSxPQUFPLGNBQWMsQ0FBQyxjQUFjLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUM7S0FDM0U7SUFDRCxPQUFPLEtBQUssQ0FBQztBQUNqQixDQUFDO0FBRUQsTUFBTSxVQUFVLGVBQWUsQ0FBQyxJQUFpQixFQUFFLEtBQTRCO0lBQzNFLElBQUksQ0FBQyxLQUFLLEVBQUU7UUFDUixPQUFPLENBQUMsb0JBQW9CLEVBQUUsQ0FBQyxDQUFDO0tBQ25DO0lBQ0QsSUFBSSxJQUFJLEtBQUssV0FBVyxDQUFDLElBQUksRUFBRTtRQUMzQixJQUFJLE9BQU8sS0FBSyxLQUFLLFFBQVEsRUFBRTtZQUMzQixPQUFPLEtBQUssQ0FBQztTQUNoQjtRQUNELElBQUksU0FBUyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUN2QixPQUFPLFdBQVcsQ0FBQyxLQUFLLENBQUMsQ0FBQztTQUM3QjtRQUNELE9BQU8sWUFBWSxDQUFDLEtBQUssQ0FBQyxDQUFDO0tBQzlCO0lBQ0QsT0FBUSxLQUFzQixJQUFJLENBQUMsb0JBQW9CLEVBQUUsQ0FBQyxDQUFDO0FBQy9ELENBQUM7QUFFRCxNQUFNLFVBQVUsZUFBZSxDQUFDLElBQWlCLEVBQUUsS0FBbUI7SUFDbEUsSUFBSSxJQUFJLEtBQUssV0FBVyxDQUFDLElBQUksRUFBRTtRQUMzQixPQUFPLGNBQWMsQ0FBQyxhQUFhLENBQUMsS0FBWSxDQUFDLENBQUM7S0FDckQ7SUFDRCxPQUFPLEtBQUssQ0FBQztBQUNqQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVGhlaWFDb252ZXJ0ZXIgfSBmcm9tICdAYXRpbmMvc2VsZW5lJztcbmltcG9ydCB7IERlc2NlbmRhbnQgfSBmcm9tICdzbGF0ZSc7XG5pbXBvcnQgeyBFbGVtZW50S2luZHMgfSBmcm9tICcuLi9jb25zdGFudHMnO1xuaW1wb3J0IHsgVGhlRGF0YU1vZGUgfSBmcm9tICcuLi9pbnRlcmZhY2VzJztcbmltcG9ydCB7IGNyZWF0ZUVtcHR5UGFyYWdyYXBoIH0gZnJvbSAnLi9jcmVhdGUtZW1wdHktcGFyYWdyYXBoJztcblxuZXhwb3J0IGZ1bmN0aW9uIHBsYWluVG9UaGVpYSh0ZXh0OiBzdHJpbmcpOiBEZXNjZW5kYW50W10ge1xuICAgIGlmICh0eXBlb2YgdGV4dCAhPT0gJ3N0cmluZycpIHtcbiAgICAgICAgcmV0dXJuIHRleHQ7XG4gICAgfVxuICAgIHJldHVybiB0ZXh0LnNwbGl0KCdcXG4nKS5tYXAoaSA9PiB7XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICB0eXBlOiBFbGVtZW50S2luZHMucGFyYWdyYXBoLFxuICAgICAgICAgICAgY2hpbGRyZW46IFtcbiAgICAgICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgICAgIHRleHQ6IGlcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICBdXG4gICAgICAgIH07XG4gICAgfSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBodG1sVG9UaGVpYSh2YWx1ZTogc3RyaW5nKTogRGVzY2VuZGFudFtdIHtcbiAgICBpZiAodHlwZW9mIHZhbHVlID09PSAnc3RyaW5nJykge1xuICAgICAgICBjb25zdCBodG1sRG9tID0gbmV3IERPTVBhcnNlcigpLnBhcnNlRnJvbVN0cmluZyh2YWx1ZSwgJ3RleHQvaHRtbCcpO1xuICAgICAgICByZXR1cm4gVGhlaWFDb252ZXJ0ZXIuY29udmVydFRvVGhlaWEoQXJyYXkuZnJvbShodG1sRG9tLmJvZHkuY2hpbGRyZW4pKTtcbiAgICB9XG4gICAgcmV0dXJuIHZhbHVlO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZGF0YURlc2VyaWFsaXplKG1vZGU6IFRoZURhdGFNb2RlLCB2YWx1ZTogRGVzY2VuZGFudFtdIHwgc3RyaW5nKTogRGVzY2VuZGFudFtdIHtcbiAgICBpZiAoIXZhbHVlKSB7XG4gICAgICAgIHJldHVybiBbY3JlYXRlRW1wdHlQYXJhZ3JhcGgoKV07XG4gICAgfVxuICAgIGlmIChtb2RlID09PSBUaGVEYXRhTW9kZS5odG1sKSB7XG4gICAgICAgIGlmICh0eXBlb2YgdmFsdWUgIT09ICdzdHJpbmcnKSB7XG4gICAgICAgICAgICByZXR1cm4gdmFsdWU7XG4gICAgICAgIH1cbiAgICAgICAgaWYgKC88W14+XSs+Ly50ZXN0KHZhbHVlKSkge1xuICAgICAgICAgICAgcmV0dXJuIGh0bWxUb1RoZWlhKHZhbHVlKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gcGxhaW5Ub1RoZWlhKHZhbHVlKTtcbiAgICB9XG4gICAgcmV0dXJuICh2YWx1ZSBhcyBEZXNjZW5kYW50W10pIHx8IFtjcmVhdGVFbXB0eVBhcmFncmFwaCgpXTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGRhdGFTZXJpYWxpemluZyhtb2RlOiBUaGVEYXRhTW9kZSwgdmFsdWU6IERlc2NlbmRhbnRbXSk6IHN0cmluZyB8IERlc2NlbmRhbnRbXSB7XG4gICAgaWYgKG1vZGUgPT09IFRoZURhdGFNb2RlLmh0bWwpIHtcbiAgICAgICAgcmV0dXJuIFRoZWlhQ29udmVydGVyLmNvbnZlcnRUb0h0bWwodmFsdWUgYXMgYW55KTtcbiAgICB9XG4gICAgcmV0dXJuIHZhbHVlO1xufVxuIl19
@@ -24,7 +24,7 @@ import { ThyDropdownDirective, ThyDropdownModule } from 'ngx-tethys/dropdown';
24
24
  import * as i8 from 'ngx-tethys/tooltip';
25
25
  import { ThyTooltipModule } from 'ngx-tethys/tooltip';
26
26
  import { DOWN_ARROW, UP_ARROW, RIGHT_ARROW, LEFT_ARROW, ENTER } from '@angular/cdk/keycodes';
27
- import { fromEvent, Subject, combineLatest, Observable, timer, BehaviorSubject, merge, ReplaySubject } from 'rxjs';
27
+ import { fromEvent, Subject, combineLatest, Observable, timer, firstValueFrom, BehaviorSubject, merge, ReplaySubject } from 'rxjs';
28
28
  import { debounceTime, takeUntil, startWith, distinctUntilChanged, skip, map as map$1, share, take, delay, filter, mapTo, pairwise } from 'rxjs/operators';
29
29
  import { mixinUnsubscribe, MixinBase, ScrollToService } from 'ngx-tethys/core';
30
30
  import { isKeyHotkey } from 'is-hotkey';
@@ -49,7 +49,7 @@ import { ThyColorPickerModule } from 'ngx-tethys/color-picker';
49
49
  import { marked } from 'marked';
50
50
  import * as i1$3 from 'ngx-tethys/alert';
51
51
  import { ThyAlertModule } from 'ngx-tethys/alert';
52
- import * as i4$1 from 'ngx-tethys/image';
52
+ import * as i1$4 from 'ngx-tethys/image';
53
53
  import { ThyImageDirective, ThyImageModule } from 'ngx-tethys/image';
54
54
  import { ThyUploadStatus } from 'ngx-tethys/upload';
55
55
  import * as i9$1 from 'ngx-tethys/progress';
@@ -5735,6 +5735,9 @@ class TheContextService {
5735
5735
  this.uploadingFiles.push(file);
5736
5736
  }
5737
5737
  removeUploadFile(file) {
5738
+ if (!file) {
5739
+ return;
5740
+ }
5738
5741
  this.uploadingFiles.splice(this.uploadingFiles.findIndex(item => item.url === file.url), 1);
5739
5742
  }
5740
5743
  ngOnDestroy() {
@@ -5800,6 +5803,23 @@ const ImageEditor = {
5800
5803
  file: new File([blob], `${new Date().getTime()}.${ext}`, { type: contentType })
5801
5804
  });
5802
5805
  },
5806
+ handleExternalImageElement(editor, image) {
5807
+ const contextService = editor.injector.get(TheContextService);
5808
+ const imageUploaderService = editor.injector.get(THE_UPLOAD_SERVICE_TOKEN);
5809
+ const isExternalUrl = image?.hasOwnProperty('externalUrl')
5810
+ ? image?.externalUrl
5811
+ : imageUploaderService.isExternalUrl?.(image.thumbUrl);
5812
+ if (isExternalUrl) {
5813
+ const url = image.thumbUrl;
5814
+ image.url = url;
5815
+ image.externalUrl = url;
5816
+ image.thumbUrl = null;
5817
+ contextService.addUploadingFiles({
5818
+ url: image.url,
5819
+ file: image.url
5820
+ });
5821
+ }
5822
+ },
5803
5823
  verifyImage(editor, image) {
5804
5824
  if (!PICTURE_ACCEPTED_UPLOAD_MIME.includes(image.type)) {
5805
5825
  editor.onError({
@@ -5835,20 +5855,6 @@ const ImageEditor = {
5835
5855
  isBase64(url) {
5836
5856
  return isString(url) && url.includes('base64');
5837
5857
  },
5838
- /**
5839
- * 设置图片来源
5840
- * @param editor 编辑器对象
5841
- * @param image 图片节点
5842
- */
5843
- setImageSource(editor, image) {
5844
- const imageUploaderService = editor.injector.get(THE_UPLOAD_SERVICE_TOKEN);
5845
- const externalSource = image?.hasOwnProperty('externalSource')
5846
- ? image?.externalSource
5847
- : imageUploaderService.isExternalSource?.(image.thumbUrl);
5848
- if (externalSource) {
5849
- image.externalSource = externalSource;
5850
- }
5851
- },
5852
5858
  removeImage(editor, image) {
5853
5859
  if (image) {
5854
5860
  deleteElement(editor, image);
@@ -8636,7 +8642,7 @@ const withDeserializeHTML = (editor) => {
8636
8642
  ImageEditor.handleBase64ImageElement(editor, node);
8637
8643
  }
8638
8644
  else {
8639
- ImageEditor.setImageSource(editor, node);
8645
+ ImageEditor.handleExternalImageElement(editor, node);
8640
8646
  }
8641
8647
  }
8642
8648
  });
@@ -8750,7 +8756,7 @@ const withDeserializeMd = (editor) => {
8750
8756
  ImageEditor.handleBase64ImageElement(editor, node);
8751
8757
  }
8752
8758
  else {
8753
- ImageEditor.setImageSource(editor, node);
8759
+ ImageEditor.handleExternalImageElement(editor, node);
8754
8760
  }
8755
8761
  }
8756
8762
  });
@@ -9142,16 +9148,17 @@ class TheImageComponent extends TheBaseElementComponent {
9142
9148
  ? this.layoutDefaultWidth
9143
9149
  : this.imageEntry.width;
9144
9150
  }
9145
- constructor(elementRef, imageUploaderService, cdr, theContextService, thyPopover, overlay, viewContainerRef, imageGroupComponent) {
9151
+ constructor(elementRef, cdr, imageGroupComponent, imageUploaderService, theContextService, thyPopover, overlay, viewContainerRef, destroyRef) {
9146
9152
  super(elementRef, cdr);
9147
9153
  this.elementRef = elementRef;
9148
- this.imageUploaderService = imageUploaderService;
9149
9154
  this.cdr = cdr;
9155
+ this.imageGroupComponent = imageGroupComponent;
9156
+ this.imageUploaderService = imageUploaderService;
9150
9157
  this.theContextService = theContextService;
9151
9158
  this.thyPopover = thyPopover;
9152
9159
  this.overlay = overlay;
9153
9160
  this.viewContainerRef = viewContainerRef;
9154
- this.imageGroupComponent = imageGroupComponent;
9161
+ this.destroyRef = destroyRef;
9155
9162
  this.naturalWidth = 0;
9156
9163
  this.naturalHeight = 0;
9157
9164
  this.imageEntry = {};
@@ -9204,68 +9211,33 @@ class TheImageComponent extends TheBaseElementComponent {
9204
9211
  this.dragable = false;
9205
9212
  this.beforeContextChange = (value) => {
9206
9213
  if (value.element !== this.element && value.element.thumbUrl) {
9207
- const externalSource = value.element?.externalSource;
9208
9214
  let thumbUrl = value.element.thumbUrl;
9209
9215
  let originUrl = value.element.originUrl;
9210
- if (!externalSource && this.imageUploaderService?.buildImageUrl) {
9216
+ if (this.imageUploaderService?.buildImageUrl) {
9211
9217
  thumbUrl = this.imageUploaderService.buildImageUrl(thumbUrl);
9212
9218
  originUrl = this.imageUploaderService.buildImageUrl(originUrl);
9213
9219
  }
9214
9220
  this.imageEntry = {
9215
- name: value.element.name,
9216
- width: value.element.width,
9217
- height: value.element.height,
9221
+ ...value.element,
9218
9222
  align: value.element.align || Alignment.left,
9219
- layout: value.element.layout,
9220
- reSized: value.element.reSized || false,
9221
- size: value.element.size,
9222
- thumbUrl,
9223
- originUrl
9223
+ reSized: value.element.reSized || false
9224
9224
  };
9225
9225
  this.setBlockCardLayoutAttr();
9226
9226
  }
9227
9227
  };
9228
9228
  }
9229
9229
  ngOnInit() {
9230
- this.fileItem = this.theContextService.uploadingFiles.find(item => item.url === this.element.url);
9231
- if (this.fileItem?.file && this.fileItem.file instanceof File) {
9232
- this.uploadImage(this.fileItem.file);
9233
- }
9234
9230
  super.ngOnInit();
9235
- this.imagePluginOptions = getPluginOptions(this.editor, PluginKeys.image);
9236
- if (this.imagePluginOptions.disablePreview && typeof this.imagePluginOptions.disablePreview === 'function') {
9237
- this.disablePreview = this.imagePluginOptions.disablePreview(this.editor);
9238
- }
9239
- else {
9240
- this.disablePreview = this.imagePluginOptions.disablePreview;
9231
+ this.setImageFileItem();
9232
+ if (this.fileItem?.file) {
9233
+ this.uploadImage();
9241
9234
  }
9235
+ this.setImagePluginOptions();
9236
+ this.setDisablePreview();
9242
9237
  }
9243
- imageClick() {
9244
- const index = this.imageGroupComponent.images.findIndex(item => item === this.imageDirective);
9245
- const imageGroup = this.imageGroupComponent.images.map(item => {
9246
- return {
9247
- originUrl: item.thyOriginSrc,
9248
- thumbUrl: item.thyPreviewSrc,
9249
- name: item.thyImageMeta.name,
9250
- size: item.thyImageMeta.size
9251
- };
9252
- });
9253
- const { originUrl, thumbUrl, name, size } = this.element;
9254
- if (this.imagePluginOptions.preview) {
9255
- this.imagePluginOptions.preview({
9256
- editor: this.editor,
9257
- previewImageInfo: {
9258
- image: {
9259
- originUrl,
9260
- thumbUrl,
9261
- name,
9262
- size
9263
- },
9264
- imageGroup,
9265
- index
9266
- }
9267
- });
9268
- }
9238
+ ngAfterViewInit() {
9239
+ this.subscribeMouseUp();
9240
+ this.subscribeImageUploadingState();
9269
9241
  }
9270
9242
  onContextChange() {
9271
9243
  super.onContextChange();
@@ -9280,18 +9252,35 @@ class TheImageComponent extends TheBaseElementComponent {
9280
9252
  }
9281
9253
  ngOnDestroy() {
9282
9254
  this.uploadingSubscription.unsubscribe();
9283
- this.mouseUpSubscription.unsubscribe();
9284
9255
  this.theContextService.removeUploadFile(this.fileItem);
9285
9256
  if (this.uploading) {
9286
9257
  this.theContextService.uploadingStatus$.next(false);
9287
9258
  }
9288
9259
  super.ngOnDestroy();
9289
9260
  }
9290
- ngAfterViewInit() {
9291
- this.mouseUpSubscription = this.theContextService.onMouseUp$.subscribe(e => this.endDrag(e));
9261
+ setImagePluginOptions() {
9262
+ this.imagePluginOptions = getPluginOptions(this.editor, PluginKeys.image);
9263
+ }
9264
+ setDisablePreview() {
9265
+ const { disablePreview } = this.imagePluginOptions;
9266
+ if (disablePreview && typeof disablePreview === 'function') {
9267
+ this.disablePreview = disablePreview(this.editor);
9268
+ }
9269
+ else {
9270
+ this.disablePreview = disablePreview;
9271
+ }
9272
+ }
9273
+ setImageFileItem() {
9274
+ this.fileItem = this.theContextService.uploadingFiles.find(item => item.url === this.element.url);
9275
+ }
9276
+ subscribeMouseUp() {
9277
+ this.theContextService.onMouseUp$.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(e => this.endDrag(e));
9278
+ }
9279
+ subscribeImageUploadingState() {
9292
9280
  this.uploadingSubscription = this.imageUploaderService
9293
9281
  .getUploadingItems$()
9294
- .pipe(map$1(fileUploadingItem => this.fileItem?.file && fileUploadingItem.find(item => item.file === this.fileItem?.file)))
9282
+ .pipe(map$1(fileUploadingItem => this.fileItem?.file &&
9283
+ fileUploadingItem.find(item => item.file === this.fileItem?.file || item?.url === this.fileItem?.file)))
9295
9284
  .subscribe(uploadingItem => {
9296
9285
  if (!uploadingItem || !uploadingItem.result) {
9297
9286
  return;
@@ -9313,21 +9302,24 @@ class TheImageComponent extends TheBaseElementComponent {
9313
9302
  const data = { type: ElementKinds.image, url: null, ...imageInfo };
9314
9303
  HistoryEditor.withoutSaving(this.editor, () => Transforms.setNodes(this.editor, data, { at: path }));
9315
9304
  }
9316
- async uploadImage(file) {
9317
- this.imageEntry = {
9318
- align: this.imageEntry.align || Alignment.center,
9319
- thumbUrl: URL.createObjectURL(file)
9320
- };
9305
+ async uploadImage() {
9321
9306
  this.uploading = true;
9307
+ const file = this.fileItem.file;
9308
+ if (file instanceof File) {
9309
+ this.imageEntry = {
9310
+ align: this.imageEntry.align || Alignment.center,
9311
+ thumbUrl: URL.createObjectURL(file)
9312
+ };
9313
+ }
9322
9314
  this.theContextService.uploadingStatus$.next(true);
9323
- const [uploadFileEntity] = await this.imageUploaderService.uploadFileHandle([file]).toPromise();
9324
- const { thumbUrl, originUrl } = uploadFileEntity;
9315
+ const [fileEntity] = await firstValueFrom(this.imageUploaderService.uploadFileHandle(file));
9316
+ const { name, size, thumbUrl, originUrl } = fileEntity;
9325
9317
  const imageInfo = {
9326
- name: file.name,
9318
+ name,
9327
9319
  thumbUrl,
9328
9320
  originUrl,
9329
- align: this.imageEntry.align || Alignment.center,
9330
- size: file.size
9321
+ size,
9322
+ align: this.imageEntry.align || Alignment.center
9331
9323
  };
9332
9324
  this.setImageNodes(imageInfo);
9333
9325
  }
@@ -9519,16 +9511,43 @@ class TheImageComponent extends TheBaseElementComponent {
9519
9511
  event.preventDefault();
9520
9512
  event.stopPropagation();
9521
9513
  }
9522
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TheImageComponent, deps: [{ token: i0.ElementRef }, { token: THE_UPLOAD_SERVICE_TOKEN }, { token: i0.ChangeDetectorRef }, { token: TheContextService }, { token: i1.ThyPopover }, { token: i2.Overlay }, { token: i0.ViewContainerRef }, { token: i4$1.ThyImageGroupComponent }], target: i0.ɵɵFactoryTarget.Component }); }
9523
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TheImageComponent, selector: "the-image, [theImage]", viewQueries: [{ propertyName: "imageContent", first: true, predicate: ["imageContent"], descendants: true }, { propertyName: "img", first: true, predicate: ["img"], descendants: true }, { propertyName: "layoutToolbar", first: true, predicate: ["layoutToolbar"], descendants: true, static: true }, { propertyName: "imageDirective", first: true, predicate: ThyImageDirective, descendants: true }], usesInheritance: true, ngImport: i0, template: "<slate-children [children]=\"children\" [context]=\"childrenContext\" [viewContext]=\"viewContext\"></slate-children>\n\n<div class=\"image-container\" contenteditable=\"false\" [style.textAlign]=\"imageEntry.align\">\n <div #imageContent *ngIf=\"imageEntry.thumbUrl\" class=\"image-content\" [class.cursor-pointer]=\"!selection\">\n <img\n #img\n thyImage\n class=\"main-image\"\n [class.image-collapsed]=\"selection && !uploading\"\n [ngStyle]=\"{ 'width.px': imageBindingWidth }\"\n [alt]=\"imageEntry.name\"\n [thySrc]=\"imageEntry.thumbUrl\"\n [thyPreviewSrc]=\"imageEntry.thumbUrl\"\n [thyOriginSrc]=\"imageEntry.originUrl\"\n [thyDisablePreview]=\"disablePreview\"\n [thyImageMeta]=\"{ name: imageEntry.name, size: imageEntry.size }\"\n (load)=\"imageLoaded($event)\"\n (mousedown)=\"preventDefault($event)\"\n (error)=\"imageError($event)\"\n (click)=\"imageClick($event)\"\n />\n <div *ngIf=\"isCollapsedAndNonReadonly\" class=\"image-profile\" [class.outline]=\"selection\">\n <ng-container *ngIf=\"!loadImageError\">\n <span (mousedown)=\"startDrag($event, '-xl')\" class=\"image-pointer left top\"></span>\n <span (mousedown)=\"startDrag($event, 'xl')\" class=\"image-pointer right top\"></span>\n <span (mousedown)=\"startDrag($event, 'xl')\" class=\"image-pointer right bottom\"></span>\n <span (mousedown)=\"startDrag($event, '-xl')\" class=\"image-pointer left bottom\"></span>\n </ng-container>\n </div>\n <div *ngIf=\"uploading\" class=\"uploading\">\n <div class=\"uploading-percentage\">\n <thy-progress thyType=\"primary\" [thyValue]=\"percentage\" thySize=\"sm\"></thy-progress>\n <thy-icon (click)=\"cancelUpload($event)\" thyIconName=\"close-circle-bold-fill\" thyIconLegging=\"true\"> </thy-icon>\n </div>\n </div>\n <div *ngIf=\"!uploading\" class=\"layer\" [class.readonly]=\"readonly\"></div>\n </div>\n <div *ngIf=\"!imageEntry.thumbUrl\" class=\"image-loading cursor-pointer\" contenteditable=\"false\">\n <thy-icon thyIconName=\"image\"></thy-icon>\n </div>\n</div>\n\n<ng-template #layoutToolbar>\n <thy-actions thySize=\"xxs\">\n <ng-container *ngFor=\"let item of layoutOptions\">\n <a\n *ngIf=\"item.key !== 'split'\"\n href=\"javascript:;\"\n thyAction\n [thyType]=\"item.key === 'remove' ? 'danger' : 'primary'\"\n [thyActionIcon]=\"item.icon\"\n [thyActionActive]=\"layoutActive(item.key)\"\n [thyTooltip]=\"item.name\"\n thyTooltipPlacement=\"top\"\n (mousedown)=\"item?.handle($event, item.key)\"\n ></a>\n <thy-divider *ngIf=\"item.key === 'split'\" class=\"mr-2 ml-1 align-self-center\" [thyVertical]=\"true\" thyColor=\"light\"></thy-divider>\n </ng-container>\n </thy-actions>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i2$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2$1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i1$1.SlateChildren, selector: "slate-children", inputs: ["children", "context", "viewContext"] }, { kind: "component", type: i4.ThyIconComponent, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "directive", type: i8.ThyTooltipDirective, selector: "[thyTooltip],[thy-tooltip]", inputs: ["thyTooltip", "thyTooltipPlacement", "thyTooltipClass", "thyTooltipShowDelay", "thyTooltipHideDelay", "thyTooltipTrigger", "thyTooltipDisabled", "thyTooltipTemplateContext", "thyTooltipOffset", "thyTooltipPin"], exportAs: ["thyTooltip"] }, { kind: "component", type: i9$1.ThyProgressComponent, selector: "thy-progress", inputs: ["thyType", "thySize", "thyValue", "thyMax", "thyTips", "thyShape", "thyGapDegree", "thyGapPosition", "thyStrokeWidth"] }, { kind: "directive", type: i4$1.ThyImageDirective, selector: "img[thyImage]", inputs: ["thySrc", "thyPreviewSrc", "thyOriginSrc", "thyImageMeta", "thyDisablePreview", "thyResolveSize"], exportAs: ["thyImage"] }, { kind: "component", type: i7.ThyActionComponent, selector: "thy-action, [thyAction]", inputs: ["thyType", "thyIcon", "thyActionIcon", "thyActive", "thyActionActive", "thyTheme", "thyHoverIcon", "thyDisabled"] }, { kind: "component", type: i7.ThyActionsComponent, selector: "thy-actions", inputs: ["thySize"] }, { kind: "component", type: i8$1.ThyDividerComponent, selector: "thy-divider", inputs: ["thyVertical", "thyStyle", "thyColor", "thyText", "thyTextDirection", "thyDeeper"] }] }); }
9514
+ imageClick() {
9515
+ const index = this.imageGroupComponent.images.findIndex(item => item === this.imageDirective);
9516
+ const imageGroup = this.imageGroupComponent.images.map(item => {
9517
+ return {
9518
+ originUrl: item.thyOriginSrc,
9519
+ thumbUrl: item.thyPreviewSrc,
9520
+ name: item.thyImageMeta.name,
9521
+ size: item.thyImageMeta.size
9522
+ };
9523
+ });
9524
+ const { originUrl, thumbUrl, name, size } = this.element;
9525
+ if (this.imagePluginOptions.preview) {
9526
+ this.imagePluginOptions.preview({
9527
+ editor: this.editor,
9528
+ previewImageInfo: {
9529
+ image: {
9530
+ originUrl,
9531
+ thumbUrl,
9532
+ name,
9533
+ size
9534
+ },
9535
+ imageGroup,
9536
+ index
9537
+ }
9538
+ });
9539
+ }
9540
+ }
9541
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TheImageComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i1$4.ThyImageGroupComponent }, { token: THE_UPLOAD_SERVICE_TOKEN }, { token: TheContextService }, { token: i1.ThyPopover }, { token: i2.Overlay }, { token: i0.ViewContainerRef }, { token: i0.DestroyRef }], target: i0.ɵɵFactoryTarget.Component }); }
9542
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TheImageComponent, selector: "the-image, [theImage]", viewQueries: [{ propertyName: "imageContent", first: true, predicate: ["imageContent"], descendants: true }, { propertyName: "img", first: true, predicate: ["img"], descendants: true }, { propertyName: "layoutToolbar", first: true, predicate: ["layoutToolbar"], descendants: true, static: true }, { propertyName: "imageDirective", first: true, predicate: ThyImageDirective, descendants: true }], usesInheritance: true, ngImport: i0, template: "<slate-children [children]=\"children\" [context]=\"childrenContext\" [viewContext]=\"viewContext\"></slate-children>\n\n<div class=\"image-container\" contenteditable=\"false\" [style.textAlign]=\"imageEntry.align\">\n <div #imageContent *ngIf=\"imageEntry.thumbUrl; else imageLoading\" class=\"image-content\" [class.cursor-pointer]=\"!selection\">\n <img\n #img\n thyImage\n class=\"main-image\"\n [class.image-collapsed]=\"selection && !uploading\"\n [ngStyle]=\"{ 'width.px': imageBindingWidth }\"\n [alt]=\"imageEntry.name\"\n [thySrc]=\"imageEntry.thumbUrl\"\n [thyPreviewSrc]=\"imageEntry.thumbUrl\"\n [thyOriginSrc]=\"imageEntry.originUrl\"\n [thyDisablePreview]=\"disablePreview\"\n [thyImageMeta]=\"{ name: imageEntry.name, size: imageEntry.size }\"\n (load)=\"imageLoaded($event)\"\n (mousedown)=\"preventDefault($event)\"\n (error)=\"imageError($event)\"\n (click)=\"imageClick($event)\"\n />\n <div *ngIf=\"isCollapsedAndNonReadonly\" class=\"image-profile\" [class.outline]=\"selection\">\n <ng-container *ngIf=\"!loadImageError\">\n <span (mousedown)=\"startDrag($event, '-xl')\" class=\"image-pointer left top\"></span>\n <span (mousedown)=\"startDrag($event, 'xl')\" class=\"image-pointer right top\"></span>\n <span (mousedown)=\"startDrag($event, 'xl')\" class=\"image-pointer right bottom\"></span>\n <span (mousedown)=\"startDrag($event, '-xl')\" class=\"image-pointer left bottom\"></span>\n </ng-container>\n </div>\n <ng-template [ngTemplateOutlet]=\"imageUploading\"></ng-template>\n <div *ngIf=\"!uploading\" class=\"layer\" [class.readonly]=\"readonly\"></div>\n </div>\n</div>\n\n<ng-template #imageLoading>\n <div *ngIf=\"!imageEntry.thumbUrl\" class=\"image-loading cursor-pointer\" contenteditable=\"false\">\n <thy-icon thyIconName=\"image\"></thy-icon>\n </div>\n\n <ng-template [ngTemplateOutlet]=\"imageUploading\"></ng-template>\n</ng-template>\n\n<ng-template #layoutToolbar>\n <thy-actions thySize=\"xxs\">\n <ng-container *ngFor=\"let item of layoutOptions\">\n <a\n *ngIf=\"item.key !== 'split'\"\n href=\"javascript:;\"\n thyAction\n [thyType]=\"item.key === 'remove' ? 'danger' : 'primary'\"\n [thyActionIcon]=\"item.icon\"\n [thyActionActive]=\"layoutActive(item.key)\"\n [thyTooltip]=\"item.name\"\n thyTooltipPlacement=\"top\"\n (mousedown)=\"item?.handle($event, item.key)\"\n ></a>\n <thy-divider *ngIf=\"item.key === 'split'\" class=\"mr-2 ml-1 align-self-center\" [thyVertical]=\"true\" thyColor=\"light\"></thy-divider>\n </ng-container>\n </thy-actions>\n</ng-template>\n\n<ng-template #imageUploading>\n <div *ngIf=\"uploading\" class=\"uploading\">\n <div class=\"uploading-percentage\">\n <thy-progress thyType=\"primary\" [thyValue]=\"percentage\" thySize=\"sm\"></thy-progress>\n <thy-icon (click)=\"cancelUpload($event)\" thyIconName=\"close-circle-bold-fill\" thyIconLegging=\"true\"> </thy-icon>\n </div>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i2$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2$1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2$1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i1$1.SlateChildren, selector: "slate-children", inputs: ["children", "context", "viewContext"] }, { kind: "component", type: i4.ThyIconComponent, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "directive", type: i8.ThyTooltipDirective, selector: "[thyTooltip],[thy-tooltip]", inputs: ["thyTooltip", "thyTooltipPlacement", "thyTooltipClass", "thyTooltipShowDelay", "thyTooltipHideDelay", "thyTooltipTrigger", "thyTooltipDisabled", "thyTooltipTemplateContext", "thyTooltipOffset", "thyTooltipPin"], exportAs: ["thyTooltip"] }, { kind: "component", type: i9$1.ThyProgressComponent, selector: "thy-progress", inputs: ["thyType", "thySize", "thyValue", "thyMax", "thyTips", "thyShape", "thyGapDegree", "thyGapPosition", "thyStrokeWidth"] }, { kind: "directive", type: i1$4.ThyImageDirective, selector: "img[thyImage]", inputs: ["thySrc", "thyPreviewSrc", "thyOriginSrc", "thyImageMeta", "thyDisablePreview", "thyResolveSize"], exportAs: ["thyImage"] }, { kind: "component", type: i7.ThyActionComponent, selector: "thy-action, [thyAction]", inputs: ["thyType", "thyIcon", "thyActionIcon", "thyActive", "thyActionActive", "thyTheme", "thyHoverIcon", "thyDisabled"] }, { kind: "component", type: i7.ThyActionsComponent, selector: "thy-actions", inputs: ["thySize"] }, { kind: "component", type: i8$1.ThyDividerComponent, selector: "thy-divider", inputs: ["thyVertical", "thyStyle", "thyColor", "thyText", "thyTextDirection", "thyDeeper"] }] }); }
9524
9543
  }
9525
9544
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TheImageComponent, decorators: [{
9526
9545
  type: Component,
9527
- args: [{ selector: 'the-image, [theImage]', template: "<slate-children [children]=\"children\" [context]=\"childrenContext\" [viewContext]=\"viewContext\"></slate-children>\n\n<div class=\"image-container\" contenteditable=\"false\" [style.textAlign]=\"imageEntry.align\">\n <div #imageContent *ngIf=\"imageEntry.thumbUrl\" class=\"image-content\" [class.cursor-pointer]=\"!selection\">\n <img\n #img\n thyImage\n class=\"main-image\"\n [class.image-collapsed]=\"selection && !uploading\"\n [ngStyle]=\"{ 'width.px': imageBindingWidth }\"\n [alt]=\"imageEntry.name\"\n [thySrc]=\"imageEntry.thumbUrl\"\n [thyPreviewSrc]=\"imageEntry.thumbUrl\"\n [thyOriginSrc]=\"imageEntry.originUrl\"\n [thyDisablePreview]=\"disablePreview\"\n [thyImageMeta]=\"{ name: imageEntry.name, size: imageEntry.size }\"\n (load)=\"imageLoaded($event)\"\n (mousedown)=\"preventDefault($event)\"\n (error)=\"imageError($event)\"\n (click)=\"imageClick($event)\"\n />\n <div *ngIf=\"isCollapsedAndNonReadonly\" class=\"image-profile\" [class.outline]=\"selection\">\n <ng-container *ngIf=\"!loadImageError\">\n <span (mousedown)=\"startDrag($event, '-xl')\" class=\"image-pointer left top\"></span>\n <span (mousedown)=\"startDrag($event, 'xl')\" class=\"image-pointer right top\"></span>\n <span (mousedown)=\"startDrag($event, 'xl')\" class=\"image-pointer right bottom\"></span>\n <span (mousedown)=\"startDrag($event, '-xl')\" class=\"image-pointer left bottom\"></span>\n </ng-container>\n </div>\n <div *ngIf=\"uploading\" class=\"uploading\">\n <div class=\"uploading-percentage\">\n <thy-progress thyType=\"primary\" [thyValue]=\"percentage\" thySize=\"sm\"></thy-progress>\n <thy-icon (click)=\"cancelUpload($event)\" thyIconName=\"close-circle-bold-fill\" thyIconLegging=\"true\"> </thy-icon>\n </div>\n </div>\n <div *ngIf=\"!uploading\" class=\"layer\" [class.readonly]=\"readonly\"></div>\n </div>\n <div *ngIf=\"!imageEntry.thumbUrl\" class=\"image-loading cursor-pointer\" contenteditable=\"false\">\n <thy-icon thyIconName=\"image\"></thy-icon>\n </div>\n</div>\n\n<ng-template #layoutToolbar>\n <thy-actions thySize=\"xxs\">\n <ng-container *ngFor=\"let item of layoutOptions\">\n <a\n *ngIf=\"item.key !== 'split'\"\n href=\"javascript:;\"\n thyAction\n [thyType]=\"item.key === 'remove' ? 'danger' : 'primary'\"\n [thyActionIcon]=\"item.icon\"\n [thyActionActive]=\"layoutActive(item.key)\"\n [thyTooltip]=\"item.name\"\n thyTooltipPlacement=\"top\"\n (mousedown)=\"item?.handle($event, item.key)\"\n ></a>\n <thy-divider *ngIf=\"item.key === 'split'\" class=\"mr-2 ml-1 align-self-center\" [thyVertical]=\"true\" thyColor=\"light\"></thy-divider>\n </ng-container>\n </thy-actions>\n</ng-template>\n" }]
9528
- }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: undefined, decorators: [{
9546
+ args: [{ selector: 'the-image, [theImage]', template: "<slate-children [children]=\"children\" [context]=\"childrenContext\" [viewContext]=\"viewContext\"></slate-children>\n\n<div class=\"image-container\" contenteditable=\"false\" [style.textAlign]=\"imageEntry.align\">\n <div #imageContent *ngIf=\"imageEntry.thumbUrl; else imageLoading\" class=\"image-content\" [class.cursor-pointer]=\"!selection\">\n <img\n #img\n thyImage\n class=\"main-image\"\n [class.image-collapsed]=\"selection && !uploading\"\n [ngStyle]=\"{ 'width.px': imageBindingWidth }\"\n [alt]=\"imageEntry.name\"\n [thySrc]=\"imageEntry.thumbUrl\"\n [thyPreviewSrc]=\"imageEntry.thumbUrl\"\n [thyOriginSrc]=\"imageEntry.originUrl\"\n [thyDisablePreview]=\"disablePreview\"\n [thyImageMeta]=\"{ name: imageEntry.name, size: imageEntry.size }\"\n (load)=\"imageLoaded($event)\"\n (mousedown)=\"preventDefault($event)\"\n (error)=\"imageError($event)\"\n (click)=\"imageClick($event)\"\n />\n <div *ngIf=\"isCollapsedAndNonReadonly\" class=\"image-profile\" [class.outline]=\"selection\">\n <ng-container *ngIf=\"!loadImageError\">\n <span (mousedown)=\"startDrag($event, '-xl')\" class=\"image-pointer left top\"></span>\n <span (mousedown)=\"startDrag($event, 'xl')\" class=\"image-pointer right top\"></span>\n <span (mousedown)=\"startDrag($event, 'xl')\" class=\"image-pointer right bottom\"></span>\n <span (mousedown)=\"startDrag($event, '-xl')\" class=\"image-pointer left bottom\"></span>\n </ng-container>\n </div>\n <ng-template [ngTemplateOutlet]=\"imageUploading\"></ng-template>\n <div *ngIf=\"!uploading\" class=\"layer\" [class.readonly]=\"readonly\"></div>\n </div>\n</div>\n\n<ng-template #imageLoading>\n <div *ngIf=\"!imageEntry.thumbUrl\" class=\"image-loading cursor-pointer\" contenteditable=\"false\">\n <thy-icon thyIconName=\"image\"></thy-icon>\n </div>\n\n <ng-template [ngTemplateOutlet]=\"imageUploading\"></ng-template>\n</ng-template>\n\n<ng-template #layoutToolbar>\n <thy-actions thySize=\"xxs\">\n <ng-container *ngFor=\"let item of layoutOptions\">\n <a\n *ngIf=\"item.key !== 'split'\"\n href=\"javascript:;\"\n thyAction\n [thyType]=\"item.key === 'remove' ? 'danger' : 'primary'\"\n [thyActionIcon]=\"item.icon\"\n [thyActionActive]=\"layoutActive(item.key)\"\n [thyTooltip]=\"item.name\"\n thyTooltipPlacement=\"top\"\n (mousedown)=\"item?.handle($event, item.key)\"\n ></a>\n <thy-divider *ngIf=\"item.key === 'split'\" class=\"mr-2 ml-1 align-self-center\" [thyVertical]=\"true\" thyColor=\"light\"></thy-divider>\n </ng-container>\n </thy-actions>\n</ng-template>\n\n<ng-template #imageUploading>\n <div *ngIf=\"uploading\" class=\"uploading\">\n <div class=\"uploading-percentage\">\n <thy-progress thyType=\"primary\" [thyValue]=\"percentage\" thySize=\"sm\"></thy-progress>\n <thy-icon (click)=\"cancelUpload($event)\" thyIconName=\"close-circle-bold-fill\" thyIconLegging=\"true\"> </thy-icon>\n </div>\n </div>\n</ng-template>\n" }]
9547
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i1$4.ThyImageGroupComponent }, { type: undefined, decorators: [{
9529
9548
  type: Inject,
9530
9549
  args: [THE_UPLOAD_SERVICE_TOKEN]
9531
- }] }, { type: i0.ChangeDetectorRef }, { type: TheContextService }, { type: i1.ThyPopover }, { type: i2.Overlay }, { type: i0.ViewContainerRef }, { type: i4$1.ThyImageGroupComponent }]; }, propDecorators: { imageContent: [{
9550
+ }] }, { type: TheContextService }, { type: i1.ThyPopover }, { type: i2.Overlay }, { type: i0.ViewContainerRef }, { type: i0.DestroyRef }]; }, propDecorators: { imageContent: [{
9532
9551
  type: ViewChild,
9533
9552
  args: ['imageContent']
9534
9553
  }], img: [{
@@ -16680,7 +16699,7 @@ class TheEditorComponent {
16680
16699
  useExisting: forwardRef(() => TheEditorComponent),
16681
16700
  multi: true
16682
16701
  }
16683
- ], viewQueries: [{ propertyName: "templateInstance", first: true, predicate: ["templateInstance"], descendants: true, static: true }, { propertyName: "theEditableContainer", first: true, predicate: ["theEditableContainer"], descendants: true, read: ElementRef, static: true }, { propertyName: "globalToolbarInstance", first: true, predicate: ["globalToolbar"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<the-toolbar\n *ngIf=\"!options?.readonly && !theGlobalToolbar && !isMobileMode\"\n [ngClass]=\"{\n 'the-toolbar-disabled': options?.disabled\n }\"\n #globalToolbar\n [editor]=\"editor\"\n [toolbarItems]=\"toolbarEntity.global\"\n [containerClass]=\"globalToolbarClass\"\n [align]=\"options?.toolbar?.align\"\n></the-toolbar>\n\n<div\n #theEditableContainer\n class=\"the-editable-container\"\n thyImageGroup\n [ngClass]=\"{\n 'the-editor-disabled': options?.disabled,\n 'max-height': maxHeight\n }\"\n [ngStyle]=\"{ 'max-height': maxHeight }\"\n>\n <slate-editable\n class=\"the-editor-typo\"\n [editor]=\"editor\"\n [ngModel]=\"editorValue\"\n [renderElement]=\"renderElement\"\n [renderText]=\"renderText\"\n [renderLeaf]=\"renderLeaf\"\n [isStrictDecorate]=\"false\"\n [decorate]=\"decorate\"\n [placeholder]=\"options?.placeholder\"\n [placeholderDecorate]=\"options?.placeholderDecorate ? options?.placeholderDecorate : null\"\n [readonly]=\"options?.readonly || options?.disabled\"\n [keydown]=\"onKeyDown\"\n [click]=\"onClick\"\n [paste]=\"onSlaPaste\"\n [blur]=\"onSlaBlur\"\n [focus]=\"onSlaFocus\"\n [copy]=\"onSlaCopy\"\n [cut]=\"onSlaCut\"\n [beforeInput]=\"onSlaBeforeInput\"\n [compositionStart]=\"onSlaCompositionStart\"\n [compositionEnd]=\"onSlaCompositionEnd\"\n [dragStart]=\"onSlaDragStart\"\n [dragOver]=\"onSlaDragOver\"\n [drop]=\"onDrop\"\n [scrollSelectionIntoView]=\"scrollSelectionIntoView\"\n (ngModelChange)=\"valueChange($event)\"\n (mousedown)=\"mousedown($event)\"\n ></slate-editable>\n\n <ng-container *ngIf=\"!isMobileMode\">\n <the-inline-toolbar\n *ngIf=\"!options?.readonly && options?.inlineToolbarVisible\"\n [editor]=\"editor\"\n [toolbarItems]=\"toolbarEntity.inline\"\n ></the-inline-toolbar>\n <div *ngIf=\"!options?.readonly\" theQuickInsert [editor]=\"editor\" [isVisible]=\"visibleQuickInsertPlus\"></div>\n </ng-container>\n\n <the-template #templateInstance></the-template>\n</div>\n", dependencies: [{ kind: "directive", type: i2$1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2$1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i1$1.SlateEditable, selector: "slate-editable", inputs: ["editor", "renderElement", "renderLeaf", "renderText", "decorate", "placeholderDecorate", "scrollSelectionIntoView", "isStrictDecorate", "trackBy", "readonly", "placeholder", "beforeInput", "blur", "click", "compositionEnd", "compositionUpdate", "compositionStart", "copy", "cut", "dragOver", "dragStart", "dragEnd", "drop", "focus", "keydown", "paste", "spellCheck", "autoCorrect", "autoCapitalize"] }, { kind: "directive", type: i2$2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2$2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4$1.ThyImageGroupComponent, selector: "thy-image-group, [thyImageGroup]" }, { kind: "component", type: TheToolbarComponent, selector: "the-toolbar", inputs: ["editor", "toolbarItems", "align", "containerClass", "isMore", "afterTemplate"] }, { kind: "component", type: TheInlineToolbarComponent, selector: "the-inline-toolbar", inputs: ["editor", "toolbarItems"] }, { kind: "component", type: TheQuickInsertComponent, selector: "[theQuickInsert]", inputs: ["editor", "isVisible"] }, { kind: "component", type: TheTemplateComponent, selector: "the-template,[theTemplate]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
16702
+ ], viewQueries: [{ propertyName: "templateInstance", first: true, predicate: ["templateInstance"], descendants: true, static: true }, { propertyName: "theEditableContainer", first: true, predicate: ["theEditableContainer"], descendants: true, read: ElementRef, static: true }, { propertyName: "globalToolbarInstance", first: true, predicate: ["globalToolbar"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<the-toolbar\n *ngIf=\"!options?.readonly && !theGlobalToolbar && !isMobileMode\"\n [ngClass]=\"{\n 'the-toolbar-disabled': options?.disabled\n }\"\n #globalToolbar\n [editor]=\"editor\"\n [toolbarItems]=\"toolbarEntity.global\"\n [containerClass]=\"globalToolbarClass\"\n [align]=\"options?.toolbar?.align\"\n></the-toolbar>\n\n<div\n #theEditableContainer\n class=\"the-editable-container\"\n thyImageGroup\n [ngClass]=\"{\n 'the-editor-disabled': options?.disabled,\n 'max-height': maxHeight\n }\"\n [ngStyle]=\"{ 'max-height': maxHeight }\"\n>\n <slate-editable\n class=\"the-editor-typo\"\n [editor]=\"editor\"\n [ngModel]=\"editorValue\"\n [renderElement]=\"renderElement\"\n [renderText]=\"renderText\"\n [renderLeaf]=\"renderLeaf\"\n [isStrictDecorate]=\"false\"\n [decorate]=\"decorate\"\n [placeholder]=\"options?.placeholder\"\n [placeholderDecorate]=\"options?.placeholderDecorate ? options?.placeholderDecorate : null\"\n [readonly]=\"options?.readonly || options?.disabled\"\n [keydown]=\"onKeyDown\"\n [click]=\"onClick\"\n [paste]=\"onSlaPaste\"\n [blur]=\"onSlaBlur\"\n [focus]=\"onSlaFocus\"\n [copy]=\"onSlaCopy\"\n [cut]=\"onSlaCut\"\n [beforeInput]=\"onSlaBeforeInput\"\n [compositionStart]=\"onSlaCompositionStart\"\n [compositionEnd]=\"onSlaCompositionEnd\"\n [dragStart]=\"onSlaDragStart\"\n [dragOver]=\"onSlaDragOver\"\n [drop]=\"onDrop\"\n [scrollSelectionIntoView]=\"scrollSelectionIntoView\"\n (ngModelChange)=\"valueChange($event)\"\n (mousedown)=\"mousedown($event)\"\n ></slate-editable>\n\n <ng-container *ngIf=\"!isMobileMode\">\n <the-inline-toolbar\n *ngIf=\"!options?.readonly && options?.inlineToolbarVisible\"\n [editor]=\"editor\"\n [toolbarItems]=\"toolbarEntity.inline\"\n ></the-inline-toolbar>\n <div *ngIf=\"!options?.readonly\" theQuickInsert [editor]=\"editor\" [isVisible]=\"visibleQuickInsertPlus\"></div>\n </ng-container>\n\n <the-template #templateInstance></the-template>\n</div>\n", dependencies: [{ kind: "directive", type: i2$1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2$1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i1$1.SlateEditable, selector: "slate-editable", inputs: ["editor", "renderElement", "renderLeaf", "renderText", "decorate", "placeholderDecorate", "scrollSelectionIntoView", "isStrictDecorate", "trackBy", "readonly", "placeholder", "beforeInput", "blur", "click", "compositionEnd", "compositionUpdate", "compositionStart", "copy", "cut", "dragOver", "dragStart", "dragEnd", "drop", "focus", "keydown", "paste", "spellCheck", "autoCorrect", "autoCapitalize"] }, { kind: "directive", type: i2$2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2$2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i1$4.ThyImageGroupComponent, selector: "thy-image-group, [thyImageGroup]" }, { kind: "component", type: TheToolbarComponent, selector: "the-toolbar", inputs: ["editor", "toolbarItems", "align", "containerClass", "isMore", "afterTemplate"] }, { kind: "component", type: TheInlineToolbarComponent, selector: "the-inline-toolbar", inputs: ["editor", "toolbarItems"] }, { kind: "component", type: TheQuickInsertComponent, selector: "[theQuickInsert]", inputs: ["editor", "isVisible"] }, { kind: "component", type: TheTemplateComponent, selector: "the-template,[theTemplate]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
16684
16703
  }
16685
16704
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TheEditorComponent, decorators: [{
16686
16705
  type: Component,