TUI moved to separate module
This commit is contained in:
parent
a7354f1939
commit
9a26d2821f
1 changed files with 88 additions and 0 deletions
88
src/tui/mod.rs
Normal file
88
src/tui/mod.rs
Normal file
|
@ -0,0 +1,88 @@
|
|||
use std::ops::Deref;
|
||||
use std::sync::{Arc};
|
||||
use chrono::{Duration, Utc};
|
||||
use tokio::sync::{RwLock, RwLockReadGuard};
|
||||
use tokio::time::sleep;
|
||||
use crate::{SharedData};
|
||||
|
||||
pub(crate) async fn run<'a>(shared_data: Arc<RwLock<SharedData>>) {
|
||||
let mut min_len_series: u32 = 0;
|
||||
let mut min_len_slug: u32 = 0;
|
||||
println!("TUI restarted");
|
||||
loop {
|
||||
let snapshot_data = shared_data.read().await;
|
||||
sleep(Duration::milliseconds(250).to_std().unwrap()).await;
|
||||
print_info(snapshot_data, &mut min_len_series, &mut min_len_slug).await;
|
||||
}
|
||||
}
|
||||
|
||||
async fn print_info<'a>(data: RwLockReadGuard<'a, SharedData>, min_len_series: &mut u32, min_len_slug: &mut u32) {
|
||||
let mut local_min_len_series = *min_len_series.deref() as usize;
|
||||
let mut local_min_len_slug = *min_len_slug.deref() as usize;
|
||||
let separator_width = local_min_len_slug + local_min_len_series + 44; // 44 should account for length of every other string
|
||||
|
||||
print!("\x1B[2J\x1B[1;1H");
|
||||
println!(
|
||||
"##[Ascendance of a Bookworm Bot]## | Time: {}",
|
||||
Utc::now().naive_local().format("%H:%M:%S")
|
||||
);
|
||||
println!("Instance: {}", data.config.instance);
|
||||
println!(
|
||||
"Ran Last: {}",
|
||||
data
|
||||
.start
|
||||
.naive_local()
|
||||
.format("%d/%m/%Y %H:%M:%S")
|
||||
);
|
||||
println!("{:#<1$}", "", separator_width);
|
||||
data.post_history.series.iter().for_each(|(series, post_history)| {
|
||||
|
||||
if series.len() > local_min_len_series {
|
||||
local_min_len_series = series.len() + 1;
|
||||
*min_len_series = local_min_len_series as u32;
|
||||
}
|
||||
|
||||
let series_config = data.config.series
|
||||
.iter()
|
||||
.find(|ser| {&ser.slug == series})
|
||||
.expect("Config should not parse without this");
|
||||
post_history.parts.iter().for_each(|(part, part_history)| {
|
||||
|
||||
if part_history.volume.len() > local_min_len_slug {
|
||||
local_min_len_slug = part_history.chapter.len() + 1;
|
||||
*min_len_slug = local_min_len_slug as u32;
|
||||
}
|
||||
|
||||
print!("{series}");
|
||||
print!("{:<1$}| ", "", local_min_len_series - series.len());
|
||||
print!("Part {part}");
|
||||
print!("{:<1$}| Volume | ", "", 2-part.len());
|
||||
print!("{}", part_history.volume);
|
||||
print!("{:<1$}| ", "", local_min_len_slug - part_history.volume.len());
|
||||
print!("{}", series_config.volume_community.name);
|
||||
println!("{:<1$}|", "", 20 - series_config.volume_community.name.len());
|
||||
|
||||
if part_history.chapter.len() > local_min_len_slug {
|
||||
local_min_len_slug = part_history.chapter.len() + 1;
|
||||
*min_len_slug = local_min_len_slug as u32;
|
||||
}
|
||||
|
||||
print!("{series}");
|
||||
print!("{:<1$}| ", "", local_min_len_series - series.len());
|
||||
print!("Part {part}");
|
||||
print!("{:<1$}| Chapter | ", "", 2-part.len());
|
||||
print!("{}", part_history.chapter);
|
||||
print!("{:<1$}| ", "", local_min_len_slug - part_history.chapter.len());
|
||||
print!("{}", series_config.prepub_community.name);
|
||||
println!("{:<1$}|", "", 20 - series_config.prepub_community.name.len());
|
||||
});
|
||||
});
|
||||
println!("{:#<1$}", "", separator_width);
|
||||
for error in data.get_messages(true, true, false).iter() {
|
||||
println!("{}", error);
|
||||
}
|
||||
println!("{:#<1$}", "", separator_width);
|
||||
for message in data.get_messages(false, false, false).iter() {
|
||||
println!("{}", message);
|
||||
}
|
||||
}
|
Loading…
Reference in a new issue