commit
fd90f2c360
18 changed files with 213 additions and 273 deletions
|
@ -259,6 +259,7 @@
|
||||||
'msvs_disabled_warnings': [
|
'msvs_disabled_warnings': [
|
||||||
4100, # unreferenced formal parameter
|
4100, # unreferenced formal parameter
|
||||||
4127, # conditional expression is constant
|
4127, # conditional expression is constant
|
||||||
|
4189, # local variable is initialized but not referenced
|
||||||
4244, # 'initializing' : conversion from 'double' to 'size_t', possible loss of data
|
4244, # 'initializing' : conversion from 'double' to 'size_t', possible loss of data
|
||||||
4245, # 'initializing' : conversion from 'int' to 'const net::QuicVersionTag', signed/unsigned mismatch
|
4245, # 'initializing' : conversion from 'int' to 'const net::QuicVersionTag', signed/unsigned mismatch
|
||||||
4251, # class 'std::xx' needs to have dll-interface.
|
4251, # class 'std::xx' needs to have dll-interface.
|
||||||
|
|
|
@ -9,6 +9,8 @@
|
||||||
#include "browser/media/media_capture_devices_dispatcher.h"
|
#include "browser/media/media_capture_devices_dispatcher.h"
|
||||||
#include "browser/notification_presenter.h"
|
#include "browser/notification_presenter.h"
|
||||||
|
|
||||||
|
#include "base/base_paths.h"
|
||||||
|
#include "base/path_service.h"
|
||||||
#include "content/public/common/url_constants.h"
|
#include "content/public/common/url_constants.h"
|
||||||
|
|
||||||
namespace brightray {
|
namespace brightray {
|
||||||
|
@ -66,24 +68,12 @@ net::URLRequestContextGetter* BrowserClient::CreateRequestContext(
|
||||||
|
|
||||||
void BrowserClient::ShowDesktopNotification(
|
void BrowserClient::ShowDesktopNotification(
|
||||||
const content::ShowDesktopNotificationHostMsgParams& params,
|
const content::ShowDesktopNotificationHostMsgParams& params,
|
||||||
int render_process_id,
|
content::RenderFrameHost* render_frame_host,
|
||||||
int render_view_id,
|
content::DesktopNotificationDelegate* delegate,
|
||||||
bool worker) {
|
base::Closure* cancel_callback) {
|
||||||
auto presenter = notification_presenter();
|
auto presenter = notification_presenter();
|
||||||
if (!presenter)
|
if (presenter)
|
||||||
return;
|
presenter->ShowNotification(params, delegate, cancel_callback);
|
||||||
presenter->ShowNotification(params, render_process_id, render_view_id);
|
|
||||||
}
|
|
||||||
|
|
||||||
void BrowserClient::CancelDesktopNotification(
|
|
||||||
int render_process_id,
|
|
||||||
int render_view_id,
|
|
||||||
int notification_id) {
|
|
||||||
auto presenter = notification_presenter();
|
|
||||||
if (!presenter)
|
|
||||||
return;
|
|
||||||
presenter->CancelNotification(
|
|
||||||
render_process_id, render_view_id, notification_id);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
content::MediaObserver* BrowserClient::GetMediaObserver() {
|
content::MediaObserver* BrowserClient::GetMediaObserver() {
|
||||||
|
@ -96,4 +86,13 @@ void BrowserClient::GetAdditionalAllowedSchemesForFileSystem(
|
||||||
additional_schemes->push_back(content::kChromeUIScheme);
|
additional_schemes->push_back(content::kChromeUIScheme);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
base::FilePath BrowserClient::GetDefaultDownloadDirectory() {
|
||||||
|
// ~/Downloads
|
||||||
|
base::FilePath path;
|
||||||
|
if (PathService::Get(base::DIR_HOME, &path))
|
||||||
|
path = path.Append(FILE_PATH_LITERAL("Downloads"));
|
||||||
|
|
||||||
|
return path;
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace brightray
|
} // namespace brightray
|
||||||
|
|
|
@ -43,16 +43,13 @@ class BrowserClient : public content::ContentBrowserClient {
|
||||||
const content::MainFunctionParams&) OVERRIDE;
|
const content::MainFunctionParams&) OVERRIDE;
|
||||||
virtual void ShowDesktopNotification(
|
virtual void ShowDesktopNotification(
|
||||||
const content::ShowDesktopNotificationHostMsgParams&,
|
const content::ShowDesktopNotificationHostMsgParams&,
|
||||||
int render_process_id,
|
content::RenderFrameHost* render_frame_host,
|
||||||
int render_view_id,
|
content::DesktopNotificationDelegate* delegate,
|
||||||
bool worker) OVERRIDE;
|
base::Closure* cancel_callback) OVERRIDE;
|
||||||
virtual void CancelDesktopNotification(
|
|
||||||
int render_process_id,
|
|
||||||
int render_view_id,
|
|
||||||
int notification_id) OVERRIDE;
|
|
||||||
virtual content::MediaObserver* GetMediaObserver() OVERRIDE;
|
virtual content::MediaObserver* GetMediaObserver() OVERRIDE;
|
||||||
virtual void GetAdditionalAllowedSchemesForFileSystem(
|
virtual void GetAdditionalAllowedSchemesForFileSystem(
|
||||||
std::vector<std::string>* additional_schemes) OVERRIDE;
|
std::vector<std::string>* additional_schemes) OVERRIDE;
|
||||||
|
virtual base::FilePath GetDefaultDownloadDirectory() OVERRIDE;
|
||||||
|
|
||||||
BrowserMainParts* browser_main_parts_;
|
BrowserMainParts* browser_main_parts_;
|
||||||
scoped_ptr<NotificationPresenter> notification_presenter_;
|
scoped_ptr<NotificationPresenter> notification_presenter_;
|
||||||
|
|
|
@ -204,4 +204,8 @@ quota::SpecialStoragePolicy* BrowserContext::GetSpecialStoragePolicy() {
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
content::BrowserPluginGuestManagerDelegate* BrowserContext::GetGuestManagerDelegate() {
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace brightray
|
} // namespace brightray
|
||||||
|
|
|
@ -80,6 +80,8 @@ class BrowserContext : public content::BrowserContext {
|
||||||
GetDownloadManagerDelegate() OVERRIDE;
|
GetDownloadManagerDelegate() OVERRIDE;
|
||||||
virtual content::GeolocationPermissionContext*
|
virtual content::GeolocationPermissionContext*
|
||||||
GetGeolocationPermissionContext() OVERRIDE;
|
GetGeolocationPermissionContext() OVERRIDE;
|
||||||
|
virtual content::BrowserPluginGuestManagerDelegate*
|
||||||
|
GetGuestManagerDelegate() OVERRIDE;
|
||||||
virtual quota::SpecialStoragePolicy*
|
virtual quota::SpecialStoragePolicy*
|
||||||
GetSpecialStoragePolicy() OVERRIDE;
|
GetSpecialStoragePolicy() OVERRIDE;
|
||||||
|
|
||||||
|
|
|
@ -9,7 +9,6 @@
|
||||||
#include "net/proxy/proxy_resolver_v8.h"
|
#include "net/proxy/proxy_resolver_v8.h"
|
||||||
|
|
||||||
#if defined(USE_AURA)
|
#if defined(USE_AURA)
|
||||||
#include "ui/aura/env.h"
|
|
||||||
#include "ui/gfx/screen.h"
|
#include "ui/gfx/screen.h"
|
||||||
#include "ui/views/widget/desktop_aura/desktop_screen.h"
|
#include "ui/views/widget/desktop_aura/desktop_screen.h"
|
||||||
#endif
|
#endif
|
||||||
|
@ -61,6 +60,8 @@ void BrowserMainParts::PreEarlyInitialization() {
|
||||||
#if defined(USE_AURA) && defined(USE_X11)
|
#if defined(USE_AURA) && defined(USE_X11)
|
||||||
views::LinuxUI::SetInstance(BuildGtk2UI());
|
views::LinuxUI::SetInstance(BuildGtk2UI());
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
InitProxyResolverV8();
|
||||||
}
|
}
|
||||||
|
|
||||||
void BrowserMainParts::ToolkitInitialized() {
|
void BrowserMainParts::ToolkitInitialized() {
|
||||||
|
@ -97,19 +98,14 @@ void BrowserMainParts::PreMainMessageLoopRun() {
|
||||||
|
|
||||||
void BrowserMainParts::PostMainMessageLoopRun() {
|
void BrowserMainParts::PostMainMessageLoopRun() {
|
||||||
browser_context_.reset();
|
browser_context_.reset();
|
||||||
#if defined(USE_AURA)
|
|
||||||
aura::Env::DeleteInstance();
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int BrowserMainParts::PreCreateThreads() {
|
int BrowserMainParts::PreCreateThreads() {
|
||||||
#if defined(USE_AURA)
|
#if defined(USE_AURA)
|
||||||
aura::Env::CreateInstance();
|
|
||||||
gfx::Screen::SetScreenInstance(gfx::SCREEN_TYPE_NATIVE,
|
gfx::Screen::SetScreenInstance(gfx::SCREEN_TYPE_NATIVE,
|
||||||
views::CreateDesktopScreen());
|
views::CreateDesktopScreen());
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
InitProxyResolverV8();
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -118,11 +114,7 @@ BrowserContext* BrowserMainParts::CreateBrowserContext() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void BrowserMainParts::InitProxyResolverV8() {
|
void BrowserMainParts::InitProxyResolverV8() {
|
||||||
#if defined(OS_WIN)
|
net::ProxyResolverV8::EnsureIsolateCreated();
|
||||||
net::ProxyResolverV8::CreateIsolate();
|
|
||||||
#else
|
|
||||||
net::ProxyResolverV8::RememberDefaultIsolate();
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace brightray
|
} // namespace brightray
|
||||||
|
|
|
@ -2,18 +2,11 @@
|
||||||
|
|
||||||
#include "browser/inspectable_web_contents_impl.h"
|
#include "browser/inspectable_web_contents_impl.h"
|
||||||
|
|
||||||
#include "content/public/browser/web_contents_view.h"
|
|
||||||
|
|
||||||
namespace brightray {
|
namespace brightray {
|
||||||
|
|
||||||
InspectableWebContents* InspectableWebContents::Create(
|
InspectableWebContents* InspectableWebContents::Create(
|
||||||
const content::WebContents::CreateParams& create_params) {
|
const content::WebContents::CreateParams& create_params) {
|
||||||
auto contents = content::WebContents::Create(create_params);
|
auto contents = content::WebContents::Create(create_params);
|
||||||
#if defined(OS_MACOSX)
|
|
||||||
// Work around http://crbug.com/279472.
|
|
||||||
contents->GetView()->SetAllowOverlappingViews(true);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
return Create(contents);
|
return Create(contents);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -21,7 +21,6 @@
|
||||||
#include "content/public/browser/devtools_client_host.h"
|
#include "content/public/browser/devtools_client_host.h"
|
||||||
#include "content/public/browser/devtools_http_handler.h"
|
#include "content/public/browser/devtools_http_handler.h"
|
||||||
#include "content/public/browser/devtools_manager.h"
|
#include "content/public/browser/devtools_manager.h"
|
||||||
#include "content/public/browser/web_contents_view.h"
|
|
||||||
#include "content/public/browser/render_frame_host.h"
|
#include "content/public/browser/render_frame_host.h"
|
||||||
#include "content/public/browser/render_view_host.h"
|
#include "content/public/browser/render_view_host.h"
|
||||||
|
|
||||||
|
@ -152,7 +151,7 @@ void InspectableWebContentsImpl::CloseDevTools() {
|
||||||
if (devtools_web_contents_) {
|
if (devtools_web_contents_) {
|
||||||
view_->CloseDevTools();
|
view_->CloseDevTools();
|
||||||
devtools_web_contents_.reset();
|
devtools_web_contents_.reset();
|
||||||
web_contents_->GetView()->Focus();
|
web_contents_->Focus();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -176,7 +175,7 @@ void InspectableWebContentsImpl::ActivateWindow() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void InspectableWebContentsImpl::CloseWindow() {
|
void InspectableWebContentsImpl::CloseWindow() {
|
||||||
devtools_web_contents()->GetMainFrame()->DispatchBeforeUnload(false);
|
devtools_web_contents()->DispatchBeforeUnload(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void InspectableWebContentsImpl::SetContentsResizingStrategy(
|
void InspectableWebContentsImpl::SetContentsResizingStrategy(
|
||||||
|
@ -289,7 +288,7 @@ void InspectableWebContentsImpl::DidFinishLoad(int64 frame_id,
|
||||||
view_->ShowDevTools();
|
view_->ShowDevTools();
|
||||||
}
|
}
|
||||||
|
|
||||||
void InspectableWebContentsImpl::WebContentsDestroyed(content::WebContents*) {
|
void InspectableWebContentsImpl::WebContentsDestroyed() {
|
||||||
content::DevToolsManager::GetInstance()->ClientHostClosing(
|
content::DevToolsManager::GetInstance()->ClientHostClosing(
|
||||||
frontend_host_.get());
|
frontend_host_.get());
|
||||||
Observe(nullptr);
|
Observe(nullptr);
|
||||||
|
|
|
@ -103,7 +103,7 @@ class InspectableWebContentsImpl :
|
||||||
const GURL& validated_url,
|
const GURL& validated_url,
|
||||||
bool is_main_frame,
|
bool is_main_frame,
|
||||||
content::RenderViewHost*) OVERRIDE;
|
content::RenderViewHost*) OVERRIDE;
|
||||||
virtual void WebContentsDestroyed(content::WebContents*) OVERRIDE;
|
virtual void WebContentsDestroyed() OVERRIDE;
|
||||||
|
|
||||||
// content::WebContentsDelegate
|
// content::WebContentsDelegate
|
||||||
|
|
||||||
|
|
|
@ -5,8 +5,6 @@
|
||||||
#include "browser/inspectable_web_contents.h"
|
#include "browser/inspectable_web_contents.h"
|
||||||
#import "browser/mac/bry_inspectable_web_contents_view.h"
|
#import "browser/mac/bry_inspectable_web_contents_view.h"
|
||||||
|
|
||||||
#include "content/public/browser/web_contents_view.h"
|
|
||||||
|
|
||||||
namespace brightray {
|
namespace brightray {
|
||||||
|
|
||||||
InspectableWebContentsView* CreateInspectableContentsView(InspectableWebContentsImpl* inspectable_web_contents) {
|
InspectableWebContentsView* CreateInspectableContentsView(InspectableWebContentsImpl* inspectable_web_contents) {
|
||||||
|
|
|
@ -3,13 +3,12 @@
|
||||||
// Use of this source code is governed by a BSD-style license that can be
|
// Use of this source code is governed by a BSD-style license that can be
|
||||||
// found in the LICENSE-CHROMIUM file.
|
// found in the LICENSE-CHROMIUM file.
|
||||||
|
|
||||||
#include <libnotify/notify.h>
|
|
||||||
|
|
||||||
#include "browser/linux/notification_presenter_linux.h"
|
#include "browser/linux/notification_presenter_linux.h"
|
||||||
|
|
||||||
#include "base/strings/stringprintf.h"
|
#include "base/bind.h"
|
||||||
|
#include "base/logging.h"
|
||||||
#include "base/strings/utf_string_conversions.h"
|
#include "base/strings/utf_string_conversions.h"
|
||||||
#include "content/public/browser/render_view_host.h"
|
#include "content/public/browser/desktop_notification_delegate.h"
|
||||||
#include "content/public/common/show_desktop_notification_params.h"
|
#include "content/public/common/show_desktop_notification_params.h"
|
||||||
#include "common/application_info.h"
|
#include "common/application_info.h"
|
||||||
|
|
||||||
|
@ -17,13 +16,7 @@ namespace brightray {
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
const char *kRenderProcessIDKey = "RenderProcessID";
|
void log_and_clear_error(GError* error, const char* context) {
|
||||||
const char *kRenderViewIDKey = "RenderViewID";
|
|
||||||
const char *kNotificationIDKey = "NotificationID";
|
|
||||||
|
|
||||||
void log_and_clear_error(GError *error, const char *context) {
|
|
||||||
if (!error) return;
|
|
||||||
|
|
||||||
LOG(ERROR) << context
|
LOG(ERROR) << context
|
||||||
<< ": domain=" << error->domain
|
<< ": domain=" << error->domain
|
||||||
<< " code=" << error->code
|
<< " code=" << error->code
|
||||||
|
@ -31,38 +24,15 @@ void log_and_clear_error(GError *error, const char *context) {
|
||||||
g_error_free(error);
|
g_error_free(error);
|
||||||
}
|
}
|
||||||
|
|
||||||
int GetObjectInt(NotifyNotification *noti, const char *key) {
|
content::DesktopNotificationDelegate* GetDelegateFromNotification(
|
||||||
return GPOINTER_TO_INT(g_object_get_data(G_OBJECT(noti), key));
|
NotifyNotification* notification) {
|
||||||
}
|
return static_cast<content::DesktopNotificationDelegate*>(
|
||||||
|
g_object_get_data(G_OBJECT(notification), "delegate"));
|
||||||
void SetObjectInt(NotifyNotification *noti, const char *key, int value) {
|
|
||||||
g_object_set_data(G_OBJECT(noti), key, GINT_TO_POINTER(value));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void NotificationClosedCallback(NotifyNotification *noti, NotificationPresenterLinux *obj) {
|
|
||||||
int render_process_id = GetObjectInt(noti, kRenderProcessIDKey);
|
|
||||||
int render_view_id = GetObjectInt(noti, kRenderViewIDKey);
|
|
||||||
int notification_id = GetObjectInt(noti, kNotificationIDKey);
|
|
||||||
|
|
||||||
auto host = content::RenderViewHost::FromID(render_process_id, render_view_id);
|
|
||||||
if (host) host->DesktopNotificationPostClose(notification_id, false);
|
|
||||||
obj->RemoveNotification(noti);
|
|
||||||
}
|
|
||||||
|
|
||||||
void NotificationViewCallback(NotifyNotification *noti, const char *action,
|
|
||||||
NotificationPresenterLinux *obj) {
|
|
||||||
int render_process_id = GetObjectInt(noti, kRenderProcessIDKey);
|
|
||||||
int render_view_id = GetObjectInt(noti, kRenderViewIDKey);
|
|
||||||
int notification_id = GetObjectInt(noti, kNotificationIDKey);
|
|
||||||
|
|
||||||
auto host = content::RenderViewHost::FromID(render_process_id, render_view_id);
|
|
||||||
if (host) host->DesktopNotificationPostClick(notification_id);
|
|
||||||
obj->RemoveNotification(noti);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
|
// static
|
||||||
NotificationPresenter* NotificationPresenter::Create() {
|
NotificationPresenter* NotificationPresenter::Create() {
|
||||||
if (!notify_is_initted()) {
|
if (!notify_is_initted()) {
|
||||||
notify_init(GetApplicationName().c_str());
|
notify_init(GetApplicationName().c_str());
|
||||||
|
@ -70,79 +40,71 @@ NotificationPresenter* NotificationPresenter::Create() {
|
||||||
return new NotificationPresenterLinux;
|
return new NotificationPresenterLinux;
|
||||||
}
|
}
|
||||||
|
|
||||||
NotificationPresenterLinux::NotificationPresenterLinux() : notifications_(nullptr) { }
|
NotificationPresenterLinux::NotificationPresenterLinux()
|
||||||
|
: notifications_(nullptr) {
|
||||||
|
}
|
||||||
|
|
||||||
NotificationPresenterLinux::~NotificationPresenterLinux() {
|
NotificationPresenterLinux::~NotificationPresenterLinux() {
|
||||||
// unref any outstanding notifications, and then free the list.
|
// unref any outstanding notifications, and then free the list.
|
||||||
if (!notifications_) return;
|
if (notifications_)
|
||||||
|
g_list_free_full(notifications_, g_object_unref);
|
||||||
for (GList *p = notifications_; p != nullptr; p = p->next) {
|
|
||||||
g_object_unref(G_OBJECT(p->data));
|
|
||||||
}
|
|
||||||
g_list_free(notifications_);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void NotificationPresenterLinux::ShowNotification(
|
void NotificationPresenterLinux::ShowNotification(
|
||||||
const content::ShowDesktopNotificationHostMsgParams& params,
|
const content::ShowDesktopNotificationHostMsgParams& params,
|
||||||
int render_process_id,
|
content::DesktopNotificationDelegate* delegate,
|
||||||
int render_view_id) {
|
base::Closure* cancel_callback) {
|
||||||
std::string title = base::UTF16ToUTF8(params.title);
|
std::string title = base::UTF16ToUTF8(params.title);
|
||||||
std::string body = base::UTF16ToUTF8(params.body);
|
std::string body = base::UTF16ToUTF8(params.body);
|
||||||
NotifyNotification *noti = notify_notification_new(title.c_str(), body.c_str(), nullptr);
|
NotifyNotification* notification = notify_notification_new(title.c_str(), body.c_str(), nullptr);
|
||||||
SetObjectInt(noti, kRenderProcessIDKey, render_process_id);
|
|
||||||
SetObjectInt(noti, kRenderViewIDKey, render_view_id);
|
|
||||||
SetObjectInt(noti, kNotificationIDKey, params.notification_id);
|
|
||||||
g_signal_connect(noti, "closed",
|
|
||||||
G_CALLBACK(NotificationClosedCallback), this);
|
|
||||||
notify_notification_add_action(noti, "default", "View",
|
|
||||||
(NotifyActionCallback)NotificationViewCallback, this, nullptr);
|
|
||||||
|
|
||||||
notifications_ = g_list_append(notifications_, noti);
|
g_object_set_data(G_OBJECT(notification), "delegate", delegate);
|
||||||
|
g_signal_connect(notification, "closed", G_CALLBACK(OnNotificationClosedThunk), this);
|
||||||
|
notify_notification_add_action(notification, "default", "View", OnNotificationViewThunk, this,
|
||||||
|
nullptr);
|
||||||
|
|
||||||
GError *error = nullptr;
|
GError* error = nullptr;
|
||||||
notify_notification_show(noti, &error);
|
notify_notification_show(notification, &error);
|
||||||
|
if (error) {
|
||||||
log_and_clear_error(error, "notify_notification_show");
|
log_and_clear_error(error, "notify_notification_show");
|
||||||
|
delegate->NotificationError();
|
||||||
auto host = content::RenderViewHost::FromID(render_process_id, render_view_id);
|
|
||||||
if (!host)
|
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
host->DesktopNotificationPostDisplay(params.notification_id);
|
notifications_ = g_list_append(notifications_, notification);
|
||||||
|
delegate->NotificationDisplayed();
|
||||||
|
|
||||||
|
if (cancel_callback)
|
||||||
|
*cancel_callback = base::Bind(
|
||||||
|
&NotificationPresenterLinux::CancelNotification,
|
||||||
|
base::Unretained(this),
|
||||||
|
notification);
|
||||||
}
|
}
|
||||||
|
|
||||||
void NotificationPresenterLinux::CancelNotification(
|
void NotificationPresenterLinux::CancelNotification(NotifyNotification* notification) {
|
||||||
int render_process_id,
|
GError* error = nullptr;
|
||||||
int render_view_id,
|
notify_notification_close(notification, &error);
|
||||||
int notification_id) {
|
if (error)
|
||||||
NotifyNotification *noti = nullptr;
|
|
||||||
for (GList *p = notifications_; p != nullptr; p = p->next) {
|
|
||||||
int rpid = GetObjectInt(noti, kRenderProcessIDKey);
|
|
||||||
int rvid = GetObjectInt(noti, kRenderViewIDKey);
|
|
||||||
int nid = GetObjectInt(noti, kNotificationIDKey);
|
|
||||||
if (render_process_id == rpid && render_view_id == rvid && notification_id == nid) {
|
|
||||||
noti = reinterpret_cast<NotifyNotification*>(p->data);
|
|
||||||
notifications_ = g_list_delete_link(notifications_, p);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!noti)
|
|
||||||
return;
|
|
||||||
|
|
||||||
GError *error = nullptr;
|
|
||||||
notify_notification_close(noti, &error);
|
|
||||||
log_and_clear_error(error, "notify_notification_close");
|
log_and_clear_error(error, "notify_notification_close");
|
||||||
g_object_unref(noti);
|
|
||||||
|
|
||||||
auto host = content::RenderViewHost::FromID(render_process_id, render_view_id);
|
GetDelegateFromNotification(notification)->NotificationClosed(false);
|
||||||
if (!host)
|
DeleteNotification(notification);
|
||||||
return;
|
|
||||||
|
|
||||||
host->DesktopNotificationPostClose(notification_id, false);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void NotificationPresenterLinux::RemoveNotification(NotifyNotification *noti) {
|
void NotificationPresenterLinux::DeleteNotification(NotifyNotification* notification) {
|
||||||
notifications_ = g_list_remove(notifications_, noti);
|
notifications_ = g_list_remove(notifications_, notification);
|
||||||
g_object_unref(noti);
|
g_object_unref(notification);
|
||||||
|
}
|
||||||
|
|
||||||
|
void NotificationPresenterLinux::OnNotificationClosed(NotifyNotification* notification) {
|
||||||
|
GetDelegateFromNotification(notification)->NotificationClosed(false);
|
||||||
|
DeleteNotification(notification);
|
||||||
|
}
|
||||||
|
|
||||||
|
void NotificationPresenterLinux::OnNotificationView(
|
||||||
|
NotifyNotification* notification, char* action) {
|
||||||
|
GetDelegateFromNotification(notification)->NotificationClick();
|
||||||
|
DeleteNotification(notification);
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace brightray
|
} // namespace brightray
|
||||||
|
|
|
@ -7,10 +7,12 @@
|
||||||
#define BRIGHTRAY_BROWSER_NOTIFICATION_PRESENTER_LINUX_H_
|
#define BRIGHTRAY_BROWSER_NOTIFICATION_PRESENTER_LINUX_H_
|
||||||
|
|
||||||
#include <libnotify/notify.h>
|
#include <libnotify/notify.h>
|
||||||
|
|
||||||
#include <map>
|
#include <map>
|
||||||
|
|
||||||
#include "base/compiler_specific.h"
|
#include "base/compiler_specific.h"
|
||||||
#include "browser/notification_presenter.h"
|
#include "browser/notification_presenter.h"
|
||||||
|
#include "ui/base/glib/glib_signal.h"
|
||||||
|
|
||||||
namespace brightray {
|
namespace brightray {
|
||||||
|
|
||||||
|
@ -22,14 +24,18 @@ class NotificationPresenterLinux : public NotificationPresenter {
|
||||||
void RemoveNotification(NotifyNotification *notification);
|
void RemoveNotification(NotifyNotification *notification);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
// NotificationPresenter:
|
||||||
virtual void ShowNotification(
|
virtual void ShowNotification(
|
||||||
const content::ShowDesktopNotificationHostMsgParams&,
|
const content::ShowDesktopNotificationHostMsgParams&,
|
||||||
int render_process_id,
|
content::DesktopNotificationDelegate* delegate,
|
||||||
int render_view_id) OVERRIDE;
|
base::Closure* cancel_callback) OVERRIDE;
|
||||||
virtual void CancelNotification(
|
|
||||||
int render_process_id,
|
void CancelNotification(NotifyNotification* notification);
|
||||||
int render_view_id,
|
void DeleteNotification(NotifyNotification* notification);
|
||||||
int notification_id) OVERRIDE;
|
|
||||||
|
CHROMEG_CALLBACK_0(NotificationPresenterLinux, void, OnNotificationClosed, NotifyNotification*);
|
||||||
|
CHROMEG_CALLBACK_1(NotificationPresenterLinux, void, OnNotificationView, NotifyNotification*,
|
||||||
|
char*);
|
||||||
|
|
||||||
// A list of all open NotifyNotification objects.
|
// A list of all open NotifyNotification objects.
|
||||||
// We do lookups here both by NotifyNotification object (when the user
|
// We do lookups here both by NotifyNotification object (when the user
|
||||||
|
@ -38,7 +44,7 @@ class NotificationPresenterLinux : public NotificationPresenter {
|
||||||
// a map.
|
// a map.
|
||||||
// Entries in this list count as refs, so removal from this list should
|
// Entries in this list count as refs, so removal from this list should
|
||||||
// always go with g_object_unref().
|
// always go with g_object_unref().
|
||||||
GList *notifications_;
|
GList* notifications_;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace brightray
|
} // namespace brightray
|
||||||
|
|
|
@ -4,7 +4,6 @@
|
||||||
#include "browser/inspectable_web_contents_view_mac.h"
|
#include "browser/inspectable_web_contents_view_mac.h"
|
||||||
|
|
||||||
#include "content/public/browser/render_widget_host_view.h"
|
#include "content/public/browser/render_widget_host_view.h"
|
||||||
#include "content/public/browser/web_contents_view.h"
|
|
||||||
#import "ui/base/cocoa/underlay_opengl_hosting_window.h"
|
#import "ui/base/cocoa/underlay_opengl_hosting_window.h"
|
||||||
#include "ui/gfx/mac/scoped_ns_disable_screen_updates.h"
|
#include "ui/gfx/mac/scoped_ns_disable_screen_updates.h"
|
||||||
|
|
||||||
|
@ -22,10 +21,15 @@ using namespace brightray;
|
||||||
devtools_docked_ = NO;
|
devtools_docked_ = NO;
|
||||||
|
|
||||||
auto contents = inspectableWebContentsView_->inspectable_web_contents()->GetWebContents();
|
auto contents = inspectableWebContentsView_->inspectable_web_contents()->GetWebContents();
|
||||||
auto contentsView = contents->GetView()->GetNativeView();
|
contents->SetAllowOverlappingViews(true);
|
||||||
|
|
||||||
|
auto contentsView = contents->GetNativeView();
|
||||||
[contentsView setAutoresizingMask:NSViewWidthSizable | NSViewHeightSizable];
|
[contentsView setAutoresizingMask:NSViewWidthSizable | NSViewHeightSizable];
|
||||||
[self addSubview:contentsView];
|
[self addSubview:contentsView];
|
||||||
|
|
||||||
|
// See https://code.google.com/p/chromium/issues/detail?id=348490.
|
||||||
|
[self setWantsLayer:YES];
|
||||||
|
|
||||||
return self;
|
return self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -42,7 +46,7 @@ using namespace brightray;
|
||||||
return;
|
return;
|
||||||
|
|
||||||
auto devToolsWebContents = inspectableWebContentsView_->inspectable_web_contents()->devtools_web_contents();
|
auto devToolsWebContents = inspectableWebContentsView_->inspectable_web_contents()->devtools_web_contents();
|
||||||
auto devToolsView = devToolsWebContents->GetView()->GetNativeView();
|
auto devToolsView = devToolsWebContents->GetNativeView();
|
||||||
|
|
||||||
devtools_visible_ = visible;
|
devtools_visible_ = visible;
|
||||||
if (devtools_docked_) {
|
if (devtools_docked_) {
|
||||||
|
@ -53,7 +57,7 @@ using namespace brightray;
|
||||||
[self update];
|
[self update];
|
||||||
} else {
|
} else {
|
||||||
gfx::ScopedNSDisableScreenUpdates disabler;
|
gfx::ScopedNSDisableScreenUpdates disabler;
|
||||||
devToolsWebContents->GetView()->RemoveOverlayView();
|
devToolsWebContents->RemoveOverlayView();
|
||||||
[devToolsView removeFromSuperview];
|
[devToolsView removeFromSuperview];
|
||||||
[self adjustSubviews];
|
[self adjustSubviews];
|
||||||
}
|
}
|
||||||
|
@ -79,7 +83,7 @@ using namespace brightray;
|
||||||
devtools_docked_ = docked;
|
devtools_docked_ = docked;
|
||||||
if (!docked) {
|
if (!docked) {
|
||||||
auto devToolsWebContents = inspectableWebContentsView_->inspectable_web_contents()->devtools_web_contents();
|
auto devToolsWebContents = inspectableWebContentsView_->inspectable_web_contents()->devtools_web_contents();
|
||||||
auto devToolsView = devToolsWebContents->GetView()->GetNativeView();
|
auto devToolsView = devToolsWebContents->GetNativeView();
|
||||||
|
|
||||||
auto styleMask = NSTitledWindowMask | NSClosableWindowMask |
|
auto styleMask = NSTitledWindowMask | NSClosableWindowMask |
|
||||||
NSMiniaturizableWindowMask | NSResizableWindowMask |
|
NSMiniaturizableWindowMask | NSResizableWindowMask |
|
||||||
|
@ -119,8 +123,8 @@ using namespace brightray;
|
||||||
auto devToolsWebContents = inspectableWebContentsView_->inspectable_web_contents()->devtools_web_contents();
|
auto devToolsWebContents = inspectableWebContentsView_->inspectable_web_contents()->devtools_web_contents();
|
||||||
|
|
||||||
gfx::ScopedNSDisableScreenUpdates disabler;
|
gfx::ScopedNSDisableScreenUpdates disabler;
|
||||||
devToolsWebContents->GetView()->SetOverlayView(
|
devToolsWebContents->SetOverlayView(
|
||||||
contents->GetView(),
|
contents,
|
||||||
gfx::Point(strategy_.insets().left(), strategy_.insets().top()));
|
gfx::Point(strategy_.insets().left(), strategy_.insets().top()));
|
||||||
[self adjustSubviews];
|
[self adjustSubviews];
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,7 +1,10 @@
|
||||||
#ifndef BRIGHTRAY_BROWSER_NOTIFICATION_PRESENTER_H_
|
#ifndef BRIGHTRAY_BROWSER_NOTIFICATION_PRESENTER_H_
|
||||||
#define BRIGHTRAY_BROWSER_NOTIFICATION_PRESENTER_H_
|
#define BRIGHTRAY_BROWSER_NOTIFICATION_PRESENTER_H_
|
||||||
|
|
||||||
|
#include "base/callback_forward.h"
|
||||||
|
|
||||||
namespace content {
|
namespace content {
|
||||||
|
class DesktopNotificationDelegate;
|
||||||
struct ShowDesktopNotificationHostMsgParams;
|
struct ShowDesktopNotificationHostMsgParams;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -15,12 +18,8 @@ class NotificationPresenter {
|
||||||
|
|
||||||
virtual void ShowNotification(
|
virtual void ShowNotification(
|
||||||
const content::ShowDesktopNotificationHostMsgParams&,
|
const content::ShowDesktopNotificationHostMsgParams&,
|
||||||
int render_process_id,
|
content::DesktopNotificationDelegate* delegate,
|
||||||
int render_view_id) = 0;
|
base::Closure* cancel_callback) = 0;
|
||||||
virtual void CancelNotification(
|
|
||||||
int render_process_id,
|
|
||||||
int render_view_id,
|
|
||||||
int notification_id) = 0;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace brightray
|
} // namespace brightray
|
||||||
|
|
|
@ -22,17 +22,27 @@ class NotificationPresenterMac : public NotificationPresenter {
|
||||||
|
|
||||||
virtual void ShowNotification(
|
virtual void ShowNotification(
|
||||||
const content::ShowDesktopNotificationHostMsgParams&,
|
const content::ShowDesktopNotificationHostMsgParams&,
|
||||||
int render_process_id,
|
content::DesktopNotificationDelegate* delegate,
|
||||||
int render_view_id) OVERRIDE;
|
base::Closure* cancel_callback) OVERRIDE;
|
||||||
virtual void CancelNotification(
|
|
||||||
int render_process_id,
|
// Get the delegate accroding from the notification object.
|
||||||
int render_view_id,
|
content::DesktopNotificationDelegate* GetDelegateFromNotification(
|
||||||
int notification_id) OVERRIDE;
|
NSUserNotification* notification);
|
||||||
|
|
||||||
|
// Remove the notification object accroding to its delegate.
|
||||||
|
void RemoveNotification(content::DesktopNotificationDelegate* delegate);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
typedef std::map<std::string, base::scoped_nsobject<NSUserNotification>>
|
void CancelNotification(content::DesktopNotificationDelegate* delegate);
|
||||||
NotificationMap;
|
|
||||||
NotificationMap notification_map_;
|
// The userInfo of NSUserNotification can not store pointers (because they are
|
||||||
|
// not in property list), so we have to track them in a C++ map.
|
||||||
|
// Also notice that the delegate acts as "ID" or "Key", because it is certain
|
||||||
|
// that each notification has a unique delegate.
|
||||||
|
typedef std::map<content::DesktopNotificationDelegate*, base::scoped_nsobject<NSUserNotification>>
|
||||||
|
NotificationsMap;
|
||||||
|
NotificationsMap notifications_map_;
|
||||||
|
|
||||||
base::scoped_nsobject<BRYUserNotificationCenterDelegate> delegate_;
|
base::scoped_nsobject<BRYUserNotificationCenterDelegate> delegate_;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -5,146 +5,121 @@
|
||||||
|
|
||||||
#import "browser/notification_presenter_mac.h"
|
#import "browser/notification_presenter_mac.h"
|
||||||
|
|
||||||
#import "base/strings/stringprintf.h"
|
#include "base/bind.h"
|
||||||
#import "base/strings/sys_string_conversions.h"
|
#include "base/stl_util.h"
|
||||||
#import "content/public/browser/render_view_host.h"
|
#include "base/strings/sys_string_conversions.h"
|
||||||
#import "content/public/common/show_desktop_notification_params.h"
|
#include "content/public/browser/desktop_notification_delegate.h"
|
||||||
|
#include "content/public/common/show_desktop_notification_params.h"
|
||||||
|
|
||||||
#import <Foundation/Foundation.h>
|
#import <Foundation/Foundation.h>
|
||||||
|
|
||||||
@interface BRYUserNotificationCenterDelegate : NSObject <NSUserNotificationCenterDelegate>
|
@interface BRYUserNotificationCenterDelegate : NSObject<NSUserNotificationCenterDelegate> {
|
||||||
|
@private
|
||||||
|
brightray::NotificationPresenterMac* presenter_;
|
||||||
|
}
|
||||||
|
- (instancetype)initWithNotificationPresenter:(brightray::NotificationPresenterMac*)presenter;
|
||||||
@end
|
@end
|
||||||
|
|
||||||
namespace brightray {
|
namespace brightray {
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
NSString * const kRenderProcessIDKey = @"RenderProcessID";
|
} // namespace
|
||||||
NSString * const kRenderViewIDKey = @"RenderViewID";
|
|
||||||
NSString * const kNotificationIDKey = @"NotificationID";
|
|
||||||
|
|
||||||
struct NotificationID {
|
|
||||||
NotificationID(
|
|
||||||
int render_process_id,
|
|
||||||
int render_view_id,
|
|
||||||
int notification_id)
|
|
||||||
: render_process_id(render_process_id),
|
|
||||||
render_view_id(render_view_id),
|
|
||||||
notification_id(notification_id) {
|
|
||||||
}
|
|
||||||
|
|
||||||
NotificationID(NSUserNotification* notification)
|
|
||||||
: render_process_id([[notification.userInfo objectForKey:kRenderProcessIDKey] intValue]),
|
|
||||||
render_view_id([[notification.userInfo objectForKey:kRenderViewIDKey] intValue]),
|
|
||||||
notification_id([[notification.userInfo objectForKey:kNotificationIDKey] intValue]) {
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string GetID() {
|
|
||||||
return base::StringPrintf("%d:%d:%d", render_process_id, render_view_id, notification_id);
|
|
||||||
}
|
|
||||||
|
|
||||||
NSDictionary* GetUserInfo() {
|
|
||||||
return @{
|
|
||||||
kRenderProcessIDKey: @(render_process_id),
|
|
||||||
kRenderViewIDKey: @(render_view_id),
|
|
||||||
kNotificationIDKey: @(notification_id),
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
int render_process_id;
|
|
||||||
int render_view_id;
|
|
||||||
int notification_id;
|
|
||||||
};
|
|
||||||
|
|
||||||
base::scoped_nsobject<NSUserNotification> CreateUserNotification(
|
|
||||||
const content::ShowDesktopNotificationHostMsgParams& params,
|
|
||||||
int render_process_id,
|
|
||||||
int render_view_id) {
|
|
||||||
auto notification = [[NSUserNotification alloc] init];
|
|
||||||
notification.title = base::SysUTF16ToNSString(params.title);
|
|
||||||
notification.informativeText = base::SysUTF16ToNSString(params.body);
|
|
||||||
notification.userInfo = NotificationID(render_process_id, render_view_id, params.notification_id).GetUserInfo();
|
|
||||||
|
|
||||||
return base::scoped_nsobject<NSUserNotification>(notification);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
NotificationPresenter* NotificationPresenter::Create() {
|
NotificationPresenter* NotificationPresenter::Create() {
|
||||||
return new NotificationPresenterMac;
|
return new NotificationPresenterMac;
|
||||||
}
|
}
|
||||||
|
|
||||||
NotificationPresenterMac::NotificationPresenterMac()
|
NotificationPresenterMac::NotificationPresenterMac()
|
||||||
: delegate_([[BRYUserNotificationCenterDelegate alloc] init]) {
|
: delegate_([[BRYUserNotificationCenterDelegate alloc] initWithNotificationPresenter:this]) {
|
||||||
NSUserNotificationCenter.defaultUserNotificationCenter.delegate = delegate_;
|
NSUserNotificationCenter.defaultUserNotificationCenter.delegate = delegate_;
|
||||||
}
|
}
|
||||||
|
|
||||||
NotificationPresenterMac::~NotificationPresenterMac() {
|
NotificationPresenterMac::~NotificationPresenterMac() {
|
||||||
|
NSUserNotificationCenter.defaultUserNotificationCenter.delegate = nil;
|
||||||
}
|
}
|
||||||
|
|
||||||
void NotificationPresenterMac::ShowNotification(
|
void NotificationPresenterMac::ShowNotification(
|
||||||
const content::ShowDesktopNotificationHostMsgParams& params,
|
const content::ShowDesktopNotificationHostMsgParams& params,
|
||||||
int render_process_id,
|
content::DesktopNotificationDelegate* delegate,
|
||||||
int render_view_id) {
|
base::Closure* cancel_callback) {
|
||||||
auto notification = CreateUserNotification(params, render_process_id, render_view_id);
|
auto notification = [[NSUserNotification alloc] init];
|
||||||
notification_map_.insert(std::make_pair(NotificationID(notification).GetID(), notification));
|
notification.title = base::SysUTF16ToNSString(params.title);
|
||||||
|
notification.informativeText = base::SysUTF16ToNSString(params.body);
|
||||||
|
|
||||||
|
notifications_map_[delegate].reset(notification);
|
||||||
[NSUserNotificationCenter.defaultUserNotificationCenter deliverNotification:notification];
|
[NSUserNotificationCenter.defaultUserNotificationCenter deliverNotification:notification];
|
||||||
|
|
||||||
|
if (cancel_callback)
|
||||||
|
*cancel_callback = base::Bind(
|
||||||
|
&NotificationPresenterMac::CancelNotification,
|
||||||
|
base::Unretained(this),
|
||||||
|
delegate);
|
||||||
}
|
}
|
||||||
|
|
||||||
void NotificationPresenterMac::CancelNotification(
|
content::DesktopNotificationDelegate* NotificationPresenterMac::GetDelegateFromNotification(
|
||||||
int render_process_id,
|
NSUserNotification* notification) {
|
||||||
int render_view_id,
|
for (NotificationsMap::const_iterator it = notifications_map_.begin();
|
||||||
int notification_id) {
|
it != notifications_map_.end(); ++it)
|
||||||
auto found = notification_map_.find(NotificationID(render_process_id, render_view_id, notification_id).GetID());
|
if ([it->second isEqual:notification])
|
||||||
if (found == notification_map_.end())
|
return it->first;
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
void NotificationPresenterMac::RemoveNotification(content::DesktopNotificationDelegate* delegate) {
|
||||||
|
if (ContainsKey(notifications_map_, delegate))
|
||||||
|
notifications_map_.erase(delegate);
|
||||||
|
}
|
||||||
|
|
||||||
|
void NotificationPresenterMac::CancelNotification(content::DesktopNotificationDelegate* delegate) {
|
||||||
|
if (!ContainsKey(notifications_map_, delegate))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
auto notification = found->second;
|
|
||||||
|
|
||||||
notification_map_.erase(found);
|
|
||||||
|
|
||||||
// Notifications in -deliveredNotifications aren't the same objects we passed to
|
// Notifications in -deliveredNotifications aren't the same objects we passed to
|
||||||
// -deliverNotification:, but they will respond YES to -isEqual:.
|
// -deliverNotification:, but they will respond YES to -isEqual:.
|
||||||
|
auto notification = notifications_map_[delegate];
|
||||||
auto center = NSUserNotificationCenter.defaultUserNotificationCenter;
|
auto center = NSUserNotificationCenter.defaultUserNotificationCenter;
|
||||||
for (NSUserNotification* deliveredNotification in center.deliveredNotifications) {
|
for (NSUserNotification* deliveredNotification in center.deliveredNotifications)
|
||||||
if (![notification isEqual:deliveredNotification])
|
if ([notification isEqual:deliveredNotification]) {
|
||||||
continue;
|
|
||||||
[center removeDeliveredNotification:deliveredNotification];
|
[center removeDeliveredNotification:deliveredNotification];
|
||||||
|
delegate->NotificationClosed(false);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
NotificationID ID(notification);
|
RemoveNotification(delegate);
|
||||||
auto host = content::RenderViewHost::FromID(ID.render_process_id, ID.render_view_id);
|
|
||||||
if (!host)
|
|
||||||
return;
|
|
||||||
|
|
||||||
host->DesktopNotificationPostClose(ID.notification_id, false);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
} // namespace brightray
|
||||||
|
|
||||||
@implementation BRYUserNotificationCenterDelegate
|
@implementation BRYUserNotificationCenterDelegate
|
||||||
|
|
||||||
- (void)userNotificationCenter:(NSUserNotificationCenter *)center didDeliverNotification:(NSUserNotification *)notification {
|
- (instancetype)initWithNotificationPresenter:(brightray::NotificationPresenterMac*)presenter {
|
||||||
brightray::NotificationID ID(notification);
|
self = [super init];
|
||||||
|
if (!self)
|
||||||
|
return nil;
|
||||||
|
|
||||||
auto host = content::RenderViewHost::FromID(ID.render_process_id, ID.render_view_id);
|
presenter_ = presenter;
|
||||||
if (!host)
|
return self;
|
||||||
return;
|
|
||||||
|
|
||||||
host->DesktopNotificationPostDisplay(ID.notification_id);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)userNotificationCenter:(NSUserNotificationCenter *)center didActivateNotification:(NSUserNotification *)notification {
|
- (void)userNotificationCenter:(NSUserNotificationCenter*)center
|
||||||
brightray::NotificationID ID(notification);
|
didDeliverNotification:(NSUserNotification*)notification {
|
||||||
|
auto delegate = presenter_->GetDelegateFromNotification(notification);
|
||||||
auto host = content::RenderViewHost::FromID(ID.render_process_id, ID.render_view_id);
|
if (delegate)
|
||||||
if (!host)
|
delegate->NotificationDisplayed();
|
||||||
return;
|
|
||||||
|
|
||||||
host->DesktopNotificationPostClick(ID.notification_id);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
- (BOOL)userNotificationCenter:(NSUserNotificationCenter *)center shouldPresentNotification:(NSUserNotification *)notification {
|
- (void)userNotificationCenter:(NSUserNotificationCenter*)center
|
||||||
|
didActivateNotification:(NSUserNotification *)notification {
|
||||||
|
auto delegate = presenter_->GetDelegateFromNotification(notification);
|
||||||
|
if (delegate) {
|
||||||
|
delegate->NotificationClick();
|
||||||
|
presenter_->RemoveNotification(delegate);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
- (BOOL)userNotificationCenter:(NSUserNotificationCenter*)center
|
||||||
|
shouldPresentNotification:(NSUserNotification*)notification {
|
||||||
// Display notifications even if the app is active.
|
// Display notifications even if the app is active.
|
||||||
return YES;
|
return YES;
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,7 +3,6 @@
|
||||||
#include "browser/inspectable_web_contents_impl.h"
|
#include "browser/inspectable_web_contents_impl.h"
|
||||||
|
|
||||||
#include "base/strings/utf_string_conversions.h"
|
#include "base/strings/utf_string_conversions.h"
|
||||||
#include "content/public/browser/web_contents_view.h"
|
|
||||||
#include "ui/views/controls/webview/webview.h"
|
#include "ui/views/controls/webview/webview.h"
|
||||||
#include "ui/views/widget/widget.h"
|
#include "ui/views/widget/widget.h"
|
||||||
#include "ui/views/widget/widget_delegate.h"
|
#include "ui/views/widget/widget_delegate.h"
|
||||||
|
|
2
brightray/vendor/libchromiumcontent
vendored
2
brightray/vendor/libchromiumcontent
vendored
|
@ -1 +1 @@
|
||||||
Subproject commit 4b4bcec11a02d1c7981562cf0b8a4670c338992b
|
Subproject commit a88222442d2a85345d9a208c23456956c208571d
|
Loading…
Reference in a new issue