mirror of
https://github.com/seigler/Dash-price-widget
synced 2025-07-26 23:56:10 +00:00
64 lines
4.6 KiB
JavaScript
64 lines
4.6 KiB
JavaScript
(function () {
|
|
"use strict";
|
|
|
|
function init() {
|
|
var css = '[data-dash-price-widget],[data-dash-price-widget] *,[data-dash-price-widget] :after,[data-dash-price-widget] :before{box-sizing:inherit;vertical-align:baseline;font-weight:inherit;font-family:inherit;font-style:inherit;font-size:100%;border:0;outline:0;padding:0;margin:0;line-height:1}[data-dash-price-widget]{display:inline-block;max-width:18em;margin:.5em auto;border-radius:.5em;background-color:#1D76BC;box-sizing:border-box;color:#fff;padding:.5em;font-family:serif}[data-dash-price-widget] .dash-ticker--title{font-size:3em;float:left;height:1em;width:1em;overflow:hidden;text-indent:-999px;background-image:url();background-size:100% 100%}[data-dash-price-widget] .dash-ticker--wrapper{margin-left:3.5em}[data-dash-price-widget] .dash-ticker--fiat{font-size:2em;text-align:right}[data-dash-price-widget] .dash-ticker--btc{float:left}[data-dash-price-widget] .dash-ticker--change{float:right}',
|
|
head = document.head || document.getElementsByTagName('head')[0],
|
|
style = document.createElement('style');
|
|
|
|
style.type = 'text/css';
|
|
if (style.styleSheet) {
|
|
style.styleSheet.cssText = css;
|
|
} else {
|
|
style.appendChild(document.createTextNode(css));
|
|
}
|
|
|
|
head.appendChild(style);
|
|
|
|
updatePrices(); // update prices now
|
|
setInterval(updatePrices, 5 * 60 * 1000); // ...and every five minutes after this
|
|
}
|
|
|
|
function fetchJSONFile(path, callback) {
|
|
var httpRequest = (window.XMLHttpRequest) ? new XMLHttpRequest() : new ActiveXObject("Microsoft.XMLHTTP");
|
|
httpRequest.onreadystatechange = function () {
|
|
if (httpRequest.readyState === 4) {
|
|
if (httpRequest.status === 200) {
|
|
var data = JSON.parse(httpRequest.responseText);
|
|
if (callback) {
|
|
callback(data);
|
|
}
|
|
}
|
|
}
|
|
};
|
|
httpRequest.open('GET', path);
|
|
httpRequest.send();
|
|
}
|
|
|
|
function makeCurrencyString(number) {
|
|
// return 3 significant figures or two decimal places, whichever is longer.
|
|
return (number.toPrecision(3).length > number.toFixed(2) ? number.toPrecision(3) : number.toFixed(2));
|
|
}
|
|
|
|
function updatePrices() {
|
|
// this requests the Dash price JSON and executes a callback with the parsed result once it is available
|
|
fetchJSONFile('https://coinmarketcap-nexuist.rhcloud.com/api/dash/', function (data) {
|
|
var markup = '<div class="dash-ticker--title">Dash Price</div><div class="dash-ticker--wrapper">!fiat<div class="dash-ticker--change">!percent_change_24h</div><div class="dash-ticker--btc">!price_btc</div></div>',
|
|
fiatTemplate = '<div class="dash-ticker--fiat">!price</div>',
|
|
fiatMarkup = '';
|
|
|
|
for (var currencyName in data.price) {
|
|
if (document.querySelector('[data-dash-price-widget~="' + currencyName + '"]')) {
|
|
fiatMarkup += fiatTemplate.replace('!price', makeCurrencyString(data.price[currencyName]) + ' ' + currencyName.toUpperCase());
|
|
}
|
|
}
|
|
|
|
markup = markup.replace('!fiat', fiatMarkup);
|
|
markup = markup.replace('!percent_change_24h', (data.change > 0 ? '↗' : '↘') + data.change + "%");
|
|
markup = markup.replace('!price_btc', makeCurrencyString(data.price.btc) + " BTC");
|
|
document.querySelector('[data-dash-price-widget]').innerHTML = markup;
|
|
});
|
|
}
|
|
|
|
init();
|
|
}());
|