| 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-present eyeo GmbH | 3 * Copyright (C) 2006-present 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 219 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 230 displays[j].textContent = title; | 230 displays[j].textContent = title; |
| 231 } | 231 } |
| 232 | 232 |
| 233 element.setAttribute("aria-label", title); | 233 element.setAttribute("aria-label", title); |
| 234 if (this.details[i].searchable) | 234 if (this.details[i].searchable) |
| 235 element.setAttribute("data-search", title.toLowerCase()); | 235 element.setAttribute("data-search", title.toLowerCase()); |
| 236 let controls = element.querySelectorAll(".control[role='checkbox']"); | 236 let controls = element.querySelectorAll(".control[role='checkbox']"); |
| 237 for (let control of controls) | 237 for (let control of controls) |
| 238 { | 238 { |
| 239 control.setAttribute("aria-checked", item.disabled == false); | 239 control.setAttribute("aria-checked", item.disabled == false); |
| 240 if (isAcceptableAds(item.url) && this == collections.filterLists) | 240 if (isAcceptableAds(item.url) && this == collections.filterLists && |
| 241 !item.disabled) |
| 241 { | 242 { |
| 242 control.disabled = true; | 243 control.disabled = true; |
| 243 } | 244 } |
| 244 } | 245 } |
| 245 if (additionalSubscriptions.includes(item.url)) | 246 if (additionalSubscriptions.includes(item.url)) |
| 246 { | 247 { |
| 247 element.classList.add("preconfigured"); | 248 element.classList.add("preconfigured"); |
| 248 let disablePreconfigures = | 249 let disablePreconfigures = |
| 249 element.querySelectorAll("[data-disable~='preconfigured']"); | 250 element.querySelectorAll("[data-disable~='preconfigured']"); |
| 250 for (let disablePreconfigure of disablePreconfigures) | 251 for (let disablePreconfigure of disablePreconfigures) |
| (...skipping 821 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1072 | 1073 |
| 1073 function setAcceptableAds() | 1074 function setAcceptableAds() |
| 1074 { | 1075 { |
| 1075 let acceptableAdsForm = E("acceptable-ads"); | 1076 let acceptableAdsForm = E("acceptable-ads"); |
| 1076 let acceptableAds = E("acceptable-ads-allow"); | 1077 let acceptableAds = E("acceptable-ads-allow"); |
| 1077 let acceptableAdsPrivacy = E("acceptable-ads-privacy-allow"); | 1078 let acceptableAdsPrivacy = E("acceptable-ads-privacy-allow"); |
| 1078 acceptableAdsForm.classList.remove("show-dnt-notification"); | 1079 acceptableAdsForm.classList.remove("show-dnt-notification"); |
| 1079 acceptableAds.setAttribute("aria-checked", false); | 1080 acceptableAds.setAttribute("aria-checked", false); |
| 1080 acceptableAdsPrivacy.setAttribute("aria-checked", false); | 1081 acceptableAdsPrivacy.setAttribute("aria-checked", false); |
| 1081 acceptableAdsPrivacy.setAttribute("tabindex", 0); | 1082 acceptableAdsPrivacy.setAttribute("tabindex", 0); |
| 1082 if (acceptableAdsUrl in subscriptionsMap) | 1083 if (acceptableAdsUrl in subscriptionsMap && |
| 1084 !subscriptionsMap[acceptableAdsUrl].disabled) |
| 1083 { | 1085 { |
| 1084 acceptableAds.setAttribute("aria-checked", true); | 1086 acceptableAds.setAttribute("aria-checked", true); |
| 1085 acceptableAdsPrivacy.setAttribute("aria-disabled", false); | 1087 acceptableAdsPrivacy.setAttribute("aria-disabled", false); |
| 1086 } | 1088 } |
| 1087 else if (acceptableAdsPrivacyUrl in subscriptionsMap) | 1089 else if (acceptableAdsPrivacyUrl in subscriptionsMap && |
| 1090 !subscriptionsMap[acceptableAdsPrivacyUrl].disabled) |
| 1088 { | 1091 { |
| 1089 acceptableAds.setAttribute("aria-checked", true); | 1092 acceptableAds.setAttribute("aria-checked", true); |
| 1090 acceptableAdsPrivacy.setAttribute("aria-checked", true); | 1093 acceptableAdsPrivacy.setAttribute("aria-checked", true); |
| 1091 acceptableAdsPrivacy.setAttribute("aria-disabled", false); | 1094 acceptableAdsPrivacy.setAttribute("aria-disabled", false); |
| 1092 | 1095 |
| 1093 // Edge uses window instead of navigator. | 1096 // Edge uses window instead of navigator. |
| 1094 // Prefer navigator first since it's the standard. | 1097 // Prefer navigator first since it's the standard. |
| 1095 if ((navigator.doNotTrack || window.doNotTrack) != 1) | 1098 if ((navigator.doNotTrack || window.doNotTrack) != 1) |
| 1096 acceptableAdsForm.classList.add("show-dnt-notification"); | 1099 acceptableAdsForm.classList.add("show-dnt-notification"); |
| 1097 } | 1100 } |
| (...skipping 186 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1284 knownSubscription.originalTitle = subscription.title; | 1287 knownSubscription.originalTitle = subscription.title; |
| 1285 else | 1288 else |
| 1286 knownSubscription[property] = subscription[property]; | 1289 knownSubscription[property] = subscription[property]; |
| 1287 } | 1290 } |
| 1288 subscription = knownSubscription; | 1291 subscription = knownSubscription; |
| 1289 } | 1292 } |
| 1290 switch (action) | 1293 switch (action) |
| 1291 { | 1294 { |
| 1292 case "disabled": | 1295 case "disabled": |
| 1293 updateSubscription(subscription); | 1296 updateSubscription(subscription); |
| 1297 if (isAcceptableAds(subscription.url)) |
| 1298 setAcceptableAds(); |
| 1299 |
| 1294 setPrivacyConflict(); | 1300 setPrivacyConflict(); |
| 1295 break; | 1301 break; |
| 1296 case "downloading": | 1302 case "downloading": |
| 1297 case "downloadStatus": | 1303 case "downloadStatus": |
| 1298 case "homepage": | 1304 case "homepage": |
| 1299 case "lastDownload": | 1305 case "lastDownload": |
| 1300 case "title": | 1306 case "title": |
| 1301 updateSubscription(subscription); | 1307 updateSubscription(subscription); |
| 1302 break; | 1308 break; |
| 1303 case "added": | 1309 case "added": |
| (...skipping 193 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1497 "ui_warn_tracking"] | 1503 "ui_warn_tracking"] |
| 1498 }); | 1504 }); |
| 1499 port.postMessage({ | 1505 port.postMessage({ |
| 1500 type: "subscriptions.listen", | 1506 type: "subscriptions.listen", |
| 1501 filter: ["added", "disabled", "homepage", "lastDownload", "removed", | 1507 filter: ["added", "disabled", "homepage", "lastDownload", "removed", |
| 1502 "title", "downloadStatus", "downloading"] | 1508 "title", "downloadStatus", "downloading"] |
| 1503 }); | 1509 }); |
| 1504 | 1510 |
| 1505 window.addEventListener("DOMContentLoaded", onDOMLoaded, false); | 1511 window.addEventListener("DOMContentLoaded", onDOMLoaded, false); |
| 1506 window.addEventListener("hashchange", onHashChange, false); | 1512 window.addEventListener("hashchange", onHashChange, false); |
| OLD | NEW |