import * as React from 'react'; import { IEvents } from '../Events'; import { ScriptItem } from '../ScriptLoader2'; import { IEditorPropTypes } from './EditorPropTypes'; import { Editor as TinyMCEEditor, TinyMCE } from 'tinymce'; type EditorOptions = Parameters[0]; export interface IProps { apiKey: string; id: string; inline: boolean; initialValue: string; onEditorChange: (a: string, editor: TinyMCEEditor) => void; value: string; init: EditorOptions & { selector?: undefined; target?: undefined; }; tagName: string; cloudChannel: string; plugins: NonNullable; toolbar: NonNullable; disabled: boolean; textareaName: string; tinymceScriptSrc: string | string[] | ScriptItem[]; rollback: number | false; scriptLoading: { async?: boolean; defer?: boolean; delay?: number; }; } export interface IAllProps extends Partial, Partial { } export declare class Editor extends React.Component { static propTypes: IEditorPropTypes; static defaultProps: Partial; editor?: TinyMCEEditor; private id; private elementRef; private inline; private currentContent?; private boundHandlers; private rollbackTimer; private valueCursor; constructor(props: Partial); private get view(); componentDidUpdate(prevProps: Partial): void; componentDidMount(): void; componentWillUnmount(): void; render(): React.ReactElement<{ ref: React.RefObject; id: string; }, string | React.JSXElementConstructor>; private changeEvents; private beforeInputEvent; private renderInline; private renderIframe; private getScriptSources; private getInitialValue; private bindHandlers; private rollbackChange; private handleBeforeInput; private handleBeforeInputSpecial; private handleEditorChange; private handleEditorChangeSpecial; private initialise; } export {};