Server IP : 80.87.202.40 / Your IP : 216.73.216.169 Web Server : Apache System : Linux rospirotorg.ru 5.14.0-539.el9.x86_64 #1 SMP PREEMPT_DYNAMIC Thu Dec 5 22:26:13 UTC 2024 x86_64 User : bitrix ( 600) PHP Version : 8.2.27 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : ON Directory : /home/bitrix/ext_www/rospirotorg.ru/bitrix/js/ui/text-editor/src/plugins/image/ |
Upload File : |
import { Dom, Tag, Type } from 'main.core'; import { MemoryCache, type BaseCache } from 'main.core.cache'; import type { BaseEvent } from 'main.core.events'; import type { EditorConfig } from 'ui.lexical.core'; import { $getNodeByKey } from 'ui.lexical.core'; import DecoratorComponent from '../../decorator-component'; import FigureResizer from '../../helpers/figure-resizer'; import { $isImageNode, ImageNode } from './image-node'; import type { JsonObject } from 'main.core'; import type { DecoratorComponentOptions } from '../../types/decorator-component-options'; export default class ImageComponent extends DecoratorComponent { #refs: BaseCache<HTMLElement> = new MemoryCache(); #figureResizer: FigureResizer = null; #maxWidth: number | 'none' = 'none'; constructor(options: DecoratorComponentOptions) { super(options); this.#figureResizer = new FigureResizer({ target: this.getImage(), editor: this.getEditor(), originalWidth: this.getOption('width'), originalHeight: this.getOption('height'), maxWidth: this.getMaxWidth(), events: { onResizeStart: this.#handleResizeStart.bind(this), onResizeEnd: this.#handleResizeEnd.bind(this), }, }); this.getNodeSelection().onSelect((selected: boolean) => { if (selected || this.#figureResizer.isResizing()) { Dom.addClass(this.#getContainer(), '--selected'); this.#figureResizer.show(); } else { Dom.removeClass(this.#getContainer(), '--selected'); this.#figureResizer.hide(); } const draggable = selected && !this.#figureResizer.isResizing(); this.#setDraggable(draggable); }); this.update(this.getOptions()); this.#render(); } #render() { Dom.append(this.#getContainer(), this.getTarget()); } #getContainer(): HTMLElement { return this.#refs.remember('container', () => { const figureResizer = this.#figureResizer.getContainer(); return Tag.render` <div class="ui-text-editor-image-component"> ${this.#getImageContainer()} ${figureResizer} </div> `; }); } #getImageContainer(): HTMLElement { return this.#refs.remember('image-container', () => { return Tag.render` <div class="ui-text-editor-image-container"> ${this.getImage()} </div> `; }); } #setDraggable(draggable: boolean): void { Dom.attr(this.#getImageContainer(), { draggable }); if (draggable) { Dom.addClass(this.#getContainer(), '--draggable'); } else { Dom.removeClass(this.#getContainer(), '--draggable'); } } #handleResizeStart(event: BaseEvent): void { this.#setDraggable(false); this.setSelected(true); } #handleResizeEnd(event: BaseEvent): void { this.setSelected(true); this.getEditor().update(() => { const node: ImageNode = $getNodeByKey(this.getNodeKey()); if ($isImageNode(node)) { const { width, height } = event.getData(); node.setWidthAndHeight(width, height); } }); } getImage(): HTMLImageElement { return this.#refs.remember('image', () => { const img: HTMLImageElement = document.createElement('img'); img.draggable = false; img.src = this.getOption('src'); const config: EditorConfig = this.getOption('config', {}); if (config?.theme?.image?.img) { img.className = config.theme.image.img; } img.onerror = (event) => { img.src = ''; Dom.addClass(this.getTarget(), '--error ui-icon-set__scope'); }; return img; }); } getMaxWidth(): 'none' | number { return this.#maxWidth; } update(options: JsonObject) { const width = options.width > 0 ? `${options.width}px` : 'inherit'; const aspectRatio = options.width > 0 && options.height > 0 ? `${options.width} / ${options.height}` : 'auto'; this.#maxWidth = options.maxWidth; Dom.style(this.getImage(), { width, height: 'auto', aspectRatio }); } }