Tooltiplize is a fast and fully customizable tooltip component for iOS, Android, and web.
Based on react-native-reanimated v2, framer-motion, and @gorhom/portal.
See Also:
How to use it:
1. Installation.
# Yarn $ yarn add react-native-tooltiplize # NPM $ npm i react-native-tooltiplize
2. Basic usage.
import { PortalProvider } from '@gorhom/portal'; const App = () => { return ( <PortalProvider> <App /> </PortalProvider> ); };
import React from 'react'; import Tooltip from 'react-native-tooltiplize'; import { PortalProvider } from '@gorhom/portal'; import { View, TouchableOpacity, StyleSheet, Text } from 'react-native'; const App = () => { const [isVisible, toggle] = React.useReducer((state) => !state, false); const renderContent = React.useCallback(() => { return ( <TouchableOpacity style={styles.tooltipContainer} onPress={toggle}> <Text style={styles.tooltipText}> Welcome to React Native Tooltiplize 🥳 </Text> </TouchableOpacity> ); }, []); return ( <View style={styles.container}> <Tooltip position="top" offset={8} renderContent={renderContent} isVisible={isVisible} withOverlay onDismiss={toggle} pointerStyle={styles.pointer} pointerColor="green" > <TouchableOpacity onPress={toggle} style={styles.newFeature}> <Text style={styles.newFeatureText}>This is new cool feature</Text> </TouchableOpacity> </Tooltip> </View> ); }; export default App; const styles = StyleSheet.create({ container: { flex: 1, justifyContent: 'center', alignItems: 'center', }, tooltipContainer: { paddingHorizontal: 16, paddingVertical: 8, borderRadius: 8, shadowColor: '#000', shadowOffset: { width: 0, height: 2, }, shadowOpacity: 0.1, shadowRadius: 12, elevation: 5, backgroundColor: 'green', }, tooltipText: { fontSize: 12, color: 'white', }, pointer: { width: 16, height: 8 }, newFeature: { backgroundColor: 'white', padding: 16, borderRadius: 8, }, newFeatureText: { fontSize: 16, }, });
Preview:
Download Details:
Author: Stringsaeed
Live Demo: View The Demo
Download Link: Download The Source Code
Official Website: https://github.com/Stringsaeed/react-native-tooltiplize
License: MIT