Bind TrayIcon to JS.
This commit is contained in:
parent
52d8d6fdb3
commit
6c7fe80ec5
13 changed files with 169 additions and 11 deletions
5
atom.gyp
5
atom.gyp
|
@ -24,6 +24,7 @@
|
||||||
'atom/browser/api/lib/menu-item.coffee',
|
'atom/browser/api/lib/menu-item.coffee',
|
||||||
'atom/browser/api/lib/power-monitor.coffee',
|
'atom/browser/api/lib/power-monitor.coffee',
|
||||||
'atom/browser/api/lib/protocol.coffee',
|
'atom/browser/api/lib/protocol.coffee',
|
||||||
|
'atom/browser/api/lib/tray.coffee',
|
||||||
'atom/browser/api/lib/web-contents.coffee',
|
'atom/browser/api/lib/web-contents.coffee',
|
||||||
'atom/browser/lib/init.coffee',
|
'atom/browser/lib/init.coffee',
|
||||||
'atom/browser/lib/objects-registry.coffee',
|
'atom/browser/lib/objects-registry.coffee',
|
||||||
|
@ -62,6 +63,8 @@
|
||||||
'atom/browser/api/atom_api_power_monitor.h',
|
'atom/browser/api/atom_api_power_monitor.h',
|
||||||
'atom/browser/api/atom_api_protocol.cc',
|
'atom/browser/api/atom_api_protocol.cc',
|
||||||
'atom/browser/api/atom_api_protocol.h',
|
'atom/browser/api/atom_api_protocol.h',
|
||||||
|
'atom/browser/api/atom_api_tray.cc',
|
||||||
|
'atom/browser/api/atom_api_tray.h',
|
||||||
'atom/browser/api/atom_api_web_contents.cc',
|
'atom/browser/api/atom_api_web_contents.cc',
|
||||||
'atom/browser/api/atom_api_web_contents.h',
|
'atom/browser/api/atom_api_web_contents.h',
|
||||||
'atom/browser/api/atom_api_window.cc',
|
'atom/browser/api/atom_api_window.cc',
|
||||||
|
@ -184,6 +187,8 @@
|
||||||
'atom/common/native_mate_converters/file_path_converter.h',
|
'atom/common/native_mate_converters/file_path_converter.h',
|
||||||
'atom/common/native_mate_converters/function_converter.h',
|
'atom/common/native_mate_converters/function_converter.h',
|
||||||
'atom/common/native_mate_converters/gurl_converter.h',
|
'atom/common/native_mate_converters/gurl_converter.h',
|
||||||
|
'atom/common/native_mate_converters/image_converter.cc',
|
||||||
|
'atom/common/native_mate_converters/image_converter.h',
|
||||||
'atom/common/native_mate_converters/string16_converter.h',
|
'atom/common/native_mate_converters/string16_converter.h',
|
||||||
'atom/common/native_mate_converters/v8_value_converter.cc',
|
'atom/common/native_mate_converters/v8_value_converter.cc',
|
||||||
'atom/common/native_mate_converters/v8_value_converter.h',
|
'atom/common/native_mate_converters/v8_value_converter.h',
|
||||||
|
|
|
@ -34,6 +34,8 @@ class Menu : public mate::Wrappable,
|
||||||
static void SendActionToFirstResponder(const std::string& action);
|
static void SendActionToFirstResponder(const std::string& action);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
ui::SimpleMenuModel* model() const { return model_.get(); }
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
Menu();
|
Menu();
|
||||||
virtual ~Menu();
|
virtual ~Menu();
|
||||||
|
|
76
atom/browser/api/atom_api_tray.cc
Normal file
76
atom/browser/api/atom_api_tray.cc
Normal file
|
@ -0,0 +1,76 @@
|
||||||
|
// Copyright (c) 2014 GitHub, Inc. All rights reserved.
|
||||||
|
// Use of this source code is governed by the MIT license that can be
|
||||||
|
// found in the LICENSE file.
|
||||||
|
|
||||||
|
#include "atom/browser/api/atom_api_tray.h"
|
||||||
|
|
||||||
|
#include "atom/browser/api/atom_api_menu.h"
|
||||||
|
#include "atom/browser/ui/tray_icon.h"
|
||||||
|
#include "atom/common/native_mate_converters/image_converter.h"
|
||||||
|
#include "native_mate/constructor.h"
|
||||||
|
#include "native_mate/dictionary.h"
|
||||||
|
|
||||||
|
#include "atom/common/node_includes.h"
|
||||||
|
|
||||||
|
namespace atom {
|
||||||
|
|
||||||
|
namespace api {
|
||||||
|
|
||||||
|
Tray::Tray(const gfx::ImageSkia& image)
|
||||||
|
: tray_icon_(TrayIcon::Create()) {
|
||||||
|
tray_icon_->SetImage(image);
|
||||||
|
}
|
||||||
|
|
||||||
|
Tray::~Tray() {
|
||||||
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
mate::Wrappable* Tray::New(const gfx::ImageSkia& image) {
|
||||||
|
return new Tray(image);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Tray::SetImage(const gfx::ImageSkia& image) {
|
||||||
|
tray_icon_->SetImage(image);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Tray::SetPressedImage(const gfx::ImageSkia& image) {
|
||||||
|
tray_icon_->SetPressedImage(image);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Tray::SetToolTip(const std::string& tool_tip) {
|
||||||
|
tray_icon_->SetToolTip(tool_tip);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Tray::SetContextMenu(Menu* menu) {
|
||||||
|
tray_icon_->SetContextMenu(menu->model());
|
||||||
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
void Tray::BuildPrototype(v8::Isolate* isolate,
|
||||||
|
v8::Handle<v8::ObjectTemplate> prototype) {
|
||||||
|
mate::ObjectTemplateBuilder(isolate, prototype)
|
||||||
|
.SetMethod("setImage", &Tray::SetImage)
|
||||||
|
.SetMethod("setPressedImage", &Tray::SetPressedImage)
|
||||||
|
.SetMethod("setToolTip", &Tray::SetToolTip)
|
||||||
|
.SetMethod("_setContextMenu", &Tray::SetContextMenu);
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace api
|
||||||
|
|
||||||
|
} // namespace atom
|
||||||
|
|
||||||
|
|
||||||
|
namespace {
|
||||||
|
|
||||||
|
void Initialize(v8::Handle<v8::Object> exports) {
|
||||||
|
using atom::api::Tray;
|
||||||
|
v8::Isolate* isolate = v8::Isolate::GetCurrent();
|
||||||
|
v8::Handle<v8::Function> constructor = mate::CreateConstructor<Tray>(
|
||||||
|
isolate, "Tray", base::Bind(&Tray::New));
|
||||||
|
mate::Dictionary dict(isolate, exports);
|
||||||
|
dict.Set("Tray", static_cast<v8::Handle<v8::Value>>(constructor));
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace
|
||||||
|
|
||||||
|
NODE_MODULE(atom_browser_tray, Initialize)
|
49
atom/browser/api/atom_api_tray.h
Normal file
49
atom/browser/api/atom_api_tray.h
Normal file
|
@ -0,0 +1,49 @@
|
||||||
|
// Copyright (c) 2014 GitHub, Inc. All rights reserved.
|
||||||
|
// Use of this source code is governed by the MIT license that can be
|
||||||
|
// found in the LICENSE file.
|
||||||
|
|
||||||
|
#ifndef ATOM_BROWSER_API_ATOM_API_TRAY_H_
|
||||||
|
#define ATOM_BROWSER_API_ATOM_API_TRAY_H_
|
||||||
|
|
||||||
|
#include "atom/browser/api/event_emitter.h"
|
||||||
|
#include "base/memory/scoped_ptr.h"
|
||||||
|
|
||||||
|
namespace gfx {
|
||||||
|
class ImageSkia;
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace atom {
|
||||||
|
|
||||||
|
class TrayIcon;
|
||||||
|
|
||||||
|
namespace api {
|
||||||
|
|
||||||
|
class Menu;
|
||||||
|
|
||||||
|
class Tray : public mate::EventEmitter {
|
||||||
|
public:
|
||||||
|
static mate::Wrappable* New(const gfx::ImageSkia& image);
|
||||||
|
|
||||||
|
static void BuildPrototype(v8::Isolate* isolate,
|
||||||
|
v8::Handle<v8::ObjectTemplate> prototype);
|
||||||
|
|
||||||
|
protected:
|
||||||
|
Tray(const gfx::ImageSkia& image);
|
||||||
|
virtual ~Tray();
|
||||||
|
|
||||||
|
void SetImage(const gfx::ImageSkia& image);
|
||||||
|
void SetPressedImage(const gfx::ImageSkia& image);
|
||||||
|
void SetToolTip(const std::string& tool_tip);
|
||||||
|
void SetContextMenu(Menu* menu);
|
||||||
|
|
||||||
|
private:
|
||||||
|
scoped_ptr<TrayIcon> tray_icon_;
|
||||||
|
|
||||||
|
DISALLOW_COPY_AND_ASSIGN(Tray);
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace api
|
||||||
|
|
||||||
|
} // namespace atom
|
||||||
|
|
||||||
|
#endif // ATOM_BROWSER_API_ATOM_API_TRAY_H_
|
10
atom/browser/api/lib/tray.coffee
Normal file
10
atom/browser/api/lib/tray.coffee
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
EventEmitter = require('events').EventEmitter
|
||||||
|
bindings = process.atomBinding 'tray'
|
||||||
|
|
||||||
|
Tray = bindings.Tray
|
||||||
|
Tray::__proto__ = EventEmitter.prototype
|
||||||
|
Tray::setContextMenu = (menu) ->
|
||||||
|
@_setContextMenu menu
|
||||||
|
@menu = menu # Keep a strong reference of menu.
|
||||||
|
|
||||||
|
module.exports = Tray
|
|
@ -15,6 +15,8 @@ class TrayIcon {
|
||||||
public:
|
public:
|
||||||
static TrayIcon* Create();
|
static TrayIcon* Create();
|
||||||
|
|
||||||
|
virtual ~TrayIcon();
|
||||||
|
|
||||||
// Sets the image associated with this status icon.
|
// Sets the image associated with this status icon.
|
||||||
virtual void SetImage(const gfx::ImageSkia& image) = 0;
|
virtual void SetImage(const gfx::ImageSkia& image) = 0;
|
||||||
|
|
||||||
|
@ -32,7 +34,6 @@ class TrayIcon {
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
TrayIcon();
|
TrayIcon();
|
||||||
virtual ~TrayIcon();
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
DISALLOW_COPY_AND_ASSIGN(TrayIcon);
|
DISALLOW_COPY_AND_ASSIGN(TrayIcon);
|
||||||
|
|
|
@ -18,15 +18,15 @@ namespace atom {
|
||||||
|
|
||||||
class TrayIconCocoa : public TrayIcon {
|
class TrayIconCocoa : public TrayIcon {
|
||||||
public:
|
public:
|
||||||
|
TrayIconCocoa();
|
||||||
|
virtual ~TrayIconCocoa();
|
||||||
|
|
||||||
virtual void SetImage(const gfx::ImageSkia& image) OVERRIDE;
|
virtual void SetImage(const gfx::ImageSkia& image) OVERRIDE;
|
||||||
virtual void SetPressedImage(const gfx::ImageSkia& image) OVERRIDE;
|
virtual void SetPressedImage(const gfx::ImageSkia& image) OVERRIDE;
|
||||||
virtual void SetToolTip(const std::string& tool_tip) OVERRIDE;
|
virtual void SetToolTip(const std::string& tool_tip) OVERRIDE;
|
||||||
virtual void SetContextMenu(ui::SimpleMenuModel* menu_model) OVERRIDE;
|
virtual void SetContextMenu(ui::SimpleMenuModel* menu_model) OVERRIDE;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
TrayIconCocoa();
|
|
||||||
virtual ~TrayIconCocoa();
|
|
||||||
|
|
||||||
base::scoped_nsobject<NSStatusItem> item_;
|
base::scoped_nsobject<NSStatusItem> item_;
|
||||||
|
|
||||||
// Status menu shown when right-clicking the system icon.
|
// Status menu shown when right-clicking the system icon.
|
||||||
|
|
|
@ -41,9 +41,13 @@ void TrayIconCocoa::SetToolTip(const std::string& tool_tip) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void TrayIconCocoa::SetContextMenu(ui::SimpleMenuModel* menu_model) {
|
void TrayIconCocoa::SetContextMenu(ui::SimpleMenuModel* menu_model) {
|
||||||
TrayIcon::SetContextMenu(menu_model);
|
|
||||||
menu_.reset([[AtomMenuController alloc] initWithModel:menu_model]);
|
menu_.reset([[AtomMenuController alloc] initWithModel:menu_model]);
|
||||||
[item_ setMenu:[menu_ menu]];
|
[item_ setMenu:[menu_ menu]];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
TrayIcon* TrayIcon::Create() {
|
||||||
|
return new TrayIconCocoa;
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace atom
|
} // namespace atom
|
||||||
|
|
|
@ -24,4 +24,9 @@ void TrayIconGtk::SetToolTip(const std::string& tool_tip) {
|
||||||
void TrayIconGtk::SetContextMenu(ui::SimpleMenuModel* menu_model) {
|
void TrayIconGtk::SetContextMenu(ui::SimpleMenuModel* menu_model) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
TrayIcon* TrayIcon::Create() {
|
||||||
|
return new TrayIconGtk;
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace atom
|
} // namespace atom
|
||||||
|
|
|
@ -13,15 +13,15 @@ namespace atom {
|
||||||
|
|
||||||
class TrayIconGtk : public TrayIcon {
|
class TrayIconGtk : public TrayIcon {
|
||||||
public:
|
public:
|
||||||
|
TrayIconGtk();
|
||||||
|
virtual ~TrayIconGtk();
|
||||||
|
|
||||||
virtual void SetImage(const gfx::ImageSkia& image) OVERRIDE;
|
virtual void SetImage(const gfx::ImageSkia& image) OVERRIDE;
|
||||||
virtual void SetPressedImage(const gfx::ImageSkia& image) OVERRIDE;
|
virtual void SetPressedImage(const gfx::ImageSkia& image) OVERRIDE;
|
||||||
virtual void SetToolTip(const std::string& tool_tip) OVERRIDE;
|
virtual void SetToolTip(const std::string& tool_tip) OVERRIDE;
|
||||||
virtual void SetContextMenu(ui::SimpleMenuModel* menu_model) OVERRIDE;
|
virtual void SetContextMenu(ui::SimpleMenuModel* menu_model) OVERRIDE;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
TrayIconGtk();
|
|
||||||
virtual ~TrayIconGtk();
|
|
||||||
|
|
||||||
DISALLOW_COPY_AND_ASSIGN(TrayIconGtk);
|
DISALLOW_COPY_AND_ASSIGN(TrayIconGtk);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -24,4 +24,9 @@ void TrayIconWin::SetToolTip(const std::string& tool_tip) {
|
||||||
void TrayIconWin::SetContextMenu(ui::SimpleMenuModel* menu_model) {
|
void TrayIconWin::SetContextMenu(ui::SimpleMenuModel* menu_model) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
|
TrayIcon* TrayIcon::Create() {
|
||||||
|
return new TrayIconWin;
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace atom
|
} // namespace atom
|
||||||
|
|
|
@ -13,15 +13,15 @@ namespace atom {
|
||||||
|
|
||||||
class TrayIconWin : public TrayIcon {
|
class TrayIconWin : public TrayIcon {
|
||||||
public:
|
public:
|
||||||
|
TrayIconWin();
|
||||||
|
virtual ~TrayIconWin();
|
||||||
|
|
||||||
virtual void SetImage(const gfx::ImageSkia& image) OVERRIDE;
|
virtual void SetImage(const gfx::ImageSkia& image) OVERRIDE;
|
||||||
virtual void SetPressedImage(const gfx::ImageSkia& image) OVERRIDE;
|
virtual void SetPressedImage(const gfx::ImageSkia& image) OVERRIDE;
|
||||||
virtual void SetToolTip(const std::string& tool_tip) OVERRIDE;
|
virtual void SetToolTip(const std::string& tool_tip) OVERRIDE;
|
||||||
virtual void SetContextMenu(ui::SimpleMenuModel* menu_model) OVERRIDE;
|
virtual void SetContextMenu(ui::SimpleMenuModel* menu_model) OVERRIDE;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
TrayIconWin();
|
|
||||||
virtual ~TrayIconWin();
|
|
||||||
|
|
||||||
DISALLOW_COPY_AND_ASSIGN(TrayIconWin);
|
DISALLOW_COPY_AND_ASSIGN(TrayIconWin);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -15,6 +15,7 @@ NODE_EXT_LIST_ITEM(atom_browser_dialog)
|
||||||
NODE_EXT_LIST_ITEM(atom_browser_menu)
|
NODE_EXT_LIST_ITEM(atom_browser_menu)
|
||||||
NODE_EXT_LIST_ITEM(atom_browser_power_monitor)
|
NODE_EXT_LIST_ITEM(atom_browser_power_monitor)
|
||||||
NODE_EXT_LIST_ITEM(atom_browser_protocol)
|
NODE_EXT_LIST_ITEM(atom_browser_protocol)
|
||||||
|
NODE_EXT_LIST_ITEM(atom_browser_tray)
|
||||||
NODE_EXT_LIST_ITEM(atom_browser_window)
|
NODE_EXT_LIST_ITEM(atom_browser_window)
|
||||||
|
|
||||||
// Module names start with `atom_renderer_` can only be used by renderer
|
// Module names start with `atom_renderer_` can only be used by renderer
|
||||||
|
|
Loading…
Reference in a new issue