decap-cms-core 3.2.0 → 3.2.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/decap-cms-core.js +2 -2
- package/dist/decap-cms-core.js.map +1 -1
- package/dist/esm/bootstrap.js +2 -2
- package/dist/esm/components/Editor/EditorToolbar.js +32 -31
- package/dist/esm/components/UI/ErrorBoundary.js +2 -2
- package/package.json +7 -7
- package/src/components/Editor/EditorToolbar.js +1 -0
- package/src/components/Editor/__tests__/__snapshots__/EditorToolbar.spec.js.snap +15 -15
|
@@ -26,7 +26,7 @@ const styles = {
|
|
|
26
26
|
} : {
|
|
27
27
|
name: "1ven8wv-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/core';\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        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/core';\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"]} */",
|
|
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: "1yqtsv2-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/core';\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        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/core';\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"]} */",
|
|
39
39
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
40
40
|
},
|
|
41
|
-
toolbarSection: /*#__PURE__*/(0, _core.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/core';\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        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, _core.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/core';\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        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, _core.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/core';\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, _core.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/core';\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"]} */"))
|
|
43
43
|
};
|
|
44
44
|
const TooltipText = (0, _styledBase.default)("div", {
|
|
45
45
|
target: "e1d2l9mo0",
|
|
@@ -50,13 +50,13 @@ const TooltipText = (0, _styledBase.default)("div", {
|
|
|
50
50
|
} : {
|
|
51
51
|
name: "198q1ye",
|
|
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/core';\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        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/core';\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"]} */",
|
|
54
54
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
55
55
|
});
|
|
56
56
|
const Tooltip = (0, _styledBase.default)("div", {
|
|
57
57
|
target: "e1d2l9mo1",
|
|
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/core';\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        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/core';\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"]} */"));
|
|
60
60
|
const TooltipContainer = (0, _styledBase.default)("div", {
|
|
61
61
|
target: "e1d2l9mo2",
|
|
62
62
|
label: "TooltipContainer"
|
|
@@ -66,21 +66,21 @@ const TooltipContainer = (0, _styledBase.default)("div", {
|
|
|
66
66
|
} : {
|
|
67
67
|
name: "79elbk",
|
|
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/core';\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        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/core';\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"]} */",
|
|
70
70
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
71
71
|
});
|
|
72
72
|
const DropdownButton = ( /*#__PURE__*/0, _styledBase.default)(_decapCmsUiDefault.StyledDropdownButton, {
|
|
73
73
|
target: "e1d2l9mo3",
|
|
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/core';\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        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/core';\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"]} */"));
|
|
76
76
|
const ToolbarContainer = (0, _styledBase.default)("div", {
|
|
77
77
|
target: "e1d2l9mo4",
|
|
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/core';\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        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: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/core';\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"]} */"));
|
|
80
80
|
const ToolbarSectionMain = (0, _styledBase.default)("div", {
|
|
81
81
|
target: "e1d2l9mo5",
|
|
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/core';\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        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/core';\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"]} */"));
|
|
84
84
|
const ToolbarSubSectionFirst = (0, _styledBase.default)("div", {
|
|
85
85
|
target: "e1d2l9mo6",
|
|
86
86
|
label: "ToolbarSubSectionFirst"
|
|
@@ -90,7 +90,7 @@ const ToolbarSubSectionFirst = (0, _styledBase.default)("div", {
|
|
|
90
90
|
} : {
|
|
91
91
|
name: "70qvj9",
|
|
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/core';\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        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/core';\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"]} */",
|
|
94
94
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
95
95
|
});
|
|
96
96
|
const ToolbarSubSectionLast = ( /*#__PURE__*/0, _styledBase.default)(ToolbarSubSectionFirst, {
|
|
@@ -102,29 +102,29 @@ const ToolbarSubSectionLast = ( /*#__PURE__*/0, _styledBase.default)(ToolbarSubS
|
|
|
102
102
|
} : {
|
|
103
103
|
name: "1a9getn",
|
|
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/core';\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        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/core';\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"]} */",
|
|
106
106
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
107
107
|
});
|
|
108
108
|
const ToolbarSectionBackLink = ( /*#__PURE__*/0, _styledBase.default)(_reactRouterDom.Link, {
|
|
109
109
|
target: "e1d2l9mo8",
|
|
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/core';\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        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/core';\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"]} */"));
|
|
112
112
|
const ToolbarSectionMeta = (0, _styledBase.default)("div", {
|
|
113
113
|
target: "e1d2l9mo9",
|
|
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/core';\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        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/core';\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"]} */"));
|
|
116
116
|
const ToolbarDropdown = ( /*#__PURE__*/0, _styledBase.default)(_decapCmsUiDefault.Dropdown, {
|
|
117
117
|
target: "e1d2l9mo10",
|
|
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/core';\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        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/core';\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"]} */"));
|
|
120
120
|
const BackArrow = (0, _styledBase.default)("div", {
|
|
121
121
|
target: "e1d2l9mo11",
|
|
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/core';\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        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/core';\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"]} */"));
|
|
124
124
|
const BackCollection = (0, _styledBase.default)("div", {
|
|
125
125
|
target: "e1d2l9mo12",
|
|
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/core';\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        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/core';\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"]} */"));
|
|
128
128
|
const BackStatus = (0, _styledBase.default)("div", {
|
|
129
129
|
target: "e1d2l9mo13",
|
|
130
130
|
label: "BackStatus"
|
|
@@ -134,53 +134,53 @@ const BackStatus = (0, _styledBase.default)("div", {
|
|
|
134
134
|
} : {
|
|
135
135
|
name: "19ug521",
|
|
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/core';\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        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/core';\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"]} */",
|
|
138
138
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
139
139
|
});
|
|
140
140
|
const BackStatusUnchanged = ( /*#__PURE__*/0, _styledBase.default)(BackStatus, {
|
|
141
141
|
target: "e1d2l9mo14",
|
|
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/core';\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        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/core';\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"]} */"));
|
|
144
144
|
const BackStatusChanged = ( /*#__PURE__*/0, _styledBase.default)(BackStatus, {
|
|
145
145
|
target: "e1d2l9mo15",
|
|
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/core';\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        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/core';\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"]} */"));
|
|
148
148
|
const ToolbarButton = (0, _styledBase.default)("button", {
|
|
149
149
|
target: "e1d2l9mo16",
|
|
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/core';\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        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/core';\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"]} */"));
|
|
152
152
|
const DeleteButton = ( /*#__PURE__*/0, _styledBase.default)(ToolbarButton, {
|
|
153
153
|
target: "e1d2l9mo17",
|
|
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/core';\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        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/core';\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"]} */"));
|
|
156
156
|
const SaveButton = ( /*#__PURE__*/0, _styledBase.default)(ToolbarButton, {
|
|
157
157
|
target: "e1d2l9mo18",
|
|
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/core';\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        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/core';\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"]} */"));
|
|
160
160
|
const PublishedToolbarButton = ( /*#__PURE__*/0, _styledBase.default)(DropdownButton, {
|
|
161
161
|
target: "e1d2l9mo19",
|
|
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/core';\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        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/core';\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"]} */");
|
|
164
164
|
const PublishedButton = ( /*#__PURE__*/0, _styledBase.default)(ToolbarButton, {
|
|
165
165
|
target: "e1d2l9mo20",
|
|
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/core';\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        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/core';\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"]} */");
|
|
168
168
|
const PublishButton = ( /*#__PURE__*/0, _styledBase.default)(DropdownButton, {
|
|
169
169
|
target: "e1d2l9mo21",
|
|
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/core';\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        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/core';\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"]} */"));
|
|
172
172
|
const StatusButton = ( /*#__PURE__*/0, _styledBase.default)(DropdownButton, {
|
|
173
173
|
target: "e1d2l9mo22",
|
|
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/core';\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        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/core';\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"]} */"));
|
|
176
176
|
const PreviewButtonContainer = (0, _styledBase.default)("div", {
|
|
177
177
|
target: "e1d2l9mo23",
|
|
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/core';\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        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/core';\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"]} */"));
|
|
180
180
|
const RefreshPreviewButton = (0, _styledBase.default)("button", {
|
|
181
181
|
target: "e1d2l9mo24",
|
|
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/core';\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        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/core';\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"]} */"));
|
|
184
184
|
const PreviewLink = RefreshPreviewButton.withComponent('a', {
|
|
185
185
|
target: "e1d2l9mo27",
|
|
186
186
|
label: "PreviewLink"
|
|
@@ -194,13 +194,13 @@ const PublishDropDownItem = ( /*#__PURE__*/0, _styledBase.default)(_decapCmsUiDe
|
|
|
194
194
|
} : {
|
|
195
195
|
name: "12k1a1h",
|
|
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/core';\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        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/core';\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"]} */",
|
|
198
198
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
199
199
|
});
|
|
200
200
|
const StatusDropdownItem = ( /*#__PURE__*/0, _styledBase.default)(_decapCmsUiDefault.DropdownItem, {
|
|
201
201
|
target: "e1d2l9mo26",
|
|
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/core';\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        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/core';\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"]} */"));
|
|
204
204
|
class EditorToolbar extends _react.default.Component {
|
|
205
205
|
constructor(...args) {
|
|
206
206
|
super(...args);
|
|
@@ -345,6 +345,7 @@ class EditorToolbar extends _react.default.Component {
|
|
|
345
345
|
return canPublish || canCreate ? (0, _core.jsx)(ToolbarDropdown, {
|
|
346
346
|
dropdownTopOverlap: "40px",
|
|
347
347
|
dropdownWidth: "150px",
|
|
348
|
+
key: "td-publish-create",
|
|
348
349
|
renderButton: () => (0, _core.jsx)(PublishedToolbarButton, null, isPersisting ? t('editor.editorToolbar.unpublishing') : t('editor.editorToolbar.published'))
|
|
349
350
|
}, canDelete && canPublish && (0, _core.jsx)(_decapCmsUiDefault.DropdownItem, {
|
|
350
351
|
label: t('editor.editorToolbar.unpublish'),
|