@pie-lib/editable-html-tip-tap 1.0.13 → 1.0.15

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.
@@ -65,6 +65,8 @@ var _size = require("../utils/size");
65
65
 
66
66
  var _extensions = require("../extensions");
67
67
 
68
+ var _editableHtml = require("@pie-lib/editable-html");
69
+
68
70
  var _excluded = ["customPlugins"];
69
71
 
70
72
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
@@ -162,7 +164,7 @@ var EditableHtml = function EditableHtml(props) {
162
164
  }, [props]);
163
165
  var extensions = [_extensionTextStyle.TextStyleKit, _extensionCharacterCount.CharacterCount.configure({
164
166
  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({
167
+ }), _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
168
  toolbarOpts: toolbarOptsToUse
167
169
  }), _extensionSubscript["default"], _extensionSuperscript["default"], _extensionTextAlign["default"].configure({
168
170
  types: ['heading', 'paragraph'],
@@ -255,23 +257,33 @@ var EditableHtml = function EditableHtml(props) {
255
257
  editable: !props.disabled,
256
258
  content: props.markup,
257
259
  onUpdate: function onUpdate(_ref4) {
258
- var _props$onChange;
260
+ var _props$responseAreaPr2;
259
261
 
260
262
  var editor = _ref4.editor,
261
263
  transaction = _ref4.transaction;
262
- return transaction.isDone && ((_props$onChange = props.onChange) === null || _props$onChange === void 0 ? void 0 : _props$onChange.call(props, editor.getHTML()));
264
+
265
+ if (transaction.isDone) {
266
+ var _props$onChange;
267
+
268
+ (_props$onChange = props.onChange) === null || _props$onChange === void 0 ? void 0 : _props$onChange.call(props, editor.getHTML());
269
+ }
270
+
271
+ if ((_props$responseAreaPr2 = props.responseAreaProps) !== null && _props$responseAreaPr2 !== void 0 && _props$responseAreaPr2.onHandleAreaChange) {// props.responseAreaProps.onHandleAreaChange(editor.getHTML());
272
+ }
263
273
  },
264
274
  onBlur: function onBlur(_ref5) {
265
275
  var editor = _ref5.editor;
266
276
 
277
+ if (props.markup !== editor.getHTML()) {
278
+ var _props$onChange2;
279
+
280
+ (_props$onChange2 = props.onChange) === null || _props$onChange2 === void 0 ? void 0 : _props$onChange2.call(props, editor.getHTML());
281
+ }
282
+
267
283
  if (toolbarOptsToUse.doneOn === 'blur') {
268
284
  var _props$onDone2;
269
285
 
270
286
  (_props$onDone2 = props.onDone) === null || _props$onDone2 === void 0 ? void 0 : _props$onDone2.call(props, editor.getHTML());
271
- } else {
272
- var _props$onChange2;
273
-
274
- (_props$onChange2 = props.onChange) === null || _props$onChange2 === void 0 ? void 0 : _props$onChange2.call(props, editor.getHTML());
275
287
  }
276
288
  }
277
289
  });
@@ -375,4 +387,4 @@ var StyledEditor = (0, _styles.withStyles)({
375
387
  })(EditableHtml);
376
388
  var _default = StyledEditor;
377
389
  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"]}
390
+ //# 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';\nimport { htmlToValue } from \"@pie-lib/editable-html\";\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 (props.markup !== editor.getHTML()) {\n        props.onChange?.(editor.getHTML());\n      }\n\n      if (toolbarOptsToUse.doneOn === 'blur') {\n        props.onDone?.(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
- error = attributes.error;
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 = options.respAreaToolbar(node, editor, function () {});
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,{"version":3,"sources":["../../../src/components/respArea/ExplicitConstructedResponse.jsx"],"names":["ExplicitConstructedResponse","props","editor","node","getPos","options","selected","attributes","attrs","value","error","pos","showToolbar","setShowToolbar","EcrToolbar","respAreaToolbar","toolbarRef","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","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, error } = attributes;\n  const pos = getPos();\n  const [showToolbar, setShowToolbar] = useState(false);\n  const EcrToolbar = options.respAreaToolbar(node, editor, () => {});\n  const toolbarRef = useRef(null);\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          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"]}
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"]}
@@ -115,6 +115,9 @@ var InlineDropdown = function InlineDropdown(props) {
115
115
  margin: '0 4px',
116
116
  position: 'relative',
117
117
  alignItems: 'center'
118
+ },
119
+ onClick: function onClick() {
120
+ return setShowToolbar(true);
118
121
  }
119
122
  }, /*#__PURE__*/_react["default"].createElement("div", {
120
123
  style: {
@@ -153,4 +156,4 @@ InlineDropdown.propTypes = {
153
156
  };
154
157
  var _default = InlineDropdown;
155
158
  exports["default"] = _default;
156
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/respArea/InlineDropdown.jsx"],"names":["InlineDropdown","props","editor","node","getPos","options","selected","attributes","attrs","value","error","html","toolbarRef","showToolbar","setShowToolbar","top","left","position","setPosition","InlineDropdownToolbar","respAreaToolbar","selection","state","onlyThisNodeSelected","from","nodeSize","to","bodyRect","document","body","getBoundingClientRect","start","view","coordsAtPos","Math","abs","handleClickOutside","event","current","contains","target","closest","addEventListener","removeEventListener","display","height","margin","cursor","minWidth","background","border","boxSizing","borderRadius","alignItems","flex","overflow","padding","whiteSpace","textOverflow","verticalAlign","__html","right","ReactDOM","createPortal","zIndex","propTypes","PropTypes","object","selectedItem","oneOfType","string"],"mappings":"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","sourcesContent":["import React, { useEffect, useRef, useState } from \"react\";\nimport PropTypes from 'prop-types';\nimport { NodeViewWrapper } from '@tiptap/react';\nimport { Chevron } from '../icons/RespArea';\nimport ReactDOM from \"react-dom\";\nimport { MathToolbar } from \"@pie-lib/math-toolbar\";\n\nconst InlineDropdown = (props) => {\n  const { editor, node, getPos, options, selected } = props;\n  const { attrs: attributes } = node;\n  const { value, error } = attributes;\n  // TODO: Investigate\n  // Needed because items with values inside have different positioning for some reason\n  const html = value || '<div>&nbsp</div>';\n  const toolbarRef = useRef(null);\n  const [showToolbar, setShowToolbar] = useState(false);\n  const [position, setPosition] = useState({ top: 0, left: 0 });\n  const InlineDropdownToolbar = options.respAreaToolbar(node, editor, () => {});\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    // Calculate position relative to selection\n    const bodyRect = document.body.getBoundingClientRect();\n    const { from } = editor.state.selection;\n    const start = editor.view.coordsAtPos(from);\n\n    setPosition({\n      top: start.top + Math.abs(bodyRect.top) + 40, // shift above\n      left: start.left,\n    });\n\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=\"inline-dropdown\"\n      data-selected={selected}\n      style={{\n        display: 'inline-flex',\n        height: '50px',\n        margin: '0 5px',\n        cursor: 'pointer',\n      }}\n    >\n      <div\n        style={{\n          display: 'inline-flex',\n          minWidth: '178px',\n          height: '36px',\n          background: '#FFF',\n          border: '1px solid #C0C3CF',\n          boxSizing: 'border-box',\n          borderRadius: '3px',\n          margin: '0 4px',\n          position: 'relative',\n          alignItems: 'center',\n        }}\n      >\n        <div\n          style={{\n            flex: 1,\n            overflow: 'hidden',\n            padding: '0 25px 0 8px',\n            whiteSpace: 'nowrap',\n            textOverflow: 'ellipsis',\n          }}\n        >\n          <span\n            style={{\n              display: 'inline-block',\n              verticalAlign: 'middle',\n            }}\n            dangerouslySetInnerHTML={{\n              __html: html,\n            }}\n          />\n        </div>\n        <Chevron\n          direction=\"down\"\n          style={{\n            position: 'absolute',\n            top: '5px',\n            right: '5px',\n          }}\n        />\n      </div>\n      {showToolbar &&\n        ReactDOM.createPortal(\n          <div ref={toolbarRef} style={{ zIndex: 1 }}>\n            <InlineDropdownToolbar />\n          </div>,\n          document.body,\n        )}\n    </NodeViewWrapper>\n  );\n};\n\nInlineDropdown.propTypes = {\n  attributes: PropTypes.object,\n  selectedItem: PropTypes.oneOfType([PropTypes.string, PropTypes.object]),\n};\n\nexport default InlineDropdown;\n"]}
159
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/respArea/InlineDropdown.jsx"],"names":["InlineDropdown","props","editor","node","getPos","options","selected","attributes","attrs","value","error","html","toolbarRef","showToolbar","setShowToolbar","top","left","position","setPosition","InlineDropdownToolbar","respAreaToolbar","selection","state","onlyThisNodeSelected","from","nodeSize","to","bodyRect","document","body","getBoundingClientRect","start","view","coordsAtPos","Math","abs","handleClickOutside","event","current","contains","target","closest","addEventListener","removeEventListener","display","height","margin","cursor","minWidth","background","border","boxSizing","borderRadius","alignItems","flex","overflow","padding","whiteSpace","textOverflow","verticalAlign","__html","right","ReactDOM","createPortal","zIndex","propTypes","PropTypes","object","selectedItem","oneOfType","string"],"mappings":";;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;;;AAEA,IAAMA,cAAc,GAAG,SAAjBA,cAAiB,CAACC,KAAD,EAAW;AAChC,MAAQC,MAAR,GAAoDD,KAApD,CAAQC,MAAR;AAAA,MAAgBC,IAAhB,GAAoDF,KAApD,CAAgBE,IAAhB;AAAA,MAAsBC,MAAtB,GAAoDH,KAApD,CAAsBG,MAAtB;AAAA,MAA8BC,OAA9B,GAAoDJ,KAApD,CAA8BI,OAA9B;AAAA,MAAuCC,QAAvC,GAAoDL,KAApD,CAAuCK,QAAvC;AACA,MAAeC,UAAf,GAA8BJ,IAA9B,CAAQK,KAAR;AACA,MAAQC,KAAR,GAAyBF,UAAzB,CAAQE,KAAR;AAAA,MAAeC,KAAf,GAAyBH,UAAzB,CAAeG,KAAf,CAHgC,CAIhC;AACA;;AACA,MAAMC,IAAI,GAAGF,KAAK,IAAI,kBAAtB;AACA,MAAMG,UAAU,GAAG,mBAAO,IAAP,CAAnB;;AACA,kBAAsC,qBAAS,KAAT,CAAtC;AAAA;AAAA,MAAOC,WAAP;AAAA,MAAoBC,cAApB;;AACA,mBAAgC,qBAAS;AAAEC,IAAAA,GAAG,EAAE,CAAP;AAAUC,IAAAA,IAAI,EAAE;AAAhB,GAAT,CAAhC;AAAA;AAAA,MAAOC,QAAP;AAAA,MAAiBC,WAAjB;;AACA,MAAMC,qBAAqB,GAAGd,OAAO,CAACe,eAAR,CAAwBjB,IAAxB,EAA8BD,MAA9B,EAAsC,YAAM,CAAE,CAA9C,CAA9B;AAEA,wBAAU,YAAM;AACd,QAAQmB,SAAR,GAAsBnB,MAAM,CAACoB,KAA7B,CAAQD,SAAR;AACA,QAAME,oBAAoB,GAAGF,SAAS,CAACG,IAAV,GAAiBrB,IAAI,CAACsB,QAAtB,KAAmCJ,SAAS,CAACK,EAA1E;;AAEA,QAAIpB,QAAJ,EAAc;AACZ,UAAIiB,oBAAJ,EAA0B;AACxBT,QAAAA,cAAc,CAACR,QAAD,CAAd;AACD;AACF,KAJD,MAIO;AACLQ,MAAAA,cAAc,CAACR,QAAD,CAAd;AACD;AACF,GAXD,EAWG,CAACJ,MAAD,EAASC,IAAT,EAAeG,QAAf,CAXH;AAaA,wBAAU,YAAM;AACd;AACA,QAAMqB,QAAQ,GAAGC,QAAQ,CAACC,IAAT,CAAcC,qBAAd,EAAjB;AACA,QAAQN,IAAR,GAAiBtB,MAAM,CAACoB,KAAP,CAAaD,SAA9B,CAAQG,IAAR;AACA,QAAMO,KAAK,GAAG7B,MAAM,CAAC8B,IAAP,CAAYC,WAAZ,CAAwBT,IAAxB,CAAd;AAEAN,IAAAA,WAAW,CAAC;AACVH,MAAAA,GAAG,EAAEgB,KAAK,CAAChB,GAAN,GAAYmB,IAAI,CAACC,GAAL,CAASR,QAAQ,CAACZ,GAAlB,CAAZ,GAAqC,EADhC;AACoC;AAC9CC,MAAAA,IAAI,EAAEe,KAAK,CAACf;AAFF,KAAD,CAAX;;AAKA,QAAMoB,kBAAkB,GAAG,SAArBA,kBAAqB,CAACC,KAAD,EAAW;AACpC,UACEzB,UAAU,CAAC0B,OAAX,IACA,CAAC1B,UAAU,CAAC0B,OAAX,CAAmBC,QAAnB,CAA4BF,KAAK,CAACG,MAAlC,CADD,IAEA,CAACH,KAAK,CAACG,MAAN,CAAaC,OAAb,CAAqB,oBAArB,CAHH,EAIE;AACA3B,QAAAA,cAAc,CAAC,KAAD,CAAd;AACD;AACF,KARD;;AAUA,QAAID,WAAJ,EAAiB;AACfe,MAAAA,QAAQ,CAACc,gBAAT,CAA0B,WAA1B,EAAuCN,kBAAvC;AACD,KAFD,MAEO;AACLR,MAAAA,QAAQ,CAACe,mBAAT,CAA6B,WAA7B,EAA0CP,kBAA1C;AACD;;AAED,WAAO;AAAA,aAAMR,QAAQ,CAACe,mBAAT,CAA6B,WAA7B,EAA0CP,kBAA1C,CAAN;AAAA,KAAP;AACD,GA5BD,EA4BG,CAACvB,WAAD,CA5BH;AA8BA,sBACE,gCAAC,uBAAD;AACE,IAAA,SAAS,EAAC,iBADZ;AAEE,qBAAeP,QAFjB;AAGE,IAAA,KAAK,EAAE;AACLsC,MAAAA,OAAO,EAAE,aADJ;AAELC,MAAAA,MAAM,EAAE,MAFH;AAGLC,MAAAA,MAAM,EAAE,OAHH;AAILC,MAAAA,MAAM,EAAE;AAJH;AAHT,kBAUE;AACE,IAAA,KAAK,EAAE;AACLH,MAAAA,OAAO,EAAE,aADJ;AAELI,MAAAA,QAAQ,EAAE,OAFL;AAGLH,MAAAA,MAAM,EAAE,MAHH;AAILI,MAAAA,UAAU,EAAE,MAJP;AAKLC,MAAAA,MAAM,EAAE,mBALH;AAMLC,MAAAA,SAAS,EAAE,YANN;AAOLC,MAAAA,YAAY,EAAE,KAPT;AAQLN,MAAAA,MAAM,EAAE,OARH;AASL7B,MAAAA,QAAQ,EAAE,UATL;AAULoC,MAAAA,UAAU,EAAE;AAVP,KADT;AAaE,IAAA,OAAO,EAAE;AAAA,aAAMvC,cAAc,CAAC,IAAD,CAApB;AAAA;AAbX,kBAeE;AACE,IAAA,KAAK,EAAE;AACLwC,MAAAA,IAAI,EAAE,CADD;AAELC,MAAAA,QAAQ,EAAE,QAFL;AAGLC,MAAAA,OAAO,EAAE,cAHJ;AAILC,MAAAA,UAAU,EAAE,QAJP;AAKLC,MAAAA,YAAY,EAAE;AALT;AADT,kBASE;AACE,IAAA,KAAK,EAAE;AACLd,MAAAA,OAAO,EAAE,cADJ;AAELe,MAAAA,aAAa,EAAE;AAFV,KADT;AAKE,IAAA,uBAAuB,EAAE;AACvBC,MAAAA,MAAM,EAAEjD;AADe;AAL3B,IATF,CAfF,eAkCE,gCAAC,iBAAD;AACE,IAAA,SAAS,EAAC,MADZ;AAEE,IAAA,KAAK,EAAE;AACLM,MAAAA,QAAQ,EAAE,UADL;AAELF,MAAAA,GAAG,EAAE,KAFA;AAGL8C,MAAAA,KAAK,EAAE;AAHF;AAFT,IAlCF,CAVF,EAqDGhD,WAAW,iBACViD,qBAASC,YAAT,eACE;AAAK,IAAA,GAAG,EAAEnD,UAAV;AAAsB,IAAA,KAAK,EAAE;AAAEoD,MAAAA,MAAM,EAAE;AAAV;AAA7B,kBACE,gCAAC,qBAAD,OADF,CADF,EAIEpC,QAAQ,CAACC,IAJX,CAtDJ,CADF;AA+DD,CAtHD;;AAwHA7B,cAAc,CAACiE,SAAf,GAA2B;AACzB1D,EAAAA,UAAU,EAAE2D,sBAAUC,MADG;AAEzBC,EAAAA,YAAY,EAAEF,sBAAUG,SAAV,CAAoB,CAACH,sBAAUI,MAAX,EAAmBJ,sBAAUC,MAA7B,CAApB;AAFW,CAA3B;eAKenE,c","sourcesContent":["import React, { useEffect, useRef, useState } from \"react\";\nimport PropTypes from 'prop-types';\nimport { NodeViewWrapper } from '@tiptap/react';\nimport { Chevron } from '../icons/RespArea';\nimport ReactDOM from \"react-dom\";\nimport { MathToolbar } from \"@pie-lib/math-toolbar\";\n\nconst InlineDropdown = (props) => {\n  const { editor, node, getPos, options, selected } = props;\n  const { attrs: attributes } = node;\n  const { value, error } = attributes;\n  // TODO: Investigate\n  // Needed because items with values inside have different positioning for some reason\n  const html = value || '<div>&nbsp</div>';\n  const toolbarRef = useRef(null);\n  const [showToolbar, setShowToolbar] = useState(false);\n  const [position, setPosition] = useState({ top: 0, left: 0 });\n  const InlineDropdownToolbar = options.respAreaToolbar(node, editor, () => {});\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    // Calculate position relative to selection\n    const bodyRect = document.body.getBoundingClientRect();\n    const { from } = editor.state.selection;\n    const start = editor.view.coordsAtPos(from);\n\n    setPosition({\n      top: start.top + Math.abs(bodyRect.top) + 40, // shift above\n      left: start.left,\n    });\n\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=\"inline-dropdown\"\n      data-selected={selected}\n      style={{\n        display: 'inline-flex',\n        height: '50px',\n        margin: '0 5px',\n        cursor: 'pointer',\n      }}\n    >\n      <div\n        style={{\n          display: 'inline-flex',\n          minWidth: '178px',\n          height: '36px',\n          background: '#FFF',\n          border: '1px solid #C0C3CF',\n          boxSizing: 'border-box',\n          borderRadius: '3px',\n          margin: '0 4px',\n          position: 'relative',\n          alignItems: 'center',\n        }}\n        onClick={() => setShowToolbar(true)}\n      >\n        <div\n          style={{\n            flex: 1,\n            overflow: 'hidden',\n            padding: '0 25px 0 8px',\n            whiteSpace: 'nowrap',\n            textOverflow: 'ellipsis',\n          }}\n        >\n          <span\n            style={{\n              display: 'inline-block',\n              verticalAlign: 'middle',\n            }}\n            dangerouslySetInnerHTML={{\n              __html: html,\n            }}\n          />\n        </div>\n        <Chevron\n          direction=\"down\"\n          style={{\n            position: 'absolute',\n            top: '5px',\n            right: '5px',\n          }}\n        />\n      </div>\n      {showToolbar &&\n        ReactDOM.createPortal(\n          <div ref={toolbarRef} style={{ zIndex: 1 }}>\n            <InlineDropdownToolbar />\n          </div>,\n          document.body,\n        )}\n    </NodeViewWrapper>\n  );\n};\n\nInlineDropdown.propTypes = {\n  attributes: PropTypes.object,\n  selectedItem: PropTypes.oneOfType([PropTypes.string, PropTypes.object]),\n};\n\nexport default InlineDropdown;\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,231 @@ var _DragInTheBlank = _interopRequireDefault(require("../components/respArea/Dra
19
23
 
20
24
  var _InlineDropdown = _interopRequireDefault(require("../components/respArea/InlineDropdown"));
21
25
 
22
- var _core = require("@tiptap/core");
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 (_ref) {
34
- var tr = _ref.tr,
35
- state = _ref.state,
36
- dispatch = _ref.dispatch;
37
- var schema = state.schema,
38
- selection = state.selection;
39
- var position = selection.$from.pos;
40
- var RESP_MAP = {
41
- 'drag-in-the-blank': 'drag_in_the_blank',
42
- 'explicit-constructed-response': 'explicit_constructed_response',
43
- 'inline-dropdown': 'inline_dropdown'
44
- };
45
- var node = schema.nodes[RESP_MAP[type]].create({
46
- index: '1',
47
- id: '1',
48
- value: ''
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 === 'inline_dropdown' || typeName === 'math_templated') {
220
+ tr.setSelection(_prosemirrorState.NodeSelection.create(tr.doc, usedPos));
221
+ } else {
222
+ // Default: put cursor after inserted node
223
+ var after = usedPos + newInline.nodeSize;
224
+ tr.setSelection(selectionAfterPos(tr.doc, after));
225
+ }
50
226
 
51
227
  if (dispatch) {
52
- tr.insert(position, node);
228
+ commands.focus();
229
+ dispatch(tr);
230
+ }
231
+
232
+ return true;
233
+ };
234
+ },
235
+ refreshResponseArea: function refreshResponseArea() {
236
+ return function (_ref3) {
237
+ var tr = _ref3.tr,
238
+ state = _ref3.state,
239
+ commands = _ref3.commands,
240
+ dispatch = _ref3.dispatch;
241
+ var selection = state.selection;
242
+ var node = selection.$from.nodeAfter;
243
+ var nodePos = selection.from;
244
+ tr.setNodeMarkup(nodePos, undefined, _objectSpread(_objectSpread({}, node.attrs), {}, {
245
+ updated: "".concat(Date.now())
246
+ }));
247
+ tr.setSelection(_prosemirrorState.NodeSelection.create(tr.doc, nodePos));
248
+
249
+ if (dispatch) {
250
+ commands.focus();
53
251
  dispatch(tr);
54
252
  }
55
253
 
@@ -78,6 +276,9 @@ var ExplicitConstructedResponseNode = _react2.Node.create({
78
276
  },
79
277
  value: {
80
278
  "default": ''
279
+ },
280
+ updated: {
281
+ "default": ''
81
282
  }
82
283
  };
83
284
  },
@@ -92,8 +293,8 @@ var ExplicitConstructedResponseNode = _react2.Node.create({
92
293
  }
93
294
  }];
94
295
  },
95
- renderHTML: function renderHTML(_ref2) {
96
- var HTMLAttributes = _ref2.HTMLAttributes;
296
+ renderHTML: function renderHTML(_ref4) {
297
+ var HTMLAttributes = _ref4.HTMLAttributes;
97
298
  return ['span', {
98
299
  'data-type': 'explicit_constructed_response',
99
300
  'data-index': HTMLAttributes.index,
@@ -101,11 +302,11 @@ var ExplicitConstructedResponseNode = _react2.Node.create({
101
302
  }];
102
303
  },
103
304
  addNodeView: function addNodeView() {
104
- var _this = this;
305
+ var _this3 = this;
105
306
 
106
307
  return (0, _react2.ReactNodeViewRenderer)(function (props) {
107
308
  return /*#__PURE__*/_react["default"].createElement(_ExplicitConstructedResponse["default"], _objectSpread(_objectSpread({}, props), {}, {
108
- options: _this.options
309
+ options: _this3.options
109
310
  }));
110
311
  });
111
312
  }
@@ -129,6 +330,9 @@ var MathTemplatedNode = _react2.Node.create({
129
330
  },
130
331
  value: {
131
332
  "default": ''
333
+ },
334
+ updated: {
335
+ "default": ''
132
336
  }
133
337
  };
134
338
  },
@@ -143,8 +347,8 @@ var MathTemplatedNode = _react2.Node.create({
143
347
  }
144
348
  }];
145
349
  },
146
- renderHTML: function renderHTML(_ref3) {
147
- var HTMLAttributes = _ref3.HTMLAttributes;
350
+ renderHTML: function renderHTML(_ref5) {
351
+ var HTMLAttributes = _ref5.HTMLAttributes;
148
352
  return ['span', {
149
353
  'data-type': 'math_templated',
150
354
  'data-index': HTMLAttributes.index,
@@ -182,6 +386,9 @@ var DragInTheBlankNode = _react2.Node.create({
182
386
  },
183
387
  inTable: {
184
388
  "default": null
389
+ },
390
+ updated: {
391
+ "default": ''
185
392
  }
186
393
  };
187
394
  },
@@ -198,8 +405,8 @@ var DragInTheBlankNode = _react2.Node.create({
198
405
  }
199
406
  }];
200
407
  },
201
- renderHTML: function renderHTML(_ref4) {
202
- var HTMLAttributes = _ref4.HTMLAttributes;
408
+ renderHTML: function renderHTML(_ref6) {
409
+ var HTMLAttributes = _ref6.HTMLAttributes;
203
410
  return ['span', {
204
411
  'data-type': 'drag_in_the_blank',
205
412
  'data-index': HTMLAttributes.index,
@@ -209,11 +416,11 @@ var DragInTheBlankNode = _react2.Node.create({
209
416
  }];
210
417
  },
211
418
  addNodeView: function addNodeView() {
212
- var _this2 = this;
419
+ var _this4 = this;
213
420
 
214
421
  return (0, _react2.ReactNodeViewRenderer)(function (props) {
215
422
  return /*#__PURE__*/_react["default"].createElement(_DragInTheBlank["default"], _objectSpread(_objectSpread({}, props), {}, {
216
- options: _this2.options
423
+ options: _this4.options
217
424
  }));
218
425
  });
219
426
  }
@@ -237,6 +444,9 @@ var InlineDropdownNode = _react2.Node.create({
237
444
  },
238
445
  value: {
239
446
  "default": ''
447
+ },
448
+ updated: {
449
+ "default": ''
240
450
  }
241
451
  };
242
452
  },
@@ -251,8 +461,8 @@ var InlineDropdownNode = _react2.Node.create({
251
461
  }
252
462
  }];
253
463
  },
254
- renderHTML: function renderHTML(_ref5) {
255
- var HTMLAttributes = _ref5.HTMLAttributes;
464
+ renderHTML: function renderHTML(_ref7) {
465
+ var HTMLAttributes = _ref7.HTMLAttributes;
256
466
  return ['span', {
257
467
  'data-type': 'inline_dropdown',
258
468
  'data-index': HTMLAttributes.index,
@@ -260,15 +470,15 @@ var InlineDropdownNode = _react2.Node.create({
260
470
  }];
261
471
  },
262
472
  addNodeView: function addNodeView() {
263
- var _this3 = this;
473
+ var _this5 = this;
264
474
 
265
475
  return (0, _react2.ReactNodeViewRenderer)(function (props) {
266
476
  return /*#__PURE__*/_react["default"].createElement(_InlineDropdown["default"], _objectSpread(_objectSpread({}, props), {}, {
267
- options: _this3.options
477
+ options: _this5.options
268
478
  }));
269
479
  });
270
480
  }
271
481
  });
272
482
 
273
483
  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"]}
484
+ //# 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","setSelection","NodeSelection","after","nodeSize","focus","refreshResponseArea","$from","nodeAfter","nodePos","setNodeMarkup","updated","Date","now","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, NodeSelection } 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\n        if (typeName === 'drag_in_the_blank' || typeName === 'inline_dropdown' || typeName === 'math_templated') {\n          tr.setSelection(NodeSelection.create(tr.doc, usedPos));\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      refreshResponseArea: () => ({ tr, state, commands, dispatch }) => {\n        const { selection } = state;\n        const node = selection.$from.nodeAfter;\n        const nodePos = selection.from;\n\n        tr.setNodeMarkup(nodePos, undefined, { ...node.attrs, updated: `${Date.now()}` });\n        tr.setSelection(NodeSelection.create(tr.doc, nodePos));\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      updated: { 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      updated: { 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      updated: { default: '' },\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      updated: { 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.13",
3
+ "version": "1.0.15",
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-image": "3.0.9",
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": {
@@ -28,6 +28,7 @@ import { CSSMark } from '../extensions/css';
28
28
  import EditorContainer from './TiptapContainer';
29
29
  import { valueToSize } from '../utils/size';
30
30
  import { buildExtensions } from '../extensions';
31
+ import { htmlToValue } from "@pie-lib/editable-html";
31
32
 
32
33
  const defaultToolbarOpts = {
33
34
  position: 'bottom',
@@ -139,7 +140,7 @@ export const EditableHtml = (props) => {
139
140
  TableRow,
140
141
  TableHeader,
141
142
  TableCell,
142
- ResponseAreaExtension,
143
+ ResponseAreaExtension.configure(props.responseAreaProps),
143
144
  ExplicitConstructedResponseNode.configure(props.responseAreaProps),
144
145
  DragInTheBlankNode.configure(props.responseAreaProps),
145
146
  InlineDropdownNode.configure(props.responseAreaProps),
@@ -240,12 +241,22 @@ export const EditableHtml = (props) => {
240
241
  },
241
242
  editable: !props.disabled,
242
243
  content: props.markup,
243
- onUpdate: ({ editor, transaction }) => transaction.isDone && props.onChange?.(editor.getHTML()),
244
+ onUpdate: ({ editor, transaction }) => {
245
+ if (transaction.isDone) {
246
+ props.onChange?.(editor.getHTML());
247
+ }
248
+
249
+ if (props.responseAreaProps?.onHandleAreaChange) {
250
+ // props.responseAreaProps.onHandleAreaChange(editor.getHTML());
251
+ }
252
+ },
244
253
  onBlur: ({ editor }) => {
254
+ if (props.markup !== editor.getHTML()) {
255
+ props.onChange?.(editor.getHTML());
256
+ }
257
+
245
258
  if (toolbarOptsToUse.doneOn === 'blur') {
246
259
  props.onDone?.(editor.getHTML());
247
- } else {
248
- props.onChange?.(editor.getHTML());
249
260
  }
250
261
  },
251
262
  });
@@ -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, error } = attributes;
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 = options.respAreaToolbar(node, editor, () => {});
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)}
@@ -84,6 +84,7 @@ const InlineDropdown = (props) => {
84
84
  position: 'relative',
85
85
  alignItems: 'center',
86
86
  }}
87
+ onClick={() => setShowToolbar(true)}
87
88
  >
88
89
  <div
89
90
  style={{
@@ -1,31 +1,217 @@
1
1
  import React from 'react';
2
- import { Node, ReactNodeViewRenderer, ReactRenderer } from '@tiptap/react';
2
+ import { Plugin, PluginKey, TextSelection, NodeSelection } 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 { Extension } from '@tiptap/core';
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 { schema, selection } = state;
14
- const position = selection.$from.pos;
15
- const RESP_MAP = {
16
- 'drag-in-the-blank': 'drag_in_the_blank',
17
- 'explicit-constructed-response': 'explicit_constructed_response',
18
- 'inline-dropdown': 'inline_dropdown',
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;
20
144
 
21
- const node = schema.nodes[RESP_MAP[type]].create({
22
- index: '1',
23
- id: '1',
24
- value: '',
145
+ const prevIndex = lastIndexMap[typeName];
146
+ const newIndex = prevIndex === 0 ? prevIndex : prevIndex + 1;
147
+
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
+
190
+ if (typeName === 'drag_in_the_blank' || typeName === 'inline_dropdown' || typeName === 'math_templated') {
191
+ tr.setSelection(NodeSelection.create(tr.doc, usedPos));
192
+ } else {
193
+ // Default: put cursor after inserted node
194
+ const after = usedPos + newInline.nodeSize;
195
+ tr.setSelection(selectionAfterPos(tr.doc, after));
196
+ }
197
+
198
+ if (dispatch) {
199
+ commands.focus();
200
+ dispatch(tr);
201
+ }
202
+
203
+ return true;
204
+ },
205
+ refreshResponseArea: () => ({ tr, state, commands, dispatch }) => {
206
+ const { selection } = state;
207
+ const node = selection.$from.nodeAfter;
208
+ const nodePos = selection.from;
209
+
210
+ tr.setNodeMarkup(nodePos, undefined, { ...node.attrs, updated: `${Date.now()}` });
211
+ tr.setSelection(NodeSelection.create(tr.doc, nodePos));
212
+
27
213
  if (dispatch) {
28
- tr.insert(position, node);
214
+ commands.focus();
29
215
  dispatch(tr);
30
216
  }
31
217
 
@@ -47,6 +233,7 @@ export const ExplicitConstructedResponseNode = Node.create({
47
233
  return {
48
234
  index: { default: null },
49
235
  value: { default: '' },
236
+ updated: { default: '' },
50
237
  };
51
238
  },
52
239
  parseHTML() {
@@ -87,6 +274,7 @@ export const MathTemplatedNode = Node.create({
87
274
  return {
88
275
  index: { default: null },
89
276
  value: { default: '' },
277
+ updated: { default: '' },
90
278
  };
91
279
  },
92
280
  parseHTML() {
@@ -129,6 +317,7 @@ export const DragInTheBlankNode = Node.create({
129
317
  id: { default: null },
130
318
  value: { default: '' },
131
319
  inTable: { default: null },
320
+ updated: { default: '' },
132
321
  };
133
322
  },
134
323
  parseHTML() {
@@ -173,6 +362,7 @@ export const InlineDropdownNode = Node.create({
173
362
  return {
174
363
  index: { default: null },
175
364
  value: { default: '' },
365
+ updated: { default: '' },
176
366
  };
177
367
  },
178
368
  parseHTML() {