Implement listing tests to a JSON file for iOS gtest test launcher
[chromium-blink-merge.git] / ash / system / tray / hover_highlight_view.h
blob2b736ceebd3435f36e7cf6f6125b4617e19359f9
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 ASH_SYSTEM_TRAY_HOVER_HIGHLIGHT_VIEW_H_
6 #define ASH_SYSTEM_TRAY_HOVER_HIGHLIGHT_VIEW_H_
8 #include "ash/system/tray/actionable_view.h"
9 #include "base/basictypes.h"
10 #include "base/compiler_specific.h"
11 #include "ui/gfx/font.h"
12 #include "ui/gfx/text_constants.h"
14 namespace views {
15 class Label;
18 namespace ash {
19 class ViewClickListener;
21 // A view that changes background color on hover, and triggers a callback in the
22 // associated ViewClickListener on click. The view can also be forced to
23 // maintain a fixed height.
24 class HoverHighlightView : public ActionableView {
25 public:
26 explicit HoverHighlightView(ViewClickListener* listener);
27 ~HoverHighlightView() override;
29 // Convenience function for adding an icon and a label. This also sets the
30 // accessible name.
31 void AddIconAndLabel(const gfx::ImageSkia& image,
32 const base::string16& text,
33 gfx::Font::FontStyle style);
35 // Convenience function for adding a label with padding on the left for a
36 // blank icon. This also sets the accessible name.
37 // Returns label after parenting it.
38 views::Label* AddLabel(const base::string16& text,
39 gfx::HorizontalAlignment alignment,
40 gfx::Font::FontStyle style);
42 // Convenience function for adding an optional check and a label. In the
43 // absence of a check, padding is added to align with checked items.
44 // Returns label after parenting it.
45 views::Label* AddCheckableLabel(const base::string16& text,
46 gfx::Font::FontStyle style,
47 bool checked);
49 // Allows view to expand its height.
50 // Size of unexapandable view is fixed and equals to kTrayPopupItemHeight.
51 void SetExpandable(bool expandable);
53 void set_highlight_color(SkColor color) { highlight_color_ = color; }
54 void set_default_color(SkColor color) { default_color_ = color; }
55 void set_text_highlight_color(SkColor c) { text_highlight_color_ = c; }
56 void set_text_default_color(SkColor color) { text_default_color_ = color; }
58 views::Label* text_label() { return text_label_; }
60 bool hover() const { return hover_; }
62 protected:
63 // Overridden from views::View.
64 void GetAccessibleState(ui::AXViewState* state) override;
66 private:
67 // Sets the highlighted color on a text label if |hover| is set.
68 void SetHoverHighlight(bool hover);
70 // Overridden from ActionableView:
71 bool PerformAction(const ui::Event& event) override;
73 // Overridden from views::View.
74 gfx::Size GetPreferredSize() const override;
75 int GetHeightForWidth(int width) const override;
76 void OnMouseEntered(const ui::MouseEvent& event) override;
77 void OnMouseExited(const ui::MouseEvent& event) override;
78 void OnGestureEvent(ui::GestureEvent* event) override;
79 void OnEnabledChanged() override;
80 void OnPaintBackground(gfx::Canvas* canvas) override;
81 void OnFocus() override;
83 ViewClickListener* listener_;
84 views::Label* text_label_;
85 SkColor highlight_color_;
86 SkColor default_color_;
87 SkColor text_highlight_color_;
88 SkColor text_default_color_;
89 bool hover_;
90 bool expandable_;
91 bool checkable_;
92 bool checked_;
94 DISALLOW_COPY_AND_ASSIGN(HoverHighlightView);
97 } // namespace ash
99 #endif // ASH_SYSTEM_TRAY_HOVER_HIGHLIGHT_VIEW_H_