aboutsummaryrefslogtreecommitdiff
path: root/src/app.rs
diff options
context:
space:
mode:
authorMroik <mroik@delayed.space>2025-01-27 17:56:06 +0100
committerMroik <mroik@delayed.space>2025-02-01 19:33:03 +0100
commit695024ae427eb5014457d42d832ba5e6ff233c64 (patch)
tree7c629c58621e482617754b0b25334c6d568bb0d2 /src/app.rs
parent5bd36b139d8ba07bce7edb8828beec3f114b3271 (diff)
Move out of App the quote selection
Diffstat (limited to 'src/app.rs')
-rw-r--r--src/app.rs19
1 files changed, 11 insertions, 8 deletions
diff --git a/src/app.rs b/src/app.rs
index 7ba3da8..e5d0f25 100644
--- a/src/app.rs
+++ b/src/app.rs
@@ -7,7 +7,6 @@ use crossterm::{
terminal::{disable_raw_mode, enable_raw_mode, EnterAlternateScreen, LeaveAlternateScreen},
ExecutableCommand,
};
-use rand::Rng;
use tokio::{
spawn,
sync::mpsc::{channel, Receiver, Sender},
@@ -19,23 +18,27 @@ pub const TICK_RATE: u64 = 1000 / 20;
pub struct App {
stdout: Stdout,
- quote: Vec<String>,
pub event_tx: Sender<Event>,
event_rx: Receiver<Event>,
running: bool,
+ quote: Vec<String>,
+ current: (usize, usize),
}
impl App {
- pub fn new(quotes: &[Vec<String>]) -> App {
- let mut rng = rand::thread_rng();
- let chosen = rng.gen_range(0..quotes.len());
+ pub fn new(quote: String) -> App {
let (event_tx, event_rx): (Sender<Event>, Receiver<Event>) = channel(10);
App {
stdout: stdout(),
- quote: quotes[chosen].clone(),
+ quote: quote
+ .split_whitespace()
+ .filter(|s| !s.is_empty())
+ .map(|s| s.to_string())
+ .collect(),
event_rx,
event_tx,
running: false,
+ current: (0, 0),
}
}
@@ -75,8 +78,8 @@ impl App {
async fn start_input_handler(ev: Sender<Event>, mut kill_switch: Receiver<()>) {
loop {
tokio::select! {
- _ = handle_input(&ev) => (),
- _ = kill_switch.recv() => return,
+ _ = handle_input(&ev) => (),
+ _ = kill_switch.recv() => return,
}
}
}
XMR address: 854DmXNrxULU3ZFJVs4Wc8PFhbq29RhqHhY8W6cdWrtFN3qmooKyyeYPcDzZTNRxphhJ5UzASQfAdEMwSteVqymk28aLhqj