decap-cms-core 3.3.0 → 3.3.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/decap-cms-core.js +2 -2
- package/dist/decap-cms-core.js.map +1 -1
- package/dist/esm/bootstrap.js +2 -2
- package/dist/esm/components/Collection/CollectionSearch.js +9 -9
- package/dist/esm/components/Collection/Entries/EntriesCollection.js +2 -2
- package/dist/esm/components/Collection/Entries/EntryCard.js +9 -9
- package/dist/esm/components/Collection/NestedCollection.js +6 -6
- package/dist/esm/components/Collection/Sidebar.js +9 -9
- package/dist/esm/components/UI/ErrorBoundary.js +2 -2
- package/package.json +2 -2
- package/src/components/Collection/CollectionSearch.js +3 -3
- package/src/components/Collection/Entries/EntriesCollection.js +3 -1
- package/src/components/Collection/Entries/EntryCard.js +2 -2
- package/src/components/Collection/NestedCollection.js +2 -2
- package/src/components/Collection/Sidebar.js +6 -5
- package/src/components/Collection/__tests__/__snapshots__/NestedCollection.spec.js.snap +14 -14
- package/src/components/Collection/__tests__/__snapshots__/Sidebar.spec.js.snap +20 -16
package/dist/esm/bootstrap.js
CHANGED
|
@@ -55,8 +55,8 @@ function bootstrap(opts = {}) {
|
|
|
55
55
|
/**
|
|
56
56
|
* Log the version number.
|
|
57
57
|
*/
|
|
58
|
-
if (typeof "3.3.
|
|
59
|
-
console.log(`decap-cms-core ${"3.3.
|
|
58
|
+
if (typeof "3.3.1" === 'string') {
|
|
59
|
+
console.log(`decap-cms-core ${"3.3.1"}`);
|
|
60
60
|
}
|
|
61
61
|
|
|
62
62
|
/**
|
|
@@ -19,7 +19,7 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringif
|
|
|
19
19
|
const SearchContainer = /*#__PURE__*/(0, _base.default)("div", {
|
|
20
20
|
target: "e6w847r7",
|
|
21
21
|
label: "SearchContainer"
|
|
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,
|
|
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 34px;\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 34px;\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 34px;\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
23
|
const InputContainer = /*#__PURE__*/(0, _base.default)("div", {
|
|
24
24
|
target: "e6w847r6",
|
|
25
25
|
label: "InputContainer"
|
|
@@ -29,13 +29,13 @@ const InputContainer = /*#__PURE__*/(0, _base.default)("div", {
|
|
|
29
29
|
} : {
|
|
30
30
|
name: "1dbubah",
|
|
31
31
|
styles: "display:flex;align-items:center;position:relative",
|
|
32
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
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 34px;\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 34px;\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 34px;\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
35
|
const SearchInput = /*#__PURE__*/(0, _base.default)("input", {
|
|
36
36
|
target: "e6w847r5",
|
|
37
37
|
label: "SearchInput"
|
|
38
|
-
})("background-color:#eff0f4;border-radius:", _decapCmsUiDefault.lengths.borderRadius, ";font-size:14px;padding:10px 6px 10px
|
|
38
|
+
})("background-color:#eff0f4;border-radius:", _decapCmsUiDefault.lengths.borderRadius, ";font-size:14px;padding:10px 6px 10px 34px;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 34px;\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 34px;\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 34px;\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
39
|
const SuggestionsContainer = /*#__PURE__*/(0, _base.default)("div", {
|
|
40
40
|
target: "e6w847r4",
|
|
41
41
|
label: "SuggestionsContainer"
|
|
@@ -45,17 +45,17 @@ const SuggestionsContainer = /*#__PURE__*/(0, _base.default)("div", {
|
|
|
45
45
|
} : {
|
|
46
46
|
name: "pw7jst",
|
|
47
47
|
styles: "position:relative;width:100%",
|
|
48
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
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 34px;\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 34px;\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 34px;\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
51
|
const Suggestions = /*#__PURE__*/(0, _base.default)("ul", {
|
|
52
52
|
target: "e6w847r3",
|
|
53
53
|
label: "Suggestions"
|
|
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,
|
|
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 34px;\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 34px;\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 34px;\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
55
|
const SuggestionHeader = /*#__PURE__*/(0, _base.default)("li", {
|
|
56
56
|
target: "e6w847r2",
|
|
57
57
|
label: "SuggestionHeader"
|
|
58
|
-
})("padding:0 6px 6px
|
|
58
|
+
})("padding:0 6px 6px 34px;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 34px;\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 34px;\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 34px;\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
59
|
const SuggestionItem = /*#__PURE__*/(0, _base.default)("li", {
|
|
60
60
|
target: "e6w847r1",
|
|
61
61
|
label: "SuggestionItem"
|
|
@@ -64,7 +64,7 @@ const SuggestionItem = /*#__PURE__*/(0, _base.default)("li", {
|
|
|
64
64
|
}) => `
|
|
65
65
|
color: ${isActive ? _decapCmsUiDefault.colors.active : _decapCmsUiDefault.colorsRaw.grayDark};
|
|
66
66
|
background-color: ${isActive ? _decapCmsUiDefault.colors.activeBackground : 'inherit'};
|
|
67
|
-
padding: 6px 6px 6px
|
|
67
|
+
padding: 6px 6px 6px 34px;
|
|
68
68
|
cursor: pointer;
|
|
69
69
|
position: relative;
|
|
70
70
|
|
|
@@ -72,7 +72,7 @@ const SuggestionItem = /*#__PURE__*/(0, _base.default)("li", {
|
|
|
72
72
|
color: ${_decapCmsUiDefault.colors.active};
|
|
73
73
|
background-color: ${_decapCmsUiDefault.colors.activeBackground};
|
|
74
74
|
}
|
|
75
|
-
`, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
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 34px;\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 34px;\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 34px;\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
76
|
const SuggestionDivider = /*#__PURE__*/(0, _base.default)("div", {
|
|
77
77
|
target: "e6w847r0",
|
|
78
78
|
label: "SuggestionDivider"
|
|
@@ -82,7 +82,7 @@ const SuggestionDivider = /*#__PURE__*/(0, _base.default)("div", {
|
|
|
82
82
|
} : {
|
|
83
83
|
name: "1d3w5wq",
|
|
84
84
|
styles: "width:100%",
|
|
85
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
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 34px;\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 34px;\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 34px;\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
|
});
|
|
88
88
|
class CollectionSearch extends _react.default.Component {
|
|
@@ -26,11 +26,11 @@ function _toPrimitive(input, hint) { if (typeof input !== "object" || input ===
|
|
|
26
26
|
const GroupHeading = /*#__PURE__*/(0, _base.default)("h2", {
|
|
27
27
|
target: "eucqz2q1",
|
|
28
28
|
label: "GroupHeading"
|
|
29
|
-
})("font-size:
|
|
29
|
+
})("font-size:22px;font-weight:600;line-height:37px;padding-inline-start:20px;color:", _decapCmsUiDefault.colors.textLead, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vRW50cmllcy9FbnRyaWVzQ29sbGVjdGlvbi5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1QjhCIiwiZmlsZSI6Ii4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vRW50cmllcy9FbnRyaWVzQ29sbGVjdGlvbi5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IEltbXV0YWJsZVByb3BUeXBlcyBmcm9tICdyZWFjdC1pbW11dGFibGUtcHJvcHR5cGVzJztcbmltcG9ydCB7IGNvbm5lY3QgfSBmcm9tICdyZWFjdC1yZWR1eCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyB0cmFuc2xhdGUgfSBmcm9tICdyZWFjdC1wb2x5Z2xvdCc7XG5pbXBvcnQgeyBwYXJ0aWFsIH0gZnJvbSAnbG9kYXNoJztcbmltcG9ydCB7IEN1cnNvciB9IGZyb20gJ2RlY2FwLWNtcy1saWItdXRpbCc7XG5pbXBvcnQgeyBjb2xvcnMgfSBmcm9tICdkZWNhcC1jbXMtdWktZGVmYXVsdCc7XG5cbmltcG9ydCB7XG4gIGxvYWRFbnRyaWVzIGFzIGFjdGlvbkxvYWRFbnRyaWVzLFxuICB0cmF2ZXJzZUNvbGxlY3Rpb25DdXJzb3IgYXMgYWN0aW9uVHJhdmVyc2VDb2xsZWN0aW9uQ3Vyc29yLFxufSBmcm9tICcuLi8uLi8uLi9hY3Rpb25zL2VudHJpZXMnO1xuaW1wb3J0IHtcbiAgc2VsZWN0RW50cmllcyxcbiAgc2VsZWN0RW50cmllc0xvYWRlZCxcbiAgc2VsZWN0SXNGZXRjaGluZyxcbiAgc2VsZWN0R3JvdXBzLFxufSBmcm9tICcuLi8uLi8uLi9yZWR1Y2Vycy9lbnRyaWVzJztcbmltcG9ydCB7IHNlbGVjdENvbGxlY3Rpb25FbnRyaWVzQ3Vyc29yIH0gZnJvbSAnLi4vLi4vLi4vcmVkdWNlcnMvY3Vyc29ycyc7XG5pbXBvcnQgRW50cmllcyBmcm9tICcuL0VudHJpZXMnO1xuXG5jb25zdCBHcm91cEhlYWRpbmcgPSBzdHlsZWQuaDJgXG4gIGZvbnQtc2l6ZTogMjJweDtcbiAgZm9udC13ZWlnaHQ6IDYwMDtcbiAgbGluZS1oZWlnaHQ6IDM3cHg7XG4gIHBhZGRpbmctaW5saW5lLXN0YXJ0OiAyMHB4O1xuICBjb2xvcjogJHtjb2xvcnMudGV4dExlYWR9O1xuYDtcblxuY29uc3QgR3JvdXBDb250YWluZXIgPSBzdHlsZWQuZGl2YGA7XG5cbmZ1bmN0aW9uIGdldEdyb3VwRW50cmllcyhlbnRyaWVzLCBwYXRocykge1xuICByZXR1cm4gZW50cmllcy5maWx0ZXIoZW50cnkgPT4gcGF0aHMuaGFzKGVudHJ5LmdldCgncGF0aCcpKSk7XG59XG5cbmZ1bmN0aW9uIGdldEdyb3VwVGl0bGUoZ3JvdXAsIHQpIHtcbiAgY29uc3QgeyBsYWJlbCwgdmFsdWUgfSA9IGdyb3VwO1xuICBpZiAodmFsdWUgPT09IHVuZGVmaW5lZCkge1xuICAgIHJldHVybiB0KCdjb2xsZWN0aW9uLmdyb3Vwcy5vdGhlcicpO1xuICB9XG4gIGlmICh0eXBlb2YgdmFsdWUgPT09ICdib29sZWFuJykge1xuICAgIHJldHVybiB2YWx1ZSA/IGxhYmVsIDogdCgnY29sbGVjdGlvbi5ncm91cHMubmVnYXRlTGFiZWwnLCB7IGxhYmVsIH0pO1xuICB9XG4gIHJldHVybiBgJHtsYWJlbH0gJHt2YWx1ZX1gLnRyaW0oKTtcbn1cblxuZnVuY3Rpb24gd2l0aEdyb3Vwcyhncm91cHMsIGVudHJpZXMsIEVudHJpZXNUb1JlbmRlciwgdCkge1xuICByZXR1cm4gZ3JvdXBzLm1hcChncm91cCA9PiB7XG4gICAgY29uc3QgdGl0bGUgPSBnZXRHcm91cFRpdGxlKGdyb3VwLCB0KTtcbiAgICByZXR1cm4gKFxuICAgICAgPEdyb3VwQ29udGFpbmVyIGtleT17Z3JvdXAuaWR9IGlkPXtncm91cC5pZH0+XG4gICAgICAgIDxHcm91cEhlYWRpbmc+e3RpdGxlfTwvR3JvdXBIZWFkaW5nPlxuICAgICAgICA8RW50cmllc1RvUmVuZGVyIGVudHJpZXM9e2dldEdyb3VwRW50cmllcyhlbnRyaWVzLCBncm91cC5wYXRocyl9IC8+XG4gICAgICA8L0dyb3VwQ29udGFpbmVyPlxuICAgICk7XG4gIH0pO1xufVxuXG5leHBvcnQgY2xhc3MgRW50cmllc0NvbGxlY3Rpb24gZXh0ZW5kcyBSZWFjdC5Db21wb25lbnQge1xuICBzdGF0aWMgcHJvcFR5cGVzID0ge1xuICAgIGNvbGxlY3Rpb246IEltbXV0YWJsZVByb3BUeXBlcy5tYXAuaXNSZXF1aXJlZCxcbiAgICBwYWdlOiBQcm9wVHlwZXMubnVtYmVyLFxuICAgIGVudHJpZXM6IEltbXV0YWJsZVByb3BUeXBlcy5saXN0LFxuICAgIGdyb3VwczogUHJvcFR5cGVzLmFycmF5LFxuICAgIGlzRmV0Y2hpbmc6IFByb3BUeXBlcy5ib29sLmlzUmVxdWlyZWQsXG4gICAgdmlld1N0eWxlOiBQcm9wVHlwZXMuc3RyaW5nLFxuICAgIGN1cnNvcjogUHJvcFR5cGVzLm9iamVjdC5pc1JlcXVpcmVkLFxuICAgIGxvYWRFbnRyaWVzOiBQcm9wVHlwZXMuZnVuYy5pc1JlcXVpcmVkLFxuICAgIHRyYXZlcnNlQ29sbGVjdGlvbkN1cnNvcjogUHJvcFR5cGVzLmZ1bmMuaXNSZXF1aXJlZCxcbiAgICBlbnRyaWVzTG9hZGVkOiBQcm9wVHlwZXMuYm9vbCxcbiAgfTtcblxuICBjb21wb25lbnREaWRNb3VudCgpIHtcbiAgICBjb25zdCB7IGNvbGxlY3Rpb24sIGVudHJpZXNMb2FkZWQsIGxvYWRFbnRyaWVzIH0gPSB0aGlzLnByb3BzO1xuICAgIGlmIChjb2xsZWN0aW9uICYmICFlbnRyaWVzTG9hZGVkKSB7XG4gICAgICBsb2FkRW50cmllcyhjb2xsZWN0aW9uKTtcbiAgICB9XG4gIH1cblxuICBjb21wb25lbnREaWRVcGRhdGUocHJldlByb3BzKSB7XG4gICAgY29uc3QgeyBjb2xsZWN0aW9uLCBlbnRyaWVzTG9hZGVkLCBsb2FkRW50cmllcyB9ID0gdGhpcy5wcm9wcztcbiAgICBpZiAoY29sbGVjdGlvbiAhPT0gcHJldlByb3BzLmNvbGxlY3Rpb24gJiYgIWVudHJpZXNMb2FkZWQpIHtcbiAgICAgIGxvYWRFbnRyaWVzKGNvbGxlY3Rpb24pO1xuICAgIH1cbiAgfVxuXG4gIGhhbmRsZUN1cnNvckFjdGlvbnMgPSAoY3Vyc29yLCBhY3Rpb24pID0+IHtcbiAgICBjb25zdCB7IGNvbGxlY3Rpb24sIHRyYXZlcnNlQ29sbGVjdGlvbkN1cnNvciB9ID0gdGhpcy5wcm9wcztcbiAgICB0cmF2ZXJzZUNvbGxlY3Rpb25DdXJzb3IoY29sbGVjdGlvbiwgYWN0aW9uKTtcbiAgfTtcblxuICByZW5kZXIoKSB7XG4gICAgY29uc3QgeyBjb2xsZWN0aW9uLCBlbnRyaWVzLCBncm91cHMsIGlzRmV0Y2hpbmcsIHZpZXdTdHlsZSwgY3Vyc29yLCBwYWdlLCB0IH0gPSB0aGlzLnByb3BzO1xuXG4gICAgY29uc3QgRW50cmllc1RvUmVuZGVyID0gKHsgZW50cmllcyB9KSA9PiB7XG4gICAgICByZXR1cm4gKFxuICAgICAgICA8RW50cmllc1xuICAgICAgICAgIGNvbGxlY3Rpb25zPXtjb2xsZWN0aW9ufVxuICAgICAgICAgIGVudHJpZXM9e2VudHJpZXN9XG4gICAgICAgICAgaXNGZXRjaGluZz17aXNGZXRjaGluZ31cbiAgICAgICAgICBjb2xsZWN0aW9uTmFtZT17Y29sbGVjdGlvbi5nZXQoJ2xhYmVsJyl9XG4gICAgICAgICAgdmlld1N0eWxlPXt2aWV3U3R5bGV9XG4gICAgICAgICAgY3Vyc29yPXtjdXJzb3J9XG4gICAgICAgICAgaGFuZGxlQ3Vyc29yQWN0aW9ucz17cGFydGlhbCh0aGlzLmhhbmRsZUN1cnNvckFjdGlvbnMsIGN1cnNvcil9XG4gICAgICAgICAgcGFnZT17cGFnZX1cbiAgICAgICAgLz5cbiAgICAgICk7XG4gICAgfTtcblxuICAgIGlmIChncm91cHMgJiYgZ3JvdXBzLmxlbmd0aCA+IDApIHtcbiAgICAgIHJldHVybiB3aXRoR3JvdXBzKGdyb3VwcywgZW50cmllcywgRW50cmllc1RvUmVuZGVyLCB0KTtcbiAgICB9XG5cbiAgICByZXR1cm4gPEVudHJpZXNUb1JlbmRlciBlbnRyaWVzPXtlbnRyaWVzfSAvPjtcbiAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gZmlsdGVyTmVzdGVkRW50cmllcyhwYXRoLCBjb2xsZWN0aW9uRm9sZGVyLCBlbnRyaWVzKSB7XG4gIGNvbnN0IGZpbHRlcmVkID0gZW50cmllcy5maWx0ZXIoZSA9PiB7XG4gICAgY29uc3QgZW50cnlQYXRoID0gZS5nZXQoJ3BhdGgnKS5zbGljZShjb2xsZWN0aW9uRm9sZGVyLmxlbmd0aCArIDEpO1xuICAgIGlmICghZW50cnlQYXRoLnN0YXJ0c1dpdGgocGF0aCkpIHtcbiAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG5cbiAgICAvLyBvbmx5IHNob3cgaW1tZWRpYXRlIGNoaWxkcmVuXG4gICAgaWYgKHBhdGgpIHtcbiAgICAgIC8vIG5vbiByb290IHBhdGhcbiAgICAgIGNvbnN0IHRyaW1tZWQgPSBlbnRyeVBhdGguc2xpY2UocGF0aC5sZW5ndGggKyAxKTtcbiAgICAgIHJldHVybiB0cmltbWVkLnNwbGl0KCcvJykubGVuZ3RoID09PSAyO1xuICAgIH0gZWxzZSB7XG4gICAgICAvLyByb290IHBhdGhcbiAgICAgIHJldHVybiBlbnRyeVBhdGguc3BsaXQoJy8nKS5sZW5ndGggPD0gMjtcbiAgICB9XG4gIH0pO1xuICByZXR1cm4gZmlsdGVyZWQ7XG59XG5cbmZ1bmN0aW9uIG1hcFN0YXRlVG9Qcm9wcyhzdGF0ZSwgb3duUHJvcHMpIHtcbiAgY29uc3QgeyBjb2xsZWN0aW9uLCB2aWV3U3R5bGUsIGZpbHRlclRlcm0gfSA9IG93blByb3BzO1xuICBjb25zdCBwYWdlID0gc3RhdGUuZW50cmllcy5nZXRJbihbJ3BhZ2VzJywgY29sbGVjdGlvbi5nZXQoJ25hbWUnKSwgJ3BhZ2UnXSk7XG5cbiAgbGV0IGVudHJpZXMgPSBzZWxlY3RFbnRyaWVzKHN0YXRlLmVudHJpZXMsIGNvbGxlY3Rpb24pO1xuICBjb25zdCBncm91cHMgPSBzZWxlY3RHcm91cHMoc3RhdGUuZW50cmllcywgY29sbGVjdGlvbik7XG5cbiAgaWYgKGNvbGxlY3Rpb24uaGFzKCduZXN0ZWQnKSkge1xuICAgIGNvbnN0IGNvbGxlY3Rpb25Gb2xkZXIgPSBjb2xsZWN0aW9uLmdldCgnZm9sZGVyJyk7XG4gICAgZW50cmllcyA9IGZpbHRlck5lc3RlZEVudHJpZXMoZmlsdGVyVGVybSB8fCAnJywgY29sbGVjdGlvbkZvbGRlciwgZW50cmllcyk7XG4gIH1cbiAgY29uc3QgZW50cmllc0xvYWRlZCA9IHNlbGVjdEVudHJpZXNMb2FkZWQoc3RhdGUuZW50cmllcywgY29sbGVjdGlvbi5nZXQoJ25hbWUnKSk7XG4gIGNvbnN0IGlzRmV0Y2hpbmcgPSBzZWxlY3RJc0ZldGNoaW5nKHN0YXRlLmVudHJpZXMsIGNvbGxlY3Rpb24uZ2V0KCduYW1lJykpO1xuXG4gIGNvbnN0IHJhd0N1cnNvciA9IHNlbGVjdENvbGxlY3Rpb25FbnRyaWVzQ3Vyc29yKHN0YXRlLmN1cnNvcnMsIGNvbGxlY3Rpb24uZ2V0KCduYW1lJykpO1xuICBjb25zdCBjdXJzb3IgPSBDdXJzb3IuY3JlYXRlKHJhd0N1cnNvcikuY2xlYXJEYXRhKCk7XG5cbiAgcmV0dXJuIHsgY29sbGVjdGlvbiwgcGFnZSwgZW50cmllcywgZ3JvdXBzLCBlbnRyaWVzTG9hZGVkLCBpc0ZldGNoaW5nLCB2aWV3U3R5bGUsIGN1cnNvciB9O1xufVxuXG5jb25zdCBtYXBEaXNwYXRjaFRvUHJvcHMgPSB7XG4gIGxvYWRFbnRyaWVzOiBhY3Rpb25Mb2FkRW50cmllcyxcbiAgdHJhdmVyc2VDb2xsZWN0aW9uQ3Vyc29yOiBhY3Rpb25UcmF2ZXJzZUNvbGxlY3Rpb25DdXJzb3IsXG59O1xuXG5jb25zdCBDb25uZWN0ZWRFbnRyaWVzQ29sbGVjdGlvbiA9IGNvbm5lY3QobWFwU3RhdGVUb1Byb3BzLCBtYXBEaXNwYXRjaFRvUHJvcHMpKEVudHJpZXNDb2xsZWN0aW9uKTtcblxuZXhwb3J0IGRlZmF1bHQgdHJhbnNsYXRlKCkoQ29ubmVjdGVkRW50cmllc0NvbGxlY3Rpb24pO1xuIl19 */"));
|
|
30
30
|
const GroupContainer = /*#__PURE__*/(0, _base.default)("div", {
|
|
31
31
|
target: "eucqz2q0",
|
|
32
32
|
label: "GroupContainer"
|
|
33
|
-
})(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
33
|
+
})(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vRW50cmllcy9FbnRyaWVzQ29sbGVjdGlvbi5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErQmlDIiwiZmlsZSI6Ii4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vRW50cmllcy9FbnRyaWVzQ29sbGVjdGlvbi5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IEltbXV0YWJsZVByb3BUeXBlcyBmcm9tICdyZWFjdC1pbW11dGFibGUtcHJvcHR5cGVzJztcbmltcG9ydCB7IGNvbm5lY3QgfSBmcm9tICdyZWFjdC1yZWR1eCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyB0cmFuc2xhdGUgfSBmcm9tICdyZWFjdC1wb2x5Z2xvdCc7XG5pbXBvcnQgeyBwYXJ0aWFsIH0gZnJvbSAnbG9kYXNoJztcbmltcG9ydCB7IEN1cnNvciB9IGZyb20gJ2RlY2FwLWNtcy1saWItdXRpbCc7XG5pbXBvcnQgeyBjb2xvcnMgfSBmcm9tICdkZWNhcC1jbXMtdWktZGVmYXVsdCc7XG5cbmltcG9ydCB7XG4gIGxvYWRFbnRyaWVzIGFzIGFjdGlvbkxvYWRFbnRyaWVzLFxuICB0cmF2ZXJzZUNvbGxlY3Rpb25DdXJzb3IgYXMgYWN0aW9uVHJhdmVyc2VDb2xsZWN0aW9uQ3Vyc29yLFxufSBmcm9tICcuLi8uLi8uLi9hY3Rpb25zL2VudHJpZXMnO1xuaW1wb3J0IHtcbiAgc2VsZWN0RW50cmllcyxcbiAgc2VsZWN0RW50cmllc0xvYWRlZCxcbiAgc2VsZWN0SXNGZXRjaGluZyxcbiAgc2VsZWN0R3JvdXBzLFxufSBmcm9tICcuLi8uLi8uLi9yZWR1Y2Vycy9lbnRyaWVzJztcbmltcG9ydCB7IHNlbGVjdENvbGxlY3Rpb25FbnRyaWVzQ3Vyc29yIH0gZnJvbSAnLi4vLi4vLi4vcmVkdWNlcnMvY3Vyc29ycyc7XG5pbXBvcnQgRW50cmllcyBmcm9tICcuL0VudHJpZXMnO1xuXG5jb25zdCBHcm91cEhlYWRpbmcgPSBzdHlsZWQuaDJgXG4gIGZvbnQtc2l6ZTogMjJweDtcbiAgZm9udC13ZWlnaHQ6IDYwMDtcbiAgbGluZS1oZWlnaHQ6IDM3cHg7XG4gIHBhZGRpbmctaW5saW5lLXN0YXJ0OiAyMHB4O1xuICBjb2xvcjogJHtjb2xvcnMudGV4dExlYWR9O1xuYDtcblxuY29uc3QgR3JvdXBDb250YWluZXIgPSBzdHlsZWQuZGl2YGA7XG5cbmZ1bmN0aW9uIGdldEdyb3VwRW50cmllcyhlbnRyaWVzLCBwYXRocykge1xuICByZXR1cm4gZW50cmllcy5maWx0ZXIoZW50cnkgPT4gcGF0aHMuaGFzKGVudHJ5LmdldCgncGF0aCcpKSk7XG59XG5cbmZ1bmN0aW9uIGdldEdyb3VwVGl0bGUoZ3JvdXAsIHQpIHtcbiAgY29uc3QgeyBsYWJlbCwgdmFsdWUgfSA9IGdyb3VwO1xuICBpZiAodmFsdWUgPT09IHVuZGVmaW5lZCkge1xuICAgIHJldHVybiB0KCdjb2xsZWN0aW9uLmdyb3Vwcy5vdGhlcicpO1xuICB9XG4gIGlmICh0eXBlb2YgdmFsdWUgPT09ICdib29sZWFuJykge1xuICAgIHJldHVybiB2YWx1ZSA/IGxhYmVsIDogdCgnY29sbGVjdGlvbi5ncm91cHMubmVnYXRlTGFiZWwnLCB7IGxhYmVsIH0pO1xuICB9XG4gIHJldHVybiBgJHtsYWJlbH0gJHt2YWx1ZX1gLnRyaW0oKTtcbn1cblxuZnVuY3Rpb24gd2l0aEdyb3Vwcyhncm91cHMsIGVudHJpZXMsIEVudHJpZXNUb1JlbmRlciwgdCkge1xuICByZXR1cm4gZ3JvdXBzLm1hcChncm91cCA9PiB7XG4gICAgY29uc3QgdGl0bGUgPSBnZXRHcm91cFRpdGxlKGdyb3VwLCB0KTtcbiAgICByZXR1cm4gKFxuICAgICAgPEdyb3VwQ29udGFpbmVyIGtleT17Z3JvdXAuaWR9IGlkPXtncm91cC5pZH0+XG4gICAgICAgIDxHcm91cEhlYWRpbmc+e3RpdGxlfTwvR3JvdXBIZWFkaW5nPlxuICAgICAgICA8RW50cmllc1RvUmVuZGVyIGVudHJpZXM9e2dldEdyb3VwRW50cmllcyhlbnRyaWVzLCBncm91cC5wYXRocyl9IC8+XG4gICAgICA8L0dyb3VwQ29udGFpbmVyPlxuICAgICk7XG4gIH0pO1xufVxuXG5leHBvcnQgY2xhc3MgRW50cmllc0NvbGxlY3Rpb24gZXh0ZW5kcyBSZWFjdC5Db21wb25lbnQge1xuICBzdGF0aWMgcHJvcFR5cGVzID0ge1xuICAgIGNvbGxlY3Rpb246IEltbXV0YWJsZVByb3BUeXBlcy5tYXAuaXNSZXF1aXJlZCxcbiAgICBwYWdlOiBQcm9wVHlwZXMubnVtYmVyLFxuICAgIGVudHJpZXM6IEltbXV0YWJsZVByb3BUeXBlcy5saXN0LFxuICAgIGdyb3VwczogUHJvcFR5cGVzLmFycmF5LFxuICAgIGlzRmV0Y2hpbmc6IFByb3BUeXBlcy5ib29sLmlzUmVxdWlyZWQsXG4gICAgdmlld1N0eWxlOiBQcm9wVHlwZXMuc3RyaW5nLFxuICAgIGN1cnNvcjogUHJvcFR5cGVzLm9iamVjdC5pc1JlcXVpcmVkLFxuICAgIGxvYWRFbnRyaWVzOiBQcm9wVHlwZXMuZnVuYy5pc1JlcXVpcmVkLFxuICAgIHRyYXZlcnNlQ29sbGVjdGlvbkN1cnNvcjogUHJvcFR5cGVzLmZ1bmMuaXNSZXF1aXJlZCxcbiAgICBlbnRyaWVzTG9hZGVkOiBQcm9wVHlwZXMuYm9vbCxcbiAgfTtcblxuICBjb21wb25lbnREaWRNb3VudCgpIHtcbiAgICBjb25zdCB7IGNvbGxlY3Rpb24sIGVudHJpZXNMb2FkZWQsIGxvYWRFbnRyaWVzIH0gPSB0aGlzLnByb3BzO1xuICAgIGlmIChjb2xsZWN0aW9uICYmICFlbnRyaWVzTG9hZGVkKSB7XG4gICAgICBsb2FkRW50cmllcyhjb2xsZWN0aW9uKTtcbiAgICB9XG4gIH1cblxuICBjb21wb25lbnREaWRVcGRhdGUocHJldlByb3BzKSB7XG4gICAgY29uc3QgeyBjb2xsZWN0aW9uLCBlbnRyaWVzTG9hZGVkLCBsb2FkRW50cmllcyB9ID0gdGhpcy5wcm9wcztcbiAgICBpZiAoY29sbGVjdGlvbiAhPT0gcHJldlByb3BzLmNvbGxlY3Rpb24gJiYgIWVudHJpZXNMb2FkZWQpIHtcbiAgICAgIGxvYWRFbnRyaWVzKGNvbGxlY3Rpb24pO1xuICAgIH1cbiAgfVxuXG4gIGhhbmRsZUN1cnNvckFjdGlvbnMgPSAoY3Vyc29yLCBhY3Rpb24pID0+IHtcbiAgICBjb25zdCB7IGNvbGxlY3Rpb24sIHRyYXZlcnNlQ29sbGVjdGlvbkN1cnNvciB9ID0gdGhpcy5wcm9wcztcbiAgICB0cmF2ZXJzZUNvbGxlY3Rpb25DdXJzb3IoY29sbGVjdGlvbiwgYWN0aW9uKTtcbiAgfTtcblxuICByZW5kZXIoKSB7XG4gICAgY29uc3QgeyBjb2xsZWN0aW9uLCBlbnRyaWVzLCBncm91cHMsIGlzRmV0Y2hpbmcsIHZpZXdTdHlsZSwgY3Vyc29yLCBwYWdlLCB0IH0gPSB0aGlzLnByb3BzO1xuXG4gICAgY29uc3QgRW50cmllc1RvUmVuZGVyID0gKHsgZW50cmllcyB9KSA9PiB7XG4gICAgICByZXR1cm4gKFxuICAgICAgICA8RW50cmllc1xuICAgICAgICAgIGNvbGxlY3Rpb25zPXtjb2xsZWN0aW9ufVxuICAgICAgICAgIGVudHJpZXM9e2VudHJpZXN9XG4gICAgICAgICAgaXNGZXRjaGluZz17aXNGZXRjaGluZ31cbiAgICAgICAgICBjb2xsZWN0aW9uTmFtZT17Y29sbGVjdGlvbi5nZXQoJ2xhYmVsJyl9XG4gICAgICAgICAgdmlld1N0eWxlPXt2aWV3U3R5bGV9XG4gICAgICAgICAgY3Vyc29yPXtjdXJzb3J9XG4gICAgICAgICAgaGFuZGxlQ3Vyc29yQWN0aW9ucz17cGFydGlhbCh0aGlzLmhhbmRsZUN1cnNvckFjdGlvbnMsIGN1cnNvcil9XG4gICAgICAgICAgcGFnZT17cGFnZX1cbiAgICAgICAgLz5cbiAgICAgICk7XG4gICAgfTtcblxuICAgIGlmIChncm91cHMgJiYgZ3JvdXBzLmxlbmd0aCA+IDApIHtcbiAgICAgIHJldHVybiB3aXRoR3JvdXBzKGdyb3VwcywgZW50cmllcywgRW50cmllc1RvUmVuZGVyLCB0KTtcbiAgICB9XG5cbiAgICByZXR1cm4gPEVudHJpZXNUb1JlbmRlciBlbnRyaWVzPXtlbnRyaWVzfSAvPjtcbiAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gZmlsdGVyTmVzdGVkRW50cmllcyhwYXRoLCBjb2xsZWN0aW9uRm9sZGVyLCBlbnRyaWVzKSB7XG4gIGNvbnN0IGZpbHRlcmVkID0gZW50cmllcy5maWx0ZXIoZSA9PiB7XG4gICAgY29uc3QgZW50cnlQYXRoID0gZS5nZXQoJ3BhdGgnKS5zbGljZShjb2xsZWN0aW9uRm9sZGVyLmxlbmd0aCArIDEpO1xuICAgIGlmICghZW50cnlQYXRoLnN0YXJ0c1dpdGgocGF0aCkpIHtcbiAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG5cbiAgICAvLyBvbmx5IHNob3cgaW1tZWRpYXRlIGNoaWxkcmVuXG4gICAgaWYgKHBhdGgpIHtcbiAgICAgIC8vIG5vbiByb290IHBhdGhcbiAgICAgIGNvbnN0IHRyaW1tZWQgPSBlbnRyeVBhdGguc2xpY2UocGF0aC5sZW5ndGggKyAxKTtcbiAgICAgIHJldHVybiB0cmltbWVkLnNwbGl0KCcvJykubGVuZ3RoID09PSAyO1xuICAgIH0gZWxzZSB7XG4gICAgICAvLyByb290IHBhdGhcbiAgICAgIHJldHVybiBlbnRyeVBhdGguc3BsaXQoJy8nKS5sZW5ndGggPD0gMjtcbiAgICB9XG4gIH0pO1xuICByZXR1cm4gZmlsdGVyZWQ7XG59XG5cbmZ1bmN0aW9uIG1hcFN0YXRlVG9Qcm9wcyhzdGF0ZSwgb3duUHJvcHMpIHtcbiAgY29uc3QgeyBjb2xsZWN0aW9uLCB2aWV3U3R5bGUsIGZpbHRlclRlcm0gfSA9IG93blByb3BzO1xuICBjb25zdCBwYWdlID0gc3RhdGUuZW50cmllcy5nZXRJbihbJ3BhZ2VzJywgY29sbGVjdGlvbi5nZXQoJ25hbWUnKSwgJ3BhZ2UnXSk7XG5cbiAgbGV0IGVudHJpZXMgPSBzZWxlY3RFbnRyaWVzKHN0YXRlLmVudHJpZXMsIGNvbGxlY3Rpb24pO1xuICBjb25zdCBncm91cHMgPSBzZWxlY3RHcm91cHMoc3RhdGUuZW50cmllcywgY29sbGVjdGlvbik7XG5cbiAgaWYgKGNvbGxlY3Rpb24uaGFzKCduZXN0ZWQnKSkge1xuICAgIGNvbnN0IGNvbGxlY3Rpb25Gb2xkZXIgPSBjb2xsZWN0aW9uLmdldCgnZm9sZGVyJyk7XG4gICAgZW50cmllcyA9IGZpbHRlck5lc3RlZEVudHJpZXMoZmlsdGVyVGVybSB8fCAnJywgY29sbGVjdGlvbkZvbGRlciwgZW50cmllcyk7XG4gIH1cbiAgY29uc3QgZW50cmllc0xvYWRlZCA9IHNlbGVjdEVudHJpZXNMb2FkZWQoc3RhdGUuZW50cmllcywgY29sbGVjdGlvbi5nZXQoJ25hbWUnKSk7XG4gIGNvbnN0IGlzRmV0Y2hpbmcgPSBzZWxlY3RJc0ZldGNoaW5nKHN0YXRlLmVudHJpZXMsIGNvbGxlY3Rpb24uZ2V0KCduYW1lJykpO1xuXG4gIGNvbnN0IHJhd0N1cnNvciA9IHNlbGVjdENvbGxlY3Rpb25FbnRyaWVzQ3Vyc29yKHN0YXRlLmN1cnNvcnMsIGNvbGxlY3Rpb24uZ2V0KCduYW1lJykpO1xuICBjb25zdCBjdXJzb3IgPSBDdXJzb3IuY3JlYXRlKHJhd0N1cnNvcikuY2xlYXJEYXRhKCk7XG5cbiAgcmV0dXJuIHsgY29sbGVjdGlvbiwgcGFnZSwgZW50cmllcywgZ3JvdXBzLCBlbnRyaWVzTG9hZGVkLCBpc0ZldGNoaW5nLCB2aWV3U3R5bGUsIGN1cnNvciB9O1xufVxuXG5jb25zdCBtYXBEaXNwYXRjaFRvUHJvcHMgPSB7XG4gIGxvYWRFbnRyaWVzOiBhY3Rpb25Mb2FkRW50cmllcyxcbiAgdHJhdmVyc2VDb2xsZWN0aW9uQ3Vyc29yOiBhY3Rpb25UcmF2ZXJzZUNvbGxlY3Rpb25DdXJzb3IsXG59O1xuXG5jb25zdCBDb25uZWN0ZWRFbnRyaWVzQ29sbGVjdGlvbiA9IGNvbm5lY3QobWFwU3RhdGVUb1Byb3BzLCBtYXBEaXNwYXRjaFRvUHJvcHMpKEVudHJpZXNDb2xsZWN0aW9uKTtcblxuZXhwb3J0IGRlZmF1bHQgdHJhbnNsYXRlKCkoQ29ubmVjdGVkRW50cmllc0NvbGxlY3Rpb24pO1xuIl19 */");
|
|
34
34
|
function getGroupEntries(entries, paths) {
|
|
35
35
|
return entries.filter(entry => paths.has(entry.get('path')));
|
|
36
36
|
}
|