1 // Copyright 2014 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_USER_BUTTON_FROM_VIEW_H_
6 #define ASH_SYSTEM_USER_BUTTON_FROM_VIEW_H_
8 #include "base/macros.h"
9 #include "ui/gfx/geometry/insets.h"
10 #include "ui/views/controls/button/custom_button.h"
15 // This view is used to wrap it's content and transform it into button.
16 class ButtonFromView
: public views::CustomButton
{
18 // The |content| is the content which is shown within the button. The
19 // |button_listener| will be informed - if provided - when a button was
20 // pressed. If |highlight_on_hover| is set to true, the button will be
21 // highlighted upon hover and show the accessibility caret.
22 // The |tab_frame_inset| will be used to inset the blue tab frame inside the
24 ButtonFromView(views::View
* content
,
25 views::ButtonListener
* listener
,
26 bool highlight_on_hover
,
27 const gfx::Insets
& tab_frame_inset
);
28 ~ButtonFromView() override
;
30 // Called when the border should remain even in the non highlighted state.
31 void ForceBorderVisible(bool show
);
33 // Overridden from views::View
34 void OnMouseEntered(const ui::MouseEvent
& event
) override
;
35 void OnMouseExited(const ui::MouseEvent
& event
) override
;
36 void OnPaint(gfx::Canvas
* canvas
) override
;
37 void OnFocus() override
;
38 void OnBlur() override
;
40 // Check if the item is hovered.
41 bool is_hovered_for_test() { return button_hovered_
; }
44 // Change the hover/active state of the "button" when the status changes.
48 views::View
* content_
;
50 // Whether button should be highligthed on hover.
51 bool highlight_on_hover_
;
53 // True if button is hovered.
56 // True if the border should be always visible.
59 // The insets which get used for the drawn accessibility (tab) frame.
60 gfx::Insets tab_frame_inset_
;
62 DISALLOW_COPY_AND_ASSIGN(ButtonFromView
);
68 #endif // ASH_SYSTEM_USER_BUTTON_FROM_VIEW_H_