(function (global, factory) { typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@tiptap/core')) : typeof define === 'function' && define.amd ? define(['exports', '@tiptap/core'], factory) : (global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global["@tiptap/extension-code"] = {}, global.core)); })(this, (function (exports, core) { 'use strict'; /** * Regular expressions to match inline code blocks enclosed in backticks. * It matches: * - An opening backtick, followed by * - Any text that doesn't include a backtick (captured for marking), followed by * - A closing backtick. * This ensures that any text between backticks is formatted as code, * regardless of the surrounding characters (exception being another backtick). */ const inputRegex = /(^|[^`])`([^`]+)`(?!`)/; /** * Matches inline code while pasting. */ const pasteRegex = /(^|[^`])`([^`]+)`(?!`)/g; /** * This extension allows you to mark text as inline code. * @see https://tiptap.dev/api/marks/code */ const Code = core.Mark.create({ name: 'code', addOptions() { return { HTMLAttributes: {}, }; }, excludes: '_', code: true, exitable: true, parseHTML() { return [ { tag: 'code' }, ]; }, renderHTML({ HTMLAttributes }) { return ['code', core.mergeAttributes(this.options.HTMLAttributes, HTMLAttributes), 0]; }, addCommands() { return { setCode: () => ({ commands }) => { return commands.setMark(this.name); }, toggleCode: () => ({ commands }) => { return commands.toggleMark(this.name); }, unsetCode: () => ({ commands }) => { return commands.unsetMark(this.name); }, }; }, addKeyboardShortcuts() { return { 'Mod-e': () => this.editor.commands.toggleCode(), }; }, addInputRules() { return [ core.markInputRule({ find: inputRegex, type: this.type, }), ]; }, addPasteRules() { return [ core.markPasteRule({ find: pasteRegex, type: this.type, }), ]; }, }); exports.Code = Code; exports.default = Code; exports.inputRegex = inputRegex; exports.pasteRegex = pasteRegex; Object.defineProperty(exports, '__esModule', { value: true }); })); //# sourceMappingURL=index.umd.js.map