blob: 5b131bea98c026764a0cea722d824b5065ec8e50 [file] [log] [blame]
// Copyright 2014 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef COMPONENTS_TRANSLATE_CORE_BROWSER_LANGUAGE_STATE_H_
#define COMPONENTS_TRANSLATE_CORE_BROWSER_LANGUAGE_STATE_H_
#include <string>
#include "base/memory/raw_ptr.h"
namespace translate {
class TranslateDriver;
// This class holds the language state of the current page.
// There is one LanguageState instance per tab.
// It is used to determine when navigating to a new page whether it should
// automatically be translated.
// This auto-translate behavior is the expected behavior when:
// - user is on page in language A that they had translated to language B.
// - user clicks a link in that page that takes them to a page also in language
// A.
class LanguageState {
public:
explicit LanguageState(TranslateDriver* driver);
LanguageState(const LanguageState&) = delete;
LanguageState& operator=(const LanguageState&) = delete;
~LanguageState();
// Should be called when the page did a new navigation (whether it is a main
// frame or sub-frame navigation).
void DidNavigate(bool is_same_document_navigation,
bool is_main_frame,
bool reload,
const std::string& href_translate,
bool navigation_from_google);
// Should be called when the language of the page has been determined.
// |page_level_translation_criteria_met| when false indicates that the browser
// should not offer to translate the page.
void LanguageDetermined(const std::string& page_language,
bool page_level_translation_criteria_met);
// Returns the language the current page should be translated to, based on the
// previous page languages and the transition. This should be called after
// the language page has been determined.
// Returns an empty string if the page should not be auto-translated.
std::string AutoTranslateTo() const;
// Returns true if the user is navigating through translated links.
bool InTranslateNavigation() const;
// Returns true if the current page in the associated tab has been translated.
bool IsPageTranslated() const { return source_lang_ != current_lang_; }
// Returns the source language represented as a lowercase alphabetic string
// of length 0 to 3 or "zh-CN" or "zh-TW".
const std::string& source_language() const { return source_lang_; }
void SetSourceLanguage(const std::string& language);
// Returns the current language represented as a lowercase alphabetic string
// of length 0 to 3 or "zh-CN" or "zh-TW".
const std::string& current_language() const { return current_lang_; }
void SetCurrentLanguage(const std::string& language);
bool page_level_translation_criteria_met() const {
return page_level_translation_criteria_met_;
}
// Whether the page is currently in the process of being translated.
bool translation_pending() const { return translation_pending_; }
void set_translation_pending(bool value) { translation_pending_ = value; }
// Whether an error occured during translation.
bool translation_error() const { return translation_error_; }
void set_translation_error(bool value) { translation_error_ = value; }
// Whether the user has already declined to translate the page.
bool translation_declined() const { return translation_declined_; }
void set_translation_declined(bool value) { translation_declined_ = value; }
// Whether the translate is enabled.
bool translate_enabled() const { return translate_enabled_; }
void SetTranslateEnabled(bool value);
// Whether the current page's language is different from the previous
// language.
bool HasLanguageChanged() const;
const std::string& href_translate() const { return href_translate_; }
bool navigation_from_google() const { return navigation_from_google_; }
const std::string& GetPredefinedTargetLanguage() const {
return predefined_target_language_;
}
void SetPredefinedTargetLanguage(const std::string& language,
bool should_auto_translate) {
predefined_target_language_ = language;
should_auto_translate_to_predefined_target_language_ =
should_auto_translate;
}
bool should_auto_translate_to_predefined_target_language() const {
return should_auto_translate_to_predefined_target_language_;
}
private:
void SetIsPageTranslated(bool value);
// Whether the page is translated or not.
bool is_page_translated_;
// The languages this page is in. Note that current_lang_ is different from
// source_lang_ when the page has been translated.
// Note that these might be empty if the page language has not been determined
// yet.
std::string source_lang_;
std::string current_lang_;
// Same as above but for the previous page.
std::string prev_source_lang_;
std::string prev_current_lang_;
// Provides driver-level context to the shared code of the component. Must
// outlive this object.
raw_ptr<TranslateDriver> translate_driver_;
// Whether it is OK to offer to translate the page. Translation is not offered
// if we cannot determine the source language. In addition, some pages
// explicitly specify that they should not be translated by the browser (this
// is the case for GMail for example, which provides its own translation
// features).
bool page_level_translation_criteria_met_;
// Whether a translation is currently pending.
// This is needed to avoid sending duplicate translate requests to a page.
// Translations may be initiated every time the load stops for the main frame,
// which may happen several times.
// TODO(jcampan): make the client send the language just once per navigation
// then we can get rid of that state.
bool translation_pending_;
// Whether an error occured during translation.
bool translation_error_;
// Whether the user has declined to translate the page (by closing the infobar
// for example). This is necessary as a new infobar could be shown if a new
// load happens in the page after the user closed the infobar.
bool translation_declined_;
// Whether the current navigation is a same-document navigation.
bool is_same_document_navigation_;
// Whether the Translate is enabled.
bool translate_enabled_;
// The value of the hrefTranslate attribute on the link that initiated the
// current navigation, if it was specified.
std::string href_translate_;
// True when the current page was the result of a navigation originated in a
// Google origin.
bool navigation_from_google_ = false;
// Target language set by client.
std::string predefined_target_language_;
// Indicates that the page should be automatically translated to
// |predefined_target_language_| if possible.
bool should_auto_translate_to_predefined_target_language_ = false;
};
} // namespace translate
#endif // COMPONENTS_TRANSLATE_CORE_BROWSER_LANGUAGE_STATE_H_