mirror of
https://github.com/BlueWallet/BlueWallet.git
synced 2025-01-19 05:45:15 +01:00
203 lines
5.8 KiB
JavaScript
203 lines
5.8 KiB
JavaScript
/* global alert */
|
|
import React, { useCallback, useEffect, useState } from 'react';
|
|
import { ScrollView, TouchableWithoutFeedback, StyleSheet, Linking, View, TextInput } from 'react-native';
|
|
import {
|
|
BlueLoading,
|
|
BlueText,
|
|
BlueSpacing20,
|
|
BlueListItem,
|
|
BlueNavigationStyle,
|
|
BlueCard,
|
|
BlueButton,
|
|
BlueCopyToClipboardButton,
|
|
} from '../../BlueComponents';
|
|
import { useTheme } from '@react-navigation/native';
|
|
import loc from '../../loc';
|
|
import { Button } from 'react-native-elements';
|
|
import { BlueCurrentTheme } from '../../components/themes';
|
|
import Notifications from '../../blue_modules/notifications';
|
|
|
|
const NotificationSettings = () => {
|
|
const [isLoading, setIsLoading] = useState(true);
|
|
const [isNotificationsEnabled, setNotificationsEnabled] = useState(false);
|
|
const [isShowTokenInfo, setShowTokenInfo] = useState(0);
|
|
const [tokenInfo, setTokenInfo] = useState('<empty>');
|
|
const [URI, setURI] = useState();
|
|
|
|
const { colors } = useTheme();
|
|
|
|
const onNotificationsSwitch = async value => {
|
|
setNotificationsEnabled(value); // so the slider is not 'jumpy'
|
|
if (value) {
|
|
// user is ENABLING notifications
|
|
await Notifications.cleanUserOptOutFlag();
|
|
if (await Notifications.getPushToken()) {
|
|
// we already have a token, so we just need to reenable ALL level on groundcontrol:
|
|
await Notifications.setLevels(true);
|
|
} else {
|
|
// ok, we dont have a token. we need to try to obtain permissions, configure callbacks and save token locally:
|
|
await Notifications.tryToObtainPermissions();
|
|
}
|
|
} else {
|
|
// user is DISABLING notifications
|
|
await Notifications.setLevels(false);
|
|
}
|
|
|
|
setNotificationsEnabled(await Notifications.isNotificationsEnabled());
|
|
};
|
|
|
|
useEffect(() => {
|
|
(async () => {
|
|
setNotificationsEnabled(await Notifications.isNotificationsEnabled());
|
|
setURI(await Notifications.getSavedUri());
|
|
setTokenInfo(
|
|
'token: ' +
|
|
JSON.stringify(await Notifications.getPushToken()) +
|
|
' permissions: ' +
|
|
JSON.stringify(await Notifications.checkPermissions()) +
|
|
' stored notifications: ' +
|
|
JSON.stringify(await Notifications.getStoredNotifications()),
|
|
);
|
|
setIsLoading(false);
|
|
})();
|
|
}, []);
|
|
|
|
const stylesWithThemeHook = {
|
|
root: {
|
|
...styles.root,
|
|
backgroundColor: colors.background,
|
|
},
|
|
scroll: {
|
|
...styles.scroll,
|
|
backgroundColor: colors.background,
|
|
},
|
|
scrollBody: {
|
|
...styles.scrollBody,
|
|
backgroundColor: colors.background,
|
|
},
|
|
};
|
|
|
|
const save = useCallback(async () => {
|
|
setIsLoading(true);
|
|
try {
|
|
if (URI) {
|
|
// validating only if its not empty. empty means use default
|
|
if (await Notifications.isGroundControlUriValid(URI)) {
|
|
await Notifications.saveUri(URI);
|
|
alert(loc.settings.saved);
|
|
} else {
|
|
alert(loc.settings.not_a_valid_uri);
|
|
}
|
|
} else {
|
|
await Notifications.saveUri('');
|
|
alert(loc.settings.saved);
|
|
}
|
|
} catch (error) {
|
|
console.warn(error);
|
|
}
|
|
setIsLoading(false);
|
|
}, [URI]);
|
|
|
|
return isLoading ? (
|
|
<BlueLoading />
|
|
) : (
|
|
<ScrollView style={stylesWithThemeHook.scroll}>
|
|
<BlueListItem
|
|
Component={TouchableWithoutFeedback}
|
|
title={loc.settings.push_notifications}
|
|
switch={{ onValueChange: onNotificationsSwitch, value: isNotificationsEnabled }}
|
|
/>
|
|
<BlueSpacing20 />
|
|
|
|
<BlueCard>
|
|
<BlueText>{loc.settings.groundcontrol_explanation}</BlueText>
|
|
</BlueCard>
|
|
|
|
<Button
|
|
icon={{
|
|
name: 'github',
|
|
type: 'font-awesome',
|
|
color: colors.foregroundColor,
|
|
}}
|
|
onPress={() => Linking.openURL('https://github.com/BlueWallet/GroundControl')}
|
|
titleStyle={{ color: colors.buttonAlternativeTextColor }}
|
|
title="github.com/BlueWallet/GroundControl"
|
|
color={colors.buttonTextColor}
|
|
buttonStyle={styles.buttonStyle}
|
|
/>
|
|
|
|
<BlueCard>
|
|
<View style={styles.uri}>
|
|
<TextInput
|
|
placeholder={Notifications.getDefaultUri()}
|
|
value={URI}
|
|
onChangeText={setURI}
|
|
numberOfLines={1}
|
|
style={styles.uriText}
|
|
placeholderTextColor="#81868e"
|
|
editable={!isLoading}
|
|
textContentType="URL"
|
|
autoCapitalize="none"
|
|
underlineColorAndroid="transparent"
|
|
/>
|
|
</View>
|
|
|
|
<BlueSpacing20 />
|
|
<BlueText style={styles.centered} onPress={() => setShowTokenInfo(isShowTokenInfo + 1)}>
|
|
♪ Ground Control to Major Tom ♪
|
|
</BlueText>
|
|
<BlueText style={styles.centered} onPress={() => setShowTokenInfo(isShowTokenInfo + 1)}>
|
|
♪ Commencing countdown, engines on ♪
|
|
</BlueText>
|
|
|
|
{isShowTokenInfo >= 9 && (
|
|
<View>
|
|
<BlueCopyToClipboardButton stringToCopy={tokenInfo} displayText={tokenInfo} />
|
|
</View>
|
|
)}
|
|
|
|
<BlueSpacing20 />
|
|
<BlueButton onPress={save} title={loc.settings.save} />
|
|
</BlueCard>
|
|
</ScrollView>
|
|
);
|
|
};
|
|
|
|
NotificationSettings.navigationOptions = () => ({
|
|
...BlueNavigationStyle(),
|
|
title: loc.settings.notifications,
|
|
});
|
|
|
|
const styles = StyleSheet.create({
|
|
root: {
|
|
flex: 1,
|
|
},
|
|
uri: {
|
|
flexDirection: 'row',
|
|
borderColor: BlueCurrentTheme.colors.formBorder,
|
|
borderBottomColor: BlueCurrentTheme.colors.formBorder,
|
|
borderWidth: 1,
|
|
borderBottomWidth: 0.5,
|
|
backgroundColor: BlueCurrentTheme.colors.inputBackgroundColor,
|
|
minHeight: 44,
|
|
height: 44,
|
|
alignItems: 'center',
|
|
borderRadius: 4,
|
|
},
|
|
centered: {
|
|
textAlign: 'center',
|
|
},
|
|
uriText: {
|
|
flex: 1,
|
|
color: '#81868e',
|
|
marginHorizontal: 8,
|
|
minHeight: 36,
|
|
height: 36,
|
|
},
|
|
buttonStyle: {
|
|
backgroundColor: 'transparent',
|
|
},
|
|
});
|
|
|
|
export default NotificationSettings;
|