Index: chrome/browser/ui/android/infobars/translate_compact_infobar.cc |
diff --git a/chrome/browser/ui/android/infobars/translate_compact_infobar.cc b/chrome/browser/ui/android/infobars/translate_compact_infobar.cc |
index 2e08dfe5e1d749a7d5bec4dfe63781998416c049..079eeb852de78ae2d5c7e39d541be7d37074a14d 100644 |
--- a/chrome/browser/ui/android/infobars/translate_compact_infobar.cc |
+++ b/chrome/browser/ui/android/infobars/translate_compact_infobar.cc |
@@ -80,8 +80,48 @@ void TranslateCompactInfoBar::SetJavaInfoBar( |
void TranslateCompactInfoBar::ApplyTranslateOptions( |
JNIEnv* env, |
- const JavaParamRef<jobject>& obj) { |
- // TODO(ramyasharma): Implement. |
+ const JavaParamRef<jobject>& obj, |
+ int option, |
+ const JavaParamRef<jstring>& value) { |
+ translate::TranslateInfoBarDelegate* delegate = GetDelegate(); |
+ if (option == TranslateUtils::OPTION_SOURCE_CODE) { |
gone
2017/04/11 17:32:36
These should be else ifs.
ramyasharma
2017/04/12 00:36:41
thanks. done.
|
+ std::string source_code = |
+ base::android::ConvertJavaStringToUTF8(env, value); |
+ if (delegate->original_language_code().compare(source_code) != 0) |
+ delegate->UpdateOriginalLanguage(source_code); |
+ } |
+ |
+ if (option == TranslateUtils::OPTION_TARGET_CODE) { |
+ std::string target_code = |
+ base::android::ConvertJavaStringToUTF8(env, value); |
+ if (delegate->target_language_code().compare(target_code) != 0) |
+ delegate->UpdateTargetLanguage(target_code); |
+ } |
+ |
+ if (option == TranslateUtils::OPTION_ALWAYS_TRANSLATE) { |
+ bool always_translate = GetBoolValue(env, value); |
+ if (delegate->ShouldAlwaysTranslate() != always_translate) |
+ delegate->ToggleAlwaysTranslate(); |
+ } |
+ |
+ if (option == TranslateUtils::OPTION_NEVER_TRANSLATE) { |
+ bool never_translate = GetBoolValue(env, value); |
+ if (never_translate && delegate->IsTranslatableLanguageByPrefs()) |
+ delegate->ToggleTranslatableLanguageByPrefs(); |
+ } |
+ |
+ if (option == TranslateUtils::OPTION_NEVER_TRANSLATE_SITE) { |
+ bool never_translate_site = GetBoolValue(env, value); |
+ if (never_translate_site && !delegate->IsSiteBlacklisted()) |
+ delegate->ToggleSiteBlacklist(); |
+ } |
+} |
+ |
+bool TranslateCompactInfoBar::GetBoolValue(JNIEnv* env, |
+ const JavaParamRef<jstring>& value) { |
+ const std::string kTrue = "true"; |
gone
2017/04/11 17:32:36
you shouldn't be needing this function after chang
ramyasharma
2017/04/12 00:36:40
Moved the const the anonymous namespace. Thanks.
|
+ std::string string_value = base::android::ConvertJavaStringToUTF8(env, value); |
+ return kTrue.compare(string_value) == 0; |
} |
void TranslateCompactInfoBar::OnPageTranslated( |