Massive/SettingsPage.tsx

133 lines
3.5 KiB
TypeScript
Raw Normal View History

2022-07-03 01:50:01 +00:00
import AsyncStorage from '@react-native-async-storage/async-storage';
import React, {useCallback, useEffect, useState} from 'react';
import {
NativeModules,
StyleSheet,
Text,
ToastAndroid,
View,
} from 'react-native';
import {TextInput} from 'react-native-paper';
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;
export default function SettingsPage() {
2022-07-03 01:50:01 +00:00
const [minutes, setMinutes] = useState<string>('');
const [maxSets, setMaxSets] = useState<string>('3');
2022-07-03 01:50:01 +00:00
const [seconds, setSeconds] = useState<string>('');
const [alarmEnabled, setAlarmEnabled] = useState<boolean>(false);
2022-07-10 05:53:38 +00:00
const [predictiveSets, setPredictiveSets] = useState<boolean>(false);
const [showBattery, setShowBattery] = useState(false);
2022-07-07 00:45:45 +00:00
const [ignoring, setIgnoring] = useState(false);
2022-07-03 01:50:01 +00:00
const refresh = useCallback(async () => {
setMinutes((await getItem('minutes')) || '');
2022-07-08 03:45:24 +00:00
setSeconds((await getItem('seconds')) || '');
setAlarmEnabled((await getItem('alarmEnabled')) === 'true');
setPredictiveSets((await getItem('predictiveSets')) === 'true');
setMaxSets((await getItem('maxSets')) || '');
2022-07-19 04:38:58 +00:00
NativeModules.AlarmModule.ignoringBattery(setIgnoring);
}, []);
2022-07-07 00:45:45 +00:00
useEffect(() => {
2022-07-07 00:45:45 +00:00
refresh();
}, [refresh]);
2022-07-03 01:50:01 +00:00
const changeAlarmEnabled = useCallback(
(enabled: boolean) => {
setAlarmEnabled(enabled);
if (enabled && !ignoring) setShowBattery(true);
setItem('alarmEnabled', enabled ? 'true' : 'false');
},
[setShowBattery, ignoring],
);
2022-07-10 05:53:38 +00:00
const changePredictive = useCallback(
(enabled: boolean) => {
setPredictiveSets(enabled);
setItem('predictiveSets', enabled ? 'true' : 'false');
ToastAndroid.show(
'Predictive sets guess whats next based on todays plan.',
ToastAndroid.LONG,
);
2022-07-10 05:53:38 +00:00
},
[setPredictiveSets],
2022-07-10 05:53:38 +00:00
);
2022-07-03 01:50:01 +00:00
return (
<View style={styles.container}>
<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
}}
style={styles.text}
2022-07-03 01:50:01 +00:00
/>
2022-07-10 05:53:38 +00:00
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
}}
style={styles.text}
2022-07-03 01:50:01 +00:00
/>
2022-07-10 05:53:38 +00:00
<TextInput
label="Sets per workout"
value={maxSets}
keyboardType="numeric"
onChangeText={value => {
setMaxSets(value);
setItem('maxSets', value);
}}
style={styles.text}
/>
2022-07-06 10:02:43 +00:00
<Text style={styles.text}>Rest timers</Text>
2022-07-17 01:45:31 +00:00
<MassiveSwitch
style={[styles.text, {alignSelf: 'flex-start'}]}
2022-07-03 01:50:01 +00:00
value={alarmEnabled}
onValueChange={changeAlarmEnabled}
2022-07-03 01:50:01 +00:00
/>
2022-07-10 05:53:38 +00:00
<ConfirmDialog
title="Battery optimizations"
show={showBattery}
setShow={setShowBattery}
onOk={() => {
2022-07-19 04:38:58 +00:00
NativeModules.AlarmModule.openSettings();
setShowBattery(false);
}}>
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'}]}
value={predictiveSets}
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
},
text: {
marginBottom: 10,
},
2022-07-03 01:50:01 +00:00
});