decap-cms-widget-markdown 3.4.1 → 3.6.0

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.
@@ -35,7 +35,7 @@ const RawEditorContainer = /*#__PURE__*/_styled("div", {
35
35
  styles: "position:relative"
36
36
  } : {
37
37
  name: "bjn8wh",
38
- styles: "position:relative/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9NYXJrZG93bkNvbnRyb2wvUmF3RWRpdG9yLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTRCcUMiLCJmaWxlIjoiLi4vLi4vLi4vc3JjL01hcmtkb3duQ29udHJvbC9SYXdFZGl0b3IuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlRWZmZWN0LCB1c2VNZW1vLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgSW1tdXRhYmxlUHJvcFR5cGVzIGZyb20gJ3JlYWN0LWltbXV0YWJsZS1wcm9wdHlwZXMnO1xuaW1wb3J0IHsgQ2xhc3NOYW1lcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGxlbmd0aHMsIGZvbnRzIH0gZnJvbSAnZGVjYXAtY21zLXVpLWRlZmF1bHQnO1xuaW1wb3J0IHsgY3JlYXRlRWRpdG9yIH0gZnJvbSAnc2xhdGUnO1xuaW1wb3J0IHsgRWRpdGFibGUsIFJlYWN0RWRpdG9yLCBTbGF0ZSwgd2l0aFJlYWN0IH0gZnJvbSAnc2xhdGUtcmVhY3QnO1xuaW1wb3J0IHsgd2l0aEhpc3RvcnkgfSBmcm9tICdzbGF0ZS1oaXN0b3J5JztcblxuaW1wb3J0IHsgZWRpdG9yU3R5bGVWYXJzLCBFZGl0b3JDb250cm9sQmFyIH0gZnJvbSAnLi4vc3R5bGVzJztcbmltcG9ydCBUb29sYmFyIGZyb20gJy4vVG9vbGJhcic7XG5pbXBvcnQgZGVmYXVsdEVtcHR5QmxvY2sgZnJvbSAnLi9wbHVnaW5zL2Jsb2Nrcy9kZWZhdWx0RW1wdHlCbG9jayc7XG5cbmZ1bmN0aW9uIHJhd0VkaXRvclN0eWxlcyh7IG1pbmltYWwgfSkge1xuICByZXR1cm4gYFxuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIG92ZXJmbG93LXg6IGF1dG87XG4gIG1pbi1oZWlnaHQ6ICR7bWluaW1hbCA/ICdhdXRvJyA6IGxlbmd0aHMucmljaFRleHRFZGl0b3JNaW5IZWlnaHR9O1xuICBmb250LWZhbWlseTogJHtmb250cy5tb25vfTtcbiAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogMDtcbiAgYm9yZGVyLXRvcC1yaWdodC1yYWRpdXM6IDA7XG4gIGJvcmRlci10b3A6IDA7XG4gIG1hcmdpbi10b3A6IC0ke2VkaXRvclN0eWxlVmFycy5zdGlja3lEaXN0YW5jZUJvdHRvbX07XG5gO1xufVxuXG5jb25zdCBSYXdFZGl0b3JDb250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBwb3NpdGlvbjogcmVsYXRpdmU7XG5gO1xuZnVuY3Rpb24gUmF3RWRpdG9yKHByb3BzKSB7XG4gIGNvbnN0IHsgY2xhc3NOYW1lLCBmaWVsZCwgaXNTaG93TW9kZVRvZ2dsZSwgdCwgb25DaGFuZ2UgfSA9IHByb3BzO1xuXG4gIGNvbnN0IGVkaXRvciA9IHVzZU1lbW8oKCkgPT4gd2l0aFJlYWN0KHdpdGhIaXN0b3J5KGNyZWF0ZUVkaXRvcigpKSksIFtdKTtcblxuICBjb25zdCBbdmFsdWUsIHNldFZhbHVlXSA9IHVzZVN0YXRlKFxuICAgIHByb3BzLnZhbHVlXG4gICAgICA/IHByb3BzLnZhbHVlLnNwbGl0KCdcXG4nKS5tYXAobGluZSA9PiBkZWZhdWx0RW1wdHlCbG9jayhsaW5lKSlcbiAgICAgIDogW2RlZmF1bHRFbXB0eUJsb2NrKCldLFxuICApO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKHByb3BzLnBlbmRpbmdGb2N1cykge1xuICAgICAgUmVhY3RFZGl0b3IuZm9jdXMoZWRpdG9yKTtcbiAgICAgIHByb3BzLnBlbmRpbmdGb2N1cygpO1xuICAgIH1cbiAgfSwgW3Byb3BzLnBlbmRpbmdGb2N1c10pO1xuXG4gIGZ1bmN0aW9uIGhhbmRsZVRvZ2dsZU1vZGUoKSB7XG4gICAgcHJvcHMub25Nb2RlKCdyaWNoX3RleHQnKTtcbiAgfVxuXG4gIGZ1bmN0aW9uIGhhbmRsZUNoYW5nZSh2YWx1ZSkge1xuICAgIG9uQ2hhbmdlKHZhbHVlLm1hcChsaW5lID0+IGxpbmUuY2hpbGRyZW5bMF0udGV4dCkuam9pbignXFxuJykpO1xuICAgIHNldFZhbHVlKHZhbHVlKTtcbiAgfVxuXG4gIHJldHVybiAoXG4gICAgPFNsYXRlIGVkaXRvcj17ZWRpdG9yfSB2YWx1ZT17dmFsdWV9IG9uQ2hhbmdlPXtoYW5kbGVDaGFuZ2V9PlxuICAgICAgPFJhd0VkaXRvckNvbnRhaW5lcj5cbiAgICAgICAgPEVkaXRvckNvbnRyb2xCYXI+XG4gICAgICAgICAgPFRvb2xiYXJcbiAgICAgICAgICAgIG9uVG9nZ2xlTW9kZT17aGFuZGxlVG9nZ2xlTW9kZX1cbiAgICAgICAgICAgIGJ1dHRvbnM9e2ZpZWxkLmdldCgnYnV0dG9ucycpfVxuICAgICAgICAgICAgZGlzYWJsZWRcbiAgICAgICAgICAgIHJhd01vZGVcbiAgICAgICAgICAgIGlzU2hvd01vZGVUb2dnbGU9e2lzU2hvd01vZGVUb2dnbGV9XG4gICAgICAgICAgICB0PXt0fVxuICAgICAgICAgIC8+XG4gICAgICAgIDwvRWRpdG9yQ29udHJvbEJhcj5cbiAgICAgICAgPENsYXNzTmFtZXM+XG4gICAgICAgICAgeyh7IGNzcywgY3ggfSkgPT4gKFxuICAgICAgICAgICAgPEVkaXRhYmxlXG4gICAgICAgICAgICAgIGNsYXNzTmFtZT17Y3goXG4gICAgICAgICAgICAgICAgY2xhc3NOYW1lLFxuICAgICAgICAgICAgICAgIGNzc2BcbiAgICAgICAgICAgICAgICAgICR7cmF3RWRpdG9yU3R5bGVzKHsgbWluaW1hbDogZmllbGQuZ2V0KCdtaW5pbWFsJykgfSl9XG4gICAgICAgICAgICAgICAgYCxcbiAgICAgICAgICAgICAgKX1cbiAgICAgICAgICAgICAgdmFsdWU9e3ZhbHVlfVxuICAgICAgICAgICAgICBvbkNoYW5nZT17aGFuZGxlQ2hhbmdlfVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICApfVxuICAgICAgICA8L0NsYXNzTmFtZXM+XG4gICAgICA8L1Jhd0VkaXRvckNvbnRhaW5lcj5cbiAgICA8L1NsYXRlPlxuICApO1xufVxuXG5SYXdFZGl0b3IucHJvcFR5cGVzID0ge1xuICBvbkNoYW5nZTogUHJvcFR5cGVzLmZ1bmMuaXNSZXF1aXJlZCxcbiAgb25Nb2RlOiBQcm9wVHlwZXMuZnVuYy5pc1JlcXVpcmVkLFxuICBjbGFzc05hbWU6IFByb3BUeXBlcy5zdHJpbmcuaXNSZXF1aXJlZCxcbiAgdmFsdWU6IFByb3BUeXBlcy5zdHJpbmcsXG4gIGZpZWxkOiBJbW11dGFibGVQcm9wVHlwZXMubWFwLmlzUmVxdWlyZWQsXG4gIGlzU2hvd01vZGVUb2dnbGU6IFByb3BUeXBlcy5ib29sLmlzUmVxdWlyZWQsXG4gIHQ6IFByb3BUeXBlcy5mdW5jLmlzUmVxdWlyZWQsXG59O1xuXG5leHBvcnQgZGVmYXVsdCBSYXdFZGl0b3I7XG4iXX0= */",
38
+ styles: "position:relative/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9NYXJrZG93bkNvbnRyb2wvUmF3RWRpdG9yLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTRCcUMiLCJmaWxlIjoiLi4vLi4vLi4vc3JjL01hcmtkb3duQ29udHJvbC9SYXdFZGl0b3IuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlRWZmZWN0LCB1c2VNZW1vLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgSW1tdXRhYmxlUHJvcFR5cGVzIGZyb20gJ3JlYWN0LWltbXV0YWJsZS1wcm9wdHlwZXMnO1xuaW1wb3J0IHsgQ2xhc3NOYW1lcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGxlbmd0aHMsIGZvbnRzIH0gZnJvbSAnZGVjYXAtY21zLXVpLWRlZmF1bHQnO1xuaW1wb3J0IHsgY3JlYXRlRWRpdG9yIH0gZnJvbSAnc2xhdGUnO1xuaW1wb3J0IHsgRWRpdGFibGUsIFJlYWN0RWRpdG9yLCBTbGF0ZSwgd2l0aFJlYWN0IH0gZnJvbSAnc2xhdGUtcmVhY3QnO1xuaW1wb3J0IHsgd2l0aEhpc3RvcnkgfSBmcm9tICdzbGF0ZS1oaXN0b3J5JztcblxuaW1wb3J0IHsgZWRpdG9yU3R5bGVWYXJzLCBFZGl0b3JDb250cm9sQmFyIH0gZnJvbSAnLi4vc3R5bGVzJztcbmltcG9ydCBUb29sYmFyIGZyb20gJy4vVG9vbGJhcic7XG5pbXBvcnQgZGVmYXVsdEVtcHR5QmxvY2sgZnJvbSAnLi9wbHVnaW5zL2Jsb2Nrcy9kZWZhdWx0RW1wdHlCbG9jayc7XG5cbmZ1bmN0aW9uIHJhd0VkaXRvclN0eWxlcyh7IG1pbmltYWwgfSkge1xuICByZXR1cm4gYFxuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIG92ZXJmbG93LXg6IGF1dG87XG4gIG1pbi1oZWlnaHQ6ICR7bWluaW1hbCA/ICdhdXRvJyA6IGxlbmd0aHMucmljaFRleHRFZGl0b3JNaW5IZWlnaHR9O1xuICBmb250LWZhbWlseTogJHtmb250cy5tb25vfTtcbiAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogMDtcbiAgYm9yZGVyLXRvcC1yaWdodC1yYWRpdXM6IDA7XG4gIGJvcmRlci10b3A6IDA7XG4gIG1hcmdpbi10b3A6IC0ke2VkaXRvclN0eWxlVmFycy5zdGlja3lEaXN0YW5jZUJvdHRvbX07XG5gO1xufVxuXG5jb25zdCBSYXdFZGl0b3JDb250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBwb3NpdGlvbjogcmVsYXRpdmU7XG5gO1xuZnVuY3Rpb24gUmF3RWRpdG9yKHByb3BzKSB7XG4gIGNvbnN0IHsgY2xhc3NOYW1lLCBmaWVsZCwgaXNTaG93TW9kZVRvZ2dsZSwgdCwgb25DaGFuZ2UgfSA9IHByb3BzO1xuXG4gIGNvbnN0IGVkaXRvciA9IHVzZU1lbW8oKCkgPT4gd2l0aFJlYWN0KHdpdGhIaXN0b3J5KGNyZWF0ZUVkaXRvcigpKSksIFtdKTtcblxuICBjb25zdCBbdmFsdWUsIHNldFZhbHVlXSA9IHVzZVN0YXRlKFxuICAgIHByb3BzLnZhbHVlXG4gICAgICA/IHByb3BzLnZhbHVlLnNwbGl0KCdcXG4nKS5tYXAobGluZSA9PiBkZWZhdWx0RW1wdHlCbG9jayhsaW5lKSlcbiAgICAgIDogW2RlZmF1bHRFbXB0eUJsb2NrKCldLFxuICApO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKHByb3BzLnBlbmRpbmdGb2N1cykge1xuICAgICAgUmVhY3RFZGl0b3IuZm9jdXMoZWRpdG9yKTtcbiAgICAgIHByb3BzLnBlbmRpbmdGb2N1cygpO1xuICAgIH1cbiAgfSwgW3Byb3BzLnBlbmRpbmdGb2N1c10pO1xuXG4gIGZ1bmN0aW9uIGhhbmRsZVRvZ2dsZU1vZGUoKSB7XG4gICAgcHJvcHMub25Nb2RlKCdyaWNoX3RleHQnKTtcbiAgfVxuXG4gIGZ1bmN0aW9uIGhhbmRsZUNoYW5nZSh2YWx1ZSkge1xuICAgIG9uQ2hhbmdlKHZhbHVlLm1hcChsaW5lID0+IGxpbmUuY2hpbGRyZW5bMF0udGV4dCkuam9pbignXFxuJykpO1xuICAgIHNldFZhbHVlKHZhbHVlKTtcbiAgfVxuXG4gIHJldHVybiAoXG4gICAgPFNsYXRlIGVkaXRvcj17ZWRpdG9yfSB2YWx1ZT17dmFsdWV9IGluaXRpYWxWYWx1ZT17dmFsdWV9IG9uQ2hhbmdlPXtoYW5kbGVDaGFuZ2V9PlxuICAgICAgPFJhd0VkaXRvckNvbnRhaW5lcj5cbiAgICAgICAgPEVkaXRvckNvbnRyb2xCYXI+XG4gICAgICAgICAgPFRvb2xiYXJcbiAgICAgICAgICAgIG9uVG9nZ2xlTW9kZT17aGFuZGxlVG9nZ2xlTW9kZX1cbiAgICAgICAgICAgIGJ1dHRvbnM9e2ZpZWxkLmdldCgnYnV0dG9ucycpfVxuICAgICAgICAgICAgZGlzYWJsZWRcbiAgICAgICAgICAgIHJhd01vZGVcbiAgICAgICAgICAgIGlzU2hvd01vZGVUb2dnbGU9e2lzU2hvd01vZGVUb2dnbGV9XG4gICAgICAgICAgICB0PXt0fVxuICAgICAgICAgIC8+XG4gICAgICAgIDwvRWRpdG9yQ29udHJvbEJhcj5cbiAgICAgICAgPENsYXNzTmFtZXM+XG4gICAgICAgICAgeyh7IGNzcywgY3ggfSkgPT4gKFxuICAgICAgICAgICAgPEVkaXRhYmxlXG4gICAgICAgICAgICAgIGNsYXNzTmFtZT17Y3goXG4gICAgICAgICAgICAgICAgY2xhc3NOYW1lLFxuICAgICAgICAgICAgICAgIGNzc2BcbiAgICAgICAgICAgICAgICAgICR7cmF3RWRpdG9yU3R5bGVzKHsgbWluaW1hbDogZmllbGQuZ2V0KCdtaW5pbWFsJykgfSl9XG4gICAgICAgICAgICAgICAgYCxcbiAgICAgICAgICAgICAgKX1cbiAgICAgICAgICAgICAgdmFsdWU9e3ZhbHVlfVxuICAgICAgICAgICAgICBvbkNoYW5nZT17aGFuZGxlQ2hhbmdlfVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICApfVxuICAgICAgICA8L0NsYXNzTmFtZXM+XG4gICAgICA8L1Jhd0VkaXRvckNvbnRhaW5lcj5cbiAgICA8L1NsYXRlPlxuICApO1xufVxuXG5SYXdFZGl0b3IucHJvcFR5cGVzID0ge1xuICBvbkNoYW5nZTogUHJvcFR5cGVzLmZ1bmMuaXNSZXF1aXJlZCxcbiAgb25Nb2RlOiBQcm9wVHlwZXMuZnVuYy5pc1JlcXVpcmVkLFxuICBjbGFzc05hbWU6IFByb3BUeXBlcy5zdHJpbmcuaXNSZXF1aXJlZCxcbiAgdmFsdWU6IFByb3BUeXBlcy5zdHJpbmcsXG4gIGZpZWxkOiBJbW11dGFibGVQcm9wVHlwZXMubWFwLmlzUmVxdWlyZWQsXG4gIGlzU2hvd01vZGVUb2dnbGU6IFByb3BUeXBlcy5ib29sLmlzUmVxdWlyZWQsXG4gIHQ6IFByb3BUeXBlcy5mdW5jLmlzUmVxdWlyZWQsXG59O1xuXG5leHBvcnQgZGVmYXVsdCBSYXdFZGl0b3I7XG4iXX0= */",
39
39
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
40
40
  });
41
41
  function RawEditor(props) {
@@ -64,6 +64,7 @@ function RawEditor(props) {
64
64
  return ___EmotionJSX(Slate, {
65
65
  editor: editor,
66
66
  value: value,
67
+ initialValue: value,
67
68
  onChange: handleChange
68
69
  }, ___EmotionJSX(RawEditorContainer, null, ___EmotionJSX(EditorControlBar, null, ___EmotionJSX(Toolbar, {
69
70
  onToggleMode: handleToggleMode,
@@ -11,7 +11,7 @@ import { jsx as ___EmotionJSX } from "@emotion/react";
11
11
  const ToolbarContainer = /*#__PURE__*/_styled("div", {
12
12
  target: "e11cox783",
13
13
  label: "ToolbarContainer"
14
- })("background-color:", colors.textFieldBorder, ";border-top-right-radius:", lengths.borderRadius, ";position:relative;display:flex;justify-content:space-between;align-items:center;padding:11px 14px;min-height:58px;transition:background-color ", transitions.main, ",color ", transitions.main, ";color:", colors.text, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MarkdownControl/Toolbar.js"],"names":[],"mappings":"AAkBmC","file":"../../../src/MarkdownControl/Toolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { List } from 'immutable';\nimport {\n  Toggle,\n  Dropdown,\n  DropdownItem,\n  DropdownButton,\n  colors,\n  transitions,\n  lengths,\n} from 'decap-cms-ui-default';\n\nimport ToolbarButton from './ToolbarButton';\n\nconst ToolbarContainer = styled.div`\n  background-color: ${colors.textFieldBorder};\n  border-top-right-radius: ${lengths.borderRadius};\n  position: relative;\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: 11px 14px;\n  min-height: 58px;\n  transition: background-color ${transitions.main}, color ${transitions.main};\n  color: ${colors.text};\n`;\n\nconst ToolbarDropdownWrapper = styled.div`\n  display: inline-block;\n  position: relative;\n`;\n\nconst ToolbarToggle = styled.div`\n  flex-shrink: 0;\n  display: flex;\n  align-items: center;\n  font-size: 14px;\n  margin: 0 10px;\n`;\n\nconst StyledToggle = ToolbarToggle.withComponent(Toggle);\n\nconst ToolbarToggleLabel = styled.span`\n  display: inline-block;\n  text-align: center;\n  white-space: nowrap;\n  line-height: 20px;\n  min-width: ${props => (props.offPosition ? '62px' : '70px')};\n\n  ${props =>\n    props.isActive &&\n    css`\n      font-weight: 600;\n      color: ${colors.active};\n    `};\n`;\n\nexport default class Toolbar extends React.Component {\n  static propTypes = {\n    buttons: ImmutablePropTypes.list,\n    editorComponents: ImmutablePropTypes.list,\n    onToggleMode: PropTypes.func.isRequired,\n    rawMode: PropTypes.bool,\n    isShowModeToggle: PropTypes.bool.isRequired,\n    plugins: ImmutablePropTypes.map,\n    onSubmit: PropTypes.func,\n    onAddAsset: PropTypes.func,\n    getAsset: PropTypes.func,\n    disabled: PropTypes.bool,\n    onMarkClick: PropTypes.func,\n    onBlockClick: PropTypes.func,\n    onLinkClick: PropTypes.func,\n    hasMark: PropTypes.func,\n    hasInline: PropTypes.func,\n    hasBlock: PropTypes.func,\n    t: PropTypes.func.isRequired,\n  };\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(Toolbar.propTypes, this.props, 'prop', 'Toolbar');\n  }\n\n  isVisible = button => {\n    const { buttons } = this.props;\n    return !List.isList(buttons) || buttons.includes(button);\n  };\n\n  handleBlockClick = (event, type) => {\n    if (event) {\n      event.preventDefault();\n    }\n    this.props.onBlockClick(type);\n  };\n\n  handleMarkClick = (event, type) => {\n    event.preventDefault();\n    this.props.onMarkClick(type);\n  };\n\n  render() {\n    const {\n      onLinkClick,\n      onToggleMode,\n      rawMode,\n      isShowModeToggle,\n      plugins,\n      disabled,\n      onSubmit,\n      hasMark = () => {},\n      hasInline = () => {},\n      hasBlock = () => {},\n      hasQuote = () => {},\n      hasListItems = () => {},\n      editorComponents,\n      t,\n    } = this.props;\n    const isVisible = this.isVisible;\n    const showEditorComponents = !editorComponents || editorComponents.size >= 1;\n\n    function showPlugin({ id }) {\n      return editorComponents ? editorComponents.includes(id) : true;\n    }\n\n    const pluginsList = plugins ? plugins.toList().filter(showPlugin) : List();\n\n    const headingOptions = {\n      'heading-one': t('editor.editorWidgets.headingOptions.headingOne'),\n      'heading-two': t('editor.editorWidgets.headingOptions.headingTwo'),\n      'heading-three': t('editor.editorWidgets.headingOptions.headingThree'),\n      'heading-four': t('editor.editorWidgets.headingOptions.headingFour'),\n      'heading-five': t('editor.editorWidgets.headingOptions.headingFive'),\n      'heading-six': t('editor.editorWidgets.headingOptions.headingSix'),\n    };\n\n    return (\n      <ToolbarContainer>\n        <div>\n          {isVisible('bold') && (\n            <ToolbarButton\n              type=\"bold\"\n              label={t('editor.editorWidgets.markdown.bold')}\n              icon=\"bold\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('bold')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('italic') && (\n            <ToolbarButton\n              type=\"italic\"\n              label={t('editor.editorWidgets.markdown.italic')}\n              icon=\"italic\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('italic')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('code') && (\n            <ToolbarButton\n              type=\"code\"\n              label={t('editor.editorWidgets.markdown.code')}\n              icon=\"code\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('code')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('link') && (\n            <ToolbarButton\n              type=\"link\"\n              label={t('editor.editorWidgets.markdown.link')}\n              icon=\"link\"\n              onClick={onLinkClick}\n              isActive={hasInline('link')}\n              disabled={disabled}\n            />\n          )}\n          {/* Show dropdown if at least one heading is not hidden */}\n          {Object.keys(headingOptions).some(isVisible) && (\n            <ToolbarDropdownWrapper>\n              <Dropdown\n                dropdownWidth=\"max-content\"\n                dropdownTopOverlap=\"36px\"\n                renderButton={() => (\n                  <DropdownButton>\n                    <ToolbarButton\n                      type=\"headings\"\n                      label={t('editor.editorWidgets.markdown.headings')}\n                      icon=\"hOptions\"\n                      disabled={disabled}\n                      isActive={!disabled && Object.keys(headingOptions).some(hasBlock)}\n                    />\n                  </DropdownButton>\n                )}\n              >\n                {!disabled &&\n                  Object.keys(headingOptions).map(\n                    (optionKey, idx) =>\n                      isVisible(optionKey) && (\n                        <DropdownItem\n                          key={idx}\n                          label={headingOptions[optionKey]}\n                          className={hasBlock(optionKey) ? 'active' : ''}\n                          onClick={() => this.handleBlockClick(null, optionKey)}\n                        />\n                      ),\n                  )}\n              </Dropdown>\n            </ToolbarDropdownWrapper>\n          )}\n          {isVisible('quote') && (\n            <ToolbarButton\n              type=\"quote\"\n              label={t('editor.editorWidgets.markdown.quote')}\n              icon=\"quote\"\n              onClick={this.handleBlockClick}\n              isActive={hasQuote('quote')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('bulleted-list') && (\n            <ToolbarButton\n              type=\"bulleted-list\"\n              label={t('editor.editorWidgets.markdown.bulletedList')}\n              icon=\"list-bulleted\"\n              onClick={this.handleBlockClick}\n              isActive={hasListItems('bulleted-list')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('numbered-list') && (\n            <ToolbarButton\n              type=\"numbered-list\"\n              label={t('editor.editorWidgets.markdown.numberedList')}\n              icon=\"list-numbered\"\n              onClick={this.handleBlockClick}\n              isActive={hasListItems('numbered-list')}\n              disabled={disabled}\n            />\n          )}\n          {showEditorComponents && (\n            <ToolbarDropdownWrapper>\n              <Dropdown\n                dropdownTopOverlap=\"36px\"\n                dropdownWidth=\"max-content\"\n                renderButton={() => (\n                  <DropdownButton>\n                    <ToolbarButton\n                      label={t('editor.editorWidgets.markdown.addComponent')}\n                      icon=\"add-with\"\n                      onClick={this.handleComponentsMenuToggle}\n                      disabled={disabled}\n                    />\n                  </DropdownButton>\n                )}\n              >\n                {pluginsList.map((plugin, idx) => (\n                  <DropdownItem key={idx} label={plugin.label} onClick={() => onSubmit(plugin)} />\n                ))}\n              </Dropdown>\n            </ToolbarDropdownWrapper>\n          )}\n        </div>\n        {isShowModeToggle && (\n          <ToolbarToggle>\n            <ToolbarToggleLabel isActive={!rawMode} offPosition>\n              {t('editor.editorWidgets.markdown.richText')}\n            </ToolbarToggleLabel>\n            <StyledToggle active={rawMode} onChange={onToggleMode} />\n            <ToolbarToggleLabel isActive={rawMode}>\n              {t('editor.editorWidgets.markdown.markdown')}\n            </ToolbarToggleLabel>\n          </ToolbarToggle>\n        )}\n      </ToolbarContainer>\n    );\n  }\n}\n"]} */"));
14
+ })("background-color:", colors.textFieldBorder, ";border-top-right-radius:", lengths.borderRadius, ";position:relative;display:flex;justify-content:space-between;align-items:center;padding:11px 14px;min-height:58px;transition:background-color ", transitions.main, ",color ", transitions.main, ";color:", colors.text, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MarkdownControl/Toolbar.js"],"names":[],"mappings":"AAkBmC","file":"../../../src/MarkdownControl/Toolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { List } from 'immutable';\nimport {\n  Toggle,\n  Dropdown,\n  DropdownItem,\n  DropdownButton,\n  colors,\n  transitions,\n  lengths,\n} from 'decap-cms-ui-default';\n\nimport ToolbarButton from './ToolbarButton';\n\nconst ToolbarContainer = styled.div`\n  background-color: ${colors.textFieldBorder};\n  border-top-right-radius: ${lengths.borderRadius};\n  position: relative;\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: 11px 14px;\n  min-height: 58px;\n  transition: background-color ${transitions.main}, color ${transitions.main};\n  color: ${colors.text};\n`;\n\nconst ToolbarDropdownWrapper = styled.div`\n  display: inline-block;\n  position: relative;\n`;\n\nconst ToolbarToggle = styled.div`\n  flex-shrink: 0;\n  display: flex;\n  align-items: center;\n  font-size: 14px;\n  margin: 0 10px;\n`;\n\nconst StyledToggle = ToolbarToggle.withComponent(Toggle);\n\nconst ToolbarToggleLabel = styled.span`\n  display: inline-block;\n  text-align: center;\n  white-space: nowrap;\n  line-height: 20px;\n  min-width: ${props => (props.offPosition ? '62px' : '70px')};\n\n  ${props =>\n    props.isActive &&\n    css`\n      font-weight: 600;\n      color: ${colors.active};\n    `};\n`;\n\nexport default class Toolbar extends React.Component {\n  static propTypes = {\n    buttons: ImmutablePropTypes.list,\n    editorComponents: ImmutablePropTypes.list,\n    onToggleMode: PropTypes.func.isRequired,\n    rawMode: PropTypes.bool,\n    isShowModeToggle: PropTypes.bool.isRequired,\n    plugins: ImmutablePropTypes.map,\n    onSubmit: PropTypes.func,\n    onAddAsset: PropTypes.func,\n    getAsset: PropTypes.func,\n    disabled: PropTypes.bool,\n    onMarkClick: PropTypes.func,\n    onBlockClick: PropTypes.func,\n    onLinkClick: PropTypes.func,\n    hasMark: PropTypes.func,\n    hasInline: PropTypes.func,\n    hasBlock: PropTypes.func,\n    t: PropTypes.func.isRequired,\n  };\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(Toolbar.propTypes, this.props, 'prop', 'Toolbar');\n  }\n\n  isVisible = button => {\n    const { buttons } = this.props;\n    return !List.isList(buttons) || buttons.includes(button);\n  };\n\n  handleBlockClick = (event, type) => {\n    if (event) {\n      event.preventDefault();\n    }\n    this.props.onBlockClick(type);\n  };\n\n  handleMarkClick = (event, type) => {\n    event.preventDefault();\n    this.props.onMarkClick(type);\n  };\n\n  render() {\n    const {\n      onLinkClick,\n      onToggleMode,\n      rawMode,\n      isShowModeToggle,\n      plugins,\n      disabled,\n      onSubmit,\n      hasMark = () => {},\n      hasInline = () => {},\n      hasBlock = () => {},\n      hasQuote = () => {},\n      hasListItems = () => {},\n      editorComponents,\n      t,\n    } = this.props;\n    const isVisible = this.isVisible;\n    const showEditorComponents = !editorComponents || editorComponents.size >= 1;\n\n    function showPlugin({ id }) {\n      return editorComponents ? editorComponents.includes(id) : true;\n    }\n\n    const pluginsList = plugins ? plugins.toList().filter(showPlugin) : List();\n\n    const headingOptions = {\n      'heading-one': t('editor.editorWidgets.headingOptions.headingOne'),\n      'heading-two': t('editor.editorWidgets.headingOptions.headingTwo'),\n      'heading-three': t('editor.editorWidgets.headingOptions.headingThree'),\n      'heading-four': t('editor.editorWidgets.headingOptions.headingFour'),\n      'heading-five': t('editor.editorWidgets.headingOptions.headingFive'),\n      'heading-six': t('editor.editorWidgets.headingOptions.headingSix'),\n    };\n\n    return (\n      <ToolbarContainer>\n        <div>\n          {isVisible('bold') && (\n            <ToolbarButton\n              type=\"bold\"\n              label={t('editor.editorWidgets.markdown.bold')}\n              icon=\"bold\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('bold')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('italic') && (\n            <ToolbarButton\n              type=\"italic\"\n              label={t('editor.editorWidgets.markdown.italic')}\n              icon=\"italic\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('italic')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('strikethrough') && (\n            <ToolbarButton\n              type=\"strikethrough\"\n              label={t('editor.editorWidgets.markdown.strikethrough')}\n              icon=\"strikethrough\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('delete')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('code') && (\n            <ToolbarButton\n              type=\"code\"\n              label={t('editor.editorWidgets.markdown.code')}\n              icon=\"code\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('code')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('link') && (\n            <ToolbarButton\n              type=\"link\"\n              label={t('editor.editorWidgets.markdown.link')}\n              icon=\"link\"\n              onClick={onLinkClick}\n              isActive={hasInline('link')}\n              disabled={disabled}\n            />\n          )}\n          {/* Show dropdown if at least one heading is not hidden */}\n          {Object.keys(headingOptions).some(isVisible) && (\n            <ToolbarDropdownWrapper>\n              <Dropdown\n                dropdownWidth=\"max-content\"\n                dropdownTopOverlap=\"36px\"\n                renderButton={() => (\n                  <DropdownButton>\n                    <ToolbarButton\n                      type=\"headings\"\n                      label={t('editor.editorWidgets.markdown.headings')}\n                      icon=\"hOptions\"\n                      disabled={disabled}\n                      isActive={!disabled && Object.keys(headingOptions).some(hasBlock)}\n                    />\n                  </DropdownButton>\n                )}\n              >\n                {!disabled &&\n                  Object.keys(headingOptions).map(\n                    (optionKey, idx) =>\n                      isVisible(optionKey) && (\n                        <DropdownItem\n                          key={idx}\n                          label={headingOptions[optionKey]}\n                          className={hasBlock(optionKey) ? 'active' : ''}\n                          onClick={() => this.handleBlockClick(null, optionKey)}\n                        />\n                      ),\n                  )}\n              </Dropdown>\n            </ToolbarDropdownWrapper>\n          )}\n          {isVisible('quote') && (\n            <ToolbarButton\n              type=\"quote\"\n              label={t('editor.editorWidgets.markdown.quote')}\n              icon=\"quote\"\n              onClick={this.handleBlockClick}\n              isActive={hasQuote('quote')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('bulleted-list') && (\n            <ToolbarButton\n              type=\"bulleted-list\"\n              label={t('editor.editorWidgets.markdown.bulletedList')}\n              icon=\"list-bulleted\"\n              onClick={this.handleBlockClick}\n              isActive={hasListItems('bulleted-list')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('numbered-list') && (\n            <ToolbarButton\n              type=\"numbered-list\"\n              label={t('editor.editorWidgets.markdown.numberedList')}\n              icon=\"list-numbered\"\n              onClick={this.handleBlockClick}\n              isActive={hasListItems('numbered-list')}\n              disabled={disabled}\n            />\n          )}\n          {showEditorComponents && (\n            <ToolbarDropdownWrapper>\n              <Dropdown\n                dropdownTopOverlap=\"36px\"\n                dropdownWidth=\"max-content\"\n                renderButton={() => (\n                  <DropdownButton>\n                    <ToolbarButton\n                      label={t('editor.editorWidgets.markdown.addComponent')}\n                      icon=\"add-with\"\n                      onClick={this.handleComponentsMenuToggle}\n                      disabled={disabled}\n                    />\n                  </DropdownButton>\n                )}\n              >\n                {pluginsList.map((plugin, idx) => (\n                  <DropdownItem key={idx} label={plugin.label} onClick={() => onSubmit(plugin)} />\n                ))}\n              </Dropdown>\n            </ToolbarDropdownWrapper>\n          )}\n        </div>\n        {isShowModeToggle && (\n          <ToolbarToggle>\n            <ToolbarToggleLabel isActive={!rawMode} offPosition>\n              {t('editor.editorWidgets.markdown.richText')}\n            </ToolbarToggleLabel>\n            <StyledToggle active={rawMode} onChange={onToggleMode} />\n            <ToolbarToggleLabel isActive={rawMode}>\n              {t('editor.editorWidgets.markdown.markdown')}\n            </ToolbarToggleLabel>\n          </ToolbarToggle>\n        )}\n      </ToolbarContainer>\n    );\n  }\n}\n"]} */"));
15
15
  const ToolbarDropdownWrapper = /*#__PURE__*/_styled("div", {
16
16
  target: "e11cox782",
17
17
  label: "ToolbarDropdownWrapper"
@@ -20,7 +20,7 @@ const ToolbarDropdownWrapper = /*#__PURE__*/_styled("div", {
20
20
  styles: "display:inline-block;position:relative"
21
21
  } : {
22
22
  name: "11ffxfj",
23
- styles: "display:inline-block;position:relative/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MarkdownControl/Toolbar.js"],"names":[],"mappings":"AA+ByC","file":"../../../src/MarkdownControl/Toolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { List } from 'immutable';\nimport {\n  Toggle,\n  Dropdown,\n  DropdownItem,\n  DropdownButton,\n  colors,\n  transitions,\n  lengths,\n} from 'decap-cms-ui-default';\n\nimport ToolbarButton from './ToolbarButton';\n\nconst ToolbarContainer = styled.div`\n  background-color: ${colors.textFieldBorder};\n  border-top-right-radius: ${lengths.borderRadius};\n  position: relative;\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: 11px 14px;\n  min-height: 58px;\n  transition: background-color ${transitions.main}, color ${transitions.main};\n  color: ${colors.text};\n`;\n\nconst ToolbarDropdownWrapper = styled.div`\n  display: inline-block;\n  position: relative;\n`;\n\nconst ToolbarToggle = styled.div`\n  flex-shrink: 0;\n  display: flex;\n  align-items: center;\n  font-size: 14px;\n  margin: 0 10px;\n`;\n\nconst StyledToggle = ToolbarToggle.withComponent(Toggle);\n\nconst ToolbarToggleLabel = styled.span`\n  display: inline-block;\n  text-align: center;\n  white-space: nowrap;\n  line-height: 20px;\n  min-width: ${props => (props.offPosition ? '62px' : '70px')};\n\n  ${props =>\n    props.isActive &&\n    css`\n      font-weight: 600;\n      color: ${colors.active};\n    `};\n`;\n\nexport default class Toolbar extends React.Component {\n  static propTypes = {\n    buttons: ImmutablePropTypes.list,\n    editorComponents: ImmutablePropTypes.list,\n    onToggleMode: PropTypes.func.isRequired,\n    rawMode: PropTypes.bool,\n    isShowModeToggle: PropTypes.bool.isRequired,\n    plugins: ImmutablePropTypes.map,\n    onSubmit: PropTypes.func,\n    onAddAsset: PropTypes.func,\n    getAsset: PropTypes.func,\n    disabled: PropTypes.bool,\n    onMarkClick: PropTypes.func,\n    onBlockClick: PropTypes.func,\n    onLinkClick: PropTypes.func,\n    hasMark: PropTypes.func,\n    hasInline: PropTypes.func,\n    hasBlock: PropTypes.func,\n    t: PropTypes.func.isRequired,\n  };\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(Toolbar.propTypes, this.props, 'prop', 'Toolbar');\n  }\n\n  isVisible = button => {\n    const { buttons } = this.props;\n    return !List.isList(buttons) || buttons.includes(button);\n  };\n\n  handleBlockClick = (event, type) => {\n    if (event) {\n      event.preventDefault();\n    }\n    this.props.onBlockClick(type);\n  };\n\n  handleMarkClick = (event, type) => {\n    event.preventDefault();\n    this.props.onMarkClick(type);\n  };\n\n  render() {\n    const {\n      onLinkClick,\n      onToggleMode,\n      rawMode,\n      isShowModeToggle,\n      plugins,\n      disabled,\n      onSubmit,\n      hasMark = () => {},\n      hasInline = () => {},\n      hasBlock = () => {},\n      hasQuote = () => {},\n      hasListItems = () => {},\n      editorComponents,\n      t,\n    } = this.props;\n    const isVisible = this.isVisible;\n    const showEditorComponents = !editorComponents || editorComponents.size >= 1;\n\n    function showPlugin({ id }) {\n      return editorComponents ? editorComponents.includes(id) : true;\n    }\n\n    const pluginsList = plugins ? plugins.toList().filter(showPlugin) : List();\n\n    const headingOptions = {\n      'heading-one': t('editor.editorWidgets.headingOptions.headingOne'),\n      'heading-two': t('editor.editorWidgets.headingOptions.headingTwo'),\n      'heading-three': t('editor.editorWidgets.headingOptions.headingThree'),\n      'heading-four': t('editor.editorWidgets.headingOptions.headingFour'),\n      'heading-five': t('editor.editorWidgets.headingOptions.headingFive'),\n      'heading-six': t('editor.editorWidgets.headingOptions.headingSix'),\n    };\n\n    return (\n      <ToolbarContainer>\n        <div>\n          {isVisible('bold') && (\n            <ToolbarButton\n              type=\"bold\"\n              label={t('editor.editorWidgets.markdown.bold')}\n              icon=\"bold\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('bold')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('italic') && (\n            <ToolbarButton\n              type=\"italic\"\n              label={t('editor.editorWidgets.markdown.italic')}\n              icon=\"italic\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('italic')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('code') && (\n            <ToolbarButton\n              type=\"code\"\n              label={t('editor.editorWidgets.markdown.code')}\n              icon=\"code\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('code')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('link') && (\n            <ToolbarButton\n              type=\"link\"\n              label={t('editor.editorWidgets.markdown.link')}\n              icon=\"link\"\n              onClick={onLinkClick}\n              isActive={hasInline('link')}\n              disabled={disabled}\n            />\n          )}\n          {/* Show dropdown if at least one heading is not hidden */}\n          {Object.keys(headingOptions).some(isVisible) && (\n            <ToolbarDropdownWrapper>\n              <Dropdown\n                dropdownWidth=\"max-content\"\n                dropdownTopOverlap=\"36px\"\n                renderButton={() => (\n                  <DropdownButton>\n                    <ToolbarButton\n                      type=\"headings\"\n                      label={t('editor.editorWidgets.markdown.headings')}\n                      icon=\"hOptions\"\n                      disabled={disabled}\n                      isActive={!disabled && Object.keys(headingOptions).some(hasBlock)}\n                    />\n                  </DropdownButton>\n                )}\n              >\n                {!disabled &&\n                  Object.keys(headingOptions).map(\n                    (optionKey, idx) =>\n                      isVisible(optionKey) && (\n                        <DropdownItem\n                          key={idx}\n                          label={headingOptions[optionKey]}\n                          className={hasBlock(optionKey) ? 'active' : ''}\n                          onClick={() => this.handleBlockClick(null, optionKey)}\n                        />\n                      ),\n                  )}\n              </Dropdown>\n            </ToolbarDropdownWrapper>\n          )}\n          {isVisible('quote') && (\n            <ToolbarButton\n              type=\"quote\"\n              label={t('editor.editorWidgets.markdown.quote')}\n              icon=\"quote\"\n              onClick={this.handleBlockClick}\n              isActive={hasQuote('quote')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('bulleted-list') && (\n            <ToolbarButton\n              type=\"bulleted-list\"\n              label={t('editor.editorWidgets.markdown.bulletedList')}\n              icon=\"list-bulleted\"\n              onClick={this.handleBlockClick}\n              isActive={hasListItems('bulleted-list')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('numbered-list') && (\n            <ToolbarButton\n              type=\"numbered-list\"\n              label={t('editor.editorWidgets.markdown.numberedList')}\n              icon=\"list-numbered\"\n              onClick={this.handleBlockClick}\n              isActive={hasListItems('numbered-list')}\n              disabled={disabled}\n            />\n          )}\n          {showEditorComponents && (\n            <ToolbarDropdownWrapper>\n              <Dropdown\n                dropdownTopOverlap=\"36px\"\n                dropdownWidth=\"max-content\"\n                renderButton={() => (\n                  <DropdownButton>\n                    <ToolbarButton\n                      label={t('editor.editorWidgets.markdown.addComponent')}\n                      icon=\"add-with\"\n                      onClick={this.handleComponentsMenuToggle}\n                      disabled={disabled}\n                    />\n                  </DropdownButton>\n                )}\n              >\n                {pluginsList.map((plugin, idx) => (\n                  <DropdownItem key={idx} label={plugin.label} onClick={() => onSubmit(plugin)} />\n                ))}\n              </Dropdown>\n            </ToolbarDropdownWrapper>\n          )}\n        </div>\n        {isShowModeToggle && (\n          <ToolbarToggle>\n            <ToolbarToggleLabel isActive={!rawMode} offPosition>\n              {t('editor.editorWidgets.markdown.richText')}\n            </ToolbarToggleLabel>\n            <StyledToggle active={rawMode} onChange={onToggleMode} />\n            <ToolbarToggleLabel isActive={rawMode}>\n              {t('editor.editorWidgets.markdown.markdown')}\n            </ToolbarToggleLabel>\n          </ToolbarToggle>\n        )}\n      </ToolbarContainer>\n    );\n  }\n}\n"]} */",
23
+ styles: "display:inline-block;position:relative/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MarkdownControl/Toolbar.js"],"names":[],"mappings":"AA+ByC","file":"../../../src/MarkdownControl/Toolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { List } from 'immutable';\nimport {\n  Toggle,\n  Dropdown,\n  DropdownItem,\n  DropdownButton,\n  colors,\n  transitions,\n  lengths,\n} from 'decap-cms-ui-default';\n\nimport ToolbarButton from './ToolbarButton';\n\nconst ToolbarContainer = styled.div`\n  background-color: ${colors.textFieldBorder};\n  border-top-right-radius: ${lengths.borderRadius};\n  position: relative;\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: 11px 14px;\n  min-height: 58px;\n  transition: background-color ${transitions.main}, color ${transitions.main};\n  color: ${colors.text};\n`;\n\nconst ToolbarDropdownWrapper = styled.div`\n  display: inline-block;\n  position: relative;\n`;\n\nconst ToolbarToggle = styled.div`\n  flex-shrink: 0;\n  display: flex;\n  align-items: center;\n  font-size: 14px;\n  margin: 0 10px;\n`;\n\nconst StyledToggle = ToolbarToggle.withComponent(Toggle);\n\nconst ToolbarToggleLabel = styled.span`\n  display: inline-block;\n  text-align: center;\n  white-space: nowrap;\n  line-height: 20px;\n  min-width: ${props => (props.offPosition ? '62px' : '70px')};\n\n  ${props =>\n    props.isActive &&\n    css`\n      font-weight: 600;\n      color: ${colors.active};\n    `};\n`;\n\nexport default class Toolbar extends React.Component {\n  static propTypes = {\n    buttons: ImmutablePropTypes.list,\n    editorComponents: ImmutablePropTypes.list,\n    onToggleMode: PropTypes.func.isRequired,\n    rawMode: PropTypes.bool,\n    isShowModeToggle: PropTypes.bool.isRequired,\n    plugins: ImmutablePropTypes.map,\n    onSubmit: PropTypes.func,\n    onAddAsset: PropTypes.func,\n    getAsset: PropTypes.func,\n    disabled: PropTypes.bool,\n    onMarkClick: PropTypes.func,\n    onBlockClick: PropTypes.func,\n    onLinkClick: PropTypes.func,\n    hasMark: PropTypes.func,\n    hasInline: PropTypes.func,\n    hasBlock: PropTypes.func,\n    t: PropTypes.func.isRequired,\n  };\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(Toolbar.propTypes, this.props, 'prop', 'Toolbar');\n  }\n\n  isVisible = button => {\n    const { buttons } = this.props;\n    return !List.isList(buttons) || buttons.includes(button);\n  };\n\n  handleBlockClick = (event, type) => {\n    if (event) {\n      event.preventDefault();\n    }\n    this.props.onBlockClick(type);\n  };\n\n  handleMarkClick = (event, type) => {\n    event.preventDefault();\n    this.props.onMarkClick(type);\n  };\n\n  render() {\n    const {\n      onLinkClick,\n      onToggleMode,\n      rawMode,\n      isShowModeToggle,\n      plugins,\n      disabled,\n      onSubmit,\n      hasMark = () => {},\n      hasInline = () => {},\n      hasBlock = () => {},\n      hasQuote = () => {},\n      hasListItems = () => {},\n      editorComponents,\n      t,\n    } = this.props;\n    const isVisible = this.isVisible;\n    const showEditorComponents = !editorComponents || editorComponents.size >= 1;\n\n    function showPlugin({ id }) {\n      return editorComponents ? editorComponents.includes(id) : true;\n    }\n\n    const pluginsList = plugins ? plugins.toList().filter(showPlugin) : List();\n\n    const headingOptions = {\n      'heading-one': t('editor.editorWidgets.headingOptions.headingOne'),\n      'heading-two': t('editor.editorWidgets.headingOptions.headingTwo'),\n      'heading-three': t('editor.editorWidgets.headingOptions.headingThree'),\n      'heading-four': t('editor.editorWidgets.headingOptions.headingFour'),\n      'heading-five': t('editor.editorWidgets.headingOptions.headingFive'),\n      'heading-six': t('editor.editorWidgets.headingOptions.headingSix'),\n    };\n\n    return (\n      <ToolbarContainer>\n        <div>\n          {isVisible('bold') && (\n            <ToolbarButton\n              type=\"bold\"\n              label={t('editor.editorWidgets.markdown.bold')}\n              icon=\"bold\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('bold')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('italic') && (\n            <ToolbarButton\n              type=\"italic\"\n              label={t('editor.editorWidgets.markdown.italic')}\n              icon=\"italic\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('italic')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('strikethrough') && (\n            <ToolbarButton\n              type=\"strikethrough\"\n              label={t('editor.editorWidgets.markdown.strikethrough')}\n              icon=\"strikethrough\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('delete')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('code') && (\n            <ToolbarButton\n              type=\"code\"\n              label={t('editor.editorWidgets.markdown.code')}\n              icon=\"code\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('code')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('link') && (\n            <ToolbarButton\n              type=\"link\"\n              label={t('editor.editorWidgets.markdown.link')}\n              icon=\"link\"\n              onClick={onLinkClick}\n              isActive={hasInline('link')}\n              disabled={disabled}\n            />\n          )}\n          {/* Show dropdown if at least one heading is not hidden */}\n          {Object.keys(headingOptions).some(isVisible) && (\n            <ToolbarDropdownWrapper>\n              <Dropdown\n                dropdownWidth=\"max-content\"\n                dropdownTopOverlap=\"36px\"\n                renderButton={() => (\n                  <DropdownButton>\n                    <ToolbarButton\n                      type=\"headings\"\n                      label={t('editor.editorWidgets.markdown.headings')}\n                      icon=\"hOptions\"\n                      disabled={disabled}\n                      isActive={!disabled && Object.keys(headingOptions).some(hasBlock)}\n                    />\n                  </DropdownButton>\n                )}\n              >\n                {!disabled &&\n                  Object.keys(headingOptions).map(\n                    (optionKey, idx) =>\n                      isVisible(optionKey) && (\n                        <DropdownItem\n                          key={idx}\n                          label={headingOptions[optionKey]}\n                          className={hasBlock(optionKey) ? 'active' : ''}\n                          onClick={() => this.handleBlockClick(null, optionKey)}\n                        />\n                      ),\n                  )}\n              </Dropdown>\n            </ToolbarDropdownWrapper>\n          )}\n          {isVisible('quote') && (\n            <ToolbarButton\n              type=\"quote\"\n              label={t('editor.editorWidgets.markdown.quote')}\n              icon=\"quote\"\n              onClick={this.handleBlockClick}\n              isActive={hasQuote('quote')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('bulleted-list') && (\n            <ToolbarButton\n              type=\"bulleted-list\"\n              label={t('editor.editorWidgets.markdown.bulletedList')}\n              icon=\"list-bulleted\"\n              onClick={this.handleBlockClick}\n              isActive={hasListItems('bulleted-list')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('numbered-list') && (\n            <ToolbarButton\n              type=\"numbered-list\"\n              label={t('editor.editorWidgets.markdown.numberedList')}\n              icon=\"list-numbered\"\n              onClick={this.handleBlockClick}\n              isActive={hasListItems('numbered-list')}\n              disabled={disabled}\n            />\n          )}\n          {showEditorComponents && (\n            <ToolbarDropdownWrapper>\n              <Dropdown\n                dropdownTopOverlap=\"36px\"\n                dropdownWidth=\"max-content\"\n                renderButton={() => (\n                  <DropdownButton>\n                    <ToolbarButton\n                      label={t('editor.editorWidgets.markdown.addComponent')}\n                      icon=\"add-with\"\n                      onClick={this.handleComponentsMenuToggle}\n                      disabled={disabled}\n                    />\n                  </DropdownButton>\n                )}\n              >\n                {pluginsList.map((plugin, idx) => (\n                  <DropdownItem key={idx} label={plugin.label} onClick={() => onSubmit(plugin)} />\n                ))}\n              </Dropdown>\n            </ToolbarDropdownWrapper>\n          )}\n        </div>\n        {isShowModeToggle && (\n          <ToolbarToggle>\n            <ToolbarToggleLabel isActive={!rawMode} offPosition>\n              {t('editor.editorWidgets.markdown.richText')}\n            </ToolbarToggleLabel>\n            <StyledToggle active={rawMode} onChange={onToggleMode} />\n            <ToolbarToggleLabel isActive={rawMode}>\n              {t('editor.editorWidgets.markdown.markdown')}\n            </ToolbarToggleLabel>\n          </ToolbarToggle>\n        )}\n      </ToolbarContainer>\n    );\n  }\n}\n"]} */",
24
24
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
25
25
  });
26
26
  const ToolbarToggle = /*#__PURE__*/_styled("div", {
@@ -31,7 +31,7 @@ const ToolbarToggle = /*#__PURE__*/_styled("div", {
31
31
  styles: "flex-shrink:0;display:flex;align-items:center;font-size:14px;margin:0 10px"
32
32
  } : {
33
33
  name: "1qi6e7n",
34
- styles: "flex-shrink:0;display:flex;align-items:center;font-size:14px;margin:0 10px/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MarkdownControl/Toolbar.js"],"names":[],"mappings":"AAoCgC","file":"../../../src/MarkdownControl/Toolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { List } from 'immutable';\nimport {\n  Toggle,\n  Dropdown,\n  DropdownItem,\n  DropdownButton,\n  colors,\n  transitions,\n  lengths,\n} from 'decap-cms-ui-default';\n\nimport ToolbarButton from './ToolbarButton';\n\nconst ToolbarContainer = styled.div`\n  background-color: ${colors.textFieldBorder};\n  border-top-right-radius: ${lengths.borderRadius};\n  position: relative;\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: 11px 14px;\n  min-height: 58px;\n  transition: background-color ${transitions.main}, color ${transitions.main};\n  color: ${colors.text};\n`;\n\nconst ToolbarDropdownWrapper = styled.div`\n  display: inline-block;\n  position: relative;\n`;\n\nconst ToolbarToggle = styled.div`\n  flex-shrink: 0;\n  display: flex;\n  align-items: center;\n  font-size: 14px;\n  margin: 0 10px;\n`;\n\nconst StyledToggle = ToolbarToggle.withComponent(Toggle);\n\nconst ToolbarToggleLabel = styled.span`\n  display: inline-block;\n  text-align: center;\n  white-space: nowrap;\n  line-height: 20px;\n  min-width: ${props => (props.offPosition ? '62px' : '70px')};\n\n  ${props =>\n    props.isActive &&\n    css`\n      font-weight: 600;\n      color: ${colors.active};\n    `};\n`;\n\nexport default class Toolbar extends React.Component {\n  static propTypes = {\n    buttons: ImmutablePropTypes.list,\n    editorComponents: ImmutablePropTypes.list,\n    onToggleMode: PropTypes.func.isRequired,\n    rawMode: PropTypes.bool,\n    isShowModeToggle: PropTypes.bool.isRequired,\n    plugins: ImmutablePropTypes.map,\n    onSubmit: PropTypes.func,\n    onAddAsset: PropTypes.func,\n    getAsset: PropTypes.func,\n    disabled: PropTypes.bool,\n    onMarkClick: PropTypes.func,\n    onBlockClick: PropTypes.func,\n    onLinkClick: PropTypes.func,\n    hasMark: PropTypes.func,\n    hasInline: PropTypes.func,\n    hasBlock: PropTypes.func,\n    t: PropTypes.func.isRequired,\n  };\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(Toolbar.propTypes, this.props, 'prop', 'Toolbar');\n  }\n\n  isVisible = button => {\n    const { buttons } = this.props;\n    return !List.isList(buttons) || buttons.includes(button);\n  };\n\n  handleBlockClick = (event, type) => {\n    if (event) {\n      event.preventDefault();\n    }\n    this.props.onBlockClick(type);\n  };\n\n  handleMarkClick = (event, type) => {\n    event.preventDefault();\n    this.props.onMarkClick(type);\n  };\n\n  render() {\n    const {\n      onLinkClick,\n      onToggleMode,\n      rawMode,\n      isShowModeToggle,\n      plugins,\n      disabled,\n      onSubmit,\n      hasMark = () => {},\n      hasInline = () => {},\n      hasBlock = () => {},\n      hasQuote = () => {},\n      hasListItems = () => {},\n      editorComponents,\n      t,\n    } = this.props;\n    const isVisible = this.isVisible;\n    const showEditorComponents = !editorComponents || editorComponents.size >= 1;\n\n    function showPlugin({ id }) {\n      return editorComponents ? editorComponents.includes(id) : true;\n    }\n\n    const pluginsList = plugins ? plugins.toList().filter(showPlugin) : List();\n\n    const headingOptions = {\n      'heading-one': t('editor.editorWidgets.headingOptions.headingOne'),\n      'heading-two': t('editor.editorWidgets.headingOptions.headingTwo'),\n      'heading-three': t('editor.editorWidgets.headingOptions.headingThree'),\n      'heading-four': t('editor.editorWidgets.headingOptions.headingFour'),\n      'heading-five': t('editor.editorWidgets.headingOptions.headingFive'),\n      'heading-six': t('editor.editorWidgets.headingOptions.headingSix'),\n    };\n\n    return (\n      <ToolbarContainer>\n        <div>\n          {isVisible('bold') && (\n            <ToolbarButton\n              type=\"bold\"\n              label={t('editor.editorWidgets.markdown.bold')}\n              icon=\"bold\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('bold')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('italic') && (\n            <ToolbarButton\n              type=\"italic\"\n              label={t('editor.editorWidgets.markdown.italic')}\n              icon=\"italic\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('italic')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('code') && (\n            <ToolbarButton\n              type=\"code\"\n              label={t('editor.editorWidgets.markdown.code')}\n              icon=\"code\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('code')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('link') && (\n            <ToolbarButton\n              type=\"link\"\n              label={t('editor.editorWidgets.markdown.link')}\n              icon=\"link\"\n              onClick={onLinkClick}\n              isActive={hasInline('link')}\n              disabled={disabled}\n            />\n          )}\n          {/* Show dropdown if at least one heading is not hidden */}\n          {Object.keys(headingOptions).some(isVisible) && (\n            <ToolbarDropdownWrapper>\n              <Dropdown\n                dropdownWidth=\"max-content\"\n                dropdownTopOverlap=\"36px\"\n                renderButton={() => (\n                  <DropdownButton>\n                    <ToolbarButton\n                      type=\"headings\"\n                      label={t('editor.editorWidgets.markdown.headings')}\n                      icon=\"hOptions\"\n                      disabled={disabled}\n                      isActive={!disabled && Object.keys(headingOptions).some(hasBlock)}\n                    />\n                  </DropdownButton>\n                )}\n              >\n                {!disabled &&\n                  Object.keys(headingOptions).map(\n                    (optionKey, idx) =>\n                      isVisible(optionKey) && (\n                        <DropdownItem\n                          key={idx}\n                          label={headingOptions[optionKey]}\n                          className={hasBlock(optionKey) ? 'active' : ''}\n                          onClick={() => this.handleBlockClick(null, optionKey)}\n                        />\n                      ),\n                  )}\n              </Dropdown>\n            </ToolbarDropdownWrapper>\n          )}\n          {isVisible('quote') && (\n            <ToolbarButton\n              type=\"quote\"\n              label={t('editor.editorWidgets.markdown.quote')}\n              icon=\"quote\"\n              onClick={this.handleBlockClick}\n              isActive={hasQuote('quote')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('bulleted-list') && (\n            <ToolbarButton\n              type=\"bulleted-list\"\n              label={t('editor.editorWidgets.markdown.bulletedList')}\n              icon=\"list-bulleted\"\n              onClick={this.handleBlockClick}\n              isActive={hasListItems('bulleted-list')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('numbered-list') && (\n            <ToolbarButton\n              type=\"numbered-list\"\n              label={t('editor.editorWidgets.markdown.numberedList')}\n              icon=\"list-numbered\"\n              onClick={this.handleBlockClick}\n              isActive={hasListItems('numbered-list')}\n              disabled={disabled}\n            />\n          )}\n          {showEditorComponents && (\n            <ToolbarDropdownWrapper>\n              <Dropdown\n                dropdownTopOverlap=\"36px\"\n                dropdownWidth=\"max-content\"\n                renderButton={() => (\n                  <DropdownButton>\n                    <ToolbarButton\n                      label={t('editor.editorWidgets.markdown.addComponent')}\n                      icon=\"add-with\"\n                      onClick={this.handleComponentsMenuToggle}\n                      disabled={disabled}\n                    />\n                  </DropdownButton>\n                )}\n              >\n                {pluginsList.map((plugin, idx) => (\n                  <DropdownItem key={idx} label={plugin.label} onClick={() => onSubmit(plugin)} />\n                ))}\n              </Dropdown>\n            </ToolbarDropdownWrapper>\n          )}\n        </div>\n        {isShowModeToggle && (\n          <ToolbarToggle>\n            <ToolbarToggleLabel isActive={!rawMode} offPosition>\n              {t('editor.editorWidgets.markdown.richText')}\n            </ToolbarToggleLabel>\n            <StyledToggle active={rawMode} onChange={onToggleMode} />\n            <ToolbarToggleLabel isActive={rawMode}>\n              {t('editor.editorWidgets.markdown.markdown')}\n            </ToolbarToggleLabel>\n          </ToolbarToggle>\n        )}\n      </ToolbarContainer>\n    );\n  }\n}\n"]} */",
34
+ styles: "flex-shrink:0;display:flex;align-items:center;font-size:14px;margin:0 10px/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MarkdownControl/Toolbar.js"],"names":[],"mappings":"AAoCgC","file":"../../../src/MarkdownControl/Toolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { List } from 'immutable';\nimport {\n  Toggle,\n  Dropdown,\n  DropdownItem,\n  DropdownButton,\n  colors,\n  transitions,\n  lengths,\n} from 'decap-cms-ui-default';\n\nimport ToolbarButton from './ToolbarButton';\n\nconst ToolbarContainer = styled.div`\n  background-color: ${colors.textFieldBorder};\n  border-top-right-radius: ${lengths.borderRadius};\n  position: relative;\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: 11px 14px;\n  min-height: 58px;\n  transition: background-color ${transitions.main}, color ${transitions.main};\n  color: ${colors.text};\n`;\n\nconst ToolbarDropdownWrapper = styled.div`\n  display: inline-block;\n  position: relative;\n`;\n\nconst ToolbarToggle = styled.div`\n  flex-shrink: 0;\n  display: flex;\n  align-items: center;\n  font-size: 14px;\n  margin: 0 10px;\n`;\n\nconst StyledToggle = ToolbarToggle.withComponent(Toggle);\n\nconst ToolbarToggleLabel = styled.span`\n  display: inline-block;\n  text-align: center;\n  white-space: nowrap;\n  line-height: 20px;\n  min-width: ${props => (props.offPosition ? '62px' : '70px')};\n\n  ${props =>\n    props.isActive &&\n    css`\n      font-weight: 600;\n      color: ${colors.active};\n    `};\n`;\n\nexport default class Toolbar extends React.Component {\n  static propTypes = {\n    buttons: ImmutablePropTypes.list,\n    editorComponents: ImmutablePropTypes.list,\n    onToggleMode: PropTypes.func.isRequired,\n    rawMode: PropTypes.bool,\n    isShowModeToggle: PropTypes.bool.isRequired,\n    plugins: ImmutablePropTypes.map,\n    onSubmit: PropTypes.func,\n    onAddAsset: PropTypes.func,\n    getAsset: PropTypes.func,\n    disabled: PropTypes.bool,\n    onMarkClick: PropTypes.func,\n    onBlockClick: PropTypes.func,\n    onLinkClick: PropTypes.func,\n    hasMark: PropTypes.func,\n    hasInline: PropTypes.func,\n    hasBlock: PropTypes.func,\n    t: PropTypes.func.isRequired,\n  };\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(Toolbar.propTypes, this.props, 'prop', 'Toolbar');\n  }\n\n  isVisible = button => {\n    const { buttons } = this.props;\n    return !List.isList(buttons) || buttons.includes(button);\n  };\n\n  handleBlockClick = (event, type) => {\n    if (event) {\n      event.preventDefault();\n    }\n    this.props.onBlockClick(type);\n  };\n\n  handleMarkClick = (event, type) => {\n    event.preventDefault();\n    this.props.onMarkClick(type);\n  };\n\n  render() {\n    const {\n      onLinkClick,\n      onToggleMode,\n      rawMode,\n      isShowModeToggle,\n      plugins,\n      disabled,\n      onSubmit,\n      hasMark = () => {},\n      hasInline = () => {},\n      hasBlock = () => {},\n      hasQuote = () => {},\n      hasListItems = () => {},\n      editorComponents,\n      t,\n    } = this.props;\n    const isVisible = this.isVisible;\n    const showEditorComponents = !editorComponents || editorComponents.size >= 1;\n\n    function showPlugin({ id }) {\n      return editorComponents ? editorComponents.includes(id) : true;\n    }\n\n    const pluginsList = plugins ? plugins.toList().filter(showPlugin) : List();\n\n    const headingOptions = {\n      'heading-one': t('editor.editorWidgets.headingOptions.headingOne'),\n      'heading-two': t('editor.editorWidgets.headingOptions.headingTwo'),\n      'heading-three': t('editor.editorWidgets.headingOptions.headingThree'),\n      'heading-four': t('editor.editorWidgets.headingOptions.headingFour'),\n      'heading-five': t('editor.editorWidgets.headingOptions.headingFive'),\n      'heading-six': t('editor.editorWidgets.headingOptions.headingSix'),\n    };\n\n    return (\n      <ToolbarContainer>\n        <div>\n          {isVisible('bold') && (\n            <ToolbarButton\n              type=\"bold\"\n              label={t('editor.editorWidgets.markdown.bold')}\n              icon=\"bold\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('bold')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('italic') && (\n            <ToolbarButton\n              type=\"italic\"\n              label={t('editor.editorWidgets.markdown.italic')}\n              icon=\"italic\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('italic')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('strikethrough') && (\n            <ToolbarButton\n              type=\"strikethrough\"\n              label={t('editor.editorWidgets.markdown.strikethrough')}\n              icon=\"strikethrough\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('delete')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('code') && (\n            <ToolbarButton\n              type=\"code\"\n              label={t('editor.editorWidgets.markdown.code')}\n              icon=\"code\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('code')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('link') && (\n            <ToolbarButton\n              type=\"link\"\n              label={t('editor.editorWidgets.markdown.link')}\n              icon=\"link\"\n              onClick={onLinkClick}\n              isActive={hasInline('link')}\n              disabled={disabled}\n            />\n          )}\n          {/* Show dropdown if at least one heading is not hidden */}\n          {Object.keys(headingOptions).some(isVisible) && (\n            <ToolbarDropdownWrapper>\n              <Dropdown\n                dropdownWidth=\"max-content\"\n                dropdownTopOverlap=\"36px\"\n                renderButton={() => (\n                  <DropdownButton>\n                    <ToolbarButton\n                      type=\"headings\"\n                      label={t('editor.editorWidgets.markdown.headings')}\n                      icon=\"hOptions\"\n                      disabled={disabled}\n                      isActive={!disabled && Object.keys(headingOptions).some(hasBlock)}\n                    />\n                  </DropdownButton>\n                )}\n              >\n                {!disabled &&\n                  Object.keys(headingOptions).map(\n                    (optionKey, idx) =>\n                      isVisible(optionKey) && (\n                        <DropdownItem\n                          key={idx}\n                          label={headingOptions[optionKey]}\n                          className={hasBlock(optionKey) ? 'active' : ''}\n                          onClick={() => this.handleBlockClick(null, optionKey)}\n                        />\n                      ),\n                  )}\n              </Dropdown>\n            </ToolbarDropdownWrapper>\n          )}\n          {isVisible('quote') && (\n            <ToolbarButton\n              type=\"quote\"\n              label={t('editor.editorWidgets.markdown.quote')}\n              icon=\"quote\"\n              onClick={this.handleBlockClick}\n              isActive={hasQuote('quote')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('bulleted-list') && (\n            <ToolbarButton\n              type=\"bulleted-list\"\n              label={t('editor.editorWidgets.markdown.bulletedList')}\n              icon=\"list-bulleted\"\n              onClick={this.handleBlockClick}\n              isActive={hasListItems('bulleted-list')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('numbered-list') && (\n            <ToolbarButton\n              type=\"numbered-list\"\n              label={t('editor.editorWidgets.markdown.numberedList')}\n              icon=\"list-numbered\"\n              onClick={this.handleBlockClick}\n              isActive={hasListItems('numbered-list')}\n              disabled={disabled}\n            />\n          )}\n          {showEditorComponents && (\n            <ToolbarDropdownWrapper>\n              <Dropdown\n                dropdownTopOverlap=\"36px\"\n                dropdownWidth=\"max-content\"\n                renderButton={() => (\n                  <DropdownButton>\n                    <ToolbarButton\n                      label={t('editor.editorWidgets.markdown.addComponent')}\n                      icon=\"add-with\"\n                      onClick={this.handleComponentsMenuToggle}\n                      disabled={disabled}\n                    />\n                  </DropdownButton>\n                )}\n              >\n                {pluginsList.map((plugin, idx) => (\n                  <DropdownItem key={idx} label={plugin.label} onClick={() => onSubmit(plugin)} />\n                ))}\n              </Dropdown>\n            </ToolbarDropdownWrapper>\n          )}\n        </div>\n        {isShowModeToggle && (\n          <ToolbarToggle>\n            <ToolbarToggleLabel isActive={!rawMode} offPosition>\n              {t('editor.editorWidgets.markdown.richText')}\n            </ToolbarToggleLabel>\n            <StyledToggle active={rawMode} onChange={onToggleMode} />\n            <ToolbarToggleLabel isActive={rawMode}>\n              {t('editor.editorWidgets.markdown.markdown')}\n            </ToolbarToggleLabel>\n          </ToolbarToggle>\n        )}\n      </ToolbarContainer>\n    );\n  }\n}\n"]} */",
35
35
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
36
36
  });
37
37
  const StyledToggle = ToolbarToggle.withComponent(Toggle, {
@@ -41,7 +41,7 @@ const StyledToggle = ToolbarToggle.withComponent(Toggle, {
41
41
  const ToolbarToggleLabel = /*#__PURE__*/_styled("span", {
42
42
  target: "e11cox780",
43
43
  label: "ToolbarToggleLabel"
44
- })("display:inline-block;text-align:center;white-space:nowrap;line-height:20px;min-width:", props => props.offPosition ? '62px' : '70px', ";", props => props.isActive && /*#__PURE__*/css("font-weight:600;color:", colors.active, ";;label:ToolbarToggleLabel;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MarkdownControl/Toolbar.js"],"names":[],"mappings":"AAuDO","file":"../../../src/MarkdownControl/Toolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { List } from 'immutable';\nimport {\n  Toggle,\n  Dropdown,\n  DropdownItem,\n  DropdownButton,\n  colors,\n  transitions,\n  lengths,\n} from 'decap-cms-ui-default';\n\nimport ToolbarButton from './ToolbarButton';\n\nconst ToolbarContainer = styled.div`\n  background-color: ${colors.textFieldBorder};\n  border-top-right-radius: ${lengths.borderRadius};\n  position: relative;\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: 11px 14px;\n  min-height: 58px;\n  transition: background-color ${transitions.main}, color ${transitions.main};\n  color: ${colors.text};\n`;\n\nconst ToolbarDropdownWrapper = styled.div`\n  display: inline-block;\n  position: relative;\n`;\n\nconst ToolbarToggle = styled.div`\n  flex-shrink: 0;\n  display: flex;\n  align-items: center;\n  font-size: 14px;\n  margin: 0 10px;\n`;\n\nconst StyledToggle = ToolbarToggle.withComponent(Toggle);\n\nconst ToolbarToggleLabel = styled.span`\n  display: inline-block;\n  text-align: center;\n  white-space: nowrap;\n  line-height: 20px;\n  min-width: ${props => (props.offPosition ? '62px' : '70px')};\n\n  ${props =>\n    props.isActive &&\n    css`\n      font-weight: 600;\n      color: ${colors.active};\n    `};\n`;\n\nexport default class Toolbar extends React.Component {\n  static propTypes = {\n    buttons: ImmutablePropTypes.list,\n    editorComponents: ImmutablePropTypes.list,\n    onToggleMode: PropTypes.func.isRequired,\n    rawMode: PropTypes.bool,\n    isShowModeToggle: PropTypes.bool.isRequired,\n    plugins: ImmutablePropTypes.map,\n    onSubmit: PropTypes.func,\n    onAddAsset: PropTypes.func,\n    getAsset: PropTypes.func,\n    disabled: PropTypes.bool,\n    onMarkClick: PropTypes.func,\n    onBlockClick: PropTypes.func,\n    onLinkClick: PropTypes.func,\n    hasMark: PropTypes.func,\n    hasInline: PropTypes.func,\n    hasBlock: PropTypes.func,\n    t: PropTypes.func.isRequired,\n  };\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(Toolbar.propTypes, this.props, 'prop', 'Toolbar');\n  }\n\n  isVisible = button => {\n    const { buttons } = this.props;\n    return !List.isList(buttons) || buttons.includes(button);\n  };\n\n  handleBlockClick = (event, type) => {\n    if (event) {\n      event.preventDefault();\n    }\n    this.props.onBlockClick(type);\n  };\n\n  handleMarkClick = (event, type) => {\n    event.preventDefault();\n    this.props.onMarkClick(type);\n  };\n\n  render() {\n    const {\n      onLinkClick,\n      onToggleMode,\n      rawMode,\n      isShowModeToggle,\n      plugins,\n      disabled,\n      onSubmit,\n      hasMark = () => {},\n      hasInline = () => {},\n      hasBlock = () => {},\n      hasQuote = () => {},\n      hasListItems = () => {},\n      editorComponents,\n      t,\n    } = this.props;\n    const isVisible = this.isVisible;\n    const showEditorComponents = !editorComponents || editorComponents.size >= 1;\n\n    function showPlugin({ id }) {\n      return editorComponents ? editorComponents.includes(id) : true;\n    }\n\n    const pluginsList = plugins ? plugins.toList().filter(showPlugin) : List();\n\n    const headingOptions = {\n      'heading-one': t('editor.editorWidgets.headingOptions.headingOne'),\n      'heading-two': t('editor.editorWidgets.headingOptions.headingTwo'),\n      'heading-three': t('editor.editorWidgets.headingOptions.headingThree'),\n      'heading-four': t('editor.editorWidgets.headingOptions.headingFour'),\n      'heading-five': t('editor.editorWidgets.headingOptions.headingFive'),\n      'heading-six': t('editor.editorWidgets.headingOptions.headingSix'),\n    };\n\n    return (\n      <ToolbarContainer>\n        <div>\n          {isVisible('bold') && (\n            <ToolbarButton\n              type=\"bold\"\n              label={t('editor.editorWidgets.markdown.bold')}\n              icon=\"bold\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('bold')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('italic') && (\n            <ToolbarButton\n              type=\"italic\"\n              label={t('editor.editorWidgets.markdown.italic')}\n              icon=\"italic\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('italic')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('code') && (\n            <ToolbarButton\n              type=\"code\"\n              label={t('editor.editorWidgets.markdown.code')}\n              icon=\"code\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('code')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('link') && (\n            <ToolbarButton\n              type=\"link\"\n              label={t('editor.editorWidgets.markdown.link')}\n              icon=\"link\"\n              onClick={onLinkClick}\n              isActive={hasInline('link')}\n              disabled={disabled}\n            />\n          )}\n          {/* Show dropdown if at least one heading is not hidden */}\n          {Object.keys(headingOptions).some(isVisible) && (\n            <ToolbarDropdownWrapper>\n              <Dropdown\n                dropdownWidth=\"max-content\"\n                dropdownTopOverlap=\"36px\"\n                renderButton={() => (\n                  <DropdownButton>\n                    <ToolbarButton\n                      type=\"headings\"\n                      label={t('editor.editorWidgets.markdown.headings')}\n                      icon=\"hOptions\"\n                      disabled={disabled}\n                      isActive={!disabled && Object.keys(headingOptions).some(hasBlock)}\n                    />\n                  </DropdownButton>\n                )}\n              >\n                {!disabled &&\n                  Object.keys(headingOptions).map(\n                    (optionKey, idx) =>\n                      isVisible(optionKey) && (\n                        <DropdownItem\n                          key={idx}\n                          label={headingOptions[optionKey]}\n                          className={hasBlock(optionKey) ? 'active' : ''}\n                          onClick={() => this.handleBlockClick(null, optionKey)}\n                        />\n                      ),\n                  )}\n              </Dropdown>\n            </ToolbarDropdownWrapper>\n          )}\n          {isVisible('quote') && (\n            <ToolbarButton\n              type=\"quote\"\n              label={t('editor.editorWidgets.markdown.quote')}\n              icon=\"quote\"\n              onClick={this.handleBlockClick}\n              isActive={hasQuote('quote')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('bulleted-list') && (\n            <ToolbarButton\n              type=\"bulleted-list\"\n              label={t('editor.editorWidgets.markdown.bulletedList')}\n              icon=\"list-bulleted\"\n              onClick={this.handleBlockClick}\n              isActive={hasListItems('bulleted-list')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('numbered-list') && (\n            <ToolbarButton\n              type=\"numbered-list\"\n              label={t('editor.editorWidgets.markdown.numberedList')}\n              icon=\"list-numbered\"\n              onClick={this.handleBlockClick}\n              isActive={hasListItems('numbered-list')}\n              disabled={disabled}\n            />\n          )}\n          {showEditorComponents && (\n            <ToolbarDropdownWrapper>\n              <Dropdown\n                dropdownTopOverlap=\"36px\"\n                dropdownWidth=\"max-content\"\n                renderButton={() => (\n                  <DropdownButton>\n                    <ToolbarButton\n                      label={t('editor.editorWidgets.markdown.addComponent')}\n                      icon=\"add-with\"\n                      onClick={this.handleComponentsMenuToggle}\n                      disabled={disabled}\n                    />\n                  </DropdownButton>\n                )}\n              >\n                {pluginsList.map((plugin, idx) => (\n                  <DropdownItem key={idx} label={plugin.label} onClick={() => onSubmit(plugin)} />\n                ))}\n              </Dropdown>\n            </ToolbarDropdownWrapper>\n          )}\n        </div>\n        {isShowModeToggle && (\n          <ToolbarToggle>\n            <ToolbarToggleLabel isActive={!rawMode} offPosition>\n              {t('editor.editorWidgets.markdown.richText')}\n            </ToolbarToggleLabel>\n            <StyledToggle active={rawMode} onChange={onToggleMode} />\n            <ToolbarToggleLabel isActive={rawMode}>\n              {t('editor.editorWidgets.markdown.markdown')}\n            </ToolbarToggleLabel>\n          </ToolbarToggle>\n        )}\n      </ToolbarContainer>\n    );\n  }\n}\n"]} */")), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MarkdownControl/Toolbar.js"],"names":[],"mappings":"AA8CsC","file":"../../../src/MarkdownControl/Toolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { List } from 'immutable';\nimport {\n  Toggle,\n  Dropdown,\n  DropdownItem,\n  DropdownButton,\n  colors,\n  transitions,\n  lengths,\n} from 'decap-cms-ui-default';\n\nimport ToolbarButton from './ToolbarButton';\n\nconst ToolbarContainer = styled.div`\n  background-color: ${colors.textFieldBorder};\n  border-top-right-radius: ${lengths.borderRadius};\n  position: relative;\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: 11px 14px;\n  min-height: 58px;\n  transition: background-color ${transitions.main}, color ${transitions.main};\n  color: ${colors.text};\n`;\n\nconst ToolbarDropdownWrapper = styled.div`\n  display: inline-block;\n  position: relative;\n`;\n\nconst ToolbarToggle = styled.div`\n  flex-shrink: 0;\n  display: flex;\n  align-items: center;\n  font-size: 14px;\n  margin: 0 10px;\n`;\n\nconst StyledToggle = ToolbarToggle.withComponent(Toggle);\n\nconst ToolbarToggleLabel = styled.span`\n  display: inline-block;\n  text-align: center;\n  white-space: nowrap;\n  line-height: 20px;\n  min-width: ${props => (props.offPosition ? '62px' : '70px')};\n\n  ${props =>\n    props.isActive &&\n    css`\n      font-weight: 600;\n      color: ${colors.active};\n    `};\n`;\n\nexport default class Toolbar extends React.Component {\n  static propTypes = {\n    buttons: ImmutablePropTypes.list,\n    editorComponents: ImmutablePropTypes.list,\n    onToggleMode: PropTypes.func.isRequired,\n    rawMode: PropTypes.bool,\n    isShowModeToggle: PropTypes.bool.isRequired,\n    plugins: ImmutablePropTypes.map,\n    onSubmit: PropTypes.func,\n    onAddAsset: PropTypes.func,\n    getAsset: PropTypes.func,\n    disabled: PropTypes.bool,\n    onMarkClick: PropTypes.func,\n    onBlockClick: PropTypes.func,\n    onLinkClick: PropTypes.func,\n    hasMark: PropTypes.func,\n    hasInline: PropTypes.func,\n    hasBlock: PropTypes.func,\n    t: PropTypes.func.isRequired,\n  };\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(Toolbar.propTypes, this.props, 'prop', 'Toolbar');\n  }\n\n  isVisible = button => {\n    const { buttons } = this.props;\n    return !List.isList(buttons) || buttons.includes(button);\n  };\n\n  handleBlockClick = (event, type) => {\n    if (event) {\n      event.preventDefault();\n    }\n    this.props.onBlockClick(type);\n  };\n\n  handleMarkClick = (event, type) => {\n    event.preventDefault();\n    this.props.onMarkClick(type);\n  };\n\n  render() {\n    const {\n      onLinkClick,\n      onToggleMode,\n      rawMode,\n      isShowModeToggle,\n      plugins,\n      disabled,\n      onSubmit,\n      hasMark = () => {},\n      hasInline = () => {},\n      hasBlock = () => {},\n      hasQuote = () => {},\n      hasListItems = () => {},\n      editorComponents,\n      t,\n    } = this.props;\n    const isVisible = this.isVisible;\n    const showEditorComponents = !editorComponents || editorComponents.size >= 1;\n\n    function showPlugin({ id }) {\n      return editorComponents ? editorComponents.includes(id) : true;\n    }\n\n    const pluginsList = plugins ? plugins.toList().filter(showPlugin) : List();\n\n    const headingOptions = {\n      'heading-one': t('editor.editorWidgets.headingOptions.headingOne'),\n      'heading-two': t('editor.editorWidgets.headingOptions.headingTwo'),\n      'heading-three': t('editor.editorWidgets.headingOptions.headingThree'),\n      'heading-four': t('editor.editorWidgets.headingOptions.headingFour'),\n      'heading-five': t('editor.editorWidgets.headingOptions.headingFive'),\n      'heading-six': t('editor.editorWidgets.headingOptions.headingSix'),\n    };\n\n    return (\n      <ToolbarContainer>\n        <div>\n          {isVisible('bold') && (\n            <ToolbarButton\n              type=\"bold\"\n              label={t('editor.editorWidgets.markdown.bold')}\n              icon=\"bold\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('bold')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('italic') && (\n            <ToolbarButton\n              type=\"italic\"\n              label={t('editor.editorWidgets.markdown.italic')}\n              icon=\"italic\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('italic')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('code') && (\n            <ToolbarButton\n              type=\"code\"\n              label={t('editor.editorWidgets.markdown.code')}\n              icon=\"code\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('code')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('link') && (\n            <ToolbarButton\n              type=\"link\"\n              label={t('editor.editorWidgets.markdown.link')}\n              icon=\"link\"\n              onClick={onLinkClick}\n              isActive={hasInline('link')}\n              disabled={disabled}\n            />\n          )}\n          {/* Show dropdown if at least one heading is not hidden */}\n          {Object.keys(headingOptions).some(isVisible) && (\n            <ToolbarDropdownWrapper>\n              <Dropdown\n                dropdownWidth=\"max-content\"\n                dropdownTopOverlap=\"36px\"\n                renderButton={() => (\n                  <DropdownButton>\n                    <ToolbarButton\n                      type=\"headings\"\n                      label={t('editor.editorWidgets.markdown.headings')}\n                      icon=\"hOptions\"\n                      disabled={disabled}\n                      isActive={!disabled && Object.keys(headingOptions).some(hasBlock)}\n                    />\n                  </DropdownButton>\n                )}\n              >\n                {!disabled &&\n                  Object.keys(headingOptions).map(\n                    (optionKey, idx) =>\n                      isVisible(optionKey) && (\n                        <DropdownItem\n                          key={idx}\n                          label={headingOptions[optionKey]}\n                          className={hasBlock(optionKey) ? 'active' : ''}\n                          onClick={() => this.handleBlockClick(null, optionKey)}\n                        />\n                      ),\n                  )}\n              </Dropdown>\n            </ToolbarDropdownWrapper>\n          )}\n          {isVisible('quote') && (\n            <ToolbarButton\n              type=\"quote\"\n              label={t('editor.editorWidgets.markdown.quote')}\n              icon=\"quote\"\n              onClick={this.handleBlockClick}\n              isActive={hasQuote('quote')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('bulleted-list') && (\n            <ToolbarButton\n              type=\"bulleted-list\"\n              label={t('editor.editorWidgets.markdown.bulletedList')}\n              icon=\"list-bulleted\"\n              onClick={this.handleBlockClick}\n              isActive={hasListItems('bulleted-list')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('numbered-list') && (\n            <ToolbarButton\n              type=\"numbered-list\"\n              label={t('editor.editorWidgets.markdown.numberedList')}\n              icon=\"list-numbered\"\n              onClick={this.handleBlockClick}\n              isActive={hasListItems('numbered-list')}\n              disabled={disabled}\n            />\n          )}\n          {showEditorComponents && (\n            <ToolbarDropdownWrapper>\n              <Dropdown\n                dropdownTopOverlap=\"36px\"\n                dropdownWidth=\"max-content\"\n                renderButton={() => (\n                  <DropdownButton>\n                    <ToolbarButton\n                      label={t('editor.editorWidgets.markdown.addComponent')}\n                      icon=\"add-with\"\n                      onClick={this.handleComponentsMenuToggle}\n                      disabled={disabled}\n                    />\n                  </DropdownButton>\n                )}\n              >\n                {pluginsList.map((plugin, idx) => (\n                  <DropdownItem key={idx} label={plugin.label} onClick={() => onSubmit(plugin)} />\n                ))}\n              </Dropdown>\n            </ToolbarDropdownWrapper>\n          )}\n        </div>\n        {isShowModeToggle && (\n          <ToolbarToggle>\n            <ToolbarToggleLabel isActive={!rawMode} offPosition>\n              {t('editor.editorWidgets.markdown.richText')}\n            </ToolbarToggleLabel>\n            <StyledToggle active={rawMode} onChange={onToggleMode} />\n            <ToolbarToggleLabel isActive={rawMode}>\n              {t('editor.editorWidgets.markdown.markdown')}\n            </ToolbarToggleLabel>\n          </ToolbarToggle>\n        )}\n      </ToolbarContainer>\n    );\n  }\n}\n"]} */"));
44
+ })("display:inline-block;text-align:center;white-space:nowrap;line-height:20px;min-width:", props => props.offPosition ? '62px' : '70px', ";", props => props.isActive && /*#__PURE__*/css("font-weight:600;color:", colors.active, ";;label:ToolbarToggleLabel;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MarkdownControl/Toolbar.js"],"names":[],"mappings":"AAuDO","file":"../../../src/MarkdownControl/Toolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { List } from 'immutable';\nimport {\n  Toggle,\n  Dropdown,\n  DropdownItem,\n  DropdownButton,\n  colors,\n  transitions,\n  lengths,\n} from 'decap-cms-ui-default';\n\nimport ToolbarButton from './ToolbarButton';\n\nconst ToolbarContainer = styled.div`\n  background-color: ${colors.textFieldBorder};\n  border-top-right-radius: ${lengths.borderRadius};\n  position: relative;\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: 11px 14px;\n  min-height: 58px;\n  transition: background-color ${transitions.main}, color ${transitions.main};\n  color: ${colors.text};\n`;\n\nconst ToolbarDropdownWrapper = styled.div`\n  display: inline-block;\n  position: relative;\n`;\n\nconst ToolbarToggle = styled.div`\n  flex-shrink: 0;\n  display: flex;\n  align-items: center;\n  font-size: 14px;\n  margin: 0 10px;\n`;\n\nconst StyledToggle = ToolbarToggle.withComponent(Toggle);\n\nconst ToolbarToggleLabel = styled.span`\n  display: inline-block;\n  text-align: center;\n  white-space: nowrap;\n  line-height: 20px;\n  min-width: ${props => (props.offPosition ? '62px' : '70px')};\n\n  ${props =>\n    props.isActive &&\n    css`\n      font-weight: 600;\n      color: ${colors.active};\n    `};\n`;\n\nexport default class Toolbar extends React.Component {\n  static propTypes = {\n    buttons: ImmutablePropTypes.list,\n    editorComponents: ImmutablePropTypes.list,\n    onToggleMode: PropTypes.func.isRequired,\n    rawMode: PropTypes.bool,\n    isShowModeToggle: PropTypes.bool.isRequired,\n    plugins: ImmutablePropTypes.map,\n    onSubmit: PropTypes.func,\n    onAddAsset: PropTypes.func,\n    getAsset: PropTypes.func,\n    disabled: PropTypes.bool,\n    onMarkClick: PropTypes.func,\n    onBlockClick: PropTypes.func,\n    onLinkClick: PropTypes.func,\n    hasMark: PropTypes.func,\n    hasInline: PropTypes.func,\n    hasBlock: PropTypes.func,\n    t: PropTypes.func.isRequired,\n  };\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(Toolbar.propTypes, this.props, 'prop', 'Toolbar');\n  }\n\n  isVisible = button => {\n    const { buttons } = this.props;\n    return !List.isList(buttons) || buttons.includes(button);\n  };\n\n  handleBlockClick = (event, type) => {\n    if (event) {\n      event.preventDefault();\n    }\n    this.props.onBlockClick(type);\n  };\n\n  handleMarkClick = (event, type) => {\n    event.preventDefault();\n    this.props.onMarkClick(type);\n  };\n\n  render() {\n    const {\n      onLinkClick,\n      onToggleMode,\n      rawMode,\n      isShowModeToggle,\n      plugins,\n      disabled,\n      onSubmit,\n      hasMark = () => {},\n      hasInline = () => {},\n      hasBlock = () => {},\n      hasQuote = () => {},\n      hasListItems = () => {},\n      editorComponents,\n      t,\n    } = this.props;\n    const isVisible = this.isVisible;\n    const showEditorComponents = !editorComponents || editorComponents.size >= 1;\n\n    function showPlugin({ id }) {\n      return editorComponents ? editorComponents.includes(id) : true;\n    }\n\n    const pluginsList = plugins ? plugins.toList().filter(showPlugin) : List();\n\n    const headingOptions = {\n      'heading-one': t('editor.editorWidgets.headingOptions.headingOne'),\n      'heading-two': t('editor.editorWidgets.headingOptions.headingTwo'),\n      'heading-three': t('editor.editorWidgets.headingOptions.headingThree'),\n      'heading-four': t('editor.editorWidgets.headingOptions.headingFour'),\n      'heading-five': t('editor.editorWidgets.headingOptions.headingFive'),\n      'heading-six': t('editor.editorWidgets.headingOptions.headingSix'),\n    };\n\n    return (\n      <ToolbarContainer>\n        <div>\n          {isVisible('bold') && (\n            <ToolbarButton\n              type=\"bold\"\n              label={t('editor.editorWidgets.markdown.bold')}\n              icon=\"bold\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('bold')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('italic') && (\n            <ToolbarButton\n              type=\"italic\"\n              label={t('editor.editorWidgets.markdown.italic')}\n              icon=\"italic\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('italic')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('strikethrough') && (\n            <ToolbarButton\n              type=\"strikethrough\"\n              label={t('editor.editorWidgets.markdown.strikethrough')}\n              icon=\"strikethrough\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('delete')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('code') && (\n            <ToolbarButton\n              type=\"code\"\n              label={t('editor.editorWidgets.markdown.code')}\n              icon=\"code\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('code')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('link') && (\n            <ToolbarButton\n              type=\"link\"\n              label={t('editor.editorWidgets.markdown.link')}\n              icon=\"link\"\n              onClick={onLinkClick}\n              isActive={hasInline('link')}\n              disabled={disabled}\n            />\n          )}\n          {/* Show dropdown if at least one heading is not hidden */}\n          {Object.keys(headingOptions).some(isVisible) && (\n            <ToolbarDropdownWrapper>\n              <Dropdown\n                dropdownWidth=\"max-content\"\n                dropdownTopOverlap=\"36px\"\n                renderButton={() => (\n                  <DropdownButton>\n                    <ToolbarButton\n                      type=\"headings\"\n                      label={t('editor.editorWidgets.markdown.headings')}\n                      icon=\"hOptions\"\n                      disabled={disabled}\n                      isActive={!disabled && Object.keys(headingOptions).some(hasBlock)}\n                    />\n                  </DropdownButton>\n                )}\n              >\n                {!disabled &&\n                  Object.keys(headingOptions).map(\n                    (optionKey, idx) =>\n                      isVisible(optionKey) && (\n                        <DropdownItem\n                          key={idx}\n                          label={headingOptions[optionKey]}\n                          className={hasBlock(optionKey) ? 'active' : ''}\n                          onClick={() => this.handleBlockClick(null, optionKey)}\n                        />\n                      ),\n                  )}\n              </Dropdown>\n            </ToolbarDropdownWrapper>\n          )}\n          {isVisible('quote') && (\n            <ToolbarButton\n              type=\"quote\"\n              label={t('editor.editorWidgets.markdown.quote')}\n              icon=\"quote\"\n              onClick={this.handleBlockClick}\n              isActive={hasQuote('quote')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('bulleted-list') && (\n            <ToolbarButton\n              type=\"bulleted-list\"\n              label={t('editor.editorWidgets.markdown.bulletedList')}\n              icon=\"list-bulleted\"\n              onClick={this.handleBlockClick}\n              isActive={hasListItems('bulleted-list')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('numbered-list') && (\n            <ToolbarButton\n              type=\"numbered-list\"\n              label={t('editor.editorWidgets.markdown.numberedList')}\n              icon=\"list-numbered\"\n              onClick={this.handleBlockClick}\n              isActive={hasListItems('numbered-list')}\n              disabled={disabled}\n            />\n          )}\n          {showEditorComponents && (\n            <ToolbarDropdownWrapper>\n              <Dropdown\n                dropdownTopOverlap=\"36px\"\n                dropdownWidth=\"max-content\"\n                renderButton={() => (\n                  <DropdownButton>\n                    <ToolbarButton\n                      label={t('editor.editorWidgets.markdown.addComponent')}\n                      icon=\"add-with\"\n                      onClick={this.handleComponentsMenuToggle}\n                      disabled={disabled}\n                    />\n                  </DropdownButton>\n                )}\n              >\n                {pluginsList.map((plugin, idx) => (\n                  <DropdownItem key={idx} label={plugin.label} onClick={() => onSubmit(plugin)} />\n                ))}\n              </Dropdown>\n            </ToolbarDropdownWrapper>\n          )}\n        </div>\n        {isShowModeToggle && (\n          <ToolbarToggle>\n            <ToolbarToggleLabel isActive={!rawMode} offPosition>\n              {t('editor.editorWidgets.markdown.richText')}\n            </ToolbarToggleLabel>\n            <StyledToggle active={rawMode} onChange={onToggleMode} />\n            <ToolbarToggleLabel isActive={rawMode}>\n              {t('editor.editorWidgets.markdown.markdown')}\n            </ToolbarToggleLabel>\n          </ToolbarToggle>\n        )}\n      </ToolbarContainer>\n    );\n  }\n}\n"]} */")), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MarkdownControl/Toolbar.js"],"names":[],"mappings":"AA8CsC","file":"../../../src/MarkdownControl/Toolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { List } from 'immutable';\nimport {\n  Toggle,\n  Dropdown,\n  DropdownItem,\n  DropdownButton,\n  colors,\n  transitions,\n  lengths,\n} from 'decap-cms-ui-default';\n\nimport ToolbarButton from './ToolbarButton';\n\nconst ToolbarContainer = styled.div`\n  background-color: ${colors.textFieldBorder};\n  border-top-right-radius: ${lengths.borderRadius};\n  position: relative;\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: 11px 14px;\n  min-height: 58px;\n  transition: background-color ${transitions.main}, color ${transitions.main};\n  color: ${colors.text};\n`;\n\nconst ToolbarDropdownWrapper = styled.div`\n  display: inline-block;\n  position: relative;\n`;\n\nconst ToolbarToggle = styled.div`\n  flex-shrink: 0;\n  display: flex;\n  align-items: center;\n  font-size: 14px;\n  margin: 0 10px;\n`;\n\nconst StyledToggle = ToolbarToggle.withComponent(Toggle);\n\nconst ToolbarToggleLabel = styled.span`\n  display: inline-block;\n  text-align: center;\n  white-space: nowrap;\n  line-height: 20px;\n  min-width: ${props => (props.offPosition ? '62px' : '70px')};\n\n  ${props =>\n    props.isActive &&\n    css`\n      font-weight: 600;\n      color: ${colors.active};\n    `};\n`;\n\nexport default class Toolbar extends React.Component {\n  static propTypes = {\n    buttons: ImmutablePropTypes.list,\n    editorComponents: ImmutablePropTypes.list,\n    onToggleMode: PropTypes.func.isRequired,\n    rawMode: PropTypes.bool,\n    isShowModeToggle: PropTypes.bool.isRequired,\n    plugins: ImmutablePropTypes.map,\n    onSubmit: PropTypes.func,\n    onAddAsset: PropTypes.func,\n    getAsset: PropTypes.func,\n    disabled: PropTypes.bool,\n    onMarkClick: PropTypes.func,\n    onBlockClick: PropTypes.func,\n    onLinkClick: PropTypes.func,\n    hasMark: PropTypes.func,\n    hasInline: PropTypes.func,\n    hasBlock: PropTypes.func,\n    t: PropTypes.func.isRequired,\n  };\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(Toolbar.propTypes, this.props, 'prop', 'Toolbar');\n  }\n\n  isVisible = button => {\n    const { buttons } = this.props;\n    return !List.isList(buttons) || buttons.includes(button);\n  };\n\n  handleBlockClick = (event, type) => {\n    if (event) {\n      event.preventDefault();\n    }\n    this.props.onBlockClick(type);\n  };\n\n  handleMarkClick = (event, type) => {\n    event.preventDefault();\n    this.props.onMarkClick(type);\n  };\n\n  render() {\n    const {\n      onLinkClick,\n      onToggleMode,\n      rawMode,\n      isShowModeToggle,\n      plugins,\n      disabled,\n      onSubmit,\n      hasMark = () => {},\n      hasInline = () => {},\n      hasBlock = () => {},\n      hasQuote = () => {},\n      hasListItems = () => {},\n      editorComponents,\n      t,\n    } = this.props;\n    const isVisible = this.isVisible;\n    const showEditorComponents = !editorComponents || editorComponents.size >= 1;\n\n    function showPlugin({ id }) {\n      return editorComponents ? editorComponents.includes(id) : true;\n    }\n\n    const pluginsList = plugins ? plugins.toList().filter(showPlugin) : List();\n\n    const headingOptions = {\n      'heading-one': t('editor.editorWidgets.headingOptions.headingOne'),\n      'heading-two': t('editor.editorWidgets.headingOptions.headingTwo'),\n      'heading-three': t('editor.editorWidgets.headingOptions.headingThree'),\n      'heading-four': t('editor.editorWidgets.headingOptions.headingFour'),\n      'heading-five': t('editor.editorWidgets.headingOptions.headingFive'),\n      'heading-six': t('editor.editorWidgets.headingOptions.headingSix'),\n    };\n\n    return (\n      <ToolbarContainer>\n        <div>\n          {isVisible('bold') && (\n            <ToolbarButton\n              type=\"bold\"\n              label={t('editor.editorWidgets.markdown.bold')}\n              icon=\"bold\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('bold')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('italic') && (\n            <ToolbarButton\n              type=\"italic\"\n              label={t('editor.editorWidgets.markdown.italic')}\n              icon=\"italic\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('italic')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('strikethrough') && (\n            <ToolbarButton\n              type=\"strikethrough\"\n              label={t('editor.editorWidgets.markdown.strikethrough')}\n              icon=\"strikethrough\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('delete')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('code') && (\n            <ToolbarButton\n              type=\"code\"\n              label={t('editor.editorWidgets.markdown.code')}\n              icon=\"code\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('code')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('link') && (\n            <ToolbarButton\n              type=\"link\"\n              label={t('editor.editorWidgets.markdown.link')}\n              icon=\"link\"\n              onClick={onLinkClick}\n              isActive={hasInline('link')}\n              disabled={disabled}\n            />\n          )}\n          {/* Show dropdown if at least one heading is not hidden */}\n          {Object.keys(headingOptions).some(isVisible) && (\n            <ToolbarDropdownWrapper>\n              <Dropdown\n                dropdownWidth=\"max-content\"\n                dropdownTopOverlap=\"36px\"\n                renderButton={() => (\n                  <DropdownButton>\n                    <ToolbarButton\n                      type=\"headings\"\n                      label={t('editor.editorWidgets.markdown.headings')}\n                      icon=\"hOptions\"\n                      disabled={disabled}\n                      isActive={!disabled && Object.keys(headingOptions).some(hasBlock)}\n                    />\n                  </DropdownButton>\n                )}\n              >\n                {!disabled &&\n                  Object.keys(headingOptions).map(\n                    (optionKey, idx) =>\n                      isVisible(optionKey) && (\n                        <DropdownItem\n                          key={idx}\n                          label={headingOptions[optionKey]}\n                          className={hasBlock(optionKey) ? 'active' : ''}\n                          onClick={() => this.handleBlockClick(null, optionKey)}\n                        />\n                      ),\n                  )}\n              </Dropdown>\n            </ToolbarDropdownWrapper>\n          )}\n          {isVisible('quote') && (\n            <ToolbarButton\n              type=\"quote\"\n              label={t('editor.editorWidgets.markdown.quote')}\n              icon=\"quote\"\n              onClick={this.handleBlockClick}\n              isActive={hasQuote('quote')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('bulleted-list') && (\n            <ToolbarButton\n              type=\"bulleted-list\"\n              label={t('editor.editorWidgets.markdown.bulletedList')}\n              icon=\"list-bulleted\"\n              onClick={this.handleBlockClick}\n              isActive={hasListItems('bulleted-list')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('numbered-list') && (\n            <ToolbarButton\n              type=\"numbered-list\"\n              label={t('editor.editorWidgets.markdown.numberedList')}\n              icon=\"list-numbered\"\n              onClick={this.handleBlockClick}\n              isActive={hasListItems('numbered-list')}\n              disabled={disabled}\n            />\n          )}\n          {showEditorComponents && (\n            <ToolbarDropdownWrapper>\n              <Dropdown\n                dropdownTopOverlap=\"36px\"\n                dropdownWidth=\"max-content\"\n                renderButton={() => (\n                  <DropdownButton>\n                    <ToolbarButton\n                      label={t('editor.editorWidgets.markdown.addComponent')}\n                      icon=\"add-with\"\n                      onClick={this.handleComponentsMenuToggle}\n                      disabled={disabled}\n                    />\n                  </DropdownButton>\n                )}\n              >\n                {pluginsList.map((plugin, idx) => (\n                  <DropdownItem key={idx} label={plugin.label} onClick={() => onSubmit(plugin)} />\n                ))}\n              </Dropdown>\n            </ToolbarDropdownWrapper>\n          )}\n        </div>\n        {isShowModeToggle && (\n          <ToolbarToggle>\n            <ToolbarToggleLabel isActive={!rawMode} offPosition>\n              {t('editor.editorWidgets.markdown.richText')}\n            </ToolbarToggleLabel>\n            <StyledToggle active={rawMode} onChange={onToggleMode} />\n            <ToolbarToggleLabel isActive={rawMode}>\n              {t('editor.editorWidgets.markdown.markdown')}\n            </ToolbarToggleLabel>\n          </ToolbarToggle>\n        )}\n      </ToolbarContainer>\n    );\n  }\n}\n"]} */"));
45
45
  export default class Toolbar extends React.Component {
46
46
  static propTypes = {
47
47
  buttons: ImmutablePropTypes.list,
@@ -129,6 +129,13 @@ export default class Toolbar extends React.Component {
129
129
  onClick: this.handleMarkClick,
130
130
  isActive: hasMark('italic'),
131
131
  disabled: disabled
132
+ }), isVisible('strikethrough') && ___EmotionJSX(ToolbarButton, {
133
+ type: "strikethrough",
134
+ label: t('editor.editorWidgets.markdown.strikethrough'),
135
+ icon: "strikethrough",
136
+ onClick: this.handleMarkClick,
137
+ isActive: hasMark('delete'),
138
+ disabled: disabled
132
139
  }), isVisible('code') && ___EmotionJSX(ToolbarButton, {
133
140
  type: "code",
134
141
  label: t('editor.editorWidgets.markdown.code'),
@@ -55,7 +55,7 @@ const InsertionPoint = /*#__PURE__*/_styled("div", {
55
55
  styles: "flex:1 1 auto;cursor:text"
56
56
  } : {
57
57
  name: "ma7xbc",
58
- styles: "flex:1 1 auto;cursor:text/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MarkdownControl/VisualEditor.js"],"names":[],"mappings":"AA+CiC","file":"../../../src/MarkdownControl/VisualEditor.js","sourcesContent":["// @refresh reset\nimport React, { useCallback, useEffect, useMemo, useState } from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { ClassNames, css as coreCss } from '@emotion/react';\nimport { lengths, fonts, zIndex } from 'decap-cms-ui-default';\nimport styled from '@emotion/styled';\nimport { createEditor, Transforms, Editor as SlateEditor } from 'slate';\nimport { Editable, ReactEditor, Slate, withReact } from 'slate-react';\nimport { withHistory } from 'slate-history';\nimport { fromJS } from 'immutable';\nimport isEqual from 'lodash/isEqual';\n\nimport { editorStyleVars, EditorControlBar } from '../styles';\nimport Toolbar from './Toolbar';\nimport { Element, Leaf } from './renderers';\nimport withLists from './plugins/lists/withLists';\nimport withBlocks from './plugins/blocks/withBlocks';\nimport withInlines from './plugins/inlines/withInlines';\nimport toggleMark from './plugins/inlines/events/toggleMark';\nimport toggleLink from './plugins/inlines/events/toggleLink';\nimport getActiveLink from './plugins/inlines/selectors/getActiveLink';\nimport isMarkActive from './plugins/inlines/locations/isMarkActive';\nimport isCursorInBlockType from './plugins/blocks/locations/isCursorInBlockType';\nimport { markdownToSlate, slateToMarkdown } from '../serializers';\nimport withShortcodes from './plugins/shortcodes/withShortcodes';\nimport insertShortcode from './plugins/shortcodes/insertShortcode';\nimport defaultEmptyBlock from './plugins/blocks/defaultEmptyBlock';\nimport withHtml from './plugins/html/withHtml';\n\nfunction visualEditorStyles({ minimal }) {\n  return `\n  position: relative;\n  overflow: auto;\n  font-family: ${fonts.primary};\n  min-height: ${minimal ? 'auto' : lengths.richTextEditorMinHeight};\n  border-top-left-radius: 0;\n  border-top-right-radius: 0;\n  border-top: 0;\n  margin-top: -${editorStyleVars.stickyDistanceBottom};\n  padding: 0;\n  display: flex;\n  flex-direction: column;\n  z-index: ${zIndex.zIndex100};\n`;\n}\n\nconst InsertionPoint = styled.div`\n  flex: 1 1 auto;\n  cursor: text;\n`;\n\nexport function mergeMediaConfig(editorComponents, field) {\n  // merge editor media library config to image components\n  if (editorComponents.has('image')) {\n    const imageComponent = editorComponents.get('image');\n    const fields = imageComponent?.fields;\n\n    if (fields) {\n      imageComponent.fields = fields.update(\n        fields.findIndex(f => f.get('widget') === 'image'),\n        f => {\n          // merge `media_library` config\n          if (field.has('media_library')) {\n            f = f.set(\n              'media_library',\n              field.get('media_library').mergeDeep(f.get('media_library')),\n            );\n          }\n          // merge 'media_folder'\n          if (field.has('media_folder') && !f.has('media_folder')) {\n            f = f.set('media_folder', field.get('media_folder'));\n          }\n          // merge 'public_folder'\n          if (field.has('public_folder') && !f.has('public_folder')) {\n            f = f.set('public_folder', field.get('public_folder'));\n          }\n          return f;\n        },\n      );\n    }\n  }\n}\n\nfunction Editor(props) {\n  const {\n    onAddAsset,\n    getAsset,\n    className,\n    field,\n    isShowModeToggle,\n    t,\n    isDisabled,\n    getEditorComponents,\n    getRemarkPlugins,\n    onChange,\n  } = props;\n\n  const editor = useMemo(\n    () =>\n      withHtml(\n        withReact(withHistory(withShortcodes(withBlocks(withLists(withInlines(createEditor())))))),\n      ),\n    [],\n  );\n\n  const emptyValue = [defaultEmptyBlock()];\n  let editorComponents = getEditorComponents();\n  const codeBlockComponent = fromJS(editorComponents.find(({ type }) => type === 'code-block'));\n\n  editorComponents =\n    codeBlockComponent || editorComponents.has('code-block')\n      ? editorComponents\n      : editorComponents.set('code-block', { label: 'Code Block', type: 'code-block' });\n\n  mergeMediaConfig(editorComponents, field);\n\n  const [editorValue, setEditorValue] = useState(\n    props.value\n      ? markdownToSlate(props.value, {\n          voidCodeBlock: !!codeBlockComponent,\n          remarkPlugins: getRemarkPlugins(),\n        })\n      : emptyValue,\n  );\n\n  const renderElement = useCallback(\n    props => (\n      <Element {...props} classNameWrapper={className} codeBlockComponent={codeBlockComponent} />\n    ),\n    [],\n  );\n  const renderLeaf = useCallback(props => <Leaf {...props} />, []);\n\n  useEffect(() => {\n    if (props.pendingFocus) {\n      ReactEditor.focus(editor);\n      props.pendingFocus();\n    }\n  }, [props.pendingFocus]);\n\n  function handleMarkClick(format) {\n    ReactEditor.focus(editor);\n    toggleMark(editor, format);\n  }\n\n  function handleBlockClick(format) {\n    ReactEditor.focus(editor);\n    if (format.endsWith('-list')) {\n      editor.toggleList(format);\n    } else {\n      editor.toggleBlock(format);\n    }\n  }\n\n  function handleLinkClick() {\n    toggleLink(editor, t('editor.editorWidgets.markdown.linkPrompt'));\n    ReactEditor.focus(editor);\n  }\n\n  function handleToggleMode() {\n    props.onMode('raw');\n  }\n\n  function handleInsertShortcode(pluginConfig) {\n    insertShortcode(editor, pluginConfig);\n  }\n\n  function handleKeyDown(event) {\n    for (const handler of editor.keyDownHandlers || []) {\n      if (handler(event, editor) === false) {\n        break;\n      }\n    }\n    ReactEditor.focus(editor);\n  }\n\n  function handleClickBelowDocument() {\n    ReactEditor.focus(editor);\n    Transforms.select(editor, { path: [0, 0], offset: 0 });\n    Transforms.select(editor, SlateEditor.end(editor, []));\n  }\n  const [toolbarKey, setToolbarKey] = useState(0);\n\n  function handleChange(newValue) {\n    if (!isEqual(newValue, editorValue)) {\n      setEditorValue(() => newValue);\n      onChange(\n        slateToMarkdown(newValue, {\n          voidCodeBlock: !!codeBlockComponent,\n          remarkPlugins: getRemarkPlugins(),\n        }),\n      );\n    }\n    setToolbarKey(prev => prev + 1);\n  }\n\n  function hasMark(format) {\n    return isMarkActive(editor, format);\n  }\n\n  function hasInline(format) {\n    if (format == 'link') {\n      return !!getActiveLink(editor);\n    }\n    return false;\n  }\n\n  function hasBlock(format) {\n    return isCursorInBlockType(editor, format);\n  }\n  function hasQuote() {\n    return isCursorInBlockType(editor, 'quote');\n  }\n  function hasListItems(type) {\n    return isCursorInBlockType(editor, type);\n  }\n\n  return (\n    <div\n      css={coreCss`\n        position: relative;\n      `}\n    >\n      <Slate editor={editor} value={editorValue} onChange={handleChange}>\n        <EditorControlBar>\n          {\n            <Toolbar\n              key={toolbarKey}\n              onMarkClick={handleMarkClick}\n              onBlockClick={handleBlockClick}\n              onLinkClick={handleLinkClick}\n              onToggleMode={handleToggleMode}\n              plugins={editorComponents}\n              onSubmit={handleInsertShortcode}\n              onAddAsset={onAddAsset}\n              getAsset={getAsset}\n              buttons={field.get('buttons')}\n              editorComponents={field.get('editor_components')}\n              hasMark={hasMark}\n              hasInline={hasInline}\n              hasBlock={hasBlock}\n              hasQuote={hasQuote}\n              hasListItems={hasListItems}\n              isShowModeToggle={isShowModeToggle}\n              t={t}\n              disabled={isDisabled}\n            />\n          }\n        </EditorControlBar>\n        {\n          <ClassNames>\n            {({ css, cx }) => (\n              <div\n                className={cx(\n                  className,\n                  css`\n                    ${visualEditorStyles({ minimal: field.get('minimal') })}\n                  `,\n                )}\n              >\n                {editorValue.length !== 0 && (\n                  <Editable\n                    className={css`\n                      padding: 16px 20px 0;\n                    `}\n                    renderElement={renderElement}\n                    renderLeaf={renderLeaf}\n                    onKeyDown={handleKeyDown}\n                    autoFocus={false}\n                  />\n                )}\n                <InsertionPoint onClick={handleClickBelowDocument} />\n              </div>\n            )}\n          </ClassNames>\n        }\n      </Slate>\n    </div>\n  );\n}\n\nEditor.propTypes = {\n  onAddAsset: PropTypes.func.isRequired,\n  getAsset: PropTypes.func.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onMode: PropTypes.func.isRequired,\n  className: PropTypes.string.isRequired,\n  value: PropTypes.string,\n  field: ImmutablePropTypes.map.isRequired,\n  getEditorComponents: PropTypes.func.isRequired,\n  getRemarkPlugins: PropTypes.func.isRequired,\n  isShowModeToggle: PropTypes.bool.isRequired,\n  t: PropTypes.func.isRequired,\n};\n\nexport default Editor;\n"]} */",
58
+ styles: "flex:1 1 auto;cursor:text/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MarkdownControl/VisualEditor.js"],"names":[],"mappings":"AA+CiC","file":"../../../src/MarkdownControl/VisualEditor.js","sourcesContent":["// @refresh reset\nimport React, { useCallback, useEffect, useMemo, useState } from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { ClassNames, css as coreCss } from '@emotion/react';\nimport { lengths, fonts, zIndex } from 'decap-cms-ui-default';\nimport styled from '@emotion/styled';\nimport { createEditor, Transforms, Editor as SlateEditor } from 'slate';\nimport { Editable, ReactEditor, Slate, withReact } from 'slate-react';\nimport { withHistory } from 'slate-history';\nimport { fromJS } from 'immutable';\nimport isEqual from 'lodash/isEqual';\n\nimport { editorStyleVars, EditorControlBar } from '../styles';\nimport Toolbar from './Toolbar';\nimport { Element, Leaf } from './renderers';\nimport withLists from './plugins/lists/withLists';\nimport withBlocks from './plugins/blocks/withBlocks';\nimport withInlines from './plugins/inlines/withInlines';\nimport toggleMark from './plugins/inlines/events/toggleMark';\nimport toggleLink from './plugins/inlines/events/toggleLink';\nimport getActiveLink from './plugins/inlines/selectors/getActiveLink';\nimport isMarkActive from './plugins/inlines/locations/isMarkActive';\nimport isCursorInBlockType from './plugins/blocks/locations/isCursorInBlockType';\nimport { markdownToSlate, slateToMarkdown } from '../serializers';\nimport withShortcodes from './plugins/shortcodes/withShortcodes';\nimport insertShortcode from './plugins/shortcodes/insertShortcode';\nimport defaultEmptyBlock from './plugins/blocks/defaultEmptyBlock';\nimport withHtml from './plugins/html/withHtml';\n\nfunction visualEditorStyles({ minimal }) {\n  return `\n  position: relative;\n  overflow: auto;\n  font-family: ${fonts.primary};\n  min-height: ${minimal ? 'auto' : lengths.richTextEditorMinHeight};\n  border-top-left-radius: 0;\n  border-top-right-radius: 0;\n  border-top: 0;\n  margin-top: -${editorStyleVars.stickyDistanceBottom};\n  padding: 0;\n  display: flex;\n  flex-direction: column;\n  z-index: ${zIndex.zIndex100};\n`;\n}\n\nconst InsertionPoint = styled.div`\n  flex: 1 1 auto;\n  cursor: text;\n`;\n\nexport function mergeMediaConfig(editorComponents, field) {\n  // merge editor media library config to image components\n  if (editorComponents.has('image')) {\n    const imageComponent = editorComponents.get('image');\n    const fields = imageComponent?.fields;\n\n    if (fields) {\n      imageComponent.fields = fields.update(\n        fields.findIndex(f => f.get('widget') === 'image'),\n        f => {\n          // merge `media_library` config\n          if (field.has('media_library')) {\n            f = f.set(\n              'media_library',\n              field.get('media_library').mergeDeep(f.get('media_library')),\n            );\n          }\n          // merge 'media_folder'\n          if (field.has('media_folder') && !f.has('media_folder')) {\n            f = f.set('media_folder', field.get('media_folder'));\n          }\n          // merge 'public_folder'\n          if (field.has('public_folder') && !f.has('public_folder')) {\n            f = f.set('public_folder', field.get('public_folder'));\n          }\n          return f;\n        },\n      );\n    }\n  }\n}\n\nfunction Editor(props) {\n  const {\n    onAddAsset,\n    getAsset,\n    className,\n    field,\n    isShowModeToggle,\n    t,\n    isDisabled,\n    getEditorComponents,\n    getRemarkPlugins,\n    onChange,\n  } = props;\n\n  const editor = useMemo(\n    () =>\n      withHtml(\n        withReact(withHistory(withShortcodes(withBlocks(withLists(withInlines(createEditor())))))),\n      ),\n    [],\n  );\n\n  const emptyValue = [defaultEmptyBlock()];\n  let editorComponents = getEditorComponents();\n  const codeBlockComponent = fromJS(editorComponents.find(({ type }) => type === 'code-block'));\n\n  editorComponents =\n    codeBlockComponent || editorComponents.has('code-block')\n      ? editorComponents\n      : editorComponents.set('code-block', { label: 'Code Block', type: 'code-block' });\n\n  mergeMediaConfig(editorComponents, field);\n\n  const [editorValue, setEditorValue] = useState(\n    props.value\n      ? markdownToSlate(props.value, {\n          voidCodeBlock: !!codeBlockComponent,\n          remarkPlugins: getRemarkPlugins(),\n        })\n      : emptyValue,\n  );\n\n  const renderElement = useCallback(\n    props => (\n      <Element {...props} classNameWrapper={className} codeBlockComponent={codeBlockComponent} />\n    ),\n    [],\n  );\n  const renderLeaf = useCallback(props => <Leaf {...props} />, []);\n\n  useEffect(() => {\n    if (props.pendingFocus) {\n      ReactEditor.focus(editor);\n      props.pendingFocus();\n    }\n  }, [props.pendingFocus]);\n\n  function handleMarkClick(format) {\n    ReactEditor.focus(editor);\n    const markFormat = format === 'strikethrough' ? 'delete' : format;\n    toggleMark(editor, markFormat);\n  }\n\n  function handleBlockClick(format) {\n    ReactEditor.focus(editor);\n    if (format.endsWith('-list')) {\n      editor.toggleList(format);\n    } else {\n      editor.toggleBlock(format);\n    }\n  }\n\n  function handleLinkClick() {\n    toggleLink(editor, t('editor.editorWidgets.markdown.linkPrompt'));\n    ReactEditor.focus(editor);\n  }\n\n  function handleToggleMode() {\n    props.onMode('raw');\n  }\n\n  function handleInsertShortcode(pluginConfig) {\n    insertShortcode(editor, pluginConfig);\n  }\n\n  function handleKeyDown(event) {\n    for (const handler of editor.keyDownHandlers || []) {\n      if (handler(event, editor) === false) {\n        break;\n      }\n    }\n    ReactEditor.focus(editor);\n  }\n\n  function handleClickBelowDocument() {\n    ReactEditor.focus(editor);\n    Transforms.select(editor, { path: [0, 0], offset: 0 });\n    Transforms.select(editor, SlateEditor.end(editor, []));\n  }\n  const [toolbarKey, setToolbarKey] = useState(0);\n\n  function handleChange(newValue) {\n    if (!isEqual(newValue, editorValue)) {\n      setEditorValue(() => newValue);\n      onChange(\n        slateToMarkdown(newValue, {\n          voidCodeBlock: !!codeBlockComponent,\n          remarkPlugins: getRemarkPlugins(),\n        }),\n      );\n    }\n    setToolbarKey(prev => prev + 1);\n  }\n\n  function hasMark(format) {\n    return isMarkActive(editor, format);\n  }\n\n  function hasInline(format) {\n    if (format == 'link') {\n      return !!getActiveLink(editor);\n    }\n    return false;\n  }\n\n  function hasBlock(format) {\n    return isCursorInBlockType(editor, format);\n  }\n  function hasQuote() {\n    return isCursorInBlockType(editor, 'quote');\n  }\n  function hasListItems(type) {\n    return isCursorInBlockType(editor, type);\n  }\n\n  return (\n    <div\n      css={coreCss`\n        position: relative;\n      `}\n    >\n      <Slate editor={editor} value={editorValue} initialValue={editorValue} onChange={handleChange}>\n        <EditorControlBar>\n          {\n            <Toolbar\n              key={toolbarKey}\n              onMarkClick={handleMarkClick}\n              onBlockClick={handleBlockClick}\n              onLinkClick={handleLinkClick}\n              onToggleMode={handleToggleMode}\n              plugins={editorComponents}\n              onSubmit={handleInsertShortcode}\n              onAddAsset={onAddAsset}\n              getAsset={getAsset}\n              buttons={field.get('buttons')}\n              editorComponents={field.get('editor_components')}\n              hasMark={hasMark}\n              hasInline={hasInline}\n              hasBlock={hasBlock}\n              hasQuote={hasQuote}\n              hasListItems={hasListItems}\n              isShowModeToggle={isShowModeToggle}\n              t={t}\n              disabled={isDisabled}\n            />\n          }\n        </EditorControlBar>\n        {\n          <ClassNames>\n            {({ css, cx }) => (\n              <div\n                className={cx(\n                  className,\n                  css`\n                    ${visualEditorStyles({ minimal: field.get('minimal') })}\n                  `,\n                )}\n              >\n                {editorValue.length !== 0 && (\n                  <Editable\n                    className={css`\n                      padding: 16px 20px 0;\n                    `}\n                    renderElement={renderElement}\n                    renderLeaf={renderLeaf}\n                    onKeyDown={handleKeyDown}\n                    autoFocus={false}\n                  />\n                )}\n                <InsertionPoint onClick={handleClickBelowDocument} />\n              </div>\n            )}\n          </ClassNames>\n        }\n      </Slate>\n    </div>\n  );\n}\n\nEditor.propTypes = {\n  onAddAsset: PropTypes.func.isRequired,\n  getAsset: PropTypes.func.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onMode: PropTypes.func.isRequired,\n  className: PropTypes.string.isRequired,\n  value: PropTypes.string,\n  field: ImmutablePropTypes.map.isRequired,\n  getEditorComponents: PropTypes.func.isRequired,\n  getRemarkPlugins: PropTypes.func.isRequired,\n  isShowModeToggle: PropTypes.bool.isRequired,\n  t: PropTypes.func.isRequired,\n};\n\nexport default Editor;\n"]} */",
59
59
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
60
60
  });
61
61
  export function mergeMediaConfig(editorComponents, field) {
@@ -87,7 +87,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
87
87
  styles: "position:relative;label:Editor;"
88
88
  } : {
89
89
  name: "j8ayvn-Editor",
90
- styles: "position:relative;label:Editor;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MarkdownControl/VisualEditor.js"],"names":[],"mappings":"AA4NkB","file":"../../../src/MarkdownControl/VisualEditor.js","sourcesContent":["// @refresh reset\nimport React, { useCallback, useEffect, useMemo, useState } from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { ClassNames, css as coreCss } from '@emotion/react';\nimport { lengths, fonts, zIndex } from 'decap-cms-ui-default';\nimport styled from '@emotion/styled';\nimport { createEditor, Transforms, Editor as SlateEditor } from 'slate';\nimport { Editable, ReactEditor, Slate, withReact } from 'slate-react';\nimport { withHistory } from 'slate-history';\nimport { fromJS } from 'immutable';\nimport isEqual from 'lodash/isEqual';\n\nimport { editorStyleVars, EditorControlBar } from '../styles';\nimport Toolbar from './Toolbar';\nimport { Element, Leaf } from './renderers';\nimport withLists from './plugins/lists/withLists';\nimport withBlocks from './plugins/blocks/withBlocks';\nimport withInlines from './plugins/inlines/withInlines';\nimport toggleMark from './plugins/inlines/events/toggleMark';\nimport toggleLink from './plugins/inlines/events/toggleLink';\nimport getActiveLink from './plugins/inlines/selectors/getActiveLink';\nimport isMarkActive from './plugins/inlines/locations/isMarkActive';\nimport isCursorInBlockType from './plugins/blocks/locations/isCursorInBlockType';\nimport { markdownToSlate, slateToMarkdown } from '../serializers';\nimport withShortcodes from './plugins/shortcodes/withShortcodes';\nimport insertShortcode from './plugins/shortcodes/insertShortcode';\nimport defaultEmptyBlock from './plugins/blocks/defaultEmptyBlock';\nimport withHtml from './plugins/html/withHtml';\n\nfunction visualEditorStyles({ minimal }) {\n  return `\n  position: relative;\n  overflow: auto;\n  font-family: ${fonts.primary};\n  min-height: ${minimal ? 'auto' : lengths.richTextEditorMinHeight};\n  border-top-left-radius: 0;\n  border-top-right-radius: 0;\n  border-top: 0;\n  margin-top: -${editorStyleVars.stickyDistanceBottom};\n  padding: 0;\n  display: flex;\n  flex-direction: column;\n  z-index: ${zIndex.zIndex100};\n`;\n}\n\nconst InsertionPoint = styled.div`\n  flex: 1 1 auto;\n  cursor: text;\n`;\n\nexport function mergeMediaConfig(editorComponents, field) {\n  // merge editor media library config to image components\n  if (editorComponents.has('image')) {\n    const imageComponent = editorComponents.get('image');\n    const fields = imageComponent?.fields;\n\n    if (fields) {\n      imageComponent.fields = fields.update(\n        fields.findIndex(f => f.get('widget') === 'image'),\n        f => {\n          // merge `media_library` config\n          if (field.has('media_library')) {\n            f = f.set(\n              'media_library',\n              field.get('media_library').mergeDeep(f.get('media_library')),\n            );\n          }\n          // merge 'media_folder'\n          if (field.has('media_folder') && !f.has('media_folder')) {\n            f = f.set('media_folder', field.get('media_folder'));\n          }\n          // merge 'public_folder'\n          if (field.has('public_folder') && !f.has('public_folder')) {\n            f = f.set('public_folder', field.get('public_folder'));\n          }\n          return f;\n        },\n      );\n    }\n  }\n}\n\nfunction Editor(props) {\n  const {\n    onAddAsset,\n    getAsset,\n    className,\n    field,\n    isShowModeToggle,\n    t,\n    isDisabled,\n    getEditorComponents,\n    getRemarkPlugins,\n    onChange,\n  } = props;\n\n  const editor = useMemo(\n    () =>\n      withHtml(\n        withReact(withHistory(withShortcodes(withBlocks(withLists(withInlines(createEditor())))))),\n      ),\n    [],\n  );\n\n  const emptyValue = [defaultEmptyBlock()];\n  let editorComponents = getEditorComponents();\n  const codeBlockComponent = fromJS(editorComponents.find(({ type }) => type === 'code-block'));\n\n  editorComponents =\n    codeBlockComponent || editorComponents.has('code-block')\n      ? editorComponents\n      : editorComponents.set('code-block', { label: 'Code Block', type: 'code-block' });\n\n  mergeMediaConfig(editorComponents, field);\n\n  const [editorValue, setEditorValue] = useState(\n    props.value\n      ? markdownToSlate(props.value, {\n          voidCodeBlock: !!codeBlockComponent,\n          remarkPlugins: getRemarkPlugins(),\n        })\n      : emptyValue,\n  );\n\n  const renderElement = useCallback(\n    props => (\n      <Element {...props} classNameWrapper={className} codeBlockComponent={codeBlockComponent} />\n    ),\n    [],\n  );\n  const renderLeaf = useCallback(props => <Leaf {...props} />, []);\n\n  useEffect(() => {\n    if (props.pendingFocus) {\n      ReactEditor.focus(editor);\n      props.pendingFocus();\n    }\n  }, [props.pendingFocus]);\n\n  function handleMarkClick(format) {\n    ReactEditor.focus(editor);\n    toggleMark(editor, format);\n  }\n\n  function handleBlockClick(format) {\n    ReactEditor.focus(editor);\n    if (format.endsWith('-list')) {\n      editor.toggleList(format);\n    } else {\n      editor.toggleBlock(format);\n    }\n  }\n\n  function handleLinkClick() {\n    toggleLink(editor, t('editor.editorWidgets.markdown.linkPrompt'));\n    ReactEditor.focus(editor);\n  }\n\n  function handleToggleMode() {\n    props.onMode('raw');\n  }\n\n  function handleInsertShortcode(pluginConfig) {\n    insertShortcode(editor, pluginConfig);\n  }\n\n  function handleKeyDown(event) {\n    for (const handler of editor.keyDownHandlers || []) {\n      if (handler(event, editor) === false) {\n        break;\n      }\n    }\n    ReactEditor.focus(editor);\n  }\n\n  function handleClickBelowDocument() {\n    ReactEditor.focus(editor);\n    Transforms.select(editor, { path: [0, 0], offset: 0 });\n    Transforms.select(editor, SlateEditor.end(editor, []));\n  }\n  const [toolbarKey, setToolbarKey] = useState(0);\n\n  function handleChange(newValue) {\n    if (!isEqual(newValue, editorValue)) {\n      setEditorValue(() => newValue);\n      onChange(\n        slateToMarkdown(newValue, {\n          voidCodeBlock: !!codeBlockComponent,\n          remarkPlugins: getRemarkPlugins(),\n        }),\n      );\n    }\n    setToolbarKey(prev => prev + 1);\n  }\n\n  function hasMark(format) {\n    return isMarkActive(editor, format);\n  }\n\n  function hasInline(format) {\n    if (format == 'link') {\n      return !!getActiveLink(editor);\n    }\n    return false;\n  }\n\n  function hasBlock(format) {\n    return isCursorInBlockType(editor, format);\n  }\n  function hasQuote() {\n    return isCursorInBlockType(editor, 'quote');\n  }\n  function hasListItems(type) {\n    return isCursorInBlockType(editor, type);\n  }\n\n  return (\n    <div\n      css={coreCss`\n        position: relative;\n      `}\n    >\n      <Slate editor={editor} value={editorValue} onChange={handleChange}>\n        <EditorControlBar>\n          {\n            <Toolbar\n              key={toolbarKey}\n              onMarkClick={handleMarkClick}\n              onBlockClick={handleBlockClick}\n              onLinkClick={handleLinkClick}\n              onToggleMode={handleToggleMode}\n              plugins={editorComponents}\n              onSubmit={handleInsertShortcode}\n              onAddAsset={onAddAsset}\n              getAsset={getAsset}\n              buttons={field.get('buttons')}\n              editorComponents={field.get('editor_components')}\n              hasMark={hasMark}\n              hasInline={hasInline}\n              hasBlock={hasBlock}\n              hasQuote={hasQuote}\n              hasListItems={hasListItems}\n              isShowModeToggle={isShowModeToggle}\n              t={t}\n              disabled={isDisabled}\n            />\n          }\n        </EditorControlBar>\n        {\n          <ClassNames>\n            {({ css, cx }) => (\n              <div\n                className={cx(\n                  className,\n                  css`\n                    ${visualEditorStyles({ minimal: field.get('minimal') })}\n                  `,\n                )}\n              >\n                {editorValue.length !== 0 && (\n                  <Editable\n                    className={css`\n                      padding: 16px 20px 0;\n                    `}\n                    renderElement={renderElement}\n                    renderLeaf={renderLeaf}\n                    onKeyDown={handleKeyDown}\n                    autoFocus={false}\n                  />\n                )}\n                <InsertionPoint onClick={handleClickBelowDocument} />\n              </div>\n            )}\n          </ClassNames>\n        }\n      </Slate>\n    </div>\n  );\n}\n\nEditor.propTypes = {\n  onAddAsset: PropTypes.func.isRequired,\n  getAsset: PropTypes.func.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onMode: PropTypes.func.isRequired,\n  className: PropTypes.string.isRequired,\n  value: PropTypes.string,\n  field: ImmutablePropTypes.map.isRequired,\n  getEditorComponents: PropTypes.func.isRequired,\n  getRemarkPlugins: PropTypes.func.isRequired,\n  isShowModeToggle: PropTypes.bool.isRequired,\n  t: PropTypes.func.isRequired,\n};\n\nexport default Editor;\n"]} */",
90
+ styles: "position:relative;label:Editor;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MarkdownControl/VisualEditor.js"],"names":[],"mappings":"AA6NkB","file":"../../../src/MarkdownControl/VisualEditor.js","sourcesContent":["// @refresh reset\nimport React, { useCallback, useEffect, useMemo, useState } from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { ClassNames, css as coreCss } from '@emotion/react';\nimport { lengths, fonts, zIndex } from 'decap-cms-ui-default';\nimport styled from '@emotion/styled';\nimport { createEditor, Transforms, Editor as SlateEditor } from 'slate';\nimport { Editable, ReactEditor, Slate, withReact } from 'slate-react';\nimport { withHistory } from 'slate-history';\nimport { fromJS } from 'immutable';\nimport isEqual from 'lodash/isEqual';\n\nimport { editorStyleVars, EditorControlBar } from '../styles';\nimport Toolbar from './Toolbar';\nimport { Element, Leaf } from './renderers';\nimport withLists from './plugins/lists/withLists';\nimport withBlocks from './plugins/blocks/withBlocks';\nimport withInlines from './plugins/inlines/withInlines';\nimport toggleMark from './plugins/inlines/events/toggleMark';\nimport toggleLink from './plugins/inlines/events/toggleLink';\nimport getActiveLink from './plugins/inlines/selectors/getActiveLink';\nimport isMarkActive from './plugins/inlines/locations/isMarkActive';\nimport isCursorInBlockType from './plugins/blocks/locations/isCursorInBlockType';\nimport { markdownToSlate, slateToMarkdown } from '../serializers';\nimport withShortcodes from './plugins/shortcodes/withShortcodes';\nimport insertShortcode from './plugins/shortcodes/insertShortcode';\nimport defaultEmptyBlock from './plugins/blocks/defaultEmptyBlock';\nimport withHtml from './plugins/html/withHtml';\n\nfunction visualEditorStyles({ minimal }) {\n  return `\n  position: relative;\n  overflow: auto;\n  font-family: ${fonts.primary};\n  min-height: ${minimal ? 'auto' : lengths.richTextEditorMinHeight};\n  border-top-left-radius: 0;\n  border-top-right-radius: 0;\n  border-top: 0;\n  margin-top: -${editorStyleVars.stickyDistanceBottom};\n  padding: 0;\n  display: flex;\n  flex-direction: column;\n  z-index: ${zIndex.zIndex100};\n`;\n}\n\nconst InsertionPoint = styled.div`\n  flex: 1 1 auto;\n  cursor: text;\n`;\n\nexport function mergeMediaConfig(editorComponents, field) {\n  // merge editor media library config to image components\n  if (editorComponents.has('image')) {\n    const imageComponent = editorComponents.get('image');\n    const fields = imageComponent?.fields;\n\n    if (fields) {\n      imageComponent.fields = fields.update(\n        fields.findIndex(f => f.get('widget') === 'image'),\n        f => {\n          // merge `media_library` config\n          if (field.has('media_library')) {\n            f = f.set(\n              'media_library',\n              field.get('media_library').mergeDeep(f.get('media_library')),\n            );\n          }\n          // merge 'media_folder'\n          if (field.has('media_folder') && !f.has('media_folder')) {\n            f = f.set('media_folder', field.get('media_folder'));\n          }\n          // merge 'public_folder'\n          if (field.has('public_folder') && !f.has('public_folder')) {\n            f = f.set('public_folder', field.get('public_folder'));\n          }\n          return f;\n        },\n      );\n    }\n  }\n}\n\nfunction Editor(props) {\n  const {\n    onAddAsset,\n    getAsset,\n    className,\n    field,\n    isShowModeToggle,\n    t,\n    isDisabled,\n    getEditorComponents,\n    getRemarkPlugins,\n    onChange,\n  } = props;\n\n  const editor = useMemo(\n    () =>\n      withHtml(\n        withReact(withHistory(withShortcodes(withBlocks(withLists(withInlines(createEditor())))))),\n      ),\n    [],\n  );\n\n  const emptyValue = [defaultEmptyBlock()];\n  let editorComponents = getEditorComponents();\n  const codeBlockComponent = fromJS(editorComponents.find(({ type }) => type === 'code-block'));\n\n  editorComponents =\n    codeBlockComponent || editorComponents.has('code-block')\n      ? editorComponents\n      : editorComponents.set('code-block', { label: 'Code Block', type: 'code-block' });\n\n  mergeMediaConfig(editorComponents, field);\n\n  const [editorValue, setEditorValue] = useState(\n    props.value\n      ? markdownToSlate(props.value, {\n          voidCodeBlock: !!codeBlockComponent,\n          remarkPlugins: getRemarkPlugins(),\n        })\n      : emptyValue,\n  );\n\n  const renderElement = useCallback(\n    props => (\n      <Element {...props} classNameWrapper={className} codeBlockComponent={codeBlockComponent} />\n    ),\n    [],\n  );\n  const renderLeaf = useCallback(props => <Leaf {...props} />, []);\n\n  useEffect(() => {\n    if (props.pendingFocus) {\n      ReactEditor.focus(editor);\n      props.pendingFocus();\n    }\n  }, [props.pendingFocus]);\n\n  function handleMarkClick(format) {\n    ReactEditor.focus(editor);\n    const markFormat = format === 'strikethrough' ? 'delete' : format;\n    toggleMark(editor, markFormat);\n  }\n\n  function handleBlockClick(format) {\n    ReactEditor.focus(editor);\n    if (format.endsWith('-list')) {\n      editor.toggleList(format);\n    } else {\n      editor.toggleBlock(format);\n    }\n  }\n\n  function handleLinkClick() {\n    toggleLink(editor, t('editor.editorWidgets.markdown.linkPrompt'));\n    ReactEditor.focus(editor);\n  }\n\n  function handleToggleMode() {\n    props.onMode('raw');\n  }\n\n  function handleInsertShortcode(pluginConfig) {\n    insertShortcode(editor, pluginConfig);\n  }\n\n  function handleKeyDown(event) {\n    for (const handler of editor.keyDownHandlers || []) {\n      if (handler(event, editor) === false) {\n        break;\n      }\n    }\n    ReactEditor.focus(editor);\n  }\n\n  function handleClickBelowDocument() {\n    ReactEditor.focus(editor);\n    Transforms.select(editor, { path: [0, 0], offset: 0 });\n    Transforms.select(editor, SlateEditor.end(editor, []));\n  }\n  const [toolbarKey, setToolbarKey] = useState(0);\n\n  function handleChange(newValue) {\n    if (!isEqual(newValue, editorValue)) {\n      setEditorValue(() => newValue);\n      onChange(\n        slateToMarkdown(newValue, {\n          voidCodeBlock: !!codeBlockComponent,\n          remarkPlugins: getRemarkPlugins(),\n        }),\n      );\n    }\n    setToolbarKey(prev => prev + 1);\n  }\n\n  function hasMark(format) {\n    return isMarkActive(editor, format);\n  }\n\n  function hasInline(format) {\n    if (format == 'link') {\n      return !!getActiveLink(editor);\n    }\n    return false;\n  }\n\n  function hasBlock(format) {\n    return isCursorInBlockType(editor, format);\n  }\n  function hasQuote() {\n    return isCursorInBlockType(editor, 'quote');\n  }\n  function hasListItems(type) {\n    return isCursorInBlockType(editor, type);\n  }\n\n  return (\n    <div\n      css={coreCss`\n        position: relative;\n      `}\n    >\n      <Slate editor={editor} value={editorValue} initialValue={editorValue} onChange={handleChange}>\n        <EditorControlBar>\n          {\n            <Toolbar\n              key={toolbarKey}\n              onMarkClick={handleMarkClick}\n              onBlockClick={handleBlockClick}\n              onLinkClick={handleLinkClick}\n              onToggleMode={handleToggleMode}\n              plugins={editorComponents}\n              onSubmit={handleInsertShortcode}\n              onAddAsset={onAddAsset}\n              getAsset={getAsset}\n              buttons={field.get('buttons')}\n              editorComponents={field.get('editor_components')}\n              hasMark={hasMark}\n              hasInline={hasInline}\n              hasBlock={hasBlock}\n              hasQuote={hasQuote}\n              hasListItems={hasListItems}\n              isShowModeToggle={isShowModeToggle}\n              t={t}\n              disabled={isDisabled}\n            />\n          }\n        </EditorControlBar>\n        {\n          <ClassNames>\n            {({ css, cx }) => (\n              <div\n                className={cx(\n                  className,\n                  css`\n                    ${visualEditorStyles({ minimal: field.get('minimal') })}\n                  `,\n                )}\n              >\n                {editorValue.length !== 0 && (\n                  <Editable\n                    className={css`\n                      padding: 16px 20px 0;\n                    `}\n                    renderElement={renderElement}\n                    renderLeaf={renderLeaf}\n                    onKeyDown={handleKeyDown}\n                    autoFocus={false}\n                  />\n                )}\n                <InsertionPoint onClick={handleClickBelowDocument} />\n              </div>\n            )}\n          </ClassNames>\n        }\n      </Slate>\n    </div>\n  );\n}\n\nEditor.propTypes = {\n  onAddAsset: PropTypes.func.isRequired,\n  getAsset: PropTypes.func.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onMode: PropTypes.func.isRequired,\n  className: PropTypes.string.isRequired,\n  value: PropTypes.string,\n  field: ImmutablePropTypes.map.isRequired,\n  getEditorComponents: PropTypes.func.isRequired,\n  getRemarkPlugins: PropTypes.func.isRequired,\n  isShowModeToggle: PropTypes.bool.isRequired,\n  t: PropTypes.func.isRequired,\n};\n\nexport default Editor;\n"]} */",
91
91
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
92
92
  };
93
93
  function Editor(props) {
@@ -131,7 +131,8 @@ function Editor(props) {
131
131
  }, [props.pendingFocus]);
132
132
  function handleMarkClick(format) {
133
133
  ReactEditor.focus(editor);
134
- toggleMark(editor, format);
134
+ const markFormat = format === 'strikethrough' ? 'delete' : format;
135
+ toggleMark(editor, markFormat);
135
136
  }
136
137
  function handleBlockClick(format) {
137
138
  ReactEditor.focus(editor);
@@ -201,6 +202,7 @@ function Editor(props) {
201
202
  }, ___EmotionJSX(Slate, {
202
203
  editor: editor,
203
204
  value: editorValue,
205
+ initialValue: editorValue,
204
206
  onChange: handleChange
205
207
  }, ___EmotionJSX(EditorControlBar, null, ___EmotionJSX(Toolbar, {
206
208
  key: toolbarKey,
@@ -7,7 +7,7 @@ export default {
7
7
  type: 'array',
8
8
  items: {
9
9
  type: 'string',
10
- enum: ['bold', 'italic', 'code', 'link', 'heading-one', 'heading-two', 'heading-three', 'heading-four', 'heading-five', 'heading-six', 'quote', 'bulleted-list', 'numbered-list']
10
+ enum: ['bold', 'italic', 'strikethrough', 'code', 'link', 'heading-one', 'heading-two', 'heading-three', 'heading-four', 'heading-five', 'heading-six', 'quote', 'bulleted-list', 'numbered-list']
11
11
  }
12
12
  },
13
13
  editor_components: {
@@ -34,33 +34,10 @@ export function getLinesWithOffsets(value) {
34
34
  }));
35
35
  return trimmedLines;
36
36
  }
37
- function matchFromLines({
38
- trimmedLines,
39
- plugin
40
- }) {
41
- for (const {
42
- line,
43
- start
44
- } of trimmedLines) {
45
- const match = line.match(plugin.pattern);
46
- if (match) {
47
- match.index += start;
48
- return match;
49
- }
50
- }
51
- }
52
37
  function createShortcodeTokenizer({
53
38
  plugins
54
39
  }) {
55
40
  return function tokenizeShortcode(eat, value, silent) {
56
- // Plugin patterns may rely on `^` and `$` tokens, even if they don't
57
- // use the multiline flag. To support this, we fall back to searching
58
- // through each line individually, trimming trailing whitespace and
59
- // newlines, if we don't initially match on a pattern. We keep track of
60
- // the starting position of each line so that we can sort correctly
61
- // across the full multiline matches.
62
- const trimmedLines = getLinesWithOffsets(value);
63
-
64
41
  // Attempt to find a regex match for each plugin's pattern, and then
65
42
  // select the first by its occurrence in `value`. This ensures we won't
66
43
  // skip a plugin that occurs later in the plugin registry, but earlier
@@ -68,13 +45,21 @@ function createShortcodeTokenizer({
68
45
  const [{
69
46
  plugin,
70
47
  match
71
- } = {}] = plugins.toArray().map(plugin => ({
72
- match: value.match(plugin.pattern) || matchFromLines({
73
- trimmedLines,
48
+ } = {}] = plugins.toArray().map(plugin => {
49
+ let {
50
+ pattern
51
+ } = plugin;
52
+ // Plugin patterns must start with a caret (^) to match the beginning of the line.
53
+ // If the pattern does not start with a caret, we add it
54
+ // to ensure that remark consumes only the shortcode, without any leading text.
55
+ if (!pattern.source.startsWith('^')) {
56
+ pattern = new RegExp(`^${pattern.source}`, pattern.flags);
57
+ }
58
+ return {
59
+ match: value.match(pattern),
74
60
  plugin
75
- }),
76
- plugin
77
- })).filter(({
61
+ };
62
+ }).filter(({
78
63
  match
79
64
  }) => !!match).sort((a, b) => a.match.index - b.match.index);
80
65
  if (match) {