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.
Files changed (137) hide show
  1. package/dist/decap-cms-core.js +9 -9
  2. package/dist/decap-cms-core.js.map +1 -1
  3. package/dist/esm/actions/auth.js +22 -37
  4. package/dist/esm/actions/collections.js +9 -17
  5. package/dist/esm/actions/config.js +58 -74
  6. package/dist/esm/actions/deploys.js +10 -17
  7. package/dist/esm/actions/editorialWorkflow.js +87 -101
  8. package/dist/esm/actions/entries.js +161 -211
  9. package/dist/esm/actions/media.js +31 -46
  10. package/dist/esm/actions/mediaLibrary.js +94 -126
  11. package/dist/esm/actions/notifications.js +5 -13
  12. package/dist/esm/actions/search.js +30 -47
  13. package/dist/esm/actions/status.js +13 -23
  14. package/dist/esm/actions/waitUntil.js +4 -11
  15. package/dist/esm/backend.js +132 -148
  16. package/dist/esm/bootstrap.js +37 -44
  17. package/dist/esm/components/App/App.js +82 -89
  18. package/dist/esm/components/App/Header.js +46 -52
  19. package/dist/esm/components/App/NotFoundPage.js +11 -18
  20. package/dist/esm/components/Collection/Collection.js +55 -63
  21. package/dist/esm/components/Collection/CollectionControls.js +15 -22
  22. package/dist/esm/components/Collection/CollectionSearch.js +35 -42
  23. package/dist/esm/components/Collection/CollectionTop.js +23 -30
  24. package/dist/esm/components/Collection/ControlButton.js +10 -16
  25. package/dist/esm/components/Collection/Entries/Entries.js +24 -31
  26. package/dist/esm/components/Collection/Entries/EntriesCollection.js +52 -62
  27. package/dist/esm/components/Collection/Entries/EntriesSearch.js +26 -33
  28. package/dist/esm/components/Collection/Entries/EntryCard.js +38 -45
  29. package/dist/esm/components/Collection/Entries/EntryListing.js +24 -32
  30. package/dist/esm/components/Collection/FilterControl.js +9 -16
  31. package/dist/esm/components/Collection/GroupControl.js +9 -16
  32. package/dist/esm/components/Collection/NestedCollection.js +54 -65
  33. package/dist/esm/components/Collection/Sidebar.js +36 -43
  34. package/dist/esm/components/Collection/SortControl.js +19 -26
  35. package/dist/esm/components/Collection/ViewStyleControl.js +17 -24
  36. package/dist/esm/components/Editor/Editor.js +100 -108
  37. package/dist/esm/components/Editor/EditorControlPane/EditorControl.js +105 -112
  38. package/dist/esm/components/Editor/EditorControlPane/EditorControlPane.js +68 -62
  39. package/dist/esm/components/Editor/EditorControlPane/Widget.js +87 -73
  40. package/dist/esm/components/Editor/EditorInterface.js +95 -98
  41. package/dist/esm/components/Editor/EditorPreviewPane/EditorPreview.js +13 -21
  42. package/dist/esm/components/Editor/EditorPreviewPane/EditorPreviewContent.js +64 -23
  43. package/dist/esm/components/Editor/EditorPreviewPane/EditorPreviewPane.js +94 -78
  44. package/dist/esm/components/Editor/EditorPreviewPane/PreviewHOC.js +9 -16
  45. package/dist/esm/components/Editor/EditorToolbar.js +133 -140
  46. package/dist/esm/components/Editor/withWorkflow.js +15 -22
  47. package/dist/esm/components/EditorWidgets/Unknown/UnknownControl.js +9 -16
  48. package/dist/esm/components/EditorWidgets/Unknown/UnknownPreview.js +9 -16
  49. package/dist/esm/components/EditorWidgets/index.js +4 -7
  50. package/dist/esm/components/MediaLibrary/EmptyMessage.js +12 -19
  51. package/dist/esm/components/MediaLibrary/MediaLibrary.js +55 -62
  52. package/dist/esm/components/MediaLibrary/MediaLibraryButtons.js +28 -35
  53. package/dist/esm/components/MediaLibrary/MediaLibraryCard.js +36 -43
  54. package/dist/esm/components/MediaLibrary/MediaLibraryCardGrid.js +50 -57
  55. package/dist/esm/components/MediaLibrary/MediaLibraryHeader.js +16 -23
  56. package/dist/esm/components/MediaLibrary/MediaLibraryModal.js +59 -64
  57. package/dist/esm/components/MediaLibrary/MediaLibrarySearch.js +18 -25
  58. package/dist/esm/components/MediaLibrary/MediaLibraryTop.js +39 -46
  59. package/dist/esm/components/UI/DragDrop.js +21 -30
  60. package/dist/esm/components/UI/ErrorBoundary.js +35 -43
  61. package/dist/esm/components/UI/FileUploadButton.js +11 -18
  62. package/dist/esm/components/UI/Modal.js +19 -26
  63. package/dist/esm/components/UI/Notifications.js +21 -28
  64. package/dist/esm/components/UI/SettingsDropdown.js +28 -34
  65. package/dist/esm/components/UI/index.js +6 -60
  66. package/dist/esm/components/Workflow/Workflow.js +52 -61
  67. package/dist/esm/components/Workflow/WorkflowCard.js +45 -51
  68. package/dist/esm/components/Workflow/WorkflowList.js +43 -49
  69. package/dist/esm/constants/collectionTypes.js +2 -8
  70. package/dist/esm/constants/collectionViews.js +2 -8
  71. package/dist/esm/constants/commitProps.js +2 -8
  72. package/dist/esm/constants/configSchema.js +20 -27
  73. package/dist/esm/constants/fieldInference.js +8 -15
  74. package/dist/esm/constants/publishModes.js +6 -11
  75. package/dist/esm/constants/validationErrorTypes.js +1 -7
  76. package/dist/esm/formats/formats.js +32 -41
  77. package/dist/esm/formats/frontmatter.js +18 -30
  78. package/dist/esm/formats/helpers.js +1 -7
  79. package/dist/esm/formats/json.js +1 -7
  80. package/dist/esm/formats/toml.js +11 -18
  81. package/dist/esm/formats/yaml.js +7 -14
  82. package/dist/esm/index.js +5 -12
  83. package/dist/esm/integrations/index.js +8 -16
  84. package/dist/esm/integrations/providers/algolia/implementation.js +14 -22
  85. package/dist/esm/integrations/providers/assetStore/implementation.js +10 -18
  86. package/dist/esm/lib/consoleError.js +1 -7
  87. package/dist/esm/lib/formatters.js +34 -47
  88. package/dist/esm/lib/i18n.js +37 -66
  89. package/dist/esm/lib/phrases.js +4 -11
  90. package/dist/esm/lib/registry.js +40 -75
  91. package/dist/esm/lib/serializeEntryValues.js +11 -18
  92. package/dist/esm/lib/textHelper.js +1 -7
  93. package/dist/esm/lib/urlHelper.js +28 -43
  94. package/dist/esm/mediaLibrary.js +12 -16
  95. package/dist/esm/reducers/auth.js +10 -16
  96. package/dist/esm/reducers/collections.js +70 -102
  97. package/dist/esm/reducers/combinedReducer.js +4 -11
  98. package/dist/esm/reducers/config.js +11 -19
  99. package/dist/esm/reducers/cursors.js +12 -18
  100. package/dist/esm/reducers/deploys.js +8 -15
  101. package/dist/esm/reducers/editorialWorkflow.js +37 -47
  102. package/dist/esm/reducers/entries.js +107 -132
  103. package/dist/esm/reducers/entryDraft.js +64 -72
  104. package/dist/esm/reducers/globalUI.js +5 -11
  105. package/dist/esm/reducers/index.js +43 -64
  106. package/dist/esm/reducers/integrations.js +8 -16
  107. package/dist/esm/reducers/mediaLibrary.js +43 -52
  108. package/dist/esm/reducers/medias.js +11 -18
  109. package/dist/esm/reducers/notifications.js +9 -15
  110. package/dist/esm/reducers/search.js +12 -18
  111. package/dist/esm/reducers/status.js +7 -13
  112. package/dist/esm/redux/index.js +7 -13
  113. package/dist/esm/redux/middleware/waitUntilAction.js +3 -10
  114. package/dist/esm/routing/history.js +7 -15
  115. package/dist/esm/types/diacritics.d.js +0 -1
  116. package/dist/esm/types/global.d.js +1 -5
  117. package/dist/esm/types/immutable.js +1 -5
  118. package/dist/esm/types/redux.js +7 -8
  119. package/dist/esm/types/tomlify-j0.4.d.js +0 -1
  120. package/dist/esm/valueObjects/AssetProxy.js +2 -10
  121. package/dist/esm/valueObjects/EditorComponent.js +5 -12
  122. package/dist/esm/valueObjects/Entry.js +3 -10
  123. package/package.json +3 -2
  124. package/src/components/Collection/Entries/EntriesCollection.js +7 -8
  125. package/src/components/Collection/Entries/__tests__/EntriesCollection.spec.js +3 -5
  126. package/src/components/Collection/Entries/__tests__/__snapshots__/EntriesCollection.spec.js.snap +8 -8
  127. package/src/components/Collection/NestedCollection.js +2 -2
  128. package/src/components/Collection/__tests__/__snapshots__/NestedCollection.spec.js.snap +68 -0
  129. package/src/components/Editor/EditorControlPane/EditorControl.js +0 -3
  130. package/src/components/Editor/EditorControlPane/EditorControlPane.js +21 -8
  131. package/src/components/Editor/EditorControlPane/Widget.js +22 -1
  132. package/src/components/Editor/EditorInterface.js +6 -1
  133. package/src/components/Editor/EditorPreviewPane/EditorPreviewContent.js +51 -11
  134. package/src/components/Editor/EditorPreviewPane/EditorPreviewPane.js +33 -1
  135. package/dist/esm/actions/editorControl.js +0 -14
  136. package/dist/esm/reducers/editorComponent.js +0 -1
  137. package/dist/esm/reducers/editorControl.js +0 -17
@@ -1,35 +1,29 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = void 0;
7
- var _base = _interopRequireDefault(require("@emotion/styled/base"));
8
- var _propTypes = _interopRequireDefault(require("prop-types"));
9
- var _react = _interopRequireDefault(require("react"));
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 _reactRedux = require("react-redux");
16
- var _UI = require("../UI");
17
- var _status = require("../../actions/status");
18
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
1
+ import _styled from "@emotion/styled/base";
19
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; }
20
3
  function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : String(i); }
21
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); }
22
5
  function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
23
6
  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)."; }
7
+ import PropTypes from 'prop-types';
8
+ import React from 'react';
9
+ import ImmutablePropTypes from 'react-immutable-proptypes';
10
+ import { css } from '@emotion/react';
11
+ import { translate } from 'react-polyglot';
12
+ import { NavLink } from 'react-router-dom';
13
+ import { Icon, Dropdown, DropdownItem, StyledDropdownButton, colors, lengths, shadows, buttons, zIndex } from 'decap-cms-ui-default';
14
+ import { connect } from 'react-redux';
15
+ import { SettingsDropdown } from '../UI';
16
+ import { checkBackendStatus } from '../../actions/status';
17
+ import { jsx as ___EmotionJSX } from "@emotion/react";
24
18
  const styles = {
25
- buttonActive: /*#__PURE__*/(0, _react2.css)("color:", _decapCmsUiDefault.colors.active, ";;label:buttonActive;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/App/Header.js"],"names":[],"mappings":"AAwBmB","file":"../../../../src/components/App/Header.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { translate } from 'react-polyglot';\nimport { NavLink } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colors,\n  lengths,\n  shadows,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { connect } from 'react-redux';\n\nimport { SettingsDropdown } from '../UI';\nimport { checkBackendStatus } from '../../actions/status';\n\nconst styles = {\n  buttonActive: css`\n    color: ${colors.active};\n  `,\n};\n\nfunction AppHeader(props) {\n  return (\n    <header\n      css={css`\n        ${shadows.dropMain};\n        position: sticky;\n        width: 100%;\n        top: 0;\n        background-color: ${colors.foreground};\n        z-index: ${zIndex.zIndex300};\n        height: ${lengths.topBarHeight};\n      `}\n      {...props}\n    />\n  );\n}\n\nconst AppHeaderContent = styled.div`\n  display: flex;\n  justify-content: space-between;\n  min-width: 800px;\n  max-width: 1440px;\n  padding: 0 12px;\n  margin: 0 auto;\n`;\n\nconst AppHeaderButton = styled.button`\n  ${buttons.button};\n  background: none;\n  color: #7b8290;\n  font-family: inherit;\n  font-size: 16px;\n  font-weight: 500;\n  display: inline-flex;\n  padding: 16px 20px;\n  align-items: center;\n\n  ${Icon} {\n    margin-right: 4px;\n    color: #b3b9c4;\n  }\n\n  &:hover,\n  &:active,\n  &:focus-visible {\n    ${styles.buttonActive};\n\n    ${Icon} {\n      ${styles.buttonActive};\n    }\n  }\n\n  ${props => css`\n    &.${props.activeClassName} {\n      ${styles.buttonActive};\n\n      ${Icon} {\n        ${styles.buttonActive};\n      }\n    }\n  `};\n`;\n\nconst AppHeaderNavLink = AppHeaderButton.withComponent(NavLink);\n\nconst AppHeaderActions = styled.div`\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst AppHeaderQuickNewButton = styled(StyledDropdownButton)`\n  ${buttons.button};\n  ${buttons.medium};\n  ${buttons.gray};\n  margin-right: 8px;\n\n  &:after {\n    top: 11px;\n  }\n`;\n\nconst AppHeaderNavList = styled.ul`\n  display: flex;\n  margin: 0;\n  list-style: none;\n`;\n\nclass Header extends React.Component {\n  static propTypes = {\n    user: PropTypes.object.isRequired,\n    collections: ImmutablePropTypes.map.isRequired,\n    onCreateEntryClick: PropTypes.func.isRequired,\n    onLogoutClick: PropTypes.func.isRequired,\n    openMediaLibrary: PropTypes.func.isRequired,\n    hasWorkflow: PropTypes.bool.isRequired,\n    displayUrl: PropTypes.string,\n    isTestRepo: PropTypes.bool,\n    t: PropTypes.func.isRequired,\n    checkBackendStatus: PropTypes.func.isRequired,\n  };\n\n  intervalId;\n\n  componentDidMount() {\n    this.intervalId = setInterval(() => {\n      this.props.checkBackendStatus();\n    }, 5 * 60 * 1000);\n  }\n\n  componentWillUnmount() {\n    clearInterval(this.intervalId);\n  }\n\n  handleCreatePostClick = collectionName => {\n    const { onCreateEntryClick } = this.props;\n    if (onCreateEntryClick) {\n      onCreateEntryClick(collectionName);\n    }\n  };\n\n  render() {\n    const {\n      user,\n      collections,\n      onLogoutClick,\n      openMediaLibrary,\n      hasWorkflow,\n      displayUrl,\n      isTestRepo,\n      t,\n      showMediaButton,\n    } = this.props;\n\n    const creatableCollections = collections\n      .filter(collection => collection.get('create'))\n      .toList();\n\n    return (\n      <AppHeader>\n        <AppHeaderContent>\n          <nav>\n            <AppHeaderNavList>\n              <li>\n                <AppHeaderNavLink\n                  to=\"/\"\n                  activeClassName=\"header-link-active\"\n                  isActive={(match, location) => location.pathname.startsWith('/collections/')}\n                >\n                  <Icon type=\"page\" />\n                  {t('app.header.content')}\n                </AppHeaderNavLink>\n              </li>\n              {hasWorkflow && (\n                <li>\n                  <AppHeaderNavLink to=\"/workflow\" activeClassName=\"header-link-active\">\n                    <Icon type=\"workflow\" />\n                    {t('app.header.workflow')}\n                  </AppHeaderNavLink>\n                </li>\n              )}\n              {showMediaButton && (\n                <li>\n                  <AppHeaderButton onClick={openMediaLibrary}>\n                    <Icon type=\"media-alt\" />\n                    {t('app.header.media')}\n                  </AppHeaderButton>\n                </li>\n              )}\n            </AppHeaderNavList>\n          </nav>\n          <AppHeaderActions>\n            {creatableCollections.size > 0 && (\n              <Dropdown\n                renderButton={() => (\n                  <AppHeaderQuickNewButton> {t('app.header.quickAdd')}</AppHeaderQuickNewButton>\n                )}\n                dropdownTopOverlap=\"30px\"\n                dropdownWidth=\"160px\"\n                dropdownPosition=\"left\"\n              >\n                {creatableCollections.map(collection => (\n                  <DropdownItem\n                    key={collection.get('name')}\n                    label={collection.get('label_singular') || collection.get('label')}\n                    onClick={() => this.handleCreatePostClick(collection.get('name'))}\n                  />\n                ))}\n              </Dropdown>\n            )}\n            <SettingsDropdown\n              displayUrl={displayUrl}\n              isTestRepo={isTestRepo}\n              imageUrl={user?.avatar_url}\n              onLogoutClick={onLogoutClick}\n            />\n          </AppHeaderActions>\n        </AppHeaderContent>\n      </AppHeader>\n    );\n  }\n}\n\nconst mapDispatchToProps = {\n  checkBackendStatus,\n};\n\nexport default connect(null, mapDispatchToProps)(translate()(Header));\n"]} */"))
19
+ buttonActive: /*#__PURE__*/css("color:", colors.active, ";;label:buttonActive;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/App/Header.js"],"names":[],"mappings":"AAwBmB","file":"../../../../src/components/App/Header.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { translate } from 'react-polyglot';\nimport { NavLink } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colors,\n  lengths,\n  shadows,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { connect } from 'react-redux';\n\nimport { SettingsDropdown } from '../UI';\nimport { checkBackendStatus } from '../../actions/status';\n\nconst styles = {\n  buttonActive: css`\n    color: ${colors.active};\n  `,\n};\n\nfunction AppHeader(props) {\n  return (\n    <header\n      css={css`\n        ${shadows.dropMain};\n        position: sticky;\n        width: 100%;\n        top: 0;\n        background-color: ${colors.foreground};\n        z-index: ${zIndex.zIndex300};\n        height: ${lengths.topBarHeight};\n      `}\n      {...props}\n    />\n  );\n}\n\nconst AppHeaderContent = styled.div`\n  display: flex;\n  justify-content: space-between;\n  min-width: 800px;\n  max-width: 1440px;\n  padding: 0 12px;\n  margin: 0 auto;\n`;\n\nconst AppHeaderButton = styled.button`\n  ${buttons.button};\n  background: none;\n  color: #7b8290;\n  font-family: inherit;\n  font-size: 16px;\n  font-weight: 500;\n  display: inline-flex;\n  padding: 16px 20px;\n  align-items: center;\n\n  ${Icon} {\n    margin-right: 4px;\n    color: #b3b9c4;\n  }\n\n  &:hover,\n  &:active,\n  &:focus-visible {\n    ${styles.buttonActive};\n\n    ${Icon} {\n      ${styles.buttonActive};\n    }\n  }\n\n  ${props => css`\n    &.${props.activeClassName} {\n      ${styles.buttonActive};\n\n      ${Icon} {\n        ${styles.buttonActive};\n      }\n    }\n  `};\n`;\n\nconst AppHeaderNavLink = AppHeaderButton.withComponent(NavLink);\n\nconst AppHeaderActions = styled.div`\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst AppHeaderQuickNewButton = styled(StyledDropdownButton)`\n  ${buttons.button};\n  ${buttons.medium};\n  ${buttons.gray};\n  margin-right: 8px;\n\n  &:after {\n    top: 11px;\n  }\n`;\n\nconst AppHeaderNavList = styled.ul`\n  display: flex;\n  margin: 0;\n  list-style: none;\n`;\n\nclass Header extends React.Component {\n  static propTypes = {\n    user: PropTypes.object.isRequired,\n    collections: ImmutablePropTypes.map.isRequired,\n    onCreateEntryClick: PropTypes.func.isRequired,\n    onLogoutClick: PropTypes.func.isRequired,\n    openMediaLibrary: PropTypes.func.isRequired,\n    hasWorkflow: PropTypes.bool.isRequired,\n    displayUrl: PropTypes.string,\n    isTestRepo: PropTypes.bool,\n    t: PropTypes.func.isRequired,\n    checkBackendStatus: PropTypes.func.isRequired,\n  };\n\n  intervalId;\n\n  componentDidMount() {\n    this.intervalId = setInterval(() => {\n      this.props.checkBackendStatus();\n    }, 5 * 60 * 1000);\n  }\n\n  componentWillUnmount() {\n    clearInterval(this.intervalId);\n  }\n\n  handleCreatePostClick = collectionName => {\n    const { onCreateEntryClick } = this.props;\n    if (onCreateEntryClick) {\n      onCreateEntryClick(collectionName);\n    }\n  };\n\n  render() {\n    const {\n      user,\n      collections,\n      onLogoutClick,\n      openMediaLibrary,\n      hasWorkflow,\n      displayUrl,\n      isTestRepo,\n      t,\n      showMediaButton,\n    } = this.props;\n\n    const creatableCollections = collections\n      .filter(collection => collection.get('create'))\n      .toList();\n\n    return (\n      <AppHeader>\n        <AppHeaderContent>\n          <nav>\n            <AppHeaderNavList>\n              <li>\n                <AppHeaderNavLink\n                  to=\"/\"\n                  activeClassName=\"header-link-active\"\n                  isActive={(match, location) => location.pathname.startsWith('/collections/')}\n                >\n                  <Icon type=\"page\" />\n                  {t('app.header.content')}\n                </AppHeaderNavLink>\n              </li>\n              {hasWorkflow && (\n                <li>\n                  <AppHeaderNavLink to=\"/workflow\" activeClassName=\"header-link-active\">\n                    <Icon type=\"workflow\" />\n                    {t('app.header.workflow')}\n                  </AppHeaderNavLink>\n                </li>\n              )}\n              {showMediaButton && (\n                <li>\n                  <AppHeaderButton onClick={openMediaLibrary}>\n                    <Icon type=\"media-alt\" />\n                    {t('app.header.media')}\n                  </AppHeaderButton>\n                </li>\n              )}\n            </AppHeaderNavList>\n          </nav>\n          <AppHeaderActions>\n            {creatableCollections.size > 0 && (\n              <Dropdown\n                renderButton={() => (\n                  <AppHeaderQuickNewButton> {t('app.header.quickAdd')}</AppHeaderQuickNewButton>\n                )}\n                dropdownTopOverlap=\"30px\"\n                dropdownWidth=\"160px\"\n                dropdownPosition=\"left\"\n              >\n                {creatableCollections.map(collection => (\n                  <DropdownItem\n                    key={collection.get('name')}\n                    label={collection.get('label_singular') || collection.get('label')}\n                    onClick={() => this.handleCreatePostClick(collection.get('name'))}\n                  />\n                ))}\n              </Dropdown>\n            )}\n            <SettingsDropdown\n              displayUrl={displayUrl}\n              isTestRepo={isTestRepo}\n              imageUrl={user?.avatar_url}\n              onLogoutClick={onLogoutClick}\n            />\n          </AppHeaderActions>\n        </AppHeaderContent>\n      </AppHeader>\n    );\n  }\n}\n\nconst mapDispatchToProps = {\n  checkBackendStatus,\n};\n\nexport default connect(null, mapDispatchToProps)(translate()(Header));\n"]} */"))
26
20
  };
27
21
  function AppHeader(props) {
28
- return (0, _react2.jsx)("header", _extends({
29
- css: /*#__PURE__*/(0, _react2.css)(_decapCmsUiDefault.shadows.dropMain, ";position:sticky;width:100%;top:0;background-color:", _decapCmsUiDefault.colors.foreground, ";z-index:", _decapCmsUiDefault.zIndex.zIndex300, ";height:", _decapCmsUiDefault.lengths.topBarHeight, ";;label:AppHeader;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/App/Header.js"],"names":[],"mappings":"AAgCc","file":"../../../../src/components/App/Header.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { translate } from 'react-polyglot';\nimport { NavLink } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colors,\n  lengths,\n  shadows,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { connect } from 'react-redux';\n\nimport { SettingsDropdown } from '../UI';\nimport { checkBackendStatus } from '../../actions/status';\n\nconst styles = {\n  buttonActive: css`\n    color: ${colors.active};\n  `,\n};\n\nfunction AppHeader(props) {\n  return (\n    <header\n      css={css`\n        ${shadows.dropMain};\n        position: sticky;\n        width: 100%;\n        top: 0;\n        background-color: ${colors.foreground};\n        z-index: ${zIndex.zIndex300};\n        height: ${lengths.topBarHeight};\n      `}\n      {...props}\n    />\n  );\n}\n\nconst AppHeaderContent = styled.div`\n  display: flex;\n  justify-content: space-between;\n  min-width: 800px;\n  max-width: 1440px;\n  padding: 0 12px;\n  margin: 0 auto;\n`;\n\nconst AppHeaderButton = styled.button`\n  ${buttons.button};\n  background: none;\n  color: #7b8290;\n  font-family: inherit;\n  font-size: 16px;\n  font-weight: 500;\n  display: inline-flex;\n  padding: 16px 20px;\n  align-items: center;\n\n  ${Icon} {\n    margin-right: 4px;\n    color: #b3b9c4;\n  }\n\n  &:hover,\n  &:active,\n  &:focus-visible {\n    ${styles.buttonActive};\n\n    ${Icon} {\n      ${styles.buttonActive};\n    }\n  }\n\n  ${props => css`\n    &.${props.activeClassName} {\n      ${styles.buttonActive};\n\n      ${Icon} {\n        ${styles.buttonActive};\n      }\n    }\n  `};\n`;\n\nconst AppHeaderNavLink = AppHeaderButton.withComponent(NavLink);\n\nconst AppHeaderActions = styled.div`\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst AppHeaderQuickNewButton = styled(StyledDropdownButton)`\n  ${buttons.button};\n  ${buttons.medium};\n  ${buttons.gray};\n  margin-right: 8px;\n\n  &:after {\n    top: 11px;\n  }\n`;\n\nconst AppHeaderNavList = styled.ul`\n  display: flex;\n  margin: 0;\n  list-style: none;\n`;\n\nclass Header extends React.Component {\n  static propTypes = {\n    user: PropTypes.object.isRequired,\n    collections: ImmutablePropTypes.map.isRequired,\n    onCreateEntryClick: PropTypes.func.isRequired,\n    onLogoutClick: PropTypes.func.isRequired,\n    openMediaLibrary: PropTypes.func.isRequired,\n    hasWorkflow: PropTypes.bool.isRequired,\n    displayUrl: PropTypes.string,\n    isTestRepo: PropTypes.bool,\n    t: PropTypes.func.isRequired,\n    checkBackendStatus: PropTypes.func.isRequired,\n  };\n\n  intervalId;\n\n  componentDidMount() {\n    this.intervalId = setInterval(() => {\n      this.props.checkBackendStatus();\n    }, 5 * 60 * 1000);\n  }\n\n  componentWillUnmount() {\n    clearInterval(this.intervalId);\n  }\n\n  handleCreatePostClick = collectionName => {\n    const { onCreateEntryClick } = this.props;\n    if (onCreateEntryClick) {\n      onCreateEntryClick(collectionName);\n    }\n  };\n\n  render() {\n    const {\n      user,\n      collections,\n      onLogoutClick,\n      openMediaLibrary,\n      hasWorkflow,\n      displayUrl,\n      isTestRepo,\n      t,\n      showMediaButton,\n    } = this.props;\n\n    const creatableCollections = collections\n      .filter(collection => collection.get('create'))\n      .toList();\n\n    return (\n      <AppHeader>\n        <AppHeaderContent>\n          <nav>\n            <AppHeaderNavList>\n              <li>\n                <AppHeaderNavLink\n                  to=\"/\"\n                  activeClassName=\"header-link-active\"\n                  isActive={(match, location) => location.pathname.startsWith('/collections/')}\n                >\n                  <Icon type=\"page\" />\n                  {t('app.header.content')}\n                </AppHeaderNavLink>\n              </li>\n              {hasWorkflow && (\n                <li>\n                  <AppHeaderNavLink to=\"/workflow\" activeClassName=\"header-link-active\">\n                    <Icon type=\"workflow\" />\n                    {t('app.header.workflow')}\n                  </AppHeaderNavLink>\n                </li>\n              )}\n              {showMediaButton && (\n                <li>\n                  <AppHeaderButton onClick={openMediaLibrary}>\n                    <Icon type=\"media-alt\" />\n                    {t('app.header.media')}\n                  </AppHeaderButton>\n                </li>\n              )}\n            </AppHeaderNavList>\n          </nav>\n          <AppHeaderActions>\n            {creatableCollections.size > 0 && (\n              <Dropdown\n                renderButton={() => (\n                  <AppHeaderQuickNewButton> {t('app.header.quickAdd')}</AppHeaderQuickNewButton>\n                )}\n                dropdownTopOverlap=\"30px\"\n                dropdownWidth=\"160px\"\n                dropdownPosition=\"left\"\n              >\n                {creatableCollections.map(collection => (\n                  <DropdownItem\n                    key={collection.get('name')}\n                    label={collection.get('label_singular') || collection.get('label')}\n                    onClick={() => this.handleCreatePostClick(collection.get('name'))}\n                  />\n                ))}\n              </Dropdown>\n            )}\n            <SettingsDropdown\n              displayUrl={displayUrl}\n              isTestRepo={isTestRepo}\n              imageUrl={user?.avatar_url}\n              onLogoutClick={onLogoutClick}\n            />\n          </AppHeaderActions>\n        </AppHeaderContent>\n      </AppHeader>\n    );\n  }\n}\n\nconst mapDispatchToProps = {\n  checkBackendStatus,\n};\n\nexport default connect(null, mapDispatchToProps)(translate()(Header));\n"]} */"))
22
+ return ___EmotionJSX("header", _extends({
23
+ css: /*#__PURE__*/css(shadows.dropMain, ";position:sticky;width:100%;top:0;background-color:", colors.foreground, ";z-index:", zIndex.zIndex300, ";height:", lengths.topBarHeight, ";;label:AppHeader;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/App/Header.js"],"names":[],"mappings":"AAgCc","file":"../../../../src/components/App/Header.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { translate } from 'react-polyglot';\nimport { NavLink } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colors,\n  lengths,\n  shadows,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { connect } from 'react-redux';\n\nimport { SettingsDropdown } from '../UI';\nimport { checkBackendStatus } from '../../actions/status';\n\nconst styles = {\n  buttonActive: css`\n    color: ${colors.active};\n  `,\n};\n\nfunction AppHeader(props) {\n  return (\n    <header\n      css={css`\n        ${shadows.dropMain};\n        position: sticky;\n        width: 100%;\n        top: 0;\n        background-color: ${colors.foreground};\n        z-index: ${zIndex.zIndex300};\n        height: ${lengths.topBarHeight};\n      `}\n      {...props}\n    />\n  );\n}\n\nconst AppHeaderContent = styled.div`\n  display: flex;\n  justify-content: space-between;\n  min-width: 800px;\n  max-width: 1440px;\n  padding: 0 12px;\n  margin: 0 auto;\n`;\n\nconst AppHeaderButton = styled.button`\n  ${buttons.button};\n  background: none;\n  color: #7b8290;\n  font-family: inherit;\n  font-size: 16px;\n  font-weight: 500;\n  display: inline-flex;\n  padding: 16px 20px;\n  align-items: center;\n\n  ${Icon} {\n    margin-right: 4px;\n    color: #b3b9c4;\n  }\n\n  &:hover,\n  &:active,\n  &:focus-visible {\n    ${styles.buttonActive};\n\n    ${Icon} {\n      ${styles.buttonActive};\n    }\n  }\n\n  ${props => css`\n    &.${props.activeClassName} {\n      ${styles.buttonActive};\n\n      ${Icon} {\n        ${styles.buttonActive};\n      }\n    }\n  `};\n`;\n\nconst AppHeaderNavLink = AppHeaderButton.withComponent(NavLink);\n\nconst AppHeaderActions = styled.div`\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst AppHeaderQuickNewButton = styled(StyledDropdownButton)`\n  ${buttons.button};\n  ${buttons.medium};\n  ${buttons.gray};\n  margin-right: 8px;\n\n  &:after {\n    top: 11px;\n  }\n`;\n\nconst AppHeaderNavList = styled.ul`\n  display: flex;\n  margin: 0;\n  list-style: none;\n`;\n\nclass Header extends React.Component {\n  static propTypes = {\n    user: PropTypes.object.isRequired,\n    collections: ImmutablePropTypes.map.isRequired,\n    onCreateEntryClick: PropTypes.func.isRequired,\n    onLogoutClick: PropTypes.func.isRequired,\n    openMediaLibrary: PropTypes.func.isRequired,\n    hasWorkflow: PropTypes.bool.isRequired,\n    displayUrl: PropTypes.string,\n    isTestRepo: PropTypes.bool,\n    t: PropTypes.func.isRequired,\n    checkBackendStatus: PropTypes.func.isRequired,\n  };\n\n  intervalId;\n\n  componentDidMount() {\n    this.intervalId = setInterval(() => {\n      this.props.checkBackendStatus();\n    }, 5 * 60 * 1000);\n  }\n\n  componentWillUnmount() {\n    clearInterval(this.intervalId);\n  }\n\n  handleCreatePostClick = collectionName => {\n    const { onCreateEntryClick } = this.props;\n    if (onCreateEntryClick) {\n      onCreateEntryClick(collectionName);\n    }\n  };\n\n  render() {\n    const {\n      user,\n      collections,\n      onLogoutClick,\n      openMediaLibrary,\n      hasWorkflow,\n      displayUrl,\n      isTestRepo,\n      t,\n      showMediaButton,\n    } = this.props;\n\n    const creatableCollections = collections\n      .filter(collection => collection.get('create'))\n      .toList();\n\n    return (\n      <AppHeader>\n        <AppHeaderContent>\n          <nav>\n            <AppHeaderNavList>\n              <li>\n                <AppHeaderNavLink\n                  to=\"/\"\n                  activeClassName=\"header-link-active\"\n                  isActive={(match, location) => location.pathname.startsWith('/collections/')}\n                >\n                  <Icon type=\"page\" />\n                  {t('app.header.content')}\n                </AppHeaderNavLink>\n              </li>\n              {hasWorkflow && (\n                <li>\n                  <AppHeaderNavLink to=\"/workflow\" activeClassName=\"header-link-active\">\n                    <Icon type=\"workflow\" />\n                    {t('app.header.workflow')}\n                  </AppHeaderNavLink>\n                </li>\n              )}\n              {showMediaButton && (\n                <li>\n                  <AppHeaderButton onClick={openMediaLibrary}>\n                    <Icon type=\"media-alt\" />\n                    {t('app.header.media')}\n                  </AppHeaderButton>\n                </li>\n              )}\n            </AppHeaderNavList>\n          </nav>\n          <AppHeaderActions>\n            {creatableCollections.size > 0 && (\n              <Dropdown\n                renderButton={() => (\n                  <AppHeaderQuickNewButton> {t('app.header.quickAdd')}</AppHeaderQuickNewButton>\n                )}\n                dropdownTopOverlap=\"30px\"\n                dropdownWidth=\"160px\"\n                dropdownPosition=\"left\"\n              >\n                {creatableCollections.map(collection => (\n                  <DropdownItem\n                    key={collection.get('name')}\n                    label={collection.get('label_singular') || collection.get('label')}\n                    onClick={() => this.handleCreatePostClick(collection.get('name'))}\n                  />\n                ))}\n              </Dropdown>\n            )}\n            <SettingsDropdown\n              displayUrl={displayUrl}\n              isTestRepo={isTestRepo}\n              imageUrl={user?.avatar_url}\n              onLogoutClick={onLogoutClick}\n            />\n          </AppHeaderActions>\n        </AppHeaderContent>\n      </AppHeader>\n    );\n  }\n}\n\nconst mapDispatchToProps = {\n  checkBackendStatus,\n};\n\nexport default connect(null, mapDispatchToProps)(translate()(Header));\n"]} */"))
30
24
  }, props));
31
25
  }
32
- const AppHeaderContent = /*#__PURE__*/(0, _base.default)("div", {
26
+ const AppHeaderContent = /*#__PURE__*/_styled("div", {
33
27
  target: "e1rbzf6g4",
34
28
  label: "AppHeaderContent"
35
29
  })(process.env.NODE_ENV === "production" ? {
@@ -41,15 +35,15 @@ const AppHeaderContent = /*#__PURE__*/(0, _base.default)("div", {
41
35
  map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/App/Header.js"],"names":[],"mappings":"AA8CmC","file":"../../../../src/components/App/Header.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { translate } from 'react-polyglot';\nimport { NavLink } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colors,\n  lengths,\n  shadows,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { connect } from 'react-redux';\n\nimport { SettingsDropdown } from '../UI';\nimport { checkBackendStatus } from '../../actions/status';\n\nconst styles = {\n  buttonActive: css`\n    color: ${colors.active};\n  `,\n};\n\nfunction AppHeader(props) {\n  return (\n    <header\n      css={css`\n        ${shadows.dropMain};\n        position: sticky;\n        width: 100%;\n        top: 0;\n        background-color: ${colors.foreground};\n        z-index: ${zIndex.zIndex300};\n        height: ${lengths.topBarHeight};\n      `}\n      {...props}\n    />\n  );\n}\n\nconst AppHeaderContent = styled.div`\n  display: flex;\n  justify-content: space-between;\n  min-width: 800px;\n  max-width: 1440px;\n  padding: 0 12px;\n  margin: 0 auto;\n`;\n\nconst AppHeaderButton = styled.button`\n  ${buttons.button};\n  background: none;\n  color: #7b8290;\n  font-family: inherit;\n  font-size: 16px;\n  font-weight: 500;\n  display: inline-flex;\n  padding: 16px 20px;\n  align-items: center;\n\n  ${Icon} {\n    margin-right: 4px;\n    color: #b3b9c4;\n  }\n\n  &:hover,\n  &:active,\n  &:focus-visible {\n    ${styles.buttonActive};\n\n    ${Icon} {\n      ${styles.buttonActive};\n    }\n  }\n\n  ${props => css`\n    &.${props.activeClassName} {\n      ${styles.buttonActive};\n\n      ${Icon} {\n        ${styles.buttonActive};\n      }\n    }\n  `};\n`;\n\nconst AppHeaderNavLink = AppHeaderButton.withComponent(NavLink);\n\nconst AppHeaderActions = styled.div`\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst AppHeaderQuickNewButton = styled(StyledDropdownButton)`\n  ${buttons.button};\n  ${buttons.medium};\n  ${buttons.gray};\n  margin-right: 8px;\n\n  &:after {\n    top: 11px;\n  }\n`;\n\nconst AppHeaderNavList = styled.ul`\n  display: flex;\n  margin: 0;\n  list-style: none;\n`;\n\nclass Header extends React.Component {\n  static propTypes = {\n    user: PropTypes.object.isRequired,\n    collections: ImmutablePropTypes.map.isRequired,\n    onCreateEntryClick: PropTypes.func.isRequired,\n    onLogoutClick: PropTypes.func.isRequired,\n    openMediaLibrary: PropTypes.func.isRequired,\n    hasWorkflow: PropTypes.bool.isRequired,\n    displayUrl: PropTypes.string,\n    isTestRepo: PropTypes.bool,\n    t: PropTypes.func.isRequired,\n    checkBackendStatus: PropTypes.func.isRequired,\n  };\n\n  intervalId;\n\n  componentDidMount() {\n    this.intervalId = setInterval(() => {\n      this.props.checkBackendStatus();\n    }, 5 * 60 * 1000);\n  }\n\n  componentWillUnmount() {\n    clearInterval(this.intervalId);\n  }\n\n  handleCreatePostClick = collectionName => {\n    const { onCreateEntryClick } = this.props;\n    if (onCreateEntryClick) {\n      onCreateEntryClick(collectionName);\n    }\n  };\n\n  render() {\n    const {\n      user,\n      collections,\n      onLogoutClick,\n      openMediaLibrary,\n      hasWorkflow,\n      displayUrl,\n      isTestRepo,\n      t,\n      showMediaButton,\n    } = this.props;\n\n    const creatableCollections = collections\n      .filter(collection => collection.get('create'))\n      .toList();\n\n    return (\n      <AppHeader>\n        <AppHeaderContent>\n          <nav>\n            <AppHeaderNavList>\n              <li>\n                <AppHeaderNavLink\n                  to=\"/\"\n                  activeClassName=\"header-link-active\"\n                  isActive={(match, location) => location.pathname.startsWith('/collections/')}\n                >\n                  <Icon type=\"page\" />\n                  {t('app.header.content')}\n                </AppHeaderNavLink>\n              </li>\n              {hasWorkflow && (\n                <li>\n                  <AppHeaderNavLink to=\"/workflow\" activeClassName=\"header-link-active\">\n                    <Icon type=\"workflow\" />\n                    {t('app.header.workflow')}\n                  </AppHeaderNavLink>\n                </li>\n              )}\n              {showMediaButton && (\n                <li>\n                  <AppHeaderButton onClick={openMediaLibrary}>\n                    <Icon type=\"media-alt\" />\n                    {t('app.header.media')}\n                  </AppHeaderButton>\n                </li>\n              )}\n            </AppHeaderNavList>\n          </nav>\n          <AppHeaderActions>\n            {creatableCollections.size > 0 && (\n              <Dropdown\n                renderButton={() => (\n                  <AppHeaderQuickNewButton> {t('app.header.quickAdd')}</AppHeaderQuickNewButton>\n                )}\n                dropdownTopOverlap=\"30px\"\n                dropdownWidth=\"160px\"\n                dropdownPosition=\"left\"\n              >\n                {creatableCollections.map(collection => (\n                  <DropdownItem\n                    key={collection.get('name')}\n                    label={collection.get('label_singular') || collection.get('label')}\n                    onClick={() => this.handleCreatePostClick(collection.get('name'))}\n                  />\n                ))}\n              </Dropdown>\n            )}\n            <SettingsDropdown\n              displayUrl={displayUrl}\n              isTestRepo={isTestRepo}\n              imageUrl={user?.avatar_url}\n              onLogoutClick={onLogoutClick}\n            />\n          </AppHeaderActions>\n        </AppHeaderContent>\n      </AppHeader>\n    );\n  }\n}\n\nconst mapDispatchToProps = {\n  checkBackendStatus,\n};\n\nexport default connect(null, mapDispatchToProps)(translate()(Header));\n"]} */",
42
36
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
43
37
  });
44
- const AppHeaderButton = /*#__PURE__*/(0, _base.default)("button", {
38
+ const AppHeaderButton = /*#__PURE__*/_styled("button", {
45
39
  target: "e1rbzf6g3",
46
40
  label: "AppHeaderButton"
47
- })(_decapCmsUiDefault.buttons.button, ";background:none;color:#7b8290;font-family:inherit;font-size:16px;font-weight:500;display:inline-flex;padding:16px 20px;align-items:center;", _decapCmsUiDefault.Icon, "{margin-right:4px;color:#b3b9c4;}&:hover,&:active,&:focus-visible{", styles.buttonActive, ";", _decapCmsUiDefault.Icon, "{", styles.buttonActive, ";}}", props => /*#__PURE__*/(0, _react2.css)("&.", props.activeClassName, "{", styles.buttonActive, ";", _decapCmsUiDefault.Icon, "{", styles.buttonActive, ";}};label:AppHeaderButton;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/App/Header.js"],"names":[],"mappings":"AAiFgB","file":"../../../../src/components/App/Header.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { translate } from 'react-polyglot';\nimport { NavLink } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colors,\n  lengths,\n  shadows,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { connect } from 'react-redux';\n\nimport { SettingsDropdown } from '../UI';\nimport { checkBackendStatus } from '../../actions/status';\n\nconst styles = {\n  buttonActive: css`\n    color: ${colors.active};\n  `,\n};\n\nfunction AppHeader(props) {\n  return (\n    <header\n      css={css`\n        ${shadows.dropMain};\n        position: sticky;\n        width: 100%;\n        top: 0;\n        background-color: ${colors.foreground};\n        z-index: ${zIndex.zIndex300};\n        height: ${lengths.topBarHeight};\n      `}\n      {...props}\n    />\n  );\n}\n\nconst AppHeaderContent = styled.div`\n  display: flex;\n  justify-content: space-between;\n  min-width: 800px;\n  max-width: 1440px;\n  padding: 0 12px;\n  margin: 0 auto;\n`;\n\nconst AppHeaderButton = styled.button`\n  ${buttons.button};\n  background: none;\n  color: #7b8290;\n  font-family: inherit;\n  font-size: 16px;\n  font-weight: 500;\n  display: inline-flex;\n  padding: 16px 20px;\n  align-items: center;\n\n  ${Icon} {\n    margin-right: 4px;\n    color: #b3b9c4;\n  }\n\n  &:hover,\n  &:active,\n  &:focus-visible {\n    ${styles.buttonActive};\n\n    ${Icon} {\n      ${styles.buttonActive};\n    }\n  }\n\n  ${props => css`\n    &.${props.activeClassName} {\n      ${styles.buttonActive};\n\n      ${Icon} {\n        ${styles.buttonActive};\n      }\n    }\n  `};\n`;\n\nconst AppHeaderNavLink = AppHeaderButton.withComponent(NavLink);\n\nconst AppHeaderActions = styled.div`\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst AppHeaderQuickNewButton = styled(StyledDropdownButton)`\n  ${buttons.button};\n  ${buttons.medium};\n  ${buttons.gray};\n  margin-right: 8px;\n\n  &:after {\n    top: 11px;\n  }\n`;\n\nconst AppHeaderNavList = styled.ul`\n  display: flex;\n  margin: 0;\n  list-style: none;\n`;\n\nclass Header extends React.Component {\n  static propTypes = {\n    user: PropTypes.object.isRequired,\n    collections: ImmutablePropTypes.map.isRequired,\n    onCreateEntryClick: PropTypes.func.isRequired,\n    onLogoutClick: PropTypes.func.isRequired,\n    openMediaLibrary: PropTypes.func.isRequired,\n    hasWorkflow: PropTypes.bool.isRequired,\n    displayUrl: PropTypes.string,\n    isTestRepo: PropTypes.bool,\n    t: PropTypes.func.isRequired,\n    checkBackendStatus: PropTypes.func.isRequired,\n  };\n\n  intervalId;\n\n  componentDidMount() {\n    this.intervalId = setInterval(() => {\n      this.props.checkBackendStatus();\n    }, 5 * 60 * 1000);\n  }\n\n  componentWillUnmount() {\n    clearInterval(this.intervalId);\n  }\n\n  handleCreatePostClick = collectionName => {\n    const { onCreateEntryClick } = this.props;\n    if (onCreateEntryClick) {\n      onCreateEntryClick(collectionName);\n    }\n  };\n\n  render() {\n    const {\n      user,\n      collections,\n      onLogoutClick,\n      openMediaLibrary,\n      hasWorkflow,\n      displayUrl,\n      isTestRepo,\n      t,\n      showMediaButton,\n    } = this.props;\n\n    const creatableCollections = collections\n      .filter(collection => collection.get('create'))\n      .toList();\n\n    return (\n      <AppHeader>\n        <AppHeaderContent>\n          <nav>\n            <AppHeaderNavList>\n              <li>\n                <AppHeaderNavLink\n                  to=\"/\"\n                  activeClassName=\"header-link-active\"\n                  isActive={(match, location) => location.pathname.startsWith('/collections/')}\n                >\n                  <Icon type=\"page\" />\n                  {t('app.header.content')}\n                </AppHeaderNavLink>\n              </li>\n              {hasWorkflow && (\n                <li>\n                  <AppHeaderNavLink to=\"/workflow\" activeClassName=\"header-link-active\">\n                    <Icon type=\"workflow\" />\n                    {t('app.header.workflow')}\n                  </AppHeaderNavLink>\n                </li>\n              )}\n              {showMediaButton && (\n                <li>\n                  <AppHeaderButton onClick={openMediaLibrary}>\n                    <Icon type=\"media-alt\" />\n                    {t('app.header.media')}\n                  </AppHeaderButton>\n                </li>\n              )}\n            </AppHeaderNavList>\n          </nav>\n          <AppHeaderActions>\n            {creatableCollections.size > 0 && (\n              <Dropdown\n                renderButton={() => (\n                  <AppHeaderQuickNewButton> {t('app.header.quickAdd')}</AppHeaderQuickNewButton>\n                )}\n                dropdownTopOverlap=\"30px\"\n                dropdownWidth=\"160px\"\n                dropdownPosition=\"left\"\n              >\n                {creatableCollections.map(collection => (\n                  <DropdownItem\n                    key={collection.get('name')}\n                    label={collection.get('label_singular') || collection.get('label')}\n                    onClick={() => this.handleCreatePostClick(collection.get('name'))}\n                  />\n                ))}\n              </Dropdown>\n            )}\n            <SettingsDropdown\n              displayUrl={displayUrl}\n              isTestRepo={isTestRepo}\n              imageUrl={user?.avatar_url}\n              onLogoutClick={onLogoutClick}\n            />\n          </AppHeaderActions>\n        </AppHeaderContent>\n      </AppHeader>\n    );\n  }\n}\n\nconst mapDispatchToProps = {\n  checkBackendStatus,\n};\n\nexport default connect(null, mapDispatchToProps)(translate()(Header));\n"]} */")), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/App/Header.js"],"names":[],"mappings":"AAuDqC","file":"../../../../src/components/App/Header.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { translate } from 'react-polyglot';\nimport { NavLink } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colors,\n  lengths,\n  shadows,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { connect } from 'react-redux';\n\nimport { SettingsDropdown } from '../UI';\nimport { checkBackendStatus } from '../../actions/status';\n\nconst styles = {\n  buttonActive: css`\n    color: ${colors.active};\n  `,\n};\n\nfunction AppHeader(props) {\n  return (\n    <header\n      css={css`\n        ${shadows.dropMain};\n        position: sticky;\n        width: 100%;\n        top: 0;\n        background-color: ${colors.foreground};\n        z-index: ${zIndex.zIndex300};\n        height: ${lengths.topBarHeight};\n      `}\n      {...props}\n    />\n  );\n}\n\nconst AppHeaderContent = styled.div`\n  display: flex;\n  justify-content: space-between;\n  min-width: 800px;\n  max-width: 1440px;\n  padding: 0 12px;\n  margin: 0 auto;\n`;\n\nconst AppHeaderButton = styled.button`\n  ${buttons.button};\n  background: none;\n  color: #7b8290;\n  font-family: inherit;\n  font-size: 16px;\n  font-weight: 500;\n  display: inline-flex;\n  padding: 16px 20px;\n  align-items: center;\n\n  ${Icon} {\n    margin-right: 4px;\n    color: #b3b9c4;\n  }\n\n  &:hover,\n  &:active,\n  &:focus-visible {\n    ${styles.buttonActive};\n\n    ${Icon} {\n      ${styles.buttonActive};\n    }\n  }\n\n  ${props => css`\n    &.${props.activeClassName} {\n      ${styles.buttonActive};\n\n      ${Icon} {\n        ${styles.buttonActive};\n      }\n    }\n  `};\n`;\n\nconst AppHeaderNavLink = AppHeaderButton.withComponent(NavLink);\n\nconst AppHeaderActions = styled.div`\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst AppHeaderQuickNewButton = styled(StyledDropdownButton)`\n  ${buttons.button};\n  ${buttons.medium};\n  ${buttons.gray};\n  margin-right: 8px;\n\n  &:after {\n    top: 11px;\n  }\n`;\n\nconst AppHeaderNavList = styled.ul`\n  display: flex;\n  margin: 0;\n  list-style: none;\n`;\n\nclass Header extends React.Component {\n  static propTypes = {\n    user: PropTypes.object.isRequired,\n    collections: ImmutablePropTypes.map.isRequired,\n    onCreateEntryClick: PropTypes.func.isRequired,\n    onLogoutClick: PropTypes.func.isRequired,\n    openMediaLibrary: PropTypes.func.isRequired,\n    hasWorkflow: PropTypes.bool.isRequired,\n    displayUrl: PropTypes.string,\n    isTestRepo: PropTypes.bool,\n    t: PropTypes.func.isRequired,\n    checkBackendStatus: PropTypes.func.isRequired,\n  };\n\n  intervalId;\n\n  componentDidMount() {\n    this.intervalId = setInterval(() => {\n      this.props.checkBackendStatus();\n    }, 5 * 60 * 1000);\n  }\n\n  componentWillUnmount() {\n    clearInterval(this.intervalId);\n  }\n\n  handleCreatePostClick = collectionName => {\n    const { onCreateEntryClick } = this.props;\n    if (onCreateEntryClick) {\n      onCreateEntryClick(collectionName);\n    }\n  };\n\n  render() {\n    const {\n      user,\n      collections,\n      onLogoutClick,\n      openMediaLibrary,\n      hasWorkflow,\n      displayUrl,\n      isTestRepo,\n      t,\n      showMediaButton,\n    } = this.props;\n\n    const creatableCollections = collections\n      .filter(collection => collection.get('create'))\n      .toList();\n\n    return (\n      <AppHeader>\n        <AppHeaderContent>\n          <nav>\n            <AppHeaderNavList>\n              <li>\n                <AppHeaderNavLink\n                  to=\"/\"\n                  activeClassName=\"header-link-active\"\n                  isActive={(match, location) => location.pathname.startsWith('/collections/')}\n                >\n                  <Icon type=\"page\" />\n                  {t('app.header.content')}\n                </AppHeaderNavLink>\n              </li>\n              {hasWorkflow && (\n                <li>\n                  <AppHeaderNavLink to=\"/workflow\" activeClassName=\"header-link-active\">\n                    <Icon type=\"workflow\" />\n                    {t('app.header.workflow')}\n                  </AppHeaderNavLink>\n                </li>\n              )}\n              {showMediaButton && (\n                <li>\n                  <AppHeaderButton onClick={openMediaLibrary}>\n                    <Icon type=\"media-alt\" />\n                    {t('app.header.media')}\n                  </AppHeaderButton>\n                </li>\n              )}\n            </AppHeaderNavList>\n          </nav>\n          <AppHeaderActions>\n            {creatableCollections.size > 0 && (\n              <Dropdown\n                renderButton={() => (\n                  <AppHeaderQuickNewButton> {t('app.header.quickAdd')}</AppHeaderQuickNewButton>\n                )}\n                dropdownTopOverlap=\"30px\"\n                dropdownWidth=\"160px\"\n                dropdownPosition=\"left\"\n              >\n                {creatableCollections.map(collection => (\n                  <DropdownItem\n                    key={collection.get('name')}\n                    label={collection.get('label_singular') || collection.get('label')}\n                    onClick={() => this.handleCreatePostClick(collection.get('name'))}\n                  />\n                ))}\n              </Dropdown>\n            )}\n            <SettingsDropdown\n              displayUrl={displayUrl}\n              isTestRepo={isTestRepo}\n              imageUrl={user?.avatar_url}\n              onLogoutClick={onLogoutClick}\n            />\n          </AppHeaderActions>\n        </AppHeaderContent>\n      </AppHeader>\n    );\n  }\n}\n\nconst mapDispatchToProps = {\n  checkBackendStatus,\n};\n\nexport default connect(null, mapDispatchToProps)(translate()(Header));\n"]} */"));
48
- const AppHeaderNavLink = AppHeaderButton.withComponent(_reactRouterDom.NavLink, {
41
+ })(buttons.button, ";background:none;color:#7b8290;font-family:inherit;font-size:16px;font-weight:500;display:inline-flex;padding:16px 20px;align-items:center;", Icon, "{margin-right:4px;color:#b3b9c4;}&:hover,&:active,&:focus-visible{", styles.buttonActive, ";", Icon, "{", styles.buttonActive, ";}}", props => /*#__PURE__*/css("&.", props.activeClassName, "{", styles.buttonActive, ";", Icon, "{", styles.buttonActive, ";}};label:AppHeaderButton;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/App/Header.js"],"names":[],"mappings":"AAiFgB","file":"../../../../src/components/App/Header.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { translate } from 'react-polyglot';\nimport { NavLink } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colors,\n  lengths,\n  shadows,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { connect } from 'react-redux';\n\nimport { SettingsDropdown } from '../UI';\nimport { checkBackendStatus } from '../../actions/status';\n\nconst styles = {\n  buttonActive: css`\n    color: ${colors.active};\n  `,\n};\n\nfunction AppHeader(props) {\n  return (\n    <header\n      css={css`\n        ${shadows.dropMain};\n        position: sticky;\n        width: 100%;\n        top: 0;\n        background-color: ${colors.foreground};\n        z-index: ${zIndex.zIndex300};\n        height: ${lengths.topBarHeight};\n      `}\n      {...props}\n    />\n  );\n}\n\nconst AppHeaderContent = styled.div`\n  display: flex;\n  justify-content: space-between;\n  min-width: 800px;\n  max-width: 1440px;\n  padding: 0 12px;\n  margin: 0 auto;\n`;\n\nconst AppHeaderButton = styled.button`\n  ${buttons.button};\n  background: none;\n  color: #7b8290;\n  font-family: inherit;\n  font-size: 16px;\n  font-weight: 500;\n  display: inline-flex;\n  padding: 16px 20px;\n  align-items: center;\n\n  ${Icon} {\n    margin-right: 4px;\n    color: #b3b9c4;\n  }\n\n  &:hover,\n  &:active,\n  &:focus-visible {\n    ${styles.buttonActive};\n\n    ${Icon} {\n      ${styles.buttonActive};\n    }\n  }\n\n  ${props => css`\n    &.${props.activeClassName} {\n      ${styles.buttonActive};\n\n      ${Icon} {\n        ${styles.buttonActive};\n      }\n    }\n  `};\n`;\n\nconst AppHeaderNavLink = AppHeaderButton.withComponent(NavLink);\n\nconst AppHeaderActions = styled.div`\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst AppHeaderQuickNewButton = styled(StyledDropdownButton)`\n  ${buttons.button};\n  ${buttons.medium};\n  ${buttons.gray};\n  margin-right: 8px;\n\n  &:after {\n    top: 11px;\n  }\n`;\n\nconst AppHeaderNavList = styled.ul`\n  display: flex;\n  margin: 0;\n  list-style: none;\n`;\n\nclass Header extends React.Component {\n  static propTypes = {\n    user: PropTypes.object.isRequired,\n    collections: ImmutablePropTypes.map.isRequired,\n    onCreateEntryClick: PropTypes.func.isRequired,\n    onLogoutClick: PropTypes.func.isRequired,\n    openMediaLibrary: PropTypes.func.isRequired,\n    hasWorkflow: PropTypes.bool.isRequired,\n    displayUrl: PropTypes.string,\n    isTestRepo: PropTypes.bool,\n    t: PropTypes.func.isRequired,\n    checkBackendStatus: PropTypes.func.isRequired,\n  };\n\n  intervalId;\n\n  componentDidMount() {\n    this.intervalId = setInterval(() => {\n      this.props.checkBackendStatus();\n    }, 5 * 60 * 1000);\n  }\n\n  componentWillUnmount() {\n    clearInterval(this.intervalId);\n  }\n\n  handleCreatePostClick = collectionName => {\n    const { onCreateEntryClick } = this.props;\n    if (onCreateEntryClick) {\n      onCreateEntryClick(collectionName);\n    }\n  };\n\n  render() {\n    const {\n      user,\n      collections,\n      onLogoutClick,\n      openMediaLibrary,\n      hasWorkflow,\n      displayUrl,\n      isTestRepo,\n      t,\n      showMediaButton,\n    } = this.props;\n\n    const creatableCollections = collections\n      .filter(collection => collection.get('create'))\n      .toList();\n\n    return (\n      <AppHeader>\n        <AppHeaderContent>\n          <nav>\n            <AppHeaderNavList>\n              <li>\n                <AppHeaderNavLink\n                  to=\"/\"\n                  activeClassName=\"header-link-active\"\n                  isActive={(match, location) => location.pathname.startsWith('/collections/')}\n                >\n                  <Icon type=\"page\" />\n                  {t('app.header.content')}\n                </AppHeaderNavLink>\n              </li>\n              {hasWorkflow && (\n                <li>\n                  <AppHeaderNavLink to=\"/workflow\" activeClassName=\"header-link-active\">\n                    <Icon type=\"workflow\" />\n                    {t('app.header.workflow')}\n                  </AppHeaderNavLink>\n                </li>\n              )}\n              {showMediaButton && (\n                <li>\n                  <AppHeaderButton onClick={openMediaLibrary}>\n                    <Icon type=\"media-alt\" />\n                    {t('app.header.media')}\n                  </AppHeaderButton>\n                </li>\n              )}\n            </AppHeaderNavList>\n          </nav>\n          <AppHeaderActions>\n            {creatableCollections.size > 0 && (\n              <Dropdown\n                renderButton={() => (\n                  <AppHeaderQuickNewButton> {t('app.header.quickAdd')}</AppHeaderQuickNewButton>\n                )}\n                dropdownTopOverlap=\"30px\"\n                dropdownWidth=\"160px\"\n                dropdownPosition=\"left\"\n              >\n                {creatableCollections.map(collection => (\n                  <DropdownItem\n                    key={collection.get('name')}\n                    label={collection.get('label_singular') || collection.get('label')}\n                    onClick={() => this.handleCreatePostClick(collection.get('name'))}\n                  />\n                ))}\n              </Dropdown>\n            )}\n            <SettingsDropdown\n              displayUrl={displayUrl}\n              isTestRepo={isTestRepo}\n              imageUrl={user?.avatar_url}\n              onLogoutClick={onLogoutClick}\n            />\n          </AppHeaderActions>\n        </AppHeaderContent>\n      </AppHeader>\n    );\n  }\n}\n\nconst mapDispatchToProps = {\n  checkBackendStatus,\n};\n\nexport default connect(null, mapDispatchToProps)(translate()(Header));\n"]} */")), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/App/Header.js"],"names":[],"mappings":"AAuDqC","file":"../../../../src/components/App/Header.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { translate } from 'react-polyglot';\nimport { NavLink } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colors,\n  lengths,\n  shadows,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { connect } from 'react-redux';\n\nimport { SettingsDropdown } from '../UI';\nimport { checkBackendStatus } from '../../actions/status';\n\nconst styles = {\n  buttonActive: css`\n    color: ${colors.active};\n  `,\n};\n\nfunction AppHeader(props) {\n  return (\n    <header\n      css={css`\n        ${shadows.dropMain};\n        position: sticky;\n        width: 100%;\n        top: 0;\n        background-color: ${colors.foreground};\n        z-index: ${zIndex.zIndex300};\n        height: ${lengths.topBarHeight};\n      `}\n      {...props}\n    />\n  );\n}\n\nconst AppHeaderContent = styled.div`\n  display: flex;\n  justify-content: space-between;\n  min-width: 800px;\n  max-width: 1440px;\n  padding: 0 12px;\n  margin: 0 auto;\n`;\n\nconst AppHeaderButton = styled.button`\n  ${buttons.button};\n  background: none;\n  color: #7b8290;\n  font-family: inherit;\n  font-size: 16px;\n  font-weight: 500;\n  display: inline-flex;\n  padding: 16px 20px;\n  align-items: center;\n\n  ${Icon} {\n    margin-right: 4px;\n    color: #b3b9c4;\n  }\n\n  &:hover,\n  &:active,\n  &:focus-visible {\n    ${styles.buttonActive};\n\n    ${Icon} {\n      ${styles.buttonActive};\n    }\n  }\n\n  ${props => css`\n    &.${props.activeClassName} {\n      ${styles.buttonActive};\n\n      ${Icon} {\n        ${styles.buttonActive};\n      }\n    }\n  `};\n`;\n\nconst AppHeaderNavLink = AppHeaderButton.withComponent(NavLink);\n\nconst AppHeaderActions = styled.div`\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst AppHeaderQuickNewButton = styled(StyledDropdownButton)`\n  ${buttons.button};\n  ${buttons.medium};\n  ${buttons.gray};\n  margin-right: 8px;\n\n  &:after {\n    top: 11px;\n  }\n`;\n\nconst AppHeaderNavList = styled.ul`\n  display: flex;\n  margin: 0;\n  list-style: none;\n`;\n\nclass Header extends React.Component {\n  static propTypes = {\n    user: PropTypes.object.isRequired,\n    collections: ImmutablePropTypes.map.isRequired,\n    onCreateEntryClick: PropTypes.func.isRequired,\n    onLogoutClick: PropTypes.func.isRequired,\n    openMediaLibrary: PropTypes.func.isRequired,\n    hasWorkflow: PropTypes.bool.isRequired,\n    displayUrl: PropTypes.string,\n    isTestRepo: PropTypes.bool,\n    t: PropTypes.func.isRequired,\n    checkBackendStatus: PropTypes.func.isRequired,\n  };\n\n  intervalId;\n\n  componentDidMount() {\n    this.intervalId = setInterval(() => {\n      this.props.checkBackendStatus();\n    }, 5 * 60 * 1000);\n  }\n\n  componentWillUnmount() {\n    clearInterval(this.intervalId);\n  }\n\n  handleCreatePostClick = collectionName => {\n    const { onCreateEntryClick } = this.props;\n    if (onCreateEntryClick) {\n      onCreateEntryClick(collectionName);\n    }\n  };\n\n  render() {\n    const {\n      user,\n      collections,\n      onLogoutClick,\n      openMediaLibrary,\n      hasWorkflow,\n      displayUrl,\n      isTestRepo,\n      t,\n      showMediaButton,\n    } = this.props;\n\n    const creatableCollections = collections\n      .filter(collection => collection.get('create'))\n      .toList();\n\n    return (\n      <AppHeader>\n        <AppHeaderContent>\n          <nav>\n            <AppHeaderNavList>\n              <li>\n                <AppHeaderNavLink\n                  to=\"/\"\n                  activeClassName=\"header-link-active\"\n                  isActive={(match, location) => location.pathname.startsWith('/collections/')}\n                >\n                  <Icon type=\"page\" />\n                  {t('app.header.content')}\n                </AppHeaderNavLink>\n              </li>\n              {hasWorkflow && (\n                <li>\n                  <AppHeaderNavLink to=\"/workflow\" activeClassName=\"header-link-active\">\n                    <Icon type=\"workflow\" />\n                    {t('app.header.workflow')}\n                  </AppHeaderNavLink>\n                </li>\n              )}\n              {showMediaButton && (\n                <li>\n                  <AppHeaderButton onClick={openMediaLibrary}>\n                    <Icon type=\"media-alt\" />\n                    {t('app.header.media')}\n                  </AppHeaderButton>\n                </li>\n              )}\n            </AppHeaderNavList>\n          </nav>\n          <AppHeaderActions>\n            {creatableCollections.size > 0 && (\n              <Dropdown\n                renderButton={() => (\n                  <AppHeaderQuickNewButton> {t('app.header.quickAdd')}</AppHeaderQuickNewButton>\n                )}\n                dropdownTopOverlap=\"30px\"\n                dropdownWidth=\"160px\"\n                dropdownPosition=\"left\"\n              >\n                {creatableCollections.map(collection => (\n                  <DropdownItem\n                    key={collection.get('name')}\n                    label={collection.get('label_singular') || collection.get('label')}\n                    onClick={() => this.handleCreatePostClick(collection.get('name'))}\n                  />\n                ))}\n              </Dropdown>\n            )}\n            <SettingsDropdown\n              displayUrl={displayUrl}\n              isTestRepo={isTestRepo}\n              imageUrl={user?.avatar_url}\n              onLogoutClick={onLogoutClick}\n            />\n          </AppHeaderActions>\n        </AppHeaderContent>\n      </AppHeader>\n    );\n  }\n}\n\nconst mapDispatchToProps = {\n  checkBackendStatus,\n};\n\nexport default connect(null, mapDispatchToProps)(translate()(Header));\n"]} */"));
42
+ const AppHeaderNavLink = AppHeaderButton.withComponent(NavLink, {
49
43
  target: "e1rbzf6g5",
50
44
  label: "AppHeaderNavLink"
51
45
  });
52
- const AppHeaderActions = /*#__PURE__*/(0, _base.default)("div", {
46
+ const AppHeaderActions = /*#__PURE__*/_styled("div", {
53
47
  target: "e1rbzf6g2",
54
48
  label: "AppHeaderActions"
55
49
  })(process.env.NODE_ENV === "production" ? {
@@ -61,11 +55,11 @@ const AppHeaderActions = /*#__PURE__*/(0, _base.default)("div", {
61
55
  map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/App/Header.js"],"names":[],"mappings":"AA8FmC","file":"../../../../src/components/App/Header.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { translate } from 'react-polyglot';\nimport { NavLink } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colors,\n  lengths,\n  shadows,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { connect } from 'react-redux';\n\nimport { SettingsDropdown } from '../UI';\nimport { checkBackendStatus } from '../../actions/status';\n\nconst styles = {\n  buttonActive: css`\n    color: ${colors.active};\n  `,\n};\n\nfunction AppHeader(props) {\n  return (\n    <header\n      css={css`\n        ${shadows.dropMain};\n        position: sticky;\n        width: 100%;\n        top: 0;\n        background-color: ${colors.foreground};\n        z-index: ${zIndex.zIndex300};\n        height: ${lengths.topBarHeight};\n      `}\n      {...props}\n    />\n  );\n}\n\nconst AppHeaderContent = styled.div`\n  display: flex;\n  justify-content: space-between;\n  min-width: 800px;\n  max-width: 1440px;\n  padding: 0 12px;\n  margin: 0 auto;\n`;\n\nconst AppHeaderButton = styled.button`\n  ${buttons.button};\n  background: none;\n  color: #7b8290;\n  font-family: inherit;\n  font-size: 16px;\n  font-weight: 500;\n  display: inline-flex;\n  padding: 16px 20px;\n  align-items: center;\n\n  ${Icon} {\n    margin-right: 4px;\n    color: #b3b9c4;\n  }\n\n  &:hover,\n  &:active,\n  &:focus-visible {\n    ${styles.buttonActive};\n\n    ${Icon} {\n      ${styles.buttonActive};\n    }\n  }\n\n  ${props => css`\n    &.${props.activeClassName} {\n      ${styles.buttonActive};\n\n      ${Icon} {\n        ${styles.buttonActive};\n      }\n    }\n  `};\n`;\n\nconst AppHeaderNavLink = AppHeaderButton.withComponent(NavLink);\n\nconst AppHeaderActions = styled.div`\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst AppHeaderQuickNewButton = styled(StyledDropdownButton)`\n  ${buttons.button};\n  ${buttons.medium};\n  ${buttons.gray};\n  margin-right: 8px;\n\n  &:after {\n    top: 11px;\n  }\n`;\n\nconst AppHeaderNavList = styled.ul`\n  display: flex;\n  margin: 0;\n  list-style: none;\n`;\n\nclass Header extends React.Component {\n  static propTypes = {\n    user: PropTypes.object.isRequired,\n    collections: ImmutablePropTypes.map.isRequired,\n    onCreateEntryClick: PropTypes.func.isRequired,\n    onLogoutClick: PropTypes.func.isRequired,\n    openMediaLibrary: PropTypes.func.isRequired,\n    hasWorkflow: PropTypes.bool.isRequired,\n    displayUrl: PropTypes.string,\n    isTestRepo: PropTypes.bool,\n    t: PropTypes.func.isRequired,\n    checkBackendStatus: PropTypes.func.isRequired,\n  };\n\n  intervalId;\n\n  componentDidMount() {\n    this.intervalId = setInterval(() => {\n      this.props.checkBackendStatus();\n    }, 5 * 60 * 1000);\n  }\n\n  componentWillUnmount() {\n    clearInterval(this.intervalId);\n  }\n\n  handleCreatePostClick = collectionName => {\n    const { onCreateEntryClick } = this.props;\n    if (onCreateEntryClick) {\n      onCreateEntryClick(collectionName);\n    }\n  };\n\n  render() {\n    const {\n      user,\n      collections,\n      onLogoutClick,\n      openMediaLibrary,\n      hasWorkflow,\n      displayUrl,\n      isTestRepo,\n      t,\n      showMediaButton,\n    } = this.props;\n\n    const creatableCollections = collections\n      .filter(collection => collection.get('create'))\n      .toList();\n\n    return (\n      <AppHeader>\n        <AppHeaderContent>\n          <nav>\n            <AppHeaderNavList>\n              <li>\n                <AppHeaderNavLink\n                  to=\"/\"\n                  activeClassName=\"header-link-active\"\n                  isActive={(match, location) => location.pathname.startsWith('/collections/')}\n                >\n                  <Icon type=\"page\" />\n                  {t('app.header.content')}\n                </AppHeaderNavLink>\n              </li>\n              {hasWorkflow && (\n                <li>\n                  <AppHeaderNavLink to=\"/workflow\" activeClassName=\"header-link-active\">\n                    <Icon type=\"workflow\" />\n                    {t('app.header.workflow')}\n                  </AppHeaderNavLink>\n                </li>\n              )}\n              {showMediaButton && (\n                <li>\n                  <AppHeaderButton onClick={openMediaLibrary}>\n                    <Icon type=\"media-alt\" />\n                    {t('app.header.media')}\n                  </AppHeaderButton>\n                </li>\n              )}\n            </AppHeaderNavList>\n          </nav>\n          <AppHeaderActions>\n            {creatableCollections.size > 0 && (\n              <Dropdown\n                renderButton={() => (\n                  <AppHeaderQuickNewButton> {t('app.header.quickAdd')}</AppHeaderQuickNewButton>\n                )}\n                dropdownTopOverlap=\"30px\"\n                dropdownWidth=\"160px\"\n                dropdownPosition=\"left\"\n              >\n                {creatableCollections.map(collection => (\n                  <DropdownItem\n                    key={collection.get('name')}\n                    label={collection.get('label_singular') || collection.get('label')}\n                    onClick={() => this.handleCreatePostClick(collection.get('name'))}\n                  />\n                ))}\n              </Dropdown>\n            )}\n            <SettingsDropdown\n              displayUrl={displayUrl}\n              isTestRepo={isTestRepo}\n              imageUrl={user?.avatar_url}\n              onLogoutClick={onLogoutClick}\n            />\n          </AppHeaderActions>\n        </AppHeaderContent>\n      </AppHeader>\n    );\n  }\n}\n\nconst mapDispatchToProps = {\n  checkBackendStatus,\n};\n\nexport default connect(null, mapDispatchToProps)(translate()(Header));\n"]} */",
62
56
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
63
57
  });
64
- const AppHeaderQuickNewButton = /*#__PURE__*/(0, _base.default)(_decapCmsUiDefault.StyledDropdownButton, {
58
+ const AppHeaderQuickNewButton = /*#__PURE__*/_styled(StyledDropdownButton, {
65
59
  target: "e1rbzf6g1",
66
60
  label: "AppHeaderQuickNewButton"
67
- })(_decapCmsUiDefault.buttons.button, ";", _decapCmsUiDefault.buttons.medium, ";", _decapCmsUiDefault.buttons.gray, ";margin-right:8px;&:after{top:11px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/App/Header.js"],"names":[],"mappings":"AAmG4D","file":"../../../../src/components/App/Header.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { translate } from 'react-polyglot';\nimport { NavLink } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colors,\n  lengths,\n  shadows,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { connect } from 'react-redux';\n\nimport { SettingsDropdown } from '../UI';\nimport { checkBackendStatus } from '../../actions/status';\n\nconst styles = {\n  buttonActive: css`\n    color: ${colors.active};\n  `,\n};\n\nfunction AppHeader(props) {\n  return (\n    <header\n      css={css`\n        ${shadows.dropMain};\n        position: sticky;\n        width: 100%;\n        top: 0;\n        background-color: ${colors.foreground};\n        z-index: ${zIndex.zIndex300};\n        height: ${lengths.topBarHeight};\n      `}\n      {...props}\n    />\n  );\n}\n\nconst AppHeaderContent = styled.div`\n  display: flex;\n  justify-content: space-between;\n  min-width: 800px;\n  max-width: 1440px;\n  padding: 0 12px;\n  margin: 0 auto;\n`;\n\nconst AppHeaderButton = styled.button`\n  ${buttons.button};\n  background: none;\n  color: #7b8290;\n  font-family: inherit;\n  font-size: 16px;\n  font-weight: 500;\n  display: inline-flex;\n  padding: 16px 20px;\n  align-items: center;\n\n  ${Icon} {\n    margin-right: 4px;\n    color: #b3b9c4;\n  }\n\n  &:hover,\n  &:active,\n  &:focus-visible {\n    ${styles.buttonActive};\n\n    ${Icon} {\n      ${styles.buttonActive};\n    }\n  }\n\n  ${props => css`\n    &.${props.activeClassName} {\n      ${styles.buttonActive};\n\n      ${Icon} {\n        ${styles.buttonActive};\n      }\n    }\n  `};\n`;\n\nconst AppHeaderNavLink = AppHeaderButton.withComponent(NavLink);\n\nconst AppHeaderActions = styled.div`\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst AppHeaderQuickNewButton = styled(StyledDropdownButton)`\n  ${buttons.button};\n  ${buttons.medium};\n  ${buttons.gray};\n  margin-right: 8px;\n\n  &:after {\n    top: 11px;\n  }\n`;\n\nconst AppHeaderNavList = styled.ul`\n  display: flex;\n  margin: 0;\n  list-style: none;\n`;\n\nclass Header extends React.Component {\n  static propTypes = {\n    user: PropTypes.object.isRequired,\n    collections: ImmutablePropTypes.map.isRequired,\n    onCreateEntryClick: PropTypes.func.isRequired,\n    onLogoutClick: PropTypes.func.isRequired,\n    openMediaLibrary: PropTypes.func.isRequired,\n    hasWorkflow: PropTypes.bool.isRequired,\n    displayUrl: PropTypes.string,\n    isTestRepo: PropTypes.bool,\n    t: PropTypes.func.isRequired,\n    checkBackendStatus: PropTypes.func.isRequired,\n  };\n\n  intervalId;\n\n  componentDidMount() {\n    this.intervalId = setInterval(() => {\n      this.props.checkBackendStatus();\n    }, 5 * 60 * 1000);\n  }\n\n  componentWillUnmount() {\n    clearInterval(this.intervalId);\n  }\n\n  handleCreatePostClick = collectionName => {\n    const { onCreateEntryClick } = this.props;\n    if (onCreateEntryClick) {\n      onCreateEntryClick(collectionName);\n    }\n  };\n\n  render() {\n    const {\n      user,\n      collections,\n      onLogoutClick,\n      openMediaLibrary,\n      hasWorkflow,\n      displayUrl,\n      isTestRepo,\n      t,\n      showMediaButton,\n    } = this.props;\n\n    const creatableCollections = collections\n      .filter(collection => collection.get('create'))\n      .toList();\n\n    return (\n      <AppHeader>\n        <AppHeaderContent>\n          <nav>\n            <AppHeaderNavList>\n              <li>\n                <AppHeaderNavLink\n                  to=\"/\"\n                  activeClassName=\"header-link-active\"\n                  isActive={(match, location) => location.pathname.startsWith('/collections/')}\n                >\n                  <Icon type=\"page\" />\n                  {t('app.header.content')}\n                </AppHeaderNavLink>\n              </li>\n              {hasWorkflow && (\n                <li>\n                  <AppHeaderNavLink to=\"/workflow\" activeClassName=\"header-link-active\">\n                    <Icon type=\"workflow\" />\n                    {t('app.header.workflow')}\n                  </AppHeaderNavLink>\n                </li>\n              )}\n              {showMediaButton && (\n                <li>\n                  <AppHeaderButton onClick={openMediaLibrary}>\n                    <Icon type=\"media-alt\" />\n                    {t('app.header.media')}\n                  </AppHeaderButton>\n                </li>\n              )}\n            </AppHeaderNavList>\n          </nav>\n          <AppHeaderActions>\n            {creatableCollections.size > 0 && (\n              <Dropdown\n                renderButton={() => (\n                  <AppHeaderQuickNewButton> {t('app.header.quickAdd')}</AppHeaderQuickNewButton>\n                )}\n                dropdownTopOverlap=\"30px\"\n                dropdownWidth=\"160px\"\n                dropdownPosition=\"left\"\n              >\n                {creatableCollections.map(collection => (\n                  <DropdownItem\n                    key={collection.get('name')}\n                    label={collection.get('label_singular') || collection.get('label')}\n                    onClick={() => this.handleCreatePostClick(collection.get('name'))}\n                  />\n                ))}\n              </Dropdown>\n            )}\n            <SettingsDropdown\n              displayUrl={displayUrl}\n              isTestRepo={isTestRepo}\n              imageUrl={user?.avatar_url}\n              onLogoutClick={onLogoutClick}\n            />\n          </AppHeaderActions>\n        </AppHeaderContent>\n      </AppHeader>\n    );\n  }\n}\n\nconst mapDispatchToProps = {\n  checkBackendStatus,\n};\n\nexport default connect(null, mapDispatchToProps)(translate()(Header));\n"]} */"));
68
- const AppHeaderNavList = /*#__PURE__*/(0, _base.default)("ul", {
61
+ })(buttons.button, ";", buttons.medium, ";", buttons.gray, ";margin-right:8px;&:after{top:11px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/App/Header.js"],"names":[],"mappings":"AAmG4D","file":"../../../../src/components/App/Header.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { translate } from 'react-polyglot';\nimport { NavLink } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colors,\n  lengths,\n  shadows,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { connect } from 'react-redux';\n\nimport { SettingsDropdown } from '../UI';\nimport { checkBackendStatus } from '../../actions/status';\n\nconst styles = {\n  buttonActive: css`\n    color: ${colors.active};\n  `,\n};\n\nfunction AppHeader(props) {\n  return (\n    <header\n      css={css`\n        ${shadows.dropMain};\n        position: sticky;\n        width: 100%;\n        top: 0;\n        background-color: ${colors.foreground};\n        z-index: ${zIndex.zIndex300};\n        height: ${lengths.topBarHeight};\n      `}\n      {...props}\n    />\n  );\n}\n\nconst AppHeaderContent = styled.div`\n  display: flex;\n  justify-content: space-between;\n  min-width: 800px;\n  max-width: 1440px;\n  padding: 0 12px;\n  margin: 0 auto;\n`;\n\nconst AppHeaderButton = styled.button`\n  ${buttons.button};\n  background: none;\n  color: #7b8290;\n  font-family: inherit;\n  font-size: 16px;\n  font-weight: 500;\n  display: inline-flex;\n  padding: 16px 20px;\n  align-items: center;\n\n  ${Icon} {\n    margin-right: 4px;\n    color: #b3b9c4;\n  }\n\n  &:hover,\n  &:active,\n  &:focus-visible {\n    ${styles.buttonActive};\n\n    ${Icon} {\n      ${styles.buttonActive};\n    }\n  }\n\n  ${props => css`\n    &.${props.activeClassName} {\n      ${styles.buttonActive};\n\n      ${Icon} {\n        ${styles.buttonActive};\n      }\n    }\n  `};\n`;\n\nconst AppHeaderNavLink = AppHeaderButton.withComponent(NavLink);\n\nconst AppHeaderActions = styled.div`\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst AppHeaderQuickNewButton = styled(StyledDropdownButton)`\n  ${buttons.button};\n  ${buttons.medium};\n  ${buttons.gray};\n  margin-right: 8px;\n\n  &:after {\n    top: 11px;\n  }\n`;\n\nconst AppHeaderNavList = styled.ul`\n  display: flex;\n  margin: 0;\n  list-style: none;\n`;\n\nclass Header extends React.Component {\n  static propTypes = {\n    user: PropTypes.object.isRequired,\n    collections: ImmutablePropTypes.map.isRequired,\n    onCreateEntryClick: PropTypes.func.isRequired,\n    onLogoutClick: PropTypes.func.isRequired,\n    openMediaLibrary: PropTypes.func.isRequired,\n    hasWorkflow: PropTypes.bool.isRequired,\n    displayUrl: PropTypes.string,\n    isTestRepo: PropTypes.bool,\n    t: PropTypes.func.isRequired,\n    checkBackendStatus: PropTypes.func.isRequired,\n  };\n\n  intervalId;\n\n  componentDidMount() {\n    this.intervalId = setInterval(() => {\n      this.props.checkBackendStatus();\n    }, 5 * 60 * 1000);\n  }\n\n  componentWillUnmount() {\n    clearInterval(this.intervalId);\n  }\n\n  handleCreatePostClick = collectionName => {\n    const { onCreateEntryClick } = this.props;\n    if (onCreateEntryClick) {\n      onCreateEntryClick(collectionName);\n    }\n  };\n\n  render() {\n    const {\n      user,\n      collections,\n      onLogoutClick,\n      openMediaLibrary,\n      hasWorkflow,\n      displayUrl,\n      isTestRepo,\n      t,\n      showMediaButton,\n    } = this.props;\n\n    const creatableCollections = collections\n      .filter(collection => collection.get('create'))\n      .toList();\n\n    return (\n      <AppHeader>\n        <AppHeaderContent>\n          <nav>\n            <AppHeaderNavList>\n              <li>\n                <AppHeaderNavLink\n                  to=\"/\"\n                  activeClassName=\"header-link-active\"\n                  isActive={(match, location) => location.pathname.startsWith('/collections/')}\n                >\n                  <Icon type=\"page\" />\n                  {t('app.header.content')}\n                </AppHeaderNavLink>\n              </li>\n              {hasWorkflow && (\n                <li>\n                  <AppHeaderNavLink to=\"/workflow\" activeClassName=\"header-link-active\">\n                    <Icon type=\"workflow\" />\n                    {t('app.header.workflow')}\n                  </AppHeaderNavLink>\n                </li>\n              )}\n              {showMediaButton && (\n                <li>\n                  <AppHeaderButton onClick={openMediaLibrary}>\n                    <Icon type=\"media-alt\" />\n                    {t('app.header.media')}\n                  </AppHeaderButton>\n                </li>\n              )}\n            </AppHeaderNavList>\n          </nav>\n          <AppHeaderActions>\n            {creatableCollections.size > 0 && (\n              <Dropdown\n                renderButton={() => (\n                  <AppHeaderQuickNewButton> {t('app.header.quickAdd')}</AppHeaderQuickNewButton>\n                )}\n                dropdownTopOverlap=\"30px\"\n                dropdownWidth=\"160px\"\n                dropdownPosition=\"left\"\n              >\n                {creatableCollections.map(collection => (\n                  <DropdownItem\n                    key={collection.get('name')}\n                    label={collection.get('label_singular') || collection.get('label')}\n                    onClick={() => this.handleCreatePostClick(collection.get('name'))}\n                  />\n                ))}\n              </Dropdown>\n            )}\n            <SettingsDropdown\n              displayUrl={displayUrl}\n              isTestRepo={isTestRepo}\n              imageUrl={user?.avatar_url}\n              onLogoutClick={onLogoutClick}\n            />\n          </AppHeaderActions>\n        </AppHeaderContent>\n      </AppHeader>\n    );\n  }\n}\n\nconst mapDispatchToProps = {\n  checkBackendStatus,\n};\n\nexport default connect(null, mapDispatchToProps)(translate()(Header));\n"]} */"));
62
+ const AppHeaderNavList = /*#__PURE__*/_styled("ul", {
69
63
  target: "e1rbzf6g0",
70
64
  label: "AppHeaderNavList"
71
65
  })(process.env.NODE_ENV === "production" ? {
@@ -77,7 +71,7 @@ const AppHeaderNavList = /*#__PURE__*/(0, _base.default)("ul", {
77
71
  map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/App/Header.js"],"names":[],"mappings":"AA8GkC","file":"../../../../src/components/App/Header.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { translate } from 'react-polyglot';\nimport { NavLink } from 'react-router-dom';\nimport {\n  Icon,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  colors,\n  lengths,\n  shadows,\n  buttons,\n  zIndex,\n} from 'decap-cms-ui-default';\nimport { connect } from 'react-redux';\n\nimport { SettingsDropdown } from '../UI';\nimport { checkBackendStatus } from '../../actions/status';\n\nconst styles = {\n  buttonActive: css`\n    color: ${colors.active};\n  `,\n};\n\nfunction AppHeader(props) {\n  return (\n    <header\n      css={css`\n        ${shadows.dropMain};\n        position: sticky;\n        width: 100%;\n        top: 0;\n        background-color: ${colors.foreground};\n        z-index: ${zIndex.zIndex300};\n        height: ${lengths.topBarHeight};\n      `}\n      {...props}\n    />\n  );\n}\n\nconst AppHeaderContent = styled.div`\n  display: flex;\n  justify-content: space-between;\n  min-width: 800px;\n  max-width: 1440px;\n  padding: 0 12px;\n  margin: 0 auto;\n`;\n\nconst AppHeaderButton = styled.button`\n  ${buttons.button};\n  background: none;\n  color: #7b8290;\n  font-family: inherit;\n  font-size: 16px;\n  font-weight: 500;\n  display: inline-flex;\n  padding: 16px 20px;\n  align-items: center;\n\n  ${Icon} {\n    margin-right: 4px;\n    color: #b3b9c4;\n  }\n\n  &:hover,\n  &:active,\n  &:focus-visible {\n    ${styles.buttonActive};\n\n    ${Icon} {\n      ${styles.buttonActive};\n    }\n  }\n\n  ${props => css`\n    &.${props.activeClassName} {\n      ${styles.buttonActive};\n\n      ${Icon} {\n        ${styles.buttonActive};\n      }\n    }\n  `};\n`;\n\nconst AppHeaderNavLink = AppHeaderButton.withComponent(NavLink);\n\nconst AppHeaderActions = styled.div`\n  display: inline-flex;\n  align-items: center;\n`;\n\nconst AppHeaderQuickNewButton = styled(StyledDropdownButton)`\n  ${buttons.button};\n  ${buttons.medium};\n  ${buttons.gray};\n  margin-right: 8px;\n\n  &:after {\n    top: 11px;\n  }\n`;\n\nconst AppHeaderNavList = styled.ul`\n  display: flex;\n  margin: 0;\n  list-style: none;\n`;\n\nclass Header extends React.Component {\n  static propTypes = {\n    user: PropTypes.object.isRequired,\n    collections: ImmutablePropTypes.map.isRequired,\n    onCreateEntryClick: PropTypes.func.isRequired,\n    onLogoutClick: PropTypes.func.isRequired,\n    openMediaLibrary: PropTypes.func.isRequired,\n    hasWorkflow: PropTypes.bool.isRequired,\n    displayUrl: PropTypes.string,\n    isTestRepo: PropTypes.bool,\n    t: PropTypes.func.isRequired,\n    checkBackendStatus: PropTypes.func.isRequired,\n  };\n\n  intervalId;\n\n  componentDidMount() {\n    this.intervalId = setInterval(() => {\n      this.props.checkBackendStatus();\n    }, 5 * 60 * 1000);\n  }\n\n  componentWillUnmount() {\n    clearInterval(this.intervalId);\n  }\n\n  handleCreatePostClick = collectionName => {\n    const { onCreateEntryClick } = this.props;\n    if (onCreateEntryClick) {\n      onCreateEntryClick(collectionName);\n    }\n  };\n\n  render() {\n    const {\n      user,\n      collections,\n      onLogoutClick,\n      openMediaLibrary,\n      hasWorkflow,\n      displayUrl,\n      isTestRepo,\n      t,\n      showMediaButton,\n    } = this.props;\n\n    const creatableCollections = collections\n      .filter(collection => collection.get('create'))\n      .toList();\n\n    return (\n      <AppHeader>\n        <AppHeaderContent>\n          <nav>\n            <AppHeaderNavList>\n              <li>\n                <AppHeaderNavLink\n                  to=\"/\"\n                  activeClassName=\"header-link-active\"\n                  isActive={(match, location) => location.pathname.startsWith('/collections/')}\n                >\n                  <Icon type=\"page\" />\n                  {t('app.header.content')}\n                </AppHeaderNavLink>\n              </li>\n              {hasWorkflow && (\n                <li>\n                  <AppHeaderNavLink to=\"/workflow\" activeClassName=\"header-link-active\">\n                    <Icon type=\"workflow\" />\n                    {t('app.header.workflow')}\n                  </AppHeaderNavLink>\n                </li>\n              )}\n              {showMediaButton && (\n                <li>\n                  <AppHeaderButton onClick={openMediaLibrary}>\n                    <Icon type=\"media-alt\" />\n                    {t('app.header.media')}\n                  </AppHeaderButton>\n                </li>\n              )}\n            </AppHeaderNavList>\n          </nav>\n          <AppHeaderActions>\n            {creatableCollections.size > 0 && (\n              <Dropdown\n                renderButton={() => (\n                  <AppHeaderQuickNewButton> {t('app.header.quickAdd')}</AppHeaderQuickNewButton>\n                )}\n                dropdownTopOverlap=\"30px\"\n                dropdownWidth=\"160px\"\n                dropdownPosition=\"left\"\n              >\n                {creatableCollections.map(collection => (\n                  <DropdownItem\n                    key={collection.get('name')}\n                    label={collection.get('label_singular') || collection.get('label')}\n                    onClick={() => this.handleCreatePostClick(collection.get('name'))}\n                  />\n                ))}\n              </Dropdown>\n            )}\n            <SettingsDropdown\n              displayUrl={displayUrl}\n              isTestRepo={isTestRepo}\n              imageUrl={user?.avatar_url}\n              onLogoutClick={onLogoutClick}\n            />\n          </AppHeaderActions>\n        </AppHeaderContent>\n      </AppHeader>\n    );\n  }\n}\n\nconst mapDispatchToProps = {\n  checkBackendStatus,\n};\n\nexport default connect(null, mapDispatchToProps)(translate()(Header));\n"]} */",
78
72
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
79
73
  });
80
- class Header extends _react.default.Component {
74
+ class Header extends React.Component {
81
75
  constructor(...args) {
82
76
  super(...args);
83
77
  _defineProperty(this, "intervalId", void 0);
@@ -111,31 +105,31 @@ class Header extends _react.default.Component {
111
105
  showMediaButton
112
106
  } = this.props;
113
107
  const creatableCollections = collections.filter(collection => collection.get('create')).toList();
114
- return (0, _react2.jsx)(AppHeader, null, (0, _react2.jsx)(AppHeaderContent, null, (0, _react2.jsx)("nav", null, (0, _react2.jsx)(AppHeaderNavList, null, (0, _react2.jsx)("li", null, (0, _react2.jsx)(AppHeaderNavLink, {
108
+ return ___EmotionJSX(AppHeader, null, ___EmotionJSX(AppHeaderContent, null, ___EmotionJSX("nav", null, ___EmotionJSX(AppHeaderNavList, null, ___EmotionJSX("li", null, ___EmotionJSX(AppHeaderNavLink, {
115
109
  to: "/",
116
110
  activeClassName: "header-link-active",
117
111
  isActive: (match, location) => location.pathname.startsWith('/collections/')
118
- }, (0, _react2.jsx)(_decapCmsUiDefault.Icon, {
112
+ }, ___EmotionJSX(Icon, {
119
113
  type: "page"
120
- }), t('app.header.content'))), hasWorkflow && (0, _react2.jsx)("li", null, (0, _react2.jsx)(AppHeaderNavLink, {
114
+ }), t('app.header.content'))), hasWorkflow && ___EmotionJSX("li", null, ___EmotionJSX(AppHeaderNavLink, {
121
115
  to: "/workflow",
122
116
  activeClassName: "header-link-active"
123
- }, (0, _react2.jsx)(_decapCmsUiDefault.Icon, {
117
+ }, ___EmotionJSX(Icon, {
124
118
  type: "workflow"
125
- }), t('app.header.workflow'))), showMediaButton && (0, _react2.jsx)("li", null, (0, _react2.jsx)(AppHeaderButton, {
119
+ }), t('app.header.workflow'))), showMediaButton && ___EmotionJSX("li", null, ___EmotionJSX(AppHeaderButton, {
126
120
  onClick: openMediaLibrary
127
- }, (0, _react2.jsx)(_decapCmsUiDefault.Icon, {
121
+ }, ___EmotionJSX(Icon, {
128
122
  type: "media-alt"
129
- }), t('app.header.media'))))), (0, _react2.jsx)(AppHeaderActions, null, creatableCollections.size > 0 && (0, _react2.jsx)(_decapCmsUiDefault.Dropdown, {
130
- renderButton: () => (0, _react2.jsx)(AppHeaderQuickNewButton, null, " ", t('app.header.quickAdd')),
123
+ }), t('app.header.media'))))), ___EmotionJSX(AppHeaderActions, null, creatableCollections.size > 0 && ___EmotionJSX(Dropdown, {
124
+ renderButton: () => ___EmotionJSX(AppHeaderQuickNewButton, null, " ", t('app.header.quickAdd')),
131
125
  dropdownTopOverlap: "30px",
132
126
  dropdownWidth: "160px",
133
127
  dropdownPosition: "left"
134
- }, creatableCollections.map(collection => (0, _react2.jsx)(_decapCmsUiDefault.DropdownItem, {
128
+ }, creatableCollections.map(collection => ___EmotionJSX(DropdownItem, {
135
129
  key: collection.get('name'),
136
130
  label: collection.get('label_singular') || collection.get('label'),
137
131
  onClick: () => this.handleCreatePostClick(collection.get('name'))
138
- }))), (0, _react2.jsx)(_UI.SettingsDropdown, {
132
+ }))), ___EmotionJSX(SettingsDropdown, {
139
133
  displayUrl: displayUrl,
140
134
  isTestRepo: isTestRepo,
141
135
  imageUrl: user === null || user === void 0 ? void 0 : user.avatar_url,
@@ -144,18 +138,18 @@ class Header extends _react.default.Component {
144
138
  }
145
139
  }
146
140
  _defineProperty(Header, "propTypes", {
147
- user: _propTypes.default.object.isRequired,
148
- collections: _reactImmutableProptypes.default.map.isRequired,
149
- onCreateEntryClick: _propTypes.default.func.isRequired,
150
- onLogoutClick: _propTypes.default.func.isRequired,
151
- openMediaLibrary: _propTypes.default.func.isRequired,
152
- hasWorkflow: _propTypes.default.bool.isRequired,
153
- displayUrl: _propTypes.default.string,
154
- isTestRepo: _propTypes.default.bool,
155
- t: _propTypes.default.func.isRequired,
156
- checkBackendStatus: _propTypes.default.func.isRequired
141
+ user: PropTypes.object.isRequired,
142
+ collections: ImmutablePropTypes.map.isRequired,
143
+ onCreateEntryClick: PropTypes.func.isRequired,
144
+ onLogoutClick: PropTypes.func.isRequired,
145
+ openMediaLibrary: PropTypes.func.isRequired,
146
+ hasWorkflow: PropTypes.bool.isRequired,
147
+ displayUrl: PropTypes.string,
148
+ isTestRepo: PropTypes.bool,
149
+ t: PropTypes.func.isRequired,
150
+ checkBackendStatus: PropTypes.func.isRequired
157
151
  });
158
152
  const mapDispatchToProps = {
159
- checkBackendStatus: _status.checkBackendStatus
153
+ checkBackendStatus
160
154
  };
161
- var _default = exports.default = (0, _reactRedux.connect)(null, mapDispatchToProps)((0, _reactPolyglot.translate)()(Header));
155
+ export default connect(null, mapDispatchToProps)(translate()(Header));
@@ -1,26 +1,19 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = void 0;
7
- var _base = _interopRequireDefault(require("@emotion/styled/base"));
8
- var _react = _interopRequireDefault(require("react"));
9
- var _reactPolyglot = require("react-polyglot");
10
- var _decapCmsUiDefault = require("decap-cms-ui-default");
11
- var _propTypes = _interopRequireDefault(require("prop-types"));
12
- var _react2 = require("@emotion/react");
13
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
14
- const NotFoundContainer = /*#__PURE__*/(0, _base.default)("div", {
1
+ import _styled from "@emotion/styled/base";
2
+ import React from 'react';
3
+ import { translate } from 'react-polyglot';
4
+ import { lengths } from 'decap-cms-ui-default';
5
+ import PropTypes from 'prop-types';
6
+ import { jsx as ___EmotionJSX } from "@emotion/react";
7
+ const NotFoundContainer = /*#__PURE__*/_styled("div", {
15
8
  target: "ew40z3q0",
16
9
  label: "NotFoundContainer"
17
- })("margin:", _decapCmsUiDefault.lengths.pageMargin, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0FwcC9Ob3RGb3VuZFBhZ2UuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBTW9DIiwiZmlsZSI6Ii4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0FwcC9Ob3RGb3VuZFBhZ2UuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgdHJhbnNsYXRlIH0gZnJvbSAncmVhY3QtcG9seWdsb3QnO1xuaW1wb3J0IHsgbGVuZ3RocyB9IGZyb20gJ2RlY2FwLWNtcy11aS1kZWZhdWx0JztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5cbmNvbnN0IE5vdEZvdW5kQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgbWFyZ2luOiAke2xlbmd0aHMucGFnZU1hcmdpbn07XG5gO1xuXG5mdW5jdGlvbiBOb3RGb3VuZFBhZ2UoeyB0IH0pIHtcbiAgcmV0dXJuIChcbiAgICA8Tm90Rm91bmRDb250YWluZXI+XG4gICAgICA8aDI+e3QoJ2FwcC5ub3RGb3VuZFBhZ2UuaGVhZGVyJyl9PC9oMj5cbiAgICA8L05vdEZvdW5kQ29udGFpbmVyPlxuICApO1xufVxuXG5Ob3RGb3VuZFBhZ2UucHJvcFR5cGVzID0ge1xuICB0OiBQcm9wVHlwZXMuZnVuYy5pc1JlcXVpcmVkLFxufTtcblxuZXhwb3J0IGRlZmF1bHQgdHJhbnNsYXRlKCkoTm90Rm91bmRQYWdlKTtcbiJdfQ== */"));
10
+ })("margin:", lengths.pageMargin, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0FwcC9Ob3RGb3VuZFBhZ2UuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBTW9DIiwiZmlsZSI6Ii4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0FwcC9Ob3RGb3VuZFBhZ2UuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgdHJhbnNsYXRlIH0gZnJvbSAncmVhY3QtcG9seWdsb3QnO1xuaW1wb3J0IHsgbGVuZ3RocyB9IGZyb20gJ2RlY2FwLWNtcy11aS1kZWZhdWx0JztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5cbmNvbnN0IE5vdEZvdW5kQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgbWFyZ2luOiAke2xlbmd0aHMucGFnZU1hcmdpbn07XG5gO1xuXG5mdW5jdGlvbiBOb3RGb3VuZFBhZ2UoeyB0IH0pIHtcbiAgcmV0dXJuIChcbiAgICA8Tm90Rm91bmRDb250YWluZXI+XG4gICAgICA8aDI+e3QoJ2FwcC5ub3RGb3VuZFBhZ2UuaGVhZGVyJyl9PC9oMj5cbiAgICA8L05vdEZvdW5kQ29udGFpbmVyPlxuICApO1xufVxuXG5Ob3RGb3VuZFBhZ2UucHJvcFR5cGVzID0ge1xuICB0OiBQcm9wVHlwZXMuZnVuYy5pc1JlcXVpcmVkLFxufTtcblxuZXhwb3J0IGRlZmF1bHQgdHJhbnNsYXRlKCkoTm90Rm91bmRQYWdlKTtcbiJdfQ== */"));
18
11
  function NotFoundPage({
19
12
  t
20
13
  }) {
21
- return (0, _react2.jsx)(NotFoundContainer, null, (0, _react2.jsx)("h2", null, t('app.notFoundPage.header')));
14
+ return ___EmotionJSX(NotFoundContainer, null, ___EmotionJSX("h2", null, t('app.notFoundPage.header')));
22
15
  }
23
16
  NotFoundPage.propTypes = {
24
- t: _propTypes.default.func.isRequired
17
+ t: PropTypes.func.isRequired
25
18
  };
26
- var _default = exports.default = (0, _reactPolyglot.translate)()(NotFoundPage);
19
+ export default translate()(NotFoundPage);