1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
|
// Copyright (c) 2011 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/ui/gtk/infobars/after_translate_infobar_gtk.h"
#include "base/message_loop.h"
#include "base/utf_string_conversions.h"
#include "chrome/browser/translate/translate_infobar_delegate.h"
#include "chrome/browser/ui/gtk/gtk_util.h"
#include "grit/generated_resources.h"
#include "ui/base/l10n/l10n_util.h"
AfterTranslateInfoBar::AfterTranslateInfoBar(
TabContentsWrapper* owner,
TranslateInfoBarDelegate* delegate)
: TranslateInfoBarBase(owner, delegate),
ALLOW_THIS_IN_INITIALIZER_LIST(method_factory_(this)) {
}
AfterTranslateInfoBar::~AfterTranslateInfoBar() {
}
void AfterTranslateInfoBar::Init() {
TranslateInfoBarBase::Init();
bool swapped_language_combos = false;
std::vector<string16> strings;
TranslateInfoBarDelegate::GetAfterTranslateStrings(
&strings, &swapped_language_combos);
DCHECK(strings.size() == 3U);
GtkWidget* hbox = gtk_hbox_new(FALSE, gtk_util::kControlSpacing);
gtk_util::CenterWidgetInHBox(hbox_, hbox, false, 0);
GtkWidget* original_lang_combo =
CreateLanguageCombobox(GetDelegate()->original_language_index(),
GetDelegate()->target_language_index());
g_signal_connect(original_lang_combo, "changed",
G_CALLBACK(&OnOriginalLanguageModifiedThunk), this);
GtkWidget* target_lang_combo =
CreateLanguageCombobox(GetDelegate()->target_language_index(),
GetDelegate()->original_language_index());
g_signal_connect(target_lang_combo, "changed",
G_CALLBACK(&OnTargetLanguageModifiedThunk), this);
gtk_box_pack_start(GTK_BOX(hbox), CreateLabel(UTF16ToUTF8(strings[0])),
FALSE, FALSE, 0);
gtk_box_pack_start(GTK_BOX(hbox),
swapped_language_combos ? target_lang_combo :
original_lang_combo,
FALSE, FALSE, 0);
gtk_box_pack_start(GTK_BOX(hbox), CreateLabel(UTF16ToUTF8(strings[1])),
FALSE, FALSE, 0);
gtk_box_pack_start(GTK_BOX(hbox),
swapped_language_combos ? original_lang_combo :
target_lang_combo,
FALSE, FALSE, 0);
gtk_box_pack_start(GTK_BOX(hbox), CreateLabel(UTF16ToUTF8(strings[2])),
FALSE, FALSE, 0);
GtkWidget* button = gtk_button_new_with_label(
l10n_util::GetStringUTF8(IDS_TRANSLATE_INFOBAR_REVERT).c_str());
g_signal_connect(button, "clicked",G_CALLBACK(&OnRevertPressedThunk), this);
gtk_box_pack_start(GTK_BOX(hbox), button, FALSE, FALSE, 0);
}
bool AfterTranslateInfoBar::ShowOptionsMenuButton() const {
return true;
}
void AfterTranslateInfoBar::OnOriginalLanguageModified(GtkWidget* sender) {
size_t index = GetLanguageComboboxActiveId(GTK_COMBO_BOX(sender));
if (index == GetDelegate()->original_language_index())
return;
// Setting the language will lead to a new translation that is going to close
// the infobar. This is not OK to do this from the signal handler, so we'll
// defer it.
MessageLoop::current()->PostTask(FROM_HERE, method_factory_.NewRunnableMethod(
&AfterTranslateInfoBar::SetOriginalLanguage, index));
}
void AfterTranslateInfoBar::OnTargetLanguageModified(GtkWidget* sender) {
size_t index = GetLanguageComboboxActiveId(GTK_COMBO_BOX(sender));
if (index == GetDelegate()->target_language_index())
return;
// See comment in OnOriginalLanguageModified on why we use a task.
MessageLoop::current()->PostTask(FROM_HERE, method_factory_.NewRunnableMethod(
&AfterTranslateInfoBar::SetTargetLanguage, index));
}
void AfterTranslateInfoBar::OnRevertPressed(GtkWidget* sender) {
GetDelegate()->RevertTranslation();
}
void AfterTranslateInfoBar::SetOriginalLanguage(size_t language_index) {
GetDelegate()->SetOriginalLanguage(language_index);
}
void AfterTranslateInfoBar::SetTargetLanguage(size_t language_index) {
GetDelegate()->SetTargetLanguage(language_index);
}
|