Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2017 The Chromium Authors. All rights reserved. | 1 // Copyright 2017 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/infobars/translate_compact_infobar.h" | 5 #include "chrome/browser/ui/android/infobars/translate_compact_infobar.h" |
| 6 | 6 |
| 7 #include <stddef.h> | 7 #include <stddef.h> |
| 8 | 8 |
| 9 #include "base/android/jni_android.h" | 9 #include "base/android/jni_android.h" |
| 10 #include "base/android/jni_array.h" | 10 #include "base/android/jni_array.h" |
| (...skipping 54 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 65 action_flags_ |= FLAG_TRANSLATE; | 65 action_flags_ |= FLAG_TRANSLATE; |
| 66 delegate->Translate(); | 66 delegate->Translate(); |
| 67 if (!delegate->ShouldAlwaysTranslate() && ShouldAutoAlwaysTranslate()) { | 67 if (!delegate->ShouldAlwaysTranslate() && ShouldAutoAlwaysTranslate()) { |
| 68 JNIEnv* env = base::android::AttachCurrentThread(); | 68 JNIEnv* env = base::android::AttachCurrentThread(); |
| 69 Java_TranslateCompactInfoBar_setAutoAlwaysTranslate(env, | 69 Java_TranslateCompactInfoBar_setAutoAlwaysTranslate(env, |
| 70 GetJavaInfoBar()); | 70 GetJavaInfoBar()); |
| 71 } | 71 } |
| 72 } else if (action == InfoBarAndroid::ACTION_TRANSLATE_SHOW_ORIGINAL) { | 72 } else if (action == InfoBarAndroid::ACTION_TRANSLATE_SHOW_ORIGINAL) { |
| 73 action_flags_ |= FLAG_REVERT; | 73 action_flags_ |= FLAG_REVERT; |
| 74 delegate->RevertWithoutClosingInfobar(); | 74 delegate->RevertWithoutClosingInfobar(); |
| 75 } else if (action == InfoBarAndroid::ACTION_CANCEL) { | |
| 76 delegate->TranslationDeclined(); | |
| 77 } else { | 75 } else { |
| 78 DCHECK_EQ(InfoBarAndroid::ACTION_NONE, action); | 76 DCHECK_EQ(InfoBarAndroid::ACTION_NONE, action); |
| 79 } | 77 } |
| 80 } | 78 } |
| 81 | 79 |
| 82 void TranslateCompactInfoBar::SetJavaInfoBar( | 80 void TranslateCompactInfoBar::SetJavaInfoBar( |
| 83 const base::android::JavaRef<jobject>& java_info_bar) { | 81 const base::android::JavaRef<jobject>& java_info_bar) { |
| 84 InfoBarAndroid::SetJavaInfoBar(java_info_bar); | 82 InfoBarAndroid::SetJavaInfoBar(java_info_bar); |
| 85 JNIEnv* env = base::android::AttachCurrentThread(); | 83 JNIEnv* env = base::android::AttachCurrentThread(); |
| 86 Java_TranslateCompactInfoBar_setNativePtr(env, java_info_bar, | 84 Java_TranslateCompactInfoBar_setNativePtr(env, java_info_bar, |
| (...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 134 } | 132 } |
| 135 } | 133 } |
| 136 | 134 |
| 137 bool TranslateCompactInfoBar::ShouldAutoAlwaysTranslate() { | 135 bool TranslateCompactInfoBar::ShouldAutoAlwaysTranslate() { |
| 138 translate::TranslateInfoBarDelegate* delegate = GetDelegate(); | 136 translate::TranslateInfoBarDelegate* delegate = GetDelegate(); |
| 139 return (delegate->GetTranslationAcceptedCount() == kAcceptCountThreshold); | 137 return (delegate->GetTranslationAcceptedCount() == kAcceptCountThreshold); |
| 140 } | 138 } |
| 141 | 139 |
| 142 jboolean TranslateCompactInfoBar::ShouldAutoNeverTranslate( | 140 jboolean TranslateCompactInfoBar::ShouldAutoNeverTranslate( |
| 143 JNIEnv* env, | 141 JNIEnv* env, |
| 144 const base::android::JavaParamRef<jobject>& obj) { | 142 const base::android::JavaParamRef<jobject>& obj, |
| 143 jboolean menu_expanded) { | |
| 144 // Mark menu expanded. | |
| 145 if (menu_expanded) | |
| 146 action_flags_ |= FLAG_EXPAND_MENU; | |
| 147 | |
| 148 if (!IsDeclinedByUser()) | |
| 149 return false; | |
| 150 | |
| 145 translate::TranslateInfoBarDelegate* delegate = GetDelegate(); | 151 translate::TranslateInfoBarDelegate* delegate = GetDelegate(); |
| 152 // Don't trigger if it's off the recored or already blocked. | |
|
Marti Wong
2017/05/23 08:23:32
typo: record
Leo
2017/05/23 14:33:01
Thanks for the catch.
| |
| 153 if (delegate->is_off_the_record() || | |
| 154 !delegate->IsTranslatableLanguageByPrefs()) | |
| 155 return false; | |
| 156 | |
| 146 return (delegate->GetTranslationDeniedCount() == kDeniedCountThreshold); | 157 return (delegate->GetTranslationDeniedCount() == kDeniedCountThreshold); |
| 147 } | 158 } |
| 148 | 159 |
| 149 translate::TranslateInfoBarDelegate* TranslateCompactInfoBar::GetDelegate() { | 160 translate::TranslateInfoBarDelegate* TranslateCompactInfoBar::GetDelegate() { |
| 150 return delegate()->AsTranslateInfoBarDelegate(); | 161 return delegate()->AsTranslateInfoBarDelegate(); |
| 151 } | 162 } |
| 152 | 163 |
| 153 void TranslateCompactInfoBar::OnTranslateStepChanged( | 164 void TranslateCompactInfoBar::OnTranslateStepChanged( |
| 154 translate::TranslateStep step, | 165 translate::TranslateStep step, |
| 155 translate::TranslateErrors::Type error_type) { | 166 translate::TranslateErrors::Type error_type) { |
| 156 if (!owner()) | 167 if (!owner()) |
| 157 return; // We're closing; don't call anything. | 168 return; // We're closing; don't call anything. |
| 158 | 169 |
| 159 if ((step == translate::TRANSLATE_STEP_AFTER_TRANSLATE) || | 170 if ((step == translate::TRANSLATE_STEP_AFTER_TRANSLATE) || |
| 160 (step == translate::TRANSLATE_STEP_TRANSLATE_ERROR)) { | 171 (step == translate::TRANSLATE_STEP_TRANSLATE_ERROR)) { |
| 161 JNIEnv* env = base::android::AttachCurrentThread(); | 172 JNIEnv* env = base::android::AttachCurrentThread(); |
| 162 Java_TranslateCompactInfoBar_onPageTranslated(env, GetJavaInfoBar(), | 173 Java_TranslateCompactInfoBar_onPageTranslated(env, GetJavaInfoBar(), |
| 163 error_type); | 174 error_type); |
| 164 } | 175 } |
| 165 } | 176 } |
| 166 | 177 |
| 167 bool TranslateCompactInfoBar::IsDeclinedByUser() { | 178 bool TranslateCompactInfoBar::IsDeclinedByUser() { |
| 168 return action_flags_ == FLAG_NONE; | 179 return action_flags_ == FLAG_NONE; |
|
Marti Wong
2017/05/23 08:23:32
If user clicks on CLOSE after a auto translate (wi
Leo
2017/05/23 14:33:01
Added more explanation in where it's defined.
| |
| 169 }; | 180 }; |
| 170 | 181 |
| 171 // Native JNI methods --------------------------------------------------------- | 182 // Native JNI methods --------------------------------------------------------- |
| 172 | 183 |
| 173 // static | 184 // static |
| 174 bool RegisterTranslateCompactInfoBar(JNIEnv* env) { | 185 bool RegisterTranslateCompactInfoBar(JNIEnv* env) { |
| 175 return RegisterNativesImpl(env); | 186 return RegisterNativesImpl(env); |
| 176 } | 187 } |
| OLD | NEW |