import React, { useCallback, useEffect, useState } from 'react'; import AsyncStorage from '@react-native-async-storage/async-storage'; import { RouteProp, useRoute } from '@react-navigation/native'; import { Alert, I18nManager, Linking, ScrollView, StyleSheet, TextInput, View } from 'react-native'; import { Button as ButtonRNElements } from '@rneui/themed'; import { BlueButtonLink, BlueCard, BlueLoading, BlueSpacing20, BlueText } from '../../BlueComponents'; import { BlueApp } from '../../class'; import DeeplinkSchemaMatch from '../../class/deeplink-schema-match'; import { LightningCustodianWallet } from '../../class/wallets/lightning-custodian-wallet'; import presentAlert from '../../components/Alert'; import { Button } from '../../components/Button'; import { useTheme } from '../../components/themes'; import { scanQrHelper } from '../../helpers/scan-qr'; import loc from '../../loc'; const styles = StyleSheet.create({ uri: { flexDirection: 'row', borderWidth: 1, borderBottomWidth: 0.5, minHeight: 44, height: 44, alignItems: 'center', borderRadius: 4, }, uriText: { flex: 1, color: '#81868e', marginHorizontal: 8, minHeight: 36, height: 36, }, buttonStyle: { backgroundColor: 'transparent', flexDirection: I18nManager.isRTL ? 'row-reverse' : 'row', }, }); type LightingSettingsRouteProps = RouteProp< { params?: { url?: string; }; }, 'params' >; const LightningSettings: React.FC = () => { const params = useRoute().params; const [isLoading, setIsLoading] = useState(true); const [URI, setURI] = useState(); const { colors } = useTheme(); const route = useRoute(); const styleHook = StyleSheet.create({ uri: { borderColor: colors.formBorder, borderBottomColor: colors.formBorder, backgroundColor: colors.inputBackgroundColor, }, }); useEffect(() => { AsyncStorage.getItem(BlueApp.LNDHUB) .then(value => setURI(value ?? undefined)) .then(() => setIsLoading(false)) .catch(() => setIsLoading(false)); if (params?.url) { Alert.alert( loc.formatString(loc.settings.set_lndhub_as_default, { url: params.url }) as string, '', [ { text: loc._.ok, onPress: () => { params?.url && setLndhubURI(params.url); }, style: 'default', }, { text: loc._.cancel, onPress: () => {}, style: 'cancel' }, ], { cancelable: false }, ); } }, [params?.url]); const setLndhubURI = (value: string) => { // in case user scans a QR with a deeplink like `bluewallet:setlndhuburl?url=https%3A%2F%2Flndhub.herokuapp.com` const setLndHubUrl = DeeplinkSchemaMatch.getUrlFromSetLndhubUrlAction(value); setURI(typeof setLndHubUrl === 'string' ? setLndHubUrl.trim() : value.trim()); }; const save = useCallback(async () => { setIsLoading(true); try { if (URI) { await LightningCustodianWallet.isValidNodeAddress(URI); // validating only if its not empty. empty means use default } if (URI) { await AsyncStorage.setItem(BlueApp.LNDHUB, URI); } else { await AsyncStorage.removeItem(BlueApp.LNDHUB); } presentAlert({ message: loc.settings.lightning_saved }); } catch (error) { presentAlert({ message: loc.settings.lightning_error_lndhub_uri }); console.log(error); } setIsLoading(false); }, [URI]); const importScan = () => { scanQrHelper(route.name).then(data => { if (data) { setLndhubURI(data); } }); }; return ( {loc.settings.lightning_settings_explain} Linking.openURL('https://github.com/BlueWallet/LndHub')} titleStyle={{ color: colors.buttonAlternativeTextColor }} title="github.com/BlueWallet/LndHub" // TODO: looks like there's no `color` prop on `Button`, does this make any sense? // color={colors.buttonTextColor} buttonStyle={styles.buttonStyle} /> {isLoading ? :