silvrgit/app/js/modules/bitcoin.js
2017-09-28 00:17:07 +01:00

216 lines
5.7 KiB
JavaScript

/**
* Created by mdonnel on 22/03/2017.
*/
const BitcoinModel = Backbone.Model.extend({
'initialize': function () {
this.set('url', '/btc');
this.set('balanceUrl', '/balance');
const data = {
'lastGBP': 0.0,
'lastUSD': 0.0,
'lows': { 'gbp': 0, 'usd': 0 },
'highs': { 'gbp': 0, 'usd': 0 },
'eclass': '',
'balance': 0.0,
'trend': 0
};
this.set('btcdata', data);
this.set('balance', 0);
this.update();
this.updateHourly();
},
'update': function () {
this.getBTC();
// this.getBalance();
const now = new Date();
const mod = 300000 - (now.getTime() % 300000);
const btcupdateFn = function() {
this.update();
};
console.log('>> btc timeout disabled');
// setTimeout(btcupdateFn.bind(this), mod + 10);
},
'updateHourly': function () {
this.getBalance();
const now = new Date();
const mod = 3600000 - (now.getTime() % 3600000);
const btcupdateFn = function() {
this.updateHourly();
};
console.log('>> balance timeout disabled');
// setTimeout(btcupdateFn.bind(this), mod + 10);
},
'recalc': function () {
let data = this.get('btcdata');
let lastGBP = data.lastGBP;
let lastUSD;
const g = data.gbp;
const u = data.usd;
const lows = data.lows;
const highs = data.highs;
let eclass = data.eclass;
const balance = data.balance;
let trend = data.trend;
if ((trend === undefined) || ( trend === null)) trend = 1;
if (g !== undefined) {
if (data.lastGBP !== 0)
if (g > lastGBP) {
eclass = 'up';
}
else {
eclass = 'down';
}
else {
lows.gbp = g;
lows.usd = u;
highs.gbp = g;
highs.usd = u;
}
lastGBP = g;
lastUSD = u;
if (g < lows.gbp) lows.gbp = g;
if (u < lows.usd) lows.usd = u;
if (highs.gbp < g) highs.gbp = g;
if (highs.usd < u) highs.usd = u;
data = {
lastGBP,
lastUSD,
lows,
highs,
eclass,
balance,
trend
};
}
data.stub = Math.random(Number.MAX_SAFE_INTEGER).toString(32);
this.set('btcdata', data);
// total = myBTC * g;
},
'getBTC': function () {
console.log('>> getBTC');
const self = this;
const url = this.get('url');
$.ajax({
'type': 'GET',
'url': url,
'data': '',
'dataType': 'json',
'timeout': 10000,
// contentType: ('application/json'),
'headers': {
'Access-Control-Allow-Origin': '*',
'Access-Control-Allow-Methods': 'PUT, GET, POST, DELETE, OPTIONS',
'Access-Control-Allow-Headers': 'Content-Type'
},
'success': function (data) {
let gbp = data.bpi.GBP.rate_float,
usd = data.bpi.USD.rate_float;
const trend = data.trend;
const btcdata = self.get('btcdata');
btcdata.gbp = gbp;
btcdata.usd = usd;
btcdata.trend = trend;
self.set('btcdata', btcdata);
self.recalc();
},
'error': function (xhr, type) {
console.log('ajax error');
console.log(xhr);
console.log(type);
}
});
},
'getBalance': function() {
const self = this;
const url = this.get('balanceUrl');
$.ajax({
'type': 'GET',
'url': url,
'data': '',
'dataType': 'json',
'timeout': 10000,
// contentType: ('application/json'),
'headers': {
'Access-Control-Allow-Origin': '*',
'Access-Control-Allow-Methods': 'PUT, GET, POST, DELETE, OPTIONS',
'Access-Control-Allow-Headers': 'Content-Type'
},
'success': function (data) {
const balance = data.balance;
self.set('balance', balance);
self.recalc();
},
'error': function (xhr, type) {
console.log('ajax error');
console.log(xhr);
console.log(type);
}
});
},
'btcFromSocket': function (data) {
const self = this;
console.log('>> btc from the socket', data);
const gbp = data.bpi.GBP.rate_float;
const usd = data.bpi.USD.rate_float;
const trend = data.trend;
const btcdata = self.get('btcdata');
btcdata.gbp = gbp;
btcdata.usd = usd;
btcdata.trend = trend;
self.set('btcdata', btcdata);
self.recalc();
},
'balanceFromSocket': function (data) {
const self = this;
console.log('>> balance from the socket', data);
const balance = data.balance;
self.set('balance', balance);
self.recalc();
}
});
const Bitcoin = Backbone.View.extend({
'tagName': 'div',
'initialize': function () {
_.bindAll(this, 'render');
this.model.bind('change', this.render);
this.$btc = $('#btc');
this.$trend = $('#trend');
},
'render': function () {
const btcdata = this.model.get('btcdata');
const balance = this.model.get('balance');
// console.log(`Balance: ${btcdata.balance.toFixed(4)}`);
// console.log(btcdata.lastGBP);
const owned = parseFloat(btcdata.lastGBP) * parseFloat(balance);
// console.log(`owned: ${owned}`);
const title = `High: $${ parseFloat(btcdata.highs.usd.toFixed(2)) } / Low $${ parseFloat(btcdata.lows.usd.toFixed(2))}`;
let trendClass = '';
if (btcdata.trend > 1.00)
trendClass = 'trendUp';
else if (btcdata.trend < 1.00)
trendClass = 'trendDown';
else
trendClass = '';
this.$trend.removeClass();
this.$trend.addClass(trendClass);
this.$btc.removeClass();
this.$btc.addClass(btcdata.eclass);
this.$btc.html(`&#36;${parseFloat(btcdata.lastUSD.toFixed(2)) } / &pound;${parseFloat(btcdata.lastGBP.toFixed(2))} <div>&#8383;${balance} &pound;${parseFloat(owned.toFixed(2))}</div>` );
this.$btc.prop('title', title);
}
});