From 1d8936fa443bd47872cdeb94da8f2c1507a8959c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Tautvidas=20Sipavi=C4=8Dius?= Date: Mon, 26 Dec 2016 16:14:05 +0200 Subject: [PATCH] Fix timer resets on notification closes, add human readable timers --- js/background.js | 26 ++++++++++++++++++++++++-- manifest.json | 2 +- 2 files changed, 25 insertions(+), 3 deletions(-) diff --git a/js/background.js b/js/background.js index 2367a1e..f6691ce 100644 --- a/js/background.js +++ b/js/background.js @@ -82,6 +82,7 @@ var notification, breakTime, workTime, rule, enableSound, iCloseNotification = 0 resetTimes(); $(document).ready(function () { chrome.notifications.onButtonClicked.addListener(handleNotificationInteraction); + chrome.notifications.onClosed.addListener(handleNotificationClosed); waitForNext(); updateBadge(); }); @@ -124,6 +125,12 @@ function handleNotificationInteraction(notificationId, buttonIndex) { } } +function handleNotificationClosed(notificationId, byUser) { + if (notificationId === 'bh-notification' && byUser && breakTimeLeft === 0) { + skipBreak(); + } +} + function closeNotification() { "use strict"; iCloseNotification = 1; @@ -175,7 +182,7 @@ function updateBreakNotificationTimer() { chrome.notifications.update('bh-notification', { type: 'progress', title: 'Break Helper', - message: "You're on a break.", + message: "You're on a break ($%1s).".replace("$%1s", secondsToClock(breakTimeLeft)), iconUrl: 'icon128.png', buttons: [], progress: progress @@ -276,7 +283,7 @@ function updateBadgeClock() { if (left <= 60) { chrome.browserAction.setBadgeBackgroundColor({color : [255, 0, 0, 255]}); } - chrome.browserAction.setBadgeText({text: m + ':' + s}); + chrome.browserAction.setBadgeText({text: m.pad(2) + ':' + s.pad(2)}); } else { chrome.browserAction.setBadgeBackgroundColor({color : [255, 0, 0, 255]}); @@ -292,3 +299,18 @@ function updateBadge() { function playSound ( url ) { (new Audio(url)).play(); } + +function secondsToClock(leftSeconds) { + var h, m, s, tempLeft; + h = Math.floor(leftSeconds / 3600); + tempLeft = leftSeconds % 3600; + s = tempLeft % 60; + m = (tempLeft - s) / 60; + + return h.pad(2) + ":" + m.pad(2) + ":" + s.pad(2); +} +Number.prototype.pad = function(size) { + var s = String(this); + while (s.length < (size || 2)) {s = "0" + s;} + return s; +} diff --git a/manifest.json b/manifest.json index b50a0d3..167ef55 100644 --- a/manifest.json +++ b/manifest.json @@ -1,7 +1,7 @@ { "manifest_version": 2, "name": "Break Helper", - "version": "1.5", + "version": "1.6", "description": "Reminds you to take a break, because breaks are good for your health and productivity", "icons": { "16": "icon16.png",