decap-cms-core 3.7.0 → 3.8.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 (31) hide show
  1. package/dist/decap-cms-core.js +26 -26
  2. package/dist/decap-cms-core.js.LICENSE.txt +0 -12
  3. package/dist/decap-cms-core.js.map +1 -1
  4. package/dist/esm/bootstrap.js +3 -2
  5. package/dist/esm/components/App/App.js +6 -3
  6. package/dist/esm/components/App/Header.js +38 -14
  7. package/dist/esm/components/Collection/Entries/Entries.js +14 -5
  8. package/dist/esm/components/Collection/Entries/EntriesCollection.js +65 -9
  9. package/dist/esm/components/Collection/Entries/EntryCard.js +84 -28
  10. package/dist/esm/components/Collection/Entries/EntryListing.js +46 -11
  11. package/dist/esm/components/UI/ErrorBoundary.js +2 -2
  12. package/dist/esm/constants/configSchema.js +14 -0
  13. package/dist/esm/formats/toml.js +2 -2
  14. package/dist/esm/lib/i18n.js +16 -0
  15. package/dist/esm/lib/polyfill.js +8 -0
  16. package/index.d.ts +5 -1
  17. package/package.json +8 -2
  18. package/src/bootstrap.js +1 -0
  19. package/src/components/App/App.js +2 -0
  20. package/src/components/App/Header.js +27 -0
  21. package/src/components/Collection/Entries/Entries.js +9 -0
  22. package/src/components/Collection/Entries/EntriesCollection.js +100 -4
  23. package/src/components/Collection/Entries/EntryCard.js +82 -3
  24. package/src/components/Collection/Entries/EntryListing.js +65 -5
  25. package/src/components/Collection/Entries/__tests__/EntriesCollection.spec.js +26 -18
  26. package/src/components/Collection/Entries/__tests__/__snapshots__/EntriesCollection.spec.js.snap +1 -0
  27. package/src/constants/configSchema.js +9 -1
  28. package/src/formats/toml.ts +2 -2
  29. package/src/lib/i18n.ts +21 -0
  30. package/src/lib/polyfill.js +9 -0
  31. package/src/types/redux.ts +5 -1
@@ -13,56 +13,67 @@ import { SettingsDropdown } from '../UI';
13
13
  import { checkBackendStatus } from '../../actions/status';
14
14
  import { jsx as ___EmotionJSX } from "@emotion/react";
15
15
  const styles = {
16
- 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    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(Header.propTypes, this.props, 'prop', 'Header');\n\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"]} */"))
16
+ 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\nconst AppHeaderLogo = styled.li`\n  display: flex;\n  align-items: center;\n\n  img {\n    padding: 12px 20px;\n    max-height: 56px;\n    max-width: 300px;\n    object-fit: contain;\n    object-position: center;\n  }\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    logoUrl: PropTypes.string, // Deprecated, replaced by `logo.src`\n    logo: PropTypes.shape({\n      src: PropTypes.string.isRequired,\n      show_in_header: PropTypes.bool,\n    }),\n    isTestRepo: PropTypes.bool,\n    t: PropTypes.func.isRequired,\n    checkBackendStatus: PropTypes.func.isRequired,\n  };\n\n  intervalId;\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(Header.propTypes, this.props, 'prop', 'Header');\n\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      logoUrl, // Deprecated, replaced by `logo.src`\n      logo,\n      isTestRepo,\n      t,\n      showMediaButton,\n    } = this.props;\n\n    const creatableCollections = collections\n      .filter(collection => collection.get('create'))\n      .toList();\n\n    const shouldShowLogo = logo?.show_in_header && logo?.src;\n\n    return (\n      <AppHeader>\n        <AppHeaderContent>\n          <nav>\n            <AppHeaderNavList>\n              {shouldShowLogo && (\n                <AppHeaderLogo>\n                  <img src={logo?.src || logoUrl} alt=\"Logo\" />\n                </AppHeaderLogo>\n              )}\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"]} */"))
17
17
  };
18
18
  function AppHeader(props) {
19
19
  return ___EmotionJSX("header", _extends({
20
- 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    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(Header.propTypes, this.props, 'prop', 'Header');\n\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"]} */"))
20
+ 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\nconst AppHeaderLogo = styled.li`\n  display: flex;\n  align-items: center;\n\n  img {\n    padding: 12px 20px;\n    max-height: 56px;\n    max-width: 300px;\n    object-fit: contain;\n    object-position: center;\n  }\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    logoUrl: PropTypes.string, // Deprecated, replaced by `logo.src`\n    logo: PropTypes.shape({\n      src: PropTypes.string.isRequired,\n      show_in_header: PropTypes.bool,\n    }),\n    isTestRepo: PropTypes.bool,\n    t: PropTypes.func.isRequired,\n    checkBackendStatus: PropTypes.func.isRequired,\n  };\n\n  intervalId;\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(Header.propTypes, this.props, 'prop', 'Header');\n\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      logoUrl, // Deprecated, replaced by `logo.src`\n      logo,\n      isTestRepo,\n      t,\n      showMediaButton,\n    } = this.props;\n\n    const creatableCollections = collections\n      .filter(collection => collection.get('create'))\n      .toList();\n\n    const shouldShowLogo = logo?.show_in_header && logo?.src;\n\n    return (\n      <AppHeader>\n        <AppHeaderContent>\n          <nav>\n            <AppHeaderNavList>\n              {shouldShowLogo && (\n                <AppHeaderLogo>\n                  <img src={logo?.src || logoUrl} alt=\"Logo\" />\n                </AppHeaderLogo>\n              )}\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"]} */"))
21
21
  }, props));
22
22
  }
23
23
  const AppHeaderContent = /*#__PURE__*/_styled("div", {
24
- target: "e1rbzf6g4",
24
+ target: "e1rbzf6g5",
25
25
  label: "AppHeaderContent"
26
26
  })(process.env.NODE_ENV === "production" ? {
27
27
  name: "jxf21e",
28
28
  styles: "display:flex;justify-content:space-between;min-width:800px;max-width:1440px;padding:0 12px;margin:0 auto"
29
29
  } : {
30
30
  name: "jxf21e",
31
- styles: "display:flex;justify-content:space-between;min-width:800px;max-width:1440px;padding:0 12px;margin:0 auto/*# 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    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(Header.propTypes, this.props, 'prop', 'Header');\n\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"]} */",
31
+ styles: "display:flex;justify-content:space-between;min-width:800px;max-width:1440px;padding:0 12px;margin:0 auto/*# 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\nconst AppHeaderLogo = styled.li`\n  display: flex;\n  align-items: center;\n\n  img {\n    padding: 12px 20px;\n    max-height: 56px;\n    max-width: 300px;\n    object-fit: contain;\n    object-position: center;\n  }\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    logoUrl: PropTypes.string, // Deprecated, replaced by `logo.src`\n    logo: PropTypes.shape({\n      src: PropTypes.string.isRequired,\n      show_in_header: PropTypes.bool,\n    }),\n    isTestRepo: PropTypes.bool,\n    t: PropTypes.func.isRequired,\n    checkBackendStatus: PropTypes.func.isRequired,\n  };\n\n  intervalId;\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(Header.propTypes, this.props, 'prop', 'Header');\n\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      logoUrl, // Deprecated, replaced by `logo.src`\n      logo,\n      isTestRepo,\n      t,\n      showMediaButton,\n    } = this.props;\n\n    const creatableCollections = collections\n      .filter(collection => collection.get('create'))\n      .toList();\n\n    const shouldShowLogo = logo?.show_in_header && logo?.src;\n\n    return (\n      <AppHeader>\n        <AppHeaderContent>\n          <nav>\n            <AppHeaderNavList>\n              {shouldShowLogo && (\n                <AppHeaderLogo>\n                  <img src={logo?.src || logoUrl} alt=\"Logo\" />\n                </AppHeaderLogo>\n              )}\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"]} */",
32
32
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
33
33
  });
34
34
  const AppHeaderButton = /*#__PURE__*/_styled("button", {
35
- target: "e1rbzf6g3",
35
+ target: "e1rbzf6g4",
36
36
  label: "AppHeaderButton"
37
- })(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    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(Header.propTypes, this.props, 'prop', 'Header');\n\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    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(Header.propTypes, this.props, 'prop', 'Header');\n\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"]} */"));
37
+ })(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\nconst AppHeaderLogo = styled.li`\n  display: flex;\n  align-items: center;\n\n  img {\n    padding: 12px 20px;\n    max-height: 56px;\n    max-width: 300px;\n    object-fit: contain;\n    object-position: center;\n  }\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    logoUrl: PropTypes.string, // Deprecated, replaced by `logo.src`\n    logo: PropTypes.shape({\n      src: PropTypes.string.isRequired,\n      show_in_header: PropTypes.bool,\n    }),\n    isTestRepo: PropTypes.bool,\n    t: PropTypes.func.isRequired,\n    checkBackendStatus: PropTypes.func.isRequired,\n  };\n\n  intervalId;\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(Header.propTypes, this.props, 'prop', 'Header');\n\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      logoUrl, // Deprecated, replaced by `logo.src`\n      logo,\n      isTestRepo,\n      t,\n      showMediaButton,\n    } = this.props;\n\n    const creatableCollections = collections\n      .filter(collection => collection.get('create'))\n      .toList();\n\n    const shouldShowLogo = logo?.show_in_header && logo?.src;\n\n    return (\n      <AppHeader>\n        <AppHeaderContent>\n          <nav>\n            <AppHeaderNavList>\n              {shouldShowLogo && (\n                <AppHeaderLogo>\n                  <img src={logo?.src || logoUrl} alt=\"Logo\" />\n                </AppHeaderLogo>\n              )}\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\nconst AppHeaderLogo = styled.li`\n  display: flex;\n  align-items: center;\n\n  img {\n    padding: 12px 20px;\n    max-height: 56px;\n    max-width: 300px;\n    object-fit: contain;\n    object-position: center;\n  }\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    logoUrl: PropTypes.string, // Deprecated, replaced by `logo.src`\n    logo: PropTypes.shape({\n      src: PropTypes.string.isRequired,\n      show_in_header: PropTypes.bool,\n    }),\n    isTestRepo: PropTypes.bool,\n    t: PropTypes.func.isRequired,\n    checkBackendStatus: PropTypes.func.isRequired,\n  };\n\n  intervalId;\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(Header.propTypes, this.props, 'prop', 'Header');\n\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      logoUrl, // Deprecated, replaced by `logo.src`\n      logo,\n      isTestRepo,\n      t,\n      showMediaButton,\n    } = this.props;\n\n    const creatableCollections = collections\n      .filter(collection => collection.get('create'))\n      .toList();\n\n    const shouldShowLogo = logo?.show_in_header && logo?.src;\n\n    return (\n      <AppHeader>\n        <AppHeaderContent>\n          <nav>\n            <AppHeaderNavList>\n              {shouldShowLogo && (\n                <AppHeaderLogo>\n                  <img src={logo?.src || logoUrl} alt=\"Logo\" />\n                </AppHeaderLogo>\n              )}\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"]} */"));
38
38
  const AppHeaderNavLink = AppHeaderButton.withComponent(NavLink, {
39
- target: "e1rbzf6g5",
39
+ target: "e1rbzf6g6",
40
40
  label: "AppHeaderNavLink"
41
41
  });
42
42
  const AppHeaderActions = /*#__PURE__*/_styled("div", {
43
- target: "e1rbzf6g2",
43
+ target: "e1rbzf6g3",
44
44
  label: "AppHeaderActions"
45
45
  })(process.env.NODE_ENV === "production" ? {
46
46
  name: "8irbms",
47
47
  styles: "display:inline-flex;align-items:center"
48
48
  } : {
49
49
  name: "8irbms",
50
- styles: "display:inline-flex;align-items:center/*# 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    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(Header.propTypes, this.props, 'prop', 'Header');\n\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"]} */",
50
+ styles: "display:inline-flex;align-items:center/*# 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\nconst AppHeaderLogo = styled.li`\n  display: flex;\n  align-items: center;\n\n  img {\n    padding: 12px 20px;\n    max-height: 56px;\n    max-width: 300px;\n    object-fit: contain;\n    object-position: center;\n  }\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    logoUrl: PropTypes.string, // Deprecated, replaced by `logo.src`\n    logo: PropTypes.shape({\n      src: PropTypes.string.isRequired,\n      show_in_header: PropTypes.bool,\n    }),\n    isTestRepo: PropTypes.bool,\n    t: PropTypes.func.isRequired,\n    checkBackendStatus: PropTypes.func.isRequired,\n  };\n\n  intervalId;\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(Header.propTypes, this.props, 'prop', 'Header');\n\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      logoUrl, // Deprecated, replaced by `logo.src`\n      logo,\n      isTestRepo,\n      t,\n      showMediaButton,\n    } = this.props;\n\n    const creatableCollections = collections\n      .filter(collection => collection.get('create'))\n      .toList();\n\n    const shouldShowLogo = logo?.show_in_header && logo?.src;\n\n    return (\n      <AppHeader>\n        <AppHeaderContent>\n          <nav>\n            <AppHeaderNavList>\n              {shouldShowLogo && (\n                <AppHeaderLogo>\n                  <img src={logo?.src || logoUrl} alt=\"Logo\" />\n                </AppHeaderLogo>\n              )}\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"]} */",
51
51
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
52
52
  });
53
53
  const AppHeaderQuickNewButton = /*#__PURE__*/_styled(StyledDropdownButton, {
54
- target: "e1rbzf6g1",
54
+ target: "e1rbzf6g2",
55
55
  label: "AppHeaderQuickNewButton"
56
- })(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    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(Header.propTypes, this.props, 'prop', 'Header');\n\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"]} */"));
56
+ })(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\nconst AppHeaderLogo = styled.li`\n  display: flex;\n  align-items: center;\n\n  img {\n    padding: 12px 20px;\n    max-height: 56px;\n    max-width: 300px;\n    object-fit: contain;\n    object-position: center;\n  }\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    logoUrl: PropTypes.string, // Deprecated, replaced by `logo.src`\n    logo: PropTypes.shape({\n      src: PropTypes.string.isRequired,\n      show_in_header: PropTypes.bool,\n    }),\n    isTestRepo: PropTypes.bool,\n    t: PropTypes.func.isRequired,\n    checkBackendStatus: PropTypes.func.isRequired,\n  };\n\n  intervalId;\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(Header.propTypes, this.props, 'prop', 'Header');\n\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      logoUrl, // Deprecated, replaced by `logo.src`\n      logo,\n      isTestRepo,\n      t,\n      showMediaButton,\n    } = this.props;\n\n    const creatableCollections = collections\n      .filter(collection => collection.get('create'))\n      .toList();\n\n    const shouldShowLogo = logo?.show_in_header && logo?.src;\n\n    return (\n      <AppHeader>\n        <AppHeaderContent>\n          <nav>\n            <AppHeaderNavList>\n              {shouldShowLogo && (\n                <AppHeaderLogo>\n                  <img src={logo?.src || logoUrl} alt=\"Logo\" />\n                </AppHeaderLogo>\n              )}\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"]} */"));
57
57
  const AppHeaderNavList = /*#__PURE__*/_styled("ul", {
58
- target: "e1rbzf6g0",
58
+ target: "e1rbzf6g1",
59
59
  label: "AppHeaderNavList"
60
60
  })(process.env.NODE_ENV === "production" ? {
61
61
  name: "1vufzxm",
62
62
  styles: "display:flex;margin:0;list-style:none"
63
63
  } : {
64
64
  name: "1vufzxm",
65
- styles: "display:flex;margin:0;list-style:none/*# 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    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(Header.propTypes, this.props, 'prop', 'Header');\n\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"]} */",
65
+ styles: "display:flex;margin:0;list-style:none/*# 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\nconst AppHeaderLogo = styled.li`\n  display: flex;\n  align-items: center;\n\n  img {\n    padding: 12px 20px;\n    max-height: 56px;\n    max-width: 300px;\n    object-fit: contain;\n    object-position: center;\n  }\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    logoUrl: PropTypes.string, // Deprecated, replaced by `logo.src`\n    logo: PropTypes.shape({\n      src: PropTypes.string.isRequired,\n      show_in_header: PropTypes.bool,\n    }),\n    isTestRepo: PropTypes.bool,\n    t: PropTypes.func.isRequired,\n    checkBackendStatus: PropTypes.func.isRequired,\n  };\n\n  intervalId;\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(Header.propTypes, this.props, 'prop', 'Header');\n\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      logoUrl, // Deprecated, replaced by `logo.src`\n      logo,\n      isTestRepo,\n      t,\n      showMediaButton,\n    } = this.props;\n\n    const creatableCollections = collections\n      .filter(collection => collection.get('create'))\n      .toList();\n\n    const shouldShowLogo = logo?.show_in_header && logo?.src;\n\n    return (\n      <AppHeader>\n        <AppHeaderContent>\n          <nav>\n            <AppHeaderNavList>\n              {shouldShowLogo && (\n                <AppHeaderLogo>\n                  <img src={logo?.src || logoUrl} alt=\"Logo\" />\n                </AppHeaderLogo>\n              )}\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"]} */",
66
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
67
+ });
68
+ const AppHeaderLogo = /*#__PURE__*/_styled("li", {
69
+ target: "e1rbzf6g0",
70
+ label: "AppHeaderLogo"
71
+ })(process.env.NODE_ENV === "production" ? {
72
+ name: "d1300z",
73
+ styles: "display:flex;align-items:center;img{padding:12px 20px;max-height:56px;max-width:300px;object-fit:contain;object-position:center;}"
74
+ } : {
75
+ name: "d1300z",
76
+ styles: "display:flex;align-items:center;img{padding:12px 20px;max-height:56px;max-width:300px;object-fit:contain;object-position:center;}/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/App/Header.js"],"names":[],"mappings":"AAoH+B","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\nconst AppHeaderLogo = styled.li`\n  display: flex;\n  align-items: center;\n\n  img {\n    padding: 12px 20px;\n    max-height: 56px;\n    max-width: 300px;\n    object-fit: contain;\n    object-position: center;\n  }\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    logoUrl: PropTypes.string, // Deprecated, replaced by `logo.src`\n    logo: PropTypes.shape({\n      src: PropTypes.string.isRequired,\n      show_in_header: PropTypes.bool,\n    }),\n    isTestRepo: PropTypes.bool,\n    t: PropTypes.func.isRequired,\n    checkBackendStatus: PropTypes.func.isRequired,\n  };\n\n  intervalId;\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(Header.propTypes, this.props, 'prop', 'Header');\n\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      logoUrl, // Deprecated, replaced by `logo.src`\n      logo,\n      isTestRepo,\n      t,\n      showMediaButton,\n    } = this.props;\n\n    const creatableCollections = collections\n      .filter(collection => collection.get('create'))\n      .toList();\n\n    const shouldShowLogo = logo?.show_in_header && logo?.src;\n\n    return (\n      <AppHeader>\n        <AppHeaderContent>\n          <nav>\n            <AppHeaderNavList>\n              {shouldShowLogo && (\n                <AppHeaderLogo>\n                  <img src={logo?.src || logoUrl} alt=\"Logo\" />\n                </AppHeaderLogo>\n              )}\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"]} */",
66
77
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
67
78
  });
68
79
  class Header extends React.Component {
@@ -74,6 +85,12 @@ class Header extends React.Component {
74
85
  openMediaLibrary: PropTypes.func.isRequired,
75
86
  hasWorkflow: PropTypes.bool.isRequired,
76
87
  displayUrl: PropTypes.string,
88
+ logoUrl: PropTypes.string,
89
+ // Deprecated, replaced by `logo.src`
90
+ logo: PropTypes.shape({
91
+ src: PropTypes.string.isRequired,
92
+ show_in_header: PropTypes.bool
93
+ }),
77
94
  isTestRepo: PropTypes.bool,
78
95
  t: PropTypes.func.isRequired,
79
96
  checkBackendStatus: PropTypes.func.isRequired
@@ -105,12 +122,19 @@ class Header extends React.Component {
105
122
  openMediaLibrary,
106
123
  hasWorkflow,
107
124
  displayUrl,
125
+ logoUrl,
126
+ // Deprecated, replaced by `logo.src`
127
+ logo,
108
128
  isTestRepo,
109
129
  t,
110
130
  showMediaButton
111
131
  } = this.props;
112
132
  const creatableCollections = collections.filter(collection => collection.get('create')).toList();
113
- return ___EmotionJSX(AppHeader, null, ___EmotionJSX(AppHeaderContent, null, ___EmotionJSX("nav", null, ___EmotionJSX(AppHeaderNavList, null, ___EmotionJSX("li", null, ___EmotionJSX(AppHeaderNavLink, {
133
+ const shouldShowLogo = logo?.show_in_header && logo?.src;
134
+ return ___EmotionJSX(AppHeader, null, ___EmotionJSX(AppHeaderContent, null, ___EmotionJSX("nav", null, ___EmotionJSX(AppHeaderNavList, null, shouldShowLogo && ___EmotionJSX(AppHeaderLogo, null, ___EmotionJSX("img", {
135
+ src: logo?.src || logoUrl,
136
+ alt: "Logo"
137
+ })), ___EmotionJSX("li", null, ___EmotionJSX(AppHeaderNavLink, {
114
138
  to: "/",
115
139
  activeClassName: "header-link-active",
116
140
  isActive: (match, location) => location.pathname.startsWith('/collections/')
@@ -10,7 +10,7 @@ import { jsx as ___EmotionJSX } from "@emotion/react";
10
10
  const PaginationMessage = /*#__PURE__*/_styled("div", {
11
11
  target: "e1d0i3na1",
12
12
  label: "PaginationMessage"
13
- })("width:", lengths.topCardWidth, ";padding:16px;text-align:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vRW50cmllcy9FbnRyaWVzLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVNvQyIsImZpbGUiOiIuLi8uLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9Db2xsZWN0aW9uL0VudHJpZXMvRW50cmllcy5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IEltbXV0YWJsZVByb3BUeXBlcyBmcm9tICdyZWFjdC1pbW11dGFibGUtcHJvcHR5cGVzJztcbmltcG9ydCB7IHRyYW5zbGF0ZSB9IGZyb20gJ3JlYWN0LXBvbHlnbG90JztcbmltcG9ydCB7IExvYWRlciwgbGVuZ3RocyB9IGZyb20gJ2RlY2FwLWNtcy11aS1kZWZhdWx0JztcblxuaW1wb3J0IEVudHJ5TGlzdGluZyBmcm9tICcuL0VudHJ5TGlzdGluZyc7XG5cbmNvbnN0IFBhZ2luYXRpb25NZXNzYWdlID0gc3R5bGVkLmRpdmBcbiAgd2lkdGg6ICR7bGVuZ3Rocy50b3BDYXJkV2lkdGh9O1xuICBwYWRkaW5nOiAxNnB4O1xuICB0ZXh0LWFsaWduOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBOb0VudHJpZXNNZXNzYWdlID0gc3R5bGVkKFBhZ2luYXRpb25NZXNzYWdlKWBcbiAgbWFyZ2luLXRvcDogMTZweDtcbmA7XG5cbmZ1bmN0aW9uIEVudHJpZXMoe1xuICBjb2xsZWN0aW9ucyxcbiAgZW50cmllcyxcbiAgaXNGZXRjaGluZyxcbiAgdmlld1N0eWxlLFxuICBjdXJzb3IsXG4gIGhhbmRsZUN1cnNvckFjdGlvbnMsXG4gIHQsXG4gIHBhZ2UsXG59KSB7XG4gIGNvbnN0IGxvYWRpbmdNZXNzYWdlcyA9IFtcbiAgICB0KCdjb2xsZWN0aW9uLmVudHJpZXMubG9hZGluZ0VudHJpZXMnKSxcbiAgICB0KCdjb2xsZWN0aW9uLmVudHJpZXMuY2FjaGluZ0VudHJpZXMnKSxcbiAgICB0KCdjb2xsZWN0aW9uLmVudHJpZXMubG9uZ2VyTG9hZGluZycpLFxuICBdO1xuXG4gIGlmIChpc0ZldGNoaW5nICYmIHBhZ2UgPT09IHVuZGVmaW5lZCkge1xuICAgIHJldHVybiA8TG9hZGVyIGFjdGl2ZT57bG9hZGluZ01lc3NhZ2VzfTwvTG9hZGVyPjtcbiAgfVxuXG4gIGNvbnN0IGhhc0VudHJpZXMgPSAoZW50cmllcyAmJiBlbnRyaWVzLnNpemUgPiAwKSB8fCBjdXJzb3I/LmFjdGlvbnM/LmhhcygnYXBwZW5kX25leHQnKTtcbiAgaWYgKGhhc0VudHJpZXMpIHtcbiAgICByZXR1cm4gKFxuICAgICAgPD5cbiAgICAgICAgPEVudHJ5TGlzdGluZ1xuICAgICAgICAgIGNvbGxlY3Rpb25zPXtjb2xsZWN0aW9uc31cbiAgICAgICAgICBlbnRyaWVzPXtlbnRyaWVzfVxuICAgICAgICAgIHZpZXdTdHlsZT17dmlld1N0eWxlfVxuICAgICAgICAgIGN1cnNvcj17Y3Vyc29yfVxuICAgICAgICAgIGhhbmRsZUN1cnNvckFjdGlvbnM9e2hhbmRsZUN1cnNvckFjdGlvbnN9XG4gICAgICAgICAgcGFnZT17cGFnZX1cbiAgICAgICAgLz5cbiAgICAgICAge2lzRmV0Y2hpbmcgJiYgcGFnZSAhPT0gdW5kZWZpbmVkICYmIGVudHJpZXMuc2l6ZSA+IDAgPyAoXG4gICAgICAgICAgPFBhZ2luYXRpb25NZXNzYWdlPnt0KCdjb2xsZWN0aW9uLmVudHJpZXMubG9hZGluZ0VudHJpZXMnKX08L1BhZ2luYXRpb25NZXNzYWdlPlxuICAgICAgICApIDogbnVsbH1cbiAgICAgIDwvPlxuICAgICk7XG4gIH1cblxuICByZXR1cm4gPE5vRW50cmllc01lc3NhZ2U+e3QoJ2NvbGxlY3Rpb24uZW50cmllcy5ub0VudHJpZXMnKX08L05vRW50cmllc01lc3NhZ2U+O1xufVxuXG5FbnRyaWVzLnByb3BUeXBlcyA9IHtcbiAgY29sbGVjdGlvbnM6IEltbXV0YWJsZVByb3BUeXBlcy5pdGVyYWJsZS5pc1JlcXVpcmVkLFxuICBlbnRyaWVzOiBJbW11dGFibGVQcm9wVHlwZXMubGlzdCxcbiAgcGFnZTogUHJvcFR5cGVzLm51bWJlcixcbiAgaXNGZXRjaGluZzogUHJvcFR5cGVzLmJvb2wsXG4gIHZpZXdTdHlsZTogUHJvcFR5cGVzLnN0cmluZyxcbiAgY3Vyc29yOiBQcm9wVHlwZXMuYW55LmlzUmVxdWlyZWQsXG4gIGhhbmRsZUN1cnNvckFjdGlvbnM6IFByb3BUeXBlcy5mdW5jLmlzUmVxdWlyZWQsXG4gIHQ6IFByb3BUeXBlcy5mdW5jLmlzUmVxdWlyZWQsXG59O1xuXG5leHBvcnQgZGVmYXVsdCB0cmFuc2xhdGUoKShFbnRyaWVzKTtcbiJdfQ== */"));
13
+ })("width:", lengths.topCardWidth, ";padding:16px;text-align:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vRW50cmllcy9FbnRyaWVzLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVNvQyIsImZpbGUiOiIuLi8uLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9Db2xsZWN0aW9uL0VudHJpZXMvRW50cmllcy5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IEltbXV0YWJsZVByb3BUeXBlcyBmcm9tICdyZWFjdC1pbW11dGFibGUtcHJvcHR5cGVzJztcbmltcG9ydCB7IHRyYW5zbGF0ZSB9IGZyb20gJ3JlYWN0LXBvbHlnbG90JztcbmltcG9ydCB7IExvYWRlciwgbGVuZ3RocyB9IGZyb20gJ2RlY2FwLWNtcy11aS1kZWZhdWx0JztcblxuaW1wb3J0IEVudHJ5TGlzdGluZyBmcm9tICcuL0VudHJ5TGlzdGluZyc7XG5cbmNvbnN0IFBhZ2luYXRpb25NZXNzYWdlID0gc3R5bGVkLmRpdmBcbiAgd2lkdGg6ICR7bGVuZ3Rocy50b3BDYXJkV2lkdGh9O1xuICBwYWRkaW5nOiAxNnB4O1xuICB0ZXh0LWFsaWduOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBOb0VudHJpZXNNZXNzYWdlID0gc3R5bGVkKFBhZ2luYXRpb25NZXNzYWdlKWBcbiAgbWFyZ2luLXRvcDogMTZweDtcbmA7XG5cbmZ1bmN0aW9uIEVudHJpZXMoe1xuICBjb2xsZWN0aW9ucyxcbiAgZW50cmllcyxcbiAgaXNGZXRjaGluZyxcbiAgdmlld1N0eWxlLFxuICBjdXJzb3IsXG4gIGhhbmRsZUN1cnNvckFjdGlvbnMsXG4gIHQsXG4gIHBhZ2UsXG4gIGdldFdvcmtmbG93U3RhdHVzLFxuICBnZXRVbnB1Ymxpc2hlZEVudHJpZXMsXG4gIGZpbHRlclRlcm0sXG59KSB7XG4gIGNvbnN0IGxvYWRpbmdNZXNzYWdlcyA9IFtcbiAgICB0KCdjb2xsZWN0aW9uLmVudHJpZXMubG9hZGluZ0VudHJpZXMnKSxcbiAgICB0KCdjb2xsZWN0aW9uLmVudHJpZXMuY2FjaGluZ0VudHJpZXMnKSxcbiAgICB0KCdjb2xsZWN0aW9uLmVudHJpZXMubG9uZ2VyTG9hZGluZycpLFxuICBdO1xuXG4gIGlmIChpc0ZldGNoaW5nICYmIHBhZ2UgPT09IHVuZGVmaW5lZCkge1xuICAgIHJldHVybiA8TG9hZGVyIGFjdGl2ZT57bG9hZGluZ01lc3NhZ2VzfTwvTG9hZGVyPjtcbiAgfVxuXG4gIGNvbnN0IGhhc0VudHJpZXMgPSAoZW50cmllcyAmJiBlbnRyaWVzLnNpemUgPiAwKSB8fCBjdXJzb3I/LmFjdGlvbnM/LmhhcygnYXBwZW5kX25leHQnKTtcbiAgaWYgKGhhc0VudHJpZXMpIHtcbiAgICByZXR1cm4gKFxuICAgICAgPD5cbiAgICAgICAgPEVudHJ5TGlzdGluZ1xuICAgICAgICAgIGNvbGxlY3Rpb25zPXtjb2xsZWN0aW9uc31cbiAgICAgICAgICBlbnRyaWVzPXtlbnRyaWVzfVxuICAgICAgICAgIHZpZXdTdHlsZT17dmlld1N0eWxlfVxuICAgICAgICAgIGN1cnNvcj17Y3Vyc29yfVxuICAgICAgICAgIGhhbmRsZUN1cnNvckFjdGlvbnM9e2hhbmRsZUN1cnNvckFjdGlvbnN9XG4gICAgICAgICAgcGFnZT17cGFnZX1cbiAgICAgICAgICBnZXRXb3JrZmxvd1N0YXR1cz17Z2V0V29ya2Zsb3dTdGF0dXN9XG4gICAgICAgICAgZ2V0VW5wdWJsaXNoZWRFbnRyaWVzPXtnZXRVbnB1Ymxpc2hlZEVudHJpZXN9XG4gICAgICAgICAgZmlsdGVyVGVybT17ZmlsdGVyVGVybX1cbiAgICAgICAgLz5cbiAgICAgICAge2lzRmV0Y2hpbmcgJiYgcGFnZSAhPT0gdW5kZWZpbmVkICYmIGVudHJpZXMuc2l6ZSA+IDAgPyAoXG4gICAgICAgICAgPFBhZ2luYXRpb25NZXNzYWdlPnt0KCdjb2xsZWN0aW9uLmVudHJpZXMubG9hZGluZ0VudHJpZXMnKX08L1BhZ2luYXRpb25NZXNzYWdlPlxuICAgICAgICApIDogbnVsbH1cbiAgICAgIDwvPlxuICAgICk7XG4gIH1cblxuICByZXR1cm4gPE5vRW50cmllc01lc3NhZ2U+e3QoJ2NvbGxlY3Rpb24uZW50cmllcy5ub0VudHJpZXMnKX08L05vRW50cmllc01lc3NhZ2U+O1xufVxuXG5FbnRyaWVzLnByb3BUeXBlcyA9IHtcbiAgY29sbGVjdGlvbnM6IEltbXV0YWJsZVByb3BUeXBlcy5pdGVyYWJsZS5pc1JlcXVpcmVkLFxuICBlbnRyaWVzOiBJbW11dGFibGVQcm9wVHlwZXMubGlzdCxcbiAgcGFnZTogUHJvcFR5cGVzLm51bWJlcixcbiAgaXNGZXRjaGluZzogUHJvcFR5cGVzLmJvb2wsXG4gIHZpZXdTdHlsZTogUHJvcFR5cGVzLnN0cmluZyxcbiAgY3Vyc29yOiBQcm9wVHlwZXMuYW55LmlzUmVxdWlyZWQsXG4gIGhhbmRsZUN1cnNvckFjdGlvbnM6IFByb3BUeXBlcy5mdW5jLmlzUmVxdWlyZWQsXG4gIHQ6IFByb3BUeXBlcy5mdW5jLmlzUmVxdWlyZWQsXG4gIGdldFdvcmtmbG93U3RhdHVzOiBQcm9wVHlwZXMuZnVuYyxcbiAgZ2V0VW5wdWJsaXNoZWRFbnRyaWVzOiBQcm9wVHlwZXMuZnVuYyxcbiAgZmlsdGVyVGVybTogUHJvcFR5cGVzLnN0cmluZyxcbn07XG5cbmV4cG9ydCBkZWZhdWx0IHRyYW5zbGF0ZSgpKEVudHJpZXMpO1xuIl19 */"));
14
14
  const NoEntriesMessage = /*#__PURE__*/_styled(PaginationMessage, {
15
15
  target: "e1d0i3na0",
16
16
  label: "NoEntriesMessage"
@@ -19,7 +19,7 @@ const NoEntriesMessage = /*#__PURE__*/_styled(PaginationMessage, {
19
19
  styles: "margin-top:16px"
20
20
  } : {
21
21
  name: "yz1nei",
22
- styles: "margin-top:16px/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vRW50cmllcy9FbnRyaWVzLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWVrRCIsImZpbGUiOiIuLi8uLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9Db2xsZWN0aW9uL0VudHJpZXMvRW50cmllcy5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IEltbXV0YWJsZVByb3BUeXBlcyBmcm9tICdyZWFjdC1pbW11dGFibGUtcHJvcHR5cGVzJztcbmltcG9ydCB7IHRyYW5zbGF0ZSB9IGZyb20gJ3JlYWN0LXBvbHlnbG90JztcbmltcG9ydCB7IExvYWRlciwgbGVuZ3RocyB9IGZyb20gJ2RlY2FwLWNtcy11aS1kZWZhdWx0JztcblxuaW1wb3J0IEVudHJ5TGlzdGluZyBmcm9tICcuL0VudHJ5TGlzdGluZyc7XG5cbmNvbnN0IFBhZ2luYXRpb25NZXNzYWdlID0gc3R5bGVkLmRpdmBcbiAgd2lkdGg6ICR7bGVuZ3Rocy50b3BDYXJkV2lkdGh9O1xuICBwYWRkaW5nOiAxNnB4O1xuICB0ZXh0LWFsaWduOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBOb0VudHJpZXNNZXNzYWdlID0gc3R5bGVkKFBhZ2luYXRpb25NZXNzYWdlKWBcbiAgbWFyZ2luLXRvcDogMTZweDtcbmA7XG5cbmZ1bmN0aW9uIEVudHJpZXMoe1xuICBjb2xsZWN0aW9ucyxcbiAgZW50cmllcyxcbiAgaXNGZXRjaGluZyxcbiAgdmlld1N0eWxlLFxuICBjdXJzb3IsXG4gIGhhbmRsZUN1cnNvckFjdGlvbnMsXG4gIHQsXG4gIHBhZ2UsXG59KSB7XG4gIGNvbnN0IGxvYWRpbmdNZXNzYWdlcyA9IFtcbiAgICB0KCdjb2xsZWN0aW9uLmVudHJpZXMubG9hZGluZ0VudHJpZXMnKSxcbiAgICB0KCdjb2xsZWN0aW9uLmVudHJpZXMuY2FjaGluZ0VudHJpZXMnKSxcbiAgICB0KCdjb2xsZWN0aW9uLmVudHJpZXMubG9uZ2VyTG9hZGluZycpLFxuICBdO1xuXG4gIGlmIChpc0ZldGNoaW5nICYmIHBhZ2UgPT09IHVuZGVmaW5lZCkge1xuICAgIHJldHVybiA8TG9hZGVyIGFjdGl2ZT57bG9hZGluZ01lc3NhZ2VzfTwvTG9hZGVyPjtcbiAgfVxuXG4gIGNvbnN0IGhhc0VudHJpZXMgPSAoZW50cmllcyAmJiBlbnRyaWVzLnNpemUgPiAwKSB8fCBjdXJzb3I/LmFjdGlvbnM/LmhhcygnYXBwZW5kX25leHQnKTtcbiAgaWYgKGhhc0VudHJpZXMpIHtcbiAgICByZXR1cm4gKFxuICAgICAgPD5cbiAgICAgICAgPEVudHJ5TGlzdGluZ1xuICAgICAgICAgIGNvbGxlY3Rpb25zPXtjb2xsZWN0aW9uc31cbiAgICAgICAgICBlbnRyaWVzPXtlbnRyaWVzfVxuICAgICAgICAgIHZpZXdTdHlsZT17dmlld1N0eWxlfVxuICAgICAgICAgIGN1cnNvcj17Y3Vyc29yfVxuICAgICAgICAgIGhhbmRsZUN1cnNvckFjdGlvbnM9e2hhbmRsZUN1cnNvckFjdGlvbnN9XG4gICAgICAgICAgcGFnZT17cGFnZX1cbiAgICAgICAgLz5cbiAgICAgICAge2lzRmV0Y2hpbmcgJiYgcGFnZSAhPT0gdW5kZWZpbmVkICYmIGVudHJpZXMuc2l6ZSA+IDAgPyAoXG4gICAgICAgICAgPFBhZ2luYXRpb25NZXNzYWdlPnt0KCdjb2xsZWN0aW9uLmVudHJpZXMubG9hZGluZ0VudHJpZXMnKX08L1BhZ2luYXRpb25NZXNzYWdlPlxuICAgICAgICApIDogbnVsbH1cbiAgICAgIDwvPlxuICAgICk7XG4gIH1cblxuICByZXR1cm4gPE5vRW50cmllc01lc3NhZ2U+e3QoJ2NvbGxlY3Rpb24uZW50cmllcy5ub0VudHJpZXMnKX08L05vRW50cmllc01lc3NhZ2U+O1xufVxuXG5FbnRyaWVzLnByb3BUeXBlcyA9IHtcbiAgY29sbGVjdGlvbnM6IEltbXV0YWJsZVByb3BUeXBlcy5pdGVyYWJsZS5pc1JlcXVpcmVkLFxuICBlbnRyaWVzOiBJbW11dGFibGVQcm9wVHlwZXMubGlzdCxcbiAgcGFnZTogUHJvcFR5cGVzLm51bWJlcixcbiAgaXNGZXRjaGluZzogUHJvcFR5cGVzLmJvb2wsXG4gIHZpZXdTdHlsZTogUHJvcFR5cGVzLnN0cmluZyxcbiAgY3Vyc29yOiBQcm9wVHlwZXMuYW55LmlzUmVxdWlyZWQsXG4gIGhhbmRsZUN1cnNvckFjdGlvbnM6IFByb3BUeXBlcy5mdW5jLmlzUmVxdWlyZWQsXG4gIHQ6IFByb3BUeXBlcy5mdW5jLmlzUmVxdWlyZWQsXG59O1xuXG5leHBvcnQgZGVmYXVsdCB0cmFuc2xhdGUoKShFbnRyaWVzKTtcbiJdfQ== */",
22
+ styles: "margin-top:16px/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vRW50cmllcy9FbnRyaWVzLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWVrRCIsImZpbGUiOiIuLi8uLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9Db2xsZWN0aW9uL0VudHJpZXMvRW50cmllcy5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IEltbXV0YWJsZVByb3BUeXBlcyBmcm9tICdyZWFjdC1pbW11dGFibGUtcHJvcHR5cGVzJztcbmltcG9ydCB7IHRyYW5zbGF0ZSB9IGZyb20gJ3JlYWN0LXBvbHlnbG90JztcbmltcG9ydCB7IExvYWRlciwgbGVuZ3RocyB9IGZyb20gJ2RlY2FwLWNtcy11aS1kZWZhdWx0JztcblxuaW1wb3J0IEVudHJ5TGlzdGluZyBmcm9tICcuL0VudHJ5TGlzdGluZyc7XG5cbmNvbnN0IFBhZ2luYXRpb25NZXNzYWdlID0gc3R5bGVkLmRpdmBcbiAgd2lkdGg6ICR7bGVuZ3Rocy50b3BDYXJkV2lkdGh9O1xuICBwYWRkaW5nOiAxNnB4O1xuICB0ZXh0LWFsaWduOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBOb0VudHJpZXNNZXNzYWdlID0gc3R5bGVkKFBhZ2luYXRpb25NZXNzYWdlKWBcbiAgbWFyZ2luLXRvcDogMTZweDtcbmA7XG5cbmZ1bmN0aW9uIEVudHJpZXMoe1xuICBjb2xsZWN0aW9ucyxcbiAgZW50cmllcyxcbiAgaXNGZXRjaGluZyxcbiAgdmlld1N0eWxlLFxuICBjdXJzb3IsXG4gIGhhbmRsZUN1cnNvckFjdGlvbnMsXG4gIHQsXG4gIHBhZ2UsXG4gIGdldFdvcmtmbG93U3RhdHVzLFxuICBnZXRVbnB1Ymxpc2hlZEVudHJpZXMsXG4gIGZpbHRlclRlcm0sXG59KSB7XG4gIGNvbnN0IGxvYWRpbmdNZXNzYWdlcyA9IFtcbiAgICB0KCdjb2xsZWN0aW9uLmVudHJpZXMubG9hZGluZ0VudHJpZXMnKSxcbiAgICB0KCdjb2xsZWN0aW9uLmVudHJpZXMuY2FjaGluZ0VudHJpZXMnKSxcbiAgICB0KCdjb2xsZWN0aW9uLmVudHJpZXMubG9uZ2VyTG9hZGluZycpLFxuICBdO1xuXG4gIGlmIChpc0ZldGNoaW5nICYmIHBhZ2UgPT09IHVuZGVmaW5lZCkge1xuICAgIHJldHVybiA8TG9hZGVyIGFjdGl2ZT57bG9hZGluZ01lc3NhZ2VzfTwvTG9hZGVyPjtcbiAgfVxuXG4gIGNvbnN0IGhhc0VudHJpZXMgPSAoZW50cmllcyAmJiBlbnRyaWVzLnNpemUgPiAwKSB8fCBjdXJzb3I/LmFjdGlvbnM/LmhhcygnYXBwZW5kX25leHQnKTtcbiAgaWYgKGhhc0VudHJpZXMpIHtcbiAgICByZXR1cm4gKFxuICAgICAgPD5cbiAgICAgICAgPEVudHJ5TGlzdGluZ1xuICAgICAgICAgIGNvbGxlY3Rpb25zPXtjb2xsZWN0aW9uc31cbiAgICAgICAgICBlbnRyaWVzPXtlbnRyaWVzfVxuICAgICAgICAgIHZpZXdTdHlsZT17dmlld1N0eWxlfVxuICAgICAgICAgIGN1cnNvcj17Y3Vyc29yfVxuICAgICAgICAgIGhhbmRsZUN1cnNvckFjdGlvbnM9e2hhbmRsZUN1cnNvckFjdGlvbnN9XG4gICAgICAgICAgcGFnZT17cGFnZX1cbiAgICAgICAgICBnZXRXb3JrZmxvd1N0YXR1cz17Z2V0V29ya2Zsb3dTdGF0dXN9XG4gICAgICAgICAgZ2V0VW5wdWJsaXNoZWRFbnRyaWVzPXtnZXRVbnB1Ymxpc2hlZEVudHJpZXN9XG4gICAgICAgICAgZmlsdGVyVGVybT17ZmlsdGVyVGVybX1cbiAgICAgICAgLz5cbiAgICAgICAge2lzRmV0Y2hpbmcgJiYgcGFnZSAhPT0gdW5kZWZpbmVkICYmIGVudHJpZXMuc2l6ZSA+IDAgPyAoXG4gICAgICAgICAgPFBhZ2luYXRpb25NZXNzYWdlPnt0KCdjb2xsZWN0aW9uLmVudHJpZXMubG9hZGluZ0VudHJpZXMnKX08L1BhZ2luYXRpb25NZXNzYWdlPlxuICAgICAgICApIDogbnVsbH1cbiAgICAgIDwvPlxuICAgICk7XG4gIH1cblxuICByZXR1cm4gPE5vRW50cmllc01lc3NhZ2U+e3QoJ2NvbGxlY3Rpb24uZW50cmllcy5ub0VudHJpZXMnKX08L05vRW50cmllc01lc3NhZ2U+O1xufVxuXG5FbnRyaWVzLnByb3BUeXBlcyA9IHtcbiAgY29sbGVjdGlvbnM6IEltbXV0YWJsZVByb3BUeXBlcy5pdGVyYWJsZS5pc1JlcXVpcmVkLFxuICBlbnRyaWVzOiBJbW11dGFibGVQcm9wVHlwZXMubGlzdCxcbiAgcGFnZTogUHJvcFR5cGVzLm51bWJlcixcbiAgaXNGZXRjaGluZzogUHJvcFR5cGVzLmJvb2wsXG4gIHZpZXdTdHlsZTogUHJvcFR5cGVzLnN0cmluZyxcbiAgY3Vyc29yOiBQcm9wVHlwZXMuYW55LmlzUmVxdWlyZWQsXG4gIGhhbmRsZUN1cnNvckFjdGlvbnM6IFByb3BUeXBlcy5mdW5jLmlzUmVxdWlyZWQsXG4gIHQ6IFByb3BUeXBlcy5mdW5jLmlzUmVxdWlyZWQsXG4gIGdldFdvcmtmbG93U3RhdHVzOiBQcm9wVHlwZXMuZnVuYyxcbiAgZ2V0VW5wdWJsaXNoZWRFbnRyaWVzOiBQcm9wVHlwZXMuZnVuYyxcbiAgZmlsdGVyVGVybTogUHJvcFR5cGVzLnN0cmluZyxcbn07XG5cbmV4cG9ydCBkZWZhdWx0IHRyYW5zbGF0ZSgpKEVudHJpZXMpO1xuIl19 */",
23
23
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
24
24
  });
25
25
  function Entries({
@@ -30,7 +30,10 @@ function Entries({
30
30
  cursor,
31
31
  handleCursorActions,
32
32
  t,
33
- page
33
+ page,
34
+ getWorkflowStatus,
35
+ getUnpublishedEntries,
36
+ filterTerm
34
37
  }) {
35
38
  const loadingMessages = [t('collection.entries.loadingEntries'), t('collection.entries.cachingEntries'), t('collection.entries.longerLoading')];
36
39
  if (isFetching && page === undefined) {
@@ -46,7 +49,10 @@ function Entries({
46
49
  viewStyle: viewStyle,
47
50
  cursor: cursor,
48
51
  handleCursorActions: handleCursorActions,
49
- page: page
52
+ page: page,
53
+ getWorkflowStatus: getWorkflowStatus,
54
+ getUnpublishedEntries: getUnpublishedEntries,
55
+ filterTerm: filterTerm
50
56
  }), isFetching && page !== undefined && entries.size > 0 ? ___EmotionJSX(PaginationMessage, null, t('collection.entries.loadingEntries')) : null);
51
57
  }
52
58
  return ___EmotionJSX(NoEntriesMessage, null, t('collection.entries.noEntries'));
@@ -59,6 +65,9 @@ Entries.propTypes = {
59
65
  viewStyle: PropTypes.string,
60
66
  cursor: PropTypes.any.isRequired,
61
67
  handleCursorActions: PropTypes.func.isRequired,
62
- t: PropTypes.func.isRequired
68
+ t: PropTypes.func.isRequired,
69
+ getWorkflowStatus: PropTypes.func,
70
+ getUnpublishedEntries: PropTypes.func,
71
+ filterTerm: PropTypes.string
63
72
  };
64
73
  export default translate()(Entries);