Add EventEmitter::CreateEventFromFlags
This commit is contained in:
parent
08a1e92650
commit
e6327fb015
4 changed files with 24 additions and 25 deletions
|
@ -16,7 +16,6 @@
|
||||||
#include "atom/common/node_includes.h"
|
#include "atom/common/node_includes.h"
|
||||||
#include "native_mate/constructor.h"
|
#include "native_mate/constructor.h"
|
||||||
#include "native_mate/dictionary.h"
|
#include "native_mate/dictionary.h"
|
||||||
#include "ui/events/event_constants.h"
|
|
||||||
#include "ui/gfx/image/image.h"
|
#include "ui/gfx/image/image.h"
|
||||||
|
|
||||||
namespace atom {
|
namespace atom {
|
||||||
|
@ -44,24 +43,15 @@ mate::WrappableBase* Tray::New(v8::Isolate* isolate,
|
||||||
}
|
}
|
||||||
|
|
||||||
void Tray::OnClicked(const gfx::Rect& bounds, int modifiers) {
|
void Tray::OnClicked(const gfx::Rect& bounds, int modifiers) {
|
||||||
v8::Locker locker(isolate());
|
EmitWithFlags("click", modifiers, bounds);
|
||||||
v8::HandleScope handle_scope(isolate());
|
|
||||||
EmitCustomEvent("click",
|
|
||||||
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());
|
EmitWithFlags("double-click", modifiers, bounds);
|
||||||
v8::HandleScope handle_scope(isolate());
|
|
||||||
EmitCustomEvent("double-click",
|
|
||||||
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());
|
EmitWithFlags("right-click", modifiers, bounds);
|
||||||
v8::HandleScope handle_scope(isolate());
|
|
||||||
EmitCustomEvent("right-click",
|
|
||||||
ModifiersToObject(isolate(), modifiers), bounds);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void Tray::OnBalloonShow() {
|
void Tray::OnBalloonShow() {
|
||||||
|
@ -163,16 +153,6 @@ gfx::Rect Tray::GetBounds() {
|
||||||
return tray_icon_->GetBounds();
|
return tray_icon_->GetBounds();
|
||||||
}
|
}
|
||||||
|
|
||||||
v8::Local<v8::Object> Tray::ModifiersToObject(v8::Isolate* isolate,
|
|
||||||
int modifiers) {
|
|
||||||
mate::Dictionary obj(isolate, v8::Object::New(isolate));
|
|
||||||
obj.Set("shiftKey", static_cast<bool>(modifiers & ui::EF_SHIFT_DOWN));
|
|
||||||
obj.Set("ctrlKey", static_cast<bool>(modifiers & ui::EF_CONTROL_DOWN));
|
|
||||||
obj.Set("altKey", static_cast<bool>(modifiers & ui::EF_ALT_DOWN));
|
|
||||||
obj.Set("metaKey", static_cast<bool>(modifiers & ui::EF_COMMAND_DOWN));
|
|
||||||
return obj.GetHandle();
|
|
||||||
}
|
|
||||||
|
|
||||||
// static
|
// static
|
||||||
void Tray::BuildPrototype(v8::Isolate* isolate,
|
void Tray::BuildPrototype(v8::Isolate* isolate,
|
||||||
v8::Local<v8::ObjectTemplate> prototype) {
|
v8::Local<v8::ObjectTemplate> prototype) {
|
||||||
|
|
|
@ -68,8 +68,6 @@ class Tray : public mate::TrackableObject<Tray>,
|
||||||
gfx::Rect GetBounds();
|
gfx::Rect GetBounds();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
v8::Local<v8::Object> ModifiersToObject(v8::Isolate* isolate, int modifiers);
|
|
||||||
|
|
||||||
v8::Global<v8::Object> menu_;
|
v8::Global<v8::Object> menu_;
|
||||||
std::unique_ptr<TrayIcon> tray_icon_;
|
std::unique_ptr<TrayIcon> tray_icon_;
|
||||||
|
|
||||||
|
|
|
@ -8,6 +8,7 @@
|
||||||
#include "native_mate/arguments.h"
|
#include "native_mate/arguments.h"
|
||||||
#include "native_mate/dictionary.h"
|
#include "native_mate/dictionary.h"
|
||||||
#include "native_mate/object_template_builder.h"
|
#include "native_mate/object_template_builder.h"
|
||||||
|
#include "ui/events/event_constants.h"
|
||||||
|
|
||||||
namespace mate {
|
namespace mate {
|
||||||
|
|
||||||
|
@ -65,6 +66,15 @@ v8::Local<v8::Object> CreateCustomEvent(
|
||||||
return event;
|
return event;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
v8::Local<v8::Object> CreateEventFromFlags(v8::Isolate* isolate, int flags) {
|
||||||
|
mate::Dictionary obj = mate::Dictionary::CreateEmpty(isolate);
|
||||||
|
obj.Set("shiftKey", static_cast<bool>(flags & ui::EF_SHIFT_DOWN));
|
||||||
|
obj.Set("ctrlKey", static_cast<bool>(flags & ui::EF_CONTROL_DOWN));
|
||||||
|
obj.Set("altKey", static_cast<bool>(flags & ui::EF_ALT_DOWN));
|
||||||
|
obj.Set("metaKey", static_cast<bool>(flags & ui::EF_COMMAND_DOWN));
|
||||||
|
return obj.GetHandle();
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace internal
|
} // namespace internal
|
||||||
|
|
||||||
} // namespace mate
|
} // namespace mate
|
||||||
|
|
|
@ -30,6 +30,7 @@ v8::Local<v8::Object> CreateCustomEvent(
|
||||||
v8::Isolate* isolate,
|
v8::Isolate* isolate,
|
||||||
v8::Local<v8::Object> object,
|
v8::Local<v8::Object> object,
|
||||||
v8::Local<v8::Object> event);
|
v8::Local<v8::Object> event);
|
||||||
|
v8::Local<v8::Object> CreateEventFromFlags(v8::Isolate* isolate, int flags);
|
||||||
|
|
||||||
} // namespace internal
|
} // namespace internal
|
||||||
|
|
||||||
|
@ -54,6 +55,16 @@ class EventEmitter : public Wrappable<T> {
|
||||||
internal::CreateCustomEvent(isolate(), GetWrapper(), event), args...);
|
internal::CreateCustomEvent(isolate(), GetWrapper(), event), args...);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// this.emit(name, new Event(flags), args...);
|
||||||
|
template<typename... Args>
|
||||||
|
bool EmitWithFlags(const base::StringPiece& name,
|
||||||
|
int flags,
|
||||||
|
const Args&... args) {
|
||||||
|
return EmitCustomEvent(
|
||||||
|
name,
|
||||||
|
internal::CreateEventFromFlags(isolate(), flags), args...);
|
||||||
|
}
|
||||||
|
|
||||||
// this.emit(name, new Event(), args...);
|
// this.emit(name, new Event(), args...);
|
||||||
template<typename... Args>
|
template<typename... Args>
|
||||||
bool Emit(const base::StringPiece& name, const Args&... args) {
|
bool Emit(const base::StringPiece& name, const Args&... args) {
|
||||||
|
|
Loading…
Reference in a new issue