import { RouteProp, useFocusEffect, useNavigation, useRoute, } from '@react-navigation/native'; import React, {useCallback, useContext} from 'react'; import {NativeModules, View} from 'react-native'; import {IconButton} from 'react-native-paper'; import {SnackbarContext} from './App'; import {addSet, getSettings, setSet} from './db'; import {HomePageParams} from './HomePage'; import Set from './set'; import SetForm from './SetForm'; export default function EditSet() { const {params} = useRoute>(); const navigation = useNavigation(); const {toast} = useContext(SnackbarContext); useFocusEffect( useCallback(() => { navigation.getParent()?.setOptions({ headerLeft: () => ( navigation.goBack()} /> ), headerRight: null, title: params.set.id ? 'Edit set' : 'Create set', }); }, [navigation, params.set.id]), ); const startTimer = useCallback(async () => { const settings = await getSettings(); if (!settings.alarm) return; const milliseconds = settings.minutes * 60 * 1000 + settings.seconds * 1000; NativeModules.AlarmModule.timer( milliseconds, !!settings.vibrate, settings.sound, ); }, []); const update = useCallback( async (set: Set) => { console.log(`${EditSet.name}.update`, set); await setSet(set); navigation.goBack(); }, [navigation], ); const add = useCallback( async (set: Set) => { startTimer(); await addSet(set); const settings = await getSettings(); if (settings.notify === 0) return navigation.goBack(); if ( set.weight > params.set.weight || (set.reps > params.set.reps && set.weight === params.set.weight) ) toast("Great work King, that's a new record!", 3000); navigation.goBack(); }, [navigation, startTimer, params.set, toast], ); const save = useCallback( async (set: Set) => { if (params.set.id) return update(set); return add(set); }, [update, add, params.set.id], ); return ( ); }