Skip to main content

@lexical/link

Classes

AutoLinkNode

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:469

Extends

Constructors

Constructor

new AutoLinkNode(url?, attributes?, key?): AutoLinkNode

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:474

Parameters
url?

string = ''

attributes?

AutoLinkAttributes = {}

key?

string

Returns

AutoLinkNode

Overrides

LinkNode.constructor

Properties

__isUnlinked

__isUnlinked: boolean

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:472

Indicates whether the autolink was ever unlinked. *

Methods

$config()

$config(): StaticNodeConfigRecord<"autolink", { json: SerializationSchema<{ isUnlinked: boolean; }>; }>

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:524

Override this to implement the new static node configuration protocol, this method is called directly on the prototype and must not depend on anything initialized in the constructor. Generally it should be a trivial implementation.

Returns

StaticNodeConfigRecord<"autolink", { json: SerializationSchema<{ isUnlinked: boolean; }>; }>

Example
class MyNode extends TextNode {
$config() {
return this.config('my-node', {extends: TextNode});
}
}
Overrides

LinkNode.$config

afterCloneFrom()

afterCloneFrom(prevNode): void

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:486

Perform any state updates on the clone of prevNode that are not already handled by the constructor call in the static clone method. If you have state to update in your clone that is not handled directly by the constructor, it is advisable to override this method but it is required to include a call to super.afterCloneFrom(prevNode) in your implementation. This is only intended to be called by $cloneWithProperties function or via a super call.

Parameters
prevNode

this

Returns

void

Example
class ClassesTextNode extends TextNode {
// Not shown: static getType, static importJSON, exportJSON, createDOM, updateDOM
__classes = new Set<string>();
static clone(node: ClassesTextNode): ClassesTextNode {
// The inherited TextNode constructor is used here, so
// classes is not set by this method.
return new ClassesTextNode(node.__text, node.__key);
}
afterCloneFrom(node: this): void {
// This calls TextNode.afterCloneFrom and LexicalNode.afterCloneFrom
// for necessary state updates
super.afterCloneFrom(node);
this.__addClasses(node.__classes);
}
// This method is a private implementation detail, it is not
// suitable for the public API because it does not call getWritable
__addClasses(classNames: Iterable<string>): this {
for (const className of classNames) {
this.__classes.add(className);
}
return this;
}
addClass(...classNames: string[]): this {
return this.getWritable().__addClasses(classNames);
}
removeClass(...classNames: string[]): this {
const node = this.getWritable();
for (const className of classNames) {
this.__classes.delete(className);
}
return this;
}
getClasses(): Set<string> {
return this.getLatest().__classes;
}
}
Overrides

LinkNode.afterCloneFrom

canBeEmpty()

canBeEmpty(): boolean

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:255

Returns

boolean

Inherited from

LinkNode.canBeEmpty

canInsertTextAfter()

canInsertTextAfter(): false

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:251

Returns

false

Inherited from

LinkNode.canInsertTextAfter

canInsertTextBefore()

canInsertTextBefore(): false

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:247

Returns

false

Inherited from

LinkNode.canInsertTextBefore

createDOM()

createDOM(config): LinkHTMLElementType

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:505

Called during the reconciliation process to determine which nodes to insert into the DOM for this Lexical Node.

This method must return exactly one HTMLElement. Nested elements are not supported.

Do not attempt to update the Lexical EditorState during this phase of the update lifecycle.

Parameters
config

EditorConfig

Returns

LinkHTMLElementType

Overrides

LinkNode.createDOM

exportJSON()

exportJSON(): SerializedAutoLinkNode

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:533

Controls how the this node is serialized to JSON. This is important for copy and paste between Lexical editors sharing the same namespace. It's also important if you're serializing to JSON for persistent storage somewhere. See Serialization & Deserialization.

Returns

SerializedAutoLinkNode

Overrides

LinkNode.exportJSON

extractWithChild()

extractWithChild(child, selection, destination): boolean

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:263

Parameters
child

LexicalNode

selection

BaseSelection

destination

"clone" | "html"

Returns

boolean

Inherited from

LinkNode.extractWithChild

getIsUnlinked()

getIsUnlinked(): boolean

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:495

Returns

boolean

getRel()

getRel(): string | null

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:218

Returns

string | null

Inherited from

LinkNode.getRel

getTarget()

getTarget(): string | null

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:208

Returns

string | null

Inherited from

LinkNode.getTarget

getTitle()

getTitle(): string | null

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:228

Returns

string | null

Inherited from

LinkNode.getTitle

getURL()

getURL(): string

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:198

Returns

string

Inherited from

LinkNode.getURL

insertNewAfter()

insertNewAfter(_, restoreSelection?): ElementNode | null

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:540

Parameters
_

RangeSelection

restoreSelection?

boolean = true

Returns

ElementNode | null

Overrides

LinkNode.insertNewAfter

isEmailURI()

isEmailURI(): boolean

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:282

Returns

boolean

Inherited from

LinkNode.isEmailURI

isInline()

isInline(): true

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:259

If the method is overridden and returns true, ensure that canBeEmpty() returns false for the inline node to work correctly

Returns

true

Inherited from

LinkNode.isInline

isWebSiteURI()

isWebSiteURI(): boolean

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:286

Returns

boolean

Inherited from

LinkNode.isWebSiteURI

sanitizeUrl()

sanitizeUrl(url): string

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:174

Parameters
url

string

Returns

string

Inherited from

LinkNode.sanitizeUrl

setIsUnlinked()

setIsUnlinked(value): this

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:499

Parameters
value

boolean

Returns

this

setRel()

setRel(rel): this

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:222

Parameters
rel

string | null

Returns

this

Inherited from

LinkNode.setRel

setTarget()

setTarget(target): this

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:212

Parameters
target

string | null

Returns

this

Inherited from

LinkNode.setTarget

setTitle()

setTitle(title): this

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:232

Parameters
title

string | null

Returns

this

Inherited from

LinkNode.setTitle

setURL()

setURL(url): this

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:202

Parameters
url

string

Returns

this

Inherited from

LinkNode.setURL

shouldMergeAdjacentLink(_otherLink): boolean

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:491

Parameters

LinkNode

Returns

boolean

Overrides

LinkNode.shouldMergeAdjacentLink

updateDOM()

updateDOM(prevNode, anchor, config): boolean

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:513

Called when a node changes and should update the DOM in whatever way is necessary to make it align with any changes that might have happened during the update.

Returning "true" here will cause lexical to unmount and recreate the DOM node (by calling createDOM). You would need to do this if the element tag changes, for instance.

Parameters
prevNode

this

anchor

LinkHTMLElementType

config

EditorConfig

Returns

boolean

Overrides

LinkNode.updateDOM

updateLinkDOM()

updateLinkDOM(prevNode, anchor, config): void

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:129

Parameters
prevNode

AutoLinkNode | null

anchor

LinkHTMLElementType

config

EditorConfig

Returns

void

Inherited from

LinkNode.updateLinkDOM

importDOM()

static importDOM(): null

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:528

Returns

null

Overrides

LinkNode.importDOM


LinkNode

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:91

Extends

Extended by

Constructors

Constructor

new LinkNode(url?, attributes?, key?): LinkNode

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:101

Parameters
url?

string = ''

attributes?

LinkAttributes = {}

key?

string

Returns

LinkNode

Overrides

ElementNode.constructor

Methods

$config()

$config(): StaticNodeConfigRecord<"link", { json: SerializationSchema<{ rel: string | null; target: string | null; title: string | null; url: string; }>; }>

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:170

Override this to implement the new static node configuration protocol, this method is called directly on the prototype and must not depend on anything initialized in the constructor. Generally it should be a trivial implementation.

Returns

StaticNodeConfigRecord<"link", { json: SerializationSchema<{ rel: string | null; target: string | null; title: string | null; url: string; }>; }>

Example
class MyNode extends TextNode {
$config() {
return this.config('my-node', {extends: TextNode});
}
}
Overrides

ElementNode.$config

afterCloneFrom()

afterCloneFrom(prevNode): void

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:114

Perform any state updates on the clone of prevNode that are not already handled by the constructor call in the static clone method. If you have state to update in your clone that is not handled directly by the constructor, it is advisable to override this method but it is required to include a call to super.afterCloneFrom(prevNode) in your implementation. This is only intended to be called by $cloneWithProperties function or via a super call.

Parameters
prevNode

this

Returns

void

Example
class ClassesTextNode extends TextNode {
// Not shown: static getType, static importJSON, exportJSON, createDOM, updateDOM
__classes = new Set<string>();
static clone(node: ClassesTextNode): ClassesTextNode {
// The inherited TextNode constructor is used here, so
// classes is not set by this method.
return new ClassesTextNode(node.__text, node.__key);
}
afterCloneFrom(node: this): void {
// This calls TextNode.afterCloneFrom and LexicalNode.afterCloneFrom
// for necessary state updates
super.afterCloneFrom(node);
this.__addClasses(node.__classes);
}
// This method is a private implementation detail, it is not
// suitable for the public API because it does not call getWritable
__addClasses(classNames: Iterable<string>): this {
for (const className of classNames) {
this.__classes.add(className);
}
return this;
}
addClass(...classNames: string[]): this {
return this.getWritable().__addClasses(classNames);
}
removeClass(...classNames: string[]): this {
const node = this.getWritable();
for (const className of classNames) {
this.__classes.delete(className);
}
return this;
}
getClasses(): Set<string> {
return this.getLatest().__classes;
}
}
Overrides

ElementNode.afterCloneFrom

canBeEmpty()

canBeEmpty(): boolean

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:255

Returns

boolean

Overrides

ElementNode.canBeEmpty

canInsertTextAfter()

canInsertTextAfter(): false

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:251

Returns

false

Overrides

ElementNode.canInsertTextAfter

canInsertTextBefore()

canInsertTextBefore(): false

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:247

Returns

false

Overrides

ElementNode.canInsertTextBefore

createDOM()

createDOM(config): LinkHTMLElementType

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:122

Called during the reconciliation process to determine which nodes to insert into the DOM for this Lexical Node.

This method must return exactly one HTMLElement. Nested elements are not supported.

Do not attempt to update the Lexical EditorState during this phase of the update lifecycle.

Parameters
config

EditorConfig

Returns

LinkHTMLElementType

Overrides

ElementNode.createDOM

exportJSON()

exportJSON(): SerializedLinkNode | SerializedAutoLinkNode

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:188

Controls how the this node is serialized to JSON. This is important for copy and paste between Lexical editors sharing the same namespace. It's also important if you're serializing to JSON for persistent storage somewhere. See Serialization & Deserialization.

Returns

SerializedLinkNode | SerializedAutoLinkNode

Overrides

ElementNode.exportJSON

extractWithChild()

extractWithChild(child, selection, destination): boolean

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:263

Parameters
child

LexicalNode

selection

BaseSelection

destination

"clone" | "html"

Returns

boolean

Overrides

ElementNode.extractWithChild

getRel()

getRel(): string | null

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:218

Returns

string | null

getTarget()

getTarget(): string | null

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:208

Returns

string | null

getTitle()

getTitle(): string | null

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:228

Returns

string | null

getURL()

getURL(): string

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:198

Returns

string

insertNewAfter()

insertNewAfter(_, restoreSelection?): ElementNode | null

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:238

Parameters
_

RangeSelection

restoreSelection?

boolean = true

Returns

ElementNode | null

Overrides

ElementNode.insertNewAfter

isEmailURI()

isEmailURI(): boolean

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:282

Returns

boolean

isInline()

isInline(): true

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:259

If the method is overridden and returns true, ensure that canBeEmpty() returns false for the inline node to work correctly

Returns

true

Overrides

ElementNode.isInline

isWebSiteURI()

isWebSiteURI(): boolean

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:286

Returns

boolean

sanitizeUrl()

sanitizeUrl(url): string

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:174

Parameters
url

string

Returns

string

setRel()

setRel(rel): this

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:222

Parameters
rel

string | null

Returns

this

setTarget()

setTarget(target): this

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:212

Parameters
target

string | null

Returns

this

setTitle()

setTitle(title): this

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:232

Parameters
title

string | null

Returns

this

setURL()

setURL(url): this

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:202

Parameters
url

string

Returns

this

shouldMergeAdjacentLink(otherLink): boolean

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:292

Parameters

LinkNode

Returns

boolean

updateDOM()

updateDOM(prevNode, anchor, config): boolean

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:152

Called when a node changes and should update the DOM in whatever way is necessary to make it align with any changes that might have happened during the update.

Returning "true" here will cause lexical to unmount and recreate the DOM node (by calling createDOM). You would need to do this if the element tag changes, for instance.

Parameters
prevNode

this

anchor

LinkHTMLElementType

config

EditorConfig

Returns

boolean

Overrides

ElementNode.updateDOM

updateLinkDOM()

updateLinkDOM(prevNode, anchor, config): void

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:129

Parameters
prevNode

LinkNode | null

anchor

LinkHTMLElementType

config

EditorConfig

Returns

void

importDOM()

static importDOM(): DOMConversionMap | null

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:161

Returns

DOMConversionMap | null

Overrides

ElementNode.importDOM

Interfaces

AutoLinkConfig

Defined in: packages/lexical-link/src/LexicalAutoLinkExtension.ts:525

Properties

changeHandlers

changeHandlers: ChangeHandler[]

Defined in: packages/lexical-link/src/LexicalAutoLinkExtension.ts:526

excludeParents

excludeParents: (parent) => boolean[]

Defined in: packages/lexical-link/src/LexicalAutoLinkExtension.ts:527

Parameters
parent

ElementNode

Returns

boolean

matchers

matchers: LinkMatcher[]

Defined in: packages/lexical-link/src/LexicalAutoLinkExtension.ts:528

separatorRegex

separatorRegex: RegExp

Defined in: packages/lexical-link/src/LexicalAutoLinkExtension.ts:534

The regular expression used to determine whether surrounding characters count as separators when validating auto-link boundaries. Defaults to /[.,;\s]/.


ClickableLinkConfig

Defined in: packages/lexical-link/src/ClickableLinkExtension.ts:40

Properties

disabled

disabled: boolean

Defined in: packages/lexical-link/src/ClickableLinkExtension.ts:44

Disable this extension when true (default false)

newTab

newTab: boolean

Defined in: packages/lexical-link/src/ClickableLinkExtension.ts:42

Open clicked links in a new tab when true (default false)

Type Aliases

AutoLinkAttributes

AutoLinkAttributes = Partial<Spread<LinkAttributes, { isUnlinked?: boolean; }>>

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:62


ChangeHandler

ChangeHandler = (url, prevUrl) => void

Defined in: packages/lexical-link/src/LexicalAutoLinkExtension.ts:36

Parameters

url

string | null

prevUrl

string | null

Returns

void


LinkAttributes

LinkAttributes = object

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:56

Properties

rel?

optional rel?: null | string

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:57

target?

optional target?: null | string

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:58

title?

optional title?: null | string

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:59


LinkMatcher

LinkMatcher = (text) => LinkMatcherResult | null

Defined in: packages/lexical-link/src/LexicalAutoLinkExtension.ts:49

Parameters

text

string

Returns

LinkMatcherResult | null


SerializedAutoLinkNode

SerializedAutoLinkNode = Spread<{ isUnlinked: boolean; }, SerializedLinkNode>

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:456


SerializedLinkNode

SerializedLinkNode = Spread<{ url: string; }, Spread<LinkAttributes, SerializedElementNode>>

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:66

Variables

AutoLinkExtension

const AutoLinkExtension: LexicalExtension<AutoLinkConfig, "@lexical/link/AutoLink", unknown, unknown>

Defined in: packages/lexical-link/src/LexicalAutoLinkExtension.ts:623

An extension to automatically create AutoLinkNode from text that matches the configured matchers. No default implementation is provided for any matcher, see createLinkMatcherWithRegExp for a helper function to create a matcher from a RegExp, and the Playground's AutoLinkPlugin for some example RegExps that could be used.

The given matchers and changeHandlers will be merged by concatenating the configured arrays.


ClickableLinkExtension

const ClickableLinkExtension: LexicalExtension<ClickableLinkConfig, "@lexical/link/ClickableLink", NamedSignalsOutput<ClickableLinkConfig>, unknown>

Defined in: packages/lexical-link/src/ClickableLinkExtension.ts:132

Normally in a Lexical editor the CLICK_COMMAND on a LinkNode will cause the selection to change instead of opening a link. This extension can be used to restore the default behavior, e.g. when the editor is not editable.


LinkExtension

const LinkExtension: LexicalExtension<LinkConfig, "@lexical/link/Link", NamedSignalsOutput<LinkConfig>, unknown>

Defined in: packages/lexical-link/src/LexicalLinkExtension.ts:144

Provides LinkNode, an implementation of TOGGLE_LINK_COMMAND, and a PASTE_COMMAND listener to wrap selected nodes in a link when a URL is pasted and validateUrl is defined.


LinkImportExtension

const LinkImportExtension: LexicalExtension<ExtensionConfigBase, "@lexical/link/Import", unknown, unknown>

Defined in: packages/lexical-link/src/LinkImportExtension.ts:61

Experimental

Bundles LinkImportRules together with the runtime LinkExtension. The application is expected to already have CoreImportExtension (or some equivalent) in its dependency graph — the core/text/paragraph/inline-format rules are a shared baseline, not something this leaf importer should re-declare.


LinkImportRules

const LinkImportRules: DOMImportRule<ElementSelectorBuilder<HTMLAnchorElement, Record<string, never>>>[]

Defined in: packages/lexical-link/src/LinkImportExtension.ts:50

Experimental

Import rules for LinkNode.


const TOGGLE_LINK_COMMAND: LexicalCommand<string | object & LinkAttributes | null>

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:580


const toggleLink: (urlOrAttributes, attributes) => void = $toggleLink

Defined in: packages/lexical-link/src/index.ts:43

Generates or updates a LinkNode. It can also delete a LinkNode if the URL is null, but saves any children and brings them up to the parent node.

Parameters

urlOrAttributes

string | LinkAttributes & object | null

The URL the link directs to, or an attributes object with an url property

attributes?

LinkAttributes = {}

Optional HTML a tag attributes. { target, rel, title }

Returns

void

Deprecated

renamed to $toggleLink by @lexical/eslint-plugin rules-of-lexical

Functions

$createAutoLinkNode()

$createAutoLinkNode(url?, attributes?): AutoLinkNode

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:562

Takes a URL and creates an AutoLinkNode. AutoLinkNodes are generally automatically generated during typing, which is especially useful when a button to generate a LinkNode is not practical.

Parameters

url?

string = ''

The URL the LinkNode should direct to.

attributes?

Partial<Spread<LinkAttributes, { isUnlinked?: boolean; }>>

Optional HTML a tag attributes. { target, rel, title }

Returns

AutoLinkNode

The LinkNode.


$createLinkNode()

$createLinkNode(url?, attributes?): LinkNode

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:438

Takes a URL and creates a LinkNode.

Parameters

url?

string = ''

The URL the LinkNode should direct to.

attributes?

LinkAttributes

Optional HTML a tag attributes { target, rel, title }

Returns

LinkNode

The LinkNode.


$isAutoLinkNode()

$isAutoLinkNode(node): node is AutoLinkNode

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:574

Determines if node is an AutoLinkNode.

Parameters

node

LexicalNode | null | undefined

The node to be checked.

Returns

node is AutoLinkNode

true if node is an AutoLinkNode, false otherwise.


$isLinkNode()

$isLinkNode(node): node is LinkNode

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:450

Determines if node is a LinkNode.

Parameters

node

LexicalNode | null | undefined

The node to be checked.

Returns

node is LinkNode

true if node is a LinkNode, false otherwise.


$toggleLink(urlOrAttributes, attributes?): void

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:709

Generates or updates a LinkNode. It can also delete a LinkNode if the URL is null, but saves any children and brings them up to the parent node.

Parameters

urlOrAttributes

string | LinkAttributes & object | null

The URL the link directs to, or an attributes object with an url property

attributes?

LinkAttributes = {}

Optional HTML a tag attributes. { target, rel, title }

Returns

void


createLinkMatcherWithRegExp()

createLinkMatcherWithRegExp(regExp, urlTransformer?): (text) => { index: number; length: number; text: string; url: string; } | null

Defined in: packages/lexical-link/src/LexicalAutoLinkExtension.ts:51

Parameters

regExp

RegExp

urlTransformer?

(text) => string

Returns

(text) => { index: number; length: number; text: string; url: string; } | null


formatUrl()

formatUrl(url): string

Defined in: packages/lexical-link/src/LexicalLinkNode.ts:909

Formats a URL string by adding appropriate protocol if missing

Parameters

url

string

URL to format

Returns

string

Formatted URL with appropriate protocol


registerAutoLink(editor, config?): () => void

Defined in: packages/lexical-link/src/LexicalAutoLinkExtension.ts:544

Parameters

editor

LexicalEditor

config?

Partial<AutoLinkConfig> & Omit<AutoLinkConfig, "separatorRegex"> = defaultConfig

Returns

() => void


registerClickableLink(editor, stores, eventOptions?): () => void

Defined in: packages/lexical-link/src/ClickableLinkExtension.ts:47

Parameters

editor

LexicalEditor

stores

NamedSignalsOutput<ClickableLinkConfig>

eventOptions?

Pick<AddEventListenerOptions, "signal"> = {}

Returns

() => void