decap-cms-core 3.5.0 → 3.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/decap-cms-core.js +9 -9
- package/dist/decap-cms-core.js.map +1 -1
- package/dist/esm/actions/auth.js +22 -37
- package/dist/esm/actions/collections.js +9 -17
- package/dist/esm/actions/config.js +58 -74
- package/dist/esm/actions/deploys.js +10 -17
- package/dist/esm/actions/editorialWorkflow.js +87 -101
- package/dist/esm/actions/entries.js +161 -211
- package/dist/esm/actions/media.js +31 -46
- package/dist/esm/actions/mediaLibrary.js +94 -126
- package/dist/esm/actions/notifications.js +5 -13
- package/dist/esm/actions/search.js +30 -47
- package/dist/esm/actions/status.js +13 -23
- package/dist/esm/actions/waitUntil.js +4 -11
- package/dist/esm/backend.js +132 -148
- package/dist/esm/bootstrap.js +37 -44
- package/dist/esm/components/App/App.js +82 -89
- package/dist/esm/components/App/Header.js +46 -52
- package/dist/esm/components/App/NotFoundPage.js +11 -18
- package/dist/esm/components/Collection/Collection.js +55 -63
- package/dist/esm/components/Collection/CollectionControls.js +15 -22
- package/dist/esm/components/Collection/CollectionSearch.js +35 -42
- package/dist/esm/components/Collection/CollectionTop.js +23 -30
- package/dist/esm/components/Collection/ControlButton.js +10 -16
- package/dist/esm/components/Collection/Entries/Entries.js +24 -31
- package/dist/esm/components/Collection/Entries/EntriesCollection.js +52 -62
- package/dist/esm/components/Collection/Entries/EntriesSearch.js +26 -33
- package/dist/esm/components/Collection/Entries/EntryCard.js +38 -45
- package/dist/esm/components/Collection/Entries/EntryListing.js +24 -32
- package/dist/esm/components/Collection/FilterControl.js +9 -16
- package/dist/esm/components/Collection/GroupControl.js +9 -16
- package/dist/esm/components/Collection/NestedCollection.js +54 -65
- package/dist/esm/components/Collection/Sidebar.js +36 -43
- package/dist/esm/components/Collection/SortControl.js +19 -26
- package/dist/esm/components/Collection/ViewStyleControl.js +17 -24
- package/dist/esm/components/Editor/Editor.js +100 -108
- package/dist/esm/components/Editor/EditorControlPane/EditorControl.js +105 -112
- package/dist/esm/components/Editor/EditorControlPane/EditorControlPane.js +68 -62
- package/dist/esm/components/Editor/EditorControlPane/Widget.js +87 -73
- package/dist/esm/components/Editor/EditorInterface.js +95 -98
- package/dist/esm/components/Editor/EditorPreviewPane/EditorPreview.js +13 -21
- package/dist/esm/components/Editor/EditorPreviewPane/EditorPreviewContent.js +64 -23
- package/dist/esm/components/Editor/EditorPreviewPane/EditorPreviewPane.js +94 -78
- package/dist/esm/components/Editor/EditorPreviewPane/PreviewHOC.js +9 -16
- package/dist/esm/components/Editor/EditorToolbar.js +133 -140
- package/dist/esm/components/Editor/withWorkflow.js +15 -22
- package/dist/esm/components/EditorWidgets/Unknown/UnknownControl.js +9 -16
- package/dist/esm/components/EditorWidgets/Unknown/UnknownPreview.js +9 -16
- package/dist/esm/components/EditorWidgets/index.js +4 -7
- package/dist/esm/components/MediaLibrary/EmptyMessage.js +12 -19
- package/dist/esm/components/MediaLibrary/MediaLibrary.js +55 -62
- package/dist/esm/components/MediaLibrary/MediaLibraryButtons.js +28 -35
- package/dist/esm/components/MediaLibrary/MediaLibraryCard.js +36 -43
- package/dist/esm/components/MediaLibrary/MediaLibraryCardGrid.js +50 -57
- package/dist/esm/components/MediaLibrary/MediaLibraryHeader.js +16 -23
- package/dist/esm/components/MediaLibrary/MediaLibraryModal.js +59 -64
- package/dist/esm/components/MediaLibrary/MediaLibrarySearch.js +18 -25
- package/dist/esm/components/MediaLibrary/MediaLibraryTop.js +39 -46
- package/dist/esm/components/UI/DragDrop.js +21 -30
- package/dist/esm/components/UI/ErrorBoundary.js +35 -43
- package/dist/esm/components/UI/FileUploadButton.js +11 -18
- package/dist/esm/components/UI/Modal.js +19 -26
- package/dist/esm/components/UI/Notifications.js +21 -28
- package/dist/esm/components/UI/SettingsDropdown.js +28 -34
- package/dist/esm/components/UI/index.js +6 -60
- package/dist/esm/components/Workflow/Workflow.js +52 -61
- package/dist/esm/components/Workflow/WorkflowCard.js +45 -51
- package/dist/esm/components/Workflow/WorkflowList.js +43 -49
- package/dist/esm/constants/collectionTypes.js +2 -8
- package/dist/esm/constants/collectionViews.js +2 -8
- package/dist/esm/constants/commitProps.js +2 -8
- package/dist/esm/constants/configSchema.js +20 -27
- package/dist/esm/constants/fieldInference.js +8 -15
- package/dist/esm/constants/publishModes.js +6 -11
- package/dist/esm/constants/validationErrorTypes.js +1 -7
- package/dist/esm/formats/formats.js +32 -41
- package/dist/esm/formats/frontmatter.js +18 -30
- package/dist/esm/formats/helpers.js +1 -7
- package/dist/esm/formats/json.js +1 -7
- package/dist/esm/formats/toml.js +11 -18
- package/dist/esm/formats/yaml.js +7 -14
- package/dist/esm/index.js +5 -12
- package/dist/esm/integrations/index.js +8 -16
- package/dist/esm/integrations/providers/algolia/implementation.js +14 -22
- package/dist/esm/integrations/providers/assetStore/implementation.js +10 -18
- package/dist/esm/lib/consoleError.js +1 -7
- package/dist/esm/lib/formatters.js +34 -47
- package/dist/esm/lib/i18n.js +37 -66
- package/dist/esm/lib/phrases.js +4 -11
- package/dist/esm/lib/registry.js +40 -75
- package/dist/esm/lib/serializeEntryValues.js +11 -18
- package/dist/esm/lib/textHelper.js +1 -7
- package/dist/esm/lib/urlHelper.js +28 -43
- package/dist/esm/mediaLibrary.js +12 -16
- package/dist/esm/reducers/auth.js +10 -16
- package/dist/esm/reducers/collections.js +70 -102
- package/dist/esm/reducers/combinedReducer.js +4 -11
- package/dist/esm/reducers/config.js +11 -19
- package/dist/esm/reducers/cursors.js +12 -18
- package/dist/esm/reducers/deploys.js +8 -15
- package/dist/esm/reducers/editorialWorkflow.js +37 -47
- package/dist/esm/reducers/entries.js +107 -132
- package/dist/esm/reducers/entryDraft.js +64 -72
- package/dist/esm/reducers/globalUI.js +5 -11
- package/dist/esm/reducers/index.js +43 -64
- package/dist/esm/reducers/integrations.js +8 -16
- package/dist/esm/reducers/mediaLibrary.js +43 -52
- package/dist/esm/reducers/medias.js +11 -18
- package/dist/esm/reducers/notifications.js +9 -15
- package/dist/esm/reducers/search.js +12 -18
- package/dist/esm/reducers/status.js +7 -13
- package/dist/esm/redux/index.js +7 -13
- package/dist/esm/redux/middleware/waitUntilAction.js +3 -10
- package/dist/esm/routing/history.js +7 -15
- package/dist/esm/types/diacritics.d.js +0 -1
- package/dist/esm/types/global.d.js +1 -5
- package/dist/esm/types/immutable.js +1 -5
- package/dist/esm/types/redux.js +7 -8
- package/dist/esm/types/tomlify-j0.4.d.js +0 -1
- package/dist/esm/valueObjects/AssetProxy.js +2 -10
- package/dist/esm/valueObjects/EditorComponent.js +5 -12
- package/dist/esm/valueObjects/Entry.js +3 -10
- package/package.json +3 -2
- package/src/components/Collection/Entries/EntriesCollection.js +7 -8
- package/src/components/Collection/Entries/__tests__/EntriesCollection.spec.js +3 -5
- package/src/components/Collection/Entries/__tests__/__snapshots__/EntriesCollection.spec.js.snap +8 -8
- package/src/components/Collection/NestedCollection.js +2 -2
- package/src/components/Collection/__tests__/__snapshots__/NestedCollection.spec.js.snap +68 -0
- package/src/components/Editor/EditorControlPane/EditorControl.js +0 -3
- package/src/components/Editor/EditorControlPane/EditorControlPane.js +21 -8
- package/src/components/Editor/EditorControlPane/Widget.js +22 -1
- package/src/components/Editor/EditorInterface.js +6 -1
- package/src/components/Editor/EditorPreviewPane/EditorPreviewContent.js +51 -11
- package/src/components/Editor/EditorPreviewPane/EditorPreviewPane.js +33 -1
- package/dist/esm/actions/editorControl.js +0 -14
- package/dist/esm/reducers/editorComponent.js +0 -1
- package/dist/esm/reducers/editorControl.js +0 -17
package/dist/esm/bootstrap.js
CHANGED
|
@@ -1,52 +1,45 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
}
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
var _UI = require("./components/UI");
|
|
20
|
-
var _App = _interopRequireDefault(require("./components/App/App"));
|
|
21
|
-
require("./components/EditorWidgets");
|
|
22
|
-
require("./mediaLibrary");
|
|
23
|
-
require("what-input");
|
|
24
|
-
var _react2 = require("@emotion/react");
|
|
25
|
-
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { createRoot } from 'react-dom/client';
|
|
3
|
+
import { Provider, connect } from 'react-redux';
|
|
4
|
+
import { Route, Router } from 'react-router-dom';
|
|
5
|
+
import { GlobalStyles } from 'decap-cms-ui-default';
|
|
6
|
+
import { I18n } from 'react-polyglot';
|
|
7
|
+
import { store } from './redux';
|
|
8
|
+
import { history } from './routing/history';
|
|
9
|
+
import { loadConfig } from './actions/config';
|
|
10
|
+
import { authenticateUser } from './actions/auth';
|
|
11
|
+
import { getPhrases } from './lib/phrases';
|
|
12
|
+
import { selectLocale } from './reducers/config';
|
|
13
|
+
import { ErrorBoundary } from './components/UI';
|
|
14
|
+
import App from './components/App/App';
|
|
15
|
+
import './components/EditorWidgets';
|
|
16
|
+
import './mediaLibrary';
|
|
17
|
+
import 'what-input';
|
|
18
|
+
import { jsx as ___EmotionJSX } from "@emotion/react";
|
|
26
19
|
const ROOT_ID = 'nc-root';
|
|
27
20
|
function TranslatedApp({
|
|
28
21
|
locale,
|
|
29
22
|
config
|
|
30
23
|
}) {
|
|
31
|
-
return (
|
|
24
|
+
return ___EmotionJSX(I18n, {
|
|
32
25
|
locale: locale,
|
|
33
|
-
messages:
|
|
34
|
-
}, (
|
|
26
|
+
messages: getPhrases(locale)
|
|
27
|
+
}, ___EmotionJSX(ErrorBoundary, {
|
|
35
28
|
showBackup: true,
|
|
36
29
|
config: config
|
|
37
|
-
}, (
|
|
38
|
-
history:
|
|
39
|
-
}, (
|
|
40
|
-
component:
|
|
30
|
+
}, ___EmotionJSX(Router, {
|
|
31
|
+
history: history
|
|
32
|
+
}, ___EmotionJSX(Route, {
|
|
33
|
+
component: App
|
|
41
34
|
}))));
|
|
42
35
|
}
|
|
43
36
|
function mapDispatchToProps(state) {
|
|
44
37
|
return {
|
|
45
|
-
locale:
|
|
38
|
+
locale: selectLocale(state.config),
|
|
46
39
|
config: state.config
|
|
47
40
|
};
|
|
48
41
|
}
|
|
49
|
-
const ConnectedTranslatedApp =
|
|
42
|
+
const ConnectedTranslatedApp = connect(mapDispatchToProps)(TranslatedApp);
|
|
50
43
|
function bootstrap(opts = {}) {
|
|
51
44
|
const {
|
|
52
45
|
config
|
|
@@ -55,8 +48,8 @@ function bootstrap(opts = {}) {
|
|
|
55
48
|
/**
|
|
56
49
|
* Log the version number.
|
|
57
50
|
*/
|
|
58
|
-
if (typeof "3.
|
|
59
|
-
console.log(`decap-cms-core ${"3.
|
|
51
|
+
if (typeof "3.6.0" === 'string') {
|
|
52
|
+
console.log(`decap-cms-core ${"3.6.0"}`);
|
|
60
53
|
}
|
|
61
54
|
|
|
62
55
|
/**
|
|
@@ -85,23 +78,23 @@ function bootstrap(opts = {}) {
|
|
|
85
78
|
* config.yml if it exists, and any portion that produces a conflict will be
|
|
86
79
|
* overwritten.
|
|
87
80
|
*/
|
|
88
|
-
|
|
89
|
-
|
|
81
|
+
store.dispatch(loadConfig(config, function onLoad() {
|
|
82
|
+
store.dispatch(authenticateUser());
|
|
90
83
|
}));
|
|
91
84
|
|
|
92
85
|
/**
|
|
93
86
|
* Create connected root component.
|
|
94
87
|
*/
|
|
95
88
|
function Root() {
|
|
96
|
-
return (
|
|
97
|
-
store:
|
|
98
|
-
}, (
|
|
89
|
+
return ___EmotionJSX(React.Fragment, null, ___EmotionJSX(GlobalStyles, null), ___EmotionJSX(Provider, {
|
|
90
|
+
store: store
|
|
91
|
+
}, ___EmotionJSX(ConnectedTranslatedApp, null)));
|
|
99
92
|
}
|
|
100
93
|
|
|
101
94
|
/**
|
|
102
95
|
* Render application root.
|
|
103
96
|
*/
|
|
104
|
-
const root =
|
|
105
|
-
root.render((
|
|
97
|
+
const root = createRoot(getRoot());
|
|
98
|
+
root.render(___EmotionJSX(Root, null));
|
|
106
99
|
}
|
|
107
|
-
|
|
100
|
+
export default bootstrap;
|
|
@@ -1,34 +1,5 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = void 0;
|
|
7
|
-
var _base = _interopRequireDefault(require("@emotion/styled/base"));
|
|
8
|
-
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
9
|
-
var _react = _interopRequireDefault(require("react"));
|
|
10
|
-
var _reactPolyglot = require("react-polyglot");
|
|
11
|
-
var _reactImmutableProptypes = _interopRequireDefault(require("react-immutable-proptypes"));
|
|
12
|
-
var _reactRedux = require("react-redux");
|
|
13
|
-
var _reactRouterDom = require("react-router-dom");
|
|
14
|
-
var _reactTopbarProgressIndicator = _interopRequireDefault(require("react-topbar-progress-indicator"));
|
|
15
|
-
var _decapCmsUiDefault = require("decap-cms-ui-default");
|
|
16
|
-
var _auth = require("../../actions/auth");
|
|
17
|
-
var _backend = require("../../backend");
|
|
18
|
-
var _collections = require("../../actions/collections");
|
|
19
|
-
var _mediaLibrary = require("../../actions/mediaLibrary");
|
|
20
|
-
var _MediaLibrary = _interopRequireDefault(require("../MediaLibrary/MediaLibrary"));
|
|
21
|
-
var _UI = require("../UI");
|
|
22
|
-
var _history = require("../../routing/history");
|
|
23
|
-
var _publishModes = require("../../constants/publishModes");
|
|
24
|
-
var _Collection = _interopRequireDefault(require("../Collection/Collection"));
|
|
25
|
-
var _Workflow = _interopRequireDefault(require("../Workflow/Workflow"));
|
|
26
|
-
var _Editor = _interopRequireDefault(require("../Editor/Editor"));
|
|
27
|
-
var _NotFoundPage = _interopRequireDefault(require("./NotFoundPage"));
|
|
28
|
-
var _Header = _interopRequireDefault(require("./Header"));
|
|
29
|
-
var _react2 = require("@emotion/react");
|
|
1
|
+
import _styled from "@emotion/styled/base";
|
|
30
2
|
const _excluded = ["collections", "render"];
|
|
31
|
-
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
32
3
|
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
33
4
|
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : String(i); }
|
|
34
5
|
function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
|
@@ -36,15 +7,37 @@ function _extends() { _extends = Object.assign ? Object.assign.bind() : function
|
|
|
36
7
|
function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
|
|
37
8
|
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
|
|
38
9
|
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
39
|
-
|
|
10
|
+
import PropTypes from 'prop-types';
|
|
11
|
+
import React from 'react';
|
|
12
|
+
import { translate } from 'react-polyglot';
|
|
13
|
+
import ImmutablePropTypes from 'react-immutable-proptypes';
|
|
14
|
+
import { connect } from 'react-redux';
|
|
15
|
+
import { Route, Switch, Redirect } from 'react-router-dom';
|
|
16
|
+
import TopBarProgress from 'react-topbar-progress-indicator';
|
|
17
|
+
import { Loader, colors } from 'decap-cms-ui-default';
|
|
18
|
+
import { loginUser, logoutUser } from '../../actions/auth';
|
|
19
|
+
import { currentBackend } from '../../backend';
|
|
20
|
+
import { createNewEntry } from '../../actions/collections';
|
|
21
|
+
import { openMediaLibrary } from '../../actions/mediaLibrary';
|
|
22
|
+
import MediaLibrary from '../MediaLibrary/MediaLibrary';
|
|
23
|
+
import { Notifications } from '../UI';
|
|
24
|
+
import { history } from '../../routing/history';
|
|
25
|
+
import { SIMPLE, EDITORIAL_WORKFLOW } from '../../constants/publishModes';
|
|
26
|
+
import Collection from '../Collection/Collection';
|
|
27
|
+
import Workflow from '../Workflow/Workflow';
|
|
28
|
+
import Editor from '../Editor/Editor';
|
|
29
|
+
import NotFoundPage from './NotFoundPage';
|
|
30
|
+
import Header from './Header';
|
|
31
|
+
import { jsx as ___EmotionJSX } from "@emotion/react";
|
|
32
|
+
TopBarProgress.config({
|
|
40
33
|
barColors: {
|
|
41
|
-
0:
|
|
42
|
-
'1.0':
|
|
34
|
+
0: colors.active,
|
|
35
|
+
'1.0': colors.active
|
|
43
36
|
},
|
|
44
37
|
shadowBlur: 0,
|
|
45
38
|
barThickness: 2
|
|
46
39
|
});
|
|
47
|
-
const AppMainContainer = /*#__PURE__*/(
|
|
40
|
+
const AppMainContainer = /*#__PURE__*/_styled("div", {
|
|
48
41
|
target: "eh2m33j2",
|
|
49
42
|
label: "AppMainContainer"
|
|
50
43
|
})(process.env.NODE_ENV === "production" ? {
|
|
@@ -56,7 +49,7 @@ const AppMainContainer = /*#__PURE__*/(0, _base.default)("div", {
|
|
|
56
49
|
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"]} */",
|
|
57
50
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
58
51
|
});
|
|
59
|
-
const ErrorContainer = /*#__PURE__*/(
|
|
52
|
+
const ErrorContainer = /*#__PURE__*/_styled("div", {
|
|
60
53
|
target: "eh2m33j1",
|
|
61
54
|
label: "ErrorContainer"
|
|
62
55
|
})(process.env.NODE_ENV === "production" ? {
|
|
@@ -68,7 +61,7 @@ const ErrorContainer = /*#__PURE__*/(0, _base.default)("div", {
|
|
|
68
61
|
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"]} */",
|
|
69
62
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
70
63
|
});
|
|
71
|
-
const ErrorCodeBlock = /*#__PURE__*/(
|
|
64
|
+
const ErrorCodeBlock = /*#__PURE__*/_styled("pre", {
|
|
72
65
|
target: "eh2m33j0",
|
|
73
66
|
label: "ErrorCodeBlock"
|
|
74
67
|
})(process.env.NODE_ENV === "production" ? {
|
|
@@ -95,19 +88,19 @@ function RouteInCollection(_ref) {
|
|
|
95
88
|
} = _ref,
|
|
96
89
|
props = _objectWithoutProperties(_ref, _excluded);
|
|
97
90
|
const defaultPath = getDefaultPath(collections);
|
|
98
|
-
return (
|
|
91
|
+
return ___EmotionJSX(Route, _extends({}, props, {
|
|
99
92
|
render: routeProps => {
|
|
100
93
|
const collectionExists = collections.get(routeProps.match.params.name);
|
|
101
|
-
return collectionExists ? render(routeProps) : (
|
|
94
|
+
return collectionExists ? render(routeProps) : ___EmotionJSX(Redirect, {
|
|
102
95
|
to: defaultPath
|
|
103
96
|
});
|
|
104
97
|
}
|
|
105
98
|
}));
|
|
106
99
|
}
|
|
107
|
-
class App extends
|
|
100
|
+
class App extends React.Component {
|
|
108
101
|
configError(config) {
|
|
109
102
|
const t = this.props.t;
|
|
110
|
-
return (
|
|
103
|
+
return ___EmotionJSX(ErrorContainer, null, ___EmotionJSX("h1", null, t('app.app.errorHeader')), ___EmotionJSX("div", null, ___EmotionJSX("strong", null, t('app.app.configErrors'), ":"), ___EmotionJSX(ErrorCodeBlock, null, config.error), ___EmotionJSX("span", null, t('app.app.checkConfigYml'))));
|
|
111
104
|
}
|
|
112
105
|
handleLogin(credentials) {
|
|
113
106
|
this.props.loginUser(credentials);
|
|
@@ -117,11 +110,11 @@ class App extends _react.default.Component {
|
|
|
117
110
|
auth,
|
|
118
111
|
t
|
|
119
112
|
} = this.props;
|
|
120
|
-
const backend =
|
|
113
|
+
const backend = currentBackend(this.props.config);
|
|
121
114
|
if (backend == null) {
|
|
122
|
-
return (
|
|
115
|
+
return ___EmotionJSX("div", null, ___EmotionJSX("h1", null, t('app.app.waitingBackend')));
|
|
123
116
|
}
|
|
124
|
-
return (
|
|
117
|
+
return ___EmotionJSX("div", null, ___EmotionJSX(Notifications, null), /*#__PURE__*/React.createElement(backend.authComponent(), {
|
|
125
118
|
onLogin: this.handleLogin.bind(this),
|
|
126
119
|
error: auth.error,
|
|
127
120
|
inProgress: auth.isFetching,
|
|
@@ -129,7 +122,7 @@ class App extends _react.default.Component {
|
|
|
129
122
|
base_url: this.props.config.backend.base_url,
|
|
130
123
|
authEndpoint: this.props.config.backend.auth_endpoint,
|
|
131
124
|
config: this.props.config,
|
|
132
|
-
clearHash: () =>
|
|
125
|
+
clearHash: () => history.replace('/'),
|
|
133
126
|
t
|
|
134
127
|
}));
|
|
135
128
|
}
|
|
@@ -157,7 +150,7 @@ class App extends _react.default.Component {
|
|
|
157
150
|
return this.configError(config);
|
|
158
151
|
}
|
|
159
152
|
if (config.isFetching) {
|
|
160
|
-
return (
|
|
153
|
+
return ___EmotionJSX(Loader, {
|
|
161
154
|
active: true
|
|
162
155
|
}, t('app.app.loadingConfig'));
|
|
163
156
|
}
|
|
@@ -165,75 +158,75 @@ class App extends _react.default.Component {
|
|
|
165
158
|
return this.authenticating(t);
|
|
166
159
|
}
|
|
167
160
|
const defaultPath = getDefaultPath(collections);
|
|
168
|
-
const hasWorkflow = publishMode ===
|
|
169
|
-
return (
|
|
161
|
+
const hasWorkflow = publishMode === EDITORIAL_WORKFLOW;
|
|
162
|
+
return ___EmotionJSX(React.Fragment, null, ___EmotionJSX(Notifications, null), ___EmotionJSX(Header, {
|
|
170
163
|
user: user,
|
|
171
164
|
collections: collections,
|
|
172
|
-
onCreateEntryClick:
|
|
165
|
+
onCreateEntryClick: createNewEntry,
|
|
173
166
|
onLogoutClick: logoutUser,
|
|
174
167
|
openMediaLibrary: openMediaLibrary,
|
|
175
168
|
hasWorkflow: hasWorkflow,
|
|
176
169
|
displayUrl: config.display_url,
|
|
177
170
|
isTestRepo: config.backend.name === 'test-repo',
|
|
178
171
|
showMediaButton: showMediaButton
|
|
179
|
-
}), (
|
|
172
|
+
}), ___EmotionJSX(AppMainContainer, null, isFetching && ___EmotionJSX(TopBarProgress, null), ___EmotionJSX(Switch, null, ___EmotionJSX(Redirect, {
|
|
180
173
|
exact: true,
|
|
181
174
|
from: "/",
|
|
182
175
|
to: defaultPath
|
|
183
|
-
}), (
|
|
176
|
+
}), ___EmotionJSX(Redirect, {
|
|
184
177
|
exact: true,
|
|
185
178
|
from: "/search/",
|
|
186
179
|
to: defaultPath
|
|
187
|
-
}), (
|
|
180
|
+
}), ___EmotionJSX(RouteInCollection, {
|
|
188
181
|
exact: true,
|
|
189
182
|
collections: collections,
|
|
190
183
|
path: "/collections/:name/search/",
|
|
191
184
|
render: ({
|
|
192
185
|
match
|
|
193
|
-
}) => (
|
|
186
|
+
}) => ___EmotionJSX(Redirect, {
|
|
194
187
|
to: `/collections/${match.params.name}`
|
|
195
188
|
})
|
|
196
|
-
}), (
|
|
189
|
+
}), ___EmotionJSX(Redirect
|
|
197
190
|
// This happens on Identity + Invite Only + External Provider email not matching
|
|
198
191
|
// the registered user
|
|
199
192
|
, {
|
|
200
193
|
from: "/error=access_denied&error_description=Signups+not+allowed+for+this+instance",
|
|
201
194
|
to: defaultPath
|
|
202
|
-
}), hasWorkflow ? (
|
|
195
|
+
}), hasWorkflow ? ___EmotionJSX(Route, {
|
|
203
196
|
path: "/workflow",
|
|
204
|
-
component:
|
|
205
|
-
}) : null, (
|
|
197
|
+
component: Workflow
|
|
198
|
+
}) : null, ___EmotionJSX(RouteInCollection, {
|
|
206
199
|
exact: true,
|
|
207
200
|
collections: collections,
|
|
208
201
|
path: "/collections/:name",
|
|
209
|
-
render: props => (
|
|
210
|
-
}), (
|
|
202
|
+
render: props => ___EmotionJSX(Collection, props)
|
|
203
|
+
}), ___EmotionJSX(RouteInCollection, {
|
|
211
204
|
path: "/collections/:name/new",
|
|
212
205
|
collections: collections,
|
|
213
|
-
render: props => (
|
|
206
|
+
render: props => ___EmotionJSX(Editor, _extends({}, props, {
|
|
214
207
|
newRecord: true
|
|
215
208
|
}))
|
|
216
|
-
}), (
|
|
209
|
+
}), ___EmotionJSX(RouteInCollection, {
|
|
217
210
|
path: "/collections/:name/entries/*",
|
|
218
211
|
collections: collections,
|
|
219
|
-
render: props => (
|
|
220
|
-
}), (
|
|
212
|
+
render: props => ___EmotionJSX(Editor, props)
|
|
213
|
+
}), ___EmotionJSX(RouteInCollection, {
|
|
221
214
|
path: "/collections/:name/search/:searchTerm",
|
|
222
215
|
collections: collections,
|
|
223
|
-
render: props => (
|
|
216
|
+
render: props => ___EmotionJSX(Collection, _extends({}, props, {
|
|
224
217
|
isSearchResults: true,
|
|
225
218
|
isSingleSearchResult: true
|
|
226
219
|
}))
|
|
227
|
-
}), (
|
|
220
|
+
}), ___EmotionJSX(RouteInCollection, {
|
|
228
221
|
collections: collections,
|
|
229
222
|
path: "/collections/:name/filter/:filterTerm*",
|
|
230
|
-
render: props => (
|
|
231
|
-
}), (
|
|
223
|
+
render: props => ___EmotionJSX(Collection, props)
|
|
224
|
+
}), ___EmotionJSX(Route, {
|
|
232
225
|
path: "/search/:searchTerm",
|
|
233
|
-
render: props => (
|
|
226
|
+
render: props => ___EmotionJSX(Collection, _extends({}, props, {
|
|
234
227
|
isSearchResults: true
|
|
235
228
|
}))
|
|
236
|
-
}), (
|
|
229
|
+
}), ___EmotionJSX(RouteInCollection, {
|
|
237
230
|
path: "/edit/:name/:entryName",
|
|
238
231
|
collections: collections,
|
|
239
232
|
render: ({
|
|
@@ -243,29 +236,29 @@ class App extends _react.default.Component {
|
|
|
243
236
|
name,
|
|
244
237
|
entryName
|
|
245
238
|
} = match.params;
|
|
246
|
-
return (
|
|
239
|
+
return ___EmotionJSX(Redirect, {
|
|
247
240
|
to: `/collections/${name}/entries/${entryName}`
|
|
248
241
|
});
|
|
249
242
|
}
|
|
250
|
-
}), (
|
|
251
|
-
component:
|
|
252
|
-
})), useMediaLibrary ? (
|
|
243
|
+
}), ___EmotionJSX(Route, {
|
|
244
|
+
component: NotFoundPage
|
|
245
|
+
})), useMediaLibrary ? ___EmotionJSX(MediaLibrary, null) : null));
|
|
253
246
|
}
|
|
254
247
|
}
|
|
255
248
|
_defineProperty(App, "propTypes", {
|
|
256
|
-
auth:
|
|
257
|
-
config:
|
|
258
|
-
collections:
|
|
259
|
-
loginUser:
|
|
260
|
-
logoutUser:
|
|
261
|
-
user:
|
|
262
|
-
isFetching:
|
|
263
|
-
publishMode:
|
|
264
|
-
siteId:
|
|
265
|
-
useMediaLibrary:
|
|
266
|
-
openMediaLibrary:
|
|
267
|
-
showMediaButton:
|
|
268
|
-
t:
|
|
249
|
+
auth: PropTypes.object.isRequired,
|
|
250
|
+
config: PropTypes.object.isRequired,
|
|
251
|
+
collections: ImmutablePropTypes.map.isRequired,
|
|
252
|
+
loginUser: PropTypes.func.isRequired,
|
|
253
|
+
logoutUser: PropTypes.func.isRequired,
|
|
254
|
+
user: PropTypes.object,
|
|
255
|
+
isFetching: PropTypes.bool.isRequired,
|
|
256
|
+
publishMode: PropTypes.oneOf([SIMPLE, EDITORIAL_WORKFLOW]),
|
|
257
|
+
siteId: PropTypes.string,
|
|
258
|
+
useMediaLibrary: PropTypes.bool,
|
|
259
|
+
openMediaLibrary: PropTypes.func.isRequired,
|
|
260
|
+
showMediaButton: PropTypes.bool,
|
|
261
|
+
t: PropTypes.func.isRequired
|
|
269
262
|
});
|
|
270
263
|
function mapStateToProps(state) {
|
|
271
264
|
const {
|
|
@@ -292,8 +285,8 @@ function mapStateToProps(state) {
|
|
|
292
285
|
};
|
|
293
286
|
}
|
|
294
287
|
const mapDispatchToProps = {
|
|
295
|
-
openMediaLibrary
|
|
296
|
-
loginUser
|
|
297
|
-
logoutUser
|
|
288
|
+
openMediaLibrary,
|
|
289
|
+
loginUser,
|
|
290
|
+
logoutUser
|
|
298
291
|
};
|
|
299
|
-
|
|
292
|
+
export default connect(mapStateToProps, mapDispatchToProps)(translate()(App));
|