electron/shell/browser/api/electron_api_notification.cc

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

258 lines
7.6 KiB
C++
Raw Normal View History

// Copyright (c) 2014 GitHub, Inc.
// Use of this source code is governed by the MIT license that can be
// found in the LICENSE file.
#include "shell/browser/api/electron_api_notification.h"
#include "base/uuid.h"
2020-03-31 18:42:32 +00:00
#include "gin/handle.h"
#include "shell/browser/api/electron_api_menu.h"
#include "shell/browser/browser.h"
#include "shell/browser/electron_browser_client.h"
#include "shell/common/gin_converters/image_converter.h"
#include "shell/common/gin_helper/dictionary.h"
chore: more iwyu (#43063) * chore: iwyu shell/browser/electron_pdf_document_helper_client.h * chore: iwyu shell/browser/hid/electron_hid_delegate.h * chore: iwyu content/public/browser/web_contents.h * chore: iwyu shell/browser/usb/electron_usb_delegate.h * chore: iwyu shell/browser/browser_observer.h * chore: iwyu shell/browser/bluetooth/electron_bluetooth_delegate.h * chore: iwyu shell/browser/serial/electron_serial_delegate.h * chore: iwyu shell/browser/api/frame_subscriber.h * chore: iwyu mojo/public/cpp/bindings/ * chore: iwyu components/ * chore: iwyu extensions/ * chore: iwyu shell/common/gin_helper/ * chore: iwyu v8/ * chore: iwyu base/containers/linked_list.h * chore: iwyu shell/browser/native_window.h * chore: iwyu shell/browser/api/electron_api_base_window.h * chore: iwyu shell/common/node_includes.h * chore: iwyu gin/handle.h * chore: iwyu base/functional/callback.h * chore: iwyu ui/gfx/ * chore: iwyu content/public/browser/render_frame_host.h * fix: mac * fix: mac * fix: win * chore: iwyu base/files/file_path.h * chore: iwyu base/unguessable_token.h * chore: iwyu ui/display/screen.h * chore: iwyu chrome/browser/predictors/preconnect_manager.h * chore: iwyu base/observer_list_types.h * chore: iwyu content/public/browser/web_contents.h * chore: iwyu chrome/browser/devtools/devtools_eye_dropper.h * chore: iwyu shell/browser/ui/inspectable_web_contents.h * chore: iwyu content/public/browser/keyboard_event_processing_result.h * chore: iwyu net/cookies/canonical_cookie.h * chore: iwyu net/base/address_list.h * chore: iwyu net/cert/x509_certificate.h * chore: iwyu net/cookies/cookie_change_dispatcher.h * chore: iwyu net/dns/public/host_resolver_results.h * fix: mac * Revert "chore: iwyu net/cert/x509_certificate.h" This reverts commit 002896f71146e90f1e29e090a1d6eede48cee11e.
2024-07-29 17:42:57 +00:00
#include "shell/common/gin_helper/error_thrower.h"
#include "shell/common/gin_helper/object_template_builder.h"
#include "shell/common/node_includes.h"
2017-05-29 11:18:18 +00:00
#include "url/gurl.h"
namespace gin {
2018-04-18 01:55:30 +00:00
template <>
struct Converter<electron::NotificationAction> {
2018-04-18 01:55:30 +00:00
static bool FromV8(v8::Isolate* isolate,
v8::Local<v8::Value> val,
electron::NotificationAction* out) {
gin::Dictionary dict(isolate);
if (!ConvertFromV8(isolate, val, &dict))
return false;
if (!dict.Get("type", &(out->type))) {
return false;
}
2017-06-23 11:04:39 +00:00
dict.Get("text", &(out->text));
return true;
}
static v8::Local<v8::Value> ToV8(v8::Isolate* isolate,
electron::NotificationAction val) {
auto dict = gin::Dictionary::CreateEmpty(isolate);
2017-06-23 11:04:39 +00:00
dict.Set("text", val.text);
dict.Set("type", val.type);
return ConvertToV8(isolate, dict);
}
};
} // namespace gin
2022-06-29 19:55:47 +00:00
namespace electron::api {
2020-03-31 18:42:32 +00:00
gin::WrapperInfo Notification::kWrapperInfo = {gin::kEmbedderNativeGin};
2020-03-31 18:42:32 +00:00
Notification::Notification(gin::Arguments* args) {
presenter_ = static_cast<ElectronBrowserClient*>(ElectronBrowserClient::Get())
->GetNotificationPresenter();
2017-05-31 07:17:29 +00:00
gin::Dictionary opts(nullptr);
if (args->GetNext(&opts)) {
opts.Get("title", &title_);
opts.Get("subtitle", &subtitle_);
opts.Get("body", &body_);
opts.Get("icon", &icon_);
opts.Get("silent", &silent_);
opts.Get("replyPlaceholder", &reply_placeholder_);
opts.Get("urgency", &urgency_);
opts.Get("hasReply", &has_reply_);
opts.Get("timeoutType", &timeout_type_);
opts.Get("actions", &actions_);
2017-08-18 00:28:14 +00:00
opts.Get("sound", &sound_);
2018-01-16 19:26:41 +00:00
opts.Get("closeButtonText", &close_button_text_);
opts.Get("toastXml", &toast_xml_);
}
}
2017-05-30 09:06:51 +00:00
Notification::~Notification() {
2017-05-31 07:17:29 +00:00
if (notification_)
notification_->set_delegate(nullptr);
2017-05-30 09:06:51 +00:00
}
// static
2020-03-31 18:42:32 +00:00
gin::Handle<Notification> Notification::New(gin_helper::ErrorThrower thrower,
gin::Arguments* args) {
if (!Browser::Get()->is_ready()) {
thrower.ThrowError("Cannot create Notification before app is ready");
2020-03-31 18:42:32 +00:00
return gin::Handle<Notification>();
}
2020-03-31 18:42:32 +00:00
return gin::CreateHandle(thrower.isolate(), new Notification(args));
}
// Setters
void Notification::SetTitle(const std::u16string& new_title) {
2017-04-24 03:07:42 +00:00
title_ = new_title;
}
2017-05-31 07:17:29 +00:00
void Notification::SetSubtitle(const std::u16string& new_subtitle) {
subtitle_ = new_subtitle;
}
void Notification::SetBody(const std::u16string& new_body) {
2017-04-24 03:07:42 +00:00
body_ = new_body;
}
2017-05-31 07:17:29 +00:00
2017-04-24 03:07:42 +00:00
void Notification::SetSilent(bool new_silent) {
silent_ = new_silent;
}
2017-05-31 07:17:29 +00:00
2018-01-22 18:48:12 +00:00
void Notification::SetHasReply(bool new_has_reply) {
has_reply_ = new_has_reply;
}
void Notification::SetTimeoutType(const std::u16string& new_timeout_type) {
timeout_type_ = new_timeout_type;
}
void Notification::SetReplyPlaceholder(const std::u16string& new_placeholder) {
2017-05-30 09:12:36 +00:00
reply_placeholder_ = new_placeholder;
2017-04-24 03:07:42 +00:00
}
2017-05-31 07:17:29 +00:00
void Notification::SetSound(const std::u16string& new_sound) {
2018-01-22 18:48:12 +00:00
sound_ = new_sound;
2017-04-24 03:07:42 +00:00
}
void Notification::SetUrgency(const std::u16string& new_urgency) {
urgency_ = new_urgency;
}
void Notification::SetActions(
const std::vector<electron::NotificationAction>& actions) {
actions_ = actions;
}
void Notification::SetCloseButtonText(const std::u16string& text) {
2018-01-16 19:26:41 +00:00
close_button_text_ = text;
}
void Notification::SetToastXml(const std::u16string& new_toast_xml) {
toast_xml_ = new_toast_xml;
}
void Notification::NotificationAction(int index) {
Emit("action", index);
}
2017-05-30 09:06:51 +00:00
void Notification::NotificationClick() {
Emit("click");
}
2017-05-31 07:17:29 +00:00
void Notification::NotificationReplied(const std::string& reply) {
Emit("reply", reply);
}
2017-05-30 09:06:51 +00:00
void Notification::NotificationDisplayed() {
Emit("show");
}
void Notification::NotificationFailed(const std::string& error) {
Emit("failed", error);
}
2018-04-18 01:55:30 +00:00
void Notification::NotificationDestroyed() {}
2017-05-29 11:33:43 +00:00
2017-05-31 07:17:29 +00:00
void Notification::NotificationClosed() {
Emit("close");
2017-05-31 07:17:29 +00:00
}
2017-05-29 11:18:18 +00:00
void Notification::Close() {
if (notification_) {
if (notification_->is_dismissed()) {
notification_->Remove();
} else {
notification_->Dismiss();
}
notification_->set_delegate(nullptr);
notification_.reset();
}
}
2017-05-29 11:18:18 +00:00
// Showing notifications
void Notification::Show() {
Close();
2017-05-30 09:06:51 +00:00
if (presenter_) {
notification_ = presenter_->CreateNotification(
this, base::Uuid::GenerateRandomV4().AsLowercaseString());
2017-05-30 09:06:51 +00:00
if (notification_) {
electron::NotificationOptions options;
2017-06-24 11:03:27 +00:00
options.title = title_;
options.subtitle = subtitle_;
2017-06-24 11:03:27 +00:00
options.msg = body_;
options.icon_url = GURL();
options.icon = icon_.AsBitmap();
options.silent = silent_;
options.has_reply = has_reply_;
options.timeout_type = timeout_type_;
2017-06-24 11:03:27 +00:00
options.reply_placeholder = reply_placeholder_;
options.actions = actions_;
2017-08-18 00:28:14 +00:00
options.sound = sound_;
2018-01-16 19:26:41 +00:00
options.close_button_text = close_button_text_;
options.urgency = urgency_;
options.toast_xml = toast_xml_;
2017-06-24 11:03:27 +00:00
notification_->Show(options);
2017-05-30 09:06:51 +00:00
}
2017-05-29 11:18:18 +00:00
}
}
2017-05-30 10:27:24 +00:00
bool Notification::IsSupported() {
return !!static_cast<ElectronBrowserClient*>(ElectronBrowserClient::Get())
->GetNotificationPresenter();
2017-05-30 10:27:24 +00:00
}
void Notification::FillObjectTemplate(v8::Isolate* isolate,
v8::Local<v8::ObjectTemplate> templ) {
gin::ObjectTemplateBuilder(isolate, GetClassName(), templ)
.SetMethod("show", &Notification::Show)
.SetMethod("close", &Notification::Close)
.SetProperty("title", &Notification::title, &Notification::SetTitle)
.SetProperty("subtitle", &Notification::subtitle,
&Notification::SetSubtitle)
.SetProperty("body", &Notification::body, &Notification::SetBody)
.SetProperty("silent", &Notification::is_silent, &Notification::SetSilent)
.SetProperty("hasReply", &Notification::has_reply,
&Notification::SetHasReply)
.SetProperty("timeoutType", &Notification::timeout_type,
&Notification::SetTimeoutType)
.SetProperty("replyPlaceholder", &Notification::reply_placeholder,
2018-01-22 18:48:12 +00:00
&Notification::SetReplyPlaceholder)
.SetProperty("urgency", &Notification::urgency, &Notification::SetUrgency)
.SetProperty("sound", &Notification::sound, &Notification::SetSound)
.SetProperty("actions", &Notification::actions, &Notification::SetActions)
.SetProperty("closeButtonText", &Notification::close_button_text,
2020-03-31 18:42:32 +00:00
&Notification::SetCloseButtonText)
.SetProperty("toastXml", &Notification::toast_xml,
&Notification::SetToastXml)
2020-03-31 18:42:32 +00:00
.Build();
}
const char* Notification::GetTypeName() {
return GetClassName();
}
2022-06-29 19:55:47 +00:00
} // namespace electron::api
namespace {
using electron::api::Notification;
2017-04-24 03:07:42 +00:00
void Initialize(v8::Local<v8::Object> exports,
v8::Local<v8::Value> unused,
v8::Local<v8::Context> context,
void* priv) {
v8::Isolate* isolate = context->GetIsolate();
gin_helper::Dictionary dict(isolate, exports);
2020-03-31 18:42:32 +00:00
dict.Set("Notification", Notification::GetConstructor(context));
2017-05-30 10:27:24 +00:00
dict.SetMethod("isSupported", &Notification::IsSupported);
}
} // namespace
NODE_LINKED_BINDING_CONTEXT_AWARE(electron_browser_notification, Initialize)