move some functions to helper.js
This commit is contained in:
parent
c9351d1258
commit
c9d825041b
3 changed files with 113 additions and 109 deletions
110
helper.js
Normal file
110
helper.js
Normal file
|
@ -0,0 +1,110 @@
|
||||||
|
function get(url) {
|
||||||
|
return new Promise(function(resolve, reject) {
|
||||||
|
var req = new XMLHttpRequest();
|
||||||
|
req.open('GET', url);
|
||||||
|
|
||||||
|
req.onload = function() {
|
||||||
|
if (req.status == 200) {
|
||||||
|
resolve(req.response);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
reject(Error(req.statusText));
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
req.onerror = function() {
|
||||||
|
reject(Error("Network Error"));
|
||||||
|
};
|
||||||
|
|
||||||
|
req.send();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function getJSON(url) {
|
||||||
|
return get(url).then(JSON.parse)
|
||||||
|
}
|
||||||
|
|
||||||
|
function sortByKey(key, d) {
|
||||||
|
return d.slice().sort( function (a, b) {
|
||||||
|
return a[key] - b[key]
|
||||||
|
}).reverse()
|
||||||
|
}
|
||||||
|
|
||||||
|
function limit(key, m, d) {
|
||||||
|
return d.filter( function (d) {
|
||||||
|
return d[key].isAfter(m)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
function sum(a) {
|
||||||
|
return a.reduce( function (a, b) {
|
||||||
|
return a + b
|
||||||
|
}, 0)
|
||||||
|
}
|
||||||
|
|
||||||
|
function one() {
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
|
||||||
|
function trueDefault(d) {
|
||||||
|
return d === undefined ? true : d
|
||||||
|
}
|
||||||
|
|
||||||
|
function dictGet(dict, key) {
|
||||||
|
var k = key.shift()
|
||||||
|
|
||||||
|
if (!(k in dict))
|
||||||
|
return null
|
||||||
|
|
||||||
|
if (key.length == 0)
|
||||||
|
return dict[k]
|
||||||
|
|
||||||
|
return dictGet(dict[k], key)
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Helpers working with nodes */
|
||||||
|
|
||||||
|
function offline(d) {
|
||||||
|
return !d.flags.online
|
||||||
|
}
|
||||||
|
|
||||||
|
function online(d) {
|
||||||
|
return d.flags.online
|
||||||
|
}
|
||||||
|
|
||||||
|
function has_location(d) {
|
||||||
|
return "location" in d.nodeinfo
|
||||||
|
}
|
||||||
|
|
||||||
|
function subtract(a, b) {
|
||||||
|
var ids = {}
|
||||||
|
|
||||||
|
b.forEach( function (d) {
|
||||||
|
ids[d.nodeinfo.node_id] = true
|
||||||
|
})
|
||||||
|
|
||||||
|
return a.filter( function (d) {
|
||||||
|
return !(d.nodeinfo.node_id in ids)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Helpers working with links */
|
||||||
|
|
||||||
|
function showDistance(d) {
|
||||||
|
if (isNaN(d.distance))
|
||||||
|
return
|
||||||
|
|
||||||
|
return (new Intl.NumberFormat("de-DE", {maximumFractionDigits: 0}).format(d.distance)) + " m"
|
||||||
|
}
|
||||||
|
|
||||||
|
function showTq(d) {
|
||||||
|
var opts = { maximumFractionDigits: 0 }
|
||||||
|
|
||||||
|
return (new Intl.NumberFormat("de-DE", opts).format(100/d.tq)) + "%"
|
||||||
|
}
|
||||||
|
|
||||||
|
function linkId(d) {
|
||||||
|
var ids = [d.source.node.nodeinfo.node_id, d.target.node.nodeinfo.node_id]
|
||||||
|
|
||||||
|
return ids.sort().join("-")
|
||||||
|
}
|
|
@ -287,6 +287,7 @@
|
||||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/leaflet/0.7.3/leaflet.js"></script>
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/leaflet/0.7.3/leaflet.js"></script>
|
||||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/tablesort/3.0.2/tablesort.min.js"></script>
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/tablesort/3.0.2/tablesort.min.js"></script>
|
||||||
<script src="vendor/tablesort.numeric.js"></script>
|
<script src="vendor/tablesort.numeric.js"></script>
|
||||||
|
<script src="helper.js"></script>
|
||||||
<script src="history.js"></script>
|
<script src="history.js"></script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
|
|
111
history.js
111
history.js
|
@ -1,31 +1,5 @@
|
||||||
document.addEventListener('DOMContentLoaded', main)
|
document.addEventListener('DOMContentLoaded', main)
|
||||||
|
|
||||||
function get(url) {
|
|
||||||
return new Promise(function(resolve, reject) {
|
|
||||||
var req = new XMLHttpRequest();
|
|
||||||
req.open('GET', url);
|
|
||||||
|
|
||||||
req.onload = function() {
|
|
||||||
if (req.status == 200) {
|
|
||||||
resolve(req.response);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
reject(Error(req.statusText));
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
req.onerror = function() {
|
|
||||||
reject(Error("Network Error"));
|
|
||||||
};
|
|
||||||
|
|
||||||
req.send();
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
function getJSON(url) {
|
|
||||||
return get(url).then(JSON.parse)
|
|
||||||
}
|
|
||||||
|
|
||||||
function main() {
|
function main() {
|
||||||
getJSON("config.json").then( function (config) {
|
getJSON("config.json").then( function (config) {
|
||||||
moment.locale("de")
|
moment.locale("de")
|
||||||
|
@ -52,42 +26,6 @@ function main() {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
function sort(key, d) {
|
|
||||||
return d.slice().sort( function (a, b) {
|
|
||||||
return a[key] - b[key]
|
|
||||||
}).reverse()
|
|
||||||
}
|
|
||||||
|
|
||||||
function limit(key, m, d) {
|
|
||||||
return d.filter( function (d) {
|
|
||||||
return d[key].isAfter(m)
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
function offline(d) {
|
|
||||||
return !d.flags.online
|
|
||||||
}
|
|
||||||
|
|
||||||
function online(d) {
|
|
||||||
return d.flags.online
|
|
||||||
}
|
|
||||||
|
|
||||||
function has_location(d) {
|
|
||||||
return "location" in d.nodeinfo
|
|
||||||
}
|
|
||||||
|
|
||||||
function subtract(a, b) {
|
|
||||||
var ids = {}
|
|
||||||
|
|
||||||
b.forEach( function (d) {
|
|
||||||
ids[d.nodeinfo.node_id] = true
|
|
||||||
})
|
|
||||||
|
|
||||||
return a.filter( function (d) {
|
|
||||||
return !(d.nodeinfo.node_id in ids)
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
function handle_data(config, sidebar, infobox, map, gotoAnything) {
|
function handle_data(config, sidebar, infobox, map, gotoAnything) {
|
||||||
return function (data) {
|
return function (data) {
|
||||||
var nodedict = data[0]
|
var nodedict = data[0]
|
||||||
|
@ -105,8 +43,8 @@ function handle_data(config, sidebar, infobox, map, gotoAnything) {
|
||||||
var now = moment()
|
var now = moment()
|
||||||
var age = moment(now).subtract(14, 'days')
|
var age = moment(now).subtract(14, 'days')
|
||||||
|
|
||||||
var newnodes = limit("firstseen", age, sort("firstseen", nodes).filter(online))
|
var newnodes = limit("firstseen", age, sortByKey("firstseen", nodes).filter(online))
|
||||||
var lostnodes = limit("lastseen", age, sort("lastseen", nodes).filter(offline))
|
var lostnodes = limit("lastseen", age, sortByKey("lastseen", nodes).filter(offline))
|
||||||
|
|
||||||
var onlinenodes = nodes.filter(online)
|
var onlinenodes = nodes.filter(online)
|
||||||
|
|
||||||
|
@ -206,25 +144,6 @@ function mkSidebar(el) {
|
||||||
return container
|
return container
|
||||||
}
|
}
|
||||||
|
|
||||||
function showDistance(d) {
|
|
||||||
if (isNaN(d.distance))
|
|
||||||
return
|
|
||||||
|
|
||||||
return (new Intl.NumberFormat("de-DE", {maximumFractionDigits: 0}).format(d.distance)) + " m"
|
|
||||||
}
|
|
||||||
|
|
||||||
function showTq(d) {
|
|
||||||
var opts = { maximumFractionDigits: 0 }
|
|
||||||
|
|
||||||
return (new Intl.NumberFormat("de-DE", opts).format(100/d.tq)) + "%"
|
|
||||||
}
|
|
||||||
|
|
||||||
function linkId(d) {
|
|
||||||
var ids = [d.source.node.nodeinfo.node_id, d.target.node.nodeinfo.node_id]
|
|
||||||
|
|
||||||
return ids.sort().join("-")
|
|
||||||
}
|
|
||||||
|
|
||||||
function mkmap(map, sidebar, now, newnodes, lostnodes, onlinenodes, graph, gotoAnything) {
|
function mkmap(map, sidebar, now, newnodes, lostnodes, onlinenodes, graph, gotoAnything) {
|
||||||
function mkMarker(dict, iconFunc) {
|
function mkMarker(dict, iconFunc) {
|
||||||
return function (d) {
|
return function (d) {
|
||||||
|
@ -464,16 +383,6 @@ function mkNodesList(el, showContact, tf, gotoProxy, title, list) {
|
||||||
el.appendChild(table)
|
el.appendChild(table)
|
||||||
}
|
}
|
||||||
|
|
||||||
function sum(a) {
|
|
||||||
return a.reduce( function (a, b) {
|
|
||||||
return a + b
|
|
||||||
}, 0)
|
|
||||||
}
|
|
||||||
|
|
||||||
function one() {
|
|
||||||
return 1
|
|
||||||
}
|
|
||||||
|
|
||||||
function showMeshstats(el, nodes) {
|
function showMeshstats(el, nodes) {
|
||||||
var h2 = document.createElement("h2")
|
var h2 = document.createElement("h2")
|
||||||
h2.textContent = "Übersicht"
|
h2.textContent = "Übersicht"
|
||||||
|
@ -820,10 +729,6 @@ function gotoHistory(gotoAnything, dict, s) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function trueDefault(d) {
|
|
||||||
return d === undefined ? true : d
|
|
||||||
}
|
|
||||||
|
|
||||||
function gotoBuilder(config, infobox, nodes, links) {
|
function gotoBuilder(config, infobox, nodes, links) {
|
||||||
var markers = {}
|
var markers = {}
|
||||||
var self = this
|
var self = this
|
||||||
|
@ -870,15 +775,3 @@ function gotoBuilder(config, infobox, nodes, links) {
|
||||||
|
|
||||||
return this
|
return this
|
||||||
}
|
}
|
||||||
|
|
||||||
function dictGet(dict, key) {
|
|
||||||
var k = key.shift()
|
|
||||||
|
|
||||||
if (!(k in dict))
|
|
||||||
return null
|
|
||||||
|
|
||||||
if (key.length == 0)
|
|
||||||
return dict[k]
|
|
||||||
|
|
||||||
return dictGet(dict[k], key)
|
|
||||||
}
|
|
||||||
|
|
Loading…
Reference in a new issue