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
|
@@ -1,20 +1,13 @@
|
|
|
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 _react = _interopRequireDefault(require("react"));
|
|
9
|
-
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
10
|
-
var _reactImmutableProptypes = _interopRequireDefault(require("react-immutable-proptypes"));
|
|
11
|
-
var _react2 = require("@emotion/react");
|
|
12
|
-
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
1
|
+
import _styled from "@emotion/styled/base";
|
|
13
2
|
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)."; }
|
|
3
|
+
import React from 'react';
|
|
4
|
+
import PropTypes from 'prop-types';
|
|
5
|
+
import ImmutablePropTypes from 'react-immutable-proptypes';
|
|
6
|
+
import { jsx as ___EmotionJSX } from "@emotion/react";
|
|
14
7
|
function isVisible(field) {
|
|
15
8
|
return field.get('widget') !== 'hidden';
|
|
16
9
|
}
|
|
17
|
-
const PreviewContainer = /*#__PURE__*/(
|
|
10
|
+
const PreviewContainer = /*#__PURE__*/_styled("div", {
|
|
18
11
|
target: "e1iji6y40",
|
|
19
12
|
label: "PreviewContainer"
|
|
20
13
|
})(process.env.NODE_ENV === "production" ? {
|
|
@@ -31,7 +24,7 @@ const PreviewContainer = /*#__PURE__*/(0, _base.default)("div", {
|
|
|
31
24
|
* Use a stateful component so that child components can effectively utilize
|
|
32
25
|
* `shouldComponentUpdate`.
|
|
33
26
|
*/
|
|
34
|
-
class Preview extends
|
|
27
|
+
export default class Preview extends React.Component {
|
|
35
28
|
render() {
|
|
36
29
|
const {
|
|
37
30
|
collection,
|
|
@@ -41,16 +34,15 @@ class Preview extends _react.default.Component {
|
|
|
41
34
|
if (!collection || !fields) {
|
|
42
35
|
return null;
|
|
43
36
|
}
|
|
44
|
-
return (
|
|
37
|
+
return ___EmotionJSX(PreviewContainer, null, fields.filter(isVisible).map(field => ___EmotionJSX("div", {
|
|
45
38
|
key: field.get('name')
|
|
46
39
|
}, widgetFor(field.get('name')))));
|
|
47
40
|
}
|
|
48
41
|
}
|
|
49
|
-
exports.default = Preview;
|
|
50
42
|
Preview.propTypes = {
|
|
51
|
-
collection:
|
|
52
|
-
entry:
|
|
53
|
-
fields:
|
|
54
|
-
getAsset:
|
|
55
|
-
widgetFor:
|
|
43
|
+
collection: ImmutablePropTypes.map.isRequired,
|
|
44
|
+
entry: ImmutablePropTypes.map.isRequired,
|
|
45
|
+
fields: ImmutablePropTypes.list.isRequired,
|
|
46
|
+
getAsset: PropTypes.func.isRequired,
|
|
47
|
+
widgetFor: PropTypes.func.isRequired
|
|
56
48
|
};
|
|
@@ -1,33 +1,74 @@
|
|
|
1
|
-
|
|
1
|
+
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; }
|
|
2
|
+
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : String(i); }
|
|
3
|
+
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); }
|
|
4
|
+
import PropTypes from 'prop-types';
|
|
5
|
+
import React from 'react';
|
|
6
|
+
import { isElement } from 'react-is';
|
|
7
|
+
import { ScrollSyncPane } from 'react-scroll-sync';
|
|
8
|
+
import { FrameContextConsumer } from 'react-frame-component';
|
|
9
|
+
import { vercelStegaDecode } from '@vercel/stega';
|
|
2
10
|
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = void 0;
|
|
7
|
-
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
8
|
-
var _react = _interopRequireDefault(require("react"));
|
|
9
|
-
var _reactIs = require("react-is");
|
|
10
|
-
var _reactScrollSync = require("react-scroll-sync");
|
|
11
|
-
var _reactFrameComponent = require("react-frame-component");
|
|
12
|
-
var _react2 = require("@emotion/react");
|
|
13
|
-
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
14
11
|
/**
|
|
15
|
-
*
|
|
16
|
-
*
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
12
|
+
* PreviewContent renders the preview component and optionally handles visual editing interactions.
|
|
13
|
+
* By default it uses scroll sync, but can be configured to use visual editing instead.
|
|
14
|
+
*/
|
|
15
|
+
import { jsx as ___EmotionJSX } from "@emotion/react";
|
|
16
|
+
class PreviewContent extends React.Component {
|
|
17
|
+
constructor(...args) {
|
|
18
|
+
super(...args);
|
|
19
|
+
_defineProperty(this, "handleClick", e => {
|
|
20
|
+
var _previewProps$collect;
|
|
21
|
+
const {
|
|
22
|
+
previewProps,
|
|
23
|
+
onFieldClick
|
|
24
|
+
} = this.props;
|
|
25
|
+
const visualEditing = previewProps === null || previewProps === void 0 ? void 0 : (_previewProps$collect = previewProps.collection) === null || _previewProps$collect === void 0 ? void 0 : _previewProps$collect.getIn(['editor', 'visualEditing'], false);
|
|
26
|
+
if (!visualEditing) {
|
|
27
|
+
return;
|
|
28
|
+
}
|
|
29
|
+
try {
|
|
30
|
+
const text = e.target.textContent;
|
|
31
|
+
const decoded = vercelStegaDecode(text);
|
|
32
|
+
if (decoded !== null && decoded !== void 0 && decoded.decap) {
|
|
33
|
+
if (onFieldClick) {
|
|
34
|
+
onFieldClick(decoded.decap);
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
} catch (err) {
|
|
38
|
+
console.log('Visual editing error:', err);
|
|
39
|
+
}
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
renderPreview() {
|
|
20
43
|
const {
|
|
21
44
|
previewComponent,
|
|
22
45
|
previewProps
|
|
23
46
|
} = this.props;
|
|
24
|
-
return (
|
|
25
|
-
|
|
26
|
-
},
|
|
47
|
+
return ___EmotionJSX("div", {
|
|
48
|
+
onClick: this.handleClick
|
|
49
|
+
}, isElement(previewComponent) ? /*#__PURE__*/React.cloneElement(previewComponent, previewProps) : /*#__PURE__*/React.createElement(previewComponent, previewProps));
|
|
50
|
+
}
|
|
51
|
+
render() {
|
|
52
|
+
var _previewProps$collect2;
|
|
53
|
+
const {
|
|
54
|
+
previewProps
|
|
55
|
+
} = this.props;
|
|
56
|
+
const visualEditing = previewProps === null || previewProps === void 0 ? void 0 : (_previewProps$collect2 = previewProps.collection) === null || _previewProps$collect2 === void 0 ? void 0 : _previewProps$collect2.getIn(['editor', 'visualEditing'], false);
|
|
57
|
+
const showScrollSync = !visualEditing;
|
|
58
|
+
return ___EmotionJSX(FrameContextConsumer, null, context => {
|
|
59
|
+
const preview = this.renderPreview();
|
|
60
|
+
if (showScrollSync) {
|
|
61
|
+
return ___EmotionJSX(ScrollSyncPane, {
|
|
62
|
+
attachTo: context.document.scrollingElement
|
|
63
|
+
}, preview);
|
|
64
|
+
}
|
|
65
|
+
return preview;
|
|
66
|
+
});
|
|
27
67
|
}
|
|
28
68
|
}
|
|
29
69
|
PreviewContent.propTypes = {
|
|
30
|
-
previewComponent:
|
|
31
|
-
previewProps:
|
|
70
|
+
previewComponent: PropTypes.func.isRequired,
|
|
71
|
+
previewProps: PropTypes.object,
|
|
72
|
+
onFieldClick: PropTypes.func
|
|
32
73
|
};
|
|
33
|
-
|
|
74
|
+
export default PreviewContent;
|
|
@@ -1,41 +1,33 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = exports.PreviewPane = 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 _immutable = require("immutable");
|
|
11
|
-
var _reactImmutableProptypes = _interopRequireDefault(require("react-immutable-proptypes"));
|
|
12
|
-
var _reactFrameComponent = _interopRequireWildcard(require("react-frame-component"));
|
|
13
|
-
var _decapCmsUiDefault = require("decap-cms-ui-default");
|
|
14
|
-
var _reactRedux = require("react-redux");
|
|
15
|
-
var _registry = require("../../../lib/registry");
|
|
16
|
-
var _entries = require("../../../actions/entries");
|
|
17
|
-
var _UI = require("../../UI");
|
|
18
|
-
var _collections = require("../../../reducers/collections");
|
|
19
|
-
var _media = require("../../../actions/media");
|
|
20
|
-
var _medias = require("../../../reducers/medias");
|
|
21
|
-
var _fieldInference = require("../../../constants/fieldInference");
|
|
22
|
-
var _EditorPreviewContent = _interopRequireDefault(require("./EditorPreviewContent.js"));
|
|
23
|
-
var _PreviewHOC = _interopRequireDefault(require("./PreviewHOC"));
|
|
24
|
-
var _EditorPreview = _interopRequireDefault(require("./EditorPreview"));
|
|
25
|
-
var _react2 = require("@emotion/react");
|
|
26
|
-
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
|
|
27
|
-
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
|
|
28
|
-
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
1
|
+
import _styled from "@emotion/styled/base";
|
|
29
2
|
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
30
3
|
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
31
4
|
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; }
|
|
32
5
|
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : String(i); }
|
|
33
6
|
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); }
|
|
34
|
-
|
|
7
|
+
import PropTypes from 'prop-types';
|
|
8
|
+
import React from 'react';
|
|
9
|
+
import { List, Map } from 'immutable';
|
|
10
|
+
import ImmutablePropTypes from 'react-immutable-proptypes';
|
|
11
|
+
import Frame, { FrameContextConsumer } from 'react-frame-component';
|
|
12
|
+
import { lengths } from 'decap-cms-ui-default';
|
|
13
|
+
import { connect } from 'react-redux';
|
|
14
|
+
import { encodeEntry } from 'decap-cms-lib-util/src/stega';
|
|
15
|
+
import { resolveWidget, getPreviewTemplate, getPreviewStyles, getRemarkPlugins } from '../../../lib/registry';
|
|
16
|
+
import { getAllEntries, tryLoadEntry } from '../../../actions/entries';
|
|
17
|
+
import { ErrorBoundary } from '../../UI';
|
|
18
|
+
import { selectTemplateName, selectInferredField, selectField } from '../../../reducers/collections';
|
|
19
|
+
import { boundGetAsset } from '../../../actions/media';
|
|
20
|
+
import { selectIsLoadingAsset } from '../../../reducers/medias';
|
|
21
|
+
import { INFERABLE_FIELDS } from '../../../constants/fieldInference';
|
|
22
|
+
import EditorPreviewContent from './EditorPreviewContent.js';
|
|
23
|
+
import PreviewHOC from './PreviewHOC';
|
|
24
|
+
import EditorPreview from './EditorPreview';
|
|
25
|
+
import { jsx as ___EmotionJSX } from "@emotion/react";
|
|
26
|
+
const PreviewPaneFrame = /*#__PURE__*/_styled(Frame, {
|
|
35
27
|
target: "enus48h0",
|
|
36
28
|
label: "PreviewPaneFrame"
|
|
37
|
-
})("width:100%;height:100%;border:none;background:#fff;border-radius:", _decapCmsUiDefault.lengths.borderRadius, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorPreviewPane/EditorPreviewPane.js"],"names":[],"mappings":"AA6BsC","file":"../../../../../src/components/Editor/EditorPreviewPane/EditorPreviewPane.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport { List, Map } from 'immutable';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport Frame, { FrameContextConsumer } from 'react-frame-component';\nimport { lengths } from 'decap-cms-ui-default';\nimport { connect } from 'react-redux';\n\nimport {\n  resolveWidget,\n  getPreviewTemplate,\n  getPreviewStyles,\n  getRemarkPlugins,\n} from '../../../lib/registry';\nimport { getAllEntries, tryLoadEntry } from '../../../actions/entries';\nimport { ErrorBoundary } from '../../UI';\nimport {\n  selectTemplateName,\n  selectInferredField,\n  selectField,\n} from '../../../reducers/collections';\nimport { boundGetAsset } from '../../../actions/media';\nimport { selectIsLoadingAsset } from '../../../reducers/medias';\nimport { INFERABLE_FIELDS } from '../../../constants/fieldInference';\nimport EditorPreviewContent from './EditorPreviewContent.js';\nimport PreviewHOC from './PreviewHOC';\nimport EditorPreview from './EditorPreview';\n\nconst PreviewPaneFrame = styled(Frame)`\n  width: 100%;\n  height: 100%;\n  border: none;\n  background: #fff;\n  border-radius: ${lengths.borderRadius};\n`;\n\nexport class PreviewPane extends React.Component {\n  getWidget = (field, value, metadata, props, idx = null) => {\n    const { getAsset, entry } = props;\n    const widget = resolveWidget(field.get('widget'));\n    const key = idx ? field.get('name') + '_' + idx : field.get('name');\n    const valueIsInMap = value && !widget.allowMapValue && Map.isMap(value);\n\n    /**\n     * Use an HOC to provide conditional updates for all previews.\n     */\n    return !widget.preview ? null : (\n      <PreviewHOC\n        previewComponent={widget.preview}\n        key={key}\n        field={field}\n        getAsset={getAsset}\n        value={valueIsInMap ? value.get(field.get('name')) : value}\n        entry={entry}\n        fieldsMetaData={metadata}\n        resolveWidget={resolveWidget}\n        getRemarkPlugins={getRemarkPlugins}\n      />\n    );\n  };\n\n  inferredFields = {};\n\n  inferFields() {\n    const titleField = selectInferredField(this.props.collection, 'title');\n    const shortTitleField = selectInferredField(this.props.collection, 'shortTitle');\n    const authorField = selectInferredField(this.props.collection, 'author');\n\n    this.inferredFields = {};\n    if (titleField) this.inferredFields[titleField] = INFERABLE_FIELDS.title;\n    if (shortTitleField) this.inferredFields[shortTitleField] = INFERABLE_FIELDS.shortTitle;\n    if (authorField) this.inferredFields[authorField] = INFERABLE_FIELDS.author;\n  }\n\n  /**\n   * Returns the widget component for a named field, and makes recursive calls\n   * to retrieve components for nested and deeply nested fields, which occur in\n   * object and list type fields. Used internally to retrieve widgets, and also\n   * exposed for use in custom preview templates.\n   */\n  widgetFor = (\n    name,\n    fields = this.props.fields,\n    values = this.props.entry.get('data'),\n    fieldsMetaData = this.props.fieldsMetaData,\n  ) => {\n    // We retrieve the field by name so that this function can also be used in\n    // custom preview templates, where the field object can't be passed in.\n    let field = fields && fields.find(f => f.get('name') === name);\n    let value = Map.isMap(values) && values.get(field.get('name'));\n    if (field.get('meta')) {\n      value = this.props.entry.getIn(['meta', field.get('name')]);\n    }\n    const nestedFields = field.get('fields');\n    const singleField = field.get('field');\n    const metadata = fieldsMetaData && fieldsMetaData.get(field.get('name'), Map());\n\n    if (nestedFields) {\n      field = field.set('fields', this.getNestedWidgets(nestedFields, value, metadata));\n    }\n\n    if (singleField) {\n      field = field.set('field', this.getSingleNested(singleField, value, metadata));\n    }\n\n    const labelledWidgets = ['string', 'text', 'number'];\n    const inferredField = Object.entries(this.inferredFields)\n      .filter(([key]) => {\n        const fieldToMatch = selectField(this.props.collection, key);\n        return fieldToMatch === field;\n      })\n      .map(([, value]) => value)[0];\n\n    if (inferredField) {\n      value = inferredField.defaultPreview(value);\n    } else if (\n      value &&\n      labelledWidgets.indexOf(field.get('widget')) !== -1 &&\n      value.toString().length < 50\n    ) {\n      value = (\n        <div>\n          <strong>{field.get('label', field.get('name'))}:</strong> {value}\n        </div>\n      );\n    }\n\n    return value ? this.getWidget(field, value, metadata, this.props) : null;\n  };\n\n  /**\n   * Retrieves widgets for nested fields (children of object/list fields)\n   */\n  getNestedWidgets = (fields, values, fieldsMetaData) => {\n    // Fields nested within a list field will be paired with a List of value Maps.\n    if (List.isList(values)) {\n      return values.map(value => this.widgetsForNestedFields(fields, value, fieldsMetaData));\n    }\n    // Fields nested within an object field will be paired with a single Map of values.\n    return this.widgetsForNestedFields(fields, values, fieldsMetaData);\n  };\n\n  getSingleNested = (field, values, fieldsMetaData) => {\n    if (List.isList(values)) {\n      return values.map((value, idx) =>\n        this.getWidget(field, value, fieldsMetaData.get(field.get('name')), this.props, idx),\n      );\n    }\n    return this.getWidget(field, values, fieldsMetaData.get(field.get('name')), this.props);\n  };\n\n  /**\n   * Use widgetFor as a mapping function for recursive widget retrieval\n   */\n  widgetsForNestedFields = (fields, values, fieldsMetaData) => {\n    return fields.map(field => this.widgetFor(field.get('name'), fields, values, fieldsMetaData));\n  };\n\n  /**\n   * This function exists entirely to expose nested widgets for object and list\n   * fields to custom preview templates.\n   *\n   * TODO: see if widgetFor can now provide this functionality for preview templates\n   */\n  widgetsFor = name => {\n    const { fields, entry, fieldsMetaData } = this.props;\n    const field = fields.find(f => f.get('name') === name);\n    const nestedFields = field && field.get('fields');\n    const value = entry.getIn(['data', field.get('name')]);\n    const metadata = fieldsMetaData.get(field.get('name'), Map());\n\n    if (List.isList(value)) {\n      return value.map(val => {\n        const widgets =\n          nestedFields &&\n          Map(\n            nestedFields.map((f, i) => [\n              f.get('name'),\n              <div key={i}>{this.getWidget(f, val, metadata.get(f.get('name')), this.props)}</div>,\n            ]),\n          );\n        return Map({ data: val, widgets });\n      });\n    }\n\n    return Map({\n      data: value,\n      widgets:\n        nestedFields &&\n        Map(\n          nestedFields.map(f => [\n            f.get('name'),\n            this.getWidget(f, value, metadata.get(f.get('name')), this.props),\n          ]),\n        ),\n    });\n  };\n\n  /**\n   * This function exists entirely to expose collections from outside of this entry\n   *\n   */\n  getCollection = async (collectionName, slug) => {\n    const { state } = this.props;\n    const selectedCollection = state.collections.get(collectionName);\n\n    if (typeof slug === 'undefined') {\n      const entries = await getAllEntries(state, selectedCollection);\n      return entries.map(entry => Map().set('data', entry.data));\n    }\n\n    const entry = await tryLoadEntry(state, selectedCollection, slug);\n    return Map().set('data', entry.data);\n  };\n\n  render() {\n    const { entry, collection, config } = this.props;\n\n    if (!entry || !entry.get('data')) {\n      return null;\n    }\n\n    const previewComponent =\n      getPreviewTemplate(selectTemplateName(collection, entry.get('slug'))) || EditorPreview;\n\n    this.inferFields();\n\n    const previewProps = {\n      ...this.props,\n      widgetFor: this.widgetFor,\n      widgetsFor: this.widgetsFor,\n      getCollection: this.getCollection,\n    };\n\n    const styleEls = getPreviewStyles().map((style, i) => {\n      if (style.raw) {\n        return <style key={i}>{style.value}</style>;\n      }\n      return <link key={i} href={style.value} type=\"text/css\" rel=\"stylesheet\" />;\n    });\n\n    if (!collection) {\n      <PreviewPaneFrame id=\"preview-pane\" head={styleEls} />;\n    }\n\n    const initialContent = `\n<!DOCTYPE html>\n<html>\n  <head><base target=\"_blank\"/></head>\n  <body><div></div></body>\n</html>\n`;\n\n    return (\n      <ErrorBoundary config={config}>\n        <PreviewPaneFrame id=\"preview-pane\" head={styleEls} initialContent={initialContent}>\n          <FrameContextConsumer>\n            {({ document, window }) => {\n              return (\n                <EditorPreviewContent\n                  {...{ previewComponent, previewProps: { ...previewProps, document, window } }}\n                />\n              );\n            }}\n          </FrameContextConsumer>\n        </PreviewPaneFrame>\n      </ErrorBoundary>\n    );\n  }\n}\n\nPreviewPane.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  getAsset: PropTypes.func.isRequired,\n};\n\nfunction mapStateToProps(state) {\n  const isLoadingAsset = selectIsLoadingAsset(state.medias);\n  return { isLoadingAsset, config: state.config, state };\n}\n\nfunction mapDispatchToProps(dispatch) {\n  return {\n    boundGetAsset: (collection, entry) => boundGetAsset(dispatch, collection, entry),\n  };\n}\n\nfunction mergeProps(stateProps, dispatchProps, ownProps) {\n  return {\n    ...stateProps,\n    ...dispatchProps,\n    ...ownProps,\n    getAsset: dispatchProps.boundGetAsset(ownProps.collection, ownProps.entry),\n  };\n}\n\nexport default connect(mapStateToProps, mapDispatchToProps, mergeProps)(PreviewPane);\n"]} */"));
|
|
38
|
-
class PreviewPane extends
|
|
29
|
+
})("width:100%;height:100%;border:none;background:#fff;border-radius:", lengths.borderRadius, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorPreviewPane/EditorPreviewPane.js"],"names":[],"mappings":"AA8BsC","file":"../../../../../src/components/Editor/EditorPreviewPane/EditorPreviewPane.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React from 'react';\nimport styled from '@emotion/styled';\nimport { List, Map } from 'immutable';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport Frame, { FrameContextConsumer } from 'react-frame-component';\nimport { lengths } from 'decap-cms-ui-default';\nimport { connect } from 'react-redux';\nimport { encodeEntry } from 'decap-cms-lib-util/src/stega';\n\nimport {\n  resolveWidget,\n  getPreviewTemplate,\n  getPreviewStyles,\n  getRemarkPlugins,\n} from '../../../lib/registry';\nimport { getAllEntries, tryLoadEntry } from '../../../actions/entries';\nimport { ErrorBoundary } from '../../UI';\nimport {\n  selectTemplateName,\n  selectInferredField,\n  selectField,\n} from '../../../reducers/collections';\nimport { boundGetAsset } from '../../../actions/media';\nimport { selectIsLoadingAsset } from '../../../reducers/medias';\nimport { INFERABLE_FIELDS } from '../../../constants/fieldInference';\nimport EditorPreviewContent from './EditorPreviewContent.js';\nimport PreviewHOC from './PreviewHOC';\nimport EditorPreview from './EditorPreview';\n\nconst PreviewPaneFrame = styled(Frame)`\n  width: 100%;\n  height: 100%;\n  border: none;\n  background: #fff;\n  border-radius: ${lengths.borderRadius};\n`;\n\nexport class PreviewPane extends React.Component {\n  getWidget = (field, value, metadata, props, idx = null) => {\n    const { getAsset, entry } = props;\n    const widget = resolveWidget(field.get('widget'));\n    const key = idx ? field.get('name') + '_' + idx : field.get('name');\n    const valueIsInMap = value && !widget.allowMapValue && Map.isMap(value);\n\n    /**\n     * Use an HOC to provide conditional updates for all previews.\n     */\n    return !widget.preview ? null : (\n      <PreviewHOC\n        previewComponent={widget.preview}\n        key={key}\n        field={field}\n        getAsset={getAsset}\n        value={valueIsInMap ? value.get(field.get('name')) : value}\n        entry={entry}\n        fieldsMetaData={metadata}\n        resolveWidget={resolveWidget}\n        getRemarkPlugins={getRemarkPlugins}\n      />\n    );\n  };\n\n  inferredFields = {};\n\n  inferFields() {\n    const titleField = selectInferredField(this.props.collection, 'title');\n    const shortTitleField = selectInferredField(this.props.collection, 'shortTitle');\n    const authorField = selectInferredField(this.props.collection, 'author');\n\n    this.inferredFields = {};\n    if (titleField) this.inferredFields[titleField] = INFERABLE_FIELDS.title;\n    if (shortTitleField) this.inferredFields[shortTitleField] = INFERABLE_FIELDS.shortTitle;\n    if (authorField) this.inferredFields[authorField] = INFERABLE_FIELDS.author;\n  }\n\n  /**\n   * Returns the widget component for a named field, and makes recursive calls\n   * to retrieve components for nested and deeply nested fields, which occur in\n   * object and list type fields. Used internally to retrieve widgets, and also\n   * exposed for use in custom preview templates.\n   */\n  widgetFor = (\n    name,\n    fields = this.props.fields,\n    values = this.props.entry.get('data'),\n    fieldsMetaData = this.props.fieldsMetaData,\n  ) => {\n    // We retrieve the field by name so that this function can also be used in\n    // custom preview templates, where the field object can't be passed in.\n    let field = fields && fields.find(f => f.get('name') === name);\n    let value = Map.isMap(values) && values.get(field.get('name'));\n    if (field.get('meta')) {\n      value = this.props.entry.getIn(['meta', field.get('name')]);\n    }\n\n    const nestedFields = field.get('fields');\n    const singleField = field.get('field');\n    const metadata = fieldsMetaData && fieldsMetaData.get(field.get('name'), Map());\n\n    if (nestedFields) {\n      field = field.set('fields', this.getNestedWidgets(nestedFields, value, metadata));\n    }\n\n    if (singleField) {\n      field = field.set('field', this.getSingleNested(singleField, value, metadata));\n    }\n\n    const labelledWidgets = ['string', 'text', 'number'];\n    const inferredField = Object.entries(this.inferredFields)\n      .filter(([key]) => {\n        const fieldToMatch = selectField(this.props.collection, key);\n        return fieldToMatch === field;\n      })\n      .map(([, value]) => value)[0];\n\n    if (inferredField) {\n      value = inferredField.defaultPreview(value);\n    } else if (\n      value &&\n      labelledWidgets.indexOf(field.get('widget')) !== -1 &&\n      value.toString().length < 50\n    ) {\n      value = (\n        <div>\n          <strong>{field.get('label', field.get('name'))}:</strong> {value}\n        </div>\n      );\n    }\n\n    return value ? this.getWidget(field, value, metadata, this.props) : null;\n  };\n\n  /**\n   * Retrieves widgets for nested fields (children of object/list fields)\n   */\n  getNestedWidgets = (fields, values, fieldsMetaData) => {\n    // Fields nested within a list field will be paired with a List of value Maps.\n    if (List.isList(values)) {\n      return values.map(value => this.widgetsForNestedFields(fields, value, fieldsMetaData));\n    }\n    // Fields nested within an object field will be paired with a single Map of values.\n    return this.widgetsForNestedFields(fields, values, fieldsMetaData);\n  };\n\n  getSingleNested = (field, values, fieldsMetaData) => {\n    if (List.isList(values)) {\n      return values.map((value, idx) =>\n        this.getWidget(field, value, fieldsMetaData.get(field.get('name')), this.props, idx),\n      );\n    }\n    return this.getWidget(field, values, fieldsMetaData.get(field.get('name')), this.props);\n  };\n\n  /**\n   * Use widgetFor as a mapping function for recursive widget retrieval\n   */\n  widgetsForNestedFields = (fields, values, fieldsMetaData) => {\n    return fields.map(field => this.widgetFor(field.get('name'), fields, values, fieldsMetaData));\n  };\n\n  /**\n   * This function exists entirely to expose nested widgets for object and list\n   * fields to custom preview templates.\n   *\n   * TODO: see if widgetFor can now provide this functionality for preview templates\n   */\n  widgetsFor = name => {\n    const { fields, entry, fieldsMetaData } = this.props;\n    const field = fields.find(f => f.get('name') === name);\n    const nestedFields = field && field.get('fields');\n    const variableTypes = field && field.get('types');\n    const value = entry.getIn(['data', field.get('name')]);\n    const metadata = fieldsMetaData.get(field.get('name'), Map());\n\n    // Variable Type lists\n    if (List.isList(value) && variableTypes) {\n      return value.map(val => {\n        const valueType = variableTypes.find(t => t.get('name') === val.get('type'));\n        const typeFields = valueType && valueType.get('fields');\n        const widgets =\n          typeFields &&\n          Map(\n            typeFields.map((f, i) => [\n              f.get('name'),\n              <div key={i}>{this.getWidget(f, val, metadata.get(f.get('name')), this.props)}</div>,\n            ]),\n          );\n        return Map({ data: val, widgets });\n      });\n    }\n\n    // List widgets\n    if (List.isList(value)) {\n      return value.map(val => {\n        const widgets =\n          nestedFields &&\n          Map(\n            nestedFields.map((f, i) => [\n              f.get('name'),\n              <div key={i}>{this.getWidget(f, val, metadata.get(f.get('name')), this.props)}</div>,\n            ]),\n          );\n        return Map({ data: val, widgets });\n      });\n    }\n\n    return Map({\n      data: value,\n      widgets:\n        nestedFields &&\n        Map(\n          nestedFields.map(f => [\n            f.get('name'),\n            this.getWidget(f, value, metadata.get(f.get('name')), this.props),\n          ]),\n        ),\n    });\n  };\n\n  /**\n   * This function exists entirely to expose collections from outside of this entry\n   *\n   */\n  getCollection = async (collectionName, slug) => {\n    const { state } = this.props;\n    const selectedCollection = state.collections.get(collectionName);\n\n    if (typeof slug === 'undefined') {\n      const entries = await getAllEntries(state, selectedCollection);\n      return entries.map(entry => Map().set('data', entry.data));\n    }\n\n    const entry = await tryLoadEntry(state, selectedCollection, slug);\n    return Map().set('data', entry.data);\n  };\n\n  render() {\n    const { entry, collection, config } = this.props;\n\n    if (!entry || !entry.get('data')) {\n      return null;\n    }\n\n    const previewComponent =\n      getPreviewTemplate(selectTemplateName(collection, entry.get('slug'))) || EditorPreview;\n\n    this.inferFields();\n\n    const visualEditing = collection.getIn(['editor', 'visualEditing'], false);\n\n    // Only encode entry data if visual editing is enabled\n    const previewEntry = visualEditing\n      ? entry.set('data', encodeEntry(entry.get('data'), this.props.fields))\n      : entry;\n\n    const previewProps = {\n      ...this.props,\n      entry: previewEntry,\n      widgetFor: (name, fields, values = previewEntry.get('data'), fieldsMetaData) =>\n        this.widgetFor(name, fields, values, fieldsMetaData),\n      widgetsFor: this.widgetsFor,\n      getCollection: this.getCollection,\n    };\n\n    const styleEls = getPreviewStyles().map((style, i) => {\n      if (style.raw) {\n        return <style key={i}>{style.value}</style>;\n      }\n      return <link key={i} href={style.value} type=\"text/css\" rel=\"stylesheet\" />;\n    });\n\n    if (!collection) {\n      <PreviewPaneFrame id=\"preview-pane\" head={styleEls} />;\n    }\n\n    const initialContent = `\n<!DOCTYPE html>\n<html>\n  <head><base target=\"_blank\"/></head>\n  <body><div></div></body>\n</html>\n`;\n\n    return (\n      <ErrorBoundary config={config}>\n        <PreviewPaneFrame id=\"preview-pane\" head={styleEls} initialContent={initialContent}>\n          <FrameContextConsumer>\n            {({ document, window }) => {\n              return (\n                <EditorPreviewContent\n                  {...{ previewComponent, previewProps: { ...previewProps, document, window } }}\n                  onFieldClick={this.props.onFieldClick}\n                />\n              );\n            }}\n          </FrameContextConsumer>\n        </PreviewPaneFrame>\n      </ErrorBoundary>\n    );\n  }\n}\n\nPreviewPane.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  getAsset: PropTypes.func.isRequired,\n  onFieldClick: PropTypes.func,\n};\n\nfunction mapStateToProps(state) {\n  const isLoadingAsset = selectIsLoadingAsset(state.medias);\n  return { isLoadingAsset, config: state.config, state };\n}\n\nfunction mapDispatchToProps(dispatch) {\n  return {\n    boundGetAsset: (collection, entry) => boundGetAsset(dispatch, collection, entry),\n  };\n}\n\nfunction mergeProps(stateProps, dispatchProps, ownProps) {\n  return {\n    ...stateProps,\n    ...dispatchProps,\n    ...ownProps,\n    getAsset: dispatchProps.boundGetAsset(ownProps.collection, ownProps.entry),\n  };\n}\n\nexport default connect(mapStateToProps, mapDispatchToProps, mergeProps)(PreviewPane);\n"]} */"));
|
|
30
|
+
export class PreviewPane extends React.Component {
|
|
39
31
|
constructor(...args) {
|
|
40
32
|
super(...args);
|
|
41
33
|
_defineProperty(this, "getWidget", (field, value, metadata, props, idx = null) => {
|
|
@@ -43,14 +35,14 @@ class PreviewPane extends _react.default.Component {
|
|
|
43
35
|
getAsset,
|
|
44
36
|
entry
|
|
45
37
|
} = props;
|
|
46
|
-
const widget =
|
|
38
|
+
const widget = resolveWidget(field.get('widget'));
|
|
47
39
|
const key = idx ? field.get('name') + '_' + idx : field.get('name');
|
|
48
|
-
const valueIsInMap = value && !widget.allowMapValue &&
|
|
40
|
+
const valueIsInMap = value && !widget.allowMapValue && Map.isMap(value);
|
|
49
41
|
|
|
50
42
|
/**
|
|
51
43
|
* Use an HOC to provide conditional updates for all previews.
|
|
52
44
|
*/
|
|
53
|
-
return !widget.preview ? null : (
|
|
45
|
+
return !widget.preview ? null : ___EmotionJSX(PreviewHOC, {
|
|
54
46
|
previewComponent: widget.preview,
|
|
55
47
|
key: key,
|
|
56
48
|
field: field,
|
|
@@ -58,8 +50,8 @@ class PreviewPane extends _react.default.Component {
|
|
|
58
50
|
value: valueIsInMap ? value.get(field.get('name')) : value,
|
|
59
51
|
entry: entry,
|
|
60
52
|
fieldsMetaData: metadata,
|
|
61
|
-
resolveWidget:
|
|
62
|
-
getRemarkPlugins:
|
|
53
|
+
resolveWidget: resolveWidget,
|
|
54
|
+
getRemarkPlugins: getRemarkPlugins
|
|
63
55
|
});
|
|
64
56
|
});
|
|
65
57
|
_defineProperty(this, "inferredFields", {});
|
|
@@ -73,13 +65,13 @@ class PreviewPane extends _react.default.Component {
|
|
|
73
65
|
// We retrieve the field by name so that this function can also be used in
|
|
74
66
|
// custom preview templates, where the field object can't be passed in.
|
|
75
67
|
let field = fields && fields.find(f => f.get('name') === name);
|
|
76
|
-
let value =
|
|
68
|
+
let value = Map.isMap(values) && values.get(field.get('name'));
|
|
77
69
|
if (field.get('meta')) {
|
|
78
70
|
value = this.props.entry.getIn(['meta', field.get('name')]);
|
|
79
71
|
}
|
|
80
72
|
const nestedFields = field.get('fields');
|
|
81
73
|
const singleField = field.get('field');
|
|
82
|
-
const metadata = fieldsMetaData && fieldsMetaData.get(field.get('name'),
|
|
74
|
+
const metadata = fieldsMetaData && fieldsMetaData.get(field.get('name'), Map());
|
|
83
75
|
if (nestedFields) {
|
|
84
76
|
field = field.set('fields', this.getNestedWidgets(nestedFields, value, metadata));
|
|
85
77
|
}
|
|
@@ -88,13 +80,13 @@ class PreviewPane extends _react.default.Component {
|
|
|
88
80
|
}
|
|
89
81
|
const labelledWidgets = ['string', 'text', 'number'];
|
|
90
82
|
const inferredField = Object.entries(this.inferredFields).filter(([key]) => {
|
|
91
|
-
const fieldToMatch =
|
|
83
|
+
const fieldToMatch = selectField(this.props.collection, key);
|
|
92
84
|
return fieldToMatch === field;
|
|
93
85
|
}).map(([, value]) => value)[0];
|
|
94
86
|
if (inferredField) {
|
|
95
87
|
value = inferredField.defaultPreview(value);
|
|
96
88
|
} else if (value && labelledWidgets.indexOf(field.get('widget')) !== -1 && value.toString().length < 50) {
|
|
97
|
-
value = (
|
|
89
|
+
value = ___EmotionJSX("div", null, ___EmotionJSX("strong", null, field.get('label', field.get('name')), ":"), " ", value);
|
|
98
90
|
}
|
|
99
91
|
return value ? this.getWidget(field, value, metadata, this.props) : null;
|
|
100
92
|
});
|
|
@@ -103,14 +95,14 @@ class PreviewPane extends _react.default.Component {
|
|
|
103
95
|
*/
|
|
104
96
|
_defineProperty(this, "getNestedWidgets", (fields, values, fieldsMetaData) => {
|
|
105
97
|
// Fields nested within a list field will be paired with a List of value Maps.
|
|
106
|
-
if (
|
|
98
|
+
if (List.isList(values)) {
|
|
107
99
|
return values.map(value => this.widgetsForNestedFields(fields, value, fieldsMetaData));
|
|
108
100
|
}
|
|
109
101
|
// Fields nested within an object field will be paired with a single Map of values.
|
|
110
102
|
return this.widgetsForNestedFields(fields, values, fieldsMetaData);
|
|
111
103
|
});
|
|
112
104
|
_defineProperty(this, "getSingleNested", (field, values, fieldsMetaData) => {
|
|
113
|
-
if (
|
|
105
|
+
if (List.isList(values)) {
|
|
114
106
|
return values.map((value, idx) => this.getWidget(field, value, fieldsMetaData.get(field.get('name')), this.props, idx));
|
|
115
107
|
}
|
|
116
108
|
return this.getWidget(field, values, fieldsMetaData.get(field.get('name')), this.props);
|
|
@@ -135,22 +127,40 @@ class PreviewPane extends _react.default.Component {
|
|
|
135
127
|
} = this.props;
|
|
136
128
|
const field = fields.find(f => f.get('name') === name);
|
|
137
129
|
const nestedFields = field && field.get('fields');
|
|
130
|
+
const variableTypes = field && field.get('types');
|
|
138
131
|
const value = entry.getIn(['data', field.get('name')]);
|
|
139
|
-
const metadata = fieldsMetaData.get(field.get('name'),
|
|
140
|
-
|
|
132
|
+
const metadata = fieldsMetaData.get(field.get('name'), Map());
|
|
133
|
+
|
|
134
|
+
// Variable Type lists
|
|
135
|
+
if (List.isList(value) && variableTypes) {
|
|
136
|
+
return value.map(val => {
|
|
137
|
+
const valueType = variableTypes.find(t => t.get('name') === val.get('type'));
|
|
138
|
+
const typeFields = valueType && valueType.get('fields');
|
|
139
|
+
const widgets = typeFields && Map(typeFields.map((f, i) => [f.get('name'), ___EmotionJSX("div", {
|
|
140
|
+
key: i
|
|
141
|
+
}, this.getWidget(f, val, metadata.get(f.get('name')), this.props))]));
|
|
142
|
+
return Map({
|
|
143
|
+
data: val,
|
|
144
|
+
widgets
|
|
145
|
+
});
|
|
146
|
+
});
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
// List widgets
|
|
150
|
+
if (List.isList(value)) {
|
|
141
151
|
return value.map(val => {
|
|
142
|
-
const widgets = nestedFields &&
|
|
152
|
+
const widgets = nestedFields && Map(nestedFields.map((f, i) => [f.get('name'), ___EmotionJSX("div", {
|
|
143
153
|
key: i
|
|
144
154
|
}, this.getWidget(f, val, metadata.get(f.get('name')), this.props))]));
|
|
145
|
-
return
|
|
155
|
+
return Map({
|
|
146
156
|
data: val,
|
|
147
157
|
widgets
|
|
148
158
|
});
|
|
149
159
|
});
|
|
150
160
|
}
|
|
151
|
-
return
|
|
161
|
+
return Map({
|
|
152
162
|
data: value,
|
|
153
|
-
widgets: nestedFields &&
|
|
163
|
+
widgets: nestedFields && Map(nestedFields.map(f => [f.get('name'), this.getWidget(f, value, metadata.get(f.get('name')), this.props)]))
|
|
154
164
|
});
|
|
155
165
|
});
|
|
156
166
|
/**
|
|
@@ -163,21 +173,21 @@ class PreviewPane extends _react.default.Component {
|
|
|
163
173
|
} = this.props;
|
|
164
174
|
const selectedCollection = state.collections.get(collectionName);
|
|
165
175
|
if (typeof slug === 'undefined') {
|
|
166
|
-
const entries = await
|
|
167
|
-
return entries.map(entry =>
|
|
176
|
+
const entries = await getAllEntries(state, selectedCollection);
|
|
177
|
+
return entries.map(entry => Map().set('data', entry.data));
|
|
168
178
|
}
|
|
169
|
-
const entry = await
|
|
170
|
-
return
|
|
179
|
+
const entry = await tryLoadEntry(state, selectedCollection, slug);
|
|
180
|
+
return Map().set('data', entry.data);
|
|
171
181
|
});
|
|
172
182
|
}
|
|
173
183
|
inferFields() {
|
|
174
|
-
const titleField =
|
|
175
|
-
const shortTitleField =
|
|
176
|
-
const authorField =
|
|
184
|
+
const titleField = selectInferredField(this.props.collection, 'title');
|
|
185
|
+
const shortTitleField = selectInferredField(this.props.collection, 'shortTitle');
|
|
186
|
+
const authorField = selectInferredField(this.props.collection, 'author');
|
|
177
187
|
this.inferredFields = {};
|
|
178
|
-
if (titleField) this.inferredFields[titleField] =
|
|
179
|
-
if (shortTitleField) this.inferredFields[shortTitleField] =
|
|
180
|
-
if (authorField) this.inferredFields[authorField] =
|
|
188
|
+
if (titleField) this.inferredFields[titleField] = INFERABLE_FIELDS.title;
|
|
189
|
+
if (shortTitleField) this.inferredFields[shortTitleField] = INFERABLE_FIELDS.shortTitle;
|
|
190
|
+
if (authorField) this.inferredFields[authorField] = INFERABLE_FIELDS.author;
|
|
181
191
|
}
|
|
182
192
|
render() {
|
|
183
193
|
const {
|
|
@@ -188,20 +198,25 @@ class PreviewPane extends _react.default.Component {
|
|
|
188
198
|
if (!entry || !entry.get('data')) {
|
|
189
199
|
return null;
|
|
190
200
|
}
|
|
191
|
-
const previewComponent =
|
|
201
|
+
const previewComponent = getPreviewTemplate(selectTemplateName(collection, entry.get('slug'))) || EditorPreview;
|
|
192
202
|
this.inferFields();
|
|
203
|
+
const visualEditing = collection.getIn(['editor', 'visualEditing'], false);
|
|
204
|
+
|
|
205
|
+
// Only encode entry data if visual editing is enabled
|
|
206
|
+
const previewEntry = visualEditing ? entry.set('data', encodeEntry(entry.get('data'), this.props.fields)) : entry;
|
|
193
207
|
const previewProps = _objectSpread(_objectSpread({}, this.props), {}, {
|
|
194
|
-
|
|
208
|
+
entry: previewEntry,
|
|
209
|
+
widgetFor: (name, fields, values = previewEntry.get('data'), fieldsMetaData) => this.widgetFor(name, fields, values, fieldsMetaData),
|
|
195
210
|
widgetsFor: this.widgetsFor,
|
|
196
211
|
getCollection: this.getCollection
|
|
197
212
|
});
|
|
198
|
-
const styleEls =
|
|
213
|
+
const styleEls = getPreviewStyles().map((style, i) => {
|
|
199
214
|
if (style.raw) {
|
|
200
|
-
return (
|
|
215
|
+
return ___EmotionJSX("style", {
|
|
201
216
|
key: i
|
|
202
217
|
}, style.value);
|
|
203
218
|
}
|
|
204
|
-
return (
|
|
219
|
+
return ___EmotionJSX("link", {
|
|
205
220
|
key: i,
|
|
206
221
|
href: style.value,
|
|
207
222
|
type: "text/css",
|
|
@@ -209,7 +224,7 @@ class PreviewPane extends _react.default.Component {
|
|
|
209
224
|
});
|
|
210
225
|
});
|
|
211
226
|
if (!collection) {
|
|
212
|
-
(
|
|
227
|
+
___EmotionJSX(PreviewPaneFrame, {
|
|
213
228
|
id: "preview-pane",
|
|
214
229
|
head: styleEls
|
|
215
230
|
});
|
|
@@ -221,36 +236,37 @@ class PreviewPane extends _react.default.Component {
|
|
|
221
236
|
<body><div></div></body>
|
|
222
237
|
</html>
|
|
223
238
|
`;
|
|
224
|
-
return (
|
|
239
|
+
return ___EmotionJSX(ErrorBoundary, {
|
|
225
240
|
config: config
|
|
226
|
-
}, (
|
|
241
|
+
}, ___EmotionJSX(PreviewPaneFrame, {
|
|
227
242
|
id: "preview-pane",
|
|
228
243
|
head: styleEls,
|
|
229
244
|
initialContent: initialContent
|
|
230
|
-
}, (
|
|
245
|
+
}, ___EmotionJSX(FrameContextConsumer, null, ({
|
|
231
246
|
document,
|
|
232
247
|
window
|
|
233
248
|
}) => {
|
|
234
|
-
return (
|
|
249
|
+
return ___EmotionJSX(EditorPreviewContent, {
|
|
235
250
|
previewComponent,
|
|
236
251
|
previewProps: _objectSpread(_objectSpread({}, previewProps), {}, {
|
|
237
252
|
document,
|
|
238
253
|
window
|
|
239
|
-
})
|
|
254
|
+
}),
|
|
255
|
+
onFieldClick: this.props.onFieldClick
|
|
240
256
|
});
|
|
241
257
|
})));
|
|
242
258
|
}
|
|
243
259
|
}
|
|
244
|
-
exports.PreviewPane = PreviewPane;
|
|
245
260
|
PreviewPane.propTypes = {
|
|
246
|
-
collection:
|
|
247
|
-
fields:
|
|
248
|
-
entry:
|
|
249
|
-
fieldsMetaData:
|
|
250
|
-
getAsset:
|
|
261
|
+
collection: ImmutablePropTypes.map.isRequired,
|
|
262
|
+
fields: ImmutablePropTypes.list.isRequired,
|
|
263
|
+
entry: ImmutablePropTypes.map.isRequired,
|
|
264
|
+
fieldsMetaData: ImmutablePropTypes.map.isRequired,
|
|
265
|
+
getAsset: PropTypes.func.isRequired,
|
|
266
|
+
onFieldClick: PropTypes.func
|
|
251
267
|
};
|
|
252
268
|
function mapStateToProps(state) {
|
|
253
|
-
const isLoadingAsset =
|
|
269
|
+
const isLoadingAsset = selectIsLoadingAsset(state.medias);
|
|
254
270
|
return {
|
|
255
271
|
isLoadingAsset,
|
|
256
272
|
config: state.config,
|
|
@@ -259,7 +275,7 @@ function mapStateToProps(state) {
|
|
|
259
275
|
}
|
|
260
276
|
function mapDispatchToProps(dispatch) {
|
|
261
277
|
return {
|
|
262
|
-
boundGetAsset: (collection, entry) =>
|
|
278
|
+
boundGetAsset: (collection, entry) => boundGetAsset(dispatch, collection, entry)
|
|
263
279
|
};
|
|
264
280
|
}
|
|
265
281
|
function mergeProps(stateProps, dispatchProps, ownProps) {
|
|
@@ -267,4 +283,4 @@ function mergeProps(stateProps, dispatchProps, ownProps) {
|
|
|
267
283
|
getAsset: dispatchProps.boundGetAsset(ownProps.collection, ownProps.entry)
|
|
268
284
|
});
|
|
269
285
|
}
|
|
270
|
-
|
|
286
|
+
export default connect(mapStateToProps, mapDispatchToProps, mergeProps)(PreviewPane);
|
|
@@ -1,17 +1,10 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = void 0;
|
|
7
|
-
var _react = _interopRequireDefault(require("react"));
|
|
8
|
-
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
9
|
-
var _reactImmutableProptypes = _interopRequireDefault(require("react-immutable-proptypes"));
|
|
10
1
|
const _excluded = ["previewComponent"];
|
|
11
|
-
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
12
2
|
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; }
|
|
13
3
|
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; }
|
|
14
|
-
|
|
4
|
+
import React from 'react';
|
|
5
|
+
import PropTypes from 'prop-types';
|
|
6
|
+
import ImmutablePropTypes from 'react-immutable-proptypes';
|
|
7
|
+
class PreviewHOC extends React.Component {
|
|
15
8
|
/**
|
|
16
9
|
* Only re-render on value change, but always re-render objects and lists.
|
|
17
10
|
* Their child widgets will each also be wrapped with this component, and
|
|
@@ -27,12 +20,12 @@ class PreviewHOC extends _react.default.Component {
|
|
|
27
20
|
previewComponent
|
|
28
21
|
} = _this$props,
|
|
29
22
|
props = _objectWithoutProperties(_this$props, _excluded);
|
|
30
|
-
return /*#__PURE__*/
|
|
23
|
+
return /*#__PURE__*/React.createElement(previewComponent, props);
|
|
31
24
|
}
|
|
32
25
|
}
|
|
33
26
|
PreviewHOC.propTypes = {
|
|
34
|
-
previewComponent:
|
|
35
|
-
field:
|
|
36
|
-
value:
|
|
27
|
+
previewComponent: PropTypes.func.isRequired,
|
|
28
|
+
field: ImmutablePropTypes.map.isRequired,
|
|
29
|
+
value: PropTypes.oneOfType([PropTypes.node, PropTypes.object, PropTypes.string, PropTypes.bool])
|
|
37
30
|
};
|
|
38
|
-
|
|
31
|
+
export default PreviewHOC;
|