use anyhow::Result;
use crossterm::event::{self, KeyEvent, MouseEvent};
use std::sync::mpsc;
use std::thread;
use std::time::Duration;
#[derive(Debug)]
pub enum Event {
Key(KeyEvent),
Mouse(MouseEvent),
Resize(u16, u16),
Tick,
}
pub struct EventHandler {
rx: mpsc::Receiver<Event>,
_tx: mpsc::Sender<Event>,
}
impl EventHandler {
pub fn new(tick_rate: u64) -> Self {
let tick_rate = Duration::from_millis(tick_rate);
let (tx, rx) = mpsc::channel();
let _tx = tx.clone();
thread::spawn(move || {
loop {
if event::poll(tick_rate).unwrap_or(false) {
match event::read() {
Ok(event::Event::Key(key)) => {
if tx.send(Event::Key(key)).is_err() {
break;
}
}
Ok(event::Event::Mouse(mouse)) => {
if tx.send(Event::Mouse(mouse)).is_err() {
break;
}
}
Ok(event::Event::Resize(w, h)) => {
if tx.send(Event::Resize(w, h)).is_err() {
break;
}
}
_ => {}
}
} else {
if tx.send(Event::Tick).is_err() {
break;
}
}
}
});
Self { rx, _tx }
}
pub fn next(&self) -> Result<Event> {
Ok(self.rx.recv()?)
}
}