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.
- package/CHANGELOG.md +10 -0
- package/dist/decap-cms-widget-markdown.js +6 -6
- package/dist/decap-cms-widget-markdown.js.LICENSE.txt +5 -5
- package/dist/decap-cms-widget-markdown.js.map +1 -1
- package/dist/esm/MarkdownControl/RawEditor.js +1 -2
- package/dist/esm/MarkdownControl/Toolbar.js +43 -47
- package/dist/esm/MarkdownControl/VisualEditor.js +6 -8
- package/dist/esm/MarkdownControl/components/Shortcode.js +6 -11
- package/dist/esm/MarkdownControl/components/VoidBlock.js +1 -1
- package/dist/esm/MarkdownControl/index.js +34 -34
- package/dist/esm/MarkdownControl/plugins/CommandsAndQueries.js +8 -8
- package/dist/esm/MarkdownControl/plugins/inlines/events/toggleLink.js +1 -2
- package/dist/esm/MarkdownControl/plugins/lists/events/keyDownShiftTab.js +6 -9
- package/dist/esm/MarkdownControl/plugins/lists/events/keyDownTab.js +3 -7
- package/dist/esm/MarkdownControl/plugins/lists/transforms/liftFirstMatchedParent.js +4 -8
- package/dist/esm/MarkdownControl/plugins/lists/transforms/unwrapSelectionFromList.js +3 -7
- package/dist/esm/MarkdownControl/plugins/util.js +4 -4
- package/dist/esm/MarkdownControl/renderers.js +6 -11
- package/dist/esm/MarkdownPreview.js +11 -10
- package/dist/esm/index.js +4 -8
- package/dist/esm/regexHelper.js +4 -3
- package/dist/esm/serializers/index.js +2 -2
- package/dist/esm/serializers/remarkAssertParents.js +17 -20
- package/dist/esm/serializers/remarkEscapeMarkdownEntities.js +17 -17
- package/dist/esm/serializers/remarkImagesToText.js +3 -7
- package/dist/esm/serializers/remarkPaddedLinks.js +17 -21
- package/dist/esm/serializers/remarkRehypeShortcodes.js +10 -13
- package/dist/esm/serializers/remarkSlate.js +64 -55
- package/dist/esm/serializers/remarkSquashReferences.js +7 -11
- package/dist/esm/serializers/slateRemark.js +52 -52
- package/package.json +9 -7
- package/src/MarkdownControl/Toolbar.js +5 -0
- package/src/MarkdownControl/VisualEditor.js +1 -1
- package/src/MarkdownControl/components/Shortcode.js +1 -1
- package/src/MarkdownControl/index.js +5 -0
- package/src/MarkdownControl/plugins/CommandsAndQueries.js +3 -1
- package/src/MarkdownControl/plugins/util.js +2 -1
- package/src/MarkdownPreview.js +5 -0
- package/src/__tests__/renderer.spec.js +84 -117
- package/src/regexHelper.js +1 -1
- package/src/serializers/__tests__/commonmark.spec.js +1 -1
- package/src/serializers/__tests__/slate.spec.js +1 -1
- package/src/serializers/index.js +1 -1
- package/src/serializers/remarkAssertParents.js +4 -1
- package/src/serializers/remarkEscapeMarkdownEntities.js +4 -1
- package/src/serializers/remarkPaddedLinks.js +7 -1
- package/src/serializers/remarkRehypeShortcodes.js +2 -1
- package/src/serializers/remarkSlate.js +6 -1
- package/src/serializers/remarkSquashReferences.js +2 -1
- package/src/serializers/slateRemark.js +6 -1
- 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 (
|
|
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
|
|
26
|
-
const toRender = field
|
|
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
|
|
5
|
+
return {
|
|
11
6
|
name: 'markdown',
|
|
12
7
|
controlComponent,
|
|
13
8
|
previewComponent,
|
|
14
|
-
schema
|
|
15
|
-
|
|
9
|
+
schema,
|
|
10
|
+
...opts
|
|
11
|
+
};
|
|
16
12
|
}
|
|
17
13
|
export const DecapCmsWidgetMarkdown = {
|
|
18
14
|
Widget,
|
package/dist/esm/regexHelper.js
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
import
|
|
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 =
|
|
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 =
|
|
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
|
|
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
|
|
145
|
+
return trimEnd(markdown);
|
|
146
146
|
}
|
|
147
147
|
|
|
148
148
|
/**
|
|
@@ -1,12 +1,7 @@
|
|
|
1
|
-
import
|
|
2
|
-
import
|
|
3
|
-
import
|
|
4
|
-
import
|
|
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 = !
|
|
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 =
|
|
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 =
|
|
64
|
-
const parent =
|
|
65
|
-
const node =
|
|
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 = !
|
|
66
|
+
const nodeBefore = !isEmpty(childrenBefore) && {
|
|
67
|
+
...parent,
|
|
72
68
|
children: childrenBefore
|
|
73
|
-
}
|
|
74
|
-
const nodeAfter = !
|
|
69
|
+
};
|
|
70
|
+
const nodeAfter = !isEmpty(childrenAfter) && {
|
|
71
|
+
...parent,
|
|
75
72
|
children: childrenAfter
|
|
76
|
-
}
|
|
77
|
-
const childrenToInsert = [nodeBefore, node, nodeAfter].filter(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 =
|
|
77
|
+
const newChildren = concat(beforeChildren, childrenToInsert, afterChildren);
|
|
81
78
|
grandparent.children = newChildren;
|
|
82
79
|
}
|
|
83
80
|
}
|
|
@@ -1,12 +1,7 @@
|
|
|
1
|
-
import
|
|
2
|
-
import
|
|
3
|
-
import
|
|
4
|
-
import
|
|
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 =
|
|
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 =>
|
|
145
|
-
const escapeAll =
|
|
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 (
|
|
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
|
|
255
|
-
|
|
256
|
-
|
|
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
|
|
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
|
|
26
|
+
return {
|
|
27
|
+
...node,
|
|
32
28
|
children
|
|
33
|
-
}
|
|
29
|
+
};
|
|
34
30
|
}
|
|
35
31
|
}
|