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

Side by Side Diff: chrome/browser/gtk/browser_actions_toolbar_gtk.h

Issue 6251001: Move chrome/browser/gtk/ to chrome/browser/ui/gtk/... (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: '' Created 9 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 | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef CHROME_BROWSER_GTK_BROWSER_ACTIONS_TOOLBAR_GTK_H_ 5 #ifndef CHROME_BROWSER_GTK_BROWSER_ACTIONS_TOOLBAR_GTK_H_
6 #define CHROME_BROWSER_GTK_BROWSER_ACTIONS_TOOLBAR_GTK_H_ 6 #define CHROME_BROWSER_GTK_BROWSER_ACTIONS_TOOLBAR_GTK_H_
7 #pragma once 7 #pragma once
8 8
9 #include <map> 9 #include "chrome/browser/ui/gtk/browser_actions_toolbar_gtk.h"
10 #include <string> 10 // TODO(msw): remove this file once all includes have been updated.
11
12 #include "app/gtk_signal.h"
13 #include "app/gtk_signal_registrar.h"
14 #include "app/menus/simple_menu_model.h"
15 #include "base/linked_ptr.h"
16 #include "base/task.h"
17 #include "chrome/browser/extensions/extension_toolbar_model.h"
18 #include "chrome/browser/gtk/custom_button.h"
19 #include "chrome/browser/gtk/menu_gtk.h"
20 #include "chrome/browser/gtk/overflow_button.h"
21 #include "chrome/browser/gtk/owned_widget_gtk.h"
22 #include "chrome/common/notification_observer.h"
23 #include "chrome/common/notification_registrar.h"
24 #include "ui/base/animation/animation_delegate.h"
25 #include "ui/base/animation/slide_animation.h"
26
27 class Browser;
28 class BrowserActionButton;
29 class Extension;
30 class GtkThemeProvider;
31 class Profile;
32
33 typedef struct _GdkDragContext GdkDragContext;
34 typedef struct _GtkWidget GtkWidget;
35
36 class BrowserActionsToolbarGtk : public ExtensionToolbarModel::Observer,
37 public ui::AnimationDelegate,
38 public MenuGtk::Delegate,
39 public menus::SimpleMenuModel::Delegate,
40 public NotificationObserver {
41 public:
42 explicit BrowserActionsToolbarGtk(Browser* browser);
43 virtual ~BrowserActionsToolbarGtk();
44
45 GtkWidget* widget() { return hbox_.get(); }
46 GtkWidget* chevron() { return overflow_button_->widget(); }
47
48 // Returns the widget in use by the BrowserActionButton corresponding to
49 // |extension|. Used in positioning the ExtensionInstalledBubble for
50 // BrowserActions.
51 GtkWidget* GetBrowserActionWidget(const Extension* extension);
52
53 int button_count() { return extension_button_map_.size(); }
54
55 Browser* browser() { return browser_; }
56
57 // Returns the currently selected tab ID, or -1 if there is none.
58 int GetCurrentTabId();
59
60 // Update the display of all buttons.
61 void Update();
62
63 // NotificationObserver implementation.
64 virtual void Observe(NotificationType type,
65 const NotificationSource& source,
66 const NotificationDetails& details);
67
68 bool animating() {
69 return resize_animation_.is_animating();
70 }
71
72 private:
73 friend class BrowserActionButton;
74
75 // Initialize drag and drop.
76 void SetupDrags();
77
78 // Query the extensions service for all extensions with browser actions,
79 // and create the UI for them.
80 void CreateAllButtons();
81
82 // Sets the width of the container and overflow state according to the model.
83 void SetContainerWidth();
84
85 // Create the UI for a single browser action. This will stick the button
86 // at the end of the toolbar.
87 void CreateButtonForExtension(const Extension* extension, int index);
88
89 // Delete resources associated with UI for a browser action.
90 void RemoveButtonForExtension(const Extension* extension);
91
92 // Change the visibility of widget() based on whether we have any buttons
93 // to show.
94 void UpdateVisibility();
95
96 // Hide the extension popup, if any.
97 void HidePopup();
98
99 // Animate the toolbar to show the given number of icons. This assumes the
100 // visibility of the overflow button will not change.
101 void AnimateToShowNIcons(int count);
102
103 // Returns true if this extension should be shown in this toolbar. This can
104 // return false if we are in an incognito window and the extension is disabled
105 // for incognito.
106 bool ShouldDisplayBrowserAction(const Extension* extension);
107
108 // ExtensionToolbarModel::Observer implementation.
109 virtual void BrowserActionAdded(const Extension* extension, int index);
110 virtual void BrowserActionRemoved(const Extension* extension);
111 virtual void BrowserActionMoved(const Extension* extension, int index);
112 virtual void ModelLoaded();
113
114 // ui::AnimationDelegate implementation.
115 virtual void AnimationProgressed(const ui::Animation* animation);
116 virtual void AnimationEnded(const ui::Animation* animation);
117
118 // SimpleMenuModel::Delegate implementation.
119 // In our case, |command_id| is be the index into the model's extension list.
120 virtual bool IsCommandIdChecked(int command_id) const;
121 virtual bool IsCommandIdEnabled(int command_id) const;
122 virtual bool GetAcceleratorForCommandId(
123 int command_id,
124 menus::Accelerator* accelerator);
125 virtual void ExecuteCommand(int command_id);
126
127 // MenuGtk::Delegate implementation.
128 virtual void StoppedShowing();
129 virtual bool AlwaysShowIconForCmd(int command_id) const;
130
131 // Called by the BrowserActionButton in response to drag-begin.
132 void DragStarted(BrowserActionButton* button, GdkDragContext* drag_context);
133
134 // Sets the width of the button area of the toolbar to |new_width|, clamping
135 // it to appropriate values.
136 void SetButtonHBoxWidth(int new_width);
137
138 // Shows or hides the chevron as appropriate.
139 void UpdateChevronVisibility();
140
141 CHROMEGTK_CALLBACK_4(BrowserActionsToolbarGtk, gboolean, OnDragMotion,
142 GdkDragContext*, gint, gint, guint);
143 CHROMEGTK_CALLBACK_1(BrowserActionsToolbarGtk, void, OnDragEnd,
144 GdkDragContext*);
145 CHROMEGTK_CALLBACK_2(BrowserActionsToolbarGtk, gboolean, OnDragFailed,
146 GdkDragContext*, GtkDragResult);
147 CHROMEGTK_CALLBACK_1(BrowserActionsToolbarGtk, void, OnHierarchyChanged,
148 GtkWidget*);
149 CHROMEGTK_CALLBACK_1(BrowserActionsToolbarGtk, void, OnSetFocus, GtkWidget*);
150 CHROMEGTK_CALLBACK_1(BrowserActionsToolbarGtk, gboolean,
151 OnGripperMotionNotify, GdkEventMotion*);
152 CHROMEGTK_CALLBACK_1(BrowserActionsToolbarGtk, gboolean, OnGripperExpose,
153 GdkEventExpose*);
154 CHROMEGTK_CALLBACK_1(BrowserActionsToolbarGtk, gboolean,
155 OnGripperEnterNotify, GdkEventCrossing*);
156 CHROMEGTK_CALLBACK_1(BrowserActionsToolbarGtk, gboolean,
157 OnGripperLeaveNotify, GdkEventCrossing*);
158 CHROMEGTK_CALLBACK_1(BrowserActionsToolbarGtk, gboolean,
159 OnGripperButtonRelease, GdkEventButton*);
160 CHROMEGTK_CALLBACK_1(BrowserActionsToolbarGtk, gboolean,
161 OnGripperButtonPress, GdkEventButton*);
162 // The overflow button is pressed.
163 CHROMEGTK_CALLBACK_1(BrowserActionsToolbarGtk, gboolean,
164 OnOverflowButtonPress, GdkEventButton*);
165 // The user presses a mouse button over the popped up overflow menu.
166 CHROMEGTK_CALLBACK_1(BrowserActionsToolbarGtk, gboolean,
167 OnOverflowMenuButtonPress, GdkEventButton*);
168 CHROMEGTK_CALLBACK_0(BrowserActionsToolbarGtk, void, OnButtonShowOrHide);
169
170 Browser* browser_;
171
172 Profile* profile_;
173 GtkThemeProvider* theme_provider_;
174
175 ExtensionToolbarModel* model_;
176
177 // Contains the drag gripper, browser action buttons, and overflow chevron.
178 OwnedWidgetGtk hbox_;
179
180 // Contains the browser action buttons.
181 OwnedWidgetGtk button_hbox_;
182
183 // The overflow button for chrome theme mode.
184 scoped_ptr<CustomDrawButton> overflow_button_;
185 // The separator just next to the overflow button. Only shown in GTK+ theme
186 // mode. In Chrome theme mode, the overflow button has a separator built in.
187 GtkWidget* separator_;
188 scoped_ptr<MenuGtk> overflow_menu_;
189 scoped_ptr<menus::SimpleMenuModel> overflow_menu_model_;
190 GtkWidget* overflow_area_;
191 // A widget for adding extra padding to the left of the overflow button.
192 GtkWidget* overflow_alignment_;
193
194 // The button that is currently being dragged, or NULL.
195 BrowserActionButton* drag_button_;
196
197 // The new position of the button in the drag, or -1.
198 int drop_index_;
199
200 // Map from extension ID to BrowserActionButton, which is a wrapper for
201 // a chrome button and related functionality. There should be one entry
202 // for every extension that has a browser action.
203 typedef std::map<std::string, linked_ptr<BrowserActionButton> >
204 ExtensionButtonMap;
205 ExtensionButtonMap extension_button_map_;
206
207 // We use this animation for the smart resizing of the toolbar.
208 ui::SlideAnimation resize_animation_;
209 // This is the final width we are animating towards.
210 int desired_width_;
211 // This is the width we were at when we started animating.
212 int start_width_;
213
214 GtkSignalRegistrar signals_;
215
216 NotificationRegistrar registrar_;
217
218 ScopedRunnableMethodFactory<BrowserActionsToolbarGtk> method_factory_;
219
220 DISALLOW_COPY_AND_ASSIGN(BrowserActionsToolbarGtk);
221 };
222 11
223 #endif // CHROME_BROWSER_GTK_BROWSER_ACTIONS_TOOLBAR_GTK_H_ 12 #endif // CHROME_BROWSER_GTK_BROWSER_ACTIONS_TOOLBAR_GTK_H_
OLDNEW
« no previous file with comments | « chrome/browser/gtk/bookmark_utils_gtk_unittest.cc ('k') | chrome/browser/gtk/browser_actions_toolbar_gtk.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698