// Copyright 2014 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef ASH_SYSTEM_USER_BUTTON_FROM_VIEW_H_ #define ASH_SYSTEM_USER_BUTTON_FROM_VIEW_H_ #include "base/macros.h" #include "ui/views/controls/button/custom_button.h" namespace ash { namespace tray { // This view is used to wrap it's content and transform it into button. class ButtonFromView : public views::CustomButton { public: ButtonFromView(views::View* content, views::ButtonListener* listener, bool highlight_on_hover); virtual ~ButtonFromView(); // Called when the border should remain even in the non highlighted state. void ForceBorderVisible(bool show); // Overridden from views::View virtual void OnMouseEntered(const ui::MouseEvent& event) OVERRIDE; virtual void OnMouseExited(const ui::MouseEvent& event) OVERRIDE; // Check if the item is hovered. bool is_hovered_for_test() { return button_hovered_; } private: // Change the hover/active state of the "button" when the status changes. void ShowActive(); // Content of button. views::View* content_; // Whether button should be highligthed on hover. bool highlight_on_hover_; // True if button is hovered. bool button_hovered_; // True if the border should be always visible. bool show_border_; DISALLOW_COPY_AND_ASSIGN(ButtonFromView); }; } // namespace tray } // namespace ash #endif // ASH_SYSTEM_USER_BUTTON_FROM_VIEW_H_