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.
- package/dist/decap-cms-core.js +26 -26
- package/dist/decap-cms-core.js.LICENSE.txt +0 -12
- package/dist/decap-cms-core.js.map +1 -1
- package/dist/esm/bootstrap.js +3 -2
- package/dist/esm/components/App/App.js +6 -3
- package/dist/esm/components/App/Header.js +38 -14
- package/dist/esm/components/Collection/Entries/Entries.js +14 -5
- package/dist/esm/components/Collection/Entries/EntriesCollection.js +65 -9
- package/dist/esm/components/Collection/Entries/EntryCard.js +84 -28
- package/dist/esm/components/Collection/Entries/EntryListing.js +46 -11
- package/dist/esm/components/UI/ErrorBoundary.js +2 -2
- package/dist/esm/constants/configSchema.js +14 -0
- package/dist/esm/formats/toml.js +2 -2
- package/dist/esm/lib/i18n.js +16 -0
- package/dist/esm/lib/polyfill.js +8 -0
- package/index.d.ts +5 -1
- package/package.json +8 -2
- package/src/bootstrap.js +1 -0
- package/src/components/App/App.js +2 -0
- package/src/components/App/Header.js +27 -0
- package/src/components/Collection/Entries/Entries.js +9 -0
- package/src/components/Collection/Entries/EntriesCollection.js +100 -4
- package/src/components/Collection/Entries/EntryCard.js +82 -3
- package/src/components/Collection/Entries/EntryListing.js +65 -5
- package/src/components/Collection/Entries/__tests__/EntriesCollection.spec.js +26 -18
- package/src/components/Collection/Entries/__tests__/__snapshots__/EntriesCollection.spec.js.snap +1 -0
- package/src/constants/configSchema.js +9 -1
- package/src/formats/toml.ts +2 -2
- package/src/lib/i18n.ts +21 -0
- package/src/lib/polyfill.js +9 -0
- 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,
|
|
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0FwcC9IZWFkZXIuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0NjIiwiZmlsZSI6Ii4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0FwcC9IZWFkZXIuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBJbW11dGFibGVQcm9wVHlwZXMgZnJvbSAncmVhY3QtaW1tdXRhYmxlLXByb3B0eXBlcyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgeyB0cmFuc2xhdGUgfSBmcm9tICdyZWFjdC1wb2x5Z2xvdCc7XG5pbXBvcnQgeyBOYXZMaW5rIH0gZnJvbSAncmVhY3Qtcm91dGVyLWRvbSc7XG5pbXBvcnQge1xuICBJY29uLFxuICBEcm9wZG93bixcbiAgRHJvcGRvd25JdGVtLFxuICBTdHlsZWREcm9wZG93bkJ1dHRvbixcbiAgY29sb3JzLFxuICBsZW5ndGhzLFxuICBzaGFkb3dzLFxuICBidXR0b25zLFxuICB6SW5kZXgsXG59IGZyb20gJ2RlY2FwLWNtcy11aS1kZWZhdWx0JztcbmltcG9ydCB7IGNvbm5lY3QgfSBmcm9tICdyZWFjdC1yZWR1eCc7XG5cbmltcG9ydCB7IFNldHRpbmdzRHJvcGRvd24gfSBmcm9tICcuLi9VSSc7XG5pbXBvcnQgeyBjaGVja0JhY2tlbmRTdGF0dXMgfSBmcm9tICcuLi8uLi9hY3Rpb25zL3N0YXR1cyc7XG5cbmNvbnN0IHN0eWxlcyA9IHtcbiAgYnV0dG9uQWN0aXZlOiBjc3NgXG4gICAgY29sb3I6ICR7Y29sb3JzLmFjdGl2ZX07XG4gIGAsXG59O1xuXG5mdW5jdGlvbiBBcHBIZWFkZXIocHJvcHMpIHtcbiAgcmV0dXJuIChcbiAgICA8aGVhZGVyXG4gICAgICBjc3M9e2Nzc2BcbiAgICAgICAgJHtzaGFkb3dzLmRyb3BNYWlufTtcbiAgICAgICAgcG9zaXRpb246IHN0aWNreTtcbiAgICAgICAgd2lkdGg6IDEwMCU7XG4gICAgICAgIHRvcDogMDtcbiAgICAgICAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuZm9yZWdyb3VuZH07XG4gICAgICAgIHotaW5kZXg6ICR7ekluZGV4LnpJbmRleDMwMH07XG4gICAgICAgIGhlaWdodDogJHtsZW5ndGhzLnRvcEJhckhlaWdodH07XG4gICAgICBgfVxuICAgICAgey4uLnByb3BzfVxuICAgIC8+XG4gICk7XG59XG5cbmNvbnN0IEFwcEhlYWRlckNvbnRlbnQgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG4gIG1pbi13aWR0aDogODAwcHg7XG4gIG1heC13aWR0aDogMTQ0MHB4O1xuICBwYWRkaW5nOiAwIDEycHg7XG4gIG1hcmdpbjogMCBhdXRvO1xuYDtcblxuY29uc3QgQXBwSGVhZGVyQnV0dG9uID0gc3R5bGVkLmJ1dHRvbmBcbiAgJHtidXR0b25zLmJ1dHRvbn07XG4gIGJhY2tncm91bmQ6IG5vbmU7XG4gIGNvbG9yOiAjN2I4MjkwO1xuICBmb250LWZhbWlseTogaW5oZXJpdDtcbiAgZm9udC1zaXplOiAxNnB4O1xuICBmb250LXdlaWdodDogNTAwO1xuICBkaXNwbGF5OiBpbmxpbmUtZmxleDtcbiAgcGFkZGluZzogMTZweCAyMHB4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuXG4gICR7SWNvbn0ge1xuICAgIG1hcmdpbi1yaWdodDogNHB4O1xuICAgIGNvbG9yOiAjYjNiOWM0O1xuICB9XG5cbiAgJjpob3ZlcixcbiAgJjphY3RpdmUsXG4gICY6Zm9jdXMtdmlzaWJsZSB7XG4gICAgJHtzdHlsZXMuYnV0dG9uQWN0aXZlfTtcblxuICAgICR7SWNvbn0ge1xuICAgICAgJHtzdHlsZXMuYnV0dG9uQWN0aXZlfTtcbiAgICB9XG4gIH1cblxuICAke3Byb3BzID0+
|
|
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: "
|
|
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,
|
|
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: "
|
|
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: "
|
|
39
|
+
target: "e1rbzf6g6",
|
|
40
40
|
label: "AppHeaderNavLink"
|
|
41
41
|
});
|
|
42
42
|
const AppHeaderActions = /*#__PURE__*/_styled("div", {
|
|
43
|
-
target: "
|
|
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,
|
|
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: "
|
|
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,
|
|
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: "
|
|
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,
|
|
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
|
-
|
|
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,
|
|
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,
|
|
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);
|