diff options
| author | lukeflo | 2024-10-03 00:15:20 +0200 |
|---|---|---|
| committer | lukeflo | 2024-10-03 00:15:20 +0200 |
| commit | 790b7633f8405be847ced2862cbd7032ef285951 (patch) | |
| tree | b5c1805bd46e4c50f3a7ae32b5461effe5a63a31 /src/frontend/event.rs | |
| parent | 36f01f65b1804125e7d18a17ce57205248e1b7fd (diff) | |
| download | bibiman-790b7633f8405be847ced2862cbd7032ef285951.tar.gz bibiman-790b7633f8405be847ced2862cbd7032ef285951.zip | |
further reodering of tui process, removed event.rs (integrated into tui.rs)
Diffstat (limited to 'src/frontend/event.rs')
| -rw-r--r-- | src/frontend/event.rs | 111 |
1 files changed, 0 insertions, 111 deletions
diff --git a/src/frontend/event.rs b/src/frontend/event.rs deleted file mode 100644 index 65b61f1..0000000 --- a/src/frontend/event.rs +++ /dev/null @@ -1,111 +0,0 @@ -// bibiman - a TUI for managing BibLaTeX databases -// Copyright (C) 2024 lukeflo -// -// This program is free software: you can redistribute it and/or modify -// it under the terms of the GNU General Public License as published by -// the Free Software Foundation, either version 3 of the License, or -// (at your option) any later version. -// -// This program is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -// GNU General Public License for more details. -// -// You should have received a copy of the GNU General Public License -// along with this program. If not, see <https://www.gnu.org/licenses/>. -///// - -use std::time::Duration; - -use color_eyre::eyre::{OptionExt, Result}; -use crossterm::event::{Event as CrosstermEvent, KeyEvent, MouseEvent}; -use futures::{FutureExt, StreamExt}; -use tokio::sync::mpsc; - -/// Terminal events. -#[derive(Clone, Copy, Debug)] -pub enum Event { - /// Terminal tick. - Tick, - /// Key press. - Key(KeyEvent), - /// Mouse click/scroll. - Mouse(MouseEvent), - /// Terminal resize. - Resize(u16, u16), -} - -/// Terminal event handler. -#[allow(dead_code)] -#[derive(Debug)] -pub struct EventHandler { - /// Event sender channel. - sender: mpsc::UnboundedSender<Event>, - /// Event receiver channel. - receiver: mpsc::UnboundedReceiver<Event>, - /// Event handler thread. - handler: tokio::task::JoinHandle<()>, -} - -impl EventHandler { - /// Constructs a new instance of [`EventHandler`]. - pub fn new(tick_rate: u64) -> Self { - let tick_rate = Duration::from_millis(tick_rate); - let (sender, receiver) = mpsc::unbounded_channel(); - let _sender = sender.clone(); - let handler = tokio::spawn(async move { - let mut reader = crossterm::event::EventStream::new(); - let mut tick = tokio::time::interval(tick_rate); - loop { - let tick_delay = tick.tick(); - let crossterm_event = reader.next().fuse(); - tokio::select! { - _ = _sender.closed() => { - break; - } - _ = tick_delay => { - _sender.send(Event::Tick).unwrap(); - } - Some(Ok(evt)) = crossterm_event => { - match evt { - CrosstermEvent::Key(key) => { - if key.kind == crossterm::event::KeyEventKind::Press { - _sender.send(Event::Key(key)).unwrap(); - } - }, - CrosstermEvent::Mouse(mouse) => { - _sender.send(Event::Mouse(mouse)).unwrap(); - }, - CrosstermEvent::Resize(x, y) => { - _sender.send(Event::Resize(x, y)).unwrap(); - }, - CrosstermEvent::FocusLost => { - }, - CrosstermEvent::FocusGained => { - }, - CrosstermEvent::Paste(_) => { - }, - } - } - }; - } - }); - Self { - sender, - receiver, - handler, - } - } - - /// Receive the next event from the handler thread. - /// - /// This function will always block the current thread if - /// there is no data available and it's possible for more data to be sent. - pub async fn next(&mut self) -> Result<Event> { - self.receiver.recv().await.ok_or_eyre("This is an IO error") - // .ok_or(Box::new(std::io::Error::new( - // std::io::ErrorKind::Other, - // "This is an IO error", - // ))) - } -} |
