summaryrefslogtreecommitdiff
path: root/chromium/weblayer/browser/infobar_android.cc
diff options
context:
space:
mode:
authorAllan Sandfeld Jensen <allan.jensen@qt.io>2020-10-12 14:27:29 +0200
committerAllan Sandfeld Jensen <allan.jensen@qt.io>2020-10-13 09:35:20 +0000
commitc30a6232df03e1efbd9f3b226777b07e087a1122 (patch)
treee992f45784689f373bcc38d1b79a239ebe17ee23 /chromium/weblayer/browser/infobar_android.cc
parent7b5b123ac58f58ffde0f4f6e488bcd09aa4decd3 (diff)
downloadqtwebengine-chromium-85-based.tar.gz
BASELINE: Update Chromium to 85.0.4183.14085-based
Change-Id: Iaa42f4680837c57725b1344f108c0196741f6057 Reviewed-by: Allan Sandfeld Jensen <allan.jensen@qt.io>
Diffstat (limited to 'chromium/weblayer/browser/infobar_android.cc')
-rw-r--r--chromium/weblayer/browser/infobar_android.cc91
1 files changed, 91 insertions, 0 deletions
diff --git a/chromium/weblayer/browser/infobar_android.cc b/chromium/weblayer/browser/infobar_android.cc
new file mode 100644
index 00000000000..4aa24af9285
--- /dev/null
+++ b/chromium/weblayer/browser/infobar_android.cc
@@ -0,0 +1,91 @@
+// Copyright 2020 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "weblayer/browser/infobar_android.h"
+
+#include <utility>
+
+#include "base/android/jni_android.h"
+#include "base/android/jni_string.h"
+#include "base/strings/string_util.h"
+#include "components/infobars/core/infobar.h"
+#include "components/infobars/core/infobar_delegate.h"
+#include "weblayer/browser/android/resource_mapper.h"
+#include "weblayer/browser/java/jni/InfoBar_jni.h"
+
+using base::android::JavaParamRef;
+using base::android::JavaRef;
+
+namespace weblayer {
+
+// InfoBarAndroid -------------------------------------------------------------
+
+InfoBarAndroid::InfoBarAndroid(
+ std::unique_ptr<infobars::InfoBarDelegate> delegate)
+ : infobars::InfoBar(std::move(delegate)) {}
+
+InfoBarAndroid::~InfoBarAndroid() {
+ if (!java_info_bar_.is_null()) {
+ JNIEnv* env = base::android::AttachCurrentThread();
+ Java_InfoBar_onNativeDestroyed(env, java_info_bar_);
+ }
+}
+
+void InfoBarAndroid::ReassignJavaInfoBar(InfoBarAndroid* replacement) {
+ DCHECK(replacement);
+ if (!java_info_bar_.is_null()) {
+ replacement->SetJavaInfoBar(java_info_bar_);
+ java_info_bar_.Reset();
+ }
+}
+
+void InfoBarAndroid::SetJavaInfoBar(
+ const base::android::JavaRef<jobject>& java_info_bar) {
+ DCHECK(java_info_bar_.is_null());
+ java_info_bar_.Reset(java_info_bar);
+ JNIEnv* env = base::android::AttachCurrentThread();
+ Java_InfoBar_setNativeInfoBar(env, java_info_bar,
+ reinterpret_cast<intptr_t>(this));
+}
+
+const JavaRef<jobject>& InfoBarAndroid::GetJavaInfoBar() {
+ return java_info_bar_;
+}
+
+bool InfoBarAndroid::HasSetJavaInfoBar() const {
+ return !java_info_bar_.is_null();
+}
+
+int InfoBarAndroid::GetInfoBarIdentifier(JNIEnv* env,
+ const JavaParamRef<jobject>& obj) {
+ return delegate()->GetIdentifier();
+}
+
+void InfoBarAndroid::OnButtonClicked(JNIEnv* env,
+ const JavaParamRef<jobject>& obj,
+ jint action) {
+ ProcessButton(action);
+}
+
+void InfoBarAndroid::OnCloseButtonClicked(JNIEnv* env,
+ const JavaParamRef<jobject>& obj) {
+ if (!owner())
+ return; // We're closing; don't call anything, it might access the owner.
+ delegate()->InfoBarDismissed();
+ RemoveSelf();
+}
+
+void InfoBarAndroid::CloseJavaInfoBar() {
+ if (!java_info_bar_.is_null()) {
+ JNIEnv* env = base::android::AttachCurrentThread();
+ Java_InfoBar_closeInfoBar(env, java_info_bar_);
+ java_info_bar_.Reset(nullptr);
+ }
+}
+
+int InfoBarAndroid::GetJavaIconId() {
+ return weblayer::MapToJavaDrawableId(delegate()->GetIconId());
+}
+
+} // namespace weblayer