- add sources.
[platform/framework/web/crosswalk.git] / src / chrome / browser / ui / views / infobars / infobar_view.h
1 // Copyright (c) 2012 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 #ifndef CHROME_BROWSER_UI_VIEWS_INFOBARS_INFOBAR_VIEW_H_
6 #define CHROME_BROWSER_UI_VIEWS_INFOBARS_INFOBAR_VIEW_H_
7
8 #include "base/basictypes.h"
9 #include "base/compiler_specific.h"
10 #include "chrome/browser/infobars/infobar.h"
11 #include "chrome/browser/infobars/infobar_container.h"
12 #include "third_party/skia/include/core/SkPath.h"
13 #include "ui/views/controls/button/button.h"
14 #include "ui/views/controls/menu/menu_item_view.h"
15 #include "ui/views/focus/external_focus_tracker.h"
16
17 namespace ui {
18 class MenuModel;
19 }
20 namespace views {
21 class ImageButton;
22 class ImageView;
23 class Label;
24 class LabelButton;
25 class Link;
26 class LinkListener;
27 class MenuButton;
28 class MenuButtonListener;
29 class MenuRunner;
30 }
31
32 class InfoBarView : public InfoBar,
33                     public views::View,
34                     public views::ButtonListener,
35                     public views::ExternalFocusTracker {
36  public:
37   InfoBarView(InfoBarService* owner, InfoBarDelegate* delegate);
38
39   const SkPath& fill_path() const { return fill_path_; }
40   const SkPath& stroke_path() const { return stroke_path_; }
41
42  protected:
43   static const int kButtonButtonSpacing;
44   static const int kEndOfLabelSpacing;
45
46   virtual ~InfoBarView();
47
48   // Creates a label with the appropriate font and color for an infobar.
49   views::Label* CreateLabel(const string16& text) const;
50
51   // Creates a link with the appropriate font and color for an infobar.
52   // NOTE: Subclasses must ignore link clicks if we're unowned.
53   views::Link* CreateLink(const string16& text,
54                           views::LinkListener* listener) const;
55
56   // Creates a menu button with an infobar-specific appearance.
57   // NOTE: Subclasses must ignore button presses if we're unowned.
58   static views::MenuButton* CreateMenuButton(
59       const string16& text,
60       views::MenuButtonListener* menu_button_listener);
61
62   // Creates a button with an infobar-specific appearance.
63   // NOTE: Subclasses must ignore button presses if we're unowned.
64   static views::LabelButton* CreateLabelButton(views::ButtonListener* listener,
65                                                const string16& text,
66                                                bool needs_elevation);
67
68   // views::View:
69   virtual void Layout() OVERRIDE;
70   virtual void ViewHierarchyChanged(
71       const ViewHierarchyChangedDetails& details) OVERRIDE;
72
73   // views::ButtonListener:
74   // NOTE: This must not be called if we're unowned.  (Subclasses should ignore
75   // calls to ButtonPressed() in this case.)
76   virtual void ButtonPressed(views::Button* sender,
77                              const ui::Event& event) OVERRIDE;
78
79   // Returns the minimum width the content (that is, everything between the icon
80   // and the close button) can be shrunk to.  This is used to prevent the close
81   // button from overlapping views that cannot be shrunk any further.
82   virtual int ContentMinimumWidth() const;
83
84   // These return x coordinates delimiting the usable area for subclasses to lay
85   // out their controls.
86   int StartX() const;
87   int EndX() const;
88
89   // Convenience getter.
90   const InfoBarContainer::Delegate* container_delegate() const;
91
92   // Shows a menu at the specified position.
93   // NOTE: This must not be called if we're unowned.  (Subclasses should ignore
94   // calls to RunMenu() in this case.)
95   void RunMenuAt(ui::MenuModel* menu_model,
96                  views::MenuButton* button,
97                  views::MenuItemView::AnchorPosition anchor);
98
99  private:
100   static const int kHorizontalPadding;
101
102   // InfoBar:
103   virtual void PlatformSpecificShow(bool animate) OVERRIDE;
104   virtual void PlatformSpecificHide(bool animate) OVERRIDE;
105   virtual void PlatformSpecificOnHeightsRecalculated() OVERRIDE;
106
107   // views::View:
108   virtual void GetAccessibleState(ui::AccessibleViewState* state) OVERRIDE;
109   virtual gfx::Size GetPreferredSize() OVERRIDE;
110   virtual void PaintChildren(gfx::Canvas* canvas) OVERRIDE;
111
112   // views::ExternalFocusTracker:
113   virtual void OnWillChangeFocus(View* focused_before,
114                                  View* focused_now) OVERRIDE;
115
116   // The optional icon at the left edge of the InfoBar.
117   views::ImageView* icon_;
118
119   // The close button at the right edge of the InfoBar.
120   views::ImageButton* close_button_;
121
122   // The paths for the InfoBarBackground to draw, sized according to the heights
123   // above.
124   SkPath fill_path_;
125   SkPath stroke_path_;
126
127   // Used to run the menu.
128   scoped_ptr<views::MenuRunner> menu_runner_;
129
130   DISALLOW_COPY_AND_ASSIGN(InfoBarView);
131 };
132
133 #endif  // CHROME_BROWSER_UI_VIEWS_INFOBARS_INFOBAR_VIEW_H_