ui: show worker and static threads in account tab

embed
Manos Pitsidianakis 2019-09-11 18:00:02 +03:00
parent f394fde143
commit f61a43108c
Signed by: Manos Pitsidianakis
GPG Key ID: 73627C2F690DF710
1 changed files with 137 additions and 17 deletions

View File

@ -24,7 +24,8 @@ use std::fmt;
#[derive(Debug)]
pub struct AccountsPanel {
cursor: usize,
cursor: (usize, usize),
account_cursor: usize,
content: CellBuffer,
dirty: bool,
id: ComponentId,
@ -42,31 +43,149 @@ impl Component for AccountsPanel {
self.initialize(context);
self.dirty = false;
}
clear_area(grid, area);
let (width, height) = self.content.size();
copy_area(grid, &self.content, area, ((0, 0), (width - 1, height - 1)));
{
let (_, y) = write_string_to_grid(
"Worker threads",
&mut self.content,
Color::Default,
Color::Default,
Attr::Bold,
((1, 1), (width - 1, height - 1)),
true,
);
let mut y = y + 1;
let work_controller = context.work_controller().threads.lock().unwrap();
let mut workers: Vec<&Worker> = work_controller.values().collect::<Vec<&Worker>>();
let mut max_name = 0;
workers.sort_by_key(|w| {
max_name = std::cmp::max(max_name, w.name.len());
w.name.as_str()
});
for worker in workers {
let (x, y_off) = write_string_to_grid(
&format!(
"- {:<max_name$} {}",
worker.name.as_str(),
worker.status.as_str(),
max_name = max_name
),
&mut self.content,
Color::Default,
Color::Default,
Attr::Default,
((1, y), (width - 1, height - 1)),
true,
);
for x in x..(width - 1) {
self.content[(x, y)].set_ch(' ');
}
y = y_off + 1;
}
write_string_to_grid(
"Static threads",
&mut self.content,
Color::Default,
Color::Default,
Attr::Bold,
((1, y + 1), (width - 1, height - 1)),
true,
);
y += 2;
let work_controller = context.work_controller().static_threads.lock().unwrap();
let mut workers: Vec<&Worker> = work_controller.values().collect::<Vec<&Worker>>();
max_name = 0;
workers.retain(|w| w.name != "WorkController-thread");
workers.sort_by_key(|w| {
max_name = std::cmp::max(max_name, w.name.len());
w.name.as_str()
});
for worker in workers {
let (x, y_off) = write_string_to_grid(
&format!(
"- {:<max_name$} {}",
worker.name.as_str(),
worker.status.as_str(),
max_name = max_name
),
&mut self.content,
Color::Default,
Color::Default,
Attr::Default,
((1, y), (width - 1, height - 1)),
true,
);
for x in x..(width - 1) {
self.content[(x, y)].set_ch(' ');
}
y = y_off + 1;
}
}
let (cols, rows) = (width!(area), height!(area));
self.cursor = (
std::cmp::min(width.saturating_sub(cols), self.cursor.0),
std::cmp::min(height.saturating_sub(rows), self.cursor.1),
);
clear_area(grid, area);
copy_area(
grid,
&self.content,
area,
(
(
std::cmp::min((width - 1).saturating_sub(cols), self.cursor.0),
std::cmp::min((height - 1).saturating_sub(rows), self.cursor.1),
),
(
std::cmp::min(self.cursor.0 + cols, width - 1),
std::cmp::min(self.cursor.1 + rows, height - 1),
),
),
);
context.dirty_areas.push_back(area);
}
fn process_event(&mut self, event: &mut UIEvent, context: &mut Context) -> bool {
match *event {
UIEvent::Input(Key::Char('k')) => {
self.account_cursor = self.account_cursor.saturating_sub(1);
self.dirty = true;
return true;
}
UIEvent::Input(Key::Char('j')) => {
if self.account_cursor + 1 < context.accounts.len() {
self.account_cursor += 1;
self.dirty = true;
}
return true;
}
UIEvent::Input(Key::Left) => {
self.cursor.0 = self.cursor.0.saturating_sub(1);
self.dirty = true;
return true;
}
UIEvent::Input(Key::Right) => {
self.cursor.0 = self.cursor.0 + 1;
self.dirty = true;
return true;
}
UIEvent::Input(Key::Up) => {
self.cursor = self.cursor.saturating_sub(1);
self.cursor.1 = self.cursor.1.saturating_sub(1);
self.dirty = true;
return true;
}
UIEvent::Input(Key::Down) => {
if self.cursor + 1 < context.accounts.len() {
self.cursor += 1;
self.dirty = true;
}
self.cursor.1 = self.cursor.1 + 1;
self.dirty = true;
return true;
}
UIEvent::Input(Key::Char('\n')) => {
context
.replies
.push_back(UIEvent::Action(Tab(New(Some(Box::new(
ContactList::for_account(self.cursor),
ContactList::for_account(self.account_cursor),
))))));
return true;
}
@ -95,10 +214,11 @@ impl Component for AccountsPanel {
impl AccountsPanel {
pub fn new(context: &Context) -> AccountsPanel {
let content = CellBuffer::new(120, 25 + context.accounts.len() * 20, Cell::default());
let content = CellBuffer::new(120, 40 + context.accounts.len() * 20, Cell::default());
AccountsPanel {
cursor: 0,
cursor: (0, 0),
account_cursor: 0,
content,
dirty: true,
id: ComponentId::new_v4(),
@ -111,13 +231,13 @@ impl AccountsPanel {
Color::Default,
Color::Default,
Attr::Default,
((2, 3), (120 - 1, 3)),
((2, 10), (120 - 1, 10)),
true,
);
for (i, a) in context.accounts.iter().enumerate() {
for x in 2..(120 - 1) {
set_and_join_box(&mut self.content, (x, 5 + i * 10), HORZ_BOUNDARY);
set_and_join_box(&mut self.content, (x, 12 + i * 10), HORZ_BOUNDARY);
}
//create_box(&mut self.content, ((2, 5 + i * 10), (120 - 1, 15 + i * 10)));
let (x, y) = write_string_to_grid(
@ -126,7 +246,7 @@ impl AccountsPanel {
Color::Default,
Color::Default,
Attr::Bold,
((3, 5 + i * 10), (120 - 2, 5 + i * 10)),
((3, 12 + i * 10), (120 - 2, 12 + i * 10)),
true,
);
write_string_to_grid(
@ -135,7 +255,7 @@ impl AccountsPanel {
Color::Byte(32),
Color::Default,
Attr::Default,
((x, y), (120 - 2, 5 + i * 10)),
((x, y), (120 - 2, 12 + i * 10)),
true,
);
write_string_to_grid(
@ -147,7 +267,7 @@ impl AccountsPanel {
((4, y + 2), (120 - 2, y + 2)),
true,
);
if i == self.cursor {
if i == self.account_cursor {
for h in 1..8 {
self.content[(2, h + y + 1)].set_ch('*');
}