decap-cms-core 3.2.6 → 3.3.0-beta.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.
@@ -5,7 +5,7 @@ Object.defineProperty(exports, "__esModule", {
5
5
  });
6
6
  exports.default = void 0;
7
7
  var _react = _interopRequireDefault(require("react"));
8
- var _reactDom = require("react-dom");
8
+ var _client = require("react-dom/client");
9
9
  var _reactRedux = require("react-redux");
10
10
  var _reactRouterDom = require("react-router-dom");
11
11
  var _decapCmsUiDefault = require("decap-cms-ui-default");
@@ -55,8 +55,8 @@ function bootstrap(opts = {}) {
55
55
  /**
56
56
  * Log the version number.
57
57
  */
58
- if (typeof "3.2.6" === 'string') {
59
- console.log(`decap-cms-core ${"3.2.6"}`);
58
+ if (typeof "3.3.0-beta.0" === 'string') {
59
+ console.log(`decap-cms-core ${"3.3.0-beta.0"}`);
60
60
  }
61
61
 
62
62
  /**
@@ -101,6 +101,7 @@ function bootstrap(opts = {}) {
101
101
  /**
102
102
  * Render application root.
103
103
  */
104
- (0, _reactDom.render)((0, _react2.jsx)(Root, null), getRoot());
104
+ const root = (0, _client.createRoot)(getRoot());
105
+ root.render((0, _react2.jsx)(Root, null));
105
106
  }
106
107
  var _default = exports.default = bootstrap;
@@ -7,7 +7,6 @@ exports.default = void 0;
7
7
  var _base = _interopRequireDefault(require("@emotion/styled/base"));
8
8
  var _propTypes = _interopRequireDefault(require("prop-types"));
9
9
  var _react = _interopRequireDefault(require("react"));
10
- var _reactHotLoader = require("react-hot-loader");
11
10
  var _reactPolyglot = require("react-polyglot");
12
11
  var _reactImmutableProptypes = _interopRequireDefault(require("react-immutable-proptypes"));
13
12
  var _reactRedux = require("react-redux");
@@ -54,7 +53,7 @@ const AppMainContainer = /*#__PURE__*/(0, _base.default)("div", {
54
53
  } : {
55
54
  name: "y0stlg",
56
55
  styles: "min-width:800px;max-width:1440px;margin:0 auto",
57
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/App/App.js"],"names":[],"mappings":"AAkCmC","file":"../../../../src/components/App/App.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React from 'react';\nimport { hot } from 'react-hot-loader';\nimport { translate } from 'react-polyglot';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { Route, Switch, Redirect } from 'react-router-dom';\nimport TopBarProgress from 'react-topbar-progress-indicator';\nimport { Loader, colors } from 'decap-cms-ui-default';\n\nimport { loginUser, logoutUser } from '../../actions/auth';\nimport { currentBackend } from '../../backend';\nimport { createNewEntry } from '../../actions/collections';\nimport { openMediaLibrary } from '../../actions/mediaLibrary';\nimport MediaLibrary from '../MediaLibrary/MediaLibrary';\nimport { Notifications } from '../UI';\nimport { history } from '../../routing/history';\nimport { SIMPLE, EDITORIAL_WORKFLOW } from '../../constants/publishModes';\nimport Collection from '../Collection/Collection';\nimport Workflow from '../Workflow/Workflow';\nimport Editor from '../Editor/Editor';\nimport NotFoundPage from './NotFoundPage';\nimport Header from './Header';\n\nTopBarProgress.config({\n  barColors: {\n    0: colors.active,\n    '1.0': colors.active,\n  },\n  shadowBlur: 0,\n  barThickness: 2,\n});\n\nconst AppMainContainer = styled.div`\n  min-width: 800px;\n  max-width: 1440px;\n  margin: 0 auto;\n`;\n\nconst ErrorContainer = styled.div`\n  margin: 20px;\n`;\n\nconst ErrorCodeBlock = styled.pre`\n  margin-left: 20px;\n  font-size: 15px;\n  line-height: 1.5;\n`;\n\nfunction getDefaultPath(collections) {\n  const first = collections.filter(collection => collection.get('hide') !== true).first();\n  if (first) {\n    return `/collections/${first.get('name')}`;\n  } else {\n    throw new Error('Could not find a non hidden collection');\n  }\n}\n\nfunction RouteInCollection({ collections, render, ...props }) {\n  const defaultPath = getDefaultPath(collections);\n  return (\n    <Route\n      {...props}\n      render={routeProps => {\n        const collectionExists = collections.get(routeProps.match.params.name);\n        return collectionExists ? render(routeProps) : <Redirect to={defaultPath} />;\n      }}\n    />\n  );\n}\n\nclass App extends React.Component {\n  static propTypes = {\n    auth: PropTypes.object.isRequired,\n    config: PropTypes.object.isRequired,\n    collections: ImmutablePropTypes.map.isRequired,\n    loginUser: PropTypes.func.isRequired,\n    logoutUser: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    isFetching: PropTypes.bool.isRequired,\n    publishMode: PropTypes.oneOf([SIMPLE, EDITORIAL_WORKFLOW]),\n    siteId: PropTypes.string,\n    useMediaLibrary: PropTypes.bool,\n    openMediaLibrary: PropTypes.func.isRequired,\n    showMediaButton: PropTypes.bool,\n    t: PropTypes.func.isRequired,\n  };\n\n  configError(config) {\n    const t = this.props.t;\n    return (\n      <ErrorContainer>\n        <h1>{t('app.app.errorHeader')}</h1>\n        <div>\n          <strong>{t('app.app.configErrors')}:</strong>\n          <ErrorCodeBlock>{config.error}</ErrorCodeBlock>\n          <span>{t('app.app.checkConfigYml')}</span>\n        </div>\n      </ErrorContainer>\n    );\n  }\n\n  handleLogin(credentials) {\n    this.props.loginUser(credentials);\n  }\n\n  authenticating() {\n    const { auth, t } = this.props;\n    const backend = currentBackend(this.props.config);\n\n    if (backend == null) {\n      return (\n        <div>\n          <h1>{t('app.app.waitingBackend')}</h1>\n        </div>\n      );\n    }\n\n    return (\n      <div>\n        <Notifications />\n        {React.createElement(backend.authComponent(), {\n          onLogin: this.handleLogin.bind(this),\n          error: auth.error,\n          inProgress: auth.isFetching,\n          siteId: this.props.config.backend.site_domain,\n          base_url: this.props.config.backend.base_url,\n          authEndpoint: this.props.config.backend.auth_endpoint,\n          config: this.props.config,\n          clearHash: () => history.replace('/'),\n          t,\n        })}\n      </div>\n    );\n  }\n\n  handleLinkClick(event, handler, ...args) {\n    event.preventDefault();\n    handler(...args);\n  }\n\n  render() {\n    const {\n      user,\n      config,\n      collections,\n      logoutUser,\n      isFetching,\n      publishMode,\n      useMediaLibrary,\n      openMediaLibrary,\n      t,\n      showMediaButton,\n    } = this.props;\n\n    if (config === null) {\n      return null;\n    }\n\n    if (config.error) {\n      return this.configError(config);\n    }\n\n    if (config.isFetching) {\n      return <Loader active>{t('app.app.loadingConfig')}</Loader>;\n    }\n\n    if (user == null) {\n      return this.authenticating(t);\n    }\n\n    const defaultPath = getDefaultPath(collections);\n    const hasWorkflow = publishMode === EDITORIAL_WORKFLOW;\n\n    return (\n      <>\n        <Notifications />\n        <Header\n          user={user}\n          collections={collections}\n          onCreateEntryClick={createNewEntry}\n          onLogoutClick={logoutUser}\n          openMediaLibrary={openMediaLibrary}\n          hasWorkflow={hasWorkflow}\n          displayUrl={config.display_url}\n          isTestRepo={config.backend.name === 'test-repo'}\n          showMediaButton={showMediaButton}\n        />\n        <AppMainContainer>\n          {isFetching && <TopBarProgress />}\n          <Switch>\n            <Redirect exact from=\"/\" to={defaultPath} />\n            <Redirect exact from=\"/search/\" to={defaultPath} />\n            <RouteInCollection\n              exact\n              collections={collections}\n              path=\"/collections/:name/search/\"\n              render={({ match }) => <Redirect to={`/collections/${match.params.name}`} />}\n            />\n            <Redirect\n              // This happens on Identity + Invite Only + External Provider email not matching\n              // the registered user\n              from=\"/error=access_denied&error_description=Signups+not+allowed+for+this+instance\"\n              to={defaultPath}\n            />\n            {hasWorkflow ? <Route path=\"/workflow\" component={Workflow} /> : null}\n            <RouteInCollection\n              exact\n              collections={collections}\n              path=\"/collections/:name\"\n              render={props => <Collection {...props} />}\n            />\n            <RouteInCollection\n              path=\"/collections/:name/new\"\n              collections={collections}\n              render={props => <Editor {...props} newRecord />}\n            />\n            <RouteInCollection\n              path=\"/collections/:name/entries/*\"\n              collections={collections}\n              render={props => <Editor {...props} />}\n            />\n            <RouteInCollection\n              path=\"/collections/:name/search/:searchTerm\"\n              collections={collections}\n              render={props => <Collection {...props} isSearchResults isSingleSearchResult />}\n            />\n            <RouteInCollection\n              collections={collections}\n              path=\"/collections/:name/filter/:filterTerm*\"\n              render={props => <Collection {...props} />}\n            />\n            <Route\n              path=\"/search/:searchTerm\"\n              render={props => <Collection {...props} isSearchResults />}\n            />\n            <RouteInCollection\n              path=\"/edit/:name/:entryName\"\n              collections={collections}\n              render={({ match }) => {\n                const { name, entryName } = match.params;\n                return <Redirect to={`/collections/${name}/entries/${entryName}`} />;\n              }}\n            />\n            <Route component={NotFoundPage} />\n          </Switch>\n          {useMediaLibrary ? <MediaLibrary /> : null}\n        </AppMainContainer>\n      </>\n    );\n  }\n}\n\nfunction mapStateToProps(state) {\n  const { auth, config, collections, globalUI, mediaLibrary } = state;\n  const user = auth.user;\n  const isFetching = globalUI.isFetching;\n  const publishMode = config.publish_mode;\n  const useMediaLibrary = !mediaLibrary.get('externalLibrary');\n  const showMediaButton = mediaLibrary.get('showMediaButton');\n  return {\n    auth,\n    config,\n    collections,\n    user,\n    isFetching,\n    publishMode,\n    showMediaButton,\n    useMediaLibrary,\n  };\n}\n\nconst mapDispatchToProps = {\n  openMediaLibrary,\n  loginUser,\n  logoutUser,\n};\n\nexport default hot(module)(connect(mapStateToProps, mapDispatchToProps)(translate()(App)));\n"]} */",
56
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/App/App.js"],"names":[],"mappings":"AAiCmC","file":"../../../../src/components/App/App.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React from 'react';\nimport { translate } from 'react-polyglot';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { Route, Switch, Redirect } from 'react-router-dom';\nimport TopBarProgress from 'react-topbar-progress-indicator';\nimport { Loader, colors } from 'decap-cms-ui-default';\n\nimport { loginUser, logoutUser } from '../../actions/auth';\nimport { currentBackend } from '../../backend';\nimport { createNewEntry } from '../../actions/collections';\nimport { openMediaLibrary } from '../../actions/mediaLibrary';\nimport MediaLibrary from '../MediaLibrary/MediaLibrary';\nimport { Notifications } from '../UI';\nimport { history } from '../../routing/history';\nimport { SIMPLE, EDITORIAL_WORKFLOW } from '../../constants/publishModes';\nimport Collection from '../Collection/Collection';\nimport Workflow from '../Workflow/Workflow';\nimport Editor from '../Editor/Editor';\nimport NotFoundPage from './NotFoundPage';\nimport Header from './Header';\n\nTopBarProgress.config({\n  barColors: {\n    0: colors.active,\n    '1.0': colors.active,\n  },\n  shadowBlur: 0,\n  barThickness: 2,\n});\n\nconst AppMainContainer = styled.div`\n  min-width: 800px;\n  max-width: 1440px;\n  margin: 0 auto;\n`;\n\nconst ErrorContainer = styled.div`\n  margin: 20px;\n`;\n\nconst ErrorCodeBlock = styled.pre`\n  margin-left: 20px;\n  font-size: 15px;\n  line-height: 1.5;\n`;\n\nfunction getDefaultPath(collections) {\n  const first = collections.filter(collection => collection.get('hide') !== true).first();\n  if (first) {\n    return `/collections/${first.get('name')}`;\n  } else {\n    throw new Error('Could not find a non hidden collection');\n  }\n}\n\nfunction RouteInCollection({ collections, render, ...props }) {\n  const defaultPath = getDefaultPath(collections);\n  return (\n    <Route\n      {...props}\n      render={routeProps => {\n        const collectionExists = collections.get(routeProps.match.params.name);\n        return collectionExists ? render(routeProps) : <Redirect to={defaultPath} />;\n      }}\n    />\n  );\n}\n\nclass App extends React.Component {\n  static propTypes = {\n    auth: PropTypes.object.isRequired,\n    config: PropTypes.object.isRequired,\n    collections: ImmutablePropTypes.map.isRequired,\n    loginUser: PropTypes.func.isRequired,\n    logoutUser: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    isFetching: PropTypes.bool.isRequired,\n    publishMode: PropTypes.oneOf([SIMPLE, EDITORIAL_WORKFLOW]),\n    siteId: PropTypes.string,\n    useMediaLibrary: PropTypes.bool,\n    openMediaLibrary: PropTypes.func.isRequired,\n    showMediaButton: PropTypes.bool,\n    t: PropTypes.func.isRequired,\n  };\n\n  configError(config) {\n    const t = this.props.t;\n    return (\n      <ErrorContainer>\n        <h1>{t('app.app.errorHeader')}</h1>\n        <div>\n          <strong>{t('app.app.configErrors')}:</strong>\n          <ErrorCodeBlock>{config.error}</ErrorCodeBlock>\n          <span>{t('app.app.checkConfigYml')}</span>\n        </div>\n      </ErrorContainer>\n    );\n  }\n\n  handleLogin(credentials) {\n    this.props.loginUser(credentials);\n  }\n\n  authenticating() {\n    const { auth, t } = this.props;\n    const backend = currentBackend(this.props.config);\n\n    if (backend == null) {\n      return (\n        <div>\n          <h1>{t('app.app.waitingBackend')}</h1>\n        </div>\n      );\n    }\n\n    return (\n      <div>\n        <Notifications />\n        {React.createElement(backend.authComponent(), {\n          onLogin: this.handleLogin.bind(this),\n          error: auth.error,\n          inProgress: auth.isFetching,\n          siteId: this.props.config.backend.site_domain,\n          base_url: this.props.config.backend.base_url,\n          authEndpoint: this.props.config.backend.auth_endpoint,\n          config: this.props.config,\n          clearHash: () => history.replace('/'),\n          t,\n        })}\n      </div>\n    );\n  }\n\n  handleLinkClick(event, handler, ...args) {\n    event.preventDefault();\n    handler(...args);\n  }\n\n  render() {\n    const {\n      user,\n      config,\n      collections,\n      logoutUser,\n      isFetching,\n      publishMode,\n      useMediaLibrary,\n      openMediaLibrary,\n      t,\n      showMediaButton,\n    } = this.props;\n\n    if (config === null) {\n      return null;\n    }\n\n    if (config.error) {\n      return this.configError(config);\n    }\n\n    if (config.isFetching) {\n      return <Loader active>{t('app.app.loadingConfig')}</Loader>;\n    }\n\n    if (user == null) {\n      return this.authenticating(t);\n    }\n\n    const defaultPath = getDefaultPath(collections);\n    const hasWorkflow = publishMode === EDITORIAL_WORKFLOW;\n\n    return (\n      <>\n        <Notifications />\n        <Header\n          user={user}\n          collections={collections}\n          onCreateEntryClick={createNewEntry}\n          onLogoutClick={logoutUser}\n          openMediaLibrary={openMediaLibrary}\n          hasWorkflow={hasWorkflow}\n          displayUrl={config.display_url}\n          isTestRepo={config.backend.name === 'test-repo'}\n          showMediaButton={showMediaButton}\n        />\n        <AppMainContainer>\n          {isFetching && <TopBarProgress />}\n          <Switch>\n            <Redirect exact from=\"/\" to={defaultPath} />\n            <Redirect exact from=\"/search/\" to={defaultPath} />\n            <RouteInCollection\n              exact\n              collections={collections}\n              path=\"/collections/:name/search/\"\n              render={({ match }) => <Redirect to={`/collections/${match.params.name}`} />}\n            />\n            <Redirect\n              // This happens on Identity + Invite Only + External Provider email not matching\n              // the registered user\n              from=\"/error=access_denied&error_description=Signups+not+allowed+for+this+instance\"\n              to={defaultPath}\n            />\n            {hasWorkflow ? <Route path=\"/workflow\" component={Workflow} /> : null}\n            <RouteInCollection\n              exact\n              collections={collections}\n              path=\"/collections/:name\"\n              render={props => <Collection {...props} />}\n            />\n            <RouteInCollection\n              path=\"/collections/:name/new\"\n              collections={collections}\n              render={props => <Editor {...props} newRecord />}\n            />\n            <RouteInCollection\n              path=\"/collections/:name/entries/*\"\n              collections={collections}\n              render={props => <Editor {...props} />}\n            />\n            <RouteInCollection\n              path=\"/collections/:name/search/:searchTerm\"\n              collections={collections}\n              render={props => <Collection {...props} isSearchResults isSingleSearchResult />}\n            />\n            <RouteInCollection\n              collections={collections}\n              path=\"/collections/:name/filter/:filterTerm*\"\n              render={props => <Collection {...props} />}\n            />\n            <Route\n              path=\"/search/:searchTerm\"\n              render={props => <Collection {...props} isSearchResults />}\n            />\n            <RouteInCollection\n              path=\"/edit/:name/:entryName\"\n              collections={collections}\n              render={({ match }) => {\n                const { name, entryName } = match.params;\n                return <Redirect to={`/collections/${name}/entries/${entryName}`} />;\n              }}\n            />\n            <Route component={NotFoundPage} />\n          </Switch>\n          {useMediaLibrary ? <MediaLibrary /> : null}\n        </AppMainContainer>\n      </>\n    );\n  }\n}\n\nfunction mapStateToProps(state) {\n  const { auth, config, collections, globalUI, mediaLibrary } = state;\n  const user = auth.user;\n  const isFetching = globalUI.isFetching;\n  const publishMode = config.publish_mode;\n  const useMediaLibrary = !mediaLibrary.get('externalLibrary');\n  const showMediaButton = mediaLibrary.get('showMediaButton');\n  return {\n    auth,\n    config,\n    collections,\n    user,\n    isFetching,\n    publishMode,\n    showMediaButton,\n    useMediaLibrary,\n  };\n}\n\nconst mapDispatchToProps = {\n  openMediaLibrary,\n  loginUser,\n  logoutUser,\n};\n\nexport default connect(mapStateToProps, mapDispatchToProps)(translate()(App));\n"]} */",
58
57
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
59
58
  });
60
59
  const ErrorContainer = /*#__PURE__*/(0, _base.default)("div", {
@@ -66,7 +65,7 @@ const ErrorContainer = /*#__PURE__*/(0, _base.default)("div", {
66
65
  } : {
67
66
  name: "3zy121",
68
67
  styles: "margin:20px",
69
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/App/App.js"],"names":[],"mappings":"AAwCiC","file":"../../../../src/components/App/App.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React from 'react';\nimport { hot } from 'react-hot-loader';\nimport { translate } from 'react-polyglot';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { Route, Switch, Redirect } from 'react-router-dom';\nimport TopBarProgress from 'react-topbar-progress-indicator';\nimport { Loader, colors } from 'decap-cms-ui-default';\n\nimport { loginUser, logoutUser } from '../../actions/auth';\nimport { currentBackend } from '../../backend';\nimport { createNewEntry } from '../../actions/collections';\nimport { openMediaLibrary } from '../../actions/mediaLibrary';\nimport MediaLibrary from '../MediaLibrary/MediaLibrary';\nimport { Notifications } from '../UI';\nimport { history } from '../../routing/history';\nimport { SIMPLE, EDITORIAL_WORKFLOW } from '../../constants/publishModes';\nimport Collection from '../Collection/Collection';\nimport Workflow from '../Workflow/Workflow';\nimport Editor from '../Editor/Editor';\nimport NotFoundPage from './NotFoundPage';\nimport Header from './Header';\n\nTopBarProgress.config({\n  barColors: {\n    0: colors.active,\n    '1.0': colors.active,\n  },\n  shadowBlur: 0,\n  barThickness: 2,\n});\n\nconst AppMainContainer = styled.div`\n  min-width: 800px;\n  max-width: 1440px;\n  margin: 0 auto;\n`;\n\nconst ErrorContainer = styled.div`\n  margin: 20px;\n`;\n\nconst ErrorCodeBlock = styled.pre`\n  margin-left: 20px;\n  font-size: 15px;\n  line-height: 1.5;\n`;\n\nfunction getDefaultPath(collections) {\n  const first = collections.filter(collection => collection.get('hide') !== true).first();\n  if (first) {\n    return `/collections/${first.get('name')}`;\n  } else {\n    throw new Error('Could not find a non hidden collection');\n  }\n}\n\nfunction RouteInCollection({ collections, render, ...props }) {\n  const defaultPath = getDefaultPath(collections);\n  return (\n    <Route\n      {...props}\n      render={routeProps => {\n        const collectionExists = collections.get(routeProps.match.params.name);\n        return collectionExists ? render(routeProps) : <Redirect to={defaultPath} />;\n      }}\n    />\n  );\n}\n\nclass App extends React.Component {\n  static propTypes = {\n    auth: PropTypes.object.isRequired,\n    config: PropTypes.object.isRequired,\n    collections: ImmutablePropTypes.map.isRequired,\n    loginUser: PropTypes.func.isRequired,\n    logoutUser: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    isFetching: PropTypes.bool.isRequired,\n    publishMode: PropTypes.oneOf([SIMPLE, EDITORIAL_WORKFLOW]),\n    siteId: PropTypes.string,\n    useMediaLibrary: PropTypes.bool,\n    openMediaLibrary: PropTypes.func.isRequired,\n    showMediaButton: PropTypes.bool,\n    t: PropTypes.func.isRequired,\n  };\n\n  configError(config) {\n    const t = this.props.t;\n    return (\n      <ErrorContainer>\n        <h1>{t('app.app.errorHeader')}</h1>\n        <div>\n          <strong>{t('app.app.configErrors')}:</strong>\n          <ErrorCodeBlock>{config.error}</ErrorCodeBlock>\n          <span>{t('app.app.checkConfigYml')}</span>\n        </div>\n      </ErrorContainer>\n    );\n  }\n\n  handleLogin(credentials) {\n    this.props.loginUser(credentials);\n  }\n\n  authenticating() {\n    const { auth, t } = this.props;\n    const backend = currentBackend(this.props.config);\n\n    if (backend == null) {\n      return (\n        <div>\n          <h1>{t('app.app.waitingBackend')}</h1>\n        </div>\n      );\n    }\n\n    return (\n      <div>\n        <Notifications />\n        {React.createElement(backend.authComponent(), {\n          onLogin: this.handleLogin.bind(this),\n          error: auth.error,\n          inProgress: auth.isFetching,\n          siteId: this.props.config.backend.site_domain,\n          base_url: this.props.config.backend.base_url,\n          authEndpoint: this.props.config.backend.auth_endpoint,\n          config: this.props.config,\n          clearHash: () => history.replace('/'),\n          t,\n        })}\n      </div>\n    );\n  }\n\n  handleLinkClick(event, handler, ...args) {\n    event.preventDefault();\n    handler(...args);\n  }\n\n  render() {\n    const {\n      user,\n      config,\n      collections,\n      logoutUser,\n      isFetching,\n      publishMode,\n      useMediaLibrary,\n      openMediaLibrary,\n      t,\n      showMediaButton,\n    } = this.props;\n\n    if (config === null) {\n      return null;\n    }\n\n    if (config.error) {\n      return this.configError(config);\n    }\n\n    if (config.isFetching) {\n      return <Loader active>{t('app.app.loadingConfig')}</Loader>;\n    }\n\n    if (user == null) {\n      return this.authenticating(t);\n    }\n\n    const defaultPath = getDefaultPath(collections);\n    const hasWorkflow = publishMode === EDITORIAL_WORKFLOW;\n\n    return (\n      <>\n        <Notifications />\n        <Header\n          user={user}\n          collections={collections}\n          onCreateEntryClick={createNewEntry}\n          onLogoutClick={logoutUser}\n          openMediaLibrary={openMediaLibrary}\n          hasWorkflow={hasWorkflow}\n          displayUrl={config.display_url}\n          isTestRepo={config.backend.name === 'test-repo'}\n          showMediaButton={showMediaButton}\n        />\n        <AppMainContainer>\n          {isFetching && <TopBarProgress />}\n          <Switch>\n            <Redirect exact from=\"/\" to={defaultPath} />\n            <Redirect exact from=\"/search/\" to={defaultPath} />\n            <RouteInCollection\n              exact\n              collections={collections}\n              path=\"/collections/:name/search/\"\n              render={({ match }) => <Redirect to={`/collections/${match.params.name}`} />}\n            />\n            <Redirect\n              // This happens on Identity + Invite Only + External Provider email not matching\n              // the registered user\n              from=\"/error=access_denied&error_description=Signups+not+allowed+for+this+instance\"\n              to={defaultPath}\n            />\n            {hasWorkflow ? <Route path=\"/workflow\" component={Workflow} /> : null}\n            <RouteInCollection\n              exact\n              collections={collections}\n              path=\"/collections/:name\"\n              render={props => <Collection {...props} />}\n            />\n            <RouteInCollection\n              path=\"/collections/:name/new\"\n              collections={collections}\n              render={props => <Editor {...props} newRecord />}\n            />\n            <RouteInCollection\n              path=\"/collections/:name/entries/*\"\n              collections={collections}\n              render={props => <Editor {...props} />}\n            />\n            <RouteInCollection\n              path=\"/collections/:name/search/:searchTerm\"\n              collections={collections}\n              render={props => <Collection {...props} isSearchResults isSingleSearchResult />}\n            />\n            <RouteInCollection\n              collections={collections}\n              path=\"/collections/:name/filter/:filterTerm*\"\n              render={props => <Collection {...props} />}\n            />\n            <Route\n              path=\"/search/:searchTerm\"\n              render={props => <Collection {...props} isSearchResults />}\n            />\n            <RouteInCollection\n              path=\"/edit/:name/:entryName\"\n              collections={collections}\n              render={({ match }) => {\n                const { name, entryName } = match.params;\n                return <Redirect to={`/collections/${name}/entries/${entryName}`} />;\n              }}\n            />\n            <Route component={NotFoundPage} />\n          </Switch>\n          {useMediaLibrary ? <MediaLibrary /> : null}\n        </AppMainContainer>\n      </>\n    );\n  }\n}\n\nfunction mapStateToProps(state) {\n  const { auth, config, collections, globalUI, mediaLibrary } = state;\n  const user = auth.user;\n  const isFetching = globalUI.isFetching;\n  const publishMode = config.publish_mode;\n  const useMediaLibrary = !mediaLibrary.get('externalLibrary');\n  const showMediaButton = mediaLibrary.get('showMediaButton');\n  return {\n    auth,\n    config,\n    collections,\n    user,\n    isFetching,\n    publishMode,\n    showMediaButton,\n    useMediaLibrary,\n  };\n}\n\nconst mapDispatchToProps = {\n  openMediaLibrary,\n  loginUser,\n  logoutUser,\n};\n\nexport default hot(module)(connect(mapStateToProps, mapDispatchToProps)(translate()(App)));\n"]} */",
68
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/App/App.js"],"names":[],"mappings":"AAuCiC","file":"../../../../src/components/App/App.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React from 'react';\nimport { translate } from 'react-polyglot';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { Route, Switch, Redirect } from 'react-router-dom';\nimport TopBarProgress from 'react-topbar-progress-indicator';\nimport { Loader, colors } from 'decap-cms-ui-default';\n\nimport { loginUser, logoutUser } from '../../actions/auth';\nimport { currentBackend } from '../../backend';\nimport { createNewEntry } from '../../actions/collections';\nimport { openMediaLibrary } from '../../actions/mediaLibrary';\nimport MediaLibrary from '../MediaLibrary/MediaLibrary';\nimport { Notifications } from '../UI';\nimport { history } from '../../routing/history';\nimport { SIMPLE, EDITORIAL_WORKFLOW } from '../../constants/publishModes';\nimport Collection from '../Collection/Collection';\nimport Workflow from '../Workflow/Workflow';\nimport Editor from '../Editor/Editor';\nimport NotFoundPage from './NotFoundPage';\nimport Header from './Header';\n\nTopBarProgress.config({\n  barColors: {\n    0: colors.active,\n    '1.0': colors.active,\n  },\n  shadowBlur: 0,\n  barThickness: 2,\n});\n\nconst AppMainContainer = styled.div`\n  min-width: 800px;\n  max-width: 1440px;\n  margin: 0 auto;\n`;\n\nconst ErrorContainer = styled.div`\n  margin: 20px;\n`;\n\nconst ErrorCodeBlock = styled.pre`\n  margin-left: 20px;\n  font-size: 15px;\n  line-height: 1.5;\n`;\n\nfunction getDefaultPath(collections) {\n  const first = collections.filter(collection => collection.get('hide') !== true).first();\n  if (first) {\n    return `/collections/${first.get('name')}`;\n  } else {\n    throw new Error('Could not find a non hidden collection');\n  }\n}\n\nfunction RouteInCollection({ collections, render, ...props }) {\n  const defaultPath = getDefaultPath(collections);\n  return (\n    <Route\n      {...props}\n      render={routeProps => {\n        const collectionExists = collections.get(routeProps.match.params.name);\n        return collectionExists ? render(routeProps) : <Redirect to={defaultPath} />;\n      }}\n    />\n  );\n}\n\nclass App extends React.Component {\n  static propTypes = {\n    auth: PropTypes.object.isRequired,\n    config: PropTypes.object.isRequired,\n    collections: ImmutablePropTypes.map.isRequired,\n    loginUser: PropTypes.func.isRequired,\n    logoutUser: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    isFetching: PropTypes.bool.isRequired,\n    publishMode: PropTypes.oneOf([SIMPLE, EDITORIAL_WORKFLOW]),\n    siteId: PropTypes.string,\n    useMediaLibrary: PropTypes.bool,\n    openMediaLibrary: PropTypes.func.isRequired,\n    showMediaButton: PropTypes.bool,\n    t: PropTypes.func.isRequired,\n  };\n\n  configError(config) {\n    const t = this.props.t;\n    return (\n      <ErrorContainer>\n        <h1>{t('app.app.errorHeader')}</h1>\n        <div>\n          <strong>{t('app.app.configErrors')}:</strong>\n          <ErrorCodeBlock>{config.error}</ErrorCodeBlock>\n          <span>{t('app.app.checkConfigYml')}</span>\n        </div>\n      </ErrorContainer>\n    );\n  }\n\n  handleLogin(credentials) {\n    this.props.loginUser(credentials);\n  }\n\n  authenticating() {\n    const { auth, t } = this.props;\n    const backend = currentBackend(this.props.config);\n\n    if (backend == null) {\n      return (\n        <div>\n          <h1>{t('app.app.waitingBackend')}</h1>\n        </div>\n      );\n    }\n\n    return (\n      <div>\n        <Notifications />\n        {React.createElement(backend.authComponent(), {\n          onLogin: this.handleLogin.bind(this),\n          error: auth.error,\n          inProgress: auth.isFetching,\n          siteId: this.props.config.backend.site_domain,\n          base_url: this.props.config.backend.base_url,\n          authEndpoint: this.props.config.backend.auth_endpoint,\n          config: this.props.config,\n          clearHash: () => history.replace('/'),\n          t,\n        })}\n      </div>\n    );\n  }\n\n  handleLinkClick(event, handler, ...args) {\n    event.preventDefault();\n    handler(...args);\n  }\n\n  render() {\n    const {\n      user,\n      config,\n      collections,\n      logoutUser,\n      isFetching,\n      publishMode,\n      useMediaLibrary,\n      openMediaLibrary,\n      t,\n      showMediaButton,\n    } = this.props;\n\n    if (config === null) {\n      return null;\n    }\n\n    if (config.error) {\n      return this.configError(config);\n    }\n\n    if (config.isFetching) {\n      return <Loader active>{t('app.app.loadingConfig')}</Loader>;\n    }\n\n    if (user == null) {\n      return this.authenticating(t);\n    }\n\n    const defaultPath = getDefaultPath(collections);\n    const hasWorkflow = publishMode === EDITORIAL_WORKFLOW;\n\n    return (\n      <>\n        <Notifications />\n        <Header\n          user={user}\n          collections={collections}\n          onCreateEntryClick={createNewEntry}\n          onLogoutClick={logoutUser}\n          openMediaLibrary={openMediaLibrary}\n          hasWorkflow={hasWorkflow}\n          displayUrl={config.display_url}\n          isTestRepo={config.backend.name === 'test-repo'}\n          showMediaButton={showMediaButton}\n        />\n        <AppMainContainer>\n          {isFetching && <TopBarProgress />}\n          <Switch>\n            <Redirect exact from=\"/\" to={defaultPath} />\n            <Redirect exact from=\"/search/\" to={defaultPath} />\n            <RouteInCollection\n              exact\n              collections={collections}\n              path=\"/collections/:name/search/\"\n              render={({ match }) => <Redirect to={`/collections/${match.params.name}`} />}\n            />\n            <Redirect\n              // This happens on Identity + Invite Only + External Provider email not matching\n              // the registered user\n              from=\"/error=access_denied&error_description=Signups+not+allowed+for+this+instance\"\n              to={defaultPath}\n            />\n            {hasWorkflow ? <Route path=\"/workflow\" component={Workflow} /> : null}\n            <RouteInCollection\n              exact\n              collections={collections}\n              path=\"/collections/:name\"\n              render={props => <Collection {...props} />}\n            />\n            <RouteInCollection\n              path=\"/collections/:name/new\"\n              collections={collections}\n              render={props => <Editor {...props} newRecord />}\n            />\n            <RouteInCollection\n              path=\"/collections/:name/entries/*\"\n              collections={collections}\n              render={props => <Editor {...props} />}\n            />\n            <RouteInCollection\n              path=\"/collections/:name/search/:searchTerm\"\n              collections={collections}\n              render={props => <Collection {...props} isSearchResults isSingleSearchResult />}\n            />\n            <RouteInCollection\n              collections={collections}\n              path=\"/collections/:name/filter/:filterTerm*\"\n              render={props => <Collection {...props} />}\n            />\n            <Route\n              path=\"/search/:searchTerm\"\n              render={props => <Collection {...props} isSearchResults />}\n            />\n            <RouteInCollection\n              path=\"/edit/:name/:entryName\"\n              collections={collections}\n              render={({ match }) => {\n                const { name, entryName } = match.params;\n                return <Redirect to={`/collections/${name}/entries/${entryName}`} />;\n              }}\n            />\n            <Route component={NotFoundPage} />\n          </Switch>\n          {useMediaLibrary ? <MediaLibrary /> : null}\n        </AppMainContainer>\n      </>\n    );\n  }\n}\n\nfunction mapStateToProps(state) {\n  const { auth, config, collections, globalUI, mediaLibrary } = state;\n  const user = auth.user;\n  const isFetching = globalUI.isFetching;\n  const publishMode = config.publish_mode;\n  const useMediaLibrary = !mediaLibrary.get('externalLibrary');\n  const showMediaButton = mediaLibrary.get('showMediaButton');\n  return {\n    auth,\n    config,\n    collections,\n    user,\n    isFetching,\n    publishMode,\n    showMediaButton,\n    useMediaLibrary,\n  };\n}\n\nconst mapDispatchToProps = {\n  openMediaLibrary,\n  loginUser,\n  logoutUser,\n};\n\nexport default connect(mapStateToProps, mapDispatchToProps)(translate()(App));\n"]} */",
70
69
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
71
70
  });
72
71
  const ErrorCodeBlock = /*#__PURE__*/(0, _base.default)("pre", {
@@ -78,7 +77,7 @@ const ErrorCodeBlock = /*#__PURE__*/(0, _base.default)("pre", {
78
77
  } : {
79
78
  name: "1dps4tx",
80
79
  styles: "margin-left:20px;font-size:15px;line-height:1.5",
81
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/App/App.js"],"names":[],"mappings":"AA4CiC","file":"../../../../src/components/App/App.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React from 'react';\nimport { hot } from 'react-hot-loader';\nimport { translate } from 'react-polyglot';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { Route, Switch, Redirect } from 'react-router-dom';\nimport TopBarProgress from 'react-topbar-progress-indicator';\nimport { Loader, colors } from 'decap-cms-ui-default';\n\nimport { loginUser, logoutUser } from '../../actions/auth';\nimport { currentBackend } from '../../backend';\nimport { createNewEntry } from '../../actions/collections';\nimport { openMediaLibrary } from '../../actions/mediaLibrary';\nimport MediaLibrary from '../MediaLibrary/MediaLibrary';\nimport { Notifications } from '../UI';\nimport { history } from '../../routing/history';\nimport { SIMPLE, EDITORIAL_WORKFLOW } from '../../constants/publishModes';\nimport Collection from '../Collection/Collection';\nimport Workflow from '../Workflow/Workflow';\nimport Editor from '../Editor/Editor';\nimport NotFoundPage from './NotFoundPage';\nimport Header from './Header';\n\nTopBarProgress.config({\n  barColors: {\n    0: colors.active,\n    '1.0': colors.active,\n  },\n  shadowBlur: 0,\n  barThickness: 2,\n});\n\nconst AppMainContainer = styled.div`\n  min-width: 800px;\n  max-width: 1440px;\n  margin: 0 auto;\n`;\n\nconst ErrorContainer = styled.div`\n  margin: 20px;\n`;\n\nconst ErrorCodeBlock = styled.pre`\n  margin-left: 20px;\n  font-size: 15px;\n  line-height: 1.5;\n`;\n\nfunction getDefaultPath(collections) {\n  const first = collections.filter(collection => collection.get('hide') !== true).first();\n  if (first) {\n    return `/collections/${first.get('name')}`;\n  } else {\n    throw new Error('Could not find a non hidden collection');\n  }\n}\n\nfunction RouteInCollection({ collections, render, ...props }) {\n  const defaultPath = getDefaultPath(collections);\n  return (\n    <Route\n      {...props}\n      render={routeProps => {\n        const collectionExists = collections.get(routeProps.match.params.name);\n        return collectionExists ? render(routeProps) : <Redirect to={defaultPath} />;\n      }}\n    />\n  );\n}\n\nclass App extends React.Component {\n  static propTypes = {\n    auth: PropTypes.object.isRequired,\n    config: PropTypes.object.isRequired,\n    collections: ImmutablePropTypes.map.isRequired,\n    loginUser: PropTypes.func.isRequired,\n    logoutUser: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    isFetching: PropTypes.bool.isRequired,\n    publishMode: PropTypes.oneOf([SIMPLE, EDITORIAL_WORKFLOW]),\n    siteId: PropTypes.string,\n    useMediaLibrary: PropTypes.bool,\n    openMediaLibrary: PropTypes.func.isRequired,\n    showMediaButton: PropTypes.bool,\n    t: PropTypes.func.isRequired,\n  };\n\n  configError(config) {\n    const t = this.props.t;\n    return (\n      <ErrorContainer>\n        <h1>{t('app.app.errorHeader')}</h1>\n        <div>\n          <strong>{t('app.app.configErrors')}:</strong>\n          <ErrorCodeBlock>{config.error}</ErrorCodeBlock>\n          <span>{t('app.app.checkConfigYml')}</span>\n        </div>\n      </ErrorContainer>\n    );\n  }\n\n  handleLogin(credentials) {\n    this.props.loginUser(credentials);\n  }\n\n  authenticating() {\n    const { auth, t } = this.props;\n    const backend = currentBackend(this.props.config);\n\n    if (backend == null) {\n      return (\n        <div>\n          <h1>{t('app.app.waitingBackend')}</h1>\n        </div>\n      );\n    }\n\n    return (\n      <div>\n        <Notifications />\n        {React.createElement(backend.authComponent(), {\n          onLogin: this.handleLogin.bind(this),\n          error: auth.error,\n          inProgress: auth.isFetching,\n          siteId: this.props.config.backend.site_domain,\n          base_url: this.props.config.backend.base_url,\n          authEndpoint: this.props.config.backend.auth_endpoint,\n          config: this.props.config,\n          clearHash: () => history.replace('/'),\n          t,\n        })}\n      </div>\n    );\n  }\n\n  handleLinkClick(event, handler, ...args) {\n    event.preventDefault();\n    handler(...args);\n  }\n\n  render() {\n    const {\n      user,\n      config,\n      collections,\n      logoutUser,\n      isFetching,\n      publishMode,\n      useMediaLibrary,\n      openMediaLibrary,\n      t,\n      showMediaButton,\n    } = this.props;\n\n    if (config === null) {\n      return null;\n    }\n\n    if (config.error) {\n      return this.configError(config);\n    }\n\n    if (config.isFetching) {\n      return <Loader active>{t('app.app.loadingConfig')}</Loader>;\n    }\n\n    if (user == null) {\n      return this.authenticating(t);\n    }\n\n    const defaultPath = getDefaultPath(collections);\n    const hasWorkflow = publishMode === EDITORIAL_WORKFLOW;\n\n    return (\n      <>\n        <Notifications />\n        <Header\n          user={user}\n          collections={collections}\n          onCreateEntryClick={createNewEntry}\n          onLogoutClick={logoutUser}\n          openMediaLibrary={openMediaLibrary}\n          hasWorkflow={hasWorkflow}\n          displayUrl={config.display_url}\n          isTestRepo={config.backend.name === 'test-repo'}\n          showMediaButton={showMediaButton}\n        />\n        <AppMainContainer>\n          {isFetching && <TopBarProgress />}\n          <Switch>\n            <Redirect exact from=\"/\" to={defaultPath} />\n            <Redirect exact from=\"/search/\" to={defaultPath} />\n            <RouteInCollection\n              exact\n              collections={collections}\n              path=\"/collections/:name/search/\"\n              render={({ match }) => <Redirect to={`/collections/${match.params.name}`} />}\n            />\n            <Redirect\n              // This happens on Identity + Invite Only + External Provider email not matching\n              // the registered user\n              from=\"/error=access_denied&error_description=Signups+not+allowed+for+this+instance\"\n              to={defaultPath}\n            />\n            {hasWorkflow ? <Route path=\"/workflow\" component={Workflow} /> : null}\n            <RouteInCollection\n              exact\n              collections={collections}\n              path=\"/collections/:name\"\n              render={props => <Collection {...props} />}\n            />\n            <RouteInCollection\n              path=\"/collections/:name/new\"\n              collections={collections}\n              render={props => <Editor {...props} newRecord />}\n            />\n            <RouteInCollection\n              path=\"/collections/:name/entries/*\"\n              collections={collections}\n              render={props => <Editor {...props} />}\n            />\n            <RouteInCollection\n              path=\"/collections/:name/search/:searchTerm\"\n              collections={collections}\n              render={props => <Collection {...props} isSearchResults isSingleSearchResult />}\n            />\n            <RouteInCollection\n              collections={collections}\n              path=\"/collections/:name/filter/:filterTerm*\"\n              render={props => <Collection {...props} />}\n            />\n            <Route\n              path=\"/search/:searchTerm\"\n              render={props => <Collection {...props} isSearchResults />}\n            />\n            <RouteInCollection\n              path=\"/edit/:name/:entryName\"\n              collections={collections}\n              render={({ match }) => {\n                const { name, entryName } = match.params;\n                return <Redirect to={`/collections/${name}/entries/${entryName}`} />;\n              }}\n            />\n            <Route component={NotFoundPage} />\n          </Switch>\n          {useMediaLibrary ? <MediaLibrary /> : null}\n        </AppMainContainer>\n      </>\n    );\n  }\n}\n\nfunction mapStateToProps(state) {\n  const { auth, config, collections, globalUI, mediaLibrary } = state;\n  const user = auth.user;\n  const isFetching = globalUI.isFetching;\n  const publishMode = config.publish_mode;\n  const useMediaLibrary = !mediaLibrary.get('externalLibrary');\n  const showMediaButton = mediaLibrary.get('showMediaButton');\n  return {\n    auth,\n    config,\n    collections,\n    user,\n    isFetching,\n    publishMode,\n    showMediaButton,\n    useMediaLibrary,\n  };\n}\n\nconst mapDispatchToProps = {\n  openMediaLibrary,\n  loginUser,\n  logoutUser,\n};\n\nexport default hot(module)(connect(mapStateToProps, mapDispatchToProps)(translate()(App)));\n"]} */",
80
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/App/App.js"],"names":[],"mappings":"AA2CiC","file":"../../../../src/components/App/App.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React from 'react';\nimport { translate } from 'react-polyglot';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { Route, Switch, Redirect } from 'react-router-dom';\nimport TopBarProgress from 'react-topbar-progress-indicator';\nimport { Loader, colors } from 'decap-cms-ui-default';\n\nimport { loginUser, logoutUser } from '../../actions/auth';\nimport { currentBackend } from '../../backend';\nimport { createNewEntry } from '../../actions/collections';\nimport { openMediaLibrary } from '../../actions/mediaLibrary';\nimport MediaLibrary from '../MediaLibrary/MediaLibrary';\nimport { Notifications } from '../UI';\nimport { history } from '../../routing/history';\nimport { SIMPLE, EDITORIAL_WORKFLOW } from '../../constants/publishModes';\nimport Collection from '../Collection/Collection';\nimport Workflow from '../Workflow/Workflow';\nimport Editor from '../Editor/Editor';\nimport NotFoundPage from './NotFoundPage';\nimport Header from './Header';\n\nTopBarProgress.config({\n  barColors: {\n    0: colors.active,\n    '1.0': colors.active,\n  },\n  shadowBlur: 0,\n  barThickness: 2,\n});\n\nconst AppMainContainer = styled.div`\n  min-width: 800px;\n  max-width: 1440px;\n  margin: 0 auto;\n`;\n\nconst ErrorContainer = styled.div`\n  margin: 20px;\n`;\n\nconst ErrorCodeBlock = styled.pre`\n  margin-left: 20px;\n  font-size: 15px;\n  line-height: 1.5;\n`;\n\nfunction getDefaultPath(collections) {\n  const first = collections.filter(collection => collection.get('hide') !== true).first();\n  if (first) {\n    return `/collections/${first.get('name')}`;\n  } else {\n    throw new Error('Could not find a non hidden collection');\n  }\n}\n\nfunction RouteInCollection({ collections, render, ...props }) {\n  const defaultPath = getDefaultPath(collections);\n  return (\n    <Route\n      {...props}\n      render={routeProps => {\n        const collectionExists = collections.get(routeProps.match.params.name);\n        return collectionExists ? render(routeProps) : <Redirect to={defaultPath} />;\n      }}\n    />\n  );\n}\n\nclass App extends React.Component {\n  static propTypes = {\n    auth: PropTypes.object.isRequired,\n    config: PropTypes.object.isRequired,\n    collections: ImmutablePropTypes.map.isRequired,\n    loginUser: PropTypes.func.isRequired,\n    logoutUser: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    isFetching: PropTypes.bool.isRequired,\n    publishMode: PropTypes.oneOf([SIMPLE, EDITORIAL_WORKFLOW]),\n    siteId: PropTypes.string,\n    useMediaLibrary: PropTypes.bool,\n    openMediaLibrary: PropTypes.func.isRequired,\n    showMediaButton: PropTypes.bool,\n    t: PropTypes.func.isRequired,\n  };\n\n  configError(config) {\n    const t = this.props.t;\n    return (\n      <ErrorContainer>\n        <h1>{t('app.app.errorHeader')}</h1>\n        <div>\n          <strong>{t('app.app.configErrors')}:</strong>\n          <ErrorCodeBlock>{config.error}</ErrorCodeBlock>\n          <span>{t('app.app.checkConfigYml')}</span>\n        </div>\n      </ErrorContainer>\n    );\n  }\n\n  handleLogin(credentials) {\n    this.props.loginUser(credentials);\n  }\n\n  authenticating() {\n    const { auth, t } = this.props;\n    const backend = currentBackend(this.props.config);\n\n    if (backend == null) {\n      return (\n        <div>\n          <h1>{t('app.app.waitingBackend')}</h1>\n        </div>\n      );\n    }\n\n    return (\n      <div>\n        <Notifications />\n        {React.createElement(backend.authComponent(), {\n          onLogin: this.handleLogin.bind(this),\n          error: auth.error,\n          inProgress: auth.isFetching,\n          siteId: this.props.config.backend.site_domain,\n          base_url: this.props.config.backend.base_url,\n          authEndpoint: this.props.config.backend.auth_endpoint,\n          config: this.props.config,\n          clearHash: () => history.replace('/'),\n          t,\n        })}\n      </div>\n    );\n  }\n\n  handleLinkClick(event, handler, ...args) {\n    event.preventDefault();\n    handler(...args);\n  }\n\n  render() {\n    const {\n      user,\n      config,\n      collections,\n      logoutUser,\n      isFetching,\n      publishMode,\n      useMediaLibrary,\n      openMediaLibrary,\n      t,\n      showMediaButton,\n    } = this.props;\n\n    if (config === null) {\n      return null;\n    }\n\n    if (config.error) {\n      return this.configError(config);\n    }\n\n    if (config.isFetching) {\n      return <Loader active>{t('app.app.loadingConfig')}</Loader>;\n    }\n\n    if (user == null) {\n      return this.authenticating(t);\n    }\n\n    const defaultPath = getDefaultPath(collections);\n    const hasWorkflow = publishMode === EDITORIAL_WORKFLOW;\n\n    return (\n      <>\n        <Notifications />\n        <Header\n          user={user}\n          collections={collections}\n          onCreateEntryClick={createNewEntry}\n          onLogoutClick={logoutUser}\n          openMediaLibrary={openMediaLibrary}\n          hasWorkflow={hasWorkflow}\n          displayUrl={config.display_url}\n          isTestRepo={config.backend.name === 'test-repo'}\n          showMediaButton={showMediaButton}\n        />\n        <AppMainContainer>\n          {isFetching && <TopBarProgress />}\n          <Switch>\n            <Redirect exact from=\"/\" to={defaultPath} />\n            <Redirect exact from=\"/search/\" to={defaultPath} />\n            <RouteInCollection\n              exact\n              collections={collections}\n              path=\"/collections/:name/search/\"\n              render={({ match }) => <Redirect to={`/collections/${match.params.name}`} />}\n            />\n            <Redirect\n              // This happens on Identity + Invite Only + External Provider email not matching\n              // the registered user\n              from=\"/error=access_denied&error_description=Signups+not+allowed+for+this+instance\"\n              to={defaultPath}\n            />\n            {hasWorkflow ? <Route path=\"/workflow\" component={Workflow} /> : null}\n            <RouteInCollection\n              exact\n              collections={collections}\n              path=\"/collections/:name\"\n              render={props => <Collection {...props} />}\n            />\n            <RouteInCollection\n              path=\"/collections/:name/new\"\n              collections={collections}\n              render={props => <Editor {...props} newRecord />}\n            />\n            <RouteInCollection\n              path=\"/collections/:name/entries/*\"\n              collections={collections}\n              render={props => <Editor {...props} />}\n            />\n            <RouteInCollection\n              path=\"/collections/:name/search/:searchTerm\"\n              collections={collections}\n              render={props => <Collection {...props} isSearchResults isSingleSearchResult />}\n            />\n            <RouteInCollection\n              collections={collections}\n              path=\"/collections/:name/filter/:filterTerm*\"\n              render={props => <Collection {...props} />}\n            />\n            <Route\n              path=\"/search/:searchTerm\"\n              render={props => <Collection {...props} isSearchResults />}\n            />\n            <RouteInCollection\n              path=\"/edit/:name/:entryName\"\n              collections={collections}\n              render={({ match }) => {\n                const { name, entryName } = match.params;\n                return <Redirect to={`/collections/${name}/entries/${entryName}`} />;\n              }}\n            />\n            <Route component={NotFoundPage} />\n          </Switch>\n          {useMediaLibrary ? <MediaLibrary /> : null}\n        </AppMainContainer>\n      </>\n    );\n  }\n}\n\nfunction mapStateToProps(state) {\n  const { auth, config, collections, globalUI, mediaLibrary } = state;\n  const user = auth.user;\n  const isFetching = globalUI.isFetching;\n  const publishMode = config.publish_mode;\n  const useMediaLibrary = !mediaLibrary.get('externalLibrary');\n  const showMediaButton = mediaLibrary.get('showMediaButton');\n  return {\n    auth,\n    config,\n    collections,\n    user,\n    isFetching,\n    publishMode,\n    showMediaButton,\n    useMediaLibrary,\n  };\n}\n\nconst mapDispatchToProps = {\n  openMediaLibrary,\n  loginUser,\n  logoutUser,\n};\n\nexport default connect(mapStateToProps, mapDispatchToProps)(translate()(App));\n"]} */",
82
81
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
83
82
  });
84
83
  function getDefaultPath(collections) {
@@ -297,4 +296,4 @@ const mapDispatchToProps = {
297
296
  loginUser: _auth.loginUser,
298
297
  logoutUser: _auth.logoutUser
299
298
  };
300
- var _default = exports.default = (0, _reactHotLoader.hot)(module)((0, _reactRedux.connect)(mapStateToProps, mapDispatchToProps)((0, _reactPolyglot.translate)()(App)));
299
+ var _default = exports.default = (0, _reactRedux.connect)(mapStateToProps, mapDispatchToProps)((0, _reactPolyglot.translate)()(App));
@@ -54,8 +54,8 @@ function buildIssueTemplate({
54
54
  let version = '';
55
55
  if (typeof DECAP_CMS_VERSION === 'string') {
56
56
  version = `decap-cms@${DECAP_CMS_VERSION}`;
57
- } else if (typeof "3.0.10" === 'string') {
58
- version = `decap-cms-app@${"3.0.10"}`;
57
+ } else if (typeof "3.1.0-beta.0" === 'string') {
58
+ version = `decap-cms-app@${"3.1.0-beta.0"}`;
59
59
  }
60
60
  const template = getIssueTemplate({
61
61
  version,
package/index.d.ts CHANGED
@@ -9,6 +9,7 @@ declare module 'decap-cms-core' {
9
9
  | 'git-gateway'
10
10
  | 'github'
11
11
  | 'gitlab'
12
+ | 'gitea'
12
13
  | 'bitbucket'
13
14
  | 'test-repo'
14
15
  | 'proxy';
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "decap-cms-core",
3
3
  "description": "Decap CMS core application, see decap-cms package for the main distribution.",
4
- "version": "3.2.6",
4
+ "version": "3.3.0-beta.0",
5
5
  "repository": "https://github.com/decaporg/decap-cms/tree/master/packages/decap-cms-core",
6
6
  "bugs": "https://github.com/decaporg/decap-cms/issues",
7
7
  "module": "dist/esm/index.js",
@@ -42,12 +42,11 @@
42
42
  "jwt-decode": "^3.0.0",
43
43
  "node-polyglot": "^2.3.0",
44
44
  "prop-types": "^15.7.2",
45
- "react": "^16.8.4",
45
+ "react": "^18.2.0",
46
46
  "react-dnd": "^14.0.0",
47
47
  "react-dnd-html5-backend": "^14.0.0",
48
- "react-dom": "^16.8.4",
48
+ "react-dom": "^18.2.0",
49
49
  "react-frame-component": "^5.2.1",
50
- "react-hot-loader": "^4.8.0",
51
50
  "react-immutable-proptypes": "^2.1.0",
52
51
  "react-is": "16.13.1",
53
52
  "react-markdown": "^6.0.2",
@@ -87,8 +86,8 @@
87
86
  "lodash": "^4.17.11",
88
87
  "moment": "^2.24.0",
89
88
  "prop-types": "^15.7.2",
90
- "react": "^16.8.4 || ^17.0.0",
91
- "react-dom": "^16.8.4 || ^17.0.0",
89
+ "react": "^18.2.0",
90
+ "react-dom": "^18.2.0",
92
91
  "react-immutable-proptypes": "^2.1.0"
93
92
  },
94
93
  "devDependencies": {
@@ -97,5 +96,5 @@
97
96
  "@types/url-join": "^4.0.0",
98
97
  "redux-mock-store": "^1.5.3"
99
98
  },
100
- "gitHead": "d9cb3119d09e7a76b995e477f7578fb5ad80b461"
99
+ "gitHead": "26f650bbfd8b20611ad9bb8957ce2d889a1a9085"
101
100
  }
@@ -1,7 +1,7 @@
1
1
  import { Map } from 'immutable';
2
2
  import configureMockStore from 'redux-mock-store';
3
3
  import thunk from 'redux-thunk';
4
- import { mocked } from 'ts-jest/utils';
4
+ import { mocked } from 'jest-mock';
5
5
 
6
6
  import { getAsset, ADD_ASSET, LOAD_ASSET_REQUEST } from '../media';
7
7
  import { selectMediaFilePath } from '../../reducers/entries';
package/src/bootstrap.js CHANGED
@@ -1,5 +1,5 @@
1
1
  import React from 'react';
2
- import { render } from 'react-dom';
2
+ import { createRoot } from 'react-dom/client';
3
3
  import { Provider, connect } from 'react-redux';
4
4
  import { Route, Router } from 'react-router-dom';
5
5
  import { GlobalStyles } from 'decap-cms-ui-default';
@@ -96,7 +96,8 @@ function bootstrap(opts = {}) {
96
96
  /**
97
97
  * Render application root.
98
98
  */
99
- render(<Root />, getRoot());
99
+ const root = createRoot(getRoot());
100
+ root.render(<Root />);
100
101
  }
101
102
 
102
103
  export default bootstrap;
@@ -1,6 +1,5 @@
1
1
  import PropTypes from 'prop-types';
2
2
  import React from 'react';
3
- import { hot } from 'react-hot-loader';
4
3
  import { translate } from 'react-polyglot';
5
4
  import ImmutablePropTypes from 'react-immutable-proptypes';
6
5
  import styled from '@emotion/styled';
@@ -277,4 +276,4 @@ const mapDispatchToProps = {
277
276
  logoutUser,
278
277
  };
279
278
 
280
- export default hot(module)(connect(mapStateToProps, mapDispatchToProps)(translate()(App)));
279
+ export default connect(mapStateToProps, mapDispatchToProps)(translate()(App));
@@ -65,7 +65,10 @@ describe('Editor', () => {
65
65
  expect(asFragment()).toMatchSnapshot();
66
66
  expect(console.error).toHaveBeenCalledTimes(1);
67
67
  expect(console.error).toHaveBeenCalledWith(
68
- 'Warning: Failed prop type: Required prop `entryDraft` was not specified in `Editor`.\n in Editor',
68
+ 'Warning: Failed %s type: %s%s',
69
+ 'prop',
70
+ 'Required prop `entryDraft` was not specified in `Editor`.',
71
+ expect.anything(),
69
72
  );
70
73
  });
71
74
 
@@ -1,5 +1,5 @@
1
1
  import { createHashHistory } from 'history';
2
- import { mocked } from 'ts-jest/utils';
2
+ import { mocked } from 'jest-mock';
3
3
 
4
4
  import type { History } from 'history';
5
5
 
@@ -17,6 +17,7 @@ export type CmsBackendType =
17
17
  | 'git-gateway'
18
18
  | 'github'
19
19
  | 'gitlab'
20
+ | 'gitea'
20
21
  | 'bitbucket'
21
22
  | 'test-repo'
22
23
  | 'proxy';