OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/autofill/card_unmask_prompt_view_android.h" | 5 #include "chrome/browser/ui/android/autofill/card_unmask_prompt_view_android.h" |
6 | 6 |
| 7 #include "chrome/browser/android/resource_mapper.h" |
7 #include "chrome/browser/ui/autofill/card_unmask_prompt_controller.h" | 8 #include "chrome/browser/ui/autofill/card_unmask_prompt_controller.h" |
8 #include "content/public/browser/web_contents.h" | 9 #include "content/public/browser/web_contents.h" |
9 #include "jni/CardUnmaskBridge_jni.h" | 10 #include "jni/CardUnmaskBridge_jni.h" |
10 #include "ui/base/android/view_android.h" | 11 #include "ui/base/android/view_android.h" |
11 #include "ui/base/android/window_android.h" | 12 #include "ui/base/android/window_android.h" |
12 | 13 |
13 namespace autofill { | 14 namespace autofill { |
14 | 15 |
15 CardUnmaskPromptView* CardUnmaskPromptView::CreateAndShow( | 16 CardUnmaskPromptView* CardUnmaskPromptView::CreateAndShow( |
16 CardUnmaskPromptController* controller) { | 17 CardUnmaskPromptController* controller) { |
(...skipping 19 matching lines...) Expand all Loading... |
36 controller_->GetWebContents()->GetNativeView(); | 37 controller_->GetWebContents()->GetNativeView(); |
37 | 38 |
38 ScopedJavaLocalRef<jstring> dialog_title = | 39 ScopedJavaLocalRef<jstring> dialog_title = |
39 base::android::ConvertUTF16ToJavaString(env, | 40 base::android::ConvertUTF16ToJavaString(env, |
40 controller_->GetWindowTitle()); | 41 controller_->GetWindowTitle()); |
41 ScopedJavaLocalRef<jstring> instructions = | 42 ScopedJavaLocalRef<jstring> instructions = |
42 base::android::ConvertUTF16ToJavaString( | 43 base::android::ConvertUTF16ToJavaString( |
43 env, controller_->GetInstructionsMessage()); | 44 env, controller_->GetInstructionsMessage()); |
44 java_object_.Reset(Java_CardUnmaskBridge_create( | 45 java_object_.Reset(Java_CardUnmaskBridge_create( |
45 env, reinterpret_cast<intptr_t>(this), dialog_title.obj(), | 46 env, reinterpret_cast<intptr_t>(this), dialog_title.obj(), |
46 instructions.obj(), | 47 instructions.obj(), controller_->ShouldRequestExpirationDate(), |
| 48 ResourceMapper::MapFromChromiumId(controller_->GetCvcImageRid()), |
47 view_android->GetWindowAndroid()->GetJavaObject().obj())); | 49 view_android->GetWindowAndroid()->GetJavaObject().obj())); |
48 | 50 |
49 Java_CardUnmaskBridge_show(env, java_object_.obj()); | 51 Java_CardUnmaskBridge_show(env, java_object_.obj()); |
50 } | 52 } |
51 | 53 |
52 bool CardUnmaskPromptViewAndroid::CheckUserInputValidity(JNIEnv* env, | 54 bool CardUnmaskPromptViewAndroid::CheckUserInputValidity(JNIEnv* env, |
53 jobject obj, | 55 jobject obj, |
54 jstring response) { | 56 jstring response) { |
55 return controller_->InputTextIsValid( | 57 return controller_->InputTextIsValid( |
56 base::android::ConvertJavaStringToUTF16(env, response)); | 58 base::android::ConvertJavaStringToUTF16(env, response)); |
57 } | 59 } |
58 | 60 |
59 void CardUnmaskPromptViewAndroid::OnUserInput(JNIEnv* env, | 61 void CardUnmaskPromptViewAndroid::OnUserInput(JNIEnv* env, |
60 jobject obj, | 62 jobject obj, |
61 jstring response) { | 63 jstring cvc, |
| 64 jstring month, |
| 65 jstring year) { |
62 controller_->OnUnmaskResponse( | 66 controller_->OnUnmaskResponse( |
63 base::android::ConvertJavaStringToUTF16(env, response), | 67 base::android::ConvertJavaStringToUTF16(env, cvc), |
64 base::string16(), | 68 base::android::ConvertJavaStringToUTF16(env, month), |
65 base::string16()); | 69 base::android::ConvertJavaStringToUTF16(env, year)); |
66 } | 70 } |
67 | 71 |
68 void CardUnmaskPromptViewAndroid::PromptDismissed(JNIEnv* env, jobject obj) { | 72 void CardUnmaskPromptViewAndroid::PromptDismissed(JNIEnv* env, jobject obj) { |
69 delete this; | 73 delete this; |
70 } | 74 } |
71 | 75 |
72 void CardUnmaskPromptViewAndroid::ControllerGone() { | 76 void CardUnmaskPromptViewAndroid::ControllerGone() { |
73 controller_ = nullptr; | 77 controller_ = nullptr; |
74 JNIEnv* env = base::android::AttachCurrentThread(); | 78 JNIEnv* env = base::android::AttachCurrentThread(); |
75 Java_CardUnmaskBridge_dismiss(env, java_object_.obj()); | 79 Java_CardUnmaskBridge_dismiss(env, java_object_.obj()); |
76 } | 80 } |
77 | 81 |
78 void CardUnmaskPromptViewAndroid::DisableAndWaitForVerification() { | 82 void CardUnmaskPromptViewAndroid::DisableAndWaitForVerification() { |
79 JNIEnv* env = base::android::AttachCurrentThread(); | 83 JNIEnv* env = base::android::AttachCurrentThread(); |
80 Java_CardUnmaskBridge_disableAndWaitForVerification(env, java_object_.obj()); | 84 Java_CardUnmaskBridge_disableAndWaitForVerification(env, java_object_.obj()); |
81 } | 85 } |
82 | 86 |
83 void CardUnmaskPromptViewAndroid::GotVerificationResult(bool success) { | 87 void CardUnmaskPromptViewAndroid::GotVerificationResult(bool success) { |
84 JNIEnv* env = base::android::AttachCurrentThread(); | 88 JNIEnv* env = base::android::AttachCurrentThread(); |
85 Java_CardUnmaskBridge_verificationFinished(env, java_object_.obj(), success); | 89 Java_CardUnmaskBridge_verificationFinished(env, java_object_.obj(), success); |
86 } | 90 } |
87 | 91 |
88 // static | 92 // static |
89 bool CardUnmaskPromptViewAndroid::Register(JNIEnv* env) { | 93 bool CardUnmaskPromptViewAndroid::Register(JNIEnv* env) { |
90 return RegisterNativesImpl(env); | 94 return RegisterNativesImpl(env); |
91 } | 95 } |
92 | 96 |
93 } // namespace autofill | 97 } // namespace autofill |
OLD | NEW |