dext5editor-react
Version:
React component for DEXT5 Editor
210 lines (209 loc) • 5.9 kB
TypeScript
/**
* @license Copyright (c) 2003-2022, RAONWIZ DevTeam. All rights reserved.
*/
import * as PropTypes from 'prop-types';
import DEXT5Editor from './DEXT5Editor';
import { events, namespaceEvents } from './events';
/**
* Event names associated with `component` events.
*/
export declare type ComponentEventName = typeof events[number];
/**
* Event names associated with `namespace` events.
*/
export declare type ComponentNamespaceEventName = typeof namespaceEvents[number];
/**
* Combined `component` and `namespace` events.
*/
export declare type ComponentDefaultEvent = ComponentEventName | ComponentNamespaceEventName;
/**
* Payload passed to `component` event handlers.
*/
export interface ComponentEventPayload<EventName> {
/**
* Additional event data.
*/
data?: Record<string, unknown> | null;
/**
* component instance that holds the event sender.
*/
component?: ComponentInstance | null;
/**
* Extra data appended during listener registration.
*/
eventInfo?: any;
/**
* Event name.
*/
name: EventName;
/**
* Object that publishes event.
*/
sender: Record<string, unknown>;
/**
* Cancels event (if cancelable).
*/
cancel?: () => void | null;
/**
* Removes current listener.
*/
removeListener?: () => void | null;
/**
* No listeners will be called afterwards.
*/
stop?: () => void | null;
}
/**
* Signature of `component` event handler.
*/
export declare type ComponentEventHandler<EventName> = (evt: ComponentEventPayload<EventName>) => void;
/**
* Signature of `namespace` event handler.
*/
export declare type ComponentNamespaceHandler = (namespace: ComponentNamespace) => void;
/**
* Component instance.
*/
export declare type ComponentInstance = any;
/**
* Component configuration object.
*/
export declare type ComponentConfig = Record<string, any>;
/**
* Namespace object.
*/
export declare type ComponentNamespace = any;
/**
* `useDEXT5Editor` hook arguments.
*/
export interface ComponentHookProps<EventName extends string> {
/**
* Config object passed to component's constructor.
*
* A new instance of component will be created everytime a new instance of `config` is provided.
* If this is not expected behavior then ensure referential equality of `config` between renders.
*/
config?: ComponentConfig | null;
/**
* Toggles debugging. Logs info related to component lifecycle events.
*/
debug?: boolean | null;
/**
* Dispatches `component` / `namespace` events.
*/
dispatchEvent?: ComponentEventDispatcher;
/**
* List of component events that will be dispatched. Omit if all events are to be dispatched.
*/
subscribeTo?: readonly EventName[];
/**
* Url with component's source code.
*/
componentUrl?: string | null;
/**
* Url with component's source code.
*/
createMode?: string | null;
/**
* DOM element to which component will be bound.
*/
element: HTMLElement | null;
/**
* Initial editor content. Only `string` values are accepted.
*/
initContent?: string | null;
}
/**
* Arguments passed to event registeration helper.
*/
export interface ComponentRegisterEventArgs<EventName> {
/**
* Toggles debugging. Logs info related to component lifecycle events.
*/
debug?: boolean | null;
/**
* Component instance.
*/
component: ComponentInstance;
/**
* Event handler to register.
*/
handler: ComponentEventHandler<EventName>;
/**
* Component's event name.
*/
evtName: EventName;
/**
* Custom data passed to listener.
*/
eventInfo?: any;
}
export interface ComponentHookResult {
/**
* Instance of component.
*/
component?: ComponentInstance;
/**
* Status of component's instance. Equivalent of `component.status`.
*/
status?: ComponentStatus;
/**
* Indicates if an error occurred. This is a non-recoverable state. Hook must be remounted.
*/
error?: boolean;
/**
* Indicates if loading of DEXT5Editor is in progress.
*/
loading?: boolean;
}
/**
* Dispatcher of component events.
*/
export declare type ComponentEventDispatcher = ({ type, payload }: {
type: string;
payload: any;
}) => void;
/**
* Component status.
*/
export declare type ComponentStatus = 'unloaded' | 'loaded' | 'ready' | 'destroyed';
/**
* Props of `DEXT5Editor` component.
*
* Some prop types are overriden to provide better typings than `PropTypes.InferProps` has to offer.
*/
export declare type ComponentProps<EventHandlerProp> = PropTypes.InferProps<Omit<typeof DEXT5Editor.propTypes, 'config' | keyof ComponentEventHandlerProp>> & {
config?: ComponentConfig | null;
} & Partial<ComponentEventHandlerProp> & EventHandlerProp;
/**
* Event handler props.
*/
export interface ComponentEventHandlerProp {
/**
* Namespace events.
*/
onBeforeLoad: ComponentNamespaceHandler;
onNamespaceLoaded: ComponentNamespaceHandler;
onLoaded: ComponentEventHandler<'loaded'>;
/**
* DEXT5 Editor events.
*/
onCreationComplete: ComponentEventHandler<'creationComplete'>;
onDestroy: ComponentEventHandler<'destroy'>;
}
/**
* Event action types.
*/
export interface ComponentAction {
/**
* Namespace events.
*/
beforeLoad: '__RDE__beforeLoad';
namespaceLoaded: '__RDE__namespaceLoaded';
loaded: '__RDE__loaded';
/**
* DEXT5 Editor events.
*/
creationComplete: '__RDE__creationComplete';
destroy: '__RDE__destroy';
}