@tiptap/extension-text-style
Version:
text style extension for tiptap
90 lines (80 loc) • 2.05 kB
text/typescript
import '../text-style/index.js'
import { Extension } from '@tiptap/core'
export type LineHeightOptions = {
/**
* A list of node names where the line height can be applied.
* @default ['textStyle']
* @example ['heading', 'paragraph']
*/
types: string[]
}
declare module '@tiptap/core' {
interface Commands<ReturnType> {
lineHeight: {
/**
* Set the line height
* @param lineHeight The line height
* @example editor.commands.setLineHeight('1.5')
*/
setLineHeight: (lineHeight: string) => ReturnType
/**
* Unset the line height
* @example editor.commands.unsetLineHeight()
*/
unsetLineHeight: () => ReturnType
}
}
}
// @ts-ignore because the module is not found during dts build
declare module '@tiptap/extension-text-style' {
interface TextStyleAttributes {
lineHeight?: string | null
}
}
/**
* This extension allows you to set the line-height for text.
* @see https://www.tiptap.dev/api/extensions/line-height
*/
export const LineHeight = Extension.create<LineHeightOptions>({
name: 'lineHeight',
addOptions() {
return {
types: ['textStyle'],
}
},
addGlobalAttributes() {
return [
{
types: this.options.types,
attributes: {
lineHeight: {
default: null,
parseHTML: element => element.style.lineHeight,
renderHTML: attributes => {
if (!attributes.lineHeight) {
return {}
}
return {
style: `line-height: ${attributes.lineHeight}`,
}
},
},
},
},
]
},
addCommands() {
return {
setLineHeight:
lineHeight =>
({ chain }) => {
return chain().setMark('textStyle', { lineHeight }).run()
},
unsetLineHeight:
() =>
({ chain }) => {
return chain().setMark('textStyle', { lineHeight: null }).removeEmptyTextStyle().run()
},
}
},
})