All files / app/assets/javascripts/content_editor/extensions blockquote.js

100% Statements 9/9
33.33% Branches 1/3
100% Functions 6/6
100% Lines 9/9

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47              313x                 1457x           12x 12x 12x     12x             73x   73x         2x          
import { Blockquote } from '@tiptap/extension-blockquote';
import { wrappingInputRule } from '@tiptap/core';
import { getParents } from '~/lib/utils/dom_utils';
import { getMarkdownSource } from '../services/markdown_sourcemap';
 
export default Blockquote.extend({
  addOptions() {
    return {
      ...this.parent?.(),
      HTMLAttributes: {
        dir: 'auto',
      },
    };
  },
 
  addAttributes() {
    return {
      ...this.parent?.(),
 
      multiline: {
        default: false,
        parseHTML: (element) => {
          const source = getMarkdownSource(element);
          const parentsIncludeBlockquote = getParents(element).some(
            (p) => p.nodeName.toLowerCase() === 'blockquote',
          );
 
          return source && !source.startsWith('>') && !parentsIncludeBlockquote;
        },
      },
    };
  },
 
  addInputRules() {
    const multilineInputRegex = /^\s*>>>\s$/gm;
 
    return [
      ...this.parent(),
      wrappingInputRule({
        find: multilineInputRegex,
        type: this.type,
        getAttributes: () => ({ multiline: true }),
      }),
    ];
  },
});