2022-07-03 01:50:01 +00:00
|
|
|
import AsyncStorage from '@react-native-async-storage/async-storage';
|
2022-07-19 04:24:16 +00:00
|
|
|
import React, {useCallback, useEffect, useState} from 'react';
|
2022-07-09 07:39:11 +00:00
|
|
|
import {
|
|
|
|
NativeModules,
|
|
|
|
StyleSheet,
|
|
|
|
Text,
|
2022-07-19 04:24:16 +00:00
|
|
|
ToastAndroid,
|
2022-07-09 07:39:11 +00:00
|
|
|
View,
|
|
|
|
} from 'react-native';
|
2022-07-19 04:24:16 +00:00
|
|
|
import {TextInput} from 'react-native-paper';
|
2022-07-10 23:26:45 +00:00
|
|
|
import ConfirmDialog from './ConfirmDialog';
|
2022-07-17 01:45:31 +00:00
|
|
|
import MassiveSwitch from './MassiveSwitch';
|
2022-07-03 01:50:01 +00:00
|
|
|
|
2022-07-08 03:45:24 +00:00
|
|
|
const {getItem, setItem} = AsyncStorage;
|
|
|
|
|
2022-07-08 03:20:03 +00:00
|
|
|
export default function SettingsPage() {
|
2022-08-20 04:37:59 +00:00
|
|
|
const [vibrate, setVibrate] = useState(true);
|
2022-07-03 01:50:01 +00:00
|
|
|
const [minutes, setMinutes] = useState<string>('');
|
2022-07-10 07:03:07 +00:00
|
|
|
const [maxSets, setMaxSets] = useState<string>('3');
|
2022-07-03 01:50:01 +00:00
|
|
|
const [seconds, setSeconds] = useState<string>('');
|
2022-08-20 04:37:59 +00:00
|
|
|
const [alarm, setAlarm] = useState<boolean>(false);
|
|
|
|
const [predictive, setPredictive] = useState<boolean>(false);
|
|
|
|
const [battery, setBattery] = useState(false);
|
2022-07-07 00:45:45 +00:00
|
|
|
const [ignoring, setIgnoring] = useState(false);
|
2022-07-03 01:50:01 +00:00
|
|
|
|
2022-07-09 07:39:11 +00:00
|
|
|
const refresh = useCallback(async () => {
|
2022-07-08 03:51:10 +00:00
|
|
|
setMinutes((await getItem('minutes')) || '');
|
2022-07-08 03:45:24 +00:00
|
|
|
setSeconds((await getItem('seconds')) || '');
|
2022-08-20 04:37:59 +00:00
|
|
|
setAlarm((await getItem('alarmEnabled')) === 'true');
|
|
|
|
setPredictive((await getItem('predictiveSets')) === 'true');
|
2022-07-10 07:03:07 +00:00
|
|
|
setMaxSets((await getItem('maxSets')) || '');
|
2022-07-19 04:38:58 +00:00
|
|
|
NativeModules.AlarmModule.ignoringBattery(setIgnoring);
|
2022-07-10 07:03:07 +00:00
|
|
|
}, []);
|
2022-07-07 00:45:45 +00:00
|
|
|
|
2022-07-07 03:13:44 +00:00
|
|
|
useEffect(() => {
|
2022-07-07 00:45:45 +00:00
|
|
|
refresh();
|
2022-07-09 07:39:11 +00:00
|
|
|
}, [refresh]);
|
2022-07-03 01:50:01 +00:00
|
|
|
|
2022-07-09 07:39:11 +00:00
|
|
|
const changeAlarmEnabled = useCallback(
|
|
|
|
(enabled: boolean) => {
|
2022-08-20 04:37:59 +00:00
|
|
|
setAlarm(enabled);
|
|
|
|
if (enabled && !ignoring) setBattery(true);
|
2022-07-09 07:39:11 +00:00
|
|
|
setItem('alarmEnabled', enabled ? 'true' : 'false');
|
|
|
|
},
|
2022-08-20 04:37:59 +00:00
|
|
|
[setBattery, ignoring],
|
2022-07-09 07:39:11 +00:00
|
|
|
);
|
2022-07-06 09:03:56 +00:00
|
|
|
|
2022-07-10 05:53:38 +00:00
|
|
|
const changePredictive = useCallback(
|
|
|
|
(enabled: boolean) => {
|
2022-08-20 04:37:59 +00:00
|
|
|
setPredictive(enabled);
|
2022-07-10 05:53:38 +00:00
|
|
|
setItem('predictiveSets', enabled ? 'true' : 'false');
|
2022-07-19 04:24:16 +00:00
|
|
|
ToastAndroid.show(
|
|
|
|
'Predictive sets guess whats next based on todays plan.',
|
|
|
|
ToastAndroid.LONG,
|
|
|
|
);
|
2022-07-10 05:53:38 +00:00
|
|
|
},
|
2022-08-20 04:37:59 +00:00
|
|
|
[setPredictive],
|
2022-07-10 05:53:38 +00:00
|
|
|
);
|
|
|
|
|
2022-08-20 04:37:59 +00:00
|
|
|
const textInputs = (
|
|
|
|
<>
|
2022-07-03 01:50:01 +00:00
|
|
|
<TextInput
|
2022-07-04 04:03:48 +00:00
|
|
|
label="Rest minutes"
|
2022-07-03 01:50:01 +00:00
|
|
|
value={minutes}
|
|
|
|
keyboardType="numeric"
|
|
|
|
placeholder="3"
|
2022-07-08 03:46:48 +00:00
|
|
|
onChangeText={text => {
|
2022-07-08 03:45:24 +00:00
|
|
|
setMinutes(text);
|
2022-07-08 03:46:48 +00:00
|
|
|
setItem('minutes', text);
|
2022-07-08 03:45:24 +00:00
|
|
|
}}
|
2022-07-04 04:17:29 +00:00
|
|
|
style={styles.text}
|
2022-08-20 04:37:59 +00:00
|
|
|
selectTextOnFocus
|
2022-07-03 01:50:01 +00:00
|
|
|
/>
|
|
|
|
<TextInput
|
2022-07-04 04:03:48 +00:00
|
|
|
label="Rest seconds"
|
2022-07-03 01:50:01 +00:00
|
|
|
value={seconds}
|
|
|
|
keyboardType="numeric"
|
|
|
|
placeholder="30"
|
2022-07-09 01:27:19 +00:00
|
|
|
onChangeText={s => {
|
|
|
|
setSeconds(s);
|
|
|
|
setItem('seconds', s);
|
2022-07-08 03:45:24 +00:00
|
|
|
}}
|
2022-07-04 04:17:29 +00:00
|
|
|
style={styles.text}
|
2022-08-20 04:37:59 +00:00
|
|
|
selectTextOnFocus
|
2022-07-03 01:50:01 +00:00
|
|
|
/>
|
2022-07-10 07:03:07 +00:00
|
|
|
<TextInput
|
2022-07-21 01:54:53 +00:00
|
|
|
label="Sets per workout"
|
2022-07-10 07:03:07 +00:00
|
|
|
value={maxSets}
|
|
|
|
keyboardType="numeric"
|
|
|
|
onChangeText={value => {
|
|
|
|
setMaxSets(value);
|
|
|
|
setItem('maxSets', value);
|
|
|
|
}}
|
|
|
|
style={styles.text}
|
2022-08-20 04:37:59 +00:00
|
|
|
selectTextOnFocus
|
2022-07-10 07:03:07 +00:00
|
|
|
/>
|
2022-08-20 04:37:59 +00:00
|
|
|
</>
|
|
|
|
);
|
|
|
|
|
|
|
|
const changeVibrate = useCallback(
|
|
|
|
(value: boolean) => {
|
|
|
|
setVibrate(value);
|
|
|
|
setItem('vibrate', value ? 'true' : 'false');
|
|
|
|
},
|
|
|
|
[setVibrate],
|
|
|
|
);
|
2022-07-10 07:03:07 +00:00
|
|
|
|
2022-08-20 04:37:59 +00:00
|
|
|
return (
|
|
|
|
<View style={styles.container}>
|
|
|
|
{textInputs}
|
2022-07-06 10:02:43 +00:00
|
|
|
<Text style={styles.text}>Rest timers</Text>
|
2022-07-17 01:45:31 +00:00
|
|
|
<MassiveSwitch
|
2022-07-04 04:17:29 +00:00
|
|
|
style={[styles.text, {alignSelf: 'flex-start'}]}
|
2022-08-20 04:37:59 +00:00
|
|
|
value={alarm}
|
2022-07-06 09:03:56 +00:00
|
|
|
onValueChange={changeAlarmEnabled}
|
2022-07-03 01:50:01 +00:00
|
|
|
/>
|
2022-08-20 04:37:59 +00:00
|
|
|
<Text style={styles.text}>Vibrate</Text>
|
|
|
|
<MassiveSwitch
|
|
|
|
style={[styles.text, {alignSelf: 'flex-start'}]}
|
|
|
|
value={vibrate}
|
|
|
|
onValueChange={changeVibrate}
|
|
|
|
/>
|
2022-07-10 23:26:45 +00:00
|
|
|
<ConfirmDialog
|
|
|
|
title="Battery optimizations"
|
2022-08-20 04:37:59 +00:00
|
|
|
show={battery}
|
|
|
|
setShow={setBattery}
|
2022-07-10 23:26:45 +00:00
|
|
|
onOk={() => {
|
2022-07-19 04:38:58 +00:00
|
|
|
NativeModules.AlarmModule.openSettings();
|
2022-08-20 04:37:59 +00:00
|
|
|
setBattery(false);
|
2022-07-10 23:26:45 +00:00
|
|
|
}}>
|
|
|
|
Disable battery optimizations for Massive to use rest timers.
|
|
|
|
</ConfirmDialog>
|
2022-07-10 05:53:38 +00:00
|
|
|
<Text style={styles.text}>Predictive sets</Text>
|
2022-07-17 01:45:31 +00:00
|
|
|
<MassiveSwitch
|
2022-07-10 05:53:38 +00:00
|
|
|
style={[styles.text, {alignSelf: 'flex-start'}]}
|
2022-08-20 04:37:59 +00:00
|
|
|
value={predictive}
|
2022-07-10 05:53:38 +00:00
|
|
|
onValueChange={changePredictive}
|
|
|
|
/>
|
2022-07-03 01:50:01 +00:00
|
|
|
</View>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
const styles = StyleSheet.create({
|
|
|
|
container: {
|
|
|
|
padding: 10,
|
2022-07-05 03:33:42 +00:00
|
|
|
flex: 1,
|
2022-07-03 01:50:01 +00:00
|
|
|
},
|
2022-07-04 04:17:29 +00:00
|
|
|
text: {
|
|
|
|
marginBottom: 10,
|
|
|
|
},
|
2022-07-03 01:50:01 +00:00
|
|
|
});
|