summaryrefslogtreecommitdiff
path: root/src/tangara/input/input_hook_actions.cpp
diff options
context:
space:
mode:
authorcooljqln <cooljqln@noreply.codeberg.org>2024-05-03 04:48:17 +0000
committercooljqln <cooljqln@noreply.codeberg.org>2024-05-03 04:48:17 +0000
commit3ceb8025ee4330c177101ed30ec17dfb0002f41e (patch)
tree58350210f15df7d00d967cac6f30eeceeb031a3c /src/tangara/input/input_hook_actions.cpp
parent964da15a0b84f8e5f00e8abac2f7dfda0bf60488 (diff)
parent9fafd797a5504f458b5fcae4a1d28a68da936315 (diff)
downloadtangara-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.cpp73
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