// Copyright 2019 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef ASH_STYLE_ASH_COLOR_PROVIDER_H_
#define ASH_STYLE_ASH_COLOR_PROVIDER_H_
#include "ash/ash_export.h"
#include "ash/public/cpp/style/color_provider.h"
#include "base/functional/callback_helpers.h"
#include "third_party/skia/include/core/SkColor.h"
#include "ui/gfx/color_palette.h"
namespace ui {
class ColorProvider;
}
namespace ash {
// TODO(minch): AshColorProvider is not needed to be a class now.
// The color provider for system UI. It provides colors for Shield layer, Base
// layer, Controls layer and Content layer. Shield layer is a combination of
// color, opacity and blur which may change depending on the context, it is
// usually a fullscreen layer. e.g, PowerButtoneMenuScreenView for power button
// menu. Base layer is the bottom layer of any UI displayed on top of all other
// UIs. e.g, the ShelfView that contains all the shelf items. Controls layer is
// where components such as icons and inkdrops lay on, it may also indicate the
// state of an interactive element (active/inactive states). Content layer means
// the UI elements, e.g., separator, text, icon. The color of an element in
// system UI will be the combination of the colors of the four layers.
class ASH_EXPORT AshColorProvider : public ColorProvider {
public:
AshColorProvider();
AshColorProvider(const AshColorProvider& other) = delete;
AshColorProvider operator=(const AshColorProvider& other) = delete;
~AshColorProvider() override;
static AshColorProvider* Get();
// ColorProvider:
SkColor GetControlsLayerColor(ControlsLayerType type) const override;
SkColor GetContentLayerColor(ContentLayerType type) const override;
std::pair<SkColor, float> GetInkDropBaseColorAndOpacity(
SkColor background_color = gfx::kPlaceholderColor) const override;
// Gets the background color that can be applied on any layer. The returned
// color will be different based on color mode and color theme (see
// |is_themed_|).
SkColor GetBackgroundColor() const;
private:
// Returns a ColorProvider for the current NativeTheme which will correctly
// reflect the current ColorMode.
ui::ColorProvider* GetColorProvider() const;
};
} // namespace ash
#endif // ASH_STYLE_ASH_COLOR_PROVIDER_H_