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
|
// Copyright (c) 2010 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.
#ifndef CHROME_BROWSER_GTK_TRANSLATE_TRANSLATE_INFOBAR_BASE_GTK_H_
#define CHROME_BROWSER_GTK_TRANSLATE_TRANSLATE_INFOBAR_BASE_GTK_H_
#pragma once
#include "app/animation_delegate.h"
#include "chrome/browser/translate/translate_infobar_view.h"
#include "chrome/browser/gtk/infobar_gtk.h"
class MenuGtk;
class OptionsMenuModel;
class TranslateInfoBarDelegate;
// This class contains some of the base functionality that translate infobars
// use.
class TranslateInfoBarBase : public TranslateInfoBarView,
public InfoBar,
public AnimationDelegate {
public:
explicit TranslateInfoBarBase(TranslateInfoBarDelegate* delegate);
virtual ~TranslateInfoBarBase();
// Initializes the infobar widgets. Should be called after the object has been
// created.
virtual void Init();
// Overridden from InfoBar:
virtual void GetTopColor(InfoBarDelegate::Type type,
double* r, double* g, double *b);
virtual void GetBottomColor(InfoBarDelegate::Type type,
double* r, double* g, double *b);
// Overridden from TranslateInfoBarView:
virtual void OriginalLanguageChanged() {}
virtual void TargetLanguageChanged() {}
// Overridden from AnimationDelegate:
virtual void AnimationProgressed(const Animation* animation);
protected:
// Sub-classes that want to have the options menu button showing sould
// override and return true.
virtual bool ShowOptionsMenuButton() const { return false; }
// Creates a label with the appropriate font and color for the translate
// infobars.
GtkWidget* CreateLabel(const std::string& text);
// Creates a combobox that displays the languages currently available.
// |selected_language| is the language index (as used in the
// TranslateInfoDelegate) that should be selected initially.
// |exclude_language| is the language index of the language that should not be
// included in the list (-1 means no language excluded).
GtkWidget* CreateLanguageCombobox(int selected_language,
int exclude_language);
// Given an above-constructed combobox, returns the currently selected
// language id.
static int GetLanguageComboboxActiveId(GtkComboBox* combo);
// Convenience to retrieve the TranslateInfoBarDelegate for this infobar.
TranslateInfoBarDelegate* GetDelegate() const;
private:
// Builds a button with an arrow in it to emulate the menu-button style from
// the windows version.
static GtkWidget* BuildOptionsMenuButton();
// The menu displayed when the Options button is pressed.
scoped_ptr<OptionsMenuModel> options_menu_model_;
scoped_ptr<MenuGtk> options_menu_menu_;
CHROMEGTK_CALLBACK_0(TranslateInfoBarBase, void, OnOptionsClicked);
// A percentage to average the normal page action background with the error
// background. When 0, the infobar background should be pure PAGE_ACTION_TYPE.
// When 1, the infobar background should be pure WARNING_TYPE.
double background_error_percent_;
// Changes the color of the background from normal to error color and back.
scoped_ptr<SlideAnimation> background_color_animation_;
DISALLOW_COPY_AND_ASSIGN(TranslateInfoBarBase);
};
#endif // CHROME_BROWSER_GTK_TRANSLATE_TRANSLATE_INFOBAR_BASE_GTK_H_
|