mirror of
				https://github.com/open-metadata/OpenMetadata.git
				synced 2025-10-25 07:42:40 +00:00 
			
		
		
		
	ui: fixed broken tour feature (#13568)
* ui: fixed broken tour feature * translation sync * updated the status of import/update glossary via csv * fixed tour
This commit is contained in:
		
							parent
							
								
									f323a4a8b1
								
							
						
					
					
						commit
						c959f9ca56
					
				| @ -44,6 +44,7 @@ import { | |||||||
|   TagSource, |   TagSource, | ||||||
|   TopicSource, |   TopicSource, | ||||||
| } from '../GlobalSearchProvider/GlobalSearchSuggestions/GlobalSearchSuggestions.interface'; | } from '../GlobalSearchProvider/GlobalSearchSuggestions/GlobalSearchSuggestions.interface'; | ||||||
|  | import { useTourProvider } from '../TourProvider/TourProvider'; | ||||||
| 
 | 
 | ||||||
| type SuggestionProp = { | type SuggestionProp = { | ||||||
|   searchText: string; |   searchText: string; | ||||||
| @ -58,6 +59,7 @@ const Suggestions = ({ | |||||||
|   searchCriteria, |   searchCriteria, | ||||||
| }: SuggestionProp) => { | }: SuggestionProp) => { | ||||||
|   const { t } = useTranslation(); |   const { t } = useTranslation(); | ||||||
|  |   const { isTourOpen } = useTourProvider(); | ||||||
|   const [isLoading, setIsLoading] = useState<boolean>(true); |   const [isLoading, setIsLoading] = useState<boolean>(true); | ||||||
|   const [options, setOptions] = useState<Array<Option>>([]); |   const [options, setOptions] = useState<Array<Option>>([]); | ||||||
|   const [tableSuggestions, setTableSuggestions] = useState<TableSource[]>([]); |   const [tableSuggestions, setTableSuggestions] = useState<TableSource[]>([]); | ||||||
| @ -210,8 +212,10 @@ const Suggestions = ({ | |||||||
|   }, [searchText, searchCriteria]); |   }, [searchText, searchCriteria]); | ||||||
| 
 | 
 | ||||||
|   useEffect(() => { |   useEffect(() => { | ||||||
|     if (!isMounting.current && searchText) { |     if (!isMounting.current && searchText && !isTourOpen) { | ||||||
|       fetchSearchData(); |       fetchSearchData(); | ||||||
|  |     } else { | ||||||
|  |       setIsLoading(false); | ||||||
|     } |     } | ||||||
|   }, [searchText, searchCriteria]); |   }, [searchText, searchCriteria]); | ||||||
| 
 | 
 | ||||||
| @ -224,7 +228,7 @@ const Suggestions = ({ | |||||||
|     return <Loader />; |     return <Loader />; | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   if (options.length === 0) { |   if (options.length === 0 && !isTourOpen) { | ||||||
|     return ( |     return ( | ||||||
|       <Typography.Text> |       <Typography.Text> | ||||||
|         <Transi18next |         <Transi18next | ||||||
|  | |||||||
| @ -19,6 +19,7 @@ import { usePapaParse } from 'react-papaparse'; | |||||||
| import { ReactComponent as FailBadgeIcon } from '../../../assets/svg/fail-badge.svg'; | import { ReactComponent as FailBadgeIcon } from '../../../assets/svg/fail-badge.svg'; | ||||||
| import { ReactComponent as SuccessBadgeIcon } from '../../../assets/svg/success-badge.svg'; | import { ReactComponent as SuccessBadgeIcon } from '../../../assets/svg/success-badge.svg'; | ||||||
| import Table from '../../../components/common/Table/Table'; | import Table from '../../../components/common/Table/Table'; | ||||||
|  | import { GLOSSARY_IMPORT_STATUS } from '../../../constants/Glossary.constant'; | ||||||
| import { | import { | ||||||
|   CSVImportResult, |   CSVImportResult, | ||||||
|   Status, |   Status, | ||||||
| @ -53,15 +54,7 @@ export const GlossaryImportResult: FC<Props> = ({ csvImportResult }) => { | |||||||
|               data-testid="status-container" |               data-testid="status-container" | ||||||
|               // Added max width because in case of full success we don't want to occupied full width
 |               // Added max width because in case of full success we don't want to occupied full width
 | ||||||
|               style={{ maxWidth: 200 }}> |               style={{ maxWidth: 200 }}> | ||||||
|               {status === Status.Success && ( |               {status === Status.Failure ? ( | ||||||
|                 <SuccessBadgeIcon |  | ||||||
|                   className="m-t-xss" |  | ||||||
|                   data-testid="success-badge" |  | ||||||
|                   height={16} |  | ||||||
|                   width={16} |  | ||||||
|                 /> |  | ||||||
|               )} |  | ||||||
|               {status === Status.Failure && ( |  | ||||||
|                 <> |                 <> | ||||||
|                   <FailBadgeIcon |                   <FailBadgeIcon | ||||||
|                     className="m-t-xss" |                     className="m-t-xss" | ||||||
| @ -71,6 +64,13 @@ export const GlossaryImportResult: FC<Props> = ({ csvImportResult }) => { | |||||||
|                   /> |                   /> | ||||||
|                   {record.details} |                   {record.details} | ||||||
|                 </> |                 </> | ||||||
|  |               ) : ( | ||||||
|  |                 <SuccessBadgeIcon | ||||||
|  |                   className="m-t-xss" | ||||||
|  |                   data-testid="success-badge" | ||||||
|  |                   height={16} | ||||||
|  |                   width={16} | ||||||
|  |                 /> | ||||||
|               )} |               )} | ||||||
|             </Space> |             </Space> | ||||||
|           ); |           ); | ||||||
| @ -201,8 +201,7 @@ export const GlossaryImportResult: FC<Props> = ({ csvImportResult }) => { | |||||||
|               (value) => ({ |               (value) => ({ | ||||||
|                 ...value, |                 ...value, | ||||||
|                 key: value['name*'], |                 key: value['name*'], | ||||||
|                 status: |                 status: GLOSSARY_IMPORT_STATUS.includes(value['details'] ?? '') | ||||||
|                   value['details'] === 'Entity created' |  | ||||||
|                   ? Status.Success |                   ? Status.Success | ||||||
|                   : Status.Failure, |                   : Status.Failure, | ||||||
|               }) |               }) | ||||||
|  | |||||||
| @ -37,6 +37,7 @@ const TourEndModal = ({ onSave, visible }: TourEndModalProps) => { | |||||||
|         <Col className="mt-4" span={24}> |         <Col className="mt-4" span={24}> | ||||||
|           <SVGIcons |           <SVGIcons | ||||||
|             alt={t('label.open-metadata-logo')} |             alt={t('label.open-metadata-logo')} | ||||||
|  |             height="70" | ||||||
|             icon={Icons.LOGO_SMALL} |             icon={Icons.LOGO_SMALL} | ||||||
|             width="70" |             width="70" | ||||||
|           /> |           /> | ||||||
|  | |||||||
| @ -47,8 +47,9 @@ const Tour = ({ steps }: { steps: TourSteps[] }) => { | |||||||
|           accentColor={PRIMERY_COLOR} |           accentColor={PRIMERY_COLOR} | ||||||
|           inViewThreshold={200} |           inViewThreshold={200} | ||||||
|           lastStepNextButton={ |           lastStepNextButton={ | ||||||
|             <Button onClick={() => setShowTourEndModal(true)}> |             <Button | ||||||
|               <svg viewBox="0 0 18.4 14.4"> |               icon={ | ||||||
|  |                 <svg viewBox="0 0 18.4 14.4" width={16}> | ||||||
|                   <path |                   <path | ||||||
|                     d="M17 7.2H1M10.8 1 17 7.2l-6.2 6.2" |                     d="M17 7.2H1M10.8 1 17 7.2l-6.2 6.2" | ||||||
|                     fill="none" |                     fill="none" | ||||||
| @ -58,7 +59,10 @@ const Tour = ({ steps }: { steps: TourSteps[] }) => { | |||||||
|                     strokeWidth={2} |                     strokeWidth={2} | ||||||
|                   /> |                   /> | ||||||
|                 </svg> |                 </svg> | ||||||
|             </Button> |               } | ||||||
|  |               type="text" | ||||||
|  |               onClick={() => setShowTourEndModal(true)} | ||||||
|  |             /> | ||||||
|           } |           } | ||||||
|           maskColor="#302E36" |           maskColor="#302E36" | ||||||
|           playTour={isTourOpen} |           playTour={isTourOpen} | ||||||
|  | |||||||
| @ -0,0 +1,13 @@ | |||||||
|  | /* | ||||||
|  |  *  Copyright 2023 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. | ||||||
|  |  */ | ||||||
|  | export const GLOSSARY_IMPORT_STATUS = ['Entity created', 'Entity updated']; | ||||||
| @ -11,6 +11,8 @@ | |||||||
|  *  limitations under the License. |  *  limitations under the License. | ||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
|  | import { SearchIndex } from '../enums/search.enum'; | ||||||
|  | 
 | ||||||
| /* eslint-disable max-len */ | /* eslint-disable max-len */ | ||||||
| 
 | 
 | ||||||
| export const MOCK_ASSETS_COUNTS = { | export const MOCK_ASSETS_COUNTS = { | ||||||
| @ -1913,3 +1915,17 @@ export const mockSearchData = { | |||||||
|     }, |     }, | ||||||
|   }, |   }, | ||||||
| }; | }; | ||||||
|  | 
 | ||||||
|  | export const MOCK_EXPLORE_PAGE_COUNT = { | ||||||
|  |   [SearchIndex.TABLE]: mockSearchData.hits.total.value, | ||||||
|  |   [SearchIndex.TOPIC]: 0, | ||||||
|  |   [SearchIndex.DASHBOARD]: 0, | ||||||
|  |   [SearchIndex.PIPELINE]: 0, | ||||||
|  |   [SearchIndex.MLMODEL]: 0, | ||||||
|  |   [SearchIndex.CONTAINER]: 0, | ||||||
|  |   [SearchIndex.STORED_PROCEDURE]: 0, | ||||||
|  |   [SearchIndex.DASHBOARD_DATA_MODEL]: 0, | ||||||
|  |   [SearchIndex.GLOSSARY]: 0, | ||||||
|  |   [SearchIndex.TAG]: 0, | ||||||
|  |   [SearchIndex.SEARCH_INDEX]: 0, | ||||||
|  | }; | ||||||
|  | |||||||
| @ -970,7 +970,7 @@ | |||||||
|     "table-entity-text": "Tabelle {{entityText}}", |     "table-entity-text": "Tabelle {{entityText}}", | ||||||
|     "table-lowercase": "tabelle", |     "table-lowercase": "tabelle", | ||||||
|     "table-lowercase-plural": "tabellen", |     "table-lowercase-plural": "tabellen", | ||||||
|     "table-partitioned": "Tabelle partitioniert", |     "table-partitioned": "Table Partitioned", | ||||||
|     "table-plural": "Tabellen", |     "table-plural": "Tabellen", | ||||||
|     "table-profile": "Tabellenprofil", |     "table-profile": "Tabellenprofil", | ||||||
|     "table-tests-summary": "Tabellentestzusammenfassung", |     "table-tests-summary": "Tabellentestzusammenfassung", | ||||||
|  | |||||||
| @ -42,7 +42,10 @@ import { | |||||||
|   INITIAL_SORT_FIELD, |   INITIAL_SORT_FIELD, | ||||||
|   tabsInfo, |   tabsInfo, | ||||||
| } from '../../constants/explore.constants'; | } from '../../constants/explore.constants'; | ||||||
| import { mockSearchData } from '../../constants/mockTourData.constants'; | import { | ||||||
|  |   mockSearchData, | ||||||
|  |   MOCK_EXPLORE_PAGE_COUNT, | ||||||
|  | } from '../../constants/mockTourData.constants'; | ||||||
| import { SORT_ORDER } from '../../enums/common.enum'; | import { SORT_ORDER } from '../../enums/common.enum'; | ||||||
| import { SearchIndex } from '../../enums/search.enum'; | import { SearchIndex } from '../../enums/search.enum'; | ||||||
| import { Aggregations, SearchResponse } from '../../interface/search.interface'; | import { Aggregations, SearchResponse } from '../../interface/search.interface'; | ||||||
| @ -286,7 +289,7 @@ const ExplorePageV1: FunctionComponent = () => { | |||||||
|     } |     } | ||||||
|   }, [parsedSearch]); |   }, [parsedSearch]); | ||||||
| 
 | 
 | ||||||
|   useEffect(() => { |   const fetchEntityCount = () => { | ||||||
|     const updatedQuickFilters = getAdvancedSearchQuickFilters(); |     const updatedQuickFilters = getAdvancedSearchQuickFilters(); | ||||||
| 
 | 
 | ||||||
|     const combinedQueryFilter = getCombinedQueryFilterObject( |     const combinedQueryFilter = getCombinedQueryFilterObject( | ||||||
| @ -379,6 +382,14 @@ const ExplorePageV1: FunctionComponent = () => { | |||||||
|         showErrorToast(err); |         showErrorToast(err); | ||||||
|       }) |       }) | ||||||
|       .finally(() => setIsLoading(false)); |       .finally(() => setIsLoading(false)); | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   useEffect(() => { | ||||||
|  |     if (isTourOpen) { | ||||||
|  |       setSearchHitCounts(MOCK_EXPLORE_PAGE_COUNT); | ||||||
|  |     } else { | ||||||
|  |       fetchEntityCount(); | ||||||
|  |     } | ||||||
|   }, [ |   }, [ | ||||||
|     parsedSearch.quickFilter, |     parsedSearch.quickFilter, | ||||||
|     queryFilter, |     queryFilter, | ||||||
| @ -419,7 +430,7 @@ const ExplorePageV1: FunctionComponent = () => { | |||||||
|       showDeleted={showDeleted} |       showDeleted={showDeleted} | ||||||
|       sortOrder={sortOrder} |       sortOrder={sortOrder} | ||||||
|       sortValue={sortValue} |       sortValue={sortValue} | ||||||
|       tabCounts={searchHitCounts} |       tabCounts={isTourOpen ? MOCK_EXPLORE_PAGE_COUNT : searchHitCounts} | ||||||
|       tabItems={tabItems} |       tabItems={tabItems} | ||||||
|       onChangeAdvancedSearchQuickFilters={handleAdvanceSearchQuickFiltersChange} |       onChangeAdvancedSearchQuickFilters={handleAdvanceSearchQuickFiltersChange} | ||||||
|       onChangePage={handlePageChange} |       onChangePage={handlePageChange} | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Shailesh Parmar
						Shailesh Parmar