| Left: | ||
| Right: |
| OLD | NEW |
|---|---|
| 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-2016 Eyeo GmbH | 3 * Copyright (C) 2006-2016 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 66 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 77 var addFilter = wrapper({type: "filters.add"}, "text"); | 77 var addFilter = wrapper({type: "filters.add"}, "text"); |
| 78 var getFilters = wrapper({type: "filters.get"}, "subscriptionUrl"); | 78 var getFilters = wrapper({type: "filters.get"}, "subscriptionUrl"); |
| 79 var removeFilter = wrapper({type: "filters.remove"}, "text"); | 79 var removeFilter = wrapper({type: "filters.remove"}, "text"); |
| 80 | 80 |
| 81 var i18n = ext.i18n; | 81 var i18n = ext.i18n; |
| 82 var whitelistedDomainRegexp = /^@@\|\|([^\/:]+)\^\$document$/; | 82 var whitelistedDomainRegexp = /^@@\|\|([^\/:]+)\^\$document$/; |
| 83 var delayedSubscriptionSelection = null; | 83 var delayedSubscriptionSelection = null; |
| 84 | 84 |
| 85 var acceptableAdsUrl; | 85 var acceptableAdsUrl; |
| 86 | 86 |
| 87 // Loads options and sets UI elements accordingly | 87 // Loads options from localStorage and sets UI elements accordingly |
| 88 function loadOptions() | 88 function loadOptions() |
| 89 { | 89 { |
| 90 // Set page title to i18n version of "Adblock Plus Options" | 90 // Set page title to i18n version of "Adblock Plus Options" |
| 91 document.title = i18n.getMessage("options"); | 91 document.title = i18n.getMessage("options"); |
| 92 | 92 |
| 93 // Set links | 93 // Set links |
| 94 getPref("subscriptions_exceptionsurl", function(url) | 94 getPref("subscriptions_exceptionsurl", function(url) |
| 95 { | 95 { |
| 96 acceptableAdsUrl = url; | 96 acceptableAdsUrl = url; |
| 97 $("#acceptableAdsLink").attr("href", acceptableAdsUrl); | 97 $("#acceptableAdsLink").attr("href", acceptableAdsUrl); |
| (...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 141 // Popuplate option checkboxes | 141 // Popuplate option checkboxes |
| 142 initCheckbox("shouldShowBlockElementMenu"); | 142 initCheckbox("shouldShowBlockElementMenu"); |
| 143 initCheckbox("show_devtools_panel"); | 143 initCheckbox("show_devtools_panel"); |
| 144 initCheckbox("shouldShowNotifications", { | 144 initCheckbox("shouldShowNotifications", { |
| 145 key: "notifications_ignoredcategories", | 145 key: "notifications_ignoredcategories", |
| 146 get: function(ignoredcategories) | 146 get: function(ignoredcategories) |
| 147 { | 147 { |
| 148 return ignoredcategories.indexOf("*") == -1; | 148 return ignoredcategories.indexOf("*") == -1; |
| 149 } | 149 } |
| 150 }); | 150 }); |
| 151 initCheckbox("safariContentBlocker", {onChange: function(checkbox) | |
| 152 { | |
| 153 var restartMessage = document.getElementById("restart-safari"); | |
| 154 restartMessage.hidden = true; | |
| 155 | |
| 156 // When the user has chosen to use the legacy APIs but Safari has disabled | |
| 157 // them we need to show a "Please restart Safari" message. | |
| 158 if (!checkbox.checked) | |
|
Sebastian Noack
2016/05/12 11:12:22
As discussed with Thomas on the review for the rel
kzar
2016/05/17 15:15:38
I don't understand what you mean by "persistent lo
Sebastian Noack
2016/05/17 18:35:24
At the very least this logic is inconsistent with
kzar
2016/05/17 19:20:21
Acknowledged.
| |
| 159 { | |
| 160 ext.backgroundPage.sendMessage({type: "safari.contentBlockingActive"}, | |
| 161 function (contentBlockingActive) | |
| 162 { | |
| 163 if (contentBlockingActive) | |
| 164 restartMessage.hidden = false; | |
| 165 }); | |
| 166 } | |
| 167 }}); | |
| 151 | 168 |
| 152 getInfo("features", function(features) | 169 getInfo("features", function(features) |
| 153 { | 170 { |
| 154 if (!features.devToolsPanel) | 171 if (!features.devToolsPanel) |
| 155 document.getElementById("showDevtoolsPanelContainer").hidden = true; | 172 document.getElementById("showDevtoolsPanelContainer").hidden = true; |
| 173 | |
| 174 // Only show the option for Safari content blocking API if the user is | |
| 175 // running Safari and both the legacy and content blocking APIs are | |
| 176 // available. | |
| 177 document.getElementById("safariContentBlockerContainer").hidden = !( | |
| 178 features.safariContentBlocker && | |
| 179 typeof safari != "undefined" && | |
| 180 "canLoad" in safari.self.tab && | |
| 181 "onbeforeload" in Element.prototype | |
| 182 ); | |
| 156 }); | 183 }); |
| 157 getPref("notifications_showui", function(notifications_showui) | 184 getPref("notifications_showui", function(notifications_showui) |
| 158 { | 185 { |
| 159 if (!notifications_showui) | 186 if (!notifications_showui) |
| 160 document.getElementById("shouldShowNotificationsContainer").hidden = true; | 187 document.getElementById("shouldShowNotificationsContainer").hidden = true; |
| 161 }); | 188 }); |
| 162 | 189 |
| 163 // Register listeners in the background message responder | 190 // Register listeners in the background message responder |
| 164 ext.backgroundPage.sendMessage({ | 191 ext.backgroundPage.sendMessage({ |
| 165 type: "app.listen", | 192 type: "app.listen", |
| 166 filter: ["addSubscription", "focusSection"] | 193 filter: ["addSubscription", "focusSection"] |
| 167 }); | 194 }); |
| 168 ext.backgroundPage.sendMessage( | 195 ext.backgroundPage.sendMessage( |
| 169 { | 196 { |
| 170 type: "filters.listen", | 197 type: "filters.listen", |
| 171 filter: ["added", "loaded", "removed"] | 198 filter: ["added", "loaded", "removed"] |
| 172 }); | 199 }); |
| 173 ext.backgroundPage.sendMessage( | 200 ext.backgroundPage.sendMessage( |
| 174 { | 201 { |
| 175 type: "prefs.listen", | 202 type: "prefs.listen", |
| 176 filter: ["notifications_ignoredcategories", "notifications_showui", | 203 filter: ["notifications_ignoredcategories", "notifications_showui", |
| 177 "safari_contentblocker", "show_devtools_panel", | 204 "safariContentBlocker", "show_devtools_panel", |
| 178 "shouldShowBlockElementMenu"] | 205 "shouldShowBlockElementMenu"] |
| 179 }); | 206 }); |
| 180 ext.backgroundPage.sendMessage( | 207 ext.backgroundPage.sendMessage( |
| 181 { | 208 { |
| 182 type: "subscriptions.listen", | 209 type: "subscriptions.listen", |
| 183 filter: ["added", "disabled", "homepage", "lastDownload", "removed", | 210 filter: ["added", "disabled", "homepage", "lastDownload", "removed", |
| 184 "title", "downloadStatus", "downloading"] | 211 "title", "downloadStatus", "downloading"] |
| 185 }); | 212 }); |
| 186 | 213 |
| 187 // Load recommended subscriptions | 214 // Load recommended subscriptions |
| (...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 235 | 262 |
| 236 for (var i = 0; i < subscriptions.length; i++) | 263 for (var i = 0; i < subscriptions.length; i++) |
| 237 convertSpecialSubscription(subscriptions[i]); | 264 convertSpecialSubscription(subscriptions[i]); |
| 238 }); | 265 }); |
| 239 } | 266 } |
| 240 | 267 |
| 241 function initCheckbox(id, descriptor) | 268 function initCheckbox(id, descriptor) |
| 242 { | 269 { |
| 243 var checkbox = document.getElementById(id); | 270 var checkbox = document.getElementById(id); |
| 244 var key = descriptor && descriptor.key || id; | 271 var key = descriptor && descriptor.key || id; |
| 272 var onChange; | |
| 273 if (descriptor && descriptor.onChange) | |
| 274 onChange = descriptor.onChange.bind(undefined, checkbox); | |
| 245 getPref(key, function(value) | 275 getPref(key, function(value) |
| 246 { | 276 { |
| 247 if (descriptor && descriptor.get) | 277 if (descriptor && descriptor.get) |
| 248 checkbox.checked = descriptor.get(value); | 278 checkbox.checked = descriptor.get(value); |
| 249 else | 279 else |
| 250 checkbox.checked = value; | 280 checkbox.checked = value; |
| 281 | |
| 282 if (onChange) | |
| 283 onChange(); | |
| 251 }); | 284 }); |
| 252 | 285 |
| 253 checkbox.addEventListener("click", function() | 286 checkbox.addEventListener("click", function() |
| 254 { | 287 { |
| 255 if (descriptor && descriptor.toggle) | |
| 256 checkbox.checked = descriptor.toggle(); | |
| 257 togglePref(key); | 288 togglePref(key); |
| 258 }, false); | 289 }, false); |
| 290 | |
| 291 if (onChange) | |
| 292 checkbox.addEventListener("change", onChange); | |
| 259 } | 293 } |
| 260 | 294 |
| 261 function loadRecommendations() | 295 function loadRecommendations() |
| 262 { | 296 { |
| 263 fetch("subscriptions.xml") | 297 fetch("subscriptions.xml") |
| 264 .then(function(response) | 298 .then(function(response) |
| 265 { | 299 { |
| 266 return response.text(); | 300 return response.text(); |
| 267 }) | 301 }) |
| 268 .then(function(text) | 302 .then(function(text) |
| (...skipping 229 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 498 document.getElementById("shouldShowNotificationsContainer").hidden = !valu e; | 532 document.getElementById("shouldShowNotificationsContainer").hidden = !valu e; |
| 499 return; | 533 return; |
| 500 case "notifications_ignoredcategories": | 534 case "notifications_ignoredcategories": |
| 501 key = "shouldShowNotifications"; | 535 key = "shouldShowNotifications"; |
| 502 value = value.indexOf("*") == -1; | 536 value = value.indexOf("*") == -1; |
| 503 break; | 537 break; |
| 504 } | 538 } |
| 505 | 539 |
| 506 var checkbox = document.getElementById(key); | 540 var checkbox = document.getElementById(key); |
| 507 if (checkbox) | 541 if (checkbox) |
| 542 { | |
| 508 checkbox.checked = value; | 543 checkbox.checked = value; |
| 544 // Apparently modifying the checked attribute for a checkbox does not | |
|
Sebastian Noack
2016/05/12 11:12:23
If you want to emulate user actions that's what th
kzar
2016/05/17 15:15:37
Calling .click() would also toggle the checkbox ri
Sebastian Noack
2016/05/17 18:35:25
I wonder whether the change listener is even neces
kzar
2016/05/17 19:20:21
We also need to call the logic when the checkbox i
Sebastian Noack
2016/05/18 07:03:29
Well, in the new options page we call the same fun
kzar
2016/05/18 08:02:48
Yes, I already do that here.
Sebastian Noack
2016/05/18 08:13:37
But why can't you put the logic simply here then i
kzar
2016/05/18 09:28:47
Oh I finally understand, I think you mean that we
Sebastian Noack
2016/05/18 10:07:24
I don't see how that makes anything more confusing
kzar
2016/05/18 10:43:40
Done.
| |
| 545 // dispatch the change event automatically... | |
| 546 checkbox.dispatchEvent(new Event("change")); | |
| 547 } | |
| 509 } | 548 } |
| 510 | 549 |
| 511 function onFilterMessage(action, filter) | 550 function onFilterMessage(action, filter) |
| 512 { | 551 { |
| 513 switch (action) | 552 switch (action) |
| 514 { | 553 { |
| 515 case "loaded": | 554 case "loaded": |
| 516 reloadFilters(); | 555 reloadFilters(); |
| 517 break; | 556 break; |
| 518 case "added": | 557 case "added": |
| (...skipping 229 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 748 onFilterMessage(message.action, message.args[0]); | 787 onFilterMessage(message.action, message.args[0]); |
| 749 break; | 788 break; |
| 750 case "prefs.respond": | 789 case "prefs.respond": |
| 751 onPrefMessage(message.action, message.args[0]); | 790 onPrefMessage(message.action, message.args[0]); |
| 752 break; | 791 break; |
| 753 case "subscriptions.respond": | 792 case "subscriptions.respond": |
| 754 onSubscriptionMessage(message.action, message.args[0]); | 793 onSubscriptionMessage(message.action, message.args[0]); |
| 755 break; | 794 break; |
| 756 } | 795 } |
| 757 }); | 796 }); |
| OLD | NEW |