API reference
For projects using TypeScript, Draftail includes type definitions.
DraftailEditor
import { DraftailEditor } from "draftail"
const editor = <DraftailEditor />
To change the behavior of the editor, pass props to the DraftailEditor
component. Here are the available props, and their default values:
/** Initial content of the editor. Use this to edit pre-existing content. */
rawContentState?: RawDraftContentState | null
/** Called when changes occurred. Use this to persist editor content. */
onSave?: ((content: null | RawDraftContentState) => void) | null
/** Content of the editor, when using the editor as a controlled component. Incompatible with `rawContentState` and `onSave`. */
editorState?: EditorState | null
/** Called whenever the editor state is updated. Use this to manage the content of a controlled editor. Incompatible with `rawContentState` and `onSave`. */
onChange?: ((editorState: EditorState) => void) | null
/** Called when the editor receives focus. */
onFocus?: (() => void) | null
/** Called when the editor loses focus. */
onBlur?: (() => void) | null
/** Displayed when the editor is empty. Hidden if the user changes styling. */
placeholder?: string | null
/** Enable the use of horizontal rules in the editor. */
enableHorizontalRule: BoolControl
/** Enable the use of line breaks in the editor. */
enableLineBreak: BoolControl
/** Show undo control in the toolbar. */
showUndoControl: BoolControl
/** Show redo control in the toolbar. */
showRedoControl: BoolControl
/** Disable copy/paste of rich text in the editor. Default: true */
stripPastedStyles: boolean
/** Set if the editor supports multiple lines / blocks of text, or only a single line. Default: true */
multiline: boolean
/** Set whether spellcheck is turned on for your editor.
* See https://draftjs.org/docs/api-reference-editor.html#spellcheck.
*/
spellCheck: boolean
/** Set whether the editor should be rendered in readOnly mode.
* See https://draftjs.org/docs/api-reference-editor.html#readonly
*/
readOnly: boolean
/** Optionally set the overriding text alignment for this editor.
* See https://draftjs.org/docs/api-reference-editor.html#textalignment.
*/
textAlignment?: string | null
/** Optionally set the overriding text directionality for this editor.
* See https://draftjs.org/docs/api-reference-editor.html#textdirectionality.
*/
textDirectionality: TextDirectionality
/** Set if auto capitalization is turned on and how it behaves.
* See https://draftjs.org/docs/api-reference-editor.html#autocapitalize-string.
*/
autoCapitalize?: string | null
/** Set if auto complete is turned on and how it behaves.
* See https://draftjs.org/docs/api-reference-editor.html#autocomplete-string.
*/
autoComplete?: string | null
/** Set if auto correct is turned on and how it behaves.
* See https://draftjs.org/docs/api-reference-editor.html#autocorrect-string.
*/
autoCorrect?: string | null
/** See https://draftjs.org/docs/api-reference-editor.html#aria-props. */
ariaDescribedBy?: string | null
ariaExpanded?: boolean | null
ariaLabel?: string | null
ariaLabelledBy?: string | null
ariaOwneeID?: string | null
ariaRequired?: string | null
/** List of the available block types. */
blockTypes: ReadonlyArray<BlockTypeControl>
/** List of the available inline styles. */
inlineStyles: ReadonlyArray<InlineStyleControl>
/** List of the available entity types. */
entityTypes: ReadonlyArray<EntityTypeControl>
/** List of active decorators. */
decorators: ReadonlyArray<DraftDecorator>
/** List of extra toolbar controls. */
controls: ReadonlyArray<ControlControl | LegacyControlControl>
/** Optionally enable the command palette UI. */
commands: boolean | ReadonlyArray<CommandCategory>
/** List of plugins of the draft-js-plugins architecture. */
plugins: ReadonlyArray<any>
/** Optionally override the default Draftail toolbar, removing or replacing it. Default: Toolbar */
topToolbar?: React.ComponentType<ToolbarProps> | null
/** Optionally add a custom toolbar underneath the editor, e.g. for metrics. */
bottomToolbar?: React.ComponentType<MetaToolbarProps> | null
/** Optionally override the default command toolbar, removing or replacing it. Default: CommandPalette */
commandToolbar?: React.ComponentType<CommandPaletteProps> | null
/** Max level of nesting for list items. 0 = no nesting. Maximum = 10. Default: 1 */
maxListNesting: number
/** Frequency at which to call the onSave callback (ms). Default: 250 */
stateSaveInterval: number
rawContentState and onSave
rawContentState
and onSave
are used to initialise the editor with content, and to periodically save new content. They work with raw ContentState objects representing the editor’s content, or null
if the editor is empty.
This is the editor’s uncontrolled component API, which is easier to use for simple implementations. Have a look at the controlled component API as well, with editorState
and onChange
.
editorState and onChange
editorState
and onChange
are used to set the state of the editor, and update this state whenever there are changes to the editor’s content or selection. They work with EditorState
objects representing all of the editor’s state.
This is the editor’s controlled component API, matching that of other Draft.js examples.
Inline styles
How-to guide: Inline styles
const editor = <DraftailEditor inlineStyles={[...]} />
Each item in inlineStyles
can have the following props:
// Unique type shared between inline style instances.
type: string,
// CSS properties (in JS format) to apply for styling within the editor area.
style?: CSSProperties;
// Describes the control in the editor UI, concisely.
label?: string | null;
// Describes the control in the editor UI.
description?: string | null;
// Represents the control in the editor UI.
icon?: IconProp;
Blocks
How-to guide: Blocks
const editor = <DraftailEditor blockTypes={[...]} />
Each item in blockTypes
can have the following props:
// Unique type shared between block instances.
type: string,
// Describes the control in the editor UI, concisely.
label?: string | null;
// Describes the control in the editor UI.
description?: string | null;
// Represents the control in the editor UI.
icon?: IconProp;
// DOM element used to display the block within the editor area.
element?: string;
Entities
How-to guide: Entities
const editor = <DraftailEditor entityTypes={[...]} />
Each item in entityTypes
can have the following props:
// Unique type shared between entity instances.
type: string,
// Describes the control in the editor UI, concisely.
label?: string | null;
// Describes the control in the editor UI.
description?: string | null;
// Represents the control in the editor UI.
icon?: IconProp;
/** React component providing the UI to manage entities of this type. */
source: React.ComponentType<EntitySourceProps>;
/** React component to display inline entities. */
decorator?: React.ComponentType<EntityDecoratorProps>;
/** React component to display block-level entities. */
block?: React.ComponentType<EntityBlockProps>;
/** Custom copy-paste processing checker. */
onPaste?: (
text: string,
html: string | null | undefined,
editorState: EditorState,
helpers: {
setEditorState: (state: EditorState) => void;
getEditorState: () => EditorState;
},
entityType: EntityTypeControl,
) => "handled" | "not-handled";
/** Array of attributes the entity uses, to preserve when filtering entities on paste.
* If undefined, all entity data is preserved.
*/
attributes?: ReadonlyArray<string>;
/** Attribute - regex mapping, to preserve entities based on their data on paste.
* For example, { url: '^https:' } will only preserve links that point to HTTPS URLs.
*/
allowlist?: { [attr: string]: string };
Decorators
How-to guide: Decorators
const editor = <DraftailEditor decorators={[...]} />
Each item in decorators
can have the following props:
// Determines which pieces of content are to be decorated.
strategy: (block: ContentBlock, callback: (start: number, end: number) => void, contentState: ContentState) => void,
// React component to display the decoration.
component: ComponentType<{}>,
Controls
How-to guide: Controls
const editor = <DraftailEditor controls={[...]} />
Each item in controls
can either be inline
, block
, or meta
, and have the following props:
// Or block or meta.
inline: {
// Retrieve the full Draft.js EditorState.
getEditorState: () => EditorState,
// Change any part of the EditorState.
onChange: (EditorState) => void,
}
Plugins
How-to guide: Plugins
const editor = <DraftailEditor plugins={[...]} />
Each item in plugins
follows the draft-js-plugins API.
Managing focus
The DraftailEditor
has a focus()
API like that of Draft.js. Use it to imperatively move focus to the editor. There are also onFocus
and onBlur
props to hook into the editor’s focus lifecycle, for example for form validation.
Content format identifiers
Draftail exports identifiers for common rich text formats to ensure the same identifiers are used consistently.
import { INLINE_STYLE, BLOCK_TYPE, ENTITY_TYPE } from "draftail"
For inline styles:
// See https://github.com/facebook/draft-js/blob/master/src/model/immutable/DefaultDraftInlineStyle.js
export const INLINE_STYLE = {
BOLD: "BOLD",
ITALIC: "ITALIC",
CODE: "CODE",
UNDERLINE: "UNDERLINE",
STRIKETHROUGH: "STRIKETHROUGH",
MARK: "MARK",
QUOTATION: "QUOTATION",
SMALL: "SMALL",
SAMPLE: "SAMPLE",
INSERT: "INSERT",
DELETE: "DELETE",
KEYBOARD: "KEYBOARD",
SUPERSCRIPT: "SUPERSCRIPT",
SUBSCRIPT: "SUBSCRIPT",
}
For blocks:
// See https://github.com/facebook/draft-js/blob/master/src/model/immutable/DefaultDraftBlockRenderMap.js
export const BLOCK_TYPE = {
// This is used to represent a normal text block (paragraph).
UNSTYLED: "unstyled",
HEADER_ONE: "header-one",
HEADER_TWO: "header-two",
HEADER_THREE: "header-three",
HEADER_FOUR: "header-four",
HEADER_FIVE: "header-five",
HEADER_SIX: "header-six",
UNORDERED_LIST_ITEM: "unordered-list-item",
ORDERED_LIST_ITEM: "ordered-list-item",
BLOCKQUOTE: "blockquote",
CODE: "code-block",
// This represents a "custom" block, not for rich text, with arbitrary content.
ATOMIC: "atomic",
}
For entities:
export const ENTITY_TYPE = {
LINK: "LINK",
IMAGE: "IMAGE",
HORIZONTAL_RULE: "HORIZONTAL_RULE",
}
Data conversion helpers
How-to guide: Data conversion helpers
Draftail exports the methods it uses internally to initialise the editor’s content via rawContentState
and persist it in onSave
: createEditorStateFromRaw
, and serialiseEditorStateToRaw
.
createEditorStateFromRaw
Creates a new EditorState from a RawDraftContentState, or an empty editor state by passing null
.
createEditorStateFromRaw = (rawContentState: ?RawDraftContentState) =>
EditorState
serialiseEditorStateToRaw
Serialises the editorState using convertToRaw
, but returns null
if the editor content is empty (no text, entities, styles).
serialiseEditorStateToRaw = (editorState: EditorState) => RawDraftContentState
Reusable UI components
Some of Draftail’s UI components can be reused to more easily build extensions that are consistent.
Icon
The Icon can be reused to have consistent icon sizing between different extensions and the toolbar.
import { Icon } from "draftail"
const icon = <Icon icon="#square" />
Supported props:
icon?: string | string[] | JSX.Element;;
title?: string | null;
className?: string | null;
There is further documentation about what formats are allowed for icon
: Customising icons.
ToolbarButton
The ToolbarButton can be reused when building custom controls
in the toolbar.
import { ToolbarButton } from "draftail"
const button = <ToolbarButton />
Supproted props:
name: ?string,
active: boolean,
label: ?string,
title: ?string,
icon: ?IconProp,
onClick: ?(string) => void,