Store weak ref to Notification in ToastEventHandler

This commit is contained in:
Cheng Zhao 2016-04-15 16:14:13 +09:00
parent ddee77fae4
commit f4c27c6d29
9 changed files with 32 additions and 47 deletions

View file

@ -136,19 +136,12 @@ void LibnotifyNotification::Dismiss() {
void LibnotifyNotification::OnNotificationClosed( void LibnotifyNotification::OnNotificationClosed(
NotifyNotification* notification) { NotifyNotification* notification) {
delegate()->NotificationClosed(); NotificationDismissed();
Destroy();
} }
void LibnotifyNotification::OnNotificationView( void LibnotifyNotification::OnNotificationView(
NotifyNotification* notification, char* action) { NotifyNotification* notification, char* action) {
delegate()->NotificationClick(); NotificationClicked();
Destroy();
}
void LibnotifyNotification::NotificationFailed() {
delegate()->NotificationFailed();
Destroy();
} }
} // namespace brightray } // namespace brightray

View file

@ -34,8 +34,6 @@ class LibnotifyNotification : public Notification {
CHROMEG_CALLBACK_1(LibnotifyNotification, void, OnNotificationView, CHROMEG_CALLBACK_1(LibnotifyNotification, void, OnNotificationView,
NotifyNotification*, char*); NotifyNotification*, char*);
void NotificationFailed();
NotifyNotification* notification_; NotifyNotification* notification_;
DISALLOW_COPY_AND_ASSIGN(LibnotifyNotification); DISALLOW_COPY_AND_ASSIGN(LibnotifyNotification);

View file

@ -28,8 +28,7 @@ class CocoaNotification : public Notification {
const bool silent) override; const bool silent) override;
void Dismiss() override; void Dismiss() override;
void NotifyDisplayed(); void NotificationDisplayed();
void NotifyClick();
NSUserNotification* notification() const { return notification_; } NSUserNotification* notification() const { return notification_; }

View file

@ -58,17 +58,11 @@ void CocoaNotification::Show(const base::string16& title,
void CocoaNotification::Dismiss() { void CocoaNotification::Dismiss() {
[NSUserNotificationCenter.defaultUserNotificationCenter [NSUserNotificationCenter.defaultUserNotificationCenter
removeDeliveredNotification:notification_]; removeDeliveredNotification:notification_];
delegate()->NotificationClosed(); NotificationDismissed();
Destroy();
} }
void CocoaNotification::NotifyDisplayed() { void CocoaNotification::NotificationDisplayed() {
delegate()->NotificationDisplayed(); delegate()->NotificationDisplayed();
} }
void CocoaNotification::NotifyClick() {
delegate()->NotificationClick();
Destroy();
}
} // namespace brightray } // namespace brightray

View file

@ -22,14 +22,14 @@
didDeliverNotification:(NSUserNotification*)notif { didDeliverNotification:(NSUserNotification*)notif {
auto notification = presenter_->GetNotification(notif); auto notification = presenter_->GetNotification(notif);
if (notification) if (notification)
notification->NotifyDisplayed(); notification->NotificationDisplayed();
} }
- (void)userNotificationCenter:(NSUserNotificationCenter*)center - (void)userNotificationCenter:(NSUserNotificationCenter*)center
didActivateNotification:(NSUserNotification *)notif { didActivateNotification:(NSUserNotification *)notif {
auto notification = presenter_->GetNotification(notif); auto notification = presenter_->GetNotification(notif);
if (notification) if (notification)
notification->NotifyClick(); notification->NotificationClicked();
} }
- (BOOL)userNotificationCenter:(NSUserNotificationCenter*)center - (BOOL)userNotificationCenter:(NSUserNotificationCenter*)center

View file

@ -20,6 +20,21 @@ Notification::~Notification() {
delegate()->NotificationDestroyed(); delegate()->NotificationDestroyed();
} }
void Notification::NotificationClicked() {
delegate()->NotificationClick();
Destroy();
}
void Notification::NotificationDismissed() {
delegate()->NotificationClosed();
Destroy();
}
void Notification::NotificationFailed() {
delegate()->NotificationFailed();
Destroy();
}
void Notification::Destroy() { void Notification::Destroy() {
presenter()->RemoveNotification(this); presenter()->RemoveNotification(this);
} }

View file

@ -29,6 +29,11 @@ class Notification {
// notification gets closed. // notification gets closed.
virtual void Dismiss() = 0; virtual void Dismiss() = 0;
// Should be called by derived classes.
void NotificationClicked();
void NotificationDismissed();
void NotificationFailed();
base::WeakPtr<Notification> GetWeakPtr() { base::WeakPtr<Notification> GetWeakPtr() {
return weak_factory_.GetWeakPtr(); return weak_factory_.GetWeakPtr();
} }

View file

@ -117,7 +117,7 @@ void WindowsToastNotification::Show(
return; return;
} }
if (FAILED(SetupCallbacks(toast_notification_.Get()))) { if (!SetupCallbacks(toast_notification_.Get())) {
NotificationFailed(); NotificationFailed();
return; return;
} }
@ -134,21 +134,6 @@ void WindowsToastNotification::Dismiss() {
toast_notifier_->Hide(toast_notification_.Get()); toast_notifier_->Hide(toast_notification_.Get());
} }
void WindowsToastNotification::NotificationClicked() {
delegate()->NotificationClick();
Destroy();
}
void WindowsToastNotification::NotificationDismissed() {
delegate()->NotificationClosed();
Destroy();
}
void WindowsToastNotification::NotificationFailed() {
delegate()->NotificationFailed();
Destroy();
}
bool WindowsToastNotification::GetToastXml( bool WindowsToastNotification::GetToastXml(
ABI::Windows::UI::Notifications::IToastNotificationManagerStatics* toastManager, ABI::Windows::UI::Notifications::IToastNotificationManagerStatics* toastManager,
const std::wstring& title, const std::wstring& title,
@ -390,8 +375,8 @@ bool WindowsToastNotification::RemoveCallbacks(
/* /*
/ Toast Event Handler / Toast Event Handler
*/ */
ToastEventHandler::ToastEventHandler(WindowsToastNotification* notification) ToastEventHandler::ToastEventHandler(Notification* notification)
: notification_(notification) { : notification_(notification->GetWeakPtr()) {
} }
ToastEventHandler::~ToastEventHandler() { ToastEventHandler::~ToastEventHandler() {

View file

@ -50,10 +50,6 @@ class WindowsToastNotification : public Notification {
private: private:
friend class ToastEventHandler; friend class ToastEventHandler;
void NotificationClicked();
void NotificationDismissed();
void NotificationFailed();
bool GetToastXml(ABI::Windows::UI::Notifications::IToastNotificationManagerStatics* toastManager, bool GetToastXml(ABI::Windows::UI::Notifications::IToastNotificationManagerStatics* toastManager,
const std::wstring& title, const std::wstring& title,
const std::wstring& msg, const std::wstring& msg,
@ -97,7 +93,7 @@ class ToastEventHandler : public RuntimeClass<RuntimeClassFlags<ClassicCom>,
DesktopToastDismissedEventHandler, DesktopToastDismissedEventHandler,
DesktopToastFailedEventHandler> { DesktopToastFailedEventHandler> {
public: public:
ToastEventHandler(WindowsToastNotification* notification); ToastEventHandler(Notification* notification);
~ToastEventHandler(); ~ToastEventHandler();
IFACEMETHODIMP Invoke(ABI::Windows::UI::Notifications::IToastNotification* sender, IInspectable* args); IFACEMETHODIMP Invoke(ABI::Windows::UI::Notifications::IToastNotification* sender, IInspectable* args);
@ -105,7 +101,7 @@ class ToastEventHandler : public RuntimeClass<RuntimeClassFlags<ClassicCom>,
IFACEMETHODIMP Invoke(ABI::Windows::UI::Notifications::IToastNotification* sender, ABI::Windows::UI::Notifications::IToastFailedEventArgs* e); IFACEMETHODIMP Invoke(ABI::Windows::UI::Notifications::IToastNotification* sender, ABI::Windows::UI::Notifications::IToastFailedEventArgs* e);
private: private:
WindowsToastNotification* notification_; // weak ref. base::WeakPtr<Notification> notification_; // weak ref.
DISALLOW_COPY_AND_ASSIGN(ToastEventHandler); DISALLOW_COPY_AND_ASSIGN(ToastEventHandler);
}; };