| Index: chrome/browser/translate/translate_ui_delegate.cc
 | 
| diff --git a/chrome/browser/translate/translate_ui_delegate.cc b/chrome/browser/translate/translate_ui_delegate.cc
 | 
| new file mode 100644
 | 
| index 0000000000000000000000000000000000000000..662f40f33cadf6cf0137ba75a271369c957c02d9
 | 
| --- /dev/null
 | 
| +++ b/chrome/browser/translate/translate_ui_delegate.cc
 | 
| @@ -0,0 +1,195 @@
 | 
| +// Copyright 2013 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 "chrome/browser/translate/translate_ui_delegate.h"
 | 
| +
 | 
| +#include "base/i18n/string_compare.h"
 | 
| +#include "base/metrics/histogram.h"
 | 
| +#include "chrome/browser/browser_process.h"
 | 
| +#include "chrome/browser/profiles/profile.h"
 | 
| +#include "chrome/browser/translate/translate_manager.h"
 | 
| +#include "chrome/browser/translate/translate_prefs.h"
 | 
| +#include "chrome/browser/translate/translate_tab_helper.h"
 | 
| +#include "content/public/browser/browser_context.h"
 | 
| +#include "content/public/browser/navigation_entry.h"
 | 
| +#include "content/public/browser/web_contents.h"
 | 
| +#include "third_party/icu/source/i18n/unicode/coll.h"
 | 
| +#include "ui/base/l10n/l10n_util.h"
 | 
| +
 | 
| +namespace {
 | 
| +
 | 
| +const char kDeclineTranslate[] = "Translate.DeclineTranslate";
 | 
| +const char kRevertTranslation[] = "Translate.RevertTranslation";
 | 
| +const char kPerformTranslate[] = "Translate.Translate";
 | 
| +const char kNeverTranslateLang[] = "Translate.NeverTranslateLang";
 | 
| +const char kNeverTranslateSite[] = "Translate.NeverTranslateSite";
 | 
| +const char kAlwaysTranslateLang[] = "Translate.AlwaysTranslateLang";
 | 
| +
 | 
| +}
 | 
| +
 | 
| +// static
 | 
| +const size_t TranslateUIDelegate::kNoIndex = static_cast<size_t>(-1);
 | 
| +
 | 
| +TranslateUIDelegate::TranslateUIDelegate(content::WebContents* web_contents,
 | 
| +                                         const std::string& original_language,
 | 
| +                                         const std::string& target_language)
 | 
| +    : web_contents_(web_contents),
 | 
| +      original_language_index_(kNoIndex),
 | 
| +      initial_original_language_index_(kNoIndex),
 | 
| +      target_language_index_(kNoIndex) {
 | 
| +  std::vector<std::string> language_codes;
 | 
| +  TranslateManager::GetSupportedLanguages(&language_codes);
 | 
| +
 | 
| +  // Preparing for the alphabetical order in the locale.
 | 
| +  UErrorCode error = U_ZERO_ERROR;
 | 
| +  std::string locale = g_browser_process->GetApplicationLocale();
 | 
| +  icu::Locale loc(locale.c_str());
 | 
| +  scoped_ptr<icu::Collator> collator(icu::Collator::createInstance(loc, error));
 | 
| +  collator->setStrength(icu::Collator::PRIMARY);
 | 
| +
 | 
| +  languages_.reserve(language_codes.size());
 | 
| +  for (std::vector<std::string>::const_iterator iter = language_codes.begin();
 | 
| +       iter != language_codes.end(); ++iter) {
 | 
| +    std::string language_code = *iter;
 | 
| +
 | 
| +    string16 language_name = l10n_util::GetDisplayNameForLocale(
 | 
| +        language_code, g_browser_process->GetApplicationLocale(), true);
 | 
| +    // Insert the language in languages_ in alphabetical order.
 | 
| +    std::vector<LanguageNamePair>::iterator iter2;
 | 
| +    for (iter2 = languages_.begin(); iter2 != languages_.end(); ++iter2) {
 | 
| +      if (base::i18n::CompareString16WithCollator(collator.get(),
 | 
| +          language_name, iter2->second) == UCOL_LESS) {
 | 
| +        break;
 | 
| +      }
 | 
| +    }
 | 
| +    languages_.insert(iter2, LanguageNamePair(language_code, language_name));
 | 
| +  }
 | 
| +  for (std::vector<LanguageNamePair>::const_iterator iter = languages_.begin();
 | 
| +       iter != languages_.end(); ++iter) {
 | 
| +    std::string language_code = iter->first;
 | 
| +    if (language_code == original_language) {
 | 
| +      original_language_index_ = iter - languages_.begin();
 | 
| +      initial_original_language_index_ = original_language_index_;
 | 
| +    }
 | 
| +    if (language_code == target_language)
 | 
| +      target_language_index_ = iter - languages_.begin();
 | 
| +  }
 | 
| +
 | 
| +  Profile* profile =
 | 
| +      Profile::FromBrowserContext(web_contents->GetBrowserContext());
 | 
| +  prefs_.reset(new TranslatePrefs(profile->GetPrefs()));
 | 
| +}
 | 
| +
 | 
| +TranslateUIDelegate::~TranslateUIDelegate() {
 | 
| +}
 | 
| +
 | 
| +std::string TranslateUIDelegate::GetLanguageCodeAt(size_t index) const {
 | 
| +  DCHECK_LT(index, num_languages());
 | 
| +  return languages_[index].first;
 | 
| +}
 | 
| +
 | 
| +string16 TranslateUIDelegate::GetLanguageNameAt(size_t index) const {
 | 
| +  if (index == kNoIndex)
 | 
| +    return string16();
 | 
| +  DCHECK_LT(index, num_languages());
 | 
| +  return languages_[index].second;
 | 
| +}
 | 
| +
 | 
| +std::string TranslateUIDelegate::GetOriginalLanguageCode() const {
 | 
| +  return (original_language_index() == kNoIndex) ?
 | 
| +      chrome::kUnknownLanguageCode :
 | 
| +      GetLanguageCodeAt(original_language_index());
 | 
| +}
 | 
| +
 | 
| +std::string TranslateUIDelegate::GetTargetLanguageCode() const {
 | 
| +  return GetLanguageCodeAt(target_language_index());
 | 
| +}
 | 
| +
 | 
| +void TranslateUIDelegate::Translate() {
 | 
| +  if (!web_contents()->GetBrowserContext()->IsOffTheRecord()) {
 | 
| +    prefs_->ResetTranslationDeniedCount(GetOriginalLanguageCode());
 | 
| +    prefs_->IncrementTranslationAcceptedCount(GetOriginalLanguageCode());
 | 
| +  }
 | 
| +  TranslateManager::GetInstance()->TranslatePage(web_contents(),
 | 
| +                                                 GetOriginalLanguageCode(),
 | 
| +                                                 GetTargetLanguageCode());
 | 
| +
 | 
| +  UMA_HISTOGRAM_BOOLEAN(kPerformTranslate, true);
 | 
| +}
 | 
| +
 | 
| +void TranslateUIDelegate::RevertTranslation() {
 | 
| +  TranslateManager::GetInstance()->RevertTranslation(web_contents());
 | 
| +
 | 
| +  UMA_HISTOGRAM_BOOLEAN(kRevertTranslation, true);
 | 
| +}
 | 
| +
 | 
| +void TranslateUIDelegate::TranslationDeclined() {
 | 
| +  if (!web_contents()->GetBrowserContext()->IsOffTheRecord()) {
 | 
| +    prefs_->ResetTranslationAcceptedCount(GetOriginalLanguageCode());
 | 
| +    prefs_->IncrementTranslationDeniedCount(GetOriginalLanguageCode());
 | 
| +  }
 | 
| +
 | 
| +  // Remember that the user declined the translation so as to prevent showing a
 | 
| +  // translate infobar for that page again.  (TranslateManager initiates
 | 
| +  // translations when getting a LANGUAGE_DETERMINED from the page, which
 | 
| +  // happens when a load stops. That could happen multiple times, including
 | 
| +  // after the user already declined the translation.)
 | 
| +  TranslateTabHelper::FromWebContents(web_contents())->
 | 
| +      language_state().set_translation_declined(true);
 | 
| +
 | 
| +  UMA_HISTOGRAM_BOOLEAN(kDeclineTranslate, true);
 | 
| +}
 | 
| +
 | 
| +bool TranslateUIDelegate::IsLanguageBlocked() {
 | 
| +  return prefs_->IsBlockedLanguage(GetOriginalLanguageCode());
 | 
| +}
 | 
| +
 | 
| +void TranslateUIDelegate::SetLanguageBlocked(bool value) {
 | 
| +  if (value)
 | 
| +    prefs_->BlockLanguage(GetOriginalLanguageCode());
 | 
| +  else
 | 
| +    prefs_->UnblockLanguage(GetOriginalLanguageCode());
 | 
| +
 | 
| +  UMA_HISTOGRAM_BOOLEAN(kNeverTranslateLang, true);
 | 
| +}
 | 
| +
 | 
| +bool TranslateUIDelegate::IsSiteBlacklisted() {
 | 
| +  std::string host = GetPageHost();
 | 
| +  return !host.empty() && prefs_->IsSiteBlacklisted(host);
 | 
| +}
 | 
| +
 | 
| +void TranslateUIDelegate::SetSiteBlacklist(bool value) {
 | 
| +  std::string host = GetPageHost();
 | 
| +  if (host.empty())
 | 
| +    return;
 | 
| +
 | 
| +  if (value)
 | 
| +    prefs_->BlacklistSite(host);
 | 
| +  else
 | 
| +    prefs_->RemoveSiteFromBlacklist(host);
 | 
| +
 | 
| +  UMA_HISTOGRAM_BOOLEAN(kNeverTranslateSite, true);
 | 
| +}
 | 
| +
 | 
| +bool TranslateUIDelegate::ShouldAlwaysTranslate() {
 | 
| +  return prefs_->IsLanguagePairWhitelisted(GetOriginalLanguageCode(),
 | 
| +                                           GetTargetLanguageCode());
 | 
| +}
 | 
| +
 | 
| +void TranslateUIDelegate::SetAlwaysTranslate(bool value) {
 | 
| +  const std::string& original_lang = GetOriginalLanguageCode();
 | 
| +  const std::string& target_lang = GetTargetLanguageCode();
 | 
| +  if (value)
 | 
| +    prefs_->WhitelistLanguagePair(original_lang, target_lang);
 | 
| +  else
 | 
| +    prefs_->RemoveLanguagePairFromWhitelist(original_lang, target_lang);
 | 
| +
 | 
| +  UMA_HISTOGRAM_BOOLEAN(kAlwaysTranslateLang, true);
 | 
| +}
 | 
| +
 | 
| +std::string TranslateUIDelegate::GetPageHost() {
 | 
| +  content::NavigationEntry* entry =
 | 
| +      web_contents()->GetController().GetActiveEntry();
 | 
| +  return entry ? entry->GetURL().HostNoBrackets() : std::string();
 | 
| +}
 | 
| 
 |