decap-cms-core 3.2.5 → 3.2.8

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 (128) hide show
  1. package/dist/decap-cms-core.js +9 -9
  2. package/dist/decap-cms-core.js.map +1 -1
  3. package/dist/esm/actions/auth.js +6 -12
  4. package/dist/esm/actions/config.js +5 -8
  5. package/dist/esm/actions/deploys.js +3 -6
  6. package/dist/esm/actions/editorialWorkflow.js +19 -36
  7. package/dist/esm/actions/entries.js +35 -68
  8. package/dist/esm/actions/media.js +6 -12
  9. package/dist/esm/actions/mediaLibrary.js +19 -36
  10. package/dist/esm/actions/notifications.js +3 -6
  11. package/dist/esm/actions/search.js +8 -16
  12. package/dist/esm/actions/status.js +3 -6
  13. package/dist/esm/backend.js +10 -8
  14. package/dist/esm/bootstrap.js +11 -12
  15. package/dist/esm/components/App/App.js +49 -50
  16. package/dist/esm/components/App/Header.js +42 -43
  17. package/dist/esm/components/App/NotFoundPage.js +5 -6
  18. package/dist/esm/components/Collection/Collection.js +23 -24
  19. package/dist/esm/components/Collection/CollectionControls.js +9 -10
  20. package/dist/esm/components/Collection/CollectionSearch.js +36 -37
  21. package/dist/esm/components/Collection/CollectionTop.js +18 -19
  22. package/dist/esm/components/Collection/ControlButton.js +6 -6
  23. package/dist/esm/components/Collection/Entries/Entries.js +15 -16
  24. package/dist/esm/components/Collection/Entries/EntriesCollection.js +11 -12
  25. package/dist/esm/components/Collection/Entries/EntriesSearch.js +3 -4
  26. package/dist/esm/components/Collection/Entries/EntryCard.js +35 -36
  27. package/dist/esm/components/Collection/Entries/EntryListing.js +10 -10
  28. package/dist/esm/components/Collection/FilterControl.js +5 -6
  29. package/dist/esm/components/Collection/GroupControl.js +5 -6
  30. package/dist/esm/components/Collection/NestedCollection.js +40 -41
  31. package/dist/esm/components/Collection/Sidebar.js +27 -28
  32. package/dist/esm/components/Collection/SortControl.js +5 -6
  33. package/dist/esm/components/Collection/ViewStyleControl.js +15 -16
  34. package/dist/esm/components/Editor/Editor.js +5 -6
  35. package/dist/esm/components/Editor/EditorControlPane/EditorControl.js +24 -26
  36. package/dist/esm/components/Editor/EditorControlPane/EditorControlPane.js +39 -39
  37. package/dist/esm/components/Editor/EditorControlPane/Widget.js +2 -2
  38. package/dist/esm/components/Editor/EditorInterface.js +67 -68
  39. package/dist/esm/components/Editor/EditorPreviewPane/EditorPreview.js +8 -8
  40. package/dist/esm/components/Editor/EditorPreviewPane/EditorPreviewContent.js +3 -4
  41. package/dist/esm/components/Editor/EditorPreviewPane/EditorPreviewPane.js +18 -19
  42. package/dist/esm/components/Editor/EditorPreviewPane/PreviewHOC.js +1 -2
  43. package/dist/esm/components/Editor/EditorToolbar.js +155 -156
  44. package/dist/esm/components/Editor/withWorkflow.js +4 -4
  45. package/dist/esm/components/EditorWidgets/Unknown/UnknownControl.js +3 -4
  46. package/dist/esm/components/EditorWidgets/Unknown/UnknownPreview.js +3 -4
  47. package/dist/esm/components/MediaLibrary/EmptyMessage.js +6 -7
  48. package/dist/esm/components/MediaLibrary/MediaLibrary.js +7 -8
  49. package/dist/esm/components/MediaLibrary/MediaLibraryButtons.js +17 -21
  50. package/dist/esm/components/MediaLibrary/MediaLibraryCard.js +25 -26
  51. package/dist/esm/components/MediaLibrary/MediaLibraryCardGrid.js +29 -30
  52. package/dist/esm/components/MediaLibrary/MediaLibraryHeader.js +10 -11
  53. package/dist/esm/components/MediaLibrary/MediaLibraryModal.js +10 -12
  54. package/dist/esm/components/MediaLibrary/MediaLibrarySearch.js +15 -16
  55. package/dist/esm/components/MediaLibrary/MediaLibraryTop.js +27 -28
  56. package/dist/esm/components/UI/DragDrop.js +3 -3
  57. package/dist/esm/components/UI/ErrorBoundary.js +15 -16
  58. package/dist/esm/components/UI/FileUploadButton.js +3 -3
  59. package/dist/esm/components/UI/Modal.js +5 -5
  60. package/dist/esm/components/UI/Notifications.js +7 -8
  61. package/dist/esm/components/UI/SettingsDropdown.js +41 -42
  62. package/dist/esm/components/Workflow/Workflow.js +21 -22
  63. package/dist/esm/components/Workflow/WorkflowCard.js +44 -45
  64. package/dist/esm/components/Workflow/WorkflowList.js +56 -57
  65. package/dist/esm/constants/collectionTypes.js +2 -4
  66. package/dist/esm/constants/collectionViews.js +2 -4
  67. package/dist/esm/constants/commitProps.js +2 -4
  68. package/dist/esm/constants/configSchema.js +2 -2
  69. package/dist/esm/constants/fieldInference.js +8 -11
  70. package/dist/esm/constants/publishModes.js +6 -11
  71. package/dist/esm/constants/validationErrorTypes.js +2 -3
  72. package/dist/esm/formats/formats.js +5 -8
  73. package/dist/esm/formats/frontmatter.js +3 -4
  74. package/dist/esm/formats/json.js +2 -3
  75. package/dist/esm/formats/toml.js +2 -3
  76. package/dist/esm/formats/yaml.js +2 -3
  77. package/dist/esm/index.js +4 -6
  78. package/dist/esm/integrations/index.js +2 -3
  79. package/dist/esm/integrations/providers/algolia/implementation.js +2 -2
  80. package/dist/esm/integrations/providers/assetStore/implementation.js +2 -2
  81. package/dist/esm/lib/formatters.js +2 -2
  82. package/dist/esm/lib/i18n.js +5 -8
  83. package/dist/esm/lib/registry.js +3 -4
  84. package/dist/esm/lib/urlHelper.js +2 -2
  85. package/dist/esm/reducers/auth.js +2 -4
  86. package/dist/esm/reducers/collections.js +3 -4
  87. package/dist/esm/reducers/combinedReducer.js +3 -4
  88. package/dist/esm/reducers/config.js +3 -4
  89. package/dist/esm/reducers/cursors.js +1 -2
  90. package/dist/esm/reducers/deploys.js +1 -2
  91. package/dist/esm/reducers/editorialWorkflow.js +3 -4
  92. package/dist/esm/reducers/entries.js +3 -4
  93. package/dist/esm/reducers/entryDraft.js +1 -2
  94. package/dist/esm/reducers/globalUI.js +1 -2
  95. package/dist/esm/reducers/index.js +15 -12
  96. package/dist/esm/reducers/integrations.js +3 -4
  97. package/dist/esm/reducers/mediaLibrary.js +3 -4
  98. package/dist/esm/reducers/medias.js +1 -2
  99. package/dist/esm/reducers/notifications.js +3 -4
  100. package/dist/esm/reducers/search.js +1 -2
  101. package/dist/esm/reducers/status.js +1 -2
  102. package/dist/esm/redux/index.js +1 -2
  103. package/dist/esm/redux/middleware/waitUntilAction.js +1 -2
  104. package/dist/esm/routing/history.js +1 -2
  105. package/dist/esm/types/redux.js +2 -3
  106. package/dist/esm/valueObjects/EditorComponent.js +2 -2
  107. package/index.d.ts +1 -0
  108. package/package.json +4 -4
  109. package/src/backend.ts +6 -1
  110. package/src/components/App/Header.js +1 -1
  111. package/src/components/Collection/ControlButton.js +1 -1
  112. package/src/components/Collection/NestedCollection.js +1 -1
  113. package/src/components/Collection/Sidebar.js +1 -1
  114. package/src/components/Collection/__tests__/__snapshots__/Collection.spec.js.snap +16 -16
  115. package/src/components/Collection/__tests__/__snapshots__/NestedCollection.spec.js.snap +143 -143
  116. package/src/components/Collection/__tests__/__snapshots__/Sidebar.spec.js.snap +36 -36
  117. package/src/components/Editor/EditorControlPane/EditorControl.js +1 -1
  118. package/src/components/Editor/EditorControlPane/EditorControlPane.js +1 -1
  119. package/src/components/Editor/EditorInterface.js +1 -1
  120. package/src/components/Editor/EditorToolbar.js +1 -1
  121. package/src/components/Editor/__tests__/__snapshots__/EditorToolbar.spec.js.snap +1000 -1102
  122. package/src/components/MediaLibrary/MediaLibraryButtons.js +1 -1
  123. package/src/components/MediaLibrary/__tests__/__snapshots__/MediaLibraryCard.spec.js.snap +94 -46
  124. package/src/components/UI/Modal.js +1 -1
  125. package/src/components/UI/SettingsDropdown.js +1 -1
  126. package/src/components/Workflow/WorkflowCard.js +1 -1
  127. package/src/components/Workflow/WorkflowList.js +1 -1
  128. package/src/types/redux.ts +1 -0
@@ -4,7 +4,7 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
6
  exports.default = exports.Collection = void 0;
7
- var _styledBase = _interopRequireDefault(require("@emotion/styled-base"));
7
+ var _base = _interopRequireDefault(require("@emotion/styled/base"));
8
8
  var _react = _interopRequireDefault(require("react"));
9
9
  var _propTypes = _interopRequireDefault(require("prop-types"));
10
10
  var _reactImmutableProptypes = _interopRequireDefault(require("react-immutable-proptypes"));
@@ -20,36 +20,36 @@ var _CollectionControls = _interopRequireDefault(require("./CollectionControls")
20
20
  var _entries = require("../../actions/entries");
21
21
  var _collections = require("../../reducers/collections");
22
22
  var _entries2 = require("../../reducers/entries");
23
- var _core = require("@emotion/core");
23
+ var _react2 = require("@emotion/react");
24
24
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
25
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
26
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
25
+ 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; }
26
+ 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; }
27
27
  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; }
28
28
  function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); }
29
29
  function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
30
30
  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)."; }
31
- const CollectionContainer = (0, _styledBase.default)("div", {
32
- target: "e1sogrfi0",
31
+ const CollectionContainer = /*#__PURE__*/(0, _base.default)("div", {
32
+ target: "e1sogrfi3",
33
33
  label: "CollectionContainer"
34
34
  })("margin:", _decapCmsUiDefault.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"]} */"));
35
- const CollectionMain = (0, _styledBase.default)("main", {
36
- target: "e1sogrfi1",
35
+ const CollectionMain = /*#__PURE__*/(0, _base.default)("main", {
36
+ target: "e1sogrfi2",
37
37
  label: "CollectionMain"
38
38
  })(process.env.NODE_ENV === "production" ? {
39
- name: "1r4jzjw",
40
- styles: "padding-left:280px;"
39
+ name: "tka7ew",
40
+ styles: "padding-left:280px"
41
41
  } : {
42
- name: "1r4jzjw",
43
- styles: "padding-left:280px;",
42
+ name: "tka7ew",
43
+ styles: "padding-left:280px",
44
44
  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"]} */",
45
45
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
46
46
  });
47
- const SearchResultContainer = (0, _styledBase.default)("div", {
48
- target: "e1sogrfi2",
47
+ const SearchResultContainer = /*#__PURE__*/(0, _base.default)("div", {
48
+ target: "e1sogrfi1",
49
49
  label: "SearchResultContainer"
50
50
  })(_decapCmsUiDefault.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"]} */"));
51
- const SearchResultHeading = (0, _styledBase.default)("h1", {
52
- target: "e1sogrfi3",
51
+ const SearchResultHeading = /*#__PURE__*/(0, _base.default)("h1", {
52
+ target: "e1sogrfi0",
53
53
  label: "SearchResultHeading"
54
54
  })(_decapCmsUiDefault.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"]} */"));
55
55
  class Collection extends _react.default.Component {
@@ -61,7 +61,7 @@ class Collection extends _react.default.Component {
61
61
  filterTerm,
62
62
  viewStyle
63
63
  } = this.props;
64
- return (0, _core.jsx)(_EntriesCollection.default, {
64
+ return (0, _react2.jsx)(_EntriesCollection.default, {
65
65
  collection: collection,
66
66
  viewStyle: viewStyle,
67
67
  filterTerm: filterTerm
@@ -74,7 +74,7 @@ class Collection extends _react.default.Component {
74
74
  collection,
75
75
  isSingleSearchResult
76
76
  } = this.props;
77
- return (0, _core.jsx)(_EntriesSearch.default, {
77
+ return (0, _react2.jsx)(_EntriesSearch.default, {
78
78
  collections: isSingleSearchResult ? collections.filter(c => c === collection) : collections,
79
79
  searchTerm: searchTerm
80
80
  });
@@ -111,19 +111,19 @@ class Collection extends _react.default.Component {
111
111
  }
112
112
  }
113
113
  const searchResultKey = 'collection.collectionTop.searchResults' + (isSingleSearchResult ? 'InCollection' : '');
114
- return (0, _core.jsx)(CollectionContainer, null, (0, _core.jsx)(_Sidebar.default, {
114
+ return (0, _react2.jsx)(CollectionContainer, null, (0, _react2.jsx)(_Sidebar.default, {
115
115
  collections: collections,
116
116
  collection: (!isSearchResults || isSingleSearchResult) && collection,
117
117
  isSearchEnabled: isSearchEnabled,
118
118
  searchTerm: searchTerm,
119
119
  filterTerm: filterTerm
120
- }), (0, _core.jsx)(CollectionMain, null, isSearchResults ? (0, _core.jsx)(SearchResultContainer, null, (0, _core.jsx)(SearchResultHeading, null, t(searchResultKey, {
120
+ }), (0, _react2.jsx)(CollectionMain, null, isSearchResults ? (0, _react2.jsx)(SearchResultContainer, null, (0, _react2.jsx)(SearchResultHeading, null, t(searchResultKey, {
121
121
  searchTerm,
122
122
  collection: collection.get('label')
123
- }))) : (0, _core.jsx)(_react.default.Fragment, null, (0, _core.jsx)(_CollectionTop.default, {
123
+ }))) : (0, _react2.jsx)(_react.default.Fragment, null, (0, _react2.jsx)(_CollectionTop.default, {
124
124
  collection: collection,
125
125
  newEntryUrl: newEntryUrl
126
- }), (0, _core.jsx)(_CollectionControls.default, {
126
+ }), (0, _react2.jsx)(_CollectionControls.default, {
127
127
  viewStyle: viewStyle,
128
128
  onChangeViewStyle: onChangeViewStyle,
129
129
  sortableFields: sortableFields,
@@ -206,5 +206,4 @@ function mergeProps(stateProps, dispatchProps, ownProps) {
206
206
  });
207
207
  }
208
208
  const ConnectedCollection = (0, _reactRedux.connect)(mapStateToProps, mapDispatchToProps, mergeProps)(Collection);
209
- var _default = (0, _reactPolyglot.translate)()(ConnectedCollection);
210
- exports.default = _default;
209
+ var _default = exports.default = (0, _reactPolyglot.translate)()(ConnectedCollection);
@@ -4,19 +4,19 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
6
  exports.default = void 0;
7
- var _styledBase = _interopRequireDefault(require("@emotion/styled-base"));
7
+ var _base = _interopRequireDefault(require("@emotion/styled/base"));
8
8
  var _react = _interopRequireDefault(require("react"));
9
9
  var _decapCmsUiDefault = require("decap-cms-ui-default");
10
10
  var _ViewStyleControl = _interopRequireDefault(require("./ViewStyleControl"));
11
11
  var _SortControl = _interopRequireDefault(require("./SortControl"));
12
12
  var _FilterControl = _interopRequireDefault(require("./FilterControl"));
13
13
  var _GroupControl = _interopRequireDefault(require("./GroupControl"));
14
- var _core = require("@emotion/core");
14
+ var _react2 = require("@emotion/react");
15
15
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
16
- const CollectionControlsContainer = (0, _styledBase.default)("div", {
16
+ const CollectionControlsContainer = /*#__PURE__*/(0, _base.default)("div", {
17
17
  target: "emfmed70",
18
18
  label: "CollectionControlsContainer"
19
- })("display:flex;align-items:center;flex-direction:row-reverse;margin-top:22px;width:", _decapCmsUiDefault.lengths.topCardWidth, ";max-width:100%;& > div{margin-left:6px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vQ29sbGVjdGlvbkNvbnRyb2xzLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVM4QyIsImZpbGUiOiIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9Db2xsZWN0aW9uL0NvbGxlY3Rpb25Db250cm9scy5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBsZW5ndGhzIH0gZnJvbSAnZGVjYXAtY21zLXVpLWRlZmF1bHQnO1xuXG5pbXBvcnQgVmlld1N0eWxlQ29udHJvbCBmcm9tICcuL1ZpZXdTdHlsZUNvbnRyb2wnO1xuaW1wb3J0IFNvcnRDb250cm9sIGZyb20gJy4vU29ydENvbnRyb2wnO1xuaW1wb3J0IEZpbHRlckNvbnRyb2wgZnJvbSAnLi9GaWx0ZXJDb250cm9sJztcbmltcG9ydCBHcm91cENvbnRyb2wgZnJvbSAnLi9Hcm91cENvbnRyb2wnO1xuXG5jb25zdCBDb2xsZWN0aW9uQ29udHJvbHNDb250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBmbGV4LWRpcmVjdGlvbjogcm93LXJldmVyc2U7XG4gIG1hcmdpbi10b3A6IDIycHg7XG4gIHdpZHRoOiAke2xlbmd0aHMudG9wQ2FyZFdpZHRofTtcbiAgbWF4LXdpZHRoOiAxMDAlO1xuXG4gICYgPiBkaXYge1xuICAgIG1hcmdpbi1sZWZ0OiA2cHg7XG4gIH1cbmA7XG5cbmZ1bmN0aW9uIENvbGxlY3Rpb25Db250cm9scyh7XG4gIHZpZXdTdHlsZSxcbiAgb25DaGFuZ2VWaWV3U3R5bGUsXG4gIHNvcnRhYmxlRmllbGRzLFxuICBvblNvcnRDbGljayxcbiAgc29ydCxcbiAgdmlld0ZpbHRlcnMsXG4gIHZpZXdHcm91cHMsXG4gIG9uRmlsdGVyQ2xpY2ssXG4gIG9uR3JvdXBDbGljayxcbiAgdCxcbiAgZmlsdGVyLFxuICBncm91cCxcbn0pIHtcbiAgcmV0dXJuIChcbiAgICA8Q29sbGVjdGlvbkNvbnRyb2xzQ29udGFpbmVyPlxuICAgICAgPFZpZXdTdHlsZUNvbnRyb2wgdmlld1N0eWxlPXt2aWV3U3R5bGV9IG9uQ2hhbmdlVmlld1N0eWxlPXtvbkNoYW5nZVZpZXdTdHlsZX0gLz5cbiAgICAgIHt2aWV3R3JvdXBzLmxlbmd0aCA+IDAgJiYgKFxuICAgICAgICA8R3JvdXBDb250cm9sIHZpZXdHcm91cHM9e3ZpZXdHcm91cHN9IG9uR3JvdXBDbGljaz17b25Hcm91cENsaWNrfSB0PXt0fSBncm91cD17Z3JvdXB9IC8+XG4gICAgICApfVxuICAgICAge3ZpZXdGaWx0ZXJzLmxlbmd0aCA+IDAgJiYgKFxuICAgICAgICA8RmlsdGVyQ29udHJvbFxuICAgICAgICAgIHZpZXdGaWx0ZXJzPXt2aWV3RmlsdGVyc31cbiAgICAgICAgICBvbkZpbHRlckNsaWNrPXtvbkZpbHRlckNsaWNrfVxuICAgICAgICAgIHQ9e3R9XG4gICAgICAgICAgZmlsdGVyPXtmaWx0ZXJ9XG4gICAgICAgIC8+XG4gICAgICApfVxuICAgICAge3NvcnRhYmxlRmllbGRzLmxlbmd0aCA+IDAgJiYgKFxuICAgICAgICA8U29ydENvbnRyb2wgZmllbGRzPXtzb3J0YWJsZUZpZWxkc30gc29ydD17c29ydH0gb25Tb3J0Q2xpY2s9e29uU29ydENsaWNrfSAvPlxuICAgICAgKX1cbiAgICA8L0NvbGxlY3Rpb25Db250cm9sc0NvbnRhaW5lcj5cbiAgKTtcbn1cblxuZXhwb3J0IGRlZmF1bHQgQ29sbGVjdGlvbkNvbnRyb2xzO1xuIl19 */"));
19
+ })("display:flex;align-items:center;flex-direction:row-reverse;margin-top:22px;width:", _decapCmsUiDefault.lengths.topCardWidth, ";max-width:100%;&>div{margin-left:6px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vQ29sbGVjdGlvbkNvbnRyb2xzLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVM4QyIsImZpbGUiOiIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9Db2xsZWN0aW9uL0NvbGxlY3Rpb25Db250cm9scy5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBsZW5ndGhzIH0gZnJvbSAnZGVjYXAtY21zLXVpLWRlZmF1bHQnO1xuXG5pbXBvcnQgVmlld1N0eWxlQ29udHJvbCBmcm9tICcuL1ZpZXdTdHlsZUNvbnRyb2wnO1xuaW1wb3J0IFNvcnRDb250cm9sIGZyb20gJy4vU29ydENvbnRyb2wnO1xuaW1wb3J0IEZpbHRlckNvbnRyb2wgZnJvbSAnLi9GaWx0ZXJDb250cm9sJztcbmltcG9ydCBHcm91cENvbnRyb2wgZnJvbSAnLi9Hcm91cENvbnRyb2wnO1xuXG5jb25zdCBDb2xsZWN0aW9uQ29udHJvbHNDb250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBmbGV4LWRpcmVjdGlvbjogcm93LXJldmVyc2U7XG4gIG1hcmdpbi10b3A6IDIycHg7XG4gIHdpZHRoOiAke2xlbmd0aHMudG9wQ2FyZFdpZHRofTtcbiAgbWF4LXdpZHRoOiAxMDAlO1xuXG4gICYgPiBkaXYge1xuICAgIG1hcmdpbi1sZWZ0OiA2cHg7XG4gIH1cbmA7XG5cbmZ1bmN0aW9uIENvbGxlY3Rpb25Db250cm9scyh7XG4gIHZpZXdTdHlsZSxcbiAgb25DaGFuZ2VWaWV3U3R5bGUsXG4gIHNvcnRhYmxlRmllbGRzLFxuICBvblNvcnRDbGljayxcbiAgc29ydCxcbiAgdmlld0ZpbHRlcnMsXG4gIHZpZXdHcm91cHMsXG4gIG9uRmlsdGVyQ2xpY2ssXG4gIG9uR3JvdXBDbGljayxcbiAgdCxcbiAgZmlsdGVyLFxuICBncm91cCxcbn0pIHtcbiAgcmV0dXJuIChcbiAgICA8Q29sbGVjdGlvbkNvbnRyb2xzQ29udGFpbmVyPlxuICAgICAgPFZpZXdTdHlsZUNvbnRyb2wgdmlld1N0eWxlPXt2aWV3U3R5bGV9IG9uQ2hhbmdlVmlld1N0eWxlPXtvbkNoYW5nZVZpZXdTdHlsZX0gLz5cbiAgICAgIHt2aWV3R3JvdXBzLmxlbmd0aCA+IDAgJiYgKFxuICAgICAgICA8R3JvdXBDb250cm9sIHZpZXdHcm91cHM9e3ZpZXdHcm91cHN9IG9uR3JvdXBDbGljaz17b25Hcm91cENsaWNrfSB0PXt0fSBncm91cD17Z3JvdXB9IC8+XG4gICAgICApfVxuICAgICAge3ZpZXdGaWx0ZXJzLmxlbmd0aCA+IDAgJiYgKFxuICAgICAgICA8RmlsdGVyQ29udHJvbFxuICAgICAgICAgIHZpZXdGaWx0ZXJzPXt2aWV3RmlsdGVyc31cbiAgICAgICAgICBvbkZpbHRlckNsaWNrPXtvbkZpbHRlckNsaWNrfVxuICAgICAgICAgIHQ9e3R9XG4gICAgICAgICAgZmlsdGVyPXtmaWx0ZXJ9XG4gICAgICAgIC8+XG4gICAgICApfVxuICAgICAge3NvcnRhYmxlRmllbGRzLmxlbmd0aCA+IDAgJiYgKFxuICAgICAgICA8U29ydENvbnRyb2wgZmllbGRzPXtzb3J0YWJsZUZpZWxkc30gc29ydD17c29ydH0gb25Tb3J0Q2xpY2s9e29uU29ydENsaWNrfSAvPlxuICAgICAgKX1cbiAgICA8L0NvbGxlY3Rpb25Db250cm9sc0NvbnRhaW5lcj5cbiAgKTtcbn1cblxuZXhwb3J0IGRlZmF1bHQgQ29sbGVjdGlvbkNvbnRyb2xzO1xuIl19 */"));
20
20
  function CollectionControls({
21
21
  viewStyle,
22
22
  onChangeViewStyle,
@@ -31,24 +31,23 @@ function CollectionControls({
31
31
  filter,
32
32
  group
33
33
  }) {
34
- return (0, _core.jsx)(CollectionControlsContainer, null, (0, _core.jsx)(_ViewStyleControl.default, {
34
+ return (0, _react2.jsx)(CollectionControlsContainer, null, (0, _react2.jsx)(_ViewStyleControl.default, {
35
35
  viewStyle: viewStyle,
36
36
  onChangeViewStyle: onChangeViewStyle
37
- }), viewGroups.length > 0 && (0, _core.jsx)(_GroupControl.default, {
37
+ }), viewGroups.length > 0 && (0, _react2.jsx)(_GroupControl.default, {
38
38
  viewGroups: viewGroups,
39
39
  onGroupClick: onGroupClick,
40
40
  t: t,
41
41
  group: group
42
- }), viewFilters.length > 0 && (0, _core.jsx)(_FilterControl.default, {
42
+ }), viewFilters.length > 0 && (0, _react2.jsx)(_FilterControl.default, {
43
43
  viewFilters: viewFilters,
44
44
  onFilterClick: onFilterClick,
45
45
  t: t,
46
46
  filter: filter
47
- }), sortableFields.length > 0 && (0, _core.jsx)(_SortControl.default, {
47
+ }), sortableFields.length > 0 && (0, _react2.jsx)(_SortControl.default, {
48
48
  fields: sortableFields,
49
49
  sort: sort,
50
50
  onSortClick: onSortClick
51
51
  }));
52
52
  }
53
- var _default = CollectionControls;
54
- exports.default = _default;
53
+ var _default = exports.default = CollectionControls;
@@ -4,60 +4,60 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
6
  exports.default = void 0;
7
- var _styledBase = _interopRequireDefault(require("@emotion/styled-base"));
7
+ var _base = _interopRequireDefault(require("@emotion/styled/base"));
8
8
  var _react = _interopRequireDefault(require("react"));
9
9
  var _decapCmsUiDefault = require("decap-cms-ui-default");
10
10
  var _reactPolyglot = require("react-polyglot");
11
11
  var _propTypes = _interopRequireDefault(require("prop-types"));
12
12
  var _reactImmutableProptypes = _interopRequireDefault(require("react-immutable-proptypes"));
13
- var _core = require("@emotion/core");
13
+ var _react2 = require("@emotion/react");
14
14
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
15
15
  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; }
16
16
  function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); }
17
17
  function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
18
18
  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)."; }
19
- const SearchContainer = (0, _styledBase.default)("div", {
20
- target: "e6w847r0",
19
+ const SearchContainer = /*#__PURE__*/(0, _base.default)("div", {
20
+ target: "e6w847r7",
21
21
  label: "SearchContainer"
22
22
  })("margin:0 12px;position:relative;", _decapCmsUiDefault.Icon, "{position:absolute;top:0;left:6px;z-index:", _decapCmsUiDefault.zIndex.zIndex2, ";height:100%;display:flex;align-items:center;pointer-events:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Collection/CollectionSearch.js"],"names":[],"mappings":"AAOkC","file":"../../../../src/components/Collection/CollectionSearch.js","sourcesContent":["import React from 'react';\nimport styled from '@emotion/styled';\nimport { colorsRaw, colors, Icon, lengths, zIndex } from 'decap-cms-ui-default';\nimport { translate } from 'react-polyglot';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\n\nconst SearchContainer = styled.div`\n  margin: 0 12px;\n  position: relative;\n\n  ${Icon} {\n    position: absolute;\n    top: 0;\n    left: 6px;\n    z-index: ${zIndex.zIndex2};\n    height: 100%;\n    display: flex;\n    align-items: center;\n    pointer-events: none;\n  }\n`;\n\nconst InputContainer = styled.div`\n  display: flex;\n  align-items: center;\n  position: relative;\n`;\n\nconst SearchInput = styled.input`\n  background-color: #eff0f4;\n  border-radius: ${lengths.borderRadius};\n  font-size: 14px;\n  padding: 10px 6px 10px 32px;\n  width: 100%;\n  position: relative;\n  z-index: ${zIndex.zIndex1};\n\n  &:focus {\n    outline: none;\n    box-shadow: inset 0 0 0 2px ${colorsRaw.blue};\n  }\n`;\n\nconst SuggestionsContainer = styled.div`\n  position: relative;\n  width: 100%;\n`;\n\nconst Suggestions = styled.ul`\n  position: absolute;\n  top: 6px;\n  left: 0;\n  right: 0;\n  padding: 10px 0;\n  margin: 0;\n  list-style: none;\n  background-color: #fff;\n  border-radius: ${lengths.borderRadius};\n  border: 1px solid ${colors.textFieldBorder};\n  z-index: ${zIndex.zIndex1};\n`;\n\nconst SuggestionHeader = styled.li`\n  padding: 0 6px 6px 32px;\n  font-size: 12px;\n  color: ${colors.text};\n`;\n\nconst SuggestionItem = styled.li(\n  ({ isActive }) => `\n  color: ${isActive ? colors.active : colorsRaw.grayDark};\n  background-color: ${isActive ? colors.activeBackground : 'inherit'};\n  padding: 6px 6px 6px 32px;\n  cursor: pointer;\n  position: relative;\n\n  &:hover {\n    color: ${colors.active};\n    background-color: ${colors.activeBackground};\n  }\n`,\n);\n\nconst SuggestionDivider = styled.div`\n  width: 100%;\n`;\n\nclass CollectionSearch extends React.Component {\n  static propTypes = {\n    collections: ImmutablePropTypes.map.isRequired,\n    collection: ImmutablePropTypes.map,\n    searchTerm: PropTypes.string.isRequired,\n    onSubmit: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    query: this.props.searchTerm,\n    suggestionsVisible: false,\n    // default to the currently selected\n    selectedCollectionIdx: this.getSelectedSelectionBasedOnProps(),\n  };\n\n  componentDidUpdate(prevProps) {\n    if (prevProps.collection !== this.props.collection) {\n      const selectedCollectionIdx = this.getSelectedSelectionBasedOnProps();\n      this.setState({ selectedCollectionIdx });\n    }\n  }\n\n  getSelectedSelectionBasedOnProps() {\n    const { collection, collections } = this.props;\n    return collection ? collections.keySeq().indexOf(collection.get('name')) : -1;\n  }\n\n  toggleSuggestions(visible) {\n    this.setState({ suggestionsVisible: visible });\n  }\n\n  selectNextSuggestion() {\n    const { collections } = this.props;\n    const { selectedCollectionIdx } = this.state;\n    this.setState({\n      selectedCollectionIdx: Math.min(selectedCollectionIdx + 1, collections.size - 1),\n    });\n  }\n\n  selectPreviousSuggestion() {\n    const { selectedCollectionIdx } = this.state;\n    this.setState({\n      selectedCollectionIdx: Math.max(selectedCollectionIdx - 1, -1),\n    });\n  }\n\n  resetSelectedSuggestion() {\n    this.setState({\n      selectedCollectionIdx: -1,\n    });\n  }\n\n  submitSearch = () => {\n    const { onSubmit, collections } = this.props;\n    const { selectedCollectionIdx, query } = this.state;\n\n    this.toggleSuggestions(false);\n    if (selectedCollectionIdx !== -1) {\n      onSubmit(query, collections.toIndexedSeq().getIn([selectedCollectionIdx, 'name']));\n    } else {\n      onSubmit(query);\n    }\n  };\n\n  handleKeyDown = event => {\n    const { suggestionsVisible } = this.state;\n\n    if (event.key === 'Enter') {\n      this.submitSearch();\n    }\n\n    if (suggestionsVisible) {\n      // allow closing of suggestions with escape key\n      if (event.key === 'Escape') {\n        this.toggleSuggestions(false);\n      }\n\n      if (event.key === 'ArrowDown') {\n        this.selectNextSuggestion();\n        event.preventDefault();\n      } else if (event.key === 'ArrowUp') {\n        this.selectPreviousSuggestion();\n        event.preventDefault();\n      }\n    }\n  };\n\n  handleQueryChange = query => {\n    this.setState({ query });\n    this.toggleSuggestions(query !== '');\n    if (query === '') {\n      this.resetSelectedSuggestion();\n    }\n  };\n\n  handleSuggestionClick = (event, idx) => {\n    this.setState({ selectedCollectionIdx: idx }, this.submitSearch);\n    event.preventDefault();\n  };\n\n  render() {\n    const { collections, t } = this.props;\n    const { suggestionsVisible, selectedCollectionIdx, query } = this.state;\n    return (\n      <SearchContainer\n        onBlur={() => this.toggleSuggestions(false)}\n        onFocus={() => this.toggleSuggestions(query !== '')}\n      >\n        <InputContainer>\n          <Icon type=\"search\" />\n          <SearchInput\n            onChange={e => this.handleQueryChange(e.target.value)}\n            onKeyDown={this.handleKeyDown}\n            onClick={() => this.toggleSuggestions(true)}\n            placeholder={t('collection.sidebar.searchAll')}\n            value={query}\n          />\n        </InputContainer>\n        {suggestionsVisible && (\n          <SuggestionsContainer>\n            <Suggestions>\n              <SuggestionHeader>{t('collection.sidebar.searchIn')}</SuggestionHeader>\n              <SuggestionItem\n                isActive={selectedCollectionIdx === -1}\n                onClick={e => this.handleSuggestionClick(e, -1)}\n                onMouseDown={e => e.preventDefault()}\n              >\n                {t('collection.sidebar.allCollections')}\n              </SuggestionItem>\n              <SuggestionDivider />\n              {collections.toIndexedSeq().map((collection, idx) => (\n                <SuggestionItem\n                  key={idx}\n                  isActive={idx === selectedCollectionIdx}\n                  onClick={e => this.handleSuggestionClick(e, idx)}\n                  onMouseDown={e => e.preventDefault()}\n                >\n                  {collection.get('label')}\n                </SuggestionItem>\n              ))}\n            </Suggestions>\n          </SuggestionsContainer>\n        )}\n      </SearchContainer>\n    );\n  }\n}\n\nexport default translate()(CollectionSearch);\n"]} */"));
23
- const InputContainer = (0, _styledBase.default)("div", {
24
- target: "e6w847r1",
23
+ const InputContainer = /*#__PURE__*/(0, _base.default)("div", {
24
+ target: "e6w847r6",
25
25
  label: "InputContainer"
26
26
  })(process.env.NODE_ENV === "production" ? {
27
- name: "14s4iyf",
28
- styles: "display:flex;align-items:center;position:relative;"
27
+ name: "1dbubah",
28
+ styles: "display:flex;align-items:center;position:relative"
29
29
  } : {
30
- name: "14s4iyf",
31
- styles: "display:flex;align-items:center;position:relative;",
30
+ name: "1dbubah",
31
+ styles: "display:flex;align-items:center;position:relative",
32
32
  map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Collection/CollectionSearch.js"],"names":[],"mappings":"AAuBiC","file":"../../../../src/components/Collection/CollectionSearch.js","sourcesContent":["import React from 'react';\nimport styled from '@emotion/styled';\nimport { colorsRaw, colors, Icon, lengths, zIndex } from 'decap-cms-ui-default';\nimport { translate } from 'react-polyglot';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\n\nconst SearchContainer = styled.div`\n  margin: 0 12px;\n  position: relative;\n\n  ${Icon} {\n    position: absolute;\n    top: 0;\n    left: 6px;\n    z-index: ${zIndex.zIndex2};\n    height: 100%;\n    display: flex;\n    align-items: center;\n    pointer-events: none;\n  }\n`;\n\nconst InputContainer = styled.div`\n  display: flex;\n  align-items: center;\n  position: relative;\n`;\n\nconst SearchInput = styled.input`\n  background-color: #eff0f4;\n  border-radius: ${lengths.borderRadius};\n  font-size: 14px;\n  padding: 10px 6px 10px 32px;\n  width: 100%;\n  position: relative;\n  z-index: ${zIndex.zIndex1};\n\n  &:focus {\n    outline: none;\n    box-shadow: inset 0 0 0 2px ${colorsRaw.blue};\n  }\n`;\n\nconst SuggestionsContainer = styled.div`\n  position: relative;\n  width: 100%;\n`;\n\nconst Suggestions = styled.ul`\n  position: absolute;\n  top: 6px;\n  left: 0;\n  right: 0;\n  padding: 10px 0;\n  margin: 0;\n  list-style: none;\n  background-color: #fff;\n  border-radius: ${lengths.borderRadius};\n  border: 1px solid ${colors.textFieldBorder};\n  z-index: ${zIndex.zIndex1};\n`;\n\nconst SuggestionHeader = styled.li`\n  padding: 0 6px 6px 32px;\n  font-size: 12px;\n  color: ${colors.text};\n`;\n\nconst SuggestionItem = styled.li(\n  ({ isActive }) => `\n  color: ${isActive ? colors.active : colorsRaw.grayDark};\n  background-color: ${isActive ? colors.activeBackground : 'inherit'};\n  padding: 6px 6px 6px 32px;\n  cursor: pointer;\n  position: relative;\n\n  &:hover {\n    color: ${colors.active};\n    background-color: ${colors.activeBackground};\n  }\n`,\n);\n\nconst SuggestionDivider = styled.div`\n  width: 100%;\n`;\n\nclass CollectionSearch extends React.Component {\n  static propTypes = {\n    collections: ImmutablePropTypes.map.isRequired,\n    collection: ImmutablePropTypes.map,\n    searchTerm: PropTypes.string.isRequired,\n    onSubmit: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    query: this.props.searchTerm,\n    suggestionsVisible: false,\n    // default to the currently selected\n    selectedCollectionIdx: this.getSelectedSelectionBasedOnProps(),\n  };\n\n  componentDidUpdate(prevProps) {\n    if (prevProps.collection !== this.props.collection) {\n      const selectedCollectionIdx = this.getSelectedSelectionBasedOnProps();\n      this.setState({ selectedCollectionIdx });\n    }\n  }\n\n  getSelectedSelectionBasedOnProps() {\n    const { collection, collections } = this.props;\n    return collection ? collections.keySeq().indexOf(collection.get('name')) : -1;\n  }\n\n  toggleSuggestions(visible) {\n    this.setState({ suggestionsVisible: visible });\n  }\n\n  selectNextSuggestion() {\n    const { collections } = this.props;\n    const { selectedCollectionIdx } = this.state;\n    this.setState({\n      selectedCollectionIdx: Math.min(selectedCollectionIdx + 1, collections.size - 1),\n    });\n  }\n\n  selectPreviousSuggestion() {\n    const { selectedCollectionIdx } = this.state;\n    this.setState({\n      selectedCollectionIdx: Math.max(selectedCollectionIdx - 1, -1),\n    });\n  }\n\n  resetSelectedSuggestion() {\n    this.setState({\n      selectedCollectionIdx: -1,\n    });\n  }\n\n  submitSearch = () => {\n    const { onSubmit, collections } = this.props;\n    const { selectedCollectionIdx, query } = this.state;\n\n    this.toggleSuggestions(false);\n    if (selectedCollectionIdx !== -1) {\n      onSubmit(query, collections.toIndexedSeq().getIn([selectedCollectionIdx, 'name']));\n    } else {\n      onSubmit(query);\n    }\n  };\n\n  handleKeyDown = event => {\n    const { suggestionsVisible } = this.state;\n\n    if (event.key === 'Enter') {\n      this.submitSearch();\n    }\n\n    if (suggestionsVisible) {\n      // allow closing of suggestions with escape key\n      if (event.key === 'Escape') {\n        this.toggleSuggestions(false);\n      }\n\n      if (event.key === 'ArrowDown') {\n        this.selectNextSuggestion();\n        event.preventDefault();\n      } else if (event.key === 'ArrowUp') {\n        this.selectPreviousSuggestion();\n        event.preventDefault();\n      }\n    }\n  };\n\n  handleQueryChange = query => {\n    this.setState({ query });\n    this.toggleSuggestions(query !== '');\n    if (query === '') {\n      this.resetSelectedSuggestion();\n    }\n  };\n\n  handleSuggestionClick = (event, idx) => {\n    this.setState({ selectedCollectionIdx: idx }, this.submitSearch);\n    event.preventDefault();\n  };\n\n  render() {\n    const { collections, t } = this.props;\n    const { suggestionsVisible, selectedCollectionIdx, query } = this.state;\n    return (\n      <SearchContainer\n        onBlur={() => this.toggleSuggestions(false)}\n        onFocus={() => this.toggleSuggestions(query !== '')}\n      >\n        <InputContainer>\n          <Icon type=\"search\" />\n          <SearchInput\n            onChange={e => this.handleQueryChange(e.target.value)}\n            onKeyDown={this.handleKeyDown}\n            onClick={() => this.toggleSuggestions(true)}\n            placeholder={t('collection.sidebar.searchAll')}\n            value={query}\n          />\n        </InputContainer>\n        {suggestionsVisible && (\n          <SuggestionsContainer>\n            <Suggestions>\n              <SuggestionHeader>{t('collection.sidebar.searchIn')}</SuggestionHeader>\n              <SuggestionItem\n                isActive={selectedCollectionIdx === -1}\n                onClick={e => this.handleSuggestionClick(e, -1)}\n                onMouseDown={e => e.preventDefault()}\n              >\n                {t('collection.sidebar.allCollections')}\n              </SuggestionItem>\n              <SuggestionDivider />\n              {collections.toIndexedSeq().map((collection, idx) => (\n                <SuggestionItem\n                  key={idx}\n                  isActive={idx === selectedCollectionIdx}\n                  onClick={e => this.handleSuggestionClick(e, idx)}\n                  onMouseDown={e => e.preventDefault()}\n                >\n                  {collection.get('label')}\n                </SuggestionItem>\n              ))}\n            </Suggestions>\n          </SuggestionsContainer>\n        )}\n      </SearchContainer>\n    );\n  }\n}\n\nexport default translate()(CollectionSearch);\n"]} */",
33
33
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
34
34
  });
35
- const SearchInput = (0, _styledBase.default)("input", {
36
- target: "e6w847r2",
35
+ const SearchInput = /*#__PURE__*/(0, _base.default)("input", {
36
+ target: "e6w847r5",
37
37
  label: "SearchInput"
38
38
  })("background-color:#eff0f4;border-radius:", _decapCmsUiDefault.lengths.borderRadius, ";font-size:14px;padding:10px 6px 10px 32px;width:100%;position:relative;z-index:", _decapCmsUiDefault.zIndex.zIndex1, ";&:focus{outline:none;box-shadow:inset 0 0 0 2px ", _decapCmsUiDefault.colorsRaw.blue, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Collection/CollectionSearch.js"],"names":[],"mappings":"AA6BgC","file":"../../../../src/components/Collection/CollectionSearch.js","sourcesContent":["import React from 'react';\nimport styled from '@emotion/styled';\nimport { colorsRaw, colors, Icon, lengths, zIndex } from 'decap-cms-ui-default';\nimport { translate } from 'react-polyglot';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\n\nconst SearchContainer = styled.div`\n  margin: 0 12px;\n  position: relative;\n\n  ${Icon} {\n    position: absolute;\n    top: 0;\n    left: 6px;\n    z-index: ${zIndex.zIndex2};\n    height: 100%;\n    display: flex;\n    align-items: center;\n    pointer-events: none;\n  }\n`;\n\nconst InputContainer = styled.div`\n  display: flex;\n  align-items: center;\n  position: relative;\n`;\n\nconst SearchInput = styled.input`\n  background-color: #eff0f4;\n  border-radius: ${lengths.borderRadius};\n  font-size: 14px;\n  padding: 10px 6px 10px 32px;\n  width: 100%;\n  position: relative;\n  z-index: ${zIndex.zIndex1};\n\n  &:focus {\n    outline: none;\n    box-shadow: inset 0 0 0 2px ${colorsRaw.blue};\n  }\n`;\n\nconst SuggestionsContainer = styled.div`\n  position: relative;\n  width: 100%;\n`;\n\nconst Suggestions = styled.ul`\n  position: absolute;\n  top: 6px;\n  left: 0;\n  right: 0;\n  padding: 10px 0;\n  margin: 0;\n  list-style: none;\n  background-color: #fff;\n  border-radius: ${lengths.borderRadius};\n  border: 1px solid ${colors.textFieldBorder};\n  z-index: ${zIndex.zIndex1};\n`;\n\nconst SuggestionHeader = styled.li`\n  padding: 0 6px 6px 32px;\n  font-size: 12px;\n  color: ${colors.text};\n`;\n\nconst SuggestionItem = styled.li(\n  ({ isActive }) => `\n  color: ${isActive ? colors.active : colorsRaw.grayDark};\n  background-color: ${isActive ? colors.activeBackground : 'inherit'};\n  padding: 6px 6px 6px 32px;\n  cursor: pointer;\n  position: relative;\n\n  &:hover {\n    color: ${colors.active};\n    background-color: ${colors.activeBackground};\n  }\n`,\n);\n\nconst SuggestionDivider = styled.div`\n  width: 100%;\n`;\n\nclass CollectionSearch extends React.Component {\n  static propTypes = {\n    collections: ImmutablePropTypes.map.isRequired,\n    collection: ImmutablePropTypes.map,\n    searchTerm: PropTypes.string.isRequired,\n    onSubmit: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    query: this.props.searchTerm,\n    suggestionsVisible: false,\n    // default to the currently selected\n    selectedCollectionIdx: this.getSelectedSelectionBasedOnProps(),\n  };\n\n  componentDidUpdate(prevProps) {\n    if (prevProps.collection !== this.props.collection) {\n      const selectedCollectionIdx = this.getSelectedSelectionBasedOnProps();\n      this.setState({ selectedCollectionIdx });\n    }\n  }\n\n  getSelectedSelectionBasedOnProps() {\n    const { collection, collections } = this.props;\n    return collection ? collections.keySeq().indexOf(collection.get('name')) : -1;\n  }\n\n  toggleSuggestions(visible) {\n    this.setState({ suggestionsVisible: visible });\n  }\n\n  selectNextSuggestion() {\n    const { collections } = this.props;\n    const { selectedCollectionIdx } = this.state;\n    this.setState({\n      selectedCollectionIdx: Math.min(selectedCollectionIdx + 1, collections.size - 1),\n    });\n  }\n\n  selectPreviousSuggestion() {\n    const { selectedCollectionIdx } = this.state;\n    this.setState({\n      selectedCollectionIdx: Math.max(selectedCollectionIdx - 1, -1),\n    });\n  }\n\n  resetSelectedSuggestion() {\n    this.setState({\n      selectedCollectionIdx: -1,\n    });\n  }\n\n  submitSearch = () => {\n    const { onSubmit, collections } = this.props;\n    const { selectedCollectionIdx, query } = this.state;\n\n    this.toggleSuggestions(false);\n    if (selectedCollectionIdx !== -1) {\n      onSubmit(query, collections.toIndexedSeq().getIn([selectedCollectionIdx, 'name']));\n    } else {\n      onSubmit(query);\n    }\n  };\n\n  handleKeyDown = event => {\n    const { suggestionsVisible } = this.state;\n\n    if (event.key === 'Enter') {\n      this.submitSearch();\n    }\n\n    if (suggestionsVisible) {\n      // allow closing of suggestions with escape key\n      if (event.key === 'Escape') {\n        this.toggleSuggestions(false);\n      }\n\n      if (event.key === 'ArrowDown') {\n        this.selectNextSuggestion();\n        event.preventDefault();\n      } else if (event.key === 'ArrowUp') {\n        this.selectPreviousSuggestion();\n        event.preventDefault();\n      }\n    }\n  };\n\n  handleQueryChange = query => {\n    this.setState({ query });\n    this.toggleSuggestions(query !== '');\n    if (query === '') {\n      this.resetSelectedSuggestion();\n    }\n  };\n\n  handleSuggestionClick = (event, idx) => {\n    this.setState({ selectedCollectionIdx: idx }, this.submitSearch);\n    event.preventDefault();\n  };\n\n  render() {\n    const { collections, t } = this.props;\n    const { suggestionsVisible, selectedCollectionIdx, query } = this.state;\n    return (\n      <SearchContainer\n        onBlur={() => this.toggleSuggestions(false)}\n        onFocus={() => this.toggleSuggestions(query !== '')}\n      >\n        <InputContainer>\n          <Icon type=\"search\" />\n          <SearchInput\n            onChange={e => this.handleQueryChange(e.target.value)}\n            onKeyDown={this.handleKeyDown}\n            onClick={() => this.toggleSuggestions(true)}\n            placeholder={t('collection.sidebar.searchAll')}\n            value={query}\n          />\n        </InputContainer>\n        {suggestionsVisible && (\n          <SuggestionsContainer>\n            <Suggestions>\n              <SuggestionHeader>{t('collection.sidebar.searchIn')}</SuggestionHeader>\n              <SuggestionItem\n                isActive={selectedCollectionIdx === -1}\n                onClick={e => this.handleSuggestionClick(e, -1)}\n                onMouseDown={e => e.preventDefault()}\n              >\n                {t('collection.sidebar.allCollections')}\n              </SuggestionItem>\n              <SuggestionDivider />\n              {collections.toIndexedSeq().map((collection, idx) => (\n                <SuggestionItem\n                  key={idx}\n                  isActive={idx === selectedCollectionIdx}\n                  onClick={e => this.handleSuggestionClick(e, idx)}\n                  onMouseDown={e => e.preventDefault()}\n                >\n                  {collection.get('label')}\n                </SuggestionItem>\n              ))}\n            </Suggestions>\n          </SuggestionsContainer>\n        )}\n      </SearchContainer>\n    );\n  }\n}\n\nexport default translate()(CollectionSearch);\n"]} */"));
39
- const SuggestionsContainer = (0, _styledBase.default)("div", {
40
- target: "e6w847r3",
39
+ const SuggestionsContainer = /*#__PURE__*/(0, _base.default)("div", {
40
+ target: "e6w847r4",
41
41
  label: "SuggestionsContainer"
42
42
  })(process.env.NODE_ENV === "production" ? {
43
- name: "1jke4yk",
44
- styles: "position:relative;width:100%;"
43
+ name: "pw7jst",
44
+ styles: "position:relative;width:100%"
45
45
  } : {
46
- name: "1jke4yk",
47
- styles: "position:relative;width:100%;",
46
+ name: "pw7jst",
47
+ styles: "position:relative;width:100%",
48
48
  map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Collection/CollectionSearch.js"],"names":[],"mappings":"AA4CuC","file":"../../../../src/components/Collection/CollectionSearch.js","sourcesContent":["import React from 'react';\nimport styled from '@emotion/styled';\nimport { colorsRaw, colors, Icon, lengths, zIndex } from 'decap-cms-ui-default';\nimport { translate } from 'react-polyglot';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\n\nconst SearchContainer = styled.div`\n  margin: 0 12px;\n  position: relative;\n\n  ${Icon} {\n    position: absolute;\n    top: 0;\n    left: 6px;\n    z-index: ${zIndex.zIndex2};\n    height: 100%;\n    display: flex;\n    align-items: center;\n    pointer-events: none;\n  }\n`;\n\nconst InputContainer = styled.div`\n  display: flex;\n  align-items: center;\n  position: relative;\n`;\n\nconst SearchInput = styled.input`\n  background-color: #eff0f4;\n  border-radius: ${lengths.borderRadius};\n  font-size: 14px;\n  padding: 10px 6px 10px 32px;\n  width: 100%;\n  position: relative;\n  z-index: ${zIndex.zIndex1};\n\n  &:focus {\n    outline: none;\n    box-shadow: inset 0 0 0 2px ${colorsRaw.blue};\n  }\n`;\n\nconst SuggestionsContainer = styled.div`\n  position: relative;\n  width: 100%;\n`;\n\nconst Suggestions = styled.ul`\n  position: absolute;\n  top: 6px;\n  left: 0;\n  right: 0;\n  padding: 10px 0;\n  margin: 0;\n  list-style: none;\n  background-color: #fff;\n  border-radius: ${lengths.borderRadius};\n  border: 1px solid ${colors.textFieldBorder};\n  z-index: ${zIndex.zIndex1};\n`;\n\nconst SuggestionHeader = styled.li`\n  padding: 0 6px 6px 32px;\n  font-size: 12px;\n  color: ${colors.text};\n`;\n\nconst SuggestionItem = styled.li(\n  ({ isActive }) => `\n  color: ${isActive ? colors.active : colorsRaw.grayDark};\n  background-color: ${isActive ? colors.activeBackground : 'inherit'};\n  padding: 6px 6px 6px 32px;\n  cursor: pointer;\n  position: relative;\n\n  &:hover {\n    color: ${colors.active};\n    background-color: ${colors.activeBackground};\n  }\n`,\n);\n\nconst SuggestionDivider = styled.div`\n  width: 100%;\n`;\n\nclass CollectionSearch extends React.Component {\n  static propTypes = {\n    collections: ImmutablePropTypes.map.isRequired,\n    collection: ImmutablePropTypes.map,\n    searchTerm: PropTypes.string.isRequired,\n    onSubmit: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    query: this.props.searchTerm,\n    suggestionsVisible: false,\n    // default to the currently selected\n    selectedCollectionIdx: this.getSelectedSelectionBasedOnProps(),\n  };\n\n  componentDidUpdate(prevProps) {\n    if (prevProps.collection !== this.props.collection) {\n      const selectedCollectionIdx = this.getSelectedSelectionBasedOnProps();\n      this.setState({ selectedCollectionIdx });\n    }\n  }\n\n  getSelectedSelectionBasedOnProps() {\n    const { collection, collections } = this.props;\n    return collection ? collections.keySeq().indexOf(collection.get('name')) : -1;\n  }\n\n  toggleSuggestions(visible) {\n    this.setState({ suggestionsVisible: visible });\n  }\n\n  selectNextSuggestion() {\n    const { collections } = this.props;\n    const { selectedCollectionIdx } = this.state;\n    this.setState({\n      selectedCollectionIdx: Math.min(selectedCollectionIdx + 1, collections.size - 1),\n    });\n  }\n\n  selectPreviousSuggestion() {\n    const { selectedCollectionIdx } = this.state;\n    this.setState({\n      selectedCollectionIdx: Math.max(selectedCollectionIdx - 1, -1),\n    });\n  }\n\n  resetSelectedSuggestion() {\n    this.setState({\n      selectedCollectionIdx: -1,\n    });\n  }\n\n  submitSearch = () => {\n    const { onSubmit, collections } = this.props;\n    const { selectedCollectionIdx, query } = this.state;\n\n    this.toggleSuggestions(false);\n    if (selectedCollectionIdx !== -1) {\n      onSubmit(query, collections.toIndexedSeq().getIn([selectedCollectionIdx, 'name']));\n    } else {\n      onSubmit(query);\n    }\n  };\n\n  handleKeyDown = event => {\n    const { suggestionsVisible } = this.state;\n\n    if (event.key === 'Enter') {\n      this.submitSearch();\n    }\n\n    if (suggestionsVisible) {\n      // allow closing of suggestions with escape key\n      if (event.key === 'Escape') {\n        this.toggleSuggestions(false);\n      }\n\n      if (event.key === 'ArrowDown') {\n        this.selectNextSuggestion();\n        event.preventDefault();\n      } else if (event.key === 'ArrowUp') {\n        this.selectPreviousSuggestion();\n        event.preventDefault();\n      }\n    }\n  };\n\n  handleQueryChange = query => {\n    this.setState({ query });\n    this.toggleSuggestions(query !== '');\n    if (query === '') {\n      this.resetSelectedSuggestion();\n    }\n  };\n\n  handleSuggestionClick = (event, idx) => {\n    this.setState({ selectedCollectionIdx: idx }, this.submitSearch);\n    event.preventDefault();\n  };\n\n  render() {\n    const { collections, t } = this.props;\n    const { suggestionsVisible, selectedCollectionIdx, query } = this.state;\n    return (\n      <SearchContainer\n        onBlur={() => this.toggleSuggestions(false)}\n        onFocus={() => this.toggleSuggestions(query !== '')}\n      >\n        <InputContainer>\n          <Icon type=\"search\" />\n          <SearchInput\n            onChange={e => this.handleQueryChange(e.target.value)}\n            onKeyDown={this.handleKeyDown}\n            onClick={() => this.toggleSuggestions(true)}\n            placeholder={t('collection.sidebar.searchAll')}\n            value={query}\n          />\n        </InputContainer>\n        {suggestionsVisible && (\n          <SuggestionsContainer>\n            <Suggestions>\n              <SuggestionHeader>{t('collection.sidebar.searchIn')}</SuggestionHeader>\n              <SuggestionItem\n                isActive={selectedCollectionIdx === -1}\n                onClick={e => this.handleSuggestionClick(e, -1)}\n                onMouseDown={e => e.preventDefault()}\n              >\n                {t('collection.sidebar.allCollections')}\n              </SuggestionItem>\n              <SuggestionDivider />\n              {collections.toIndexedSeq().map((collection, idx) => (\n                <SuggestionItem\n                  key={idx}\n                  isActive={idx === selectedCollectionIdx}\n                  onClick={e => this.handleSuggestionClick(e, idx)}\n                  onMouseDown={e => e.preventDefault()}\n                >\n                  {collection.get('label')}\n                </SuggestionItem>\n              ))}\n            </Suggestions>\n          </SuggestionsContainer>\n        )}\n      </SearchContainer>\n    );\n  }\n}\n\nexport default translate()(CollectionSearch);\n"]} */",
49
49
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
50
50
  });
51
- const Suggestions = (0, _styledBase.default)("ul", {
52
- target: "e6w847r4",
51
+ const Suggestions = /*#__PURE__*/(0, _base.default)("ul", {
52
+ target: "e6w847r3",
53
53
  label: "Suggestions"
54
54
  })("position:absolute;top:6px;left:0;right:0;padding:10px 0;margin:0;list-style:none;background-color:#fff;border-radius:", _decapCmsUiDefault.lengths.borderRadius, ";border:1px solid ", _decapCmsUiDefault.colors.textFieldBorder, ";z-index:", _decapCmsUiDefault.zIndex.zIndex1, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Collection/CollectionSearch.js"],"names":[],"mappings":"AAiD6B","file":"../../../../src/components/Collection/CollectionSearch.js","sourcesContent":["import React from 'react';\nimport styled from '@emotion/styled';\nimport { colorsRaw, colors, Icon, lengths, zIndex } from 'decap-cms-ui-default';\nimport { translate } from 'react-polyglot';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\n\nconst SearchContainer = styled.div`\n  margin: 0 12px;\n  position: relative;\n\n  ${Icon} {\n    position: absolute;\n    top: 0;\n    left: 6px;\n    z-index: ${zIndex.zIndex2};\n    height: 100%;\n    display: flex;\n    align-items: center;\n    pointer-events: none;\n  }\n`;\n\nconst InputContainer = styled.div`\n  display: flex;\n  align-items: center;\n  position: relative;\n`;\n\nconst SearchInput = styled.input`\n  background-color: #eff0f4;\n  border-radius: ${lengths.borderRadius};\n  font-size: 14px;\n  padding: 10px 6px 10px 32px;\n  width: 100%;\n  position: relative;\n  z-index: ${zIndex.zIndex1};\n\n  &:focus {\n    outline: none;\n    box-shadow: inset 0 0 0 2px ${colorsRaw.blue};\n  }\n`;\n\nconst SuggestionsContainer = styled.div`\n  position: relative;\n  width: 100%;\n`;\n\nconst Suggestions = styled.ul`\n  position: absolute;\n  top: 6px;\n  left: 0;\n  right: 0;\n  padding: 10px 0;\n  margin: 0;\n  list-style: none;\n  background-color: #fff;\n  border-radius: ${lengths.borderRadius};\n  border: 1px solid ${colors.textFieldBorder};\n  z-index: ${zIndex.zIndex1};\n`;\n\nconst SuggestionHeader = styled.li`\n  padding: 0 6px 6px 32px;\n  font-size: 12px;\n  color: ${colors.text};\n`;\n\nconst SuggestionItem = styled.li(\n  ({ isActive }) => `\n  color: ${isActive ? colors.active : colorsRaw.grayDark};\n  background-color: ${isActive ? colors.activeBackground : 'inherit'};\n  padding: 6px 6px 6px 32px;\n  cursor: pointer;\n  position: relative;\n\n  &:hover {\n    color: ${colors.active};\n    background-color: ${colors.activeBackground};\n  }\n`,\n);\n\nconst SuggestionDivider = styled.div`\n  width: 100%;\n`;\n\nclass CollectionSearch extends React.Component {\n  static propTypes = {\n    collections: ImmutablePropTypes.map.isRequired,\n    collection: ImmutablePropTypes.map,\n    searchTerm: PropTypes.string.isRequired,\n    onSubmit: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    query: this.props.searchTerm,\n    suggestionsVisible: false,\n    // default to the currently selected\n    selectedCollectionIdx: this.getSelectedSelectionBasedOnProps(),\n  };\n\n  componentDidUpdate(prevProps) {\n    if (prevProps.collection !== this.props.collection) {\n      const selectedCollectionIdx = this.getSelectedSelectionBasedOnProps();\n      this.setState({ selectedCollectionIdx });\n    }\n  }\n\n  getSelectedSelectionBasedOnProps() {\n    const { collection, collections } = this.props;\n    return collection ? collections.keySeq().indexOf(collection.get('name')) : -1;\n  }\n\n  toggleSuggestions(visible) {\n    this.setState({ suggestionsVisible: visible });\n  }\n\n  selectNextSuggestion() {\n    const { collections } = this.props;\n    const { selectedCollectionIdx } = this.state;\n    this.setState({\n      selectedCollectionIdx: Math.min(selectedCollectionIdx + 1, collections.size - 1),\n    });\n  }\n\n  selectPreviousSuggestion() {\n    const { selectedCollectionIdx } = this.state;\n    this.setState({\n      selectedCollectionIdx: Math.max(selectedCollectionIdx - 1, -1),\n    });\n  }\n\n  resetSelectedSuggestion() {\n    this.setState({\n      selectedCollectionIdx: -1,\n    });\n  }\n\n  submitSearch = () => {\n    const { onSubmit, collections } = this.props;\n    const { selectedCollectionIdx, query } = this.state;\n\n    this.toggleSuggestions(false);\n    if (selectedCollectionIdx !== -1) {\n      onSubmit(query, collections.toIndexedSeq().getIn([selectedCollectionIdx, 'name']));\n    } else {\n      onSubmit(query);\n    }\n  };\n\n  handleKeyDown = event => {\n    const { suggestionsVisible } = this.state;\n\n    if (event.key === 'Enter') {\n      this.submitSearch();\n    }\n\n    if (suggestionsVisible) {\n      // allow closing of suggestions with escape key\n      if (event.key === 'Escape') {\n        this.toggleSuggestions(false);\n      }\n\n      if (event.key === 'ArrowDown') {\n        this.selectNextSuggestion();\n        event.preventDefault();\n      } else if (event.key === 'ArrowUp') {\n        this.selectPreviousSuggestion();\n        event.preventDefault();\n      }\n    }\n  };\n\n  handleQueryChange = query => {\n    this.setState({ query });\n    this.toggleSuggestions(query !== '');\n    if (query === '') {\n      this.resetSelectedSuggestion();\n    }\n  };\n\n  handleSuggestionClick = (event, idx) => {\n    this.setState({ selectedCollectionIdx: idx }, this.submitSearch);\n    event.preventDefault();\n  };\n\n  render() {\n    const { collections, t } = this.props;\n    const { suggestionsVisible, selectedCollectionIdx, query } = this.state;\n    return (\n      <SearchContainer\n        onBlur={() => this.toggleSuggestions(false)}\n        onFocus={() => this.toggleSuggestions(query !== '')}\n      >\n        <InputContainer>\n          <Icon type=\"search\" />\n          <SearchInput\n            onChange={e => this.handleQueryChange(e.target.value)}\n            onKeyDown={this.handleKeyDown}\n            onClick={() => this.toggleSuggestions(true)}\n            placeholder={t('collection.sidebar.searchAll')}\n            value={query}\n          />\n        </InputContainer>\n        {suggestionsVisible && (\n          <SuggestionsContainer>\n            <Suggestions>\n              <SuggestionHeader>{t('collection.sidebar.searchIn')}</SuggestionHeader>\n              <SuggestionItem\n                isActive={selectedCollectionIdx === -1}\n                onClick={e => this.handleSuggestionClick(e, -1)}\n                onMouseDown={e => e.preventDefault()}\n              >\n                {t('collection.sidebar.allCollections')}\n              </SuggestionItem>\n              <SuggestionDivider />\n              {collections.toIndexedSeq().map((collection, idx) => (\n                <SuggestionItem\n                  key={idx}\n                  isActive={idx === selectedCollectionIdx}\n                  onClick={e => this.handleSuggestionClick(e, idx)}\n                  onMouseDown={e => e.preventDefault()}\n                >\n                  {collection.get('label')}\n                </SuggestionItem>\n              ))}\n            </Suggestions>\n          </SuggestionsContainer>\n        )}\n      </SearchContainer>\n    );\n  }\n}\n\nexport default translate()(CollectionSearch);\n"]} */"));
55
- const SuggestionHeader = (0, _styledBase.default)("li", {
56
- target: "e6w847r5",
55
+ const SuggestionHeader = /*#__PURE__*/(0, _base.default)("li", {
56
+ target: "e6w847r2",
57
57
  label: "SuggestionHeader"
58
58
  })("padding:0 6px 6px 32px;font-size:12px;color:", _decapCmsUiDefault.colors.text, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Collection/CollectionSearch.js"],"names":[],"mappings":"AA+DkC","file":"../../../../src/components/Collection/CollectionSearch.js","sourcesContent":["import React from 'react';\nimport styled from '@emotion/styled';\nimport { colorsRaw, colors, Icon, lengths, zIndex } from 'decap-cms-ui-default';\nimport { translate } from 'react-polyglot';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\n\nconst SearchContainer = styled.div`\n  margin: 0 12px;\n  position: relative;\n\n  ${Icon} {\n    position: absolute;\n    top: 0;\n    left: 6px;\n    z-index: ${zIndex.zIndex2};\n    height: 100%;\n    display: flex;\n    align-items: center;\n    pointer-events: none;\n  }\n`;\n\nconst InputContainer = styled.div`\n  display: flex;\n  align-items: center;\n  position: relative;\n`;\n\nconst SearchInput = styled.input`\n  background-color: #eff0f4;\n  border-radius: ${lengths.borderRadius};\n  font-size: 14px;\n  padding: 10px 6px 10px 32px;\n  width: 100%;\n  position: relative;\n  z-index: ${zIndex.zIndex1};\n\n  &:focus {\n    outline: none;\n    box-shadow: inset 0 0 0 2px ${colorsRaw.blue};\n  }\n`;\n\nconst SuggestionsContainer = styled.div`\n  position: relative;\n  width: 100%;\n`;\n\nconst Suggestions = styled.ul`\n  position: absolute;\n  top: 6px;\n  left: 0;\n  right: 0;\n  padding: 10px 0;\n  margin: 0;\n  list-style: none;\n  background-color: #fff;\n  border-radius: ${lengths.borderRadius};\n  border: 1px solid ${colors.textFieldBorder};\n  z-index: ${zIndex.zIndex1};\n`;\n\nconst SuggestionHeader = styled.li`\n  padding: 0 6px 6px 32px;\n  font-size: 12px;\n  color: ${colors.text};\n`;\n\nconst SuggestionItem = styled.li(\n  ({ isActive }) => `\n  color: ${isActive ? colors.active : colorsRaw.grayDark};\n  background-color: ${isActive ? colors.activeBackground : 'inherit'};\n  padding: 6px 6px 6px 32px;\n  cursor: pointer;\n  position: relative;\n\n  &:hover {\n    color: ${colors.active};\n    background-color: ${colors.activeBackground};\n  }\n`,\n);\n\nconst SuggestionDivider = styled.div`\n  width: 100%;\n`;\n\nclass CollectionSearch extends React.Component {\n  static propTypes = {\n    collections: ImmutablePropTypes.map.isRequired,\n    collection: ImmutablePropTypes.map,\n    searchTerm: PropTypes.string.isRequired,\n    onSubmit: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    query: this.props.searchTerm,\n    suggestionsVisible: false,\n    // default to the currently selected\n    selectedCollectionIdx: this.getSelectedSelectionBasedOnProps(),\n  };\n\n  componentDidUpdate(prevProps) {\n    if (prevProps.collection !== this.props.collection) {\n      const selectedCollectionIdx = this.getSelectedSelectionBasedOnProps();\n      this.setState({ selectedCollectionIdx });\n    }\n  }\n\n  getSelectedSelectionBasedOnProps() {\n    const { collection, collections } = this.props;\n    return collection ? collections.keySeq().indexOf(collection.get('name')) : -1;\n  }\n\n  toggleSuggestions(visible) {\n    this.setState({ suggestionsVisible: visible });\n  }\n\n  selectNextSuggestion() {\n    const { collections } = this.props;\n    const { selectedCollectionIdx } = this.state;\n    this.setState({\n      selectedCollectionIdx: Math.min(selectedCollectionIdx + 1, collections.size - 1),\n    });\n  }\n\n  selectPreviousSuggestion() {\n    const { selectedCollectionIdx } = this.state;\n    this.setState({\n      selectedCollectionIdx: Math.max(selectedCollectionIdx - 1, -1),\n    });\n  }\n\n  resetSelectedSuggestion() {\n    this.setState({\n      selectedCollectionIdx: -1,\n    });\n  }\n\n  submitSearch = () => {\n    const { onSubmit, collections } = this.props;\n    const { selectedCollectionIdx, query } = this.state;\n\n    this.toggleSuggestions(false);\n    if (selectedCollectionIdx !== -1) {\n      onSubmit(query, collections.toIndexedSeq().getIn([selectedCollectionIdx, 'name']));\n    } else {\n      onSubmit(query);\n    }\n  };\n\n  handleKeyDown = event => {\n    const { suggestionsVisible } = this.state;\n\n    if (event.key === 'Enter') {\n      this.submitSearch();\n    }\n\n    if (suggestionsVisible) {\n      // allow closing of suggestions with escape key\n      if (event.key === 'Escape') {\n        this.toggleSuggestions(false);\n      }\n\n      if (event.key === 'ArrowDown') {\n        this.selectNextSuggestion();\n        event.preventDefault();\n      } else if (event.key === 'ArrowUp') {\n        this.selectPreviousSuggestion();\n        event.preventDefault();\n      }\n    }\n  };\n\n  handleQueryChange = query => {\n    this.setState({ query });\n    this.toggleSuggestions(query !== '');\n    if (query === '') {\n      this.resetSelectedSuggestion();\n    }\n  };\n\n  handleSuggestionClick = (event, idx) => {\n    this.setState({ selectedCollectionIdx: idx }, this.submitSearch);\n    event.preventDefault();\n  };\n\n  render() {\n    const { collections, t } = this.props;\n    const { suggestionsVisible, selectedCollectionIdx, query } = this.state;\n    return (\n      <SearchContainer\n        onBlur={() => this.toggleSuggestions(false)}\n        onFocus={() => this.toggleSuggestions(query !== '')}\n      >\n        <InputContainer>\n          <Icon type=\"search\" />\n          <SearchInput\n            onChange={e => this.handleQueryChange(e.target.value)}\n            onKeyDown={this.handleKeyDown}\n            onClick={() => this.toggleSuggestions(true)}\n            placeholder={t('collection.sidebar.searchAll')}\n            value={query}\n          />\n        </InputContainer>\n        {suggestionsVisible && (\n          <SuggestionsContainer>\n            <Suggestions>\n              <SuggestionHeader>{t('collection.sidebar.searchIn')}</SuggestionHeader>\n              <SuggestionItem\n                isActive={selectedCollectionIdx === -1}\n                onClick={e => this.handleSuggestionClick(e, -1)}\n                onMouseDown={e => e.preventDefault()}\n              >\n                {t('collection.sidebar.allCollections')}\n              </SuggestionItem>\n              <SuggestionDivider />\n              {collections.toIndexedSeq().map((collection, idx) => (\n                <SuggestionItem\n                  key={idx}\n                  isActive={idx === selectedCollectionIdx}\n                  onClick={e => this.handleSuggestionClick(e, idx)}\n                  onMouseDown={e => e.preventDefault()}\n                >\n                  {collection.get('label')}\n                </SuggestionItem>\n              ))}\n            </Suggestions>\n          </SuggestionsContainer>\n        )}\n      </SearchContainer>\n    );\n  }\n}\n\nexport default translate()(CollectionSearch);\n"]} */"));
59
- const SuggestionItem = (0, _styledBase.default)("li", {
60
- target: "e6w847r6",
59
+ const SuggestionItem = /*#__PURE__*/(0, _base.default)("li", {
60
+ target: "e6w847r1",
61
61
  label: "SuggestionItem"
62
62
  })(({
63
63
  isActive
@@ -73,15 +73,15 @@ const SuggestionItem = (0, _styledBase.default)("li", {
73
73
  background-color: ${_decapCmsUiDefault.colors.activeBackground};
74
74
  }
75
75
  `, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Collection/CollectionSearch.js"],"names":[],"mappings":"AAqEuB","file":"../../../../src/components/Collection/CollectionSearch.js","sourcesContent":["import React from 'react';\nimport styled from '@emotion/styled';\nimport { colorsRaw, colors, Icon, lengths, zIndex } from 'decap-cms-ui-default';\nimport { translate } from 'react-polyglot';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\n\nconst SearchContainer = styled.div`\n  margin: 0 12px;\n  position: relative;\n\n  ${Icon} {\n    position: absolute;\n    top: 0;\n    left: 6px;\n    z-index: ${zIndex.zIndex2};\n    height: 100%;\n    display: flex;\n    align-items: center;\n    pointer-events: none;\n  }\n`;\n\nconst InputContainer = styled.div`\n  display: flex;\n  align-items: center;\n  position: relative;\n`;\n\nconst SearchInput = styled.input`\n  background-color: #eff0f4;\n  border-radius: ${lengths.borderRadius};\n  font-size: 14px;\n  padding: 10px 6px 10px 32px;\n  width: 100%;\n  position: relative;\n  z-index: ${zIndex.zIndex1};\n\n  &:focus {\n    outline: none;\n    box-shadow: inset 0 0 0 2px ${colorsRaw.blue};\n  }\n`;\n\nconst SuggestionsContainer = styled.div`\n  position: relative;\n  width: 100%;\n`;\n\nconst Suggestions = styled.ul`\n  position: absolute;\n  top: 6px;\n  left: 0;\n  right: 0;\n  padding: 10px 0;\n  margin: 0;\n  list-style: none;\n  background-color: #fff;\n  border-radius: ${lengths.borderRadius};\n  border: 1px solid ${colors.textFieldBorder};\n  z-index: ${zIndex.zIndex1};\n`;\n\nconst SuggestionHeader = styled.li`\n  padding: 0 6px 6px 32px;\n  font-size: 12px;\n  color: ${colors.text};\n`;\n\nconst SuggestionItem = styled.li(\n  ({ isActive }) => `\n  color: ${isActive ? colors.active : colorsRaw.grayDark};\n  background-color: ${isActive ? colors.activeBackground : 'inherit'};\n  padding: 6px 6px 6px 32px;\n  cursor: pointer;\n  position: relative;\n\n  &:hover {\n    color: ${colors.active};\n    background-color: ${colors.activeBackground};\n  }\n`,\n);\n\nconst SuggestionDivider = styled.div`\n  width: 100%;\n`;\n\nclass CollectionSearch extends React.Component {\n  static propTypes = {\n    collections: ImmutablePropTypes.map.isRequired,\n    collection: ImmutablePropTypes.map,\n    searchTerm: PropTypes.string.isRequired,\n    onSubmit: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    query: this.props.searchTerm,\n    suggestionsVisible: false,\n    // default to the currently selected\n    selectedCollectionIdx: this.getSelectedSelectionBasedOnProps(),\n  };\n\n  componentDidUpdate(prevProps) {\n    if (prevProps.collection !== this.props.collection) {\n      const selectedCollectionIdx = this.getSelectedSelectionBasedOnProps();\n      this.setState({ selectedCollectionIdx });\n    }\n  }\n\n  getSelectedSelectionBasedOnProps() {\n    const { collection, collections } = this.props;\n    return collection ? collections.keySeq().indexOf(collection.get('name')) : -1;\n  }\n\n  toggleSuggestions(visible) {\n    this.setState({ suggestionsVisible: visible });\n  }\n\n  selectNextSuggestion() {\n    const { collections } = this.props;\n    const { selectedCollectionIdx } = this.state;\n    this.setState({\n      selectedCollectionIdx: Math.min(selectedCollectionIdx + 1, collections.size - 1),\n    });\n  }\n\n  selectPreviousSuggestion() {\n    const { selectedCollectionIdx } = this.state;\n    this.setState({\n      selectedCollectionIdx: Math.max(selectedCollectionIdx - 1, -1),\n    });\n  }\n\n  resetSelectedSuggestion() {\n    this.setState({\n      selectedCollectionIdx: -1,\n    });\n  }\n\n  submitSearch = () => {\n    const { onSubmit, collections } = this.props;\n    const { selectedCollectionIdx, query } = this.state;\n\n    this.toggleSuggestions(false);\n    if (selectedCollectionIdx !== -1) {\n      onSubmit(query, collections.toIndexedSeq().getIn([selectedCollectionIdx, 'name']));\n    } else {\n      onSubmit(query);\n    }\n  };\n\n  handleKeyDown = event => {\n    const { suggestionsVisible } = this.state;\n\n    if (event.key === 'Enter') {\n      this.submitSearch();\n    }\n\n    if (suggestionsVisible) {\n      // allow closing of suggestions with escape key\n      if (event.key === 'Escape') {\n        this.toggleSuggestions(false);\n      }\n\n      if (event.key === 'ArrowDown') {\n        this.selectNextSuggestion();\n        event.preventDefault();\n      } else if (event.key === 'ArrowUp') {\n        this.selectPreviousSuggestion();\n        event.preventDefault();\n      }\n    }\n  };\n\n  handleQueryChange = query => {\n    this.setState({ query });\n    this.toggleSuggestions(query !== '');\n    if (query === '') {\n      this.resetSelectedSuggestion();\n    }\n  };\n\n  handleSuggestionClick = (event, idx) => {\n    this.setState({ selectedCollectionIdx: idx }, this.submitSearch);\n    event.preventDefault();\n  };\n\n  render() {\n    const { collections, t } = this.props;\n    const { suggestionsVisible, selectedCollectionIdx, query } = this.state;\n    return (\n      <SearchContainer\n        onBlur={() => this.toggleSuggestions(false)}\n        onFocus={() => this.toggleSuggestions(query !== '')}\n      >\n        <InputContainer>\n          <Icon type=\"search\" />\n          <SearchInput\n            onChange={e => this.handleQueryChange(e.target.value)}\n            onKeyDown={this.handleKeyDown}\n            onClick={() => this.toggleSuggestions(true)}\n            placeholder={t('collection.sidebar.searchAll')}\n            value={query}\n          />\n        </InputContainer>\n        {suggestionsVisible && (\n          <SuggestionsContainer>\n            <Suggestions>\n              <SuggestionHeader>{t('collection.sidebar.searchIn')}</SuggestionHeader>\n              <SuggestionItem\n                isActive={selectedCollectionIdx === -1}\n                onClick={e => this.handleSuggestionClick(e, -1)}\n                onMouseDown={e => e.preventDefault()}\n              >\n                {t('collection.sidebar.allCollections')}\n              </SuggestionItem>\n              <SuggestionDivider />\n              {collections.toIndexedSeq().map((collection, idx) => (\n                <SuggestionItem\n                  key={idx}\n                  isActive={idx === selectedCollectionIdx}\n                  onClick={e => this.handleSuggestionClick(e, idx)}\n                  onMouseDown={e => e.preventDefault()}\n                >\n                  {collection.get('label')}\n                </SuggestionItem>\n              ))}\n            </Suggestions>\n          </SuggestionsContainer>\n        )}\n      </SearchContainer>\n    );\n  }\n}\n\nexport default translate()(CollectionSearch);\n"]} */");
76
- const SuggestionDivider = (0, _styledBase.default)("div", {
77
- target: "e6w847r7",
76
+ const SuggestionDivider = /*#__PURE__*/(0, _base.default)("div", {
77
+ target: "e6w847r0",
78
78
  label: "SuggestionDivider"
79
79
  })(process.env.NODE_ENV === "production" ? {
80
- name: "8atqhb",
81
- styles: "width:100%;"
80
+ name: "1d3w5wq",
81
+ styles: "width:100%"
82
82
  } : {
83
- name: "8atqhb",
84
- styles: "width:100%;",
83
+ name: "1d3w5wq",
84
+ styles: "width:100%",
85
85
  map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Collection/CollectionSearch.js"],"names":[],"mappings":"AAoFoC","file":"../../../../src/components/Collection/CollectionSearch.js","sourcesContent":["import React from 'react';\nimport styled from '@emotion/styled';\nimport { colorsRaw, colors, Icon, lengths, zIndex } from 'decap-cms-ui-default';\nimport { translate } from 'react-polyglot';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\n\nconst SearchContainer = styled.div`\n  margin: 0 12px;\n  position: relative;\n\n  ${Icon} {\n    position: absolute;\n    top: 0;\n    left: 6px;\n    z-index: ${zIndex.zIndex2};\n    height: 100%;\n    display: flex;\n    align-items: center;\n    pointer-events: none;\n  }\n`;\n\nconst InputContainer = styled.div`\n  display: flex;\n  align-items: center;\n  position: relative;\n`;\n\nconst SearchInput = styled.input`\n  background-color: #eff0f4;\n  border-radius: ${lengths.borderRadius};\n  font-size: 14px;\n  padding: 10px 6px 10px 32px;\n  width: 100%;\n  position: relative;\n  z-index: ${zIndex.zIndex1};\n\n  &:focus {\n    outline: none;\n    box-shadow: inset 0 0 0 2px ${colorsRaw.blue};\n  }\n`;\n\nconst SuggestionsContainer = styled.div`\n  position: relative;\n  width: 100%;\n`;\n\nconst Suggestions = styled.ul`\n  position: absolute;\n  top: 6px;\n  left: 0;\n  right: 0;\n  padding: 10px 0;\n  margin: 0;\n  list-style: none;\n  background-color: #fff;\n  border-radius: ${lengths.borderRadius};\n  border: 1px solid ${colors.textFieldBorder};\n  z-index: ${zIndex.zIndex1};\n`;\n\nconst SuggestionHeader = styled.li`\n  padding: 0 6px 6px 32px;\n  font-size: 12px;\n  color: ${colors.text};\n`;\n\nconst SuggestionItem = styled.li(\n  ({ isActive }) => `\n  color: ${isActive ? colors.active : colorsRaw.grayDark};\n  background-color: ${isActive ? colors.activeBackground : 'inherit'};\n  padding: 6px 6px 6px 32px;\n  cursor: pointer;\n  position: relative;\n\n  &:hover {\n    color: ${colors.active};\n    background-color: ${colors.activeBackground};\n  }\n`,\n);\n\nconst SuggestionDivider = styled.div`\n  width: 100%;\n`;\n\nclass CollectionSearch extends React.Component {\n  static propTypes = {\n    collections: ImmutablePropTypes.map.isRequired,\n    collection: ImmutablePropTypes.map,\n    searchTerm: PropTypes.string.isRequired,\n    onSubmit: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    query: this.props.searchTerm,\n    suggestionsVisible: false,\n    // default to the currently selected\n    selectedCollectionIdx: this.getSelectedSelectionBasedOnProps(),\n  };\n\n  componentDidUpdate(prevProps) {\n    if (prevProps.collection !== this.props.collection) {\n      const selectedCollectionIdx = this.getSelectedSelectionBasedOnProps();\n      this.setState({ selectedCollectionIdx });\n    }\n  }\n\n  getSelectedSelectionBasedOnProps() {\n    const { collection, collections } = this.props;\n    return collection ? collections.keySeq().indexOf(collection.get('name')) : -1;\n  }\n\n  toggleSuggestions(visible) {\n    this.setState({ suggestionsVisible: visible });\n  }\n\n  selectNextSuggestion() {\n    const { collections } = this.props;\n    const { selectedCollectionIdx } = this.state;\n    this.setState({\n      selectedCollectionIdx: Math.min(selectedCollectionIdx + 1, collections.size - 1),\n    });\n  }\n\n  selectPreviousSuggestion() {\n    const { selectedCollectionIdx } = this.state;\n    this.setState({\n      selectedCollectionIdx: Math.max(selectedCollectionIdx - 1, -1),\n    });\n  }\n\n  resetSelectedSuggestion() {\n    this.setState({\n      selectedCollectionIdx: -1,\n    });\n  }\n\n  submitSearch = () => {\n    const { onSubmit, collections } = this.props;\n    const { selectedCollectionIdx, query } = this.state;\n\n    this.toggleSuggestions(false);\n    if (selectedCollectionIdx !== -1) {\n      onSubmit(query, collections.toIndexedSeq().getIn([selectedCollectionIdx, 'name']));\n    } else {\n      onSubmit(query);\n    }\n  };\n\n  handleKeyDown = event => {\n    const { suggestionsVisible } = this.state;\n\n    if (event.key === 'Enter') {\n      this.submitSearch();\n    }\n\n    if (suggestionsVisible) {\n      // allow closing of suggestions with escape key\n      if (event.key === 'Escape') {\n        this.toggleSuggestions(false);\n      }\n\n      if (event.key === 'ArrowDown') {\n        this.selectNextSuggestion();\n        event.preventDefault();\n      } else if (event.key === 'ArrowUp') {\n        this.selectPreviousSuggestion();\n        event.preventDefault();\n      }\n    }\n  };\n\n  handleQueryChange = query => {\n    this.setState({ query });\n    this.toggleSuggestions(query !== '');\n    if (query === '') {\n      this.resetSelectedSuggestion();\n    }\n  };\n\n  handleSuggestionClick = (event, idx) => {\n    this.setState({ selectedCollectionIdx: idx }, this.submitSearch);\n    event.preventDefault();\n  };\n\n  render() {\n    const { collections, t } = this.props;\n    const { suggestionsVisible, selectedCollectionIdx, query } = this.state;\n    return (\n      <SearchContainer\n        onBlur={() => this.toggleSuggestions(false)}\n        onFocus={() => this.toggleSuggestions(query !== '')}\n      >\n        <InputContainer>\n          <Icon type=\"search\" />\n          <SearchInput\n            onChange={e => this.handleQueryChange(e.target.value)}\n            onKeyDown={this.handleKeyDown}\n            onClick={() => this.toggleSuggestions(true)}\n            placeholder={t('collection.sidebar.searchAll')}\n            value={query}\n          />\n        </InputContainer>\n        {suggestionsVisible && (\n          <SuggestionsContainer>\n            <Suggestions>\n              <SuggestionHeader>{t('collection.sidebar.searchIn')}</SuggestionHeader>\n              <SuggestionItem\n                isActive={selectedCollectionIdx === -1}\n                onClick={e => this.handleSuggestionClick(e, -1)}\n                onMouseDown={e => e.preventDefault()}\n              >\n                {t('collection.sidebar.allCollections')}\n              </SuggestionItem>\n              <SuggestionDivider />\n              {collections.toIndexedSeq().map((collection, idx) => (\n                <SuggestionItem\n                  key={idx}\n                  isActive={idx === selectedCollectionIdx}\n                  onClick={e => this.handleSuggestionClick(e, idx)}\n                  onMouseDown={e => e.preventDefault()}\n                >\n                  {collection.get('label')}\n                </SuggestionItem>\n              ))}\n            </Suggestions>\n          </SuggestionsContainer>\n        )}\n      </SearchContainer>\n    );\n  }\n}\n\nexport default translate()(CollectionSearch);\n"]} */",
86
86
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
87
87
  });
@@ -201,22 +201,22 @@ class CollectionSearch extends _react.default.Component {
201
201
  selectedCollectionIdx,
202
202
  query
203
203
  } = this.state;
204
- return (0, _core.jsx)(SearchContainer, {
204
+ return (0, _react2.jsx)(SearchContainer, {
205
205
  onBlur: () => this.toggleSuggestions(false),
206
206
  onFocus: () => this.toggleSuggestions(query !== '')
207
- }, (0, _core.jsx)(InputContainer, null, (0, _core.jsx)(_decapCmsUiDefault.Icon, {
207
+ }, (0, _react2.jsx)(InputContainer, null, (0, _react2.jsx)(_decapCmsUiDefault.Icon, {
208
208
  type: "search"
209
- }), (0, _core.jsx)(SearchInput, {
209
+ }), (0, _react2.jsx)(SearchInput, {
210
210
  onChange: e => this.handleQueryChange(e.target.value),
211
211
  onKeyDown: this.handleKeyDown,
212
212
  onClick: () => this.toggleSuggestions(true),
213
213
  placeholder: t('collection.sidebar.searchAll'),
214
214
  value: query
215
- })), suggestionsVisible && (0, _core.jsx)(SuggestionsContainer, null, (0, _core.jsx)(Suggestions, null, (0, _core.jsx)(SuggestionHeader, null, t('collection.sidebar.searchIn')), (0, _core.jsx)(SuggestionItem, {
215
+ })), suggestionsVisible && (0, _react2.jsx)(SuggestionsContainer, null, (0, _react2.jsx)(Suggestions, null, (0, _react2.jsx)(SuggestionHeader, null, t('collection.sidebar.searchIn')), (0, _react2.jsx)(SuggestionItem, {
216
216
  isActive: selectedCollectionIdx === -1,
217
217
  onClick: e => this.handleSuggestionClick(e, -1),
218
218
  onMouseDown: e => e.preventDefault()
219
- }, t('collection.sidebar.allCollections')), (0, _core.jsx)(SuggestionDivider, null), collections.toIndexedSeq().map((collection, idx) => (0, _core.jsx)(SuggestionItem, {
219
+ }, t('collection.sidebar.allCollections')), (0, _react2.jsx)(SuggestionDivider, null), collections.toIndexedSeq().map((collection, idx) => (0, _react2.jsx)(SuggestionItem, {
220
220
  key: idx,
221
221
  isActive: idx === selectedCollectionIdx,
222
222
  onClick: e => this.handleSuggestionClick(e, idx),
@@ -231,5 +231,4 @@ _defineProperty(CollectionSearch, "propTypes", {
231
231
  onSubmit: _propTypes.default.func.isRequired,
232
232
  t: _propTypes.default.func.isRequired
233
233
  });
234
- var _default = (0, _reactPolyglot.translate)()(CollectionSearch);
235
- exports.default = _default;
234
+ var _default = exports.default = (0, _reactPolyglot.translate)()(CollectionSearch);