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.
- package/CHANGELOG.md +14 -0
- package/dist/decap-cms-widget-markdown.js +6 -6
- package/dist/decap-cms-widget-markdown.js.LICENSE.txt +1 -1
- package/dist/decap-cms-widget-markdown.js.map +1 -1
- package/dist/esm/MarkdownControl/RawEditor.js +2 -1
- package/dist/esm/MarkdownControl/Toolbar.js +11 -4
- package/dist/esm/MarkdownControl/VisualEditor.js +5 -3
- package/dist/esm/schema.js +1 -1
- package/dist/esm/serializers/remarkShortcodes.js +14 -29
- package/package.json +9 -8
- package/src/MarkdownControl/RawEditor.js +1 -1
- package/src/MarkdownControl/Toolbar.js +10 -0
- package/src/MarkdownControl/VisualEditor.js +3 -2
- package/src/schema.js +1 -0
- package/src/serializers/__tests__/__snapshots__/remarkShortcodes.spec.js.snap +132 -0
- package/src/serializers/__tests__/remarkShortcodes.spec.js +68 -29
- package/src/serializers/remarkShortcodes.js +14 -22
|
@@ -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+
|
|
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
|
-
|
|
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,
|
package/dist/esm/schema.js
CHANGED
|
@@ -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
|
-
|
|
73
|
-
|
|
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
|
-
|
|
77
|
-
})).filter(({
|
|
61
|
+
};
|
|
62
|
+
}).filter(({
|
|
78
63
|
match
|
|
79
64
|
}) => !!match).sort((a, b) => a.match.index - b.match.index);
|
|
80
65
|
if (match) {
|