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 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
64 return result; | 64 return result; |
65 } | 65 } |
66 | 66 |
67 var convertSubscription = convertObject.bind(null, ["disabled", | 67 var convertSubscription = convertObject.bind(null, ["disabled", |
68 "downloadStatus", "homepage", "lastDownload", "title", "url"]); | 68 "downloadStatus", "homepage", "lastDownload", "title", "url"]); |
69 var convertFilter = convertObject.bind(null, ["text"]); | 69 var convertFilter = convertObject.bind(null, ["text"]); |
70 | 70 |
71 var changeListeners = new global.ext.PageMap(); | 71 var changeListeners = new global.ext.PageMap(); |
72 var listenedPreferences = Object.create(null); | 72 var listenedPreferences = Object.create(null); |
73 var listenedFilterChanges = Object.create(null); | 73 var listenedFilterChanges = Object.create(null); |
| 74 var safariRestartRequired = null; |
74 var messageTypes = { | 75 var messageTypes = { |
75 "app": "app.respond", | 76 "app": "app.respond", |
76 "filter": "filters.respond", | 77 "filter": "filters.respond", |
77 "pref": "prefs.respond", | 78 "pref": "prefs.respond", |
78 "subscription": "subscriptions.respond" | 79 "subscription": "subscriptions.respond" |
79 }; | 80 }; |
80 | 81 |
81 function sendMessage(type, action) | 82 function sendMessage(type, action) |
82 { | 83 { |
83 var pages = changeListeners.keys(); | 84 var pages = changeListeners.keys(); |
(...skipping 98 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
182 safariContentBlocker: "safari" in global | 183 safariContentBlocker: "safari" in global |
183 && "extension" in global.safari | 184 && "extension" in global.safari |
184 && "setContentBlocker" in global.safari.extension | 185 && "setContentBlocker" in global.safari.extension |
185 }); | 186 }); |
186 } | 187 } |
187 else | 188 else |
188 callback(info[message.what]); | 189 callback(info[message.what]); |
189 break; | 190 break; |
190 case "app.listen": | 191 case "app.listen": |
191 getListenerFilters(sender.page).app = message.filter; | 192 getListenerFilters(sender.page).app = message.filter; |
| 193 if (message.filter.indexOf("safariRestartRequired") != -1) |
| 194 { |
| 195 if (safariRestartRequired == null) |
| 196 { |
| 197 safariRestartRequired = false; |
| 198 Prefs.on("safari_contentblocker", function() |
| 199 { |
| 200 safariRestartRequired = !Prefs.safari_contentblocker; |
| 201 sendMessage("app", "safariRestartRequired", safariRestartRequired)
; |
| 202 }); |
| 203 } |
| 204 |
| 205 sender.page.sendMessage({ |
| 206 type: messageTypes.app, |
| 207 action: "safariRestartRequired", |
| 208 args: [safariRestartRequired] |
| 209 }); |
| 210 } |
192 break; | 211 break; |
193 case "app.open": | 212 case "app.open": |
194 if (message.what == "options") | 213 if (message.what == "options") |
195 ext.showOptions(); | 214 ext.showOptions(); |
196 break; | 215 break; |
197 case "filters.add": | 216 case "filters.add": |
198 var result = require("filterValidation").parseFilter(message.text); | 217 var result = require("filterValidation").parseFilter(message.text); |
199 var errors = []; | 218 var errors = []; |
200 if (result.error) | 219 if (result.error) |
201 errors.push(result.error.toString()); | 220 errors.push(result.error.toString()); |
(...skipping 193 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
395 if (subscription instanceof DownloadableSubscription) | 414 if (subscription instanceof DownloadableSubscription) |
396 Synchronizer.execute(subscription, true); | 415 Synchronizer.execute(subscription, true); |
397 } | 416 } |
398 break; | 417 break; |
399 case "subscriptions.isDownloading": | 418 case "subscriptions.isDownloading": |
400 callback(Synchronizer.isExecuting(message.url)); | 419 callback(Synchronizer.isExecuting(message.url)); |
401 break; | 420 break; |
402 } | 421 } |
403 }); | 422 }); |
404 })(this); | 423 })(this); |
OLD | NEW |