@blaze-cms/plugin-data-ui 0.146.0-node18-core-styles-tooltips.56 → 0.146.0-node18-core-styles-tooltips.58
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/CHANGELOG.md +11 -0
- package/lib/components/ListingTable/ListingTableContent/ListingTableContent.js.map +1 -1
- package/lib/components/ListingTable/SearchFilter/SearchContainer.js.map +1 -1
- package/lib/components/Tabs/index.js +3 -4
- package/lib/components/Tabs/index.js.map +1 -1
- package/lib/utils/hoc/withContext.js.map +1 -1
- package/lib-es/components/ListingTable/ListingTableContent/ListingTableContent.js.map +1 -1
- package/lib-es/components/ListingTable/SearchFilter/SearchContainer.js.map +1 -1
- package/lib-es/components/Tabs/index.js +3 -5
- package/lib-es/components/Tabs/index.js.map +1 -1
- package/lib-es/utils/hoc/withContext.js +1 -1
- package/lib-es/utils/hoc/withContext.js.map +1 -1
- package/package.json +6 -6
- package/src/components/ListingTable/ListingTableContent/ListingTableContent.js +3 -3
- package/src/components/ListingTable/SearchFilter/SearchContainer.js +105 -120
- package/src/components/Tabs/index.js +2 -6
- package/src/utils/hoc/withContext.js +5 -4
package/CHANGELOG.md
CHANGED
|
@@ -3,6 +3,17 @@
|
|
|
3
3
|
All notable changes to this project will be documented in this file.
|
|
4
4
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
|
5
5
|
|
|
6
|
+
# [0.146.0-node18-core-styles-tooltips.58](https://github.com/thebyte9/blaze/compare/v0.146.0-node18-core-styles-tooltips.57...v0.146.0-node18-core-styles-tooltips.58) (2026-04-28)
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
### Bug Fixes
|
|
10
|
+
|
|
11
|
+
* fix lint and tests errors across repository ([#5047](https://github.com/thebyte9/blaze/issues/5047)) ([c2b86dd](https://github.com/thebyte9/blaze/commit/c2b86dd7aebb12198a49097692a549a9f9378d6e))
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
|
|
6
17
|
# [0.146.0-node18-core-styles-tooltips.56](https://github.com/thebyte9/blaze/compare/v0.146.0-node18-core-styles-tooltips.55...v0.146.0-node18-core-styles-tooltips.56) (2026-03-27)
|
|
7
18
|
|
|
8
19
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ListingTableContent.js","names":["_react","_interopRequireWildcard","require","_table","_interopRequireDefault","_pagination","_propTypes","_reactRouterDom","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ListingTableContent","_ref","tableData","handleSelect","onSort","handleOnPageChange","currentPage","totalItems","ref","useRef","displayTable","rows","length","isEnquiry","className","concat","useEffect","current","tableHeadCells","querySelectorAll","firstRowCells","forEach","element","styles","window","getComputedStyle","style","flex","createElement","data","onSelect","visiblePages","onPageChange","propTypes","PropTypes","object","isRequired","match","shape","url","string","func","number","defaultProps","_default","exports","withRouter"],"sources":["../../../../src/components/ListingTable/ListingTableContent/ListingTableContent.js"],"sourcesContent":["import React, { useEffect, useRef } from 'react';\nimport Table from '@blaze-react/table';\nimport Pagination from '@blaze-react/pagination';\nimport PropTypes from 'prop-types';\nimport { withRouter } from 'react-router-dom';\n\nconst ListingTableContent = ({\n tableData,\n handleSelect,\n onSort,\n handleOnPageChange,\n currentPage,\n totalItems\n}) => {\n const ref = useRef(null);\n const displayTable = tableData && tableData.rows && !!tableData.rows.length;\n const { isEnquiry } = tableData;\n const className = `page__content${isEnquiry ? ' array-table' : ''}`;\n\n useEffect(() => {\n // set table head to match body column widths to handle dynamic content\n if (ref.current && displayTable) {\n const tableHeadCells = ref.current.querySelectorAll('.table-head .table-cell');\n const firstRowCells = ref.current.querySelectorAll(\n '.table-body .table-row:first-child .table-cell'\n );\n\n firstRowCells.forEach((element, i) => {\n const styles = window.getComputedStyle(element);\n\n if (tableHeadCells[i]) {\n tableHeadCells[i].style.flex = styles.flex;\n tableHeadCells[i].style['justify-content'] = styles['justify-content'];\n }\n });\n }\n }, [tableData, displayTable]);\n\n if (displayTable) {\n return (\n <div ref={ref} className={className}>\n <Table\n onSort={onSort}\n data={tableData}\n onSelect={handleSelect}\n data-testid=\"listing-table-content\"\n />\n <Pagination\n visiblePages={10}\n totalItems={totalItems}\n currentPage={currentPage}\n onPageChange={handleOnPageChange}\n />\n </div>\n );\n }\n\n return (\n <span className=\"table-no-results\" data-testid=\"no-results\">\n No results\n </span>\n );\n};\n\nListingTableContent.propTypes = {\n tableData: PropTypes.object.isRequired,\n match: PropTypes.shape({\n url: PropTypes.string\n }).isRequired,\n handleSelect: PropTypes.func,\n onSort: PropTypes.func,\n handleOnPageChange: PropTypes.func,\n currentPage: PropTypes.number.isRequired,\n totalItems: PropTypes.number.isRequired\n};\n\nListingTableContent.defaultProps = {\n handleSelect: () => {
|
|
1
|
+
{"version":3,"file":"ListingTableContent.js","names":["_react","_interopRequireWildcard","require","_table","_interopRequireDefault","_pagination","_propTypes","_reactRouterDom","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ListingTableContent","_ref","tableData","handleSelect","onSort","handleOnPageChange","currentPage","totalItems","ref","useRef","displayTable","rows","length","isEnquiry","className","concat","useEffect","current","tableHeadCells","querySelectorAll","firstRowCells","forEach","element","styles","window","getComputedStyle","style","flex","createElement","data","onSelect","visiblePages","onPageChange","propTypes","PropTypes","object","isRequired","match","shape","url","string","func","number","defaultProps","_default","exports","withRouter"],"sources":["../../../../src/components/ListingTable/ListingTableContent/ListingTableContent.js"],"sourcesContent":["import React, { useEffect, useRef } from 'react';\nimport Table from '@blaze-react/table';\nimport Pagination from '@blaze-react/pagination';\nimport PropTypes from 'prop-types';\nimport { withRouter } from 'react-router-dom';\n\nconst ListingTableContent = ({\n tableData,\n handleSelect,\n onSort,\n handleOnPageChange,\n currentPage,\n totalItems\n}) => {\n const ref = useRef(null);\n const displayTable = tableData && tableData.rows && !!tableData.rows.length;\n const { isEnquiry } = tableData;\n const className = `page__content${isEnquiry ? ' array-table' : ''}`;\n\n useEffect(() => {\n // set table head to match body column widths to handle dynamic content\n if (ref.current && displayTable) {\n const tableHeadCells = ref.current.querySelectorAll('.table-head .table-cell');\n const firstRowCells = ref.current.querySelectorAll(\n '.table-body .table-row:first-child .table-cell'\n );\n\n firstRowCells.forEach((element, i) => {\n const styles = window.getComputedStyle(element);\n\n if (tableHeadCells[i]) {\n tableHeadCells[i].style.flex = styles.flex;\n tableHeadCells[i].style['justify-content'] = styles['justify-content'];\n }\n });\n }\n }, [tableData, displayTable]);\n\n if (displayTable) {\n return (\n <div ref={ref} className={className}>\n <Table\n onSort={onSort}\n data={tableData}\n onSelect={handleSelect}\n data-testid=\"listing-table-content\"\n />\n <Pagination\n visiblePages={10}\n totalItems={totalItems}\n currentPage={currentPage}\n onPageChange={handleOnPageChange}\n />\n </div>\n );\n }\n\n return (\n <span className=\"table-no-results\" data-testid=\"no-results\">\n No results\n </span>\n );\n};\n\nListingTableContent.propTypes = {\n tableData: PropTypes.object.isRequired,\n match: PropTypes.shape({\n url: PropTypes.string\n }).isRequired,\n handleSelect: PropTypes.func,\n onSort: PropTypes.func,\n handleOnPageChange: PropTypes.func,\n currentPage: PropTypes.number.isRequired,\n totalItems: PropTypes.number.isRequired\n};\n\nListingTableContent.defaultProps = {\n handleSelect: () => {},\n onSort: () => {},\n handleOnPageChange: () => {}\n};\n\nexport default withRouter(ListingTableContent);\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SearchContainer.js","names":["_react","_interopRequireWildcard","require","_propTypes","_interopRequireDefault","_select","_client","_adminUiUtils","_bs","_helpers","_querys","_constants","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ownKeys","keys","getOwnPropertySymbols","o","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","SearchContainer","_ref","setListFilters","_ref$keywordFiltersTo","keywordFiltersToUse","_ref$selectFiltersToD","selectFiltersToDisplay","schema","index","apolloClient","useApolloClient","_useState","useState","_useState2","_slicedToArray2","searchTerm","setSearchTerm","_useState3","_useState4","selectedFilters","setSelectedFilters","_useState5","_useState6","selectOptions","setSelectOptions","displaySearchFilter","displaySelectFilters","_useMemo","useMemo","labels","properties","_ref2","_ref3","property","label","keywordSearchProperties","keywordSearchLabels","_useMemo2","buildQueryFields","id","gqlFields","rawQuery","action","getDynamicQuery","NOOP_QUERY","_useQuery","useQuery","skip","variables","where","limit","fetchPolicy","data","filterData","_ref4","_ref4$searchResults","searchResults","_ref4$searchResults2","_ref4$searchResults2$","rawResults","_ref4$searchResults2$2","_ref4$searchResults2$3","aggregations","proccessedData","entries","_ref5","_ref6","key","buckets","Array","isArray","map","b","Boolean","useEffect","_asyncToGenerator2","_regenerator","mark","_callee2","results","wrap","_callee2$","_context2","prev","next","Promise","all","_ref9","_callee","_ref8","_ref10","ids","_ref11","_ref12","selectionDetails","query","_yield$apolloClient$q","_yield$apolloClient$q2","relationSchema","_yield$apolloClient$q3","_yield$apolloClient$q4","selected","_callee$","_context","abrupt","find","_ref13","_ref14","selectProperty","relation","options","value","getQuery","identifier","entityIdentifier","sent","getEntitySchemas","_in","sort","direction","console","error","result","item","name","t0","stop","_x","updateFilters","useCallback","term","filters","updateListFilters","handleSearch","handleSearchChange","target","handleEnterKey","ENTER_KEY","handleReset","reduce","acc","DEFAULT_FILTER_OPTION_LABEL","handleSelect","event","placeholderText","concat","join","createElement","className","type","placeholder","onChange","onKeyDown","role","onClick","BsSearch","_ref15","Fragment","defaultTextValue","BsArrowCounterclockwise","propTypes","PropTypes","func","isRequired","array","object","string","defaultProps","_default","exports"],"sources":["../../../../src/components/ListingTable/SearchFilter/SearchContainer.js"],"sourcesContent":["import React, { useState, useMemo, useEffect, useCallback } from 'react';\nimport PropTypes from 'prop-types';\nimport Select from '@blaze-react/select';\nimport { useQuery, useApolloClient } from '@apollo/client';\nimport { getDynamicQuery, getQuery } from '@blaze-cms/admin-ui-utils';\nimport { BsArrowCounterclockwise, BsSearch } from 'react-icons/bs';\nimport { updateListFilters, buildQueryFields } from './helpers';\nimport { NOOP_QUERY } from './querys';\nimport { ENTER_KEY, DEFAULT_FILTER_OPTION_LABEL } from '../../../constants';\n\nconst SearchContainer = ({\n setListFilters,\n keywordFiltersToUse = [],\n selectFiltersToDisplay = [],\n schema,\n index\n}) => {\n const apolloClient = useApolloClient();\n const [searchTerm, setSearchTerm] = useState('');\n const [selectedFilters, setSelectedFilters] = useState({});\n const [selectOptions, setSelectOptions] = useState([]);\n\n const displaySearchFilter = keywordFiltersToUse.length > 0;\n const displaySelectFilters = selectFiltersToDisplay.length > 0;\n\n const { keywordSearchProperties, keywordSearchLabels } = useMemo(\n () => {\n const labels = [];\n const properties = [];\n\n keywordFiltersToUse.forEach(([property, { label }]) => {\n if (label) labels.push(label);\n properties.push(property);\n });\n\n return { keywordSearchProperties: properties, keywordSearchLabels: labels };\n },\n [keywordFiltersToUse]\n );\n\n const { gqlFields, rawQuery } = useMemo(\n () => buildQueryFields(selectFiltersToDisplay, schema.id),\n [selectFiltersToDisplay, schema.id]\n );\n const action = displaySelectFilters\n ? getDynamicQuery('ADMIN_SEARCH')([schema], gqlFields, false, index)\n : NOOP_QUERY;\n\n const { data } = useQuery(action, {\n skip: !displaySelectFilters,\n variables: { where: rawQuery, limit: 0 },\n fetchPolicy: 'cache-and-network'\n });\n\n const filterData = useMemo(\n () => {\n const { searchResults: { rawResults: { aggregations = {} } = {} } = {} } = data || {};\n const proccessedData = [];\n Object.entries(aggregations).forEach(([key, { buckets }]) => {\n proccessedData.push(\n Array.isArray(buckets) ? [key, buckets.map(b => b.key).filter(Boolean)] : []\n );\n });\n\n return proccessedData;\n },\n [data]\n );\n\n useEffect(\n () => {\n if (!filterData.length) {\n setSelectOptions([]);\n return;\n }\n\n (async () => {\n const results = await Promise.all(\n filterData.map(async ([property, ids]) => {\n try {\n if (!ids || !ids.length) return {};\n\n const [, selectionDetails] =\n selectFiltersToDisplay.find(([selectProperty]) => selectProperty === property) ||\n [];\n\n if (!selectionDetails) return null;\n\n if (!selectionDetails.relation) {\n return {\n id: property,\n label: selectionDetails.label,\n options: ids.map(value => [value, value])\n };\n }\n const query = getQuery('GET_ENTITY_SCHEMA');\n const {\n data: {\n getEntitySchemas: [relationSchema]\n }\n } = await apolloClient.query({\n query,\n variables: { identifier: selectionDetails.relation.entityIdentifier }\n });\n\n const {\n data: { result: selected = [] }\n } = await apolloClient\n .query({\n query: getDynamicQuery('GET_ALL_ENTITIES')(relationSchema),\n variables: {\n where: {\n id: {\n _in: ids\n }\n },\n sort: [{ property: 'name', direction: 'asc' }]\n }\n })\n // eslint-disable-next-line no-console\n .catch(e => console.error(e));\n\n return {\n id: property,\n label: selectionDetails.label,\n options: selected.map(item => [item.id, item.name])\n };\n } catch {\n return null;\n }\n })\n );\n\n setSelectOptions(results.filter(Boolean));\n })();\n },\n [apolloClient, filterData, schema, selectFiltersToDisplay]\n );\n\n const updateFilters = useCallback(\n (term, filters) => updateListFilters(term, filters, setListFilters, keywordSearchProperties),\n [setListFilters, keywordSearchProperties]\n );\n\n const handleSearch = useCallback(() => updateFilters(searchTerm, selectedFilters), [\n searchTerm,\n selectedFilters,\n updateFilters\n ]);\n const handleSearchChange = useCallback(e => setSearchTerm(e.target.value), []);\n const handleEnterKey = useCallback(\n e => {\n if (e.key === ENTER_KEY) handleSearch();\n },\n [handleSearch]\n );\n const handleReset = useCallback(\n () => {\n setSearchTerm('');\n setSelectedFilters(\n Object.keys(selectedFilters).reduce(\n (acc, key) => ({ ...acc, [key]: DEFAULT_FILTER_OPTION_LABEL }),\n {}\n )\n );\n updateFilters('', {});\n },\n [selectedFilters, updateFilters]\n );\n const handleSelect = useCallback(\n (property, event) => {\n const { value } = event;\n const next = { ...selectedFilters, [property]: value };\n setSelectedFilters(next);\n updateFilters(searchTerm, next);\n },\n [searchTerm, selectedFilters, updateFilters]\n );\n\n const placeholderText = `Search ${keywordSearchLabels.join(', ')}`;\n\n return (\n <div className=\"search-container\">\n {displaySearchFilter && (\n <div className=\"search-container__search-input-container\">\n <input\n type=\"search\"\n className=\"search-container__search-input-container__search-input\"\n placeholder={placeholderText}\n value={searchTerm}\n onChange={handleSearchChange}\n onKeyDown={handleEnterKey}\n />\n <i role=\"button\" onClick={handleSearch}>\n <BsSearch />\n </i>\n </div>\n )}\n\n {displaySelectFilters &&\n selectOptions.map(({ id, options, label }) => (\n <>\n {options &&\n !!options.length && (\n <div className=\"search-container__select-wrapper\">\n <Select\n label={label}\n id={id}\n name={id}\n onChange={event => handleSelect(id, event)}\n options={options}\n value={selectedFilters[id]}\n defaultTextValue={DEFAULT_FILTER_OPTION_LABEL}\n />\n </div>\n )}\n </>\n ))}\n\n <div className=\"search-container__reset-button\">\n <span role=\"button\" onClick={handleReset}>\n <BsArrowCounterclockwise />\n </span>\n </div>\n </div>\n );\n};\n\nSearchContainer.propTypes = {\n setListFilters: PropTypes.func.isRequired,\n keywordFiltersToUse: PropTypes.array,\n selectFiltersToDisplay: PropTypes.array,\n schema: PropTypes.object.isRequired,\n index: PropTypes.string\n};\n\nSearchContainer.defaultProps = {\n keywordFiltersToUse: [],\n selectFiltersToDisplay: [],\n index: 'admin'\n};\n\nexport default SearchContainer;\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"SearchContainer.js","names":["_react","_interopRequireWildcard","require","_propTypes","_interopRequireDefault","_select","_client","_adminUiUtils","_bs","_helpers","_querys","_constants","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ownKeys","keys","getOwnPropertySymbols","o","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","SearchContainer","_ref","setListFilters","_ref$keywordFiltersTo","keywordFiltersToUse","_ref$selectFiltersToD","selectFiltersToDisplay","schema","index","apolloClient","useApolloClient","_useState","useState","_useState2","_slicedToArray2","searchTerm","setSearchTerm","_useState3","_useState4","selectedFilters","setSelectedFilters","_useState5","_useState6","selectOptions","setSelectOptions","displaySearchFilter","displaySelectFilters","_useMemo","useMemo","labels","properties","_ref2","_ref3","property","label","keywordSearchProperties","keywordSearchLabels","_useMemo2","buildQueryFields","id","gqlFields","rawQuery","action","getDynamicQuery","NOOP_QUERY","_useQuery","useQuery","skip","variables","where","limit","fetchPolicy","data","filterData","_ref4","_ref4$searchResults","searchResults","_ref4$searchResults2","_ref4$searchResults2$","rawResults","_ref4$searchResults2$2","_ref4$searchResults2$3","aggregations","proccessedData","entries","_ref5","_ref6","key","buckets","Array","isArray","map","b","Boolean","useEffect","_asyncToGenerator2","_regenerator","mark","_callee2","results","wrap","_callee2$","_context2","prev","next","Promise","all","_ref9","_callee","_ref8","_ref10","ids","_ref11","_ref12","selectionDetails","query","_yield$apolloClient$q","_yield$apolloClient$q2","relationSchema","_yield$apolloClient$q3","_yield$apolloClient$q4","selected","_callee$","_context","abrupt","find","_ref13","_ref14","selectProperty","relation","options","value","getQuery","identifier","entityIdentifier","sent","getEntitySchemas","_in","sort","direction","console","error","result","item","name","t0","stop","_x","updateFilters","useCallback","term","filters","updateListFilters","handleSearch","handleSearchChange","target","handleEnterKey","ENTER_KEY","handleReset","reduce","acc","DEFAULT_FILTER_OPTION_LABEL","handleSelect","event","placeholderText","concat","join","createElement","className","type","placeholder","onChange","onKeyDown","role","onClick","BsSearch","_ref15","Fragment","defaultTextValue","BsArrowCounterclockwise","propTypes","PropTypes","func","isRequired","array","object","string","defaultProps","_default","exports"],"sources":["../../../../src/components/ListingTable/SearchFilter/SearchContainer.js"],"sourcesContent":["import React, { useState, useMemo, useEffect, useCallback } from 'react';\nimport PropTypes from 'prop-types';\nimport Select from '@blaze-react/select';\nimport { useQuery, useApolloClient } from '@apollo/client';\nimport { getDynamicQuery, getQuery } from '@blaze-cms/admin-ui-utils';\nimport { BsArrowCounterclockwise, BsSearch } from 'react-icons/bs';\nimport { updateListFilters, buildQueryFields } from './helpers';\nimport { NOOP_QUERY } from './querys';\nimport { ENTER_KEY, DEFAULT_FILTER_OPTION_LABEL } from '../../../constants';\n\nconst SearchContainer = ({\n setListFilters,\n keywordFiltersToUse = [],\n selectFiltersToDisplay = [],\n schema,\n index\n}) => {\n const apolloClient = useApolloClient();\n const [searchTerm, setSearchTerm] = useState('');\n const [selectedFilters, setSelectedFilters] = useState({});\n const [selectOptions, setSelectOptions] = useState([]);\n\n const displaySearchFilter = keywordFiltersToUse.length > 0;\n const displaySelectFilters = selectFiltersToDisplay.length > 0;\n\n const { keywordSearchProperties, keywordSearchLabels } = useMemo(() => {\n const labels = [];\n const properties = [];\n\n keywordFiltersToUse.forEach(([property, { label }]) => {\n if (label) labels.push(label);\n properties.push(property);\n });\n\n return { keywordSearchProperties: properties, keywordSearchLabels: labels };\n }, [keywordFiltersToUse]);\n\n const { gqlFields, rawQuery } = useMemo(\n () => buildQueryFields(selectFiltersToDisplay, schema.id),\n [selectFiltersToDisplay, schema.id]\n );\n const action = displaySelectFilters\n ? getDynamicQuery('ADMIN_SEARCH')([schema], gqlFields, false, index)\n : NOOP_QUERY;\n\n const { data } = useQuery(action, {\n skip: !displaySelectFilters,\n variables: { where: rawQuery, limit: 0 },\n fetchPolicy: 'cache-and-network'\n });\n\n const filterData = useMemo(() => {\n const { searchResults: { rawResults: { aggregations = {} } = {} } = {} } = data || {};\n const proccessedData = [];\n Object.entries(aggregations).forEach(([key, { buckets }]) => {\n proccessedData.push(\n Array.isArray(buckets) ? [key, buckets.map(b => b.key).filter(Boolean)] : []\n );\n });\n\n return proccessedData;\n }, [data]);\n\n useEffect(() => {\n if (!filterData.length) {\n setSelectOptions([]);\n return;\n }\n\n (async () => {\n const results = await Promise.all(\n filterData.map(async ([property, ids]) => {\n try {\n if (!ids || !ids.length) return {};\n\n const [, selectionDetails] =\n selectFiltersToDisplay.find(([selectProperty]) => selectProperty === property) || [];\n\n if (!selectionDetails) return null;\n\n if (!selectionDetails.relation) {\n return {\n id: property,\n label: selectionDetails.label,\n options: ids.map(value => [value, value])\n };\n }\n const query = getQuery('GET_ENTITY_SCHEMA');\n const {\n data: {\n getEntitySchemas: [relationSchema]\n }\n } = await apolloClient.query({\n query,\n variables: { identifier: selectionDetails.relation.entityIdentifier }\n });\n\n const {\n data: { result: selected = [] }\n } = await apolloClient\n .query({\n query: getDynamicQuery('GET_ALL_ENTITIES')(relationSchema),\n variables: {\n where: {\n id: {\n _in: ids\n }\n },\n sort: [{ property: 'name', direction: 'asc' }]\n }\n })\n // eslint-disable-next-line no-console\n .catch(e => console.error(e));\n\n return {\n id: property,\n label: selectionDetails.label,\n options: selected.map(item => [item.id, item.name])\n };\n } catch {\n return null;\n }\n })\n );\n\n setSelectOptions(results.filter(Boolean));\n })();\n }, [apolloClient, filterData, schema, selectFiltersToDisplay]);\n\n const updateFilters = useCallback(\n (term, filters) => updateListFilters(term, filters, setListFilters, keywordSearchProperties),\n [setListFilters, keywordSearchProperties]\n );\n\n const handleSearch = useCallback(\n () => updateFilters(searchTerm, selectedFilters),\n [searchTerm, selectedFilters, updateFilters]\n );\n const handleSearchChange = useCallback(e => setSearchTerm(e.target.value), []);\n const handleEnterKey = useCallback(\n e => {\n if (e.key === ENTER_KEY) handleSearch();\n },\n [handleSearch]\n );\n const handleReset = useCallback(() => {\n setSearchTerm('');\n setSelectedFilters(\n Object.keys(selectedFilters).reduce(\n (acc, key) => ({ ...acc, [key]: DEFAULT_FILTER_OPTION_LABEL }),\n {}\n )\n );\n updateFilters('', {});\n }, [selectedFilters, updateFilters]);\n const handleSelect = useCallback(\n (property, event) => {\n const { value } = event;\n const next = { ...selectedFilters, [property]: value };\n setSelectedFilters(next);\n updateFilters(searchTerm, next);\n },\n [searchTerm, selectedFilters, updateFilters]\n );\n\n const placeholderText = `Search ${keywordSearchLabels.join(', ')}`;\n\n return (\n <div className=\"search-container\">\n {displaySearchFilter && (\n <div className=\"search-container__search-input-container\">\n <input\n type=\"search\"\n className=\"search-container__search-input-container__search-input\"\n placeholder={placeholderText}\n value={searchTerm}\n onChange={handleSearchChange}\n onKeyDown={handleEnterKey}\n />\n <i role=\"button\" onClick={handleSearch}>\n <BsSearch />\n </i>\n </div>\n )}\n\n {displaySelectFilters &&\n selectOptions.map(({ id, options, label }) => (\n <>\n {options && !!options.length && (\n <div className=\"search-container__select-wrapper\">\n <Select\n label={label}\n id={id}\n name={id}\n onChange={event => handleSelect(id, event)}\n options={options}\n value={selectedFilters[id]}\n defaultTextValue={DEFAULT_FILTER_OPTION_LABEL}\n />\n </div>\n )}\n </>\n ))}\n\n <div className=\"search-container__reset-button\">\n <span role=\"button\" onClick={handleReset}>\n <BsArrowCounterclockwise />\n </span>\n </div>\n </div>\n );\n};\n\nSearchContainer.propTypes = {\n setListFilters: PropTypes.func.isRequired,\n keywordFiltersToUse: PropTypes.array,\n selectFiltersToDisplay: PropTypes.array,\n schema: PropTypes.object.isRequired,\n index: PropTypes.string\n};\n\nSearchContainer.defaultProps = {\n keywordFiltersToUse: [],\n selectFiltersToDisplay: [],\n index: 'admin'\n};\n\nexport default SearchContainer;\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -25,10 +25,9 @@ var Tabs = function Tabs(_ref) {
|
|
|
25
25
|
var children = _ref.children,
|
|
26
26
|
onTabChange = _ref.onTabChange,
|
|
27
27
|
enabled = _ref.enabled;
|
|
28
|
-
var _ref2 = (0, _adminUiUtils.
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
currentTabId = _ref2.currentTabId;
|
|
28
|
+
var _ref2 = (0, _adminUiUtils.useTabsContext)() || {},
|
|
29
|
+
_ref2$currentTabId = _ref2.currentTabId,
|
|
30
|
+
currentTabId = _ref2$currentTabId === void 0 ? _constants.EDITOR_VIEW_TAB_INDEX : _ref2$currentTabId;
|
|
32
31
|
var _useState = (0, _react.useState)([]),
|
|
33
32
|
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
|
|
34
33
|
activeAccordions = _useState2[0],
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":["_react","_interopRequireWildcard","require","_propTypes","_interopRequireDefault","_tab","_adminUiUtils","_constants","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","Tabs","_ref","children","onTabChange","enabled","_ref2","
|
|
1
|
+
{"version":3,"file":"index.js","names":["_react","_interopRequireWildcard","require","_propTypes","_interopRequireDefault","_tab","_adminUiUtils","_constants","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","Tabs","_ref","children","onTabChange","enabled","_ref2","useTabsContext","_ref2$currentTabId","currentTabId","EDITOR_VIEW_TAB_INDEX","_useState","useState","_useState2","_slicedToArray2","activeAccordions","setActiveAccordions","createElement","TabsContextProvider","value","Tab","selected","TabItem","title","EDITOR_VIEW_TAB","action","PAGE_BUILDER_TAB","PAGE_BUILDER_TAB_INDEX","propTypes","PropTypes","oneOfType","object","arrayOf","isRequired","func","bool","_default","exports"],"sources":["../../../src/components/Tabs/index.js"],"sourcesContent":["import React, { useState } from 'react';\nimport PropTypes from 'prop-types';\nimport { Tab, TabItem } from '@blaze-react/tab';\nimport { useTabsContext, TabsContextProvider } from '@blaze-cms/admin-ui-utils';\nimport {\n PAGE_BUILDER_TAB,\n PAGE_BUILDER_TAB_INDEX,\n EDITOR_VIEW_TAB,\n EDITOR_VIEW_TAB_INDEX\n} from '../../constants';\n\nconst Tabs = ({ children, onTabChange, enabled }) => {\n const { currentTabId = EDITOR_VIEW_TAB_INDEX } = useTabsContext() || {};\n const [activeAccordions, setActiveAccordions] = useState([]);\n\n if (!enabled) return children;\n\n return (\n <TabsContextProvider value={{ currentTabId, activeAccordions, setActiveAccordions }}>\n <Tab selected={currentTabId}>\n <TabItem title={EDITOR_VIEW_TAB} action={() => onTabChange(EDITOR_VIEW_TAB_INDEX)}>\n {children}\n </TabItem>\n <TabItem title={PAGE_BUILDER_TAB} action={() => onTabChange(PAGE_BUILDER_TAB_INDEX)}>\n {children}\n </TabItem>\n </Tab>\n </TabsContextProvider>\n );\n};\n\nTabs.propTypes = {\n children: PropTypes.oneOfType([PropTypes.object, PropTypes.arrayOf(PropTypes.object)]).isRequired,\n onTabChange: PropTypes.func.isRequired,\n enabled: PropTypes.bool.isRequired\n};\n\nexport default Tabs;\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"withContext.js","names":["_react","_interopRequireDefault","require","_adminUiUtils","withContext","exports","Component","props","contexts","useMainContext","MainContext","createElement","_extends2"],"sources":["../../../src/utils/hoc/withContext.js"],"sourcesContent":["import React from 'react';\nimport { useMainContext, MainContext } from '@blaze-cms/admin-ui-utils';\n\nexport const withContext = Component
|
|
1
|
+
{"version":3,"file":"withContext.js","names":["_react","_interopRequireDefault","require","_adminUiUtils","withContext","exports","Component","props","contexts","useMainContext","MainContext","createElement","_extends2"],"sources":["../../../src/utils/hoc/withContext.js"],"sourcesContent":["import React from 'react';\nimport { useMainContext, MainContext } from '@blaze-cms/admin-ui-utils';\n\nexport const withContext = Component =>\n function (props) {\n const contexts = useMainContext(MainContext);\n return <Component {...props} {...contexts} />;\n };\n"],"mappings":";;;;;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,aAAA,GAAAD,OAAA;AAEO,IAAME,WAAW,GAAAC,OAAA,CAAAD,WAAA,GAAG,SAAdA,WAAWA,CAAGE,SAAS;EAAA,OAClC,UAAUC,KAAK,EAAE;IACf,IAAMC,QAAQ,GAAG,IAAAC,4BAAc,EAACC,yBAAW,CAAC;IAC5C,oBAAOV,MAAA,YAAAW,aAAA,CAACL,SAAS,MAAAM,SAAA,iBAAKL,KAAK,EAAMC,QAAQ,CAAG,CAAC;EAC/C,CAAC;AAAA","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ListingTableContent.js","names":["React","useEffect","useRef","Table","Pagination","PropTypes","withRouter","ListingTableContent","tableData","handleSelect","onSort","handleOnPageChange","currentPage","totalItems","ref","displayTable","rows","length","isEnquiry","className","current","tableHeadCells","querySelectorAll","firstRowCells","forEach","element","i","styles","window","getComputedStyle","style","flex","createElement","data","onSelect","visiblePages","onPageChange","propTypes","object","isRequired","match","shape","url","string","func","number","defaultProps"],"sources":["../../../../src/components/ListingTable/ListingTableContent/ListingTableContent.js"],"sourcesContent":["import React, { useEffect, useRef } from 'react';\nimport Table from '@blaze-react/table';\nimport Pagination from '@blaze-react/pagination';\nimport PropTypes from 'prop-types';\nimport { withRouter } from 'react-router-dom';\n\nconst ListingTableContent = ({\n tableData,\n handleSelect,\n onSort,\n handleOnPageChange,\n currentPage,\n totalItems\n}) => {\n const ref = useRef(null);\n const displayTable = tableData && tableData.rows && !!tableData.rows.length;\n const { isEnquiry } = tableData;\n const className = `page__content${isEnquiry ? ' array-table' : ''}`;\n\n useEffect(() => {\n // set table head to match body column widths to handle dynamic content\n if (ref.current && displayTable) {\n const tableHeadCells = ref.current.querySelectorAll('.table-head .table-cell');\n const firstRowCells = ref.current.querySelectorAll(\n '.table-body .table-row:first-child .table-cell'\n );\n\n firstRowCells.forEach((element, i) => {\n const styles = window.getComputedStyle(element);\n\n if (tableHeadCells[i]) {\n tableHeadCells[i].style.flex = styles.flex;\n tableHeadCells[i].style['justify-content'] = styles['justify-content'];\n }\n });\n }\n }, [tableData, displayTable]);\n\n if (displayTable) {\n return (\n <div ref={ref} className={className}>\n <Table\n onSort={onSort}\n data={tableData}\n onSelect={handleSelect}\n data-testid=\"listing-table-content\"\n />\n <Pagination\n visiblePages={10}\n totalItems={totalItems}\n currentPage={currentPage}\n onPageChange={handleOnPageChange}\n />\n </div>\n );\n }\n\n return (\n <span className=\"table-no-results\" data-testid=\"no-results\">\n No results\n </span>\n );\n};\n\nListingTableContent.propTypes = {\n tableData: PropTypes.object.isRequired,\n match: PropTypes.shape({\n url: PropTypes.string\n }).isRequired,\n handleSelect: PropTypes.func,\n onSort: PropTypes.func,\n handleOnPageChange: PropTypes.func,\n currentPage: PropTypes.number.isRequired,\n totalItems: PropTypes.number.isRequired\n};\n\nListingTableContent.defaultProps = {\n handleSelect: () => {
|
|
1
|
+
{"version":3,"file":"ListingTableContent.js","names":["React","useEffect","useRef","Table","Pagination","PropTypes","withRouter","ListingTableContent","tableData","handleSelect","onSort","handleOnPageChange","currentPage","totalItems","ref","displayTable","rows","length","isEnquiry","className","current","tableHeadCells","querySelectorAll","firstRowCells","forEach","element","i","styles","window","getComputedStyle","style","flex","createElement","data","onSelect","visiblePages","onPageChange","propTypes","object","isRequired","match","shape","url","string","func","number","defaultProps"],"sources":["../../../../src/components/ListingTable/ListingTableContent/ListingTableContent.js"],"sourcesContent":["import React, { useEffect, useRef } from 'react';\nimport Table from '@blaze-react/table';\nimport Pagination from '@blaze-react/pagination';\nimport PropTypes from 'prop-types';\nimport { withRouter } from 'react-router-dom';\n\nconst ListingTableContent = ({\n tableData,\n handleSelect,\n onSort,\n handleOnPageChange,\n currentPage,\n totalItems\n}) => {\n const ref = useRef(null);\n const displayTable = tableData && tableData.rows && !!tableData.rows.length;\n const { isEnquiry } = tableData;\n const className = `page__content${isEnquiry ? ' array-table' : ''}`;\n\n useEffect(() => {\n // set table head to match body column widths to handle dynamic content\n if (ref.current && displayTable) {\n const tableHeadCells = ref.current.querySelectorAll('.table-head .table-cell');\n const firstRowCells = ref.current.querySelectorAll(\n '.table-body .table-row:first-child .table-cell'\n );\n\n firstRowCells.forEach((element, i) => {\n const styles = window.getComputedStyle(element);\n\n if (tableHeadCells[i]) {\n tableHeadCells[i].style.flex = styles.flex;\n tableHeadCells[i].style['justify-content'] = styles['justify-content'];\n }\n });\n }\n }, [tableData, displayTable]);\n\n if (displayTable) {\n return (\n <div ref={ref} className={className}>\n <Table\n onSort={onSort}\n data={tableData}\n onSelect={handleSelect}\n data-testid=\"listing-table-content\"\n />\n <Pagination\n visiblePages={10}\n totalItems={totalItems}\n currentPage={currentPage}\n onPageChange={handleOnPageChange}\n />\n </div>\n );\n }\n\n return (\n <span className=\"table-no-results\" data-testid=\"no-results\">\n No results\n </span>\n );\n};\n\nListingTableContent.propTypes = {\n tableData: PropTypes.object.isRequired,\n match: PropTypes.shape({\n url: PropTypes.string\n }).isRequired,\n handleSelect: PropTypes.func,\n onSort: PropTypes.func,\n handleOnPageChange: PropTypes.func,\n currentPage: PropTypes.number.isRequired,\n totalItems: PropTypes.number.isRequired\n};\n\nListingTableContent.defaultProps = {\n handleSelect: () => {},\n onSort: () => {},\n handleOnPageChange: () => {}\n};\n\nexport default withRouter(ListingTableContent);\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SearchContainer.js","names":["React","useState","useMemo","useEffect","useCallback","PropTypes","Select","useQuery","useApolloClient","getDynamicQuery","getQuery","BsArrowCounterclockwise","BsSearch","updateListFilters","buildQueryFields","NOOP_QUERY","ENTER_KEY","DEFAULT_FILTER_OPTION_LABEL","SearchContainer","setListFilters","keywordFiltersToUse","selectFiltersToDisplay","schema","index","apolloClient","searchTerm","setSearchTerm","selectedFilters","setSelectedFilters","selectOptions","setSelectOptions","displaySearchFilter","length","displaySelectFilters","keywordSearchProperties","keywordSearchLabels","labels","properties","forEach","property","label","push","gqlFields","rawQuery","id","action","data","skip","variables","where","limit","fetchPolicy","filterData","searchResults","rawResults","aggregations","proccessedData","Object","entries","key","buckets","Array","isArray","map","b","filter","Boolean","results","Promise","all","ids","selectionDetails","find","selectProperty","relation","options","value","query","getEntitySchemas","relationSchema","identifier","entityIdentifier","result","selected","_in","sort","direction","catch","e","console","error","item","name","updateFilters","term","filters","handleSearch","handleSearchChange","target","handleEnterKey","handleReset","keys","reduce","acc","_objectSpread","handleSelect","event","next","placeholderText","join","createElement","className","type","placeholder","onChange","onKeyDown","role","onClick","Fragment","defaultTextValue","propTypes","func","isRequired","array","object","string","defaultProps"],"sources":["../../../../src/components/ListingTable/SearchFilter/SearchContainer.js"],"sourcesContent":["import React, { useState, useMemo, useEffect, useCallback } from 'react';\nimport PropTypes from 'prop-types';\nimport Select from '@blaze-react/select';\nimport { useQuery, useApolloClient } from '@apollo/client';\nimport { getDynamicQuery, getQuery } from '@blaze-cms/admin-ui-utils';\nimport { BsArrowCounterclockwise, BsSearch } from 'react-icons/bs';\nimport { updateListFilters, buildQueryFields } from './helpers';\nimport { NOOP_QUERY } from './querys';\nimport { ENTER_KEY, DEFAULT_FILTER_OPTION_LABEL } from '../../../constants';\n\nconst SearchContainer = ({\n setListFilters,\n keywordFiltersToUse = [],\n selectFiltersToDisplay = [],\n schema,\n index\n}) => {\n const apolloClient = useApolloClient();\n const [searchTerm, setSearchTerm] = useState('');\n const [selectedFilters, setSelectedFilters] = useState({});\n const [selectOptions, setSelectOptions] = useState([]);\n\n const displaySearchFilter = keywordFiltersToUse.length > 0;\n const displaySelectFilters = selectFiltersToDisplay.length > 0;\n\n const { keywordSearchProperties, keywordSearchLabels } = useMemo(\n () => {\n const labels = [];\n const properties = [];\n\n keywordFiltersToUse.forEach(([property, { label }]) => {\n if (label) labels.push(label);\n properties.push(property);\n });\n\n return { keywordSearchProperties: properties, keywordSearchLabels: labels };\n },\n [keywordFiltersToUse]\n );\n\n const { gqlFields, rawQuery } = useMemo(\n () => buildQueryFields(selectFiltersToDisplay, schema.id),\n [selectFiltersToDisplay, schema.id]\n );\n const action = displaySelectFilters\n ? getDynamicQuery('ADMIN_SEARCH')([schema], gqlFields, false, index)\n : NOOP_QUERY;\n\n const { data } = useQuery(action, {\n skip: !displaySelectFilters,\n variables: { where: rawQuery, limit: 0 },\n fetchPolicy: 'cache-and-network'\n });\n\n const filterData = useMemo(\n () => {\n const { searchResults: { rawResults: { aggregations = {} } = {} } = {} } = data || {};\n const proccessedData = [];\n Object.entries(aggregations).forEach(([key, { buckets }]) => {\n proccessedData.push(\n Array.isArray(buckets) ? [key, buckets.map(b => b.key).filter(Boolean)] : []\n );\n });\n\n return proccessedData;\n },\n [data]\n );\n\n useEffect(\n () => {\n if (!filterData.length) {\n setSelectOptions([]);\n return;\n }\n\n (async () => {\n const results = await Promise.all(\n filterData.map(async ([property, ids]) => {\n try {\n if (!ids || !ids.length) return {};\n\n const [, selectionDetails] =\n selectFiltersToDisplay.find(([selectProperty]) => selectProperty === property) ||\n [];\n\n if (!selectionDetails) return null;\n\n if (!selectionDetails.relation) {\n return {\n id: property,\n label: selectionDetails.label,\n options: ids.map(value => [value, value])\n };\n }\n const query = getQuery('GET_ENTITY_SCHEMA');\n const {\n data: {\n getEntitySchemas: [relationSchema]\n }\n } = await apolloClient.query({\n query,\n variables: { identifier: selectionDetails.relation.entityIdentifier }\n });\n\n const {\n data: { result: selected = [] }\n } = await apolloClient\n .query({\n query: getDynamicQuery('GET_ALL_ENTITIES')(relationSchema),\n variables: {\n where: {\n id: {\n _in: ids\n }\n },\n sort: [{ property: 'name', direction: 'asc' }]\n }\n })\n // eslint-disable-next-line no-console\n .catch(e => console.error(e));\n\n return {\n id: property,\n label: selectionDetails.label,\n options: selected.map(item => [item.id, item.name])\n };\n } catch {\n return null;\n }\n })\n );\n\n setSelectOptions(results.filter(Boolean));\n })();\n },\n [apolloClient, filterData, schema, selectFiltersToDisplay]\n );\n\n const updateFilters = useCallback(\n (term, filters) => updateListFilters(term, filters, setListFilters, keywordSearchProperties),\n [setListFilters, keywordSearchProperties]\n );\n\n const handleSearch = useCallback(() => updateFilters(searchTerm, selectedFilters), [\n searchTerm,\n selectedFilters,\n updateFilters\n ]);\n const handleSearchChange = useCallback(e => setSearchTerm(e.target.value), []);\n const handleEnterKey = useCallback(\n e => {\n if (e.key === ENTER_KEY) handleSearch();\n },\n [handleSearch]\n );\n const handleReset = useCallback(\n () => {\n setSearchTerm('');\n setSelectedFilters(\n Object.keys(selectedFilters).reduce(\n (acc, key) => ({ ...acc, [key]: DEFAULT_FILTER_OPTION_LABEL }),\n {}\n )\n );\n updateFilters('', {});\n },\n [selectedFilters, updateFilters]\n );\n const handleSelect = useCallback(\n (property, event) => {\n const { value } = event;\n const next = { ...selectedFilters, [property]: value };\n setSelectedFilters(next);\n updateFilters(searchTerm, next);\n },\n [searchTerm, selectedFilters, updateFilters]\n );\n\n const placeholderText = `Search ${keywordSearchLabels.join(', ')}`;\n\n return (\n <div className=\"search-container\">\n {displaySearchFilter && (\n <div className=\"search-container__search-input-container\">\n <input\n type=\"search\"\n className=\"search-container__search-input-container__search-input\"\n placeholder={placeholderText}\n value={searchTerm}\n onChange={handleSearchChange}\n onKeyDown={handleEnterKey}\n />\n <i role=\"button\" onClick={handleSearch}>\n <BsSearch />\n </i>\n </div>\n )}\n\n {displaySelectFilters &&\n selectOptions.map(({ id, options, label }) => (\n <>\n {options &&\n !!options.length && (\n <div className=\"search-container__select-wrapper\">\n <Select\n label={label}\n id={id}\n name={id}\n onChange={event => handleSelect(id, event)}\n options={options}\n value={selectedFilters[id]}\n defaultTextValue={DEFAULT_FILTER_OPTION_LABEL}\n />\n </div>\n )}\n </>\n ))}\n\n <div className=\"search-container__reset-button\">\n <span role=\"button\" onClick={handleReset}>\n <BsArrowCounterclockwise />\n </span>\n </div>\n </div>\n );\n};\n\nSearchContainer.propTypes = {\n setListFilters: PropTypes.func.isRequired,\n keywordFiltersToUse: PropTypes.array,\n selectFiltersToDisplay: PropTypes.array,\n schema: PropTypes.object.isRequired,\n index: PropTypes.string\n};\n\nSearchContainer.defaultProps = {\n keywordFiltersToUse: [],\n selectFiltersToDisplay: [],\n index: 'admin'\n};\n\nexport default SearchContainer;\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"SearchContainer.js","names":["React","useState","useMemo","useEffect","useCallback","PropTypes","Select","useQuery","useApolloClient","getDynamicQuery","getQuery","BsArrowCounterclockwise","BsSearch","updateListFilters","buildQueryFields","NOOP_QUERY","ENTER_KEY","DEFAULT_FILTER_OPTION_LABEL","SearchContainer","setListFilters","keywordFiltersToUse","selectFiltersToDisplay","schema","index","apolloClient","searchTerm","setSearchTerm","selectedFilters","setSelectedFilters","selectOptions","setSelectOptions","displaySearchFilter","length","displaySelectFilters","keywordSearchProperties","keywordSearchLabels","labels","properties","forEach","property","label","push","gqlFields","rawQuery","id","action","data","skip","variables","where","limit","fetchPolicy","filterData","searchResults","rawResults","aggregations","proccessedData","Object","entries","key","buckets","Array","isArray","map","b","filter","Boolean","results","Promise","all","ids","selectionDetails","find","selectProperty","relation","options","value","query","getEntitySchemas","relationSchema","identifier","entityIdentifier","result","selected","_in","sort","direction","catch","e","console","error","item","name","updateFilters","term","filters","handleSearch","handleSearchChange","target","handleEnterKey","handleReset","keys","reduce","acc","_objectSpread","handleSelect","event","next","placeholderText","join","createElement","className","type","placeholder","onChange","onKeyDown","role","onClick","Fragment","defaultTextValue","propTypes","func","isRequired","array","object","string","defaultProps"],"sources":["../../../../src/components/ListingTable/SearchFilter/SearchContainer.js"],"sourcesContent":["import React, { useState, useMemo, useEffect, useCallback } from 'react';\nimport PropTypes from 'prop-types';\nimport Select from '@blaze-react/select';\nimport { useQuery, useApolloClient } from '@apollo/client';\nimport { getDynamicQuery, getQuery } from '@blaze-cms/admin-ui-utils';\nimport { BsArrowCounterclockwise, BsSearch } from 'react-icons/bs';\nimport { updateListFilters, buildQueryFields } from './helpers';\nimport { NOOP_QUERY } from './querys';\nimport { ENTER_KEY, DEFAULT_FILTER_OPTION_LABEL } from '../../../constants';\n\nconst SearchContainer = ({\n setListFilters,\n keywordFiltersToUse = [],\n selectFiltersToDisplay = [],\n schema,\n index\n}) => {\n const apolloClient = useApolloClient();\n const [searchTerm, setSearchTerm] = useState('');\n const [selectedFilters, setSelectedFilters] = useState({});\n const [selectOptions, setSelectOptions] = useState([]);\n\n const displaySearchFilter = keywordFiltersToUse.length > 0;\n const displaySelectFilters = selectFiltersToDisplay.length > 0;\n\n const { keywordSearchProperties, keywordSearchLabels } = useMemo(() => {\n const labels = [];\n const properties = [];\n\n keywordFiltersToUse.forEach(([property, { label }]) => {\n if (label) labels.push(label);\n properties.push(property);\n });\n\n return { keywordSearchProperties: properties, keywordSearchLabels: labels };\n }, [keywordFiltersToUse]);\n\n const { gqlFields, rawQuery } = useMemo(\n () => buildQueryFields(selectFiltersToDisplay, schema.id),\n [selectFiltersToDisplay, schema.id]\n );\n const action = displaySelectFilters\n ? getDynamicQuery('ADMIN_SEARCH')([schema], gqlFields, false, index)\n : NOOP_QUERY;\n\n const { data } = useQuery(action, {\n skip: !displaySelectFilters,\n variables: { where: rawQuery, limit: 0 },\n fetchPolicy: 'cache-and-network'\n });\n\n const filterData = useMemo(() => {\n const { searchResults: { rawResults: { aggregations = {} } = {} } = {} } = data || {};\n const proccessedData = [];\n Object.entries(aggregations).forEach(([key, { buckets }]) => {\n proccessedData.push(\n Array.isArray(buckets) ? [key, buckets.map(b => b.key).filter(Boolean)] : []\n );\n });\n\n return proccessedData;\n }, [data]);\n\n useEffect(() => {\n if (!filterData.length) {\n setSelectOptions([]);\n return;\n }\n\n (async () => {\n const results = await Promise.all(\n filterData.map(async ([property, ids]) => {\n try {\n if (!ids || !ids.length) return {};\n\n const [, selectionDetails] =\n selectFiltersToDisplay.find(([selectProperty]) => selectProperty === property) || [];\n\n if (!selectionDetails) return null;\n\n if (!selectionDetails.relation) {\n return {\n id: property,\n label: selectionDetails.label,\n options: ids.map(value => [value, value])\n };\n }\n const query = getQuery('GET_ENTITY_SCHEMA');\n const {\n data: {\n getEntitySchemas: [relationSchema]\n }\n } = await apolloClient.query({\n query,\n variables: { identifier: selectionDetails.relation.entityIdentifier }\n });\n\n const {\n data: { result: selected = [] }\n } = await apolloClient\n .query({\n query: getDynamicQuery('GET_ALL_ENTITIES')(relationSchema),\n variables: {\n where: {\n id: {\n _in: ids\n }\n },\n sort: [{ property: 'name', direction: 'asc' }]\n }\n })\n // eslint-disable-next-line no-console\n .catch(e => console.error(e));\n\n return {\n id: property,\n label: selectionDetails.label,\n options: selected.map(item => [item.id, item.name])\n };\n } catch {\n return null;\n }\n })\n );\n\n setSelectOptions(results.filter(Boolean));\n })();\n }, [apolloClient, filterData, schema, selectFiltersToDisplay]);\n\n const updateFilters = useCallback(\n (term, filters) => updateListFilters(term, filters, setListFilters, keywordSearchProperties),\n [setListFilters, keywordSearchProperties]\n );\n\n const handleSearch = useCallback(\n () => updateFilters(searchTerm, selectedFilters),\n [searchTerm, selectedFilters, updateFilters]\n );\n const handleSearchChange = useCallback(e => setSearchTerm(e.target.value), []);\n const handleEnterKey = useCallback(\n e => {\n if (e.key === ENTER_KEY) handleSearch();\n },\n [handleSearch]\n );\n const handleReset = useCallback(() => {\n setSearchTerm('');\n setSelectedFilters(\n Object.keys(selectedFilters).reduce(\n (acc, key) => ({ ...acc, [key]: DEFAULT_FILTER_OPTION_LABEL }),\n {}\n )\n );\n updateFilters('', {});\n }, [selectedFilters, updateFilters]);\n const handleSelect = useCallback(\n (property, event) => {\n const { value } = event;\n const next = { ...selectedFilters, [property]: value };\n setSelectedFilters(next);\n updateFilters(searchTerm, next);\n },\n [searchTerm, selectedFilters, updateFilters]\n );\n\n const placeholderText = `Search ${keywordSearchLabels.join(', ')}`;\n\n return (\n <div className=\"search-container\">\n {displaySearchFilter && (\n <div className=\"search-container__search-input-container\">\n <input\n type=\"search\"\n className=\"search-container__search-input-container__search-input\"\n placeholder={placeholderText}\n value={searchTerm}\n onChange={handleSearchChange}\n onKeyDown={handleEnterKey}\n />\n <i role=\"button\" onClick={handleSearch}>\n <BsSearch />\n </i>\n </div>\n )}\n\n {displaySelectFilters &&\n selectOptions.map(({ id, options, label }) => (\n <>\n {options && !!options.length && (\n <div className=\"search-container__select-wrapper\">\n <Select\n label={label}\n id={id}\n name={id}\n onChange={event => handleSelect(id, event)}\n options={options}\n value={selectedFilters[id]}\n defaultTextValue={DEFAULT_FILTER_OPTION_LABEL}\n />\n </div>\n )}\n </>\n ))}\n\n <div className=\"search-container__reset-button\">\n <span role=\"button\" onClick={handleReset}>\n <BsArrowCounterclockwise />\n </span>\n </div>\n </div>\n );\n};\n\nSearchContainer.propTypes = {\n setListFilters: PropTypes.func.isRequired,\n keywordFiltersToUse: PropTypes.array,\n selectFiltersToDisplay: PropTypes.array,\n schema: PropTypes.object.isRequired,\n index: PropTypes.string\n};\n\nSearchContainer.defaultProps = {\n keywordFiltersToUse: [],\n selectFiltersToDisplay: [],\n index: 'admin'\n};\n\nexport default SearchContainer;\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import React, { useState } from 'react';
|
|
2
2
|
import PropTypes from 'prop-types';
|
|
3
3
|
import { Tab, TabItem } from '@blaze-react/tab';
|
|
4
|
-
import {
|
|
4
|
+
import { useTabsContext, TabsContextProvider } from '@blaze-cms/admin-ui-utils';
|
|
5
5
|
import { PAGE_BUILDER_TAB, PAGE_BUILDER_TAB_INDEX, EDITOR_VIEW_TAB, EDITOR_VIEW_TAB_INDEX } from '../../constants';
|
|
6
6
|
const Tabs = ({
|
|
7
7
|
children,
|
|
@@ -9,10 +9,8 @@ const Tabs = ({
|
|
|
9
9
|
enabled
|
|
10
10
|
}) => {
|
|
11
11
|
const {
|
|
12
|
-
currentTabId
|
|
13
|
-
} =
|
|
14
|
-
query: GET_CURRENT_TAB_ID
|
|
15
|
-
}) || EDITOR_VIEW_TAB_INDEX;
|
|
12
|
+
currentTabId = EDITOR_VIEW_TAB_INDEX
|
|
13
|
+
} = useTabsContext() || {};
|
|
16
14
|
const [activeAccordions, setActiveAccordions] = useState([]);
|
|
17
15
|
if (!enabled) return children;
|
|
18
16
|
return /*#__PURE__*/React.createElement(TabsContextProvider, {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":["React","useState","PropTypes","Tab","TabItem","
|
|
1
|
+
{"version":3,"file":"index.js","names":["React","useState","PropTypes","Tab","TabItem","useTabsContext","TabsContextProvider","PAGE_BUILDER_TAB","PAGE_BUILDER_TAB_INDEX","EDITOR_VIEW_TAB","EDITOR_VIEW_TAB_INDEX","Tabs","children","onTabChange","enabled","currentTabId","activeAccordions","setActiveAccordions","createElement","value","selected","title","action","propTypes","oneOfType","object","arrayOf","isRequired","func","bool"],"sources":["../../../src/components/Tabs/index.js"],"sourcesContent":["import React, { useState } from 'react';\nimport PropTypes from 'prop-types';\nimport { Tab, TabItem } from '@blaze-react/tab';\nimport { useTabsContext, TabsContextProvider } from '@blaze-cms/admin-ui-utils';\nimport {\n PAGE_BUILDER_TAB,\n PAGE_BUILDER_TAB_INDEX,\n EDITOR_VIEW_TAB,\n EDITOR_VIEW_TAB_INDEX\n} from '../../constants';\n\nconst Tabs = ({ children, onTabChange, enabled }) => {\n const { currentTabId = EDITOR_VIEW_TAB_INDEX } = useTabsContext() || {};\n const [activeAccordions, setActiveAccordions] = useState([]);\n\n if (!enabled) return children;\n\n return (\n <TabsContextProvider value={{ currentTabId, activeAccordions, setActiveAccordions }}>\n <Tab selected={currentTabId}>\n <TabItem title={EDITOR_VIEW_TAB} action={() => onTabChange(EDITOR_VIEW_TAB_INDEX)}>\n {children}\n </TabItem>\n <TabItem title={PAGE_BUILDER_TAB} action={() => onTabChange(PAGE_BUILDER_TAB_INDEX)}>\n {children}\n </TabItem>\n </Tab>\n </TabsContextProvider>\n );\n};\n\nTabs.propTypes = {\n children: PropTypes.oneOfType([PropTypes.object, PropTypes.arrayOf(PropTypes.object)]).isRequired,\n onTabChange: PropTypes.func.isRequired,\n enabled: PropTypes.bool.isRequired\n};\n\nexport default Tabs;\n"],"mappings":"AAAA,OAAOA,KAAK,IAAIC,QAAQ,QAAQ,OAAO;AACvC,OAAOC,SAAS,MAAM,YAAY;AAClC,SAASC,GAAG,EAAEC,OAAO,QAAQ,kBAAkB;AAC/C,SAASC,cAAc,EAAEC,mBAAmB,QAAQ,2BAA2B;AAC/E,SACEC,gBAAgB,EAChBC,sBAAsB,EACtBC,eAAe,EACfC,qBAAqB,QAChB,iBAAiB;AAExB,MAAMC,IAAI,GAAGA,CAAC;EAAEC,QAAQ;EAAEC,WAAW;EAAEC;AAAQ,CAAC,KAAK;EACnD,MAAM;IAAEC,YAAY,GAAGL;EAAsB,CAAC,GAAGL,cAAc,CAAC,CAAC,IAAI,CAAC,CAAC;EACvE,MAAM,CAACW,gBAAgB,EAAEC,mBAAmB,CAAC,GAAGhB,QAAQ,CAAC,EAAE,CAAC;EAE5D,IAAI,CAACa,OAAO,EAAE,OAAOF,QAAQ;EAE7B,oBACEZ,KAAA,CAAAkB,aAAA,CAACZ,mBAAmB;IAACa,KAAK,EAAE;MAAEJ,YAAY;MAAEC,gBAAgB;MAAEC;IAAoB;EAAE,gBAClFjB,KAAA,CAAAkB,aAAA,CAACf,GAAG;IAACiB,QAAQ,EAAEL;EAAa,gBAC1Bf,KAAA,CAAAkB,aAAA,CAACd,OAAO;IAACiB,KAAK,EAAEZ,eAAgB;IAACa,MAAM,EAAEA,CAAA,KAAMT,WAAW,CAACH,qBAAqB;EAAE,GAC/EE,QACM,CAAC,eACVZ,KAAA,CAAAkB,aAAA,CAACd,OAAO;IAACiB,KAAK,EAAEd,gBAAiB;IAACe,MAAM,EAAEA,CAAA,KAAMT,WAAW,CAACL,sBAAsB;EAAE,GACjFI,QACM,CACN,CACc,CAAC;AAE1B,CAAC;AAEDD,IAAI,CAACY,SAAS,GAAG;EACfX,QAAQ,EAAEV,SAAS,CAACsB,SAAS,CAAC,CAACtB,SAAS,CAACuB,MAAM,EAAEvB,SAAS,CAACwB,OAAO,CAACxB,SAAS,CAACuB,MAAM,CAAC,CAAC,CAAC,CAACE,UAAU;EACjGd,WAAW,EAAEX,SAAS,CAAC0B,IAAI,CAACD,UAAU;EACtCb,OAAO,EAAEZ,SAAS,CAAC2B,IAAI,CAACF;AAC1B,CAAC;AAED,eAAehB,IAAI","ignoreList":[]}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import _extends from "@babel/runtime/helpers/extends";
|
|
2
2
|
import React from 'react';
|
|
3
3
|
import { useMainContext, MainContext } from '@blaze-cms/admin-ui-utils';
|
|
4
|
-
export const withContext = Component => props
|
|
4
|
+
export const withContext = Component => function (props) {
|
|
5
5
|
const contexts = useMainContext(MainContext);
|
|
6
6
|
return /*#__PURE__*/React.createElement(Component, _extends({}, props, contexts));
|
|
7
7
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"withContext.js","names":["React","useMainContext","MainContext","withContext","Component","props","contexts","createElement","_extends"],"sources":["../../../src/utils/hoc/withContext.js"],"sourcesContent":["import React from 'react';\nimport { useMainContext, MainContext } from '@blaze-cms/admin-ui-utils';\n\nexport const withContext = Component
|
|
1
|
+
{"version":3,"file":"withContext.js","names":["React","useMainContext","MainContext","withContext","Component","props","contexts","createElement","_extends"],"sources":["../../../src/utils/hoc/withContext.js"],"sourcesContent":["import React from 'react';\nimport { useMainContext, MainContext } from '@blaze-cms/admin-ui-utils';\n\nexport const withContext = Component =>\n function (props) {\n const contexts = useMainContext(MainContext);\n return <Component {...props} {...contexts} />;\n };\n"],"mappings":";AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,cAAc,EAAEC,WAAW,QAAQ,2BAA2B;AAEvE,OAAO,MAAMC,WAAW,GAAGC,SAAS,IAClC,UAAUC,KAAK,EAAE;EACf,MAAMC,QAAQ,GAAGL,cAAc,CAACC,WAAW,CAAC;EAC5C,oBAAOF,KAAA,CAAAO,aAAA,CAACH,SAAS,EAAAI,QAAA,KAAKH,KAAK,EAAMC,QAAQ,CAAG,CAAC;AAC/C,CAAC","ignoreList":[]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@blaze-cms/plugin-data-ui",
|
|
3
|
-
"version": "0.146.0-node18-core-styles-tooltips.
|
|
3
|
+
"version": "0.146.0-node18-core-styles-tooltips.58",
|
|
4
4
|
"description": "Blaze plugin data ui",
|
|
5
5
|
"main": "lib/index.js",
|
|
6
6
|
"module": "lib-es/index.js",
|
|
@@ -27,11 +27,11 @@
|
|
|
27
27
|
},
|
|
28
28
|
"license": "GPL-3.0",
|
|
29
29
|
"dependencies": {
|
|
30
|
-
"@blaze-cms/admin-ui-utils": "0.146.0-node18-core-styles-tooltips.
|
|
30
|
+
"@blaze-cms/admin-ui-utils": "0.146.0-node18-core-styles-tooltips.58",
|
|
31
31
|
"@blaze-cms/core-errors": "0.146.0-node18-core-styles-tooltips.46",
|
|
32
32
|
"@blaze-cms/plugin-render-hooks-ui": "0.146.0-node18-core-styles-tooltips.46",
|
|
33
|
-
"@blaze-cms/react-form-builder": "0.146.0-node18-core-styles-tooltips.
|
|
34
|
-
"@blaze-cms/react-page-builder": "0.146.0-node18-core-styles-tooltips.
|
|
33
|
+
"@blaze-cms/react-form-builder": "0.146.0-node18-core-styles-tooltips.58",
|
|
34
|
+
"@blaze-cms/react-page-builder": "0.146.0-node18-core-styles-tooltips.58",
|
|
35
35
|
"@blaze-cms/setup-ui": "0.146.0-node18-core-styles-tooltips.46",
|
|
36
36
|
"@blaze-cms/versioning-ui": "0.146.0-node18-core-styles-tooltips.46",
|
|
37
37
|
"@blaze-react/button": "0.8.0-alpha.82",
|
|
@@ -57,7 +57,7 @@
|
|
|
57
57
|
"uuid": "^3.3.3"
|
|
58
58
|
},
|
|
59
59
|
"devDependencies": {
|
|
60
|
-
"@blaze-cms/core-ui": "0.146.0-node18-core-styles-tooltips.
|
|
60
|
+
"@blaze-cms/core-ui": "0.146.0-node18-core-styles-tooltips.58"
|
|
61
61
|
},
|
|
62
62
|
"peerDependencies": {
|
|
63
63
|
"@apollo/client": "3.x",
|
|
@@ -69,5 +69,5 @@
|
|
|
69
69
|
"lib/*",
|
|
70
70
|
"lib-es/*"
|
|
71
71
|
],
|
|
72
|
-
"gitHead": "
|
|
72
|
+
"gitHead": "f7a6d4bdce550c1edced07053c611a4e5aa28d8b"
|
|
73
73
|
}
|
|
@@ -75,9 +75,9 @@ ListingTableContent.propTypes = {
|
|
|
75
75
|
};
|
|
76
76
|
|
|
77
77
|
ListingTableContent.defaultProps = {
|
|
78
|
-
handleSelect: () => {
|
|
79
|
-
onSort: () => {
|
|
80
|
-
handleOnPageChange: () => {
|
|
78
|
+
handleSelect: () => {},
|
|
79
|
+
onSort: () => {},
|
|
80
|
+
handleOnPageChange: () => {}
|
|
81
81
|
};
|
|
82
82
|
|
|
83
83
|
export default withRouter(ListingTableContent);
|
|
@@ -23,20 +23,17 @@ const SearchContainer = ({
|
|
|
23
23
|
const displaySearchFilter = keywordFiltersToUse.length > 0;
|
|
24
24
|
const displaySelectFilters = selectFiltersToDisplay.length > 0;
|
|
25
25
|
|
|
26
|
-
const { keywordSearchProperties, keywordSearchLabels } = useMemo(
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
const properties = [];
|
|
26
|
+
const { keywordSearchProperties, keywordSearchLabels } = useMemo(() => {
|
|
27
|
+
const labels = [];
|
|
28
|
+
const properties = [];
|
|
30
29
|
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
30
|
+
keywordFiltersToUse.forEach(([property, { label }]) => {
|
|
31
|
+
if (label) labels.push(label);
|
|
32
|
+
properties.push(property);
|
|
33
|
+
});
|
|
35
34
|
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
[keywordFiltersToUse]
|
|
39
|
-
);
|
|
35
|
+
return { keywordSearchProperties: properties, keywordSearchLabels: labels };
|
|
36
|
+
}, [keywordFiltersToUse]);
|
|
40
37
|
|
|
41
38
|
const { gqlFields, rawQuery } = useMemo(
|
|
42
39
|
() => buildQueryFields(selectFiltersToDisplay, schema.id),
|
|
@@ -52,101 +49,93 @@ const SearchContainer = ({
|
|
|
52
49
|
fetchPolicy: 'cache-and-network'
|
|
53
50
|
});
|
|
54
51
|
|
|
55
|
-
const filterData = useMemo(
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
});
|
|
64
|
-
|
|
65
|
-
return proccessedData;
|
|
66
|
-
},
|
|
67
|
-
[data]
|
|
68
|
-
);
|
|
52
|
+
const filterData = useMemo(() => {
|
|
53
|
+
const { searchResults: { rawResults: { aggregations = {} } = {} } = {} } = data || {};
|
|
54
|
+
const proccessedData = [];
|
|
55
|
+
Object.entries(aggregations).forEach(([key, { buckets }]) => {
|
|
56
|
+
proccessedData.push(
|
|
57
|
+
Array.isArray(buckets) ? [key, buckets.map(b => b.key).filter(Boolean)] : []
|
|
58
|
+
);
|
|
59
|
+
});
|
|
69
60
|
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
if (!selectionDetails.relation) {
|
|
90
|
-
return {
|
|
91
|
-
id: property,
|
|
92
|
-
label: selectionDetails.label,
|
|
93
|
-
options: ids.map(value => [value, value])
|
|
94
|
-
};
|
|
95
|
-
}
|
|
96
|
-
const query = getQuery('GET_ENTITY_SCHEMA');
|
|
97
|
-
const {
|
|
98
|
-
data: {
|
|
99
|
-
getEntitySchemas: [relationSchema]
|
|
100
|
-
}
|
|
101
|
-
} = await apolloClient.query({
|
|
102
|
-
query,
|
|
103
|
-
variables: { identifier: selectionDetails.relation.entityIdentifier }
|
|
104
|
-
});
|
|
105
|
-
|
|
106
|
-
const {
|
|
107
|
-
data: { result: selected = [] }
|
|
108
|
-
} = await apolloClient
|
|
109
|
-
.query({
|
|
110
|
-
query: getDynamicQuery('GET_ALL_ENTITIES')(relationSchema),
|
|
111
|
-
variables: {
|
|
112
|
-
where: {
|
|
113
|
-
id: {
|
|
114
|
-
_in: ids
|
|
115
|
-
}
|
|
116
|
-
},
|
|
117
|
-
sort: [{ property: 'name', direction: 'asc' }]
|
|
118
|
-
}
|
|
119
|
-
})
|
|
120
|
-
// eslint-disable-next-line no-console
|
|
121
|
-
.catch(e => console.error(e));
|
|
61
|
+
return proccessedData;
|
|
62
|
+
}, [data]);
|
|
63
|
+
|
|
64
|
+
useEffect(() => {
|
|
65
|
+
if (!filterData.length) {
|
|
66
|
+
setSelectOptions([]);
|
|
67
|
+
return;
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
(async () => {
|
|
71
|
+
const results = await Promise.all(
|
|
72
|
+
filterData.map(async ([property, ids]) => {
|
|
73
|
+
try {
|
|
74
|
+
if (!ids || !ids.length) return {};
|
|
75
|
+
|
|
76
|
+
const [, selectionDetails] =
|
|
77
|
+
selectFiltersToDisplay.find(([selectProperty]) => selectProperty === property) || [];
|
|
78
|
+
|
|
79
|
+
if (!selectionDetails) return null;
|
|
122
80
|
|
|
81
|
+
if (!selectionDetails.relation) {
|
|
123
82
|
return {
|
|
124
83
|
id: property,
|
|
125
84
|
label: selectionDetails.label,
|
|
126
|
-
options:
|
|
85
|
+
options: ids.map(value => [value, value])
|
|
127
86
|
};
|
|
128
|
-
} catch {
|
|
129
|
-
return null;
|
|
130
87
|
}
|
|
131
|
-
|
|
132
|
-
|
|
88
|
+
const query = getQuery('GET_ENTITY_SCHEMA');
|
|
89
|
+
const {
|
|
90
|
+
data: {
|
|
91
|
+
getEntitySchemas: [relationSchema]
|
|
92
|
+
}
|
|
93
|
+
} = await apolloClient.query({
|
|
94
|
+
query,
|
|
95
|
+
variables: { identifier: selectionDetails.relation.entityIdentifier }
|
|
96
|
+
});
|
|
97
|
+
|
|
98
|
+
const {
|
|
99
|
+
data: { result: selected = [] }
|
|
100
|
+
} = await apolloClient
|
|
101
|
+
.query({
|
|
102
|
+
query: getDynamicQuery('GET_ALL_ENTITIES')(relationSchema),
|
|
103
|
+
variables: {
|
|
104
|
+
where: {
|
|
105
|
+
id: {
|
|
106
|
+
_in: ids
|
|
107
|
+
}
|
|
108
|
+
},
|
|
109
|
+
sort: [{ property: 'name', direction: 'asc' }]
|
|
110
|
+
}
|
|
111
|
+
})
|
|
112
|
+
// eslint-disable-next-line no-console
|
|
113
|
+
.catch(e => console.error(e));
|
|
114
|
+
|
|
115
|
+
return {
|
|
116
|
+
id: property,
|
|
117
|
+
label: selectionDetails.label,
|
|
118
|
+
options: selected.map(item => [item.id, item.name])
|
|
119
|
+
};
|
|
120
|
+
} catch {
|
|
121
|
+
return null;
|
|
122
|
+
}
|
|
123
|
+
})
|
|
124
|
+
);
|
|
133
125
|
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
[apolloClient, filterData, schema, selectFiltersToDisplay]
|
|
138
|
-
);
|
|
126
|
+
setSelectOptions(results.filter(Boolean));
|
|
127
|
+
})();
|
|
128
|
+
}, [apolloClient, filterData, schema, selectFiltersToDisplay]);
|
|
139
129
|
|
|
140
130
|
const updateFilters = useCallback(
|
|
141
131
|
(term, filters) => updateListFilters(term, filters, setListFilters, keywordSearchProperties),
|
|
142
132
|
[setListFilters, keywordSearchProperties]
|
|
143
133
|
);
|
|
144
134
|
|
|
145
|
-
const handleSearch = useCallback(
|
|
146
|
-
searchTerm,
|
|
147
|
-
selectedFilters,
|
|
148
|
-
|
|
149
|
-
]);
|
|
135
|
+
const handleSearch = useCallback(
|
|
136
|
+
() => updateFilters(searchTerm, selectedFilters),
|
|
137
|
+
[searchTerm, selectedFilters, updateFilters]
|
|
138
|
+
);
|
|
150
139
|
const handleSearchChange = useCallback(e => setSearchTerm(e.target.value), []);
|
|
151
140
|
const handleEnterKey = useCallback(
|
|
152
141
|
e => {
|
|
@@ -154,19 +143,16 @@ const SearchContainer = ({
|
|
|
154
143
|
},
|
|
155
144
|
[handleSearch]
|
|
156
145
|
);
|
|
157
|
-
const handleReset = useCallback(
|
|
158
|
-
()
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
},
|
|
168
|
-
[selectedFilters, updateFilters]
|
|
169
|
-
);
|
|
146
|
+
const handleReset = useCallback(() => {
|
|
147
|
+
setSearchTerm('');
|
|
148
|
+
setSelectedFilters(
|
|
149
|
+
Object.keys(selectedFilters).reduce(
|
|
150
|
+
(acc, key) => ({ ...acc, [key]: DEFAULT_FILTER_OPTION_LABEL }),
|
|
151
|
+
{}
|
|
152
|
+
)
|
|
153
|
+
);
|
|
154
|
+
updateFilters('', {});
|
|
155
|
+
}, [selectedFilters, updateFilters]);
|
|
170
156
|
const handleSelect = useCallback(
|
|
171
157
|
(property, event) => {
|
|
172
158
|
const { value } = event;
|
|
@@ -200,20 +186,19 @@ const SearchContainer = ({
|
|
|
200
186
|
{displaySelectFilters &&
|
|
201
187
|
selectOptions.map(({ id, options, label }) => (
|
|
202
188
|
<>
|
|
203
|
-
{options &&
|
|
204
|
-
|
|
205
|
-
<
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
)}
|
|
189
|
+
{options && !!options.length && (
|
|
190
|
+
<div className="search-container__select-wrapper">
|
|
191
|
+
<Select
|
|
192
|
+
label={label}
|
|
193
|
+
id={id}
|
|
194
|
+
name={id}
|
|
195
|
+
onChange={event => handleSelect(id, event)}
|
|
196
|
+
options={options}
|
|
197
|
+
value={selectedFilters[id]}
|
|
198
|
+
defaultTextValue={DEFAULT_FILTER_OPTION_LABEL}
|
|
199
|
+
/>
|
|
200
|
+
</div>
|
|
201
|
+
)}
|
|
217
202
|
</>
|
|
218
203
|
))}
|
|
219
204
|
|
|
@@ -1,11 +1,7 @@
|
|
|
1
1
|
import React, { useState } from 'react';
|
|
2
2
|
import PropTypes from 'prop-types';
|
|
3
3
|
import { Tab, TabItem } from '@blaze-react/tab';
|
|
4
|
-
import {
|
|
5
|
-
useReadFromCache,
|
|
6
|
-
GET_CURRENT_TAB_ID,
|
|
7
|
-
TabsContextProvider
|
|
8
|
-
} from '@blaze-cms/admin-ui-utils';
|
|
4
|
+
import { useTabsContext, TabsContextProvider } from '@blaze-cms/admin-ui-utils';
|
|
9
5
|
import {
|
|
10
6
|
PAGE_BUILDER_TAB,
|
|
11
7
|
PAGE_BUILDER_TAB_INDEX,
|
|
@@ -14,7 +10,7 @@ import {
|
|
|
14
10
|
} from '../../constants';
|
|
15
11
|
|
|
16
12
|
const Tabs = ({ children, onTabChange, enabled }) => {
|
|
17
|
-
const { currentTabId } =
|
|
13
|
+
const { currentTabId = EDITOR_VIEW_TAB_INDEX } = useTabsContext() || {};
|
|
18
14
|
const [activeAccordions, setActiveAccordions] = useState([]);
|
|
19
15
|
|
|
20
16
|
if (!enabled) return children;
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
import { useMainContext, MainContext } from '@blaze-cms/admin-ui-utils';
|
|
3
3
|
|
|
4
|
-
export const withContext = Component =>
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
}
|
|
4
|
+
export const withContext = Component =>
|
|
5
|
+
function (props) {
|
|
6
|
+
const contexts = useMainContext(MainContext);
|
|
7
|
+
return <Component {...props} {...contexts} />;
|
|
8
|
+
};
|