chromium/ash/system/keyboard_brightness_control_delegate.h

// Copyright 2012 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_SYSTEM_KEYBOARD_BRIGHTNESS_CONTROL_DELEGATE_H_
#define ASH_SYSTEM_KEYBOARD_BRIGHTNESS_CONTROL_DELEGATE_H_

#include <optional>

#include "base/functional/callback_forward.h"

namespace ash {

// Enum to represent the source of a keyboard brightness change.
enum class KeyboardBrightnessChangeSource {
  kQuickSettings = 0,
  kSettingsApp = 1,
  kRestoredFromUserPref = 2,
  kMaxValue = kRestoredFromUserPref,
};

// Enum to represent the source of a keyboard ambient light sensor enabled
// change. Note that changing keyboard brightness can also disable the
// KeyboardAmbient Light Sensor. This change is not directly made by calling the
// HandleSetKeyboardAmbientLightSensorEnabled function in Chrome, it is handled
// in the platform.
enum class KeyboardAmbientLightSensorEnabledChangeSource {
  kSettingsApp = 0,
  kRestoredFromUserPref = 1,
  kSystemReenabled = 2,
  kMaxValue = kSystemReenabled,
};

// Delegate for controlling the keyboard brightness.
class KeyboardBrightnessControlDelegate {
 public:
  virtual ~KeyboardBrightnessControlDelegate() {}

  // Handles an accelerator-driven request to decrease or increase the keyboard
  // brightness.
  virtual void HandleKeyboardBrightnessDown() = 0;
  virtual void HandleKeyboardBrightnessUp() = 0;

  // Request that to turn keyboard brightness on or off.
  virtual void HandleToggleKeyboardBacklight() = 0;

  // Requests that the keyboard brightness be set to |percent|, in the range
  // [0.0, 100.0].  |gradual| specifies whether the transition to the new
  // brightness should be animated or instantaneous.
  virtual void HandleSetKeyboardBrightness(
      double percent,
      bool gradual,
      KeyboardBrightnessChangeSource source) = 0;

  // Asynchronously invokes |callback| with the current brightness, in the range
  // [0.0, 100.0]. In case of error, it is called with nullopt.
  virtual void HandleGetKeyboardBrightness(
      base::OnceCallback<void(std::optional<double>)> callback) = 0;

  // Sets whether the ambient light sensor should be used in keyboard brightness
  // calculations.
  virtual void HandleSetKeyboardAmbientLightSensorEnabled(
      bool enabled,
      KeyboardAmbientLightSensorEnabledChangeSource source) = 0;

  // Asynchronously invokes |callback| with the current keyboard ambient light
  // enabled status, In case of error, it is called with nullopt.
  virtual void HandleGetKeyboardAmbientLightSensorEnabled(
      base::OnceCallback<void(std::optional<bool>)> callback) = 0;
};

}  // namespace ash

#endif  // ASH_SYSTEM_KEYBOARD_BRIGHTNESS_CONTROL_DELEGATE_H_