Merge pull request #3425 from atom/tray-api

Rename the "clicked" event to "click" in Tray
This commit is contained in:
Cheng Zhao 2015-11-13 18:52:56 +08:00
commit 5d52ff76ab
5 changed files with 26 additions and 17 deletions

View file

@ -44,21 +44,21 @@ mate::Wrappable* Tray::New(v8::Isolate* isolate, const gfx::Image& image) {
void Tray::OnClicked(const gfx::Rect& bounds, int modifiers) { void Tray::OnClicked(const gfx::Rect& bounds, int modifiers) {
v8::Locker locker(isolate()); v8::Locker locker(isolate());
v8::HandleScope handle_scope(isolate()); v8::HandleScope handle_scope(isolate());
EmitCustomEvent("clicked", EmitCustomEvent("click",
ModifiersToObject(isolate(), modifiers), bounds); ModifiersToObject(isolate(), modifiers), bounds);
} }
void Tray::OnDoubleClicked(const gfx::Rect& bounds, int modifiers) { void Tray::OnDoubleClicked(const gfx::Rect& bounds, int modifiers) {
v8::Locker locker(isolate()); v8::Locker locker(isolate());
v8::HandleScope handle_scope(isolate()); v8::HandleScope handle_scope(isolate());
EmitCustomEvent("double-clicked", EmitCustomEvent("double-click",
ModifiersToObject(isolate(), modifiers), bounds); ModifiersToObject(isolate(), modifiers), bounds);
} }
void Tray::OnRightClicked(const gfx::Rect& bounds, int modifiers) { void Tray::OnRightClicked(const gfx::Rect& bounds, int modifiers) {
v8::Locker locker(isolate()); v8::Locker locker(isolate());
v8::HandleScope handle_scope(isolate()); v8::HandleScope handle_scope(isolate());
EmitCustomEvent("right-clicked", EmitCustomEvent("right-click",
ModifiersToObject(isolate(), modifiers), bounds); ModifiersToObject(isolate(), modifiers), bounds);
} }
@ -67,7 +67,7 @@ void Tray::OnBalloonShow() {
} }
void Tray::OnBalloonClicked() { void Tray::OnBalloonClicked() {
Emit("balloon-clicked"); Emit("balloon-click");
} }
void Tray::OnBalloonClosed() { void Tray::OnBalloonClosed() {

View file

@ -1,7 +1,7 @@
{app, ipcMain, deprecate} = require 'electron' {app, ipcMain, deprecate} = require 'electron'
{EventEmitter} = require 'events' {EventEmitter} = require 'events'
BrowserWindow = process.atomBinding('window').BrowserWindow {BrowserWindow} = process.atomBinding 'window'
BrowserWindow::__proto__ = EventEmitter.prototype BrowserWindow::__proto__ = EventEmitter.prototype
BrowserWindow::_init = -> BrowserWindow::_init = ->

View file

@ -1,13 +1,19 @@
{deprecate} = require 'electron'
{EventEmitter} = require 'events' {EventEmitter} = require 'events'
{Tray} = process.atomBinding 'tray'
{Tray} = process.atomBinding 'tray'
Tray::__proto__ = EventEmitter.prototype Tray::__proto__ = EventEmitter.prototype
Tray::_init = ->
# Deprecated.
deprecate.rename this, 'popContextMenu', 'popUpContextMenu'
deprecate.event this, 'clicked', 'click'
deprecate.event this, 'double-clicked', 'double-click'
deprecate.event this, 'right-clicked', 'right-click'
deprecate.event this, 'balloon-clicked', 'balloon-click'
Tray::setContextMenu = (menu) -> Tray::setContextMenu = (menu) ->
@_setContextMenu menu @_setContextMenu menu
@menu = menu # Keep a strong reference of menu. @menu = menu # Keep a strong reference of menu.
# Keep compatibility with old APIs.
Tray::popContextMenu = Tray::popUpContextMenu
module.exports = Tray module.exports = Tray

View file

@ -42,12 +42,15 @@ deprecate.property = (object, property, method) ->
# Deprecate an event. # Deprecate an event.
deprecate.event = (emitter, oldName, newName, fn) -> deprecate.event = (emitter, oldName, newName, fn) ->
warned = false warned = false
emitter.on newName, -> emitter.on newName, (args...) ->
if @listenerCount(oldName) > 0 # there is listeners for old API. if @listenerCount(oldName) > 0 # there is listeners for old API.
unless warned or process.noDeprecation unless warned or process.noDeprecation
warned = true warned = true
deprecate.warn "'#{oldName}' event", "'#{newName}' event" deprecate.warn "'#{oldName}' event", "'#{newName}' event"
if fn?
fn.apply this, arguments fn.apply this, arguments
else
@emit oldName, args...
# Print deprecate warning. # Print deprecate warning.
deprecate.warn = (oldName, newName) -> deprecate.warn = (oldName, newName) ->

View file

@ -31,10 +31,10 @@ __Platform limitations:__
* On Linux distributions that only have app indicator support, you have to * On Linux distributions that only have app indicator support, you have to
install `libappindicator1` to make the tray icon work. install `libappindicator1` to make the tray icon work.
* App indicator will only be shown when it has a context menu. * App indicator will only be shown when it has a context menu.
* When app indicator is used on Linux, the `clicked` event is ignored. * When app indicator is used on Linux, the `click` event is ignored.
If you want to keep exact same behaviors on all platforms, you should not If you want to keep exact same behaviors on all platforms, you should not
rely on the `clicked` event and always attach a context menu to the tray icon. rely on the `click` event and always attach a context menu to the tray icon.
## Class: Tray ## Class: Tray
@ -53,7 +53,7 @@ The `Tray` module emits the following events:
**Note:** Some events are only available on specific operating systems and are **Note:** Some events are only available on specific operating systems and are
labeled as such. labeled as such.
### Event: 'clicked' ### Event: 'click'
* `event` Event * `event` Event
* `altKey` Boolean * `altKey` Boolean
@ -70,7 +70,7 @@ Emitted when the tray icon is clicked.
__Note:__ The `bounds` payload is only implemented on OS X and Windows. __Note:__ The `bounds` payload is only implemented on OS X and Windows.
### Event: 'right-clicked' _OS X_ _Windows_ ### Event: 'right-click' _OS X_ _Windows_
* `event` Event * `event` Event
* `altKey` Boolean * `altKey` Boolean
@ -85,7 +85,7 @@ __Note:__ The `bounds` payload is only implemented on OS X and Windows.
Emitted when the tray icon is right clicked. Emitted when the tray icon is right clicked.
### Event: 'double-clicked' _OS X_ _Windows_ ### Event: 'double-click' _OS X_ _Windows_
* `event` Event * `event` Event
* `altKey` Boolean * `altKey` Boolean
@ -104,7 +104,7 @@ Emitted when the tray icon is double clicked.
Emitted when the tray balloon shows. Emitted when the tray balloon shows.
### Event: 'balloon-clicked' _Windows_ ### Event: 'balloon-click' _Windows_
Emitted when the tray balloon is clicked. Emitted when the tray balloon is clicked.