Massive/Settings.tsx

117 lines
3.3 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, {useContext, useEffect, useState} from 'react';
2022-07-05 12:06:16 +00:00
import {NativeModules, StyleSheet, Text, View} from 'react-native';
import {Button, Snackbar, Switch, TextInput} from 'react-native-paper';
import {DatabaseContext} from './App';
import BatteryDialog from './BatteryDialog';
2022-07-03 01:50:01 +00:00
2022-07-07 00:45:45 +00:00
export default function Settings() {
2022-07-03 01:50:01 +00:00
const [minutes, setMinutes] = useState<string>('');
const [seconds, setSeconds] = useState<string>('');
const [alarmEnabled, setAlarmEnabled] = useState<boolean>(false);
const [snackbar, setSnackbar] = useState('');
const [showBattery, setShowBattery] = useState(false);
2022-07-07 00:45:45 +00:00
const [ignoring, setIgnoring] = useState(false);
const db = useContext(DatabaseContext);
2022-07-03 01:50:01 +00:00
2022-07-07 00:45:45 +00:00
const refresh = async () => {
setMinutes((await AsyncStorage.getItem('minutes')) || '3');
setSeconds((await AsyncStorage.getItem('seconds')) || '');
setAlarmEnabled((await AsyncStorage.getItem('alarmEnabled')) === 'true');
NativeModules.AlarmModule.ignoringBatteryOptimizations(setIgnoring);
};
useEffect(() => {
2022-07-07 00:45:45 +00:00
refresh();
}, []);
2022-07-03 01:50:01 +00:00
useEffect(() => {
if (minutes) AsyncStorage.setItem('minutes', minutes);
if (seconds) AsyncStorage.setItem('seconds', seconds);
AsyncStorage.setItem('alarmEnabled', alarmEnabled ? 'true' : 'false');
}, [minutes, seconds, alarmEnabled]);
const clear = async () => {
setSnackbar('Deleting all data...');
setTimeout(() => setSnackbar(''), 5000);
2022-07-03 01:50:01 +00:00
await db.executeSql(`DELETE FROM sets`);
};
2022-07-05 12:06:16 +00:00
const exportSets = () => {
NativeModules.ExportModule.sets();
};
const importSets = () => {
NativeModules.ImportModule.sets();
};
const changeAlarmEnabled = (enabled: boolean) => {
2022-07-07 00:45:45 +00:00
setAlarmEnabled(enabled);
if (enabled && !ignoring) setShowBattery(true);
};
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"
onChangeText={setMinutes}
style={styles.text}
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"
onChangeText={setSeconds}
style={styles.text}
2022-07-03 01:50:01 +00:00
/>
2022-07-06 10:02:43 +00:00
<Text style={styles.text}>Rest timers</Text>
2022-07-03 01:50:01 +00:00
<Switch
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-05 12:06:16 +00:00
<Button
style={{alignSelf: 'flex-start'}}
icon="arrow-down"
onPress={exportSets}>
Export
</Button>
<Button
style={{alignSelf: 'flex-start'}}
icon="arrow-up"
onPress={importSets}>
Import
2022-07-05 12:06:16 +00:00
</Button>
2022-07-05 03:33:42 +00:00
<Button
style={{alignSelf: 'flex-start', marginTop: 'auto'}}
icon="trash"
onPress={clear}>
Delete all data
2022-07-03 01:50:01 +00:00
</Button>
<BatteryDialog show={showBattery} setShow={setShowBattery} />
<Snackbar
visible={!!snackbar}
onDismiss={() => setSnackbar('')}
action={{label: 'Close', onPress: () => setSnackbar('')}}>
{snackbar}
</Snackbar>
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
});