All checks were successful
Publish To Prod / deploy_and_publish (push) Successful in 35s
216 lines
70 KiB
JavaScript
216 lines
70 KiB
JavaScript
"use strict";
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
value: true
|
|
});
|
|
exports.default = void 0;
|
|
var _base = _interopRequireDefault(require("@emotion/styled/base"));
|
|
var _react = _interopRequireDefault(require("react"));
|
|
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
var _reactImmutableProptypes = _interopRequireDefault(require("react-immutable-proptypes"));
|
|
var _react2 = require("@emotion/react");
|
|
var _immutable = require("immutable");
|
|
var _decapCmsUiDefault = require("decap-cms-ui-default");
|
|
var _ToolbarButton = _interopRequireDefault(require("./ToolbarButton"));
|
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : String(i); }
|
|
function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
|
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
const ToolbarContainer = /*#__PURE__*/(0, _base.default)("div", {
|
|
target: "e11cox783",
|
|
label: "ToolbarContainer"
|
|
})("background-color:", _decapCmsUiDefault.colors.textFieldBorder, ";border-top-right-radius:", _decapCmsUiDefault.lengths.borderRadius, ";position:relative;display:flex;justify-content:space-between;align-items:center;padding:11px 14px;min-height:58px;transition:background-color ", _decapCmsUiDefault.transitions.main, ",color ", _decapCmsUiDefault.transitions.main, ";color:", _decapCmsUiDefault.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  isVisible = button => {\n    const { buttons } = this.props;\n    return !List.isList(buttons) || buttons.includes(button);\n  };\n\n  handleBlockClick = (event, type) => {\n    if (event) {\n      event.preventDefault();\n    }\n    this.props.onBlockClick(type);\n  };\n\n  handleMarkClick = (event, type) => {\n    event.preventDefault();\n    this.props.onMarkClick(type);\n  };\n\n  render() {\n    const {\n      onLinkClick,\n      onToggleMode,\n      rawMode,\n      isShowModeToggle,\n      plugins,\n      disabled,\n      onSubmit,\n      hasMark = () => {},\n      hasInline = () => {},\n      hasBlock = () => {},\n      hasQuote = () => {},\n      hasListItems = () => {},\n      editorComponents,\n      t,\n    } = this.props;\n    const isVisible = this.isVisible;\n    const showEditorComponents = !editorComponents || editorComponents.size >= 1;\n\n    function showPlugin({ id }) {\n      return editorComponents ? editorComponents.includes(id) : true;\n    }\n\n    const pluginsList = plugins ? plugins.toList().filter(showPlugin) : List();\n\n    const headingOptions = {\n      'heading-one': t('editor.editorWidgets.headingOptions.headingOne'),\n      'heading-two': t('editor.editorWidgets.headingOptions.headingTwo'),\n      'heading-three': t('editor.editorWidgets.headingOptions.headingThree'),\n      'heading-four': t('editor.editorWidgets.headingOptions.headingFour'),\n      'heading-five': t('editor.editorWidgets.headingOptions.headingFive'),\n      'heading-six': t('editor.editorWidgets.headingOptions.headingSix'),\n    };\n\n    return (\n      <ToolbarContainer>\n        <div>\n          {isVisible('bold') && (\n            <ToolbarButton\n              type=\"bold\"\n              label={t('editor.editorWidgets.markdown.bold')}\n              icon=\"bold\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('bold')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('italic') && (\n            <ToolbarButton\n              type=\"italic\"\n              label={t('editor.editorWidgets.markdown.italic')}\n              icon=\"italic\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('italic')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('code') && (\n            <ToolbarButton\n              type=\"code\"\n              label={t('editor.editorWidgets.markdown.code')}\n              icon=\"code\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('code')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('link') && (\n            <ToolbarButton\n              type=\"link\"\n              label={t('editor.editorWidgets.markdown.link')}\n              icon=\"link\"\n              onClick={onLinkClick}\n              isActive={hasInline('link')}\n              disabled={disabled}\n            />\n          )}\n          {/* Show dropdown if at least one heading is not hidden */}\n          {Object.keys(headingOptions).some(isVisible) && (\n            <ToolbarDropdownWrapper>\n              <Dropdown\n                dropdownWidth=\"max-content\"\n                dropdownTopOverlap=\"36px\"\n                renderButton={() => (\n                  <DropdownButton>\n                    <ToolbarButton\n                      type=\"headings\"\n                      label={t('editor.editorWidgets.markdown.headings')}\n                      icon=\"hOptions\"\n                      disabled={disabled}\n                      isActive={!disabled && Object.keys(headingOptions).some(hasBlock)}\n                    />\n                  </DropdownButton>\n                )}\n              >\n                {!disabled &&\n                  Object.keys(headingOptions).map(\n                    (optionKey, idx) =>\n                      isVisible(optionKey) && (\n                        <DropdownItem\n                          key={idx}\n                          label={headingOptions[optionKey]}\n                          className={hasBlock(optionKey) ? 'active' : ''}\n                          onClick={() => this.handleBlockClick(null, optionKey)}\n                        />\n                      ),\n                  )}\n              </Dropdown>\n            </ToolbarDropdownWrapper>\n          )}\n          {isVisible('quote') && (\n            <ToolbarButton\n              type=\"quote\"\n              label={t('editor.editorWidgets.markdown.quote')}\n              icon=\"quote\"\n              onClick={this.handleBlockClick}\n              isActive={hasQuote('quote')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('bulleted-list') && (\n            <ToolbarButton\n              type=\"bulleted-list\"\n              label={t('editor.editorWidgets.markdown.bulletedList')}\n              icon=\"list-bulleted\"\n              onClick={this.handleBlockClick}\n              isActive={hasListItems('bulleted-list')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('numbered-list') && (\n            <ToolbarButton\n              type=\"numbered-list\"\n              label={t('editor.editorWidgets.markdown.numberedList')}\n              icon=\"list-numbered\"\n              onClick={this.handleBlockClick}\n              isActive={hasListItems('numbered-list')}\n              disabled={disabled}\n            />\n          )}\n          {showEditorComponents && (\n            <ToolbarDropdownWrapper>\n              <Dropdown\n                dropdownTopOverlap=\"36px\"\n                dropdownWidth=\"max-content\"\n                renderButton={() => (\n                  <DropdownButton>\n                    <ToolbarButton\n                      label={t('editor.editorWidgets.markdown.addComponent')}\n                      icon=\"add-with\"\n                      onClick={this.handleComponentsMenuToggle}\n                      disabled={disabled}\n                    />\n                  </DropdownButton>\n                )}\n              >\n                {pluginsList.map((plugin, idx) => (\n                  <DropdownItem key={idx} label={plugin.label} onClick={() => onSubmit(plugin)} />\n                ))}\n              </Dropdown>\n            </ToolbarDropdownWrapper>\n          )}\n        </div>\n        {isShowModeToggle && (\n          <ToolbarToggle>\n            <ToolbarToggleLabel isActive={!rawMode} offPosition>\n              {t('editor.editorWidgets.markdown.richText')}\n            </ToolbarToggleLabel>\n            <StyledToggle active={rawMode} onChange={onToggleMode} />\n            <ToolbarToggleLabel isActive={rawMode}>\n              {t('editor.editorWidgets.markdown.markdown')}\n            </ToolbarToggleLabel>\n          </ToolbarToggle>\n        )}\n      </ToolbarContainer>\n    );\n  }\n}\n"]} */"));
|
|
const ToolbarDropdownWrapper = /*#__PURE__*/(0, _base.default)("div", {
|
|
target: "e11cox782",
|
|
label: "ToolbarDropdownWrapper"
|
|
})(process.env.NODE_ENV === "production" ? {
|
|
name: "11ffxfj",
|
|
styles: "display:inline-block;position:relative"
|
|
} : {
|
|
name: "11ffxfj",
|
|
styles: "display:inline-block;position:relative",
|
|
map: "/*# 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  isVisible = button => {\n    const { buttons } = this.props;\n    return !List.isList(buttons) || buttons.includes(button);\n  };\n\n  handleBlockClick = (event, type) => {\n    if (event) {\n      event.preventDefault();\n    }\n    this.props.onBlockClick(type);\n  };\n\n  handleMarkClick = (event, type) => {\n    event.preventDefault();\n    this.props.onMarkClick(type);\n  };\n\n  render() {\n    const {\n      onLinkClick,\n      onToggleMode,\n      rawMode,\n      isShowModeToggle,\n      plugins,\n      disabled,\n      onSubmit,\n      hasMark = () => {},\n      hasInline = () => {},\n      hasBlock = () => {},\n      hasQuote = () => {},\n      hasListItems = () => {},\n      editorComponents,\n      t,\n    } = this.props;\n    const isVisible = this.isVisible;\n    const showEditorComponents = !editorComponents || editorComponents.size >= 1;\n\n    function showPlugin({ id }) {\n      return editorComponents ? editorComponents.includes(id) : true;\n    }\n\n    const pluginsList = plugins ? plugins.toList().filter(showPlugin) : List();\n\n    const headingOptions = {\n      'heading-one': t('editor.editorWidgets.headingOptions.headingOne'),\n      'heading-two': t('editor.editorWidgets.headingOptions.headingTwo'),\n      'heading-three': t('editor.editorWidgets.headingOptions.headingThree'),\n      'heading-four': t('editor.editorWidgets.headingOptions.headingFour'),\n      'heading-five': t('editor.editorWidgets.headingOptions.headingFive'),\n      'heading-six': t('editor.editorWidgets.headingOptions.headingSix'),\n    };\n\n    return (\n      <ToolbarContainer>\n        <div>\n          {isVisible('bold') && (\n            <ToolbarButton\n              type=\"bold\"\n              label={t('editor.editorWidgets.markdown.bold')}\n              icon=\"bold\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('bold')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('italic') && (\n            <ToolbarButton\n              type=\"italic\"\n              label={t('editor.editorWidgets.markdown.italic')}\n              icon=\"italic\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('italic')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('code') && (\n            <ToolbarButton\n              type=\"code\"\n              label={t('editor.editorWidgets.markdown.code')}\n              icon=\"code\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('code')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('link') && (\n            <ToolbarButton\n              type=\"link\"\n              label={t('editor.editorWidgets.markdown.link')}\n              icon=\"link\"\n              onClick={onLinkClick}\n              isActive={hasInline('link')}\n              disabled={disabled}\n            />\n          )}\n          {/* Show dropdown if at least one heading is not hidden */}\n          {Object.keys(headingOptions).some(isVisible) && (\n            <ToolbarDropdownWrapper>\n              <Dropdown\n                dropdownWidth=\"max-content\"\n                dropdownTopOverlap=\"36px\"\n                renderButton={() => (\n                  <DropdownButton>\n                    <ToolbarButton\n                      type=\"headings\"\n                      label={t('editor.editorWidgets.markdown.headings')}\n                      icon=\"hOptions\"\n                      disabled={disabled}\n                      isActive={!disabled && Object.keys(headingOptions).some(hasBlock)}\n                    />\n                  </DropdownButton>\n                )}\n              >\n                {!disabled &&\n                  Object.keys(headingOptions).map(\n                    (optionKey, idx) =>\n                      isVisible(optionKey) && (\n                        <DropdownItem\n                          key={idx}\n                          label={headingOptions[optionKey]}\n                          className={hasBlock(optionKey) ? 'active' : ''}\n                          onClick={() => this.handleBlockClick(null, optionKey)}\n                        />\n                      ),\n                  )}\n              </Dropdown>\n            </ToolbarDropdownWrapper>\n          )}\n          {isVisible('quote') && (\n            <ToolbarButton\n              type=\"quote\"\n              label={t('editor.editorWidgets.markdown.quote')}\n              icon=\"quote\"\n              onClick={this.handleBlockClick}\n              isActive={hasQuote('quote')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('bulleted-list') && (\n            <ToolbarButton\n              type=\"bulleted-list\"\n              label={t('editor.editorWidgets.markdown.bulletedList')}\n              icon=\"list-bulleted\"\n              onClick={this.handleBlockClick}\n              isActive={hasListItems('bulleted-list')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('numbered-list') && (\n            <ToolbarButton\n              type=\"numbered-list\"\n              label={t('editor.editorWidgets.markdown.numberedList')}\n              icon=\"list-numbered\"\n              onClick={this.handleBlockClick}\n              isActive={hasListItems('numbered-list')}\n              disabled={disabled}\n            />\n          )}\n          {showEditorComponents && (\n            <ToolbarDropdownWrapper>\n              <Dropdown\n                dropdownTopOverlap=\"36px\"\n                dropdownWidth=\"max-content\"\n                renderButton={() => (\n                  <DropdownButton>\n                    <ToolbarButton\n                      label={t('editor.editorWidgets.markdown.addComponent')}\n                      icon=\"add-with\"\n                      onClick={this.handleComponentsMenuToggle}\n                      disabled={disabled}\n                    />\n                  </DropdownButton>\n                )}\n              >\n                {pluginsList.map((plugin, idx) => (\n                  <DropdownItem key={idx} label={plugin.label} onClick={() => onSubmit(plugin)} />\n                ))}\n              </Dropdown>\n            </ToolbarDropdownWrapper>\n          )}\n        </div>\n        {isShowModeToggle && (\n          <ToolbarToggle>\n            <ToolbarToggleLabel isActive={!rawMode} offPosition>\n              {t('editor.editorWidgets.markdown.richText')}\n            </ToolbarToggleLabel>\n            <StyledToggle active={rawMode} onChange={onToggleMode} />\n            <ToolbarToggleLabel isActive={rawMode}>\n              {t('editor.editorWidgets.markdown.markdown')}\n            </ToolbarToggleLabel>\n          </ToolbarToggle>\n        )}\n      </ToolbarContainer>\n    );\n  }\n}\n"]} */",
|
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
});
|
|
const ToolbarToggle = /*#__PURE__*/(0, _base.default)("div", {
|
|
target: "e11cox781",
|
|
label: "ToolbarToggle"
|
|
})(process.env.NODE_ENV === "production" ? {
|
|
name: "1qi6e7n",
|
|
styles: "flex-shrink:0;display:flex;align-items:center;font-size:14px;margin:0 10px"
|
|
} : {
|
|
name: "1qi6e7n",
|
|
styles: "flex-shrink:0;display:flex;align-items:center;font-size:14px;margin:0 10px",
|
|
map: "/*# 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  isVisible = button => {\n    const { buttons } = this.props;\n    return !List.isList(buttons) || buttons.includes(button);\n  };\n\n  handleBlockClick = (event, type) => {\n    if (event) {\n      event.preventDefault();\n    }\n    this.props.onBlockClick(type);\n  };\n\n  handleMarkClick = (event, type) => {\n    event.preventDefault();\n    this.props.onMarkClick(type);\n  };\n\n  render() {\n    const {\n      onLinkClick,\n      onToggleMode,\n      rawMode,\n      isShowModeToggle,\n      plugins,\n      disabled,\n      onSubmit,\n      hasMark = () => {},\n      hasInline = () => {},\n      hasBlock = () => {},\n      hasQuote = () => {},\n      hasListItems = () => {},\n      editorComponents,\n      t,\n    } = this.props;\n    const isVisible = this.isVisible;\n    const showEditorComponents = !editorComponents || editorComponents.size >= 1;\n\n    function showPlugin({ id }) {\n      return editorComponents ? editorComponents.includes(id) : true;\n    }\n\n    const pluginsList = plugins ? plugins.toList().filter(showPlugin) : List();\n\n    const headingOptions = {\n      'heading-one': t('editor.editorWidgets.headingOptions.headingOne'),\n      'heading-two': t('editor.editorWidgets.headingOptions.headingTwo'),\n      'heading-three': t('editor.editorWidgets.headingOptions.headingThree'),\n      'heading-four': t('editor.editorWidgets.headingOptions.headingFour'),\n      'heading-five': t('editor.editorWidgets.headingOptions.headingFive'),\n      'heading-six': t('editor.editorWidgets.headingOptions.headingSix'),\n    };\n\n    return (\n      <ToolbarContainer>\n        <div>\n          {isVisible('bold') && (\n            <ToolbarButton\n              type=\"bold\"\n              label={t('editor.editorWidgets.markdown.bold')}\n              icon=\"bold\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('bold')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('italic') && (\n            <ToolbarButton\n              type=\"italic\"\n              label={t('editor.editorWidgets.markdown.italic')}\n              icon=\"italic\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('italic')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('code') && (\n            <ToolbarButton\n              type=\"code\"\n              label={t('editor.editorWidgets.markdown.code')}\n              icon=\"code\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('code')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('link') && (\n            <ToolbarButton\n              type=\"link\"\n              label={t('editor.editorWidgets.markdown.link')}\n              icon=\"link\"\n              onClick={onLinkClick}\n              isActive={hasInline('link')}\n              disabled={disabled}\n            />\n          )}\n          {/* Show dropdown if at least one heading is not hidden */}\n          {Object.keys(headingOptions).some(isVisible) && (\n            <ToolbarDropdownWrapper>\n              <Dropdown\n                dropdownWidth=\"max-content\"\n                dropdownTopOverlap=\"36px\"\n                renderButton={() => (\n                  <DropdownButton>\n                    <ToolbarButton\n                      type=\"headings\"\n                      label={t('editor.editorWidgets.markdown.headings')}\n                      icon=\"hOptions\"\n                      disabled={disabled}\n                      isActive={!disabled && Object.keys(headingOptions).some(hasBlock)}\n                    />\n                  </DropdownButton>\n                )}\n              >\n                {!disabled &&\n                  Object.keys(headingOptions).map(\n                    (optionKey, idx) =>\n                      isVisible(optionKey) && (\n                        <DropdownItem\n                          key={idx}\n                          label={headingOptions[optionKey]}\n                          className={hasBlock(optionKey) ? 'active' : ''}\n                          onClick={() => this.handleBlockClick(null, optionKey)}\n                        />\n                      ),\n                  )}\n              </Dropdown>\n            </ToolbarDropdownWrapper>\n          )}\n          {isVisible('quote') && (\n            <ToolbarButton\n              type=\"quote\"\n              label={t('editor.editorWidgets.markdown.quote')}\n              icon=\"quote\"\n              onClick={this.handleBlockClick}\n              isActive={hasQuote('quote')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('bulleted-list') && (\n            <ToolbarButton\n              type=\"bulleted-list\"\n              label={t('editor.editorWidgets.markdown.bulletedList')}\n              icon=\"list-bulleted\"\n              onClick={this.handleBlockClick}\n              isActive={hasListItems('bulleted-list')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('numbered-list') && (\n            <ToolbarButton\n              type=\"numbered-list\"\n              label={t('editor.editorWidgets.markdown.numberedList')}\n              icon=\"list-numbered\"\n              onClick={this.handleBlockClick}\n              isActive={hasListItems('numbered-list')}\n              disabled={disabled}\n            />\n          )}\n          {showEditorComponents && (\n            <ToolbarDropdownWrapper>\n              <Dropdown\n                dropdownTopOverlap=\"36px\"\n                dropdownWidth=\"max-content\"\n                renderButton={() => (\n                  <DropdownButton>\n                    <ToolbarButton\n                      label={t('editor.editorWidgets.markdown.addComponent')}\n                      icon=\"add-with\"\n                      onClick={this.handleComponentsMenuToggle}\n                      disabled={disabled}\n                    />\n                  </DropdownButton>\n                )}\n              >\n                {pluginsList.map((plugin, idx) => (\n                  <DropdownItem key={idx} label={plugin.label} onClick={() => onSubmit(plugin)} />\n                ))}\n              </Dropdown>\n            </ToolbarDropdownWrapper>\n          )}\n        </div>\n        {isShowModeToggle && (\n          <ToolbarToggle>\n            <ToolbarToggleLabel isActive={!rawMode} offPosition>\n              {t('editor.editorWidgets.markdown.richText')}\n            </ToolbarToggleLabel>\n            <StyledToggle active={rawMode} onChange={onToggleMode} />\n            <ToolbarToggleLabel isActive={rawMode}>\n              {t('editor.editorWidgets.markdown.markdown')}\n            </ToolbarToggleLabel>\n          </ToolbarToggle>\n        )}\n      </ToolbarContainer>\n    );\n  }\n}\n"]} */",
|
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
});
|
|
const StyledToggle = ToolbarToggle.withComponent(_decapCmsUiDefault.Toggle, {
|
|
target: "e11cox784",
|
|
label: "StyledToggle"
|
|
});
|
|
const ToolbarToggleLabel = /*#__PURE__*/(0, _base.default)("span", {
|
|
target: "e11cox780",
|
|
label: "ToolbarToggleLabel"
|
|
})("display:inline-block;text-align:center;white-space:nowrap;line-height:20px;min-width:", props => props.offPosition ? '62px' : '70px', ";", props => props.isActive && /*#__PURE__*/(0, _react2.css)("font-weight:600;color:", _decapCmsUiDefault.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  isVisible = button => {\n    const { buttons } = this.props;\n    return !List.isList(buttons) || buttons.includes(button);\n  };\n\n  handleBlockClick = (event, type) => {\n    if (event) {\n      event.preventDefault();\n    }\n    this.props.onBlockClick(type);\n  };\n\n  handleMarkClick = (event, type) => {\n    event.preventDefault();\n    this.props.onMarkClick(type);\n  };\n\n  render() {\n    const {\n      onLinkClick,\n      onToggleMode,\n      rawMode,\n      isShowModeToggle,\n      plugins,\n      disabled,\n      onSubmit,\n      hasMark = () => {},\n      hasInline = () => {},\n      hasBlock = () => {},\n      hasQuote = () => {},\n      hasListItems = () => {},\n      editorComponents,\n      t,\n    } = this.props;\n    const isVisible = this.isVisible;\n    const showEditorComponents = !editorComponents || editorComponents.size >= 1;\n\n    function showPlugin({ id }) {\n      return editorComponents ? editorComponents.includes(id) : true;\n    }\n\n    const pluginsList = plugins ? plugins.toList().filter(showPlugin) : List();\n\n    const headingOptions = {\n      'heading-one': t('editor.editorWidgets.headingOptions.headingOne'),\n      'heading-two': t('editor.editorWidgets.headingOptions.headingTwo'),\n      'heading-three': t('editor.editorWidgets.headingOptions.headingThree'),\n      'heading-four': t('editor.editorWidgets.headingOptions.headingFour'),\n      'heading-five': t('editor.editorWidgets.headingOptions.headingFive'),\n      'heading-six': t('editor.editorWidgets.headingOptions.headingSix'),\n    };\n\n    return (\n      <ToolbarContainer>\n        <div>\n          {isVisible('bold') && (\n            <ToolbarButton\n              type=\"bold\"\n              label={t('editor.editorWidgets.markdown.bold')}\n              icon=\"bold\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('bold')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('italic') && (\n            <ToolbarButton\n              type=\"italic\"\n              label={t('editor.editorWidgets.markdown.italic')}\n              icon=\"italic\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('italic')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('code') && (\n            <ToolbarButton\n              type=\"code\"\n              label={t('editor.editorWidgets.markdown.code')}\n              icon=\"code\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('code')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('link') && (\n            <ToolbarButton\n              type=\"link\"\n              label={t('editor.editorWidgets.markdown.link')}\n              icon=\"link\"\n              onClick={onLinkClick}\n              isActive={hasInline('link')}\n              disabled={disabled}\n            />\n          )}\n          {/* Show dropdown if at least one heading is not hidden */}\n          {Object.keys(headingOptions).some(isVisible) && (\n            <ToolbarDropdownWrapper>\n              <Dropdown\n                dropdownWidth=\"max-content\"\n                dropdownTopOverlap=\"36px\"\n                renderButton={() => (\n                  <DropdownButton>\n                    <ToolbarButton\n                      type=\"headings\"\n                      label={t('editor.editorWidgets.markdown.headings')}\n                      icon=\"hOptions\"\n                      disabled={disabled}\n                      isActive={!disabled && Object.keys(headingOptions).some(hasBlock)}\n                    />\n                  </DropdownButton>\n                )}\n              >\n                {!disabled &&\n                  Object.keys(headingOptions).map(\n                    (optionKey, idx) =>\n                      isVisible(optionKey) && (\n                        <DropdownItem\n                          key={idx}\n                          label={headingOptions[optionKey]}\n                          className={hasBlock(optionKey) ? 'active' : ''}\n                          onClick={() => this.handleBlockClick(null, optionKey)}\n                        />\n                      ),\n                  )}\n              </Dropdown>\n            </ToolbarDropdownWrapper>\n          )}\n          {isVisible('quote') && (\n            <ToolbarButton\n              type=\"quote\"\n              label={t('editor.editorWidgets.markdown.quote')}\n              icon=\"quote\"\n              onClick={this.handleBlockClick}\n              isActive={hasQuote('quote')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('bulleted-list') && (\n            <ToolbarButton\n              type=\"bulleted-list\"\n              label={t('editor.editorWidgets.markdown.bulletedList')}\n              icon=\"list-bulleted\"\n              onClick={this.handleBlockClick}\n              isActive={hasListItems('bulleted-list')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('numbered-list') && (\n            <ToolbarButton\n              type=\"numbered-list\"\n              label={t('editor.editorWidgets.markdown.numberedList')}\n              icon=\"list-numbered\"\n              onClick={this.handleBlockClick}\n              isActive={hasListItems('numbered-list')}\n              disabled={disabled}\n            />\n          )}\n          {showEditorComponents && (\n            <ToolbarDropdownWrapper>\n              <Dropdown\n                dropdownTopOverlap=\"36px\"\n                dropdownWidth=\"max-content\"\n                renderButton={() => (\n                  <DropdownButton>\n                    <ToolbarButton\n                      label={t('editor.editorWidgets.markdown.addComponent')}\n                      icon=\"add-with\"\n                      onClick={this.handleComponentsMenuToggle}\n                      disabled={disabled}\n                    />\n                  </DropdownButton>\n                )}\n              >\n                {pluginsList.map((plugin, idx) => (\n                  <DropdownItem key={idx} label={plugin.label} onClick={() => onSubmit(plugin)} />\n                ))}\n              </Dropdown>\n            </ToolbarDropdownWrapper>\n          )}\n        </div>\n        {isShowModeToggle && (\n          <ToolbarToggle>\n            <ToolbarToggleLabel isActive={!rawMode} offPosition>\n              {t('editor.editorWidgets.markdown.richText')}\n            </ToolbarToggleLabel>\n            <StyledToggle active={rawMode} onChange={onToggleMode} />\n            <ToolbarToggleLabel isActive={rawMode}>\n              {t('editor.editorWidgets.markdown.markdown')}\n            </ToolbarToggleLabel>\n          </ToolbarToggle>\n        )}\n      </ToolbarContainer>\n    );\n  }\n}\n"]} */")), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/MarkdownControl/Toolbar.js"],"names":[],"mappings":"AA8CsC","file":"../../../src/MarkdownControl/Toolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { List } from 'immutable';\nimport {\n  Toggle,\n  Dropdown,\n  DropdownItem,\n  DropdownButton,\n  colors,\n  transitions,\n  lengths,\n} from 'decap-cms-ui-default';\n\nimport ToolbarButton from './ToolbarButton';\n\nconst ToolbarContainer = styled.div`\n  background-color: ${colors.textFieldBorder};\n  border-top-right-radius: ${lengths.borderRadius};\n  position: relative;\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: 11px 14px;\n  min-height: 58px;\n  transition: background-color ${transitions.main}, color ${transitions.main};\n  color: ${colors.text};\n`;\n\nconst ToolbarDropdownWrapper = styled.div`\n  display: inline-block;\n  position: relative;\n`;\n\nconst ToolbarToggle = styled.div`\n  flex-shrink: 0;\n  display: flex;\n  align-items: center;\n  font-size: 14px;\n  margin: 0 10px;\n`;\n\nconst StyledToggle = ToolbarToggle.withComponent(Toggle);\n\nconst ToolbarToggleLabel = styled.span`\n  display: inline-block;\n  text-align: center;\n  white-space: nowrap;\n  line-height: 20px;\n  min-width: ${props => (props.offPosition ? '62px' : '70px')};\n\n  ${props =>\n    props.isActive &&\n    css`\n      font-weight: 600;\n      color: ${colors.active};\n    `};\n`;\n\nexport default class Toolbar extends React.Component {\n  static propTypes = {\n    buttons: ImmutablePropTypes.list,\n    editorComponents: ImmutablePropTypes.list,\n    onToggleMode: PropTypes.func.isRequired,\n    rawMode: PropTypes.bool,\n    isShowModeToggle: PropTypes.bool.isRequired,\n    plugins: ImmutablePropTypes.map,\n    onSubmit: PropTypes.func,\n    onAddAsset: PropTypes.func,\n    getAsset: PropTypes.func,\n    disabled: PropTypes.bool,\n    onMarkClick: PropTypes.func,\n    onBlockClick: PropTypes.func,\n    onLinkClick: PropTypes.func,\n    hasMark: PropTypes.func,\n    hasInline: PropTypes.func,\n    hasBlock: PropTypes.func,\n    t: PropTypes.func.isRequired,\n  };\n\n  isVisible = button => {\n    const { buttons } = this.props;\n    return !List.isList(buttons) || buttons.includes(button);\n  };\n\n  handleBlockClick = (event, type) => {\n    if (event) {\n      event.preventDefault();\n    }\n    this.props.onBlockClick(type);\n  };\n\n  handleMarkClick = (event, type) => {\n    event.preventDefault();\n    this.props.onMarkClick(type);\n  };\n\n  render() {\n    const {\n      onLinkClick,\n      onToggleMode,\n      rawMode,\n      isShowModeToggle,\n      plugins,\n      disabled,\n      onSubmit,\n      hasMark = () => {},\n      hasInline = () => {},\n      hasBlock = () => {},\n      hasQuote = () => {},\n      hasListItems = () => {},\n      editorComponents,\n      t,\n    } = this.props;\n    const isVisible = this.isVisible;\n    const showEditorComponents = !editorComponents || editorComponents.size >= 1;\n\n    function showPlugin({ id }) {\n      return editorComponents ? editorComponents.includes(id) : true;\n    }\n\n    const pluginsList = plugins ? plugins.toList().filter(showPlugin) : List();\n\n    const headingOptions = {\n      'heading-one': t('editor.editorWidgets.headingOptions.headingOne'),\n      'heading-two': t('editor.editorWidgets.headingOptions.headingTwo'),\n      'heading-three': t('editor.editorWidgets.headingOptions.headingThree'),\n      'heading-four': t('editor.editorWidgets.headingOptions.headingFour'),\n      'heading-five': t('editor.editorWidgets.headingOptions.headingFive'),\n      'heading-six': t('editor.editorWidgets.headingOptions.headingSix'),\n    };\n\n    return (\n      <ToolbarContainer>\n        <div>\n          {isVisible('bold') && (\n            <ToolbarButton\n              type=\"bold\"\n              label={t('editor.editorWidgets.markdown.bold')}\n              icon=\"bold\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('bold')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('italic') && (\n            <ToolbarButton\n              type=\"italic\"\n              label={t('editor.editorWidgets.markdown.italic')}\n              icon=\"italic\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('italic')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('code') && (\n            <ToolbarButton\n              type=\"code\"\n              label={t('editor.editorWidgets.markdown.code')}\n              icon=\"code\"\n              onClick={this.handleMarkClick}\n              isActive={hasMark('code')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('link') && (\n            <ToolbarButton\n              type=\"link\"\n              label={t('editor.editorWidgets.markdown.link')}\n              icon=\"link\"\n              onClick={onLinkClick}\n              isActive={hasInline('link')}\n              disabled={disabled}\n            />\n          )}\n          {/* Show dropdown if at least one heading is not hidden */}\n          {Object.keys(headingOptions).some(isVisible) && (\n            <ToolbarDropdownWrapper>\n              <Dropdown\n                dropdownWidth=\"max-content\"\n                dropdownTopOverlap=\"36px\"\n                renderButton={() => (\n                  <DropdownButton>\n                    <ToolbarButton\n                      type=\"headings\"\n                      label={t('editor.editorWidgets.markdown.headings')}\n                      icon=\"hOptions\"\n                      disabled={disabled}\n                      isActive={!disabled && Object.keys(headingOptions).some(hasBlock)}\n                    />\n                  </DropdownButton>\n                )}\n              >\n                {!disabled &&\n                  Object.keys(headingOptions).map(\n                    (optionKey, idx) =>\n                      isVisible(optionKey) && (\n                        <DropdownItem\n                          key={idx}\n                          label={headingOptions[optionKey]}\n                          className={hasBlock(optionKey) ? 'active' : ''}\n                          onClick={() => this.handleBlockClick(null, optionKey)}\n                        />\n                      ),\n                  )}\n              </Dropdown>\n            </ToolbarDropdownWrapper>\n          )}\n          {isVisible('quote') && (\n            <ToolbarButton\n              type=\"quote\"\n              label={t('editor.editorWidgets.markdown.quote')}\n              icon=\"quote\"\n              onClick={this.handleBlockClick}\n              isActive={hasQuote('quote')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('bulleted-list') && (\n            <ToolbarButton\n              type=\"bulleted-list\"\n              label={t('editor.editorWidgets.markdown.bulletedList')}\n              icon=\"list-bulleted\"\n              onClick={this.handleBlockClick}\n              isActive={hasListItems('bulleted-list')}\n              disabled={disabled}\n            />\n          )}\n          {isVisible('numbered-list') && (\n            <ToolbarButton\n              type=\"numbered-list\"\n              label={t('editor.editorWidgets.markdown.numberedList')}\n              icon=\"list-numbered\"\n              onClick={this.handleBlockClick}\n              isActive={hasListItems('numbered-list')}\n              disabled={disabled}\n            />\n          )}\n          {showEditorComponents && (\n            <ToolbarDropdownWrapper>\n              <Dropdown\n                dropdownTopOverlap=\"36px\"\n                dropdownWidth=\"max-content\"\n                renderButton={() => (\n                  <DropdownButton>\n                    <ToolbarButton\n                      label={t('editor.editorWidgets.markdown.addComponent')}\n                      icon=\"add-with\"\n                      onClick={this.handleComponentsMenuToggle}\n                      disabled={disabled}\n                    />\n                  </DropdownButton>\n                )}\n              >\n                {pluginsList.map((plugin, idx) => (\n                  <DropdownItem key={idx} label={plugin.label} onClick={() => onSubmit(plugin)} />\n                ))}\n              </Dropdown>\n            </ToolbarDropdownWrapper>\n          )}\n        </div>\n        {isShowModeToggle && (\n          <ToolbarToggle>\n            <ToolbarToggleLabel isActive={!rawMode} offPosition>\n              {t('editor.editorWidgets.markdown.richText')}\n            </ToolbarToggleLabel>\n            <StyledToggle active={rawMode} onChange={onToggleMode} />\n            <ToolbarToggleLabel isActive={rawMode}>\n              {t('editor.editorWidgets.markdown.markdown')}\n            </ToolbarToggleLabel>\n          </ToolbarToggle>\n        )}\n      </ToolbarContainer>\n    );\n  }\n}\n"]} */"));
|
|
class Toolbar extends _react.default.Component {
|
|
constructor(...args) {
|
|
super(...args);
|
|
_defineProperty(this, "isVisible", button => {
|
|
const {
|
|
buttons
|
|
} = this.props;
|
|
return !_immutable.List.isList(buttons) || buttons.includes(button);
|
|
});
|
|
_defineProperty(this, "handleBlockClick", (event, type) => {
|
|
if (event) {
|
|
event.preventDefault();
|
|
}
|
|
this.props.onBlockClick(type);
|
|
});
|
|
_defineProperty(this, "handleMarkClick", (event, type) => {
|
|
event.preventDefault();
|
|
this.props.onMarkClick(type);
|
|
});
|
|
}
|
|
render() {
|
|
const {
|
|
onLinkClick,
|
|
onToggleMode,
|
|
rawMode,
|
|
isShowModeToggle,
|
|
plugins,
|
|
disabled,
|
|
onSubmit,
|
|
hasMark = () => {},
|
|
hasInline = () => {},
|
|
hasBlock = () => {},
|
|
hasQuote = () => {},
|
|
hasListItems = () => {},
|
|
editorComponents,
|
|
t
|
|
} = this.props;
|
|
const isVisible = this.isVisible;
|
|
const showEditorComponents = !editorComponents || editorComponents.size >= 1;
|
|
function showPlugin({
|
|
id
|
|
}) {
|
|
return editorComponents ? editorComponents.includes(id) : true;
|
|
}
|
|
const pluginsList = plugins ? plugins.toList().filter(showPlugin) : (0, _immutable.List)();
|
|
const headingOptions = {
|
|
'heading-one': t('editor.editorWidgets.headingOptions.headingOne'),
|
|
'heading-two': t('editor.editorWidgets.headingOptions.headingTwo'),
|
|
'heading-three': t('editor.editorWidgets.headingOptions.headingThree'),
|
|
'heading-four': t('editor.editorWidgets.headingOptions.headingFour'),
|
|
'heading-five': t('editor.editorWidgets.headingOptions.headingFive'),
|
|
'heading-six': t('editor.editorWidgets.headingOptions.headingSix')
|
|
};
|
|
return (0, _react2.jsx)(ToolbarContainer, null, (0, _react2.jsx)("div", null, isVisible('bold') && (0, _react2.jsx)(_ToolbarButton.default, {
|
|
type: "bold",
|
|
label: t('editor.editorWidgets.markdown.bold'),
|
|
icon: "bold",
|
|
onClick: this.handleMarkClick,
|
|
isActive: hasMark('bold'),
|
|
disabled: disabled
|
|
}), isVisible('italic') && (0, _react2.jsx)(_ToolbarButton.default, {
|
|
type: "italic",
|
|
label: t('editor.editorWidgets.markdown.italic'),
|
|
icon: "italic",
|
|
onClick: this.handleMarkClick,
|
|
isActive: hasMark('italic'),
|
|
disabled: disabled
|
|
}), isVisible('code') && (0, _react2.jsx)(_ToolbarButton.default, {
|
|
type: "code",
|
|
label: t('editor.editorWidgets.markdown.code'),
|
|
icon: "code",
|
|
onClick: this.handleMarkClick,
|
|
isActive: hasMark('code'),
|
|
disabled: disabled
|
|
}), isVisible('link') && (0, _react2.jsx)(_ToolbarButton.default, {
|
|
type: "link",
|
|
label: t('editor.editorWidgets.markdown.link'),
|
|
icon: "link",
|
|
onClick: onLinkClick,
|
|
isActive: hasInline('link'),
|
|
disabled: disabled
|
|
}), Object.keys(headingOptions).some(isVisible) && (0, _react2.jsx)(ToolbarDropdownWrapper, null, (0, _react2.jsx)(_decapCmsUiDefault.Dropdown, {
|
|
dropdownWidth: "max-content",
|
|
dropdownTopOverlap: "36px",
|
|
renderButton: () => (0, _react2.jsx)(_decapCmsUiDefault.DropdownButton, null, (0, _react2.jsx)(_ToolbarButton.default, {
|
|
type: "headings",
|
|
label: t('editor.editorWidgets.markdown.headings'),
|
|
icon: "hOptions",
|
|
disabled: disabled,
|
|
isActive: !disabled && Object.keys(headingOptions).some(hasBlock)
|
|
}))
|
|
}, !disabled && Object.keys(headingOptions).map((optionKey, idx) => isVisible(optionKey) && (0, _react2.jsx)(_decapCmsUiDefault.DropdownItem, {
|
|
key: idx,
|
|
label: headingOptions[optionKey],
|
|
className: hasBlock(optionKey) ? 'active' : '',
|
|
onClick: () => this.handleBlockClick(null, optionKey)
|
|
})))), isVisible('quote') && (0, _react2.jsx)(_ToolbarButton.default, {
|
|
type: "quote",
|
|
label: t('editor.editorWidgets.markdown.quote'),
|
|
icon: "quote",
|
|
onClick: this.handleBlockClick,
|
|
isActive: hasQuote('quote'),
|
|
disabled: disabled
|
|
}), isVisible('bulleted-list') && (0, _react2.jsx)(_ToolbarButton.default, {
|
|
type: "bulleted-list",
|
|
label: t('editor.editorWidgets.markdown.bulletedList'),
|
|
icon: "list-bulleted",
|
|
onClick: this.handleBlockClick,
|
|
isActive: hasListItems('bulleted-list'),
|
|
disabled: disabled
|
|
}), isVisible('numbered-list') && (0, _react2.jsx)(_ToolbarButton.default, {
|
|
type: "numbered-list",
|
|
label: t('editor.editorWidgets.markdown.numberedList'),
|
|
icon: "list-numbered",
|
|
onClick: this.handleBlockClick,
|
|
isActive: hasListItems('numbered-list'),
|
|
disabled: disabled
|
|
}), showEditorComponents && (0, _react2.jsx)(ToolbarDropdownWrapper, null, (0, _react2.jsx)(_decapCmsUiDefault.Dropdown, {
|
|
dropdownTopOverlap: "36px",
|
|
dropdownWidth: "max-content",
|
|
renderButton: () => (0, _react2.jsx)(_decapCmsUiDefault.DropdownButton, null, (0, _react2.jsx)(_ToolbarButton.default, {
|
|
label: t('editor.editorWidgets.markdown.addComponent'),
|
|
icon: "add-with",
|
|
onClick: this.handleComponentsMenuToggle,
|
|
disabled: disabled
|
|
}))
|
|
}, pluginsList.map((plugin, idx) => (0, _react2.jsx)(_decapCmsUiDefault.DropdownItem, {
|
|
key: idx,
|
|
label: plugin.label,
|
|
onClick: () => onSubmit(plugin)
|
|
}))))), isShowModeToggle && (0, _react2.jsx)(ToolbarToggle, null, (0, _react2.jsx)(ToolbarToggleLabel, {
|
|
isActive: !rawMode,
|
|
offPosition: true
|
|
}, t('editor.editorWidgets.markdown.richText')), (0, _react2.jsx)(StyledToggle, {
|
|
active: rawMode,
|
|
onChange: onToggleMode
|
|
}), (0, _react2.jsx)(ToolbarToggleLabel, {
|
|
isActive: rawMode
|
|
}, t('editor.editorWidgets.markdown.markdown'))));
|
|
}
|
|
}
|
|
exports.default = Toolbar;
|
|
_defineProperty(Toolbar, "propTypes", {
|
|
buttons: _reactImmutableProptypes.default.list,
|
|
editorComponents: _reactImmutableProptypes.default.list,
|
|
onToggleMode: _propTypes.default.func.isRequired,
|
|
rawMode: _propTypes.default.bool,
|
|
isShowModeToggle: _propTypes.default.bool.isRequired,
|
|
plugins: _reactImmutableProptypes.default.map,
|
|
onSubmit: _propTypes.default.func,
|
|
onAddAsset: _propTypes.default.func,
|
|
getAsset: _propTypes.default.func,
|
|
disabled: _propTypes.default.bool,
|
|
onMarkClick: _propTypes.default.func,
|
|
onBlockClick: _propTypes.default.func,
|
|
onLinkClick: _propTypes.default.func,
|
|
hasMark: _propTypes.default.func,
|
|
hasInline: _propTypes.default.func,
|
|
hasBlock: _propTypes.default.func,
|
|
t: _propTypes.default.func.isRequired
|
|
}); |