blob: 4d0ab8b60c2d3554c8e6926ef83d1d54867d2aa9 [file] [log] [blame]
// Copyright 2015 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 UI_BASE_MATERIAL_DESIGN_MATERIAL_DESIGN_CONTROLLER_H_
#define UI_BASE_MATERIAL_DESIGN_MATERIAL_DESIGN_CONTROLLER_H_
#include "base/macros.h"
#include "ui/base/ui_base_export.h"
namespace ui {
namespace test {
class MaterialDesignControllerTestAPI;
} // namespace test
// Central controller to handle material design modes.
class UI_BASE_EXPORT MaterialDesignController {
public:
// The different material design modes. The order cannot be changed without
// updating references as these are used as array indices.
enum Mode {
// Basic material design.
MATERIAL_NORMAL = 0,
// Material design targeted at mouse/touch hybrid devices.
MATERIAL_HYBRID = 1,
// Material design that is more optimized for touch devices.
MATERIAL_TOUCH_OPTIMIZED = 2,
// Material Refresh design targeted at mouse devices.
MATERIAL_REFRESH = 3,
// Material Refresh design optimized for touch devices.
MATERIAL_TOUCH_REFRESH = 4,
};
// Initializes |mode_|. Must be called before checking |mode_|.
static void Initialize();
// Get the current Mode that should be used by the system.
static Mode GetMode();
// Returns true if the current mode is a material design variant and this mode
// should be extended to cover secondary UI.
static bool IsSecondaryUiMaterial();
// Returns true if the touch-optimized UI material design mode is enabled.
static bool IsTouchOptimizedUiEnabled();
// Returns true if the Material Refresh or touch-optimized UI is enabled.
static bool IsNewerMaterialUi();
// Returns true if any Material Refresh mode is enabled.
static bool IsRefreshUi();
// Returns the per-platform default material design variant.
static Mode DefaultMode();
static bool is_mode_initialized() { return is_mode_initialized_; }
private:
friend class test::MaterialDesignControllerTestAPI;
// Tracks whether |mode_| has been initialized. This is necessary to avoid
// checking the |mode_| early in initialization before a call to Initialize().
// Tests can use it to reset the state back to a clean state during tear down.
static bool is_mode_initialized_;
// The current Mode to be used by the system.
static Mode mode_;
// Declarations only. Do not allow construction of an object.
MaterialDesignController();
~MaterialDesignController();
// Resets the initialization state to uninitialized. To be used by tests to
// allow calling Initialize() more than once.
static void Uninitialize();
// Set |mode_| to |mode| and updates |is_mode_initialized_| to true. Can be
// used by tests to directly set the mode.
static void SetMode(Mode mode);
DISALLOW_COPY_AND_ASSIGN(MaterialDesignController);
};
} // namespace ui
#endif // UI_BASE_MATERIAL_DESIGN_MATERIAL_DESIGN_CONTROLLER_H_