2022-02-05 17:55:53 +01:00
|
|
|
interface StringPathBookmark {
|
|
|
|
start: string;
|
|
|
|
end?: string;
|
2022-07-17 19:33:03 +02:00
|
|
|
forward?: boolean;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
|
|
|
interface RangeBookmark {
|
|
|
|
rng: Range;
|
2022-07-17 19:33:03 +02:00
|
|
|
forward?: boolean;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
|
|
|
interface IdBookmark {
|
|
|
|
id: string;
|
|
|
|
keep?: boolean;
|
2022-07-17 19:33:03 +02:00
|
|
|
forward?: boolean;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
|
|
|
interface IndexBookmark {
|
|
|
|
name: string;
|
|
|
|
index: number;
|
|
|
|
}
|
|
|
|
interface PathBookmark {
|
|
|
|
start: number[];
|
|
|
|
end?: number[];
|
|
|
|
isFakeCaret?: boolean;
|
2022-07-17 19:33:03 +02:00
|
|
|
forward?: boolean;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
|
|
|
declare type Bookmark = StringPathBookmark | RangeBookmark | IdBookmark | IndexBookmark | PathBookmark;
|
|
|
|
declare type NormalizedEvent<E, T = any> = E & {
|
|
|
|
readonly type: string;
|
|
|
|
readonly target: T;
|
|
|
|
readonly isDefaultPrevented: () => boolean;
|
|
|
|
readonly preventDefault: () => void;
|
|
|
|
readonly isPropagationStopped: () => boolean;
|
|
|
|
readonly stopPropagation: () => void;
|
|
|
|
readonly isImmediatePropagationStopped: () => boolean;
|
|
|
|
readonly stopImmediatePropagation: () => void;
|
|
|
|
};
|
|
|
|
declare type MappedEvent<T, K extends string> = K extends keyof T ? T[K] : any;
|
|
|
|
interface NativeEventMap {
|
|
|
|
'beforepaste': Event;
|
|
|
|
'blur': FocusEvent;
|
|
|
|
'beforeinput': InputEvent;
|
|
|
|
'click': MouseEvent;
|
|
|
|
'compositionend': Event;
|
|
|
|
'compositionstart': Event;
|
|
|
|
'compositionupdate': Event;
|
|
|
|
'contextmenu': PointerEvent;
|
|
|
|
'copy': ClipboardEvent;
|
|
|
|
'cut': ClipboardEvent;
|
|
|
|
'dblclick': MouseEvent;
|
|
|
|
'drag': DragEvent;
|
|
|
|
'dragdrop': DragEvent;
|
|
|
|
'dragend': DragEvent;
|
|
|
|
'draggesture': DragEvent;
|
|
|
|
'dragover': DragEvent;
|
|
|
|
'dragstart': DragEvent;
|
|
|
|
'drop': DragEvent;
|
|
|
|
'focus': FocusEvent;
|
|
|
|
'focusin': FocusEvent;
|
|
|
|
'focusout': FocusEvent;
|
|
|
|
'input': InputEvent;
|
|
|
|
'keydown': KeyboardEvent;
|
|
|
|
'keypress': KeyboardEvent;
|
|
|
|
'keyup': KeyboardEvent;
|
|
|
|
'mousedown': MouseEvent;
|
|
|
|
'mouseenter': MouseEvent;
|
|
|
|
'mouseleave': MouseEvent;
|
|
|
|
'mousemove': MouseEvent;
|
|
|
|
'mouseout': MouseEvent;
|
|
|
|
'mouseover': MouseEvent;
|
|
|
|
'mouseup': MouseEvent;
|
|
|
|
'paste': ClipboardEvent;
|
|
|
|
'selectionchange': Event;
|
|
|
|
'submit': Event;
|
|
|
|
'touchend': TouchEvent;
|
|
|
|
'touchmove': TouchEvent;
|
|
|
|
'touchstart': TouchEvent;
|
|
|
|
'touchcancel': TouchEvent;
|
|
|
|
'wheel': WheelEvent;
|
|
|
|
}
|
|
|
|
declare type EditorEvent<T> = NormalizedEvent<T>;
|
|
|
|
interface EventDispatcherSettings {
|
|
|
|
scope?: any;
|
|
|
|
toggleEvent?: (name: string, state: boolean) => void | boolean;
|
|
|
|
beforeFire?: <T>(args: EditorEvent<T>) => void;
|
|
|
|
}
|
|
|
|
interface EventDispatcherConstructor<T extends NativeEventMap> {
|
|
|
|
readonly prototype: EventDispatcher<T>;
|
|
|
|
new (settings?: EventDispatcherSettings): EventDispatcher<T>;
|
|
|
|
isNative: (name: string) => boolean;
|
|
|
|
}
|
|
|
|
declare class EventDispatcher<T> {
|
|
|
|
static isNative(name: string): boolean;
|
|
|
|
private readonly settings;
|
|
|
|
private readonly scope;
|
|
|
|
private readonly toggleEvent;
|
|
|
|
private bindings;
|
|
|
|
constructor(settings?: Record<string, any>);
|
|
|
|
fire<K extends string, U extends MappedEvent<T, K>>(name: K, args?: U): EditorEvent<U>;
|
2022-07-17 19:33:03 +02:00
|
|
|
dispatch<K extends string, U extends MappedEvent<T, K>>(name: K, args?: U): EditorEvent<U>;
|
2022-02-05 17:55:53 +01:00
|
|
|
on<K extends string>(name: K, callback: false | ((event: EditorEvent<MappedEvent<T, K>>) => void), prepend?: boolean, extra?: {}): this;
|
|
|
|
off<K extends string>(name?: K, callback?: (event: EditorEvent<MappedEvent<T, K>>) => void): this;
|
|
|
|
once<K extends string>(name: K, callback: (event: EditorEvent<MappedEvent<T, K>>) => void, prepend?: boolean): this;
|
|
|
|
has(name: string): boolean;
|
|
|
|
}
|
|
|
|
declare const enum UndoLevelType {
|
|
|
|
Fragmented = "fragmented",
|
|
|
|
Complete = "complete"
|
|
|
|
}
|
|
|
|
interface UndoLevel {
|
|
|
|
type: UndoLevelType;
|
|
|
|
fragments: string[];
|
|
|
|
content: string;
|
|
|
|
bookmark: Bookmark;
|
|
|
|
beforeBookmark: Bookmark;
|
|
|
|
}
|
|
|
|
interface UndoManager {
|
|
|
|
data: UndoLevel[];
|
|
|
|
typing: boolean;
|
|
|
|
add: (level?: UndoLevel, event?: EditorEvent<any>) => UndoLevel;
|
2022-07-17 19:33:03 +02:00
|
|
|
dispatchChange: () => void;
|
2022-02-05 17:55:53 +01:00
|
|
|
beforeChange: () => void;
|
|
|
|
undo: () => UndoLevel;
|
|
|
|
redo: () => UndoLevel;
|
|
|
|
clear: () => void;
|
|
|
|
reset: () => void;
|
|
|
|
hasUndo: () => boolean;
|
|
|
|
hasRedo: () => boolean;
|
|
|
|
transact: (callback: () => void) => UndoLevel;
|
|
|
|
ignore: (callback: () => void) => void;
|
|
|
|
extra: (callback1: () => void, callback2: () => void) => void;
|
|
|
|
}
|
|
|
|
declare type SchemaType = 'html4' | 'html5' | 'html5-strict';
|
|
|
|
interface SchemaSettings {
|
|
|
|
custom_elements?: string;
|
|
|
|
extended_valid_elements?: string;
|
|
|
|
invalid_elements?: string;
|
|
|
|
invalid_styles?: string | Record<string, string>;
|
|
|
|
schema?: SchemaType;
|
|
|
|
valid_children?: string;
|
|
|
|
valid_classes?: string | Record<string, string>;
|
|
|
|
valid_elements?: string;
|
|
|
|
valid_styles?: string | Record<string, string>;
|
|
|
|
verify_html?: boolean;
|
2022-07-17 19:33:03 +02:00
|
|
|
padd_empty_block_inline_children?: boolean;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
|
|
|
interface Attribute {
|
|
|
|
required?: boolean;
|
|
|
|
defaultValue?: string;
|
|
|
|
forcedValue?: string;
|
2022-07-17 19:33:03 +02:00
|
|
|
validValues?: Record<string, {}>;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
|
|
|
interface DefaultAttribute {
|
|
|
|
name: string;
|
|
|
|
value: string;
|
|
|
|
}
|
|
|
|
interface AttributePattern {
|
|
|
|
defaultValue?: string;
|
|
|
|
forcedValue?: string;
|
|
|
|
pattern: RegExp;
|
|
|
|
required?: boolean;
|
2022-07-17 19:33:03 +02:00
|
|
|
validValues?: Record<string, {}>;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
|
|
|
interface ElementRule {
|
|
|
|
attributes: Record<string, Attribute>;
|
|
|
|
attributesDefault?: DefaultAttribute[];
|
|
|
|
attributesForced?: DefaultAttribute[];
|
|
|
|
attributesOrder: string[];
|
|
|
|
attributePatterns?: AttributePattern[];
|
|
|
|
attributesRequired?: string[];
|
|
|
|
paddEmpty?: boolean;
|
|
|
|
removeEmpty?: boolean;
|
|
|
|
removeEmptyAttrs?: boolean;
|
2022-07-17 19:33:03 +02:00
|
|
|
paddInEmptyBlock?: boolean;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
|
|
|
interface SchemaElement extends ElementRule {
|
|
|
|
outputName?: string;
|
|
|
|
parentsRequired?: string[];
|
|
|
|
pattern?: RegExp;
|
|
|
|
}
|
|
|
|
interface SchemaMap {
|
|
|
|
[name: string]: {};
|
|
|
|
}
|
|
|
|
interface SchemaRegExpMap {
|
|
|
|
[name: string]: RegExp;
|
|
|
|
}
|
|
|
|
interface Schema {
|
2022-07-17 19:33:03 +02:00
|
|
|
type: SchemaType;
|
2022-02-05 17:55:53 +01:00
|
|
|
children: Record<string, SchemaMap>;
|
|
|
|
elements: Record<string, SchemaElement>;
|
|
|
|
getValidStyles: () => Record<string, string[]> | undefined;
|
|
|
|
getValidClasses: () => Record<string, SchemaMap> | undefined;
|
|
|
|
getBlockElements: () => SchemaMap;
|
|
|
|
getInvalidStyles: () => Record<string, SchemaMap> | undefined;
|
2022-07-17 19:33:03 +02:00
|
|
|
getVoidElements: () => SchemaMap;
|
2022-02-05 17:55:53 +01:00
|
|
|
getTextBlockElements: () => SchemaMap;
|
|
|
|
getTextInlineElements: () => SchemaMap;
|
|
|
|
getBoolAttrs: () => SchemaMap;
|
|
|
|
getElementRule: (name: string) => SchemaElement | undefined;
|
|
|
|
getSelfClosingElements: () => SchemaMap;
|
|
|
|
getNonEmptyElements: () => SchemaMap;
|
|
|
|
getMoveCaretBeforeOnEnterElements: () => SchemaMap;
|
2022-07-17 19:33:03 +02:00
|
|
|
getWhitespaceElements: () => SchemaMap;
|
2022-02-05 17:55:53 +01:00
|
|
|
getSpecialElements: () => SchemaRegExpMap;
|
|
|
|
isValidChild: (name: string, child: string) => boolean;
|
|
|
|
isValid: (name: string, attr?: string) => boolean;
|
|
|
|
getCustomElements: () => SchemaMap;
|
|
|
|
addValidElements: (validElements: string) => void;
|
|
|
|
setValidElements: (validElements: string) => void;
|
|
|
|
addCustomElements: (customElements: string) => void;
|
|
|
|
addValidChildren: (validChildren: any) => void;
|
|
|
|
}
|
|
|
|
declare type Attributes$1 = Array<{
|
|
|
|
name: string;
|
|
|
|
value: string;
|
|
|
|
}> & {
|
|
|
|
map: Record<string, string>;
|
|
|
|
};
|
|
|
|
interface AstNodeConstructor {
|
|
|
|
readonly prototype: AstNode;
|
|
|
|
new (name: string, type: number): AstNode;
|
|
|
|
create(name: string, attrs?: Record<string, string>): AstNode;
|
|
|
|
}
|
|
|
|
declare class AstNode {
|
|
|
|
static create(name: string, attrs?: Record<string, string>): AstNode;
|
|
|
|
name: string;
|
|
|
|
type: number;
|
|
|
|
attributes?: Attributes$1;
|
|
|
|
value?: string;
|
|
|
|
parent?: AstNode;
|
|
|
|
firstChild?: AstNode;
|
|
|
|
lastChild?: AstNode;
|
|
|
|
next?: AstNode;
|
|
|
|
prev?: AstNode;
|
|
|
|
raw?: boolean;
|
|
|
|
constructor(name: string, type: number);
|
|
|
|
replace(node: AstNode): AstNode;
|
|
|
|
attr(name: string, value: string | null): AstNode | undefined;
|
|
|
|
attr(name: Record<string, string | null>): AstNode | undefined;
|
|
|
|
attr(name: string): string | undefined;
|
|
|
|
clone(): AstNode;
|
|
|
|
wrap(wrapper: AstNode): AstNode;
|
|
|
|
unwrap(): void;
|
|
|
|
remove(): AstNode;
|
|
|
|
append(node: AstNode): AstNode;
|
|
|
|
insert(node: AstNode, refNode: AstNode, before?: boolean): AstNode;
|
|
|
|
getAll(name: string): AstNode[];
|
|
|
|
children(): AstNode[];
|
|
|
|
empty(): AstNode;
|
|
|
|
isEmpty(elements: SchemaMap, whitespace?: SchemaMap, predicate?: (node: AstNode) => boolean): boolean;
|
|
|
|
walk(prev?: boolean): AstNode;
|
|
|
|
}
|
|
|
|
declare type Content = string | AstNode;
|
|
|
|
declare type ContentFormat = 'raw' | 'text' | 'html' | 'tree';
|
|
|
|
interface GetContentArgs {
|
2022-07-17 19:33:03 +02:00
|
|
|
format: ContentFormat;
|
|
|
|
get: boolean;
|
|
|
|
getInner: boolean;
|
2022-02-05 17:55:53 +01:00
|
|
|
no_events?: boolean;
|
2022-07-17 19:33:03 +02:00
|
|
|
save?: boolean;
|
|
|
|
source_view?: boolean;
|
2022-02-05 17:55:53 +01:00
|
|
|
[key: string]: any;
|
|
|
|
}
|
|
|
|
interface SetContentArgs {
|
2022-07-17 19:33:03 +02:00
|
|
|
format: string;
|
|
|
|
set: boolean;
|
|
|
|
content: Content;
|
2022-02-05 17:55:53 +01:00
|
|
|
no_events?: boolean;
|
|
|
|
no_selection?: boolean;
|
2022-07-17 19:33:03 +02:00
|
|
|
paste?: boolean;
|
|
|
|
}
|
|
|
|
interface GetSelectionContentArgs extends GetContentArgs {
|
|
|
|
selection?: boolean;
|
|
|
|
contextual?: boolean;
|
|
|
|
}
|
|
|
|
interface SetSelectionContentArgs extends SetContentArgs {
|
|
|
|
content: string;
|
|
|
|
selection?: boolean;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
|
|
|
interface BlobInfoData {
|
|
|
|
id?: string;
|
|
|
|
name?: string;
|
|
|
|
filename?: string;
|
|
|
|
blob: Blob;
|
|
|
|
base64: string;
|
|
|
|
blobUri?: string;
|
|
|
|
uri?: string;
|
|
|
|
}
|
|
|
|
interface BlobInfo {
|
|
|
|
id: () => string;
|
|
|
|
name: () => string;
|
|
|
|
filename: () => string;
|
|
|
|
blob: () => Blob;
|
|
|
|
base64: () => string;
|
|
|
|
blobUri: () => string;
|
|
|
|
uri: () => string | undefined;
|
|
|
|
}
|
|
|
|
interface BlobCache {
|
2022-07-17 19:33:03 +02:00
|
|
|
create: {
|
|
|
|
(o: BlobInfoData): BlobInfo;
|
|
|
|
(id: string, blob: Blob, base64: string, name?: string, filename?: string): BlobInfo;
|
|
|
|
};
|
2022-02-05 17:55:53 +01:00
|
|
|
add: (blobInfo: BlobInfo) => void;
|
|
|
|
get: (id: string) => BlobInfo | undefined;
|
|
|
|
getByUri: (blobUri: string) => BlobInfo | undefined;
|
|
|
|
getByData: (base64: string, type: string) => BlobInfo | undefined;
|
|
|
|
findFirst: (predicate: (blobInfo: BlobInfo) => boolean) => BlobInfo | undefined;
|
|
|
|
removeByUri: (blobUri: string) => void;
|
|
|
|
destroy: () => void;
|
|
|
|
}
|
2022-07-17 19:33:03 +02:00
|
|
|
interface BlobInfoImagePair {
|
|
|
|
image: HTMLImageElement;
|
|
|
|
blobInfo: BlobInfo;
|
|
|
|
}
|
|
|
|
declare class NodeChange {
|
|
|
|
private readonly editor;
|
|
|
|
private lastPath;
|
|
|
|
constructor(editor: Editor);
|
|
|
|
nodeChanged(args?: any): void;
|
|
|
|
private isSameElementPath;
|
|
|
|
}
|
|
|
|
interface SelectionOverrides {
|
|
|
|
showCaret: (direction: number, node: Element, before: boolean, scrollIntoView?: boolean) => Range | null;
|
|
|
|
showBlockCaretContainer: (blockCaretContainer: Element) => void;
|
|
|
|
hideFakeCaret: () => void;
|
|
|
|
destroy: () => void;
|
|
|
|
}
|
|
|
|
interface Quirks {
|
|
|
|
refreshContentEditable(): void;
|
|
|
|
isHidden(): boolean;
|
|
|
|
}
|
|
|
|
declare type DecoratorData = Record<string, any>;
|
|
|
|
declare type Decorator = (uid: string, data: DecoratorData) => {
|
|
|
|
attributes?: {};
|
|
|
|
classes?: string[];
|
|
|
|
};
|
|
|
|
declare type AnnotationListener = (state: boolean, name: string, data?: {
|
|
|
|
uid: string;
|
|
|
|
nodes: any[];
|
|
|
|
}) => void;
|
|
|
|
declare type AnnotationListenerApi = AnnotationListener;
|
|
|
|
interface AnnotatorSettings {
|
|
|
|
decorate: Decorator;
|
|
|
|
persistent?: boolean;
|
|
|
|
}
|
|
|
|
interface Annotator {
|
|
|
|
register: (name: string, settings: AnnotatorSettings) => void;
|
|
|
|
annotate: (name: string, data: DecoratorData) => void;
|
|
|
|
annotationChanged: (name: string, f: AnnotationListenerApi) => void;
|
|
|
|
remove: (name: string) => void;
|
|
|
|
removeAll: (name: string) => void;
|
|
|
|
getAll: (name: string) => Record<string, Element[]>;
|
|
|
|
}
|
|
|
|
interface GeomRect {
|
|
|
|
readonly x: number;
|
|
|
|
readonly y: number;
|
|
|
|
readonly w: number;
|
|
|
|
readonly h: number;
|
|
|
|
}
|
|
|
|
interface Rect {
|
|
|
|
inflate: (rect: GeomRect, w: number, h: number) => GeomRect;
|
|
|
|
relativePosition: (rect: GeomRect, targetRect: GeomRect, rel: string) => GeomRect;
|
|
|
|
findBestRelativePosition: (rect: GeomRect, targetRect: GeomRect, constrainRect: GeomRect, rels: string[]) => string | null;
|
|
|
|
intersect: (rect: GeomRect, cropRect: GeomRect) => GeomRect | null;
|
|
|
|
clamp: (rect: GeomRect, clampRect: GeomRect, fixedSize?: boolean) => GeomRect;
|
|
|
|
create: (x: number, y: number, w: number, h: number) => GeomRect;
|
|
|
|
fromClientRect: (clientRect: DOMRect) => GeomRect;
|
|
|
|
}
|
2022-02-05 17:55:53 +01:00
|
|
|
interface NotificationManagerImpl {
|
|
|
|
open: (spec: NotificationSpec, closeCallback?: () => void) => NotificationApi;
|
|
|
|
close: <T extends NotificationApi>(notification: T) => void;
|
|
|
|
getArgs: <T extends NotificationApi>(notification: T) => NotificationSpec;
|
|
|
|
}
|
|
|
|
interface NotificationSpec {
|
|
|
|
type?: 'info' | 'warning' | 'error' | 'success';
|
|
|
|
text: string;
|
|
|
|
icon?: string;
|
|
|
|
progressBar?: boolean;
|
|
|
|
timeout?: number;
|
|
|
|
closeButton?: boolean;
|
|
|
|
}
|
|
|
|
interface NotificationApi {
|
|
|
|
close: () => void;
|
|
|
|
progressBar: {
|
|
|
|
value: (percent: number) => void;
|
|
|
|
};
|
|
|
|
text: (text: string) => void;
|
2022-07-17 19:33:03 +02:00
|
|
|
reposition: () => void;
|
2022-02-05 17:55:53 +01:00
|
|
|
getEl: () => HTMLElement;
|
|
|
|
settings: NotificationSpec;
|
|
|
|
}
|
|
|
|
interface NotificationManager {
|
|
|
|
open: (spec: NotificationSpec) => NotificationApi;
|
|
|
|
close: () => void;
|
|
|
|
getNotifications: () => NotificationApi[];
|
|
|
|
}
|
2022-07-17 19:33:03 +02:00
|
|
|
interface UploadFailure {
|
|
|
|
message: string;
|
2022-02-05 17:55:53 +01:00
|
|
|
remove?: boolean;
|
|
|
|
}
|
2022-07-17 19:33:03 +02:00
|
|
|
declare type ProgressFn = (percent: number) => void;
|
|
|
|
declare type UploadHandler = (blobInfo: BlobInfo, progress: ProgressFn) => Promise<string>;
|
2022-02-05 17:55:53 +01:00
|
|
|
interface UploadResult$2 {
|
|
|
|
url: string;
|
|
|
|
blobInfo: BlobInfo;
|
|
|
|
status: boolean;
|
2022-07-17 19:33:03 +02:00
|
|
|
error?: UploadFailure;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
2022-07-17 19:33:03 +02:00
|
|
|
interface RawPattern {
|
|
|
|
start?: any;
|
|
|
|
end?: any;
|
|
|
|
format?: any;
|
|
|
|
cmd?: any;
|
|
|
|
value?: any;
|
|
|
|
replacement?: any;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
2022-07-17 19:33:03 +02:00
|
|
|
interface InlineBasePattern {
|
|
|
|
readonly start: string;
|
|
|
|
readonly end: string;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
2022-07-17 19:33:03 +02:00
|
|
|
interface InlineFormatPattern extends InlineBasePattern {
|
|
|
|
readonly type: 'inline-format';
|
|
|
|
readonly format: string[];
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
2022-07-17 19:33:03 +02:00
|
|
|
interface InlineCmdPattern extends InlineBasePattern {
|
|
|
|
readonly type: 'inline-command';
|
|
|
|
readonly cmd: string;
|
|
|
|
readonly value?: any;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
2022-07-17 19:33:03 +02:00
|
|
|
declare type InlinePattern = InlineFormatPattern | InlineCmdPattern;
|
|
|
|
interface BlockBasePattern {
|
|
|
|
readonly start: string;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
2022-07-17 19:33:03 +02:00
|
|
|
interface BlockFormatPattern extends BlockBasePattern {
|
|
|
|
readonly type: 'block-format';
|
|
|
|
readonly format: string;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
2022-07-17 19:33:03 +02:00
|
|
|
interface BlockCmdPattern extends BlockBasePattern {
|
|
|
|
readonly type: 'block-command';
|
|
|
|
readonly cmd: string;
|
|
|
|
readonly value?: any;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
2022-07-17 19:33:03 +02:00
|
|
|
declare type BlockPattern = BlockFormatPattern | BlockCmdPattern;
|
|
|
|
declare type Pattern = InlinePattern | BlockPattern;
|
2022-02-05 17:55:53 +01:00
|
|
|
interface AlertBannerSpec {
|
|
|
|
type: 'alertbanner';
|
|
|
|
level: 'info' | 'warn' | 'error' | 'success';
|
|
|
|
text: string;
|
|
|
|
icon: string;
|
|
|
|
url?: string;
|
|
|
|
}
|
|
|
|
interface ButtonSpec {
|
|
|
|
type: 'button';
|
|
|
|
text: string;
|
2022-07-17 19:33:03 +02:00
|
|
|
enabled?: boolean;
|
2022-02-05 17:55:53 +01:00
|
|
|
primary?: boolean;
|
|
|
|
name?: string;
|
|
|
|
icon?: string;
|
|
|
|
borderless?: boolean;
|
2022-07-17 19:33:03 +02:00
|
|
|
buttonType?: 'primary' | 'secondary' | 'toolbar';
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
|
|
|
interface FormComponentSpec {
|
|
|
|
type: string;
|
|
|
|
name: string;
|
|
|
|
}
|
|
|
|
interface FormComponentWithLabelSpec extends FormComponentSpec {
|
|
|
|
label?: string;
|
|
|
|
}
|
2022-07-17 19:33:03 +02:00
|
|
|
interface CheckboxSpec extends FormComponentSpec {
|
|
|
|
type: 'checkbox';
|
|
|
|
label: string;
|
|
|
|
enabled?: boolean;
|
|
|
|
}
|
2022-02-05 17:55:53 +01:00
|
|
|
interface CollectionSpec extends FormComponentWithLabelSpec {
|
|
|
|
type: 'collection';
|
|
|
|
}
|
2022-07-17 19:33:03 +02:00
|
|
|
interface CollectionItem {
|
|
|
|
value: string;
|
|
|
|
text: string;
|
|
|
|
icon: string;
|
|
|
|
}
|
2022-02-05 17:55:53 +01:00
|
|
|
interface ColorInputSpec extends FormComponentWithLabelSpec {
|
|
|
|
type: 'colorinput';
|
|
|
|
}
|
|
|
|
interface ColorPickerSpec extends FormComponentWithLabelSpec {
|
|
|
|
type: 'colorpicker';
|
|
|
|
}
|
|
|
|
interface CustomEditorInit {
|
|
|
|
setValue: (value: string) => void;
|
|
|
|
getValue: () => string;
|
|
|
|
destroy: () => void;
|
|
|
|
}
|
|
|
|
declare type CustomEditorInitFn = (elm: HTMLElement, settings: any) => Promise<CustomEditorInit>;
|
|
|
|
interface CustomEditorOldSpec extends FormComponentSpec {
|
|
|
|
type: 'customeditor';
|
|
|
|
tag?: string;
|
|
|
|
init: (e: HTMLElement) => Promise<CustomEditorInit>;
|
|
|
|
}
|
|
|
|
interface CustomEditorNewSpec extends FormComponentSpec {
|
|
|
|
type: 'customeditor';
|
|
|
|
tag?: string;
|
|
|
|
scriptId: string;
|
|
|
|
scriptUrl: string;
|
|
|
|
settings?: any;
|
|
|
|
}
|
|
|
|
declare type CustomEditorSpec = CustomEditorOldSpec | CustomEditorNewSpec;
|
|
|
|
interface DropZoneSpec extends FormComponentWithLabelSpec {
|
|
|
|
type: 'dropzone';
|
|
|
|
}
|
|
|
|
interface GridSpec {
|
|
|
|
type: 'grid';
|
|
|
|
columns: number;
|
|
|
|
items: BodyComponentSpec[];
|
|
|
|
}
|
|
|
|
interface HtmlPanelSpec {
|
|
|
|
type: 'htmlpanel';
|
|
|
|
html: string;
|
|
|
|
presets?: 'presentation' | 'document';
|
|
|
|
}
|
|
|
|
interface IframeSpec extends FormComponentWithLabelSpec {
|
|
|
|
type: 'iframe';
|
|
|
|
sandboxed?: boolean;
|
2022-07-17 19:33:03 +02:00
|
|
|
transparent?: boolean;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
2022-07-17 19:33:03 +02:00
|
|
|
interface ImagePreviewSpec extends FormComponentSpec {
|
|
|
|
type: 'imagepreview';
|
|
|
|
height?: string;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
|
|
|
interface InputSpec extends FormComponentWithLabelSpec {
|
|
|
|
type: 'input';
|
|
|
|
inputMode?: string;
|
|
|
|
placeholder?: string;
|
|
|
|
maximized?: boolean;
|
2022-07-17 19:33:03 +02:00
|
|
|
enabled?: boolean;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
|
|
|
interface LabelSpec {
|
|
|
|
type: 'label';
|
|
|
|
label: string;
|
|
|
|
items: BodyComponentSpec[];
|
|
|
|
}
|
|
|
|
interface ListBoxSingleItemSpec {
|
|
|
|
text: string;
|
|
|
|
value: string;
|
|
|
|
}
|
|
|
|
interface ListBoxNestedItemSpec {
|
|
|
|
text: string;
|
|
|
|
items: ListBoxItemSpec[];
|
|
|
|
}
|
|
|
|
declare type ListBoxItemSpec = ListBoxNestedItemSpec | ListBoxSingleItemSpec;
|
|
|
|
interface ListBoxSpec extends FormComponentWithLabelSpec {
|
|
|
|
type: 'listbox';
|
|
|
|
items: ListBoxItemSpec[];
|
|
|
|
disabled?: boolean;
|
|
|
|
}
|
|
|
|
interface PanelSpec {
|
|
|
|
type: 'panel';
|
|
|
|
classes?: string[];
|
|
|
|
items: BodyComponentSpec[];
|
|
|
|
}
|
|
|
|
interface SelectBoxItemSpec {
|
|
|
|
text: string;
|
|
|
|
value: string;
|
|
|
|
}
|
|
|
|
interface SelectBoxSpec extends FormComponentWithLabelSpec {
|
|
|
|
type: 'selectbox';
|
|
|
|
items: SelectBoxItemSpec[];
|
|
|
|
size?: number;
|
2022-07-17 19:33:03 +02:00
|
|
|
enabled?: boolean;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
|
|
|
interface SizeInputSpec extends FormComponentWithLabelSpec {
|
|
|
|
type: 'sizeinput';
|
|
|
|
constrain?: boolean;
|
2022-07-17 19:33:03 +02:00
|
|
|
enabled?: boolean;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
2022-07-17 19:33:03 +02:00
|
|
|
interface SliderSpec extends FormComponentSpec {
|
|
|
|
type: 'slider';
|
|
|
|
label: string;
|
|
|
|
min?: number;
|
|
|
|
max?: number;
|
|
|
|
}
|
|
|
|
interface TableSpec {
|
2022-02-05 17:55:53 +01:00
|
|
|
type: 'table';
|
|
|
|
header: string[];
|
|
|
|
cells: string[][];
|
|
|
|
}
|
|
|
|
interface TextAreaSpec extends FormComponentWithLabelSpec {
|
|
|
|
type: 'textarea';
|
|
|
|
placeholder?: string;
|
|
|
|
maximized?: boolean;
|
2022-07-17 19:33:03 +02:00
|
|
|
enabled?: boolean;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
|
|
|
interface UrlInputSpec extends FormComponentWithLabelSpec {
|
|
|
|
type: 'urlinput';
|
|
|
|
filetype?: 'image' | 'media' | 'file';
|
2022-07-17 19:33:03 +02:00
|
|
|
enabled?: boolean;
|
|
|
|
}
|
|
|
|
interface UrlInputData {
|
|
|
|
value: string;
|
|
|
|
meta: {
|
|
|
|
text?: string;
|
|
|
|
};
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
2022-07-17 19:33:03 +02:00
|
|
|
declare type BodyComponentSpec = BarSpec | ButtonSpec | CheckboxSpec | TextAreaSpec | InputSpec | ListBoxSpec | SelectBoxSpec | SizeInputSpec | SliderSpec | IframeSpec | HtmlPanelSpec | UrlInputSpec | DropZoneSpec | ColorInputSpec | GridSpec | ColorPickerSpec | ImagePreviewSpec | AlertBannerSpec | CollectionSpec | LabelSpec | TableSpec | PanelSpec | CustomEditorSpec;
|
2022-02-05 17:55:53 +01:00
|
|
|
interface BarSpec {
|
|
|
|
type: 'bar';
|
|
|
|
items: BodyComponentSpec[];
|
|
|
|
}
|
|
|
|
interface CommonMenuItemSpec {
|
2022-07-17 19:33:03 +02:00
|
|
|
enabled?: boolean;
|
2022-02-05 17:55:53 +01:00
|
|
|
text?: string;
|
|
|
|
value?: string;
|
|
|
|
meta?: Record<string, any>;
|
|
|
|
shortcut?: string;
|
|
|
|
}
|
|
|
|
interface CommonMenuItemInstanceApi {
|
2022-07-17 19:33:03 +02:00
|
|
|
isEnabled: () => boolean;
|
|
|
|
setEnabled: (state: boolean) => void;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
|
|
|
interface DialogToggleMenuItemSpec extends CommonMenuItemSpec {
|
|
|
|
type?: 'togglemenuitem';
|
|
|
|
name: string;
|
|
|
|
}
|
|
|
|
declare type DialogFooterMenuButtonItemSpec = DialogToggleMenuItemSpec;
|
|
|
|
interface BaseDialogFooterButtonSpec {
|
|
|
|
name?: string;
|
|
|
|
align?: 'start' | 'end';
|
|
|
|
primary?: boolean;
|
2022-07-17 19:33:03 +02:00
|
|
|
enabled?: boolean;
|
2022-02-05 17:55:53 +01:00
|
|
|
icon?: string;
|
2022-07-17 19:33:03 +02:00
|
|
|
buttonType?: 'primary' | 'secondary';
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
|
|
|
interface DialogFooterNormalButtonSpec extends BaseDialogFooterButtonSpec {
|
|
|
|
type: 'submit' | 'cancel' | 'custom';
|
|
|
|
text: string;
|
|
|
|
}
|
|
|
|
interface DialogFooterMenuButtonSpec extends BaseDialogFooterButtonSpec {
|
|
|
|
type: 'menu';
|
|
|
|
text?: string;
|
|
|
|
tooltip?: string;
|
|
|
|
icon?: string;
|
|
|
|
items: DialogFooterMenuButtonItemSpec[];
|
|
|
|
}
|
|
|
|
declare type DialogFooterButtonSpec = DialogFooterNormalButtonSpec | DialogFooterMenuButtonSpec;
|
|
|
|
interface TabSpec {
|
|
|
|
name?: string;
|
|
|
|
title: string;
|
|
|
|
items: BodyComponentSpec[];
|
|
|
|
}
|
|
|
|
interface TabPanelSpec {
|
|
|
|
type: 'tabpanel';
|
|
|
|
tabs: TabSpec[];
|
|
|
|
}
|
|
|
|
declare type DialogDataItem = any;
|
|
|
|
declare type DialogData = Record<string, DialogDataItem>;
|
|
|
|
interface DialogInstanceApi<T extends DialogData> {
|
|
|
|
getData: () => T;
|
|
|
|
setData: (data: Partial<T>) => void;
|
2022-07-17 19:33:03 +02:00
|
|
|
setEnabled: (name: string, state: boolean) => void;
|
2022-02-05 17:55:53 +01:00
|
|
|
focus: (name: string) => void;
|
|
|
|
showTab: (name: string) => void;
|
|
|
|
redial: (nu: DialogSpec<T>) => void;
|
|
|
|
block: (msg: string) => void;
|
|
|
|
unblock: () => void;
|
|
|
|
close: () => void;
|
|
|
|
}
|
|
|
|
interface DialogActionDetails {
|
|
|
|
name: string;
|
|
|
|
value?: any;
|
|
|
|
}
|
|
|
|
interface DialogChangeDetails<T> {
|
|
|
|
name: keyof T;
|
|
|
|
}
|
|
|
|
interface DialogTabChangeDetails {
|
|
|
|
newTabName: string;
|
|
|
|
oldTabName: string;
|
|
|
|
}
|
|
|
|
declare type DialogActionHandler<T> = (api: DialogInstanceApi<T>, details: DialogActionDetails) => void;
|
|
|
|
declare type DialogChangeHandler<T> = (api: DialogInstanceApi<T>, details: DialogChangeDetails<T>) => void;
|
|
|
|
declare type DialogSubmitHandler<T> = (api: DialogInstanceApi<T>) => void;
|
|
|
|
declare type DialogCloseHandler = () => void;
|
|
|
|
declare type DialogCancelHandler<T> = (api: DialogInstanceApi<T>) => void;
|
|
|
|
declare type DialogTabChangeHandler<T> = (api: DialogInstanceApi<T>, details: DialogTabChangeDetails) => void;
|
|
|
|
declare type DialogSize = 'normal' | 'medium' | 'large';
|
|
|
|
interface DialogSpec<T extends DialogData> {
|
|
|
|
title: string;
|
|
|
|
size?: DialogSize;
|
|
|
|
body: TabPanelSpec | PanelSpec;
|
|
|
|
buttons: DialogFooterButtonSpec[];
|
2022-07-17 19:33:03 +02:00
|
|
|
initialData?: Partial<T>;
|
2022-02-05 17:55:53 +01:00
|
|
|
onAction?: DialogActionHandler<T>;
|
|
|
|
onChange?: DialogChangeHandler<T>;
|
|
|
|
onSubmit?: DialogSubmitHandler<T>;
|
|
|
|
onClose?: DialogCloseHandler;
|
|
|
|
onCancel?: DialogCancelHandler<T>;
|
|
|
|
onTabChange?: DialogTabChangeHandler<T>;
|
|
|
|
}
|
|
|
|
interface UrlDialogInstanceApi {
|
|
|
|
block: (msg: string) => void;
|
|
|
|
unblock: () => void;
|
|
|
|
close: () => void;
|
|
|
|
sendMessage: (msg: any) => void;
|
|
|
|
}
|
|
|
|
interface UrlDialogActionDetails {
|
|
|
|
name: string;
|
|
|
|
value?: any;
|
|
|
|
}
|
|
|
|
interface UrlDialogMessage {
|
|
|
|
mceAction: string;
|
|
|
|
[key: string]: any;
|
|
|
|
}
|
|
|
|
declare type UrlDialogActionHandler = (api: UrlDialogInstanceApi, actions: UrlDialogActionDetails) => void;
|
|
|
|
declare type UrlDialogCloseHandler = () => void;
|
|
|
|
declare type UrlDialogCancelHandler = (api: UrlDialogInstanceApi) => void;
|
|
|
|
declare type UrlDialogMessageHandler = (api: UrlDialogInstanceApi, message: UrlDialogMessage) => void;
|
|
|
|
interface UrlDialogFooterButtonSpec extends DialogFooterNormalButtonSpec {
|
|
|
|
type: 'cancel' | 'custom';
|
|
|
|
}
|
|
|
|
interface UrlDialogSpec {
|
|
|
|
title: string;
|
|
|
|
url: string;
|
|
|
|
height?: number;
|
|
|
|
width?: number;
|
|
|
|
buttons?: UrlDialogFooterButtonSpec[];
|
|
|
|
onAction?: UrlDialogActionHandler;
|
|
|
|
onClose?: UrlDialogCloseHandler;
|
|
|
|
onCancel?: UrlDialogCancelHandler;
|
|
|
|
onMessage?: UrlDialogMessageHandler;
|
|
|
|
}
|
|
|
|
declare type CardContainerDirection = 'vertical' | 'horizontal';
|
|
|
|
declare type CardContainerAlign = 'left' | 'right';
|
|
|
|
declare type CardContainerValign = 'top' | 'middle' | 'bottom';
|
|
|
|
interface CardContainerSpec {
|
|
|
|
type: 'cardcontainer';
|
|
|
|
items: CardItemSpec[];
|
|
|
|
direction?: CardContainerDirection;
|
|
|
|
align?: CardContainerAlign;
|
|
|
|
valign?: CardContainerValign;
|
|
|
|
}
|
|
|
|
interface CardImageSpec {
|
|
|
|
type: 'cardimage';
|
|
|
|
src: string;
|
|
|
|
alt?: string;
|
|
|
|
classes?: string[];
|
|
|
|
}
|
|
|
|
interface CardTextSpec {
|
|
|
|
type: 'cardtext';
|
|
|
|
text: string;
|
|
|
|
name?: string;
|
|
|
|
classes?: string[];
|
|
|
|
}
|
|
|
|
declare type CardItemSpec = CardContainerSpec | CardImageSpec | CardTextSpec;
|
|
|
|
interface CardMenuItemInstanceApi extends CommonMenuItemInstanceApi {
|
|
|
|
}
|
|
|
|
interface CardMenuItemSpec extends Omit<CommonMenuItemSpec, 'text' | 'shortcut'> {
|
|
|
|
type: 'cardmenuitem';
|
|
|
|
label?: string;
|
|
|
|
items: CardItemSpec[];
|
|
|
|
onSetup?: (api: CardMenuItemInstanceApi) => (api: CardMenuItemInstanceApi) => void;
|
|
|
|
onAction?: (api: CardMenuItemInstanceApi) => void;
|
|
|
|
}
|
|
|
|
interface SeparatorMenuItemSpec {
|
|
|
|
type?: 'separator';
|
|
|
|
text?: string;
|
|
|
|
}
|
|
|
|
declare type ColumnTypes$1 = number | 'auto';
|
|
|
|
declare type SeparatorItemSpec = SeparatorMenuItemSpec;
|
|
|
|
interface AutocompleterItemSpec {
|
|
|
|
type?: 'autocompleteitem';
|
|
|
|
value: string;
|
|
|
|
text?: string;
|
|
|
|
icon?: string;
|
|
|
|
meta?: Record<string, any>;
|
|
|
|
}
|
|
|
|
declare type AutocompleterContents = SeparatorItemSpec | AutocompleterItemSpec | CardMenuItemSpec;
|
|
|
|
interface AutocompleterSpec {
|
|
|
|
type?: 'autocompleter';
|
|
|
|
ch: string;
|
|
|
|
minChars?: number;
|
|
|
|
columns?: ColumnTypes$1;
|
|
|
|
matches?: (rng: Range, text: string, pattern: string) => boolean;
|
|
|
|
fetch: (pattern: string, maxResults: number, fetchOptions: Record<string, any>) => Promise<AutocompleterContents[]>;
|
|
|
|
onAction: (autocompleterApi: AutocompleterInstanceApi, rng: Range, value: string, meta: Record<string, any>) => void;
|
|
|
|
maxResults?: number;
|
|
|
|
highlightOn?: string[];
|
|
|
|
}
|
|
|
|
interface AutocompleterInstanceApi {
|
|
|
|
hide: () => void;
|
|
|
|
reload: (fetchOptions: Record<string, any>) => void;
|
|
|
|
}
|
|
|
|
declare type ContextPosition = 'node' | 'selection' | 'line';
|
|
|
|
declare type ContextScope = 'node' | 'editor';
|
|
|
|
interface ContextBarSpec {
|
|
|
|
predicate?: (elem: Element) => boolean;
|
|
|
|
position?: ContextPosition;
|
|
|
|
scope?: ContextScope;
|
|
|
|
}
|
|
|
|
interface BaseToolbarButtonSpec<I extends BaseToolbarButtonInstanceApi> {
|
2022-07-17 19:33:03 +02:00
|
|
|
enabled?: boolean;
|
2022-02-05 17:55:53 +01:00
|
|
|
tooltip?: string;
|
|
|
|
icon?: string;
|
|
|
|
text?: string;
|
|
|
|
onSetup?: (api: I) => (api: I) => void;
|
|
|
|
}
|
|
|
|
interface BaseToolbarButtonInstanceApi {
|
2022-07-17 19:33:03 +02:00
|
|
|
isEnabled: () => boolean;
|
|
|
|
setEnabled: (state: boolean) => void;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
|
|
|
interface ToolbarButtonSpec extends BaseToolbarButtonSpec<ToolbarButtonInstanceApi> {
|
|
|
|
type?: 'button';
|
|
|
|
onAction: (api: ToolbarButtonInstanceApi) => void;
|
|
|
|
}
|
|
|
|
interface ToolbarButtonInstanceApi extends BaseToolbarButtonInstanceApi {
|
|
|
|
}
|
|
|
|
interface BaseToolbarToggleButtonSpec<I extends BaseToolbarButtonInstanceApi> extends BaseToolbarButtonSpec<I> {
|
|
|
|
active?: boolean;
|
|
|
|
}
|
|
|
|
interface BaseToolbarToggleButtonInstanceApi extends BaseToolbarButtonInstanceApi {
|
|
|
|
isActive: () => boolean;
|
|
|
|
setActive: (state: boolean) => void;
|
|
|
|
}
|
|
|
|
interface ToolbarToggleButtonSpec extends BaseToolbarToggleButtonSpec<ToolbarToggleButtonInstanceApi> {
|
|
|
|
type?: 'togglebutton';
|
|
|
|
onAction: (api: ToolbarToggleButtonInstanceApi) => void;
|
|
|
|
}
|
|
|
|
interface ToolbarToggleButtonInstanceApi extends BaseToolbarToggleButtonInstanceApi {
|
|
|
|
}
|
|
|
|
interface ContextFormLaunchButtonApi extends BaseToolbarButtonSpec<BaseToolbarButtonInstanceApi> {
|
|
|
|
type: 'contextformbutton';
|
|
|
|
}
|
|
|
|
interface ContextFormLaunchToggleButtonSpec extends BaseToolbarToggleButtonSpec<BaseToolbarToggleButtonInstanceApi> {
|
|
|
|
type: 'contextformtogglebutton';
|
|
|
|
}
|
|
|
|
interface ContextFormButtonInstanceApi extends BaseToolbarButtonInstanceApi {
|
|
|
|
}
|
|
|
|
interface ContextFormToggleButtonInstanceApi extends BaseToolbarToggleButtonInstanceApi {
|
|
|
|
}
|
|
|
|
interface ContextFormButtonSpec extends BaseToolbarButtonSpec<ContextFormButtonInstanceApi> {
|
|
|
|
type?: 'contextformbutton';
|
|
|
|
primary?: boolean;
|
|
|
|
onAction: (formApi: ContextFormInstanceApi, api: ContextFormButtonInstanceApi) => void;
|
|
|
|
}
|
|
|
|
interface ContextFormToggleButtonSpec extends BaseToolbarToggleButtonSpec<ContextFormToggleButtonInstanceApi> {
|
|
|
|
type?: 'contextformtogglebutton';
|
|
|
|
onAction: (formApi: ContextFormInstanceApi, buttonApi: ContextFormToggleButtonInstanceApi) => void;
|
|
|
|
primary?: boolean;
|
|
|
|
}
|
|
|
|
interface ContextFormInstanceApi {
|
|
|
|
hide: () => void;
|
|
|
|
getValue: () => string;
|
|
|
|
}
|
|
|
|
interface ContextFormSpec extends ContextBarSpec {
|
|
|
|
type?: 'contextform';
|
|
|
|
initValue?: () => string;
|
|
|
|
label?: string;
|
|
|
|
launch?: ContextFormLaunchButtonApi | ContextFormLaunchToggleButtonSpec;
|
|
|
|
commands: Array<ContextFormToggleButtonSpec | ContextFormButtonSpec>;
|
|
|
|
}
|
|
|
|
interface ContextToolbarSpec extends ContextBarSpec {
|
|
|
|
type?: 'contexttoolbar';
|
|
|
|
items: string;
|
|
|
|
}
|
|
|
|
interface ChoiceMenuItemSpec extends CommonMenuItemSpec {
|
|
|
|
type?: 'choiceitem';
|
|
|
|
icon?: string;
|
|
|
|
}
|
|
|
|
interface ChoiceMenuItemInstanceApi extends CommonMenuItemInstanceApi {
|
|
|
|
isActive: () => boolean;
|
|
|
|
setActive: (state: boolean) => void;
|
|
|
|
}
|
|
|
|
interface ContextMenuItem extends CommonMenuItemSpec {
|
|
|
|
text: string;
|
|
|
|
icon?: string;
|
|
|
|
type?: 'item';
|
|
|
|
onAction: () => void;
|
|
|
|
}
|
|
|
|
interface ContextSubMenu extends CommonMenuItemSpec {
|
|
|
|
type: 'submenu';
|
|
|
|
text: string;
|
|
|
|
icon?: string;
|
|
|
|
getSubmenuItems: () => string | Array<ContextMenuContents>;
|
|
|
|
}
|
|
|
|
declare type ContextMenuContents = string | ContextMenuItem | SeparatorMenuItemSpec | ContextSubMenu;
|
|
|
|
interface ContextMenuApi {
|
|
|
|
update: (element: Element) => string | Array<ContextMenuContents>;
|
|
|
|
}
|
|
|
|
interface FancyActionArgsMap {
|
|
|
|
'inserttable': {
|
|
|
|
numRows: number;
|
|
|
|
numColumns: number;
|
|
|
|
};
|
|
|
|
'colorswatch': {
|
|
|
|
value: string;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
interface BaseFancyMenuItemSpec<T extends keyof FancyActionArgsMap> {
|
|
|
|
type: 'fancymenuitem';
|
|
|
|
fancytype: T;
|
|
|
|
initData?: Record<string, unknown>;
|
|
|
|
onAction?: (data: FancyActionArgsMap[T]) => void;
|
|
|
|
}
|
|
|
|
interface InsertTableMenuItemSpec extends BaseFancyMenuItemSpec<'inserttable'> {
|
|
|
|
fancytype: 'inserttable';
|
|
|
|
initData?: {};
|
|
|
|
}
|
|
|
|
interface ColorSwatchMenuItemSpec extends BaseFancyMenuItemSpec<'colorswatch'> {
|
|
|
|
fancytype: 'colorswatch';
|
|
|
|
initData?: {
|
|
|
|
allowCustomColors?: boolean;
|
|
|
|
colors: ChoiceMenuItemSpec[];
|
|
|
|
};
|
|
|
|
}
|
|
|
|
declare type FancyMenuItemSpec = InsertTableMenuItemSpec | ColorSwatchMenuItemSpec;
|
|
|
|
interface MenuItemSpec extends CommonMenuItemSpec {
|
|
|
|
type?: 'menuitem';
|
|
|
|
icon?: string;
|
|
|
|
onSetup?: (api: MenuItemInstanceApi) => (api: MenuItemInstanceApi) => void;
|
|
|
|
onAction?: (api: MenuItemInstanceApi) => void;
|
|
|
|
}
|
|
|
|
interface MenuItemInstanceApi extends CommonMenuItemInstanceApi {
|
|
|
|
}
|
|
|
|
declare type NestedMenuItemContents = string | MenuItemSpec | NestedMenuItemSpec | ToggleMenuItemSpec | SeparatorMenuItemSpec | FancyMenuItemSpec;
|
|
|
|
interface NestedMenuItemSpec extends CommonMenuItemSpec {
|
|
|
|
type?: 'nestedmenuitem';
|
|
|
|
icon?: string;
|
|
|
|
getSubmenuItems: () => string | Array<NestedMenuItemContents>;
|
|
|
|
onSetup?: (api: NestedMenuItemInstanceApi) => (api: NestedMenuItemInstanceApi) => void;
|
|
|
|
}
|
|
|
|
interface NestedMenuItemInstanceApi extends CommonMenuItemInstanceApi {
|
|
|
|
}
|
|
|
|
interface ToggleMenuItemSpec extends CommonMenuItemSpec {
|
|
|
|
type?: 'togglemenuitem';
|
|
|
|
icon?: string;
|
|
|
|
active?: boolean;
|
|
|
|
onSetup?: (api: ToggleMenuItemInstanceApi) => void;
|
|
|
|
onAction: (api: ToggleMenuItemInstanceApi) => void;
|
|
|
|
}
|
|
|
|
interface ToggleMenuItemInstanceApi extends CommonMenuItemInstanceApi {
|
|
|
|
isActive: () => boolean;
|
|
|
|
setActive: (state: boolean) => void;
|
|
|
|
}
|
|
|
|
type PublicDialog_d_AlertBannerSpec = AlertBannerSpec;
|
|
|
|
type PublicDialog_d_BarSpec = BarSpec;
|
|
|
|
type PublicDialog_d_BodyComponentSpec = BodyComponentSpec;
|
|
|
|
type PublicDialog_d_ButtonSpec = ButtonSpec;
|
|
|
|
type PublicDialog_d_CheckboxSpec = CheckboxSpec;
|
2022-07-17 19:33:03 +02:00
|
|
|
type PublicDialog_d_CollectionItem = CollectionItem;
|
2022-02-05 17:55:53 +01:00
|
|
|
type PublicDialog_d_CollectionSpec = CollectionSpec;
|
|
|
|
type PublicDialog_d_ColorInputSpec = ColorInputSpec;
|
|
|
|
type PublicDialog_d_ColorPickerSpec = ColorPickerSpec;
|
|
|
|
type PublicDialog_d_CustomEditorSpec = CustomEditorSpec;
|
|
|
|
type PublicDialog_d_CustomEditorInit = CustomEditorInit;
|
|
|
|
type PublicDialog_d_CustomEditorInitFn = CustomEditorInitFn;
|
|
|
|
type PublicDialog_d_DialogData = DialogData;
|
|
|
|
type PublicDialog_d_DialogSize = DialogSize;
|
|
|
|
type PublicDialog_d_DialogSpec<_0> = DialogSpec<_0>;
|
|
|
|
type PublicDialog_d_DialogInstanceApi<_0> = DialogInstanceApi<_0>;
|
|
|
|
type PublicDialog_d_DialogFooterButtonSpec = DialogFooterButtonSpec;
|
|
|
|
type PublicDialog_d_DialogActionDetails = DialogActionDetails;
|
|
|
|
type PublicDialog_d_DialogChangeDetails<_0> = DialogChangeDetails<_0>;
|
|
|
|
type PublicDialog_d_DialogTabChangeDetails = DialogTabChangeDetails;
|
|
|
|
type PublicDialog_d_DropZoneSpec = DropZoneSpec;
|
|
|
|
type PublicDialog_d_GridSpec = GridSpec;
|
|
|
|
type PublicDialog_d_HtmlPanelSpec = HtmlPanelSpec;
|
|
|
|
type PublicDialog_d_IframeSpec = IframeSpec;
|
2022-07-17 19:33:03 +02:00
|
|
|
type PublicDialog_d_ImagePreviewSpec = ImagePreviewSpec;
|
2022-02-05 17:55:53 +01:00
|
|
|
type PublicDialog_d_InputSpec = InputSpec;
|
|
|
|
type PublicDialog_d_LabelSpec = LabelSpec;
|
|
|
|
type PublicDialog_d_ListBoxSpec = ListBoxSpec;
|
|
|
|
type PublicDialog_d_ListBoxItemSpec = ListBoxItemSpec;
|
|
|
|
type PublicDialog_d_ListBoxNestedItemSpec = ListBoxNestedItemSpec;
|
|
|
|
type PublicDialog_d_ListBoxSingleItemSpec = ListBoxSingleItemSpec;
|
|
|
|
type PublicDialog_d_PanelSpec = PanelSpec;
|
|
|
|
type PublicDialog_d_SelectBoxSpec = SelectBoxSpec;
|
|
|
|
type PublicDialog_d_SelectBoxItemSpec = SelectBoxItemSpec;
|
|
|
|
type PublicDialog_d_SizeInputSpec = SizeInputSpec;
|
2022-07-17 19:33:03 +02:00
|
|
|
type PublicDialog_d_SliderSpec = SliderSpec;
|
2022-02-05 17:55:53 +01:00
|
|
|
type PublicDialog_d_TableSpec = TableSpec;
|
|
|
|
type PublicDialog_d_TabSpec = TabSpec;
|
|
|
|
type PublicDialog_d_TabPanelSpec = TabPanelSpec;
|
|
|
|
type PublicDialog_d_TextAreaSpec = TextAreaSpec;
|
2022-07-17 19:33:03 +02:00
|
|
|
type PublicDialog_d_UrlInputData = UrlInputData;
|
2022-02-05 17:55:53 +01:00
|
|
|
type PublicDialog_d_UrlInputSpec = UrlInputSpec;
|
|
|
|
type PublicDialog_d_UrlDialogSpec = UrlDialogSpec;
|
|
|
|
type PublicDialog_d_UrlDialogFooterButtonSpec = UrlDialogFooterButtonSpec;
|
|
|
|
type PublicDialog_d_UrlDialogInstanceApi = UrlDialogInstanceApi;
|
|
|
|
type PublicDialog_d_UrlDialogActionDetails = UrlDialogActionDetails;
|
|
|
|
type PublicDialog_d_UrlDialogMessage = UrlDialogMessage;
|
|
|
|
declare namespace PublicDialog_d {
|
2022-07-17 19:33:03 +02:00
|
|
|
export { PublicDialog_d_AlertBannerSpec as AlertBannerSpec, PublicDialog_d_BarSpec as BarSpec, PublicDialog_d_BodyComponentSpec as BodyComponentSpec, PublicDialog_d_ButtonSpec as ButtonSpec, PublicDialog_d_CheckboxSpec as CheckboxSpec, PublicDialog_d_CollectionItem as CollectionItem, PublicDialog_d_CollectionSpec as CollectionSpec, PublicDialog_d_ColorInputSpec as ColorInputSpec, PublicDialog_d_ColorPickerSpec as ColorPickerSpec, PublicDialog_d_CustomEditorSpec as CustomEditorSpec, PublicDialog_d_CustomEditorInit as CustomEditorInit, PublicDialog_d_CustomEditorInitFn as CustomEditorInitFn, PublicDialog_d_DialogData as DialogData, PublicDialog_d_DialogSize as DialogSize, PublicDialog_d_DialogSpec as DialogSpec, PublicDialog_d_DialogInstanceApi as DialogInstanceApi, PublicDialog_d_DialogFooterButtonSpec as DialogFooterButtonSpec, PublicDialog_d_DialogActionDetails as DialogActionDetails, PublicDialog_d_DialogChangeDetails as DialogChangeDetails, PublicDialog_d_DialogTabChangeDetails as DialogTabChangeDetails, PublicDialog_d_DropZoneSpec as DropZoneSpec, PublicDialog_d_GridSpec as GridSpec, PublicDialog_d_HtmlPanelSpec as HtmlPanelSpec, PublicDialog_d_IframeSpec as IframeSpec, PublicDialog_d_ImagePreviewSpec as ImagePreviewSpec, PublicDialog_d_InputSpec as InputSpec, PublicDialog_d_LabelSpec as LabelSpec, PublicDialog_d_ListBoxSpec as ListBoxSpec, PublicDialog_d_ListBoxItemSpec as ListBoxItemSpec, PublicDialog_d_ListBoxNestedItemSpec as ListBoxNestedItemSpec, PublicDialog_d_ListBoxSingleItemSpec as ListBoxSingleItemSpec, PublicDialog_d_PanelSpec as PanelSpec, PublicDialog_d_SelectBoxSpec as SelectBoxSpec, PublicDialog_d_SelectBoxItemSpec as SelectBoxItemSpec, PublicDialog_d_SizeInputSpec as SizeInputSpec, PublicDialog_d_SliderSpec as SliderSpec, PublicDialog_d_TableSpec as TableSpec, PublicDialog_d_TabSpec as TabSpec, PublicDialog_d_TabPanelSpec as TabPanelSpec, PublicDialog_d_TextAreaSpec as TextAreaSpec, PublicDialog_d_UrlInputData as UrlInputData, PublicDialog_d_UrlInputSpec as UrlInputSpec, PublicDialog_d_UrlDialogSpec as UrlDialogSpec, PublicDialog_d_UrlDialogFooterButtonSpec as UrlDialogFooterButtonSpec, PublicDialog_d_UrlDialogInstanceApi as UrlDialogInstanceApi, PublicDialog_d_UrlDialogActionDetails as UrlDialogActionDetails, PublicDialog_d_UrlDialogMessage as UrlDialogMessage, };
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
|
|
|
type PublicInlineContent_d_AutocompleterSpec = AutocompleterSpec;
|
|
|
|
type PublicInlineContent_d_AutocompleterItemSpec = AutocompleterItemSpec;
|
|
|
|
type PublicInlineContent_d_AutocompleterContents = AutocompleterContents;
|
|
|
|
type PublicInlineContent_d_AutocompleterInstanceApi = AutocompleterInstanceApi;
|
|
|
|
type PublicInlineContent_d_ContextPosition = ContextPosition;
|
|
|
|
type PublicInlineContent_d_ContextScope = ContextScope;
|
|
|
|
type PublicInlineContent_d_ContextFormSpec = ContextFormSpec;
|
|
|
|
type PublicInlineContent_d_ContextFormInstanceApi = ContextFormInstanceApi;
|
|
|
|
type PublicInlineContent_d_ContextFormButtonSpec = ContextFormButtonSpec;
|
|
|
|
type PublicInlineContent_d_ContextFormButtonInstanceApi = ContextFormButtonInstanceApi;
|
|
|
|
type PublicInlineContent_d_ContextFormToggleButtonSpec = ContextFormToggleButtonSpec;
|
|
|
|
type PublicInlineContent_d_ContextFormToggleButtonInstanceApi = ContextFormToggleButtonInstanceApi;
|
|
|
|
type PublicInlineContent_d_ContextToolbarSpec = ContextToolbarSpec;
|
|
|
|
type PublicInlineContent_d_SeparatorItemSpec = SeparatorItemSpec;
|
|
|
|
declare namespace PublicInlineContent_d {
|
|
|
|
export { PublicInlineContent_d_AutocompleterSpec as AutocompleterSpec, PublicInlineContent_d_AutocompleterItemSpec as AutocompleterItemSpec, PublicInlineContent_d_AutocompleterContents as AutocompleterContents, PublicInlineContent_d_AutocompleterInstanceApi as AutocompleterInstanceApi, PublicInlineContent_d_ContextPosition as ContextPosition, PublicInlineContent_d_ContextScope as ContextScope, PublicInlineContent_d_ContextFormSpec as ContextFormSpec, PublicInlineContent_d_ContextFormInstanceApi as ContextFormInstanceApi, PublicInlineContent_d_ContextFormButtonSpec as ContextFormButtonSpec, PublicInlineContent_d_ContextFormButtonInstanceApi as ContextFormButtonInstanceApi, PublicInlineContent_d_ContextFormToggleButtonSpec as ContextFormToggleButtonSpec, PublicInlineContent_d_ContextFormToggleButtonInstanceApi as ContextFormToggleButtonInstanceApi, PublicInlineContent_d_ContextToolbarSpec as ContextToolbarSpec, PublicInlineContent_d_SeparatorItemSpec as SeparatorItemSpec, };
|
|
|
|
}
|
|
|
|
type PublicMenu_d_MenuItemSpec = MenuItemSpec;
|
|
|
|
type PublicMenu_d_MenuItemInstanceApi = MenuItemInstanceApi;
|
|
|
|
type PublicMenu_d_NestedMenuItemContents = NestedMenuItemContents;
|
|
|
|
type PublicMenu_d_NestedMenuItemSpec = NestedMenuItemSpec;
|
|
|
|
type PublicMenu_d_NestedMenuItemInstanceApi = NestedMenuItemInstanceApi;
|
|
|
|
type PublicMenu_d_FancyMenuItemSpec = FancyMenuItemSpec;
|
|
|
|
type PublicMenu_d_ColorSwatchMenuItemSpec = ColorSwatchMenuItemSpec;
|
|
|
|
type PublicMenu_d_InsertTableMenuItemSpec = InsertTableMenuItemSpec;
|
|
|
|
type PublicMenu_d_ToggleMenuItemSpec = ToggleMenuItemSpec;
|
|
|
|
type PublicMenu_d_ToggleMenuItemInstanceApi = ToggleMenuItemInstanceApi;
|
|
|
|
type PublicMenu_d_ChoiceMenuItemSpec = ChoiceMenuItemSpec;
|
|
|
|
type PublicMenu_d_ChoiceMenuItemInstanceApi = ChoiceMenuItemInstanceApi;
|
|
|
|
type PublicMenu_d_SeparatorMenuItemSpec = SeparatorMenuItemSpec;
|
|
|
|
type PublicMenu_d_ContextMenuApi = ContextMenuApi;
|
|
|
|
type PublicMenu_d_ContextMenuContents = ContextMenuContents;
|
|
|
|
type PublicMenu_d_ContextMenuItem = ContextMenuItem;
|
|
|
|
type PublicMenu_d_ContextSubMenu = ContextSubMenu;
|
|
|
|
type PublicMenu_d_CardMenuItemSpec = CardMenuItemSpec;
|
|
|
|
type PublicMenu_d_CardMenuItemInstanceApi = CardMenuItemInstanceApi;
|
|
|
|
type PublicMenu_d_CardItemSpec = CardItemSpec;
|
|
|
|
type PublicMenu_d_CardContainerSpec = CardContainerSpec;
|
|
|
|
type PublicMenu_d_CardImageSpec = CardImageSpec;
|
|
|
|
type PublicMenu_d_CardTextSpec = CardTextSpec;
|
|
|
|
declare namespace PublicMenu_d {
|
|
|
|
export { PublicMenu_d_MenuItemSpec as MenuItemSpec, PublicMenu_d_MenuItemInstanceApi as MenuItemInstanceApi, PublicMenu_d_NestedMenuItemContents as NestedMenuItemContents, PublicMenu_d_NestedMenuItemSpec as NestedMenuItemSpec, PublicMenu_d_NestedMenuItemInstanceApi as NestedMenuItemInstanceApi, PublicMenu_d_FancyMenuItemSpec as FancyMenuItemSpec, PublicMenu_d_ColorSwatchMenuItemSpec as ColorSwatchMenuItemSpec, PublicMenu_d_InsertTableMenuItemSpec as InsertTableMenuItemSpec, PublicMenu_d_ToggleMenuItemSpec as ToggleMenuItemSpec, PublicMenu_d_ToggleMenuItemInstanceApi as ToggleMenuItemInstanceApi, PublicMenu_d_ChoiceMenuItemSpec as ChoiceMenuItemSpec, PublicMenu_d_ChoiceMenuItemInstanceApi as ChoiceMenuItemInstanceApi, PublicMenu_d_SeparatorMenuItemSpec as SeparatorMenuItemSpec, PublicMenu_d_ContextMenuApi as ContextMenuApi, PublicMenu_d_ContextMenuContents as ContextMenuContents, PublicMenu_d_ContextMenuItem as ContextMenuItem, PublicMenu_d_ContextSubMenu as ContextSubMenu, PublicMenu_d_CardMenuItemSpec as CardMenuItemSpec, PublicMenu_d_CardMenuItemInstanceApi as CardMenuItemInstanceApi, PublicMenu_d_CardItemSpec as CardItemSpec, PublicMenu_d_CardContainerSpec as CardContainerSpec, PublicMenu_d_CardImageSpec as CardImageSpec, PublicMenu_d_CardTextSpec as CardTextSpec, };
|
|
|
|
}
|
|
|
|
interface SidebarInstanceApi {
|
|
|
|
element: () => HTMLElement;
|
|
|
|
}
|
|
|
|
interface SidebarSpec {
|
|
|
|
icon?: string;
|
|
|
|
tooltip?: string;
|
|
|
|
onShow?: (api: SidebarInstanceApi) => void;
|
|
|
|
onSetup?: (api: SidebarInstanceApi) => (api: SidebarInstanceApi) => void;
|
|
|
|
onHide?: (api: SidebarInstanceApi) => void;
|
|
|
|
}
|
|
|
|
type PublicSidebar_d_SidebarSpec = SidebarSpec;
|
|
|
|
type PublicSidebar_d_SidebarInstanceApi = SidebarInstanceApi;
|
|
|
|
declare namespace PublicSidebar_d {
|
|
|
|
export { PublicSidebar_d_SidebarSpec as SidebarSpec, PublicSidebar_d_SidebarInstanceApi as SidebarInstanceApi, };
|
|
|
|
}
|
|
|
|
interface ToolbarGroupSetting {
|
|
|
|
name: string;
|
|
|
|
items: string[];
|
|
|
|
}
|
|
|
|
declare type ToolbarConfig = string | ToolbarGroupSetting[];
|
|
|
|
interface GroupToolbarButtonInstanceApi extends BaseToolbarButtonInstanceApi {
|
|
|
|
}
|
|
|
|
interface GroupToolbarButtonSpec extends BaseToolbarButtonSpec<GroupToolbarButtonInstanceApi> {
|
|
|
|
type?: 'grouptoolbarbutton';
|
|
|
|
items?: ToolbarConfig;
|
|
|
|
}
|
|
|
|
declare type MenuButtonItemTypes = NestedMenuItemContents;
|
|
|
|
declare type SuccessCallback$1 = (menu: string | MenuButtonItemTypes[]) => void;
|
|
|
|
interface BaseMenuButtonSpec {
|
|
|
|
text?: string;
|
|
|
|
tooltip?: string;
|
|
|
|
icon?: string;
|
|
|
|
fetch: (success: SuccessCallback$1) => void;
|
|
|
|
onSetup?: (api: BaseMenuButtonInstanceApi) => (api: BaseMenuButtonInstanceApi) => void;
|
|
|
|
}
|
|
|
|
interface BaseMenuButtonInstanceApi {
|
2022-07-17 19:33:03 +02:00
|
|
|
isEnabled: () => boolean;
|
|
|
|
setEnabled: (state: boolean) => void;
|
2022-02-05 17:55:53 +01:00
|
|
|
isActive: () => boolean;
|
|
|
|
setActive: (state: boolean) => void;
|
|
|
|
}
|
|
|
|
interface ToolbarMenuButtonSpec extends BaseMenuButtonSpec {
|
|
|
|
type?: 'menubutton';
|
|
|
|
onSetup?: (api: ToolbarMenuButtonInstanceApi) => (api: ToolbarMenuButtonInstanceApi) => void;
|
|
|
|
}
|
|
|
|
interface ToolbarMenuButtonInstanceApi extends BaseMenuButtonInstanceApi {
|
|
|
|
}
|
|
|
|
declare type ToolbarSplitButtonItemTypes = ChoiceMenuItemSpec | SeparatorMenuItemSpec;
|
|
|
|
declare type SuccessCallback = (menu: ToolbarSplitButtonItemTypes[]) => void;
|
|
|
|
declare type SelectPredicate = (value: string) => boolean;
|
|
|
|
declare type PresetTypes = 'color' | 'normal' | 'listpreview';
|
|
|
|
declare type ColumnTypes = number | 'auto';
|
|
|
|
interface ToolbarSplitButtonSpec {
|
|
|
|
type?: 'splitbutton';
|
|
|
|
tooltip?: string;
|
|
|
|
icon?: string;
|
|
|
|
text?: string;
|
|
|
|
select?: SelectPredicate;
|
|
|
|
presets?: PresetTypes;
|
|
|
|
columns?: ColumnTypes;
|
|
|
|
fetch: (success: SuccessCallback) => void;
|
|
|
|
onSetup?: (api: ToolbarSplitButtonInstanceApi) => (api: ToolbarSplitButtonInstanceApi) => void;
|
|
|
|
onAction: (api: ToolbarSplitButtonInstanceApi) => void;
|
|
|
|
onItemAction: (api: ToolbarSplitButtonInstanceApi, value: string) => void;
|
|
|
|
}
|
|
|
|
interface ToolbarSplitButtonInstanceApi {
|
2022-07-17 19:33:03 +02:00
|
|
|
isEnabled: () => boolean;
|
|
|
|
setEnabled: (state: boolean) => void;
|
2022-02-05 17:55:53 +01:00
|
|
|
setIconFill: (id: string, value: string) => void;
|
|
|
|
isActive: () => boolean;
|
|
|
|
setActive: (state: boolean) => void;
|
|
|
|
}
|
|
|
|
type PublicToolbar_d_ToolbarButtonSpec = ToolbarButtonSpec;
|
|
|
|
type PublicToolbar_d_ToolbarButtonInstanceApi = ToolbarButtonInstanceApi;
|
|
|
|
type PublicToolbar_d_ToolbarSplitButtonSpec = ToolbarSplitButtonSpec;
|
|
|
|
type PublicToolbar_d_ToolbarSplitButtonInstanceApi = ToolbarSplitButtonInstanceApi;
|
|
|
|
type PublicToolbar_d_ToolbarMenuButtonSpec = ToolbarMenuButtonSpec;
|
|
|
|
type PublicToolbar_d_ToolbarMenuButtonInstanceApi = ToolbarMenuButtonInstanceApi;
|
|
|
|
type PublicToolbar_d_ToolbarToggleButtonSpec = ToolbarToggleButtonSpec;
|
|
|
|
type PublicToolbar_d_ToolbarToggleButtonInstanceApi = ToolbarToggleButtonInstanceApi;
|
|
|
|
type PublicToolbar_d_GroupToolbarButtonSpec = GroupToolbarButtonSpec;
|
|
|
|
type PublicToolbar_d_GroupToolbarButtonInstanceApi = GroupToolbarButtonInstanceApi;
|
|
|
|
declare namespace PublicToolbar_d {
|
|
|
|
export { PublicToolbar_d_ToolbarButtonSpec as ToolbarButtonSpec, PublicToolbar_d_ToolbarButtonInstanceApi as ToolbarButtonInstanceApi, PublicToolbar_d_ToolbarSplitButtonSpec as ToolbarSplitButtonSpec, PublicToolbar_d_ToolbarSplitButtonInstanceApi as ToolbarSplitButtonInstanceApi, PublicToolbar_d_ToolbarMenuButtonSpec as ToolbarMenuButtonSpec, PublicToolbar_d_ToolbarMenuButtonInstanceApi as ToolbarMenuButtonInstanceApi, PublicToolbar_d_ToolbarToggleButtonSpec as ToolbarToggleButtonSpec, PublicToolbar_d_ToolbarToggleButtonInstanceApi as ToolbarToggleButtonInstanceApi, PublicToolbar_d_GroupToolbarButtonSpec as GroupToolbarButtonSpec, PublicToolbar_d_GroupToolbarButtonInstanceApi as GroupToolbarButtonInstanceApi, };
|
|
|
|
}
|
|
|
|
interface Registry$1 {
|
|
|
|
addButton: (name: string, spec: ToolbarButtonSpec) => void;
|
|
|
|
addGroupToolbarButton: (name: string, spec: GroupToolbarButtonSpec) => void;
|
|
|
|
addToggleButton: (name: string, spec: ToolbarToggleButtonSpec) => void;
|
|
|
|
addMenuButton: (name: string, spec: ToolbarMenuButtonSpec) => void;
|
|
|
|
addSplitButton: (name: string, spec: ToolbarSplitButtonSpec) => void;
|
|
|
|
addMenuItem: (name: string, spec: MenuItemSpec) => void;
|
|
|
|
addNestedMenuItem: (name: string, spec: NestedMenuItemSpec) => void;
|
|
|
|
addToggleMenuItem: (name: string, spec: ToggleMenuItemSpec) => void;
|
|
|
|
addContextMenu: (name: string, spec: ContextMenuApi) => void;
|
|
|
|
addContextToolbar: (name: string, spec: ContextToolbarSpec) => void;
|
|
|
|
addContextForm: (name: string, spec: ContextFormSpec) => void;
|
|
|
|
addIcon: (name: string, svgData: string) => void;
|
|
|
|
addAutocompleter: (name: string, spec: AutocompleterSpec) => void;
|
|
|
|
addSidebar: (name: string, spec: SidebarSpec) => void;
|
|
|
|
getAll: () => {
|
|
|
|
buttons: Record<string, ToolbarButtonSpec | GroupToolbarButtonSpec | ToolbarMenuButtonSpec | ToolbarSplitButtonSpec | ToolbarToggleButtonSpec>;
|
|
|
|
menuItems: Record<string, MenuItemSpec | NestedMenuItemSpec | ToggleMenuItemSpec>;
|
|
|
|
popups: Record<string, AutocompleterSpec>;
|
|
|
|
contextMenus: Record<string, ContextMenuApi>;
|
|
|
|
contextToolbars: Record<string, ContextToolbarSpec | ContextFormSpec>;
|
|
|
|
icons: Record<string, string>;
|
|
|
|
sidebars: Record<string, SidebarSpec>;
|
|
|
|
};
|
|
|
|
}
|
2022-07-17 19:33:03 +02:00
|
|
|
interface AutocompleteLookupData {
|
|
|
|
readonly matchText: string;
|
|
|
|
readonly items: AutocompleterContents[];
|
|
|
|
readonly columns: ColumnTypes$1;
|
|
|
|
readonly onAction: (autoApi: AutocompleterInstanceApi, rng: Range, value: string, meta: Record<string, any>) => void;
|
|
|
|
readonly highlightOn: string[];
|
|
|
|
}
|
|
|
|
interface AutocompleterEventArgs {
|
|
|
|
readonly lookupData: AutocompleteLookupData[];
|
|
|
|
}
|
|
|
|
interface RangeLikeObject {
|
|
|
|
startContainer: Node;
|
|
|
|
startOffset: number;
|
|
|
|
endContainer: Node;
|
|
|
|
endOffset: number;
|
|
|
|
}
|
|
|
|
declare type ApplyFormat = BlockFormat | InlineFormat | SelectorFormat;
|
|
|
|
declare type RemoveFormat = RemoveBlockFormat | RemoveInlineFormat | RemoveSelectorFormat;
|
|
|
|
declare type Format = ApplyFormat | RemoveFormat;
|
|
|
|
declare type Formats = Record<string, Format | Format[]>;
|
|
|
|
declare type FormatAttrOrStyleValue = string | ((vars?: FormatVars) => string);
|
|
|
|
declare type FormatVars = Record<string, string | null>;
|
|
|
|
interface BaseFormat<T> {
|
|
|
|
ceFalseOverride?: boolean;
|
|
|
|
classes?: string | string[];
|
|
|
|
collapsed?: boolean;
|
|
|
|
exact?: boolean;
|
|
|
|
expand?: boolean;
|
|
|
|
links?: boolean;
|
|
|
|
mixed?: boolean;
|
|
|
|
block_expand?: boolean;
|
|
|
|
onmatch?: (node: Node, fmt: T, itemName: string) => boolean;
|
|
|
|
remove?: 'none' | 'empty' | 'all';
|
|
|
|
remove_similar?: boolean;
|
|
|
|
split?: boolean;
|
|
|
|
deep?: boolean;
|
|
|
|
preserve_attributes?: string[];
|
|
|
|
}
|
|
|
|
interface Block {
|
|
|
|
block: string;
|
|
|
|
list_block?: string;
|
|
|
|
wrapper?: boolean;
|
|
|
|
}
|
|
|
|
interface Inline {
|
|
|
|
inline: string;
|
|
|
|
}
|
|
|
|
interface Selector {
|
|
|
|
selector: string;
|
|
|
|
inherit?: boolean;
|
|
|
|
}
|
|
|
|
interface CommonFormat<T> extends BaseFormat<T> {
|
|
|
|
attributes?: Record<string, FormatAttrOrStyleValue>;
|
|
|
|
styles?: Record<string, FormatAttrOrStyleValue>;
|
|
|
|
toggle?: boolean;
|
|
|
|
preview?: string | false;
|
|
|
|
onformat?: (elm: Node, fmt: T, vars?: FormatVars, node?: Node | RangeLikeObject) => void;
|
|
|
|
clear_child_styles?: boolean;
|
|
|
|
merge_siblings?: boolean;
|
|
|
|
merge_with_parents?: boolean;
|
|
|
|
}
|
|
|
|
interface BlockFormat extends Block, CommonFormat<BlockFormat> {
|
|
|
|
}
|
|
|
|
interface InlineFormat extends Inline, CommonFormat<InlineFormat> {
|
|
|
|
}
|
|
|
|
interface SelectorFormat extends Selector, CommonFormat<SelectorFormat> {
|
|
|
|
}
|
|
|
|
interface CommonRemoveFormat<T> extends BaseFormat<T> {
|
|
|
|
attributes?: string[] | Record<string, FormatAttrOrStyleValue>;
|
|
|
|
styles?: string[] | Record<string, FormatAttrOrStyleValue>;
|
|
|
|
}
|
|
|
|
interface RemoveBlockFormat extends Block, CommonRemoveFormat<RemoveBlockFormat> {
|
|
|
|
}
|
|
|
|
interface RemoveInlineFormat extends Inline, CommonRemoveFormat<RemoveInlineFormat> {
|
|
|
|
}
|
|
|
|
interface RemoveSelectorFormat extends Selector, CommonRemoveFormat<RemoveSelectorFormat> {
|
|
|
|
}
|
|
|
|
interface Filter<C extends Function> {
|
|
|
|
name: string;
|
|
|
|
callbacks: C[];
|
|
|
|
}
|
|
|
|
interface ParserArgs {
|
|
|
|
getInner?: boolean | number;
|
|
|
|
forced_root_block?: boolean | string;
|
|
|
|
context?: string;
|
|
|
|
isRootContent?: boolean;
|
|
|
|
format?: string;
|
|
|
|
invalid?: boolean;
|
|
|
|
no_events?: boolean;
|
|
|
|
[key: string]: any;
|
|
|
|
}
|
|
|
|
declare type ParserFilterCallback = (nodes: AstNode[], name: string, args: ParserArgs) => void;
|
|
|
|
interface ParserFilter extends Filter<ParserFilterCallback> {
|
|
|
|
}
|
|
|
|
interface DomParserSettings {
|
|
|
|
allow_html_data_urls?: boolean;
|
|
|
|
allow_svg_data_urls?: boolean;
|
|
|
|
allow_conditional_comments?: boolean;
|
|
|
|
allow_html_in_named_anchor?: boolean;
|
|
|
|
allow_script_urls?: boolean;
|
|
|
|
allow_unsafe_link_target?: boolean;
|
|
|
|
convert_fonts_to_spans?: boolean;
|
|
|
|
fix_list_elements?: boolean;
|
|
|
|
font_size_legacy_values?: string;
|
|
|
|
forced_root_block?: boolean | string;
|
|
|
|
forced_root_block_attrs?: Record<string, string>;
|
|
|
|
preserve_cdata?: boolean;
|
|
|
|
remove_trailing_brs?: boolean;
|
|
|
|
root_name?: string;
|
|
|
|
validate?: boolean;
|
|
|
|
inline_styles?: boolean;
|
|
|
|
blob_cache?: BlobCache;
|
|
|
|
document?: Document;
|
|
|
|
}
|
|
|
|
interface DomParser {
|
|
|
|
schema: Schema;
|
|
|
|
addAttributeFilter: (name: string, callback: ParserFilterCallback) => void;
|
|
|
|
getAttributeFilters: () => ParserFilter[];
|
|
|
|
removeAttributeFilter: (name: string, callback?: ParserFilterCallback) => void;
|
|
|
|
addNodeFilter: (name: string, callback: ParserFilterCallback) => void;
|
|
|
|
getNodeFilters: () => ParserFilter[];
|
|
|
|
removeNodeFilter: (name: string, callback?: ParserFilterCallback) => void;
|
|
|
|
parse: (html: string, args?: ParserArgs) => AstNode;
|
|
|
|
}
|
2022-02-05 17:55:53 +01:00
|
|
|
interface StyleSheetLoaderSettings {
|
|
|
|
maxLoadTime?: number;
|
|
|
|
contentCssCors?: boolean;
|
|
|
|
referrerPolicy?: ReferrerPolicy;
|
|
|
|
}
|
|
|
|
interface StyleSheetLoader {
|
2022-07-17 19:33:03 +02:00
|
|
|
load: (url: string) => Promise<void>;
|
|
|
|
loadAll: (urls: string[]) => Promise<string[]>;
|
2022-02-05 17:55:53 +01:00
|
|
|
unload: (url: string) => void;
|
|
|
|
unloadAll: (urls: string[]) => void;
|
|
|
|
_setReferrerPolicy: (referrerPolicy: ReferrerPolicy) => void;
|
|
|
|
}
|
|
|
|
declare type Registry = Registry$1;
|
|
|
|
interface EditorUiApi {
|
|
|
|
show: () => void;
|
|
|
|
hide: () => void;
|
2022-07-17 19:33:03 +02:00
|
|
|
setEnabled: (state: boolean) => void;
|
|
|
|
isEnabled: () => boolean;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
|
|
|
interface EditorUi extends EditorUiApi {
|
|
|
|
registry: Registry;
|
|
|
|
styleSheetLoader: StyleSheetLoader;
|
|
|
|
}
|
|
|
|
type Ui_d_Registry = Registry;
|
|
|
|
type Ui_d_EditorUiApi = EditorUiApi;
|
|
|
|
type Ui_d_EditorUi = EditorUi;
|
|
|
|
declare namespace Ui_d {
|
|
|
|
export { Ui_d_Registry as Registry, PublicDialog_d as Dialog, PublicInlineContent_d as InlineContent, PublicMenu_d as Menu, PublicSidebar_d as Sidebar, PublicToolbar_d as Toolbar, Ui_d_EditorUiApi as EditorUiApi, Ui_d_EditorUi as EditorUi, };
|
|
|
|
}
|
2022-07-17 19:33:03 +02:00
|
|
|
interface WindowParams {
|
|
|
|
readonly inline?: 'cursor' | 'toolbar';
|
|
|
|
readonly ariaAttrs?: boolean;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
2022-07-17 19:33:03 +02:00
|
|
|
declare type InstanceApi<T> = UrlDialogInstanceApi | DialogInstanceApi<T>;
|
|
|
|
interface WindowManagerImpl {
|
|
|
|
open: <T>(config: DialogSpec<T>, params: WindowParams, closeWindow: (dialog: DialogInstanceApi<T>) => void) => DialogInstanceApi<T>;
|
|
|
|
openUrl: (config: UrlDialogSpec, closeWindow: (dialog: UrlDialogInstanceApi) => void) => UrlDialogInstanceApi;
|
|
|
|
alert: (message: string, callback: () => void) => void;
|
|
|
|
confirm: (message: string, callback: (state: boolean) => void) => void;
|
|
|
|
close: (dialog: InstanceApi<any>) => void;
|
|
|
|
}
|
|
|
|
interface WindowManager {
|
|
|
|
open: <T>(config: DialogSpec<T>, params?: WindowParams) => DialogInstanceApi<T>;
|
|
|
|
openUrl: (config: UrlDialogSpec) => UrlDialogInstanceApi;
|
|
|
|
alert: (message: string, callback?: () => void, scope?: any) => void;
|
|
|
|
confirm: (message: string, callback?: (state: boolean) => void, scope?: any) => void;
|
|
|
|
close: () => void;
|
|
|
|
}
|
|
|
|
interface ExecCommandEvent {
|
|
|
|
command: string;
|
|
|
|
ui?: boolean;
|
|
|
|
value?: any;
|
|
|
|
}
|
|
|
|
interface BeforeGetContentEvent extends GetContentArgs {
|
|
|
|
selection?: boolean;
|
|
|
|
}
|
|
|
|
interface GetContentEvent extends BeforeGetContentEvent {
|
|
|
|
content: string;
|
|
|
|
}
|
|
|
|
interface BeforeSetContentEvent extends SetContentArgs {
|
|
|
|
content: string;
|
|
|
|
selection?: boolean;
|
|
|
|
}
|
|
|
|
interface SetContentEvent extends BeforeSetContentEvent {
|
|
|
|
content: string;
|
|
|
|
}
|
|
|
|
interface NewBlockEvent {
|
|
|
|
newBlock: Element;
|
|
|
|
}
|
|
|
|
interface NodeChangeEvent {
|
|
|
|
element: Element;
|
|
|
|
parents: Node[];
|
|
|
|
selectionChange?: boolean;
|
|
|
|
initial?: boolean;
|
|
|
|
}
|
|
|
|
interface FormatEvent {
|
|
|
|
format: string;
|
|
|
|
vars?: FormatVars;
|
|
|
|
node?: Node | RangeLikeObject;
|
|
|
|
}
|
|
|
|
interface ObjectResizeEvent {
|
|
|
|
target: HTMLElement;
|
|
|
|
width: number;
|
|
|
|
height: number;
|
|
|
|
origin: string;
|
|
|
|
}
|
|
|
|
interface ObjectSelectedEvent {
|
|
|
|
target: Node;
|
|
|
|
targetClone?: Node;
|
|
|
|
}
|
|
|
|
interface ScrollIntoViewEvent {
|
|
|
|
elm: HTMLElement;
|
|
|
|
alignToTop: boolean;
|
|
|
|
}
|
|
|
|
interface SetSelectionRangeEvent {
|
|
|
|
range: Range;
|
|
|
|
forward: boolean;
|
|
|
|
}
|
|
|
|
interface ShowCaretEvent {
|
|
|
|
target: Node;
|
|
|
|
direction: number;
|
|
|
|
before: boolean;
|
|
|
|
}
|
|
|
|
interface SwitchModeEvent {
|
|
|
|
mode: string;
|
|
|
|
}
|
|
|
|
interface AddUndoEvent {
|
|
|
|
level: UndoLevel;
|
|
|
|
lastLevel: UndoLevel;
|
|
|
|
originalEvent: Event;
|
|
|
|
}
|
|
|
|
interface UndoRedoEvent {
|
|
|
|
level: UndoLevel;
|
|
|
|
}
|
|
|
|
interface WindowEvent<T extends DialogData> {
|
|
|
|
dialog: InstanceApi<T>;
|
|
|
|
}
|
|
|
|
interface ProgressStateEvent {
|
|
|
|
state: boolean;
|
|
|
|
time?: number;
|
|
|
|
}
|
|
|
|
interface AfterProgressStateEvent {
|
|
|
|
state: boolean;
|
|
|
|
}
|
|
|
|
interface PlaceholderToggleEvent {
|
|
|
|
state: boolean;
|
|
|
|
}
|
|
|
|
interface LoadErrorEvent {
|
2022-02-05 17:55:53 +01:00
|
|
|
message: string;
|
|
|
|
}
|
2022-07-17 19:33:03 +02:00
|
|
|
interface PreProcessEvent extends ParserArgs {
|
|
|
|
node: Element;
|
|
|
|
}
|
|
|
|
interface PostProcessEvent extends ParserArgs {
|
|
|
|
content: string;
|
|
|
|
}
|
|
|
|
interface PastePlainTextToggleEvent {
|
|
|
|
state: boolean;
|
|
|
|
}
|
|
|
|
interface PastePreProcessEvent {
|
|
|
|
content: string;
|
|
|
|
readonly internal: boolean;
|
|
|
|
}
|
|
|
|
interface PastePostProcessEvent {
|
|
|
|
node: HTMLElement;
|
|
|
|
readonly internal: boolean;
|
|
|
|
}
|
|
|
|
interface NewTableRowEvent {
|
|
|
|
node: HTMLTableRowElement;
|
|
|
|
}
|
|
|
|
interface NewTableCellEvent {
|
|
|
|
node: HTMLTableCellElement;
|
|
|
|
}
|
|
|
|
interface TableEventData {
|
|
|
|
readonly structure: boolean;
|
|
|
|
readonly style: boolean;
|
|
|
|
}
|
|
|
|
interface TableModifiedEvent extends TableEventData {
|
|
|
|
readonly table: HTMLTableElement;
|
|
|
|
}
|
|
|
|
interface EditorEventMap extends Omit<NativeEventMap, 'blur' | 'focus'> {
|
|
|
|
'activate': {
|
|
|
|
relatedTarget: Editor;
|
|
|
|
};
|
|
|
|
'deactivate': {
|
|
|
|
relatedTarget: Editor;
|
|
|
|
};
|
|
|
|
'focus': {
|
|
|
|
blurredEditor: Editor;
|
|
|
|
};
|
|
|
|
'blur': {
|
|
|
|
focusedEditor: Editor;
|
|
|
|
};
|
|
|
|
'resize': UIEvent;
|
|
|
|
'scroll': UIEvent;
|
|
|
|
'detach': {};
|
|
|
|
'remove': {};
|
|
|
|
'init': {};
|
|
|
|
'ScrollIntoView': ScrollIntoViewEvent;
|
|
|
|
'AfterScrollIntoView': ScrollIntoViewEvent;
|
|
|
|
'ObjectResized': ObjectResizeEvent;
|
|
|
|
'ObjectResizeStart': ObjectResizeEvent;
|
|
|
|
'SwitchMode': SwitchModeEvent;
|
|
|
|
'ScrollWindow': UIEvent;
|
|
|
|
'ResizeWindow': UIEvent;
|
|
|
|
'SkinLoaded': {};
|
|
|
|
'SkinLoadError': LoadErrorEvent;
|
|
|
|
'PluginLoadError': LoadErrorEvent;
|
|
|
|
'ModelLoadError': LoadErrorEvent;
|
|
|
|
'IconsLoadError': LoadErrorEvent;
|
|
|
|
'ThemeLoadError': LoadErrorEvent;
|
|
|
|
'LanguageLoadError': LoadErrorEvent;
|
|
|
|
'BeforeExecCommand': ExecCommandEvent;
|
|
|
|
'ExecCommand': ExecCommandEvent;
|
|
|
|
'NodeChange': NodeChangeEvent;
|
|
|
|
'FormatApply': FormatEvent;
|
|
|
|
'FormatRemove': FormatEvent;
|
|
|
|
'ShowCaret': ShowCaretEvent;
|
|
|
|
'SelectionChange': {};
|
|
|
|
'ObjectSelected': ObjectSelectedEvent;
|
|
|
|
'BeforeObjectSelected': ObjectSelectedEvent;
|
|
|
|
'GetSelectionRange': {
|
|
|
|
range: Range;
|
|
|
|
};
|
|
|
|
'SetSelectionRange': SetSelectionRangeEvent;
|
|
|
|
'AfterSetSelectionRange': SetSelectionRangeEvent;
|
|
|
|
'BeforeGetContent': BeforeGetContentEvent;
|
|
|
|
'GetContent': GetContentEvent;
|
|
|
|
'BeforeSetContent': BeforeSetContentEvent;
|
|
|
|
'SetContent': SetContentEvent;
|
|
|
|
'LoadContent': {};
|
|
|
|
'PreviewFormats': {};
|
|
|
|
'AfterPreviewFormats': {};
|
|
|
|
'ScriptsLoaded': {};
|
|
|
|
'PreInit': {};
|
|
|
|
'PostRender': {};
|
|
|
|
'NewBlock': NewBlockEvent;
|
|
|
|
'ClearUndos': {};
|
|
|
|
'TypingUndo': {};
|
|
|
|
'Redo': UndoRedoEvent;
|
|
|
|
'Undo': UndoRedoEvent;
|
|
|
|
'BeforeAddUndo': AddUndoEvent;
|
|
|
|
'AddUndo': AddUndoEvent;
|
|
|
|
'CloseWindow': WindowEvent<any>;
|
|
|
|
'OpenWindow': WindowEvent<any>;
|
|
|
|
'ProgressState': ProgressStateEvent;
|
|
|
|
'AfterProgressState': AfterProgressStateEvent;
|
|
|
|
'PlaceholderToggle': PlaceholderToggleEvent;
|
|
|
|
'tap': TouchEvent;
|
|
|
|
'longpress': TouchEvent;
|
|
|
|
'longpresscancel': {};
|
|
|
|
'PreProcess': PreProcessEvent;
|
|
|
|
'PostProcess': PostProcessEvent;
|
|
|
|
'AutocompleterStart': AutocompleterEventArgs;
|
|
|
|
'AutocompleterUpdate': AutocompleterEventArgs;
|
|
|
|
'AutocompleterEnd': {};
|
|
|
|
'PastePlainTextToggle': PastePlainTextToggleEvent;
|
|
|
|
'PastePreProcess': PastePreProcessEvent;
|
|
|
|
'PastePostProcess': PastePostProcessEvent;
|
|
|
|
'TableModified': TableModifiedEvent;
|
|
|
|
'NewRow': NewTableRowEvent;
|
|
|
|
'NewCell': NewTableCellEvent;
|
|
|
|
}
|
|
|
|
interface EditorManagerEventMap {
|
|
|
|
'AddEditor': {
|
|
|
|
editor: Editor;
|
|
|
|
};
|
|
|
|
'RemoveEditor': {
|
|
|
|
editor: Editor;
|
|
|
|
};
|
|
|
|
'BeforeUnload': {
|
|
|
|
returnValue: any;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
type EventTypes_d_ExecCommandEvent = ExecCommandEvent;
|
|
|
|
type EventTypes_d_BeforeGetContentEvent = BeforeGetContentEvent;
|
|
|
|
type EventTypes_d_GetContentEvent = GetContentEvent;
|
|
|
|
type EventTypes_d_BeforeSetContentEvent = BeforeSetContentEvent;
|
|
|
|
type EventTypes_d_SetContentEvent = SetContentEvent;
|
|
|
|
type EventTypes_d_NewBlockEvent = NewBlockEvent;
|
|
|
|
type EventTypes_d_NodeChangeEvent = NodeChangeEvent;
|
|
|
|
type EventTypes_d_FormatEvent = FormatEvent;
|
|
|
|
type EventTypes_d_ObjectResizeEvent = ObjectResizeEvent;
|
|
|
|
type EventTypes_d_ObjectSelectedEvent = ObjectSelectedEvent;
|
|
|
|
type EventTypes_d_ScrollIntoViewEvent = ScrollIntoViewEvent;
|
|
|
|
type EventTypes_d_SetSelectionRangeEvent = SetSelectionRangeEvent;
|
|
|
|
type EventTypes_d_ShowCaretEvent = ShowCaretEvent;
|
|
|
|
type EventTypes_d_SwitchModeEvent = SwitchModeEvent;
|
|
|
|
type EventTypes_d_AddUndoEvent = AddUndoEvent;
|
|
|
|
type EventTypes_d_UndoRedoEvent = UndoRedoEvent;
|
|
|
|
type EventTypes_d_WindowEvent<_0> = WindowEvent<_0>;
|
|
|
|
type EventTypes_d_ProgressStateEvent = ProgressStateEvent;
|
|
|
|
type EventTypes_d_AfterProgressStateEvent = AfterProgressStateEvent;
|
|
|
|
type EventTypes_d_PlaceholderToggleEvent = PlaceholderToggleEvent;
|
|
|
|
type EventTypes_d_LoadErrorEvent = LoadErrorEvent;
|
|
|
|
type EventTypes_d_PreProcessEvent = PreProcessEvent;
|
|
|
|
type EventTypes_d_PostProcessEvent = PostProcessEvent;
|
|
|
|
type EventTypes_d_PastePlainTextToggleEvent = PastePlainTextToggleEvent;
|
|
|
|
type EventTypes_d_PastePreProcessEvent = PastePreProcessEvent;
|
|
|
|
type EventTypes_d_PastePostProcessEvent = PastePostProcessEvent;
|
|
|
|
type EventTypes_d_NewTableRowEvent = NewTableRowEvent;
|
|
|
|
type EventTypes_d_NewTableCellEvent = NewTableCellEvent;
|
|
|
|
type EventTypes_d_TableEventData = TableEventData;
|
|
|
|
type EventTypes_d_TableModifiedEvent = TableModifiedEvent;
|
|
|
|
type EventTypes_d_EditorEventMap = EditorEventMap;
|
|
|
|
type EventTypes_d_EditorManagerEventMap = EditorManagerEventMap;
|
|
|
|
declare namespace EventTypes_d {
|
|
|
|
export { EventTypes_d_ExecCommandEvent as ExecCommandEvent, EventTypes_d_BeforeGetContentEvent as BeforeGetContentEvent, EventTypes_d_GetContentEvent as GetContentEvent, EventTypes_d_BeforeSetContentEvent as BeforeSetContentEvent, EventTypes_d_SetContentEvent as SetContentEvent, EventTypes_d_NewBlockEvent as NewBlockEvent, EventTypes_d_NodeChangeEvent as NodeChangeEvent, EventTypes_d_FormatEvent as FormatEvent, EventTypes_d_ObjectResizeEvent as ObjectResizeEvent, EventTypes_d_ObjectSelectedEvent as ObjectSelectedEvent, EventTypes_d_ScrollIntoViewEvent as ScrollIntoViewEvent, EventTypes_d_SetSelectionRangeEvent as SetSelectionRangeEvent, EventTypes_d_ShowCaretEvent as ShowCaretEvent, EventTypes_d_SwitchModeEvent as SwitchModeEvent, EventTypes_d_AddUndoEvent as AddUndoEvent, EventTypes_d_UndoRedoEvent as UndoRedoEvent, EventTypes_d_WindowEvent as WindowEvent, EventTypes_d_ProgressStateEvent as ProgressStateEvent, EventTypes_d_AfterProgressStateEvent as AfterProgressStateEvent, EventTypes_d_PlaceholderToggleEvent as PlaceholderToggleEvent, EventTypes_d_LoadErrorEvent as LoadErrorEvent, EventTypes_d_PreProcessEvent as PreProcessEvent, EventTypes_d_PostProcessEvent as PostProcessEvent, EventTypes_d_PastePlainTextToggleEvent as PastePlainTextToggleEvent, EventTypes_d_PastePreProcessEvent as PastePreProcessEvent, EventTypes_d_PastePostProcessEvent as PastePostProcessEvent, EventTypes_d_NewTableRowEvent as NewTableRowEvent, EventTypes_d_NewTableCellEvent as NewTableCellEvent, EventTypes_d_TableEventData as TableEventData, EventTypes_d_TableModifiedEvent as TableModifiedEvent, EventTypes_d_EditorEventMap as EditorEventMap, EventTypes_d_EditorManagerEventMap as EditorManagerEventMap, };
|
|
|
|
}
|
|
|
|
type Format_d_Formats = Formats;
|
|
|
|
type Format_d_Format = Format;
|
|
|
|
type Format_d_ApplyFormat = ApplyFormat;
|
|
|
|
type Format_d_BlockFormat = BlockFormat;
|
|
|
|
type Format_d_InlineFormat = InlineFormat;
|
|
|
|
type Format_d_SelectorFormat = SelectorFormat;
|
|
|
|
type Format_d_RemoveFormat = RemoveFormat;
|
|
|
|
type Format_d_RemoveBlockFormat = RemoveBlockFormat;
|
|
|
|
type Format_d_RemoveInlineFormat = RemoveInlineFormat;
|
|
|
|
type Format_d_RemoveSelectorFormat = RemoveSelectorFormat;
|
|
|
|
declare namespace Format_d {
|
|
|
|
export { Format_d_Formats as Formats, Format_d_Format as Format, Format_d_ApplyFormat as ApplyFormat, Format_d_BlockFormat as BlockFormat, Format_d_InlineFormat as InlineFormat, Format_d_SelectorFormat as SelectorFormat, Format_d_RemoveFormat as RemoveFormat, Format_d_RemoveBlockFormat as RemoveBlockFormat, Format_d_RemoveInlineFormat as RemoveInlineFormat, Format_d_RemoveSelectorFormat as RemoveSelectorFormat, };
|
|
|
|
}
|
|
|
|
declare type StyleFormat = BlockStyleFormat | InlineStyleFormat | SelectorStyleFormat;
|
|
|
|
declare type AllowedFormat = Separator | FormatReference | StyleFormat | NestedFormatting;
|
|
|
|
interface Separator {
|
|
|
|
title: string;
|
|
|
|
}
|
|
|
|
interface FormatReference {
|
|
|
|
title: string;
|
|
|
|
format: string;
|
|
|
|
icon?: string;
|
|
|
|
}
|
|
|
|
interface NestedFormatting {
|
|
|
|
title: string;
|
|
|
|
items: Array<FormatReference | StyleFormat>;
|
|
|
|
}
|
|
|
|
interface CommonStyleFormat {
|
|
|
|
name?: string;
|
|
|
|
title: string;
|
|
|
|
icon?: string;
|
|
|
|
}
|
|
|
|
interface BlockStyleFormat extends BlockFormat, CommonStyleFormat {
|
|
|
|
}
|
|
|
|
interface InlineStyleFormat extends InlineFormat, CommonStyleFormat {
|
|
|
|
}
|
|
|
|
interface SelectorStyleFormat extends SelectorFormat, CommonStyleFormat {
|
|
|
|
}
|
|
|
|
declare type EntityEncoding = 'named' | 'numeric' | 'raw' | 'named,numeric' | 'named+numeric' | 'numeric,named' | 'numeric+named';
|
|
|
|
interface ContentLanguage {
|
|
|
|
readonly title: string;
|
|
|
|
readonly code: string;
|
|
|
|
readonly customCode?: string;
|
|
|
|
}
|
|
|
|
declare type ThemeInitFunc = (editor: Editor, elm: HTMLElement) => {
|
|
|
|
editorContainer: HTMLElement;
|
|
|
|
iframeContainer: HTMLElement;
|
|
|
|
height?: number;
|
|
|
|
iframeHeight?: number;
|
|
|
|
api?: EditorUiApi;
|
|
|
|
};
|
|
|
|
declare type SetupCallback = (editor: Editor) => void;
|
|
|
|
declare type FilePickerCallback = (callback: Function, value: any, meta: Record<string, any>) => void;
|
|
|
|
declare type FilePickerValidationStatus = 'valid' | 'unknown' | 'invalid' | 'none';
|
|
|
|
declare type FilePickerValidationCallback = (info: {
|
|
|
|
type: string;
|
|
|
|
url: string;
|
|
|
|
}, callback: (validation: {
|
|
|
|
status: FilePickerValidationStatus;
|
|
|
|
message: string;
|
|
|
|
}) => void) => void;
|
|
|
|
declare type PastePreProcessFn = (editor: Editor, args: PastePreProcessEvent) => void;
|
|
|
|
declare type PastePostProcessFn = (editor: Editor, args: PastePostProcessEvent) => void;
|
|
|
|
declare type URLConverter = (url: string, name: string, elm?: HTMLElement) => string;
|
|
|
|
declare type URLConverterCallback = (url: string, node: Node, on_save: boolean, name: string) => string;
|
|
|
|
interface ToolbarGroup {
|
|
|
|
name?: string;
|
|
|
|
items: string[];
|
|
|
|
}
|
|
|
|
declare type ToolbarMode = 'floating' | 'sliding' | 'scrolling' | 'wrap';
|
|
|
|
interface BaseEditorOptions {
|
|
|
|
a11y_advanced_options?: boolean;
|
|
|
|
add_form_submit_trigger?: boolean;
|
|
|
|
add_unload_trigger?: boolean;
|
|
|
|
allow_conditional_comments?: boolean;
|
|
|
|
allow_html_data_urls?: boolean;
|
|
|
|
allow_html_in_named_anchor?: boolean;
|
|
|
|
allow_script_urls?: boolean;
|
|
|
|
allow_svg_data_urls?: boolean;
|
|
|
|
allow_unsafe_link_target?: boolean;
|
|
|
|
anchor_bottom?: false | string;
|
|
|
|
anchor_top?: false | string;
|
|
|
|
auto_focus?: string | true;
|
|
|
|
automatic_uploads?: boolean;
|
|
|
|
base_url?: string;
|
|
|
|
block_formats?: string;
|
|
|
|
block_unsupported_drop?: boolean;
|
|
|
|
body_id?: string;
|
|
|
|
body_class?: string;
|
2022-02-05 17:55:53 +01:00
|
|
|
br_in_pre?: boolean;
|
|
|
|
br_newline_selector?: string;
|
|
|
|
browser_spellcheck?: boolean;
|
|
|
|
branding?: boolean;
|
|
|
|
cache_suffix?: string;
|
|
|
|
color_cols?: number;
|
|
|
|
color_map?: string[];
|
|
|
|
content_css?: boolean | string | string[];
|
|
|
|
content_css_cors?: boolean;
|
|
|
|
content_security_policy?: string;
|
|
|
|
content_style?: string;
|
|
|
|
content_langs?: ContentLanguage[];
|
2022-07-17 19:33:03 +02:00
|
|
|
contextmenu?: string | string[] | false;
|
2022-02-05 17:55:53 +01:00
|
|
|
contextmenu_never_use_native?: boolean;
|
|
|
|
convert_fonts_to_spans?: boolean;
|
|
|
|
convert_urls?: boolean;
|
|
|
|
custom_colors?: boolean;
|
|
|
|
custom_elements?: string;
|
|
|
|
custom_ui_selector?: string;
|
|
|
|
custom_undo_redo_levels?: number;
|
2022-07-17 19:33:03 +02:00
|
|
|
deprecation_warnings?: boolean;
|
2022-02-05 17:55:53 +01:00
|
|
|
directionality?: 'ltr' | 'rtl';
|
|
|
|
doctype?: string;
|
|
|
|
document_base_url?: string;
|
2022-07-17 19:33:03 +02:00
|
|
|
editable_class?: string;
|
2022-02-05 17:55:53 +01:00
|
|
|
element_format?: 'xhtml' | 'html';
|
|
|
|
elementpath?: boolean;
|
|
|
|
encoding?: string;
|
2022-07-17 19:33:03 +02:00
|
|
|
end_container_on_empty_block?: boolean | string;
|
2022-02-05 17:55:53 +01:00
|
|
|
entities?: string;
|
|
|
|
entity_encoding?: EntityEncoding;
|
|
|
|
extended_valid_elements?: string;
|
|
|
|
event_root?: string;
|
|
|
|
file_picker_callback?: FilePickerCallback;
|
|
|
|
file_picker_types?: string;
|
|
|
|
file_picker_validator_handler?: FilePickerValidationCallback;
|
|
|
|
fix_list_elements?: boolean;
|
|
|
|
fixed_toolbar_container?: string;
|
|
|
|
fixed_toolbar_container_target?: HTMLElement;
|
2022-07-17 19:33:03 +02:00
|
|
|
font_css?: string | string[];
|
|
|
|
font_family_formats?: string;
|
2022-02-05 17:55:53 +01:00
|
|
|
font_size_classes?: string;
|
|
|
|
font_size_legacy_values?: string;
|
|
|
|
font_size_style_values?: string;
|
2022-07-17 19:33:03 +02:00
|
|
|
font_size_formats?: string;
|
|
|
|
forced_root_block?: string;
|
2022-02-05 17:55:53 +01:00
|
|
|
forced_root_block_attrs?: Record<string, string>;
|
|
|
|
formats?: Formats;
|
|
|
|
height?: number | string;
|
|
|
|
hidden_input?: boolean;
|
|
|
|
icons?: string;
|
|
|
|
icons_url?: string;
|
|
|
|
id?: string;
|
|
|
|
iframe_aria_text?: string;
|
2022-07-17 19:33:03 +02:00
|
|
|
iframe_attrs?: Record<string, string>;
|
2022-02-05 17:55:53 +01:00
|
|
|
images_file_types?: string;
|
|
|
|
images_replace_blob_uris?: boolean;
|
|
|
|
images_reuse_filename?: boolean;
|
|
|
|
images_upload_base_path?: string;
|
|
|
|
images_upload_credentials?: boolean;
|
|
|
|
images_upload_handler?: UploadHandler;
|
|
|
|
images_upload_url?: string;
|
|
|
|
indent?: boolean;
|
|
|
|
indent_after?: string;
|
|
|
|
indent_before?: string;
|
|
|
|
indent_use_margin?: boolean;
|
|
|
|
indentation?: string;
|
|
|
|
init_instance_callback?: SetupCallback;
|
|
|
|
inline?: boolean;
|
|
|
|
inline_boundaries?: boolean;
|
|
|
|
inline_boundaries_selector?: string;
|
|
|
|
inline_styles?: boolean;
|
|
|
|
invalid_elements?: string;
|
|
|
|
invalid_styles?: string | Record<string, string>;
|
|
|
|
keep_styles?: boolean;
|
|
|
|
language?: string;
|
|
|
|
language_load?: boolean;
|
|
|
|
language_url?: string;
|
2022-07-17 19:33:03 +02:00
|
|
|
line_height_formats?: string;
|
2022-02-05 17:55:53 +01:00
|
|
|
max_height?: number;
|
|
|
|
max_width?: number;
|
|
|
|
menu?: Record<string, {
|
|
|
|
title: string;
|
|
|
|
items: string;
|
|
|
|
}>;
|
|
|
|
menubar?: boolean | string;
|
|
|
|
min_height?: number;
|
|
|
|
min_width?: number;
|
2022-07-17 19:33:03 +02:00
|
|
|
model?: string;
|
|
|
|
model_url?: string;
|
|
|
|
newline_behavior?: 'block' | 'linebreak' | 'invert' | 'default';
|
2022-02-05 17:55:53 +01:00
|
|
|
no_newline_selector?: string;
|
2022-07-17 19:33:03 +02:00
|
|
|
noneditable_class?: string;
|
|
|
|
noneditable_regexp?: RegExp | RegExp[];
|
2022-02-05 17:55:53 +01:00
|
|
|
nowrap?: boolean;
|
|
|
|
object_resizing?: boolean | string;
|
2022-07-17 19:33:03 +02:00
|
|
|
paste_as_text?: boolean;
|
|
|
|
paste_block_drop?: boolean;
|
|
|
|
paste_data_images?: boolean;
|
|
|
|
paste_merge_formats?: boolean;
|
|
|
|
paste_postprocess?: PastePostProcessFn;
|
|
|
|
paste_preprocess?: PastePreProcessFn;
|
|
|
|
paste_remove_styles_if_webkit?: boolean;
|
|
|
|
paste_tab_spaces?: number;
|
|
|
|
paste_webkit_styles?: string;
|
2022-02-05 17:55:53 +01:00
|
|
|
placeholder?: string;
|
|
|
|
preserve_cdata?: boolean;
|
2022-07-17 19:33:03 +02:00
|
|
|
preview_styles?: false | string;
|
2022-02-05 17:55:53 +01:00
|
|
|
protect?: RegExp[];
|
|
|
|
readonly?: boolean;
|
|
|
|
referrer_policy?: ReferrerPolicy;
|
|
|
|
relative_urls?: boolean;
|
|
|
|
remove_script_host?: boolean;
|
|
|
|
remove_trailing_brs?: boolean;
|
|
|
|
removed_menuitems?: string;
|
|
|
|
resize?: boolean | 'both';
|
|
|
|
resize_img_proportional?: boolean;
|
|
|
|
root_name?: string;
|
|
|
|
schema?: SchemaType;
|
|
|
|
selector?: string;
|
|
|
|
setup?: SetupCallback;
|
2022-07-17 19:33:03 +02:00
|
|
|
sidebar_show?: string;
|
2022-02-05 17:55:53 +01:00
|
|
|
skin?: boolean | string;
|
|
|
|
skin_url?: string;
|
2022-07-17 19:33:03 +02:00
|
|
|
smart_paste?: boolean;
|
2022-02-05 17:55:53 +01:00
|
|
|
statusbar?: boolean;
|
|
|
|
style_formats?: AllowedFormat[];
|
|
|
|
style_formats_autohide?: boolean;
|
|
|
|
style_formats_merge?: boolean;
|
|
|
|
submit_patch?: boolean;
|
|
|
|
suffix?: string;
|
2022-07-17 19:33:03 +02:00
|
|
|
table_tab_navigation?: boolean;
|
2022-02-05 17:55:53 +01:00
|
|
|
target?: HTMLElement;
|
2022-07-17 19:33:03 +02:00
|
|
|
text_patterns?: RawPattern[] | false;
|
|
|
|
theme?: string | ThemeInitFunc | false;
|
2022-02-05 17:55:53 +01:00
|
|
|
theme_url?: string;
|
|
|
|
toolbar?: boolean | string | string[] | Array<ToolbarGroup>;
|
|
|
|
toolbar1?: string;
|
|
|
|
toolbar2?: string;
|
|
|
|
toolbar3?: string;
|
|
|
|
toolbar4?: string;
|
|
|
|
toolbar5?: string;
|
|
|
|
toolbar6?: string;
|
|
|
|
toolbar7?: string;
|
|
|
|
toolbar8?: string;
|
|
|
|
toolbar9?: string;
|
|
|
|
toolbar_mode?: ToolbarMode;
|
2022-07-17 19:33:03 +02:00
|
|
|
toolbar_sticky?: boolean;
|
|
|
|
toolbar_sticky_offset?: number;
|
2022-02-05 17:55:53 +01:00
|
|
|
typeahead_urls?: boolean;
|
|
|
|
url_converter?: URLConverter;
|
|
|
|
url_converter_scope?: any;
|
2022-07-17 19:33:03 +02:00
|
|
|
urlconverter_callback?: URLConverterCallback;
|
2022-02-05 17:55:53 +01:00
|
|
|
valid_children?: string;
|
|
|
|
valid_classes?: string | Record<string, string>;
|
|
|
|
valid_elements?: string;
|
|
|
|
valid_styles?: string | Record<string, string>;
|
|
|
|
verify_html?: boolean;
|
|
|
|
visual?: boolean;
|
|
|
|
visual_anchor_class?: string;
|
|
|
|
visual_table_class?: string;
|
|
|
|
width?: number | string;
|
|
|
|
disable_nodechange?: boolean;
|
|
|
|
forced_plugins?: string | string[];
|
|
|
|
plugin_base_urls?: Record<string, string>;
|
|
|
|
service_message?: string;
|
2022-07-17 19:33:03 +02:00
|
|
|
[key: string]: any;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
2022-07-17 19:33:03 +02:00
|
|
|
interface RawEditorOptions extends BaseEditorOptions {
|
|
|
|
external_plugins?: Record<string, string>;
|
|
|
|
mobile?: RawEditorOptions;
|
|
|
|
plugins?: string | string[];
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
2022-07-17 19:33:03 +02:00
|
|
|
interface NormalizedEditorOptions extends BaseEditorOptions {
|
|
|
|
external_plugins: Record<string, string>;
|
|
|
|
forced_plugins: string[];
|
|
|
|
plugins: string[];
|
|
|
|
}
|
|
|
|
interface EditorOptions extends NormalizedEditorOptions {
|
|
|
|
content_css: string[];
|
|
|
|
contextmenu: string[];
|
|
|
|
font_css: string[];
|
|
|
|
forced_root_block: string;
|
|
|
|
forced_root_block_attrs: Record<string, string>;
|
|
|
|
noneditable_regexp: RegExp[];
|
|
|
|
object_resizing?: string;
|
|
|
|
preview_styles?: string;
|
|
|
|
text_patterns?: Pattern[];
|
|
|
|
}
|
|
|
|
declare type StyleMap = Record<string, string | number>;
|
2022-02-05 17:55:53 +01:00
|
|
|
interface StylesSettings {
|
|
|
|
allow_script_urls?: boolean;
|
|
|
|
allow_svg_data_urls?: boolean;
|
|
|
|
url_converter?: URLConverter;
|
|
|
|
url_converter_scope?: any;
|
|
|
|
}
|
|
|
|
interface Styles {
|
|
|
|
parse: (css: string) => Record<string, string>;
|
|
|
|
serialize: (styles: StyleMap, elementName?: string) => string;
|
|
|
|
}
|
2022-07-17 19:33:03 +02:00
|
|
|
declare type EventUtilsCallback<T> = (event: EventUtilsEvent<T>) => void;
|
|
|
|
declare type EventUtilsEvent<T> = NormalizedEvent<T> & {
|
|
|
|
metaKey: boolean;
|
|
|
|
};
|
|
|
|
interface EventUtilsConstructor {
|
|
|
|
readonly prototype: EventUtils;
|
|
|
|
new (): EventUtils;
|
|
|
|
Event: EventUtils;
|
|
|
|
}
|
|
|
|
declare class EventUtils {
|
|
|
|
static Event: EventUtils;
|
|
|
|
domLoaded: boolean;
|
|
|
|
events: Record<string, any>;
|
|
|
|
private readonly expando;
|
|
|
|
private hasFocusIn;
|
|
|
|
private hasMouseEnterLeave;
|
|
|
|
private mouseEnterLeave;
|
|
|
|
private count;
|
|
|
|
constructor();
|
|
|
|
bind<K extends keyof HTMLElementEventMap>(target: any, name: K, callback: EventUtilsCallback<HTMLElementEventMap[K]>, scope?: any): EventUtilsCallback<HTMLElementEventMap[K]>;
|
|
|
|
bind<T = any>(target: any, names: string, callback: EventUtilsCallback<T>, scope?: any): EventUtilsCallback<T>;
|
|
|
|
unbind<K extends keyof HTMLElementEventMap>(target: any, name: K, callback?: EventUtilsCallback<HTMLElementEventMap[K]>): this;
|
|
|
|
unbind<T = any>(target: any, names: string, callback?: EventUtilsCallback<T>): this;
|
|
|
|
unbind(target: any): this;
|
|
|
|
fire(target: any, name: string, args?: {}): this;
|
|
|
|
dispatch(target: any, name: string, args?: {}): this;
|
|
|
|
clean(target: any): this;
|
|
|
|
destroy(): void;
|
|
|
|
cancel<T = any>(e: EventUtilsEvent<T>): boolean;
|
|
|
|
private executeHandlers;
|
|
|
|
}
|
2022-02-05 17:55:53 +01:00
|
|
|
interface DOMUtilsSettings {
|
|
|
|
schema: Schema;
|
|
|
|
url_converter: URLConverter;
|
|
|
|
url_converter_scope: any;
|
|
|
|
ownEvents: boolean;
|
|
|
|
keep_values: boolean;
|
|
|
|
update_styles: boolean;
|
|
|
|
root_element: HTMLElement;
|
|
|
|
collect: Function;
|
|
|
|
onSetAttrib: Function;
|
|
|
|
contentCssCors: boolean;
|
|
|
|
referrerPolicy: ReferrerPolicy;
|
|
|
|
}
|
|
|
|
declare type Target = Node | Window;
|
|
|
|
declare type RunArguments<T extends Node = Node> = string | T | Array<string | T>;
|
|
|
|
declare type BoundEvent = [
|
|
|
|
Target,
|
|
|
|
string,
|
|
|
|
EventUtilsCallback<any>,
|
|
|
|
any
|
|
|
|
];
|
|
|
|
declare type Callback<K extends string> = EventUtilsCallback<MappedEvent<HTMLElementEventMap, K>>;
|
2022-07-17 19:33:03 +02:00
|
|
|
declare type RunResult<T, R> = T extends Array<any> ? false | R[] : false | R;
|
2022-02-05 17:55:53 +01:00
|
|
|
interface DOMUtils {
|
|
|
|
doc: Document;
|
|
|
|
settings: Partial<DOMUtilsSettings>;
|
|
|
|
win: Window;
|
|
|
|
files: Record<string, boolean>;
|
|
|
|
stdMode: boolean;
|
|
|
|
boxModel: boolean;
|
|
|
|
styleSheetLoader: StyleSheetLoader;
|
|
|
|
boundEvents: BoundEvent[];
|
|
|
|
styles: Styles;
|
|
|
|
schema: Schema;
|
|
|
|
events: EventUtils;
|
|
|
|
root: Node;
|
|
|
|
isBlock: (node: string | Node) => boolean;
|
|
|
|
clone: (node: Node, deep: boolean) => Node;
|
|
|
|
getRoot: () => HTMLElement;
|
|
|
|
getViewPort: (argWin?: Window) => GeomRect;
|
|
|
|
getRect: (elm: string | HTMLElement) => GeomRect;
|
|
|
|
getSize: (elm: string | HTMLElement) => {
|
|
|
|
w: number;
|
|
|
|
h: number;
|
|
|
|
};
|
|
|
|
getParent: {
|
|
|
|
<K extends keyof HTMLElementTagNameMap>(node: string | Node, selector: K, root?: Node): HTMLElementTagNameMap[K] | null;
|
|
|
|
<T extends HTMLElement>(node: string | Node, selector: (node: HTMLElement) => node is T, root?: Node): T | null;
|
|
|
|
<T extends Element = Element>(node: string | Node, selector?: string | ((node: HTMLElement) => boolean | void), root?: Node): T | null;
|
|
|
|
};
|
|
|
|
getParents: {
|
|
|
|
<K extends keyof HTMLElementTagNameMap>(elm: string | Node, selector: K, root?: Node, collect?: boolean): Array<HTMLElementTagNameMap[K]>;
|
|
|
|
<T extends HTMLElement>(node: string | Node, selector: (node: HTMLElement) => node is T, root?: Node): T[];
|
|
|
|
<T extends Element = Element>(elm: string | Node, selector?: string | ((node: HTMLElement) => boolean | void), root?: Node, collect?: boolean): T[];
|
|
|
|
};
|
|
|
|
get: (elm: string | Node) => HTMLElement | null;
|
|
|
|
getNext: (node: Node, selector: string | ((node: Node) => boolean)) => Node | null;
|
|
|
|
getPrev: (node: Node, selector: string | ((node: Node) => boolean)) => Node | null;
|
|
|
|
select: {
|
|
|
|
<K extends keyof HTMLElementTagNameMap>(selector: K, scope?: string | Node): Array<HTMLElementTagNameMap[K]>;
|
|
|
|
<T extends HTMLElement = HTMLElement>(selector: string, scope?: string | Node): T[];
|
|
|
|
};
|
|
|
|
is: (elm: Node | Node[], selector: string) => boolean;
|
|
|
|
add: (parentElm: RunArguments, name: string | Node, attrs?: Record<string, string | boolean | number>, html?: string | Node, create?: boolean) => HTMLElement;
|
|
|
|
create: {
|
|
|
|
<K extends keyof HTMLElementTagNameMap>(name: K, attrs?: Record<string, string | boolean | number>, html?: string | Node): HTMLElementTagNameMap[K];
|
|
|
|
(name: string, attrs?: Record<string, string | boolean | number>, html?: string | Node): HTMLElement;
|
|
|
|
};
|
|
|
|
createHTML: (name: string, attrs?: Record<string, string>, html?: string) => string;
|
|
|
|
createFragment: (html?: string) => DocumentFragment;
|
2022-07-17 19:33:03 +02:00
|
|
|
remove: <T extends Node>(node: string | T | T[], keepChildren?: boolean) => RunResult<typeof node, T>;
|
|
|
|
setStyle: (elm: string | Node | Node[], name: string, value: string | number | null) => void;
|
|
|
|
getStyle: (elm: string | Node, name: string, computed?: boolean) => string | undefined;
|
2022-02-05 17:55:53 +01:00
|
|
|
setStyles: (elm: string | Node | Node[], stylesArg: StyleMap) => void;
|
|
|
|
removeAllAttribs: (e: RunArguments<Element>) => void;
|
|
|
|
setAttrib: (elm: string | Node | Node[], name: string, value: string | boolean | number | null) => void;
|
|
|
|
setAttribs: (elm: string | Node | Node[], attrs: Record<string, string | boolean | number | null>) => void;
|
|
|
|
getAttrib: (elm: string | Node, name: string, defaultVal?: string) => string;
|
|
|
|
getPos: (elm: string | Node, rootElm?: Node) => {
|
|
|
|
x: number;
|
|
|
|
y: number;
|
|
|
|
};
|
|
|
|
parseStyle: (cssText: string) => Record<string, string>;
|
|
|
|
serializeStyle: (stylesArg: StyleMap, name?: string) => string;
|
|
|
|
addStyle: (cssText: string) => void;
|
|
|
|
loadCSS: (url: string) => void;
|
|
|
|
addClass: (elm: string | Node | Node[], cls: string) => void;
|
|
|
|
removeClass: (elm: string | Node | Node[], cls: string) => void;
|
|
|
|
hasClass: (elm: string | Node, cls: string) => boolean;
|
|
|
|
toggleClass: (elm: string | Node | Node[], cls: string, state?: boolean) => void;
|
|
|
|
show: (elm: string | Node | Node[]) => void;
|
|
|
|
hide: (elm: string | Node | Node[]) => void;
|
|
|
|
isHidden: (elm: string | Node) => boolean;
|
|
|
|
uniqueId: (prefix?: string) => string;
|
|
|
|
setHTML: (elm: string | Node | Node[], html: string) => void;
|
|
|
|
getOuterHTML: (elm: string | Node) => string;
|
|
|
|
setOuterHTML: (elm: string | Node | Node[], html: string) => void;
|
|
|
|
decode: (text: string) => string;
|
|
|
|
encode: (text: string) => string;
|
|
|
|
insertAfter: {
|
|
|
|
<T extends Node>(node: T | T[], reference: string | Node): T;
|
2022-07-17 19:33:03 +02:00
|
|
|
<T extends Node>(node: RunArguments<T>, reference: string | Node): RunResult<typeof node, T>;
|
2022-02-05 17:55:53 +01:00
|
|
|
};
|
|
|
|
replace: {
|
|
|
|
<T extends Node>(newElm: Node, oldElm: T | T[], keepChildren?: boolean): T;
|
|
|
|
<T extends Node>(newElm: Node, oldElm: RunArguments<T>, keepChildren?: boolean): false | T;
|
|
|
|
};
|
|
|
|
rename: {
|
|
|
|
<K extends keyof HTMLElementTagNameMap>(elm: Element, name: K): HTMLElementTagNameMap[K];
|
|
|
|
(elm: Element, name: string): Element;
|
|
|
|
};
|
|
|
|
findCommonAncestor: (a: Node, b: Node) => Node;
|
2022-07-17 19:33:03 +02:00
|
|
|
run<R, T extends Node>(this: DOMUtils, elm: T | T[], func: (node: T) => R, scope?: any): typeof elm extends Array<any> ? R[] : R;
|
|
|
|
run<R, T extends Node>(this: DOMUtils, elm: RunArguments<T>, func: (node: T) => R, scope?: any): RunResult<typeof elm, R>;
|
2022-02-05 17:55:53 +01:00
|
|
|
getAttribs: (elm: string | Node) => NamedNodeMap | Attr[];
|
|
|
|
isEmpty: (node: Node, elements?: Record<string, any>) => boolean;
|
|
|
|
createRng: () => Range;
|
|
|
|
nodeIndex: (node: Node, normalized?: boolean) => number;
|
|
|
|
split: {
|
|
|
|
<T extends Node>(parentElm: Node, splitElm: Node, replacementElm: T): T;
|
|
|
|
<T extends Node>(parentElm: Node, splitElm: T): T;
|
|
|
|
};
|
|
|
|
bind: {
|
|
|
|
<K extends string>(target: Target, name: K, func: Callback<K>, scope?: any): Callback<K>;
|
|
|
|
<K extends string>(target: Target[], name: K, func: Callback<K>, scope?: any): Callback<K>[];
|
|
|
|
};
|
|
|
|
unbind: {
|
|
|
|
<K extends string>(target: Target, name?: K, func?: EventUtilsCallback<MappedEvent<HTMLElementEventMap, K>>): EventUtils;
|
|
|
|
<K extends string>(target: Target[], name?: K, func?: EventUtilsCallback<MappedEvent<HTMLElementEventMap, K>>): EventUtils[];
|
|
|
|
};
|
|
|
|
fire: (target: Node | Window, name: string, evt?: {}) => EventUtils;
|
2022-07-17 19:33:03 +02:00
|
|
|
dispatch: (target: Node | Window, name: string, evt?: {}) => EventUtils;
|
2022-02-05 17:55:53 +01:00
|
|
|
getContentEditable: (node: Node) => string | null;
|
|
|
|
getContentEditableParent: (node: Node) => string | null;
|
|
|
|
destroy: () => void;
|
|
|
|
isChildOf: (node: Node, parent: Node) => boolean;
|
|
|
|
dumpRng: (r: Range) => string;
|
|
|
|
}
|
|
|
|
interface ClientRect {
|
|
|
|
left: number;
|
|
|
|
top: number;
|
|
|
|
bottom: number;
|
|
|
|
right: number;
|
|
|
|
width: number;
|
|
|
|
height: number;
|
|
|
|
}
|
|
|
|
interface BookmarkManager {
|
|
|
|
getBookmark: (type: number, normalized?: boolean) => Bookmark;
|
|
|
|
moveToBookmark: (bookmark: Bookmark) => void;
|
|
|
|
}
|
|
|
|
interface ControlSelection {
|
|
|
|
isResizable: (elm: Element) => boolean;
|
|
|
|
showResizeRect: (elm: Element) => void;
|
|
|
|
hideResizeRect: () => void;
|
|
|
|
updateResizeRect: (evt: EditorEvent<any>) => void;
|
|
|
|
destroy: () => void;
|
|
|
|
}
|
|
|
|
interface WriterSettings {
|
|
|
|
element_format?: 'xhtml' | 'html';
|
|
|
|
entities?: string;
|
|
|
|
entity_encoding?: EntityEncoding;
|
|
|
|
indent?: boolean;
|
|
|
|
indent_after?: string;
|
|
|
|
indent_before?: string;
|
|
|
|
}
|
|
|
|
declare type Attributes = Array<{
|
|
|
|
name: string;
|
|
|
|
value: string;
|
|
|
|
}>;
|
|
|
|
interface Writer {
|
|
|
|
cdata: (text: string) => void;
|
|
|
|
comment: (text: string) => void;
|
|
|
|
doctype: (text: string) => void;
|
|
|
|
end: (name: string) => void;
|
|
|
|
getContent: () => string;
|
|
|
|
pi: (name: string, text?: string) => void;
|
|
|
|
reset: () => void;
|
|
|
|
start: (name: string, attrs?: Attributes, empty?: boolean) => void;
|
|
|
|
text: (text: string, raw?: boolean) => void;
|
|
|
|
}
|
|
|
|
interface HtmlSerializerSettings extends WriterSettings {
|
|
|
|
inner?: boolean;
|
|
|
|
validate?: boolean;
|
|
|
|
}
|
|
|
|
interface HtmlSerializer {
|
|
|
|
serialize: (node: AstNode) => string;
|
|
|
|
}
|
|
|
|
interface DomSerializerSettings extends DomParserSettings, WriterSettings, SchemaSettings, HtmlSerializerSettings {
|
|
|
|
url_converter?: URLConverter;
|
|
|
|
url_converter_scope?: {};
|
|
|
|
}
|
|
|
|
interface DomSerializerImpl {
|
|
|
|
schema: Schema;
|
2022-07-17 19:33:03 +02:00
|
|
|
addNodeFilter: (name: string, callback: ParserFilterCallback) => void;
|
|
|
|
addAttributeFilter: (name: string, callback: ParserFilterCallback) => void;
|
2022-02-05 17:55:53 +01:00
|
|
|
getNodeFilters: () => ParserFilter[];
|
|
|
|
getAttributeFilters: () => ParserFilter[];
|
2022-07-17 19:33:03 +02:00
|
|
|
removeNodeFilter: (name: string, callback?: ParserFilterCallback) => void;
|
|
|
|
removeAttributeFilter: (name: string, callback?: ParserFilterCallback) => void;
|
2022-02-05 17:55:53 +01:00
|
|
|
serialize: {
|
|
|
|
(node: Element, parserArgs: {
|
|
|
|
format: 'tree';
|
|
|
|
} & ParserArgs): AstNode;
|
|
|
|
(node: Element, parserArgs?: ParserArgs): string;
|
|
|
|
};
|
2022-07-17 19:33:03 +02:00
|
|
|
addRules: (rules: string) => void;
|
|
|
|
setRules: (rules: string) => void;
|
|
|
|
addTempAttr: (name: string) => void;
|
|
|
|
getTempAttrs: () => string[];
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
2022-07-17 19:33:03 +02:00
|
|
|
interface DomSerializer extends DomSerializerImpl {
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
2022-07-17 19:33:03 +02:00
|
|
|
interface EditorSelection {
|
|
|
|
bookmarkManager: BookmarkManager;
|
|
|
|
controlSelection: ControlSelection;
|
|
|
|
dom: DOMUtils;
|
|
|
|
win: Window;
|
|
|
|
serializer: DomSerializer;
|
|
|
|
editor: Editor;
|
|
|
|
collapse: (toStart?: boolean) => void;
|
|
|
|
setCursorLocation: {
|
|
|
|
(node: Node, offset: number): void;
|
|
|
|
(): void;
|
2022-02-05 17:55:53 +01:00
|
|
|
};
|
2022-07-17 19:33:03 +02:00
|
|
|
getContent: {
|
|
|
|
(args: {
|
|
|
|
format: 'tree';
|
|
|
|
} & Partial<GetSelectionContentArgs>): AstNode;
|
|
|
|
(args?: Partial<GetSelectionContentArgs>): string;
|
2022-02-05 17:55:53 +01:00
|
|
|
};
|
2022-07-17 19:33:03 +02:00
|
|
|
setContent: (content: string, args?: Partial<SetSelectionContentArgs>) => void;
|
|
|
|
getBookmark: (type?: number, normalized?: boolean) => Bookmark;
|
|
|
|
moveToBookmark: (bookmark: Bookmark) => void;
|
|
|
|
select: (node: Node, content?: boolean) => Node;
|
|
|
|
isCollapsed: () => boolean;
|
|
|
|
isForward: () => boolean;
|
|
|
|
setNode: (elm: Element) => Element;
|
|
|
|
getNode: () => Element;
|
|
|
|
getSel: () => Selection | null;
|
|
|
|
setRng: (rng: Range, forward?: boolean) => void;
|
|
|
|
getRng: () => Range;
|
|
|
|
getStart: (real?: boolean) => Element;
|
|
|
|
getEnd: (real?: boolean) => Element;
|
|
|
|
getSelectedBlocks: (startElm?: Element, endElm?: Element) => Element[];
|
|
|
|
normalize: () => Range;
|
|
|
|
selectorChanged: (selector: string, callback: (active: boolean, args: {
|
|
|
|
node: Node;
|
|
|
|
selector: String;
|
|
|
|
parents: Element[];
|
|
|
|
}) => void) => EditorSelection;
|
|
|
|
selectorChangedWithUnbind: (selector: string, callback: (active: boolean, args: {
|
|
|
|
node: Node;
|
|
|
|
selector: String;
|
|
|
|
parents: Element[];
|
|
|
|
}) => void) => {
|
|
|
|
unbind: () => void;
|
2022-02-05 17:55:53 +01:00
|
|
|
};
|
2022-07-17 19:33:03 +02:00
|
|
|
getScrollContainer: () => HTMLElement;
|
|
|
|
scrollIntoView: (elm?: HTMLElement, alignToTop?: boolean) => void;
|
|
|
|
placeCaretAt: (clientX: number, clientY: number) => void;
|
|
|
|
getBoundingClientRect: () => ClientRect | DOMRect;
|
|
|
|
destroy: () => void;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
2022-07-17 19:33:03 +02:00
|
|
|
declare type EditorCommandCallback = (ui: boolean, value: any) => void;
|
|
|
|
declare type EditorCommandsCallback = (command: string, ui: boolean, value: any) => void;
|
|
|
|
interface Commands {
|
|
|
|
state: Record<string, (command: string) => boolean>;
|
|
|
|
exec: Record<string, EditorCommandsCallback>;
|
|
|
|
value: Record<string, (command: string) => string>;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
2022-07-17 19:33:03 +02:00
|
|
|
interface ExecCommandArgs {
|
|
|
|
skip_focus?: boolean;
|
|
|
|
}
|
|
|
|
interface EditorCommandsConstructor {
|
|
|
|
readonly prototype: EditorCommands;
|
|
|
|
new (editor: Editor): EditorCommands;
|
|
|
|
}
|
|
|
|
declare class EditorCommands {
|
|
|
|
private readonly editor;
|
|
|
|
private commands;
|
|
|
|
constructor(editor: Editor);
|
|
|
|
execCommand(command: string, ui?: boolean, value?: any, args?: ExecCommandArgs): boolean;
|
|
|
|
queryCommandState(command: string): boolean;
|
|
|
|
queryCommandValue(command: string): string;
|
|
|
|
addCommands<K extends keyof Commands>(commandList: Commands[K], type: K): void;
|
|
|
|
addCommands(commandList: Record<string, EditorCommandsCallback>): void;
|
|
|
|
addCommand(command: string, callback: EditorCommandCallback, scope?: any): void;
|
|
|
|
queryCommandSupported(command: string): boolean;
|
|
|
|
addQueryStateHandler(command: string, callback: () => boolean, scope?: any): void;
|
|
|
|
addQueryValueHandler(command: string, callback: () => string, scope?: any): void;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
|
|
|
interface RawString {
|
|
|
|
raw: string;
|
|
|
|
}
|
|
|
|
declare type Primitive = string | number | boolean | Record<string | number, any> | Function;
|
|
|
|
declare type TokenisedString = [
|
|
|
|
string,
|
|
|
|
...Primitive[]
|
|
|
|
];
|
|
|
|
declare type Untranslated = Primitive | TokenisedString | RawString;
|
|
|
|
declare type TranslatedString = string;
|
|
|
|
interface I18n {
|
|
|
|
getData: () => Record<string, Record<string, string>>;
|
|
|
|
setCode: (newCode: string) => void;
|
|
|
|
getCode: () => string;
|
|
|
|
add: (code: string, items: Record<string, string>) => void;
|
|
|
|
translate: (text: Untranslated) => TranslatedString;
|
|
|
|
isRtl: () => boolean;
|
|
|
|
hasCode: (code: string) => boolean;
|
|
|
|
}
|
|
|
|
interface Observable<T> {
|
|
|
|
fire<K extends string, U extends MappedEvent<T, K>>(name: K, args?: U, bubble?: boolean): EditorEvent<U>;
|
2022-07-17 19:33:03 +02:00
|
|
|
dispatch<K extends string, U extends MappedEvent<T, K>>(name: K, args?: U, bubble?: boolean): EditorEvent<U>;
|
2022-02-05 17:55:53 +01:00
|
|
|
on<K extends string>(name: K, callback: (event: EditorEvent<MappedEvent<T, K>>) => void, prepend?: boolean): EventDispatcher<T>;
|
|
|
|
off<K extends string>(name?: K, callback?: (event: EditorEvent<MappedEvent<T, K>>) => void): EventDispatcher<T>;
|
|
|
|
once<K extends string>(name: K, callback: (event: EditorEvent<MappedEvent<T, K>>) => void): EventDispatcher<T>;
|
|
|
|
hasEventListeners(name: string): boolean;
|
|
|
|
}
|
|
|
|
interface URISettings {
|
|
|
|
base_uri?: URI;
|
|
|
|
}
|
|
|
|
interface URIConstructor {
|
|
|
|
readonly prototype: URI;
|
|
|
|
new (url: string, settings?: URISettings): URI;
|
|
|
|
getDocumentBaseUrl: (loc: {
|
|
|
|
protocol: string;
|
|
|
|
host?: string;
|
|
|
|
href?: string;
|
|
|
|
pathname?: string;
|
|
|
|
}) => string;
|
|
|
|
parseDataUri: (uri: string) => {
|
|
|
|
type: string;
|
|
|
|
data: string;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
interface SafeUriOptions {
|
|
|
|
readonly allow_html_data_urls?: boolean;
|
|
|
|
readonly allow_script_urls?: boolean;
|
|
|
|
readonly allow_svg_data_urls?: boolean;
|
|
|
|
}
|
|
|
|
declare class URI {
|
|
|
|
static parseDataUri(uri: string): {
|
|
|
|
type: string;
|
|
|
|
data: string;
|
|
|
|
};
|
|
|
|
static isDomSafe(uri: string, context?: string, options?: SafeUriOptions): boolean;
|
|
|
|
static getDocumentBaseUrl(loc: {
|
|
|
|
protocol: string;
|
|
|
|
host?: string;
|
|
|
|
href?: string;
|
|
|
|
pathname?: string;
|
|
|
|
}): string;
|
|
|
|
source: string;
|
|
|
|
protocol: string;
|
|
|
|
authority: string;
|
|
|
|
userInfo: string;
|
|
|
|
user: string;
|
|
|
|
password: string;
|
|
|
|
host: string;
|
|
|
|
port: string;
|
|
|
|
relative: string;
|
|
|
|
path: string;
|
|
|
|
directory: string;
|
|
|
|
file: string;
|
|
|
|
query: string;
|
|
|
|
anchor: string;
|
|
|
|
settings: URISettings;
|
|
|
|
constructor(url: string, settings?: URISettings);
|
|
|
|
setPath(path: string): void;
|
|
|
|
toRelative(uri: string): string;
|
|
|
|
toAbsolute(uri: string, noHost?: boolean): string;
|
|
|
|
isSameOrigin(uri: URI): boolean;
|
|
|
|
toRelPath(base: string, path: string): string;
|
|
|
|
toAbsPath(base: string, path: string): string;
|
|
|
|
getURI(noProtoHost?: boolean): string;
|
|
|
|
}
|
|
|
|
interface EditorManager extends Observable<EditorManagerEventMap> {
|
2022-07-17 19:33:03 +02:00
|
|
|
defaultOptions: RawEditorOptions;
|
2022-02-05 17:55:53 +01:00
|
|
|
majorVersion: string;
|
|
|
|
minorVersion: string;
|
|
|
|
releaseDate: string;
|
|
|
|
activeEditor: Editor;
|
|
|
|
focusedEditor: Editor;
|
|
|
|
baseURI: URI;
|
|
|
|
baseURL: string;
|
|
|
|
documentBaseURL: string;
|
|
|
|
i18n: I18n;
|
|
|
|
suffix: string;
|
|
|
|
add(this: EditorManager, editor: Editor): Editor;
|
|
|
|
addI18n: (code: string, item: Record<string, string>) => void;
|
2022-07-17 19:33:03 +02:00
|
|
|
createEditor(this: EditorManager, id: string, options: RawEditorOptions): Editor;
|
2022-02-05 17:55:53 +01:00
|
|
|
execCommand(this: EditorManager, cmd: string, ui: boolean, value: any): boolean;
|
|
|
|
get(this: EditorManager): Editor[];
|
|
|
|
get(this: EditorManager, id: number | string): Editor;
|
2022-07-17 19:33:03 +02:00
|
|
|
init(this: EditorManager, options: RawEditorOptions): Promise<Editor[]>;
|
|
|
|
overrideDefaults(this: EditorManager, defaultOptions: Partial<RawEditorOptions>): void;
|
2022-02-05 17:55:53 +01:00
|
|
|
remove(this: EditorManager): void;
|
|
|
|
remove(this: EditorManager, selector: string | Editor): Editor | void;
|
|
|
|
setActive(this: EditorManager, editor: Editor): void;
|
|
|
|
setup(this: EditorManager): void;
|
|
|
|
translate: (text: Untranslated) => TranslatedString;
|
|
|
|
triggerSave: () => void;
|
|
|
|
_setBaseUrl(this: EditorManager, baseUrl: string): void;
|
|
|
|
}
|
|
|
|
interface EditorObservable extends Observable<EditorEventMap> {
|
|
|
|
bindPendingEventDelegates(this: Editor): void;
|
|
|
|
toggleNativeEvent(this: Editor, name: string, state: boolean): any;
|
|
|
|
unbindAllNativeEvents(this: Editor): void;
|
|
|
|
}
|
2022-07-17 19:33:03 +02:00
|
|
|
interface ProcessorSuccess<T> {
|
|
|
|
valid: true;
|
|
|
|
value: T;
|
|
|
|
}
|
|
|
|
interface ProcessorError {
|
|
|
|
valid: false;
|
|
|
|
message: string;
|
|
|
|
}
|
|
|
|
declare type SimpleProcessor = (value: unknown) => boolean;
|
|
|
|
declare type Processor<T> = (value: unknown) => ProcessorSuccess<T> | ProcessorError;
|
|
|
|
interface BuiltInOptionTypeMap {
|
|
|
|
'string': string;
|
|
|
|
'number': number;
|
|
|
|
'boolean': boolean;
|
|
|
|
'array': any[];
|
|
|
|
'function': Function;
|
|
|
|
'object': any;
|
|
|
|
'string[]': string[];
|
|
|
|
'object[]': any[];
|
|
|
|
'regexp': RegExp;
|
|
|
|
}
|
|
|
|
declare type BuiltInOptionType = keyof BuiltInOptionTypeMap;
|
|
|
|
interface BaseOptionSpec {
|
|
|
|
immutable?: boolean;
|
|
|
|
deprecated?: boolean;
|
|
|
|
docsUrl?: string;
|
|
|
|
}
|
|
|
|
interface BuiltInOptionSpec<K extends BuiltInOptionType> extends BaseOptionSpec {
|
|
|
|
processor: K;
|
|
|
|
default?: BuiltInOptionTypeMap[K];
|
|
|
|
}
|
|
|
|
interface SimpleOptionSpec<T> extends BaseOptionSpec {
|
|
|
|
processor: SimpleProcessor;
|
|
|
|
default?: T;
|
|
|
|
}
|
|
|
|
interface OptionSpec<T, U> extends BaseOptionSpec {
|
|
|
|
processor: Processor<U>;
|
|
|
|
default?: T;
|
|
|
|
}
|
|
|
|
interface Options {
|
|
|
|
register: {
|
|
|
|
<K extends BuiltInOptionType>(name: string, spec: BuiltInOptionSpec<K>): void;
|
|
|
|
<K extends keyof NormalizedEditorOptions>(name: K, spec: OptionSpec<NormalizedEditorOptions[K], EditorOptions[K]> | SimpleOptionSpec<NormalizedEditorOptions[K]>): void;
|
|
|
|
<T, U>(name: string, spec: OptionSpec<T, U>): void;
|
|
|
|
<T>(name: string, spec: SimpleOptionSpec<T>): void;
|
|
|
|
};
|
|
|
|
isRegistered: (name: string) => boolean;
|
|
|
|
get: {
|
|
|
|
<K extends keyof EditorOptions>(name: K): EditorOptions[K] | undefined;
|
|
|
|
<T>(name: string): T | undefined;
|
|
|
|
};
|
|
|
|
set: <K extends string, T>(name: K, value: K extends keyof NormalizedEditorOptions ? NormalizedEditorOptions[K] : T) => boolean;
|
|
|
|
unset: (name: string) => boolean;
|
|
|
|
isSet: (name: string) => boolean;
|
|
|
|
}
|
2022-02-05 17:55:53 +01:00
|
|
|
interface UploadResult$1 {
|
|
|
|
element: HTMLImageElement;
|
|
|
|
status: boolean;
|
|
|
|
blobInfo: BlobInfo;
|
|
|
|
uploadUri: string;
|
2022-07-17 19:33:03 +02:00
|
|
|
removed: boolean;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
|
|
|
interface EditorUpload {
|
|
|
|
blobCache: BlobCache;
|
|
|
|
addFilter: (filter: (img: HTMLImageElement) => boolean) => void;
|
2022-07-17 19:33:03 +02:00
|
|
|
uploadImages: () => Promise<UploadResult$1[]>;
|
|
|
|
uploadImagesAuto: () => Promise<UploadResult$1[]>;
|
2022-02-05 17:55:53 +01:00
|
|
|
scanForImages: () => Promise<BlobInfoImagePair[]>;
|
|
|
|
destroy: () => void;
|
|
|
|
}
|
|
|
|
declare type FormatChangeCallback = (state: boolean, data: {
|
|
|
|
node: Node;
|
|
|
|
format: string;
|
|
|
|
parents: any;
|
|
|
|
}) => void;
|
|
|
|
interface FormatRegistry {
|
|
|
|
get: {
|
|
|
|
(name: string): Format[] | undefined;
|
|
|
|
(): Record<string, Format[]>;
|
|
|
|
};
|
|
|
|
has: (name: string) => boolean;
|
|
|
|
register: (name: string | Formats, format?: Format[] | Format) => void;
|
|
|
|
unregister: (name: string) => Formats;
|
|
|
|
}
|
|
|
|
interface Formatter extends FormatRegistry {
|
|
|
|
apply: (name: string, vars?: FormatVars, node?: Node | RangeLikeObject) => void;
|
|
|
|
remove: (name: string, vars?: FormatVars, node?: Node | Range, similar?: boolean) => void;
|
|
|
|
toggle: (name: string, vars?: FormatVars, node?: Node) => void;
|
|
|
|
match: (name: string, vars?: FormatVars, node?: Node, similar?: boolean) => boolean;
|
|
|
|
closest: (names: string[]) => string | null;
|
|
|
|
matchAll: (names: string[], vars?: FormatVars) => string[];
|
|
|
|
matchNode: (node: Node, name: string, vars?: FormatVars, similar?: boolean) => Format | undefined;
|
|
|
|
canApply: (name: string) => boolean;
|
|
|
|
formatChanged: (names: string, callback: FormatChangeCallback, similar?: boolean, vars?: FormatVars) => {
|
|
|
|
unbind: () => void;
|
|
|
|
};
|
|
|
|
getCssText: (format: string | Format) => string;
|
|
|
|
}
|
|
|
|
interface EditorMode {
|
|
|
|
isReadOnly: () => boolean;
|
|
|
|
set: (mode: string) => void;
|
|
|
|
get: () => string;
|
|
|
|
register: (mode: string, api: EditorModeApi) => void;
|
|
|
|
}
|
|
|
|
interface EditorModeApi {
|
|
|
|
activate: () => void;
|
|
|
|
deactivate: () => void;
|
|
|
|
editorReadOnly: boolean;
|
|
|
|
}
|
2022-07-17 19:33:03 +02:00
|
|
|
interface Model {
|
|
|
|
readonly table: {
|
|
|
|
readonly getSelectedCells: () => HTMLTableCellElement[];
|
|
|
|
readonly clearSelectedCells: (container: Node) => void;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
declare type ModelManager = AddOnManager<Model>;
|
2022-02-05 17:55:53 +01:00
|
|
|
interface Plugin {
|
|
|
|
getMetadata?: () => {
|
|
|
|
name: string;
|
|
|
|
url: string;
|
|
|
|
};
|
2022-07-17 19:33:03 +02:00
|
|
|
init?: (editor: Editor, url: string) => void;
|
2022-02-05 17:55:53 +01:00
|
|
|
[key: string]: any;
|
|
|
|
}
|
2022-07-17 19:33:03 +02:00
|
|
|
declare type PluginManager = AddOnManager<void | Plugin>;
|
2022-02-05 17:55:53 +01:00
|
|
|
interface ShortcutsConstructor {
|
|
|
|
readonly prototype: Shortcuts;
|
|
|
|
new (editor: Editor): Shortcuts;
|
|
|
|
}
|
|
|
|
declare type CommandFunc = string | [
|
|
|
|
string,
|
|
|
|
boolean,
|
|
|
|
any
|
|
|
|
] | (() => void);
|
|
|
|
declare class Shortcuts {
|
|
|
|
private readonly editor;
|
|
|
|
private readonly shortcuts;
|
|
|
|
private pendingPatterns;
|
|
|
|
constructor(editor: Editor);
|
|
|
|
add(pattern: string, desc: string, cmdFunc: CommandFunc, scope?: any): boolean;
|
|
|
|
remove(pattern: string): boolean;
|
|
|
|
private normalizeCommandFunc;
|
|
|
|
private createShortcut;
|
|
|
|
private hasModifier;
|
|
|
|
private isFunctionKey;
|
|
|
|
private matchShortcut;
|
|
|
|
private executeShortcutAction;
|
|
|
|
}
|
|
|
|
interface Theme {
|
|
|
|
ui?: any;
|
|
|
|
inline?: any;
|
|
|
|
execCommand?: (command: string, ui?: boolean, value?: any) => boolean;
|
|
|
|
destroy?: () => void;
|
2022-07-17 19:33:03 +02:00
|
|
|
init?: (editor: Editor, url: string) => void;
|
2022-02-05 17:55:53 +01:00
|
|
|
renderUI?: () => {
|
|
|
|
iframeContainer?: HTMLIFrameElement;
|
|
|
|
editorContainer: HTMLElement;
|
|
|
|
api?: Partial<EditorUiApi>;
|
|
|
|
};
|
|
|
|
getNotificationManagerImpl?: () => NotificationManagerImpl;
|
|
|
|
getWindowManagerImpl?: () => WindowManagerImpl;
|
|
|
|
}
|
2022-07-17 19:33:03 +02:00
|
|
|
declare type ThemeManager = AddOnManager<void | Theme>;
|
2022-02-05 17:55:53 +01:00
|
|
|
interface EditorConstructor {
|
|
|
|
readonly prototype: Editor;
|
2022-07-17 19:33:03 +02:00
|
|
|
new (id: string, options: RawEditorOptions, editorManager: EditorManager): Editor;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
|
|
|
declare class Editor implements EditorObservable {
|
|
|
|
documentBaseUrl: string;
|
|
|
|
baseUri: URI;
|
|
|
|
id: string;
|
|
|
|
plugins: Record<string, Plugin>;
|
|
|
|
documentBaseURI: URI;
|
|
|
|
baseURI: URI;
|
|
|
|
contentCSS: string[];
|
|
|
|
contentStyles: string[];
|
|
|
|
ui: EditorUi;
|
|
|
|
mode: EditorMode;
|
2022-07-17 19:33:03 +02:00
|
|
|
options: Options;
|
2022-02-05 17:55:53 +01:00
|
|
|
shortcuts: Shortcuts;
|
|
|
|
loadedCSS: Record<string, any>;
|
|
|
|
editorCommands: EditorCommands;
|
|
|
|
suffix: string;
|
|
|
|
editorManager: EditorManager;
|
|
|
|
inline: boolean;
|
|
|
|
isNotDirty: boolean;
|
|
|
|
annotator: Annotator;
|
|
|
|
bodyElement: HTMLElement;
|
|
|
|
bookmark: any;
|
|
|
|
composing: boolean;
|
|
|
|
container: HTMLElement;
|
|
|
|
contentAreaContainer: HTMLElement;
|
|
|
|
contentDocument: Document;
|
|
|
|
contentWindow: Window;
|
|
|
|
delegates: Record<string, (event: any) => void>;
|
|
|
|
destroyed: boolean;
|
|
|
|
dom: DOMUtils;
|
|
|
|
editorContainer: HTMLElement;
|
2022-07-17 19:33:03 +02:00
|
|
|
editorUpload: EditorUpload;
|
2022-02-05 17:55:53 +01:00
|
|
|
eventRoot?: Element;
|
|
|
|
formatter: Formatter;
|
|
|
|
formElement: HTMLElement;
|
|
|
|
formEventDelegate: (e: Event) => void;
|
|
|
|
hasHiddenInput: boolean;
|
|
|
|
hasVisual: boolean;
|
|
|
|
hidden: boolean;
|
|
|
|
iframeElement: HTMLIFrameElement | null;
|
|
|
|
iframeHTML: string;
|
|
|
|
initialized: boolean;
|
|
|
|
notificationManager: NotificationManager;
|
|
|
|
orgDisplay: string;
|
|
|
|
orgVisibility: string;
|
|
|
|
parser: DomParser;
|
|
|
|
quirks: Quirks;
|
|
|
|
readonly: boolean;
|
|
|
|
removed: boolean;
|
|
|
|
schema: Schema;
|
|
|
|
selection: EditorSelection;
|
|
|
|
serializer: DomSerializer;
|
|
|
|
startContent: string;
|
|
|
|
targetElm: HTMLElement;
|
|
|
|
theme: Theme;
|
2022-07-17 19:33:03 +02:00
|
|
|
model: Model;
|
2022-02-05 17:55:53 +01:00
|
|
|
undoManager: UndoManager;
|
|
|
|
windowManager: WindowManager;
|
|
|
|
_beforeUnload: () => void;
|
|
|
|
_eventDispatcher: EventDispatcher<NativeEventMap>;
|
2022-07-17 19:33:03 +02:00
|
|
|
_nodeChangeDispatcher: NodeChange;
|
2022-02-05 17:55:53 +01:00
|
|
|
_pendingNativeEvents: string[];
|
|
|
|
_selectionOverrides: SelectionOverrides;
|
|
|
|
_skinLoaded: boolean;
|
|
|
|
bindPendingEventDelegates: EditorObservable['bindPendingEventDelegates'];
|
|
|
|
toggleNativeEvent: EditorObservable['toggleNativeEvent'];
|
|
|
|
unbindAllNativeEvents: EditorObservable['unbindAllNativeEvents'];
|
|
|
|
fire: EditorObservable['fire'];
|
2022-07-17 19:33:03 +02:00
|
|
|
dispatch: EditorObservable['dispatch'];
|
2022-02-05 17:55:53 +01:00
|
|
|
on: EditorObservable['on'];
|
|
|
|
off: EditorObservable['off'];
|
|
|
|
once: EditorObservable['once'];
|
|
|
|
hasEventListeners: EditorObservable['hasEventListeners'];
|
2022-07-17 19:33:03 +02:00
|
|
|
constructor(id: string, options: RawEditorOptions, editorManager: EditorManager);
|
2022-02-05 17:55:53 +01:00
|
|
|
render(): void;
|
|
|
|
focus(skipFocus?: boolean): void;
|
|
|
|
hasFocus(): boolean;
|
|
|
|
translate(text: Untranslated): TranslatedString;
|
2022-07-17 19:33:03 +02:00
|
|
|
getParam<K extends BuiltInOptionType>(name: string, defaultVal: BuiltInOptionTypeMap[K], type: K): BuiltInOptionTypeMap[K];
|
|
|
|
getParam<K extends keyof NormalizedEditorOptions>(name: K, defaultVal?: NormalizedEditorOptions[K], type?: BuiltInOptionType): NormalizedEditorOptions[K];
|
|
|
|
getParam<T>(name: string, defaultVal: T, type?: BuiltInOptionType): T;
|
2022-02-05 17:55:53 +01:00
|
|
|
hasPlugin(name: string, loaded?: boolean): boolean;
|
|
|
|
nodeChanged(args?: any): void;
|
|
|
|
addCommand(name: string, callback: EditorCommandCallback, scope?: object): void;
|
|
|
|
addQueryStateHandler(name: string, callback: () => boolean, scope?: any): void;
|
|
|
|
addQueryValueHandler(name: string, callback: () => string, scope?: any): void;
|
|
|
|
addShortcut(pattern: string, desc: string, cmdFunc: string | [
|
|
|
|
string,
|
|
|
|
boolean,
|
|
|
|
any
|
|
|
|
] | (() => void), scope?: any): void;
|
2022-07-17 19:33:03 +02:00
|
|
|
execCommand(cmd: string, ui?: boolean, value?: any, args?: ExecCommandArgs): boolean;
|
2022-02-05 17:55:53 +01:00
|
|
|
queryCommandState(cmd: string): boolean;
|
|
|
|
queryCommandValue(cmd: string): string;
|
|
|
|
queryCommandSupported(cmd: string): boolean;
|
|
|
|
show(): void;
|
|
|
|
hide(): void;
|
|
|
|
isHidden(): boolean;
|
|
|
|
setProgressState(state: boolean, time?: number): void;
|
|
|
|
load(args?: any): string;
|
|
|
|
save(args?: any): string;
|
2022-07-17 19:33:03 +02:00
|
|
|
setContent(content: string, args?: Partial<SetContentArgs>): string;
|
|
|
|
setContent(content: AstNode, args?: Partial<SetContentArgs>): AstNode;
|
|
|
|
setContent(content: Content, args?: Partial<SetContentArgs>): Content;
|
2022-02-05 17:55:53 +01:00
|
|
|
getContent(args: {
|
|
|
|
format: 'tree';
|
2022-07-17 19:33:03 +02:00
|
|
|
} & Partial<GetContentArgs>): AstNode;
|
|
|
|
getContent(args?: Partial<GetContentArgs>): string;
|
2022-02-05 17:55:53 +01:00
|
|
|
insertContent(content: string, args?: any): void;
|
|
|
|
resetContent(initialContent?: string): void;
|
|
|
|
isDirty(): boolean;
|
|
|
|
setDirty(state: boolean): void;
|
|
|
|
getContainer(): HTMLElement;
|
|
|
|
getContentAreaContainer(): HTMLElement;
|
|
|
|
getElement(): HTMLElement;
|
|
|
|
getWin(): Window;
|
|
|
|
getDoc(): Document;
|
|
|
|
getBody(): HTMLElement;
|
|
|
|
convertURL(url: string, name: string, elm?: any): string;
|
|
|
|
addVisual(elm?: HTMLElement): void;
|
|
|
|
remove(): void;
|
|
|
|
destroy(automatic?: boolean): void;
|
2022-07-17 19:33:03 +02:00
|
|
|
uploadImages(): Promise<UploadResult$1[]>;
|
2022-02-05 17:55:53 +01:00
|
|
|
_scanForImages(): Promise<BlobInfoImagePair[]>;
|
|
|
|
}
|
|
|
|
interface UrlObject {
|
|
|
|
prefix: string;
|
|
|
|
resource: string;
|
|
|
|
suffix: string;
|
|
|
|
}
|
|
|
|
declare type WaitState = 'added' | 'loaded';
|
2022-07-17 19:33:03 +02:00
|
|
|
declare type AddOnConstructor<T> = (editor: Editor, url: string) => T;
|
2022-02-05 17:55:53 +01:00
|
|
|
interface AddOnManager<T> {
|
|
|
|
items: AddOnConstructor<T>[];
|
|
|
|
urls: Record<string, string>;
|
|
|
|
lookup: Record<string, {
|
|
|
|
instance: AddOnConstructor<T>;
|
|
|
|
}>;
|
|
|
|
get: (name: string) => AddOnConstructor<T>;
|
|
|
|
requireLangPack: (name: string, languages: string) => void;
|
2022-07-17 19:33:03 +02:00
|
|
|
add: (id: string, addOn: AddOnConstructor<T>) => AddOnConstructor<T>;
|
2022-02-05 17:55:53 +01:00
|
|
|
remove: (name: string) => void;
|
|
|
|
createUrl: (baseUrl: UrlObject, dep: string | UrlObject) => UrlObject;
|
2022-07-17 19:33:03 +02:00
|
|
|
load: (name: string, addOnUrl: string | UrlObject) => Promise<void>;
|
|
|
|
waitFor: (name: string, state?: WaitState) => Promise<void>;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
|
|
|
interface RangeUtils {
|
|
|
|
walk: (rng: Range, callback: (nodes: Node[]) => void) => void;
|
|
|
|
split: (rng: Range) => RangeLikeObject;
|
|
|
|
normalize: (rng: Range) => boolean;
|
|
|
|
}
|
|
|
|
interface ScriptLoaderSettings {
|
|
|
|
referrerPolicy?: ReferrerPolicy;
|
|
|
|
}
|
|
|
|
interface ScriptLoaderConstructor {
|
|
|
|
readonly prototype: ScriptLoader;
|
|
|
|
new (): ScriptLoader;
|
|
|
|
ScriptLoader: ScriptLoader;
|
|
|
|
}
|
|
|
|
declare class ScriptLoader {
|
|
|
|
static ScriptLoader: ScriptLoader;
|
|
|
|
private settings;
|
|
|
|
private states;
|
|
|
|
private queue;
|
|
|
|
private scriptLoadedCallbacks;
|
|
|
|
private queueLoadedCallbacks;
|
|
|
|
private loading;
|
|
|
|
constructor(settings?: ScriptLoaderSettings);
|
|
|
|
_setReferrerPolicy(referrerPolicy: ReferrerPolicy): void;
|
2022-07-17 19:33:03 +02:00
|
|
|
loadScript(url: string): Promise<void>;
|
2022-02-05 17:55:53 +01:00
|
|
|
isDone(url: string): boolean;
|
|
|
|
markDone(url: string): void;
|
2022-07-17 19:33:03 +02:00
|
|
|
add(url: string): Promise<void>;
|
|
|
|
load(url: string): Promise<void>;
|
2022-02-05 17:55:53 +01:00
|
|
|
remove(url: string): void;
|
2022-07-17 19:33:03 +02:00
|
|
|
loadQueue(): Promise<void>;
|
|
|
|
loadScripts(scripts: string[]): Promise<void>;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
|
|
|
declare type TextProcessCallback = (node: Text, offset: number, text: string) => number;
|
|
|
|
interface Spot {
|
|
|
|
container: Text;
|
|
|
|
offset: number;
|
|
|
|
}
|
|
|
|
interface TextSeeker {
|
|
|
|
backwards: (node: Node, offset: number, process: TextProcessCallback, root?: Node) => Spot | null;
|
|
|
|
forwards: (node: Node, offset: number, process: TextProcessCallback, root?: Node) => Spot | null;
|
|
|
|
}
|
|
|
|
interface DomTreeWalkerConstructor {
|
|
|
|
readonly prototype: DomTreeWalker;
|
|
|
|
new (startNode: Node, rootNode: Node): DomTreeWalker;
|
|
|
|
}
|
|
|
|
declare class DomTreeWalker {
|
|
|
|
private readonly rootNode;
|
|
|
|
private node;
|
|
|
|
constructor(startNode: Node, rootNode: Node);
|
2022-07-17 19:33:03 +02:00
|
|
|
current(): Node | undefined;
|
|
|
|
next(shallow?: boolean): Node | undefined;
|
|
|
|
prev(shallow?: boolean): Node | undefined;
|
|
|
|
prev2(shallow?: boolean): Node | undefined;
|
2022-02-05 17:55:53 +01:00
|
|
|
private findSibling;
|
|
|
|
private findPreviousNode;
|
|
|
|
}
|
|
|
|
interface Version {
|
|
|
|
major: number;
|
|
|
|
minor: number;
|
|
|
|
}
|
|
|
|
interface Env {
|
|
|
|
transparentSrc: string;
|
|
|
|
documentMode: number;
|
|
|
|
cacheSuffix: any;
|
|
|
|
container: any;
|
|
|
|
canHaveCSP: boolean;
|
|
|
|
windowsPhone: boolean;
|
|
|
|
browser: {
|
|
|
|
current: string | undefined;
|
|
|
|
version: Version;
|
|
|
|
isEdge: () => boolean;
|
2022-07-17 19:33:03 +02:00
|
|
|
isChromium: () => boolean;
|
2022-02-05 17:55:53 +01:00
|
|
|
isIE: () => boolean;
|
|
|
|
isOpera: () => boolean;
|
|
|
|
isFirefox: () => boolean;
|
|
|
|
isSafari: () => boolean;
|
|
|
|
};
|
|
|
|
os: {
|
|
|
|
current: string | undefined;
|
|
|
|
version: Version;
|
|
|
|
isWindows: () => boolean;
|
|
|
|
isiOS: () => boolean;
|
|
|
|
isAndroid: () => boolean;
|
2022-07-17 19:33:03 +02:00
|
|
|
isMacOS: () => boolean;
|
2022-02-05 17:55:53 +01:00
|
|
|
isLinux: () => boolean;
|
|
|
|
isSolaris: () => boolean;
|
|
|
|
isFreeBSD: () => boolean;
|
|
|
|
isChromeOS: () => boolean;
|
|
|
|
};
|
|
|
|
deviceType: {
|
|
|
|
isiPad: () => boolean;
|
|
|
|
isiPhone: () => boolean;
|
|
|
|
isTablet: () => boolean;
|
|
|
|
isPhone: () => boolean;
|
|
|
|
isTouch: () => boolean;
|
|
|
|
isWebView: () => boolean;
|
|
|
|
isDesktop: () => boolean;
|
|
|
|
};
|
|
|
|
}
|
2022-07-17 19:33:03 +02:00
|
|
|
interface FakeClipboardItem {
|
|
|
|
readonly items: Record<string, any>;
|
|
|
|
readonly types: ReadonlyArray<string>;
|
|
|
|
readonly getType: <D = any>(type: string) => D | undefined;
|
|
|
|
}
|
|
|
|
interface FakeClipboard {
|
|
|
|
readonly FakeClipboardItem: (items: Record<string, any>) => FakeClipboardItem;
|
|
|
|
readonly write: (data: FakeClipboardItem[]) => void;
|
|
|
|
readonly read: () => FakeClipboardItem[] | undefined;
|
|
|
|
readonly clear: () => void;
|
|
|
|
}
|
2022-02-05 17:55:53 +01:00
|
|
|
interface FocusManager {
|
|
|
|
isEditorUIElement: (elm: Element) => boolean;
|
|
|
|
}
|
|
|
|
interface EntitiesMap {
|
|
|
|
[name: string]: string;
|
|
|
|
}
|
|
|
|
interface Entities {
|
|
|
|
encodeRaw: (text: string, attr?: boolean) => string;
|
|
|
|
encodeAllRaw: (text: string) => string;
|
|
|
|
encodeNumeric: (text: string, attr?: boolean) => string;
|
|
|
|
encodeNamed: (text: string, attr?: boolean, entities?: EntitiesMap) => string;
|
|
|
|
getEncodeFunc: (name: string, entities?: EntitiesMap | string) => (text: string, attr?: boolean) => string;
|
|
|
|
decode: (text: string) => string;
|
|
|
|
}
|
|
|
|
interface IconPack {
|
|
|
|
icons: Record<string, string>;
|
|
|
|
}
|
|
|
|
interface IconManager {
|
|
|
|
add: (id: string, iconPack: IconPack) => void;
|
|
|
|
get: (id: string) => IconPack;
|
|
|
|
has: (id: string) => boolean;
|
|
|
|
}
|
|
|
|
interface Resource {
|
|
|
|
load: <T = any>(id: string, url: string) => Promise<T>;
|
|
|
|
add: (id: string, data: any) => void;
|
2022-07-17 19:33:03 +02:00
|
|
|
unload: (id: string) => void;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
|
|
|
interface Delay {
|
|
|
|
setEditorInterval: (editor: Editor, callback: () => void, time?: number) => number;
|
|
|
|
setEditorTimeout: (editor: Editor, callback: () => void, time?: number) => number;
|
|
|
|
}
|
|
|
|
declare type UploadResult = UploadResult$2;
|
|
|
|
interface ImageUploader {
|
|
|
|
upload: (blobInfos: BlobInfo[], showNotification?: boolean) => Promise<UploadResult[]>;
|
|
|
|
}
|
2022-07-17 19:33:03 +02:00
|
|
|
declare type ArrayCallback$1<T, R> = (x: T, i: number, xs: ReadonlyArray<T>) => R;
|
|
|
|
declare type ObjCallback$1<T, R> = (value: T, key: string, obj: Record<string, T>) => R;
|
|
|
|
declare type ArrayCallback<T, R> = ArrayCallback$1<T, R>;
|
|
|
|
declare type ObjCallback<T, R> = ObjCallback$1<T, R>;
|
|
|
|
interface Tools {
|
|
|
|
is: (obj: any, type: string) => boolean;
|
|
|
|
isArray: <T>(arr: any) => arr is Array<T>;
|
|
|
|
inArray: <T>(arr: ArrayLike<T>, value: T) => number;
|
|
|
|
grep: {
|
|
|
|
<T>(arr: ArrayLike<T> | null | undefined, pred?: ArrayCallback<T, boolean>): T[];
|
|
|
|
<T>(arr: Record<string, T> | null | undefined, pred?: ObjCallback<T, boolean>): T[];
|
|
|
|
};
|
|
|
|
trim: (str: string | null | undefined) => string;
|
|
|
|
toArray: <T>(obj: ArrayLike<T>) => T[];
|
|
|
|
hasOwn: (obj: any, name: string) => boolean;
|
|
|
|
makeMap: <T>(items: ArrayLike<T> | string, delim?: string | RegExp, map?: Record<string, T | string>) => Record<string, T | string>;
|
|
|
|
each: {
|
|
|
|
<T>(arr: ArrayLike<T> | null | undefined, cb: ArrayCallback<T, void | boolean>, scope?: any): boolean;
|
|
|
|
<T>(obj: Record<string, T> | null | undefined, cb: ObjCallback<T, void | boolean>, scope?: any): boolean;
|
|
|
|
};
|
|
|
|
map: {
|
|
|
|
<T, R>(arr: ArrayLike<T> | null | undefined, cb: ArrayCallback<T, R>): R[];
|
|
|
|
<T, R>(obj: Record<string, T> | null | undefined, cb: ObjCallback<T, R>): R[];
|
|
|
|
};
|
|
|
|
extend: (obj: Object, ext: Object, ...objs: Object[]) => any;
|
|
|
|
walk: <T = any>(obj: T, f: Function, n?: keyof T, scope?: any) => void;
|
|
|
|
resolve: (path: string, o?: Object) => any;
|
|
|
|
explode: (s: string, d?: string | RegExp) => string[];
|
|
|
|
_addCacheSuffix: (url: string) => string;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
|
|
|
interface KeyboardLikeEvent {
|
|
|
|
shiftKey: boolean;
|
|
|
|
ctrlKey: boolean;
|
|
|
|
altKey: boolean;
|
|
|
|
metaKey: boolean;
|
|
|
|
}
|
|
|
|
interface VK {
|
|
|
|
BACKSPACE: number;
|
|
|
|
DELETE: number;
|
|
|
|
DOWN: number;
|
|
|
|
ENTER: number;
|
|
|
|
ESC: number;
|
|
|
|
LEFT: number;
|
|
|
|
RIGHT: number;
|
|
|
|
SPACEBAR: number;
|
|
|
|
TAB: number;
|
|
|
|
UP: number;
|
|
|
|
PAGE_UP: number;
|
|
|
|
PAGE_DOWN: number;
|
|
|
|
END: number;
|
|
|
|
HOME: number;
|
|
|
|
modifierPressed: (e: KeyboardLikeEvent) => boolean;
|
|
|
|
metaKeyPressed: (e: KeyboardLikeEvent) => boolean;
|
|
|
|
}
|
|
|
|
interface DOMUtilsNamespace {
|
2022-07-17 19:33:03 +02:00
|
|
|
(doc: Document, settings: Partial<DOMUtilsSettings>): DOMUtils;
|
2022-02-05 17:55:53 +01:00
|
|
|
DOM: DOMUtils;
|
|
|
|
nodeIndex: (node: Node, normalized?: boolean) => number;
|
|
|
|
}
|
|
|
|
interface RangeUtilsNamespace {
|
2022-07-17 19:33:03 +02:00
|
|
|
(dom: DOMUtils): RangeUtils;
|
2022-02-05 17:55:53 +01:00
|
|
|
compareRanges: (rng1: RangeLikeObject, rng2: RangeLikeObject) => boolean;
|
|
|
|
getCaretRangeFromPoint: (clientX: number, clientY: number, doc: Document) => Range;
|
|
|
|
getSelectedNode: (range: Range) => Node;
|
|
|
|
getNode: (container: Node, offset: number) => Node;
|
|
|
|
}
|
|
|
|
interface AddOnManagerNamespace {
|
2022-07-17 19:33:03 +02:00
|
|
|
<T>(): AddOnManager<T>;
|
2022-02-05 17:55:53 +01:00
|
|
|
language: string | undefined;
|
|
|
|
languageLoad: boolean;
|
|
|
|
baseURL: string;
|
|
|
|
PluginManager: PluginManager;
|
|
|
|
ThemeManager: ThemeManager;
|
2022-07-17 19:33:03 +02:00
|
|
|
ModelManager: ModelManager;
|
2022-02-05 17:55:53 +01:00
|
|
|
}
|
|
|
|
interface BookmarkManagerNamespace {
|
|
|
|
(selection: EditorSelection): BookmarkManager;
|
|
|
|
isBookmarkNode: (node: Node) => boolean;
|
|
|
|
}
|
|
|
|
interface TinyMCE extends EditorManager {
|
|
|
|
geom: {
|
|
|
|
Rect: Rect;
|
|
|
|
};
|
|
|
|
util: {
|
|
|
|
Delay: Delay;
|
|
|
|
Tools: Tools;
|
|
|
|
VK: VK;
|
|
|
|
URI: URIConstructor;
|
|
|
|
EventDispatcher: EventDispatcherConstructor<any>;
|
|
|
|
Observable: Observable<any>;
|
|
|
|
I18n: I18n;
|
|
|
|
LocalStorage: Storage;
|
|
|
|
ImageUploader: ImageUploader;
|
|
|
|
};
|
|
|
|
dom: {
|
|
|
|
EventUtils: EventUtilsConstructor;
|
|
|
|
TreeWalker: DomTreeWalkerConstructor;
|
2022-07-17 19:33:03 +02:00
|
|
|
TextSeeker: (dom: DOMUtils, isBlockBoundary?: (node: Node) => boolean) => TextSeeker;
|
2022-02-05 17:55:53 +01:00
|
|
|
DOMUtils: DOMUtilsNamespace;
|
|
|
|
ScriptLoader: ScriptLoaderConstructor;
|
|
|
|
RangeUtils: RangeUtilsNamespace;
|
2022-07-17 19:33:03 +02:00
|
|
|
Serializer: (settings: DomSerializerSettings, editor?: Editor) => DomSerializer;
|
2022-02-05 17:55:53 +01:00
|
|
|
ControlSelection: (selection: EditorSelection, editor: Editor) => ControlSelection;
|
|
|
|
BookmarkManager: BookmarkManagerNamespace;
|
2022-07-17 19:33:03 +02:00
|
|
|
Selection: (dom: DOMUtils, win: Window, serializer: DomSerializer, editor: Editor) => EditorSelection;
|
|
|
|
StyleSheetLoader: (documentOrShadowRoot: Document | ShadowRoot, settings: StyleSheetLoaderSettings) => StyleSheetLoader;
|
2022-02-05 17:55:53 +01:00
|
|
|
Event: EventUtils;
|
|
|
|
};
|
|
|
|
html: {
|
2022-07-17 19:33:03 +02:00
|
|
|
Styles: (settings?: StylesSettings, schema?: Schema) => Styles;
|
2022-02-05 17:55:53 +01:00
|
|
|
Entities: Entities;
|
|
|
|
Node: AstNodeConstructor;
|
2022-07-17 19:33:03 +02:00
|
|
|
Schema: (settings?: SchemaSettings) => Schema;
|
|
|
|
DomParser: (settings?: DomParserSettings, schema?: Schema) => DomParser;
|
|
|
|
Writer: (settings?: WriterSettings) => Writer;
|
|
|
|
Serializer: (settings?: HtmlSerializerSettings, schema?: Schema) => HtmlSerializer;
|
2022-02-05 17:55:53 +01:00
|
|
|
};
|
|
|
|
AddOnManager: AddOnManagerNamespace;
|
2022-07-17 19:33:03 +02:00
|
|
|
Annotator: (editor: Editor) => Annotator;
|
2022-02-05 17:55:53 +01:00
|
|
|
Editor: EditorConstructor;
|
|
|
|
EditorCommands: EditorCommandsConstructor;
|
|
|
|
EditorManager: EditorManager;
|
|
|
|
EditorObservable: EditorObservable;
|
|
|
|
Env: Env;
|
|
|
|
FocusManager: FocusManager;
|
2022-07-17 19:33:03 +02:00
|
|
|
Formatter: (editor: Editor) => Formatter;
|
|
|
|
NotificationManager: (editor: Editor) => NotificationManager;
|
2022-02-05 17:55:53 +01:00
|
|
|
Shortcuts: ShortcutsConstructor;
|
2022-07-17 19:33:03 +02:00
|
|
|
UndoManager: (editor: Editor) => UndoManager;
|
|
|
|
WindowManager: (editor: Editor) => WindowManager;
|
2022-02-05 17:55:53 +01:00
|
|
|
DOM: DOMUtils;
|
|
|
|
ScriptLoader: ScriptLoader;
|
|
|
|
PluginManager: PluginManager;
|
|
|
|
ThemeManager: ThemeManager;
|
2022-07-17 19:33:03 +02:00
|
|
|
ModelManager: ModelManager;
|
2022-02-05 17:55:53 +01:00
|
|
|
IconManager: IconManager;
|
|
|
|
Resource: Resource;
|
2022-07-17 19:33:03 +02:00
|
|
|
FakeClipboard: FakeClipboard;
|
2022-02-05 17:55:53 +01:00
|
|
|
trim: Tools['trim'];
|
|
|
|
isArray: Tools['isArray'];
|
|
|
|
is: Tools['is'];
|
|
|
|
toArray: Tools['toArray'];
|
|
|
|
makeMap: Tools['makeMap'];
|
|
|
|
each: Tools['each'];
|
|
|
|
map: Tools['map'];
|
|
|
|
grep: Tools['grep'];
|
|
|
|
inArray: Tools['inArray'];
|
|
|
|
extend: Tools['extend'];
|
|
|
|
walk: Tools['walk'];
|
|
|
|
resolve: Tools['resolve'];
|
|
|
|
explode: Tools['explode'];
|
|
|
|
_addCacheSuffix: Tools['_addCacheSuffix'];
|
|
|
|
}
|
|
|
|
declare const tinymce: TinyMCE;
|
2022-07-17 19:33:03 +02:00
|
|
|
export { AddOnManager, Annotator, AstNode, Bookmark, BookmarkManager, ControlSelection, DOMUtils, Delay, DomParser, DomParserSettings, DomSerializer, DomSerializerSettings, DomTreeWalker, Editor, EditorCommands, EditorEvent, EditorManager, EditorModeApi, EditorObservable, EditorOptions, EditorSelection, Entities, Env, EventDispatcher, EventUtils, EventTypes_d as Events, FakeClipboard, FocusManager, Format_d as Formats, Formatter, GeomRect, HtmlSerializer, HtmlSerializerSettings, I18n, IconManager, Model, ModelManager, NotificationApi, NotificationManager, NotificationSpec, Observable, Plugin, PluginManager, RangeUtils, RawEditorOptions, Rect, Resource, Schema, SchemaSettings, ScriptLoader, Shortcuts, StyleSheetLoader, Styles, TextSeeker, Theme, ThemeManager, TinyMCE, Tools, URI, Ui_d as Ui, UndoManager, VK, WindowManager, Writer, WriterSettings, tinymce as default };
|