2017-10-29 20:01:13 +00:00
|
|
|
/* Baby Buddy Dashboard
|
|
|
|
*
|
|
|
|
* Provides a "watch" function to update the dashboard at one minute intervals
|
|
|
|
* and/or on visibility state changes.
|
|
|
|
*/
|
|
|
|
BabyBuddy.Dashboard = function ($) {
|
|
|
|
var runIntervalId = null;
|
|
|
|
var dashboardElement = null;
|
2018-03-23 03:29:40 +00:00
|
|
|
var hidden = null;
|
2017-10-29 20:01:13 +00:00
|
|
|
|
|
|
|
var Dashboard = {
|
2017-11-11 22:27:42 +00:00
|
|
|
watch: function(element_id, refresh_rate) {
|
2017-10-29 20:01:13 +00:00
|
|
|
dashboardElement = $('#' + element_id);
|
|
|
|
|
|
|
|
if (dashboardElement.length == 0) {
|
|
|
|
console.error('Baby Buddy: Dashboard element not found.');
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2018-03-23 03:29:40 +00:00
|
|
|
if (typeof document.hidden !== "undefined") {
|
|
|
|
hidden = "hidden";
|
|
|
|
}
|
|
|
|
else if (typeof document.msHidden !== "undefined") {
|
|
|
|
hidden = "msHidden";
|
|
|
|
}
|
|
|
|
else if (typeof document.webkitHidden !== "undefined") {
|
|
|
|
hidden = "webkitHidden";
|
|
|
|
}
|
2017-10-29 20:01:13 +00:00
|
|
|
|
2018-03-23 03:29:40 +00:00
|
|
|
if (typeof window.addEventListener === "undefined" || typeof document.hidden === "undefined") {
|
|
|
|
if (refresh_rate) {
|
|
|
|
runIntervalId = setInterval(this.update, refresh_rate);
|
2017-10-29 20:01:13 +00:00
|
|
|
}
|
2018-03-23 03:29:40 +00:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
window.addEventListener('focus', Dashboard.handleVisibilityChange, false);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
handleVisibilityChange: function() {
|
|
|
|
if (!document[hidden]) {
|
|
|
|
Dashboard.update();
|
|
|
|
}
|
2017-10-29 20:01:13 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
update: function() {
|
|
|
|
// TODO: Someday maybe update in place?
|
|
|
|
location.reload();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
return Dashboard;
|
|
|
|
}(jQuery);
|