decap-cms-core 3.5.0 → 3.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/decap-cms-core.js +9 -9
- package/dist/decap-cms-core.js.map +1 -1
- package/dist/esm/actions/auth.js +22 -37
- package/dist/esm/actions/collections.js +9 -17
- package/dist/esm/actions/config.js +58 -74
- package/dist/esm/actions/deploys.js +10 -17
- package/dist/esm/actions/editorialWorkflow.js +87 -101
- package/dist/esm/actions/entries.js +161 -211
- package/dist/esm/actions/media.js +31 -46
- package/dist/esm/actions/mediaLibrary.js +94 -126
- package/dist/esm/actions/notifications.js +5 -13
- package/dist/esm/actions/search.js +30 -47
- package/dist/esm/actions/status.js +13 -23
- package/dist/esm/actions/waitUntil.js +4 -11
- package/dist/esm/backend.js +132 -148
- package/dist/esm/bootstrap.js +37 -44
- package/dist/esm/components/App/App.js +82 -89
- package/dist/esm/components/App/Header.js +46 -52
- package/dist/esm/components/App/NotFoundPage.js +11 -18
- package/dist/esm/components/Collection/Collection.js +55 -63
- package/dist/esm/components/Collection/CollectionControls.js +15 -22
- package/dist/esm/components/Collection/CollectionSearch.js +35 -42
- package/dist/esm/components/Collection/CollectionTop.js +23 -30
- package/dist/esm/components/Collection/ControlButton.js +10 -16
- package/dist/esm/components/Collection/Entries/Entries.js +24 -31
- package/dist/esm/components/Collection/Entries/EntriesCollection.js +52 -62
- package/dist/esm/components/Collection/Entries/EntriesSearch.js +26 -33
- package/dist/esm/components/Collection/Entries/EntryCard.js +38 -45
- package/dist/esm/components/Collection/Entries/EntryListing.js +24 -32
- package/dist/esm/components/Collection/FilterControl.js +9 -16
- package/dist/esm/components/Collection/GroupControl.js +9 -16
- package/dist/esm/components/Collection/NestedCollection.js +54 -65
- package/dist/esm/components/Collection/Sidebar.js +36 -43
- package/dist/esm/components/Collection/SortControl.js +19 -26
- package/dist/esm/components/Collection/ViewStyleControl.js +17 -24
- package/dist/esm/components/Editor/Editor.js +100 -108
- package/dist/esm/components/Editor/EditorControlPane/EditorControl.js +105 -112
- package/dist/esm/components/Editor/EditorControlPane/EditorControlPane.js +68 -62
- package/dist/esm/components/Editor/EditorControlPane/Widget.js +87 -73
- package/dist/esm/components/Editor/EditorInterface.js +95 -98
- package/dist/esm/components/Editor/EditorPreviewPane/EditorPreview.js +13 -21
- package/dist/esm/components/Editor/EditorPreviewPane/EditorPreviewContent.js +64 -23
- package/dist/esm/components/Editor/EditorPreviewPane/EditorPreviewPane.js +94 -78
- package/dist/esm/components/Editor/EditorPreviewPane/PreviewHOC.js +9 -16
- package/dist/esm/components/Editor/EditorToolbar.js +133 -140
- package/dist/esm/components/Editor/withWorkflow.js +15 -22
- package/dist/esm/components/EditorWidgets/Unknown/UnknownControl.js +9 -16
- package/dist/esm/components/EditorWidgets/Unknown/UnknownPreview.js +9 -16
- package/dist/esm/components/EditorWidgets/index.js +4 -7
- package/dist/esm/components/MediaLibrary/EmptyMessage.js +12 -19
- package/dist/esm/components/MediaLibrary/MediaLibrary.js +55 -62
- package/dist/esm/components/MediaLibrary/MediaLibraryButtons.js +28 -35
- package/dist/esm/components/MediaLibrary/MediaLibraryCard.js +36 -43
- package/dist/esm/components/MediaLibrary/MediaLibraryCardGrid.js +50 -57
- package/dist/esm/components/MediaLibrary/MediaLibraryHeader.js +16 -23
- package/dist/esm/components/MediaLibrary/MediaLibraryModal.js +59 -64
- package/dist/esm/components/MediaLibrary/MediaLibrarySearch.js +18 -25
- package/dist/esm/components/MediaLibrary/MediaLibraryTop.js +39 -46
- package/dist/esm/components/UI/DragDrop.js +21 -30
- package/dist/esm/components/UI/ErrorBoundary.js +35 -43
- package/dist/esm/components/UI/FileUploadButton.js +11 -18
- package/dist/esm/components/UI/Modal.js +19 -26
- package/dist/esm/components/UI/Notifications.js +21 -28
- package/dist/esm/components/UI/SettingsDropdown.js +28 -34
- package/dist/esm/components/UI/index.js +6 -60
- package/dist/esm/components/Workflow/Workflow.js +52 -61
- package/dist/esm/components/Workflow/WorkflowCard.js +45 -51
- package/dist/esm/components/Workflow/WorkflowList.js +43 -49
- package/dist/esm/constants/collectionTypes.js +2 -8
- package/dist/esm/constants/collectionViews.js +2 -8
- package/dist/esm/constants/commitProps.js +2 -8
- package/dist/esm/constants/configSchema.js +20 -27
- package/dist/esm/constants/fieldInference.js +8 -15
- package/dist/esm/constants/publishModes.js +6 -11
- package/dist/esm/constants/validationErrorTypes.js +1 -7
- package/dist/esm/formats/formats.js +32 -41
- package/dist/esm/formats/frontmatter.js +18 -30
- package/dist/esm/formats/helpers.js +1 -7
- package/dist/esm/formats/json.js +1 -7
- package/dist/esm/formats/toml.js +11 -18
- package/dist/esm/formats/yaml.js +7 -14
- package/dist/esm/index.js +5 -12
- package/dist/esm/integrations/index.js +8 -16
- package/dist/esm/integrations/providers/algolia/implementation.js +14 -22
- package/dist/esm/integrations/providers/assetStore/implementation.js +10 -18
- package/dist/esm/lib/consoleError.js +1 -7
- package/dist/esm/lib/formatters.js +34 -47
- package/dist/esm/lib/i18n.js +37 -66
- package/dist/esm/lib/phrases.js +4 -11
- package/dist/esm/lib/registry.js +40 -75
- package/dist/esm/lib/serializeEntryValues.js +11 -18
- package/dist/esm/lib/textHelper.js +1 -7
- package/dist/esm/lib/urlHelper.js +28 -43
- package/dist/esm/mediaLibrary.js +12 -16
- package/dist/esm/reducers/auth.js +10 -16
- package/dist/esm/reducers/collections.js +70 -102
- package/dist/esm/reducers/combinedReducer.js +4 -11
- package/dist/esm/reducers/config.js +11 -19
- package/dist/esm/reducers/cursors.js +12 -18
- package/dist/esm/reducers/deploys.js +8 -15
- package/dist/esm/reducers/editorialWorkflow.js +37 -47
- package/dist/esm/reducers/entries.js +107 -132
- package/dist/esm/reducers/entryDraft.js +64 -72
- package/dist/esm/reducers/globalUI.js +5 -11
- package/dist/esm/reducers/index.js +43 -64
- package/dist/esm/reducers/integrations.js +8 -16
- package/dist/esm/reducers/mediaLibrary.js +43 -52
- package/dist/esm/reducers/medias.js +11 -18
- package/dist/esm/reducers/notifications.js +9 -15
- package/dist/esm/reducers/search.js +12 -18
- package/dist/esm/reducers/status.js +7 -13
- package/dist/esm/redux/index.js +7 -13
- package/dist/esm/redux/middleware/waitUntilAction.js +3 -10
- package/dist/esm/routing/history.js +7 -15
- package/dist/esm/types/diacritics.d.js +0 -1
- package/dist/esm/types/global.d.js +1 -5
- package/dist/esm/types/immutable.js +1 -5
- package/dist/esm/types/redux.js +7 -8
- package/dist/esm/types/tomlify-j0.4.d.js +0 -1
- package/dist/esm/valueObjects/AssetProxy.js +2 -10
- package/dist/esm/valueObjects/EditorComponent.js +5 -12
- package/dist/esm/valueObjects/Entry.js +3 -10
- package/package.json +3 -2
- package/src/components/Collection/Entries/EntriesCollection.js +7 -8
- package/src/components/Collection/Entries/__tests__/EntriesCollection.spec.js +3 -5
- package/src/components/Collection/Entries/__tests__/__snapshots__/EntriesCollection.spec.js.snap +8 -8
- package/src/components/Collection/NestedCollection.js +2 -2
- package/src/components/Collection/__tests__/__snapshots__/NestedCollection.spec.js.snap +68 -0
- package/src/components/Editor/EditorControlPane/EditorControl.js +0 -3
- package/src/components/Editor/EditorControlPane/EditorControlPane.js +21 -8
- package/src/components/Editor/EditorControlPane/Widget.js +22 -1
- package/src/components/Editor/EditorInterface.js +6 -1
- package/src/components/Editor/EditorPreviewPane/EditorPreviewContent.js +51 -11
- package/src/components/Editor/EditorPreviewPane/EditorPreviewPane.js +33 -1
- package/dist/esm/actions/editorControl.js +0 -14
- package/dist/esm/reducers/editorComponent.js +0 -1
- package/dist/esm/reducers/editorControl.js +0 -17
|
@@ -1,24 +1,18 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = exports.EditorToolbar = void 0;
|
|
7
|
-
var _base = _interopRequireDefault(require("@emotion/styled/base"));
|
|
8
|
-
var _react = _interopRequireDefault(require("react"));
|
|
9
|
-
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
10
|
-
var _reactImmutableProptypes = _interopRequireDefault(require("react-immutable-proptypes"));
|
|
11
|
-
var _react2 = require("@emotion/react");
|
|
12
|
-
var _reactPolyglot = require("react-polyglot");
|
|
13
|
-
var _reactRouterDom = require("react-router-dom");
|
|
14
|
-
var _decapCmsUiDefault = require("decap-cms-ui-default");
|
|
15
|
-
var _publishModes = require("../../constants/publishModes");
|
|
16
|
-
var _UI = require("../UI");
|
|
17
|
-
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
1
|
+
import _styled from "@emotion/styled/base";
|
|
18
2
|
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
19
3
|
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : String(i); }
|
|
20
4
|
function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
|
21
5
|
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
6
|
+
import React from 'react';
|
|
7
|
+
import PropTypes from 'prop-types';
|
|
8
|
+
import ImmutablePropTypes from 'react-immutable-proptypes';
|
|
9
|
+
import { css } from '@emotion/react';
|
|
10
|
+
import { translate } from 'react-polyglot';
|
|
11
|
+
import { Link } from 'react-router-dom';
|
|
12
|
+
import { Icon, Dropdown, DropdownItem, StyledDropdownButton, colorsRaw, colors, components, buttons, zIndex } from 'decap-cms-ui-default';
|
|
13
|
+
import { status } from '../../constants/publishModes';
|
|
14
|
+
import { SettingsDropdown } from '../UI';
|
|
15
|
+
import { jsx as ___EmotionJSX } from "@emotion/react";
|
|
22
16
|
const styles = {
|
|
23
17
|
noOverflow: process.env.NODE_ENV === "production" ? {
|
|
24
18
|
name: "1ctb18k-noOverflow",
|
|
@@ -38,10 +32,10 @@ const styles = {
|
|
|
38
32
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA4BmB","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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
33
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
40
34
|
},
|
|
41
|
-
toolbarSection: /*#__PURE__*/(0, _react2.css)("height:100%;display:flex;align-items:center;border:0 solid ", _decapCmsUiDefault.colors.textFieldBorder, ";;label:toolbarSection;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA+BqB","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\n      (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (\n        <DeleteButton\n          key=\"delete-button\"\n          onClick={hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete}\n        >\n          {isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel}\n        </DeleteButton>\n      ),\n    ];\n  };\n\n  renderWorkflowDeployPreviewControls = () => {\n    const { currentStatus, isNewEntry, t } = this.props;\n\n    if (currentStatus) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployPreviewButtonLabel'));\n    }\n\n    /**\n     * Publish control for published workflow entry.\n     */\n    if (!isNewEntry) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  render() {\n    const {\n      user,\n      hasChanged,\n      displayUrl,\n      collection,\n      hasWorkflow,\n      onLogoutClick,\n      t,\n      editorBackLink,\n    } = this.props;\n\n    return (\n      <ToolbarContainer>\n        <ToolbarSectionBackLink to={editorBackLink}>\n          <BackArrow>←</BackArrow>\n          <div>\n            <BackCollection>\n              {t('editor.editorToolbar.backCollection', {\n                collectionLabel: collection.get('label'),\n              })}\n            </BackCollection>\n            {hasChanged ? (\n              <BackStatusChanged>{t('editor.editorToolbar.unsavedChanges')}</BackStatusChanged>\n            ) : (\n              <BackStatusUnchanged>{t('editor.editorToolbar.changesSaved')}</BackStatusUnchanged>\n            )}\n          </div>\n        </ToolbarSectionBackLink>\n        <ToolbarSectionMain>\n          <ToolbarSubSectionFirst>\n            {hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()}\n          </ToolbarSubSectionFirst>\n          <ToolbarSubSectionLast>\n            {hasWorkflow\n              ? this.renderWorkflowDeployPreviewControls()\n              : this.renderSimpleDeployPreviewControls()}\n          </ToolbarSubSectionLast>\n        </ToolbarSectionMain>\n        <ToolbarSectionMeta>\n          <SettingsDropdown\n            displayUrl={displayUrl}\n            imageUrl={user?.avatar_url}\n            onLogoutClick={onLogoutClick}\n          />\n        </ToolbarSectionMeta>\n      </ToolbarContainer>\n    );\n  }\n}\n\nexport default translate()(EditorToolbar);\n"]} */")),
|
|
42
|
-
publishedButton: /*#__PURE__*/(0, _react2.css)("background-color:", _decapCmsUiDefault.colorsRaw.tealLight, ";color:", _decapCmsUiDefault.colorsRaw.tealDark, ";;label:publishedButton;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAqCsB","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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"]} */"))
|
|
35
|
+
toolbarSection: /*#__PURE__*/css("height:100%;display:flex;align-items:center;border:0 solid ", colors.textFieldBorder, ";;label:toolbarSection;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA+BqB","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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"]} */")),
|
|
36
|
+
publishedButton: /*#__PURE__*/css("background-color:", colorsRaw.tealLight, ";color:", colorsRaw.tealDark, ";;label:publishedButton;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAqCsB","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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
37
|
};
|
|
44
|
-
const TooltipText = /*#__PURE__*/(
|
|
38
|
+
const TooltipText = /*#__PURE__*/_styled("div", {
|
|
45
39
|
target: "e1d2l9mo26",
|
|
46
40
|
label: "TooltipText"
|
|
47
41
|
})(process.env.NODE_ENV === "production" ? {
|
|
@@ -53,11 +47,11 @@ const TooltipText = /*#__PURE__*/(0, _base.default)("div", {
|
|
|
53
47
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA2C8B","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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
48
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
55
49
|
});
|
|
56
|
-
const Tooltip = /*#__PURE__*/(
|
|
50
|
+
const Tooltip = /*#__PURE__*/_styled("div", {
|
|
57
51
|
target: "e1d2l9mo25",
|
|
58
52
|
label: "Tooltip"
|
|
59
53
|
})("position:relative;display:inline-block;&:hover+", TooltipText, "{visibility:visible;opacity:0.9;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAgE0B","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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
|
-
const TooltipContainer = /*#__PURE__*/(
|
|
54
|
+
const TooltipContainer = /*#__PURE__*/_styled("div", {
|
|
61
55
|
target: "e1d2l9mo24",
|
|
62
56
|
label: "TooltipContainer"
|
|
63
57
|
})(process.env.NODE_ENV === "production" ? {
|
|
@@ -69,19 +63,19 @@ const TooltipContainer = /*#__PURE__*/(0, _base.default)("div", {
|
|
|
69
63
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAyEmC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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
64
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
71
65
|
});
|
|
72
|
-
const DropdownButton = /*#__PURE__*/(
|
|
66
|
+
const DropdownButton = /*#__PURE__*/_styled(StyledDropdownButton, {
|
|
73
67
|
target: "e1d2l9mo23",
|
|
74
68
|
label: "DropdownButton"
|
|
75
69
|
})(styles.noOverflow, "@media (max-width: 1200px){padding-left:10px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA6EmD","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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
|
-
const ToolbarContainer = /*#__PURE__*/(
|
|
70
|
+
const ToolbarContainer = /*#__PURE__*/_styled("div", {
|
|
77
71
|
target: "e1d2l9mo22",
|
|
78
72
|
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:absolute;top:0;left:0;width:100%;min-width:800px;z-index:", _decapCmsUiDefault.zIndex.zIndex300, ";background-color:#fff;height:66px;display:flex;justify-content:space-between;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAoFmC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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
|
-
const ToolbarSectionMain = /*#__PURE__*/(
|
|
73
|
+
})("box-shadow:0 2px 6px 0 rgba(68, 74, 87, 0.05),0 1px 3px 0 rgba(68, 74, 87, 0.1),0 2px 54px rgba(0, 0, 0, 0.1);position:absolute;top:0;left:0;width:100%;min-width:800px;z-index:", zIndex.zIndex300, ";background-color:#fff;height:66px;display:flex;justify-content:space-between;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAoFmC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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"]} */"));
|
|
74
|
+
const ToolbarSectionMain = /*#__PURE__*/_styled("div", {
|
|
81
75
|
target: "e1d2l9mo21",
|
|
82
76
|
label: "ToolbarSectionMain"
|
|
83
77
|
})(styles.toolbarSection, ";flex:10;display:flex;justify-content:space-between;padding:0 10px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAmGqC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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
|
-
const ToolbarSubSectionFirst = /*#__PURE__*/(
|
|
78
|
+
const ToolbarSubSectionFirst = /*#__PURE__*/_styled("div", {
|
|
85
79
|
target: "e1d2l9mo20",
|
|
86
80
|
label: "ToolbarSubSectionFirst"
|
|
87
81
|
})(process.env.NODE_ENV === "production" ? {
|
|
@@ -93,7 +87,7 @@ const ToolbarSubSectionFirst = /*#__PURE__*/(0, _base.default)("div", {
|
|
|
93
87
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA2GyC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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
88
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
95
89
|
});
|
|
96
|
-
const ToolbarSubSectionLast = /*#__PURE__*/(
|
|
90
|
+
const ToolbarSubSectionLast = /*#__PURE__*/_styled(ToolbarSubSectionFirst, {
|
|
97
91
|
target: "e1d2l9mo19",
|
|
98
92
|
label: "ToolbarSubSectionLast"
|
|
99
93
|
})(process.env.NODE_ENV === "production" ? {
|
|
@@ -105,27 +99,27 @@ const ToolbarSubSectionLast = /*#__PURE__*/(0, _base.default)(ToolbarSubSectionF
|
|
|
105
99
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAgH4D","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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
100
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
107
101
|
});
|
|
108
|
-
const ToolbarSectionBackLink = /*#__PURE__*/(
|
|
102
|
+
const ToolbarSectionBackLink = /*#__PURE__*/_styled(Link, {
|
|
109
103
|
target: "e1d2l9mo18",
|
|
110
104
|
label: "ToolbarSectionBackLink"
|
|
111
105
|
})(styles.toolbarSection, ";border-right-width:1px;font-weight:normal;padding:0 20px;&:hover,&:focus{background-color:#f1f2f4;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAoH2C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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
|
-
const ToolbarSectionMeta = /*#__PURE__*/(
|
|
106
|
+
const ToolbarSectionMeta = /*#__PURE__*/_styled("div", {
|
|
113
107
|
target: "e1d2l9mo17",
|
|
114
108
|
label: "ToolbarSectionMeta"
|
|
115
109
|
})(styles.toolbarSection, ";border-left-width:1px;padding:0 7px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAgIqC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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
|
-
const ToolbarDropdown = /*#__PURE__*/(
|
|
110
|
+
const ToolbarDropdown = /*#__PURE__*/_styled(Dropdown, {
|
|
117
111
|
target: "e1d2l9mo16",
|
|
118
112
|
label: "ToolbarDropdown"
|
|
119
|
-
})(styles.buttonMargin, ";", _decapCmsUiDefault.Icon, "{color:", _decapCmsUiDefault.colorsRaw.teal, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAsIwC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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
|
-
const BackArrow = /*#__PURE__*/(
|
|
113
|
+
})(styles.buttonMargin, ";", Icon, "{color:", colorsRaw.teal, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAsIwC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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"]} */"));
|
|
114
|
+
const BackArrow = /*#__PURE__*/_styled("div", {
|
|
121
115
|
target: "e1d2l9mo15",
|
|
122
116
|
label: "BackArrow"
|
|
123
|
-
})("color:", _decapCmsUiDefault.colors.textLead, ";font-size:21px;font-weight:600;margin-right:16px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA8I4B","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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
|
-
const BackCollection = /*#__PURE__*/(
|
|
117
|
+
})("color:", colors.textLead, ";font-size:21px;font-weight:600;margin-right:16px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA8I4B","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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"]} */"));
|
|
118
|
+
const BackCollection = /*#__PURE__*/_styled("div", {
|
|
125
119
|
target: "e1d2l9mo14",
|
|
126
120
|
label: "BackCollection"
|
|
127
|
-
})("color:", _decapCmsUiDefault.colors.textLead, ";font-size:14px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAqJiC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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
|
-
const BackStatus = /*#__PURE__*/(
|
|
121
|
+
})("color:", colors.textLead, ";font-size:14px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAqJiC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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"]} */"));
|
|
122
|
+
const BackStatus = /*#__PURE__*/_styled("div", {
|
|
129
123
|
target: "e1d2l9mo13",
|
|
130
124
|
label: "BackStatus"
|
|
131
125
|
})(process.env.NODE_ENV === "production" ? {
|
|
@@ -137,55 +131,55 @@ const BackStatus = /*#__PURE__*/(0, _base.default)("div", {
|
|
|
137
131
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA0J6B","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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
132
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
139
133
|
});
|
|
140
|
-
const BackStatusUnchanged = /*#__PURE__*/(
|
|
134
|
+
const BackStatusUnchanged = /*#__PURE__*/_styled(BackStatus, {
|
|
141
135
|
target: "e1d2l9mo12",
|
|
142
136
|
label: "BackStatusUnchanged"
|
|
143
|
-
})(_decapCmsUiDefault.components.textBadgeSuccess, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA8J8C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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
|
-
const BackStatusChanged = /*#__PURE__*/(
|
|
137
|
+
})(components.textBadgeSuccess, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA8J8C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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
|
+
const BackStatusChanged = /*#__PURE__*/_styled(BackStatus, {
|
|
145
139
|
target: "e1d2l9mo11",
|
|
146
140
|
label: "BackStatusChanged"
|
|
147
|
-
})(_decapCmsUiDefault.components.textBadgeDanger, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAkK4C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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
|
-
const ToolbarButton = /*#__PURE__*/(
|
|
141
|
+
})(components.textBadgeDanger, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAkK4C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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"]} */"));
|
|
142
|
+
const ToolbarButton = /*#__PURE__*/_styled("button", {
|
|
149
143
|
target: "e1d2l9mo10",
|
|
150
144
|
label: "ToolbarButton"
|
|
151
|
-
})(_decapCmsUiDefault.buttons.button, ";", _decapCmsUiDefault.buttons.default, ";", styles.buttonMargin, ";", styles.noOverflow, ";display:block;@media (max-width: 1200px){padding:0 10px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAsKmC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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
|
-
const DeleteButton = /*#__PURE__*/(
|
|
145
|
+
})(buttons.button, ";", buttons.default, ";", styles.buttonMargin, ";", styles.noOverflow, ";display:block;@media (max-width: 1200px){padding:0 10px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAsKmC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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"]} */"));
|
|
146
|
+
const DeleteButton = /*#__PURE__*/_styled(ToolbarButton, {
|
|
153
147
|
target: "e1d2l9mo9",
|
|
154
148
|
label: "DeleteButton"
|
|
155
|
-
})(_decapCmsUiDefault.buttons.lightRed, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAkL0C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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
|
-
const SaveButton = /*#__PURE__*/(
|
|
149
|
+
})(buttons.lightRed, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAkL0C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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"]} */"));
|
|
150
|
+
const SaveButton = /*#__PURE__*/_styled(ToolbarButton, {
|
|
157
151
|
target: "e1d2l9mo8",
|
|
158
152
|
label: "SaveButton"
|
|
159
|
-
})(_decapCmsUiDefault.buttons.lightBlue, ";&[disabled]{", _decapCmsUiDefault.buttons.disabled, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAsLwC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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
|
-
const PublishedToolbarButton = /*#__PURE__*/(
|
|
153
|
+
})(buttons.lightBlue, ";&[disabled]{", buttons.disabled, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAsLwC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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"]} */"));
|
|
154
|
+
const PublishedToolbarButton = /*#__PURE__*/_styled(DropdownButton, {
|
|
161
155
|
target: "e1d2l9mo7",
|
|
162
156
|
label: "PublishedToolbarButton"
|
|
163
157
|
})(styles.publishedButton, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA6LqD","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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
|
-
const PublishedButton = /*#__PURE__*/(
|
|
158
|
+
const PublishedButton = /*#__PURE__*/_styled(ToolbarButton, {
|
|
165
159
|
target: "e1d2l9mo6",
|
|
166
160
|
label: "PublishedButton"
|
|
167
161
|
})(styles.publishedButton, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAiM6C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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
|
-
const PublishButton = /*#__PURE__*/(
|
|
162
|
+
const PublishButton = /*#__PURE__*/_styled(DropdownButton, {
|
|
169
163
|
target: "e1d2l9mo5",
|
|
170
164
|
label: "PublishButton"
|
|
171
|
-
})("background-color:", _decapCmsUiDefault.colorsRaw.teal, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAqM4C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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
|
-
const StatusButton = /*#__PURE__*/(
|
|
165
|
+
})("background-color:", colorsRaw.teal, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAqM4C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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"]} */"));
|
|
166
|
+
const StatusButton = /*#__PURE__*/_styled(DropdownButton, {
|
|
173
167
|
target: "e1d2l9mo4",
|
|
174
168
|
label: "StatusButton"
|
|
175
|
-
})("background-color:", _decapCmsUiDefault.colorsRaw.tealLight, ";color:", _decapCmsUiDefault.colorsRaw.teal, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAyM2C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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
|
-
const PreviewButtonContainer = /*#__PURE__*/(
|
|
169
|
+
})("background-color:", colorsRaw.tealLight, ";color:", colorsRaw.teal, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAyM2C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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"]} */"));
|
|
170
|
+
const PreviewButtonContainer = /*#__PURE__*/_styled("div", {
|
|
177
171
|
target: "e1d2l9mo3",
|
|
178
172
|
label: "PreviewButtonContainer"
|
|
179
|
-
})("margin-right:12px;color:", _decapCmsUiDefault.colorsRaw.blue, ";display:flex;align-items:center;a,", _decapCmsUiDefault.Icon, "{color:", _decapCmsUiDefault.colorsRaw.blue, ";}", _decapCmsUiDefault.Icon, "{position:relative;top:1px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA8MyC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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
|
-
const RefreshPreviewButton = /*#__PURE__*/(
|
|
173
|
+
})("margin-right:12px;color:", colorsRaw.blue, ";display:flex;align-items:center;a,", Icon, "{color:", colorsRaw.blue, ";}", Icon, "{position:relative;top:1px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA8MyC","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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"]} */"));
|
|
174
|
+
const RefreshPreviewButton = /*#__PURE__*/_styled("button", {
|
|
181
175
|
target: "e1d2l9mo2",
|
|
182
176
|
label: "RefreshPreviewButton"
|
|
183
|
-
})("background:none;border:0;cursor:pointer;color:", _decapCmsUiDefault.colorsRaw.blue, ";span{margin-right:6px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA+N0C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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"]} */"));
|
|
177
|
+
})("background:none;border:0;cursor:pointer;color:", colorsRaw.blue, ";span{margin-right:6px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA+N0C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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
178
|
const PreviewLink = RefreshPreviewButton.withComponent('a', {
|
|
185
179
|
target: "e1d2l9mo27",
|
|
186
180
|
label: "PreviewLink"
|
|
187
181
|
});
|
|
188
|
-
const PublishDropDownItem = /*#__PURE__*/(
|
|
182
|
+
const PublishDropDownItem = /*#__PURE__*/_styled(DropdownItem, {
|
|
189
183
|
target: "e1d2l9mo1",
|
|
190
184
|
label: "PublishDropDownItem"
|
|
191
185
|
})(process.env.NODE_ENV === "production" ? {
|
|
@@ -197,11 +191,11 @@ const PublishDropDownItem = /*#__PURE__*/(0, _base.default)(_decapCmsUiDefault.D
|
|
|
197
191
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AA4OgD","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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
192
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
199
193
|
});
|
|
200
|
-
const StatusDropdownItem = /*#__PURE__*/(
|
|
194
|
+
const StatusDropdownItem = /*#__PURE__*/_styled(DropdownItem, {
|
|
201
195
|
target: "e1d2l9mo0",
|
|
202
196
|
label: "StatusDropdownItem"
|
|
203
|
-
})(_decapCmsUiDefault.Icon, "{color:", _decapCmsUiDefault.colors.infoText, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAgP+C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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
|
-
class EditorToolbar extends
|
|
197
|
+
})(Icon, "{color:", colors.infoText, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Editor/EditorToolbar.js"],"names":[],"mappings":"AAgP+C","file":"../../../../src/components/Editor/EditorToolbar.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { translate } from 'react-polyglot';\nimport { Link } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colorsRaw,\n  colors,\n  components,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\n\nimport { status } from '../../constants/publishModes';\nimport { SettingsDropdown } from '../UI';\n\nconst styles = {\n  noOverflow: css`\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n  `,\n  buttonMargin: css`\n    margin: 0 10px;\n  `,\n  toolbarSection: css`\n    height: 100%;\n    display: flex;\n    align-items: center;\n    border: 0 solid ${colors.textFieldBorder};\n  `,\n  publishedButton: css`\n    background-color: ${colorsRaw.tealLight};\n    color: ${colorsRaw.tealDark};\n  `,\n};\n\nconst TooltipText = styled.div`\n  visibility: hidden;\n  width: 321px;\n  background-color: #555;\n  color: #fff;\n  text-align: unset;\n  border-radius: 6px;\n  padding: 5px;\n\n  /* Position the tooltip text */\n  position: absolute;\n  z-index: 1;\n  top: 145%;\n  left: 50%;\n  margin-left: -320px;\n\n  /* Fade in tooltip */\n  opacity: 0;\n  transition: opacity 0.3s;\n`;\n\nconst Tooltip = styled.div`\n  position: relative;\n  display: inline-block;\n  &:hover + ${TooltipText} {\n    visibility: visible;\n    opacity: 0.9;\n  }\n`;\n\nconst TooltipContainer = styled.div`\n  position: relative;\n`;\n\nconst DropdownButton = styled(StyledDropdownButton)`\n  ${styles.noOverflow}\n  @media (max-width: 1200px) {\n    padding-left: 10px;\n  }\n`;\n\nconst ToolbarContainer = styled.div`\n  box-shadow: 0 2px 6px 0 rgba(68, 74, 87, 0.05), 0 1px 3px 0 rgba(68, 74, 87, 0.1),\n    0 2px 54px rgba(0, 0, 0, 0.1);\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 100%;\n  min-width: 800px;\n  z-index: ${zIndex.zIndex300};\n  background-color: #fff;\n  height: 66px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst ToolbarSectionMain = styled.div`\n  ${styles.toolbarSection};\n  flex: 10;\n  display: flex;\n  justify-content: space-between;\n  padding: 0 10px;\n`;\n\nconst ToolbarSubSectionFirst = styled.div`\n  display: flex;\n  align-items: center;\n`;\n\nconst ToolbarSubSectionLast = styled(ToolbarSubSectionFirst)`\n  justify-content: flex-end;\n`;\n\nconst ToolbarSectionBackLink = styled(Link)`\n  ${styles.toolbarSection};\n  border-right-width: 1px;\n  font-weight: normal;\n  padding: 0 20px;\n\n  &:hover,\n  &:focus {\n    background-color: #f1f2f4;\n  }\n`;\n\nconst ToolbarSectionMeta = styled.div`\n  ${styles.toolbarSection};\n  border-left-width: 1px;\n  padding: 0 7px;\n`;\n\nconst ToolbarDropdown = styled(Dropdown)`\n  ${styles.buttonMargin};\n\n  ${Icon} {\n    color: ${colorsRaw.teal};\n  }\n`;\n\nconst BackArrow = styled.div`\n  color: ${colors.textLead};\n  font-size: 21px;\n  font-weight: 600;\n  margin-right: 16px;\n`;\n\nconst BackCollection = styled.div`\n  color: ${colors.textLead};\n  font-size: 14px;\n`;\n\nconst BackStatus = styled.div`\n  margin-top: 6px;\n`;\n\nconst BackStatusUnchanged = styled(BackStatus)`\n  ${components.textBadgeSuccess};\n`;\n\nconst BackStatusChanged = styled(BackStatus)`\n  ${components.textBadgeDanger};\n`;\n\nconst ToolbarButton = styled.button`\n  ${buttons.button};\n  ${buttons.default};\n  ${styles.buttonMargin};\n  ${styles.noOverflow};\n  display: block;\n\n  @media (max-width: 1200px) {\n    padding: 0 10px;\n  }\n`;\n\nconst DeleteButton = styled(ToolbarButton)`\n  ${buttons.lightRed};\n`;\n\nconst SaveButton = styled(ToolbarButton)`\n  ${buttons.lightBlue};\n  &[disabled] {\n    ${buttons.disabled};\n  }\n`;\n\nconst PublishedToolbarButton = styled(DropdownButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishedButton = styled(ToolbarButton)`\n  ${styles.publishedButton}\n`;\n\nconst PublishButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.teal};\n`;\n\nconst StatusButton = styled(DropdownButton)`\n  background-color: ${colorsRaw.tealLight};\n  color: ${colorsRaw.teal};\n`;\n\nconst PreviewButtonContainer = styled.div`\n  margin-right: 12px;\n  color: ${colorsRaw.blue};\n  display: flex;\n  align-items: center;\n\n  a,\n  ${Icon} {\n    color: ${colorsRaw.blue};\n  }\n\n  ${Icon} {\n    position: relative;\n    top: 1px;\n  }\n`;\n\nconst RefreshPreviewButton = styled.button`\n  background: none;\n  border: 0;\n  cursor: pointer;\n  color: ${colorsRaw.blue};\n\n  span {\n    margin-right: 6px;\n  }\n`;\n\nconst PreviewLink = RefreshPreviewButton.withComponent('a');\n\nconst PublishDropDownItem = styled(DropdownItem)`\n  min-width: initial;\n`;\n\nconst StatusDropdownItem = styled(DropdownItem)`\n  ${Icon} {\n    color: ${colors.infoText};\n  }\n`;\n\nexport class EditorToolbar extends React.Component {\n  static propTypes = {\n    isPersisting: PropTypes.bool,\n    isPublishing: PropTypes.bool,\n    isUpdatingStatus: PropTypes.bool,\n    isDeleting: PropTypes.bool,\n    onPersist: PropTypes.func.isRequired,\n    onPersistAndNew: PropTypes.func.isRequired,\n    onPersistAndDuplicate: PropTypes.func.isRequired,\n    showDelete: PropTypes.bool.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onDeleteUnpublishedChanges: PropTypes.func.isRequired,\n    onChangeStatus: PropTypes.func.isRequired,\n    onPublish: PropTypes.func.isRequired,\n    unPublish: PropTypes.func.isRequired,\n    onDuplicate: PropTypes.func.isRequired,\n    onPublishAndNew: PropTypes.func.isRequired,\n    onPublishAndDuplicate: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    hasChanged: PropTypes.bool,\n    displayUrl: PropTypes.string,\n    collection: ImmutablePropTypes.map.isRequired,\n    hasWorkflow: PropTypes.bool,\n    useOpenAuthoring: PropTypes.bool,\n    hasUnpublishedChanges: PropTypes.bool,\n    isNewEntry: PropTypes.bool,\n    isModification: PropTypes.bool,\n    currentStatus: PropTypes.string,\n    onLogoutClick: PropTypes.func.isRequired,\n    deployPreview: PropTypes.object,\n    loadDeployPreview: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    editorBackLink: PropTypes.string.isRequired,\n  };\n\n  componentDidMount() {\n    const { isNewEntry, loadDeployPreview } = this.props;\n    if (!isNewEntry) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const { isNewEntry, isPersisting, loadDeployPreview } = this.props;\n    if (!isNewEntry && prevProps.isPersisting && !isPersisting) {\n      loadDeployPreview({ maxAttempts: 3 });\n    }\n  }\n\n  renderSimpleControls = () => {\n    const { collection, hasChanged, isNewEntry, showDelete, onDelete, t } = this.props;\n    const canCreate = collection.get('create');\n\n    return (\n      <>\n        {!isNewEntry && !hasChanged\n          ? this.renderExistingEntrySimplePublishControls({ canCreate })\n          : this.renderNewEntrySimplePublishControls({ canCreate })}\n        <div>\n          {showDelete ? (\n            <DeleteButton onClick={onDelete}>{t('editor.editorToolbar.deleteEntry')}</DeleteButton>\n          ) : null}\n        </div>\n      </>\n    );\n  };\n\n  renderDeployPreviewControls = label => {\n    const { deployPreview = {}, loadDeployPreview, t } = this.props;\n    const { url, status, isFetching } = deployPreview;\n\n    if (!status) {\n      return;\n    }\n\n    const deployPreviewReady = status === 'SUCCESS' && !isFetching;\n    return (\n      <PreviewButtonContainer>\n        {deployPreviewReady ? (\n          <PreviewLink rel=\"noopener noreferrer\" target=\"_blank\" href={url}>\n            <span>{label}</span>\n            <Icon type=\"new-tab\" size=\"xsmall\" />\n          </PreviewLink>\n        ) : (\n          <RefreshPreviewButton onClick={loadDeployPreview}>\n            <span>{t('editor.editorToolbar.deployPreviewPendingButtonLabel')}</span>\n            <Icon type=\"refresh\" size=\"xsmall\" />\n          </RefreshPreviewButton>\n        )}\n      </PreviewButtonContainer>\n    );\n  };\n\n  renderStatusInfoTooltip = () => {\n    const { t, currentStatus } = this.props;\n\n    const statusToLocaleKey = {\n      [status.get('DRAFT')]: 'statusInfoTooltipDraft',\n      [status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview',\n    };\n\n    const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);\n    return (\n      <TooltipContainer>\n        <Tooltip>\n          <Icon type=\"info-circle\" size=\"small\" className=\"tooltip\" />\n        </Tooltip>\n        {statusKey && (\n          <TooltipText>{t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)}</TooltipText>\n        )}\n      </TooltipContainer>\n    );\n  };\n\n  renderWorkflowStatusControls = () => {\n    const { isUpdatingStatus, onChangeStatus, currentStatus, t, useOpenAuthoring } = this.props;\n\n    const statusToTranslation = {\n      [status.get('DRAFT')]: t('editor.editorToolbar.draft'),\n      [status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),\n      [status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready'),\n    };\n\n    const buttonText = isUpdatingStatus\n      ? t('editor.editorToolbar.updating')\n      : t('editor.editorToolbar.status', { status: statusToTranslation[currentStatus] });\n\n    return (\n      <>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"120px\"\n          renderButton={() => <StatusButton>{buttonText}</StatusButton>}\n        >\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.draft')}\n            onClick={() => onChangeStatus('DRAFT')}\n            icon={currentStatus === status.get('DRAFT') ? 'check' : null}\n          />\n          <StatusDropdownItem\n            label={t('editor.editorToolbar.inReview')}\n            onClick={() => onChangeStatus('PENDING_REVIEW')}\n            icon={currentStatus === status.get('PENDING_REVIEW') ? 'check' : null}\n          />\n          {useOpenAuthoring ? (\n            ''\n          ) : (\n            <StatusDropdownItem\n              label={t('editor.editorToolbar.ready')}\n              onClick={() => onChangeStatus('PENDING_PUBLISH')}\n              icon={currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null}\n            />\n          )}\n        </ToolbarDropdown>\n        {useOpenAuthoring && this.renderStatusInfoTooltip()}\n      </>\n    );\n  };\n\n  renderNewEntryWorkflowPublishControls = ({ canCreate, canPublish }) => {\n    const { isPublishing, onPublish, onPublishAndNew, onPublishAndDuplicate, t } = this.props;\n\n    return canPublish ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"200px\"\n        renderButton={() => (\n          <PublishButton>\n            {isPublishing\n              ? t('editor.editorToolbar.publishing')\n              : t('editor.editorToolbar.publish')}\n          </PublishButton>\n        )}\n      >\n        <PublishDropDownItem\n          label={t('editor.editorToolbar.publishNow')}\n          icon=\"arrow\"\n          iconDirection=\"right\"\n          onClick={onPublish}\n        />\n        {canCreate ? (\n          <>\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndCreateNew')}\n              icon=\"add\"\n              onClick={onPublishAndNew}\n            />\n            <PublishDropDownItem\n              label={t('editor.editorToolbar.publishAndDuplicate')}\n              icon=\"add\"\n              onClick={onPublishAndDuplicate}\n            />\n          </>\n        ) : null}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntryWorkflowPublishControls = ({ canCreate, canPublish, canDelete }) => {\n    const { unPublish, onDuplicate, isPersisting, t } = this.props;\n\n    return canPublish || canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        key=\"td-publish-create\"\n        renderButton={() => (\n          <PublishedToolbarButton>\n            {isPersisting\n              ? t('editor.editorToolbar.unpublishing')\n              : t('editor.editorToolbar.published')}\n          </PublishedToolbarButton>\n        )}\n      >\n        {canDelete && canPublish && (\n          <DropdownItem\n            label={t('editor.editorToolbar.unpublish')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={unPublish}\n          />\n        )}\n        {canCreate && (\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        )}\n      </ToolbarDropdown>\n    ) : (\n      ''\n    );\n  };\n\n  renderExistingEntrySimplePublishControls = ({ canCreate }) => {\n    const { onDuplicate, t } = this.props;\n    return canCreate ? (\n      <ToolbarDropdown\n        dropdownTopOverlap=\"40px\"\n        dropdownWidth=\"150px\"\n        renderButton={() => (\n          <PublishedToolbarButton>{t('editor.editorToolbar.published')}</PublishedToolbarButton>\n        )}\n      >\n        {\n          <DropdownItem\n            label={t('editor.editorToolbar.duplicate')}\n            icon=\"add\"\n            onClick={onDuplicate}\n          />\n        }\n      </ToolbarDropdown>\n    ) : (\n      <PublishedButton>{t('editor.editorToolbar.published')}</PublishedButton>\n    );\n  };\n\n  renderNewEntrySimplePublishControls = ({ canCreate }) => {\n    const { onPersist, onPersistAndNew, onPersistAndDuplicate, isPersisting, t } = this.props;\n\n    return (\n      <div>\n        <ToolbarDropdown\n          dropdownTopOverlap=\"40px\"\n          dropdownWidth=\"150px\"\n          renderButton={() => (\n            <PublishButton>\n              {isPersisting\n                ? t('editor.editorToolbar.publishing')\n                : t('editor.editorToolbar.publish')}\n            </PublishButton>\n          )}\n        >\n          <DropdownItem\n            label={t('editor.editorToolbar.publishNow')}\n            icon=\"arrow\"\n            iconDirection=\"right\"\n            onClick={onPersist}\n          />\n          {canCreate ? (\n            <>\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndCreateNew')}\n                icon=\"add\"\n                onClick={onPersistAndNew}\n              />\n              <DropdownItem\n                label={t('editor.editorToolbar.publishAndDuplicate')}\n                icon=\"add\"\n                onClick={onPersistAndDuplicate}\n              />\n            </>\n          ) : null}\n        </ToolbarDropdown>\n      </div>\n    );\n  };\n\n  renderSimpleDeployPreviewControls = () => {\n    const { hasChanged, isNewEntry, t } = this.props;\n\n    if (!isNewEntry && !hasChanged) {\n      return this.renderDeployPreviewControls(t('editor.editorToolbar.deployButtonLabel'));\n    }\n  };\n\n  renderWorkflowControls = () => {\n    const {\n      onPersist,\n      onDelete,\n      onDeleteUnpublishedChanges,\n      showDelete,\n      hasChanged,\n      hasUnpublishedChanges,\n      useOpenAuthoring,\n      isPersisting,\n      isDeleting,\n      isNewEntry,\n      isModification,\n      currentStatus,\n      collection,\n      t,\n    } = this.props;\n\n    const canCreate = collection.get('create');\n    const canPublish = collection.get('publish') && !useOpenAuthoring;\n    const canDelete = collection.get('delete', true);\n\n    const deleteLabel =\n      (hasUnpublishedChanges &&\n        isModification &&\n        t('editor.editorToolbar.deleteUnpublishedChanges')) ||\n      (hasUnpublishedChanges &&\n        (isNewEntry || !isModification) &&\n        t('editor.editorToolbar.deleteUnpublishedEntry')) ||\n      (!hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry'));\n\n    return [\n      <SaveButton\n        disabled={!hasChanged}\n        key=\"save-button\"\n        onClick={() => hasChanged && onPersist()}\n      >\n        {isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')}\n      </SaveButton>,\n      currentStatus\n        ? [\n            <React.Fragment key=\"workflow-status-controls\">\n              {this.renderWorkflowStatusControls()}\n              {!hasChanged && this.renderNewEntryWorkflowPublishControls({ canCreate, canPublish })}\n            </React.Fragment>,\n          ]\n        : !isNewEntry && (\n            <React.Fragment key=\"existing-entry-workflow-publish-controls\">\n              {this.renderExistingEntryWorkflowPublishControls({\n                canCreate,\n                canPublish,\n                canDelete,\n              })}\n            </React.Fragment>\n          ),\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
|
+
export class EditorToolbar extends React.Component {
|
|
205
199
|
constructor(...args) {
|
|
206
200
|
super(...args);
|
|
207
201
|
_defineProperty(this, "renderSimpleControls", () => {
|
|
@@ -214,11 +208,11 @@ class EditorToolbar extends _react.default.Component {
|
|
|
214
208
|
t
|
|
215
209
|
} = this.props;
|
|
216
210
|
const canCreate = collection.get('create');
|
|
217
|
-
return (
|
|
211
|
+
return ___EmotionJSX(React.Fragment, null, !isNewEntry && !hasChanged ? this.renderExistingEntrySimplePublishControls({
|
|
218
212
|
canCreate
|
|
219
213
|
}) : this.renderNewEntrySimplePublishControls({
|
|
220
214
|
canCreate
|
|
221
|
-
}), (
|
|
215
|
+
}), ___EmotionJSX("div", null, showDelete ? ___EmotionJSX(DeleteButton, {
|
|
222
216
|
onClick: onDelete
|
|
223
217
|
}, t('editor.editorToolbar.deleteEntry')) : null));
|
|
224
218
|
});
|
|
@@ -237,16 +231,16 @@ class EditorToolbar extends _react.default.Component {
|
|
|
237
231
|
return;
|
|
238
232
|
}
|
|
239
233
|
const deployPreviewReady = status === 'SUCCESS' && !isFetching;
|
|
240
|
-
return (
|
|
234
|
+
return ___EmotionJSX(PreviewButtonContainer, null, deployPreviewReady ? ___EmotionJSX(PreviewLink, {
|
|
241
235
|
rel: "noopener noreferrer",
|
|
242
236
|
target: "_blank",
|
|
243
237
|
href: url
|
|
244
|
-
}, (
|
|
238
|
+
}, ___EmotionJSX("span", null, label), ___EmotionJSX(Icon, {
|
|
245
239
|
type: "new-tab",
|
|
246
240
|
size: "xsmall"
|
|
247
|
-
})) : (
|
|
241
|
+
})) : ___EmotionJSX(RefreshPreviewButton, {
|
|
248
242
|
onClick: loadDeployPreview
|
|
249
|
-
}, (
|
|
243
|
+
}, ___EmotionJSX("span", null, t('editor.editorToolbar.deployPreviewPendingButtonLabel')), ___EmotionJSX(Icon, {
|
|
250
244
|
type: "refresh",
|
|
251
245
|
size: "xsmall"
|
|
252
246
|
})));
|
|
@@ -257,15 +251,15 @@ class EditorToolbar extends _react.default.Component {
|
|
|
257
251
|
currentStatus
|
|
258
252
|
} = this.props;
|
|
259
253
|
const statusToLocaleKey = {
|
|
260
|
-
[
|
|
261
|
-
[
|
|
254
|
+
[status.get('DRAFT')]: 'statusInfoTooltipDraft',
|
|
255
|
+
[status.get('PENDING_REVIEW')]: 'statusInfoTooltipInReview'
|
|
262
256
|
};
|
|
263
257
|
const statusKey = Object.keys(statusToLocaleKey).find(key => key === currentStatus);
|
|
264
|
-
return (
|
|
258
|
+
return ___EmotionJSX(TooltipContainer, null, ___EmotionJSX(Tooltip, null, ___EmotionJSX(Icon, {
|
|
265
259
|
type: "info-circle",
|
|
266
260
|
size: "small",
|
|
267
261
|
className: "tooltip"
|
|
268
|
-
})), statusKey && (
|
|
262
|
+
})), statusKey && ___EmotionJSX(TooltipText, null, t(`editor.editorToolbar.${statusToLocaleKey[statusKey]}`)));
|
|
269
263
|
});
|
|
270
264
|
_defineProperty(this, "renderWorkflowStatusControls", () => {
|
|
271
265
|
const {
|
|
@@ -276,29 +270,29 @@ class EditorToolbar extends _react.default.Component {
|
|
|
276
270
|
useOpenAuthoring
|
|
277
271
|
} = this.props;
|
|
278
272
|
const statusToTranslation = {
|
|
279
|
-
[
|
|
280
|
-
[
|
|
281
|
-
[
|
|
273
|
+
[status.get('DRAFT')]: t('editor.editorToolbar.draft'),
|
|
274
|
+
[status.get('PENDING_REVIEW')]: t('editor.editorToolbar.inReview'),
|
|
275
|
+
[status.get('PENDING_PUBLISH')]: t('editor.editorToolbar.ready')
|
|
282
276
|
};
|
|
283
277
|
const buttonText = isUpdatingStatus ? t('editor.editorToolbar.updating') : t('editor.editorToolbar.status', {
|
|
284
278
|
status: statusToTranslation[currentStatus]
|
|
285
279
|
});
|
|
286
|
-
return (
|
|
280
|
+
return ___EmotionJSX(React.Fragment, null, ___EmotionJSX(ToolbarDropdown, {
|
|
287
281
|
dropdownTopOverlap: "40px",
|
|
288
282
|
dropdownWidth: "120px",
|
|
289
|
-
renderButton: () => (
|
|
290
|
-
}, (
|
|
283
|
+
renderButton: () => ___EmotionJSX(StatusButton, null, buttonText)
|
|
284
|
+
}, ___EmotionJSX(StatusDropdownItem, {
|
|
291
285
|
label: t('editor.editorToolbar.draft'),
|
|
292
286
|
onClick: () => onChangeStatus('DRAFT'),
|
|
293
|
-
icon: currentStatus ===
|
|
294
|
-
}), (
|
|
287
|
+
icon: currentStatus === status.get('DRAFT') ? 'check' : null
|
|
288
|
+
}), ___EmotionJSX(StatusDropdownItem, {
|
|
295
289
|
label: t('editor.editorToolbar.inReview'),
|
|
296
290
|
onClick: () => onChangeStatus('PENDING_REVIEW'),
|
|
297
|
-
icon: currentStatus ===
|
|
298
|
-
}), useOpenAuthoring ? '' : (
|
|
291
|
+
icon: currentStatus === status.get('PENDING_REVIEW') ? 'check' : null
|
|
292
|
+
}), useOpenAuthoring ? '' : ___EmotionJSX(StatusDropdownItem, {
|
|
299
293
|
label: t('editor.editorToolbar.ready'),
|
|
300
294
|
onClick: () => onChangeStatus('PENDING_PUBLISH'),
|
|
301
|
-
icon: currentStatus ===
|
|
295
|
+
icon: currentStatus === status.get('PENDING_PUBLISH') ? 'check' : null
|
|
302
296
|
})), useOpenAuthoring && this.renderStatusInfoTooltip());
|
|
303
297
|
});
|
|
304
298
|
_defineProperty(this, "renderNewEntryWorkflowPublishControls", ({
|
|
@@ -312,20 +306,20 @@ class EditorToolbar extends _react.default.Component {
|
|
|
312
306
|
onPublishAndDuplicate,
|
|
313
307
|
t
|
|
314
308
|
} = this.props;
|
|
315
|
-
return canPublish ? (
|
|
309
|
+
return canPublish ? ___EmotionJSX(ToolbarDropdown, {
|
|
316
310
|
dropdownTopOverlap: "40px",
|
|
317
311
|
dropdownWidth: "200px",
|
|
318
|
-
renderButton: () => (
|
|
319
|
-
}, (
|
|
312
|
+
renderButton: () => ___EmotionJSX(PublishButton, null, isPublishing ? t('editor.editorToolbar.publishing') : t('editor.editorToolbar.publish'))
|
|
313
|
+
}, ___EmotionJSX(PublishDropDownItem, {
|
|
320
314
|
label: t('editor.editorToolbar.publishNow'),
|
|
321
315
|
icon: "arrow",
|
|
322
316
|
iconDirection: "right",
|
|
323
317
|
onClick: onPublish
|
|
324
|
-
}), canCreate ? (
|
|
318
|
+
}), canCreate ? ___EmotionJSX(React.Fragment, null, ___EmotionJSX(PublishDropDownItem, {
|
|
325
319
|
label: t('editor.editorToolbar.publishAndCreateNew'),
|
|
326
320
|
icon: "add",
|
|
327
321
|
onClick: onPublishAndNew
|
|
328
|
-
}), (
|
|
322
|
+
}), ___EmotionJSX(PublishDropDownItem, {
|
|
329
323
|
label: t('editor.editorToolbar.publishAndDuplicate'),
|
|
330
324
|
icon: "add",
|
|
331
325
|
onClick: onPublishAndDuplicate
|
|
@@ -342,17 +336,17 @@ class EditorToolbar extends _react.default.Component {
|
|
|
342
336
|
isPersisting,
|
|
343
337
|
t
|
|
344
338
|
} = this.props;
|
|
345
|
-
return canPublish || canCreate ? (
|
|
339
|
+
return canPublish || canCreate ? ___EmotionJSX(ToolbarDropdown, {
|
|
346
340
|
dropdownTopOverlap: "40px",
|
|
347
341
|
dropdownWidth: "150px",
|
|
348
342
|
key: "td-publish-create",
|
|
349
|
-
renderButton: () => (
|
|
350
|
-
}, canDelete && canPublish && (
|
|
343
|
+
renderButton: () => ___EmotionJSX(PublishedToolbarButton, null, isPersisting ? t('editor.editorToolbar.unpublishing') : t('editor.editorToolbar.published'))
|
|
344
|
+
}, canDelete && canPublish && ___EmotionJSX(DropdownItem, {
|
|
351
345
|
label: t('editor.editorToolbar.unpublish'),
|
|
352
346
|
icon: "arrow",
|
|
353
347
|
iconDirection: "right",
|
|
354
348
|
onClick: unPublish
|
|
355
|
-
}), canCreate && (
|
|
349
|
+
}), canCreate && ___EmotionJSX(DropdownItem, {
|
|
356
350
|
label: t('editor.editorToolbar.duplicate'),
|
|
357
351
|
icon: "add",
|
|
358
352
|
onClick: onDuplicate
|
|
@@ -365,15 +359,15 @@ class EditorToolbar extends _react.default.Component {
|
|
|
365
359
|
onDuplicate,
|
|
366
360
|
t
|
|
367
361
|
} = this.props;
|
|
368
|
-
return canCreate ? (
|
|
362
|
+
return canCreate ? ___EmotionJSX(ToolbarDropdown, {
|
|
369
363
|
dropdownTopOverlap: "40px",
|
|
370
364
|
dropdownWidth: "150px",
|
|
371
|
-
renderButton: () => (
|
|
372
|
-
}, (
|
|
365
|
+
renderButton: () => ___EmotionJSX(PublishedToolbarButton, null, t('editor.editorToolbar.published'))
|
|
366
|
+
}, ___EmotionJSX(DropdownItem, {
|
|
373
367
|
label: t('editor.editorToolbar.duplicate'),
|
|
374
368
|
icon: "add",
|
|
375
369
|
onClick: onDuplicate
|
|
376
|
-
})) : (
|
|
370
|
+
})) : ___EmotionJSX(PublishedButton, null, t('editor.editorToolbar.published'));
|
|
377
371
|
});
|
|
378
372
|
_defineProperty(this, "renderNewEntrySimplePublishControls", ({
|
|
379
373
|
canCreate
|
|
@@ -385,20 +379,20 @@ class EditorToolbar extends _react.default.Component {
|
|
|
385
379
|
isPersisting,
|
|
386
380
|
t
|
|
387
381
|
} = this.props;
|
|
388
|
-
return (
|
|
382
|
+
return ___EmotionJSX("div", null, ___EmotionJSX(ToolbarDropdown, {
|
|
389
383
|
dropdownTopOverlap: "40px",
|
|
390
384
|
dropdownWidth: "150px",
|
|
391
|
-
renderButton: () => (
|
|
392
|
-
}, (
|
|
385
|
+
renderButton: () => ___EmotionJSX(PublishButton, null, isPersisting ? t('editor.editorToolbar.publishing') : t('editor.editorToolbar.publish'))
|
|
386
|
+
}, ___EmotionJSX(DropdownItem, {
|
|
393
387
|
label: t('editor.editorToolbar.publishNow'),
|
|
394
388
|
icon: "arrow",
|
|
395
389
|
iconDirection: "right",
|
|
396
390
|
onClick: onPersist
|
|
397
|
-
}), canCreate ? (
|
|
391
|
+
}), canCreate ? ___EmotionJSX(React.Fragment, null, ___EmotionJSX(DropdownItem, {
|
|
398
392
|
label: t('editor.editorToolbar.publishAndCreateNew'),
|
|
399
393
|
icon: "add",
|
|
400
394
|
onClick: onPersistAndNew
|
|
401
|
-
}), (
|
|
395
|
+
}), ___EmotionJSX(DropdownItem, {
|
|
402
396
|
label: t('editor.editorToolbar.publishAndDuplicate'),
|
|
403
397
|
icon: "add",
|
|
404
398
|
onClick: onPersistAndDuplicate
|
|
@@ -435,22 +429,22 @@ class EditorToolbar extends _react.default.Component {
|
|
|
435
429
|
const canPublish = collection.get('publish') && !useOpenAuthoring;
|
|
436
430
|
const canDelete = collection.get('delete', true);
|
|
437
431
|
const deleteLabel = hasUnpublishedChanges && isModification && t('editor.editorToolbar.deleteUnpublishedChanges') || hasUnpublishedChanges && (isNewEntry || !isModification) && t('editor.editorToolbar.deleteUnpublishedEntry') || !hasUnpublishedChanges && !isModification && t('editor.editorToolbar.deletePublishedEntry');
|
|
438
|
-
return [(
|
|
432
|
+
return [___EmotionJSX(SaveButton, {
|
|
439
433
|
disabled: !hasChanged,
|
|
440
434
|
key: "save-button",
|
|
441
435
|
onClick: () => hasChanged && onPersist()
|
|
442
|
-
}, isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')), currentStatus ? [(
|
|
436
|
+
}, isPersisting ? t('editor.editorToolbar.saving') : t('editor.editorToolbar.save')), currentStatus ? [___EmotionJSX(React.Fragment, {
|
|
443
437
|
key: "workflow-status-controls"
|
|
444
438
|
}, this.renderWorkflowStatusControls(), !hasChanged && this.renderNewEntryWorkflowPublishControls({
|
|
445
439
|
canCreate,
|
|
446
440
|
canPublish
|
|
447
|
-
}))] : !isNewEntry && (
|
|
441
|
+
}))] : !isNewEntry && ___EmotionJSX(React.Fragment, {
|
|
448
442
|
key: "existing-entry-workflow-publish-controls"
|
|
449
443
|
}, this.renderExistingEntryWorkflowPublishControls({
|
|
450
444
|
canCreate,
|
|
451
445
|
canPublish,
|
|
452
446
|
canDelete
|
|
453
|
-
})), (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : (
|
|
447
|
+
})), (!showDelete || useOpenAuthoring) && !hasUnpublishedChanges && !isModification ? null : ___EmotionJSX(DeleteButton, {
|
|
454
448
|
key: "delete-button",
|
|
455
449
|
onClick: hasUnpublishedChanges ? onDeleteUnpublishedChanges : onDelete
|
|
456
450
|
}, isDeleting ? t('editor.editorToolbar.deleting') : deleteLabel)];
|
|
@@ -507,49 +501,48 @@ class EditorToolbar extends _react.default.Component {
|
|
|
507
501
|
t,
|
|
508
502
|
editorBackLink
|
|
509
503
|
} = this.props;
|
|
510
|
-
return (
|
|
504
|
+
return ___EmotionJSX(ToolbarContainer, null, ___EmotionJSX(ToolbarSectionBackLink, {
|
|
511
505
|
to: editorBackLink
|
|
512
|
-
}, (
|
|
506
|
+
}, ___EmotionJSX(BackArrow, null, "\u2190"), ___EmotionJSX("div", null, ___EmotionJSX(BackCollection, null, t('editor.editorToolbar.backCollection', {
|
|
513
507
|
collectionLabel: collection.get('label')
|
|
514
|
-
})), hasChanged ? (
|
|
508
|
+
})), hasChanged ? ___EmotionJSX(BackStatusChanged, null, t('editor.editorToolbar.unsavedChanges')) : ___EmotionJSX(BackStatusUnchanged, null, t('editor.editorToolbar.changesSaved')))), ___EmotionJSX(ToolbarSectionMain, null, ___EmotionJSX(ToolbarSubSectionFirst, null, hasWorkflow ? this.renderWorkflowControls() : this.renderSimpleControls()), ___EmotionJSX(ToolbarSubSectionLast, null, hasWorkflow ? this.renderWorkflowDeployPreviewControls() : this.renderSimpleDeployPreviewControls())), ___EmotionJSX(ToolbarSectionMeta, null, ___EmotionJSX(SettingsDropdown, {
|
|
515
509
|
displayUrl: displayUrl,
|
|
516
510
|
imageUrl: user === null || user === void 0 ? void 0 : user.avatar_url,
|
|
517
511
|
onLogoutClick: onLogoutClick
|
|
518
512
|
})));
|
|
519
513
|
}
|
|
520
514
|
}
|
|
521
|
-
exports.EditorToolbar = EditorToolbar;
|
|
522
515
|
_defineProperty(EditorToolbar, "propTypes", {
|
|
523
|
-
isPersisting:
|
|
524
|
-
isPublishing:
|
|
525
|
-
isUpdatingStatus:
|
|
526
|
-
isDeleting:
|
|
527
|
-
onPersist:
|
|
528
|
-
onPersistAndNew:
|
|
529
|
-
onPersistAndDuplicate:
|
|
530
|
-
showDelete:
|
|
531
|
-
onDelete:
|
|
532
|
-
onDeleteUnpublishedChanges:
|
|
533
|
-
onChangeStatus:
|
|
534
|
-
onPublish:
|
|
535
|
-
unPublish:
|
|
536
|
-
onDuplicate:
|
|
537
|
-
onPublishAndNew:
|
|
538
|
-
onPublishAndDuplicate:
|
|
539
|
-
user:
|
|
540
|
-
hasChanged:
|
|
541
|
-
displayUrl:
|
|
542
|
-
collection:
|
|
543
|
-
hasWorkflow:
|
|
544
|
-
useOpenAuthoring:
|
|
545
|
-
hasUnpublishedChanges:
|
|
546
|
-
isNewEntry:
|
|
547
|
-
isModification:
|
|
548
|
-
currentStatus:
|
|
549
|
-
onLogoutClick:
|
|
550
|
-
deployPreview:
|
|
551
|
-
loadDeployPreview:
|
|
552
|
-
t:
|
|
553
|
-
editorBackLink:
|
|
516
|
+
isPersisting: PropTypes.bool,
|
|
517
|
+
isPublishing: PropTypes.bool,
|
|
518
|
+
isUpdatingStatus: PropTypes.bool,
|
|
519
|
+
isDeleting: PropTypes.bool,
|
|
520
|
+
onPersist: PropTypes.func.isRequired,
|
|
521
|
+
onPersistAndNew: PropTypes.func.isRequired,
|
|
522
|
+
onPersistAndDuplicate: PropTypes.func.isRequired,
|
|
523
|
+
showDelete: PropTypes.bool.isRequired,
|
|
524
|
+
onDelete: PropTypes.func.isRequired,
|
|
525
|
+
onDeleteUnpublishedChanges: PropTypes.func.isRequired,
|
|
526
|
+
onChangeStatus: PropTypes.func.isRequired,
|
|
527
|
+
onPublish: PropTypes.func.isRequired,
|
|
528
|
+
unPublish: PropTypes.func.isRequired,
|
|
529
|
+
onDuplicate: PropTypes.func.isRequired,
|
|
530
|
+
onPublishAndNew: PropTypes.func.isRequired,
|
|
531
|
+
onPublishAndDuplicate: PropTypes.func.isRequired,
|
|
532
|
+
user: PropTypes.object,
|
|
533
|
+
hasChanged: PropTypes.bool,
|
|
534
|
+
displayUrl: PropTypes.string,
|
|
535
|
+
collection: ImmutablePropTypes.map.isRequired,
|
|
536
|
+
hasWorkflow: PropTypes.bool,
|
|
537
|
+
useOpenAuthoring: PropTypes.bool,
|
|
538
|
+
hasUnpublishedChanges: PropTypes.bool,
|
|
539
|
+
isNewEntry: PropTypes.bool,
|
|
540
|
+
isModification: PropTypes.bool,
|
|
541
|
+
currentStatus: PropTypes.string,
|
|
542
|
+
onLogoutClick: PropTypes.func.isRequired,
|
|
543
|
+
deployPreview: PropTypes.object,
|
|
544
|
+
loadDeployPreview: PropTypes.func.isRequired,
|
|
545
|
+
t: PropTypes.func.isRequired,
|
|
546
|
+
editorBackLink: PropTypes.string.isRequired
|
|
554
547
|
});
|
|
555
|
-
|
|
548
|
+
export default translate()(EditorToolbar);
|