👾 This library is for you - if you want to detect when the user closed the app last time and how long it took to open it again.👾
Screen.Recording.2024-07-03.at.2.57.24.PM.mov
npm install react-native-inactive-time
# or...
yarn add react-native-inactive-time
This library uses AsyncStorage, so it will be good to install it too.
yarn add @react-native-async-storage/async-storage
# or...
npm install @react-native-async-storage/async-storage
Make sure useInactivityListener() is accessible from the whole app, add it in App.js or maybe RootNavigator.
import useInactivityListener from 'react-native-inactive-time';
import CustomText from './CustomText';
export default function App() {
const { elapsedTime, formattedTime } = useInactivityListener();
return (
<View style={styles.container}>
<CustomText />
<Text>Elapsed Time: {elapsedTime}</Text>
<Text>Formatted Time: {formattedTime}</Text>
</View>
);
}
useInactivityListener is a onetime listener, so that means after when you kill the app, elapsedTime
and formattedTime
extracted from useInactivityListener()
may be null
. For that, we have another method: getElapsedTime()
import { getElapsedTime, type ITime } from 'react-native-inactive-time';
const CustomText = () => {
const [elapsedTime, setElapsedTime] = useState<ITime>(null);
useEffect(() => {
onMount();
}, []);
const onMount = async () => {
const elapsedTime = await getElapsedTime();
setElapsedTime(elapsedTime);
};
return (
<View>
<Text>Using UseEffect: {elapsedTime}</Text>
</View>
);
};
Prop | Description | Return Type |
---|---|---|
useInactivityListener() |
REQUIRED Method which should be defined at the top component, can also extend elapsed time and formatted time | void |
getElapsedTime() |
method to use inside hooks | number |
elapsedTime |
time difference from last close to last open in milliseconds | number |
formattedTime |
formatted time difference from last close to last open | string |
Library is beta version right now. I want to add tests and get some user feedback to make it more user friendly, so I appreciate all your comments and feedback.
LinkediIn: Elene Botchoradze
Email: [email protected]
See the contributing guide to learn how to contribute to the repository and the development workflow.
MIT
Made with create-react-native-library