decap-cms-widget-markdown 3.6.1 → 3.7.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 +6 -0
- package/dist/decap-cms-widget-markdown.js +2 -2
- 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/Toolbar.js +6 -10
- package/package.json +3 -3
- package/src/MarkdownControl/Toolbar.js +4 -4
|
@@ -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('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\n              active={rawMode}\n              onChange={onToggleMode}\n              aria-label={\n                rawMode\n                  ? t('editor.editorWidgets.markdown.toggleMode.rich')\n                  : t('editor.editorWidgets.markdown.toggleMode.markdown')\n              }\n            />\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    const allPlugins = plugins ? plugins.toList().sortBy(plugin => plugin.label) : List();\n\n    const pluginsList = editorComponents\n      ? editorComponents.map(id => plugins.get(id)).filter(plugin => !!plugin)\n      : allPlugins;\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\n              active={rawMode}\n              onChange={onToggleMode}\n              aria-label={\n                rawMode\n                  ? t('editor.editorWidgets.markdown.toggleMode.rich')\n                  : t('editor.editorWidgets.markdown.toggleMode.markdown')\n              }\n            />\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('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\n              active={rawMode}\n              onChange={onToggleMode}\n              aria-label={\n                rawMode\n                  ? t('editor.editorWidgets.markdown.toggleMode.rich')\n                  : t('editor.editorWidgets.markdown.toggleMode.markdown')\n              }\n            />\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    const allPlugins = plugins ? plugins.toList().sortBy(plugin => plugin.label) : List();\n\n    const pluginsList = editorComponents\n      ? editorComponents.map(id => plugins.get(id)).filter(plugin => !!plugin)\n      : allPlugins;\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\n              active={rawMode}\n              onChange={onToggleMode}\n              aria-label={\n                rawMode\n                  ? t('editor.editorWidgets.markdown.toggleMode.rich')\n                  : t('editor.editorWidgets.markdown.toggleMode.markdown')\n              }\n            />\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('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\n              active={rawMode}\n              onChange={onToggleMode}\n              aria-label={\n                rawMode\n                  ? t('editor.editorWidgets.markdown.toggleMode.rich')\n                  : t('editor.editorWidgets.markdown.toggleMode.markdown')\n              }\n            />\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    const allPlugins = plugins ? plugins.toList().sortBy(plugin => plugin.label) : List();\n\n    const pluginsList = editorComponents\n      ? editorComponents.map(id => plugins.get(id)).filter(plugin => !!plugin)\n      : allPlugins;\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\n              active={rawMode}\n              onChange={onToggleMode}\n              aria-label={\n                rawMode\n                  ? t('editor.editorWidgets.markdown.toggleMode.rich')\n                  : t('editor.editorWidgets.markdown.toggleMode.markdown')\n              }\n            />\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('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\n              active={rawMode}\n              onChange={onToggleMode}\n              aria-label={\n                rawMode\n                  ? t('editor.editorWidgets.markdown.toggleMode.rich')\n                  : t('editor.editorWidgets.markdown.toggleMode.markdown')\n              }\n            />\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\n              active={rawMode}\n              onChange={onToggleMode}\n              aria-label={\n                rawMode\n                  ? t('editor.editorWidgets.markdown.toggleMode.rich')\n                  : t('editor.editorWidgets.markdown.toggleMode.markdown')\n              }\n            />\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    const allPlugins = plugins ? plugins.toList().sortBy(plugin => plugin.label) : List();\n\n    const pluginsList = editorComponents\n      ? editorComponents.map(id => plugins.get(id)).filter(plugin => !!plugin)\n      : allPlugins;\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\n              active={rawMode}\n              onChange={onToggleMode}\n              aria-label={\n                rawMode\n                  ? t('editor.editorWidgets.markdown.toggleMode.rich')\n                  : t('editor.editorWidgets.markdown.toggleMode.markdown')\n              }\n            />\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    const allPlugins = plugins ? plugins.toList().sortBy(plugin => plugin.label) : List();\n\n    const pluginsList = editorComponents\n      ? editorComponents.map(id => plugins.get(id)).filter(plugin => !!plugin)\n      : allPlugins;\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\n              active={rawMode}\n              onChange={onToggleMode}\n              aria-label={\n                rawMode\n                  ? t('editor.editorWidgets.markdown.toggleMode.rich')\n                  : t('editor.editorWidgets.markdown.toggleMode.markdown')\n              }\n            />\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,
|
|
@@ -101,12 +101,8 @@ export default class Toolbar extends React.Component {
|
|
|
101
101
|
} = this.props;
|
|
102
102
|
const isVisible = this.isVisible;
|
|
103
103
|
const showEditorComponents = !editorComponents || editorComponents.size >= 1;
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
}) {
|
|
107
|
-
return editorComponents ? editorComponents.includes(id) : true;
|
|
108
|
-
}
|
|
109
|
-
const pluginsList = plugins ? plugins.toList().filter(showPlugin) : List();
|
|
104
|
+
const allPlugins = plugins ? plugins.toList().sortBy(plugin => plugin.label) : List();
|
|
105
|
+
const pluginsList = editorComponents ? editorComponents.map(id => plugins.get(id)).filter(plugin => !!plugin) : allPlugins;
|
|
110
106
|
const headingOptions = {
|
|
111
107
|
'heading-one': t('editor.editorWidgets.headingOptions.headingOne'),
|
|
112
108
|
'heading-two': t('editor.editorWidgets.headingOptions.headingTwo'),
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "decap-cms-widget-markdown",
|
|
3
3
|
"description": "Widget for editing markdown in Decap CMS.",
|
|
4
|
-
"version": "3.
|
|
4
|
+
"version": "3.7.0",
|
|
5
5
|
"homepage": "https://www.decapcms.org/docs/widgets/#markdown",
|
|
6
6
|
"repository": "https://github.com/decaporg/decap-cms/tree/main/packages/decap-cms-widget-markdown",
|
|
7
7
|
"bugs": "https://github.com/decaporg/decap-cms/issues",
|
|
@@ -22,7 +22,7 @@
|
|
|
22
22
|
},
|
|
23
23
|
"dependencies": {
|
|
24
24
|
"detab": "^2.0.4",
|
|
25
|
-
"dompurify": "^3.
|
|
25
|
+
"dompurify": "^3.3.3",
|
|
26
26
|
"is-hotkey": "^0.2.0",
|
|
27
27
|
"is-url": "^1.2.4",
|
|
28
28
|
"mdast-util-definitions": "^1.2.3",
|
|
@@ -63,5 +63,5 @@
|
|
|
63
63
|
"commonmark": "^0.30.0",
|
|
64
64
|
"commonmark-spec": "^0.30.0"
|
|
65
65
|
},
|
|
66
|
-
"gitHead": "
|
|
66
|
+
"gitHead": "af84ddd0532948c38a9da26026404518a59d0903"
|
|
67
67
|
}
|
|
@@ -122,11 +122,11 @@ export default class Toolbar extends React.Component {
|
|
|
122
122
|
const isVisible = this.isVisible;
|
|
123
123
|
const showEditorComponents = !editorComponents || editorComponents.size >= 1;
|
|
124
124
|
|
|
125
|
-
|
|
126
|
-
return editorComponents ? editorComponents.includes(id) : true;
|
|
127
|
-
}
|
|
125
|
+
const allPlugins = plugins ? plugins.toList().sortBy(plugin => plugin.label) : List();
|
|
128
126
|
|
|
129
|
-
const pluginsList =
|
|
127
|
+
const pluginsList = editorComponents
|
|
128
|
+
? editorComponents.map(id => plugins.get(id)).filter(plugin => !!plugin)
|
|
129
|
+
: allPlugins;
|
|
130
130
|
|
|
131
131
|
const headingOptions = {
|
|
132
132
|
'heading-one': t('editor.editorWidgets.headingOptions.headingOne'),
|