| Left: | ||
| Right: |
| LEFT | RIGHT |
|---|---|
| 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-2013 Eyeo GmbH | 3 * Copyright (C) 2006-2013 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 (function() | 18 (function() |
| 19 { | 19 { |
| 20 var backgroundPage = chrome.extension.getBackgroundPage(); | 20 var backgroundPage = chrome.extension.getBackgroundPage(); |
| 21 var require = backgroundPage.require; | 21 var require = backgroundPage.require; |
| 22 var ChromeCompat = backgroundPage.ChromeCompat; | 22 var getStats = require("stats").getStats; |
| 23 var stats = require("stats"); | |
| 24 var StatsObject = stats.StatsObject; | |
| 25 var Stats = stats.Stats; | |
| 26 var FilterNotifier = require("filterNotifier").FilterNotifier; | 23 var FilterNotifier = require("filterNotifier").FilterNotifier; |
| 27 | 24 |
| 28 var currentTabId; | 25 var currentTabId; |
| 29 var statsPage; | 26 var shareURL = "https://adblockplus.org/"; |
| 30 var statsTotal; | |
| 31 var shareBox; | |
| 32 var shareURL = "https://adblockplus.org"; | |
|
Wladimir Palant
2013/09/18 13:22:17
Add a slash at the end of the URL?
| |
| 33 var redirectURL = "https://www.facebook.com"; | |
|
Wladimir Palant
2013/09/18 13:22:17
Given that this is Facebook-specific, I don't thin
| |
| 34 | 27 |
| 35 function createShareLink(url, params) | 28 var messageMark = {}; |
| 29 var shareLinks = { | |
| 30 facebook: ["https://www.facebook.com/dialog/feed", { | |
| 31 app_id: 475542399197328, | |
|
Wladimir Palant
2013/09/24 12:43:36
Just realized that this by far exceeds the 32 bit
| |
| 32 link: shareURL, | |
| 33 redirect_uri: "https://www.facebook.com/", | |
| 34 ref: "adcounter", | |
| 35 name: messageMark, | |
| 36 actions: JSON.stringify([ | |
| 37 { | |
| 38 name: i18n.getMessage("stats_share_download"), | |
| 39 link: shareURL | |
| 40 } | |
| 41 ]) | |
| 42 }], | |
| 43 gplus: ["https://plus.google.com/share", { | |
| 44 url: shareURL | |
| 45 }], | |
| 46 twitter: ["https://twitter.com/intent/tweet", { | |
| 47 text: messageMark, | |
| 48 url: shareURL, | |
| 49 via: "AdblockPlus" | |
| 50 }] | |
| 51 }; | |
| 52 | |
| 53 function createShareLink(network, blockedCount) | |
| 36 { | 54 { |
| 55 var url = shareLinks[network][0]; | |
| 56 var params = shareLinks[network][1]; | |
| 57 | |
| 37 var querystring = []; | 58 var querystring = []; |
| 38 for (var key in params) | 59 for (var key in params) |
| 39 querystring.push(key + "=" + encodeURIComponent(params[key])); | 60 { |
|
Wladimir Palant
2013/09/18 13:22:17
encodeURIComponent(key) please, don't assume that
| |
| 61 var value = params[key]; | |
| 62 if (value == messageMark) | |
| 63 value = i18n.getMessage("stats_share_message", blockedCount); | |
| 64 querystring.push(encodeURIComponent(key) + "=" + encodeURIComponent(value) ); | |
| 65 } | |
| 40 return url + "?" + querystring.join("&"); | 66 return url + "?" + querystring.join("&"); |
| 41 } | 67 } |
| 42 | 68 |
| 43 var shareLinks = { | |
| 44 facebook: createShareLink("https://www.facebook.com/dialog/feed", { | |
| 45 app_id: 475542399197328, | |
| 46 link: shareURL, | |
| 47 redirect_uri: redirectURL, | |
| 48 ref: "adcounter", | |
| 49 name: "_MESSAGE_", | |
| 50 actions: JSON.stringify([ | |
| 51 { | |
| 52 name: chrome.i18n.getMessage("stats_share_download"), | |
| 53 link: shareURL | |
| 54 } | |
| 55 ]) | |
| 56 }), | |
| 57 gplus: createShareLink("https://plus.google.com/share", { | |
| 58 url: shareURL | |
| 59 }), | |
| 60 twitter: createShareLink("https://twitter.com/intent/tweet", { | |
| 61 text: "_MESSAGE_", | |
| 62 url: shareURL, | |
| 63 via: "AdblockPlus" | |
| 64 }) | |
| 65 }; | |
| 66 | |
| 67 function onLoad() | 69 function onLoad() |
| 68 { | 70 { |
| 69 statsPage = document.querySelector("#statsPage > strong"); | 71 document.getElementById("shareBox").addEventListener("click", share, false); |
| 70 statsTotal = document.querySelector("#statsTotal > strong"); | 72 document.getElementById("share").addEventListener("click", toggleShareBox, f alse); |
| 71 | 73 |
| 72 shareBox = document.getElementById("shareBox"); | 74 // Update stats |
| 73 var shareBoxLink = document.getElementById("share"); | 75 chrome.tabs.query({ |
| 74 shareBoxLink.addEventListener("click", showShareBox, false); | 76 active: true, |
| 75 | 77 windowId: chrome.windows.WINDOW_ID_CURRENT |
| 76 var shareActions = document.querySelectorAll("#shareBox > a"); | 78 }, function(tabs) |
| 77 for (var i = 0; i < shareActions.length; i++) | |
| 78 shareActions[i].addEventListener("click", share, false); | |
|
Wladimir Palant
2013/09/18 13:22:17
shareBox.addEventListener("click", share, false) w
| |
| 79 | |
| 80 // update stats | |
| 81 statsTotal.innerText = formatNumber(Stats.total.blocked); | |
| 82 chrome.tabs.query({active: true}, function(tabs) | |
|
Wladimir Palant
2013/09/18 13:22:17
You need windowId: chrome.windows.WINDOW_ID_CURREN
| |
| 83 { | 79 { |
| 84 if (tabs.length > 0) | 80 if (tabs.length > 0) |
| 85 { | 81 { |
| 86 currentTabId = tabs[0].id; | 82 currentTabId = tabs[0].id; |
| 87 updateStats(); | 83 updateStats(); |
| 88 | 84 |
| 89 FilterNotifier.addListener(onNotify); | 85 FilterNotifier.addListener(onNotify); |
| 90 | 86 |
| 91 document.getElementById("statsStuff").removeAttribute("hidden"); | 87 document.getElementById("statsContainer").removeAttribute("hidden"); |
| 92 } | 88 } |
|
Wladimir Palant
2013/09/24 12:43:36
How about |else window.close()| here just in case?
Thomas Greiner
2013/09/24 14:40:58
Closing the popup right after a user clicked on th
Wladimir Palant
2013/09/25 08:44:51
You are right of course. I forgot that the stats a
| |
| 93 }); | 89 }); |
| 94 } | 90 } |
| 95 | 91 |
| 96 function onUnload() | 92 function onUnload() |
| 97 { | 93 { |
| 98 FilterNotifier.removeListener(onNotify); | 94 FilterNotifier.removeListener(onNotify); |
| 99 } | 95 } |
| 100 | 96 |
| 101 function onNotify(action, item) | 97 function onNotify(action, item) |
| 102 { | 98 { |
| 103 if (action == "document.stats") | 99 if (action == "filter.hitCount") |
| 104 updateStats(); | 100 updateStats(); |
| 105 } | 101 } |
| 106 | 102 |
| 107 function updateStats() | 103 function updateStats() |
| 108 { | 104 { |
| 109 ChromeCompat.tabs.sendMessage(currentTabId, {reqtype: "get-stats"}, function (response) | 105 var statsPage = document.getElementById("statsPage"); |
| 110 { | 106 var blockedPage = getStats("blocked", currentTabId).toLocaleString(); |
| 111 var page = new StatsObject(response); | 107 i18n.setElementText(statsPage, "stats_label_page", [blockedPage]); |
| 112 statsPage.innerText = formatNumber(page.blocked); | 108 |
| 113 statsTotal.innerText = formatNumber(Stats.total.blocked); | 109 var statsTotal = document.getElementById("statsTotal"); |
|
Wladimir Palant
2013/09/18 13:22:17
So that's why we have placeholders, so that we can
| |
| 114 }); | 110 var blockedTotal = getStats("blocked").toLocaleString(); |
| 111 i18n.setElementText(statsTotal, "stats_label_total", [blockedTotal]); | |
| 115 } | 112 } |
| 116 | 113 |
| 117 function showShareBox(ev) | 114 function toggleShareBox(ev) |
| 118 { | 115 { |
| 119 if (shareBox.hasAttribute("hidden")) | 116 var shareBox = document.getElementById("shareBox"); |
| 120 shareBox.removeAttribute("hidden"); | 117 shareBox.hidden = !shareBox.hidden; |
| 121 else | |
| 122 shareBox.setAttribute("hidden", true); | |
|
Wladimir Palant
2013/09/18 13:22:17
How about:
var shareBox = document.getElementById
| |
| 123 } | 118 } |
| 124 | 119 |
| 125 function share(ev) | 120 function share(ev) |
| 126 { | 121 { |
| 127 // Easter Egg | 122 // Easter Egg |
| 128 var blocked = Stats.total.blocked; | 123 var blocked = getStats("blocked"); |
| 129 if (blocked <= 9000 || blocked >= 10000) | 124 if (blocked <= 9000 || blocked >= 10000) |
| 130 blocked = formatNumber(blocked); | 125 blocked = blocked.toLocaleString(); |
| 131 else | 126 else |
| 132 blocked = chrome.i18n.getMessage("stats_over", formatNumber(9000)); | 127 blocked = i18n.getMessage("stats_over", (9000).toLocaleString()); |
| 133 | 128 |
| 134 var url = shareLinks[ev.target.dataset.social] | 129 var url = createShareLink(ev.target.dataset.social, blocked); |
| 135 .replace("_MESSAGE_", chrome.i18n.getMessage("stats_share_message", blocke d)); | |
|
Wladimir Palant
2013/09/18 13:22:17
This is a rather ugly approach, and you forgot to
| |
| 136 | |
| 137 chrome.tabs.create({url: url}); | 130 chrome.tabs.create({url: url}); |
| 138 } | |
| 139 | |
| 140 var locale = require("utils").Utils.appLocale; | |
| 141 function formatNumber(number) | |
| 142 { | |
| 143 return number.toLocaleString(locale); | |
| 144 } | 131 } |
|
Wladimir Palant
2013/09/18 13:22:17
Utils.appLocale returns the browser's locale. So t
| |
| 145 | 132 |
| 146 document.addEventListener("DOMContentLoaded", onLoad, false); | 133 document.addEventListener("DOMContentLoaded", onLoad, false); |
| 147 window.addEventListener("unload", onUnload, false); | 134 window.addEventListener("unload", onUnload, false); |
| 148 })(); | 135 })(); |
| LEFT | RIGHT |