118 lines
3.3 KiB
JavaScript
118 lines
3.3 KiB
JavaScript
|
/**
|
||
|
* Created by mdonnel on 22/03/2017.
|
||
|
*/
|
||
|
|
||
|
let BitcoinModel = Backbone.Model.extend({
|
||
|
initialize: function () {
|
||
|
this.set('url', '/btc');
|
||
|
let data = {
|
||
|
lastGBP: 0.0,
|
||
|
lastUSD: 0.0,
|
||
|
lows: {gbp: 0, usd: 0},
|
||
|
highs: {gbp: 0, usd: 0},
|
||
|
eclass: ''
|
||
|
};
|
||
|
this.set('btcdata', data);
|
||
|
this.update();
|
||
|
},
|
||
|
update: function () {
|
||
|
this.getBTC();
|
||
|
const now = new Date;
|
||
|
const mod = 60000 - (now.getTime() % 60000);
|
||
|
|
||
|
let btcupdateFn = function() {
|
||
|
this.update();
|
||
|
};
|
||
|
setTimeout(btcupdateFn.bind(this), mod + 10);
|
||
|
},
|
||
|
recalc: function () {
|
||
|
let data = this.get('btcdata');
|
||
|
let lastGBP = data.lastGBP;
|
||
|
let lastUSD = data.lastUSD;
|
||
|
let g = data.gbp;
|
||
|
let u = data.usd;
|
||
|
let lows = data.lows;
|
||
|
let highs = data.highs;
|
||
|
let eclass = data.eclass;
|
||
|
|
||
|
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
|
||
|
};
|
||
|
this.set('btcdata', data);
|
||
|
// total = myBTC * g;
|
||
|
},
|
||
|
getBTC: function () {
|
||
|
let self = this;
|
||
|
let 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;
|
||
|
let btcdata = self.get('btcdata');
|
||
|
btcdata.gbp = gbp;
|
||
|
btcdata.usd = usd;
|
||
|
self.set('btcdata', btcdata);
|
||
|
self.recalc();
|
||
|
},
|
||
|
error: function (xhr, type) {
|
||
|
console.log('ajax error');
|
||
|
console.log(xhr);
|
||
|
console.log(type);
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
});
|
||
|
let Bitcoin = Backbone.View.extend({
|
||
|
tagName: 'div',
|
||
|
initialize: function () {
|
||
|
_.bindAll(this, 'render');
|
||
|
this.model.bind('change', this.render);
|
||
|
this.$btc = $('#btc');
|
||
|
},
|
||
|
render: function () {
|
||
|
let btcdata = this.model.get('btcdata');
|
||
|
let title = 'High: $' + parseFloat(btcdata.highs.usd.toFixed(2)) + ' / Low $' + parseFloat(btcdata.lows.usd.toFixed(2));
|
||
|
this.$btc.removeClass();
|
||
|
this.$btc.addClass(btcdata.eclass);
|
||
|
this.$btc.html(`$${parseFloat(btcdata.lastUSD.toFixed(2)) } / £${parseFloat(btcdata.lastGBP.toFixed(2))}` );
|
||
|
this.$btc.prop('title', title);
|
||
|
}
|
||
|
});
|