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-2017 eyeo GmbH | 3 * Copyright (C) 2006-2017 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 51 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
62 "downloadable", "special"); | 62 "downloadable", "special"); |
63 const removeSubscription = wrapper({type: "subscriptions.remove"}, "url"); | 63 const removeSubscription = wrapper({type: "subscriptions.remove"}, "url"); |
64 const addSubscription = wrapper({type: "subscriptions.add"}, | 64 const addSubscription = wrapper({type: "subscriptions.add"}, |
65 "url", "title", "homepage"); | 65 "url", "title", "homepage"); |
66 const toggleSubscription = wrapper({type: "subscriptions.toggle"}, | 66 const toggleSubscription = wrapper({type: "subscriptions.toggle"}, |
67 "url", "keepInstalled"); | 67 "url", "keepInstalled"); |
68 const updateSubscription = wrapper({type: "subscriptions.update"}, "url"); | 68 const updateSubscription = wrapper({type: "subscriptions.update"}, "url"); |
69 const importRawFilters = wrapper({type: "filters.importRaw"}, | 69 const importRawFilters = wrapper({type: "filters.importRaw"}, |
70 "text", "removeExisting"); | 70 "text", "removeExisting"); |
71 const addFilter = wrapper({type: "filters.add"}, "text"); | 71 const addFilter = wrapper({type: "filters.add"}, "text"); |
72 const getFilters = wrapper({type: "filters.get"}, "subscriptionUrl"); | |
73 const removeFilter = wrapper({type: "filters.remove"}, "text"); | 72 const removeFilter = wrapper({type: "filters.remove"}, "text"); |
73 const quoteCSS = wrapper({type: "composer.quoteCSS"}, "CSS"); | |
74 | 74 |
75 const whitelistedDomainRegexp = /^@@\|\|([^/:]+)\^\$document$/; | 75 const whitelistedDomainRegexp = /^@@\|\|([^/:]+)\^\$document$/; |
76 const statusMessages = new Map([ | 76 const statusMessages = new Map([ |
77 ["synchronize_invalid_url", | 77 ["synchronize_invalid_url", |
78 "filters_subscription_lastDownload_invalidURL"], | 78 "filters_subscription_lastDownload_invalidURL"], |
79 ["synchronize_connection_error", | 79 ["synchronize_connection_error", |
80 "filters_subscription_lastDownload_connectionError"], | 80 "filters_subscription_lastDownload_connectionError"], |
81 ["synchronize_invalid_data", | 81 ["synchronize_invalid_data", |
82 "filters_subscription_lastDownload_invalidData"], | 82 "filters_subscription_lastDownload_invalidData"], |
83 ["synchronize_checksum_mismatch", | 83 ["synchronize_checksum_mismatch", |
(...skipping 96 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
180 // Load recommended subscriptions | 180 // Load recommended subscriptions |
181 loadRecommendations(); | 181 loadRecommendations(); |
182 | 182 |
183 // Show user's filters | 183 // Show user's filters |
184 reloadFilters(); | 184 reloadFilters(); |
185 } | 185 } |
186 $(loadOptions); | 186 $(loadOptions); |
187 | 187 |
188 function convertSpecialSubscription(subscription) | 188 function convertSpecialSubscription(subscription) |
189 { | 189 { |
190 getFilters(subscription.url, filters => | 190 for (let filter of subscription.filters) |
191 { | 191 { |
192 for (let filter of filters) | 192 if (whitelistedDomainRegexp.test(filter.text)) |
193 { | 193 appendToListBox("excludedDomainsBox", RegExp.$1); |
194 if (whitelistedDomainRegexp.test(filter.text)) | 194 else |
195 appendToListBox("excludedDomainsBox", RegExp.$1); | 195 appendToListBox("userFiltersBox", filter.text); |
196 else | 196 } |
197 appendToListBox("userFiltersBox", filter.text); | |
198 } | |
199 }); | |
200 } | 197 } |
201 | 198 |
202 // Reloads the displayed subscriptions and filters | 199 // Reloads the displayed subscriptions and filters |
203 function reloadFilters() | 200 function reloadFilters() |
204 { | 201 { |
205 // Load user filter URLs | 202 // Load user filter URLs |
206 let container = document.getElementById("filterLists"); | 203 let container = document.getElementById("filterLists"); |
207 while (container.lastChild) | 204 while (container.lastChild) |
208 container.removeChild(container.lastChild); | 205 container.removeChild(container.lastChild); |
209 | 206 |
(...skipping 318 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
528 elt.value = text; | 525 elt.value = text; |
529 document.getElementById(boxId).appendChild(elt); | 526 document.getElementById(boxId).appendChild(elt); |
530 } | 527 } |
531 | 528 |
532 // Remove a filter string from a list box. | 529 // Remove a filter string from a list box. |
533 function removeFromListBox(boxId, text) | 530 function removeFromListBox(boxId, text) |
534 { | 531 { |
535 let list = document.getElementById(boxId); | 532 let list = document.getElementById(boxId); |
536 // Edge does not support CSS.escape yet: | 533 // Edge does not support CSS.escape yet: |
537 // https://developer.microsoft.com/en-us/microsoft-edge/platform/issues/101410 / | 534 // https://developer.microsoft.com/en-us/microsoft-edge/platform/issues/101410 / |
538 if (typeof CSS.escape == "undefined") | 535 quoteCSS(text, escapedCSS => |
539 { | 536 { |
540 for (let i = 0; i < list.length; i++) | 537 let selector = "option[value=" + escapedCSS + "]"; |
kzar
2017/07/17 14:08:19
This will be kinda slow when there are lots of fil
Sebastian Noack
2017/07/17 14:17:21
Couldn't we just do this instead of CSS.escape():
kzar
2017/07/17 14:27:02
I'm not sure that would always work, for example w
Sebastian Noack
2017/07/17 14:31:25
It seems that we have already implemented the same
kzar
2017/07/17 14:41:37
Sounds good to me.
Though to avoid duplicating th
Sebastian Noack
2017/07/17 15:49:56
How about using messaging?
Oleksandr
2017/07/17 23:52:09
Done.
| |
541 if (list.options[i].value == text) | |
542 list.remove(i--); | |
543 } | |
544 else | |
545 { | |
546 let selector = "option[value=" + CSS.escape(text) + "]"; | |
547 for (let option of list.querySelectorAll(selector)) | 538 for (let option of list.querySelectorAll(selector)) |
548 list.removeChild(option); | 539 list.removeChild(option); |
549 } | 540 }); |
550 } | 541 } |
551 | 542 |
552 function addWhitelistDomain(event) | 543 function addWhitelistDomain(event) |
553 { | 544 { |
554 event.preventDefault(); | 545 event.preventDefault(); |
555 | 546 |
556 let domain = document.getElementById( | 547 let domain = document.getElementById( |
557 "newWhitelistDomain" | 548 "newWhitelistDomain" |
558 ).value.replace(/\s/g, ""); | 549 ).value.replace(/\s/g, ""); |
559 document.getElementById("newWhitelistDomain").value = ""; | 550 document.getElementById("newWhitelistDomain").value = ""; |
(...skipping 184 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
744 onFilterMessage(message.action, message.args[0]); | 735 onFilterMessage(message.action, message.args[0]); |
745 break; | 736 break; |
746 case "prefs.respond": | 737 case "prefs.respond": |
747 onPrefMessage(message.action, message.args[0]); | 738 onPrefMessage(message.action, message.args[0]); |
748 break; | 739 break; |
749 case "subscriptions.respond": | 740 case "subscriptions.respond": |
750 onSubscriptionMessage(message.action, message.args[0]); | 741 onSubscriptionMessage(message.action, message.args[0]); |
751 break; | 742 break; |
752 } | 743 } |
753 }); | 744 }); |
LEFT | RIGHT |