import { Command, Mark, markInputRule, markPasteRule, mergeAttributes, } from '@tiptap/core' export interface BoldOptions { HTMLAttributes: { [key: string]: any }, } declare module '@tiptap/core' { interface Commands { setBold: () => Command, toggleBold: () => Command, unsetBold: () => Command, } } export const starInputRegex = /(?:^|\s)((?:\*\*)((?:[^*]+))(?:\*\*))$/gm export const starPasteRegex = /(?:^|\s)((?:\*\*)((?:[^*]+))(?:\*\*))/gm export const underscoreInputRegex = /(?:^|\s)((?:__)((?:[^__]+))(?:__))$/gm export const underscorePasteRegex = /(?:^|\s)((?:__)((?:[^__]+))(?:__))/gm export const Bold = Mark.create({ name: 'bold', defaultOptions: { HTMLAttributes: {}, }, parseHTML() { return [ { tag: 'strong', }, { tag: 'b', getAttrs: node => (node as HTMLElement).style.fontWeight !== 'normal' && null, }, { style: 'font-weight', getAttrs: value => /^(bold(er)?|[5-9]\d{2,})$/.test(value as string) && null, }, ] }, renderHTML({ HTMLAttributes }) { return ['strong', mergeAttributes(this.options.HTMLAttributes, HTMLAttributes), 0] }, addCommands() { return { /** * Set a bold mark */ setBold: () => ({ commands }) => { return commands.setMark('bold') }, /** * Toggle a bold mark */ toggleBold: () => ({ commands }) => { return commands.toggleMark('bold') }, /** * Unset a bold mark */ unsetBold: () => ({ commands }) => { return commands.unsetMark('bold') }, } }, addKeyboardShortcuts() { return { 'Mod-b': () => this.editor.commands.toggleBold(), } }, addInputRules() { return [ markInputRule(starInputRegex, this.type), markInputRule(underscoreInputRegex, this.type), ] }, addPasteRules() { return [ markPasteRule(starPasteRegex, this.type), markPasteRule(underscorePasteRegex, this.type), ] }, })