@pie-lib/editable-html-tip-tap 1.0.13 → 1.0.14
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/components/EditableHtml.js +12 -4
- package/lib/components/respArea/ExplicitConstructedResponse.js +15 -4
- package/lib/extensions/responseArea.js +211 -33
- package/package.json +6 -6
- package/src/components/EditableHtml.jsx +10 -2
- package/src/components/respArea/ExplicitConstructedResponse.jsx +13 -2
- package/src/extensions/responseArea.js +186 -15
|
@@ -162,7 +162,7 @@ var EditableHtml = function EditableHtml(props) {
|
|
|
162
162
|
}, [props]);
|
|
163
163
|
var extensions = [_extensionTextStyle.TextStyleKit, _extensionCharacterCount.CharacterCount.configure({
|
|
164
164
|
limit: props.charactersLimit
|
|
165
|
-
}), _starterKit["default"], _extendedTable["default"], _extensionTableRow.TableRow, _extensionTableHeader.TableHeader, _extensionTableCell.TableCell, _responseArea.ResponseAreaExtension, _responseArea.ExplicitConstructedResponseNode.configure(props.responseAreaProps), _responseArea.DragInTheBlankNode.configure(props.responseAreaProps), _responseArea.InlineDropdownNode.configure(props.responseAreaProps), _math.MathNode.configure({
|
|
165
|
+
}), _starterKit["default"], _extendedTable["default"], _extensionTableRow.TableRow, _extensionTableHeader.TableHeader, _extensionTableCell.TableCell, _responseArea.ResponseAreaExtension.configure(props.responseAreaProps), _responseArea.ExplicitConstructedResponseNode.configure(props.responseAreaProps), _responseArea.DragInTheBlankNode.configure(props.responseAreaProps), _responseArea.InlineDropdownNode.configure(props.responseAreaProps), _math.MathNode.configure({
|
|
166
166
|
toolbarOpts: toolbarOptsToUse
|
|
167
167
|
}), _extensionSubscript["default"], _extensionSuperscript["default"], _extensionTextAlign["default"].configure({
|
|
168
168
|
types: ['heading', 'paragraph'],
|
|
@@ -255,11 +255,19 @@ var EditableHtml = function EditableHtml(props) {
|
|
|
255
255
|
editable: !props.disabled,
|
|
256
256
|
content: props.markup,
|
|
257
257
|
onUpdate: function onUpdate(_ref4) {
|
|
258
|
-
var _props$
|
|
258
|
+
var _props$responseAreaPr2;
|
|
259
259
|
|
|
260
260
|
var editor = _ref4.editor,
|
|
261
261
|
transaction = _ref4.transaction;
|
|
262
|
-
|
|
262
|
+
|
|
263
|
+
if (transaction.isDone) {
|
|
264
|
+
var _props$onChange;
|
|
265
|
+
|
|
266
|
+
(_props$onChange = props.onChange) === null || _props$onChange === void 0 ? void 0 : _props$onChange.call(props, editor.getHTML());
|
|
267
|
+
}
|
|
268
|
+
|
|
269
|
+
if ((_props$responseAreaPr2 = props.responseAreaProps) !== null && _props$responseAreaPr2 !== void 0 && _props$responseAreaPr2.onHandleAreaChange) {// props.responseAreaProps.onHandleAreaChange(editor.getHTML());
|
|
270
|
+
}
|
|
263
271
|
},
|
|
264
272
|
onBlur: function onBlur(_ref5) {
|
|
265
273
|
var editor = _ref5.editor;
|
|
@@ -375,4 +383,4 @@ var StyledEditor = (0, _styles.withStyles)({
|
|
|
375
383
|
})(EditableHtml);
|
|
376
384
|
var _default = StyledEditor;
|
|
377
385
|
exports["default"] = _default;
|
|
378
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/EditableHtml.jsx"],"names":["defaultToolbarOpts","position","alignment","alwaysVisible","showDone","doneOn","defaultResponseAreaProps","options","respAreaToolbar","onHandleAreaChange","DEFAULT_ACTIVE_PLUGINS","cssVariables","EditableHtml","props","pluginProps","showParagraphs","separateParagraphs","pendingImages","setPendingImages","scheduled","setScheduled","classes","toolbarOpts","toolbarOptsToUse","activePluginsToUse","customPlugins","otherPluginProps","filteredActivePlugins","activePlugins","filter","pluginName","pluginInfo","disabled","math","textAlign","html","extraCSSRules","image","toolbar","table","responseArea","type","responseAreaProps","languageCharacters","languageCharactersProps","keyPadCharacterRef","setKeypadInteraction","media","extensions","TextStyleKit","CharacterCount","configure","limit","charactersLimit","StarterKit","ExtendedTable","TableRow","TableHeader","TableCell","ResponseAreaExtension","ExplicitConstructedResponseNode","DragInTheBlankNode","InlineDropdownNode","MathNode","SubScript","SuperScript","TextAlign","types","alignments","Image","ImageUploadNode","imageHandling","disableImageAlignmentButtons","onDone","editor","getHTML","onDelete","imageSupport","node","done","src","attrs","e","newPendingImages","img","key","newState","length","insertImageRequested","addedImage","getHandler","onFinish","result","cb","onChange","callback","handler","add","maxImageWidth","maxImageHeight","Media","uploadSoundSupport","CSSMark","immediatelyRender","editorProps","handleKeyDown","view","event","onKeyDown","editable","content","markup","onUpdate","transaction","isDone","onBlur","setEditable","commands","setContent","Object","entries","forEach","value","document","documentElement","style","setProperty","editorState","selector","ctx","isFocused","sizeStyle","minWidth","width","maxWidth","minHeight","height","maxHeight","showParagraph","separateParagraph","root","StyledEditor","outline","padding","margin","display","fontSize","color","marginBottom"],"mappings":"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","sourcesContent":["import React, { useEffect, useMemo, useState } from 'react';\nimport classNames from 'classnames';\nimport { EditorContent, useEditor, useEditorState } from '@tiptap/react';\nimport StarterKit from '@tiptap/starter-kit';\nimport { TextStyleKit } from '@tiptap/extension-text-style';\nimport { CharacterCount } from '@tiptap/extension-character-count';\nimport SuperScript from '@tiptap/extension-superscript';\nimport SubScript from '@tiptap/extension-subscript';\nimport TextAlign from '@tiptap/extension-text-align';\nimport Image from '@tiptap/extension-image';\nimport { withStyles } from '@material-ui/core/styles';\n\nimport ExtendedTable from '../extensions/extended-table';\nimport { TableRow } from '@tiptap/extension-table-row';\nimport { TableCell } from '@tiptap/extension-table-cell';\nimport { TableHeader } from '@tiptap/extension-table-header';\nimport {\n  ExplicitConstructedResponseNode,\n  DragInTheBlankNode,\n  InlineDropdownNode,\n  ResponseAreaExtension,\n} from '../extensions/responseArea';\nimport { MathNode } from '../extensions/math';\nimport { ImageUploadNode } from '../extensions/image';\nimport { Media } from '../extensions/media';\nimport { CSSMark } from '../extensions/css';\n\nimport EditorContainer from './TiptapContainer';\nimport { valueToSize } from '../utils/size';\nimport { buildExtensions } from '../extensions';\n\nconst defaultToolbarOpts = {\n  position: 'bottom',\n  alignment: 'left',\n  alwaysVisible: false,\n  showDone: true,\n  doneOn: 'blur',\n};\n\nconst defaultResponseAreaProps = {\n  options: {},\n  respAreaToolbar: () => {},\n  onHandleAreaChange: () => {},\n};\n\nconst DEFAULT_ACTIVE_PLUGINS = [\n  'bold',\n  'italic',\n  'underline',\n  'strikethrough',\n  'code',\n  'bulleted-list',\n  'numbered-list',\n  'image',\n  'math',\n  'languageCharacters',\n  'text-align',\n  'table',\n  'video',\n  'audio',\n  'responseArea',\n  'superscript',\n  'subscript',\n  'css',\n  'h3',\n  'undo',\n  'redo',\n];\n\nconst cssVariables = {\n  '--white': '#fff',\n  '--black': '#2e2b29',\n  '--black-contrast': '#110f0e',\n  '--gray-1': 'rgba(61, 37, 20, .05)',\n  '--gray-2': 'rgba(61, 37, 20, .08)',\n  '--gray-3': 'rgba(61, 37, 20, .12)',\n  '--gray-4': 'rgba(53, 38, 28, .3)',\n  '--gray-5': 'rgba(28, 25, 23, .6)',\n  '--green': '#22c55e',\n  '--purple': '#6a00f5',\n  '--purple-contrast': '#5800cc',\n  '--purple-light': 'rgba(88, 5, 255, .05)',\n  '--yellow-contrast': '#facc15',\n  '--yellow': 'rgba(250, 204, 21, .4)',\n  '--yellow-light': '#fffae5',\n  '--red': '#ff5c33',\n  '--red-light': '#ffebe5',\n  '--shadow': `0px 12px 33px 0px rgba(0, 0, 0, .06),\n               0px 3.618px 9.949px 0px rgba(0, 0, 0, .04)`,\n};\n\nexport const EditableHtml = (props) => {\n  const { showParagraphs, separateParagraphs } = props.pluginProps || {};\n  const [pendingImages, setPendingImages] = useState([]);\n  const [scheduled, setScheduled] = useState(false);\n  const { classes, toolbarOpts } = props;\n\n  const toolbarOptsToUse = {\n    ...defaultToolbarOpts,\n    ...toolbarOpts,\n  };\n\n  const activePluginsToUse = useMemo(() => {\n    let { customPlugins, ...otherPluginProps } = props.pluginProps || {};\n\n    customPlugins = customPlugins || [];\n\n    const filteredActivePlugins = (props.activePlugins || DEFAULT_ACTIVE_PLUGINS)?.filter((pluginName) => {\n      const pluginInfo = otherPluginProps[pluginName] || {};\n\n      return !pluginInfo || !pluginInfo.disabled;\n    });\n\n    return buildExtensions(filteredActivePlugins, customPlugins, {\n      math: {},\n      textAlign: {},\n      html: {},\n      extraCSSRules: props.extraCSSRules || {},\n      image: {},\n      toolbar: {},\n      table: {},\n      responseArea: {\n        type: props.responseAreaProps?.type,\n      },\n      languageCharacters: props.languageCharactersProps,\n      keyPadCharacterRef: {},\n      setKeypadInteraction: {},\n      media: {},\n    });\n  }, [props]);\n\n  const extensions = [\n    TextStyleKit,\n    CharacterCount.configure({\n      limit: props.charactersLimit,\n    }),\n    StarterKit,\n    ExtendedTable,\n    TableRow,\n    TableHeader,\n    TableCell,\n    ResponseAreaExtension,\n    ExplicitConstructedResponseNode.configure(props.responseAreaProps),\n    DragInTheBlankNode.configure(props.responseAreaProps),\n    InlineDropdownNode.configure(props.responseAreaProps),\n    MathNode.configure({\n      toolbarOpts: toolbarOptsToUse,\n    }),\n    SubScript,\n    SuperScript,\n    TextAlign.configure({\n      types: ['heading', 'paragraph'],\n      alignments: ['left', 'right', 'center'],\n    }),\n    Image,\n    ImageUploadNode.configure({\n      toolbarOpts: toolbarOptsToUse,\n      imageHandling: {\n        disableImageAlignmentButtons: props.disableImageAlignmentButtons,\n        onDone: () => props.onDone?.(editor.getHTML()),\n        onDelete:\n          props.imageSupport &&\n          props.imageSupport.delete &&\n          ((node, done) => {\n            const { src } = node.attrs;\n\n            props.imageSupport.delete(src, (e) => {\n              const newPendingImages = pendingImages.filter((img) => img.key !== node.key);\n              const newState = {\n                pendingImages: newPendingImages,\n                scheduled: scheduled && newPendingImages.length === 0 ? false : scheduled,\n              };\n\n              setPendingImages(newState.pendingImages);\n              setScheduled(newState.scheduled);\n              done();\n            });\n          }),\n        insertImageRequested:\n          props.imageSupport &&\n          ((addedImage, getHandler) => {\n            const onFinish = (result) => {\n              let cb;\n\n              if (scheduled && result) {\n                // finish editing only on success\n                cb = props.onChange;\n              }\n\n              const newPendingImages = pendingImages.filter((img) => img.key !== addedImage.key);\n              const newState = {\n                pendingImages: newPendingImages,\n              };\n\n              if (newPendingImages.length === 0) {\n                newState.scheduled = false;\n              }\n\n              setPendingImages(newState.pendingImages);\n              setScheduled(newState.scheduled);\n              cb?.(editor.getHTML());\n            };\n            const callback = () => {\n              /**\n               * The handler is the object through which the outer context\n               * communicates file upload events like: fileChosen, cancel, progress\n               */\n              const handler = getHandler(onFinish);\n              props.imageSupport.add(handler);\n            };\n\n            setPendingImages([...pendingImages, addedImage]);\n            callback();\n          }),\n        maxImageWidth: props.maxImageWidth,\n        maxImageHeight: props.maxImageHeight,\n      },\n      limit: 3,\n    }),\n    Media.configure({\n      uploadSoundSupport: props.uploadSoundSupport,\n    }),\n    CSSMark.configure({\n      extraCSSRules: props.extraCSSRules,\n    }),\n  ];\n\n  const editor = useEditor({\n    extensions,\n    immediatelyRender: false,\n    editorProps: {\n      handleKeyDown(view, event) {\n        if (props.onKeyDown) {\n          return props.onKeyDown(event);\n        }\n\n        // Return false to let default behavior continue\n        return false;\n      },\n    },\n    editable: !props.disabled,\n    content: props.markup,\n    onUpdate: ({ editor, transaction }) => transaction.isDone && props.onChange?.(editor.getHTML()),\n    onBlur: ({ editor }) => {\n      if (toolbarOptsToUse.doneOn === 'blur') {\n        props.onDone?.(editor.getHTML());\n      } else {\n        props.onChange?.(editor.getHTML());\n      }\n    },\n  });\n\n  useEffect(() => {\n    editor?.setEditable(!props.disabled);\n  }, [props.disabled, editor]);\n\n  useEffect(() => {\n    if (!editor) {\n      return;\n    }\n\n    if (props.markup !== editor.getHTML()) {\n      editor.commands.setContent(props.markup, false); // false = don’t emit update\n    }\n  }, [props.markup, editor]);\n\n  useEffect(() => {\n    Object.entries(cssVariables).forEach(([key, value]) => {\n      document.documentElement.style.setProperty(key, value);\n    });\n  }, []);\n\n  const editorState = useEditorState({\n    editor,\n    selector: (ctx) => ({\n      isFocused: ctx.editor?.isFocused,\n    }),\n  });\n\n  const sizeStyle = useMemo(() => {\n    const { minWidth, width, maxWidth, minHeight, height, maxHeight } = props;\n\n    return {\n      width: valueToSize(width),\n      minWidth: valueToSize(minWidth),\n      maxWidth: valueToSize(maxWidth),\n      height: valueToSize(height),\n      minHeight: valueToSize(minHeight),\n      maxHeight: valueToSize(maxHeight),\n    };\n  }, [props]);\n\n  return (\n    <EditorContainer\n      {...{\n        ...props,\n        activePlugins: activePluginsToUse,\n        toolbarOpts: toolbarOptsToUse,\n      }}\n      editorState={editorState}\n      editor={editor}\n    >\n      {editor && (\n        <EditorContent\n          style={{\n            minHeight: sizeStyle.minHeight,\n            height: sizeStyle.height,\n            maxHeight: sizeStyle.maxHeight,\n          }}\n          className={classNames(\n            {\n              [classes.showParagraph]: showParagraphs && !showParagraphs.disabled,\n              [classes.separateParagraph]: separateParagraphs && !separateParagraphs.disabled,\n            },\n            classes.root,\n          )}\n          editor={editor}\n        />\n      )}\n    </EditorContainer>\n  );\n};\n\nconst StyledEditor = withStyles({\n  root: {\n    outline: 'none !important',\n    '& .ProseMirror': {\n      padding: '5px',\n      maxHeight: '500px',\n      outline: 'none !important',\n      position: 'initial',\n      '& > p': {\n        margin: '0',\n      },\n    },\n  },\n  showParagraph: {\n    '& .ProseMirror': {\n      // a p that has a p after it\n      '& > p:has(+ p)::after': {\n        display: 'block',\n        content: '\"¶\"',\n        fontSize: '1em',\n        color: '#146EB3',\n      },\n    },\n  },\n  separateParagraph: {\n    '& .ProseMirror': {\n      // a p that has a p after it\n      '& > div:has(+ div)': {\n        marginBottom: '1em',\n      },\n    },\n  },\n})(EditableHtml);\n\nexport default StyledEditor;\n"]}
|
|
386
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/EditableHtml.jsx"],"names":["defaultToolbarOpts","position","alignment","alwaysVisible","showDone","doneOn","defaultResponseAreaProps","options","respAreaToolbar","onHandleAreaChange","DEFAULT_ACTIVE_PLUGINS","cssVariables","EditableHtml","props","pluginProps","showParagraphs","separateParagraphs","pendingImages","setPendingImages","scheduled","setScheduled","classes","toolbarOpts","toolbarOptsToUse","activePluginsToUse","customPlugins","otherPluginProps","filteredActivePlugins","activePlugins","filter","pluginName","pluginInfo","disabled","math","textAlign","html","extraCSSRules","image","toolbar","table","responseArea","type","responseAreaProps","languageCharacters","languageCharactersProps","keyPadCharacterRef","setKeypadInteraction","media","extensions","TextStyleKit","CharacterCount","configure","limit","charactersLimit","StarterKit","ExtendedTable","TableRow","TableHeader","TableCell","ResponseAreaExtension","ExplicitConstructedResponseNode","DragInTheBlankNode","InlineDropdownNode","MathNode","SubScript","SuperScript","TextAlign","types","alignments","Image","ImageUploadNode","imageHandling","disableImageAlignmentButtons","onDone","editor","getHTML","onDelete","imageSupport","node","done","src","attrs","e","newPendingImages","img","key","newState","length","insertImageRequested","addedImage","getHandler","onFinish","result","cb","onChange","callback","handler","add","maxImageWidth","maxImageHeight","Media","uploadSoundSupport","CSSMark","immediatelyRender","editorProps","handleKeyDown","view","event","onKeyDown","editable","content","markup","onUpdate","transaction","isDone","onBlur","setEditable","commands","setContent","Object","entries","forEach","value","document","documentElement","style","setProperty","editorState","selector","ctx","isFocused","sizeStyle","minWidth","width","maxWidth","minHeight","height","maxHeight","showParagraph","separateParagraph","root","StyledEditor","outline","padding","margin","display","fontSize","color","marginBottom"],"mappings":"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","sourcesContent":["import React, { useEffect, useMemo, useState } from 'react';\nimport classNames from 'classnames';\nimport { EditorContent, useEditor, useEditorState } from '@tiptap/react';\nimport StarterKit from '@tiptap/starter-kit';\nimport { TextStyleKit } from '@tiptap/extension-text-style';\nimport { CharacterCount } from '@tiptap/extension-character-count';\nimport SuperScript from '@tiptap/extension-superscript';\nimport SubScript from '@tiptap/extension-subscript';\nimport TextAlign from '@tiptap/extension-text-align';\nimport Image from '@tiptap/extension-image';\nimport { withStyles } from '@material-ui/core/styles';\n\nimport ExtendedTable from '../extensions/extended-table';\nimport { TableRow } from '@tiptap/extension-table-row';\nimport { TableCell } from '@tiptap/extension-table-cell';\nimport { TableHeader } from '@tiptap/extension-table-header';\nimport {\n  ExplicitConstructedResponseNode,\n  DragInTheBlankNode,\n  InlineDropdownNode,\n  ResponseAreaExtension,\n} from '../extensions/responseArea';\nimport { MathNode } from '../extensions/math';\nimport { ImageUploadNode } from '../extensions/image';\nimport { Media } from '../extensions/media';\nimport { CSSMark } from '../extensions/css';\n\nimport EditorContainer from './TiptapContainer';\nimport { valueToSize } from '../utils/size';\nimport { buildExtensions } from '../extensions';\n\nconst defaultToolbarOpts = {\n  position: 'bottom',\n  alignment: 'left',\n  alwaysVisible: false,\n  showDone: true,\n  doneOn: 'blur',\n};\n\nconst defaultResponseAreaProps = {\n  options: {},\n  respAreaToolbar: () => {},\n  onHandleAreaChange: () => {},\n};\n\nconst DEFAULT_ACTIVE_PLUGINS = [\n  'bold',\n  'italic',\n  'underline',\n  'strikethrough',\n  'code',\n  'bulleted-list',\n  'numbered-list',\n  'image',\n  'math',\n  'languageCharacters',\n  'text-align',\n  'table',\n  'video',\n  'audio',\n  'responseArea',\n  'superscript',\n  'subscript',\n  'css',\n  'h3',\n  'undo',\n  'redo',\n];\n\nconst cssVariables = {\n  '--white': '#fff',\n  '--black': '#2e2b29',\n  '--black-contrast': '#110f0e',\n  '--gray-1': 'rgba(61, 37, 20, .05)',\n  '--gray-2': 'rgba(61, 37, 20, .08)',\n  '--gray-3': 'rgba(61, 37, 20, .12)',\n  '--gray-4': 'rgba(53, 38, 28, .3)',\n  '--gray-5': 'rgba(28, 25, 23, .6)',\n  '--green': '#22c55e',\n  '--purple': '#6a00f5',\n  '--purple-contrast': '#5800cc',\n  '--purple-light': 'rgba(88, 5, 255, .05)',\n  '--yellow-contrast': '#facc15',\n  '--yellow': 'rgba(250, 204, 21, .4)',\n  '--yellow-light': '#fffae5',\n  '--red': '#ff5c33',\n  '--red-light': '#ffebe5',\n  '--shadow': `0px 12px 33px 0px rgba(0, 0, 0, .06),\n               0px 3.618px 9.949px 0px rgba(0, 0, 0, .04)`,\n};\n\nexport const EditableHtml = (props) => {\n  const { showParagraphs, separateParagraphs } = props.pluginProps || {};\n  const [pendingImages, setPendingImages] = useState([]);\n  const [scheduled, setScheduled] = useState(false);\n  const { classes, toolbarOpts } = props;\n\n  const toolbarOptsToUse = {\n    ...defaultToolbarOpts,\n    ...toolbarOpts,\n  };\n\n  const activePluginsToUse = useMemo(() => {\n    let { customPlugins, ...otherPluginProps } = props.pluginProps || {};\n\n    customPlugins = customPlugins || [];\n\n    const filteredActivePlugins = (props.activePlugins || DEFAULT_ACTIVE_PLUGINS)?.filter((pluginName) => {\n      const pluginInfo = otherPluginProps[pluginName] || {};\n\n      return !pluginInfo || !pluginInfo.disabled;\n    });\n\n    return buildExtensions(filteredActivePlugins, customPlugins, {\n      math: {},\n      textAlign: {},\n      html: {},\n      extraCSSRules: props.extraCSSRules || {},\n      image: {},\n      toolbar: {},\n      table: {},\n      responseArea: {\n        type: props.responseAreaProps?.type,\n      },\n      languageCharacters: props.languageCharactersProps,\n      keyPadCharacterRef: {},\n      setKeypadInteraction: {},\n      media: {},\n    });\n  }, [props]);\n\n  const extensions = [\n    TextStyleKit,\n    CharacterCount.configure({\n      limit: props.charactersLimit,\n    }),\n    StarterKit,\n    ExtendedTable,\n    TableRow,\n    TableHeader,\n    TableCell,\n    ResponseAreaExtension.configure(props.responseAreaProps),\n    ExplicitConstructedResponseNode.configure(props.responseAreaProps),\n    DragInTheBlankNode.configure(props.responseAreaProps),\n    InlineDropdownNode.configure(props.responseAreaProps),\n    MathNode.configure({\n      toolbarOpts: toolbarOptsToUse,\n    }),\n    SubScript,\n    SuperScript,\n    TextAlign.configure({\n      types: ['heading', 'paragraph'],\n      alignments: ['left', 'right', 'center'],\n    }),\n    Image,\n    ImageUploadNode.configure({\n      toolbarOpts: toolbarOptsToUse,\n      imageHandling: {\n        disableImageAlignmentButtons: props.disableImageAlignmentButtons,\n        onDone: () => props.onDone?.(editor.getHTML()),\n        onDelete:\n          props.imageSupport &&\n          props.imageSupport.delete &&\n          ((node, done) => {\n            const { src } = node.attrs;\n\n            props.imageSupport.delete(src, (e) => {\n              const newPendingImages = pendingImages.filter((img) => img.key !== node.key);\n              const newState = {\n                pendingImages: newPendingImages,\n                scheduled: scheduled && newPendingImages.length === 0 ? false : scheduled,\n              };\n\n              setPendingImages(newState.pendingImages);\n              setScheduled(newState.scheduled);\n              done();\n            });\n          }),\n        insertImageRequested:\n          props.imageSupport &&\n          ((addedImage, getHandler) => {\n            const onFinish = (result) => {\n              let cb;\n\n              if (scheduled && result) {\n                // finish editing only on success\n                cb = props.onChange;\n              }\n\n              const newPendingImages = pendingImages.filter((img) => img.key !== addedImage.key);\n              const newState = {\n                pendingImages: newPendingImages,\n              };\n\n              if (newPendingImages.length === 0) {\n                newState.scheduled = false;\n              }\n\n              setPendingImages(newState.pendingImages);\n              setScheduled(newState.scheduled);\n              cb?.(editor.getHTML());\n            };\n            const callback = () => {\n              /**\n               * The handler is the object through which the outer context\n               * communicates file upload events like: fileChosen, cancel, progress\n               */\n              const handler = getHandler(onFinish);\n              props.imageSupport.add(handler);\n            };\n\n            setPendingImages([...pendingImages, addedImage]);\n            callback();\n          }),\n        maxImageWidth: props.maxImageWidth,\n        maxImageHeight: props.maxImageHeight,\n      },\n      limit: 3,\n    }),\n    Media.configure({\n      uploadSoundSupport: props.uploadSoundSupport,\n    }),\n    CSSMark.configure({\n      extraCSSRules: props.extraCSSRules,\n    }),\n  ];\n\n  const editor = useEditor({\n    extensions,\n    immediatelyRender: false,\n    editorProps: {\n      handleKeyDown(view, event) {\n        if (props.onKeyDown) {\n          return props.onKeyDown(event);\n        }\n\n        // Return false to let default behavior continue\n        return false;\n      },\n    },\n    editable: !props.disabled,\n    content: props.markup,\n    onUpdate: ({ editor, transaction }) => {\n      if (transaction.isDone) {\n        props.onChange?.(editor.getHTML());\n      }\n\n      if (props.responseAreaProps?.onHandleAreaChange) {\n        // props.responseAreaProps.onHandleAreaChange(editor.getHTML());\n      }\n    },\n    onBlur: ({ editor }) => {\n      if (toolbarOptsToUse.doneOn === 'blur') {\n        props.onDone?.(editor.getHTML());\n      } else {\n        props.onChange?.(editor.getHTML());\n      }\n    },\n  });\n\n  useEffect(() => {\n    editor?.setEditable(!props.disabled);\n  }, [props.disabled, editor]);\n\n  useEffect(() => {\n    if (!editor) {\n      return;\n    }\n\n    if (props.markup !== editor.getHTML()) {\n      editor.commands.setContent(props.markup, false); // false = don’t emit update\n    }\n  }, [props.markup, editor]);\n\n  useEffect(() => {\n    Object.entries(cssVariables).forEach(([key, value]) => {\n      document.documentElement.style.setProperty(key, value);\n    });\n  }, []);\n\n  const editorState = useEditorState({\n    editor,\n    selector: (ctx) => ({\n      isFocused: ctx.editor?.isFocused,\n    }),\n  });\n\n  const sizeStyle = useMemo(() => {\n    const { minWidth, width, maxWidth, minHeight, height, maxHeight } = props;\n\n    return {\n      width: valueToSize(width),\n      minWidth: valueToSize(minWidth),\n      maxWidth: valueToSize(maxWidth),\n      height: valueToSize(height),\n      minHeight: valueToSize(minHeight),\n      maxHeight: valueToSize(maxHeight),\n    };\n  }, [props]);\n\n  return (\n    <EditorContainer\n      {...{\n        ...props,\n        activePlugins: activePluginsToUse,\n        toolbarOpts: toolbarOptsToUse,\n      }}\n      editorState={editorState}\n      editor={editor}\n    >\n      {editor && (\n        <EditorContent\n          style={{\n            minHeight: sizeStyle.minHeight,\n            height: sizeStyle.height,\n            maxHeight: sizeStyle.maxHeight,\n          }}\n          className={classNames(\n            {\n              [classes.showParagraph]: showParagraphs && !showParagraphs.disabled,\n              [classes.separateParagraph]: separateParagraphs && !separateParagraphs.disabled,\n            },\n            classes.root,\n          )}\n          editor={editor}\n        />\n      )}\n    </EditorContainer>\n  );\n};\n\nconst StyledEditor = withStyles({\n  root: {\n    outline: 'none !important',\n    '& .ProseMirror': {\n      padding: '5px',\n      maxHeight: '500px',\n      outline: 'none !important',\n      position: 'initial',\n      '& > p': {\n        margin: '0',\n      },\n    },\n  },\n  showParagraph: {\n    '& .ProseMirror': {\n      // a p that has a p after it\n      '& > p:has(+ p)::after': {\n        display: 'block',\n        content: '\"¶\"',\n        fontSize: '1em',\n        color: '#146EB3',\n      },\n    },\n  },\n  separateParagraph: {\n    '& .ProseMirror': {\n      // a p that has a p after it\n      '& > div:has(+ div)': {\n        marginBottom: '1em',\n      },\n    },\n  },\n})(EditableHtml);\n\nexport default StyledEditor;\n"]}
|
|
@@ -30,8 +30,9 @@ var ExplicitConstructedResponse = function ExplicitConstructedResponse(props) {
|
|
|
30
30
|
options = props.options,
|
|
31
31
|
selected = props.selected;
|
|
32
32
|
var attributes = node.attrs;
|
|
33
|
-
var value = attributes.value
|
|
34
|
-
|
|
33
|
+
var value = attributes.value;
|
|
34
|
+
var respAreaToolbar = options.respAreaToolbar,
|
|
35
|
+
errorFn = options.error;
|
|
35
36
|
var pos = getPos();
|
|
36
37
|
|
|
37
38
|
var _useState = (0, _react.useState)(false),
|
|
@@ -39,8 +40,17 @@ var ExplicitConstructedResponse = function ExplicitConstructedResponse(props) {
|
|
|
39
40
|
showToolbar = _useState2[0],
|
|
40
41
|
setShowToolbar = _useState2[1];
|
|
41
42
|
|
|
42
|
-
var EcrToolbar =
|
|
43
|
+
var EcrToolbar = respAreaToolbar(node, editor, function () {});
|
|
43
44
|
var toolbarRef = (0, _react.useRef)(null);
|
|
45
|
+
var error;
|
|
46
|
+
|
|
47
|
+
if (errorFn) {
|
|
48
|
+
var _errorValue$respIndex;
|
|
49
|
+
|
|
50
|
+
var errorValue = errorFn();
|
|
51
|
+
var respIndex = parseInt(attributes.index, 10);
|
|
52
|
+
error = !!(errorValue !== null && errorValue !== void 0 && (_errorValue$respIndex = errorValue[respIndex]) !== null && _errorValue$respIndex !== void 0 && _errorValue$respIndex[0]);
|
|
53
|
+
}
|
|
44
54
|
|
|
45
55
|
var handleDone = function handleDone(newLatex) {
|
|
46
56
|
updateAttributes({
|
|
@@ -101,6 +111,7 @@ var ExplicitConstructedResponse = function ExplicitConstructedResponse(props) {
|
|
|
101
111
|
overflow: 'hidden',
|
|
102
112
|
padding: '12px 21px',
|
|
103
113
|
margin: '0 4px',
|
|
114
|
+
minWidth: '178px',
|
|
104
115
|
visibility: showToolbar ? 'hidden' : 'visible'
|
|
105
116
|
},
|
|
106
117
|
onClick: function onClick() {
|
|
@@ -126,4 +137,4 @@ ExplicitConstructedResponse.propTypes = {
|
|
|
126
137
|
};
|
|
127
138
|
var _default = ExplicitConstructedResponse;
|
|
128
139
|
exports["default"] = _default;
|
|
129
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
140
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/respArea/ExplicitConstructedResponse.jsx"],"names":["ExplicitConstructedResponse","props","editor","node","getPos","options","selected","attributes","attrs","value","respAreaToolbar","errorFn","error","pos","showToolbar","setShowToolbar","EcrToolbar","toolbarRef","errorValue","respIndex","parseInt","index","handleDone","newLatex","updateAttributes","latex","commands","focus","selection","state","onlyThisNodeSelected","from","nodeSize","to","handleClickOutside","event","current","contains","target","closest","document","addEventListener","removeEventListener","display","minHeight","position","cursor","width","height","backgroundColor","border","boxSizing","borderRadius","overflow","padding","margin","minWidth","visibility","__html","zIndex","propTypes","PropTypes","object","any","string","isFocused","bool"],"mappings":"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","sourcesContent":["import React, { useEffect, useState, useRef } from 'react';\nimport { NodeViewWrapper } from '@tiptap/react';\nimport PropTypes from 'prop-types';\n\nconst ExplicitConstructedResponse = (props) => {\n  const { editor, node, getPos, options, selected } = props;\n  const { attrs: attributes } = node;\n  const { value } = attributes;\n  const { respAreaToolbar, error: errorFn } = options;\n  const pos = getPos();\n  const [showToolbar, setShowToolbar] = useState(false);\n  const EcrToolbar = respAreaToolbar(node, editor, () => {});\n  const toolbarRef = useRef(null);\n\n  let error;\n\n  if (errorFn) {\n    const errorValue = errorFn();\n    const respIndex = parseInt(attributes.index, 10);\n\n    error = !!errorValue?.[respIndex]?.[0];\n  }\n\n  const handleDone = (newLatex) => {\n    updateAttributes({ latex: newLatex });\n    setShowToolbar(false);\n    editor.commands.focus();\n  };\n\n  useEffect(() => {\n    const { selection } = editor.state;\n    const onlyThisNodeSelected = selection.from + node.nodeSize === selection.to;\n\n    if (selected) {\n      if (onlyThisNodeSelected) {\n        setShowToolbar(selected);\n      }\n    } else {\n      setShowToolbar(selected);\n    }\n  }, [editor, node, selected]);\n\n  useEffect(() => {\n    const handleClickOutside = (event) => {\n      if (\n        toolbarRef.current &&\n        !toolbarRef.current.contains(event.target) &&\n        !event.target.closest('[data-inline-node]')\n      ) {\n        setShowToolbar(false);\n      }\n    };\n\n    if (showToolbar) {\n      document.addEventListener('mousedown', handleClickOutside);\n    } else {\n      document.removeEventListener('mousedown', handleClickOutside);\n    }\n\n    return () => document.removeEventListener('mousedown', handleClickOutside);\n  }, [showToolbar]);\n\n  return (\n    <NodeViewWrapper\n      className=\"drag-in-the-blank\"\n      data-selected={selected}\n      style={{\n        display: 'inline-flex',\n        minHeight: '55px',\n        position: 'relative',\n        cursor: 'pointer',\n      }}\n    >\n      <div\n        {...attributes}\n        style={{\n          display: 'inline-flex',\n          width: '100%',\n          minHeight: '46px',\n          height: '46px',\n          backgroundColor: '#FFF',\n          border: `1px solid ${error ? 'red' : '#C0C3CF'}`,\n          boxSizing: 'border-box',\n          borderRadius: '4px',\n          overflow: 'hidden',\n          padding: '12px 21px',\n          margin: '0 4px',\n          minWidth: '178px',\n          visibility: showToolbar ? 'hidden' : 'visible',\n        }}\n        onClick={() => setShowToolbar(true)}\n        dangerouslySetInnerHTML={{\n          __html: value || '<div>&nbsp;</div>',\n        }}\n      />\n      {showToolbar && (\n        <div ref={toolbarRef} className=\"absolute z-50 bg-white shadow-lg rounded p-2\" style={{ zIndex: 1 }}>\n          <EcrToolbar />\n        </div>\n      )}\n    </NodeViewWrapper>\n  );\n};\n\nExplicitConstructedResponse.propTypes = {\n  attributes: PropTypes.object,\n  error: PropTypes.any,\n  value: PropTypes.string,\n  isFocused: PropTypes.bool,\n};\n\nexport default ExplicitConstructedResponse;\n"]}
|
|
@@ -11,6 +11,10 @@ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/de
|
|
|
11
11
|
|
|
12
12
|
var _react = _interopRequireDefault(require("react"));
|
|
13
13
|
|
|
14
|
+
var _prosemirrorState = require("prosemirror-state");
|
|
15
|
+
|
|
16
|
+
var _core = require("@tiptap/core");
|
|
17
|
+
|
|
14
18
|
var _react2 = require("@tiptap/react");
|
|
15
19
|
|
|
16
20
|
var _ExplicitConstructedResponse = _interopRequireDefault(require("../components/respArea/ExplicitConstructedResponse"));
|
|
@@ -19,37 +23,211 @@ var _DragInTheBlank = _interopRequireDefault(require("../components/respArea/Dra
|
|
|
19
23
|
|
|
20
24
|
var _InlineDropdown = _interopRequireDefault(require("../components/respArea/InlineDropdown"));
|
|
21
25
|
|
|
22
|
-
var
|
|
26
|
+
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
23
27
|
|
|
24
28
|
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
25
29
|
|
|
26
30
|
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
27
31
|
|
|
32
|
+
var lastIndexMap = {};
|
|
33
|
+
|
|
34
|
+
var normalizeType = function normalizeType(type) {
|
|
35
|
+
return String(type || '').replace(/-/g, '_');
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
var getAttrIndex = function getAttrIndex(node) {
|
|
39
|
+
return node && node.attrs && node.attrs.index != null ? String(node.attrs.index) : null;
|
|
40
|
+
};
|
|
41
|
+
|
|
42
|
+
var collectNodesOfType = function collectNodesOfType(doc, typeName) {
|
|
43
|
+
var results = [];
|
|
44
|
+
doc.descendants(function (node, pos) {
|
|
45
|
+
if (node.type && node.type.name === typeName) {
|
|
46
|
+
var index = getAttrIndex(node);
|
|
47
|
+
if (index != null) results.push({
|
|
48
|
+
index: index,
|
|
49
|
+
pos: pos,
|
|
50
|
+
node: node
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
return true;
|
|
55
|
+
});
|
|
56
|
+
return results;
|
|
57
|
+
};
|
|
58
|
+
|
|
59
|
+
var countNodesOfType = function countNodesOfType(doc, typeName) {
|
|
60
|
+
var count = 0;
|
|
61
|
+
doc.descendants(function (node) {
|
|
62
|
+
if (node.type && node.type.name === typeName) count += 1;
|
|
63
|
+
return true;
|
|
64
|
+
});
|
|
65
|
+
return count;
|
|
66
|
+
};
|
|
67
|
+
|
|
68
|
+
var getDefaultNode = function getDefaultNode(_ref) {
|
|
69
|
+
var schema = _ref.schema,
|
|
70
|
+
typeName = _ref.typeName,
|
|
71
|
+
index = _ref.index;
|
|
72
|
+
var nodeType = schema.nodes[typeName];
|
|
73
|
+
if (!nodeType) return null; // mirror your Slate "getDefaultElement(opts, newIndex)"
|
|
74
|
+
// customize attrs as needed:
|
|
75
|
+
|
|
76
|
+
return nodeType.create({
|
|
77
|
+
index: String(index),
|
|
78
|
+
id: String(index),
|
|
79
|
+
value: ''
|
|
80
|
+
});
|
|
81
|
+
}; // Find a good cursor position *after* an inserted node.
|
|
82
|
+
|
|
83
|
+
|
|
84
|
+
var selectionAfterPos = function selectionAfterPos(doc, pos) {
|
|
85
|
+
var $pos = doc.resolve(Math.min(pos, doc.content.size));
|
|
86
|
+
return _prosemirrorState.TextSelection.near($pos, 1);
|
|
87
|
+
};
|
|
88
|
+
|
|
28
89
|
var ResponseAreaExtension = _core.Extension.create({
|
|
29
90
|
name: 'responseArea',
|
|
91
|
+
addOptions: function addOptions() {
|
|
92
|
+
return {
|
|
93
|
+
maxResponseAreas: null,
|
|
94
|
+
error: null,
|
|
95
|
+
options: null,
|
|
96
|
+
respAreaToolbar: null,
|
|
97
|
+
onHandleAreaChange: null
|
|
98
|
+
};
|
|
99
|
+
},
|
|
100
|
+
addProseMirrorPlugins: function addProseMirrorPlugins() {
|
|
101
|
+
var _this = this;
|
|
102
|
+
|
|
103
|
+
if (!this.options.type) {
|
|
104
|
+
return [];
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
var typeName = normalizeType(this.options.type);
|
|
108
|
+
var key = new _prosemirrorState.PluginKey("response-area-watcher:".concat(typeName));
|
|
109
|
+
return [new _prosemirrorState.Plugin({
|
|
110
|
+
key: key,
|
|
111
|
+
view: function view(_view) {
|
|
112
|
+
// Lazy init lastIndexMap[typeName]
|
|
113
|
+
if (lastIndexMap[typeName] === undefined) {
|
|
114
|
+
lastIndexMap[typeName] = 0;
|
|
115
|
+
|
|
116
|
+
_view.state.doc.descendants(function (node) {
|
|
117
|
+
if (node.type && node.type.name === typeName) {
|
|
118
|
+
var idx = getAttrIndex(node);
|
|
119
|
+
|
|
120
|
+
if (idx != null) {
|
|
121
|
+
var n = parseInt(idx, 10);
|
|
122
|
+
|
|
123
|
+
if (!Number.isNaN(n) && n > lastIndexMap[typeName]) {
|
|
124
|
+
lastIndexMap[typeName] = n;
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
return true;
|
|
130
|
+
});
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
return {
|
|
134
|
+
update: function update(view, prevState) {
|
|
135
|
+
var state = view.state;
|
|
136
|
+
if (prevState.doc.eq(state.doc)) return;
|
|
137
|
+
var currentList = collectNodesOfType(state.doc, typeName);
|
|
138
|
+
var oldList = collectNodesOfType(prevState.doc, typeName);
|
|
139
|
+
|
|
140
|
+
if (_this.options.toolbar) {
|
|
141
|
+
_this.options.toolbar.disabled = currentList.length >= _this.options.maxResponseAreas;
|
|
142
|
+
} // Removed elements (same logic as Slate)
|
|
143
|
+
|
|
144
|
+
|
|
145
|
+
if (oldList.length > currentList.length) {
|
|
146
|
+
var currentIndexSet = new Set(currentList.map(function (x) {
|
|
147
|
+
return x.index;
|
|
148
|
+
}));
|
|
149
|
+
var removed = oldList.filter(function (x) {
|
|
150
|
+
return !currentIndexSet.has(x.index);
|
|
151
|
+
});
|
|
152
|
+
|
|
153
|
+
if (removed.length && typeof _this.options.onHandleAreaChange === 'function') {
|
|
154
|
+
_this.options.onHandleAreaChange(removed);
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
};
|
|
159
|
+
}
|
|
160
|
+
})];
|
|
161
|
+
},
|
|
30
162
|
addCommands: function addCommands() {
|
|
163
|
+
var _this2 = this;
|
|
164
|
+
|
|
31
165
|
return {
|
|
32
166
|
insertResponseArea: function insertResponseArea(type) {
|
|
33
|
-
return function (
|
|
34
|
-
var tr =
|
|
35
|
-
state =
|
|
36
|
-
dispatch =
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
var
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
167
|
+
return function (_ref2) {
|
|
168
|
+
var tr = _ref2.tr,
|
|
169
|
+
state = _ref2.state,
|
|
170
|
+
dispatch = _ref2.dispatch,
|
|
171
|
+
commands = _ref2.commands;
|
|
172
|
+
var typeName = normalizeType(type); // --- Slate: currentRespAreaList + max check ---
|
|
173
|
+
|
|
174
|
+
var currentCount = countNodesOfType(state.doc, typeName);
|
|
175
|
+
|
|
176
|
+
if (currentCount >= _this2.options.maxResponseAreas) {
|
|
177
|
+
return false;
|
|
178
|
+
} // --- Slate: indexing logic (kept identical) ---
|
|
179
|
+
|
|
180
|
+
|
|
181
|
+
if (lastIndexMap[typeName] === undefined) lastIndexMap[typeName] = 0;
|
|
182
|
+
var prevIndex = lastIndexMap[typeName];
|
|
183
|
+
var newIndex = prevIndex === 0 ? prevIndex : prevIndex + 1; // Slate increments map even if newIndex === 0
|
|
184
|
+
|
|
185
|
+
lastIndexMap[typeName] += 1;
|
|
186
|
+
var newInline = getDefaultNode({
|
|
187
|
+
schema: state.schema,
|
|
188
|
+
typeName: typeName,
|
|
189
|
+
index: newIndex
|
|
49
190
|
});
|
|
191
|
+
if (!newInline) return false; // --- Insert logic ---
|
|
192
|
+
|
|
193
|
+
var selection = state.selection;
|
|
194
|
+
var insertPos = selection.from; // If we're in a NodeSelection, insert before/after is ambiguous;
|
|
195
|
+
// We'll insert at its "from" (like your current code).
|
|
196
|
+
// If insertion fails, we fallback to end of doc.
|
|
197
|
+
|
|
198
|
+
var tryInsertAt = function tryInsertAt(pos) {
|
|
199
|
+
try {
|
|
200
|
+
tr.insert(pos, newInline);
|
|
201
|
+
return pos;
|
|
202
|
+
} catch (e) {
|
|
203
|
+
return null;
|
|
204
|
+
}
|
|
205
|
+
};
|
|
206
|
+
|
|
207
|
+
var usedPos = tryInsertAt(insertPos); // Slate branch: "markup empty and there's no focus"
|
|
208
|
+
// ProseMirror doesn't expose "no focus" the same way, so the closest
|
|
209
|
+
// equivalent fallback is inserting at end of document.
|
|
210
|
+
|
|
211
|
+
if (usedPos == null) {
|
|
212
|
+
usedPos = tryInsertAt(tr.doc.content.size);
|
|
213
|
+
}
|
|
214
|
+
|
|
215
|
+
if (usedPos == null) return false; // Optionally select the node you just inserted (like your original command)
|
|
216
|
+
// tr.setSelection(NodeSelection.create(tr.doc, usedPos))
|
|
217
|
+
// --- Cursor move behavior for certain types (Slate: moveFocusTo next text) ---
|
|
218
|
+
|
|
219
|
+
if (typeName === 'drag_in_the_blank' || typeName === 'math_templated') {
|
|
220
|
+
var after = usedPos + newInline.nodeSize;
|
|
221
|
+
tr.setSelection(selectionAfterPos(tr.doc, after));
|
|
222
|
+
} else {
|
|
223
|
+
// Default: put cursor after inserted node
|
|
224
|
+
var _after = usedPos + newInline.nodeSize;
|
|
225
|
+
|
|
226
|
+
tr.setSelection(selectionAfterPos(tr.doc, _after));
|
|
227
|
+
}
|
|
50
228
|
|
|
51
229
|
if (dispatch) {
|
|
52
|
-
|
|
230
|
+
commands.focus();
|
|
53
231
|
dispatch(tr);
|
|
54
232
|
}
|
|
55
233
|
|
|
@@ -92,8 +270,8 @@ var ExplicitConstructedResponseNode = _react2.Node.create({
|
|
|
92
270
|
}
|
|
93
271
|
}];
|
|
94
272
|
},
|
|
95
|
-
renderHTML: function renderHTML(
|
|
96
|
-
var HTMLAttributes =
|
|
273
|
+
renderHTML: function renderHTML(_ref3) {
|
|
274
|
+
var HTMLAttributes = _ref3.HTMLAttributes;
|
|
97
275
|
return ['span', {
|
|
98
276
|
'data-type': 'explicit_constructed_response',
|
|
99
277
|
'data-index': HTMLAttributes.index,
|
|
@@ -101,11 +279,11 @@ var ExplicitConstructedResponseNode = _react2.Node.create({
|
|
|
101
279
|
}];
|
|
102
280
|
},
|
|
103
281
|
addNodeView: function addNodeView() {
|
|
104
|
-
var
|
|
282
|
+
var _this3 = this;
|
|
105
283
|
|
|
106
284
|
return (0, _react2.ReactNodeViewRenderer)(function (props) {
|
|
107
285
|
return /*#__PURE__*/_react["default"].createElement(_ExplicitConstructedResponse["default"], _objectSpread(_objectSpread({}, props), {}, {
|
|
108
|
-
options:
|
|
286
|
+
options: _this3.options
|
|
109
287
|
}));
|
|
110
288
|
});
|
|
111
289
|
}
|
|
@@ -143,8 +321,8 @@ var MathTemplatedNode = _react2.Node.create({
|
|
|
143
321
|
}
|
|
144
322
|
}];
|
|
145
323
|
},
|
|
146
|
-
renderHTML: function renderHTML(
|
|
147
|
-
var HTMLAttributes =
|
|
324
|
+
renderHTML: function renderHTML(_ref4) {
|
|
325
|
+
var HTMLAttributes = _ref4.HTMLAttributes;
|
|
148
326
|
return ['span', {
|
|
149
327
|
'data-type': 'math_templated',
|
|
150
328
|
'data-index': HTMLAttributes.index,
|
|
@@ -198,8 +376,8 @@ var DragInTheBlankNode = _react2.Node.create({
|
|
|
198
376
|
}
|
|
199
377
|
}];
|
|
200
378
|
},
|
|
201
|
-
renderHTML: function renderHTML(
|
|
202
|
-
var HTMLAttributes =
|
|
379
|
+
renderHTML: function renderHTML(_ref5) {
|
|
380
|
+
var HTMLAttributes = _ref5.HTMLAttributes;
|
|
203
381
|
return ['span', {
|
|
204
382
|
'data-type': 'drag_in_the_blank',
|
|
205
383
|
'data-index': HTMLAttributes.index,
|
|
@@ -209,11 +387,11 @@ var DragInTheBlankNode = _react2.Node.create({
|
|
|
209
387
|
}];
|
|
210
388
|
},
|
|
211
389
|
addNodeView: function addNodeView() {
|
|
212
|
-
var
|
|
390
|
+
var _this4 = this;
|
|
213
391
|
|
|
214
392
|
return (0, _react2.ReactNodeViewRenderer)(function (props) {
|
|
215
393
|
return /*#__PURE__*/_react["default"].createElement(_DragInTheBlank["default"], _objectSpread(_objectSpread({}, props), {}, {
|
|
216
|
-
options:
|
|
394
|
+
options: _this4.options
|
|
217
395
|
}));
|
|
218
396
|
});
|
|
219
397
|
}
|
|
@@ -251,8 +429,8 @@ var InlineDropdownNode = _react2.Node.create({
|
|
|
251
429
|
}
|
|
252
430
|
}];
|
|
253
431
|
},
|
|
254
|
-
renderHTML: function renderHTML(
|
|
255
|
-
var HTMLAttributes =
|
|
432
|
+
renderHTML: function renderHTML(_ref6) {
|
|
433
|
+
var HTMLAttributes = _ref6.HTMLAttributes;
|
|
256
434
|
return ['span', {
|
|
257
435
|
'data-type': 'inline_dropdown',
|
|
258
436
|
'data-index': HTMLAttributes.index,
|
|
@@ -260,15 +438,15 @@ var InlineDropdownNode = _react2.Node.create({
|
|
|
260
438
|
}];
|
|
261
439
|
},
|
|
262
440
|
addNodeView: function addNodeView() {
|
|
263
|
-
var
|
|
441
|
+
var _this5 = this;
|
|
264
442
|
|
|
265
443
|
return (0, _react2.ReactNodeViewRenderer)(function (props) {
|
|
266
444
|
return /*#__PURE__*/_react["default"].createElement(_InlineDropdown["default"], _objectSpread(_objectSpread({}, props), {}, {
|
|
267
|
-
options:
|
|
445
|
+
options: _this5.options
|
|
268
446
|
}));
|
|
269
447
|
});
|
|
270
448
|
}
|
|
271
449
|
});
|
|
272
450
|
|
|
273
451
|
exports.InlineDropdownNode = InlineDropdownNode;
|
|
274
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/extensions/responseArea.js"],"names":["ResponseAreaExtension","Extension","create","name","addCommands","insertResponseArea","type","tr","state","dispatch","schema","selection","position","$from","pos","RESP_MAP","node","nodes","index","id","value","insert","ExplicitConstructedResponseNode","Node","group","inline","atom","addAttributes","parseHTML","tag","getAttrs","el","dataset","renderHTML","HTMLAttributes","addNodeView","props","options","MathTemplatedNode","DragInTheBlankNode","inTable","InlineDropdownNode"],"mappings":"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","sourcesContent":["import React from 'react';\nimport { Node, ReactNodeViewRenderer, ReactRenderer } from '@tiptap/react';\nimport ExplicitConstructedResponse from '../components/respArea/ExplicitConstructedResponse';\nimport DragInTheBlank from '../components/respArea/DragInTheBlank/DragInTheBlank';\nimport InlineDropdown from '../components/respArea/InlineDropdown';\nimport { Extension } from '@tiptap/core';\n\nexport const ResponseAreaExtension = Extension.create({\n  name: 'responseArea',\n  addCommands() {\n    return {\n      insertResponseArea: (type) => ({ tr, state, dispatch }) => {\n        const { schema, selection } = state;\n        const position = selection.$from.pos;\n        const RESP_MAP = {\n          'drag-in-the-blank': 'drag_in_the_blank',\n          'explicit-constructed-response': 'explicit_constructed_response',\n          'inline-dropdown': 'inline_dropdown',\n        };\n\n        const node = schema.nodes[RESP_MAP[type]].create({\n          index: '1',\n          id: '1',\n          value: '',\n        });\n\n        if (dispatch) {\n          tr.insert(position, node);\n          dispatch(tr);\n        }\n\n        return true;\n      },\n    };\n  },\n});\n\n/**\n * ExplicitConstructedResponse Node\n */\nexport const ExplicitConstructedResponseNode = Node.create({\n  name: 'explicit_constructed_response',\n  group: 'inline',\n  inline: true,\n  atom: true,\n  addAttributes() {\n    return {\n      index: { default: null },\n      value: { default: '' },\n    };\n  },\n  parseHTML() {\n    return [\n      {\n        tag: 'span[data-type=\"explicit_constructed_response\"]',\n        getAttrs: (el) => ({\n          index: el.dataset.index,\n          value: el.dataset.value,\n        }),\n      },\n    ];\n  },\n  renderHTML({ HTMLAttributes }) {\n    return [\n      'span',\n      {\n        'data-type': 'explicit_constructed_response',\n        'data-index': HTMLAttributes.index,\n        'data-value': HTMLAttributes.value,\n      },\n    ];\n  },\n  addNodeView() {\n    return ReactNodeViewRenderer((props) => <ExplicitConstructedResponse {...{ ...props, options: this.options }} />);\n  },\n});\n\n/**\n * MathTemplated Node\n */\nexport const MathTemplatedNode = Node.create({\n  name: 'math_templated',\n  group: 'inline',\n  inline: true,\n  atom: true,\n  addAttributes() {\n    return {\n      index: { default: null },\n      value: { default: '' },\n    };\n  },\n  parseHTML() {\n    return [\n      {\n        tag: 'span[data-type=\"math_templated\"]',\n        getAttrs: (el) => ({\n          index: el.dataset.index,\n          value: el.dataset.value,\n        }),\n      },\n    ];\n  },\n  renderHTML({ HTMLAttributes }) {\n    return [\n      'span',\n      {\n        'data-type': 'math_templated',\n        'data-index': HTMLAttributes.index,\n        'data-value': HTMLAttributes.value,\n      },\n    ];\n  },\n  addNodeView() {\n    return ReactNodeViewRenderer(() => <div></div>);\n  },\n});\n\n/**\n * DragInTheBlank Node\n */\nexport const DragInTheBlankNode = Node.create({\n  name: 'drag_in_the_blank',\n  group: 'inline',\n  inline: true,\n  atom: true,\n  addAttributes() {\n    return {\n      index: { default: null },\n      id: { default: null },\n      value: { default: '' },\n      inTable: { default: null },\n    };\n  },\n  parseHTML() {\n    return [\n      {\n        tag: 'span[data-type=\"drag_in_the_blank\"]',\n        getAttrs: (el) => ({\n          index: el.dataset.index,\n          id: el.dataset.id,\n          value: el.dataset.value,\n          inTable: el.dataset.inTable,\n        }),\n      },\n    ];\n  },\n  renderHTML({ HTMLAttributes }) {\n    return [\n      'span',\n      {\n        'data-type': 'drag_in_the_blank',\n        'data-index': HTMLAttributes.index,\n        'data-id': HTMLAttributes.id,\n        'data-value': HTMLAttributes.value,\n        'data-in-table': HTMLAttributes.inTable,\n      },\n    ];\n  },\n  addNodeView() {\n    return ReactNodeViewRenderer((props) => <DragInTheBlank {...{ ...props, options: this.options }} />);\n  },\n});\n\n/**\n * InlineDropdown Node\n */\nexport const InlineDropdownNode = Node.create({\n  name: 'inline_dropdown',\n  group: 'inline',\n  inline: true,\n  atom: true,\n  addAttributes() {\n    return {\n      index: { default: null },\n      value: { default: '' },\n    };\n  },\n  parseHTML() {\n    return [\n      {\n        tag: 'span[data-type=\"inline_dropdown\"]',\n        getAttrs: (el) => ({\n          index: el.dataset.index,\n          value: el.dataset.value,\n        }),\n      },\n    ];\n  },\n  renderHTML({ HTMLAttributes }) {\n    return [\n      'span',\n      {\n        'data-type': 'inline_dropdown',\n        'data-index': HTMLAttributes.index,\n        'data-value': HTMLAttributes.value,\n      },\n    ];\n  },\n  addNodeView() {\n    return ReactNodeViewRenderer((props) => <InlineDropdown {...{ ...props, options: this.options }} />);\n  },\n});\n"]}
|
|
452
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/extensions/responseArea.js"],"names":["lastIndexMap","normalizeType","type","String","replace","getAttrIndex","node","attrs","index","collectNodesOfType","doc","typeName","results","descendants","pos","name","push","countNodesOfType","count","getDefaultNode","schema","nodeType","nodes","create","id","value","selectionAfterPos","$pos","resolve","Math","min","content","size","TextSelection","near","ResponseAreaExtension","Extension","addOptions","maxResponseAreas","error","options","respAreaToolbar","onHandleAreaChange","addProseMirrorPlugins","key","PluginKey","Plugin","view","undefined","state","idx","n","parseInt","Number","isNaN","update","prevState","eq","currentList","oldList","toolbar","disabled","length","currentIndexSet","Set","map","x","removed","filter","has","addCommands","insertResponseArea","tr","dispatch","commands","currentCount","prevIndex","newIndex","newInline","selection","insertPos","from","tryInsertAt","insert","e","usedPos","after","nodeSize","setSelection","focus","ExplicitConstructedResponseNode","Node","group","inline","atom","addAttributes","parseHTML","tag","getAttrs","el","dataset","renderHTML","HTMLAttributes","addNodeView","props","MathTemplatedNode","DragInTheBlankNode","inTable","InlineDropdownNode"],"mappings":"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","sourcesContent":["import React from 'react';\nimport { Plugin, PluginKey, TextSelection } from 'prosemirror-state';\nimport { Extension } from '@tiptap/core';\nimport { Node, ReactNodeViewRenderer } from '@tiptap/react';\nimport ExplicitConstructedResponse from '../components/respArea/ExplicitConstructedResponse';\nimport DragInTheBlank from '../components/respArea/DragInTheBlank/DragInTheBlank';\nimport InlineDropdown from '../components/respArea/InlineDropdown';\nimport PropTypes from 'prop-types';\n\nconst lastIndexMap = {};\n\nconst normalizeType = (type) => String(type || '').replace(/-/g, '_');\n\nconst getAttrIndex = (node) => (node && node.attrs && node.attrs.index != null ? String(node.attrs.index) : null);\n\nconst collectNodesOfType = (doc, typeName) => {\n  const results = [];\n\n  doc.descendants((node, pos) => {\n    if (node.type && node.type.name === typeName) {\n      const index = getAttrIndex(node);\n      if (index != null) results.push({ index, pos, node });\n    }\n    return true;\n  });\n\n  return results;\n};\n\nconst countNodesOfType = (doc, typeName) => {\n  let count = 0;\n  doc.descendants((node) => {\n    if (node.type && node.type.name === typeName) count += 1;\n    return true;\n  });\n  return count;\n};\n\nconst getDefaultNode = ({ schema, typeName, index }) => {\n  const nodeType = schema.nodes[typeName];\n  if (!nodeType) return null;\n\n  // mirror your Slate \"getDefaultElement(opts, newIndex)\"\n  // customize attrs as needed:\n  return nodeType.create({\n    index: String(index),\n    id: String(index),\n    value: '',\n  });\n};\n\n// Find a good cursor position *after* an inserted node.\nconst selectionAfterPos = (doc, pos) => {\n  const $pos = doc.resolve(Math.min(pos, doc.content.size));\n  return TextSelection.near($pos, 1);\n};\n\nexport const ResponseAreaExtension = Extension.create({\n  name: 'responseArea',\n\n  addOptions() {\n    return {\n      maxResponseAreas: null,\n      error: null,\n      options: null,\n      respAreaToolbar: null,\n      onHandleAreaChange: null,\n    };\n  },\n\n  addProseMirrorPlugins() {\n    if (!this.options.type) {\n      return [];\n    }\n\n    const typeName = normalizeType(this.options.type);\n    const key = new PluginKey(`response-area-watcher:${typeName}`);\n\n    return [\n      new Plugin({\n        key,\n\n        view: (view) => {\n          // Lazy init lastIndexMap[typeName]\n          if (lastIndexMap[typeName] === undefined) {\n            lastIndexMap[typeName] = 0;\n\n            view.state.doc.descendants((node) => {\n              if (node.type && node.type.name === typeName) {\n                const idx = getAttrIndex(node);\n                if (idx != null) {\n                  const n = parseInt(idx, 10);\n                  if (!Number.isNaN(n) && n > lastIndexMap[typeName]) {\n                    lastIndexMap[typeName] = n;\n                  }\n                }\n              }\n              return true;\n            });\n          }\n\n          return {\n            update: (view, prevState) => {\n              const state = view.state;\n              if (prevState.doc.eq(state.doc)) return;\n\n              const currentList = collectNodesOfType(state.doc, typeName);\n              const oldList = collectNodesOfType(prevState.doc, typeName);\n\n              if (this.options.toolbar) {\n                this.options.toolbar.disabled = currentList.length >= this.options.maxResponseAreas;\n              }\n\n              // Removed elements (same logic as Slate)\n              if (oldList.length > currentList.length) {\n                const currentIndexSet = new Set(currentList.map((x) => x.index));\n\n                const removed = oldList.filter((x) => !currentIndexSet.has(x.index));\n\n                if (removed.length && typeof this.options.onHandleAreaChange === 'function') {\n                  this.options.onHandleAreaChange(removed);\n                }\n              }\n            },\n          };\n        },\n      }),\n    ];\n  },\n\n  addCommands() {\n    return {\n      insertResponseArea: (type) => ({ tr, state, dispatch, commands }) => {\n        const typeName = normalizeType(type);\n\n        // --- Slate: currentRespAreaList + max check ---\n        const currentCount = countNodesOfType(state.doc, typeName);\n        if (currentCount >= this.options.maxResponseAreas) {\n          return false;\n        }\n\n        // --- Slate: indexing logic (kept identical) ---\n        if (lastIndexMap[typeName] === undefined) lastIndexMap[typeName] = 0;\n\n        const prevIndex = lastIndexMap[typeName];\n        const newIndex = prevIndex === 0 ? prevIndex : prevIndex + 1;\n\n        // Slate increments map even if newIndex === 0\n        lastIndexMap[typeName] += 1;\n\n        const newInline = getDefaultNode({\n          schema: state.schema,\n          typeName,\n          index: newIndex,\n        });\n\n        if (!newInline) return false;\n\n        // --- Insert logic ---\n        const { selection } = state;\n        let insertPos = selection.from;\n\n        // If we're in a NodeSelection, insert before/after is ambiguous;\n        // We'll insert at its \"from\" (like your current code).\n        // If insertion fails, we fallback to end of doc.\n        const tryInsertAt = (pos) => {\n          try {\n            tr.insert(pos, newInline);\n            return pos;\n          } catch (e) {\n            return null;\n          }\n        };\n\n        let usedPos = tryInsertAt(insertPos);\n\n        // Slate branch: \"markup empty and there's no focus\"\n        // ProseMirror doesn't expose \"no focus\" the same way, so the closest\n        // equivalent fallback is inserting at end of document.\n        if (usedPos == null) {\n          usedPos = tryInsertAt(tr.doc.content.size);\n        }\n        if (usedPos == null) return false;\n\n        // Optionally select the node you just inserted (like your original command)\n        // tr.setSelection(NodeSelection.create(tr.doc, usedPos))\n\n        // --- Cursor move behavior for certain types (Slate: moveFocusTo next text) ---\n        if (typeName === 'drag_in_the_blank' || typeName === 'math_templated') {\n          const after = usedPos + newInline.nodeSize;\n          tr.setSelection(selectionAfterPos(tr.doc, after));\n        } else {\n          // Default: put cursor after inserted node\n          const after = usedPos + newInline.nodeSize;\n          tr.setSelection(selectionAfterPos(tr.doc, after));\n        }\n\n        if (dispatch) {\n          commands.focus();\n          dispatch(tr);\n        }\n\n        return true;\n      },\n    };\n  },\n});\n\n/**\n * ExplicitConstructedResponse Node\n */\nexport const ExplicitConstructedResponseNode = Node.create({\n  name: 'explicit_constructed_response',\n  group: 'inline',\n  inline: true,\n  atom: true,\n  addAttributes() {\n    return {\n      index: { default: null },\n      value: { default: '' },\n    };\n  },\n  parseHTML() {\n    return [\n      {\n        tag: 'span[data-type=\"explicit_constructed_response\"]',\n        getAttrs: (el) => ({\n          index: el.dataset.index,\n          value: el.dataset.value,\n        }),\n      },\n    ];\n  },\n  renderHTML({ HTMLAttributes }) {\n    return [\n      'span',\n      {\n        'data-type': 'explicit_constructed_response',\n        'data-index': HTMLAttributes.index,\n        'data-value': HTMLAttributes.value,\n      },\n    ];\n  },\n  addNodeView() {\n    return ReactNodeViewRenderer((props) => <ExplicitConstructedResponse {...{ ...props, options: this.options }} />);\n  },\n});\n\n/**\n * MathTemplated Node\n */\nexport const MathTemplatedNode = Node.create({\n  name: 'math_templated',\n  group: 'inline',\n  inline: true,\n  atom: true,\n  addAttributes() {\n    return {\n      index: { default: null },\n      value: { default: '' },\n    };\n  },\n  parseHTML() {\n    return [\n      {\n        tag: 'span[data-type=\"math_templated\"]',\n        getAttrs: (el) => ({\n          index: el.dataset.index,\n          value: el.dataset.value,\n        }),\n      },\n    ];\n  },\n  renderHTML({ HTMLAttributes }) {\n    return [\n      'span',\n      {\n        'data-type': 'math_templated',\n        'data-index': HTMLAttributes.index,\n        'data-value': HTMLAttributes.value,\n      },\n    ];\n  },\n  addNodeView() {\n    return ReactNodeViewRenderer(() => <div></div>);\n  },\n});\n\n/**\n * DragInTheBlank Node\n */\nexport const DragInTheBlankNode = Node.create({\n  name: 'drag_in_the_blank',\n  group: 'inline',\n  inline: true,\n  atom: true,\n  addAttributes() {\n    return {\n      index: { default: null },\n      id: { default: null },\n      value: { default: '' },\n      inTable: { default: null },\n    };\n  },\n  parseHTML() {\n    return [\n      {\n        tag: 'span[data-type=\"drag_in_the_blank\"]',\n        getAttrs: (el) => ({\n          index: el.dataset.index,\n          id: el.dataset.id,\n          value: el.dataset.value,\n          inTable: el.dataset.inTable,\n        }),\n      },\n    ];\n  },\n  renderHTML({ HTMLAttributes }) {\n    return [\n      'span',\n      {\n        'data-type': 'drag_in_the_blank',\n        'data-index': HTMLAttributes.index,\n        'data-id': HTMLAttributes.id,\n        'data-value': HTMLAttributes.value,\n        'data-in-table': HTMLAttributes.inTable,\n      },\n    ];\n  },\n  addNodeView() {\n    return ReactNodeViewRenderer((props) => <DragInTheBlank {...{ ...props, options: this.options }} />);\n  },\n});\n\n/**\n * InlineDropdown Node\n */\nexport const InlineDropdownNode = Node.create({\n  name: 'inline_dropdown',\n  group: 'inline',\n  inline: true,\n  atom: true,\n  addAttributes() {\n    return {\n      index: { default: null },\n      value: { default: '' },\n    };\n  },\n  parseHTML() {\n    return [\n      {\n        tag: 'span[data-type=\"inline_dropdown\"]',\n        getAttrs: (el) => ({\n          index: el.dataset.index,\n          value: el.dataset.value,\n        }),\n      },\n    ];\n  },\n  renderHTML({ HTMLAttributes }) {\n    return [\n      'span',\n      {\n        'data-type': 'inline_dropdown',\n        'data-index': HTMLAttributes.index,\n        'data-value': HTMLAttributes.value,\n      },\n    ];\n  },\n  addNodeView() {\n    return ReactNodeViewRenderer((props) => <InlineDropdown {...{ ...props, options: this.options }} />);\n  },\n});\n"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@pie-lib/editable-html-tip-tap",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.14",
|
|
4
4
|
"description": "",
|
|
5
5
|
"license": "ISC",
|
|
6
6
|
"main": "lib/index.js",
|
|
@@ -18,20 +18,19 @@
|
|
|
18
18
|
"@tiptap/core": "3.0.9",
|
|
19
19
|
"@tiptap/extension-character-count": "3.0.9",
|
|
20
20
|
"@tiptap/extension-color": "3.0.9",
|
|
21
|
+
"@tiptap/extension-image": "3.0.9",
|
|
21
22
|
"@tiptap/extension-list-item": "3.0.9",
|
|
23
|
+
"@tiptap/extension-subscript": "3.0.9",
|
|
24
|
+
"@tiptap/extension-superscript": "3.0.9",
|
|
22
25
|
"@tiptap/extension-table": "3.0.9",
|
|
23
26
|
"@tiptap/extension-table-cell": "3.0.9",
|
|
24
27
|
"@tiptap/extension-table-header": "3.0.9",
|
|
25
28
|
"@tiptap/extension-table-row": "3.0.9",
|
|
26
|
-
"@tiptap/extension-text-style": "3.0.9",
|
|
27
|
-
"@tiptap/extension-superscript": "3.0.9",
|
|
28
|
-
"@tiptap/extension-subscript": "3.0.9",
|
|
29
29
|
"@tiptap/extension-text-align": "3.0.9",
|
|
30
|
-
"@tiptap/extension-
|
|
30
|
+
"@tiptap/extension-text-style": "3.0.9",
|
|
31
31
|
"@tiptap/pm": "3.0.9",
|
|
32
32
|
"@tiptap/react": "3.0.9",
|
|
33
33
|
"@tiptap/starter-kit": "3.0.9",
|
|
34
|
-
"tippy.js": "latest",
|
|
35
34
|
"change-case": "^3.0.2",
|
|
36
35
|
"classnames": "^2.2.6",
|
|
37
36
|
"debug": "^4.1.1",
|
|
@@ -52,6 +51,7 @@
|
|
|
52
51
|
"slate-react": "^0.14.3",
|
|
53
52
|
"slate-schema-violations": "^0.1.39",
|
|
54
53
|
"slate-soft-break": "^0.8.1",
|
|
54
|
+
"tippy.js": "latest",
|
|
55
55
|
"to-style": "^1.3.3"
|
|
56
56
|
},
|
|
57
57
|
"devDependencies": {
|
|
@@ -139,7 +139,7 @@ export const EditableHtml = (props) => {
|
|
|
139
139
|
TableRow,
|
|
140
140
|
TableHeader,
|
|
141
141
|
TableCell,
|
|
142
|
-
ResponseAreaExtension,
|
|
142
|
+
ResponseAreaExtension.configure(props.responseAreaProps),
|
|
143
143
|
ExplicitConstructedResponseNode.configure(props.responseAreaProps),
|
|
144
144
|
DragInTheBlankNode.configure(props.responseAreaProps),
|
|
145
145
|
InlineDropdownNode.configure(props.responseAreaProps),
|
|
@@ -240,7 +240,15 @@ export const EditableHtml = (props) => {
|
|
|
240
240
|
},
|
|
241
241
|
editable: !props.disabled,
|
|
242
242
|
content: props.markup,
|
|
243
|
-
onUpdate: ({ editor, transaction }) =>
|
|
243
|
+
onUpdate: ({ editor, transaction }) => {
|
|
244
|
+
if (transaction.isDone) {
|
|
245
|
+
props.onChange?.(editor.getHTML());
|
|
246
|
+
}
|
|
247
|
+
|
|
248
|
+
if (props.responseAreaProps?.onHandleAreaChange) {
|
|
249
|
+
// props.responseAreaProps.onHandleAreaChange(editor.getHTML());
|
|
250
|
+
}
|
|
251
|
+
},
|
|
244
252
|
onBlur: ({ editor }) => {
|
|
245
253
|
if (toolbarOptsToUse.doneOn === 'blur') {
|
|
246
254
|
props.onDone?.(editor.getHTML());
|
|
@@ -5,12 +5,22 @@ import PropTypes from 'prop-types';
|
|
|
5
5
|
const ExplicitConstructedResponse = (props) => {
|
|
6
6
|
const { editor, node, getPos, options, selected } = props;
|
|
7
7
|
const { attrs: attributes } = node;
|
|
8
|
-
const { value
|
|
8
|
+
const { value } = attributes;
|
|
9
|
+
const { respAreaToolbar, error: errorFn } = options;
|
|
9
10
|
const pos = getPos();
|
|
10
11
|
const [showToolbar, setShowToolbar] = useState(false);
|
|
11
|
-
const EcrToolbar =
|
|
12
|
+
const EcrToolbar = respAreaToolbar(node, editor, () => {});
|
|
12
13
|
const toolbarRef = useRef(null);
|
|
13
14
|
|
|
15
|
+
let error;
|
|
16
|
+
|
|
17
|
+
if (errorFn) {
|
|
18
|
+
const errorValue = errorFn();
|
|
19
|
+
const respIndex = parseInt(attributes.index, 10);
|
|
20
|
+
|
|
21
|
+
error = !!errorValue?.[respIndex]?.[0];
|
|
22
|
+
}
|
|
23
|
+
|
|
14
24
|
const handleDone = (newLatex) => {
|
|
15
25
|
updateAttributes({ latex: newLatex });
|
|
16
26
|
setShowToolbar(false);
|
|
@@ -75,6 +85,7 @@ const ExplicitConstructedResponse = (props) => {
|
|
|
75
85
|
overflow: 'hidden',
|
|
76
86
|
padding: '12px 21px',
|
|
77
87
|
margin: '0 4px',
|
|
88
|
+
minWidth: '178px',
|
|
78
89
|
visibility: showToolbar ? 'hidden' : 'visible',
|
|
79
90
|
}}
|
|
80
91
|
onClick={() => setShowToolbar(true)}
|
|
@@ -1,31 +1,202 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
-
import {
|
|
2
|
+
import { Plugin, PluginKey, TextSelection } from 'prosemirror-state';
|
|
3
|
+
import { Extension } from '@tiptap/core';
|
|
4
|
+
import { Node, ReactNodeViewRenderer } from '@tiptap/react';
|
|
3
5
|
import ExplicitConstructedResponse from '../components/respArea/ExplicitConstructedResponse';
|
|
4
6
|
import DragInTheBlank from '../components/respArea/DragInTheBlank/DragInTheBlank';
|
|
5
7
|
import InlineDropdown from '../components/respArea/InlineDropdown';
|
|
6
|
-
import
|
|
8
|
+
import PropTypes from 'prop-types';
|
|
9
|
+
|
|
10
|
+
const lastIndexMap = {};
|
|
11
|
+
|
|
12
|
+
const normalizeType = (type) => String(type || '').replace(/-/g, '_');
|
|
13
|
+
|
|
14
|
+
const getAttrIndex = (node) => (node && node.attrs && node.attrs.index != null ? String(node.attrs.index) : null);
|
|
15
|
+
|
|
16
|
+
const collectNodesOfType = (doc, typeName) => {
|
|
17
|
+
const results = [];
|
|
18
|
+
|
|
19
|
+
doc.descendants((node, pos) => {
|
|
20
|
+
if (node.type && node.type.name === typeName) {
|
|
21
|
+
const index = getAttrIndex(node);
|
|
22
|
+
if (index != null) results.push({ index, pos, node });
|
|
23
|
+
}
|
|
24
|
+
return true;
|
|
25
|
+
});
|
|
26
|
+
|
|
27
|
+
return results;
|
|
28
|
+
};
|
|
29
|
+
|
|
30
|
+
const countNodesOfType = (doc, typeName) => {
|
|
31
|
+
let count = 0;
|
|
32
|
+
doc.descendants((node) => {
|
|
33
|
+
if (node.type && node.type.name === typeName) count += 1;
|
|
34
|
+
return true;
|
|
35
|
+
});
|
|
36
|
+
return count;
|
|
37
|
+
};
|
|
38
|
+
|
|
39
|
+
const getDefaultNode = ({ schema, typeName, index }) => {
|
|
40
|
+
const nodeType = schema.nodes[typeName];
|
|
41
|
+
if (!nodeType) return null;
|
|
42
|
+
|
|
43
|
+
// mirror your Slate "getDefaultElement(opts, newIndex)"
|
|
44
|
+
// customize attrs as needed:
|
|
45
|
+
return nodeType.create({
|
|
46
|
+
index: String(index),
|
|
47
|
+
id: String(index),
|
|
48
|
+
value: '',
|
|
49
|
+
});
|
|
50
|
+
};
|
|
51
|
+
|
|
52
|
+
// Find a good cursor position *after* an inserted node.
|
|
53
|
+
const selectionAfterPos = (doc, pos) => {
|
|
54
|
+
const $pos = doc.resolve(Math.min(pos, doc.content.size));
|
|
55
|
+
return TextSelection.near($pos, 1);
|
|
56
|
+
};
|
|
7
57
|
|
|
8
58
|
export const ResponseAreaExtension = Extension.create({
|
|
9
59
|
name: 'responseArea',
|
|
60
|
+
|
|
61
|
+
addOptions() {
|
|
62
|
+
return {
|
|
63
|
+
maxResponseAreas: null,
|
|
64
|
+
error: null,
|
|
65
|
+
options: null,
|
|
66
|
+
respAreaToolbar: null,
|
|
67
|
+
onHandleAreaChange: null,
|
|
68
|
+
};
|
|
69
|
+
},
|
|
70
|
+
|
|
71
|
+
addProseMirrorPlugins() {
|
|
72
|
+
if (!this.options.type) {
|
|
73
|
+
return [];
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
const typeName = normalizeType(this.options.type);
|
|
77
|
+
const key = new PluginKey(`response-area-watcher:${typeName}`);
|
|
78
|
+
|
|
79
|
+
return [
|
|
80
|
+
new Plugin({
|
|
81
|
+
key,
|
|
82
|
+
|
|
83
|
+
view: (view) => {
|
|
84
|
+
// Lazy init lastIndexMap[typeName]
|
|
85
|
+
if (lastIndexMap[typeName] === undefined) {
|
|
86
|
+
lastIndexMap[typeName] = 0;
|
|
87
|
+
|
|
88
|
+
view.state.doc.descendants((node) => {
|
|
89
|
+
if (node.type && node.type.name === typeName) {
|
|
90
|
+
const idx = getAttrIndex(node);
|
|
91
|
+
if (idx != null) {
|
|
92
|
+
const n = parseInt(idx, 10);
|
|
93
|
+
if (!Number.isNaN(n) && n > lastIndexMap[typeName]) {
|
|
94
|
+
lastIndexMap[typeName] = n;
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
return true;
|
|
99
|
+
});
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
return {
|
|
103
|
+
update: (view, prevState) => {
|
|
104
|
+
const state = view.state;
|
|
105
|
+
if (prevState.doc.eq(state.doc)) return;
|
|
106
|
+
|
|
107
|
+
const currentList = collectNodesOfType(state.doc, typeName);
|
|
108
|
+
const oldList = collectNodesOfType(prevState.doc, typeName);
|
|
109
|
+
|
|
110
|
+
if (this.options.toolbar) {
|
|
111
|
+
this.options.toolbar.disabled = currentList.length >= this.options.maxResponseAreas;
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
// Removed elements (same logic as Slate)
|
|
115
|
+
if (oldList.length > currentList.length) {
|
|
116
|
+
const currentIndexSet = new Set(currentList.map((x) => x.index));
|
|
117
|
+
|
|
118
|
+
const removed = oldList.filter((x) => !currentIndexSet.has(x.index));
|
|
119
|
+
|
|
120
|
+
if (removed.length && typeof this.options.onHandleAreaChange === 'function') {
|
|
121
|
+
this.options.onHandleAreaChange(removed);
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
},
|
|
125
|
+
};
|
|
126
|
+
},
|
|
127
|
+
}),
|
|
128
|
+
];
|
|
129
|
+
},
|
|
130
|
+
|
|
10
131
|
addCommands() {
|
|
11
132
|
return {
|
|
12
|
-
insertResponseArea: (type) => ({ tr, state, dispatch }) => {
|
|
13
|
-
const
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
}
|
|
133
|
+
insertResponseArea: (type) => ({ tr, state, dispatch, commands }) => {
|
|
134
|
+
const typeName = normalizeType(type);
|
|
135
|
+
|
|
136
|
+
// --- Slate: currentRespAreaList + max check ---
|
|
137
|
+
const currentCount = countNodesOfType(state.doc, typeName);
|
|
138
|
+
if (currentCount >= this.options.maxResponseAreas) {
|
|
139
|
+
return false;
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
// --- Slate: indexing logic (kept identical) ---
|
|
143
|
+
if (lastIndexMap[typeName] === undefined) lastIndexMap[typeName] = 0;
|
|
144
|
+
|
|
145
|
+
const prevIndex = lastIndexMap[typeName];
|
|
146
|
+
const newIndex = prevIndex === 0 ? prevIndex : prevIndex + 1;
|
|
20
147
|
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
148
|
+
// Slate increments map even if newIndex === 0
|
|
149
|
+
lastIndexMap[typeName] += 1;
|
|
150
|
+
|
|
151
|
+
const newInline = getDefaultNode({
|
|
152
|
+
schema: state.schema,
|
|
153
|
+
typeName,
|
|
154
|
+
index: newIndex,
|
|
25
155
|
});
|
|
26
156
|
|
|
157
|
+
if (!newInline) return false;
|
|
158
|
+
|
|
159
|
+
// --- Insert logic ---
|
|
160
|
+
const { selection } = state;
|
|
161
|
+
let insertPos = selection.from;
|
|
162
|
+
|
|
163
|
+
// If we're in a NodeSelection, insert before/after is ambiguous;
|
|
164
|
+
// We'll insert at its "from" (like your current code).
|
|
165
|
+
// If insertion fails, we fallback to end of doc.
|
|
166
|
+
const tryInsertAt = (pos) => {
|
|
167
|
+
try {
|
|
168
|
+
tr.insert(pos, newInline);
|
|
169
|
+
return pos;
|
|
170
|
+
} catch (e) {
|
|
171
|
+
return null;
|
|
172
|
+
}
|
|
173
|
+
};
|
|
174
|
+
|
|
175
|
+
let usedPos = tryInsertAt(insertPos);
|
|
176
|
+
|
|
177
|
+
// Slate branch: "markup empty and there's no focus"
|
|
178
|
+
// ProseMirror doesn't expose "no focus" the same way, so the closest
|
|
179
|
+
// equivalent fallback is inserting at end of document.
|
|
180
|
+
if (usedPos == null) {
|
|
181
|
+
usedPos = tryInsertAt(tr.doc.content.size);
|
|
182
|
+
}
|
|
183
|
+
if (usedPos == null) return false;
|
|
184
|
+
|
|
185
|
+
// Optionally select the node you just inserted (like your original command)
|
|
186
|
+
// tr.setSelection(NodeSelection.create(tr.doc, usedPos))
|
|
187
|
+
|
|
188
|
+
// --- Cursor move behavior for certain types (Slate: moveFocusTo next text) ---
|
|
189
|
+
if (typeName === 'drag_in_the_blank' || typeName === 'math_templated') {
|
|
190
|
+
const after = usedPos + newInline.nodeSize;
|
|
191
|
+
tr.setSelection(selectionAfterPos(tr.doc, after));
|
|
192
|
+
} else {
|
|
193
|
+
// Default: put cursor after inserted node
|
|
194
|
+
const after = usedPos + newInline.nodeSize;
|
|
195
|
+
tr.setSelection(selectionAfterPos(tr.doc, after));
|
|
196
|
+
}
|
|
197
|
+
|
|
27
198
|
if (dispatch) {
|
|
28
|
-
|
|
199
|
+
commands.focus();
|
|
29
200
|
dispatch(tr);
|
|
30
201
|
}
|
|
31
202
|
|