var MISSING_FAVICON_BASE64 = ""; var tooltip = $('#tooltip'); function getTimestamp(ms, timeOnly) { var date = new Date(0); date.setUTCSeconds(ms); return date.toLocaleTimeString(); } function safeName(name) { return name.replace(/ /g, ''); } function renderTooltip(x, y, html) { tooltip.html(html).css({ top: y, left: x }).fadeIn(0); } function hideTooltip() { tooltip.hide(); } function formatNumber(x) { return x.toString().replace(/\B(?=(\d{3})+(?!\d))/g, ','); } function handlePlotHover(event, pos, item) { if (item) { var text = getTimestamp(item.datapoint[0] / 1000) + '\
\ ' + formatNumber(item.datapoint[1]) + ' Players'; if (item.series && item.series.label) { text = item.series.label + '
' + text; } renderTooltip(item.pageX + 5, item.pageY + 5, text); } else { hideTooltip(); } } function convertGraphData(rawData) { var data = []; var keys = Object.keys(rawData); for (var i = 0; i < keys.length; i++) { data.push({ data: rawData[keys[i]], yaxis: 1, label: keys[i], color: stringToColor(keys[i]) }); } return data; } function stringToColor(base) { var hash; for (var i = 0, hash = 0; i < base.length; i++) { hash = base.charCodeAt(i) + ((hash << 5) - hash); } color = Math.floor(Math.abs((Math.sin(hash) * 10000) % 1 * 16777216)).toString(16); return '#' + Array(6 - color.length + 1).join('0') + color; } function msToTime(timer) { var milliseconds = timer % 1000; timer = (timer - milliseconds) / 1000; var seconds = timer % 60; timer = (timer - seconds) / 60; var minutes = timer % 60; var hours = (timer - minutes) / 60; var string = ''; if (hours > 0) { string += hours + 'h'; } if (minutes > 0) { string += minutes + 'm'; } if (seconds > 0) { string += seconds + 's'; } return string; }