// 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_