| Left: | ||
| Right: |
| OLD | NEW |
|---|---|
| 1 var DownloadableSubscription = require("subscriptionClasses").DownloadableSubscr iption; | |
| 2 var WhitelistFilter = require("filterClasses").WhitelistFilter; | |
| 1 var FilterNotifier = require("filterNotifier").FilterNotifier; | 3 var FilterNotifier = require("filterNotifier").FilterNotifier; |
| 2 var FilterStorage = require("filterStorage").FilterStorage; | 4 var FilterStorage = require("filterStorage").FilterStorage; |
| 5 var Prefs = require("prefs").Prefs; | |
| 3 var Synchronizer = require("synchronizer").Synchronizer; | 6 var Synchronizer = require("synchronizer").Synchronizer; |
| 4 var Subscription = require("subscriptionClasses").Subscription; | 7 var Subscription = require("subscriptionClasses").Subscription; |
| 5 var DownloadableSubscription = require("subscriptionClasses").DownloadableSubscr iption; | 8 var SpecialSubscription = require("subscriptionClasses").SpecialSubscription; |
| 9 var Utils = require("utils").Utils; | |
| 6 | 10 |
| 7 var isFirstRun = false; | 11 var isFirstRun = false; |
| 8 FilterNotifier.addListener(function(action) | 12 FilterNotifier.addListener(function(action) |
| 9 { | 13 { |
| 10 if (action == "load") | 14 if (action == "load") |
| 11 { | 15 { |
| 12 importOldData(); | 16 importOldData(); |
| 13 if (!window.localStorage.currentVersion) | 17 if (!window.localStorage.currentVersion) |
| 14 { | 18 { |
| 15 isFirstRun = true; | 19 isFirstRun = true; |
| 16 executeFirstRunActions(); | 20 executeFirstRunActions(); |
| 17 } | 21 } |
| 18 window.localStorage.currentVersion = require("info").addonVersion; | 22 window.localStorage.currentVersion = require("info").addonVersion; |
| 19 } | 23 } |
| 20 }); | 24 }); |
| 21 | 25 |
| 26 var toolbarButton; | |
| 27 var i18nMessages; | |
| 28 | |
| 22 function importOldData() | 29 function importOldData() |
| 23 { | 30 { |
| 24 // TODO: Remove this once most people have the update | 31 // TODO: Remove this once most people have the update |
| 25 if ("version" in widget.preferences) | 32 if ("version" in widget.preferences) |
| 26 { | 33 { |
| 27 var oldLists = { | 34 var oldLists = { |
| 28 "fanboy": "https://secure.fanboy.co.nz/fanboy-adblock.txt", | 35 "fanboy": "https://secure.fanboy.co.nz/fanboy-adblock.txt", |
| 29 "fanboy-ru": "https://secure.fanboy.co.nz/fanboy-russian.txt", | 36 "fanboy-ru": "https://secure.fanboy.co.nz/fanboy-russian.txt", |
| 30 "fanboy-es": "https://secure.fanboy.co.nz/fanboy-espanol.txt", | 37 "fanboy-es": "https://secure.fanboy.co.nz/fanboy-espanol.txt", |
| 31 "fanboy-ja": "https://secure.fanboy.co.nz/fanboy-japanese.txt", | 38 "fanboy-ja": "https://secure.fanboy.co.nz/fanboy-japanese.txt", |
| (...skipping 105 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 137 subscription.disabled = false; | 144 subscription.disabled = false; |
| 138 subscription.title = selectedItem.getAttribute("title"); | 145 subscription.title = selectedItem.getAttribute("title"); |
| 139 subscription.homepage = selectedItem.getAttribute("homepage"); | 146 subscription.homepage = selectedItem.getAttribute("homepage"); |
| 140 if (subscription instanceof DownloadableSubscription && !subscription.last Download) | 147 if (subscription instanceof DownloadableSubscription && !subscription.last Download) |
| 141 Synchronizer.execute(subscription); | 148 Synchronizer.execute(subscription); |
| 142 FilterStorage.addSubscription(subscription); | 149 FilterStorage.addSubscription(subscription); |
| 143 } | 150 } |
| 144 }; | 151 }; |
| 145 request.send(null); | 152 request.send(null); |
| 146 } | 153 } |
| 154 | |
| 155 function setDefaultOptions() | |
| 156 { | |
| 157 function defaultOptionValue(opt, val) | |
| 158 { | |
| 159 if(!(opt in localStorage)) | |
| 160 localStorage[opt] = val; | |
| 161 } | |
| 162 | |
| 163 defaultOptionValue("shouldShowIcon", "true"); | |
| 164 } | |
| 165 | |
| 166 function createToolbarButton() | |
| 167 { | |
| 168 var properties = { | |
| 169 disabled: false, | |
| 170 title: "Adblock Plus", | |
| 171 icon: "icons/abp-18.png" | |
| 172 }; | |
| 173 | |
| 174 toolbarButton = opera.contexts.toolbar.createItem(properties); | |
| 175 } | |
| 176 | |
| 177 function refreshToolbarButton() | |
| 178 { | |
| 179 var toolbar = opera.contexts.toolbar; | |
| 180 if (localStorage["shouldShowIcon"] === "true") | |
| 181 toolbar.addItem(toolbarButton); | |
| 182 else | |
| 183 toolbar.removeItem(toolbarButton); | |
| 184 } | |
| 185 | |
| 186 function getJson(url) | |
| 187 { | |
| 188 var request = new XMLHttpRequest(); | |
| 189 request.open("GET", url, false); | |
| 190 request.responseType = "json"; | |
| 191 request.send(); | |
|
Wladimir Palant
2012/10/19 15:47:41
There is still a potential unhandled exception her
Felix Dahlke
2012/10/19 16:07:27
Yes, it will return an undefined value. My first a
Wladimir Palant
2012/10/22 08:57:51
Ok, it seems that the widget:// protocol behaves d
| |
| 192 return request.response; | |
| 193 } | |
| 194 | |
| 195 function loadMessagesForLocale(locale) | |
| 196 { | |
| 197 var messagesFileName = "messages.json"; | |
| 198 var messagesPath; | |
| 199 if (locale) | |
| 200 messagesPath = "locales/" + locale + "/" + messagesFileName; | |
| 201 else | |
| 202 messagesPath = messagesFileName; | |
| 203 | |
| 204 var messages = getJson(messagesPath); | |
| 205 if (!messages) | |
| 206 { | |
| 207 console.error("Failed to load messages for locale " | |
| 208 + (locale ? locale : "default")); | |
| 209 return; | |
| 210 } | |
| 211 | |
| 212 for (var i in messages) | |
| 213 i18nMessages[i] = messages[i]; | |
| 214 } | |
| 215 | |
| 216 function loadI18nMessages() | |
| 217 { | |
| 218 i18nMessages = {}; | |
| 219 | |
| 220 // Could be parsed from config.xml | |
| 221 var defaultLocale = "en"; | |
| 222 | |
| 223 if (locale !== defaultLocale) | |
|
Wladimir Palant
2012/10/19 15:47:41
I'm not really happy with the hack you use to defi
Felix Dahlke
2012/10/19 16:07:27
Done. It's not necessary anymore and I'm frankly h
| |
| 224 loadMessagesForLocale(defaultLocale); | |
| 225 | |
| 226 loadMessagesForLocale(); | |
| 227 } | |
| 228 | |
| 229 setDefaultOptions(); | |
| 230 createToolbarButton(); | |
| 231 refreshToolbarButton(); | |
| 232 loadI18nMessages(); | |
| OLD | NEW |