|
1 | 1 | import React, {useState} from 'react'; |
2 | 2 | import {Animated} from 'react-native'; |
3 | 3 | import PressableWithFeedback from '@components/Pressable/PressableWithFeedback'; |
| 4 | +import Tooltip from '@components/Tooltip'; |
4 | 5 | import useThemeStyles from '@hooks/useThemeStyles'; |
5 | 6 | import CONST from '@src/CONST'; |
6 | 7 | import type IconAsset from '@src/types/utils/IconAsset'; |
@@ -49,29 +50,34 @@ function TabSelectorItem({ |
49 | 50 | const [isHovered, setIsHovered] = useState(false); |
50 | 51 |
|
51 | 52 | return ( |
52 | | - <AnimatedPressableWithFeedback |
53 | | - accessibilityLabel={title} |
54 | | - style={[styles.tabSelectorButton, styles.tabBackground(isHovered, isActive, backgroundColor), styles.userSelectNone]} |
55 | | - wrapperStyle={[styles.flexGrow1]} |
56 | | - onPress={onPress} |
57 | | - onHoverIn={() => setIsHovered(true)} |
58 | | - onHoverOut={() => setIsHovered(false)} |
59 | | - role={CONST.ROLE.BUTTON} |
60 | | - dataSet={{[CONST.SELECTION_SCRAPER_HIDDEN_ELEMENT]: true}} |
| 53 | + <Tooltip |
| 54 | + shouldRender={!shouldShowLabelWhenInactive && !isActive} |
| 55 | + text={title} |
61 | 56 | > |
62 | | - <TabIcon |
63 | | - icon={icon} |
64 | | - activeOpacity={styles.tabOpacity(isHovered, isActive, activeOpacity, inactiveOpacity).opacity} |
65 | | - inactiveOpacity={styles.tabOpacity(isHovered, isActive, inactiveOpacity, activeOpacity).opacity} |
66 | | - /> |
67 | | - {(shouldShowLabelWhenInactive || isActive) && ( |
68 | | - <TabLabel |
69 | | - title={title} |
| 57 | + <AnimatedPressableWithFeedback |
| 58 | + accessibilityLabel={title} |
| 59 | + style={[styles.tabSelectorButton, styles.tabBackground(isHovered, isActive, backgroundColor), styles.userSelectNone]} |
| 60 | + wrapperStyle={[styles.flexGrow1]} |
| 61 | + onPress={onPress} |
| 62 | + onHoverIn={() => setIsHovered(true)} |
| 63 | + onHoverOut={() => setIsHovered(false)} |
| 64 | + role={CONST.ROLE.BUTTON} |
| 65 | + dataSet={{[CONST.SELECTION_SCRAPER_HIDDEN_ELEMENT]: true}} |
| 66 | + > |
| 67 | + <TabIcon |
| 68 | + icon={icon} |
70 | 69 | activeOpacity={styles.tabOpacity(isHovered, isActive, activeOpacity, inactiveOpacity).opacity} |
71 | 70 | inactiveOpacity={styles.tabOpacity(isHovered, isActive, inactiveOpacity, activeOpacity).opacity} |
72 | 71 | /> |
73 | | - )} |
74 | | - </AnimatedPressableWithFeedback> |
| 72 | + {(shouldShowLabelWhenInactive || isActive) && ( |
| 73 | + <TabLabel |
| 74 | + title={title} |
| 75 | + activeOpacity={styles.tabOpacity(isHovered, isActive, activeOpacity, inactiveOpacity).opacity} |
| 76 | + inactiveOpacity={styles.tabOpacity(isHovered, isActive, inactiveOpacity, activeOpacity).opacity} |
| 77 | + /> |
| 78 | + )} |
| 79 | + </AnimatedPressableWithFeedback> |
| 80 | + </Tooltip> |
75 | 81 | ); |
76 | 82 | } |
77 | 83 |
|
|
0 commit comments