mirror of
https://github.com/BlueWallet/BlueWallet.git
synced 2025-01-19 05:45:15 +01:00
00bb9fe28b
Update MainInterface.storyboard ADD: Cache fetched data ADD: Add "Up from/Down from" data OPS: Add Provision Profile Update project.pbxproj ADD: Synchronize user selected currency with Today extension Update Info.plist ADD: quick actions Update App.js Update App.js Update App.js Update App.js Update App.js FIX: Fix currency bugs FIX: Hide balance from quick actions ADD: cqc Update currency.js Update TodayViewController.swift Update App.js REF: headercolor Update App.js FIX: carousel would not show FIX: Fix FIX FIX Update API.swift FIX: Fixed alerts TST Revert "TST" This reverts commit bcdf62e9b238cc5da200cc4bce45e4e55f480d6d. ADD: Tests mocks REF: Device Quick Actions ref FIX: Fixed crash Update quickActions.ios.js ADD: QuickActions for Android D FIX: Tests OP
138 lines
4.6 KiB
JavaScript
138 lines
4.6 KiB
JavaScript
import Frisbee from 'frisbee';
|
|
import AsyncStorage from '@react-native-community/async-storage';
|
|
import { AppStorage } from './class';
|
|
import { FiatUnit } from './models/fiatUnit';
|
|
import DefaultPreference from 'react-native-default-preference';
|
|
import DeviceQuickActions from './class/quickActions';
|
|
let BigNumber = require('bignumber.js');
|
|
let preferredFiatCurrency = FiatUnit.USD;
|
|
let exchangeRates = {};
|
|
|
|
const STRUCT = {
|
|
LAST_UPDATED: 'LAST_UPDATED',
|
|
};
|
|
|
|
/**
|
|
* Saves to storage preferred currency, whole object
|
|
* from `./models/fiatUnit`
|
|
*
|
|
* @param item {Object} one of the values in `./models/fiatUnit`
|
|
* @returns {Promise<void>}
|
|
*/
|
|
async function setPrefferedCurrency(item) {
|
|
await AsyncStorage.setItem(AppStorage.PREFERRED_CURRENCY, JSON.stringify(item));
|
|
await DefaultPreference.setName('group.io.bluewallet.bluewallet');
|
|
await DefaultPreference.set('preferredCurrency', item.endPointKey);
|
|
await DefaultPreference.set('preferredCurrencyLocale', item.locale.replace('-', '_'));
|
|
DeviceQuickActions.setQuickActions();
|
|
}
|
|
|
|
async function getPreferredCurrency() {
|
|
let preferredCurrency = await JSON.parse(await AsyncStorage.getItem(AppStorage.PREFERRED_CURRENCY));
|
|
await DefaultPreference.set('preferredCurrency', preferredCurrency.endPointKey);
|
|
await DefaultPreference.set('preferredCurrencyLocale', preferredCurrency.locale.replace('-', '_'));
|
|
return preferredCurrency;
|
|
}
|
|
|
|
async function updateExchangeRate() {
|
|
if (+new Date() - exchangeRates[STRUCT.LAST_UPDATED] <= 30 * 60 * 1000) {
|
|
// not updating too often
|
|
return;
|
|
}
|
|
|
|
try {
|
|
preferredFiatCurrency = JSON.parse(await AsyncStorage.getItem(AppStorage.PREFERRED_CURRENCY));
|
|
} catch (_) {}
|
|
preferredFiatCurrency = preferredFiatCurrency || FiatUnit.USD;
|
|
|
|
let json;
|
|
try {
|
|
const api = new Frisbee({
|
|
baseURI: 'https://api.coindesk.com',
|
|
});
|
|
let response = await api.get('/v1/bpi/currentprice/' + preferredFiatCurrency.endPointKey + '.json');
|
|
json = JSON.parse(response.body);
|
|
if (!json || !json.bpi || !json.bpi[preferredFiatCurrency.endPointKey] || !json.bpi[preferredFiatCurrency.endPointKey].rate_float) {
|
|
throw new Error('Could not update currency rate: ' + response.err);
|
|
}
|
|
} catch (Err) {
|
|
console.warn(Err);
|
|
const lastSavedExchangeRate = JSON.parse(await AsyncStorage.getItem(AppStorage.EXCHANGE_RATES));
|
|
exchangeRates['BTC_' + preferredFiatCurrency.endPointKey] = lastSavedExchangeRate['BTC_' + preferredFiatCurrency.endPointKey] * 1;
|
|
return;
|
|
}
|
|
|
|
exchangeRates[STRUCT.LAST_UPDATED] = +new Date();
|
|
exchangeRates['BTC_' + preferredFiatCurrency.endPointKey] = json.bpi[preferredFiatCurrency.endPointKey].rate_float * 1;
|
|
await AsyncStorage.setItem(AppStorage.EXCHANGE_RATES, JSON.stringify(exchangeRates));
|
|
await AsyncStorage.setItem(AppStorage.PREFERRED_CURRENCY, JSON.stringify(preferredFiatCurrency));
|
|
DeviceQuickActions.setQuickActions();
|
|
}
|
|
|
|
let interval = false;
|
|
async function startUpdater() {
|
|
if (interval) {
|
|
clearInterval(interval);
|
|
exchangeRates[STRUCT.LAST_UPDATED] = 0;
|
|
}
|
|
|
|
interval = setInterval(() => updateExchangeRate(), 2 * 60 * 100);
|
|
return updateExchangeRate();
|
|
}
|
|
|
|
function satoshiToLocalCurrency(satoshi) {
|
|
if (!exchangeRates['BTC_' + preferredFiatCurrency.endPointKey]) {
|
|
startUpdater();
|
|
return '...';
|
|
}
|
|
|
|
let b = new BigNumber(satoshi);
|
|
b = b
|
|
.dividedBy(100000000)
|
|
.multipliedBy(exchangeRates['BTC_' + preferredFiatCurrency.endPointKey])
|
|
.toString(10);
|
|
b = parseFloat(b).toFixed(2);
|
|
|
|
let formatter;
|
|
|
|
try {
|
|
formatter = new Intl.NumberFormat(preferredFiatCurrency.locale, {
|
|
style: 'currency',
|
|
currency: preferredFiatCurrency.endPointKey,
|
|
minimumFractionDigits: 2,
|
|
});
|
|
} catch (error) {
|
|
console.warn(error);
|
|
console.log(error);
|
|
formatter = new Intl.NumberFormat(FiatUnit.USD.locale, {
|
|
style: 'currency',
|
|
currency: preferredFiatCurrency.endPointKey,
|
|
minimumFractionDigits: 2,
|
|
});
|
|
}
|
|
|
|
return formatter.format(b);
|
|
}
|
|
|
|
function BTCToLocalCurrency(bitcoin) {
|
|
let sat = new BigNumber(bitcoin);
|
|
sat = sat.multipliedBy(100000000).toNumber();
|
|
|
|
return satoshiToLocalCurrency(sat);
|
|
}
|
|
|
|
function satoshiToBTC(satoshi) {
|
|
let b = new BigNumber(satoshi);
|
|
b = b.dividedBy(100000000);
|
|
return b.toString(10);
|
|
}
|
|
|
|
module.exports.updateExchangeRate = updateExchangeRate;
|
|
module.exports.startUpdater = startUpdater;
|
|
module.exports.STRUCT = STRUCT;
|
|
module.exports.satoshiToLocalCurrency = satoshiToLocalCurrency;
|
|
module.exports.satoshiToBTC = satoshiToBTC;
|
|
module.exports.BTCToLocalCurrency = BTCToLocalCurrency;
|
|
module.exports.setPrefferedCurrency = setPrefferedCurrency;
|
|
module.exports.getPreferredCurrency = getPreferredCurrency;
|