aboutsummaryrefslogtreecommitdiffstats
path: root/app/scripts/lib/config-manager.js
diff options
context:
space:
mode:
authorDan Finlay <somniac@me.com>2016-08-17 06:32:06 +0800
committerGitHub <noreply@github.com>2016-08-17 06:32:06 +0800
commit90d6bec3ed51ba4b2d4696132642a4d97712dec9 (patch)
treeae8f2a3a805e0ac24ed3d1058138cf1b3c25b763 /app/scripts/lib/config-manager.js
parentf1986d7a3757aea50fba798b295397e69739b891 (diff)
parent666f3cd66ce56013e5688d514e3c1fc3ec8a6ac4 (diff)
downloadtangerine-wallet-browser-90d6bec3ed51ba4b2d4696132642a4d97712dec9.tar
tangerine-wallet-browser-90d6bec3ed51ba4b2d4696132642a4d97712dec9.tar.gz
tangerine-wallet-browser-90d6bec3ed51ba4b2d4696132642a4d97712dec9.tar.bz2
tangerine-wallet-browser-90d6bec3ed51ba4b2d4696132642a4d97712dec9.tar.lz
tangerine-wallet-browser-90d6bec3ed51ba4b2d4696132642a4d97712dec9.tar.xz
tangerine-wallet-browser-90d6bec3ed51ba4b2d4696132642a4d97712dec9.tar.zst
tangerine-wallet-browser-90d6bec3ed51ba4b2d4696132642a4d97712dec9.zip
Merge pull request #520 from MetaMask/usd-conversion
Conversion implementation
Diffstat (limited to 'app/scripts/lib/config-manager.js')
-rw-r--r--app/scripts/lib/config-manager.js48
1 files changed, 48 insertions, 0 deletions
diff --git a/app/scripts/lib/config-manager.js b/app/scripts/lib/config-manager.js
index d14d3afc3..c56f52e48 100644
--- a/app/scripts/lib/config-manager.js
+++ b/app/scripts/lib/config-manager.js
@@ -1,6 +1,7 @@
const Migrator = require('pojo-migrator')
const MetamaskConfig = require('../config.js')
const migrations = require('./migrations')
+const rp = require('request-promise')
const TESTNET_RPC = MetamaskConfig.network.testnet
const MAINNET_RPC = MetamaskConfig.network.mainnet
@@ -270,6 +271,53 @@ ConfigManager.prototype.getConfirmed = function () {
return ('isConfirmed' in data) && data.isConfirmed
}
+ConfigManager.prototype.setCurrentFiat = function (currency) {
+ var data = this.getData()
+ data.fiatCurrency = currency
+ this.setData(data)
+}
+
+ConfigManager.prototype.getCurrentFiat = function () {
+ var data = this.getData()
+ return ('fiatCurrency' in data) && data.fiatCurrency
+}
+
+ConfigManager.prototype.updateConversionRate = function () {
+ var data = this.getData()
+ return rp(`https://www.cryptonator.com/api/ticker/eth-${data.fiatCurrency}`)
+ .then((response) => {
+ const parsedResponse = JSON.parse(response)
+ this.setConversionPrice(parsedResponse.ticker.price)
+ this.setConversionDate(parsedResponse.timestamp)
+ }).catch((err) => {
+ console.error('Error in conversion.', err)
+ this.setConversionPrice(0)
+ this.setConversionDate('N/A')
+ })
+}
+
+ConfigManager.prototype.setConversionPrice = function(price) {
+ var data = this.getData()
+ data.conversionRate = Number(price)
+ this.setData(data)
+}
+
+ConfigManager.prototype.setConversionDate = function (datestring) {
+ var data = this.getData()
+ data.conversionDate = datestring
+ this.setData(data)
+}
+
+ConfigManager.prototype.getConversionRate = function () {
+ var data = this.getData()
+ return (('conversionRate' in data) && data.conversionRate) || 0
+}
+
+ConfigManager.prototype.getConversionDate = function () {
+ var data = this.getData()
+ return (('conversionDate' in data) && data.conversionDate) || 'N/A'
+}
+
ConfigManager.prototype.setShouldntShowWarning = function () {
var data = this.getData()
if (data.isEthConfirmed) {