| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "chrome/browser/ui/android/javascript_app_modal_dialog_android.h" | 5 #include "chrome/browser/ui/android/javascript_app_modal_dialog_android.h" |
| 6 | 6 |
| 7 #include "base/android/jni_android.h" | 7 #include "base/android/jni_android.h" |
| 8 #include "base/android/jni_string.h" | 8 #include "base/android/jni_string.h" |
| 9 #include "base/strings/utf_string_conversions.h" | |
| 10 | |
| 11 #include "chrome/browser/browser_process.h" | |
| 12 #include "components/app_modal_dialogs/app_modal_dialog_queue.h" | 9 #include "components/app_modal_dialogs/app_modal_dialog_queue.h" |
| 13 #include "components/app_modal_dialogs/javascript_app_modal_dialog.h" | 10 #include "components/app_modal_dialogs/javascript_app_modal_dialog.h" |
| 14 #include "content/public/browser/browser_thread.h" | 11 #include "content/public/browser/browser_thread.h" |
| 15 #include "content/public/browser/web_contents.h" | |
| 16 #include "content/public/common/javascript_message_type.h" | 12 #include "content/public/common/javascript_message_type.h" |
| 17 #include "jni/JavascriptAppModalDialog_jni.h" | 13 #include "jni/JavascriptAppModalDialog_jni.h" |
| 18 #include "ui/base/android/window_android.h" | 14 #include "ui/base/android/window_android.h" |
| 19 | 15 |
| 20 using base::android::AttachCurrentThread; | 16 using base::android::AttachCurrentThread; |
| 21 using base::android::ConvertUTF16ToJavaString; | 17 using base::android::ConvertUTF16ToJavaString; |
| 22 using base::android::ScopedJavaGlobalRef; | 18 using base::android::ScopedJavaGlobalRef; |
| 23 using base::android::ScopedJavaLocalRef; | 19 using base::android::ScopedJavaLocalRef; |
| 24 using content::BrowserThread; | |
| 25 | |
| 26 // static | |
| 27 NativeAppModalDialog* NativeAppModalDialog::CreateNativeJavaScriptPrompt( | |
| 28 JavaScriptAppModalDialog* dialog, | |
| 29 gfx::NativeWindow parent_window) { | |
| 30 return new JavascriptAppModalDialogAndroid(AttachCurrentThread(), | |
| 31 dialog, parent_window); | |
| 32 } | |
| 33 | 20 |
| 34 JavascriptAppModalDialogAndroid::JavascriptAppModalDialogAndroid( | 21 JavascriptAppModalDialogAndroid::JavascriptAppModalDialogAndroid( |
| 35 JNIEnv* env, | 22 JNIEnv* env, |
| 36 JavaScriptAppModalDialog* dialog, | 23 JavaScriptAppModalDialog* dialog, |
| 37 gfx::NativeWindow parent) | 24 gfx::NativeWindow parent) |
| 38 : dialog_(dialog), | 25 : dialog_(dialog), |
| 39 parent_jobject_weak_ref_(env, parent->GetJavaObject().obj()) { | 26 parent_jobject_weak_ref_(env, parent->GetJavaObject().obj()) { |
| 40 } | 27 } |
| 41 | 28 |
| 42 int JavascriptAppModalDialogAndroid::GetAppModalDialogButtons() const { | 29 int JavascriptAppModalDialogAndroid::GetAppModalDialogButtons() const { |
| 43 NOTIMPLEMENTED(); | 30 NOTIMPLEMENTED(); |
| 44 return 0; | 31 return 0; |
| 45 } | 32 } |
| 46 | 33 |
| 47 void JavascriptAppModalDialogAndroid::ShowAppModalDialog() { | 34 void JavascriptAppModalDialogAndroid::ShowAppModalDialog() { |
| 48 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 35 DCHECK_CURRENTLY_ON(content::BrowserThread::UI); |
| 49 | 36 |
| 50 JNIEnv* env = AttachCurrentThread(); | 37 JNIEnv* env = AttachCurrentThread(); |
| 51 // Keep a strong ref to the parent window while we make the call to java to | 38 // Keep a strong ref to the parent window while we make the call to java to |
| 52 // display the dialog. | 39 // display the dialog. |
| 53 ScopedJavaLocalRef<jobject> parent_jobj = parent_jobject_weak_ref_.get(env); | 40 ScopedJavaLocalRef<jobject> parent_jobj = parent_jobject_weak_ref_.get(env); |
| 54 if (parent_jobj.is_null()) { | 41 if (parent_jobj.is_null()) { |
| 55 CancelAppModalDialog(); | 42 CancelAppModalDialog(); |
| 56 return; | 43 return; |
| 57 } | 44 } |
| 58 | 45 |
| (...skipping 99 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 158 | 145 |
| 159 JavascriptAppModalDialogAndroid::~JavascriptAppModalDialogAndroid() { | 146 JavascriptAppModalDialogAndroid::~JavascriptAppModalDialogAndroid() { |
| 160 // In case the dialog is still displaying, tell it to close itself. | 147 // In case the dialog is still displaying, tell it to close itself. |
| 161 // This can happen if you trigger a dialog but close the Tab before it's | 148 // This can happen if you trigger a dialog but close the Tab before it's |
| 162 // shown, and then accept the dialog. | 149 // shown, and then accept the dialog. |
| 163 if (!dialog_jobject_.is_null()) { | 150 if (!dialog_jobject_.is_null()) { |
| 164 JNIEnv* env = AttachCurrentThread(); | 151 JNIEnv* env = AttachCurrentThread(); |
| 165 Java_JavascriptAppModalDialog_dismiss(env, dialog_jobject_.obj()); | 152 Java_JavascriptAppModalDialog_dismiss(env, dialog_jobject_.obj()); |
| 166 } | 153 } |
| 167 } | 154 } |
| OLD | NEW |