Skip to content

Input Rule

Execute some action when a certain pattern is typed. This is based on the prosemirror-inputrules.

Usage

You can directly pass an InputRule instance to defineInputRule.

ts
import { 
defineInputRule
} from 'prosekit/extensions/input-rule'
import {
InputRule
} from 'prosekit/pm/inputrules'
/** * Converts three dots to an ellipsis character. */ function
defineEllipsis
() {
const
rule
= new
InputRule
(/\.{3}$/, '…')
return
defineInputRule
(
rule
)
}

Use defineTextBlockInputRule to create a new input rule that can change the current text block into a different node type.

ts
import { 
defineTextBlockInputRule
} from 'prosekit/extensions/input-rule'
/** * Converts the text block to a heading when `#` is typed at the start of a new * line followed by a space. */ export function
defineHeadingInputRule
() {
return
defineTextBlockInputRule
({
regex
: /^(#{1,6})\s$/,
type
: 'heading',
attrs
: (
match
) => {
const
level
: number =
match
[1]?.
length
?? 1
return {
level
}
}, }) }

Use defineWrappingInputRule to create a new input rule that can change the current text block into a different node type.

ts
import { 
defineWrappingInputRule
} from 'prosekit/extensions/input-rule'
/** * Wraps the text block in a blockquote when `>` is typed at the start of a new * line followed by a space. */ export function
defineBlockquoteInputRule
() {
return
defineWrappingInputRule
({
regex
: /^>\s/,
type
: 'blockquote',
}) }

API Reference