| Left: | ||
| Right: |
| LEFT | RIGHT |
|---|---|
| 1 /* | 1 /* |
| 2 * This file is part of Adblock Plus <https://adblockplus.org/>, | 2 * This file is part of Adblock Plus <https://adblockplus.org/>, |
| 3 * Copyright (C) 2006-2015 Eyeo GmbH | 3 * Copyright (C) 2006-2015 Eyeo GmbH |
| 4 * | 4 * |
| 5 * Adblock Plus is free software: you can redistribute it and/or modify | 5 * Adblock Plus is free software: you can redistribute it and/or modify |
| 6 * it under the terms of the GNU General Public License version 3 as | 6 * it under the terms of the GNU General Public License version 3 as |
| 7 * published by the Free Software Foundation. | 7 * published by the Free Software Foundation. |
| 8 * | 8 * |
| 9 * Adblock Plus is distributed in the hope that it will be useful, | 9 * Adblock Plus is distributed in the hope that it will be useful, |
| 10 * but WITHOUT ANY WARRANTY; without even the implied warranty of | 10 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | 11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| 12 * GNU General Public License for more details. | 12 * GNU General Public License for more details. |
| 13 * | 13 * |
| 14 * You should have received a copy of the GNU General Public License | 14 * You should have received a copy of the GNU General Public License |
| 15 * along with Adblock Plus. If not, see <http://www.gnu.org/licenses/>. | 15 * along with Adblock Plus. If not, see <http://www.gnu.org/licenses/>. |
| 16 */ | 16 */ |
| 17 | 17 |
| 18 /** | 18 /** |
| 19 * @fileOverview Handles notifications. | 19 * @fileOverview Handles notifications. |
| 20 */ | 20 */ |
| 21 | 21 |
| 22 Cu.import("resource://gre/modules/Services.jsm"); | 22 Cu.import("resource://gre/modules/Services.jsm"); |
| 23 | 23 |
| 24 let {Prefs} = require("prefs"); | 24 let {Prefs} = require("prefs"); |
| 25 let {Downloader, Downloadable, MILLIS_IN_MINUTE, MILLIS_IN_HOUR, MILLIS_IN_DAY} = require("downloader"); | 25 let {Downloader, Downloadable, MILLIS_IN_MINUTE, MILLIS_IN_HOUR, MILLIS_IN_DAY} = require("downloader"); |
| 26 let {Utils} = require("utils"); | 26 let {Utils} = require("utils"); |
| 27 let {Matcher} = require("matcher"); | 27 let {Matcher} = require("matcher"); |
| 28 let {Filter} = require("filterClasses"); | 28 let {Filter} = require("filterClasses"); |
| 29 | 29 |
| 30 let INITIAL_DELAY = 1 * MILLIS_IN_MINUTE; | 30 let INITIAL_DELAY = 12 * MILLIS_IN_MINUTE; |
| 31 let CHECK_INTERVAL = 1 * MILLIS_IN_HOUR; | 31 let CHECK_INTERVAL = 1 * MILLIS_IN_HOUR; |
| 32 let EXPIRATION_INTERVAL = 1 * MILLIS_IN_DAY; | 32 let EXPIRATION_INTERVAL = 1 * MILLIS_IN_DAY; |
| 33 let STARTUP_SHOW_DELAY = 3 * MILLIS_IN_MINUTE; | 33 let STARTUP_SHOW_DELAY = 3 * MILLIS_IN_MINUTE; |
| 34 let TYPE = { | 34 let TYPE = { |
| 35 information: 0, | 35 information: 0, |
| 36 question: 1, | 36 question: 1, |
| 37 critical: 2 | 37 critical: 2 |
| 38 }; | 38 }; |
| 39 | 39 |
| 40 let showListeners = []; | 40 let showListeners = []; |
| (...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 76 * @class | 76 * @class |
| 77 */ | 77 */ |
| 78 let Notification = exports.Notification = | 78 let Notification = exports.Notification = |
| 79 { | 79 { |
| 80 /** | 80 /** |
| 81 * Called on module startup. | 81 * Called on module startup. |
| 82 */ | 82 */ |
| 83 init: function() | 83 init: function() |
| 84 { | 84 { |
| 85 downloader = new Downloader(this._getDownloadables.bind(this), INITIAL_DELAY , CHECK_INTERVAL); | 85 downloader = new Downloader(this._getDownloadables.bind(this), INITIAL_DELAY , CHECK_INTERVAL); |
| 86 onShutdown.add(function() | |
| 87 { | |
| 88 downloader.cancel(); | |
| 89 }); | |
|
Wladimir Palant
2015/06/08 11:33:15
Mind changing this into arrow function as well for
Felix Dahlke
2015/06/08 19:34:34
Done.
| |
| 90 | |
| 91 downloader.onExpirationChange = this._onExpirationChange.bind(this); | 86 downloader.onExpirationChange = this._onExpirationChange.bind(this); |
| 92 downloader.onDownloadSuccess = this._onDownloadSuccess.bind(this); | 87 downloader.onDownloadSuccess = this._onDownloadSuccess.bind(this); |
| 93 downloader.onDownloadError = this._onDownloadError.bind(this); | 88 downloader.onDownloadError = this._onDownloadError.bind(this); |
| 89 onShutdown.add(() => downloader.cancel()); | |
| 94 | 90 |
| 95 notificationTimer = Cc["@mozilla.org/timer;1"].createInstance(Ci.nsITimer); | 91 notificationTimer = Cc["@mozilla.org/timer;1"].createInstance(Ci.nsITimer); |
| 96 notificationTimer.initWithCallback(Notification.showNext, | 92 notificationTimer.initWithCallback(Notification.showNext.bind(this), |
|
Wladimir Palant
2015/06/08 11:33:15
Notification.showNext.bind(this)? The next person
Felix Dahlke
2015/06/08 19:34:34
Done.
| |
| 97 STARTUP_SHOW_DELAY, | 93 STARTUP_SHOW_DELAY, |
| 98 Ci.nsITimer.TYPE_ONE_SHOT); | 94 Ci.nsITimer.TYPE_ONE_SHOT); |
| 99 onShutdown.add(() => notificationTimer.cancel()); | 95 onShutdown.add(() => notificationTimer.cancel()); |
| 100 }, | 96 }, |
| 101 | 97 |
| 102 /** | 98 /** |
| 103 * Yields a Downloadable instances for the notifications download. | 99 * Yields a Downloadable instances for the notifications download. |
| 104 */ | 100 */ |
| 105 _getDownloadables: function*() | 101 _getDownloadables: function*() |
| 106 { | 102 { |
| (...skipping 68 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 175 if (showListeners.indexOf(listener) == -1) | 171 if (showListeners.indexOf(listener) == -1) |
| 176 showListeners.push(listener); | 172 showListeners.push(listener); |
| 177 }, | 173 }, |
| 178 | 174 |
| 179 /** | 175 /** |
| 180 * Removes the supplied listener. | 176 * Removes the supplied listener. |
| 181 * @param {Function} listener Listener that was added via addShowListener() | 177 * @param {Function} listener Listener that was added via addShowListener() |
| 182 */ | 178 */ |
| 183 removeShowListener: function(listener) | 179 removeShowListener: function(listener) |
| 184 { | 180 { |
| 185 showListeners.splice(showListeners.indexOf(listener)); | 181 let index = showListeners.indexOf(listener); |
|
Wladimir Palant
2015/06/08 11:33:15
For reference:
[1,2,3].splice(1) => [1]
[1,2,3].s
Felix Dahlke
2015/06/08 19:34:34
Done.
| |
| 186 }, | 182 if (index != -1) |
| 187 | 183 showListeners.splice(index, 1); |
| 188 /** | |
| 189 * Removes all listeners added via addShowListener(). | |
| 190 */ | |
| 191 removeAllShowListeners: function() | |
|
Wladimir Palant
2015/06/08 11:33:15
Why do we need that function? Seems to be a footgu
Felix Dahlke
2015/06/08 19:34:34
Done.
Wladimir Palant
2015/06/08 20:45:15
Why am I still seeing it? :)
Felix Dahlke
2015/06/08 22:01:53
Good question, done for real now.
| |
| 192 { | |
| 193 showListeners = []; | |
| 194 }, | 184 }, |
| 195 | 185 |
| 196 /** | 186 /** |
| 197 * Determines which notification is to be shown next. | 187 * Determines which notification is to be shown next. |
| 198 * @param {String} url URL to match notifications to (optional) | 188 * @param {String} url URL to match notifications to (optional) |
| 199 * @return {Object} notification to be shown, or null if there is none | 189 * @return {Object} notification to be shown, or null if there is none |
| 200 */ | 190 */ |
| 201 _getNextToShow: function(url) | 191 _getNextToShow: function(url) |
| 202 { | 192 { |
| 203 function checkTarget(target, parameter, name, version) | 193 function checkTarget(target, parameter, name, version) |
| (...skipping 168 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 372 | 362 |
| 373 /** | 363 /** |
| 374 * Notifies question listeners about interactions with a notification | 364 * Notifies question listeners about interactions with a notification |
| 375 * @param {String} id notification ID | 365 * @param {String} id notification ID |
| 376 * @param {Boolean} approved indicator whether notification has been approved or not | 366 * @param {Boolean} approved indicator whether notification has been approved or not |
| 377 */ | 367 */ |
| 378 triggerQuestionListeners: function(id, approved) | 368 triggerQuestionListeners: function(id, approved) |
| 379 { | 369 { |
| 380 if (!(id in questionListeners)) | 370 if (!(id in questionListeners)) |
| 381 return; | 371 return; |
| 382 for (let listener of questionListeners[id]) | 372 let listeners = questionListeners[id]; |
|
Wladimir Palant
2015/06/08 11:33:15
Please keep using a temporary variable here - othe
Felix Dahlke
2015/06/08 19:34:34
Done.
Wladimir Palant
2015/06/08 20:45:15
I would have called that variable "listeners" or s
Felix Dahlke
2015/06/08 22:01:53
True, wasn't a brilliant name. Done, since I was u
| |
| 373 for (let listener of listeners) | |
| 383 listener(approved); | 374 listener(approved); |
| 384 }, | 375 }, |
| 385 | 376 |
| 386 /** | 377 /** |
| 387 * Toggles whether notifications of a specific category should be ignored | 378 * Toggles whether notifications of a specific category should be ignored |
| 388 * @param {String} category notification category identifier | 379 * @param {String} category notification category identifier |
| 389 * @param {Boolean} [forceValue] force specified value | 380 * @param {Boolean} [forceValue] force specified value |
| 390 */ | 381 */ |
| 391 toggleIgnoreCategory: function(category, forceValue) | 382 toggleIgnoreCategory: function(category, forceValue) |
| 392 { | 383 { |
| 393 let categories = Prefs.notifications_ignoredcategories; | 384 let categories = Prefs.notifications_ignoredcategories; |
| 394 let index = categories.indexOf(category); | 385 let index = categories.indexOf(category); |
| 395 if (index == -1 && forceValue !== false) | 386 if (index == -1 && forceValue !== false) |
| 396 { | 387 { |
| 397 categories.push(category); | 388 categories.push(category); |
| 398 Prefs.notifications_showui = true; | 389 Prefs.notifications_showui = true; |
| 399 } | 390 } |
| 400 else if (index != -1 && forceValue !== true) | 391 else if (index != -1 && forceValue !== true) |
| 401 categories.splice(index, 1); | 392 categories.splice(index, 1); |
| 402 | 393 |
| 403 // HACK: JSON values aren't saved unless they are assigned a different objec t. | 394 // HACK: JSON values aren't saved unless they are assigned a different objec t. |
| 404 Prefs.notifications_ignoredcategories = JSON.parse(JSON.stringify(categories )); | 395 Prefs.notifications_ignoredcategories = JSON.parse(JSON.stringify(categories )); |
| 405 } | 396 } |
| 406 }; | 397 }; |
| 407 Notification.init(); | 398 Notification.init(); |
| LEFT | RIGHT |