decap-cms-core 3.3.6 → 3.3.7

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.
@@ -26,7 +26,7 @@ const styles = {
26
26
  } : {
27
27
  name: "1ctb18k-noOverflow",
28
28
  styles: "overflow:hidden;white-space:nowrap;text-overflow:ellipsis;label:noOverflow;",
29
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAuBiB","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */",
29
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAuBiB","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */",
30
30
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
31
31
  },
32
32
  buttonMargin: process.env.NODE_ENV === "production" ? {
@@ -35,11 +35,11 @@ const styles = {
35
35
  } : {
36
36
  name: "bx8mhy-buttonMargin",
37
37
  styles: "margin:0 10px;label:buttonMargin;",
38
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA4BmB","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */",
38
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA4BmB","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */",
39
39
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
40
40
  },
41
- toolbarSection: /*#__PURE__*/(0, _react2.css)("height:100%;display:flex;align-items:center;border:0 solid ", _decapCmsUiDefault.colors.textFieldBorder, ";;label:toolbarSection;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA+BqB","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */")),
42
- publishedButton: /*#__PURE__*/(0, _react2.css)("background-color:", _decapCmsUiDefault.colorsRaw.tealLight, ";color:", _decapCmsUiDefault.colorsRaw.tealDark, ";;label:publishedButton;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAqCsB","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"))
41
+ toolbarSection: /*#__PURE__*/(0, _react2.css)("height:100%;display:flex;align-items:center;border:0 solid ", _decapCmsUiDefault.colors.textFieldBorder, ";;label:toolbarSection;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA+BqB","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */")),
42
+ publishedButton: /*#__PURE__*/(0, _react2.css)("background-color:", _decapCmsUiDefault.colorsRaw.tealLight, ";color:", _decapCmsUiDefault.colorsRaw.tealDark, ";;label:publishedButton;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAqCsB","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"))
43
43
  };
44
44
  const TooltipText = /*#__PURE__*/(0, _base.default)("div", {
45
45
  target: "e1d2l9mo26",
@@ -50,13 +50,13 @@ const TooltipText = /*#__PURE__*/(0, _base.default)("div", {
50
50
  } : {
51
51
  name: "1ykbu60",
52
52
  styles: "visibility:hidden;width:321px;background-color:#555;color:#fff;text-align:unset;border-radius:6px;padding:5px;position:absolute;z-index:1;top:145%;left:50%;margin-left:-320px;opacity:0;transition:opacity 0.3s",
53
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA2C8B","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */",
53
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA2C8B","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */",
54
54
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
55
55
  });
56
56
  const Tooltip = /*#__PURE__*/(0, _base.default)("div", {
57
57
  target: "e1d2l9mo25",
58
58
  label: "Tooltip"
59
- })("position:relative;display:inline-block;&:hover+", TooltipText, "{visibility:visible;opacity:0.9;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAgE0B","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
59
+ })("position:relative;display:inline-block;&:hover+", TooltipText, "{visibility:visible;opacity:0.9;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAgE0B","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
60
60
  const TooltipContainer = /*#__PURE__*/(0, _base.default)("div", {
61
61
  target: "e1d2l9mo24",
62
62
  label: "TooltipContainer"
@@ -66,21 +66,21 @@ const TooltipContainer = /*#__PURE__*/(0, _base.default)("div", {
66
66
  } : {
67
67
  name: "bjn8wh",
68
68
  styles: "position:relative",
69
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAyEmC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */",
69
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAyEmC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */",
70
70
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
71
71
  });
72
72
  const DropdownButton = /*#__PURE__*/(0, _base.default)(_decapCmsUiDefault.StyledDropdownButton, {
73
73
  target: "e1d2l9mo23",
74
74
  label: "DropdownButton"
75
- })(styles.noOverflow, "@media (max-width: 1200px){padding-left:10px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA6EmD","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
75
+ })(styles.noOverflow, "@media (max-width: 1200px){padding-left:10px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA6EmD","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
76
76
  const ToolbarContainer = /*#__PURE__*/(0, _base.default)("div", {
77
77
  target: "e1d2l9mo22",
78
78
  label: "ToolbarContainer"
79
- })("box-shadow:0 2px 6px 0 rgba(68, 74, 87, 0.05),0 1px 3px 0 rgba(68, 74, 87, 0.1),0 2px 54px rgba(0, 0, 0, 0.1);position:fixed;top:0;left:0;width:100%;min-width:800px;z-index:", _decapCmsUiDefault.zIndex.zIndex300, ";background-color:#fff;height:66px;display:flex;justify-content:space-between;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAoFmC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
79
+ })("box-shadow:0 2px 6px 0 rgba(68, 74, 87, 0.05),0 1px 3px 0 rgba(68, 74, 87, 0.1),0 2px 54px rgba(0, 0, 0, 0.1);position:absolute;top:0;left:0;width:100%;min-width:800px;z-index:", _decapCmsUiDefault.zIndex.zIndex300, ";background-color:#fff;height:66px;display:flex;justify-content:space-between;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAoFmC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
80
80
  const ToolbarSectionMain = /*#__PURE__*/(0, _base.default)("div", {
81
81
  target: "e1d2l9mo21",
82
82
  label: "ToolbarSectionMain"
83
- })(styles.toolbarSection, ";flex:10;display:flex;justify-content:space-between;padding:0 10px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAmGqC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
83
+ })(styles.toolbarSection, ";flex:10;display:flex;justify-content:space-between;padding:0 10px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAmGqC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
84
84
  const ToolbarSubSectionFirst = /*#__PURE__*/(0, _base.default)("div", {
85
85
  target: "e1d2l9mo20",
86
86
  label: "ToolbarSubSectionFirst"
@@ -90,7 +90,7 @@ const ToolbarSubSectionFirst = /*#__PURE__*/(0, _base.default)("div", {
90
90
  } : {
91
91
  name: "s5xdrg",
92
92
  styles: "display:flex;align-items:center",
93
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA2GyC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */",
93
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA2GyC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */",
94
94
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
95
95
  });
96
96
  const ToolbarSubSectionLast = /*#__PURE__*/(0, _base.default)(ToolbarSubSectionFirst, {
@@ -102,29 +102,29 @@ const ToolbarSubSectionLast = /*#__PURE__*/(0, _base.default)(ToolbarSubSectionF
102
102
  } : {
103
103
  name: "1f60if8",
104
104
  styles: "justify-content:flex-end",
105
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAgH4D","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */",
105
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAgH4D","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */",
106
106
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
107
107
  });
108
108
  const ToolbarSectionBackLink = /*#__PURE__*/(0, _base.default)(_reactRouterDom.Link, {
109
109
  target: "e1d2l9mo18",
110
110
  label: "ToolbarSectionBackLink"
111
- })(styles.toolbarSection, ";border-right-width:1px;font-weight:normal;padding:0 20px;&:hover,&:focus{background-color:#f1f2f4;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAoH2C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
111
+ })(styles.toolbarSection, ";border-right-width:1px;font-weight:normal;padding:0 20px;&:hover,&:focus{background-color:#f1f2f4;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAoH2C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
112
112
  const ToolbarSectionMeta = /*#__PURE__*/(0, _base.default)("div", {
113
113
  target: "e1d2l9mo17",
114
114
  label: "ToolbarSectionMeta"
115
- })(styles.toolbarSection, ";border-left-width:1px;padding:0 7px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAgIqC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
115
+ })(styles.toolbarSection, ";border-left-width:1px;padding:0 7px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAgIqC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
116
116
  const ToolbarDropdown = /*#__PURE__*/(0, _base.default)(_decapCmsUiDefault.Dropdown, {
117
117
  target: "e1d2l9mo16",
118
118
  label: "ToolbarDropdown"
119
- })(styles.buttonMargin, ";", _decapCmsUiDefault.Icon, "{color:", _decapCmsUiDefault.colorsRaw.teal, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAsIwC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
119
+ })(styles.buttonMargin, ";", _decapCmsUiDefault.Icon, "{color:", _decapCmsUiDefault.colorsRaw.teal, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAsIwC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
120
120
  const BackArrow = /*#__PURE__*/(0, _base.default)("div", {
121
121
  target: "e1d2l9mo15",
122
122
  label: "BackArrow"
123
- })("color:", _decapCmsUiDefault.colors.textLead, ";font-size:21px;font-weight:600;margin-right:16px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA8I4B","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
123
+ })("color:", _decapCmsUiDefault.colors.textLead, ";font-size:21px;font-weight:600;margin-right:16px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA8I4B","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
124
124
  const BackCollection = /*#__PURE__*/(0, _base.default)("div", {
125
125
  target: "e1d2l9mo14",
126
126
  label: "BackCollection"
127
- })("color:", _decapCmsUiDefault.colors.textLead, ";font-size:14px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAqJiC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
127
+ })("color:", _decapCmsUiDefault.colors.textLead, ";font-size:14px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAqJiC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
128
128
  const BackStatus = /*#__PURE__*/(0, _base.default)("div", {
129
129
  target: "e1d2l9mo13",
130
130
  label: "BackStatus"
@@ -134,53 +134,53 @@ const BackStatus = /*#__PURE__*/(0, _base.default)("div", {
134
134
  } : {
135
135
  name: "j9a02z",
136
136
  styles: "margin-top:6px",
137
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA0J6B","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */",
137
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA0J6B","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */",
138
138
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
139
139
  });
140
140
  const BackStatusUnchanged = /*#__PURE__*/(0, _base.default)(BackStatus, {
141
141
  target: "e1d2l9mo12",
142
142
  label: "BackStatusUnchanged"
143
- })(_decapCmsUiDefault.components.textBadgeSuccess, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA8J8C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
143
+ })(_decapCmsUiDefault.components.textBadgeSuccess, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA8J8C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
144
144
  const BackStatusChanged = /*#__PURE__*/(0, _base.default)(BackStatus, {
145
145
  target: "e1d2l9mo11",
146
146
  label: "BackStatusChanged"
147
- })(_decapCmsUiDefault.components.textBadgeDanger, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAkK4C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
147
+ })(_decapCmsUiDefault.components.textBadgeDanger, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAkK4C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
148
148
  const ToolbarButton = /*#__PURE__*/(0, _base.default)("button", {
149
149
  target: "e1d2l9mo10",
150
150
  label: "ToolbarButton"
151
- })(_decapCmsUiDefault.buttons.button, ";", _decapCmsUiDefault.buttons.default, ";", styles.buttonMargin, ";", styles.noOverflow, ";display:block;@media (max-width: 1200px){padding:0 10px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAsKmC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
151
+ })(_decapCmsUiDefault.buttons.button, ";", _decapCmsUiDefault.buttons.default, ";", styles.buttonMargin, ";", styles.noOverflow, ";display:block;@media (max-width: 1200px){padding:0 10px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAsKmC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
152
152
  const DeleteButton = /*#__PURE__*/(0, _base.default)(ToolbarButton, {
153
153
  target: "e1d2l9mo9",
154
154
  label: "DeleteButton"
155
- })(_decapCmsUiDefault.buttons.lightRed, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAkL0C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
155
+ })(_decapCmsUiDefault.buttons.lightRed, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAkL0C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
156
156
  const SaveButton = /*#__PURE__*/(0, _base.default)(ToolbarButton, {
157
157
  target: "e1d2l9mo8",
158
158
  label: "SaveButton"
159
- })(_decapCmsUiDefault.buttons.lightBlue, ";&[disabled]{", _decapCmsUiDefault.buttons.disabled, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAsLwC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
159
+ })(_decapCmsUiDefault.buttons.lightBlue, ";&[disabled]{", _decapCmsUiDefault.buttons.disabled, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAsLwC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
160
160
  const PublishedToolbarButton = /*#__PURE__*/(0, _base.default)(DropdownButton, {
161
161
  target: "e1d2l9mo7",
162
162
  label: "PublishedToolbarButton"
163
- })(styles.publishedButton, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA6LqD","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
163
+ })(styles.publishedButton, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA6LqD","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
164
164
  const PublishedButton = /*#__PURE__*/(0, _base.default)(ToolbarButton, {
165
165
  target: "e1d2l9mo6",
166
166
  label: "PublishedButton"
167
- })(styles.publishedButton, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAiM6C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
167
+ })(styles.publishedButton, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAiM6C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
168
168
  const PublishButton = /*#__PURE__*/(0, _base.default)(DropdownButton, {
169
169
  target: "e1d2l9mo5",
170
170
  label: "PublishButton"
171
- })("background-color:", _decapCmsUiDefault.colorsRaw.teal, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAqM4C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
171
+ })("background-color:", _decapCmsUiDefault.colorsRaw.teal, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAqM4C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
172
172
  const StatusButton = /*#__PURE__*/(0, _base.default)(DropdownButton, {
173
173
  target: "e1d2l9mo4",
174
174
  label: "StatusButton"
175
- })("background-color:", _decapCmsUiDefault.colorsRaw.tealLight, ";color:", _decapCmsUiDefault.colorsRaw.teal, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAyM2C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
175
+ })("background-color:", _decapCmsUiDefault.colorsRaw.tealLight, ";color:", _decapCmsUiDefault.colorsRaw.teal, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAyM2C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
176
176
  const PreviewButtonContainer = /*#__PURE__*/(0, _base.default)("div", {
177
177
  target: "e1d2l9mo3",
178
178
  label: "PreviewButtonContainer"
179
- })("margin-right:12px;color:", _decapCmsUiDefault.colorsRaw.blue, ";display:flex;align-items:center;a,", _decapCmsUiDefault.Icon, "{color:", _decapCmsUiDefault.colorsRaw.blue, ";}", _decapCmsUiDefault.Icon, "{position:relative;top:1px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA8MyC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
179
+ })("margin-right:12px;color:", _decapCmsUiDefault.colorsRaw.blue, ";display:flex;align-items:center;a,", _decapCmsUiDefault.Icon, "{color:", _decapCmsUiDefault.colorsRaw.blue, ";}", _decapCmsUiDefault.Icon, "{position:relative;top:1px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA8MyC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
180
180
  const RefreshPreviewButton = /*#__PURE__*/(0, _base.default)("button", {
181
181
  target: "e1d2l9mo2",
182
182
  label: "RefreshPreviewButton"
183
- })("background:none;border:0;cursor:pointer;color:", _decapCmsUiDefault.colorsRaw.blue, ";span{margin-right:6px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA+N0C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
183
+ })("background:none;border:0;cursor:pointer;color:", _decapCmsUiDefault.colorsRaw.blue, ";span{margin-right:6px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA+N0C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
184
184
  const PreviewLink = RefreshPreviewButton.withComponent('a', {
185
185
  target: "e1d2l9mo27",
186
186
  label: "PreviewLink"
@@ -194,13 +194,13 @@ const PublishDropDownItem = /*#__PURE__*/(0, _base.default)(_decapCmsUiDefault.D
194
194
  } : {
195
195
  name: "svxjwj",
196
196
  styles: "min-width:initial",
197
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA4OgD","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */",
197
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA4OgD","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */",
198
198
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
199
199
  });
200
200
  const StatusDropdownItem = /*#__PURE__*/(0, _base.default)(_decapCmsUiDefault.DropdownItem, {
201
201
  target: "e1d2l9mo0",
202
202
  label: "StatusDropdownItem"
203
- })(_decapCmsUiDefault.Icon, "{color:", _decapCmsUiDefault.colors.infoText, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAgP+C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
203
+ })(_decapCmsUiDefault.Icon, "{color:", _decapCmsUiDefault.colors.infoText, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAgP+C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            this.renderWorkflowStatusControls(),\n            this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish }),\n          ]\n        : !isNewEntry &&\n          this.renderExistingEntryWorkflowPublishControls({ canCreate, canPublish, canDelete }),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */"));
204
204
  class EditorToolbar extends _react.default.Component {
205
205
  constructor(...args) {
206
206
  super(...args);