| Index: ash/common/system/tray/tray_popup_utils.h
|
| diff --git a/ash/common/system/tray/tray_popup_utils.h b/ash/common/system/tray/tray_popup_utils.h
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..82da40f2907632acae01825a17e8bb93f672f05c
|
| --- /dev/null
|
| +++ b/ash/common/system/tray/tray_popup_utils.h
|
| @@ -0,0 +1,78 @@
|
| +// 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/system/tray/tri_view.h"
|
| +#include "base/strings/string16.h"
|
| +
|
| +namespace views {
|
| +class ButtonListener;
|
| +class ImageView;
|
| +class Label;
|
| +class LabelButton;
|
| +class LayoutManager;
|
| +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();
|
| +
|
| + 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_
|
|
|