@pie-lib/editable-html 10.0.0-beta.2 → 10.0.0-beta.3

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.
@@ -166,14 +166,9 @@ function MediaPlugin(type, opts) {
166
166
  type: type,
167
167
  opts: opts,
168
168
  callback: function callback(val, data) {
169
- var _getNodeBy = getNodeBy(editor, function (descendant) {
170
- return descendant.type === type && (0, _get["default"])(descendant, 'data.newMedia');
171
- }),
172
- _getNodeBy2 = (0, _slicedToArray2["default"])(_getNodeBy, 2),
173
- node = _getNodeBy2[0],
174
- nodePath = _getNodeBy2[1];
175
-
176
- if (node) {
169
+ var nodePath = _slateReact.ReactEditor.findPath(editor, inline);
170
+
171
+ if (inline) {
177
172
  if (!val) {
178
173
  editor.apply({
179
174
  type: 'remove_node',
@@ -184,7 +179,7 @@ function MediaPlugin(type, opts) {
184
179
  type: 'set_node',
185
180
  path: nodePath,
186
181
  properties: {
187
- data: node.data
182
+ data: inline.data
188
183
  },
189
184
  newProperties: {
190
185
  data: _objectSpread(_objectSpread({}, data), {}, {
@@ -195,7 +190,7 @@ function MediaPlugin(type, opts) {
195
190
  }
196
191
  }
197
192
 
198
- moveFocusAfterMedia(editor, node);
193
+ moveFocusAfterMedia(editor, inline);
199
194
  }
200
195
  });
201
196
  }
@@ -258,14 +253,9 @@ function MediaPlugin(type, opts) {
258
253
  type: type,
259
254
  opts: opts,
260
255
  callback: function callback(val, data) {
261
- var _getNodeBy3 = getNodeBy(editor, function (descendant) {
262
- return descendant.type === type && (0, _get["default"])(descendant, 'data.editing');
263
- }),
264
- _getNodeBy4 = (0, _slicedToArray2["default"])(_getNodeBy3, 2),
265
- nodeIsThere = _getNodeBy4[0],
266
- nodePath = _getNodeBy4[1];
267
-
268
- if (nodeIsThere && val) {
256
+ var nodePath = _slateReact.ReactEditor.findPath(editor, nodeToEdit);
257
+
258
+ if (nodePath && val) {
269
259
  editor.apply({
270
260
  type: 'set_node',
271
261
  path: nodePath,
@@ -451,4 +441,4 @@ var serialization = {
451
441
  }
452
442
  };
453
443
  exports.serialization = serialization;
454
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["log","debug","removeDialogs","prevDialogs","document","querySelectorAll","forEach","s","remove","insertDialog","props","newEl","createElement","type","callback","opts","rest","initialBodyOverflow","body","style","overflow","className","handleClose","val","data","el","uploadSoundSupport","ReactDOM","render","appendChild","getNodeBy","editor","descendants","SlateNode","reverse","descendant","descendantPath","moveFocusAfterMedia","node","setTimeout","ReactEditor","focus","Transforms","move","distance","unit","types","MediaPlugin","toolbar","icon","onClick","inline","isVoid","newMedia","editing","ends","undefined","height","title","starts","src","url","width","children","text","insertNode","get","nodePath","apply","path","properties","newProperties","name","rules","isInline","element","includes","supports","renderNode","omit","tag","attributes","handleEdit","event","nodeToEdit","toSlateNode","target","findPath","edit","nodeIsThere","handleDelete","serialization","deserialize","dataset","typeIndex","indexOf","Element","tagName","toLowerCase","firstChild","getAttribute","parseInt","out","jsx","serialize","object","divProps"],"sources":["../../../src/plugins/media/index.jsx"],"sourcesContent":["import React from 'react';\nimport ReactDOM from 'react-dom';\nimport { Node as SlateNode, Transforms } from 'slate';\nimport { jsx } from 'slate-hyperscript';\nimport { ReactEditor } from 'slate-react';\nimport TheatersIcon from '@material-ui/icons/Theaters';\nimport VolumeUpIcon from '@material-ui/icons/VolumeUp';\nimport get from 'lodash/get';\nimport omit from 'lodash/omit';\n\nimport debug from 'debug';\nimport MediaDialog from './media-dialog';\nimport MediaToolbar from './media-toolbar';\nimport MediaWrapper from './media-wrapper';\n\nconst log = debug('@pie-lib:editable-html:plugins:image');\n\nconst removeDialogs = () => {\n  const prevDialogs = document.querySelectorAll('.insert-media-dialog');\n\n  prevDialogs.forEach(s => s.remove());\n};\n\nexport const insertDialog = props => {\n  const newEl = document.createElement('div');\n  const { type, callback, opts, ...rest } = props;\n  const initialBodyOverflow = document.body.style.overflow;\n\n  removeDialogs();\n\n  newEl.className = 'insert-media-dialog';\n  document.body.style.overflow = 'hidden';\n\n  const handleClose = (val, data) => {\n    callback(val, data);\n    newEl.remove();\n    document.body.style.overflow = initialBodyOverflow;\n  };\n\n  const el = (\n    <MediaDialog\n      {...rest}\n      uploadSoundSupport={opts.uploadSoundSupport}\n      type={type}\n      disablePortal={true}\n      open={true}\n      handleClose={handleClose}\n    />\n  );\n\n  ReactDOM.render(el, newEl);\n\n  document.body.appendChild(newEl);\n};\n\nconst getNodeBy = (editor, callback) => {\n  const descendants = SlateNode.descendants(editor, {\n    reverse: true\n  });\n\n  for (const [descendant, descendantPath] of descendants) {\n    if (callback(descendant, descendantPath)) {\n      return [descendant, descendantPath];\n    }\n  }\n};\n\nconst moveFocusAfterMedia = (editor, node) => {\n  if (!editor || !node) {\n    return;\n  }\n\n  setTimeout(() => {\n    ReactEditor.focus(editor);\n    Transforms.move(editor, { distance: 1, unit: 'offset' });\n  }, 0);\n};\n\nconst types = ['audio', 'video'];\n\nexport default function MediaPlugin(type, opts) {\n  const toolbar = {\n    icon: type === 'audio' ? <VolumeUpIcon /> : <TheatersIcon />,\n    onClick: editor => {\n      log('[toolbar] onClick');\n      const inline = {\n        type: type,\n        isVoid: true,\n        data: {\n          newMedia: true,\n          editing: false,\n          ends: undefined,\n          height: undefined,\n          title: undefined,\n          starts: undefined,\n          src: undefined,\n          url: undefined,\n          width: undefined\n        },\n        children: [{ text: '' }]\n      };\n\n      editor.insertNode(inline);\n\n      insertDialog({\n        type,\n        opts,\n        callback: (val, data) => {\n          const [node, nodePath] = getNodeBy(\n            editor,\n            descendant => descendant.type === type && get(descendant, 'data.newMedia')\n          );\n\n          if (node) {\n            if (!val) {\n              editor.apply({\n                type: 'remove_node',\n                path: nodePath\n              });\n            } else {\n              editor.apply({\n                type: 'set_node',\n                path: nodePath,\n                properties: {\n                  data: node.data\n                },\n                newProperties: {\n                  data: {\n                    ...data,\n                    newMedia: false\n                  }\n                }\n              });\n            }\n          }\n\n          moveFocusAfterMedia(editor, node);\n        }\n      });\n    }\n  };\n\n  return {\n    name: type,\n    toolbar,\n    rules: editor => {\n      const { isVoid, isInline } = editor;\n\n      editor.isVoid = element => {\n        return ['audio', 'video'].includes(element.type) ? true : isVoid(element);\n      };\n\n      editor.isInline = element => {\n        return ['audio', 'video'].includes(element.type) ? true : isInline(element);\n      };\n\n      return editor;\n    },\n    supports: node => node.type === type,\n    renderNode(props) {\n      if (props.node.type === type) {\n        const { node, editor } = props;\n        const { data } = node;\n        const { src, height, width, editing, tag, ...rest } = omit(data, ['newMedia', 'urlToUse']);\n        const attributes = { ...rest, ...props.attributes };\n        const handleEdit = event => {\n          const nodeToEdit = ReactEditor.toSlateNode(editor, event.target);\n          const nodePath = ReactEditor.findPath(editor, nodeToEdit);\n\n          editor.apply({\n            type: 'set_node',\n            path: nodePath,\n            properties: {\n              data: node.data\n            },\n            newProperties: {\n              data: {\n                ...data,\n                editing: true\n              }\n            }\n          });\n\n          insertDialog({\n            ...data,\n            edit: true,\n            type,\n            opts,\n            callback: (val, data) => {\n              const [nodeIsThere, nodePath] = getNodeBy(\n                editor,\n                descendant => descendant.type === type && get(descendant, 'data.editing')\n              );\n\n              if (nodeIsThere && val) {\n                editor.apply({\n                  type: 'set_node',\n                  path: nodePath,\n                  properties: {\n                    data: node.data\n                  },\n                  newProperties: {\n                    data: {\n                      ...data,\n                      editing: true\n                    }\n                  }\n                });\n              }\n            }\n          });\n        };\n        const handleDelete = event => {\n          const nodeToEdit = ReactEditor.toSlateNode(editor, event.target);\n          const nodePath = ReactEditor.findPath(editor, nodeToEdit);\n\n          editor.apply({\n            type: 'remove_node',\n            path: nodePath\n          });\n        };\n        const style = {};\n\n        if (width) {\n          style.width = `${width}px`;\n        }\n\n        if (height) {\n          style.height = `${height}px`;\n        }\n\n        if (tag === 'audio') {\n          return (\n            <MediaWrapper data-type={type} width={style.width} attributes={attributes}>\n              <audio controls=\"controls\">\n                <source type=\"audio/mp3\" src={src} />\n              </audio>\n              <MediaToolbar hideEdit onRemove={handleDelete} />\n              {props.children}\n            </MediaWrapper>\n          );\n        }\n\n        return (\n          <MediaWrapper data-type={type} width={style.width} attributes={attributes}>\n            <div contentEditable={false}>\n              <iframe\n                frameBorder=\"0\"\n                allow=\"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture\"\n                allowFullScreen\n                src={src}\n                editing={editing ? 1 : 0}\n                {...rest}\n                {...style}\n              />\n              <MediaToolbar onEdit={handleEdit} onRemove={handleDelete} />\n            </div>\n            {props.children}\n          </MediaWrapper>\n        );\n      }\n    },\n  };\n}\n\nexport const serialization = {\n  deserialize(el /*, next*/) {\n    let type = el.dataset && el.dataset.type;\n    let tag = 'iframe';\n    let src;\n    const typeIndex = types.indexOf(type);\n\n    if (typeIndex < 0) {\n      if (el instanceof Element && el.tagName.toLowerCase() === 'audio') {\n        type = 'audio';\n        tag = 'audio';\n        src = el.firstChild?.getAttribute('src');\n      } else {\n        return;\n      }\n    }\n\n    const { ends, starts, title, editing, url } = el.dataset || {};\n\n    log('deserialize: ', name);\n    const width = parseInt(el.getAttribute('width'), 10) || null;\n    const height = parseInt(el.getAttribute('height'), 10) || null;\n\n    const out = jsx('element', {\n      type,\n      data: {\n        tag,\n        src: src || el.getAttribute('src'),\n        editing,\n        ends,\n        height,\n        starts,\n        title,\n        width,\n        url\n      }\n    });\n\n    log('return object: ', out);\n    return out;\n  },\n  serialize(object) {\n    const typeIndex = types.indexOf(object.type);\n\n    if (typeIndex < 0) {\n      return;\n    }\n\n    const type = types[typeIndex];\n\n    const { editing, tag, ends, src, starts, title, width, height, url } = object.data || {};\n    const style = {};\n\n    if (width) {\n      style.width = `${width}px`;\n    }\n\n    if (height) {\n      style.height = `${height}px`;\n    }\n\n    const divProps = {\n      'data-editing': editing,\n      'data-ends': ends,\n      'data-starts': starts,\n      'data-title': title,\n      'data-url': url\n    };\n    const props = {\n      ...style,\n      src\n    };\n\n    if (tag === 'audio') {\n      return (\n        <audio controls=\"controls\">\n          <source type=\"audio/mp3\" src={src} />\n        </audio>\n      );\n    }\n\n    return (\n      <iframe\n        data-type={type}\n        src={src}\n        {...divProps}\n        frameBorder=\"0\"\n        allow=\"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture\"\n        allowFullScreen\n        {...props}\n      />\n    );\n  }\n};\n"],"mappings":"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"}
444
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["log","debug","removeDialogs","prevDialogs","document","querySelectorAll","forEach","s","remove","insertDialog","props","newEl","createElement","type","callback","opts","rest","initialBodyOverflow","body","style","overflow","className","handleClose","val","data","el","uploadSoundSupport","ReactDOM","render","appendChild","getNodeBy","editor","descendants","SlateNode","reverse","descendant","descendantPath","moveFocusAfterMedia","node","setTimeout","ReactEditor","focus","Transforms","move","distance","unit","types","MediaPlugin","toolbar","icon","onClick","inline","isVoid","newMedia","editing","ends","undefined","height","title","starts","src","url","width","children","text","insertNode","nodePath","findPath","apply","path","properties","newProperties","name","rules","isInline","element","includes","supports","renderNode","omit","tag","attributes","handleEdit","event","nodeToEdit","toSlateNode","target","edit","handleDelete","serialization","deserialize","dataset","typeIndex","indexOf","Element","tagName","toLowerCase","firstChild","getAttribute","parseInt","out","jsx","serialize","object","divProps"],"sources":["../../../src/plugins/media/index.jsx"],"sourcesContent":["import React from 'react';\nimport ReactDOM from 'react-dom';\nimport { Node as SlateNode, Transforms } from 'slate';\nimport { jsx } from 'slate-hyperscript';\nimport { ReactEditor } from 'slate-react';\nimport TheatersIcon from '@material-ui/icons/Theaters';\nimport VolumeUpIcon from '@material-ui/icons/VolumeUp';\nimport get from 'lodash/get';\nimport omit from 'lodash/omit';\n\nimport debug from 'debug';\nimport MediaDialog from './media-dialog';\nimport MediaToolbar from './media-toolbar';\nimport MediaWrapper from './media-wrapper';\n\nconst log = debug('@pie-lib:editable-html:plugins:image');\n\nconst removeDialogs = () => {\n  const prevDialogs = document.querySelectorAll('.insert-media-dialog');\n\n  prevDialogs.forEach(s => s.remove());\n};\n\nexport const insertDialog = props => {\n  const newEl = document.createElement('div');\n  const { type, callback, opts, ...rest } = props;\n  const initialBodyOverflow = document.body.style.overflow;\n\n  removeDialogs();\n\n  newEl.className = 'insert-media-dialog';\n  document.body.style.overflow = 'hidden';\n\n  const handleClose = (val, data) => {\n    callback(val, data);\n    newEl.remove();\n    document.body.style.overflow = initialBodyOverflow;\n  };\n\n  const el = (\n    <MediaDialog\n      {...rest}\n      uploadSoundSupport={opts.uploadSoundSupport}\n      type={type}\n      disablePortal={true}\n      open={true}\n      handleClose={handleClose}\n    />\n  );\n\n  ReactDOM.render(el, newEl);\n\n  document.body.appendChild(newEl);\n};\n\nconst getNodeBy = (editor, callback) => {\n  const descendants = SlateNode.descendants(editor, {\n    reverse: true\n  });\n\n  for (const [descendant, descendantPath] of descendants) {\n    if (callback(descendant, descendantPath)) {\n      return [descendant, descendantPath];\n    }\n  }\n};\n\nconst moveFocusAfterMedia = (editor, node) => {\n  if (!editor || !node) {\n    return;\n  }\n\n  setTimeout(() => {\n    ReactEditor.focus(editor);\n    Transforms.move(editor, { distance: 1, unit: 'offset' });\n  }, 0);\n};\n\nconst types = ['audio', 'video'];\n\nexport default function MediaPlugin(type, opts) {\n  const toolbar = {\n    icon: type === 'audio' ? <VolumeUpIcon /> : <TheatersIcon />,\n    onClick: editor => {\n      log('[toolbar] onClick');\n      const inline = {\n        type: type,\n        isVoid: true,\n        data: {\n          newMedia: true,\n          editing: false,\n          ends: undefined,\n          height: undefined,\n          title: undefined,\n          starts: undefined,\n          src: undefined,\n          url: undefined,\n          width: undefined\n        },\n        children: [{ text: '' }]\n      };\n\n      editor.insertNode(inline);\n\n      insertDialog({\n        type,\n        opts,\n        callback: (val, data) => {\n          const nodePath = ReactEditor.findPath(editor, inline);\n\n          if (inline) {\n            if (!val) {\n              editor.apply({\n                type: 'remove_node',\n                path: nodePath\n              });\n            } else {\n              editor.apply({\n                type: 'set_node',\n                path: nodePath,\n                properties: {\n                  data: inline.data\n                },\n                newProperties: {\n                  data: {\n                    ...data,\n                    newMedia: false\n                  }\n                }\n              });\n            }\n          }\n\n          moveFocusAfterMedia(editor, inline);\n        }\n      });\n    }\n  };\n\n  return {\n    name: type,\n    toolbar,\n    rules: editor => {\n      const { isVoid, isInline } = editor;\n\n      editor.isVoid = element => {\n        return ['audio', 'video'].includes(element.type) ? true : isVoid(element);\n      };\n\n      editor.isInline = element => {\n        return ['audio', 'video'].includes(element.type) ? true : isInline(element);\n      };\n\n      return editor;\n    },\n    supports: node => node.type === type,\n    renderNode(props) {\n      if (props.node.type === type) {\n        const { node, editor } = props;\n        const { data } = node;\n        const { src, height, width, editing, tag, ...rest } = omit(data, ['newMedia', 'urlToUse']);\n        const attributes = { ...rest, ...props.attributes };\n        const handleEdit = event => {\n          const nodeToEdit = ReactEditor.toSlateNode(editor, event.target);\n          const nodePath = ReactEditor.findPath(editor, nodeToEdit);\n\n          editor.apply({\n            type: 'set_node',\n            path: nodePath,\n            properties: {\n              data: node.data\n            },\n            newProperties: {\n              data: {\n                ...data,\n                editing: true\n              }\n            }\n          });\n\n          insertDialog({\n            ...data,\n            edit: true,\n            type,\n            opts,\n            callback: (val, data) => {\n              const nodePath = ReactEditor.findPath(editor, nodeToEdit);\n\n              if (nodePath && val) {\n                editor.apply({\n                  type: 'set_node',\n                  path: nodePath,\n                  properties: {\n                    data: node.data\n                  },\n                  newProperties: {\n                    data: {\n                      ...data,\n                      editing: true\n                    }\n                  }\n                });\n              }\n            }\n          });\n        };\n        const handleDelete = event => {\n          const nodeToEdit = ReactEditor.toSlateNode(editor, event.target);\n          const nodePath = ReactEditor.findPath(editor, nodeToEdit);\n\n          editor.apply({\n            type: 'remove_node',\n            path: nodePath\n          });\n        };\n        const style = {};\n\n        if (width) {\n          style.width = `${width}px`;\n        }\n\n        if (height) {\n          style.height = `${height}px`;\n        }\n\n        if (tag === 'audio') {\n          return (\n            <MediaWrapper data-type={type} width={style.width} attributes={attributes}>\n              <audio controls=\"controls\">\n                <source type=\"audio/mp3\" src={src} />\n              </audio>\n              <MediaToolbar hideEdit onRemove={handleDelete} />\n              {props.children}\n            </MediaWrapper>\n          );\n        }\n\n        return (\n          <MediaWrapper data-type={type} width={style.width} attributes={attributes}>\n            <div contentEditable={false}>\n              <iframe\n                frameBorder=\"0\"\n                allow=\"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture\"\n                allowFullScreen\n                src={src}\n                editing={editing ? 1 : 0}\n                {...rest}\n                {...style}\n              />\n              <MediaToolbar onEdit={handleEdit} onRemove={handleDelete} />\n            </div>\n            {props.children}\n          </MediaWrapper>\n        );\n      }\n    },\n  };\n}\n\nexport const serialization = {\n  deserialize(el /*, next*/) {\n    let type = el.dataset && el.dataset.type;\n    let tag = 'iframe';\n    let src;\n    const typeIndex = types.indexOf(type);\n\n    if (typeIndex < 0) {\n      if (el instanceof Element && el.tagName.toLowerCase() === 'audio') {\n        type = 'audio';\n        tag = 'audio';\n        src = el.firstChild?.getAttribute('src');\n      } else {\n        return;\n      }\n    }\n\n    const { ends, starts, title, editing, url } = el.dataset || {};\n\n    log('deserialize: ', name);\n    const width = parseInt(el.getAttribute('width'), 10) || null;\n    const height = parseInt(el.getAttribute('height'), 10) || null;\n\n    const out = jsx('element', {\n      type,\n      data: {\n        tag,\n        src: src || el.getAttribute('src'),\n        editing,\n        ends,\n        height,\n        starts,\n        title,\n        width,\n        url\n      }\n    });\n\n    log('return object: ', out);\n    return out;\n  },\n  serialize(object) {\n    const typeIndex = types.indexOf(object.type);\n\n    if (typeIndex < 0) {\n      return;\n    }\n\n    const type = types[typeIndex];\n\n    const { editing, tag, ends, src, starts, title, width, height, url } = object.data || {};\n    const style = {};\n\n    if (width) {\n      style.width = `${width}px`;\n    }\n\n    if (height) {\n      style.height = `${height}px`;\n    }\n\n    const divProps = {\n      'data-editing': editing,\n      'data-ends': ends,\n      'data-starts': starts,\n      'data-title': title,\n      'data-url': url\n    };\n    const props = {\n      ...style,\n      src\n    };\n\n    if (tag === 'audio') {\n      return (\n        <audio controls=\"controls\">\n          <source type=\"audio/mp3\" src={src} />\n        </audio>\n      );\n    }\n\n    return (\n      <iframe\n        data-type={type}\n        src={src}\n        {...divProps}\n        frameBorder=\"0\"\n        allow=\"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture\"\n        allowFullScreen\n        {...props}\n      />\n    );\n  }\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAEA;;AACA;;AACA;;AACA;;;;;;;;;;;;;;;AAEA,IAAMA,GAAG,GAAG,IAAAC,iBAAA,EAAM,sCAAN,CAAZ;;AAEA,IAAMC,aAAa,GAAG,SAAhBA,aAAgB,GAAM;EAC1B,IAAMC,WAAW,GAAGC,QAAQ,CAACC,gBAAT,CAA0B,sBAA1B,CAApB;EAEAF,WAAW,CAACG,OAAZ,CAAoB,UAAAC,CAAC;IAAA,OAAIA,CAAC,CAACC,MAAF,EAAJ;EAAA,CAArB;AACD,CAJD;;AAMO,IAAMC,YAAY,GAAG,SAAfA,YAAe,CAAAC,KAAK,EAAI;EACnC,IAAMC,KAAK,GAAGP,QAAQ,CAACQ,aAAT,CAAuB,KAAvB,CAAd;EACA,IAAQC,IAAR,GAA0CH,KAA1C,CAAQG,IAAR;EAAA,IAAcC,QAAd,GAA0CJ,KAA1C,CAAcI,QAAd;EAAA,IAAwBC,IAAxB,GAA0CL,KAA1C,CAAwBK,IAAxB;EAAA,IAAiCC,IAAjC,6CAA0CN,KAA1C;EACA,IAAMO,mBAAmB,GAAGb,QAAQ,CAACc,IAAT,CAAcC,KAAd,CAAoBC,QAAhD;EAEAlB,aAAa;EAEbS,KAAK,CAACU,SAAN,GAAkB,qBAAlB;EACAjB,QAAQ,CAACc,IAAT,CAAcC,KAAd,CAAoBC,QAApB,GAA+B,QAA/B;;EAEA,IAAME,WAAW,GAAG,SAAdA,WAAc,CAACC,GAAD,EAAMC,IAAN,EAAe;IACjCV,QAAQ,CAACS,GAAD,EAAMC,IAAN,CAAR;IACAb,KAAK,CAACH,MAAN;IACAJ,QAAQ,CAACc,IAAT,CAAcC,KAAd,CAAoBC,QAApB,GAA+BH,mBAA/B;EACD,CAJD;;EAMA,IAAMQ,EAAE,gBACN,gCAAC,uBAAD,gCACMT,IADN;IAEE,kBAAkB,EAAED,IAAI,CAACW,kBAF3B;IAGE,IAAI,EAAEb,IAHR;IAIE,aAAa,EAAE,IAJjB;IAKE,IAAI,EAAE,IALR;IAME,WAAW,EAAES;EANf,GADF;;EAWAK,oBAAA,CAASC,MAAT,CAAgBH,EAAhB,EAAoBd,KAApB;;EAEAP,QAAQ,CAACc,IAAT,CAAcW,WAAd,CAA0BlB,KAA1B;AACD,CA9BM;;;;AAgCP,IAAMmB,SAAS,GAAG,SAAZA,SAAY,CAACC,MAAD,EAASjB,QAAT,EAAsB;EACtC,IAAMkB,WAAW,GAAGC,WAAA,CAAUD,WAAV,CAAsBD,MAAtB,EAA8B;IAChDG,OAAO,EAAE;EADuC,CAA9B,CAApB;;EADsC,2CAKKF,WALL;EAAA;;EAAA;IAKtC,oDAAwD;MAAA;MAAA,IAA5CG,UAA4C;MAAA,IAAhCC,cAAgC;;MACtD,IAAItB,QAAQ,CAACqB,UAAD,EAAaC,cAAb,CAAZ,EAA0C;QACxC,OAAO,CAACD,UAAD,EAAaC,cAAb,CAAP;MACD;IACF;EATqC;IAAA;EAAA;IAAA;EAAA;AAUvC,CAVD;;AAYA,IAAMC,mBAAmB,GAAG,SAAtBA,mBAAsB,CAACN,MAAD,EAASO,IAAT,EAAkB;EAC5C,IAAI,CAACP,MAAD,IAAW,CAACO,IAAhB,EAAsB;IACpB;EACD;;EAEDC,UAAU,CAAC,YAAM;IACfC,uBAAA,CAAYC,KAAZ,CAAkBV,MAAlB;;IACAW,iBAAA,CAAWC,IAAX,CAAgBZ,MAAhB,EAAwB;MAAEa,QAAQ,EAAE,CAAZ;MAAeC,IAAI,EAAE;IAArB,CAAxB;EACD,CAHS,EAGP,CAHO,CAAV;AAID,CATD;;AAWA,IAAMC,KAAK,GAAG,CAAC,OAAD,EAAU,OAAV,CAAd;;AAEe,SAASC,WAAT,CAAqBlC,IAArB,EAA2BE,IAA3B,EAAiC;EAC9C,IAAMiC,OAAO,GAAG;IACdC,IAAI,EAAEpC,IAAI,KAAK,OAAT,gBAAmB,gCAAC,oBAAD,OAAnB,gBAAsC,gCAAC,oBAAD,OAD9B;IAEdqC,OAAO,EAAE,iBAAAnB,MAAM,EAAI;MACjB/B,GAAG,CAAC,mBAAD,CAAH;MACA,IAAMmD,MAAM,GAAG;QACbtC,IAAI,EAAEA,IADO;QAEbuC,MAAM,EAAE,IAFK;QAGb5B,IAAI,EAAE;UACJ6B,QAAQ,EAAE,IADN;UAEJC,OAAO,EAAE,KAFL;UAGJC,IAAI,EAAEC,SAHF;UAIJC,MAAM,EAAED,SAJJ;UAKJE,KAAK,EAAEF,SALH;UAMJG,MAAM,EAAEH,SANJ;UAOJI,GAAG,EAAEJ,SAPD;UAQJK,GAAG,EAAEL,SARD;UASJM,KAAK,EAAEN;QATH,CAHO;QAcbO,QAAQ,EAAE,CAAC;UAAEC,IAAI,EAAE;QAAR,CAAD;MAdG,CAAf;MAiBAjC,MAAM,CAACkC,UAAP,CAAkBd,MAAlB;MAEA1C,YAAY,CAAC;QACXI,IAAI,EAAJA,IADW;QAEXE,IAAI,EAAJA,IAFW;QAGXD,QAAQ,EAAE,kBAACS,GAAD,EAAMC,IAAN,EAAe;UACvB,IAAM0C,QAAQ,GAAG1B,uBAAA,CAAY2B,QAAZ,CAAqBpC,MAArB,EAA6BoB,MAA7B,CAAjB;;UAEA,IAAIA,MAAJ,EAAY;YACV,IAAI,CAAC5B,GAAL,EAAU;cACRQ,MAAM,CAACqC,KAAP,CAAa;gBACXvD,IAAI,EAAE,aADK;gBAEXwD,IAAI,EAAEH;cAFK,CAAb;YAID,CALD,MAKO;cACLnC,MAAM,CAACqC,KAAP,CAAa;gBACXvD,IAAI,EAAE,UADK;gBAEXwD,IAAI,EAAEH,QAFK;gBAGXI,UAAU,EAAE;kBACV9C,IAAI,EAAE2B,MAAM,CAAC3B;gBADH,CAHD;gBAMX+C,aAAa,EAAE;kBACb/C,IAAI,kCACCA,IADD;oBAEF6B,QAAQ,EAAE;kBAFR;gBADS;cANJ,CAAb;YAaD;UACF;;UAEDhB,mBAAmB,CAACN,MAAD,EAASoB,MAAT,CAAnB;QACD;MA9BU,CAAD,CAAZ;IAgCD;EAvDa,CAAhB;EA0DA,OAAO;IACLqB,IAAI,EAAE3D,IADD;IAELmC,OAAO,EAAPA,OAFK;IAGLyB,KAAK,EAAE,eAAA1C,MAAM,EAAI;MACf,IAAQqB,MAAR,GAA6BrB,MAA7B,CAAQqB,MAAR;MAAA,IAAgBsB,QAAhB,GAA6B3C,MAA7B,CAAgB2C,QAAhB;;MAEA3C,MAAM,CAACqB,MAAP,GAAgB,UAAAuB,OAAO,EAAI;QACzB,OAAO,CAAC,OAAD,EAAU,OAAV,EAAmBC,QAAnB,CAA4BD,OAAO,CAAC9D,IAApC,IAA4C,IAA5C,GAAmDuC,MAAM,CAACuB,OAAD,CAAhE;MACD,CAFD;;MAIA5C,MAAM,CAAC2C,QAAP,GAAkB,UAAAC,OAAO,EAAI;QAC3B,OAAO,CAAC,OAAD,EAAU,OAAV,EAAmBC,QAAnB,CAA4BD,OAAO,CAAC9D,IAApC,IAA4C,IAA5C,GAAmD6D,QAAQ,CAACC,OAAD,CAAlE;MACD,CAFD;;MAIA,OAAO5C,MAAP;IACD,CAfI;IAgBL8C,QAAQ,EAAE,kBAAAvC,IAAI;MAAA,OAAIA,IAAI,CAACzB,IAAL,KAAcA,IAAlB;IAAA,CAhBT;IAiBLiE,UAjBK,sBAiBMpE,KAjBN,EAiBa;MAChB,IAAIA,KAAK,CAAC4B,IAAN,CAAWzB,IAAX,KAAoBA,IAAxB,EAA8B;QAC5B,IAAQyB,IAAR,GAAyB5B,KAAzB,CAAQ4B,IAAR;QAAA,IAAcP,MAAd,GAAyBrB,KAAzB,CAAcqB,MAAd;QACA,IAAQP,IAAR,GAAiBc,IAAjB,CAAQd,IAAR;;QACA,YAAsD,IAAAuD,iBAAA,EAAKvD,IAAL,EAAW,CAAC,UAAD,EAAa,UAAb,CAAX,CAAtD;QAAA,IAAQoC,GAAR,SAAQA,GAAR;QAAA,IAAaH,MAAb,SAAaA,MAAb;QAAA,IAAqBK,KAArB,SAAqBA,KAArB;QAAA,IAA4BR,OAA5B,SAA4BA,OAA5B;QAAA,IAAqC0B,GAArC,SAAqCA,GAArC;QAAA,IAA6ChE,IAA7C;;QACA,IAAMiE,UAAU,mCAAQjE,IAAR,GAAiBN,KAAK,CAACuE,UAAvB,CAAhB;;QACA,IAAMC,UAAU,GAAG,SAAbA,UAAa,CAAAC,KAAK,EAAI;UAC1B,IAAMC,UAAU,GAAG5C,uBAAA,CAAY6C,WAAZ,CAAwBtD,MAAxB,EAAgCoD,KAAK,CAACG,MAAtC,CAAnB;;UACA,IAAMpB,QAAQ,GAAG1B,uBAAA,CAAY2B,QAAZ,CAAqBpC,MAArB,EAA6BqD,UAA7B,CAAjB;;UAEArD,MAAM,CAACqC,KAAP,CAAa;YACXvD,IAAI,EAAE,UADK;YAEXwD,IAAI,EAAEH,QAFK;YAGXI,UAAU,EAAE;cACV9C,IAAI,EAAEc,IAAI,CAACd;YADD,CAHD;YAMX+C,aAAa,EAAE;cACb/C,IAAI,kCACCA,IADD;gBAEF8B,OAAO,EAAE;cAFP;YADS;UANJ,CAAb;UAcA7C,YAAY,iCACPe,IADO;YAEV+D,IAAI,EAAE,IAFI;YAGV1E,IAAI,EAAJA,IAHU;YAIVE,IAAI,EAAJA,IAJU;YAKVD,QAAQ,EAAE,kBAACS,GAAD,EAAMC,IAAN,EAAe;cACvB,IAAM0C,QAAQ,GAAG1B,uBAAA,CAAY2B,QAAZ,CAAqBpC,MAArB,EAA6BqD,UAA7B,CAAjB;;cAEA,IAAIlB,QAAQ,IAAI3C,GAAhB,EAAqB;gBACnBQ,MAAM,CAACqC,KAAP,CAAa;kBACXvD,IAAI,EAAE,UADK;kBAEXwD,IAAI,EAAEH,QAFK;kBAGXI,UAAU,EAAE;oBACV9C,IAAI,EAAEc,IAAI,CAACd;kBADD,CAHD;kBAMX+C,aAAa,EAAE;oBACb/C,IAAI,kCACCA,IADD;sBAEF8B,OAAO,EAAE;oBAFP;kBADS;gBANJ,CAAb;cAaD;YACF;UAvBS,GAAZ;QAyBD,CA3CD;;QA4CA,IAAMkC,YAAY,GAAG,SAAfA,YAAe,CAAAL,KAAK,EAAI;UAC5B,IAAMC,UAAU,GAAG5C,uBAAA,CAAY6C,WAAZ,CAAwBtD,MAAxB,EAAgCoD,KAAK,CAACG,MAAtC,CAAnB;;UACA,IAAMpB,QAAQ,GAAG1B,uBAAA,CAAY2B,QAAZ,CAAqBpC,MAArB,EAA6BqD,UAA7B,CAAjB;;UAEArD,MAAM,CAACqC,KAAP,CAAa;YACXvD,IAAI,EAAE,aADK;YAEXwD,IAAI,EAAEH;UAFK,CAAb;QAID,CARD;;QASA,IAAM/C,KAAK,GAAG,EAAd;;QAEA,IAAI2C,KAAJ,EAAW;UACT3C,KAAK,CAAC2C,KAAN,aAAiBA,KAAjB;QACD;;QAED,IAAIL,MAAJ,EAAY;UACVtC,KAAK,CAACsC,MAAN,aAAkBA,MAAlB;QACD;;QAED,IAAIuB,GAAG,KAAK,OAAZ,EAAqB;UACnB,oBACE,gCAAC,wBAAD;YAAc,aAAWnE,IAAzB;YAA+B,KAAK,EAAEM,KAAK,CAAC2C,KAA5C;YAAmD,UAAU,EAAEmB;UAA/D,gBACE;YAAO,QAAQ,EAAC;UAAhB,gBACE;YAAQ,IAAI,EAAC,WAAb;YAAyB,GAAG,EAAErB;UAA9B,EADF,CADF,eAIE,gCAAC,wBAAD;YAAc,QAAQ,MAAtB;YAAuB,QAAQ,EAAE4B;UAAjC,EAJF,EAKG9E,KAAK,CAACqD,QALT,CADF;QASD;;QAED,oBACE,gCAAC,wBAAD;UAAc,aAAWlD,IAAzB;UAA+B,KAAK,EAAEM,KAAK,CAAC2C,KAA5C;UAAmD,UAAU,EAAEmB;QAA/D,gBACE;UAAK,eAAe,EAAE;QAAtB,gBACE;UACE,WAAW,EAAC,GADd;UAEE,KAAK,EAAC,0FAFR;UAGE,eAAe,MAHjB;UAIE,GAAG,EAAErB,GAJP;UAKE,OAAO,EAAEN,OAAO,GAAG,CAAH,GAAO;QALzB,GAMMtC,IANN,EAOMG,KAPN,EADF,eAUE,gCAAC,wBAAD;UAAc,MAAM,EAAE+D,UAAtB;UAAkC,QAAQ,EAAEM;QAA5C,EAVF,CADF,EAaG9E,KAAK,CAACqD,QAbT,CADF;MAiBD;IACF;EApHI,CAAP;AAsHD;;AAEM,IAAM0B,aAAa,GAAG;EAC3BC,WAD2B,uBACfjE;EAAG;EADY,EACA;IACzB,IAAIZ,IAAI,GAAGY,EAAE,CAACkE,OAAH,IAAclE,EAAE,CAACkE,OAAH,CAAW9E,IAApC;IACA,IAAImE,GAAG,GAAG,QAAV;IACA,IAAIpB,GAAJ;IACA,IAAMgC,SAAS,GAAG9C,KAAK,CAAC+C,OAAN,CAAchF,IAAd,CAAlB;;IAEA,IAAI+E,SAAS,GAAG,CAAhB,EAAmB;MACjB,IAAInE,EAAE,YAAYqE,OAAd,IAAyBrE,EAAE,CAACsE,OAAH,CAAWC,WAAX,OAA6B,OAA1D,EAAmE;QAAA;;QACjEnF,IAAI,GAAG,OAAP;QACAmE,GAAG,GAAG,OAAN;QACApB,GAAG,qBAAGnC,EAAE,CAACwE,UAAN,mDAAG,eAAeC,YAAf,CAA4B,KAA5B,CAAN;MACD,CAJD,MAIO;QACL;MACD;IACF;;IAED,WAA8CzE,EAAE,CAACkE,OAAH,IAAc,EAA5D;IAAA,IAAQpC,IAAR,QAAQA,IAAR;IAAA,IAAcI,MAAd,QAAcA,MAAd;IAAA,IAAsBD,KAAtB,QAAsBA,KAAtB;IAAA,IAA6BJ,OAA7B,QAA6BA,OAA7B;IAAA,IAAsCO,GAAtC,QAAsCA,GAAtC;;IAEA7D,GAAG,CAAC,eAAD,EAAkBwE,IAAlB,CAAH;IACA,IAAMV,KAAK,GAAGqC,QAAQ,CAAC1E,EAAE,CAACyE,YAAH,CAAgB,OAAhB,CAAD,EAA2B,EAA3B,CAAR,IAA0C,IAAxD;IACA,IAAMzC,MAAM,GAAG0C,QAAQ,CAAC1E,EAAE,CAACyE,YAAH,CAAgB,QAAhB,CAAD,EAA4B,EAA5B,CAAR,IAA2C,IAA1D;IAEA,IAAME,GAAG,GAAG,IAAAC,qBAAA,EAAI,SAAJ,EAAe;MACzBxF,IAAI,EAAJA,IADyB;MAEzBW,IAAI,EAAE;QACJwD,GAAG,EAAHA,GADI;QAEJpB,GAAG,EAAEA,GAAG,IAAInC,EAAE,CAACyE,YAAH,CAAgB,KAAhB,CAFR;QAGJ5C,OAAO,EAAPA,OAHI;QAIJC,IAAI,EAAJA,IAJI;QAKJE,MAAM,EAANA,MALI;QAMJE,MAAM,EAANA,MANI;QAOJD,KAAK,EAALA,KAPI;QAQJI,KAAK,EAALA,KARI;QASJD,GAAG,EAAHA;MATI;IAFmB,CAAf,CAAZ;IAeA7D,GAAG,CAAC,iBAAD,EAAoBoG,GAApB,CAAH;IACA,OAAOA,GAAP;EACD,CAxC0B;EAyC3BE,SAzC2B,qBAyCjBC,MAzCiB,EAyCT;IAChB,IAAMX,SAAS,GAAG9C,KAAK,CAAC+C,OAAN,CAAcU,MAAM,CAAC1F,IAArB,CAAlB;;IAEA,IAAI+E,SAAS,GAAG,CAAhB,EAAmB;MACjB;IACD;;IAED,IAAM/E,IAAI,GAAGiC,KAAK,CAAC8C,SAAD,CAAlB;;IAEA,YAAuEW,MAAM,CAAC/E,IAAP,IAAe,EAAtF;IAAA,IAAQ8B,OAAR,SAAQA,OAAR;IAAA,IAAiB0B,GAAjB,SAAiBA,GAAjB;IAAA,IAAsBzB,IAAtB,SAAsBA,IAAtB;IAAA,IAA4BK,GAA5B,SAA4BA,GAA5B;IAAA,IAAiCD,MAAjC,SAAiCA,MAAjC;IAAA,IAAyCD,KAAzC,SAAyCA,KAAzC;IAAA,IAAgDI,KAAhD,SAAgDA,KAAhD;IAAA,IAAuDL,MAAvD,SAAuDA,MAAvD;IAAA,IAA+DI,GAA/D,SAA+DA,GAA/D;;IACA,IAAM1C,KAAK,GAAG,EAAd;;IAEA,IAAI2C,KAAJ,EAAW;MACT3C,KAAK,CAAC2C,KAAN,aAAiBA,KAAjB;IACD;;IAED,IAAIL,MAAJ,EAAY;MACVtC,KAAK,CAACsC,MAAN,aAAkBA,MAAlB;IACD;;IAED,IAAM+C,QAAQ,GAAG;MACf,gBAAgBlD,OADD;MAEf,aAAaC,IAFE;MAGf,eAAeI,MAHA;MAIf,cAAcD,KAJC;MAKf,YAAYG;IALG,CAAjB;;IAOA,IAAMnD,KAAK,mCACNS,KADM;MAETyC,GAAG,EAAHA;IAFS,EAAX;;IAKA,IAAIoB,GAAG,KAAK,OAAZ,EAAqB;MACnB,oBACE;QAAO,QAAQ,EAAC;MAAhB,gBACE;QAAQ,IAAI,EAAC,WAAb;QAAyB,GAAG,EAAEpB;MAA9B,EADF,CADF;IAKD;;IAED,oBACE;MACE,aAAW/C,IADb;MAEE,GAAG,EAAE+C;IAFP,GAGM4C,QAHN;MAIE,WAAW,EAAC,GAJd;MAKE,KAAK,EAAC,0FALR;MAME,eAAe;IANjB,GAOM9F,KAPN,EADF;EAWD;AA5F0B,CAAtB"}
@@ -26,7 +26,7 @@ var onValueChange = function onValueChange(nodeProps, n, value) {
26
26
  var change = val.change();
27
27
  change.setNodeByKey(n.key, {
28
28
  data: _objectSpread(_objectSpread({}, value), {}, {
29
- index: n.data.get('index')
29
+ index: n.data.index
30
30
  })
31
31
  });
32
32
  nodeProps.editor.props.onChange(change, function () {
@@ -40,11 +40,11 @@ var onRemoveResponse = function onRemoveResponse(nodeProps, value) {
40
40
  var val = nodeProps.editor.value;
41
41
  var change = val.change();
42
42
  var dragInTheBlank = val.document.findDescendant(function (n) {
43
- return n.data && n.data.get('index') === value.index;
43
+ return n.data && n.data.index === value.index;
44
44
  });
45
45
  change.setNodeByKey(dragInTheBlank.key, {
46
46
  data: {
47
- index: dragInTheBlank.data.get('index')
47
+ index: dragInTheBlank.data.index
48
48
  }
49
49
  });
50
50
  nodeProps.editor.props.onChange(change, function () {
@@ -95,4 +95,4 @@ DragDrop.propTypes = {
95
95
  };
96
96
  var _default = DragDrop;
97
97
  exports["default"] = _default;
98
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJvblZhbHVlQ2hhbmdlIiwibm9kZVByb3BzIiwibiIsInZhbHVlIiwidmFsIiwiZWRpdG9yIiwiY2hhbmdlIiwic2V0Tm9kZUJ5S2V5Iiwia2V5IiwiZGF0YSIsImluZGV4IiwiZ2V0IiwicHJvcHMiLCJvbkNoYW5nZSIsIm9uRWRpdGluZ0RvbmUiLCJvblJlbW92ZVJlc3BvbnNlIiwiZHJhZ0luVGhlQmxhbmsiLCJkb2N1bWVudCIsImZpbmREZXNjZW5kYW50IiwiRHJhZ0Ryb3AiLCJhdHRyaWJ1dGVzIiwiY2hpbGRyZW4iLCJvcHRzIiwiaW5UYWJsZSIsImRpc3BsYXkiLCJtaW5IZWlnaHQiLCJtaW5XaWR0aCIsInBvc2l0aW9uIiwibWFyZ2luIiwiY3Vyc29yIiwib3B0aW9ucyIsImR1cGxpY2F0ZXMiLCJwcm9wVHlwZXMiLCJQcm9wVHlwZXMiLCJvYmplY3QiXSwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvcGx1Z2lucy9yZXNwQXJlYS9kcmFnLWluLXRoZS1ibGFuay9pbmRleC5qc3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgRHJhZ0Ryb3BUaWxlIGZyb20gJy4vY2hvaWNlJztcblxuZXhwb3J0IGNvbnN0IG9uVmFsdWVDaGFuZ2UgPSAobm9kZVByb3BzLCBuLCB2YWx1ZSkgPT4ge1xuICBjb25zdCB2YWwgPSBub2RlUHJvcHMuZWRpdG9yLnZhbHVlO1xuICBjb25zdCBjaGFuZ2UgPSB2YWwuY2hhbmdlKCk7XG5cbiAgY2hhbmdlLnNldE5vZGVCeUtleShuLmtleSwge1xuICAgIGRhdGE6IHtcbiAgICAgIC4uLnZhbHVlLFxuICAgICAgaW5kZXg6IG4uZGF0YS5nZXQoJ2luZGV4JylcbiAgICB9XG4gIH0pO1xuXG4gIG5vZGVQcm9wcy5lZGl0b3IucHJvcHMub25DaGFuZ2UoY2hhbmdlLCAoKSA9PiB7XG4gICAgbm9kZVByb3BzLmVkaXRvci5wcm9wcy5vbkVkaXRpbmdEb25lKCk7XG4gIH0pO1xufTtcblxuZXhwb3J0IGNvbnN0IG9uUmVtb3ZlUmVzcG9uc2UgPSAobm9kZVByb3BzLCB2YWx1ZSkgPT4ge1xuICBjb25zdCB2YWwgPSBub2RlUHJvcHMuZWRpdG9yLnZhbHVlO1xuICBjb25zdCBjaGFuZ2UgPSB2YWwuY2hhbmdlKCk7XG4gIGNvbnN0IGRyYWdJblRoZUJsYW5rID0gdmFsLmRvY3VtZW50LmZpbmREZXNjZW5kYW50KFxuICAgIG4gPT4gbi5kYXRhICYmIG4uZGF0YS5nZXQoJ2luZGV4JykgPT09IHZhbHVlLmluZGV4XG4gICk7XG5cbiAgY2hhbmdlLnNldE5vZGVCeUtleShkcmFnSW5UaGVCbGFuay5rZXksIHtcbiAgICBkYXRhOiB7XG4gICAgICBpbmRleDogZHJhZ0luVGhlQmxhbmsuZGF0YS5nZXQoJ2luZGV4JylcbiAgICB9XG4gIH0pO1xuXG4gIG5vZGVQcm9wcy5lZGl0b3IucHJvcHMub25DaGFuZ2UoY2hhbmdlLCAoKSA9PiB7XG4gICAgbm9kZVByb3BzLmVkaXRvci5wcm9wcy5vbkVkaXRpbmdEb25lKCk7XG4gIH0pO1xufTtcblxuY29uc3QgRHJhZ0Ryb3AgPSBwcm9wcyA9PiB7XG4gIGNvbnN0IHsgYXR0cmlidXRlcywgY2hpbGRyZW4sIGRhdGEsIG4sIG5vZGVQcm9wcywgb3B0cyB9ID0gcHJvcHM7XG4gIGNvbnN0IHsgaW5UYWJsZSB9ID0gZGF0YTtcblxuICByZXR1cm4gKFxuICAgIDxzcGFuXG4gICAgICB7Li4uYXR0cmlidXRlc31cbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIGRpc3BsYXk6ICdpbmxpbmUtZmxleCcsXG4gICAgICAgIG1pbkhlaWdodDogJzUwcHgnLFxuICAgICAgICBtaW5XaWR0aDogJzE3OHB4JyxcbiAgICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICAgIG1hcmdpbjogaW5UYWJsZSA/ICcxMHB4JyA6ICcwIDEwcHgnLFxuICAgICAgICBjdXJzb3I6ICdwb2ludGVyJ1xuICAgICAgfX1cbiAgICA+XG4gICAgICA8RHJhZ0Ryb3BUaWxlXG4gICAgICAgIG49e259XG4gICAgICAgIGRyYWdLZXk9e24ua2V5fVxuICAgICAgICB0YXJnZXRJZD1cIjBcIlxuICAgICAgICB2YWx1ZT17ZGF0YX1cbiAgICAgICAgZHVwbGljYXRlcz17b3B0cy5vcHRpb25zLmR1cGxpY2F0ZXN9XG4gICAgICAgIG9uQ2hhbmdlPXt2YWx1ZSA9PiBvblZhbHVlQ2hhbmdlKG5vZGVQcm9wcywgbiwgdmFsdWUpfVxuICAgICAgICByZW1vdmVSZXNwb25zZT17dmFsdWUgPT4gb25SZW1vdmVSZXNwb25zZShub2RlUHJvcHMsIHZhbHVlKX1cbiAgICAgID5cbiAgICAgICAge25vZGVQcm9wcy5jaGlsZHJlbn1cbiAgICAgICAge2NoaWxkcmVufVxuICAgICAgPC9EcmFnRHJvcFRpbGU+XG4gICAgPC9zcGFuPlxuICApO1xufTtcblxuRHJhZ0Ryb3AucHJvcFR5cGVzID0ge1xuICBhdHRyaWJ1dGVzOiBQcm9wVHlwZXMub2JqZWN0LFxuICBkYXRhOiBQcm9wVHlwZXMub2JqZWN0LFxuICBuOiBQcm9wVHlwZXMub2JqZWN0LFxuICBub2RlUHJvcHM6IFByb3BUeXBlcy5vYmplY3QsXG4gIG9wdHM6IFByb3BUeXBlcy5vYmplY3Rcbn07XG5cbmV4cG9ydCBkZWZhdWx0IERyYWdEcm9wO1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7Ozs7OztBQUVPLElBQU1BLGFBQWEsR0FBRyxTQUFoQkEsYUFBZ0IsQ0FBQ0MsU0FBRCxFQUFZQyxDQUFaLEVBQWVDLEtBQWYsRUFBeUI7RUFDcEQsSUFBTUMsR0FBRyxHQUFHSCxTQUFTLENBQUNJLE1BQVYsQ0FBaUJGLEtBQTdCO0VBQ0EsSUFBTUcsTUFBTSxHQUFHRixHQUFHLENBQUNFLE1BQUosRUFBZjtFQUVBQSxNQUFNLENBQUNDLFlBQVAsQ0FBb0JMLENBQUMsQ0FBQ00sR0FBdEIsRUFBMkI7SUFDekJDLElBQUks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
98
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJvblZhbHVlQ2hhbmdlIiwibm9kZVByb3BzIiwibiIsInZhbHVlIiwidmFsIiwiZWRpdG9yIiwiY2hhbmdlIiwic2V0Tm9kZUJ5S2V5Iiwia2V5IiwiZGF0YSIsImluZGV4IiwicHJvcHMiLCJvbkNoYW5nZSIsIm9uRWRpdGluZ0RvbmUiLCJvblJlbW92ZVJlc3BvbnNlIiwiZHJhZ0luVGhlQmxhbmsiLCJkb2N1bWVudCIsImZpbmREZXNjZW5kYW50IiwiRHJhZ0Ryb3AiLCJhdHRyaWJ1dGVzIiwiY2hpbGRyZW4iLCJvcHRzIiwiaW5UYWJsZSIsImRpc3BsYXkiLCJtaW5IZWlnaHQiLCJtaW5XaWR0aCIsInBvc2l0aW9uIiwibWFyZ2luIiwiY3Vyc29yIiwib3B0aW9ucyIsImR1cGxpY2F0ZXMiLCJwcm9wVHlwZXMiLCJQcm9wVHlwZXMiLCJvYmplY3QiXSwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvcGx1Z2lucy9yZXNwQXJlYS9kcmFnLWluLXRoZS1ibGFuay9pbmRleC5qc3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgRHJhZ0Ryb3BUaWxlIGZyb20gJy4vY2hvaWNlJztcblxuZXhwb3J0IGNvbnN0IG9uVmFsdWVDaGFuZ2UgPSAobm9kZVByb3BzLCBuLCB2YWx1ZSkgPT4ge1xuICBjb25zdCB2YWwgPSBub2RlUHJvcHMuZWRpdG9yLnZhbHVlO1xuICBjb25zdCBjaGFuZ2UgPSB2YWwuY2hhbmdlKCk7XG5cbiAgY2hhbmdlLnNldE5vZGVCeUtleShuLmtleSwge1xuICAgIGRhdGE6IHtcbiAgICAgIC4uLnZhbHVlLFxuICAgICAgaW5kZXg6IG4uZGF0YS5pbmRleFxuICAgIH1cbiAgfSk7XG5cbiAgbm9kZVByb3BzLmVkaXRvci5wcm9wcy5vbkNoYW5nZShjaGFuZ2UsICgpID0+IHtcbiAgICBub2RlUHJvcHMuZWRpdG9yLnByb3BzLm9uRWRpdGluZ0RvbmUoKTtcbiAgfSk7XG59O1xuXG5leHBvcnQgY29uc3Qgb25SZW1vdmVSZXNwb25zZSA9IChub2RlUHJvcHMsIHZhbHVlKSA9PiB7XG4gIGNvbnN0IHZhbCA9IG5vZGVQcm9wcy5lZGl0b3IudmFsdWU7XG4gIGNvbnN0IGNoYW5nZSA9IHZhbC5jaGFuZ2UoKTtcbiAgY29uc3QgZHJhZ0luVGhlQmxhbmsgPSB2YWwuZG9jdW1lbnQuZmluZERlc2NlbmRhbnQoXG4gICAgbiA9PiBuLmRhdGEgJiYgbi5kYXRhLmluZGV4ID09PSB2YWx1ZS5pbmRleFxuICApO1xuXG4gIGNoYW5nZS5zZXROb2RlQnlLZXkoZHJhZ0luVGhlQmxhbmsua2V5LCB7XG4gICAgZGF0YToge1xuICAgICAgaW5kZXg6IGRyYWdJblRoZUJsYW5rLmRhdGEuaW5kZXhcbiAgICB9XG4gIH0pO1xuXG4gIG5vZGVQcm9wcy5lZGl0b3IucHJvcHMub25DaGFuZ2UoY2hhbmdlLCAoKSA9PiB7XG4gICAgbm9kZVByb3BzLmVkaXRvci5wcm9wcy5vbkVkaXRpbmdEb25lKCk7XG4gIH0pO1xufTtcblxuY29uc3QgRHJhZ0Ryb3AgPSBwcm9wcyA9PiB7XG4gIGNvbnN0IHsgYXR0cmlidXRlcywgY2hpbGRyZW4sIGRhdGEsIG4sIG5vZGVQcm9wcywgb3B0cyB9ID0gcHJvcHM7XG4gIGNvbnN0IHsgaW5UYWJsZSB9ID0gZGF0YTtcblxuICByZXR1cm4gKFxuICAgIDxzcGFuXG4gICAgICB7Li4uYXR0cmlidXRlc31cbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIGRpc3BsYXk6ICdpbmxpbmUtZmxleCcsXG4gICAgICAgIG1pbkhlaWdodDogJzUwcHgnLFxuICAgICAgICBtaW5XaWR0aDogJzE3OHB4JyxcbiAgICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICAgIG1hcmdpbjogaW5UYWJsZSA/ICcxMHB4JyA6ICcwIDEwcHgnLFxuICAgICAgICBjdXJzb3I6ICdwb2ludGVyJ1xuICAgICAgfX1cbiAgICA+XG4gICAgICA8RHJhZ0Ryb3BUaWxlXG4gICAgICAgIG49e259XG4gICAgICAgIGRyYWdLZXk9e24ua2V5fVxuICAgICAgICB0YXJnZXRJZD1cIjBcIlxuICAgICAgICB2YWx1ZT17ZGF0YX1cbiAgICAgICAgZHVwbGljYXRlcz17b3B0cy5vcHRpb25zLmR1cGxpY2F0ZXN9XG4gICAgICAgIG9uQ2hhbmdlPXt2YWx1ZSA9PiBvblZhbHVlQ2hhbmdlKG5vZGVQcm9wcywgbiwgdmFsdWUpfVxuICAgICAgICByZW1vdmVSZXNwb25zZT17dmFsdWUgPT4gb25SZW1vdmVSZXNwb25zZShub2RlUHJvcHMsIHZhbHVlKX1cbiAgICAgID5cbiAgICAgICAge25vZGVQcm9wcy5jaGlsZHJlbn1cbiAgICAgICAge2NoaWxkcmVufVxuICAgICAgPC9EcmFnRHJvcFRpbGU+XG4gICAgPC9zcGFuPlxuICApO1xufTtcblxuRHJhZ0Ryb3AucHJvcFR5cGVzID0ge1xuICBhdHRyaWJ1dGVzOiBQcm9wVHlwZXMub2JqZWN0LFxuICBkYXRhOiBQcm9wVHlwZXMub2JqZWN0LFxuICBuOiBQcm9wVHlwZXMub2JqZWN0LFxuICBub2RlUHJvcHM6IFByb3BUeXBlcy5vYmplY3QsXG4gIG9wdHM6IFByb3BUeXBlcy5vYmplY3Rcbn07XG5cbmV4cG9ydCBkZWZhdWx0IERyYWdEcm9wO1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7Ozs7OztBQUVPLElBQU1BLGFBQWEsR0FBRyxTQUFoQkEsYUFBZ0IsQ0FBQ0MsU0FBRCxFQUFZQyxDQUFaLEVBQWVDLEtBQWYsRUFBeUI7RUFDcEQsSUFBTUMsR0FBRyxHQUFHSCxTQUFTLENBQUNJLE1BQVYsQ0FBaUJGLEtBQTdCO0VBQ0EsSUFBTUcsTUFBTSxHQUFHRixHQUFHLENBQUNFLE1BQUosRUFBZjtFQUVBQSxNQUFNLENBQUNDLFlBQVAsQ0FBb0JMLENBQUMsQ0FBQ00sR0FBdEIsRUFBMkI7SUFDekJDLElBQUksa0NBQ0NOLEtBREQ7TUFFRk8sS0FBSyxFQUFF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
@@ -18,6 +18,10 @@ var _slateHyperscript = require("slate-hyperscript");
18
18
 
19
19
  var _debug = _interopRequireDefault(require("debug"));
20
20
 
21
+ var _cloneDeep = _interopRequireDefault(require("lodash/cloneDeep"));
22
+
23
+ var _isEqual = _interopRequireDefault(require("lodash/isEqual"));
24
+
21
25
  var _isUndefined = _interopRequireDefault(require("lodash/isUndefined"));
22
26
 
23
27
  var _inlineDropdown = _interopRequireDefault(require("./inline-dropdown"));
@@ -30,12 +34,6 @@ var _utils = require("./utils");
30
34
 
31
35
  var _icons = require("./icons");
32
36
 
33
- function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; }
34
-
35
- function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
36
-
37
- function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
38
-
39
37
  var log = (0, _debug["default"])('@pie-lib:editable-html:plugins:respArea');
40
38
  var lastIndexMap = {};
41
39
  var elTypesMap = {
@@ -58,29 +56,19 @@ function ResponseAreaPlugin(opts) {
58
56
  onClick: function onClick(editor) {
59
57
  log('[toolbar] onClick');
60
58
  var currentRespAreaList = [];
61
-
62
- var descendants = _slate.Node.descendants(editor, {
59
+ var descendants = Array.from(_slate.Node.descendants(editor, {
63
60
  reverse: true
64
- });
65
-
66
- var _iterator = _createForOfIteratorHelper(descendants),
67
- _step;
61
+ })).map(function (_ref) {
62
+ var _ref2 = (0, _slicedToArray2["default"])(_ref, 1),
63
+ d = _ref2[0];
68
64
 
69
- try {
70
- for (_iterator.s(); !(_step = _iterator.n()).done;) {
71
- var _step$value = (0, _slicedToArray2["default"])(_step.value, 2),
72
- descendant = _step$value[0],
73
- descendantPath = _step$value[1];
74
-
75
- if (isOfCurrentType(descendant, descendantPath)) {
76
- currentRespAreaList.push(descendant);
77
- }
65
+ return d;
66
+ });
67
+ descendants.forEach(function (d) {
68
+ if (isOfCurrentType(d)) {
69
+ currentRespAreaList.push(d);
78
70
  }
79
- } catch (err) {
80
- _iterator.e(err);
81
- } finally {
82
- _iterator.f();
83
- }
71
+ });
84
72
 
85
73
  if (currentRespAreaList.length >= opts.maxResponseAreas) {
86
74
  return;
@@ -125,7 +113,8 @@ function ResponseAreaPlugin(opts) {
125
113
  toolbar: toolbar,
126
114
  rules: function rules(editor) {
127
115
  var isVoid = editor.isVoid,
128
- isInline = editor.isInline;
116
+ isInline = editor.isInline,
117
+ onChange = editor.onChange;
129
118
 
130
119
  editor.isVoid = function (element) {
131
120
  return elTypesArray.includes(element.type) ? true : isVoid(element);
@@ -135,6 +124,63 @@ function ResponseAreaPlugin(opts) {
135
124
  return elTypesArray.includes(element.type) ? true : isInline(element);
136
125
  };
137
126
 
127
+ var oldEditor = (0, _cloneDeep["default"])(editor);
128
+
129
+ editor.onChange = function (options) {
130
+ var descendants = Array.from(_slate.Node.descendants(editor, {
131
+ reverse: true
132
+ })).map(function (_ref3) {
133
+ var _ref4 = (0, _slicedToArray2["default"])(_ref3, 1),
134
+ d = _ref4[0];
135
+
136
+ return d;
137
+ });
138
+ var type = opts.type.replace(/-/g, '_');
139
+
140
+ if ((0, _isUndefined["default"])(lastIndexMap[type])) {
141
+ lastIndexMap[type] = 0;
142
+ descendants.forEach(function (d) {
143
+ if (d.type === type) {
144
+ var newIndex = parseInt(d.data.index, 10);
145
+
146
+ if (newIndex > lastIndexMap[type]) {
147
+ lastIndexMap[type] = newIndex;
148
+ }
149
+ }
150
+ });
151
+ }
152
+
153
+ if ((0, _isEqual["default"])(editor, oldEditor)) {
154
+ return;
155
+ }
156
+
157
+ var oldDescendants = Array.from(_slate.Node.descendants(oldEditor, {
158
+ reverse: true
159
+ })).map(function (_ref5) {
160
+ var _ref6 = (0, _slicedToArray2["default"])(_ref5, 1),
161
+ d = _ref6[0];
162
+
163
+ return d;
164
+ });
165
+ var currentRespAreaList = descendants.filter(isOfCurrentType);
166
+ var oldRespAreaList = oldDescendants.filter(isOfCurrentType);
167
+ toolbar.disabled = currentRespAreaList.length >= opts.maxResponseAreas;
168
+ var arrayToFilter = oldRespAreaList.length > currentRespAreaList.length ? oldRespAreaList : currentRespAreaList;
169
+ var arrayToUseForFilter = arrayToFilter === oldRespAreaList ? currentRespAreaList : oldRespAreaList;
170
+ var elementsWithChangedStatus = arrayToFilter.filter(function (d) {
171
+ return !arrayToUseForFilter.find(function (e) {
172
+ return e.data.index === d.data.index;
173
+ });
174
+ });
175
+
176
+ if (elementsWithChangedStatus.length && oldRespAreaList.length > currentRespAreaList.length) {
177
+ opts.onHandleAreaChange(elementsWithChangedStatus);
178
+ }
179
+
180
+ oldEditor = (0, _cloneDeep["default"])(editor);
181
+ onChange(options);
182
+ };
183
+
138
184
  return editor;
139
185
  },
140
186
  filterPlugins: function filterPlugins(node, plugins) {
@@ -146,10 +192,13 @@ function ResponseAreaPlugin(opts) {
146
192
  return p.name !== 'response_area';
147
193
  });
148
194
  },
149
- deleteNode: function deleteNode(e, node, value, onChange) {
195
+ deleteNode: function deleteNode(e, node, nodePath, editor, onChange) {
150
196
  e.preventDefault();
151
- var change = value.change().removeNodeByKey(node.key);
152
- onChange(change);
197
+ editor.apply({
198
+ type: 'remove_node',
199
+ path: nodePath
200
+ });
201
+ onChange(editor);
153
202
  },
154
203
  supports: function supports(node) {
155
204
  return elTypesArray.indexOf(node.type) >= 0;
@@ -192,47 +241,6 @@ function ResponseAreaPlugin(opts) {
192
241
  }, props.children);
193
242
  }
194
243
  },
195
- onChange: function onChange(change, editor) {
196
- var type = opts.type.replace(/-/g, '_');
197
-
198
- if ((0, _isUndefined["default"])(lastIndexMap[type])) {
199
- lastIndexMap[type] = 0;
200
- change.value.document.forEachDescendant(function (d) {
201
- if (d.type === type) {
202
- var newIndex = parseInt(d.data.get('index'), 10);
203
-
204
- if (newIndex > lastIndexMap[type]) {
205
- lastIndexMap[type] = newIndex;
206
- }
207
- }
208
- });
209
- }
210
-
211
- if (!editor.value) {
212
- return;
213
- }
214
-
215
- var currentRespAreaList = change.value.document.filterDescendants(isOfCurrentType);
216
- var oldRespAreaList = editor.value.document.filterDescendants(isOfCurrentType);
217
-
218
- if (currentRespAreaList.size >= opts.maxResponseAreas) {
219
- toolbar.disabled = true;
220
- } else {
221
- toolbar.disabled = false;
222
- }
223
-
224
- var arrayToFilter = oldRespAreaList.size > currentRespAreaList.size ? oldRespAreaList : currentRespAreaList;
225
- var arrayToUseForFilter = arrayToFilter === oldRespAreaList ? currentRespAreaList : oldRespAreaList;
226
- var elementsWithChangedStatus = arrayToFilter.filter(function (d) {
227
- return !arrayToUseForFilter.find(function (e) {
228
- return e.data.get('index') === d.data.get('index');
229
- });
230
- });
231
-
232
- if (elementsWithChangedStatus.size && oldRespAreaList.size > currentRespAreaList.size) {
233
- opts.onHandleAreaChange(elementsWithChangedStatus);
234
- }
235
- },
236
244
  onDrop: function onDrop(event, change, editor) {
237
245
  var closestEl = event.target.closest('[data-key]');
238
246
  var inline = editor.value.document.findDescendant(function (d) {
@@ -282,14 +290,10 @@ var serialization = {
282
290
  }
283
291
  },
284
292
  serialize: function serialize(object) {
285
- if (object.object !== 'inline') {
286
- return;
287
- }
288
-
289
293
  switch (object.type) {
290
294
  case 'inline_dropdown':
291
295
  {
292
- var data = object.data.toJSON();
296
+ var data = object.data;
293
297
  return /*#__PURE__*/_react["default"].createElement("span", {
294
298
  "data-type": "inline_dropdown",
295
299
  "data-index": data.index,
@@ -299,8 +303,7 @@ var serialization = {
299
303
 
300
304
  case 'explicit_constructed_response':
301
305
  {
302
- var _data3 = object.data.toJSON();
303
-
306
+ var _data3 = object.data;
304
307
  return /*#__PURE__*/_react["default"].createElement("span", {
305
308
  "data-type": "explicit_constructed_response",
306
309
  "data-index": _data3.index,
@@ -310,8 +313,7 @@ var serialization = {
310
313
 
311
314
  case 'drag_in_the_blank':
312
315
  {
313
- var _data4 = object.data.toJSON();
314
-
316
+ var _data4 = object.data;
315
317
  return /*#__PURE__*/_react["default"].createElement("span", {
316
318
  "data-type": "drag_in_the_blank",
317
319
  "data-index": _data4.index,
@@ -324,4 +326,4 @@ var serialization = {
324
326
  }
325
327
  };
326
328
  exports.serialization = serialization;
327
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["log","debug","lastIndexMap","elTypesMap","elTypesArray","Object","values","ResponseAreaPlugin","opts","isOfCurrentType","d","type","toolbar","icon","buttonStyles","margin","onClick","editor","currentRespAreaList","descendants","SlateNode","reverse","descendant","descendantPath","push","length","maxResponseAreas","replace","prevIndex","newIndex","newInline","getDefaultElement","insertNode","customToolbar","respAreaToolbar","showDone","name","rules","isVoid","isInline","element","includes","filterPlugins","node","plugins","filter","p","deleteNode","e","value","onChange","preventDefault","change","removeNodeByKey","key","supports","indexOf","renderNode","props","attributes","data","error","index","children","isUndefined","document","forEachDescendant","parseInt","get","filterDescendants","oldRespAreaList","size","disabled","arrayToFilter","arrayToUseForFilter","elementsWithChangedStatus","find","onHandleAreaChange","onDrop","event","closestEl","target","closest","inline","findDescendant","dataset","serialization","deserialize","el","jsx","id","inTable","serialize","object","toJSON"],"sources":["../../../src/plugins/respArea/index.jsx"],"sourcesContent":["import React from 'react';\nimport { Node as SlateNode } from 'slate';\nimport { jsx } from 'slate-hyperscript';\nimport debug from 'debug';\n\nimport isUndefined from 'lodash/isUndefined';\nimport InlineDropdown from './inline-dropdown';\nimport DragInTheBlank from './drag-in-the-blank';\nimport ExplicitConstructedResponse from './explicit-constructed-response';\nimport { getDefaultElement } from './utils';\nimport { ToolbarIcon } from './icons';\n\nconst log = debug('@pie-lib:editable-html:plugins:respArea');\n\nconst lastIndexMap = {};\nconst elTypesMap = {\n  'inline-dropdown': 'inline_dropdown',\n  'explicit-constructed-response': 'explicit_constructed_response',\n  'drag-in-the-blank': 'drag_in_the_blank'\n};\nconst elTypesArray = Object.values(elTypesMap);\n\nexport default function ResponseAreaPlugin(opts) {\n  const isOfCurrentType = d => d.type === opts.type || d.type === elTypesMap[opts.type];\n\n  const toolbar = {\n    icon: <ToolbarIcon />,\n    buttonStyles: {\n      margin: '0 20px 0 auto'\n    },\n    onClick: editor => {\n      log('[toolbar] onClick');\n      const currentRespAreaList = [];\n      const descendants = SlateNode.descendants(editor, {\n        reverse: true\n      });\n\n      for (const [descendant, descendantPath] of descendants) {\n        if (isOfCurrentType(descendant, descendantPath)) {\n          currentRespAreaList.push(descendant);\n        }\n      }\n\n      if (currentRespAreaList.length >= opts.maxResponseAreas) {\n        return;\n      }\n\n      const type = opts.type.replace(/-/g, '_');\n      const prevIndex = lastIndexMap[type];\n      const newIndex = !prevIndex ? 0 : prevIndex + 1;\n      const newInline = getDefaultElement(opts, newIndex);\n\n      lastIndexMap[type] += 1;\n\n      if (newInline) {\n        /*        if (change.value.selection.startKey || change.value.selection.endKey) {\n          change.insertInline(newInline);\n        } else {\n          // If the markup is empty and there's no focus\n          const lastText = value.document.getLastText();\n\n          if (!lastText) {\n            return;\n          }\n          const parentNode = value.document.getParent(lastText.key);\n\n          if (parentNode) {\n            const index = parentNode.nodes.indexOf(lastText.key);\n\n            if (parentNode.isVoid) return;\n\n            change.insertNodeByKey(parentNode.key, index + 1, newInline);\n          }\n        }\n\n        if (newInline.type === 'drag_in_the_blank') {\n          const nextText = change.value.document.getNextText(newInline.key);\n\n          if (nextText) {\n            change.moveFocusTo(nextText.key, 0).moveAnchorTo(nextText.key, 0);\n          }\n        }*/\n        editor.insertNode(newInline);\n      }\n    },\n    customToolbar: opts.respAreaToolbar,\n    showDone: false\n  };\n\n  return {\n    name: 'response_area',\n    toolbar,\n    rules: editor => {\n      const { isVoid, isInline } = editor;\n\n      editor.isVoid = element => {\n        return elTypesArray.includes(element.type) ? true : isVoid(element);\n      };\n\n      editor.isInline = element => {\n        return elTypesArray.includes(element.type) ? true : isInline(element);\n      };\n\n      return editor;\n    },\n    filterPlugins: (node, plugins) => {\n      if (node.type === 'explicit_constructed_response' || node.type === 'drag_in_the_blank') {\n        return [];\n      }\n\n      return plugins.filter(p => p.name !== 'response_area');\n    },\n    deleteNode: (e, node, value, onChange) => {\n      e.preventDefault();\n\n      const change = value.change().removeNodeByKey(node.key);\n\n      onChange(change);\n    },\n    supports: node => elTypesArray.indexOf(node.type) >= 0,\n    renderNode(props) {\n      const { attributes, node } = props;\n\n      if (node.type === 'explicit_constructed_response') {\n        const { data } = node;\n        let error;\n\n        if (opts.error) {\n          error = opts.error();\n        }\n\n        return (\n          <ExplicitConstructedResponse\n            attributes={attributes}\n            value={data.value}\n            error={error && error[data.index] && error[data.index][0]}\n          >\n            {props.children}\n          </ExplicitConstructedResponse>\n        );\n      }\n\n      if (node.type === 'drag_in_the_blank') {\n        const { data } = node;\n\n        return (\n          <DragInTheBlank\n            attributes={attributes}\n            data={data}\n            n={node}\n            nodeProps={props}\n            opts={opts}\n          >\n            {props.children}\n          </DragInTheBlank>\n        );\n      }\n\n      if (node.type === 'inline_dropdown') {\n        const { data } = node;\n\n        return (\n          <InlineDropdown attributes={attributes} selectedItem={data.value}>\n            {props.children}\n          </InlineDropdown>\n        );\n      }\n    },\n    onChange(change, editor) {\n      const type = opts.type.replace(/-/g, '_');\n\n      if (isUndefined(lastIndexMap[type])) {\n        lastIndexMap[type] = 0;\n\n        change.value.document.forEachDescendant(d => {\n          if (d.type === type) {\n            const newIndex = parseInt(d.data.get('index'), 10);\n\n            if (newIndex > lastIndexMap[type]) {\n              lastIndexMap[type] = newIndex;\n            }\n          }\n        });\n      }\n\n      if (!editor.value) {\n        return;\n      }\n\n      const currentRespAreaList = change.value.document.filterDescendants(isOfCurrentType);\n      const oldRespAreaList = editor.value.document.filterDescendants(isOfCurrentType);\n\n      if (currentRespAreaList.size >= opts.maxResponseAreas) {\n        toolbar.disabled = true;\n      } else {\n        toolbar.disabled = false;\n      }\n\n      const arrayToFilter =\n        oldRespAreaList.size > currentRespAreaList.size ? oldRespAreaList : currentRespAreaList;\n      const arrayToUseForFilter =\n        arrayToFilter === oldRespAreaList ? currentRespAreaList : oldRespAreaList;\n\n      const elementsWithChangedStatus = arrayToFilter.filter(\n        d => !arrayToUseForFilter.find(e => e.data.get('index') === d.data.get('index'))\n      );\n\n      if (elementsWithChangedStatus.size && oldRespAreaList.size > currentRespAreaList.size) {\n        opts.onHandleAreaChange(elementsWithChangedStatus);\n      }\n    },\n    onDrop(event, change, editor) {\n      const closestEl = event.target.closest('[data-key]');\n      const inline = editor.value.document.findDescendant(d => d.key === closestEl.dataset.key);\n\n      if (inline.type === 'drag_in_the_blank') {\n        return false;\n      }\n    }\n  };\n}\n\nexport const serialization = {\n  deserialize(el) {\n    const type = el.dataset && el.dataset.type;\n\n    switch (type) {\n      case 'inline_dropdown':\n        return jsx('element', {\n          type: 'inline_dropdown',\n          data: {\n            index: el.dataset.index,\n            value: el.dataset.value\n          }\n        });\n      case 'explicit_constructed_response':\n        return jsx('element', {\n          type: 'explicit_constructed_response',\n          data: {\n            index: el.dataset.index,\n            value: el.dataset.value\n          }\n        });\n      case 'drag_in_the_blank':\n        return jsx('element', {\n          type: 'drag_in_the_blank',\n          data: {\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  serialize(object) {\n    if (object.object !== 'inline') {\n      return;\n    }\n\n    switch (object.type) {\n      case 'inline_dropdown': {\n        const data = object.data.toJSON();\n\n        return <span data-type=\"inline_dropdown\" data-index={data.index} data-value={data.value} />;\n      }\n      case 'explicit_constructed_response': {\n        const data = object.data.toJSON();\n\n        return (\n          <span\n            data-type=\"explicit_constructed_response\"\n            data-index={data.index}\n            data-value={data.value}\n          />\n        );\n      }\n      case 'drag_in_the_blank': {\n        const data = object.data.toJSON();\n\n        return (\n          <span\n            data-type=\"drag_in_the_blank\"\n            data-index={data.index}\n            data-id={data.id}\n            data-value={data.value}\n            data-in-table={data.inTable}\n          />\n        );\n      }\n    }\n  }\n};\n"],"mappings":"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"}
329
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["log","debug","lastIndexMap","elTypesMap","elTypesArray","Object","values","ResponseAreaPlugin","opts","isOfCurrentType","d","type","toolbar","icon","buttonStyles","margin","onClick","editor","currentRespAreaList","descendants","Array","from","SlateNode","reverse","map","forEach","push","length","maxResponseAreas","replace","prevIndex","newIndex","newInline","getDefaultElement","insertNode","customToolbar","respAreaToolbar","showDone","name","rules","isVoid","isInline","onChange","element","includes","oldEditor","cloneDeep","options","isUndefined","parseInt","data","index","isEqual","oldDescendants","filter","oldRespAreaList","disabled","arrayToFilter","arrayToUseForFilter","elementsWithChangedStatus","find","e","onHandleAreaChange","filterPlugins","node","plugins","p","deleteNode","nodePath","preventDefault","apply","path","supports","indexOf","renderNode","props","attributes","error","value","children","onDrop","event","change","closestEl","target","closest","inline","document","findDescendant","key","dataset","serialization","deserialize","el","jsx","id","inTable","serialize","object"],"sources":["../../../src/plugins/respArea/index.jsx"],"sourcesContent":["import React from 'react';\nimport { Node as SlateNode } from 'slate';\nimport { jsx } from 'slate-hyperscript';\nimport debug from 'debug';\n\nimport cloneDeep from 'lodash/cloneDeep';\nimport isEqual from 'lodash/isEqual';\nimport isUndefined from 'lodash/isUndefined';\nimport InlineDropdown from './inline-dropdown';\nimport DragInTheBlank from './drag-in-the-blank';\nimport ExplicitConstructedResponse from './explicit-constructed-response';\nimport { getDefaultElement } from './utils';\nimport { ToolbarIcon } from './icons';\n\nconst log = debug('@pie-lib:editable-html:plugins:respArea');\n\nconst lastIndexMap = {};\nconst elTypesMap = {\n  'inline-dropdown': 'inline_dropdown',\n  'explicit-constructed-response': 'explicit_constructed_response',\n  'drag-in-the-blank': 'drag_in_the_blank'\n};\nconst elTypesArray = Object.values(elTypesMap);\n\nexport default function ResponseAreaPlugin(opts) {\n  const isOfCurrentType = d => d.type === opts.type || d.type === elTypesMap[opts.type];\n\n  const toolbar = {\n    icon: <ToolbarIcon />,\n    buttonStyles: {\n      margin: '0 20px 0 auto'\n    },\n    onClick: editor => {\n      log('[toolbar] onClick');\n      const currentRespAreaList = [];\n      const descendants = Array.from(SlateNode.descendants(editor, { reverse: true })).map(\n        ([d]) => d\n      );\n\n      descendants.forEach(d => {\n        if (isOfCurrentType(d)) {\n          currentRespAreaList.push(d);\n        }\n      });\n\n      if (currentRespAreaList.length >= opts.maxResponseAreas) {\n        return;\n      }\n\n      const type = opts.type.replace(/-/g, '_');\n      const prevIndex = lastIndexMap[type];\n      const newIndex = !prevIndex ? 0 : prevIndex + 1;\n      const newInline = getDefaultElement(opts, newIndex);\n\n      lastIndexMap[type] += 1;\n\n      if (newInline) {\n        /*        if (change.value.selection.startKey || change.value.selection.endKey) {\n          change.insertInline(newInline);\n        } else {\n          // If the markup is empty and there's no focus\n          const lastText = value.document.getLastText();\n\n          if (!lastText) {\n            return;\n          }\n          const parentNode = value.document.getParent(lastText.key);\n\n          if (parentNode) {\n            const index = parentNode.nodes.indexOf(lastText.key);\n\n            if (parentNode.isVoid) return;\n\n            change.insertNodeByKey(parentNode.key, index + 1, newInline);\n          }\n        }\n\n        if (newInline.type === 'drag_in_the_blank') {\n          const nextText = change.value.document.getNextText(newInline.key);\n\n          if (nextText) {\n            change.moveFocusTo(nextText.key, 0).moveAnchorTo(nextText.key, 0);\n          }\n        }*/\n        editor.insertNode(newInline);\n      }\n    },\n    customToolbar: opts.respAreaToolbar,\n    showDone: false\n  };\n\n  return {\n    name: 'response_area',\n    toolbar,\n    rules: editor => {\n      const { isVoid, isInline, onChange } = editor;\n\n      editor.isVoid = element => {\n        return elTypesArray.includes(element.type) ? true : isVoid(element);\n      };\n\n      editor.isInline = element => {\n        return elTypesArray.includes(element.type) ? true : isInline(element);\n      };\n\n      let oldEditor = cloneDeep(editor);\n\n      editor.onChange = options => {\n        const descendants = Array.from(SlateNode.descendants(editor, { reverse: true })).map(\n          ([d]) => d\n        );\n        const type = opts.type.replace(/-/g, '_');\n\n        if (isUndefined(lastIndexMap[type])) {\n          lastIndexMap[type] = 0;\n\n          descendants.forEach(d => {\n            if (d.type === type) {\n              const newIndex = parseInt(d.data.index, 10);\n\n              if (newIndex > lastIndexMap[type]) {\n                lastIndexMap[type] = newIndex;\n              }\n            }\n          });\n        }\n\n        if (isEqual(editor, oldEditor)) {\n          return;\n        }\n\n        const oldDescendants = Array.from(SlateNode.descendants(oldEditor, { reverse: true })).map(\n          ([d]) => d\n        );\n        const currentRespAreaList = descendants.filter(isOfCurrentType);\n        const oldRespAreaList = oldDescendants.filter(isOfCurrentType);\n\n        toolbar.disabled = currentRespAreaList.length >= opts.maxResponseAreas;\n\n        const arrayToFilter =\n          oldRespAreaList.length > currentRespAreaList.length\n            ? oldRespAreaList\n            : currentRespAreaList;\n        const arrayToUseForFilter =\n          arrayToFilter === oldRespAreaList ? currentRespAreaList : oldRespAreaList;\n\n        const elementsWithChangedStatus = arrayToFilter.filter(\n          d => !arrayToUseForFilter.find(e => e.data.index === d.data.index)\n        );\n\n        if (\n          elementsWithChangedStatus.length &&\n          oldRespAreaList.length > currentRespAreaList.length\n        ) {\n          opts.onHandleAreaChange(elementsWithChangedStatus);\n        }\n\n        oldEditor = cloneDeep(editor);\n        onChange(options);\n      };\n\n      return editor;\n    },\n    filterPlugins: (node, plugins) => {\n      if (node.type === 'explicit_constructed_response' || node.type === 'drag_in_the_blank') {\n        return [];\n      }\n\n      return plugins.filter(p => p.name !== 'response_area');\n    },\n    deleteNode: (e, node, nodePath, editor, onChange) => {\n      e.preventDefault();\n\n      editor.apply({\n        type: 'remove_node',\n        path: nodePath\n      });\n\n      onChange(editor);\n    },\n    supports: node => elTypesArray.indexOf(node.type) >= 0,\n    renderNode(props) {\n      const { attributes, node } = props;\n\n      if (node.type === 'explicit_constructed_response') {\n        const { data } = node;\n        let error;\n\n        if (opts.error) {\n          error = opts.error();\n        }\n\n        return (\n          <ExplicitConstructedResponse\n            attributes={attributes}\n            value={data.value}\n            error={error && error[data.index] && error[data.index][0]}\n          >\n            {props.children}\n          </ExplicitConstructedResponse>\n        );\n      }\n\n      if (node.type === 'drag_in_the_blank') {\n        const { data } = node;\n\n        return (\n          <DragInTheBlank\n            attributes={attributes}\n            data={data}\n            n={node}\n            nodeProps={props}\n            opts={opts}\n          >\n            {props.children}\n          </DragInTheBlank>\n        );\n      }\n\n      if (node.type === 'inline_dropdown') {\n        const { data } = node;\n\n        return (\n          <InlineDropdown attributes={attributes} selectedItem={data.value}>\n            {props.children}\n          </InlineDropdown>\n        );\n      }\n    },\n    onDrop(event, change, editor) {\n      const closestEl = event.target.closest('[data-key]');\n      const inline = editor.value.document.findDescendant(d => d.key === closestEl.dataset.key);\n\n      if (inline.type === 'drag_in_the_blank') {\n        return false;\n      }\n    }\n  };\n}\n\nexport const serialization = {\n  deserialize(el) {\n    const type = el.dataset && el.dataset.type;\n\n    switch (type) {\n      case 'inline_dropdown':\n        return jsx('element', {\n          type: 'inline_dropdown',\n          data: {\n            index: el.dataset.index,\n            value: el.dataset.value\n          }\n        });\n      case 'explicit_constructed_response':\n        return jsx('element', {\n          type: 'explicit_constructed_response',\n          data: {\n            index: el.dataset.index,\n            value: el.dataset.value\n          }\n        });\n      case 'drag_in_the_blank':\n        return jsx('element', {\n          type: 'drag_in_the_blank',\n          data: {\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  serialize(object) {\n    switch (object.type) {\n      case 'inline_dropdown': {\n        const data = object.data;\n\n        return <span data-type=\"inline_dropdown\" data-index={data.index} data-value={data.value} />;\n      }\n      case 'explicit_constructed_response': {\n        const data = object.data;\n\n        return (\n          <span\n            data-type=\"explicit_constructed_response\"\n            data-index={data.index}\n            data-value={data.value}\n          />\n        );\n      }\n      case 'drag_in_the_blank': {\n        const data = object.data;\n\n        return (\n          <span\n            data-type=\"drag_in_the_blank\"\n            data-index={data.index}\n            data-id={data.id}\n            data-value={data.value}\n            data-in-table={data.inTable}\n          />\n        );\n      }\n    }\n  }\n};\n"],"mappings":";;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AAEA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAEA,IAAMA,GAAG,GAAG,IAAAC,iBAAA,EAAM,yCAAN,CAAZ;AAEA,IAAMC,YAAY,GAAG,EAArB;AACA,IAAMC,UAAU,GAAG;EACjB,mBAAmB,iBADF;EAEjB,iCAAiC,+BAFhB;EAGjB,qBAAqB;AAHJ,CAAnB;AAKA,IAAMC,YAAY,GAAGC,MAAM,CAACC,MAAP,CAAcH,UAAd,CAArB;;AAEe,SAASI,kBAAT,CAA4BC,IAA5B,EAAkC;EAC/C,IAAMC,eAAe,GAAG,SAAlBA,eAAkB,CAAAC,CAAC;IAAA,OAAIA,CAAC,CAACC,IAAF,KAAWH,IAAI,CAACG,IAAhB,IAAwBD,CAAC,CAACC,IAAF,KAAWR,UAAU,CAACK,IAAI,CAACG,IAAN,CAAjD;EAAA,CAAzB;;EAEA,IAAMC,OAAO,GAAG;IACdC,IAAI,eAAE,gCAAC,kBAAD,OADQ;IAEdC,YAAY,EAAE;MACZC,MAAM,EAAE;IADI,CAFA;IAKdC,OAAO,EAAE,iBAAAC,MAAM,EAAI;MACjBjB,GAAG,CAAC,mBAAD,CAAH;MACA,IAAMkB,mBAAmB,GAAG,EAA5B;MACA,IAAMC,WAAW,GAAGC,KAAK,CAACC,IAAN,CAAWC,WAAA,CAAUH,WAAV,CAAsBF,MAAtB,EAA8B;QAAEM,OAAO,EAAE;MAAX,CAA9B,CAAX,EAA6DC,GAA7D,CAClB;QAAA;QAAA,IAAEd,CAAF;;QAAA,OAASA,CAAT;MAAA,CADkB,CAApB;MAIAS,WAAW,CAACM,OAAZ,CAAoB,UAAAf,CAAC,EAAI;QACvB,IAAID,eAAe,CAACC,CAAD,CAAnB,EAAwB;UACtBQ,mBAAmB,CAACQ,IAApB,CAAyBhB,CAAzB;QACD;MACF,CAJD;;MAMA,IAAIQ,mBAAmB,CAACS,MAApB,IAA8BnB,IAAI,CAACoB,gBAAvC,EAAyD;QACvD;MACD;;MAED,IAAMjB,IAAI,GAAGH,IAAI,CAACG,IAAL,CAAUkB,OAAV,CAAkB,IAAlB,EAAwB,GAAxB,CAAb;MACA,IAAMC,SAAS,GAAG5B,YAAY,CAACS,IAAD,CAA9B;MACA,IAAMoB,QAAQ,GAAG,CAACD,SAAD,GAAa,CAAb,GAAiBA,SAAS,GAAG,CAA9C;MACA,IAAME,SAAS,GAAG,IAAAC,wBAAA,EAAkBzB,IAAlB,EAAwBuB,QAAxB,CAAlB;MAEA7B,YAAY,CAACS,IAAD,CAAZ,IAAsB,CAAtB;;MAEA,IAAIqB,SAAJ,EAAe;QACb;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;QAOQf,MAAM,CAACiB,UAAP,CAAkBF,SAAlB;MACD;IACF,CA3Da;IA4DdG,aAAa,EAAE3B,IAAI,CAAC4B,eA5DN;IA6DdC,QAAQ,EAAE;EA7DI,CAAhB;EAgEA,OAAO;IACLC,IAAI,EAAE,eADD;IAEL1B,OAAO,EAAPA,OAFK;IAGL2B,KAAK,EAAE,eAAAtB,MAAM,EAAI;MACf,IAAQuB,MAAR,GAAuCvB,MAAvC,CAAQuB,MAAR;MAAA,IAAgBC,QAAhB,GAAuCxB,MAAvC,CAAgBwB,QAAhB;MAAA,IAA0BC,QAA1B,GAAuCzB,MAAvC,CAA0ByB,QAA1B;;MAEAzB,MAAM,CAACuB,MAAP,GAAgB,UAAAG,OAAO,EAAI;QACzB,OAAOvC,YAAY,CAACwC,QAAb,CAAsBD,OAAO,CAAChC,IAA9B,IAAsC,IAAtC,GAA6C6B,MAAM,CAACG,OAAD,CAA1D;MACD,CAFD;;MAIA1B,MAAM,CAACwB,QAAP,GAAkB,UAAAE,OAAO,EAAI;QAC3B,OAAOvC,YAAY,CAACwC,QAAb,CAAsBD,OAAO,CAAChC,IAA9B,IAAsC,IAAtC,GAA6C8B,QAAQ,CAACE,OAAD,CAA5D;MACD,CAFD;;MAIA,IAAIE,SAAS,GAAG,IAAAC,qBAAA,EAAU7B,MAAV,CAAhB;;MAEAA,MAAM,CAACyB,QAAP,GAAkB,UAAAK,OAAO,EAAI;QAC3B,IAAM5B,WAAW,GAAGC,KAAK,CAACC,IAAN,CAAWC,WAAA,CAAUH,WAAV,CAAsBF,MAAtB,EAA8B;UAAEM,OAAO,EAAE;QAAX,CAA9B,CAAX,EAA6DC,GAA7D,CAClB;UAAA;UAAA,IAAEd,CAAF;;UAAA,OAASA,CAAT;QAAA,CADkB,CAApB;QAGA,IAAMC,IAAI,GAAGH,IAAI,CAACG,IAAL,CAAUkB,OAAV,CAAkB,IAAlB,EAAwB,GAAxB,CAAb;;QAEA,IAAI,IAAAmB,uBAAA,EAAY9C,YAAY,CAACS,IAAD,CAAxB,CAAJ,EAAqC;UACnCT,YAAY,CAACS,IAAD,CAAZ,GAAqB,CAArB;UAEAQ,WAAW,CAACM,OAAZ,CAAoB,UAAAf,CAAC,EAAI;YACvB,IAAIA,CAAC,CAACC,IAAF,KAAWA,IAAf,EAAqB;cACnB,IAAMoB,QAAQ,GAAGkB,QAAQ,CAACvC,CAAC,CAACwC,IAAF,CAAOC,KAAR,EAAe,EAAf,CAAzB;;cAEA,IAAIpB,QAAQ,GAAG7B,YAAY,CAACS,IAAD,CAA3B,EAAmC;gBACjCT,YAAY,CAACS,IAAD,CAAZ,GAAqBoB,QAArB;cACD;YACF;UACF,CARD;QASD;;QAED,IAAI,IAAAqB,mBAAA,EAAQnC,MAAR,EAAgB4B,SAAhB,CAAJ,EAAgC;UAC9B;QACD;;QAED,IAAMQ,cAAc,GAAGjC,KAAK,CAACC,IAAN,CAAWC,WAAA,CAAUH,WAAV,CAAsB0B,SAAtB,EAAiC;UAAEtB,OAAO,EAAE;QAAX,CAAjC,CAAX,EAAgEC,GAAhE,CACrB;UAAA;UAAA,IAAEd,CAAF;;UAAA,OAASA,CAAT;QAAA,CADqB,CAAvB;QAGA,IAAMQ,mBAAmB,GAAGC,WAAW,CAACmC,MAAZ,CAAmB7C,eAAnB,CAA5B;QACA,IAAM8C,eAAe,GAAGF,cAAc,CAACC,MAAf,CAAsB7C,eAAtB,CAAxB;QAEAG,OAAO,CAAC4C,QAAR,GAAmBtC,mBAAmB,CAACS,MAApB,IAA8BnB,IAAI,CAACoB,gBAAtD;QAEA,IAAM6B,aAAa,GACjBF,eAAe,CAAC5B,MAAhB,GAAyBT,mBAAmB,CAACS,MAA7C,GACI4B,eADJ,GAEIrC,mBAHN;QAIA,IAAMwC,mBAAmB,GACvBD,aAAa,KAAKF,eAAlB,GAAoCrC,mBAApC,GAA0DqC,eAD5D;QAGA,IAAMI,yBAAyB,GAAGF,aAAa,CAACH,MAAd,CAChC,UAAA5C,CAAC;UAAA,OAAI,CAACgD,mBAAmB,CAACE,IAApB,CAAyB,UAAAC,CAAC;YAAA,OAAIA,CAAC,CAACX,IAAF,CAAOC,KAAP,KAAiBzC,CAAC,CAACwC,IAAF,CAAOC,KAA5B;UAAA,CAA1B,CAAL;QAAA,CAD+B,CAAlC;;QAIA,IACEQ,yBAAyB,CAAChC,MAA1B,IACA4B,eAAe,CAAC5B,MAAhB,GAAyBT,mBAAmB,CAACS,MAF/C,EAGE;UACAnB,IAAI,CAACsD,kBAAL,CAAwBH,yBAAxB;QACD;;QAEDd,SAAS,GAAG,IAAAC,qBAAA,EAAU7B,MAAV,CAAZ;QACAyB,QAAQ,CAACK,OAAD,CAAR;MACD,CApDD;;MAsDA,OAAO9B,MAAP;IACD,CAvEI;IAwEL8C,aAAa,EAAE,uBAACC,IAAD,EAAOC,OAAP,EAAmB;MAChC,IAAID,IAAI,CAACrD,IAAL,KAAc,+BAAd,IAAiDqD,IAAI,CAACrD,IAAL,KAAc,mBAAnE,EAAwF;QACtF,OAAO,EAAP;MACD;;MAED,OAAOsD,OAAO,CAACX,MAAR,CAAe,UAAAY,CAAC;QAAA,OAAIA,CAAC,CAAC5B,IAAF,KAAW,eAAf;MAAA,CAAhB,CAAP;IACD,CA9EI;IA+EL6B,UAAU,EAAE,oBAACN,CAAD,EAAIG,IAAJ,EAAUI,QAAV,EAAoBnD,MAApB,EAA4ByB,QAA5B,EAAyC;MACnDmB,CAAC,CAACQ,cAAF;MAEApD,MAAM,CAACqD,KAAP,CAAa;QACX3D,IAAI,EAAE,aADK;QAEX4D,IAAI,EAAEH;MAFK,CAAb;MAKA1B,QAAQ,CAACzB,MAAD,CAAR;IACD,CAxFI;IAyFLuD,QAAQ,EAAE,kBAAAR,IAAI;MAAA,OAAI5D,YAAY,CAACqE,OAAb,CAAqBT,IAAI,CAACrD,IAA1B,KAAmC,CAAvC;IAAA,CAzFT;IA0FL+D,UA1FK,sBA0FMC,KA1FN,EA0Fa;MAChB,IAAQC,UAAR,GAA6BD,KAA7B,CAAQC,UAAR;MAAA,IAAoBZ,IAApB,GAA6BW,KAA7B,CAAoBX,IAApB;;MAEA,IAAIA,IAAI,CAACrD,IAAL,KAAc,+BAAlB,EAAmD;QACjD,IAAQuC,IAAR,GAAiBc,IAAjB,CAAQd,IAAR;QACA,IAAI2B,KAAJ;;QAEA,IAAIrE,IAAI,CAACqE,KAAT,EAAgB;UACdA,KAAK,GAAGrE,IAAI,CAACqE,KAAL,EAAR;QACD;;QAED,oBACE,gCAAC,uCAAD;UACE,UAAU,EAAED,UADd;UAEE,KAAK,EAAE1B,IAAI,CAAC4B,KAFd;UAGE,KAAK,EAAED,KAAK,IAAIA,KAAK,CAAC3B,IAAI,CAACC,KAAN,CAAd,IAA8B0B,KAAK,CAAC3B,IAAI,CAACC,KAAN,CAAL,CAAkB,CAAlB;QAHvC,GAKGwB,KAAK,CAACI,QALT,CADF;MASD;;MAED,IAAIf,IAAI,CAACrD,IAAL,KAAc,mBAAlB,EAAuC;QACrC,IAAQuC,KAAR,GAAiBc,IAAjB,CAAQd,IAAR;QAEA,oBACE,gCAAC,0BAAD;UACE,UAAU,EAAE0B,UADd;UAEE,IAAI,EAAE1B,KAFR;UAGE,CAAC,EAAEc,IAHL;UAIE,SAAS,EAAEW,KAJb;UAKE,IAAI,EAAEnE;QALR,GAOGmE,KAAK,CAACI,QAPT,CADF;MAWD;;MAED,IAAIf,IAAI,CAACrD,IAAL,KAAc,iBAAlB,EAAqC;QACnC,IAAQuC,MAAR,GAAiBc,IAAjB,CAAQd,IAAR;QAEA,oBACE,gCAAC,0BAAD;UAAgB,UAAU,EAAE0B,UAA5B;UAAwC,YAAY,EAAE1B,MAAI,CAAC4B;QAA3D,GACGH,KAAK,CAACI,QADT,CADF;MAKD;IACF,CAzII;IA0ILC,MA1IK,kBA0IEC,KA1IF,EA0ISC,MA1IT,EA0IiBjE,MA1IjB,EA0IyB;MAC5B,IAAMkE,SAAS,GAAGF,KAAK,CAACG,MAAN,CAAaC,OAAb,CAAqB,YAArB,CAAlB;MACA,IAAMC,MAAM,GAAGrE,MAAM,CAAC6D,KAAP,CAAaS,QAAb,CAAsBC,cAAtB,CAAqC,UAAA9E,CAAC;QAAA,OAAIA,CAAC,CAAC+E,GAAF,KAAUN,SAAS,CAACO,OAAV,CAAkBD,GAAhC;MAAA,CAAtC,CAAf;;MAEA,IAAIH,MAAM,CAAC3E,IAAP,KAAgB,mBAApB,EAAyC;QACvC,OAAO,KAAP;MACD;IACF;EAjJI,CAAP;AAmJD;;AAEM,IAAMgF,aAAa,GAAG;EAC3BC,WAD2B,uBACfC,EADe,EACX;IACd,IAAMlF,IAAI,GAAGkF,EAAE,CAACH,OAAH,IAAcG,EAAE,CAACH,OAAH,CAAW/E,IAAtC;;IAEA,QAAQA,IAAR;MACE,KAAK,iBAAL;QACE,OAAO,IAAAmF,qBAAA,EAAI,SAAJ,EAAe;UACpBnF,IAAI,EAAE,iBADc;UAEpBuC,IAAI,EAAE;YACJC,KAAK,EAAE0C,EAAE,CAACH,OAAH,CAAWvC,KADd;YAEJ2B,KAAK,EAAEe,EAAE,CAACH,OAAH,CAAWZ;UAFd;QAFc,CAAf,CAAP;;MAOF,KAAK,+BAAL;QACE,OAAO,IAAAgB,qBAAA,EAAI,SAAJ,EAAe;UACpBnF,IAAI,EAAE,+BADc;UAEpBuC,IAAI,EAAE;YACJC,KAAK,EAAE0C,EAAE,CAACH,OAAH,CAAWvC,KADd;YAEJ2B,KAAK,EAAEe,EAAE,CAACH,OAAH,CAAWZ;UAFd;QAFc,CAAf,CAAP;;MAOF,KAAK,mBAAL;QACE,OAAO,IAAAgB,qBAAA,EAAI,SAAJ,EAAe;UACpBnF,IAAI,EAAE,mBADc;UAEpBuC,IAAI,EAAE;YACJC,KAAK,EAAE0C,EAAE,CAACH,OAAH,CAAWvC,KADd;YAEJ4C,EAAE,EAAEF,EAAE,CAACH,OAAH,CAAWK,EAFX;YAGJjB,KAAK,EAAEe,EAAE,CAACH,OAAH,CAAWZ,KAHd;YAIJkB,OAAO,EAAEH,EAAE,CAACH,OAAH,CAAWM;UAJhB;QAFc,CAAf,CAAP;IAlBJ;EA4BD,CAhC0B;EAiC3BC,SAjC2B,qBAiCjBC,MAjCiB,EAiCT;IAChB,QAAQA,MAAM,CAACvF,IAAf;MACE,KAAK,iBAAL;QAAwB;UACtB,IAAMuC,IAAI,GAAGgD,MAAM,CAAChD,IAApB;UAEA,oBAAO;YAAM,aAAU,iBAAhB;YAAkC,cAAYA,IAAI,CAACC,KAAnD;YAA0D,cAAYD,IAAI,CAAC4B;UAA3E,EAAP;QACD;;MACD,KAAK,+BAAL;QAAsC;UACpC,IAAM5B,MAAI,GAAGgD,MAAM,CAAChD,IAApB;UAEA,oBACE;YACE,aAAU,+BADZ;YAEE,cAAYA,MAAI,CAACC,KAFnB;YAGE,cAAYD,MAAI,CAAC4B;UAHnB,EADF;QAOD;;MACD,KAAK,mBAAL;QAA0B;UACxB,IAAM5B,MAAI,GAAGgD,MAAM,CAAChD,IAApB;UAEA,oBACE;YACE,aAAU,mBADZ;YAEE,cAAYA,MAAI,CAACC,KAFnB;YAGE,WAASD,MAAI,CAAC6C,EAHhB;YAIE,cAAY7C,MAAI,CAAC4B,KAJnB;YAKE,iBAAe5B,MAAI,CAAC8C;UALtB,EADF;QASD;IA7BH;EA+BD;AAjE0B,CAAtB"}