mirror of
https://github.com/Cyrix126/gupaxx.git
synced 2025-01-23 13:55:50 +00:00
feat: Status, add buttons to hide/show column processes
also make code more simple
This commit is contained in:
parent
cd1f5192b4
commit
f940caf1b9
2 changed files with 76 additions and 67 deletions
|
@ -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))
|
||||
});
|
||||
});
|
||||
}
|
||||
|
|
|
@ -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,
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue