| Left: | ||
| Right: |
| 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 171 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 182 onLoading: new LoadingTabEventTarget(safari.application), | 182 onLoading: new LoadingTabEventTarget(safari.application), |
| 183 onBeforeNavigate: new TabEventTarget(safari.application, "beforeNavigate", t rue), | 183 onBeforeNavigate: new TabEventTarget(safari.application, "beforeNavigate", t rue), |
| 184 onCompleted: new TabEventTarget(safari.application, "navigate", true), | 184 onCompleted: new TabEventTarget(safari.application, "navigate", true), |
| 185 onActivated: new TabEventTarget(safari.application, "activate", true), | 185 onActivated: new TabEventTarget(safari.application, "activate", true), |
| 186 onRemoved: new TabEventTarget(safari.application, "close", true) | 186 onRemoved: new TabEventTarget(safari.application, "close", true) |
| 187 }; | 187 }; |
| 188 | 188 |
| 189 | 189 |
| 190 /* Browser actions */ | 190 /* Browser actions */ |
| 191 | 191 |
| 192 var globalTooltipItemProperties = {} | 192 var toolbarItemProperties = {}; |
| 193 var tooltipItemPropertiesPerTab = new TabMap(); | 193 |
|
Wladimir Palant
2014/01/15 15:24:47
You meant toolbarItem, not tooltipItem, right?
Sebastian Noack
2014/01/15 19:25:47
It is gone now.
| |
| 194 var getToolbarItemProperty = function(name) | |
| 195 { | |
| 196 var property = toolbarItemProperties[name]; | |
| 197 if (!property) | |
| 198 { | |
| 199 property = {tabs: new TabMap()}; | |
| 200 toolbarItemProperties[name] = property; | |
| 201 } | |
| 202 return property; | |
| 203 }; | |
| 194 | 204 |
| 195 var getToolbarItemForWindow = function(win) | 205 var getToolbarItemForWindow = function(win) |
| 196 { | 206 { |
| 197 for (var i = 0; i < safari.extension.toolbarItems.length; i++) | 207 for (var i = 0; i < safari.extension.toolbarItems.length; i++) |
| 198 { | 208 { |
| 199 var toolbarItem = safari.extension.toolbarItems[i]; | 209 var toolbarItem = safari.extension.toolbarItems[i]; |
| 200 | 210 |
| 201 if (toolbarItem.browserWindow == win) | 211 if (toolbarItem.browserWindow == win) |
| 202 return toolbarItem; | 212 return toolbarItem; |
| 203 } | 213 } |
|
Wladimir Palant
2014/01/15 15:24:47
This should return something if no toolbar item is
Sebastian Noack
2014/01/15 19:25:47
Done. Even though I think that it is a bug when th
| |
| 214 | |
| 215 return null; | |
| 204 }; | 216 }; |
| 205 | 217 |
| 206 var BrowserAction = function(tab) | 218 var BrowserAction = function(tab) |
| 207 { | 219 { |
| 208 this._tab = tab; | 220 this._tab = tab; |
| 209 }; | 221 }; |
| 210 BrowserAction.prototype = { | 222 BrowserAction.prototype = { |
| 211 _set: function(property, value) | 223 _set: function(name, value) |
| 212 { | 224 { |
| 213 var currentWindow = this._tab._tab.browserWindow; | 225 var currentWindow = this._tab._tab.browserWindow; |
| 214 var toolbarItem = getToolbarItemForWindow(currentWindow); | 226 var toolbarItem = getToolbarItemForWindow(currentWindow); |
| 215 | 227 |
| 216 if (!(property in globalTooltipItemProperties)) | 228 if (toolbarItem) |
| 217 globalTooltipItemProperties[property] = toolbarItem[property]; | 229 { |
| 218 | 230 var property = getToolbarItemProperty(name); |
| 219 if (this._tab._tab == currentWindow.activeTab) | 231 property.tabs.set(this._tab, value); |
| 220 toolbarItem[property] = value; | 232 |
| 221 | 233 if (!("global" in property)) |
| 222 var props = tooltipItemPropertiesPerTab.get(this._tab); | 234 property.global = toolbarItem[name]; |
| 223 if (!props) | 235 |
| 224 { | 236 if (this._tab._tab == currentWindow.activeTab) |
| 225 props = {}; | 237 toolbarItem[name] = value; |
| 226 tooltipItemPropertiesPerTab.set(this._tab, props); | 238 } |
| 227 } | |
| 228 props[property] = value; | |
| 229 }, | 239 }, |
| 230 setIcon: function(path) | 240 setIcon: function(path) |
| 231 { | 241 { |
| 232 this._set("image", safari.extension.baseURI + path); | 242 this._set("image", safari.extension.baseURI + path); |
| 233 }, | 243 }, |
| 234 setTitle: function(title) | 244 setTitle: function(title) |
| 235 { | 245 { |
| 246 this._set("label", title); | |
| 236 this._set("toolTip", title); | 247 this._set("toolTip", title); |
| 237 }, | 248 }, |
| 238 setBadge: function(badge) | 249 setBadge: function(badge) |
| 239 { | 250 { |
| 240 if (!badge) | 251 if (!badge) |
| 241 this._set("badge", 0); | 252 this._set("badge", 0); |
| 242 else if ("number" in badge) | 253 else if ("number" in badge) |
| 243 this._set("badge", badge.number); | 254 this._set("badge", badge.number); |
| 244 } | 255 } |
| 245 }; | 256 }; |
| 246 | 257 |
| 247 ext.tabs.onActivated.addListener(function(tab) | 258 ext.tabs.onActivated.addListener(function(tab) |
| 248 { | 259 { |
| 249 var props = tooltipItemPropertiesPerTab.get(tab); | |
| 250 var toolbarItem = getToolbarItemForWindow(tab._tab.browserWindow); | 260 var toolbarItem = getToolbarItemForWindow(tab._tab.browserWindow); |
| 251 | 261 |
| 252 for (var property in globalTooltipItemProperties) | 262 if (!toolbarItem) |
| 253 { | 263 return; |
| 254 if (props && property in props) | 264 |
| 255 toolbarItem[property] = props[property]; | 265 for (var name in toolbarItemProperties) |
| 266 { | |
| 267 var property = toolbarItemProperties[name]; | |
| 268 | |
| 269 if (property.tabs.has(tab)) | |
| 270 toolbarItem[name] = property.tabs.get(tab); | |
| 256 else | 271 else |
| 257 toolbarItem[property] = globalTooltipItemProperties[property]; | 272 toolbarItem[name] = property.global; |
| 258 } | 273 } |
|
Wladimir Palant
2014/01/15 15:24:47
What's the point of globalTooltipItemProperties? I
Sebastian Noack
2014/01/15 19:25:47
This approach just emulates the behavior we alread
| |
| 259 }); | 274 }); |
| 260 | 275 |
| 261 | 276 |
| 262 /* Windows */ | 277 /* Windows */ |
| 263 | 278 |
| 264 Window = function(win) | 279 Window = function(win) |
| 265 { | 280 { |
| 266 this._win = win; | 281 this._win = win; |
| 267 } | 282 } |
| 268 Window.prototype = { | 283 Window.prototype = { |
| (...skipping 342 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 611 }; | 626 }; |
| 612 | 627 |
| 613 ext.onMessage = new BackgroundMessageEventTarget(); | 628 ext.onMessage = new BackgroundMessageEventTarget(); |
| 614 | 629 |
| 615 // TODO: Implement context menu | 630 // TODO: Implement context menu |
| 616 ext.contextMenus = { | 631 ext.contextMenus = { |
| 617 create: function(title, contexts, onclick) {}, | 632 create: function(title, contexts, onclick) {}, |
| 618 removeAll: function(callback) {} | 633 removeAll: function(callback) {} |
| 619 }; | 634 }; |
| 620 })(); | 635 })(); |
| LEFT | RIGHT |