Roll src/third_party/WebKit d9c6159:8139f33 (svn 201974:201975)
[chromium-blink-merge.git] / chrome / browser / ui / views / toolbar / back_button.h
blob4aa7a43a8db61f4b00343f9a0b5368c293381d46
1 // Copyright 2013 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.
5 #ifndef CHROME_BROWSER_UI_VIEWS_TOOLBAR_BACK_BUTTON_H_
6 #define CHROME_BROWSER_UI_VIEWS_TOOLBAR_BACK_BUTTON_H_
8 #include "chrome/browser/ui/views/toolbar/toolbar_button.h"
10 namespace ui {
11 class MenuModel;
14 namespace views {
15 class Border;
16 class ButtonListener;
19 // A subclass of ToolbarButton to allow the back button's hittest region to
20 // extend all the way to the start of the toolbar (i.e. the screen edge) in
21 // maximized mode, to benefit from Fitt's Law. The button images and focus
22 // border are still drawn with the normal square shape.
23 class BackButton : public ToolbarButton {
24 public:
25 // Takes ownership of the |model|, which can be null if no menu
26 // is to be shown.
27 BackButton(views::ButtonListener* listener, ui::MenuModel* model);
28 ~BackButton() override;
30 void SetLeadingMargin(int margin);
32 protected:
33 // ToolbarButton:
34 void LayoutInkDrop() override;
36 private:
37 // ToolbarButton:
38 const char* GetClassName() const override;
39 scoped_ptr<views::LabelButtonBorder> CreateDefaultBorder() const override;
40 gfx::Rect GetThemePaintRect() const override;
42 // Any leading margin to be applied. Used when the back button is in
43 // a maximized state to extend to the full window width.
44 int margin_leading_;
46 DISALLOW_COPY_AND_ASSIGN(BackButton);
49 #endif // CHROME_BROWSER_UI_VIEWS_TOOLBAR_BACK_BUTTON_H_