decap-cms-core 3.6.2 → 3.7.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (132) hide show
  1. package/dist/decap-cms-core.js +26 -26
  2. package/dist/decap-cms-core.js.LICENSE.txt +22 -4
  3. package/dist/decap-cms-core.js.map +1 -1
  4. package/dist/esm/actions/config.js +57 -49
  5. package/dist/esm/actions/editorialWorkflow.js +4 -4
  6. package/dist/esm/actions/entries.js +8 -14
  7. package/dist/esm/actions/mediaLibrary.js +6 -11
  8. package/dist/esm/actions/search.js +2 -2
  9. package/dist/esm/actions/status.js +2 -8
  10. package/dist/esm/backend.js +70 -79
  11. package/dist/esm/bootstrap.js +2 -2
  12. package/dist/esm/components/App/App.js +28 -34
  13. package/dist/esm/components/App/Header.js +32 -39
  14. package/dist/esm/components/Collection/Collection.js +45 -48
  15. package/dist/esm/components/Collection/CollectionSearch.js +76 -81
  16. package/dist/esm/components/Collection/CollectionTop.js +1 -2
  17. package/dist/esm/components/Collection/Entries/Entries.js +2 -4
  18. package/dist/esm/components/Collection/Entries/EntriesCollection.js +25 -29
  19. package/dist/esm/components/Collection/Entries/EntriesSearch.js +34 -38
  20. package/dist/esm/components/Collection/Entries/EntryCard.js +8 -13
  21. package/dist/esm/components/Collection/Entries/EntryListing.js +72 -76
  22. package/dist/esm/components/Collection/FilterControl.js +1 -1
  23. package/dist/esm/components/Collection/GroupControl.js +1 -1
  24. package/dist/esm/components/Collection/NestedCollection.js +50 -53
  25. package/dist/esm/components/Collection/Sidebar.js +35 -38
  26. package/dist/esm/components/Collection/SortControl.js +3 -3
  27. package/dist/esm/components/Collection/ViewStyleControl.js +1 -2
  28. package/dist/esm/components/Editor/Editor.js +197 -201
  29. package/dist/esm/components/Editor/EditorControlPane/EditorControl.js +79 -87
  30. package/dist/esm/components/Editor/EditorControlPane/EditorControlPane.js +75 -86
  31. package/dist/esm/components/Editor/EditorControlPane/Widget.js +226 -228
  32. package/dist/esm/components/Editor/EditorInterface.js +69 -80
  33. package/dist/esm/components/Editor/EditorPreviewPane/EditorPreview.js +1 -2
  34. package/dist/esm/components/Editor/EditorPreviewPane/EditorPreviewContent.js +20 -28
  35. package/dist/esm/components/Editor/EditorPreviewPane/EditorPreviewPane.js +163 -161
  36. package/dist/esm/components/Editor/EditorPreviewPane/PreviewHOC.js +4 -8
  37. package/dist/esm/components/Editor/EditorToolbar.js +335 -347
  38. package/dist/esm/components/Editor/withWorkflow.js +5 -6
  39. package/dist/esm/components/MediaLibrary/MediaLibrary.js +304 -294
  40. package/dist/esm/components/MediaLibrary/MediaLibraryButtons.js +40 -46
  41. package/dist/esm/components/MediaLibrary/MediaLibraryCard.js +1 -2
  42. package/dist/esm/components/MediaLibrary/MediaLibraryCardGrid.js +8 -13
  43. package/dist/esm/components/MediaLibrary/MediaLibraryModal.js +3 -3
  44. package/dist/esm/components/MediaLibrary/MediaLibrarySearch.js +1 -2
  45. package/dist/esm/components/MediaLibrary/MediaLibraryTop.js +3 -6
  46. package/dist/esm/components/UI/DragDrop.js +15 -23
  47. package/dist/esm/components/UI/ErrorBoundary.js +23 -25
  48. package/dist/esm/components/UI/Modal.js +10 -12
  49. package/dist/esm/components/UI/Notifications.js +4 -8
  50. package/dist/esm/components/UI/SettingsDropdown.js +4 -8
  51. package/dist/esm/components/Workflow/Workflow.js +19 -20
  52. package/dist/esm/components/Workflow/WorkflowCard.js +2 -4
  53. package/dist/esm/components/Workflow/WorkflowList.js +105 -113
  54. package/dist/esm/constants/configSchema.js +18 -16
  55. package/dist/esm/formats/formats.js +11 -12
  56. package/dist/esm/formats/frontmatter.js +17 -21
  57. package/dist/esm/formats/yaml.js +2 -6
  58. package/dist/esm/index.js +3 -7
  59. package/dist/esm/integrations/providers/algolia/implementation.js +12 -14
  60. package/dist/esm/integrations/providers/assetStore/implementation.js +10 -12
  61. package/dist/esm/lib/formatters.js +13 -17
  62. package/dist/esm/lib/i18n.js +35 -33
  63. package/dist/esm/lib/phrases.js +2 -2
  64. package/dist/esm/lib/registry.js +35 -35
  65. package/dist/esm/lib/serializeEntryValues.js +3 -3
  66. package/dist/esm/lib/stega.js +142 -0
  67. package/dist/esm/lib/urlHelper.js +16 -18
  68. package/dist/esm/mediaLibrary.js +3 -4
  69. package/dist/esm/reducers/collections.js +26 -42
  70. package/dist/esm/reducers/combinedReducer.js +3 -6
  71. package/dist/esm/reducers/config.js +3 -7
  72. package/dist/esm/reducers/editorialWorkflow.js +5 -9
  73. package/dist/esm/reducers/entries.js +33 -35
  74. package/dist/esm/reducers/entryDraft.js +2 -2
  75. package/dist/esm/reducers/integrations.js +8 -14
  76. package/dist/esm/reducers/mediaLibrary.js +18 -20
  77. package/dist/esm/reducers/notifications.js +4 -8
  78. package/dist/esm/types/immutable.js +7 -1
  79. package/dist/esm/valueObjects/AssetProxy.js +1 -9
  80. package/dist/esm/valueObjects/EditorComponent.js +18 -25
  81. package/dist/esm/valueObjects/Entry.js +2 -2
  82. package/index.d.ts +2 -0
  83. package/package.json +8 -11
  84. package/src/actions/__tests__/config.spec.js +3 -3
  85. package/src/actions/config.ts +3 -1
  86. package/src/actions/editorialWorkflow.ts +1 -1
  87. package/src/actions/entries.ts +1 -1
  88. package/src/actions/search.ts +1 -1
  89. package/src/backend.ts +8 -1
  90. package/src/components/App/App.js +5 -0
  91. package/src/components/App/Header.js +3 -0
  92. package/src/components/Collection/Collection.js +5 -0
  93. package/src/components/Collection/CollectionSearch.js +5 -0
  94. package/src/components/Collection/Entries/EntriesCollection.js +4 -1
  95. package/src/components/Collection/Entries/EntriesSearch.js +4 -1
  96. package/src/components/Collection/Entries/EntryListing.js +5 -0
  97. package/src/components/Collection/Entries/__tests__/__snapshots__/EntriesCollection.spec.js.snap +0 -4
  98. package/src/components/Collection/NestedCollection.js +6 -1
  99. package/src/components/Collection/Sidebar.js +5 -0
  100. package/src/components/Editor/Editor.js +4 -1
  101. package/src/components/Editor/EditorControlPane/EditorControl.js +7 -1
  102. package/src/components/Editor/EditorControlPane/Widget.js +5 -0
  103. package/src/components/Editor/EditorPreviewPane/EditorPreviewPane.js +1 -1
  104. package/src/components/Editor/EditorToolbar.js +6 -3
  105. package/src/components/Editor/__tests__/Editor.spec.js +3 -4
  106. package/src/components/Editor/__tests__/__snapshots__/Editor.spec.js.snap +5 -5
  107. package/src/components/Editor/__tests__/__snapshots__/EditorToolbar.spec.js.snap +708 -393
  108. package/src/components/MediaLibrary/MediaLibrary.js +5 -1
  109. package/src/components/MediaLibrary/MediaLibraryModal.js +1 -1
  110. package/src/components/UI/ErrorBoundary.js +6 -1
  111. package/src/components/UI/Modal.js +3 -0
  112. package/src/components/Workflow/Workflow.js +3 -0
  113. package/src/components/Workflow/WorkflowList.js +5 -0
  114. package/src/constants/__tests__/configSchema.spec.js +1 -1
  115. package/src/formats/formats.ts +1 -1
  116. package/src/integrations/providers/algolia/implementation.js +2 -2
  117. package/src/integrations/providers/assetStore/implementation.js +2 -1
  118. package/src/lib/formatters.ts +4 -1
  119. package/src/lib/i18n.ts +3 -1
  120. package/src/lib/phrases.js +1 -1
  121. package/src/lib/serializeEntryValues.js +1 -1
  122. package/src/lib/stega.ts +145 -0
  123. package/src/lib/urlHelper.ts +4 -1
  124. package/src/mediaLibrary.ts +1 -1
  125. package/src/reducers/collections.ts +2 -1
  126. package/src/reducers/editorialWorkflow.ts +1 -1
  127. package/src/reducers/entries.ts +6 -1
  128. package/src/reducers/entryDraft.js +1 -1
  129. package/src/types/immutable.ts +10 -0
  130. package/src/types/redux.ts +2 -0
  131. package/src/valueObjects/EditorComponent.js +1 -1
  132. package/src/valueObjects/Entry.ts +1 -1
@@ -1,9 +1,4 @@
1
1
  import _styled from "@emotion/styled/base";
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; }
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; }
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; }
5
- function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : String(i); }
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); }
7
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)."; }
8
3
  import React from 'react';
9
4
  import PropTypes from 'prop-types';
@@ -24,7 +19,7 @@ import { jsx as ___EmotionJSX } from "@emotion/react";
24
19
  const CollectionContainer = /*#__PURE__*/_styled("div", {
25
20
  target: "e1sogrfi3",
26
21
  label: "CollectionContainer"
27
- })("margin:", lengths.pageMargin, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Collection/Collection.js"],"names":[],"mappings":"AA2BsC","file":"../../../../src/components/Collection/Collection.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { translate } from 'react-polyglot';\nimport { lengths, components } from 'decap-cms-ui-default';\n\nimport { getNewEntryUrl } from '../../lib/urlHelper';\nimport Sidebar from './Sidebar';\nimport CollectionTop from './CollectionTop';\nimport EntriesCollection from './Entries/EntriesCollection';\nimport EntriesSearch from './Entries/EntriesSearch';\nimport CollectionControls from './CollectionControls';\nimport { sortByField, filterByField, changeViewStyle, groupByField } from '../../actions/entries';\nimport {\n  selectSortableFields,\n  selectViewFilters,\n  selectViewGroups,\n} from '../../reducers/collections';\nimport {\n  selectEntriesSort,\n  selectEntriesFilter,\n  selectEntriesGroup,\n  selectViewStyle,\n} from '../../reducers/entries';\n\nconst CollectionContainer = styled.div`\n  margin: ${lengths.pageMargin};\n`;\n\nconst CollectionMain = styled.main`\n  padding-left: 280px;\n`;\n\nconst SearchResultContainer = styled.div`\n  ${components.cardTop};\n  margin-bottom: 22px;\n`;\n\nconst SearchResultHeading = styled.h1`\n  ${components.cardTopHeading};\n`;\n\nexport class Collection extends React.Component {\n  static propTypes = {\n    searchTerm: PropTypes.string,\n    collectionName: PropTypes.string,\n    isSearchResults: PropTypes.bool,\n    isSingleSearchResult: PropTypes.bool,\n    collection: ImmutablePropTypes.map.isRequired,\n    collections: ImmutablePropTypes.map.isRequired,\n    sortableFields: PropTypes.array,\n    sort: ImmutablePropTypes.orderedMap,\n    onSortClick: PropTypes.func.isRequired,\n  };\n\n  renderEntriesCollection = () => {\n    const { collection, filterTerm, viewStyle } = this.props;\n    return (\n      <EntriesCollection collection={collection} viewStyle={viewStyle} filterTerm={filterTerm} />\n    );\n  };\n\n  renderEntriesSearch = () => {\n    const { searchTerm, collections, collection, isSingleSearchResult } = this.props;\n    return (\n      <EntriesSearch\n        collections={isSingleSearchResult ? collections.filter(c => c === collection) : collections}\n        searchTerm={searchTerm}\n      />\n    );\n  };\n\n  render() {\n    const {\n      collection,\n      collections,\n      collectionName,\n      isSearchEnabled,\n      isSearchResults,\n      isSingleSearchResult,\n      searchTerm,\n      sortableFields,\n      onSortClick,\n      sort,\n      viewFilters,\n      viewGroups,\n      filterTerm,\n      t,\n      onFilterClick,\n      onGroupClick,\n      filter,\n      group,\n      onChangeViewStyle,\n      viewStyle,\n    } = this.props;\n\n    let newEntryUrl = collection.get('create') ? getNewEntryUrl(collectionName) : '';\n    if (newEntryUrl && filterTerm) {\n      newEntryUrl = getNewEntryUrl(collectionName);\n      if (filterTerm) {\n        newEntryUrl = `${newEntryUrl}?path=${filterTerm}`;\n      }\n    }\n\n    const searchResultKey =\n      'collection.collectionTop.searchResults' + (isSingleSearchResult ? 'InCollection' : '');\n\n    return (\n      <CollectionContainer>\n        <Sidebar\n          collections={collections}\n          collection={(!isSearchResults || isSingleSearchResult) && collection}\n          isSearchEnabled={isSearchEnabled}\n          searchTerm={searchTerm}\n          filterTerm={filterTerm}\n        />\n        <CollectionMain>\n          {isSearchResults ? (\n            <SearchResultContainer>\n              <SearchResultHeading>\n                {t(searchResultKey, { searchTerm, collection: collection.get('label') })}\n              </SearchResultHeading>\n            </SearchResultContainer>\n          ) : (\n            <>\n              <CollectionTop collection={collection} newEntryUrl={newEntryUrl} />\n              <CollectionControls\n                viewStyle={viewStyle}\n                onChangeViewStyle={onChangeViewStyle}\n                sortableFields={sortableFields}\n                onSortClick={onSortClick}\n                sort={sort}\n                viewFilters={viewFilters}\n                viewGroups={viewGroups}\n                t={t}\n                onFilterClick={onFilterClick}\n                onGroupClick={onGroupClick}\n                filter={filter}\n                group={group}\n              />\n            </>\n          )}\n          {isSearchResults ? this.renderEntriesSearch() : this.renderEntriesCollection()}\n        </CollectionMain>\n      </CollectionContainer>\n    );\n  }\n}\n\nfunction mapStateToProps(state, ownProps) {\n  const { collections } = state;\n  const isSearchEnabled = state.config && state.config.search != false;\n  const { isSearchResults, match, t } = ownProps;\n  const { name, searchTerm = '', filterTerm = '' } = match.params;\n  const collection = name ? collections.get(name) : collections.first();\n  const sort = selectEntriesSort(state.entries, collection.get('name'));\n  const sortableFields = selectSortableFields(collection, t);\n  const viewFilters = selectViewFilters(collection);\n  const viewGroups = selectViewGroups(collection);\n  const filter = selectEntriesFilter(state.entries, collection.get('name'));\n  const group = selectEntriesGroup(state.entries, collection.get('name'));\n  const viewStyle = selectViewStyle(state.entries);\n\n  return {\n    collection,\n    collections,\n    collectionName: name,\n    isSearchEnabled,\n    isSearchResults,\n    searchTerm,\n    filterTerm,\n    sort,\n    sortableFields,\n    viewFilters,\n    viewGroups,\n    filter,\n    group,\n    viewStyle,\n  };\n}\n\nconst mapDispatchToProps = {\n  sortByField,\n  filterByField,\n  changeViewStyle,\n  groupByField,\n};\n\nfunction mergeProps(stateProps, dispatchProps, ownProps) {\n  return {\n    ...stateProps,\n    ...ownProps,\n    onSortClick: (key, direction) =>\n      dispatchProps.sortByField(stateProps.collection, key, direction),\n    onFilterClick: filter => dispatchProps.filterByField(stateProps.collection, filter),\n    onGroupClick: group => dispatchProps.groupByField(stateProps.collection, group),\n    onChangeViewStyle: viewStyle => dispatchProps.changeViewStyle(viewStyle),\n  };\n}\n\nconst ConnectedCollection = connect(mapStateToProps, mapDispatchToProps, mergeProps)(Collection);\n\nexport default translate()(ConnectedCollection);\n"]} */"));
22
+ })("margin:", lengths.pageMargin, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Collection/Collection.js"],"names":[],"mappings":"AA2BsC","file":"../../../../src/components/Collection/Collection.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { translate } from 'react-polyglot';\nimport { lengths, components } from 'decap-cms-ui-default';\n\nimport { getNewEntryUrl } from '../../lib/urlHelper';\nimport Sidebar from './Sidebar';\nimport CollectionTop from './CollectionTop';\nimport EntriesCollection from './Entries/EntriesCollection';\nimport EntriesSearch from './Entries/EntriesSearch';\nimport CollectionControls from './CollectionControls';\nimport { sortByField, filterByField, changeViewStyle, groupByField } from '../../actions/entries';\nimport {\n  selectSortableFields,\n  selectViewFilters,\n  selectViewGroups,\n} from '../../reducers/collections';\nimport {\n  selectEntriesSort,\n  selectEntriesFilter,\n  selectEntriesGroup,\n  selectViewStyle,\n} from '../../reducers/entries';\n\nconst CollectionContainer = styled.div`\n  margin: ${lengths.pageMargin};\n`;\n\nconst CollectionMain = styled.main`\n  padding-left: 280px;\n`;\n\nconst SearchResultContainer = styled.div`\n  ${components.cardTop};\n  margin-bottom: 22px;\n`;\n\nconst SearchResultHeading = styled.h1`\n  ${components.cardTopHeading};\n`;\n\nexport class Collection extends React.Component {\n  static propTypes = {\n    searchTerm: PropTypes.string,\n    collectionName: PropTypes.string,\n    isSearchResults: PropTypes.bool,\n    isSingleSearchResult: PropTypes.bool,\n    collection: ImmutablePropTypes.map.isRequired,\n    collections: ImmutablePropTypes.map.isRequired,\n    sortableFields: PropTypes.array,\n    sort: ImmutablePropTypes.orderedMap,\n    onSortClick: PropTypes.func.isRequired,\n  };\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(Collection.propTypes, this.props, 'prop', 'Collection');\n  }\n\n  renderEntriesCollection = () => {\n    const { collection, filterTerm, viewStyle } = this.props;\n    return (\n      <EntriesCollection collection={collection} viewStyle={viewStyle} filterTerm={filterTerm} />\n    );\n  };\n\n  renderEntriesSearch = () => {\n    const { searchTerm, collections, collection, isSingleSearchResult } = this.props;\n    return (\n      <EntriesSearch\n        collections={isSingleSearchResult ? collections.filter(c => c === collection) : collections}\n        searchTerm={searchTerm}\n      />\n    );\n  };\n\n  render() {\n    const {\n      collection,\n      collections,\n      collectionName,\n      isSearchEnabled,\n      isSearchResults,\n      isSingleSearchResult,\n      searchTerm,\n      sortableFields,\n      onSortClick,\n      sort,\n      viewFilters,\n      viewGroups,\n      filterTerm,\n      t,\n      onFilterClick,\n      onGroupClick,\n      filter,\n      group,\n      onChangeViewStyle,\n      viewStyle,\n    } = this.props;\n\n    let newEntryUrl = collection.get('create') ? getNewEntryUrl(collectionName) : '';\n    if (newEntryUrl && filterTerm) {\n      newEntryUrl = getNewEntryUrl(collectionName);\n      if (filterTerm) {\n        newEntryUrl = `${newEntryUrl}?path=${filterTerm}`;\n      }\n    }\n\n    const searchResultKey =\n      'collection.collectionTop.searchResults' + (isSingleSearchResult ? 'InCollection' : '');\n\n    return (\n      <CollectionContainer>\n        <Sidebar\n          collections={collections}\n          collection={(!isSearchResults || isSingleSearchResult) && collection}\n          isSearchEnabled={isSearchEnabled}\n          searchTerm={searchTerm}\n          filterTerm={filterTerm}\n        />\n        <CollectionMain>\n          {isSearchResults ? (\n            <SearchResultContainer>\n              <SearchResultHeading>\n                {t(searchResultKey, { searchTerm, collection: collection.get('label') })}\n              </SearchResultHeading>\n            </SearchResultContainer>\n          ) : (\n            <>\n              <CollectionTop collection={collection} newEntryUrl={newEntryUrl} />\n              <CollectionControls\n                viewStyle={viewStyle}\n                onChangeViewStyle={onChangeViewStyle}\n                sortableFields={sortableFields}\n                onSortClick={onSortClick}\n                sort={sort}\n                viewFilters={viewFilters}\n                viewGroups={viewGroups}\n                t={t}\n                onFilterClick={onFilterClick}\n                onGroupClick={onGroupClick}\n                filter={filter}\n                group={group}\n              />\n            </>\n          )}\n          {isSearchResults ? this.renderEntriesSearch() : this.renderEntriesCollection()}\n        </CollectionMain>\n      </CollectionContainer>\n    );\n  }\n}\n\nfunction mapStateToProps(state, ownProps) {\n  const { collections } = state;\n  const isSearchEnabled = state.config && state.config.search != false;\n  const { isSearchResults, match, t } = ownProps;\n  const { name, searchTerm = '', filterTerm = '' } = match.params;\n  const collection = name ? collections.get(name) : collections.first();\n  const sort = selectEntriesSort(state.entries, collection.get('name'));\n  const sortableFields = selectSortableFields(collection, t);\n  const viewFilters = selectViewFilters(collection);\n  const viewGroups = selectViewGroups(collection);\n  const filter = selectEntriesFilter(state.entries, collection.get('name'));\n  const group = selectEntriesGroup(state.entries, collection.get('name'));\n  const viewStyle = selectViewStyle(state.entries);\n\n  return {\n    collection,\n    collections,\n    collectionName: name,\n    isSearchEnabled,\n    isSearchResults,\n    searchTerm,\n    filterTerm,\n    sort,\n    sortableFields,\n    viewFilters,\n    viewGroups,\n    filter,\n    group,\n    viewStyle,\n  };\n}\n\nconst mapDispatchToProps = {\n  sortByField,\n  filterByField,\n  changeViewStyle,\n  groupByField,\n};\n\nfunction mergeProps(stateProps, dispatchProps, ownProps) {\n  return {\n    ...stateProps,\n    ...ownProps,\n    onSortClick: (key, direction) =>\n      dispatchProps.sortByField(stateProps.collection, key, direction),\n    onFilterClick: filter => dispatchProps.filterByField(stateProps.collection, filter),\n    onGroupClick: group => dispatchProps.groupByField(stateProps.collection, group),\n    onChangeViewStyle: viewStyle => dispatchProps.changeViewStyle(viewStyle),\n  };\n}\n\nconst ConnectedCollection = connect(mapStateToProps, mapDispatchToProps, mergeProps)(Collection);\n\nexport default translate()(ConnectedCollection);\n"]} */"));
28
23
  const CollectionMain = /*#__PURE__*/_styled("main", {
29
24
  target: "e1sogrfi2",
30
25
  label: "CollectionMain"
@@ -33,46 +28,57 @@ const CollectionMain = /*#__PURE__*/_styled("main", {
33
28
  styles: "padding-left:280px"
34
29
  } : {
35
30
  name: "tka7ew",
36
- styles: "padding-left:280px",
37
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Collection/Collection.js"],"names":[],"mappings":"AA+BkC","file":"../../../../src/components/Collection/Collection.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { translate } from 'react-polyglot';\nimport { lengths, components } from 'decap-cms-ui-default';\n\nimport { getNewEntryUrl } from '../../lib/urlHelper';\nimport Sidebar from './Sidebar';\nimport CollectionTop from './CollectionTop';\nimport EntriesCollection from './Entries/EntriesCollection';\nimport EntriesSearch from './Entries/EntriesSearch';\nimport CollectionControls from './CollectionControls';\nimport { sortByField, filterByField, changeViewStyle, groupByField } from '../../actions/entries';\nimport {\n  selectSortableFields,\n  selectViewFilters,\n  selectViewGroups,\n} from '../../reducers/collections';\nimport {\n  selectEntriesSort,\n  selectEntriesFilter,\n  selectEntriesGroup,\n  selectViewStyle,\n} from '../../reducers/entries';\n\nconst CollectionContainer = styled.div`\n  margin: ${lengths.pageMargin};\n`;\n\nconst CollectionMain = styled.main`\n  padding-left: 280px;\n`;\n\nconst SearchResultContainer = styled.div`\n  ${components.cardTop};\n  margin-bottom: 22px;\n`;\n\nconst SearchResultHeading = styled.h1`\n  ${components.cardTopHeading};\n`;\n\nexport class Collection extends React.Component {\n  static propTypes = {\n    searchTerm: PropTypes.string,\n    collectionName: PropTypes.string,\n    isSearchResults: PropTypes.bool,\n    isSingleSearchResult: PropTypes.bool,\n    collection: ImmutablePropTypes.map.isRequired,\n    collections: ImmutablePropTypes.map.isRequired,\n    sortableFields: PropTypes.array,\n    sort: ImmutablePropTypes.orderedMap,\n    onSortClick: PropTypes.func.isRequired,\n  };\n\n  renderEntriesCollection = () => {\n    const { collection, filterTerm, viewStyle } = this.props;\n    return (\n      <EntriesCollection collection={collection} viewStyle={viewStyle} filterTerm={filterTerm} />\n    );\n  };\n\n  renderEntriesSearch = () => {\n    const { searchTerm, collections, collection, isSingleSearchResult } = this.props;\n    return (\n      <EntriesSearch\n        collections={isSingleSearchResult ? collections.filter(c => c === collection) : collections}\n        searchTerm={searchTerm}\n      />\n    );\n  };\n\n  render() {\n    const {\n      collection,\n      collections,\n      collectionName,\n      isSearchEnabled,\n      isSearchResults,\n      isSingleSearchResult,\n      searchTerm,\n      sortableFields,\n      onSortClick,\n      sort,\n      viewFilters,\n      viewGroups,\n      filterTerm,\n      t,\n      onFilterClick,\n      onGroupClick,\n      filter,\n      group,\n      onChangeViewStyle,\n      viewStyle,\n    } = this.props;\n\n    let newEntryUrl = collection.get('create') ? getNewEntryUrl(collectionName) : '';\n    if (newEntryUrl && filterTerm) {\n      newEntryUrl = getNewEntryUrl(collectionName);\n      if (filterTerm) {\n        newEntryUrl = `${newEntryUrl}?path=${filterTerm}`;\n      }\n    }\n\n    const searchResultKey =\n      'collection.collectionTop.searchResults' + (isSingleSearchResult ? 'InCollection' : '');\n\n    return (\n      <CollectionContainer>\n        <Sidebar\n          collections={collections}\n          collection={(!isSearchResults || isSingleSearchResult) && collection}\n          isSearchEnabled={isSearchEnabled}\n          searchTerm={searchTerm}\n          filterTerm={filterTerm}\n        />\n        <CollectionMain>\n          {isSearchResults ? (\n            <SearchResultContainer>\n              <SearchResultHeading>\n                {t(searchResultKey, { searchTerm, collection: collection.get('label') })}\n              </SearchResultHeading>\n            </SearchResultContainer>\n          ) : (\n            <>\n              <CollectionTop collection={collection} newEntryUrl={newEntryUrl} />\n              <CollectionControls\n                viewStyle={viewStyle}\n                onChangeViewStyle={onChangeViewStyle}\n                sortableFields={sortableFields}\n                onSortClick={onSortClick}\n                sort={sort}\n                viewFilters={viewFilters}\n                viewGroups={viewGroups}\n                t={t}\n                onFilterClick={onFilterClick}\n                onGroupClick={onGroupClick}\n                filter={filter}\n                group={group}\n              />\n            </>\n          )}\n          {isSearchResults ? this.renderEntriesSearch() : this.renderEntriesCollection()}\n        </CollectionMain>\n      </CollectionContainer>\n    );\n  }\n}\n\nfunction mapStateToProps(state, ownProps) {\n  const { collections } = state;\n  const isSearchEnabled = state.config && state.config.search != false;\n  const { isSearchResults, match, t } = ownProps;\n  const { name, searchTerm = '', filterTerm = '' } = match.params;\n  const collection = name ? collections.get(name) : collections.first();\n  const sort = selectEntriesSort(state.entries, collection.get('name'));\n  const sortableFields = selectSortableFields(collection, t);\n  const viewFilters = selectViewFilters(collection);\n  const viewGroups = selectViewGroups(collection);\n  const filter = selectEntriesFilter(state.entries, collection.get('name'));\n  const group = selectEntriesGroup(state.entries, collection.get('name'));\n  const viewStyle = selectViewStyle(state.entries);\n\n  return {\n    collection,\n    collections,\n    collectionName: name,\n    isSearchEnabled,\n    isSearchResults,\n    searchTerm,\n    filterTerm,\n    sort,\n    sortableFields,\n    viewFilters,\n    viewGroups,\n    filter,\n    group,\n    viewStyle,\n  };\n}\n\nconst mapDispatchToProps = {\n  sortByField,\n  filterByField,\n  changeViewStyle,\n  groupByField,\n};\n\nfunction mergeProps(stateProps, dispatchProps, ownProps) {\n  return {\n    ...stateProps,\n    ...ownProps,\n    onSortClick: (key, direction) =>\n      dispatchProps.sortByField(stateProps.collection, key, direction),\n    onFilterClick: filter => dispatchProps.filterByField(stateProps.collection, filter),\n    onGroupClick: group => dispatchProps.groupByField(stateProps.collection, group),\n    onChangeViewStyle: viewStyle => dispatchProps.changeViewStyle(viewStyle),\n  };\n}\n\nconst ConnectedCollection = connect(mapStateToProps, mapDispatchToProps, mergeProps)(Collection);\n\nexport default translate()(ConnectedCollection);\n"]} */",
31
+ styles: "padding-left:280px/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Collection/Collection.js"],"names":[],"mappings":"AA+BkC","file":"../../../../src/components/Collection/Collection.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { translate } from 'react-polyglot';\nimport { lengths, components } from 'decap-cms-ui-default';\n\nimport { getNewEntryUrl } from '../../lib/urlHelper';\nimport Sidebar from './Sidebar';\nimport CollectionTop from './CollectionTop';\nimport EntriesCollection from './Entries/EntriesCollection';\nimport EntriesSearch from './Entries/EntriesSearch';\nimport CollectionControls from './CollectionControls';\nimport { sortByField, filterByField, changeViewStyle, groupByField } from '../../actions/entries';\nimport {\n  selectSortableFields,\n  selectViewFilters,\n  selectViewGroups,\n} from '../../reducers/collections';\nimport {\n  selectEntriesSort,\n  selectEntriesFilter,\n  selectEntriesGroup,\n  selectViewStyle,\n} from '../../reducers/entries';\n\nconst CollectionContainer = styled.div`\n  margin: ${lengths.pageMargin};\n`;\n\nconst CollectionMain = styled.main`\n  padding-left: 280px;\n`;\n\nconst SearchResultContainer = styled.div`\n  ${components.cardTop};\n  margin-bottom: 22px;\n`;\n\nconst SearchResultHeading = styled.h1`\n  ${components.cardTopHeading};\n`;\n\nexport class Collection extends React.Component {\n  static propTypes = {\n    searchTerm: PropTypes.string,\n    collectionName: PropTypes.string,\n    isSearchResults: PropTypes.bool,\n    isSingleSearchResult: PropTypes.bool,\n    collection: ImmutablePropTypes.map.isRequired,\n    collections: ImmutablePropTypes.map.isRequired,\n    sortableFields: PropTypes.array,\n    sort: ImmutablePropTypes.orderedMap,\n    onSortClick: PropTypes.func.isRequired,\n  };\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(Collection.propTypes, this.props, 'prop', 'Collection');\n  }\n\n  renderEntriesCollection = () => {\n    const { collection, filterTerm, viewStyle } = this.props;\n    return (\n      <EntriesCollection collection={collection} viewStyle={viewStyle} filterTerm={filterTerm} />\n    );\n  };\n\n  renderEntriesSearch = () => {\n    const { searchTerm, collections, collection, isSingleSearchResult } = this.props;\n    return (\n      <EntriesSearch\n        collections={isSingleSearchResult ? collections.filter(c => c === collection) : collections}\n        searchTerm={searchTerm}\n      />\n    );\n  };\n\n  render() {\n    const {\n      collection,\n      collections,\n      collectionName,\n      isSearchEnabled,\n      isSearchResults,\n      isSingleSearchResult,\n      searchTerm,\n      sortableFields,\n      onSortClick,\n      sort,\n      viewFilters,\n      viewGroups,\n      filterTerm,\n      t,\n      onFilterClick,\n      onGroupClick,\n      filter,\n      group,\n      onChangeViewStyle,\n      viewStyle,\n    } = this.props;\n\n    let newEntryUrl = collection.get('create') ? getNewEntryUrl(collectionName) : '';\n    if (newEntryUrl && filterTerm) {\n      newEntryUrl = getNewEntryUrl(collectionName);\n      if (filterTerm) {\n        newEntryUrl = `${newEntryUrl}?path=${filterTerm}`;\n      }\n    }\n\n    const searchResultKey =\n      'collection.collectionTop.searchResults' + (isSingleSearchResult ? 'InCollection' : '');\n\n    return (\n      <CollectionContainer>\n        <Sidebar\n          collections={collections}\n          collection={(!isSearchResults || isSingleSearchResult) && collection}\n          isSearchEnabled={isSearchEnabled}\n          searchTerm={searchTerm}\n          filterTerm={filterTerm}\n        />\n        <CollectionMain>\n          {isSearchResults ? (\n            <SearchResultContainer>\n              <SearchResultHeading>\n                {t(searchResultKey, { searchTerm, collection: collection.get('label') })}\n              </SearchResultHeading>\n            </SearchResultContainer>\n          ) : (\n            <>\n              <CollectionTop collection={collection} newEntryUrl={newEntryUrl} />\n              <CollectionControls\n                viewStyle={viewStyle}\n                onChangeViewStyle={onChangeViewStyle}\n                sortableFields={sortableFields}\n                onSortClick={onSortClick}\n                sort={sort}\n                viewFilters={viewFilters}\n                viewGroups={viewGroups}\n                t={t}\n                onFilterClick={onFilterClick}\n                onGroupClick={onGroupClick}\n                filter={filter}\n                group={group}\n              />\n            </>\n          )}\n          {isSearchResults ? this.renderEntriesSearch() : this.renderEntriesCollection()}\n        </CollectionMain>\n      </CollectionContainer>\n    );\n  }\n}\n\nfunction mapStateToProps(state, ownProps) {\n  const { collections } = state;\n  const isSearchEnabled = state.config && state.config.search != false;\n  const { isSearchResults, match, t } = ownProps;\n  const { name, searchTerm = '', filterTerm = '' } = match.params;\n  const collection = name ? collections.get(name) : collections.first();\n  const sort = selectEntriesSort(state.entries, collection.get('name'));\n  const sortableFields = selectSortableFields(collection, t);\n  const viewFilters = selectViewFilters(collection);\n  const viewGroups = selectViewGroups(collection);\n  const filter = selectEntriesFilter(state.entries, collection.get('name'));\n  const group = selectEntriesGroup(state.entries, collection.get('name'));\n  const viewStyle = selectViewStyle(state.entries);\n\n  return {\n    collection,\n    collections,\n    collectionName: name,\n    isSearchEnabled,\n    isSearchResults,\n    searchTerm,\n    filterTerm,\n    sort,\n    sortableFields,\n    viewFilters,\n    viewGroups,\n    filter,\n    group,\n    viewStyle,\n  };\n}\n\nconst mapDispatchToProps = {\n  sortByField,\n  filterByField,\n  changeViewStyle,\n  groupByField,\n};\n\nfunction mergeProps(stateProps, dispatchProps, ownProps) {\n  return {\n    ...stateProps,\n    ...ownProps,\n    onSortClick: (key, direction) =>\n      dispatchProps.sortByField(stateProps.collection, key, direction),\n    onFilterClick: filter => dispatchProps.filterByField(stateProps.collection, filter),\n    onGroupClick: group => dispatchProps.groupByField(stateProps.collection, group),\n    onChangeViewStyle: viewStyle => dispatchProps.changeViewStyle(viewStyle),\n  };\n}\n\nconst ConnectedCollection = connect(mapStateToProps, mapDispatchToProps, mergeProps)(Collection);\n\nexport default translate()(ConnectedCollection);\n"]} */",
38
32
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
39
33
  });
40
34
  const SearchResultContainer = /*#__PURE__*/_styled("div", {
41
35
  target: "e1sogrfi1",
42
36
  label: "SearchResultContainer"
43
- })(components.cardTop, ";margin-bottom:22px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Collection/Collection.js"],"names":[],"mappings":"AAmCwC","file":"../../../../src/components/Collection/Collection.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { translate } from 'react-polyglot';\nimport { lengths, components } from 'decap-cms-ui-default';\n\nimport { getNewEntryUrl } from '../../lib/urlHelper';\nimport Sidebar from './Sidebar';\nimport CollectionTop from './CollectionTop';\nimport EntriesCollection from './Entries/EntriesCollection';\nimport EntriesSearch from './Entries/EntriesSearch';\nimport CollectionControls from './CollectionControls';\nimport { sortByField, filterByField, changeViewStyle, groupByField } from '../../actions/entries';\nimport {\n  selectSortableFields,\n  selectViewFilters,\n  selectViewGroups,\n} from '../../reducers/collections';\nimport {\n  selectEntriesSort,\n  selectEntriesFilter,\n  selectEntriesGroup,\n  selectViewStyle,\n} from '../../reducers/entries';\n\nconst CollectionContainer = styled.div`\n  margin: ${lengths.pageMargin};\n`;\n\nconst CollectionMain = styled.main`\n  padding-left: 280px;\n`;\n\nconst SearchResultContainer = styled.div`\n  ${components.cardTop};\n  margin-bottom: 22px;\n`;\n\nconst SearchResultHeading = styled.h1`\n  ${components.cardTopHeading};\n`;\n\nexport class Collection extends React.Component {\n  static propTypes = {\n    searchTerm: PropTypes.string,\n    collectionName: PropTypes.string,\n    isSearchResults: PropTypes.bool,\n    isSingleSearchResult: PropTypes.bool,\n    collection: ImmutablePropTypes.map.isRequired,\n    collections: ImmutablePropTypes.map.isRequired,\n    sortableFields: PropTypes.array,\n    sort: ImmutablePropTypes.orderedMap,\n    onSortClick: PropTypes.func.isRequired,\n  };\n\n  renderEntriesCollection = () => {\n    const { collection, filterTerm, viewStyle } = this.props;\n    return (\n      <EntriesCollection collection={collection} viewStyle={viewStyle} filterTerm={filterTerm} />\n    );\n  };\n\n  renderEntriesSearch = () => {\n    const { searchTerm, collections, collection, isSingleSearchResult } = this.props;\n    return (\n      <EntriesSearch\n        collections={isSingleSearchResult ? collections.filter(c => c === collection) : collections}\n        searchTerm={searchTerm}\n      />\n    );\n  };\n\n  render() {\n    const {\n      collection,\n      collections,\n      collectionName,\n      isSearchEnabled,\n      isSearchResults,\n      isSingleSearchResult,\n      searchTerm,\n      sortableFields,\n      onSortClick,\n      sort,\n      viewFilters,\n      viewGroups,\n      filterTerm,\n      t,\n      onFilterClick,\n      onGroupClick,\n      filter,\n      group,\n      onChangeViewStyle,\n      viewStyle,\n    } = this.props;\n\n    let newEntryUrl = collection.get('create') ? getNewEntryUrl(collectionName) : '';\n    if (newEntryUrl && filterTerm) {\n      newEntryUrl = getNewEntryUrl(collectionName);\n      if (filterTerm) {\n        newEntryUrl = `${newEntryUrl}?path=${filterTerm}`;\n      }\n    }\n\n    const searchResultKey =\n      'collection.collectionTop.searchResults' + (isSingleSearchResult ? 'InCollection' : '');\n\n    return (\n      <CollectionContainer>\n        <Sidebar\n          collections={collections}\n          collection={(!isSearchResults || isSingleSearchResult) && collection}\n          isSearchEnabled={isSearchEnabled}\n          searchTerm={searchTerm}\n          filterTerm={filterTerm}\n        />\n        <CollectionMain>\n          {isSearchResults ? (\n            <SearchResultContainer>\n              <SearchResultHeading>\n                {t(searchResultKey, { searchTerm, collection: collection.get('label') })}\n              </SearchResultHeading>\n            </SearchResultContainer>\n          ) : (\n            <>\n              <CollectionTop collection={collection} newEntryUrl={newEntryUrl} />\n              <CollectionControls\n                viewStyle={viewStyle}\n                onChangeViewStyle={onChangeViewStyle}\n                sortableFields={sortableFields}\n                onSortClick={onSortClick}\n                sort={sort}\n                viewFilters={viewFilters}\n                viewGroups={viewGroups}\n                t={t}\n                onFilterClick={onFilterClick}\n                onGroupClick={onGroupClick}\n                filter={filter}\n                group={group}\n              />\n            </>\n          )}\n          {isSearchResults ? this.renderEntriesSearch() : this.renderEntriesCollection()}\n        </CollectionMain>\n      </CollectionContainer>\n    );\n  }\n}\n\nfunction mapStateToProps(state, ownProps) {\n  const { collections } = state;\n  const isSearchEnabled = state.config && state.config.search != false;\n  const { isSearchResults, match, t } = ownProps;\n  const { name, searchTerm = '', filterTerm = '' } = match.params;\n  const collection = name ? collections.get(name) : collections.first();\n  const sort = selectEntriesSort(state.entries, collection.get('name'));\n  const sortableFields = selectSortableFields(collection, t);\n  const viewFilters = selectViewFilters(collection);\n  const viewGroups = selectViewGroups(collection);\n  const filter = selectEntriesFilter(state.entries, collection.get('name'));\n  const group = selectEntriesGroup(state.entries, collection.get('name'));\n  const viewStyle = selectViewStyle(state.entries);\n\n  return {\n    collection,\n    collections,\n    collectionName: name,\n    isSearchEnabled,\n    isSearchResults,\n    searchTerm,\n    filterTerm,\n    sort,\n    sortableFields,\n    viewFilters,\n    viewGroups,\n    filter,\n    group,\n    viewStyle,\n  };\n}\n\nconst mapDispatchToProps = {\n  sortByField,\n  filterByField,\n  changeViewStyle,\n  groupByField,\n};\n\nfunction mergeProps(stateProps, dispatchProps, ownProps) {\n  return {\n    ...stateProps,\n    ...ownProps,\n    onSortClick: (key, direction) =>\n      dispatchProps.sortByField(stateProps.collection, key, direction),\n    onFilterClick: filter => dispatchProps.filterByField(stateProps.collection, filter),\n    onGroupClick: group => dispatchProps.groupByField(stateProps.collection, group),\n    onChangeViewStyle: viewStyle => dispatchProps.changeViewStyle(viewStyle),\n  };\n}\n\nconst ConnectedCollection = connect(mapStateToProps, mapDispatchToProps, mergeProps)(Collection);\n\nexport default translate()(ConnectedCollection);\n"]} */"));
37
+ })(components.cardTop, ";margin-bottom:22px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Collection/Collection.js"],"names":[],"mappings":"AAmCwC","file":"../../../../src/components/Collection/Collection.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { translate } from 'react-polyglot';\nimport { lengths, components } from 'decap-cms-ui-default';\n\nimport { getNewEntryUrl } from '../../lib/urlHelper';\nimport Sidebar from './Sidebar';\nimport CollectionTop from './CollectionTop';\nimport EntriesCollection from './Entries/EntriesCollection';\nimport EntriesSearch from './Entries/EntriesSearch';\nimport CollectionControls from './CollectionControls';\nimport { sortByField, filterByField, changeViewStyle, groupByField } from '../../actions/entries';\nimport {\n  selectSortableFields,\n  selectViewFilters,\n  selectViewGroups,\n} from '../../reducers/collections';\nimport {\n  selectEntriesSort,\n  selectEntriesFilter,\n  selectEntriesGroup,\n  selectViewStyle,\n} from '../../reducers/entries';\n\nconst CollectionContainer = styled.div`\n  margin: ${lengths.pageMargin};\n`;\n\nconst CollectionMain = styled.main`\n  padding-left: 280px;\n`;\n\nconst SearchResultContainer = styled.div`\n  ${components.cardTop};\n  margin-bottom: 22px;\n`;\n\nconst SearchResultHeading = styled.h1`\n  ${components.cardTopHeading};\n`;\n\nexport class Collection extends React.Component {\n  static propTypes = {\n    searchTerm: PropTypes.string,\n    collectionName: PropTypes.string,\n    isSearchResults: PropTypes.bool,\n    isSingleSearchResult: PropTypes.bool,\n    collection: ImmutablePropTypes.map.isRequired,\n    collections: ImmutablePropTypes.map.isRequired,\n    sortableFields: PropTypes.array,\n    sort: ImmutablePropTypes.orderedMap,\n    onSortClick: PropTypes.func.isRequired,\n  };\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(Collection.propTypes, this.props, 'prop', 'Collection');\n  }\n\n  renderEntriesCollection = () => {\n    const { collection, filterTerm, viewStyle } = this.props;\n    return (\n      <EntriesCollection collection={collection} viewStyle={viewStyle} filterTerm={filterTerm} />\n    );\n  };\n\n  renderEntriesSearch = () => {\n    const { searchTerm, collections, collection, isSingleSearchResult } = this.props;\n    return (\n      <EntriesSearch\n        collections={isSingleSearchResult ? collections.filter(c => c === collection) : collections}\n        searchTerm={searchTerm}\n      />\n    );\n  };\n\n  render() {\n    const {\n      collection,\n      collections,\n      collectionName,\n      isSearchEnabled,\n      isSearchResults,\n      isSingleSearchResult,\n      searchTerm,\n      sortableFields,\n      onSortClick,\n      sort,\n      viewFilters,\n      viewGroups,\n      filterTerm,\n      t,\n      onFilterClick,\n      onGroupClick,\n      filter,\n      group,\n      onChangeViewStyle,\n      viewStyle,\n    } = this.props;\n\n    let newEntryUrl = collection.get('create') ? getNewEntryUrl(collectionName) : '';\n    if (newEntryUrl && filterTerm) {\n      newEntryUrl = getNewEntryUrl(collectionName);\n      if (filterTerm) {\n        newEntryUrl = `${newEntryUrl}?path=${filterTerm}`;\n      }\n    }\n\n    const searchResultKey =\n      'collection.collectionTop.searchResults' + (isSingleSearchResult ? 'InCollection' : '');\n\n    return (\n      <CollectionContainer>\n        <Sidebar\n          collections={collections}\n          collection={(!isSearchResults || isSingleSearchResult) && collection}\n          isSearchEnabled={isSearchEnabled}\n          searchTerm={searchTerm}\n          filterTerm={filterTerm}\n        />\n        <CollectionMain>\n          {isSearchResults ? (\n            <SearchResultContainer>\n              <SearchResultHeading>\n                {t(searchResultKey, { searchTerm, collection: collection.get('label') })}\n              </SearchResultHeading>\n            </SearchResultContainer>\n          ) : (\n            <>\n              <CollectionTop collection={collection} newEntryUrl={newEntryUrl} />\n              <CollectionControls\n                viewStyle={viewStyle}\n                onChangeViewStyle={onChangeViewStyle}\n                sortableFields={sortableFields}\n                onSortClick={onSortClick}\n                sort={sort}\n                viewFilters={viewFilters}\n                viewGroups={viewGroups}\n                t={t}\n                onFilterClick={onFilterClick}\n                onGroupClick={onGroupClick}\n                filter={filter}\n                group={group}\n              />\n            </>\n          )}\n          {isSearchResults ? this.renderEntriesSearch() : this.renderEntriesCollection()}\n        </CollectionMain>\n      </CollectionContainer>\n    );\n  }\n}\n\nfunction mapStateToProps(state, ownProps) {\n  const { collections } = state;\n  const isSearchEnabled = state.config && state.config.search != false;\n  const { isSearchResults, match, t } = ownProps;\n  const { name, searchTerm = '', filterTerm = '' } = match.params;\n  const collection = name ? collections.get(name) : collections.first();\n  const sort = selectEntriesSort(state.entries, collection.get('name'));\n  const sortableFields = selectSortableFields(collection, t);\n  const viewFilters = selectViewFilters(collection);\n  const viewGroups = selectViewGroups(collection);\n  const filter = selectEntriesFilter(state.entries, collection.get('name'));\n  const group = selectEntriesGroup(state.entries, collection.get('name'));\n  const viewStyle = selectViewStyle(state.entries);\n\n  return {\n    collection,\n    collections,\n    collectionName: name,\n    isSearchEnabled,\n    isSearchResults,\n    searchTerm,\n    filterTerm,\n    sort,\n    sortableFields,\n    viewFilters,\n    viewGroups,\n    filter,\n    group,\n    viewStyle,\n  };\n}\n\nconst mapDispatchToProps = {\n  sortByField,\n  filterByField,\n  changeViewStyle,\n  groupByField,\n};\n\nfunction mergeProps(stateProps, dispatchProps, ownProps) {\n  return {\n    ...stateProps,\n    ...ownProps,\n    onSortClick: (key, direction) =>\n      dispatchProps.sortByField(stateProps.collection, key, direction),\n    onFilterClick: filter => dispatchProps.filterByField(stateProps.collection, filter),\n    onGroupClick: group => dispatchProps.groupByField(stateProps.collection, group),\n    onChangeViewStyle: viewStyle => dispatchProps.changeViewStyle(viewStyle),\n  };\n}\n\nconst ConnectedCollection = connect(mapStateToProps, mapDispatchToProps, mergeProps)(Collection);\n\nexport default translate()(ConnectedCollection);\n"]} */"));
44
38
  const SearchResultHeading = /*#__PURE__*/_styled("h1", {
45
39
  target: "e1sogrfi0",
46
40
  label: "SearchResultHeading"
47
- })(components.cardTopHeading, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Collection/Collection.js"],"names":[],"mappings":"AAwCqC","file":"../../../../src/components/Collection/Collection.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { translate } from 'react-polyglot';\nimport { lengths, components } from 'decap-cms-ui-default';\n\nimport { getNewEntryUrl } from '../../lib/urlHelper';\nimport Sidebar from './Sidebar';\nimport CollectionTop from './CollectionTop';\nimport EntriesCollection from './Entries/EntriesCollection';\nimport EntriesSearch from './Entries/EntriesSearch';\nimport CollectionControls from './CollectionControls';\nimport { sortByField, filterByField, changeViewStyle, groupByField } from '../../actions/entries';\nimport {\n  selectSortableFields,\n  selectViewFilters,\n  selectViewGroups,\n} from '../../reducers/collections';\nimport {\n  selectEntriesSort,\n  selectEntriesFilter,\n  selectEntriesGroup,\n  selectViewStyle,\n} from '../../reducers/entries';\n\nconst CollectionContainer = styled.div`\n  margin: ${lengths.pageMargin};\n`;\n\nconst CollectionMain = styled.main`\n  padding-left: 280px;\n`;\n\nconst SearchResultContainer = styled.div`\n  ${components.cardTop};\n  margin-bottom: 22px;\n`;\n\nconst SearchResultHeading = styled.h1`\n  ${components.cardTopHeading};\n`;\n\nexport class Collection extends React.Component {\n  static propTypes = {\n    searchTerm: PropTypes.string,\n    collectionName: PropTypes.string,\n    isSearchResults: PropTypes.bool,\n    isSingleSearchResult: PropTypes.bool,\n    collection: ImmutablePropTypes.map.isRequired,\n    collections: ImmutablePropTypes.map.isRequired,\n    sortableFields: PropTypes.array,\n    sort: ImmutablePropTypes.orderedMap,\n    onSortClick: PropTypes.func.isRequired,\n  };\n\n  renderEntriesCollection = () => {\n    const { collection, filterTerm, viewStyle } = this.props;\n    return (\n      <EntriesCollection collection={collection} viewStyle={viewStyle} filterTerm={filterTerm} />\n    );\n  };\n\n  renderEntriesSearch = () => {\n    const { searchTerm, collections, collection, isSingleSearchResult } = this.props;\n    return (\n      <EntriesSearch\n        collections={isSingleSearchResult ? collections.filter(c => c === collection) : collections}\n        searchTerm={searchTerm}\n      />\n    );\n  };\n\n  render() {\n    const {\n      collection,\n      collections,\n      collectionName,\n      isSearchEnabled,\n      isSearchResults,\n      isSingleSearchResult,\n      searchTerm,\n      sortableFields,\n      onSortClick,\n      sort,\n      viewFilters,\n      viewGroups,\n      filterTerm,\n      t,\n      onFilterClick,\n      onGroupClick,\n      filter,\n      group,\n      onChangeViewStyle,\n      viewStyle,\n    } = this.props;\n\n    let newEntryUrl = collection.get('create') ? getNewEntryUrl(collectionName) : '';\n    if (newEntryUrl && filterTerm) {\n      newEntryUrl = getNewEntryUrl(collectionName);\n      if (filterTerm) {\n        newEntryUrl = `${newEntryUrl}?path=${filterTerm}`;\n      }\n    }\n\n    const searchResultKey =\n      'collection.collectionTop.searchResults' + (isSingleSearchResult ? 'InCollection' : '');\n\n    return (\n      <CollectionContainer>\n        <Sidebar\n          collections={collections}\n          collection={(!isSearchResults || isSingleSearchResult) && collection}\n          isSearchEnabled={isSearchEnabled}\n          searchTerm={searchTerm}\n          filterTerm={filterTerm}\n        />\n        <CollectionMain>\n          {isSearchResults ? (\n            <SearchResultContainer>\n              <SearchResultHeading>\n                {t(searchResultKey, { searchTerm, collection: collection.get('label') })}\n              </SearchResultHeading>\n            </SearchResultContainer>\n          ) : (\n            <>\n              <CollectionTop collection={collection} newEntryUrl={newEntryUrl} />\n              <CollectionControls\n                viewStyle={viewStyle}\n                onChangeViewStyle={onChangeViewStyle}\n                sortableFields={sortableFields}\n                onSortClick={onSortClick}\n                sort={sort}\n                viewFilters={viewFilters}\n                viewGroups={viewGroups}\n                t={t}\n                onFilterClick={onFilterClick}\n                onGroupClick={onGroupClick}\n                filter={filter}\n                group={group}\n              />\n            </>\n          )}\n          {isSearchResults ? this.renderEntriesSearch() : this.renderEntriesCollection()}\n        </CollectionMain>\n      </CollectionContainer>\n    );\n  }\n}\n\nfunction mapStateToProps(state, ownProps) {\n  const { collections } = state;\n  const isSearchEnabled = state.config && state.config.search != false;\n  const { isSearchResults, match, t } = ownProps;\n  const { name, searchTerm = '', filterTerm = '' } = match.params;\n  const collection = name ? collections.get(name) : collections.first();\n  const sort = selectEntriesSort(state.entries, collection.get('name'));\n  const sortableFields = selectSortableFields(collection, t);\n  const viewFilters = selectViewFilters(collection);\n  const viewGroups = selectViewGroups(collection);\n  const filter = selectEntriesFilter(state.entries, collection.get('name'));\n  const group = selectEntriesGroup(state.entries, collection.get('name'));\n  const viewStyle = selectViewStyle(state.entries);\n\n  return {\n    collection,\n    collections,\n    collectionName: name,\n    isSearchEnabled,\n    isSearchResults,\n    searchTerm,\n    filterTerm,\n    sort,\n    sortableFields,\n    viewFilters,\n    viewGroups,\n    filter,\n    group,\n    viewStyle,\n  };\n}\n\nconst mapDispatchToProps = {\n  sortByField,\n  filterByField,\n  changeViewStyle,\n  groupByField,\n};\n\nfunction mergeProps(stateProps, dispatchProps, ownProps) {\n  return {\n    ...stateProps,\n    ...ownProps,\n    onSortClick: (key, direction) =>\n      dispatchProps.sortByField(stateProps.collection, key, direction),\n    onFilterClick: filter => dispatchProps.filterByField(stateProps.collection, filter),\n    onGroupClick: group => dispatchProps.groupByField(stateProps.collection, group),\n    onChangeViewStyle: viewStyle => dispatchProps.changeViewStyle(viewStyle),\n  };\n}\n\nconst ConnectedCollection = connect(mapStateToProps, mapDispatchToProps, mergeProps)(Collection);\n\nexport default translate()(ConnectedCollection);\n"]} */"));
41
+ })(components.cardTopHeading, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Collection/Collection.js"],"names":[],"mappings":"AAwCqC","file":"../../../../src/components/Collection/Collection.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { translate } from 'react-polyglot';\nimport { lengths, components } from 'decap-cms-ui-default';\n\nimport { getNewEntryUrl } from '../../lib/urlHelper';\nimport Sidebar from './Sidebar';\nimport CollectionTop from './CollectionTop';\nimport EntriesCollection from './Entries/EntriesCollection';\nimport EntriesSearch from './Entries/EntriesSearch';\nimport CollectionControls from './CollectionControls';\nimport { sortByField, filterByField, changeViewStyle, groupByField } from '../../actions/entries';\nimport {\n  selectSortableFields,\n  selectViewFilters,\n  selectViewGroups,\n} from '../../reducers/collections';\nimport {\n  selectEntriesSort,\n  selectEntriesFilter,\n  selectEntriesGroup,\n  selectViewStyle,\n} from '../../reducers/entries';\n\nconst CollectionContainer = styled.div`\n  margin: ${lengths.pageMargin};\n`;\n\nconst CollectionMain = styled.main`\n  padding-left: 280px;\n`;\n\nconst SearchResultContainer = styled.div`\n  ${components.cardTop};\n  margin-bottom: 22px;\n`;\n\nconst SearchResultHeading = styled.h1`\n  ${components.cardTopHeading};\n`;\n\nexport class Collection extends React.Component {\n  static propTypes = {\n    searchTerm: PropTypes.string,\n    collectionName: PropTypes.string,\n    isSearchResults: PropTypes.bool,\n    isSingleSearchResult: PropTypes.bool,\n    collection: ImmutablePropTypes.map.isRequired,\n    collections: ImmutablePropTypes.map.isRequired,\n    sortableFields: PropTypes.array,\n    sort: ImmutablePropTypes.orderedMap,\n    onSortClick: PropTypes.func.isRequired,\n  };\n\n  componentDidMount() {\n    // Manually validate PropTypes - React 19 breaking change\n    PropTypes.checkPropTypes(Collection.propTypes, this.props, 'prop', 'Collection');\n  }\n\n  renderEntriesCollection = () => {\n    const { collection, filterTerm, viewStyle } = this.props;\n    return (\n      <EntriesCollection collection={collection} viewStyle={viewStyle} filterTerm={filterTerm} />\n    );\n  };\n\n  renderEntriesSearch = () => {\n    const { searchTerm, collections, collection, isSingleSearchResult } = this.props;\n    return (\n      <EntriesSearch\n        collections={isSingleSearchResult ? collections.filter(c => c === collection) : collections}\n        searchTerm={searchTerm}\n      />\n    );\n  };\n\n  render() {\n    const {\n      collection,\n      collections,\n      collectionName,\n      isSearchEnabled,\n      isSearchResults,\n      isSingleSearchResult,\n      searchTerm,\n      sortableFields,\n      onSortClick,\n      sort,\n      viewFilters,\n      viewGroups,\n      filterTerm,\n      t,\n      onFilterClick,\n      onGroupClick,\n      filter,\n      group,\n      onChangeViewStyle,\n      viewStyle,\n    } = this.props;\n\n    let newEntryUrl = collection.get('create') ? getNewEntryUrl(collectionName) : '';\n    if (newEntryUrl && filterTerm) {\n      newEntryUrl = getNewEntryUrl(collectionName);\n      if (filterTerm) {\n        newEntryUrl = `${newEntryUrl}?path=${filterTerm}`;\n      }\n    }\n\n    const searchResultKey =\n      'collection.collectionTop.searchResults' + (isSingleSearchResult ? 'InCollection' : '');\n\n    return (\n      <CollectionContainer>\n        <Sidebar\n          collections={collections}\n          collection={(!isSearchResults || isSingleSearchResult) && collection}\n          isSearchEnabled={isSearchEnabled}\n          searchTerm={searchTerm}\n          filterTerm={filterTerm}\n        />\n        <CollectionMain>\n          {isSearchResults ? (\n            <SearchResultContainer>\n              <SearchResultHeading>\n                {t(searchResultKey, { searchTerm, collection: collection.get('label') })}\n              </SearchResultHeading>\n            </SearchResultContainer>\n          ) : (\n            <>\n              <CollectionTop collection={collection} newEntryUrl={newEntryUrl} />\n              <CollectionControls\n                viewStyle={viewStyle}\n                onChangeViewStyle={onChangeViewStyle}\n                sortableFields={sortableFields}\n                onSortClick={onSortClick}\n                sort={sort}\n                viewFilters={viewFilters}\n                viewGroups={viewGroups}\n                t={t}\n                onFilterClick={onFilterClick}\n                onGroupClick={onGroupClick}\n                filter={filter}\n                group={group}\n              />\n            </>\n          )}\n          {isSearchResults ? this.renderEntriesSearch() : this.renderEntriesCollection()}\n        </CollectionMain>\n      </CollectionContainer>\n    );\n  }\n}\n\nfunction mapStateToProps(state, ownProps) {\n  const { collections } = state;\n  const isSearchEnabled = state.config && state.config.search != false;\n  const { isSearchResults, match, t } = ownProps;\n  const { name, searchTerm = '', filterTerm = '' } = match.params;\n  const collection = name ? collections.get(name) : collections.first();\n  const sort = selectEntriesSort(state.entries, collection.get('name'));\n  const sortableFields = selectSortableFields(collection, t);\n  const viewFilters = selectViewFilters(collection);\n  const viewGroups = selectViewGroups(collection);\n  const filter = selectEntriesFilter(state.entries, collection.get('name'));\n  const group = selectEntriesGroup(state.entries, collection.get('name'));\n  const viewStyle = selectViewStyle(state.entries);\n\n  return {\n    collection,\n    collections,\n    collectionName: name,\n    isSearchEnabled,\n    isSearchResults,\n    searchTerm,\n    filterTerm,\n    sort,\n    sortableFields,\n    viewFilters,\n    viewGroups,\n    filter,\n    group,\n    viewStyle,\n  };\n}\n\nconst mapDispatchToProps = {\n  sortByField,\n  filterByField,\n  changeViewStyle,\n  groupByField,\n};\n\nfunction mergeProps(stateProps, dispatchProps, ownProps) {\n  return {\n    ...stateProps,\n    ...ownProps,\n    onSortClick: (key, direction) =>\n      dispatchProps.sortByField(stateProps.collection, key, direction),\n    onFilterClick: filter => dispatchProps.filterByField(stateProps.collection, filter),\n    onGroupClick: group => dispatchProps.groupByField(stateProps.collection, group),\n    onChangeViewStyle: viewStyle => dispatchProps.changeViewStyle(viewStyle),\n  };\n}\n\nconst ConnectedCollection = connect(mapStateToProps, mapDispatchToProps, mergeProps)(Collection);\n\nexport default translate()(ConnectedCollection);\n"]} */"));
48
42
  export class Collection extends React.Component {
49
- constructor(...args) {
50
- super(...args);
51
- _defineProperty(this, "renderEntriesCollection", () => {
52
- const {
53
- collection,
54
- filterTerm,
55
- viewStyle
56
- } = this.props;
57
- return ___EmotionJSX(EntriesCollection, {
58
- collection: collection,
59
- viewStyle: viewStyle,
60
- filterTerm: filterTerm
61
- });
43
+ static propTypes = {
44
+ searchTerm: PropTypes.string,
45
+ collectionName: PropTypes.string,
46
+ isSearchResults: PropTypes.bool,
47
+ isSingleSearchResult: PropTypes.bool,
48
+ collection: ImmutablePropTypes.map.isRequired,
49
+ collections: ImmutablePropTypes.map.isRequired,
50
+ sortableFields: PropTypes.array,
51
+ sort: ImmutablePropTypes.orderedMap,
52
+ onSortClick: PropTypes.func.isRequired
53
+ };
54
+ componentDidMount() {
55
+ // Manually validate PropTypes - React 19 breaking change
56
+ PropTypes.checkPropTypes(Collection.propTypes, this.props, 'prop', 'Collection');
57
+ }
58
+ renderEntriesCollection = () => {
59
+ const {
60
+ collection,
61
+ filterTerm,
62
+ viewStyle
63
+ } = this.props;
64
+ return ___EmotionJSX(EntriesCollection, {
65
+ collection: collection,
66
+ viewStyle: viewStyle,
67
+ filterTerm: filterTerm
62
68
  });
63
- _defineProperty(this, "renderEntriesSearch", () => {
64
- const {
65
- searchTerm,
66
- collections,
67
- collection,
68
- isSingleSearchResult
69
- } = this.props;
70
- return ___EmotionJSX(EntriesSearch, {
71
- collections: isSingleSearchResult ? collections.filter(c => c === collection) : collections,
72
- searchTerm: searchTerm
73
- });
69
+ };
70
+ renderEntriesSearch = () => {
71
+ const {
72
+ searchTerm,
73
+ collections,
74
+ collection,
75
+ isSingleSearchResult
76
+ } = this.props;
77
+ return ___EmotionJSX(EntriesSearch, {
78
+ collections: isSingleSearchResult ? collections.filter(c => c === collection) : collections,
79
+ searchTerm: searchTerm
74
80
  });
75
- }
81
+ };
76
82
  render() {
77
83
  const {
78
84
  collection,
@@ -132,17 +138,6 @@ export class Collection extends React.Component {
132
138
  })), isSearchResults ? this.renderEntriesSearch() : this.renderEntriesCollection()));
133
139
  }
134
140
  }
135
- _defineProperty(Collection, "propTypes", {
136
- searchTerm: PropTypes.string,
137
- collectionName: PropTypes.string,
138
- isSearchResults: PropTypes.bool,
139
- isSingleSearchResult: PropTypes.bool,
140
- collection: ImmutablePropTypes.map.isRequired,
141
- collections: ImmutablePropTypes.map.isRequired,
142
- sortableFields: PropTypes.array,
143
- sort: ImmutablePropTypes.orderedMap,
144
- onSortClick: PropTypes.func.isRequired
145
- });
146
141
  function mapStateToProps(state, ownProps) {
147
142
  const {
148
143
  collections
@@ -190,12 +185,14 @@ const mapDispatchToProps = {
190
185
  groupByField
191
186
  };
192
187
  function mergeProps(stateProps, dispatchProps, ownProps) {
193
- return _objectSpread(_objectSpread(_objectSpread({}, stateProps), ownProps), {}, {
188
+ return {
189
+ ...stateProps,
190
+ ...ownProps,
194
191
  onSortClick: (key, direction) => dispatchProps.sortByField(stateProps.collection, key, direction),
195
192
  onFilterClick: filter => dispatchProps.filterByField(stateProps.collection, filter),
196
193
  onGroupClick: group => dispatchProps.groupByField(stateProps.collection, group),
197
194
  onChangeViewStyle: viewStyle => dispatchProps.changeViewStyle(viewStyle)
198
- });
195
+ };
199
196
  }
200
197
  const ConnectedCollection = connect(mapStateToProps, mapDispatchToProps, mergeProps)(Collection);
201
198
  export default translate()(ConnectedCollection);