blob: 0412752cacfeef0acd35c70f56aa129db04ab175 [file]
// Copyright 2016 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_COMMON_SYSTEM_TRAY_TRAY_POPUP_UTILS_H_
#define ASH_COMMON_SYSTEM_TRAY_TRAY_POPUP_UTILS_H_
#include "ash/common/login_status.h"
#include "ash/common/system/tray/tri_view.h"
#include "base/strings/string16.h"
namespace views {
class ButtonListener;
class ImageView;
class Label;
class LabelButton;
class LayoutManager;
class Separator;
class Slider;
class SliderListener;
} // namespace views
namespace ash {
// Factory/utility functions used by the system menu.
class TrayPopupUtils {
public:
// Creates a default container view to be used most system menu rows. The
// caller takes over ownership of the created view.
//
// The returned view consists of 3 regions: START, CENTER, and END. Any child
// Views added to the START and END containers will be added horizonatlly and
// any Views added to the CENTER container will be added vertically.
//
// The START and END containers have a fixed width but can grow into the
// CENTER container if space is required and available.
//
// The CENTER container has a flexible width.
static TriView* CreateDefaultRowView();
// Creates the default layout manager by CreateDefault() row for the given
// |container|. To be used when mutliple targetable areas are required within
// a single row.
static std::unique_ptr<views::LayoutManager> CreateLayoutManager(
TriView::Container container);
// Returns a label that has been configured for system menu layout. This
// should be used by all rows that require a label, i.e. both default and
// detailed rows should use this.
//
// TODO(bruthig): Update all system menu rows to use this.
static views::Label* CreateDefaultLabel();
// Returns an image view to be used for the main image of a system menu row.
// This should be used by all rows that have a main image, i.e. both default
// and detailed rows should use this.
//
// TODO(bruthig): Update all system menu rows to use this.
static views::ImageView* CreateMainImageView();
// Returns an image view to be used for the 'more' arrow image on rows. In
// general this applies to all rows in the system menu that have a 'more'
// image however most, if not all, are default rows.
//
// TODO(bruthig): Update all default rows to use this.
static views::ImageView* CreateMoreImageView();
// Creates a button for use in the system menu that only has a visible border
// when being hovered/clicked. Caller assumes ownership.
static views::LabelButton* CreateTrayPopupBorderlessButton(
views::ButtonListener* listener,
const base::string16& text);
// Creates a button for use in the system menu. For MD, this is a prominent
// text
// button. For non-MD, this does the same thing as the above. Caller assumes
// ownership.
static views::LabelButton* CreateTrayPopupButton(
views::ButtonListener* listener,
const base::string16& text);
// Creates and returns a vertical separator to be used between two items in a
// material design system menu row. The caller assumes ownership of the
// returned separator.
static views::Separator* CreateVerticalSeparator();
// Returns true if it is possible to open WebUI settings in a browser window,
// i.e., the user is logged in, not on the lock screen, and not in a secondary
// account flow.
static bool CanOpenWebUISettings(LoginStatus status);
private:
TrayPopupUtils() = delete;
~TrayPopupUtils() = delete;
// Configures the specified |container| view with the default layout. Used by
// CreateDefaultRowView().
static void ConfigureDefaultLayout(TriView* tri_view,
TriView::Container container);
};
} // namespace ash
#endif // ASH_COMMON_SYSTEM_TRAY_TRAY_POPUP_UTILS_H_