Module: @lexical/clipboard
Interfaces
Functions
$generateJSONFromSelectedNodes
▸ $generateJSONFromSelectedNodes<SerializedNode>(editor, selection): Object
Gets the Lexical JSON of the nodes inside the provided Selection.
Type parameters
| Name | Type | 
|---|---|
| SerializedNode | extends BaseSerializedNode | 
Parameters
| Name | Type | Description | 
|---|---|---|
| editor | LexicalEditor | LexicalEditor to get the JSON content from. | 
| selection | null|BaseSelection | Selection to get the JSON content from. | 
Returns
Object
an object with the editor namespace and a list of serializable nodes as JavaScript objects.
| Name | Type | 
|---|---|
| namespace | string | 
| nodes | SerializedNode[] | 
Defined in
packages/lexical-clipboard/src/clipboard.ts:345
$generateNodesFromSerializedNodes
▸ $generateNodesFromSerializedNodes(serializedNodes): LexicalNode[]
This method takes an array of objects conforming to the BaseSeralizedNode interface and returns an Array containing instances of the corresponding LexicalNode classes registered on the editor. Normally, you'd get an Array of BaseSerialized nodes from $generateJSONFromSelectedNodes
Parameters
| Name | Type | Description | 
|---|---|---|
| serializedNodes | BaseSerializedNode[] | an Array of objects conforming to the BaseSerializedNode interface. | 
Returns
an Array of Lexical Node objects.
Defined in
packages/lexical-clipboard/src/clipboard.ts:375
$getClipboardDataFromSelection
▸ $getClipboardDataFromSelection(selection?): LexicalClipboardData
Serialize the content of the current selection to strings in text/plain, text/html, and application/x-lexical-editor (Lexical JSON) formats (as available).
Parameters
| Name | Type | Description | 
|---|---|---|
| selection | null|BaseSelection | the selection to serialize (defaults to $getSelection()) | 
Returns
LexicalClipboardData
Defined in
packages/lexical-clipboard/src/clipboard.ts:517
$getHtmlContent
▸ $getHtmlContent(editor, selection?): string
Returns the currently selected Lexical content as an HTML string, relying on the logic defined in the exportDOM methods on the LexicalNode classes. Note that this will not return the HTML content of the entire editor (unless all the content is included in the current selection).
Parameters
| Name | Type | Description | 
|---|---|---|
| editor | LexicalEditor | LexicalEditor instance to get HTML content from | 
| selection | null|BaseSelection | The selection to use (default is $getSelection()) | 
Returns
string
a string of HTML content
Defined in
packages/lexical-clipboard/src/clipboard.ts:51
$getLexicalContent
▸ $getLexicalContent(editor, selection?): null | string
Returns the currently selected Lexical content as a JSON string, relying on the logic defined in the exportJSON methods on the LexicalNode classes. Note that this will not return the JSON content of the entire editor (unless all the content is included in the current selection).
Parameters
| Name | Type | Description | 
|---|---|---|
| editor | LexicalEditor | LexicalEditor instance to get the JSON content from | 
| selection | null|BaseSelection | The selection to use (default is $getSelection()) | 
Returns
null | string
Defined in
packages/lexical-clipboard/src/clipboard.ts:80
$insertDataTransferForPlainText
▸ $insertDataTransferForPlainText(dataTransfer, selection): void
Attempts to insert content of the mime-types text/plain or text/uri-list from the provided DataTransfer object into the editor at the provided selection. text/uri-list is only used if text/plain is not also provided.
Parameters
| Name | Type | Description | 
|---|---|---|
| dataTransfer | DataTransfer | an object conforming to the [DataTransfer interface] (https://html.spec.whatwg.org/multipage/dnd.html#the-datatransfer-interface) | 
| selection | BaseSelection | the selection to use as the insertion point for the content in the DataTransfer object | 
Returns
void
Defined in
packages/lexical-clipboard/src/clipboard.ts:107
$insertDataTransferForRichText
▸ $insertDataTransferForRichText(dataTransfer, selection, editor): void
Attempts to insert content of the mime-types application/x-lexical-editor, text/html, text/plain, or text/uri-list (in descending order of priority) from the provided DataTransfer object into the editor at the provided selection.
Parameters
| Name | Type | Description | 
|---|---|---|
| dataTransfer | DataTransfer | an object conforming to the [DataTransfer interface] (https://html.spec.whatwg.org/multipage/dnd.html#the-datatransfer-interface) | 
| selection | BaseSelection | the selection to use as the insertion point for the content in the DataTransfer object | 
| editor | LexicalEditor | the LexicalEditor the content is being inserted into. | 
Returns
void
Defined in
packages/lexical-clipboard/src/clipboard.ts:128
$insertGeneratedNodes
▸ $insertGeneratedNodes(editor, nodes, selection): void
Inserts Lexical nodes into the editor using different strategies depending on some simple selection-based heuristics. If you're looking for a generic way to to insert nodes into the editor at a specific selection point, you probably want lexical.$insertNodes
Parameters
| Name | Type | Description | 
|---|---|---|
| editor | LexicalEditor | LexicalEditor instance to insert the nodes into. | 
| nodes | LexicalNode[] | The nodes to insert. | 
| selection | BaseSelection | The selection to insert the nodes into. | 
Returns
void
Defined in
packages/lexical-clipboard/src/clipboard.ts:215
copyToClipboard
▸ copyToClipboard(editor, event, data?): Promise<boolean>
Copies the content of the current selection to the clipboard in text/plain, text/html, and application/x-lexical-editor (Lexical JSON) formats.
Parameters
| Name | Type | Description | 
|---|---|---|
| editor | LexicalEditor | the LexicalEditor instance to copy content from | 
| event | null|ClipboardEvent | the native browser ClipboardEvent to add the content to. | 
| data? | LexicalClipboardData | - | 
Returns
Promise<boolean>
Defined in
packages/lexical-clipboard/src/clipboard.ts:404
setLexicalClipboardDataTransfer
▸ setLexicalClipboardDataTransfer(clipboardData, data): void
Call setData on the given clipboardData for each MIME type present in the given data (from $getClipboardDataFromSelection)
Parameters
| Name | Type | Description | 
|---|---|---|
| clipboardData | DataTransfer | the event.clipboardData to populate from data | 
| data | LexicalClipboardData | The lexical data | 
Returns
void