feat: Status, add buttons to hide/show column processes

also make code more simple
This commit is contained in:
Cyrix126 2025-01-03 11:59:06 +01:00
parent cd1f5192b4
commit f940caf1b9
2 changed files with 76 additions and 67 deletions

View file

@ -1,4 +1,4 @@
use egui::{Label, ScrollArea, Ui};
use egui::{Label, ScrollArea, Ui, Vec2};
use std::sync::{Arc, Mutex};
use crate::app::eframe_impl::ProcessStatesGui;
@ -31,34 +31,20 @@ impl Status {
) {
let width_column = ui.text_style_height(&TextStyle::Body) * 16.0;
let height_column = width_column * 2.7;
let size_column = Vec2::new(width_column, height_column);
ui.style_mut().wrap_mode = Some(egui::TextWrapMode::Extend);
// let width = ((ui.available_width() / 5.0) - (SPACE * 1.7500)).max(0.0);
ScrollArea::vertical().show(ui, |ui| {
ScrollArea::vertical()
.id_salt("vertical_processes")
.show(ui, |ui| {
ui.horizontal(|ui| {
ScrollArea::horizontal().show(ui, |ui| {
ui.vertical(|ui| {
ui.group(|ui| {
ui.set_width(width_column);
ui.set_height(height_column);
ui.vertical_centered(|ui| {
column_process(ui, size_column, self.show_system, |ui| {
gupax(ui, sys);
});
});
});
ui.vertical(|ui| {
ui.group(|ui| {
ui.set_width(width_column);
ui.set_height(height_column);
ui.vertical_centered(|ui| {
column_process(ui, size_column, self.show_node, |ui| {
node(ui, states.is_alive(ProcessName::Node), node_api);
});
});
});
ui.vertical(|ui| {
ui.group(|ui| {
ui.set_width(width_column);
ui.set_height(height_column);
ui.vertical_centered(|ui| {
column_process(ui, size_column, self.show_p2pool, |ui| {
p2pool(
ui,
states.is_alive(ProcessName::P2pool),
@ -66,13 +52,7 @@ impl Status {
p2pool_img,
);
});
});
});
ui.vertical(|ui| {
ui.group(|ui| {
ui.set_width(width_column);
ui.set_height(height_column);
ui.vertical_centered(|ui| {
column_process(ui, size_column, self.show_xmrig, |ui| {
xmrig(
ui,
states.is_alive(ProcessName::Xmrig),
@ -81,31 +61,48 @@ impl Status {
max_threads,
);
});
});
});
ui.vertical(|ui| {
ui.group(|ui| {
ui.set_width(width_column);
ui.set_height(height_column);
ui.vertical_centered(|ui| {
column_process(ui, size_column, self.show_proxy, |ui| {
xmrig_proxy(
ui,
states.is_alive(ProcessName::XmrigProxy),
xmrig_proxy_api,
);
});
});
});
ui.vertical(|ui| {
ui.group(|ui| {
ui.set_width(width_column);
ui.set_height(height_column);
ui.vertical_centered(|ui| {
column_process(ui, size_column, self.show_xvb, |ui| {
xvb(ui, states.is_alive(ProcessName::Xvb), xvb_api);
});
});
});
});
// buttons to hide
ScrollArea::horizontal().show(ui, |ui| {
ui.label("Visible columns:");
ui.add_space(SPACE);
ui.horizontal(|ui| {
ui.checkbox(&mut self.show_system, "System");
ui.checkbox(&mut self.show_node, "Node");
ui.checkbox(&mut self.show_p2pool, "P2Pool");
ui.checkbox(&mut self.show_xmrig, "XMRig");
ui.checkbox(&mut self.show_proxy, "XMRig-Proxy");
ui.checkbox(&mut self.show_xvb, "XvB");
});
});
}
}
pub fn column_process<R>(
ui: &mut Ui,
size_column: Vec2,
visible: bool,
add_contents: impl FnOnce(&mut Ui) -> R,
) {
if visible {
ui.vertical(|ui| {
ui.group(|ui| {
ui.set_width(size_column.x);
ui.set_height(size_column.y);
ui.vertical_centered(|ui| add_contents(ui))
});
});
}

View file

@ -179,6 +179,12 @@ pub struct Status {
pub manual_hash: bool,
pub hashrate: f64,
pub hash_metric: Hash,
pub show_system: bool,
pub show_node: bool,
pub show_p2pool: bool,
pub show_xmrig: bool,
pub show_proxy: bool,
pub show_xvb: bool,
}
#[derive(Clone, PartialEq, Debug, Deserialize, Serialize)]
@ -580,6 +586,12 @@ impl Default for Status {
manual_hash: false,
hashrate: 1.0,
hash_metric: Hash::default(),
show_system: true,
show_node: true,
show_p2pool: true,
show_xmrig: true,
show_proxy: true,
show_xvb: true,
}
}
}