mirror of
https://github.com/open-metadata/OpenMetadata.git
synced 2025-10-23 23:04:23 +00:00
* improvement in advance search based on custom property * fix a reading undefined property issue * wip: advance search based on tier * some code cleanup and improvement * some fixes * fix: ui flicker when advanceSearched is apply and refresh the page * some cleanup * no need to call customproperty api call, if entity not suppport customProperties * minor change * fix: autocomplete not working in tier search option in advance search modal * added unit test for advance search provider component * some cleanup * added testcase for open modal * added testcase for resetAllFilters method * removed unwanted code * added e2e test for testing tier advance search * fix: e2e search flow for single field * fix: string field not working after giving listValues in TierSearch * fix: group query e2e test fix * used asyncFetch way to get the tierOptions synchronously * some cleanup * remove unwanted lines * some cleanup * fix: selected option show option value instead of option title
This commit is contained in:
parent
740541c0c7
commit
9c92beaecd
@ -138,16 +138,15 @@ export const FIELDS = {
|
|||||||
searchCriteriaSecondGroup: 'PersonalData.SpecialCategory',
|
searchCriteriaSecondGroup: 'PersonalData.SpecialCategory',
|
||||||
responseValueSecondGroup: '"tagFQN":"PersonalData.SpecialCategory"',
|
responseValueSecondGroup: '"tagFQN":"PersonalData.SpecialCategory"',
|
||||||
},
|
},
|
||||||
// skipping tier for now, as it is not working, BE need to fix it
|
Tiers: {
|
||||||
|
name: 'Tier',
|
||||||
// Tiers: {
|
testid: '[title="Tier"]',
|
||||||
// name: 'Tier',
|
searchCriteriaFirstGroup: 'Tier.Tier1',
|
||||||
// testid: '[title="Tier"]',
|
responseValueFirstGroup: '"tagFQN":"Tier.Tier1"',
|
||||||
// searchCriteriaFirstGroup: 'Tier.Tier1',
|
searchCriteriaSecondGroup: 'Tier.Tier2',
|
||||||
// responseValueFirstGroup: '"tagFQN":"Tier.Tier1"',
|
responseValueSecondGroup: '"tagFQN":"Tier.Tier2"',
|
||||||
// searchCriteriaSecondGroup: 'Tier.Tier2',
|
isLocalSearch: true,
|
||||||
// responseValueSecondGroup: '"tagFQN":"Tier.Tier2"',
|
},
|
||||||
// },
|
|
||||||
Service: {
|
Service: {
|
||||||
name: 'Service',
|
name: 'Service',
|
||||||
testid: '[title="Service"]',
|
testid: '[title="Service"]',
|
||||||
@ -193,12 +192,21 @@ export const OPERATOR = {
|
|||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
export const searchForField = (condition, fieldid, searchCriteria, index) => {
|
export const searchForField = (
|
||||||
|
condition,
|
||||||
|
fieldId,
|
||||||
|
searchCriteria,
|
||||||
|
index,
|
||||||
|
isLocalSearch = false
|
||||||
|
) => {
|
||||||
|
if (!isLocalSearch) {
|
||||||
interceptURL('GET', '/api/v1/search/aggregate?*', 'suggestApi');
|
interceptURL('GET', '/api/v1/search/aggregate?*', 'suggestApi');
|
||||||
|
}
|
||||||
|
|
||||||
// Click on field dropdown
|
// Click on field dropdown
|
||||||
cy.get('.rule--field > .ant-select > .ant-select-selector').eq(index).click();
|
cy.get('.rule--field > .ant-select > .ant-select-selector').eq(index).click();
|
||||||
// Select owner fields
|
// Select owner fields
|
||||||
cy.get(`${fieldid}`).eq(index).click();
|
cy.get(`${fieldId}`).eq(index).click();
|
||||||
// Select the condition
|
// Select the condition
|
||||||
cy.get('.rule--operator > .ant-select > .ant-select-selector')
|
cy.get('.rule--operator > .ant-select > .ant-select-selector')
|
||||||
.eq(index)
|
.eq(index)
|
||||||
@ -219,8 +227,16 @@ export const searchForField = (condition, fieldid, searchCriteria, index) => {
|
|||||||
cy.get('.widget--widget > .ant-select > .ant-select-selector')
|
cy.get('.widget--widget > .ant-select > .ant-select-selector')
|
||||||
.eq(index)
|
.eq(index)
|
||||||
.type(searchCriteria);
|
.type(searchCriteria);
|
||||||
|
|
||||||
|
// checking filter is working
|
||||||
|
cy.get(
|
||||||
|
`.ant-select-item-option-active[title="${searchCriteria}"]`
|
||||||
|
).should('be.visible');
|
||||||
|
|
||||||
// select value from dropdown
|
// select value from dropdown
|
||||||
|
if (!isLocalSearch) {
|
||||||
verifyResponseStatusCode('@suggestApi', 200);
|
verifyResponseStatusCode('@suggestApi', 200);
|
||||||
|
}
|
||||||
cy.get(`.ant-select-dropdown [title = '${searchCriteria}']`)
|
cy.get(`.ant-select-dropdown [title = '${searchCriteria}']`)
|
||||||
.trigger('mouseover')
|
.trigger('mouseover')
|
||||||
.trigger('click');
|
.trigger('click');
|
||||||
@ -240,12 +256,13 @@ export const checkmustPaths = (
|
|||||||
field,
|
field,
|
||||||
searchCriteria,
|
searchCriteria,
|
||||||
index,
|
index,
|
||||||
responseSearch
|
responseSearch,
|
||||||
|
isLocalSearch
|
||||||
) => {
|
) => {
|
||||||
goToAdvanceSearch();
|
goToAdvanceSearch();
|
||||||
|
|
||||||
// Search with advance search
|
// Search with advance search
|
||||||
searchForField(condition, field, searchCriteria, index);
|
searchForField(condition, field, searchCriteria, index, isLocalSearch);
|
||||||
|
|
||||||
interceptURL(
|
interceptURL(
|
||||||
'GET',
|
'GET',
|
||||||
@ -271,12 +288,13 @@ export const checkmust_notPaths = (
|
|||||||
field,
|
field,
|
||||||
searchCriteria,
|
searchCriteria,
|
||||||
index,
|
index,
|
||||||
responseSearch
|
responseSearch,
|
||||||
|
isLocalSearch
|
||||||
) => {
|
) => {
|
||||||
goToAdvanceSearch();
|
goToAdvanceSearch();
|
||||||
|
|
||||||
// Search with advance search
|
// Search with advance search
|
||||||
searchForField(condition, field, searchCriteria, index);
|
searchForField(condition, field, searchCriteria, index, isLocalSearch);
|
||||||
interceptURL(
|
interceptURL(
|
||||||
'GET',
|
'GET',
|
||||||
`/api/v1/search/query?q=&index=*&from=0&size=10&deleted=false&query_filter=*must_not*${encodeURI(
|
`/api/v1/search/query?q=&index=*&from=0&size=10&deleted=false&query_filter=*must_not*${encodeURI(
|
||||||
@ -417,16 +435,17 @@ export const addTag = ({ tag, term, serviceName, entity }) => {
|
|||||||
export const checkAddGroupWithOperator = (
|
export const checkAddGroupWithOperator = (
|
||||||
condition_1,
|
condition_1,
|
||||||
condition_2,
|
condition_2,
|
||||||
fieldid,
|
fieldId,
|
||||||
searchCriteria_1,
|
searchCriteria_1,
|
||||||
searchCriteria_2,
|
searchCriteria_2,
|
||||||
index_1,
|
index_1,
|
||||||
index_2,
|
index_2,
|
||||||
operatorindex,
|
operatorIndex,
|
||||||
filter_1,
|
filter_1,
|
||||||
filter_2,
|
filter_2,
|
||||||
response_1,
|
response_1,
|
||||||
response_2
|
response_2,
|
||||||
|
isLocalSearch = false
|
||||||
) => {
|
) => {
|
||||||
goToAdvanceSearch();
|
goToAdvanceSearch();
|
||||||
// Click on field dropdown
|
// Click on field dropdown
|
||||||
@ -435,7 +454,7 @@ export const checkAddGroupWithOperator = (
|
|||||||
.should('be.visible')
|
.should('be.visible')
|
||||||
.click();
|
.click();
|
||||||
// Select owner fields
|
// Select owner fields
|
||||||
cy.get(fieldid).eq(0).should('be.visible').click();
|
cy.get(fieldId).eq(0).should('be.visible').click();
|
||||||
// Select the condition
|
// Select the condition
|
||||||
cy.get('.rule--operator > .ant-select > .ant-select-selector')
|
cy.get('.rule--operator > .ant-select > .ant-select-selector')
|
||||||
.eq(index_1)
|
.eq(index_1)
|
||||||
@ -456,13 +475,17 @@ export const checkAddGroupWithOperator = (
|
|||||||
.should('be.visible')
|
.should('be.visible')
|
||||||
.type(searchCriteria_1);
|
.type(searchCriteria_1);
|
||||||
} else {
|
} else {
|
||||||
|
if (!isLocalSearch) {
|
||||||
interceptURL('GET', '/api/v1/search/aggregate?*', 'suggestApi');
|
interceptURL('GET', '/api/v1/search/aggregate?*', 'suggestApi');
|
||||||
|
}
|
||||||
cy.get('.widget--widget > .ant-select > .ant-select-selector')
|
cy.get('.widget--widget > .ant-select > .ant-select-selector')
|
||||||
.eq(index_1)
|
.eq(index_1)
|
||||||
.should('be.visible')
|
.should('be.visible')
|
||||||
.type(searchCriteria_1);
|
.type(searchCriteria_1);
|
||||||
|
|
||||||
|
if (!isLocalSearch) {
|
||||||
verifyResponseStatusCode('@suggestApi', 200);
|
verifyResponseStatusCode('@suggestApi', 200);
|
||||||
|
}
|
||||||
cy.get('.ant-select-dropdown')
|
cy.get('.ant-select-dropdown')
|
||||||
.not('.ant-select-dropdown-hidden')
|
.not('.ant-select-dropdown-hidden')
|
||||||
.find(`[title="${searchCriteria_1}"]`)
|
.find(`[title="${searchCriteria_1}"]`)
|
||||||
@ -484,13 +507,13 @@ export const checkAddGroupWithOperator = (
|
|||||||
|
|
||||||
// Select the AND/OR condition
|
// Select the AND/OR condition
|
||||||
cy.get(
|
cy.get(
|
||||||
`.group--conjunctions > .ant-btn-group > :nth-child(${operatorindex})`
|
`.group--conjunctions > .ant-btn-group > :nth-child(${operatorIndex})`
|
||||||
).click();
|
).click();
|
||||||
|
|
||||||
// Click on field dropdown
|
// Click on field dropdown
|
||||||
cy.get('.rule--field').eq(index_2).should('be.visible').click();
|
cy.get('.rule--field').eq(index_2).should('be.visible').click();
|
||||||
|
|
||||||
cy.get(fieldid).eq(2).should('be.visible').click();
|
cy.get(fieldId).eq(2).should('be.visible').click();
|
||||||
|
|
||||||
// Select the condition
|
// Select the condition
|
||||||
cy.get('.rule--operator').eq(index_2).should('be.visible').click();
|
cy.get('.rule--operator').eq(index_2).should('be.visible').click();
|
||||||
@ -509,12 +532,17 @@ export const checkAddGroupWithOperator = (
|
|||||||
.should('be.visible')
|
.should('be.visible')
|
||||||
.type(searchCriteria_2);
|
.type(searchCriteria_2);
|
||||||
} else {
|
} else {
|
||||||
|
if (!isLocalSearch) {
|
||||||
interceptURL('GET', '/api/v1/search/aggregate?*', 'suggestApi');
|
interceptURL('GET', '/api/v1/search/aggregate?*', 'suggestApi');
|
||||||
|
}
|
||||||
cy.get('.widget--widget > .ant-select > .ant-select-selector')
|
cy.get('.widget--widget > .ant-select > .ant-select-selector')
|
||||||
.eq(index_2)
|
.eq(index_2)
|
||||||
.should('be.visible')
|
.should('be.visible')
|
||||||
.type(searchCriteria_2);
|
.type(searchCriteria_2);
|
||||||
|
|
||||||
|
if (!isLocalSearch) {
|
||||||
verifyResponseStatusCode('@suggestApi', 200);
|
verifyResponseStatusCode('@suggestApi', 200);
|
||||||
|
}
|
||||||
|
|
||||||
cy.get('.ant-select-dropdown')
|
cy.get('.ant-select-dropdown')
|
||||||
.not('.ant-select-dropdown-hidden')
|
.not('.ant-select-dropdown-hidden')
|
||||||
@ -547,12 +575,12 @@ export const checkAddGroupWithOperator = (
|
|||||||
export const checkAddRuleWithOperator = (
|
export const checkAddRuleWithOperator = (
|
||||||
condition_1,
|
condition_1,
|
||||||
condition_2,
|
condition_2,
|
||||||
fieldid,
|
fieldId,
|
||||||
searchCriteria_1,
|
searchCriteria_1,
|
||||||
searchCriteria_2,
|
searchCriteria_2,
|
||||||
index_1,
|
index_1,
|
||||||
index_2,
|
index_2,
|
||||||
operatorindex,
|
operatorIndex,
|
||||||
filter_1,
|
filter_1,
|
||||||
filter_2,
|
filter_2,
|
||||||
response_1,
|
response_1,
|
||||||
@ -562,7 +590,7 @@ export const checkAddRuleWithOperator = (
|
|||||||
// Click on field dropdown
|
// Click on field dropdown
|
||||||
cy.get('.rule--field').eq(index_1).should('be.visible').click();
|
cy.get('.rule--field').eq(index_1).should('be.visible').click();
|
||||||
// Select owner fields
|
// Select owner fields
|
||||||
cy.get(fieldid).eq(0).should('be.visible').click();
|
cy.get(fieldId).eq(0).should('be.visible').click();
|
||||||
// Select the condition
|
// Select the condition
|
||||||
cy.get('.rule--operator').eq(index_1).should('be.visible').click();
|
cy.get('.rule--operator').eq(index_1).should('be.visible').click();
|
||||||
|
|
||||||
@ -604,13 +632,13 @@ export const checkAddRuleWithOperator = (
|
|||||||
|
|
||||||
// Select the AND/OR condition
|
// Select the AND/OR condition
|
||||||
cy.get(
|
cy.get(
|
||||||
`.group--conjunctions > .ant-btn-group > :nth-child(${operatorindex})`
|
`.group--conjunctions > .ant-btn-group > :nth-child(${operatorIndex})`
|
||||||
).click();
|
).click();
|
||||||
|
|
||||||
// Click on field dropdown
|
// Click on field dropdown
|
||||||
cy.get('.rule--field').eq(index_2).should('be.visible').click();
|
cy.get('.rule--field').eq(index_2).should('be.visible').click();
|
||||||
|
|
||||||
cy.get(fieldid).eq(2).should('be.visible').click();
|
cy.get(fieldId).eq(2).should('be.visible').click();
|
||||||
|
|
||||||
// Select the condition
|
// Select the condition
|
||||||
cy.get('.rule--operator').eq(index_2).should('be.visible').click();
|
cy.get('.rule--operator').eq(index_2).should('be.visible').click();
|
||||||
|
@ -11,7 +11,11 @@
|
|||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import { addOwner, removeOwner } from '../../common/advancedSearch';
|
import {
|
||||||
|
addOwner,
|
||||||
|
goToAdvanceSearch,
|
||||||
|
removeOwner,
|
||||||
|
} from '../../common/advancedSearch';
|
||||||
import { searchAndClickOnOption } from '../../common/advancedSearchQuickFilters';
|
import { searchAndClickOnOption } from '../../common/advancedSearchQuickFilters';
|
||||||
import { interceptURL, verifyResponseStatusCode } from '../../common/common';
|
import { interceptURL, verifyResponseStatusCode } from '../../common/common';
|
||||||
import { QUICK_FILTERS_BY_ASSETS } from '../../constants/advancedSearchQuickFilters.constants';
|
import { QUICK_FILTERS_BY_ASSETS } from '../../constants/advancedSearchQuickFilters.constants';
|
||||||
@ -78,10 +82,7 @@ describe(`Advanced search quick filters should work properly for assets`, () =>
|
|||||||
});
|
});
|
||||||
|
|
||||||
const testIsNullAndIsNotNullFilters = (operatorTitle, queryFilter, alias) => {
|
const testIsNullAndIsNotNullFilters = (operatorTitle, queryFilter, alias) => {
|
||||||
cy.sidebarClick(SidebarItem.EXPLORE);
|
goToAdvanceSearch();
|
||||||
const asset = QUICK_FILTERS_BY_ASSETS[0];
|
|
||||||
cy.get(`[data-testid="${asset.tab}"]`).scrollIntoView().click();
|
|
||||||
cy.get('[data-testid="advance-search-button"]').click();
|
|
||||||
|
|
||||||
// Check Is Null or Is Not Null
|
// Check Is Null or Is Not Null
|
||||||
cy.get('.rule--operator > .ant-select > .ant-select-selector').eq(0).click();
|
cy.get('.rule--operator > .ant-select > .ant-select-selector').eq(0).click();
|
||||||
|
@ -68,9 +68,12 @@ describe('Advance search', () => {
|
|||||||
checkmustPaths(
|
checkmustPaths(
|
||||||
condition.name,
|
condition.name,
|
||||||
field.testid,
|
field.testid,
|
||||||
Cypress._.toLower(field.searchCriteriaFirstGroup),
|
field.isLocalSearch
|
||||||
|
? field.searchCriteriaFirstGroup
|
||||||
|
: Cypress._.toLower(field.searchCriteriaFirstGroup),
|
||||||
0,
|
0,
|
||||||
field.responseValueFirstGroup
|
field.responseValueFirstGroup,
|
||||||
|
field.isLocalSearch
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -78,9 +81,12 @@ describe('Advance search', () => {
|
|||||||
checkmust_notPaths(
|
checkmust_notPaths(
|
||||||
condition.name,
|
condition.name,
|
||||||
field.testid,
|
field.testid,
|
||||||
Cypress._.toLower(field.searchCriteriaFirstGroup),
|
field.isLocalSearch
|
||||||
|
? field.searchCriteriaFirstGroup
|
||||||
|
: Cypress._.toLower(field.searchCriteriaFirstGroup),
|
||||||
0,
|
0,
|
||||||
field.responseValueFirstGroup
|
field.responseValueFirstGroup,
|
||||||
|
field.isLocalSearch
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
@ -108,15 +114,20 @@ describe('Advance search', () => {
|
|||||||
CONDITIONS_MUST.equalTo.name,
|
CONDITIONS_MUST.equalTo.name,
|
||||||
CONDITIONS_MUST_NOT.notEqualTo.name,
|
CONDITIONS_MUST_NOT.notEqualTo.name,
|
||||||
field.testid,
|
field.testid,
|
||||||
Cypress._.toLower(field.searchCriteriaFirstGroup),
|
field.isLocalSearch
|
||||||
Cypress._.toLower(field.searchCriteriaSecondGroup),
|
? field.searchCriteriaFirstGroup
|
||||||
|
: Cypress._.toLower(field.searchCriteriaFirstGroup),
|
||||||
|
field.isLocalSearch
|
||||||
|
? field.searchCriteriaSecondGroup
|
||||||
|
: Cypress._.toLower(field.searchCriteriaSecondGroup),
|
||||||
0,
|
0,
|
||||||
1,
|
1,
|
||||||
operator.index,
|
operator.index,
|
||||||
CONDITIONS_MUST.equalTo.filter,
|
CONDITIONS_MUST.equalTo.filter,
|
||||||
CONDITIONS_MUST_NOT.notEqualTo.filter,
|
CONDITIONS_MUST_NOT.notEqualTo.filter,
|
||||||
field.responseValueFirstGroup,
|
field.responseValueFirstGroup,
|
||||||
val
|
val,
|
||||||
|
field.isLocalSearch
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
@ -131,15 +142,20 @@ describe('Advance search', () => {
|
|||||||
CONDITIONS_MUST.anyIn.name,
|
CONDITIONS_MUST.anyIn.name,
|
||||||
CONDITIONS_MUST_NOT.notIn.name,
|
CONDITIONS_MUST_NOT.notIn.name,
|
||||||
field.testid,
|
field.testid,
|
||||||
Cypress._.toLower(field.searchCriteriaFirstGroup),
|
field.isLocalSearch
|
||||||
Cypress._.toLower(field.searchCriteriaSecondGroup),
|
? field.searchCriteriaFirstGroup
|
||||||
|
: Cypress._.toLower(field.searchCriteriaFirstGroup),
|
||||||
|
field.isLocalSearch
|
||||||
|
? field.searchCriteriaSecondGroup
|
||||||
|
: Cypress._.toLower(field.searchCriteriaSecondGroup),
|
||||||
0,
|
0,
|
||||||
1,
|
1,
|
||||||
operator.index,
|
operator.index,
|
||||||
CONDITIONS_MUST.anyIn.filter,
|
CONDITIONS_MUST.anyIn.filter,
|
||||||
CONDITIONS_MUST_NOT.notIn.filter,
|
CONDITIONS_MUST_NOT.notIn.filter,
|
||||||
field.responseValueFirstGroup,
|
field.responseValueFirstGroup,
|
||||||
val
|
val,
|
||||||
|
field.isLocalSearch
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
@ -152,15 +168,20 @@ describe('Advance search', () => {
|
|||||||
CONDITIONS_MUST.contains.name,
|
CONDITIONS_MUST.contains.name,
|
||||||
CONDITIONS_MUST_NOT.notContains.name,
|
CONDITIONS_MUST_NOT.notContains.name,
|
||||||
field.testid,
|
field.testid,
|
||||||
Cypress._.toLower(field.searchCriteriaFirstGroup),
|
field.isLocalSearch
|
||||||
Cypress._.toLower(field.searchCriteriaSecondGroup),
|
? field.searchCriteriaFirstGroup
|
||||||
|
: Cypress._.toLower(field.searchCriteriaFirstGroup),
|
||||||
|
field.isLocalSearch
|
||||||
|
? field.searchCriteriaSecondGroup
|
||||||
|
: Cypress._.toLower(field.searchCriteriaSecondGroup),
|
||||||
0,
|
0,
|
||||||
1,
|
1,
|
||||||
operator.index,
|
operator.index,
|
||||||
CONDITIONS_MUST.contains.filter,
|
CONDITIONS_MUST.contains.filter,
|
||||||
CONDITIONS_MUST_NOT.notContains.filter,
|
CONDITIONS_MUST_NOT.notContains.filter,
|
||||||
field.responseValueFirstGroup,
|
field.responseValueFirstGroup,
|
||||||
val
|
val,
|
||||||
|
field.isLocalSearch
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
@ -12,18 +12,9 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
import { Button, Modal, Space, Typography } from 'antd';
|
import { Button, Modal, Space, Typography } from 'antd';
|
||||||
import { cloneDeep } from 'lodash';
|
import React, { FunctionComponent } from 'react';
|
||||||
import React, { FunctionComponent, useEffect } from 'react';
|
import { Builder, Query } from 'react-awesome-query-builder';
|
||||||
import {
|
|
||||||
Builder,
|
|
||||||
FieldGroup,
|
|
||||||
Query,
|
|
||||||
ValueSource,
|
|
||||||
} from 'react-awesome-query-builder';
|
|
||||||
import { useTranslation } from 'react-i18next';
|
import { useTranslation } from 'react-i18next';
|
||||||
import { getTypeByFQN } from '../../rest/metadataTypeAPI';
|
|
||||||
import { EntitiesSupportedCustomProperties } from '../../utils/CustomProperties/CustomProperty.utils';
|
|
||||||
import { getEntityTypeFromSearchIndex } from '../../utils/SearchUtils';
|
|
||||||
import './advanced-search-modal.less';
|
import './advanced-search-modal.less';
|
||||||
import { useAdvanceSearch } from './AdvanceSearchProvider/AdvanceSearchProvider.component';
|
import { useAdvanceSearch } from './AdvanceSearchProvider/AdvanceSearchProvider.component';
|
||||||
|
|
||||||
@ -39,51 +30,7 @@ export const AdvancedSearchModal: FunctionComponent<Props> = ({
|
|||||||
onCancel,
|
onCancel,
|
||||||
}: Props) => {
|
}: Props) => {
|
||||||
const { t } = useTranslation();
|
const { t } = useTranslation();
|
||||||
const {
|
const { config, treeInternal, onTreeUpdate, onReset } = useAdvanceSearch();
|
||||||
config,
|
|
||||||
treeInternal,
|
|
||||||
onTreeUpdate,
|
|
||||||
onReset,
|
|
||||||
onUpdateConfig,
|
|
||||||
searchIndex,
|
|
||||||
} = useAdvanceSearch();
|
|
||||||
|
|
||||||
const updatedConfig = cloneDeep(config);
|
|
||||||
|
|
||||||
async function getCustomAttributesSubfields() {
|
|
||||||
try {
|
|
||||||
const entityType = getEntityTypeFromSearchIndex(searchIndex);
|
|
||||||
if (!entityType) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
const res = await getTypeByFQN(entityType);
|
|
||||||
const customAttributes = res.customProperties;
|
|
||||||
|
|
||||||
const subfields: Record<
|
|
||||||
string,
|
|
||||||
{ type: string; valueSources: ValueSource[] }
|
|
||||||
> = {};
|
|
||||||
|
|
||||||
if (customAttributes) {
|
|
||||||
customAttributes.forEach((attr) => {
|
|
||||||
subfields[attr.name] = {
|
|
||||||
type: 'text',
|
|
||||||
valueSources: ['value'],
|
|
||||||
};
|
|
||||||
});
|
|
||||||
}
|
|
||||||
(updatedConfig.fields.extension as FieldGroup).subfields = subfields;
|
|
||||||
onUpdateConfig(updatedConfig);
|
|
||||||
} catch (error) {
|
|
||||||
// Error
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
useEffect(() => {
|
|
||||||
if (visible && EntitiesSupportedCustomProperties.includes(searchIndex)) {
|
|
||||||
getCustomAttributesSubfields();
|
|
||||||
}
|
|
||||||
}, [visible, searchIndex]);
|
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Modal
|
<Modal
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright 2023 Collate.
|
* Copyright 2024 Collate.
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
* You may obtain a copy of the License at
|
* You may obtain a copy of the License at
|
||||||
@ -10,8 +10,7 @@
|
|||||||
* See the License for the specific language governing permissions and
|
* See the License for the specific language governing permissions and
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
import { isEmpty, isEqual, isNil, isString } from 'lodash';
|
||||||
import { cloneDeep, isNil, isString } from 'lodash';
|
|
||||||
import Qs from 'qs';
|
import Qs from 'qs';
|
||||||
import React, {
|
import React, {
|
||||||
useCallback,
|
useCallback,
|
||||||
@ -35,6 +34,8 @@ import {
|
|||||||
} from '../../../constants/AdvancedSearch.constants';
|
} from '../../../constants/AdvancedSearch.constants';
|
||||||
import { SearchIndex } from '../../../enums/search.enum';
|
import { SearchIndex } from '../../../enums/search.enum';
|
||||||
import { getTypeByFQN } from '../../../rest/metadataTypeAPI';
|
import { getTypeByFQN } from '../../../rest/metadataTypeAPI';
|
||||||
|
import { getTierOptions } from '../../../utils/AdvancedSearchUtils';
|
||||||
|
import { EntitiesSupportedCustomProperties } from '../../../utils/CustomProperties/CustomProperty.utils';
|
||||||
import { elasticSearchFormat } from '../../../utils/QueryBuilderElasticsearchFormatUtils';
|
import { elasticSearchFormat } from '../../../utils/QueryBuilderElasticsearchFormatUtils';
|
||||||
import searchClassBase from '../../../utils/SearchClassBase';
|
import searchClassBase from '../../../utils/SearchClassBase';
|
||||||
import { getEntityTypeFromSearchIndex } from '../../../utils/SearchUtils';
|
import { getEntityTypeFromSearchIndex } from '../../../utils/SearchUtils';
|
||||||
@ -53,6 +54,8 @@ const AdvancedSearchContext = React.createContext<AdvanceSearchContext>(
|
|||||||
export const AdvanceSearchProvider = ({
|
export const AdvanceSearchProvider = ({
|
||||||
children,
|
children,
|
||||||
}: AdvanceSearchProviderProps) => {
|
}: AdvanceSearchProviderProps) => {
|
||||||
|
const tierOptions = useMemo(getTierOptions, []);
|
||||||
|
|
||||||
const tabsInfo = searchClassBase.getTabsInfo();
|
const tabsInfo = searchClassBase.getTabsInfo();
|
||||||
const location = useLocation();
|
const location = useLocation();
|
||||||
const history = useHistory();
|
const history = useHistory();
|
||||||
@ -68,7 +71,10 @@ export const AdvanceSearchProvider = ({
|
|||||||
|
|
||||||
return tabInfo[0] as ExploreSearchIndex;
|
return tabInfo[0] as ExploreSearchIndex;
|
||||||
}, [tab]);
|
}, [tab]);
|
||||||
const [config, setConfig] = useState<Config>(getQbConfigs(searchIndex));
|
const [config, setConfig] = useState<Config>(
|
||||||
|
getQbConfigs(searchIndex, tierOptions)
|
||||||
|
);
|
||||||
|
const [initialised, setInitialised] = useState(false);
|
||||||
|
|
||||||
const defaultTree = useMemo(
|
const defaultTree = useMemo(
|
||||||
() => QbUtils.checkTree(QbUtils.loadTree(emptyJsonTree), config),
|
() => QbUtils.checkTree(QbUtils.loadTree(emptyJsonTree), config),
|
||||||
@ -117,7 +123,7 @@ export const AdvanceSearchProvider = ({
|
|||||||
);
|
);
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
setConfig(getQbConfigs(searchIndex));
|
setConfig(getQbConfigs(searchIndex, tierOptions));
|
||||||
}, [searchIndex]);
|
}, [searchIndex]);
|
||||||
|
|
||||||
const handleChange = useCallback(
|
const handleChange = useCallback(
|
||||||
@ -150,7 +156,7 @@ export const AdvanceSearchProvider = ({
|
|||||||
setTreeInternal(QbUtils.checkTree(QbUtils.loadTree(emptyJsonTree), config));
|
setTreeInternal(QbUtils.checkTree(QbUtils.loadTree(emptyJsonTree), config));
|
||||||
setQueryFilter(undefined);
|
setQueryFilter(undefined);
|
||||||
setSQLQuery('');
|
setSQLQuery('');
|
||||||
}, []);
|
}, [config]);
|
||||||
|
|
||||||
const handleConfigUpdate = (updatedConfig: Config) => {
|
const handleConfigUpdate = (updatedConfig: Config) => {
|
||||||
setConfig(updatedConfig);
|
setConfig(updatedConfig);
|
||||||
@ -171,20 +177,24 @@ export const AdvanceSearchProvider = ({
|
|||||||
}, [history, location.pathname]);
|
}, [history, location.pathname]);
|
||||||
|
|
||||||
async function getCustomAttributesSubfields() {
|
async function getCustomAttributesSubfields() {
|
||||||
const updatedConfig = cloneDeep(config);
|
|
||||||
try {
|
|
||||||
const entityType = getEntityTypeFromSearchIndex(searchIndex);
|
|
||||||
if (!entityType) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
const res = await getTypeByFQN(entityType);
|
|
||||||
const customAttributes = res.customProperties;
|
|
||||||
|
|
||||||
const subfields: Record<
|
const subfields: Record<
|
||||||
string,
|
string,
|
||||||
{ type: string; valueSources: ValueSource[] }
|
{ type: string; valueSources: ValueSource[] }
|
||||||
> = {};
|
> = {};
|
||||||
|
|
||||||
|
try {
|
||||||
|
if (!EntitiesSupportedCustomProperties.includes(searchIndex)) {
|
||||||
|
return subfields;
|
||||||
|
}
|
||||||
|
|
||||||
|
const entityType = getEntityTypeFromSearchIndex(searchIndex);
|
||||||
|
if (!entityType) {
|
||||||
|
return subfields;
|
||||||
|
}
|
||||||
|
|
||||||
|
const res = await getTypeByFQN(entityType);
|
||||||
|
const customAttributes = res.customProperties;
|
||||||
|
|
||||||
if (customAttributes) {
|
if (customAttributes) {
|
||||||
customAttributes.forEach((attr) => {
|
customAttributes.forEach((attr) => {
|
||||||
subfields[attr.name] = {
|
subfields[attr.name] = {
|
||||||
@ -193,30 +203,55 @@ export const AdvanceSearchProvider = ({
|
|||||||
};
|
};
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
(updatedConfig.fields.extension as FieldGroup).subfields = subfields;
|
|
||||||
|
|
||||||
return updatedConfig;
|
return subfields;
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
// Error
|
// Error
|
||||||
return updatedConfig;
|
return subfields;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const loadData = async () => {
|
||||||
|
const actualConfig = getQbConfigs(searchIndex, tierOptions);
|
||||||
|
|
||||||
|
const extensionSubField = await getCustomAttributesSubfields();
|
||||||
|
|
||||||
|
if (!isEmpty(extensionSubField)) {
|
||||||
|
(actualConfig.fields.extension as FieldGroup).subfields =
|
||||||
|
extensionSubField;
|
||||||
|
}
|
||||||
|
|
||||||
|
setConfig(actualConfig);
|
||||||
|
setInitialised(true);
|
||||||
|
};
|
||||||
|
|
||||||
const loadTree = useCallback(
|
const loadTree = useCallback(
|
||||||
async (treeObj: JsonTree) => {
|
async (treeObj: JsonTree) => {
|
||||||
const updatedConfig = (await getCustomAttributesSubfields()) ?? config;
|
const updatedConfig = config;
|
||||||
const tree = QbUtils.checkTree(QbUtils.loadTree(treeObj), updatedConfig);
|
const tree = QbUtils.checkTree(QbUtils.loadTree(treeObj), updatedConfig);
|
||||||
|
|
||||||
setTreeInternal(tree);
|
setTreeInternal(tree);
|
||||||
const qFilter = {
|
const qFilter = {
|
||||||
query: elasticSearchFormat(tree, updatedConfig),
|
query: elasticSearchFormat(tree, updatedConfig),
|
||||||
};
|
};
|
||||||
|
if (isEqual(qFilter, queryFilter)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
setQueryFilter(qFilter);
|
setQueryFilter(qFilter);
|
||||||
setSQLQuery(QbUtils.sqlFormat(tree, updatedConfig) ?? '');
|
setSQLQuery(QbUtils.sqlFormat(tree, updatedConfig) ?? '');
|
||||||
},
|
},
|
||||||
[config]
|
[config, queryFilter]
|
||||||
);
|
);
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
|
loadData();
|
||||||
|
}, [searchIndex]);
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
if (!initialised) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
if (jsonTree) {
|
if (jsonTree) {
|
||||||
loadTree(jsonTree);
|
loadTree(jsonTree);
|
||||||
} else {
|
} else {
|
||||||
@ -224,7 +259,7 @@ export const AdvanceSearchProvider = ({
|
|||||||
}
|
}
|
||||||
|
|
||||||
setLoading(false);
|
setLoading(false);
|
||||||
}, [jsonTree]);
|
}, [jsonTree, initialised]);
|
||||||
|
|
||||||
const handleSubmit = useCallback(() => {
|
const handleSubmit = useCallback(() => {
|
||||||
const qFilter = {
|
const qFilter = {
|
||||||
|
@ -0,0 +1,124 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2024 Collate.
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
import { act, render, screen } from '@testing-library/react';
|
||||||
|
import userEvent from '@testing-library/user-event';
|
||||||
|
import React from 'react';
|
||||||
|
import {
|
||||||
|
AdvanceSearchProvider,
|
||||||
|
useAdvanceSearch,
|
||||||
|
} from './AdvanceSearchProvider.component';
|
||||||
|
|
||||||
|
jest.mock('../../../rest/metadataTypeAPI', () => ({
|
||||||
|
getTypeByFQN: jest.fn().mockResolvedValue({}),
|
||||||
|
}));
|
||||||
|
|
||||||
|
jest.mock('../../../rest/tagAPI', () => ({
|
||||||
|
getTags: jest.fn().mockResolvedValue({}),
|
||||||
|
}));
|
||||||
|
|
||||||
|
jest.mock('../AdvanceSearchModal.component', () => ({
|
||||||
|
AdvancedSearchModal: jest
|
||||||
|
.fn()
|
||||||
|
.mockImplementation(({ visible, onSubmit, onCancel }) => (
|
||||||
|
<>
|
||||||
|
{visible ? (
|
||||||
|
<p>AdvanceSearchModal Open</p>
|
||||||
|
) : (
|
||||||
|
<p>AdvanceSearchModal Close</p>
|
||||||
|
)}
|
||||||
|
<button onClick={onSubmit}>Apply Advance Search</button>
|
||||||
|
<button onClick={onCancel}>Close Modal</button>
|
||||||
|
</>
|
||||||
|
)),
|
||||||
|
}));
|
||||||
|
|
||||||
|
jest.mock('../../Loader/Loader', () =>
|
||||||
|
jest.fn().mockReturnValue(<div>Loader</div>)
|
||||||
|
);
|
||||||
|
|
||||||
|
const mockPush = jest.fn();
|
||||||
|
|
||||||
|
jest.mock('react-router-dom', () => ({
|
||||||
|
useLocation: jest.fn().mockReturnValue({
|
||||||
|
search: 'queryFilter={"some":"value"}',
|
||||||
|
}),
|
||||||
|
useParams: jest.fn().mockReturnValue({
|
||||||
|
tab: 'tabValue',
|
||||||
|
}),
|
||||||
|
useHistory: jest.fn().mockImplementation(() => ({
|
||||||
|
push: mockPush,
|
||||||
|
})),
|
||||||
|
}));
|
||||||
|
|
||||||
|
const Children = () => {
|
||||||
|
const { toggleModal, onResetAllFilters } = useAdvanceSearch();
|
||||||
|
|
||||||
|
return (
|
||||||
|
<>
|
||||||
|
<button onClick={() => toggleModal(true)}>
|
||||||
|
Open AdvanceSearch Modal
|
||||||
|
</button>
|
||||||
|
<button onClick={onResetAllFilters}>Reset All Filters</button>
|
||||||
|
</>
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
const mockWithAdvanceSearch =
|
||||||
|
(Component: React.FC) =>
|
||||||
|
(props: JSX.IntrinsicAttributes & { children?: React.ReactNode }) => {
|
||||||
|
return (
|
||||||
|
<AdvanceSearchProvider>
|
||||||
|
<Component {...props} />
|
||||||
|
</AdvanceSearchProvider>
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
const ComponentWithProvider = mockWithAdvanceSearch(Children);
|
||||||
|
|
||||||
|
describe('AdvanceSearchProvider component', () => {
|
||||||
|
it('should render the AdvanceSearchModal as close by default', () => {
|
||||||
|
render(<ComponentWithProvider />);
|
||||||
|
|
||||||
|
expect(screen.getByText('AdvanceSearchModal Close')).toBeInTheDocument();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should call mockPush after submit advance search form', async () => {
|
||||||
|
render(<ComponentWithProvider />);
|
||||||
|
|
||||||
|
userEvent.click(screen.getByText('Apply Advance Search'));
|
||||||
|
|
||||||
|
expect(mockPush).toHaveBeenCalled();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should open the AdvanceSearchModal on call of toggleModal with true', async () => {
|
||||||
|
await act(async () => {
|
||||||
|
render(<ComponentWithProvider />);
|
||||||
|
});
|
||||||
|
|
||||||
|
expect(screen.getByText('AdvanceSearchModal Close')).toBeInTheDocument();
|
||||||
|
|
||||||
|
userEvent.click(screen.getByText('Open AdvanceSearch Modal'));
|
||||||
|
|
||||||
|
expect(screen.getByText('AdvanceSearchModal Open')).toBeInTheDocument();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('onResetAllFilters call mockPush should be called', async () => {
|
||||||
|
await act(async () => {
|
||||||
|
render(<ComponentWithProvider />);
|
||||||
|
});
|
||||||
|
|
||||||
|
userEvent.click(screen.getByText('Reset All Filters'));
|
||||||
|
|
||||||
|
expect(mockPush).toHaveBeenCalled();
|
||||||
|
});
|
||||||
|
});
|
@ -219,7 +219,7 @@ const ExploreV1: React.FC<ExploreProps> = ({
|
|||||||
handleSummaryPanelDisplay(
|
handleSummaryPanelDisplay(
|
||||||
highlightEntityNameAndDescription(
|
highlightEntityNameAndDescription(
|
||||||
firstEntity._source,
|
firstEntity._source,
|
||||||
firstEntity.highlight
|
firstEntity?.highlight
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
@ -356,7 +356,7 @@ const ExploreV1: React.FC<ExploreProps> = ({
|
|||||||
handleClosePanel={handleClosePanel}
|
handleClosePanel={handleClosePanel}
|
||||||
highlights={omit(
|
highlights={omit(
|
||||||
{
|
{
|
||||||
...firstEntity.highlight, // highlights of firstEntity that we get from the query api
|
...firstEntity?.highlight, // highlights of firstEntity that we get from the query api
|
||||||
'tag.name': (
|
'tag.name': (
|
||||||
selectedQuickFilters?.find(
|
selectedQuickFilters?.find(
|
||||||
(filterOption) => filterOption.key === TAG_FQN_KEY
|
(filterOption) => filterOption.key === TAG_FQN_KEY
|
||||||
|
@ -13,9 +13,12 @@
|
|||||||
|
|
||||||
import { t } from 'i18next';
|
import { t } from 'i18next';
|
||||||
import {
|
import {
|
||||||
|
AsyncFetchListValues,
|
||||||
|
AsyncFetchListValuesResult,
|
||||||
BasicConfig,
|
BasicConfig,
|
||||||
Fields,
|
Fields,
|
||||||
JsonTree,
|
JsonTree,
|
||||||
|
ListItem,
|
||||||
SelectFieldSettings,
|
SelectFieldSettings,
|
||||||
Utils as QbUtils,
|
Utils as QbUtils,
|
||||||
} from 'react-awesome-query-builder';
|
} from 'react-awesome-query-builder';
|
||||||
@ -304,6 +307,23 @@ export const autocomplete: (args: {
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
export const autoCompleteTier: (
|
||||||
|
tierOptions: Promise<AsyncFetchListValues>
|
||||||
|
) => SelectFieldSettings['asyncFetch'] = (tierOptions) => {
|
||||||
|
return async (search) => {
|
||||||
|
const resolvedTierOptions = (await tierOptions) as ListItem[];
|
||||||
|
|
||||||
|
return {
|
||||||
|
values: !search
|
||||||
|
? resolvedTierOptions
|
||||||
|
: resolvedTierOptions.filter((tier) =>
|
||||||
|
tier.title?.toLowerCase()?.includes(search.toLowerCase())
|
||||||
|
),
|
||||||
|
hasMore: false,
|
||||||
|
} as AsyncFetchListValuesResult;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
const mainWidgetProps = {
|
const mainWidgetProps = {
|
||||||
fullWidth: true,
|
fullWidth: true,
|
||||||
valueLabel: t('label.criteria') + ':',
|
valueLabel: t('label.criteria') + ':',
|
||||||
@ -313,7 +333,8 @@ const mainWidgetProps = {
|
|||||||
* Common fields that exit for all searchable entities
|
* Common fields that exit for all searchable entities
|
||||||
*/
|
*/
|
||||||
const getCommonQueryBuilderFields = (
|
const getCommonQueryBuilderFields = (
|
||||||
entitySearchIndex: SearchIndex = SearchIndex.TABLE
|
entitySearchIndex: SearchIndex = SearchIndex.TABLE,
|
||||||
|
tierOptions: Promise<AsyncFetchListValues> = Promise.resolve([])
|
||||||
) => {
|
) => {
|
||||||
const commonQueryBuilderFields: Fields = {
|
const commonQueryBuilderFields: Fields = {
|
||||||
deleted: {
|
deleted: {
|
||||||
@ -356,10 +377,7 @@ const getCommonQueryBuilderFields = (
|
|||||||
type: 'select',
|
type: 'select',
|
||||||
mainWidgetProps,
|
mainWidgetProps,
|
||||||
fieldSettings: {
|
fieldSettings: {
|
||||||
asyncFetch: autocomplete({
|
asyncFetch: autoCompleteTier(tierOptions),
|
||||||
searchIndex: entitySearchIndex ?? [SearchIndex.TAG],
|
|
||||||
entityField: EntityFields.TIER,
|
|
||||||
}),
|
|
||||||
useAsyncSearch: true,
|
useAsyncSearch: true,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
@ -522,15 +540,16 @@ const getInitialConfigWithoutFields = () => {
|
|||||||
/**
|
/**
|
||||||
* Builds search index specific configuration for the query builder
|
* Builds search index specific configuration for the query builder
|
||||||
*/
|
*/
|
||||||
export const getQbConfigs: (searchIndex: SearchIndex) => BasicConfig = (
|
export const getQbConfigs: (
|
||||||
searchIndex
|
searchIndex: SearchIndex,
|
||||||
) => {
|
tierOptions: Promise<AsyncFetchListValues>
|
||||||
|
) => BasicConfig = (searchIndex, tierOptions) => {
|
||||||
switch (searchIndex) {
|
switch (searchIndex) {
|
||||||
case SearchIndex.MLMODEL:
|
case SearchIndex.MLMODEL:
|
||||||
return {
|
return {
|
||||||
...getInitialConfigWithoutFields(),
|
...getInitialConfigWithoutFields(),
|
||||||
fields: {
|
fields: {
|
||||||
...getCommonQueryBuilderFields(SearchIndex.MLMODEL),
|
...getCommonQueryBuilderFields(SearchIndex.MLMODEL, tierOptions),
|
||||||
...getServiceQueryBuilderFields(SearchIndex.MLMODEL),
|
...getServiceQueryBuilderFields(SearchIndex.MLMODEL),
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
@ -539,7 +558,7 @@ export const getQbConfigs: (searchIndex: SearchIndex) => BasicConfig = (
|
|||||||
return {
|
return {
|
||||||
...getInitialConfigWithoutFields(),
|
...getInitialConfigWithoutFields(),
|
||||||
fields: {
|
fields: {
|
||||||
...getCommonQueryBuilderFields(SearchIndex.PIPELINE),
|
...getCommonQueryBuilderFields(SearchIndex.PIPELINE, tierOptions),
|
||||||
...getServiceQueryBuilderFields(SearchIndex.PIPELINE),
|
...getServiceQueryBuilderFields(SearchIndex.PIPELINE),
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
@ -548,7 +567,7 @@ export const getQbConfigs: (searchIndex: SearchIndex) => BasicConfig = (
|
|||||||
return {
|
return {
|
||||||
...getInitialConfigWithoutFields(),
|
...getInitialConfigWithoutFields(),
|
||||||
fields: {
|
fields: {
|
||||||
...getCommonQueryBuilderFields(SearchIndex.DASHBOARD),
|
...getCommonQueryBuilderFields(SearchIndex.DASHBOARD, tierOptions),
|
||||||
...getServiceQueryBuilderFields(SearchIndex.DASHBOARD),
|
...getServiceQueryBuilderFields(SearchIndex.DASHBOARD),
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
@ -557,7 +576,7 @@ export const getQbConfigs: (searchIndex: SearchIndex) => BasicConfig = (
|
|||||||
return {
|
return {
|
||||||
...getInitialConfigWithoutFields(),
|
...getInitialConfigWithoutFields(),
|
||||||
fields: {
|
fields: {
|
||||||
...getCommonQueryBuilderFields(SearchIndex.TABLE),
|
...getCommonQueryBuilderFields(SearchIndex.TABLE, tierOptions),
|
||||||
...getServiceQueryBuilderFields(SearchIndex.TABLE),
|
...getServiceQueryBuilderFields(SearchIndex.TABLE),
|
||||||
...tableQueryBuilderFields,
|
...tableQueryBuilderFields,
|
||||||
},
|
},
|
||||||
@ -567,7 +586,7 @@ export const getQbConfigs: (searchIndex: SearchIndex) => BasicConfig = (
|
|||||||
return {
|
return {
|
||||||
...getInitialConfigWithoutFields(),
|
...getInitialConfigWithoutFields(),
|
||||||
fields: {
|
fields: {
|
||||||
...getCommonQueryBuilderFields(SearchIndex.TOPIC),
|
...getCommonQueryBuilderFields(SearchIndex.TOPIC, tierOptions),
|
||||||
...getServiceQueryBuilderFields(SearchIndex.TOPIC),
|
...getServiceQueryBuilderFields(SearchIndex.TOPIC),
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
@ -16,7 +16,10 @@ import { Button, Checkbox, MenuProps, Space, Typography } from 'antd';
|
|||||||
import i18next from 'i18next';
|
import i18next from 'i18next';
|
||||||
import { isArray, isEmpty } from 'lodash';
|
import { isArray, isEmpty } from 'lodash';
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import { RenderSettings } from 'react-awesome-query-builder';
|
import {
|
||||||
|
AsyncFetchListValues,
|
||||||
|
RenderSettings,
|
||||||
|
} from 'react-awesome-query-builder';
|
||||||
import ProfilePicture from '../components/common/ProfilePicture/ProfilePicture';
|
import ProfilePicture from '../components/common/ProfilePicture/ProfilePicture';
|
||||||
import { AssetsOfEntity } from '../components/Glossary/GlossaryTerms/tabs/AssetsTabs.interface';
|
import { AssetsOfEntity } from '../components/Glossary/GlossaryTerms/tabs/AssetsTabs.interface';
|
||||||
import { SearchDropdownOption } from '../components/SearchDropdown/SearchDropdown.interface';
|
import { SearchDropdownOption } from '../components/SearchDropdown/SearchDropdown.interface';
|
||||||
@ -38,6 +41,7 @@ import {
|
|||||||
TableSearchSource,
|
TableSearchSource,
|
||||||
TopicSearchSource,
|
TopicSearchSource,
|
||||||
} from '../interface/search.interface';
|
} from '../interface/search.interface';
|
||||||
|
import { getTags } from '../rest/tagAPI';
|
||||||
import { getCountBadge } from '../utils/CommonUtils';
|
import { getCountBadge } from '../utils/CommonUtils';
|
||||||
import { getEntityName } from './EntityUtils';
|
import { getEntityName } from './EntityUtils';
|
||||||
import searchClassBase from './SearchClassBase';
|
import searchClassBase from './SearchClassBase';
|
||||||
@ -393,3 +397,20 @@ export const getOptionsFromAggregationBucket = (buckets: Bucket[]) => {
|
|||||||
count: option.doc_count ?? 0,
|
count: option.doc_count ?? 0,
|
||||||
}));
|
}));
|
||||||
};
|
};
|
||||||
|
|
||||||
|
export const getTierOptions: () => Promise<AsyncFetchListValues> = async () => {
|
||||||
|
try {
|
||||||
|
const { data: tiers } = await getTags({
|
||||||
|
parent: 'Tier',
|
||||||
|
});
|
||||||
|
|
||||||
|
const tierFields = tiers.map((tier) => ({
|
||||||
|
title: tier.fullyQualifiedName, // tier.name,
|
||||||
|
value: tier.fullyQualifiedName,
|
||||||
|
}));
|
||||||
|
|
||||||
|
return tierFields;
|
||||||
|
} catch (error) {
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
};
|
||||||
|
Loading…
x
Reference in New Issue
Block a user