decap-cms-widget-markdown 3.3.0 → 3.4.1

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.
Files changed (51) hide show
  1. package/CHANGELOG.md +10 -0
  2. package/dist/decap-cms-widget-markdown.js +6 -6
  3. package/dist/decap-cms-widget-markdown.js.LICENSE.txt +5 -5
  4. package/dist/decap-cms-widget-markdown.js.map +1 -1
  5. package/dist/esm/MarkdownControl/RawEditor.js +1 -2
  6. package/dist/esm/MarkdownControl/Toolbar.js +43 -47
  7. package/dist/esm/MarkdownControl/VisualEditor.js +6 -8
  8. package/dist/esm/MarkdownControl/components/Shortcode.js +6 -11
  9. package/dist/esm/MarkdownControl/components/VoidBlock.js +1 -1
  10. package/dist/esm/MarkdownControl/index.js +34 -34
  11. package/dist/esm/MarkdownControl/plugins/CommandsAndQueries.js +8 -8
  12. package/dist/esm/MarkdownControl/plugins/inlines/events/toggleLink.js +1 -2
  13. package/dist/esm/MarkdownControl/plugins/lists/events/keyDownShiftTab.js +6 -9
  14. package/dist/esm/MarkdownControl/plugins/lists/events/keyDownTab.js +3 -7
  15. package/dist/esm/MarkdownControl/plugins/lists/transforms/liftFirstMatchedParent.js +4 -8
  16. package/dist/esm/MarkdownControl/plugins/lists/transforms/unwrapSelectionFromList.js +3 -7
  17. package/dist/esm/MarkdownControl/plugins/util.js +4 -4
  18. package/dist/esm/MarkdownControl/renderers.js +6 -11
  19. package/dist/esm/MarkdownPreview.js +11 -10
  20. package/dist/esm/index.js +4 -8
  21. package/dist/esm/regexHelper.js +4 -3
  22. package/dist/esm/serializers/index.js +2 -2
  23. package/dist/esm/serializers/remarkAssertParents.js +17 -20
  24. package/dist/esm/serializers/remarkEscapeMarkdownEntities.js +17 -17
  25. package/dist/esm/serializers/remarkImagesToText.js +3 -7
  26. package/dist/esm/serializers/remarkPaddedLinks.js +17 -21
  27. package/dist/esm/serializers/remarkRehypeShortcodes.js +10 -13
  28. package/dist/esm/serializers/remarkSlate.js +64 -55
  29. package/dist/esm/serializers/remarkSquashReferences.js +7 -11
  30. package/dist/esm/serializers/slateRemark.js +52 -52
  31. package/package.json +9 -7
  32. package/src/MarkdownControl/Toolbar.js +5 -0
  33. package/src/MarkdownControl/VisualEditor.js +1 -1
  34. package/src/MarkdownControl/components/Shortcode.js +1 -1
  35. package/src/MarkdownControl/index.js +5 -0
  36. package/src/MarkdownControl/plugins/CommandsAndQueries.js +3 -1
  37. package/src/MarkdownControl/plugins/util.js +2 -1
  38. package/src/MarkdownPreview.js +5 -0
  39. package/src/__tests__/renderer.spec.js +84 -117
  40. package/src/regexHelper.js +1 -1
  41. package/src/serializers/__tests__/commonmark.spec.js +1 -1
  42. package/src/serializers/__tests__/slate.spec.js +1 -1
  43. package/src/serializers/index.js +1 -1
  44. package/src/serializers/remarkAssertParents.js +4 -1
  45. package/src/serializers/remarkEscapeMarkdownEntities.js +4 -1
  46. package/src/serializers/remarkPaddedLinks.js +7 -1
  47. package/src/serializers/remarkRehypeShortcodes.js +2 -1
  48. package/src/serializers/remarkSlate.js +6 -1
  49. package/src/serializers/remarkSquashReferences.js +2 -1
  50. package/src/serializers/slateRemark.js +6 -1
  51. package/src/__tests__/__snapshots__/renderer.spec.js.snap +0 -239
@@ -1,5 +1,5 @@
1
1
  import _styled from "@emotion/styled/base";
2
- function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
2
+ function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
3
3
  function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
4
4
  /* eslint-disable react/display-name */
5
5
  import React from 'react';
@@ -66,8 +66,7 @@ const StyledLi = /*#__PURE__*/_styled("li", {
66
66
  styles: "&>p:first-of-type{margin-top:8px;}&>p:last-of-type{margin-bottom:8px;}"
67
67
  } : {
68
68
  name: "1smjpj0",
69
- styles: "&>p:first-of-type{margin-top:8px;}&>p:last-of-type{margin-bottom:8px;}",
70
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MarkdownControl/renderers.js"],"names":[],"mappings":"AA0E0B","file":"../../../src/MarkdownControl/renderers.js","sourcesContent":["/* eslint-disable react/display-name */\nimport React from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { colors, lengths } from 'decap-cms-ui-default';\nimport { useSelected } from 'slate-react';\n\nimport VoidBlock from './components/VoidBlock';\nimport Shortcode from './components/Shortcode';\n\nconst bottomMargin = '16px';\n\nconst headerStyles = `\n  font-weight: 700;\n  line-height: 1;\n`;\n\nconst StyledH1 = styled.h1`\n  ${headerStyles};\n  font-size: 32px;\n  margin-top: 16px;\n`;\n\nconst StyledH2 = styled.h2`\n  ${headerStyles};\n  font-size: 24px;\n  margin-top: 12px;\n`;\n\nconst StyledH3 = styled.h3`\n  ${headerStyles};\n  font-size: 20px;\n`;\n\nconst StyledH4 = styled.h4`\n  ${headerStyles};\n  font-size: 18px;\n  margin-top: 8px;\n`;\n\nconst StyledH5 = styled.h5`\n  ${headerStyles};\n  font-size: 16px;\n  margin-top: 8px;\n`;\n\nconst StyledH6 = StyledH5.withComponent('h6');\n\nconst StyledP = styled.p`\n  margin-bottom: ${bottomMargin};\n`;\n\nconst StyledBlockQuote = styled.blockquote`\n  padding-left: 16px;\n  border-left: 3px solid ${colors.background};\n  margin-left: 0;\n  margin-right: 0;\n  margin-bottom: ${bottomMargin};\n`;\n\nconst StyledCode = styled.code`\n  background-color: ${colors.background};\n  border-radius: ${lengths.borderRadius};\n  padding: 0 2px;\n  font-size: 85%;\n`;\n\nconst StyledUl = styled.ul`\n  margin-bottom: ${bottomMargin};\n  padding-left: 30px;\n`;\n\nconst StyledOl = StyledUl.withComponent('ol');\n\nconst StyledLi = styled.li`\n  & > p:first-of-type {\n    margin-top: 8px;\n  }\n\n  & > p:last-of-type {\n    margin-bottom: 8px;\n  }\n`;\n\nconst StyledA = styled.a`\n  text-decoration: underline;\n  font-size: inherit;\n`;\n\nconst StyledHr = styled.hr`\n  border: 1px solid;\n  margin-bottom: 16px;\n`;\n\nconst StyledTable = styled.table`\n  border-collapse: collapse;\n`;\n\nconst StyledTd = styled.td`\n  border: 2px solid black;\n  padding: 8px;\n  text-align: left;\n`;\n\n/**\n * Slate uses React components to render each type of node that it receives.\n * This is the closest thing Slate has to a schema definition. The types are set\n * by us when we manually deserialize from Remark's MDAST to Slate's AST.\n */\n\n/**\n * Mark Components\n */\nfunction Bold(props) {\n  return <strong>{props.children}</strong>;\n}\n\nfunction Italic(props) {\n  return <em>{props.children}</em>;\n}\n\nfunction Strikethrough(props) {\n  return <s>{props.children}</s>;\n}\n\nfunction Code(props) {\n  return <StyledCode>{props.children}</StyledCode>;\n}\n\n/**\n * Node Components\n */\nfunction Paragraph(props) {\n  return <StyledP {...props.attributes}>{props.children}</StyledP>;\n}\n\nfunction ListItem(props) {\n  return <StyledLi {...props.attributes}>{props.children}</StyledLi>;\n}\n\nfunction Quote(props) {\n  return <StyledBlockQuote {...props.attributes}>{props.children}</StyledBlockQuote>;\n}\n\nfunction HeadingOne(props) {\n  return <StyledH1 {...props.attributes}>{props.children}</StyledH1>;\n}\n\nfunction HeadingTwo(props) {\n  return <StyledH2 {...props.attributes}>{props.children}</StyledH2>;\n}\n\nfunction HeadingThree(props) {\n  return <StyledH3 {...props.attributes}>{props.children}</StyledH3>;\n}\n\nfunction HeadingFour(props) {\n  return <StyledH4 {...props.attributes}>{props.children}</StyledH4>;\n}\n\nfunction HeadingFive(props) {\n  return <StyledH5 {...props.attributes}>{props.children}</StyledH5>;\n}\n\nfunction HeadingSix(props) {\n  return <StyledH6 {...props.attributes}>{props.children}</StyledH6>;\n}\n\nfunction Table(props) {\n  return (\n    <StyledTable>\n      <tbody {...props.attributes}>{props.children}</tbody>\n    </StyledTable>\n  );\n}\n\nfunction TableRow(props) {\n  return <tr {...props.attributes}>{props.children}</tr>;\n}\n\nfunction TableCell(props) {\n  return <StyledTd {...props.attributes}>{props.children}</StyledTd>;\n}\n\nfunction ThematicBreak(props) {\n  const isSelected = useSelected();\n  return (\n    <div {...props.attributes}>\n      {props.children}\n      <div contentEditable={false}>\n        <StyledHr\n          {...props.attributes}\n          css={\n            isSelected &&\n            css`\n              box-shadow: 0 0 0 2px ${colors.active};\n              border-radius: 8px;\n              color: ${colors.active};\n            `\n          }\n        />\n      </div>\n    </div>\n  );\n}\n\nfunction Break(props) {\n  return (\n    <>\n      <br {...props.attributes} />\n      {props.children}\n    </>\n  );\n}\n\nfunction BulletedList(props) {\n  return <StyledUl {...props.attributes}>{props.children}</StyledUl>;\n}\n\nfunction NumberedList(props) {\n  return (\n    <StyledOl {...props.attributes} start={1}>\n      {props.children}\n    </StyledOl>\n  );\n}\n\nfunction Link(props) {\n  const url = props.element.url;\n  const title = props.element.title || url;\n\n  return (\n    <StyledA href={url} title={title} {...props.attributes}>\n      {props.children}\n    </StyledA>\n  );\n}\n\nfunction Image(props) {\n  const { url, title, alt } = props.element.data;\n  const isSelected = useSelected();\n  return (\n    <span {...props.attributes}>\n      {props.children}\n      <img\n        src={url}\n        title={title}\n        alt={alt}\n        {...props.attributes}\n        css={\n          isSelected &&\n          css`\n            box-shadow: 0 0 0 2px ${colors.active};\n          `\n        }\n      />\n    </span>\n  );\n}\n\nexport function Leaf({ attributes, children, leaf }) {\n  if (leaf.bold) {\n    children = <Bold>{children}</Bold>;\n  }\n\n  if (leaf.italic) {\n    children = <Italic>{children}</Italic>;\n  }\n\n  if (leaf.delete) {\n    children = <Strikethrough>{children}</Strikethrough>;\n  }\n\n  if (leaf.code) {\n    children = <Code>{children}</Code>;\n  }\n\n  // if (leaf.break) {\n  //   children = <Break />;\n  // }\n\n  return <span {...attributes}>{children}</span>;\n}\n\nexport function renderInline__DEPRECATED() {\n  return props => {\n    switch (props.node.type) {\n      case 'link':\n        return <Link {...props} />;\n      case 'image':\n        return <Image {...props} />;\n      case 'break':\n        return <Break {...props} />;\n    }\n  };\n}\n\nexport function Element(props) {\n  const { children, element, classNameWrapper, codeBlockComponent } = props;\n  const style = { textAlign: element.align };\n\n  switch (element.type) {\n    case 'bulleted-list':\n      return <BulletedList>{children}</BulletedList>;\n    case 'quote':\n      return <Quote>{children}</Quote>;\n    case 'heading-one':\n      return <HeadingOne>{children}</HeadingOne>;\n    case 'heading-two':\n      return <HeadingTwo>{children}</HeadingTwo>;\n    case 'heading-three':\n      return <HeadingThree>{children}</HeadingThree>;\n    case 'heading-four':\n      return <HeadingFour>{children}</HeadingFour>;\n    case 'heading-five':\n      return <HeadingFive>{children}</HeadingFive>;\n    case 'heading-six':\n      return <HeadingSix>{children}</HeadingSix>;\n    case 'list-item':\n      return <ListItem>{children}</ListItem>;\n    case 'numbered-list':\n      return <NumberedList>{children}</NumberedList>;\n    case 'table':\n      return <Table {...props} />;\n    case 'table-row':\n      return <TableRow {...props} />;\n    case 'table-cell':\n      return <TableCell {...props} />;\n    case 'thematic-break':\n      return (\n        <VoidBlock {...props}>\n          <ThematicBreak {...props} />\n        </VoidBlock>\n      );\n    case 'link':\n      return <Link {...props} />;\n    case 'image':\n      return <Image {...props} />;\n    case 'break':\n      return <Break {...props} />;\n    case 'shortcode':\n      if (element.id === 'code-block' && codeBlockComponent) {\n        return (\n          <VoidBlock {...props}>\n            <Shortcode classNameWrapper={classNameWrapper} typeOverload=\"code-block\" {...props} />\n          </VoidBlock>\n        );\n      }\n      return (\n        <VoidBlock {...props}>\n          <Shortcode {...props}>{children}</Shortcode>\n        </VoidBlock>\n      );\n    default:\n      return <Paragraph style={style}>{children}</Paragraph>;\n  }\n}\n"]} */",
69
+ styles: "&>p:first-of-type{margin-top:8px;}&>p:last-of-type{margin-bottom:8px;}/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MarkdownControl/renderers.js"],"names":[],"mappings":"AA0E0B","file":"../../../src/MarkdownControl/renderers.js","sourcesContent":["/* eslint-disable react/display-name */\nimport React from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { colors, lengths } from 'decap-cms-ui-default';\nimport { useSelected } from 'slate-react';\n\nimport VoidBlock from './components/VoidBlock';\nimport Shortcode from './components/Shortcode';\n\nconst bottomMargin = '16px';\n\nconst headerStyles = `\n  font-weight: 700;\n  line-height: 1;\n`;\n\nconst StyledH1 = styled.h1`\n  ${headerStyles};\n  font-size: 32px;\n  margin-top: 16px;\n`;\n\nconst StyledH2 = styled.h2`\n  ${headerStyles};\n  font-size: 24px;\n  margin-top: 12px;\n`;\n\nconst StyledH3 = styled.h3`\n  ${headerStyles};\n  font-size: 20px;\n`;\n\nconst StyledH4 = styled.h4`\n  ${headerStyles};\n  font-size: 18px;\n  margin-top: 8px;\n`;\n\nconst StyledH5 = styled.h5`\n  ${headerStyles};\n  font-size: 16px;\n  margin-top: 8px;\n`;\n\nconst StyledH6 = StyledH5.withComponent('h6');\n\nconst StyledP = styled.p`\n  margin-bottom: ${bottomMargin};\n`;\n\nconst StyledBlockQuote = styled.blockquote`\n  padding-left: 16px;\n  border-left: 3px solid ${colors.background};\n  margin-left: 0;\n  margin-right: 0;\n  margin-bottom: ${bottomMargin};\n`;\n\nconst StyledCode = styled.code`\n  background-color: ${colors.background};\n  border-radius: ${lengths.borderRadius};\n  padding: 0 2px;\n  font-size: 85%;\n`;\n\nconst StyledUl = styled.ul`\n  margin-bottom: ${bottomMargin};\n  padding-left: 30px;\n`;\n\nconst StyledOl = StyledUl.withComponent('ol');\n\nconst StyledLi = styled.li`\n  & > p:first-of-type {\n    margin-top: 8px;\n  }\n\n  & > p:last-of-type {\n    margin-bottom: 8px;\n  }\n`;\n\nconst StyledA = styled.a`\n  text-decoration: underline;\n  font-size: inherit;\n`;\n\nconst StyledHr = styled.hr`\n  border: 1px solid;\n  margin-bottom: 16px;\n`;\n\nconst StyledTable = styled.table`\n  border-collapse: collapse;\n`;\n\nconst StyledTd = styled.td`\n  border: 2px solid black;\n  padding: 8px;\n  text-align: left;\n`;\n\n/**\n * Slate uses React components to render each type of node that it receives.\n * This is the closest thing Slate has to a schema definition. The types are set\n * by us when we manually deserialize from Remark's MDAST to Slate's AST.\n */\n\n/**\n * Mark Components\n */\nfunction Bold(props) {\n  return <strong>{props.children}</strong>;\n}\n\nfunction Italic(props) {\n  return <em>{props.children}</em>;\n}\n\nfunction Strikethrough(props) {\n  return <s>{props.children}</s>;\n}\n\nfunction Code(props) {\n  return <StyledCode>{props.children}</StyledCode>;\n}\n\n/**\n * Node Components\n */\nfunction Paragraph(props) {\n  return <StyledP {...props.attributes}>{props.children}</StyledP>;\n}\n\nfunction ListItem(props) {\n  return <StyledLi {...props.attributes}>{props.children}</StyledLi>;\n}\n\nfunction Quote(props) {\n  return <StyledBlockQuote {...props.attributes}>{props.children}</StyledBlockQuote>;\n}\n\nfunction HeadingOne(props) {\n  return <StyledH1 {...props.attributes}>{props.children}</StyledH1>;\n}\n\nfunction HeadingTwo(props) {\n  return <StyledH2 {...props.attributes}>{props.children}</StyledH2>;\n}\n\nfunction HeadingThree(props) {\n  return <StyledH3 {...props.attributes}>{props.children}</StyledH3>;\n}\n\nfunction HeadingFour(props) {\n  return <StyledH4 {...props.attributes}>{props.children}</StyledH4>;\n}\n\nfunction HeadingFive(props) {\n  return <StyledH5 {...props.attributes}>{props.children}</StyledH5>;\n}\n\nfunction HeadingSix(props) {\n  return <StyledH6 {...props.attributes}>{props.children}</StyledH6>;\n}\n\nfunction Table(props) {\n  return (\n    <StyledTable>\n      <tbody {...props.attributes}>{props.children}</tbody>\n    </StyledTable>\n  );\n}\n\nfunction TableRow(props) {\n  return <tr {...props.attributes}>{props.children}</tr>;\n}\n\nfunction TableCell(props) {\n  return <StyledTd {...props.attributes}>{props.children}</StyledTd>;\n}\n\nfunction ThematicBreak(props) {\n  const isSelected = useSelected();\n  return (\n    <div {...props.attributes}>\n      {props.children}\n      <div contentEditable={false}>\n        <StyledHr\n          {...props.attributes}\n          css={\n            isSelected &&\n            css`\n              box-shadow: 0 0 0 2px ${colors.active};\n              border-radius: 8px;\n              color: ${colors.active};\n            `\n          }\n        />\n      </div>\n    </div>\n  );\n}\n\nfunction Break(props) {\n  return (\n    <>\n      <br {...props.attributes} />\n      {props.children}\n    </>\n  );\n}\n\nfunction BulletedList(props) {\n  return <StyledUl {...props.attributes}>{props.children}</StyledUl>;\n}\n\nfunction NumberedList(props) {\n  return (\n    <StyledOl {...props.attributes} start={1}>\n      {props.children}\n    </StyledOl>\n  );\n}\n\nfunction Link(props) {\n  const url = props.element.url;\n  const title = props.element.title || url;\n\n  return (\n    <StyledA href={url} title={title} {...props.attributes}>\n      {props.children}\n    </StyledA>\n  );\n}\n\nfunction Image(props) {\n  const { url, title, alt } = props.element.data;\n  const isSelected = useSelected();\n  return (\n    <span {...props.attributes}>\n      {props.children}\n      <img\n        src={url}\n        title={title}\n        alt={alt}\n        {...props.attributes}\n        css={\n          isSelected &&\n          css`\n            box-shadow: 0 0 0 2px ${colors.active};\n          `\n        }\n      />\n    </span>\n  );\n}\n\nexport function Leaf({ attributes, children, leaf }) {\n  if (leaf.bold) {\n    children = <Bold>{children}</Bold>;\n  }\n\n  if (leaf.italic) {\n    children = <Italic>{children}</Italic>;\n  }\n\n  if (leaf.delete) {\n    children = <Strikethrough>{children}</Strikethrough>;\n  }\n\n  if (leaf.code) {\n    children = <Code>{children}</Code>;\n  }\n\n  // if (leaf.break) {\n  //   children = <Break />;\n  // }\n\n  return <span {...attributes}>{children}</span>;\n}\n\nexport function renderInline__DEPRECATED() {\n  return props => {\n    switch (props.node.type) {\n      case 'link':\n        return <Link {...props} />;\n      case 'image':\n        return <Image {...props} />;\n      case 'break':\n        return <Break {...props} />;\n    }\n  };\n}\n\nexport function Element(props) {\n  const { children, element, classNameWrapper, codeBlockComponent } = props;\n  const style = { textAlign: element.align };\n\n  switch (element.type) {\n    case 'bulleted-list':\n      return <BulletedList>{children}</BulletedList>;\n    case 'quote':\n      return <Quote>{children}</Quote>;\n    case 'heading-one':\n      return <HeadingOne>{children}</HeadingOne>;\n    case 'heading-two':\n      return <HeadingTwo>{children}</HeadingTwo>;\n    case 'heading-three':\n      return <HeadingThree>{children}</HeadingThree>;\n    case 'heading-four':\n      return <HeadingFour>{children}</HeadingFour>;\n    case 'heading-five':\n      return <HeadingFive>{children}</HeadingFive>;\n    case 'heading-six':\n      return <HeadingSix>{children}</HeadingSix>;\n    case 'list-item':\n      return <ListItem>{children}</ListItem>;\n    case 'numbered-list':\n      return <NumberedList>{children}</NumberedList>;\n    case 'table':\n      return <Table {...props} />;\n    case 'table-row':\n      return <TableRow {...props} />;\n    case 'table-cell':\n      return <TableCell {...props} />;\n    case 'thematic-break':\n      return (\n        <VoidBlock {...props}>\n          <ThematicBreak {...props} />\n        </VoidBlock>\n      );\n    case 'link':\n      return <Link {...props} />;\n    case 'image':\n      return <Image {...props} />;\n    case 'break':\n      return <Break {...props} />;\n    case 'shortcode':\n      if (element.id === 'code-block' && codeBlockComponent) {\n        return (\n          <VoidBlock {...props}>\n            <Shortcode classNameWrapper={classNameWrapper} typeOverload=\"code-block\" {...props} />\n          </VoidBlock>\n        );\n      }\n      return (\n        <VoidBlock {...props}>\n          <Shortcode {...props}>{children}</Shortcode>\n        </VoidBlock>\n      );\n    default:\n      return <Paragraph style={style}>{children}</Paragraph>;\n  }\n}\n"]} */",
71
70
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
72
71
  });
73
72
  const StyledA = /*#__PURE__*/_styled("a", {
@@ -78,8 +77,7 @@ const StyledA = /*#__PURE__*/_styled("a", {
78
77
  styles: "text-decoration:underline;font-size:inherit"
79
78
  } : {
80
79
  name: "11z7vuy",
81
- styles: "text-decoration:underline;font-size:inherit",
82
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MarkdownControl/renderers.js"],"names":[],"mappings":"AAoFwB","file":"../../../src/MarkdownControl/renderers.js","sourcesContent":["/* eslint-disable react/display-name */\nimport React from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { colors, lengths } from 'decap-cms-ui-default';\nimport { useSelected } from 'slate-react';\n\nimport VoidBlock from './components/VoidBlock';\nimport Shortcode from './components/Shortcode';\n\nconst bottomMargin = '16px';\n\nconst headerStyles = `\n  font-weight: 700;\n  line-height: 1;\n`;\n\nconst StyledH1 = styled.h1`\n  ${headerStyles};\n  font-size: 32px;\n  margin-top: 16px;\n`;\n\nconst StyledH2 = styled.h2`\n  ${headerStyles};\n  font-size: 24px;\n  margin-top: 12px;\n`;\n\nconst StyledH3 = styled.h3`\n  ${headerStyles};\n  font-size: 20px;\n`;\n\nconst StyledH4 = styled.h4`\n  ${headerStyles};\n  font-size: 18px;\n  margin-top: 8px;\n`;\n\nconst StyledH5 = styled.h5`\n  ${headerStyles};\n  font-size: 16px;\n  margin-top: 8px;\n`;\n\nconst StyledH6 = StyledH5.withComponent('h6');\n\nconst StyledP = styled.p`\n  margin-bottom: ${bottomMargin};\n`;\n\nconst StyledBlockQuote = styled.blockquote`\n  padding-left: 16px;\n  border-left: 3px solid ${colors.background};\n  margin-left: 0;\n  margin-right: 0;\n  margin-bottom: ${bottomMargin};\n`;\n\nconst StyledCode = styled.code`\n  background-color: ${colors.background};\n  border-radius: ${lengths.borderRadius};\n  padding: 0 2px;\n  font-size: 85%;\n`;\n\nconst StyledUl = styled.ul`\n  margin-bottom: ${bottomMargin};\n  padding-left: 30px;\n`;\n\nconst StyledOl = StyledUl.withComponent('ol');\n\nconst StyledLi = styled.li`\n  & > p:first-of-type {\n    margin-top: 8px;\n  }\n\n  & > p:last-of-type {\n    margin-bottom: 8px;\n  }\n`;\n\nconst StyledA = styled.a`\n  text-decoration: underline;\n  font-size: inherit;\n`;\n\nconst StyledHr = styled.hr`\n  border: 1px solid;\n  margin-bottom: 16px;\n`;\n\nconst StyledTable = styled.table`\n  border-collapse: collapse;\n`;\n\nconst StyledTd = styled.td`\n  border: 2px solid black;\n  padding: 8px;\n  text-align: left;\n`;\n\n/**\n * Slate uses React components to render each type of node that it receives.\n * This is the closest thing Slate has to a schema definition. The types are set\n * by us when we manually deserialize from Remark's MDAST to Slate's AST.\n */\n\n/**\n * Mark Components\n */\nfunction Bold(props) {\n  return <strong>{props.children}</strong>;\n}\n\nfunction Italic(props) {\n  return <em>{props.children}</em>;\n}\n\nfunction Strikethrough(props) {\n  return <s>{props.children}</s>;\n}\n\nfunction Code(props) {\n  return <StyledCode>{props.children}</StyledCode>;\n}\n\n/**\n * Node Components\n */\nfunction Paragraph(props) {\n  return <StyledP {...props.attributes}>{props.children}</StyledP>;\n}\n\nfunction ListItem(props) {\n  return <StyledLi {...props.attributes}>{props.children}</StyledLi>;\n}\n\nfunction Quote(props) {\n  return <StyledBlockQuote {...props.attributes}>{props.children}</StyledBlockQuote>;\n}\n\nfunction HeadingOne(props) {\n  return <StyledH1 {...props.attributes}>{props.children}</StyledH1>;\n}\n\nfunction HeadingTwo(props) {\n  return <StyledH2 {...props.attributes}>{props.children}</StyledH2>;\n}\n\nfunction HeadingThree(props) {\n  return <StyledH3 {...props.attributes}>{props.children}</StyledH3>;\n}\n\nfunction HeadingFour(props) {\n  return <StyledH4 {...props.attributes}>{props.children}</StyledH4>;\n}\n\nfunction HeadingFive(props) {\n  return <StyledH5 {...props.attributes}>{props.children}</StyledH5>;\n}\n\nfunction HeadingSix(props) {\n  return <StyledH6 {...props.attributes}>{props.children}</StyledH6>;\n}\n\nfunction Table(props) {\n  return (\n    <StyledTable>\n      <tbody {...props.attributes}>{props.children}</tbody>\n    </StyledTable>\n  );\n}\n\nfunction TableRow(props) {\n  return <tr {...props.attributes}>{props.children}</tr>;\n}\n\nfunction TableCell(props) {\n  return <StyledTd {...props.attributes}>{props.children}</StyledTd>;\n}\n\nfunction ThematicBreak(props) {\n  const isSelected = useSelected();\n  return (\n    <div {...props.attributes}>\n      {props.children}\n      <div contentEditable={false}>\n        <StyledHr\n          {...props.attributes}\n          css={\n            isSelected &&\n            css`\n              box-shadow: 0 0 0 2px ${colors.active};\n              border-radius: 8px;\n              color: ${colors.active};\n            `\n          }\n        />\n      </div>\n    </div>\n  );\n}\n\nfunction Break(props) {\n  return (\n    <>\n      <br {...props.attributes} />\n      {props.children}\n    </>\n  );\n}\n\nfunction BulletedList(props) {\n  return <StyledUl {...props.attributes}>{props.children}</StyledUl>;\n}\n\nfunction NumberedList(props) {\n  return (\n    <StyledOl {...props.attributes} start={1}>\n      {props.children}\n    </StyledOl>\n  );\n}\n\nfunction Link(props) {\n  const url = props.element.url;\n  const title = props.element.title || url;\n\n  return (\n    <StyledA href={url} title={title} {...props.attributes}>\n      {props.children}\n    </StyledA>\n  );\n}\n\nfunction Image(props) {\n  const { url, title, alt } = props.element.data;\n  const isSelected = useSelected();\n  return (\n    <span {...props.attributes}>\n      {props.children}\n      <img\n        src={url}\n        title={title}\n        alt={alt}\n        {...props.attributes}\n        css={\n          isSelected &&\n          css`\n            box-shadow: 0 0 0 2px ${colors.active};\n          `\n        }\n      />\n    </span>\n  );\n}\n\nexport function Leaf({ attributes, children, leaf }) {\n  if (leaf.bold) {\n    children = <Bold>{children}</Bold>;\n  }\n\n  if (leaf.italic) {\n    children = <Italic>{children}</Italic>;\n  }\n\n  if (leaf.delete) {\n    children = <Strikethrough>{children}</Strikethrough>;\n  }\n\n  if (leaf.code) {\n    children = <Code>{children}</Code>;\n  }\n\n  // if (leaf.break) {\n  //   children = <Break />;\n  // }\n\n  return <span {...attributes}>{children}</span>;\n}\n\nexport function renderInline__DEPRECATED() {\n  return props => {\n    switch (props.node.type) {\n      case 'link':\n        return <Link {...props} />;\n      case 'image':\n        return <Image {...props} />;\n      case 'break':\n        return <Break {...props} />;\n    }\n  };\n}\n\nexport function Element(props) {\n  const { children, element, classNameWrapper, codeBlockComponent } = props;\n  const style = { textAlign: element.align };\n\n  switch (element.type) {\n    case 'bulleted-list':\n      return <BulletedList>{children}</BulletedList>;\n    case 'quote':\n      return <Quote>{children}</Quote>;\n    case 'heading-one':\n      return <HeadingOne>{children}</HeadingOne>;\n    case 'heading-two':\n      return <HeadingTwo>{children}</HeadingTwo>;\n    case 'heading-three':\n      return <HeadingThree>{children}</HeadingThree>;\n    case 'heading-four':\n      return <HeadingFour>{children}</HeadingFour>;\n    case 'heading-five':\n      return <HeadingFive>{children}</HeadingFive>;\n    case 'heading-six':\n      return <HeadingSix>{children}</HeadingSix>;\n    case 'list-item':\n      return <ListItem>{children}</ListItem>;\n    case 'numbered-list':\n      return <NumberedList>{children}</NumberedList>;\n    case 'table':\n      return <Table {...props} />;\n    case 'table-row':\n      return <TableRow {...props} />;\n    case 'table-cell':\n      return <TableCell {...props} />;\n    case 'thematic-break':\n      return (\n        <VoidBlock {...props}>\n          <ThematicBreak {...props} />\n        </VoidBlock>\n      );\n    case 'link':\n      return <Link {...props} />;\n    case 'image':\n      return <Image {...props} />;\n    case 'break':\n      return <Break {...props} />;\n    case 'shortcode':\n      if (element.id === 'code-block' && codeBlockComponent) {\n        return (\n          <VoidBlock {...props}>\n            <Shortcode classNameWrapper={classNameWrapper} typeOverload=\"code-block\" {...props} />\n          </VoidBlock>\n        );\n      }\n      return (\n        <VoidBlock {...props}>\n          <Shortcode {...props}>{children}</Shortcode>\n        </VoidBlock>\n      );\n    default:\n      return <Paragraph style={style}>{children}</Paragraph>;\n  }\n}\n"]} */",
80
+ styles: "text-decoration:underline;font-size:inherit/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MarkdownControl/renderers.js"],"names":[],"mappings":"AAoFwB","file":"../../../src/MarkdownControl/renderers.js","sourcesContent":["/* eslint-disable react/display-name */\nimport React from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { colors, lengths } from 'decap-cms-ui-default';\nimport { useSelected } from 'slate-react';\n\nimport VoidBlock from './components/VoidBlock';\nimport Shortcode from './components/Shortcode';\n\nconst bottomMargin = '16px';\n\nconst headerStyles = `\n  font-weight: 700;\n  line-height: 1;\n`;\n\nconst StyledH1 = styled.h1`\n  ${headerStyles};\n  font-size: 32px;\n  margin-top: 16px;\n`;\n\nconst StyledH2 = styled.h2`\n  ${headerStyles};\n  font-size: 24px;\n  margin-top: 12px;\n`;\n\nconst StyledH3 = styled.h3`\n  ${headerStyles};\n  font-size: 20px;\n`;\n\nconst StyledH4 = styled.h4`\n  ${headerStyles};\n  font-size: 18px;\n  margin-top: 8px;\n`;\n\nconst StyledH5 = styled.h5`\n  ${headerStyles};\n  font-size: 16px;\n  margin-top: 8px;\n`;\n\nconst StyledH6 = StyledH5.withComponent('h6');\n\nconst StyledP = styled.p`\n  margin-bottom: ${bottomMargin};\n`;\n\nconst StyledBlockQuote = styled.blockquote`\n  padding-left: 16px;\n  border-left: 3px solid ${colors.background};\n  margin-left: 0;\n  margin-right: 0;\n  margin-bottom: ${bottomMargin};\n`;\n\nconst StyledCode = styled.code`\n  background-color: ${colors.background};\n  border-radius: ${lengths.borderRadius};\n  padding: 0 2px;\n  font-size: 85%;\n`;\n\nconst StyledUl = styled.ul`\n  margin-bottom: ${bottomMargin};\n  padding-left: 30px;\n`;\n\nconst StyledOl = StyledUl.withComponent('ol');\n\nconst StyledLi = styled.li`\n  & > p:first-of-type {\n    margin-top: 8px;\n  }\n\n  & > p:last-of-type {\n    margin-bottom: 8px;\n  }\n`;\n\nconst StyledA = styled.a`\n  text-decoration: underline;\n  font-size: inherit;\n`;\n\nconst StyledHr = styled.hr`\n  border: 1px solid;\n  margin-bottom: 16px;\n`;\n\nconst StyledTable = styled.table`\n  border-collapse: collapse;\n`;\n\nconst StyledTd = styled.td`\n  border: 2px solid black;\n  padding: 8px;\n  text-align: left;\n`;\n\n/**\n * Slate uses React components to render each type of node that it receives.\n * This is the closest thing Slate has to a schema definition. The types are set\n * by us when we manually deserialize from Remark's MDAST to Slate's AST.\n */\n\n/**\n * Mark Components\n */\nfunction Bold(props) {\n  return <strong>{props.children}</strong>;\n}\n\nfunction Italic(props) {\n  return <em>{props.children}</em>;\n}\n\nfunction Strikethrough(props) {\n  return <s>{props.children}</s>;\n}\n\nfunction Code(props) {\n  return <StyledCode>{props.children}</StyledCode>;\n}\n\n/**\n * Node Components\n */\nfunction Paragraph(props) {\n  return <StyledP {...props.attributes}>{props.children}</StyledP>;\n}\n\nfunction ListItem(props) {\n  return <StyledLi {...props.attributes}>{props.children}</StyledLi>;\n}\n\nfunction Quote(props) {\n  return <StyledBlockQuote {...props.attributes}>{props.children}</StyledBlockQuote>;\n}\n\nfunction HeadingOne(props) {\n  return <StyledH1 {...props.attributes}>{props.children}</StyledH1>;\n}\n\nfunction HeadingTwo(props) {\n  return <StyledH2 {...props.attributes}>{props.children}</StyledH2>;\n}\n\nfunction HeadingThree(props) {\n  return <StyledH3 {...props.attributes}>{props.children}</StyledH3>;\n}\n\nfunction HeadingFour(props) {\n  return <StyledH4 {...props.attributes}>{props.children}</StyledH4>;\n}\n\nfunction HeadingFive(props) {\n  return <StyledH5 {...props.attributes}>{props.children}</StyledH5>;\n}\n\nfunction HeadingSix(props) {\n  return <StyledH6 {...props.attributes}>{props.children}</StyledH6>;\n}\n\nfunction Table(props) {\n  return (\n    <StyledTable>\n      <tbody {...props.attributes}>{props.children}</tbody>\n    </StyledTable>\n  );\n}\n\nfunction TableRow(props) {\n  return <tr {...props.attributes}>{props.children}</tr>;\n}\n\nfunction TableCell(props) {\n  return <StyledTd {...props.attributes}>{props.children}</StyledTd>;\n}\n\nfunction ThematicBreak(props) {\n  const isSelected = useSelected();\n  return (\n    <div {...props.attributes}>\n      {props.children}\n      <div contentEditable={false}>\n        <StyledHr\n          {...props.attributes}\n          css={\n            isSelected &&\n            css`\n              box-shadow: 0 0 0 2px ${colors.active};\n              border-radius: 8px;\n              color: ${colors.active};\n            `\n          }\n        />\n      </div>\n    </div>\n  );\n}\n\nfunction Break(props) {\n  return (\n    <>\n      <br {...props.attributes} />\n      {props.children}\n    </>\n  );\n}\n\nfunction BulletedList(props) {\n  return <StyledUl {...props.attributes}>{props.children}</StyledUl>;\n}\n\nfunction NumberedList(props) {\n  return (\n    <StyledOl {...props.attributes} start={1}>\n      {props.children}\n    </StyledOl>\n  );\n}\n\nfunction Link(props) {\n  const url = props.element.url;\n  const title = props.element.title || url;\n\n  return (\n    <StyledA href={url} title={title} {...props.attributes}>\n      {props.children}\n    </StyledA>\n  );\n}\n\nfunction Image(props) {\n  const { url, title, alt } = props.element.data;\n  const isSelected = useSelected();\n  return (\n    <span {...props.attributes}>\n      {props.children}\n      <img\n        src={url}\n        title={title}\n        alt={alt}\n        {...props.attributes}\n        css={\n          isSelected &&\n          css`\n            box-shadow: 0 0 0 2px ${colors.active};\n          `\n        }\n      />\n    </span>\n  );\n}\n\nexport function Leaf({ attributes, children, leaf }) {\n  if (leaf.bold) {\n    children = <Bold>{children}</Bold>;\n  }\n\n  if (leaf.italic) {\n    children = <Italic>{children}</Italic>;\n  }\n\n  if (leaf.delete) {\n    children = <Strikethrough>{children}</Strikethrough>;\n  }\n\n  if (leaf.code) {\n    children = <Code>{children}</Code>;\n  }\n\n  // if (leaf.break) {\n  //   children = <Break />;\n  // }\n\n  return <span {...attributes}>{children}</span>;\n}\n\nexport function renderInline__DEPRECATED() {\n  return props => {\n    switch (props.node.type) {\n      case 'link':\n        return <Link {...props} />;\n      case 'image':\n        return <Image {...props} />;\n      case 'break':\n        return <Break {...props} />;\n    }\n  };\n}\n\nexport function Element(props) {\n  const { children, element, classNameWrapper, codeBlockComponent } = props;\n  const style = { textAlign: element.align };\n\n  switch (element.type) {\n    case 'bulleted-list':\n      return <BulletedList>{children}</BulletedList>;\n    case 'quote':\n      return <Quote>{children}</Quote>;\n    case 'heading-one':\n      return <HeadingOne>{children}</HeadingOne>;\n    case 'heading-two':\n      return <HeadingTwo>{children}</HeadingTwo>;\n    case 'heading-three':\n      return <HeadingThree>{children}</HeadingThree>;\n    case 'heading-four':\n      return <HeadingFour>{children}</HeadingFour>;\n    case 'heading-five':\n      return <HeadingFive>{children}</HeadingFive>;\n    case 'heading-six':\n      return <HeadingSix>{children}</HeadingSix>;\n    case 'list-item':\n      return <ListItem>{children}</ListItem>;\n    case 'numbered-list':\n      return <NumberedList>{children}</NumberedList>;\n    case 'table':\n      return <Table {...props} />;\n    case 'table-row':\n      return <TableRow {...props} />;\n    case 'table-cell':\n      return <TableCell {...props} />;\n    case 'thematic-break':\n      return (\n        <VoidBlock {...props}>\n          <ThematicBreak {...props} />\n        </VoidBlock>\n      );\n    case 'link':\n      return <Link {...props} />;\n    case 'image':\n      return <Image {...props} />;\n    case 'break':\n      return <Break {...props} />;\n    case 'shortcode':\n      if (element.id === 'code-block' && codeBlockComponent) {\n        return (\n          <VoidBlock {...props}>\n            <Shortcode classNameWrapper={classNameWrapper} typeOverload=\"code-block\" {...props} />\n          </VoidBlock>\n        );\n      }\n      return (\n        <VoidBlock {...props}>\n          <Shortcode {...props}>{children}</Shortcode>\n        </VoidBlock>\n      );\n    default:\n      return <Paragraph style={style}>{children}</Paragraph>;\n  }\n}\n"]} */",
83
81
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
84
82
  });
85
83
  const StyledHr = /*#__PURE__*/_styled("hr", {
@@ -90,8 +88,7 @@ const StyledHr = /*#__PURE__*/_styled("hr", {
90
88
  styles: "border:1px solid;margin-bottom:16px"
91
89
  } : {
92
90
  name: "1y2p2hw",
93
- styles: "border:1px solid;margin-bottom:16px",
94
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MarkdownControl/renderers.js"],"names":[],"mappings":"AAyF0B","file":"../../../src/MarkdownControl/renderers.js","sourcesContent":["/* eslint-disable react/display-name */\nimport React from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { colors, lengths } from 'decap-cms-ui-default';\nimport { useSelected } from 'slate-react';\n\nimport VoidBlock from './components/VoidBlock';\nimport Shortcode from './components/Shortcode';\n\nconst bottomMargin = '16px';\n\nconst headerStyles = `\n  font-weight: 700;\n  line-height: 1;\n`;\n\nconst StyledH1 = styled.h1`\n  ${headerStyles};\n  font-size: 32px;\n  margin-top: 16px;\n`;\n\nconst StyledH2 = styled.h2`\n  ${headerStyles};\n  font-size: 24px;\n  margin-top: 12px;\n`;\n\nconst StyledH3 = styled.h3`\n  ${headerStyles};\n  font-size: 20px;\n`;\n\nconst StyledH4 = styled.h4`\n  ${headerStyles};\n  font-size: 18px;\n  margin-top: 8px;\n`;\n\nconst StyledH5 = styled.h5`\n  ${headerStyles};\n  font-size: 16px;\n  margin-top: 8px;\n`;\n\nconst StyledH6 = StyledH5.withComponent('h6');\n\nconst StyledP = styled.p`\n  margin-bottom: ${bottomMargin};\n`;\n\nconst StyledBlockQuote = styled.blockquote`\n  padding-left: 16px;\n  border-left: 3px solid ${colors.background};\n  margin-left: 0;\n  margin-right: 0;\n  margin-bottom: ${bottomMargin};\n`;\n\nconst StyledCode = styled.code`\n  background-color: ${colors.background};\n  border-radius: ${lengths.borderRadius};\n  padding: 0 2px;\n  font-size: 85%;\n`;\n\nconst StyledUl = styled.ul`\n  margin-bottom: ${bottomMargin};\n  padding-left: 30px;\n`;\n\nconst StyledOl = StyledUl.withComponent('ol');\n\nconst StyledLi = styled.li`\n  & > p:first-of-type {\n    margin-top: 8px;\n  }\n\n  & > p:last-of-type {\n    margin-bottom: 8px;\n  }\n`;\n\nconst StyledA = styled.a`\n  text-decoration: underline;\n  font-size: inherit;\n`;\n\nconst StyledHr = styled.hr`\n  border: 1px solid;\n  margin-bottom: 16px;\n`;\n\nconst StyledTable = styled.table`\n  border-collapse: collapse;\n`;\n\nconst StyledTd = styled.td`\n  border: 2px solid black;\n  padding: 8px;\n  text-align: left;\n`;\n\n/**\n * Slate uses React components to render each type of node that it receives.\n * This is the closest thing Slate has to a schema definition. The types are set\n * by us when we manually deserialize from Remark's MDAST to Slate's AST.\n */\n\n/**\n * Mark Components\n */\nfunction Bold(props) {\n  return <strong>{props.children}</strong>;\n}\n\nfunction Italic(props) {\n  return <em>{props.children}</em>;\n}\n\nfunction Strikethrough(props) {\n  return <s>{props.children}</s>;\n}\n\nfunction Code(props) {\n  return <StyledCode>{props.children}</StyledCode>;\n}\n\n/**\n * Node Components\n */\nfunction Paragraph(props) {\n  return <StyledP {...props.attributes}>{props.children}</StyledP>;\n}\n\nfunction ListItem(props) {\n  return <StyledLi {...props.attributes}>{props.children}</StyledLi>;\n}\n\nfunction Quote(props) {\n  return <StyledBlockQuote {...props.attributes}>{props.children}</StyledBlockQuote>;\n}\n\nfunction HeadingOne(props) {\n  return <StyledH1 {...props.attributes}>{props.children}</StyledH1>;\n}\n\nfunction HeadingTwo(props) {\n  return <StyledH2 {...props.attributes}>{props.children}</StyledH2>;\n}\n\nfunction HeadingThree(props) {\n  return <StyledH3 {...props.attributes}>{props.children}</StyledH3>;\n}\n\nfunction HeadingFour(props) {\n  return <StyledH4 {...props.attributes}>{props.children}</StyledH4>;\n}\n\nfunction HeadingFive(props) {\n  return <StyledH5 {...props.attributes}>{props.children}</StyledH5>;\n}\n\nfunction HeadingSix(props) {\n  return <StyledH6 {...props.attributes}>{props.children}</StyledH6>;\n}\n\nfunction Table(props) {\n  return (\n    <StyledTable>\n      <tbody {...props.attributes}>{props.children}</tbody>\n    </StyledTable>\n  );\n}\n\nfunction TableRow(props) {\n  return <tr {...props.attributes}>{props.children}</tr>;\n}\n\nfunction TableCell(props) {\n  return <StyledTd {...props.attributes}>{props.children}</StyledTd>;\n}\n\nfunction ThematicBreak(props) {\n  const isSelected = useSelected();\n  return (\n    <div {...props.attributes}>\n      {props.children}\n      <div contentEditable={false}>\n        <StyledHr\n          {...props.attributes}\n          css={\n            isSelected &&\n            css`\n              box-shadow: 0 0 0 2px ${colors.active};\n              border-radius: 8px;\n              color: ${colors.active};\n            `\n          }\n        />\n      </div>\n    </div>\n  );\n}\n\nfunction Break(props) {\n  return (\n    <>\n      <br {...props.attributes} />\n      {props.children}\n    </>\n  );\n}\n\nfunction BulletedList(props) {\n  return <StyledUl {...props.attributes}>{props.children}</StyledUl>;\n}\n\nfunction NumberedList(props) {\n  return (\n    <StyledOl {...props.attributes} start={1}>\n      {props.children}\n    </StyledOl>\n  );\n}\n\nfunction Link(props) {\n  const url = props.element.url;\n  const title = props.element.title || url;\n\n  return (\n    <StyledA href={url} title={title} {...props.attributes}>\n      {props.children}\n    </StyledA>\n  );\n}\n\nfunction Image(props) {\n  const { url, title, alt } = props.element.data;\n  const isSelected = useSelected();\n  return (\n    <span {...props.attributes}>\n      {props.children}\n      <img\n        src={url}\n        title={title}\n        alt={alt}\n        {...props.attributes}\n        css={\n          isSelected &&\n          css`\n            box-shadow: 0 0 0 2px ${colors.active};\n          `\n        }\n      />\n    </span>\n  );\n}\n\nexport function Leaf({ attributes, children, leaf }) {\n  if (leaf.bold) {\n    children = <Bold>{children}</Bold>;\n  }\n\n  if (leaf.italic) {\n    children = <Italic>{children}</Italic>;\n  }\n\n  if (leaf.delete) {\n    children = <Strikethrough>{children}</Strikethrough>;\n  }\n\n  if (leaf.code) {\n    children = <Code>{children}</Code>;\n  }\n\n  // if (leaf.break) {\n  //   children = <Break />;\n  // }\n\n  return <span {...attributes}>{children}</span>;\n}\n\nexport function renderInline__DEPRECATED() {\n  return props => {\n    switch (props.node.type) {\n      case 'link':\n        return <Link {...props} />;\n      case 'image':\n        return <Image {...props} />;\n      case 'break':\n        return <Break {...props} />;\n    }\n  };\n}\n\nexport function Element(props) {\n  const { children, element, classNameWrapper, codeBlockComponent } = props;\n  const style = { textAlign: element.align };\n\n  switch (element.type) {\n    case 'bulleted-list':\n      return <BulletedList>{children}</BulletedList>;\n    case 'quote':\n      return <Quote>{children}</Quote>;\n    case 'heading-one':\n      return <HeadingOne>{children}</HeadingOne>;\n    case 'heading-two':\n      return <HeadingTwo>{children}</HeadingTwo>;\n    case 'heading-three':\n      return <HeadingThree>{children}</HeadingThree>;\n    case 'heading-four':\n      return <HeadingFour>{children}</HeadingFour>;\n    case 'heading-five':\n      return <HeadingFive>{children}</HeadingFive>;\n    case 'heading-six':\n      return <HeadingSix>{children}</HeadingSix>;\n    case 'list-item':\n      return <ListItem>{children}</ListItem>;\n    case 'numbered-list':\n      return <NumberedList>{children}</NumberedList>;\n    case 'table':\n      return <Table {...props} />;\n    case 'table-row':\n      return <TableRow {...props} />;\n    case 'table-cell':\n      return <TableCell {...props} />;\n    case 'thematic-break':\n      return (\n        <VoidBlock {...props}>\n          <ThematicBreak {...props} />\n        </VoidBlock>\n      );\n    case 'link':\n      return <Link {...props} />;\n    case 'image':\n      return <Image {...props} />;\n    case 'break':\n      return <Break {...props} />;\n    case 'shortcode':\n      if (element.id === 'code-block' && codeBlockComponent) {\n        return (\n          <VoidBlock {...props}>\n            <Shortcode classNameWrapper={classNameWrapper} typeOverload=\"code-block\" {...props} />\n          </VoidBlock>\n        );\n      }\n      return (\n        <VoidBlock {...props}>\n          <Shortcode {...props}>{children}</Shortcode>\n        </VoidBlock>\n      );\n    default:\n      return <Paragraph style={style}>{children}</Paragraph>;\n  }\n}\n"]} */",
91
+ styles: "border:1px solid;margin-bottom:16px/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MarkdownControl/renderers.js"],"names":[],"mappings":"AAyF0B","file":"../../../src/MarkdownControl/renderers.js","sourcesContent":["/* eslint-disable react/display-name */\nimport React from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { colors, lengths } from 'decap-cms-ui-default';\nimport { useSelected } from 'slate-react';\n\nimport VoidBlock from './components/VoidBlock';\nimport Shortcode from './components/Shortcode';\n\nconst bottomMargin = '16px';\n\nconst headerStyles = `\n  font-weight: 700;\n  line-height: 1;\n`;\n\nconst StyledH1 = styled.h1`\n  ${headerStyles};\n  font-size: 32px;\n  margin-top: 16px;\n`;\n\nconst StyledH2 = styled.h2`\n  ${headerStyles};\n  font-size: 24px;\n  margin-top: 12px;\n`;\n\nconst StyledH3 = styled.h3`\n  ${headerStyles};\n  font-size: 20px;\n`;\n\nconst StyledH4 = styled.h4`\n  ${headerStyles};\n  font-size: 18px;\n  margin-top: 8px;\n`;\n\nconst StyledH5 = styled.h5`\n  ${headerStyles};\n  font-size: 16px;\n  margin-top: 8px;\n`;\n\nconst StyledH6 = StyledH5.withComponent('h6');\n\nconst StyledP = styled.p`\n  margin-bottom: ${bottomMargin};\n`;\n\nconst StyledBlockQuote = styled.blockquote`\n  padding-left: 16px;\n  border-left: 3px solid ${colors.background};\n  margin-left: 0;\n  margin-right: 0;\n  margin-bottom: ${bottomMargin};\n`;\n\nconst StyledCode = styled.code`\n  background-color: ${colors.background};\n  border-radius: ${lengths.borderRadius};\n  padding: 0 2px;\n  font-size: 85%;\n`;\n\nconst StyledUl = styled.ul`\n  margin-bottom: ${bottomMargin};\n  padding-left: 30px;\n`;\n\nconst StyledOl = StyledUl.withComponent('ol');\n\nconst StyledLi = styled.li`\n  & > p:first-of-type {\n    margin-top: 8px;\n  }\n\n  & > p:last-of-type {\n    margin-bottom: 8px;\n  }\n`;\n\nconst StyledA = styled.a`\n  text-decoration: underline;\n  font-size: inherit;\n`;\n\nconst StyledHr = styled.hr`\n  border: 1px solid;\n  margin-bottom: 16px;\n`;\n\nconst StyledTable = styled.table`\n  border-collapse: collapse;\n`;\n\nconst StyledTd = styled.td`\n  border: 2px solid black;\n  padding: 8px;\n  text-align: left;\n`;\n\n/**\n * Slate uses React components to render each type of node that it receives.\n * This is the closest thing Slate has to a schema definition. The types are set\n * by us when we manually deserialize from Remark's MDAST to Slate's AST.\n */\n\n/**\n * Mark Components\n */\nfunction Bold(props) {\n  return <strong>{props.children}</strong>;\n}\n\nfunction Italic(props) {\n  return <em>{props.children}</em>;\n}\n\nfunction Strikethrough(props) {\n  return <s>{props.children}</s>;\n}\n\nfunction Code(props) {\n  return <StyledCode>{props.children}</StyledCode>;\n}\n\n/**\n * Node Components\n */\nfunction Paragraph(props) {\n  return <StyledP {...props.attributes}>{props.children}</StyledP>;\n}\n\nfunction ListItem(props) {\n  return <StyledLi {...props.attributes}>{props.children}</StyledLi>;\n}\n\nfunction Quote(props) {\n  return <StyledBlockQuote {...props.attributes}>{props.children}</StyledBlockQuote>;\n}\n\nfunction HeadingOne(props) {\n  return <StyledH1 {...props.attributes}>{props.children}</StyledH1>;\n}\n\nfunction HeadingTwo(props) {\n  return <StyledH2 {...props.attributes}>{props.children}</StyledH2>;\n}\n\nfunction HeadingThree(props) {\n  return <StyledH3 {...props.attributes}>{props.children}</StyledH3>;\n}\n\nfunction HeadingFour(props) {\n  return <StyledH4 {...props.attributes}>{props.children}</StyledH4>;\n}\n\nfunction HeadingFive(props) {\n  return <StyledH5 {...props.attributes}>{props.children}</StyledH5>;\n}\n\nfunction HeadingSix(props) {\n  return <StyledH6 {...props.attributes}>{props.children}</StyledH6>;\n}\n\nfunction Table(props) {\n  return (\n    <StyledTable>\n      <tbody {...props.attributes}>{props.children}</tbody>\n    </StyledTable>\n  );\n}\n\nfunction TableRow(props) {\n  return <tr {...props.attributes}>{props.children}</tr>;\n}\n\nfunction TableCell(props) {\n  return <StyledTd {...props.attributes}>{props.children}</StyledTd>;\n}\n\nfunction ThematicBreak(props) {\n  const isSelected = useSelected();\n  return (\n    <div {...props.attributes}>\n      {props.children}\n      <div contentEditable={false}>\n        <StyledHr\n          {...props.attributes}\n          css={\n            isSelected &&\n            css`\n              box-shadow: 0 0 0 2px ${colors.active};\n              border-radius: 8px;\n              color: ${colors.active};\n            `\n          }\n        />\n      </div>\n    </div>\n  );\n}\n\nfunction Break(props) {\n  return (\n    <>\n      <br {...props.attributes} />\n      {props.children}\n    </>\n  );\n}\n\nfunction BulletedList(props) {\n  return <StyledUl {...props.attributes}>{props.children}</StyledUl>;\n}\n\nfunction NumberedList(props) {\n  return (\n    <StyledOl {...props.attributes} start={1}>\n      {props.children}\n    </StyledOl>\n  );\n}\n\nfunction Link(props) {\n  const url = props.element.url;\n  const title = props.element.title || url;\n\n  return (\n    <StyledA href={url} title={title} {...props.attributes}>\n      {props.children}\n    </StyledA>\n  );\n}\n\nfunction Image(props) {\n  const { url, title, alt } = props.element.data;\n  const isSelected = useSelected();\n  return (\n    <span {...props.attributes}>\n      {props.children}\n      <img\n        src={url}\n        title={title}\n        alt={alt}\n        {...props.attributes}\n        css={\n          isSelected &&\n          css`\n            box-shadow: 0 0 0 2px ${colors.active};\n          `\n        }\n      />\n    </span>\n  );\n}\n\nexport function Leaf({ attributes, children, leaf }) {\n  if (leaf.bold) {\n    children = <Bold>{children}</Bold>;\n  }\n\n  if (leaf.italic) {\n    children = <Italic>{children}</Italic>;\n  }\n\n  if (leaf.delete) {\n    children = <Strikethrough>{children}</Strikethrough>;\n  }\n\n  if (leaf.code) {\n    children = <Code>{children}</Code>;\n  }\n\n  // if (leaf.break) {\n  //   children = <Break />;\n  // }\n\n  return <span {...attributes}>{children}</span>;\n}\n\nexport function renderInline__DEPRECATED() {\n  return props => {\n    switch (props.node.type) {\n      case 'link':\n        return <Link {...props} />;\n      case 'image':\n        return <Image {...props} />;\n      case 'break':\n        return <Break {...props} />;\n    }\n  };\n}\n\nexport function Element(props) {\n  const { children, element, classNameWrapper, codeBlockComponent } = props;\n  const style = { textAlign: element.align };\n\n  switch (element.type) {\n    case 'bulleted-list':\n      return <BulletedList>{children}</BulletedList>;\n    case 'quote':\n      return <Quote>{children}</Quote>;\n    case 'heading-one':\n      return <HeadingOne>{children}</HeadingOne>;\n    case 'heading-two':\n      return <HeadingTwo>{children}</HeadingTwo>;\n    case 'heading-three':\n      return <HeadingThree>{children}</HeadingThree>;\n    case 'heading-four':\n      return <HeadingFour>{children}</HeadingFour>;\n    case 'heading-five':\n      return <HeadingFive>{children}</HeadingFive>;\n    case 'heading-six':\n      return <HeadingSix>{children}</HeadingSix>;\n    case 'list-item':\n      return <ListItem>{children}</ListItem>;\n    case 'numbered-list':\n      return <NumberedList>{children}</NumberedList>;\n    case 'table':\n      return <Table {...props} />;\n    case 'table-row':\n      return <TableRow {...props} />;\n    case 'table-cell':\n      return <TableCell {...props} />;\n    case 'thematic-break':\n      return (\n        <VoidBlock {...props}>\n          <ThematicBreak {...props} />\n        </VoidBlock>\n      );\n    case 'link':\n      return <Link {...props} />;\n    case 'image':\n      return <Image {...props} />;\n    case 'break':\n      return <Break {...props} />;\n    case 'shortcode':\n      if (element.id === 'code-block' && codeBlockComponent) {\n        return (\n          <VoidBlock {...props}>\n            <Shortcode classNameWrapper={classNameWrapper} typeOverload=\"code-block\" {...props} />\n          </VoidBlock>\n        );\n      }\n      return (\n        <VoidBlock {...props}>\n          <Shortcode {...props}>{children}</Shortcode>\n        </VoidBlock>\n      );\n    default:\n      return <Paragraph style={style}>{children}</Paragraph>;\n  }\n}\n"]} */",
95
92
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
96
93
  });
97
94
  const StyledTable = /*#__PURE__*/_styled("table", {
@@ -102,8 +99,7 @@ const StyledTable = /*#__PURE__*/_styled("table", {
102
99
  styles: "border-collapse:collapse"
103
100
  } : {
104
101
  name: "tkxk5i",
105
- styles: "border-collapse:collapse",
106
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MarkdownControl/renderers.js"],"names":[],"mappings":"AA8FgC","file":"../../../src/MarkdownControl/renderers.js","sourcesContent":["/* eslint-disable react/display-name */\nimport React from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { colors, lengths } from 'decap-cms-ui-default';\nimport { useSelected } from 'slate-react';\n\nimport VoidBlock from './components/VoidBlock';\nimport Shortcode from './components/Shortcode';\n\nconst bottomMargin = '16px';\n\nconst headerStyles = `\n  font-weight: 700;\n  line-height: 1;\n`;\n\nconst StyledH1 = styled.h1`\n  ${headerStyles};\n  font-size: 32px;\n  margin-top: 16px;\n`;\n\nconst StyledH2 = styled.h2`\n  ${headerStyles};\n  font-size: 24px;\n  margin-top: 12px;\n`;\n\nconst StyledH3 = styled.h3`\n  ${headerStyles};\n  font-size: 20px;\n`;\n\nconst StyledH4 = styled.h4`\n  ${headerStyles};\n  font-size: 18px;\n  margin-top: 8px;\n`;\n\nconst StyledH5 = styled.h5`\n  ${headerStyles};\n  font-size: 16px;\n  margin-top: 8px;\n`;\n\nconst StyledH6 = StyledH5.withComponent('h6');\n\nconst StyledP = styled.p`\n  margin-bottom: ${bottomMargin};\n`;\n\nconst StyledBlockQuote = styled.blockquote`\n  padding-left: 16px;\n  border-left: 3px solid ${colors.background};\n  margin-left: 0;\n  margin-right: 0;\n  margin-bottom: ${bottomMargin};\n`;\n\nconst StyledCode = styled.code`\n  background-color: ${colors.background};\n  border-radius: ${lengths.borderRadius};\n  padding: 0 2px;\n  font-size: 85%;\n`;\n\nconst StyledUl = styled.ul`\n  margin-bottom: ${bottomMargin};\n  padding-left: 30px;\n`;\n\nconst StyledOl = StyledUl.withComponent('ol');\n\nconst StyledLi = styled.li`\n  & > p:first-of-type {\n    margin-top: 8px;\n  }\n\n  & > p:last-of-type {\n    margin-bottom: 8px;\n  }\n`;\n\nconst StyledA = styled.a`\n  text-decoration: underline;\n  font-size: inherit;\n`;\n\nconst StyledHr = styled.hr`\n  border: 1px solid;\n  margin-bottom: 16px;\n`;\n\nconst StyledTable = styled.table`\n  border-collapse: collapse;\n`;\n\nconst StyledTd = styled.td`\n  border: 2px solid black;\n  padding: 8px;\n  text-align: left;\n`;\n\n/**\n * Slate uses React components to render each type of node that it receives.\n * This is the closest thing Slate has to a schema definition. The types are set\n * by us when we manually deserialize from Remark's MDAST to Slate's AST.\n */\n\n/**\n * Mark Components\n */\nfunction Bold(props) {\n  return <strong>{props.children}</strong>;\n}\n\nfunction Italic(props) {\n  return <em>{props.children}</em>;\n}\n\nfunction Strikethrough(props) {\n  return <s>{props.children}</s>;\n}\n\nfunction Code(props) {\n  return <StyledCode>{props.children}</StyledCode>;\n}\n\n/**\n * Node Components\n */\nfunction Paragraph(props) {\n  return <StyledP {...props.attributes}>{props.children}</StyledP>;\n}\n\nfunction ListItem(props) {\n  return <StyledLi {...props.attributes}>{props.children}</StyledLi>;\n}\n\nfunction Quote(props) {\n  return <StyledBlockQuote {...props.attributes}>{props.children}</StyledBlockQuote>;\n}\n\nfunction HeadingOne(props) {\n  return <StyledH1 {...props.attributes}>{props.children}</StyledH1>;\n}\n\nfunction HeadingTwo(props) {\n  return <StyledH2 {...props.attributes}>{props.children}</StyledH2>;\n}\n\nfunction HeadingThree(props) {\n  return <StyledH3 {...props.attributes}>{props.children}</StyledH3>;\n}\n\nfunction HeadingFour(props) {\n  return <StyledH4 {...props.attributes}>{props.children}</StyledH4>;\n}\n\nfunction HeadingFive(props) {\n  return <StyledH5 {...props.attributes}>{props.children}</StyledH5>;\n}\n\nfunction HeadingSix(props) {\n  return <StyledH6 {...props.attributes}>{props.children}</StyledH6>;\n}\n\nfunction Table(props) {\n  return (\n    <StyledTable>\n      <tbody {...props.attributes}>{props.children}</tbody>\n    </StyledTable>\n  );\n}\n\nfunction TableRow(props) {\n  return <tr {...props.attributes}>{props.children}</tr>;\n}\n\nfunction TableCell(props) {\n  return <StyledTd {...props.attributes}>{props.children}</StyledTd>;\n}\n\nfunction ThematicBreak(props) {\n  const isSelected = useSelected();\n  return (\n    <div {...props.attributes}>\n      {props.children}\n      <div contentEditable={false}>\n        <StyledHr\n          {...props.attributes}\n          css={\n            isSelected &&\n            css`\n              box-shadow: 0 0 0 2px ${colors.active};\n              border-radius: 8px;\n              color: ${colors.active};\n            `\n          }\n        />\n      </div>\n    </div>\n  );\n}\n\nfunction Break(props) {\n  return (\n    <>\n      <br {...props.attributes} />\n      {props.children}\n    </>\n  );\n}\n\nfunction BulletedList(props) {\n  return <StyledUl {...props.attributes}>{props.children}</StyledUl>;\n}\n\nfunction NumberedList(props) {\n  return (\n    <StyledOl {...props.attributes} start={1}>\n      {props.children}\n    </StyledOl>\n  );\n}\n\nfunction Link(props) {\n  const url = props.element.url;\n  const title = props.element.title || url;\n\n  return (\n    <StyledA href={url} title={title} {...props.attributes}>\n      {props.children}\n    </StyledA>\n  );\n}\n\nfunction Image(props) {\n  const { url, title, alt } = props.element.data;\n  const isSelected = useSelected();\n  return (\n    <span {...props.attributes}>\n      {props.children}\n      <img\n        src={url}\n        title={title}\n        alt={alt}\n        {...props.attributes}\n        css={\n          isSelected &&\n          css`\n            box-shadow: 0 0 0 2px ${colors.active};\n          `\n        }\n      />\n    </span>\n  );\n}\n\nexport function Leaf({ attributes, children, leaf }) {\n  if (leaf.bold) {\n    children = <Bold>{children}</Bold>;\n  }\n\n  if (leaf.italic) {\n    children = <Italic>{children}</Italic>;\n  }\n\n  if (leaf.delete) {\n    children = <Strikethrough>{children}</Strikethrough>;\n  }\n\n  if (leaf.code) {\n    children = <Code>{children}</Code>;\n  }\n\n  // if (leaf.break) {\n  //   children = <Break />;\n  // }\n\n  return <span {...attributes}>{children}</span>;\n}\n\nexport function renderInline__DEPRECATED() {\n  return props => {\n    switch (props.node.type) {\n      case 'link':\n        return <Link {...props} />;\n      case 'image':\n        return <Image {...props} />;\n      case 'break':\n        return <Break {...props} />;\n    }\n  };\n}\n\nexport function Element(props) {\n  const { children, element, classNameWrapper, codeBlockComponent } = props;\n  const style = { textAlign: element.align };\n\n  switch (element.type) {\n    case 'bulleted-list':\n      return <BulletedList>{children}</BulletedList>;\n    case 'quote':\n      return <Quote>{children}</Quote>;\n    case 'heading-one':\n      return <HeadingOne>{children}</HeadingOne>;\n    case 'heading-two':\n      return <HeadingTwo>{children}</HeadingTwo>;\n    case 'heading-three':\n      return <HeadingThree>{children}</HeadingThree>;\n    case 'heading-four':\n      return <HeadingFour>{children}</HeadingFour>;\n    case 'heading-five':\n      return <HeadingFive>{children}</HeadingFive>;\n    case 'heading-six':\n      return <HeadingSix>{children}</HeadingSix>;\n    case 'list-item':\n      return <ListItem>{children}</ListItem>;\n    case 'numbered-list':\n      return <NumberedList>{children}</NumberedList>;\n    case 'table':\n      return <Table {...props} />;\n    case 'table-row':\n      return <TableRow {...props} />;\n    case 'table-cell':\n      return <TableCell {...props} />;\n    case 'thematic-break':\n      return (\n        <VoidBlock {...props}>\n          <ThematicBreak {...props} />\n        </VoidBlock>\n      );\n    case 'link':\n      return <Link {...props} />;\n    case 'image':\n      return <Image {...props} />;\n    case 'break':\n      return <Break {...props} />;\n    case 'shortcode':\n      if (element.id === 'code-block' && codeBlockComponent) {\n        return (\n          <VoidBlock {...props}>\n            <Shortcode classNameWrapper={classNameWrapper} typeOverload=\"code-block\" {...props} />\n          </VoidBlock>\n        );\n      }\n      return (\n        <VoidBlock {...props}>\n          <Shortcode {...props}>{children}</Shortcode>\n        </VoidBlock>\n      );\n    default:\n      return <Paragraph style={style}>{children}</Paragraph>;\n  }\n}\n"]} */",
102
+ styles: "border-collapse:collapse/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MarkdownControl/renderers.js"],"names":[],"mappings":"AA8FgC","file":"../../../src/MarkdownControl/renderers.js","sourcesContent":["/* eslint-disable react/display-name */\nimport React from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { colors, lengths } from 'decap-cms-ui-default';\nimport { useSelected } from 'slate-react';\n\nimport VoidBlock from './components/VoidBlock';\nimport Shortcode from './components/Shortcode';\n\nconst bottomMargin = '16px';\n\nconst headerStyles = `\n  font-weight: 700;\n  line-height: 1;\n`;\n\nconst StyledH1 = styled.h1`\n  ${headerStyles};\n  font-size: 32px;\n  margin-top: 16px;\n`;\n\nconst StyledH2 = styled.h2`\n  ${headerStyles};\n  font-size: 24px;\n  margin-top: 12px;\n`;\n\nconst StyledH3 = styled.h3`\n  ${headerStyles};\n  font-size: 20px;\n`;\n\nconst StyledH4 = styled.h4`\n  ${headerStyles};\n  font-size: 18px;\n  margin-top: 8px;\n`;\n\nconst StyledH5 = styled.h5`\n  ${headerStyles};\n  font-size: 16px;\n  margin-top: 8px;\n`;\n\nconst StyledH6 = StyledH5.withComponent('h6');\n\nconst StyledP = styled.p`\n  margin-bottom: ${bottomMargin};\n`;\n\nconst StyledBlockQuote = styled.blockquote`\n  padding-left: 16px;\n  border-left: 3px solid ${colors.background};\n  margin-left: 0;\n  margin-right: 0;\n  margin-bottom: ${bottomMargin};\n`;\n\nconst StyledCode = styled.code`\n  background-color: ${colors.background};\n  border-radius: ${lengths.borderRadius};\n  padding: 0 2px;\n  font-size: 85%;\n`;\n\nconst StyledUl = styled.ul`\n  margin-bottom: ${bottomMargin};\n  padding-left: 30px;\n`;\n\nconst StyledOl = StyledUl.withComponent('ol');\n\nconst StyledLi = styled.li`\n  & > p:first-of-type {\n    margin-top: 8px;\n  }\n\n  & > p:last-of-type {\n    margin-bottom: 8px;\n  }\n`;\n\nconst StyledA = styled.a`\n  text-decoration: underline;\n  font-size: inherit;\n`;\n\nconst StyledHr = styled.hr`\n  border: 1px solid;\n  margin-bottom: 16px;\n`;\n\nconst StyledTable = styled.table`\n  border-collapse: collapse;\n`;\n\nconst StyledTd = styled.td`\n  border: 2px solid black;\n  padding: 8px;\n  text-align: left;\n`;\n\n/**\n * Slate uses React components to render each type of node that it receives.\n * This is the closest thing Slate has to a schema definition. The types are set\n * by us when we manually deserialize from Remark's MDAST to Slate's AST.\n */\n\n/**\n * Mark Components\n */\nfunction Bold(props) {\n  return <strong>{props.children}</strong>;\n}\n\nfunction Italic(props) {\n  return <em>{props.children}</em>;\n}\n\nfunction Strikethrough(props) {\n  return <s>{props.children}</s>;\n}\n\nfunction Code(props) {\n  return <StyledCode>{props.children}</StyledCode>;\n}\n\n/**\n * Node Components\n */\nfunction Paragraph(props) {\n  return <StyledP {...props.attributes}>{props.children}</StyledP>;\n}\n\nfunction ListItem(props) {\n  return <StyledLi {...props.attributes}>{props.children}</StyledLi>;\n}\n\nfunction Quote(props) {\n  return <StyledBlockQuote {...props.attributes}>{props.children}</StyledBlockQuote>;\n}\n\nfunction HeadingOne(props) {\n  return <StyledH1 {...props.attributes}>{props.children}</StyledH1>;\n}\n\nfunction HeadingTwo(props) {\n  return <StyledH2 {...props.attributes}>{props.children}</StyledH2>;\n}\n\nfunction HeadingThree(props) {\n  return <StyledH3 {...props.attributes}>{props.children}</StyledH3>;\n}\n\nfunction HeadingFour(props) {\n  return <StyledH4 {...props.attributes}>{props.children}</StyledH4>;\n}\n\nfunction HeadingFive(props) {\n  return <StyledH5 {...props.attributes}>{props.children}</StyledH5>;\n}\n\nfunction HeadingSix(props) {\n  return <StyledH6 {...props.attributes}>{props.children}</StyledH6>;\n}\n\nfunction Table(props) {\n  return (\n    <StyledTable>\n      <tbody {...props.attributes}>{props.children}</tbody>\n    </StyledTable>\n  );\n}\n\nfunction TableRow(props) {\n  return <tr {...props.attributes}>{props.children}</tr>;\n}\n\nfunction TableCell(props) {\n  return <StyledTd {...props.attributes}>{props.children}</StyledTd>;\n}\n\nfunction ThematicBreak(props) {\n  const isSelected = useSelected();\n  return (\n    <div {...props.attributes}>\n      {props.children}\n      <div contentEditable={false}>\n        <StyledHr\n          {...props.attributes}\n          css={\n            isSelected &&\n            css`\n              box-shadow: 0 0 0 2px ${colors.active};\n              border-radius: 8px;\n              color: ${colors.active};\n            `\n          }\n        />\n      </div>\n    </div>\n  );\n}\n\nfunction Break(props) {\n  return (\n    <>\n      <br {...props.attributes} />\n      {props.children}\n    </>\n  );\n}\n\nfunction BulletedList(props) {\n  return <StyledUl {...props.attributes}>{props.children}</StyledUl>;\n}\n\nfunction NumberedList(props) {\n  return (\n    <StyledOl {...props.attributes} start={1}>\n      {props.children}\n    </StyledOl>\n  );\n}\n\nfunction Link(props) {\n  const url = props.element.url;\n  const title = props.element.title || url;\n\n  return (\n    <StyledA href={url} title={title} {...props.attributes}>\n      {props.children}\n    </StyledA>\n  );\n}\n\nfunction Image(props) {\n  const { url, title, alt } = props.element.data;\n  const isSelected = useSelected();\n  return (\n    <span {...props.attributes}>\n      {props.children}\n      <img\n        src={url}\n        title={title}\n        alt={alt}\n        {...props.attributes}\n        css={\n          isSelected &&\n          css`\n            box-shadow: 0 0 0 2px ${colors.active};\n          `\n        }\n      />\n    </span>\n  );\n}\n\nexport function Leaf({ attributes, children, leaf }) {\n  if (leaf.bold) {\n    children = <Bold>{children}</Bold>;\n  }\n\n  if (leaf.italic) {\n    children = <Italic>{children}</Italic>;\n  }\n\n  if (leaf.delete) {\n    children = <Strikethrough>{children}</Strikethrough>;\n  }\n\n  if (leaf.code) {\n    children = <Code>{children}</Code>;\n  }\n\n  // if (leaf.break) {\n  //   children = <Break />;\n  // }\n\n  return <span {...attributes}>{children}</span>;\n}\n\nexport function renderInline__DEPRECATED() {\n  return props => {\n    switch (props.node.type) {\n      case 'link':\n        return <Link {...props} />;\n      case 'image':\n        return <Image {...props} />;\n      case 'break':\n        return <Break {...props} />;\n    }\n  };\n}\n\nexport function Element(props) {\n  const { children, element, classNameWrapper, codeBlockComponent } = props;\n  const style = { textAlign: element.align };\n\n  switch (element.type) {\n    case 'bulleted-list':\n      return <BulletedList>{children}</BulletedList>;\n    case 'quote':\n      return <Quote>{children}</Quote>;\n    case 'heading-one':\n      return <HeadingOne>{children}</HeadingOne>;\n    case 'heading-two':\n      return <HeadingTwo>{children}</HeadingTwo>;\n    case 'heading-three':\n      return <HeadingThree>{children}</HeadingThree>;\n    case 'heading-four':\n      return <HeadingFour>{children}</HeadingFour>;\n    case 'heading-five':\n      return <HeadingFive>{children}</HeadingFive>;\n    case 'heading-six':\n      return <HeadingSix>{children}</HeadingSix>;\n    case 'list-item':\n      return <ListItem>{children}</ListItem>;\n    case 'numbered-list':\n      return <NumberedList>{children}</NumberedList>;\n    case 'table':\n      return <Table {...props} />;\n    case 'table-row':\n      return <TableRow {...props} />;\n    case 'table-cell':\n      return <TableCell {...props} />;\n    case 'thematic-break':\n      return (\n        <VoidBlock {...props}>\n          <ThematicBreak {...props} />\n        </VoidBlock>\n      );\n    case 'link':\n      return <Link {...props} />;\n    case 'image':\n      return <Image {...props} />;\n    case 'break':\n      return <Break {...props} />;\n    case 'shortcode':\n      if (element.id === 'code-block' && codeBlockComponent) {\n        return (\n          <VoidBlock {...props}>\n            <Shortcode classNameWrapper={classNameWrapper} typeOverload=\"code-block\" {...props} />\n          </VoidBlock>\n        );\n      }\n      return (\n        <VoidBlock {...props}>\n          <Shortcode {...props}>{children}</Shortcode>\n        </VoidBlock>\n      );\n    default:\n      return <Paragraph style={style}>{children}</Paragraph>;\n  }\n}\n"]} */",
107
103
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
108
104
  });
109
105
  const StyledTd = /*#__PURE__*/_styled("td", {
@@ -114,8 +110,7 @@ const StyledTd = /*#__PURE__*/_styled("td", {
114
110
  styles: "border:2px solid black;padding:8px;text-align:left"
115
111
  } : {
116
112
  name: "zsehaa",
117
- styles: "border:2px solid black;padding:8px;text-align:left",
118
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MarkdownControl/renderers.js"],"names":[],"mappings":"AAkG0B","file":"../../../src/MarkdownControl/renderers.js","sourcesContent":["/* eslint-disable react/display-name */\nimport React from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { colors, lengths } from 'decap-cms-ui-default';\nimport { useSelected } from 'slate-react';\n\nimport VoidBlock from './components/VoidBlock';\nimport Shortcode from './components/Shortcode';\n\nconst bottomMargin = '16px';\n\nconst headerStyles = `\n  font-weight: 700;\n  line-height: 1;\n`;\n\nconst StyledH1 = styled.h1`\n  ${headerStyles};\n  font-size: 32px;\n  margin-top: 16px;\n`;\n\nconst StyledH2 = styled.h2`\n  ${headerStyles};\n  font-size: 24px;\n  margin-top: 12px;\n`;\n\nconst StyledH3 = styled.h3`\n  ${headerStyles};\n  font-size: 20px;\n`;\n\nconst StyledH4 = styled.h4`\n  ${headerStyles};\n  font-size: 18px;\n  margin-top: 8px;\n`;\n\nconst StyledH5 = styled.h5`\n  ${headerStyles};\n  font-size: 16px;\n  margin-top: 8px;\n`;\n\nconst StyledH6 = StyledH5.withComponent('h6');\n\nconst StyledP = styled.p`\n  margin-bottom: ${bottomMargin};\n`;\n\nconst StyledBlockQuote = styled.blockquote`\n  padding-left: 16px;\n  border-left: 3px solid ${colors.background};\n  margin-left: 0;\n  margin-right: 0;\n  margin-bottom: ${bottomMargin};\n`;\n\nconst StyledCode = styled.code`\n  background-color: ${colors.background};\n  border-radius: ${lengths.borderRadius};\n  padding: 0 2px;\n  font-size: 85%;\n`;\n\nconst StyledUl = styled.ul`\n  margin-bottom: ${bottomMargin};\n  padding-left: 30px;\n`;\n\nconst StyledOl = StyledUl.withComponent('ol');\n\nconst StyledLi = styled.li`\n  & > p:first-of-type {\n    margin-top: 8px;\n  }\n\n  & > p:last-of-type {\n    margin-bottom: 8px;\n  }\n`;\n\nconst StyledA = styled.a`\n  text-decoration: underline;\n  font-size: inherit;\n`;\n\nconst StyledHr = styled.hr`\n  border: 1px solid;\n  margin-bottom: 16px;\n`;\n\nconst StyledTable = styled.table`\n  border-collapse: collapse;\n`;\n\nconst StyledTd = styled.td`\n  border: 2px solid black;\n  padding: 8px;\n  text-align: left;\n`;\n\n/**\n * Slate uses React components to render each type of node that it receives.\n * This is the closest thing Slate has to a schema definition. The types are set\n * by us when we manually deserialize from Remark's MDAST to Slate's AST.\n */\n\n/**\n * Mark Components\n */\nfunction Bold(props) {\n  return <strong>{props.children}</strong>;\n}\n\nfunction Italic(props) {\n  return <em>{props.children}</em>;\n}\n\nfunction Strikethrough(props) {\n  return <s>{props.children}</s>;\n}\n\nfunction Code(props) {\n  return <StyledCode>{props.children}</StyledCode>;\n}\n\n/**\n * Node Components\n */\nfunction Paragraph(props) {\n  return <StyledP {...props.attributes}>{props.children}</StyledP>;\n}\n\nfunction ListItem(props) {\n  return <StyledLi {...props.attributes}>{props.children}</StyledLi>;\n}\n\nfunction Quote(props) {\n  return <StyledBlockQuote {...props.attributes}>{props.children}</StyledBlockQuote>;\n}\n\nfunction HeadingOne(props) {\n  return <StyledH1 {...props.attributes}>{props.children}</StyledH1>;\n}\n\nfunction HeadingTwo(props) {\n  return <StyledH2 {...props.attributes}>{props.children}</StyledH2>;\n}\n\nfunction HeadingThree(props) {\n  return <StyledH3 {...props.attributes}>{props.children}</StyledH3>;\n}\n\nfunction HeadingFour(props) {\n  return <StyledH4 {...props.attributes}>{props.children}</StyledH4>;\n}\n\nfunction HeadingFive(props) {\n  return <StyledH5 {...props.attributes}>{props.children}</StyledH5>;\n}\n\nfunction HeadingSix(props) {\n  return <StyledH6 {...props.attributes}>{props.children}</StyledH6>;\n}\n\nfunction Table(props) {\n  return (\n    <StyledTable>\n      <tbody {...props.attributes}>{props.children}</tbody>\n    </StyledTable>\n  );\n}\n\nfunction TableRow(props) {\n  return <tr {...props.attributes}>{props.children}</tr>;\n}\n\nfunction TableCell(props) {\n  return <StyledTd {...props.attributes}>{props.children}</StyledTd>;\n}\n\nfunction ThematicBreak(props) {\n  const isSelected = useSelected();\n  return (\n    <div {...props.attributes}>\n      {props.children}\n      <div contentEditable={false}>\n        <StyledHr\n          {...props.attributes}\n          css={\n            isSelected &&\n            css`\n              box-shadow: 0 0 0 2px ${colors.active};\n              border-radius: 8px;\n              color: ${colors.active};\n            `\n          }\n        />\n      </div>\n    </div>\n  );\n}\n\nfunction Break(props) {\n  return (\n    <>\n      <br {...props.attributes} />\n      {props.children}\n    </>\n  );\n}\n\nfunction BulletedList(props) {\n  return <StyledUl {...props.attributes}>{props.children}</StyledUl>;\n}\n\nfunction NumberedList(props) {\n  return (\n    <StyledOl {...props.attributes} start={1}>\n      {props.children}\n    </StyledOl>\n  );\n}\n\nfunction Link(props) {\n  const url = props.element.url;\n  const title = props.element.title || url;\n\n  return (\n    <StyledA href={url} title={title} {...props.attributes}>\n      {props.children}\n    </StyledA>\n  );\n}\n\nfunction Image(props) {\n  const { url, title, alt } = props.element.data;\n  const isSelected = useSelected();\n  return (\n    <span {...props.attributes}>\n      {props.children}\n      <img\n        src={url}\n        title={title}\n        alt={alt}\n        {...props.attributes}\n        css={\n          isSelected &&\n          css`\n            box-shadow: 0 0 0 2px ${colors.active};\n          `\n        }\n      />\n    </span>\n  );\n}\n\nexport function Leaf({ attributes, children, leaf }) {\n  if (leaf.bold) {\n    children = <Bold>{children}</Bold>;\n  }\n\n  if (leaf.italic) {\n    children = <Italic>{children}</Italic>;\n  }\n\n  if (leaf.delete) {\n    children = <Strikethrough>{children}</Strikethrough>;\n  }\n\n  if (leaf.code) {\n    children = <Code>{children}</Code>;\n  }\n\n  // if (leaf.break) {\n  //   children = <Break />;\n  // }\n\n  return <span {...attributes}>{children}</span>;\n}\n\nexport function renderInline__DEPRECATED() {\n  return props => {\n    switch (props.node.type) {\n      case 'link':\n        return <Link {...props} />;\n      case 'image':\n        return <Image {...props} />;\n      case 'break':\n        return <Break {...props} />;\n    }\n  };\n}\n\nexport function Element(props) {\n  const { children, element, classNameWrapper, codeBlockComponent } = props;\n  const style = { textAlign: element.align };\n\n  switch (element.type) {\n    case 'bulleted-list':\n      return <BulletedList>{children}</BulletedList>;\n    case 'quote':\n      return <Quote>{children}</Quote>;\n    case 'heading-one':\n      return <HeadingOne>{children}</HeadingOne>;\n    case 'heading-two':\n      return <HeadingTwo>{children}</HeadingTwo>;\n    case 'heading-three':\n      return <HeadingThree>{children}</HeadingThree>;\n    case 'heading-four':\n      return <HeadingFour>{children}</HeadingFour>;\n    case 'heading-five':\n      return <HeadingFive>{children}</HeadingFive>;\n    case 'heading-six':\n      return <HeadingSix>{children}</HeadingSix>;\n    case 'list-item':\n      return <ListItem>{children}</ListItem>;\n    case 'numbered-list':\n      return <NumberedList>{children}</NumberedList>;\n    case 'table':\n      return <Table {...props} />;\n    case 'table-row':\n      return <TableRow {...props} />;\n    case 'table-cell':\n      return <TableCell {...props} />;\n    case 'thematic-break':\n      return (\n        <VoidBlock {...props}>\n          <ThematicBreak {...props} />\n        </VoidBlock>\n      );\n    case 'link':\n      return <Link {...props} />;\n    case 'image':\n      return <Image {...props} />;\n    case 'break':\n      return <Break {...props} />;\n    case 'shortcode':\n      if (element.id === 'code-block' && codeBlockComponent) {\n        return (\n          <VoidBlock {...props}>\n            <Shortcode classNameWrapper={classNameWrapper} typeOverload=\"code-block\" {...props} />\n          </VoidBlock>\n        );\n      }\n      return (\n        <VoidBlock {...props}>\n          <Shortcode {...props}>{children}</Shortcode>\n        </VoidBlock>\n      );\n    default:\n      return <Paragraph style={style}>{children}</Paragraph>;\n  }\n}\n"]} */",
113
+ styles: "border:2px solid black;padding:8px;text-align:left/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MarkdownControl/renderers.js"],"names":[],"mappings":"AAkG0B","file":"../../../src/MarkdownControl/renderers.js","sourcesContent":["/* eslint-disable react/display-name */\nimport React from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { colors, lengths } from 'decap-cms-ui-default';\nimport { useSelected } from 'slate-react';\n\nimport VoidBlock from './components/VoidBlock';\nimport Shortcode from './components/Shortcode';\n\nconst bottomMargin = '16px';\n\nconst headerStyles = `\n  font-weight: 700;\n  line-height: 1;\n`;\n\nconst StyledH1 = styled.h1`\n  ${headerStyles};\n  font-size: 32px;\n  margin-top: 16px;\n`;\n\nconst StyledH2 = styled.h2`\n  ${headerStyles};\n  font-size: 24px;\n  margin-top: 12px;\n`;\n\nconst StyledH3 = styled.h3`\n  ${headerStyles};\n  font-size: 20px;\n`;\n\nconst StyledH4 = styled.h4`\n  ${headerStyles};\n  font-size: 18px;\n  margin-top: 8px;\n`;\n\nconst StyledH5 = styled.h5`\n  ${headerStyles};\n  font-size: 16px;\n  margin-top: 8px;\n`;\n\nconst StyledH6 = StyledH5.withComponent('h6');\n\nconst StyledP = styled.p`\n  margin-bottom: ${bottomMargin};\n`;\n\nconst StyledBlockQuote = styled.blockquote`\n  padding-left: 16px;\n  border-left: 3px solid ${colors.background};\n  margin-left: 0;\n  margin-right: 0;\n  margin-bottom: ${bottomMargin};\n`;\n\nconst StyledCode = styled.code`\n  background-color: ${colors.background};\n  border-radius: ${lengths.borderRadius};\n  padding: 0 2px;\n  font-size: 85%;\n`;\n\nconst StyledUl = styled.ul`\n  margin-bottom: ${bottomMargin};\n  padding-left: 30px;\n`;\n\nconst StyledOl = StyledUl.withComponent('ol');\n\nconst StyledLi = styled.li`\n  & > p:first-of-type {\n    margin-top: 8px;\n  }\n\n  & > p:last-of-type {\n    margin-bottom: 8px;\n  }\n`;\n\nconst StyledA = styled.a`\n  text-decoration: underline;\n  font-size: inherit;\n`;\n\nconst StyledHr = styled.hr`\n  border: 1px solid;\n  margin-bottom: 16px;\n`;\n\nconst StyledTable = styled.table`\n  border-collapse: collapse;\n`;\n\nconst StyledTd = styled.td`\n  border: 2px solid black;\n  padding: 8px;\n  text-align: left;\n`;\n\n/**\n * Slate uses React components to render each type of node that it receives.\n * This is the closest thing Slate has to a schema definition. The types are set\n * by us when we manually deserialize from Remark's MDAST to Slate's AST.\n */\n\n/**\n * Mark Components\n */\nfunction Bold(props) {\n  return <strong>{props.children}</strong>;\n}\n\nfunction Italic(props) {\n  return <em>{props.children}</em>;\n}\n\nfunction Strikethrough(props) {\n  return <s>{props.children}</s>;\n}\n\nfunction Code(props) {\n  return <StyledCode>{props.children}</StyledCode>;\n}\n\n/**\n * Node Components\n */\nfunction Paragraph(props) {\n  return <StyledP {...props.attributes}>{props.children}</StyledP>;\n}\n\nfunction ListItem(props) {\n  return <StyledLi {...props.attributes}>{props.children}</StyledLi>;\n}\n\nfunction Quote(props) {\n  return <StyledBlockQuote {...props.attributes}>{props.children}</StyledBlockQuote>;\n}\n\nfunction HeadingOne(props) {\n  return <StyledH1 {...props.attributes}>{props.children}</StyledH1>;\n}\n\nfunction HeadingTwo(props) {\n  return <StyledH2 {...props.attributes}>{props.children}</StyledH2>;\n}\n\nfunction HeadingThree(props) {\n  return <StyledH3 {...props.attributes}>{props.children}</StyledH3>;\n}\n\nfunction HeadingFour(props) {\n  return <StyledH4 {...props.attributes}>{props.children}</StyledH4>;\n}\n\nfunction HeadingFive(props) {\n  return <StyledH5 {...props.attributes}>{props.children}</StyledH5>;\n}\n\nfunction HeadingSix(props) {\n  return <StyledH6 {...props.attributes}>{props.children}</StyledH6>;\n}\n\nfunction Table(props) {\n  return (\n    <StyledTable>\n      <tbody {...props.attributes}>{props.children}</tbody>\n    </StyledTable>\n  );\n}\n\nfunction TableRow(props) {\n  return <tr {...props.attributes}>{props.children}</tr>;\n}\n\nfunction TableCell(props) {\n  return <StyledTd {...props.attributes}>{props.children}</StyledTd>;\n}\n\nfunction ThematicBreak(props) {\n  const isSelected = useSelected();\n  return (\n    <div {...props.attributes}>\n      {props.children}\n      <div contentEditable={false}>\n        <StyledHr\n          {...props.attributes}\n          css={\n            isSelected &&\n            css`\n              box-shadow: 0 0 0 2px ${colors.active};\n              border-radius: 8px;\n              color: ${colors.active};\n            `\n          }\n        />\n      </div>\n    </div>\n  );\n}\n\nfunction Break(props) {\n  return (\n    <>\n      <br {...props.attributes} />\n      {props.children}\n    </>\n  );\n}\n\nfunction BulletedList(props) {\n  return <StyledUl {...props.attributes}>{props.children}</StyledUl>;\n}\n\nfunction NumberedList(props) {\n  return (\n    <StyledOl {...props.attributes} start={1}>\n      {props.children}\n    </StyledOl>\n  );\n}\n\nfunction Link(props) {\n  const url = props.element.url;\n  const title = props.element.title || url;\n\n  return (\n    <StyledA href={url} title={title} {...props.attributes}>\n      {props.children}\n    </StyledA>\n  );\n}\n\nfunction Image(props) {\n  const { url, title, alt } = props.element.data;\n  const isSelected = useSelected();\n  return (\n    <span {...props.attributes}>\n      {props.children}\n      <img\n        src={url}\n        title={title}\n        alt={alt}\n        {...props.attributes}\n        css={\n          isSelected &&\n          css`\n            box-shadow: 0 0 0 2px ${colors.active};\n          `\n        }\n      />\n    </span>\n  );\n}\n\nexport function Leaf({ attributes, children, leaf }) {\n  if (leaf.bold) {\n    children = <Bold>{children}</Bold>;\n  }\n\n  if (leaf.italic) {\n    children = <Italic>{children}</Italic>;\n  }\n\n  if (leaf.delete) {\n    children = <Strikethrough>{children}</Strikethrough>;\n  }\n\n  if (leaf.code) {\n    children = <Code>{children}</Code>;\n  }\n\n  // if (leaf.break) {\n  //   children = <Break />;\n  // }\n\n  return <span {...attributes}>{children}</span>;\n}\n\nexport function renderInline__DEPRECATED() {\n  return props => {\n    switch (props.node.type) {\n      case 'link':\n        return <Link {...props} />;\n      case 'image':\n        return <Image {...props} />;\n      case 'break':\n        return <Break {...props} />;\n    }\n  };\n}\n\nexport function Element(props) {\n  const { children, element, classNameWrapper, codeBlockComponent } = props;\n  const style = { textAlign: element.align };\n\n  switch (element.type) {\n    case 'bulleted-list':\n      return <BulletedList>{children}</BulletedList>;\n    case 'quote':\n      return <Quote>{children}</Quote>;\n    case 'heading-one':\n      return <HeadingOne>{children}</HeadingOne>;\n    case 'heading-two':\n      return <HeadingTwo>{children}</HeadingTwo>;\n    case 'heading-three':\n      return <HeadingThree>{children}</HeadingThree>;\n    case 'heading-four':\n      return <HeadingFour>{children}</HeadingFour>;\n    case 'heading-five':\n      return <HeadingFive>{children}</HeadingFive>;\n    case 'heading-six':\n      return <HeadingSix>{children}</HeadingSix>;\n    case 'list-item':\n      return <ListItem>{children}</ListItem>;\n    case 'numbered-list':\n      return <NumberedList>{children}</NumberedList>;\n    case 'table':\n      return <Table {...props} />;\n    case 'table-row':\n      return <TableRow {...props} />;\n    case 'table-cell':\n      return <TableCell {...props} />;\n    case 'thematic-break':\n      return (\n        <VoidBlock {...props}>\n          <ThematicBreak {...props} />\n        </VoidBlock>\n      );\n    case 'link':\n      return <Link {...props} />;\n    case 'image':\n      return <Image {...props} />;\n    case 'break':\n      return <Break {...props} />;\n    case 'shortcode':\n      if (element.id === 'code-block' && codeBlockComponent) {\n        return (\n          <VoidBlock {...props}>\n            <Shortcode classNameWrapper={classNameWrapper} typeOverload=\"code-block\" {...props} />\n          </VoidBlock>\n        );\n      }\n      return (\n        <VoidBlock {...props}>\n          <Shortcode {...props}>{children}</Shortcode>\n        </VoidBlock>\n      );\n    default:\n      return <Paragraph style={style}>{children}</Paragraph>;\n  }\n}\n"]} */",
119
114
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
120
115
  });
121
116
 
@@ -1,6 +1,3 @@
1
- function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
2
- function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : String(i); }
3
- function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
4
1
  import React from 'react';
5
2
  import PropTypes from 'prop-types';
6
3
  import { WidgetPreviewContainer } from 'decap-cms-ui-default';
@@ -8,6 +5,15 @@ import DOMPurify from 'dompurify';
8
5
  import { markdownToHtml } from './serializers';
9
6
  import { jsx as ___EmotionJSX } from "@emotion/react";
10
7
  class MarkdownPreview extends React.Component {
8
+ static propTypes = {
9
+ getAsset: PropTypes.func.isRequired,
10
+ resolveWidget: PropTypes.func.isRequired,
11
+ value: PropTypes.string
12
+ };
13
+ componentDidMount() {
14
+ // Manually validate PropTypes - React 19 breaking change
15
+ PropTypes.checkPropTypes(MarkdownPreview.propTypes, this.props, 'prop', 'MarkdownPreview');
16
+ }
11
17
  render() {
12
18
  const {
13
19
  value,
@@ -22,8 +28,8 @@ class MarkdownPreview extends React.Component {
22
28
  const html = markdownToHtml(value, {
23
29
  getAsset,
24
30
  resolveWidget
25
- }, getRemarkPlugins === null || getRemarkPlugins === void 0 ? void 0 : getRemarkPlugins());
26
- const toRender = field !== null && field !== void 0 && field.get('sanitize_preview', false) ? DOMPurify.sanitize(html) : html;
31
+ }, getRemarkPlugins?.());
32
+ const toRender = field?.get('sanitize_preview', false) ? DOMPurify.sanitize(html) : html;
27
33
  return ___EmotionJSX(WidgetPreviewContainer, {
28
34
  dangerouslySetInnerHTML: {
29
35
  __html: toRender
@@ -31,9 +37,4 @@ class MarkdownPreview extends React.Component {
31
37
  });
32
38
  }
33
39
  }
34
- _defineProperty(MarkdownPreview, "propTypes", {
35
- getAsset: PropTypes.func.isRequired,
36
- resolveWidget: PropTypes.func.isRequired,
37
- value: PropTypes.string
38
- });
39
40
  export default MarkdownPreview;
package/dist/esm/index.js CHANGED
@@ -1,18 +1,14 @@
1
- function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
2
- function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
3
- function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
4
- function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : String(i); }
5
- function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
6
1
  import controlComponent from './MarkdownControl';
7
2
  import previewComponent from './MarkdownPreview';
8
3
  import schema from './schema';
9
4
  function Widget(opts = {}) {
10
- return _objectSpread({
5
+ return {
11
6
  name: 'markdown',
12
7
  controlComponent,
13
8
  previewComponent,
14
- schema
15
- }, opts);
9
+ schema,
10
+ ...opts
11
+ };
16
12
  }
17
13
  export const DecapCmsWidgetMarkdown = {
18
14
  Widget,
@@ -1,4 +1,5 @@
1
- import _last from "lodash/last";
1
+ import last from 'lodash/last';
2
+
2
3
  /**
3
4
  * Joins an array of regular expressions into a single expression, without
4
5
  * altering the received expressions.
@@ -47,7 +48,7 @@ export function replaceWhen(matchPattern, replaceFn, text, invertMatchPattern) {
47
48
  * string.
48
49
  */
49
50
  const match = exp.exec(text);
50
- const lastEntry = _last(acc);
51
+ const lastEntry = last(acc);
51
52
 
52
53
  /**
53
54
  * `match` will be null if there are no matches.
@@ -115,7 +116,7 @@ export function replaceWhen(matchPattern, replaceFn, text, invertMatchPattern) {
115
116
  /**
116
117
  * Process the trailing substring after the final match, if one exists.
117
118
  */
118
- const lastEntry = _last(acc);
119
+ const lastEntry = last(acc);
119
120
  if (!lastEntry) return replaceFn(text);
120
121
  const nextIndex = lastEntry.index + lastEntry.text.length;
121
122
  if (text.length > nextIndex) {
@@ -1,4 +1,4 @@
1
- import _trimEnd from "lodash/trimEnd";
1
+ import trimEnd from 'lodash/trimEnd';
2
2
  import unified from 'unified';
3
3
  import u from 'unist-builder';
4
4
  import markdownToRemarkPlugin from 'remark-parse';
@@ -142,7 +142,7 @@ export function remarkToMarkdown(obj, remarkPlugins) {
142
142
  /**
143
143
  * Return markdown with trailing whitespace removed.
144
144
  */
145
- return _trimEnd(markdown);
145
+ return trimEnd(markdown);
146
146
  }
147
147
 
148
148
  /**
@@ -1,12 +1,7 @@
1
- import _isEmpty from "lodash/isEmpty";
2
- import _nth from "lodash/nth";
3
- import _last from "lodash/last";
4
- import _concat from "lodash/concat";
5
- function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
6
- function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
7
- function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
8
- function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : String(i); }
9
- function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
1
+ import concat from 'lodash/concat';
2
+ import last from 'lodash/last';
3
+ import nth from 'lodash/nth';
4
+ import isEmpty from 'lodash/isEmpty';
10
5
  import visitParents from 'unist-util-visit-parents';
11
6
 
12
7
  /**
@@ -50,34 +45,36 @@ export default function remarkUnwrapInvalidNest() {
50
45
  const canContainBlocks = ['root', 'blockquote', 'listItem', 'tableCell'];
51
46
  let invalidNest;
52
47
  visitParents(tree, (node, parents) => {
53
- const parentType = !_isEmpty(parents) && _last(parents).type;
48
+ const parentType = !isEmpty(parents) && last(parents).type;
54
49
  const isInvalidNest = blocks.includes(node.type) && !canContainBlocks.includes(parentType);
55
50
  if (isInvalidNest) {
56
- invalidNest = _concat(parents, node);
51
+ invalidNest = concat(parents, node);
57
52
  return false;
58
53
  }
59
54
  });
60
55
  return invalidNest;
61
56
  }
62
57
  function splitTreeAtNest(tree, nest) {
63
- const grandparent = _nth(nest, -3) || tree;
64
- const parent = _nth(nest, -2);
65
- const node = _last(nest);
58
+ const grandparent = nth(nest, -3) || tree;
59
+ const parent = nth(nest, -2);
60
+ const node = last(nest);
66
61
  const splitIndex = grandparent.children.indexOf(parent);
67
62
  const splitChildren = grandparent.children;
68
63
  const splitChildIndex = parent.children.indexOf(node);
69
64
  const childrenBefore = parent.children.slice(0, splitChildIndex);
70
65
  const childrenAfter = parent.children.slice(splitChildIndex + 1);
71
- const nodeBefore = !_isEmpty(childrenBefore) && _objectSpread(_objectSpread({}, parent), {}, {
66
+ const nodeBefore = !isEmpty(childrenBefore) && {
67
+ ...parent,
72
68
  children: childrenBefore
73
- });
74
- const nodeAfter = !_isEmpty(childrenAfter) && _objectSpread(_objectSpread({}, parent), {}, {
69
+ };
70
+ const nodeAfter = !isEmpty(childrenAfter) && {
71
+ ...parent,
75
72
  children: childrenAfter
76
- });
77
- const childrenToInsert = [nodeBefore, node, nodeAfter].filter(val => !_isEmpty(val));
73
+ };
74
+ const childrenToInsert = [nodeBefore, node, nodeAfter].filter(val => !isEmpty(val));
78
75
  const beforeChildren = splitChildren.slice(0, splitIndex);
79
76
  const afterChildren = splitChildren.slice(splitIndex + 1);
80
- const newChildren = _concat(beforeChildren, childrenToInsert, afterChildren);
77
+ const newChildren = concat(beforeChildren, childrenToInsert, afterChildren);
81
78
  grandparent.children = newChildren;
82
79
  }
83
80
  }
@@ -1,12 +1,7 @@
1
- import _map from "lodash/map";
2
- import _partial from "lodash/partial";
3
- import _flow from "lodash/flow";
4
- import _has from "lodash/has";
5
- function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
6
- function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
7
- function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
8
- function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : String(i); }
9
- function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
1
+ import has from 'lodash/has';
2
+ import flow from 'lodash/flow';
3
+ import partial from 'lodash/partial';
4
+ import map from 'lodash/map';
10
5
  import { joinPatternSegments, combinePatterns, replaceWhen } from '../regexHelper';
11
6
 
12
7
  /**
@@ -133,7 +128,7 @@ const escapePatterns = [
133
128
  * Generate new non-escape expression. The non-escape expression matches
134
129
  * substrings whose contents should not be processed for escaping.
135
130
  */
136
- const joinedNonEscapePatterns = _map(nonEscapePatterns, pattern => {
131
+ const joinedNonEscapePatterns = map(nonEscapePatterns, pattern => {
137
132
  return new RegExp(joinPatternSegments(pattern));
138
133
  });
139
134
  const nonEscapePattern = combinePatterns(joinedNonEscapePatterns);
@@ -141,8 +136,8 @@ const nonEscapePattern = combinePatterns(joinedNonEscapePatterns);
141
136
  /**
142
137
  * Create chain of successive escape functions for various markdown entities.
143
138
  */
144
- const escapeFunctions = escapePatterns.map(pattern => _partial(escapeDelimiters, pattern));
145
- const escapeAll = _flow(escapeFunctions);
139
+ const escapeFunctions = escapePatterns.map(pattern => partial(escapeDelimiters, pattern));
140
+ const escapeAll = flow(escapeFunctions);
146
141
 
147
142
  /**
148
143
  * Executes both the `escapeCommonChars` and `escapeLeadingChars` functions.
@@ -236,7 +231,7 @@ export default function remarkEscapeMarkdownEntities() {
236
231
  * Shortcode nodes will intentionally inject markdown entities in text node
237
232
  * children not be escaped.
238
233
  */
239
- if (_has(node.data, 'shortcode')) return node;
234
+ if (has(node.data, 'shortcode')) return node;
240
235
  const children = node.children ? {
241
236
  children: node.children.map(transform)
242
237
  } : {};
@@ -251,15 +246,20 @@ export default function remarkEscapeMarkdownEntities() {
251
246
  * common characters.
252
247
  */
253
248
  const value = index === 0 ? escapeAllChars(node.value) : escapeCommonChars(node.value);
254
- return _objectSpread(_objectSpread({}, node), {}, {
255
- value
256
- }, children);
249
+ return {
250
+ ...node,
251
+ value,
252
+ ...children
253
+ };
257
254
  }
258
255
 
259
256
  /**
260
257
  * Always return nodes with recursively mapped children.
261
258
  */
262
- return _objectSpread(_objectSpread({}, node), children);
259
+ return {
260
+ ...node,
261
+ ...children
262
+ };
263
263
  }
264
264
  return transform;
265
265
  }
@@ -1,8 +1,3 @@
1
- function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
2
- function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
3
- function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
4
- function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : String(i); }
5
- function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
6
1
  /**
7
2
  * Images must be parsed as shortcodes for asset proxying. This plugin converts
8
3
  * MDAST image nodes back to text to allow shortcode pattern matching. Note that
@@ -28,8 +23,9 @@ export default function remarkImagesToText() {
28
23
  }
29
24
  return child;
30
25
  });
31
- return _objectSpread(_objectSpread({}, node), {}, {
26
+ return {
27
+ ...node,
32
28
  children
33
- });
29
+ };
34
30
  }
35
31
  }