2022-10-01 16:58:22 +00:00
|
|
|
// Gupax - GUI Uniting P2Pool And XMRig
|
|
|
|
//
|
|
|
|
// Copyright (c) 2022 hinto-janaiyo
|
|
|
|
//
|
|
|
|
// This program is free software: you can redistribute it and/or modify
|
|
|
|
// it under the terms of the GNU General Public License as published by
|
|
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
|
|
// (at your option) any later version.
|
|
|
|
//
|
|
|
|
// This program is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
|
|
// along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
|
|
|
|
use std::path::Path;
|
|
|
|
use crate::App;
|
|
|
|
use egui::WidgetType::Button;
|
|
|
|
use crate::constants::*;
|
2022-10-27 03:15:56 +00:00
|
|
|
use crate::state::{Gupax,Version};
|
2022-10-25 02:58:42 +00:00
|
|
|
use crate::update::*;
|
2022-10-27 03:15:56 +00:00
|
|
|
use std::thread;
|
|
|
|
use std::sync::{Arc,Mutex};
|
|
|
|
use log::*;
|
2022-10-01 16:58:22 +00:00
|
|
|
|
|
|
|
impl Gupax {
|
2022-10-27 03:15:56 +00:00
|
|
|
pub fn show(state: &mut Gupax, width: f32, height: f32, update: &mut Update, version: Version, ctx: &egui::Context, ui: &mut egui::Ui) {
|
|
|
|
// Update button + Progress bar
|
|
|
|
ui.group(|ui| {
|
|
|
|
// These are in unnecessary [ui.vertical()]'s
|
|
|
|
// because I need to use [ui.set_enabled]s, but I can't
|
|
|
|
// find a way to use a [ui.xxx()] with [ui.add_sized()].
|
|
|
|
// I have to pick one. This one seperates them though.
|
|
|
|
let height = height/6.0;
|
|
|
|
let width = width - SPACE;
|
2022-10-27 15:52:18 +00:00
|
|
|
let updating = *update.updating.lock().unwrap();
|
2022-10-27 03:15:56 +00:00
|
|
|
ui.vertical(|ui| {
|
2022-10-27 15:52:18 +00:00
|
|
|
ui.set_enabled(!updating);
|
2022-10-27 03:15:56 +00:00
|
|
|
if ui.add_sized([width, height], egui::Button::new("Check for updates")).on_hover_text(GUPAX_UPDATE).clicked() {
|
|
|
|
update.path_p2pool = state.absolute_p2pool_path.display().to_string();
|
|
|
|
update.path_xmrig = state.absolute_xmrig_path.display().to_string();
|
|
|
|
update.tor = state.update_via_tor;
|
|
|
|
let u = Arc::new(Mutex::new(update.clone()));
|
|
|
|
let u = Arc::clone(&u);
|
2022-10-27 15:52:18 +00:00
|
|
|
let u2 = Arc::new(Mutex::new(update.clone()));
|
|
|
|
let u2 = Arc::clone(&u);
|
2022-10-27 03:15:56 +00:00
|
|
|
thread::spawn(move|| {
|
|
|
|
info!("Spawning update thread...");
|
2022-10-27 15:52:18 +00:00
|
|
|
match Update::start(u, version) {
|
|
|
|
Err(e) => {
|
|
|
|
info!("Update | {} ... FAIL", e);
|
2022-10-28 19:45:13 +00:00
|
|
|
*u2.lock().unwrap().msg.lock().unwrap() = format!("{} | {}", MSG_FAILED, e);
|
2022-10-27 15:52:18 +00:00
|
|
|
*u2.lock().unwrap().updating.lock().unwrap() = false;
|
|
|
|
},
|
2022-10-28 19:45:13 +00:00
|
|
|
_ => (),
|
2022-10-27 15:52:18 +00:00
|
|
|
}
|
2022-10-27 03:15:56 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
ui.vertical(|ui| {
|
2022-10-27 15:52:18 +00:00
|
|
|
ui.set_enabled(updating);
|
2022-10-28 19:45:13 +00:00
|
|
|
let msg = format!("{}\n{}{}", *update.msg.lock().unwrap(), *update.prog.lock().unwrap(), "%");
|
|
|
|
ui.add_sized([width, height*1.4], egui::Label::new(msg));
|
2022-10-27 03:15:56 +00:00
|
|
|
let height = height/2.0;
|
2022-10-28 19:45:13 +00:00
|
|
|
if updating {
|
|
|
|
ui.add_sized([width, height], egui::Spinner::new().size(height));
|
|
|
|
} else {
|
|
|
|
ui.add_sized([width, height], egui::Label::new("..."));
|
|
|
|
}
|
|
|
|
ui.add_sized([width, height], egui::ProgressBar::new((update.prog.lock().unwrap().round() / 100.0)));
|
2022-10-27 03:15:56 +00:00
|
|
|
});
|
|
|
|
});
|
2022-10-01 16:58:22 +00:00
|
|
|
|
|
|
|
ui.horizontal(|ui| {
|
|
|
|
ui.group(|ui| {
|
2022-10-28 19:45:13 +00:00
|
|
|
let width = (width - SPACE*9.8)/5.0;
|
2022-10-27 03:15:56 +00:00
|
|
|
let height = height/2.0;
|
2022-10-17 00:36:58 +00:00
|
|
|
let mut style = (*ctx.style()).clone();
|
2022-10-28 19:45:13 +00:00
|
|
|
style.spacing.icon_width_inner = width / 6.0;
|
|
|
|
style.spacing.icon_width = width / 4.0;
|
|
|
|
style.spacing.icon_spacing = 20.0;
|
2022-10-17 00:36:58 +00:00
|
|
|
ctx.set_style(style);
|
2022-10-27 03:15:56 +00:00
|
|
|
let height = height/2.0;
|
|
|
|
ui.add_sized([width, height], egui::Checkbox::new(&mut state.auto_update, "Auto-update")).on_hover_text(GUPAX_AUTO_UPDATE);
|
|
|
|
ui.separator();
|
|
|
|
ui.add_sized([width, height], egui::Checkbox::new(&mut state.auto_node, "Auto-node")).on_hover_text(GUPAX_AUTO_NODE);
|
|
|
|
ui.separator();
|
|
|
|
ui.add_sized([width, height], egui::Checkbox::new(&mut state.update_via_tor, "Update via Tor")).on_hover_text(GUPAX_UPDATE_VIA_TOR);
|
|
|
|
ui.separator();
|
|
|
|
ui.add_sized([width, height], egui::Checkbox::new(&mut state.ask_before_quit, "Ask before quit")).on_hover_text(GUPAX_ASK_BEFORE_QUIT);
|
|
|
|
ui.separator();
|
|
|
|
ui.add_sized([width, height], egui::Checkbox::new(&mut state.save_before_quit, "Save before quit")).on_hover_text(GUPAX_SAVE_BEFORE_QUIT);
|
2022-10-01 16:58:22 +00:00
|
|
|
});
|
|
|
|
});
|
2022-10-27 03:15:56 +00:00
|
|
|
ui.add_space(SPACE);
|
2022-10-01 16:58:22 +00:00
|
|
|
|
|
|
|
ui.horizontal(|ui| {
|
|
|
|
ui.label("P2Pool binary path:");
|
2022-10-28 19:45:13 +00:00
|
|
|
ui.spacing_mut().text_edit_width = ui.available_width() - SPACE;
|
2022-10-17 00:36:58 +00:00
|
|
|
ui.text_edit_singleline(&mut state.p2pool_path).on_hover_text(GUPAX_PATH_P2POOL);
|
2022-10-01 16:58:22 +00:00
|
|
|
});
|
|
|
|
ui.horizontal(|ui| {
|
|
|
|
ui.label("XMRig binary path: ");
|
2022-10-28 19:45:13 +00:00
|
|
|
ui.spacing_mut().text_edit_width = ui.available_width() - SPACE;
|
2022-10-17 00:36:58 +00:00
|
|
|
ui.text_edit_singleline(&mut state.xmrig_path).on_hover_text(GUPAX_PATH_XMRIG);
|
2022-10-01 16:58:22 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|