Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(27)

Side by Side Diff: components/translate/content/browser/content_translate_driver.cc

Issue 133273029: Move LanguageState to the translate component (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Review comments Created 6 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
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
3 // found in the LICENSE file.
4
5 #include "components/translate/content/browser/content_translate_driver.h"
6
7 #include "base/logging.h"
8 #include "components/translate/content/browser/language_state_observer.h"
9 #include "content/public/browser/navigation_controller.h"
10 #include "content/public/browser/navigation_details.h"
11 #include "content/public/browser/navigation_entry.h"
12
13 ContentTranslateDriver::ContentTranslateDriver(
14 content::NavigationController* nav_controller)
15 : navigation_controller_(nav_controller),
16 language_state_(this),
17 language_state_observer_(NULL) {
18 DCHECK(navigation_controller_);
19 }
20
21 ContentTranslateDriver::~ContentTranslateDriver() {}
22
23 LanguageState& ContentTranslateDriver::GetLanguageState() {
24 return language_state_;
25 }
26
27 void ContentTranslateDriver::SetLanguageStateObserver(
28 LanguageStateObserver* observer) {
29 language_state_observer_ = observer;
30 }
31
32 void ContentTranslateDriver::DidNavigate(
33 const content::LoadCommittedDetails& details) {
34 const bool reload =
35 details.entry->GetTransitionType() == content::PAGE_TRANSITION_RELOAD ||
36 details.type == content::NAVIGATION_TYPE_SAME_PAGE;
37 language_state_.DidNavigate(
38 details.is_in_page, details.is_main_frame, reload);
39 }
40
41 // TranslateDriver methods
42
43 bool ContentTranslateDriver::IsLinkNavigation() {
44 return navigation_controller_ &&
45 navigation_controller_->GetActiveEntry() &&
46 navigation_controller_->GetActiveEntry()->GetTransitionType() ==
47 content::PAGE_TRANSITION_LINK;
48 }
49
50 void ContentTranslateDriver::OnTranslateEnabledChanged() {
51 if (language_state_observer_) {
52 content::WebContents* web_contents =
53 navigation_controller_->GetWebContents();
54 language_state_observer_->OnTranslateEnabledChanged(web_contents);
55 }
56 }
57
58 void ContentTranslateDriver::OnIsPageTranslatedChanged() {
59 if (language_state_observer_) {
60 content::WebContents* web_contents =
61 navigation_controller_->GetWebContents();
62 language_state_observer_->OnIsPageTranslatedChanged(web_contents);
63 }
64 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698