forked from jamesrom/jamesrom.github.io
-
Notifications
You must be signed in to change notification settings - Fork 0
/
timer.js
100 lines (87 loc) · 2.88 KB
/
timer.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
var Timer = (function() {
var self = {};
var fmtSeconds = d3.format(".3n");
var animating;
var baseTitle = document.title;
var timerEnd;
var timerBar = Chart.svg.append('rect')
.attr('class', 'timer-bar')
.attr('x', 1)
.attr('y', 1)
.attr('width', 1)
.attr('height', 1)
.attr('fill', '#FFF')
.attr('shape-rendering', 'crispEdges');
self.sync = function(seconds_left) {
timerEnd = moment().add(seconds_left * 1000);
updateTitle(seconds_left);
updateBar();
if (!animating) {
animate();
}
}
function animate() {
animating = true;
var timer = (timerEnd - moment());
timerBar
.attr('y', function() {
return Chart.yScale(timer / 1000);
})
.attr('height', function(d, i) {
return Chart.yScale(60) - Chart.yScale(timer / 1000);
})
.attr('fill', flairColor(timer / 1000));
$('#timer').text(fmtSeconds(timer / 1000));
requestAnimationFrame(animate);
}
self.resize = function() {
if ($(window).width() < 400) {
$('#timer')
.addClass('small')
.css('left', $('#stats').offset().left)
.css('top', $('#stats').offset().top + $('#stats').outerHeight());
return;
}
$('#timer')
.removeClass('small')
.css('left', ($('#stats').offset().left + $('#stats').outerWidth()))
.css('top', Chart.margins.top - 4);
}
//Used to update timer bar externally when zooming/scrolling
function updateBar() {
timerBar
.attr('x', function(d, i) {
return Chart.xScale(Stats.resets);
})
.attr('width', function(d, i) {
return Chart.xScale(Stats.resets) - Chart.xScale(Stats.resets - 1);
});
}
function updateTitle(seconds_left) {
// Update the title of the page to display seconds left.
document.title = '[' + seconds_left + 's] ' + baseTitle;
$('#favicon')
.prop('type', 'image/x-icon')
.prop('href', flairIcon(seconds_left));
}
function flairIcon(seconds) {
if (seconds > 51) {
return '';
}
if (seconds > 41) {
return '';
}
if (seconds > 31) {
return '';
}
if (seconds > 21) {
return '';
}
if (seconds > 11) {
return '';
}
return '';
}
self.updateBar = updateBar;
return self;
}());