diff options
| author | cooljqln <cooljqln@noreply.codeberg.org> | 2024-05-03 04:48:17 +0000 |
|---|---|---|
| committer | cooljqln <cooljqln@noreply.codeberg.org> | 2024-05-03 04:48:17 +0000 |
| commit | 3ceb8025ee4330c177101ed30ec17dfb0002f41e (patch) | |
| tree | 58350210f15df7d00d967cac6f30eeceeb031a3c /src/tangara/input/input_hook_actions.cpp | |
| parent | 964da15a0b84f8e5f00e8abac2f7dfda0bf60488 (diff) | |
| parent | 9fafd797a5504f458b5fcae4a1d28a68da936315 (diff) | |
| download | tangara-fw-3ceb8025ee4330c177101ed30ec17dfb0002f41e.tar.gz | |
Merge pull request 'Break dependency cycles with our components by merging co-dependent components together' (#68) from jqln/component-merge into main
Reviewed-on: https://codeberg.org/cool-tech-zone/tangara-fw/pulls/68
Diffstat (limited to 'src/tangara/input/input_hook_actions.cpp')
| -rw-r--r-- | src/tangara/input/input_hook_actions.cpp | 73 |
1 files changed, 73 insertions, 0 deletions
diff --git a/src/tangara/input/input_hook_actions.cpp b/src/tangara/input/input_hook_actions.cpp new file mode 100644 index 00000000..bc3760ac --- /dev/null +++ b/src/tangara/input/input_hook_actions.cpp @@ -0,0 +1,73 @@ +/* + * Copyright 2024 jacqueline <me@jacqueline.id.au> + * + * SPDX-License-Identifier: GPL-3.0-only + */ + +#include "input/input_hook_actions.hpp" + +#include <cstdint> + +#include "hal/lv_hal_indev.h" + +#include "events/event_queue.hpp" +#include "ui/ui_events.hpp" + +namespace input { +namespace actions { + +auto select() -> HookCallback { + return HookCallback{.name = "select", .fn = [&](lv_indev_data_t* d) { + d->state = LV_INDEV_STATE_PRESSED; + }}; +} + +auto scrollUp() -> HookCallback { + return HookCallback{.name = "scroll_up", + .fn = [&](lv_indev_data_t* d) { d->enc_diff = -1; }}; +} + +auto scrollDown() -> HookCallback { + return HookCallback{.name = "scroll_down", + .fn = [&](lv_indev_data_t* d) { d->enc_diff = 1; }}; +} + +auto scrollToTop() -> HookCallback { + return HookCallback{.name = "scroll_to_top", .fn = [&](lv_indev_data_t* d) { + d->enc_diff = INT16_MIN; + }}; +} + +auto scrollToBottom() -> HookCallback { + return HookCallback{ + .name = "scroll_to_bottom", + .fn = [&](lv_indev_data_t* d) { d->enc_diff = INT16_MAX; }}; +} + +auto goBack() -> HookCallback { + return HookCallback{.name = "back", .fn = [&](lv_indev_data_t* d) { + events::Ui().Dispatch(ui::internal::BackPressed{}); + }}; +} + +auto volumeUp() -> HookCallback { + return HookCallback{.name = "volume_up", .fn = [&](lv_indev_data_t* d) { + events::Audio().Dispatch(audio::StepUpVolume{}); + }}; +} + +auto volumeDown() -> HookCallback { + return HookCallback{.name = "volume_down", .fn = [&](lv_indev_data_t* d) { + events::Audio().Dispatch(audio::StepDownVolume{}); + }}; +} + +auto allActions() -> std::vector<HookCallback> { + return { + select(), scrollUp(), scrollDown(), scrollToTop(), + scrollToBottom(), goBack(), volumeUp(), volumeDown(), + }; +} + +} // namespace actions +} // namespace input |
