UNPKG

@ckeditor/ckeditor5-engine

Version:

The editing engine of CKEditor 5 – the best browser-based rich text editor.

90 lines (89 loc) 3.82 kB
/** * @license Copyright (c) 2003-2025, CKSource Holding sp. z o.o. All rights reserved. * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-licensing-options */ import { type ViewDocument } from '../document.js'; import { type EditingView } from '../view.js'; declare const Observer_base: { new (): import("@ckeditor/ckeditor5-utils").DomEmitter; prototype: import("@ckeditor/ckeditor5-utils").DomEmitter; }; /** * Abstract base observer class. Observers are classes which listen to DOM events, do the preliminary * processing and fire events on the {@link module:engine/view/document~ViewDocument} objects. * Observers can also add features to the view, for instance by updating its status or marking elements * which need a refresh on DOM events. */ export declare abstract class Observer extends /* #__PURE__ */ Observer_base { /** * An instance of the view controller. */ readonly view: EditingView; /** * A reference to the {@link module:engine/view/document~ViewDocument} object. */ readonly document: ViewDocument; /** * The state of the observer. If it is disabled, no events will be fired. */ private _isEnabled; /** * Creates an instance of the observer. */ constructor(view: EditingView); /** * The state of the observer. If it is disabled, no events will be fired. */ get isEnabled(): boolean; /** * Enables the observer. This method is called when the observer is registered to the * {@link module:engine/view/view~EditingView} and after {@link module:engine/view/view~EditingView#forceRender rendering} * (all observers are {@link #disable disabled} before rendering). * * A typical use case for disabling observers is that mutation observers need to be disabled for the rendering. * However, a child class may not need to be disabled, so it can implement an empty method. * * @see module:engine/view/observer/observer~Observer#disable */ enable(): void; /** * Disables the observer. This method is called before * {@link module:engine/view/view~EditingView#forceRender rendering} to prevent firing events during rendering. * * @see module:engine/view/observer/observer~Observer#enable */ disable(): void; /** * Disables and destroys the observer, among others removes event listeners created by the observer. */ destroy(): void; /** * Checks whether a given DOM event should be ignored (should not be turned into a synthetic view document event). * * Currently, an event will be ignored only if its target or any of its ancestors has the `data-cke-ignore-events` attribute. * This attribute can be used inside the structures generated by * {@link module:engine/view/downcastwriter~ViewDowncastWriter#createUIElement `ViewDowncastWriter#createUIElement()`} to ignore events * fired within a UI that should be excluded from CKEditor 5's realms. * * @param domTarget The DOM event target to check (usually an element, sometimes a text node and * potentially sometimes a document, too). * @returns Whether this event should be ignored by the observer. */ checkShouldIgnoreEventFromTarget(domTarget: Node | null): boolean; /** * Starts observing given DOM element. * * @param domElement DOM element to observe. * @param name The name of the related root element. */ abstract observe(domElement: HTMLElement, name: string): void; /** * Stops observing given DOM element. */ abstract stopObserving(domElement: HTMLElement): void; } /** * The constructor of {@link ~Observer} subclass. */ export type ObserverConstructor = new (view: EditingView) => Observer; export {};