chromium/ash/style/color_util.h

// Copyright 2022 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_COLOR_UTIL_H_
#define ASH_STYLE_COLOR_UTIL_H_

#include "ash/ash_export.h"
#include "ui/color/color_provider_source.h"

namespace aura {
class Window;
}  // namespace aura

namespace ash {

// Note: Please stop adding functions to this file. Adding them to
// ash/style/style_util.h file instead. As we are going to merge this class to
// StyleUtil soon.
// TODO(b/279613862): Merging this file to ash/style/style_util.h.
class ASH_EXPORT ColorUtil {
 public:
  // Returns the color provider source for the given `window` if it has
  // has a root window, otherwise returns nullptr.
  static ui::ColorProviderSource* GetColorProviderSourceForWindow(
      const aura::Window* window);

  // Returns an adjusted k means color. For dark mode, it will be dark muted
  // wallpaper prominent color + SK_ColorBLACK 50%. For light mode, it will be
  // light muted wallpaper prominent color + SK_ColorWHITE 50%. Extracts the
  // color on dark mode if `use_dark_color` is true.
  static SkColor AdjustKMeansColor(SkColor k_means_color, bool use_dark_color);

  // Gets the disabled color on |enabled_color|. It can be a disabled
  // background, disabled icon, etc.
  static SkColor GetDisabledColor(SkColor enabled_color);

  // Gets the color of second tone on the given |color_of_first_tone|. e.g,
  // power status icon inside status area is a dual tone icon.
  static SkColor GetSecondToneColor(SkColor color_of_first_tone);

 private:
  ColorUtil() = default;
  ColorUtil(const ColorUtil&) = delete;
  ColorUtil& operator=(const ColorUtil&) = delete;
  ~ColorUtil() = default;
};

}  // namespace ash

#endif  // ASH_STYLE_COLOR_UTIL_H_