| Left: | ||
| Right: |
| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * This file is part of Adblock Plus <http://adblockplus.org/>, | 2 * This file is part of Adblock Plus <http://adblockplus.org/>, |
| 3 * Copyright (C) 2006-2014 Eyeo GmbH | 3 * Copyright (C) 2006-2014 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 |
| (...skipping 23 matching lines...) Expand all Loading... | |
| 34 this.isFrameWhitelisted = isFrameWhitelisted; | 34 this.isFrameWhitelisted = isFrameWhitelisted; |
| 35 this.processKey = processKey; | 35 this.processKey = processKey; |
| 36 this.getKey = getKey; | 36 this.getKey = getKey; |
| 37 } | 37 } |
| 38 var FilterStorage = require("filterStorage").FilterStorage; | 38 var FilterStorage = require("filterStorage").FilterStorage; |
| 39 var ElemHide = require("elemHide").ElemHide; | 39 var ElemHide = require("elemHide").ElemHide; |
| 40 var defaultMatcher = require("matcher").defaultMatcher; | 40 var defaultMatcher = require("matcher").defaultMatcher; |
| 41 var Prefs = require("prefs").Prefs; | 41 var Prefs = require("prefs").Prefs; |
| 42 var Synchronizer = require("synchronizer").Synchronizer; | 42 var Synchronizer = require("synchronizer").Synchronizer; |
| 43 var Utils = require("utils").Utils; | 43 var Utils = require("utils").Utils; |
| 44 var Notification = require("notification").Notification; | 44 var NotificationStorage = require("notification").Notification; |
| 45 var initAntiAdblockNotification = require("antiadblockInit").initAntiAdblockNoti fication; | 45 var initAntiAdblockNotification = require("antiadblockInit").initAntiAdblockNoti fication; |
| 46 var parseFilters = require("filterValidation").parseFilters; | 46 var parseFilters = require("filterValidation").parseFilters; |
| 47 | 47 |
| 48 // Some types cannot be distinguished | 48 // Some types cannot be distinguished |
| 49 RegExpFilter.typeMap.OBJECT_SUBREQUEST = RegExpFilter.typeMap.OBJECT; | 49 RegExpFilter.typeMap.OBJECT_SUBREQUEST = RegExpFilter.typeMap.OBJECT; |
| 50 RegExpFilter.typeMap.MEDIA = RegExpFilter.typeMap.FONT = RegExpFilter.typeMap.OT HER; | 50 RegExpFilter.typeMap.MEDIA = RegExpFilter.typeMap.FONT = RegExpFilter.typeMap.OT HER; |
| 51 | 51 |
| 52 // Chrome on Linux does not fully support chrome.notifications until version 35 | 52 // Chrome on Linux does not fully support chrome.notifications until version 35 |
| 53 // https://code.google.com/p/chromium/issues/detail?id=291485 | 53 // https://code.google.com/p/chromium/issues/detail?id=291485 |
| 54 var canUseChromeNotifications = require("info").platform == "chromium" | 54 var canUseChromeNotifications = require("info").platform == "chromium" |
| (...skipping 237 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 292 win.openTab(Utils.getDocLink(link)); | 292 win.openTab(Utils.getDocLink(link)); |
| 293 }); | 293 }); |
| 294 }); | 294 }); |
| 295 } | 295 } |
| 296 } | 296 } |
| 297 | 297 |
| 298 function notificationButtonClick(buttonIndex) | 298 function notificationButtonClick(buttonIndex) |
| 299 { | 299 { |
| 300 if (activeNotification.type === "question") | 300 if (activeNotification.type === "question") |
| 301 { | 301 { |
| 302 Notification.triggerQuestionListeners(activeNotification.id, buttonIndex === 0); | 302 NotificationStorage.triggerQuestionListeners(activeNotification.id, buttonIn dex === 0); |
| 303 Notification.markAsShown(activeNotification.id); | 303 NotificationStorage.markAsShown(activeNotification.id); |
| 304 activeNotification.onClicked(); | 304 activeNotification.onClicked(); |
| 305 } | 305 } |
| 306 else if (activeNotification.links && activeNotification.links[buttonIndex]) | 306 else if (activeNotification.links && activeNotification.links[buttonIndex]) |
| 307 { | 307 { |
| 308 ext.windows.getLastFocused(function(win) | 308 ext.windows.getLastFocused(function(win) |
| 309 { | 309 { |
| 310 win.openTab(Utils.getDocLink(activeNotification.links[buttonIndex])); | 310 win.openTab(Utils.getDocLink(activeNotification.links[buttonIndex])); |
| 311 }); | 311 }); |
| 312 } | 312 } |
| 313 } | 313 } |
| (...skipping 44 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 358 } | 358 } |
| 359 | 359 |
| 360 function showNotification(notification) | 360 function showNotification(notification) |
| 361 { | 361 { |
| 362 if (activeNotification && activeNotification.id === notification.id) | 362 if (activeNotification && activeNotification.id === notification.id) |
| 363 return; | 363 return; |
| 364 | 364 |
| 365 activeNotification = notification; | 365 activeNotification = notification; |
| 366 if (activeNotification.type === "critical" || activeNotification.type === "que stion") | 366 if (activeNotification.type === "critical" || activeNotification.type === "que stion") |
| 367 { | 367 { |
| 368 var hasWebkitNotifications = typeof webkitNotifications !== "undefined"; | 368 var texts = NotificationStorage.getLocalizedTexts(notification); |
| 369 if (hasWebkitNotifications && "createHTMLNotification" in webkitNotification s) | |
| 370 { | |
| 371 var notification = webkitNotifications.createHTMLNotification("notificatio n.html"); | |
| 372 notification.show(); | |
| 373 prepareNotificationIconAndPopup(); | |
| 374 return; | |
| 375 } | |
| 376 | |
| 377 var texts = Notification.getLocalizedTexts(notification); | |
| 378 var title = texts.title || ""; | 369 var title = texts.title || ""; |
| 379 var message = texts.message ? texts.message.replace(/<\/?(a|strong)>/g, "") : ""; | 370 var message = texts.message ? texts.message.replace(/<\/?(a|strong)>/g, "") : ""; |
| 380 var iconUrl = ext.getURL("icons/abp-128.png"); | 371 var iconUrl = ext.getURL("icons/abp-128.png"); |
| 381 var hasLinks = activeNotification.links && activeNotification.links.length > 0; | 372 var hasLinks = activeNotification.links && activeNotification.links.length > 0; |
| 382 | 373 |
| 383 if (canUseChromeNotifications) | 374 if (canUseChromeNotifications) |
| 384 { | 375 { |
| 385 var opts = { | 376 var opts = { |
| 386 type: "basic", | 377 type: "basic", |
| 387 title: title, | 378 title: title, |
| (...skipping 14 matching lines...) Expand all Loading... | |
| 402 while (match = regex.exec(plainMessage)) | 393 while (match = regex.exec(plainMessage)) |
| 403 opts.buttons.push({title: match[1]}); | 394 opts.buttons.push({title: match[1]}); |
| 404 } | 395 } |
| 405 | 396 |
| 406 imgToBase64(iconUrl, function(iconData) | 397 imgToBase64(iconUrl, function(iconData) |
| 407 { | 398 { |
| 408 opts["iconUrl"] = iconData; | 399 opts["iconUrl"] = iconData; |
| 409 chrome.notifications.create("", opts, function() {}); | 400 chrome.notifications.create("", opts, function() {}); |
| 410 }); | 401 }); |
| 411 } | 402 } |
| 412 else if (hasWebkitNotifications && "createNotification" in webkitNotificatio ns && activeNotification.type !== "question") | 403 else if ("Notification" in window && activeNotification.type !== "question") |
| 413 { | 404 { |
| 414 if (hasLinks) | 405 if (hasLinks) |
| 415 message += " " + ext.i18n.getMessage("notification_without_buttons"); | 406 message += " " + ext.i18n.getMessage("notification_without_buttons"); |
| 416 | 407 |
| 417 imgToBase64(iconUrl, function(iconData) | 408 imgToBase64(iconUrl, function(iconData) |
| 418 { | 409 { |
| 419 var notification = webkitNotifications.createNotification(iconData, titl e, message); | 410 var notification = new Notification( |
| 420 notification.show(); | 411 title, |
| 421 notification.addEventListener("click", openNotificationLinks, false); | 412 { |
| 422 notification.addEventListener("close", notificationClosed, false); | 413 lang: Utils.appLocale, |
| 414 dir: ext.i18n.getMessage("@@bidi_dir"), | |
| 415 body: message, | |
| 416 icon: iconData | |
| 417 } | |
| 418 ); | |
| 419 | |
| 420 notification.onclick = openNotificationLinks; | |
| 421 notification.onclose = notificationClosed; | |
|
Wladimir Palant
2015/01/13 07:39:16
I certainly prefer addEventListener() to onclick -
Sebastian Noack
2015/01/13 12:30:20
Thanks for pointing this out. I just overlooked th
| |
| 423 }); | 422 }); |
| 424 } | 423 } |
| 425 else | 424 else |
| 426 { | 425 { |
| 427 var message = title + "\n" + message; | 426 var message = title + "\n" + message; |
| 428 if (hasLinks) | 427 if (hasLinks) |
| 429 message += "\n\n" + ext.i18n.getMessage("notification_with_buttons"); | 428 message += "\n\n" + ext.i18n.getMessage("notification_with_buttons"); |
| 430 | 429 |
| 431 var approved = confirm(message); | 430 var approved = confirm(message); |
| 432 if (activeNotification.type === "question") | 431 if (activeNotification.type === "question") |
| (...skipping 142 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 575 | 574 |
| 576 // update icon when page changes location | 575 // update icon when page changes location |
| 577 ext.pages.onLoading.addListener(function(page) | 576 ext.pages.onLoading.addListener(function(page) |
| 578 { | 577 { |
| 579 page.sendMessage({type: "clickhide-deactivate"}); | 578 page.sendMessage({type: "clickhide-deactivate"}); |
| 580 refreshIconAndContextMenu(page); | 579 refreshIconAndContextMenu(page); |
| 581 }); | 580 }); |
| 582 | 581 |
| 583 setTimeout(function() | 582 setTimeout(function() |
| 584 { | 583 { |
| 585 var notificationToShow = Notification.getNextToShow(); | 584 var notificationToShow = NotificationStorage.getNextToShow(); |
| 586 if (notificationToShow) | 585 if (notificationToShow) |
| 587 showNotification(notificationToShow); | 586 showNotification(notificationToShow); |
| 588 }, 3 * 60 * 1000); | 587 }, 3 * 60 * 1000); |
| OLD | NEW |