-
Notifications
You must be signed in to change notification settings - Fork 55
/
Copy pathtimer.js
127 lines (112 loc) · 3.38 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
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
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) {
$('#timer').show();
timerEnd = moment().add(seconds_left * 1000);
if (seconds_left >= 0) {
updateTitle(seconds_left);
}
else {
updateTitle("??");
}
updateBar();
if (!animating) {
animate();
}
}
function animate() {
animating = true;
// Limit framerate with setTimeout
setTimeout(function () {
var timer = (timerEnd - moment());
timerBar.attr('fill', flairColor(timer / 1000));
if (timer >= 0) {
timerBar.attr('y', function() {
return Chart.yScale(timer / 1000);
});
}
else {
timerBar.attr('y', function() {
return Chart.yScale(0);
});
}
if (timer >= 0) {
$('#timer').text(fmtSeconds(timer / 1000));
timerBar.attr('height', function(d, i) {
return Chart.yScale(60) - Chart.yScale(timer / 1000);
})
}
else {
$('#timer').text("??");
timerBar.attr('height', function(d, i) {
return Chart.yScale(60);
})
}
;
requestAnimationFrame(animate);
}, 1000 / 30); // 30 fps
}
self.resize = function() {
var statsView = $('#stats');
if ($(window).width() < 400) {
$('#timer')
.addClass('small')
.css('left', statsView.offset().left)
.css('top', statsView.offset().top + statsView.outerHeight() + 5);
return;
}
$('#timer')
.removeClass('small')
.css('left', statsView.offset().left + statsView.outerWidth() + 10)
.css('top', Chart.margins.top - 10);
}
//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;
}());