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 |
(...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
72 function removeDeprecatedOptions() | 72 function removeDeprecatedOptions() |
73 { | 73 { |
74 var deprecatedOptions = ["specialCaseYouTube", "experimental", "disableInlineT
extAds"]; | 74 var deprecatedOptions = ["specialCaseYouTube", "experimental", "disableInlineT
extAds"]; |
75 deprecatedOptions.forEach(function(option) | 75 deprecatedOptions.forEach(function(option) |
76 { | 76 { |
77 if (option in localStorage) | 77 if (option in localStorage) |
78 delete localStorage[option]; | 78 delete localStorage[option]; |
79 }); | 79 }); |
80 } | 80 } |
81 | 81 |
82 // Sets options to defaults, upgrading old options from previous versions as nec
essary | 82 // Remove deprecated options before we do anything else. |
83 function setDefaultOptions() | 83 removeDeprecatedOptions(); |
84 { | |
85 function defaultOptionValue(opt, val) | |
86 { | |
87 if(!(opt in localStorage)) | |
88 localStorage[opt] = val; | |
89 } | |
90 | |
91 defaultOptionValue("shouldShowBlockElementMenu", "true"); | |
92 | |
93 removeDeprecatedOptions(); | |
94 } | |
95 | |
96 // Upgrade options before we do anything else. | |
97 setDefaultOptions(); | |
98 | 84 |
99 var activeNotification = null; | 85 var activeNotification = null; |
100 | 86 |
101 // Adds or removes browser action icon according to options. | 87 // Adds or removes browser action icon according to options. |
102 function refreshIconAndContextMenu(tab) | 88 function refreshIconAndContextMenu(tab) |
103 { | 89 { |
104 if(!/^https?:/.test(tab.url)) | 90 if(!/^https?:/.test(tab.url)) |
105 return; | 91 return; |
106 | 92 |
107 var iconFilename; | 93 var iconFilename; |
108 if (require("info").platform == "safari") | 94 if (require("info").platform == "safari") |
109 // There is no grayscale version of the icon for whitelisted tabs | 95 // There is no grayscale version of the icon for whitelisted tabs |
110 // when using Safari, because icons are grayscale already and icons | 96 // when using Safari, because icons are grayscale already and icons |
111 // aren't per tab in Safari. | 97 // aren't per tab in Safari. |
112 iconFilename = "icons/abp-16.png" | 98 iconFilename = "icons/abp-16.png" |
113 else | 99 else |
114 { | 100 { |
115 var excluded = isWhitelisted(tab.url); | 101 var excluded = isWhitelisted(tab.url); |
116 iconFilename = excluded ? "icons/abp-19-whitelisted.png" : "icons/abp-19.png
"; | 102 iconFilename = excluded ? "icons/abp-19-whitelisted.png" : "icons/abp-19.png
"; |
117 } | 103 } |
118 | 104 |
119 tab.browserAction.setIcon(iconFilename); | 105 tab.browserAction.setIcon(iconFilename); |
120 tab.browserAction.setTitle(ext.i18n.getMessage("name")); | |
121 | |
122 iconAnimation.registerTab(tab, iconFilename); | 106 iconAnimation.registerTab(tab, iconFilename); |
123 | 107 |
124 // Set context menu status according to whether current tab has whitelisted do
main | 108 // Set context menu status according to whether current tab has whitelisted do
main |
125 if (excluded) | 109 if (excluded) |
126 chrome.contextMenus.removeAll(); | 110 ext.contextMenus.hideMenuItems(); |
127 else | 111 else |
128 showContextMenu(); | 112 ext.contextMenus.showMenuItems(); |
129 } | 113 } |
130 | 114 |
131 /** | 115 /** |
132 * Old versions for Opera stored patterns.ini in the localStorage object, this | 116 * Old versions for Opera stored patterns.ini in the localStorage object, this |
133 * will import it into FilterStorage properly. | 117 * will import it into FilterStorage properly. |
134 * @return {Boolean} true if data import is in progress | 118 * @return {Boolean} true if data import is in progress |
135 */ | 119 */ |
136 function importOldData() | 120 function importOldData() |
137 { | 121 { |
138 if ("patterns.ini" in localStorage) | 122 if ("patterns.ini" in localStorage) |
(...skipping 97 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
236 | 220 |
237 notifyUser(); | 221 notifyUser(); |
238 } | 222 } |
239 }, false); | 223 }, false); |
240 request.send(null); | 224 request.send(null); |
241 } | 225 } |
242 else | 226 else |
243 notifyUser(); | 227 notifyUser(); |
244 } | 228 } |
245 | 229 |
246 // Set up context menu for user selection of elements to block | 230 function setContextMenu() |
247 function showContextMenu() | 231 { |
248 { | 232 if (Prefs.shouldShowBlockElementMenu) |
249 ext.contextMenus.removeAll(function() | 233 { |
250 { | 234 // Register context menu item |
251 if(typeof localStorage["shouldShowBlockElementMenu"] == "string" && localSto
rage["shouldShowBlockElementMenu"] == "true") | 235 ext.contextMenus.addMenuItem(ext.i18n.getMessage("block_element"), ["image",
"video", "audio"], function(srcUrl, tab) |
252 { | 236 { |
253 ext.contextMenus.create(ext.i18n.getMessage("block_element"), ["image", "v
ideo", "audio"], function(srcUrl, tab) | 237 if (srcUrl) |
254 { | 238 tab.sendMessage({type: "clickhide-new-filter", filter: srcUrl}); |
255 if(srcUrl) | 239 }); |
256 tab.sendMessage({type: "clickhide-new-filter", filter: srcUrl}); | 240 } |
257 }); | 241 else |
258 } | 242 ext.contextMenus.removeMenuItems(); |
259 }); | 243 } |
260 } | 244 |
| 245 Prefs.addListener(function(name) |
| 246 { |
| 247 if (name == "shouldShowBlockElementMenu") |
| 248 setContextMenu(); |
| 249 }); |
| 250 setContextMenu(); |
261 | 251 |
262 /** | 252 /** |
263 * Opens options tab or focuses an existing one, within the last focused window
. | 253 * Opens options tab or focuses an existing one, within the last focused window
. |
264 * @param {Function} callback function to be called with the | 254 * @param {Function} callback function to be called with the |
265 Tab object of the options tab | 255 Tab object of the options tab |
266 */ | 256 */ |
267 function openOptions(callback) | 257 function openOptions(callback) |
268 { | 258 { |
269 ext.windows.getLastFocused(function(win) | 259 ext.windows.getLastFocused(function(win) |
270 { | 260 { |
(...skipping 87 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
358 } | 348 } |
359 | 349 |
360 var requestHost = extractHostFromURL(msg.url); | 350 var requestHost = extractHostFromURL(msg.url); |
361 var documentHost = extractHostFromURL(sender.frame.url); | 351 var documentHost = extractHostFromURL(sender.frame.url); |
362 var thirdParty = isThirdParty(requestHost, documentHost); | 352 var thirdParty = isThirdParty(requestHost, documentHost); |
363 var filter = defaultMatcher.matchesAny(msg.url, msg.mediatype, documentHos
t, thirdParty); | 353 var filter = defaultMatcher.matchesAny(msg.url, msg.mediatype, documentHos
t, thirdParty); |
364 if (filter instanceof BlockingFilter) | 354 if (filter instanceof BlockingFilter) |
365 { | 355 { |
366 var collapse = filter.collapse; | 356 var collapse = filter.collapse; |
367 if (collapse == null) | 357 if (collapse == null) |
368 collapse = (localStorage.hidePlaceholders != "false"); | 358 collapse = Prefs.hidePlaceholders; |
369 sendResponse(collapse); | 359 sendResponse(collapse); |
370 } | 360 } |
371 else | 361 else |
372 sendResponse(false); | 362 sendResponse(false); |
373 break; | 363 break; |
374 case "get-domain-enabled-state": | 364 case "get-domain-enabled-state": |
375 // Returns whether this domain is in the exclusion list. | 365 // Returns whether this domain is in the exclusion list. |
376 // The browser action popup asks us this. | 366 // The browser action popup asks us this. |
377 if(sender.tab) | 367 if(sender.tab) |
378 { | 368 { |
(...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
429 tab.sendMessage({type: "clickhide-deactivate"}); | 419 tab.sendMessage({type: "clickhide-deactivate"}); |
430 refreshIconAndContextMenu(tab); | 420 refreshIconAndContextMenu(tab); |
431 }); | 421 }); |
432 | 422 |
433 setTimeout(function() | 423 setTimeout(function() |
434 { | 424 { |
435 var notificationToShow = Notification.getNextToShow(); | 425 var notificationToShow = Notification.getNextToShow(); |
436 if (notificationToShow) | 426 if (notificationToShow) |
437 showNotification(notificationToShow); | 427 showNotification(notificationToShow); |
438 }, 3 * 60 * 1000); | 428 }, 3 * 60 * 1000); |
LEFT | RIGHT |