Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 // Custom binding for the browserAction API. | 5 // Custom binding for the browserAction API. |
| 6 | 6 |
| 7 var binding = require('binding').Binding.create('browserAction'); | 7 var binding = require('binding').Binding.create('browserAction'); |
| 8 | 8 |
| 9 var setIcon = require('setIcon').setIcon; | 9 var setIcon = require('setIcon').setIcon; |
| 10 var getExtensionViews = requireNative('extension').GetExtensionViews; | |
| 10 | 11 |
| 11 binding.registerCustomHook(function(bindingsAPI) { | 12 binding.registerCustomHook(function(bindingsAPI) { |
| 12 var apiFunctions = bindingsAPI.apiFunctions; | 13 var apiFunctions = bindingsAPI.apiFunctions; |
| 13 | 14 |
| 14 apiFunctions.setHandleRequest('setIcon', function(details, callback) { | 15 apiFunctions.setHandleRequest('setIcon', function(details, callback) { |
| 15 setIcon(details, callback, this.name, this.definition.parameters, | 16 setIcon(details, callback, this.name, this.definition.parameters, |
| 16 'browser action'); | 17 'browser action'); |
| 17 }); | 18 }); |
| 19 | |
| 20 apiFunctions.setCustomCallback('openPopup', | |
| 21 function(name, request, response) { | |
| 22 if (response && request.callback) { | |
| 23 var callback = request.callback; | |
| 24 // TODO(justinlin): Figure out how to ensure the popup is already open | |
| 25 // before calling this. | |
| 26 setTimeout(function() { | |
| 27 var views = getExtensionViews(-1, 'POPUP'); | |
| 28 callback(views.length > 0 ? views[0] : null); | |
| 29 }, 50); | |
| 30 } else { | |
| 31 request.callback(null); | |
| 32 } | |
| 33 request.callback = null; | |
| 34 }); | |
|
Finnur
2013/10/15 10:44:21
I've not been doing many custom bindings (that I c
Matt Perry
2013/10/15 21:29:41
Yep, already commented on this. The custom binding
justinlin
2013/10/16 07:06:48
I fixed the setTimeout hack. I think custom bindin
| |
| 18 }); | 35 }); |
| 19 | 36 |
| 20 exports.binding = binding.generate(); | 37 exports.binding = binding.generate(); |
| OLD | NEW |