From 16d29cf8665a25d1237525c541cfc4f5574dbb30 Mon Sep 17 00:00:00 2001 From: WayneKim92 Date: Thu, 29 Aug 2024 20:45:32 +0900 Subject: [PATCH 1/2] feat: show or hide by visible prop --- example/src/App.tsx | 71 +++++++++++++++++++++++++++++++++++++-------- src/index.tsx | 29 ++++++++---------- 2 files changed, 71 insertions(+), 29 deletions(-) diff --git a/example/src/App.tsx b/example/src/App.tsx index e14c119..473bb21 100644 --- a/example/src/App.tsx +++ b/example/src/App.tsx @@ -3,7 +3,13 @@ import Tooltip from 'react-native-good-tooltip'; import { useState } from 'react'; export default function App() { - const [inputText, setInputText] = useState('초기 텍스트'); + // Example - TextInput + const [inputText, setInputText] = useState(''); + const [tooltipMessage, setTooltipMessage] = useState('Hello'); + const [isFocused, setIsFocused] = useState(false); + + // Example - FlatList + // const data = [1, 2, 3]; return ( @@ -66,27 +72,68 @@ export default function App() { - + { + setInputText(text); + if (text.toLowerCase() === 'world') { + setTooltipMessage('Correct!'); + setTimeout(() => { + setIsFocused(false); + }, 1500); + } + }} + style={{ padding: 16, backgroundColor: 'gray', color: 'white' }} + onFocus={() => setIsFocused(true)} + onBlur={() => { + setIsFocused(false); + }} /> {/* {*/} + {/* data={data}*/} + {/* keyExtractor={(item) => item.toString()}*/} + {/* CellRendererComponent={({ index, style, ...props }) => {*/} {/* return (*/} - {/* */} {/* );*/} {/* }}*/} + {/* renderItem={() => {*/} + {/* console.log('####################################');*/} + {/* console.log('리렌더링?');*/} + {/* console.log('####################################');*/} + {/* return (*/} + {/* */} + {/* */} + {/* */} + {/* );*/} + {/* }}*/} {/*/>*/} ); diff --git a/src/index.tsx b/src/index.tsx index da128c3..bc3a300 100644 --- a/src/index.tsx +++ b/src/index.tsx @@ -1,10 +1,4 @@ -import React, { - useCallback, - useEffect, - useMemo, - useRef, - useState, -} from 'react'; +import React, { useCallback, useEffect, useMemo, useState } from 'react'; import { Animated, Dimensions, @@ -65,6 +59,7 @@ interface ToolTipProps { onVisibleChange?: (isVisible: boolean) => void; delayShowTime?: number; autoHideTime?: number; + disableAutoHide?: boolean; } const Tooltip = ({ @@ -84,9 +79,8 @@ const Tooltip = ({ onVisibleChange, delayShowTime = 0, autoHideTime = 5000, + disableAutoHide, }: ToolTipProps) => { - const showAnimationRef = useRef(false); - const hideAnimationRef = useRef(false); const animatedValue = useMemo(() => new Animated.Value(0), []); const [tooltipPosition, setTooltipPosition] = useState({ @@ -120,8 +114,6 @@ const Tooltip = ({ const runAnimation = useCallback( (isShowAnimation: boolean) => { if (isShowAnimation) { - if (showAnimationRef.current) return; - Animated.spring(animatedValue, { toValue: 1, speed: 6, @@ -129,10 +121,7 @@ const Tooltip = ({ }).start(() => { onVisibleChange && onVisibleChange(true); }); - showAnimationRef.current = true; } else { - if (hideAnimationRef.current) return; - Animated.timing(animatedValue, { toValue: 0, duration: 300, @@ -140,7 +129,6 @@ const Tooltip = ({ }).start(() => { onVisibleChange && onVisibleChange(false); }); - hideAnimationRef.current = true; } }, [animatedValue, onVisibleChange] @@ -159,12 +147,19 @@ const Tooltip = ({ // hide animation useEffect(() => { - if (onPress) return; + if (onPress || disableAutoHide) return; setTimeout(() => { runAnimation(false); }, delayShowTime + autoHideTime); - }, [autoHideTime, delayShowTime, onPress, runAnimation]); + }, [autoHideTime, delayShowTime, disableAutoHide, onPress, runAnimation]); + + // hide by props.visible + useEffect(() => { + if (visible === false) { + runAnimation(false); + } + }, [runAnimation, visible]); const handleVerticalTooltipLayout = (event: LayoutChangeEvent) => { const { width, height } = event.nativeEvent.layout; From d65f4eb4042042002f92c15551772e40c78ac293 Mon Sep 17 00:00:00 2001 From: Wayne <75321423+WayneKim92@users.noreply.github.com> Date: Thu, 29 Aug 2024 23:18:03 +0900 Subject: [PATCH 2/2] Example in flat list or scroll view (#7) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * feat: 눌러서 닫기 작동 안 할 수 있게 props 추가 * chore: add Example * chore: 조금 더 다양한 상황 고려하여 수정 * docs: 변경점 고려하여 문서 업데이트 * docs: 변경점 고려하여 문서 업데이트 --- README.md | 36 +++++++++-------- example/src/App.tsx | 95 ++++++++++++++++++++++++++++----------------- src/index.tsx | 22 ++++++++++- 3 files changed, 99 insertions(+), 54 deletions(-) diff --git a/README.md b/README.md index 30a72c8..0518322 100644 --- a/README.md +++ b/README.md @@ -37,7 +37,7 @@ import Tooltip from 'react-native-good-tooltip';
-
@@ -46,22 +46,24 @@ import Tooltip from 'react-native-good-tooltip'; ## Props -| Prop | Type | Default | Description | -|------------------------|----------------------------------------------------------------------|----------------------------------------|-----------------------------------------------------------------------------------------------| -| `placement` | `'top' \| 'bottom' \| 'left' \| 'right'` | **required** | The position of the tooltip relative to the anchor. | -| `anchor` | `'center' \| 'left' \| 'right' \| 'top' \| 'bottom'` | `'center'` | The alignment of the tooltip relative to the anchor. | -| `text` | `string \| React.ReactElement` | **required** | The content of the tooltip. | -| `isVisible` | `boolean` | **required** | Whether the tooltip is visible. | -| `offset` | `{ position?: { x?: number, y?: number }, arrow?: { x?: number, y?: number } }` | `undefined` | The offset for the tooltip and arrow position. | -| `arrowElement` | `React.ReactElement` | `undefined` | Custom arrow element. | -| `styles` | `{color?: ColorValue,containerStyle?: ViewStyle,tooltipStyle?: ViewStyle,arrowSize?: { width?: number, height?: number },closeSize?: { width?: number, height?: number} }` | `undefined` | Custom styles for the tooltip. | -| `children` | `React.ReactElement` | `undefined` | The element to which the tooltip is anchored. | -| `onPress` | `() => void` | `undefined` | Function to call when the tooltip is pressed. | -| `onVisibleChange` | `(isVisible: boolean) => void` | `undefined` | Function to call when the visibility of the tooltip changes. | -| `disableAutoHide` | `boolean` | `false` | Whether to disable the auto-hide feature. | -| `delayShowTime` | `number` | `0` | The delay time before showing the tooltip. | -| `autoHideTime` | `number` | `5000` | The time after which the tooltip will automatically hide. | -| `requiredConfirmation` | `boolean` | `false` | Whether the tooltip requires confirmation to hide. | +| Prop | Type | Default | Description | +|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|-----------------------------------------------------------------------------------------------| +| `visible` | `boolean` | `undefined` | Whether the tooltip is visible. | +| `rerenderKey` | `any` | `undefined` | Key to force re-rendering of the tooltip. | +| `placement` | `'top' \| 'bottom' \| 'left' \| 'right'` | **required** | The position of the tooltip relative to the anchor. | +| `anchor` | `'center' \| 'left' \| 'right' \| 'top' \| 'bottom'` | `'center'` | The alignment of the tooltip relative to the anchor. | +| `offset` | `{ position?: { x?: number, y?: number }, arrow?: { x?: number, y?: number } }` | `undefined` | The offset for the tooltip and arrow position. | +| `arrowElement` | `React.ReactElement` | `undefined` | Custom arrow element. | +| `styles` | `{color?: ColorValue \| 'primary', containerStyle?: ViewStyle, tooltipStyle?: ViewStyle, arrowSize?: { width?: number, height?: number }, closeSize?: { width?: number, height?: number} }` | `undefined` | Custom styles for the tooltip. | +| `text` | `string \| React.ReactElement` | **required** | The content of the tooltip. | +| `children` | `React.ReactElement` | `undefined` | The element to which the tooltip is anchored. | +| `onPress` | `() => void` | `undefined` | Function to call when the tooltip is pressed. | +| `onVisibleChange` | `(isVisible: boolean) => void` | `undefined` | Function to call when the visibility of the tooltip changes. | +| `delayShowTime` | `number` | `0` | The delay time before showing the tooltip. | +| `autoHideTime` | `number` | `5000` | The time after which the tooltip will automatically hide. | +| `disableAutoHide` | `boolean` | `false` | Whether to disable the auto-hide feature. | +| `disablePressToClose` | `boolean` | `false` | Whether to disable the press-to-close feature. | +| `numberOfLines` | `number` | `2` | The number of lines to display in the tooltip text. | ## Contributing diff --git a/example/src/App.tsx b/example/src/App.tsx index 473bb21..e6a61fb 100644 --- a/example/src/App.tsx +++ b/example/src/App.tsx @@ -1,4 +1,12 @@ -import { SafeAreaView, StyleSheet, Text, View, TextInput } from 'react-native'; +import { + SafeAreaView, + StyleSheet, + Text, + View, + TextInput, + ScrollView, + FlatList, +} from 'react-native'; import Tooltip from 'react-native-good-tooltip'; import { useState } from 'react'; @@ -8,8 +16,8 @@ export default function App() { const [tooltipMessage, setTooltipMessage] = useState('Hello'); const [isFocused, setIsFocused] = useState(false); - // Example - FlatList - // const data = [1, 2, 3]; + // Example - ScrollView and FlatList + const [inputTextInScrollVIew, setInputTextInScrollVIew] = useState(''); return ( @@ -103,38 +111,55 @@ export default function App() { /> - {/* item.toString()}*/} - {/* CellRendererComponent={({ index, style, ...props }) => {*/} - {/* return (*/} - {/* */} - {/* );*/} - {/* }}*/} - {/* renderItem={() => {*/} - {/* console.log('####################################');*/} - {/* console.log('리렌더링?');*/} - {/* console.log('####################################');*/} - {/* return (*/} - {/* */} - {/* */} - {/* */} - {/* );*/} - {/* }}*/} - {/*/>*/} + + + ( + + + + + + )} + /> + + + + + + + + + + ); } diff --git a/src/index.tsx b/src/index.tsx index bc3a300..880c7f7 100644 --- a/src/index.tsx +++ b/src/index.tsx @@ -60,6 +60,8 @@ interface ToolTipProps { delayShowTime?: number; autoHideTime?: number; disableAutoHide?: boolean; + disablePressToClose?: boolean; + numberOfLines?: number; } const Tooltip = ({ @@ -80,6 +82,8 @@ const Tooltip = ({ delayShowTime = 0, autoHideTime = 5000, disableAutoHide, + disablePressToClose = true, + numberOfLines = 2, }: ToolTipProps) => { const animatedValue = useMemo(() => new Animated.Value(0), []); @@ -283,7 +287,7 @@ const Tooltip = ({ { - if (!onPress) { + if (!disablePressToClose) { return; } @@ -306,7 +310,21 @@ const Tooltip = ({ ) : ( { + if (numberOfLines > 0) { + return numberOfLines; + } + + if ( + numberOfLines < 0 || + numberOfLines === null || + numberOfLines === undefined + ) { + return undefined; + } + + return 2; + })()} children={text} /> )}