ui + node: initial node settings, node controls, fix node restart stats, update translations

This commit is contained in:
ardocrat 2023-06-27 02:11:07 +03:00
parent 7f1c6579b1
commit 8fdc2c1e39
14 changed files with 262 additions and 81 deletions

View file

@ -11,6 +11,7 @@ network:
restart: Restart restart: Restart
autorun: Autorun autorun: Autorun
disabled_server: 'Enable integrated node or add another connection method by pressing %{dots} in the top-left corner of the screen.' disabled_server: 'Enable integrated node or add another connection method by pressing %{dots} in the top-left corner of the screen.'
no_ip_addresses: There are no available IP addresses on your system, server cannot be started, check your network connectivity.
sync_status: sync_status:
node_restarting: Node is restarting node_restarting: Node is restarting
node_down: Node is down node_down: Node is down
@ -59,7 +60,6 @@ network_mining:
enable_server: Enable server enable_server: Enable server
server_setting: 'Enable stratum server or change more settings by selecting %{settings} at the bottom of the screen. App restart is required to change settings of the running server.' server_setting: 'Enable stratum server or change more settings by selecting %{settings} at the bottom of the screen. App restart is required to change settings of the running server.'
info: 'Mining server is enabled, you can change its settings by selecting %{settings} at the bottom of the screen. Data is updating when devices are connected.' info: 'Mining server is enabled, you can change its settings by selecting %{settings} at the bottom of the screen. Data is updating when devices are connected.'
no_ip_addresses: There are no available IP addresses on your system, stratum server cannot be started, check your network connectivity.
port_unavailable: Specified port is unavailable port_unavailable: Specified port is unavailable
rewards_wallet: Wallet for rewards rewards_wallet: Wallet for rewards
server: Stratum server server: Stratum server
@ -71,14 +71,20 @@ network_mining:
connected: Connected connected: Connected
disconnected: Disconnected disconnected: Disconnected
network_settings: network_settings:
server: Server
port: Port port: Port
ip_address: IP Address ip_address: IP Address
change_port: Change port change_port: Change port
enter_value: 'Enter value:' enter_value: 'Enter value:'
server:
title: Server
enable: Enable
disable: Disable
restart: Restart
api_ip_address: API IP Address
modal: modal:
cancel: Cancel cancel: Cancel
save: Save save: Save
confirmation: Confirmation
modal_exit: modal_exit:
description: Are you sure you want to quit the application? description: Are you sure you want to quit the application?
exit: Exit exit: Exit

View file

@ -11,6 +11,7 @@ network:
restart: Перезапустить restart: Перезапустить
autorun: Автозапуск autorun: Автозапуск
disabled_server: 'Включите встроенный узел или добавьте другой способ подключения, нажав %{dots} в левом-верхнем углу экрана.' disabled_server: 'Включите встроенный узел или добавьте другой способ подключения, нажав %{dots} в левом-верхнем углу экрана.'
no_ip_addresses: В вашей системе отсутствуют доступные IP адреса, запуск сервера невозможен, проверьте ваше подключение к сети.
sync_status: sync_status:
node_restarting: Узел перезапускается node_restarting: Узел перезапускается
node_down: Узел выключен node_down: Узел выключен
@ -59,7 +60,6 @@ network_mining:
enable_server: Включить сервер enable_server: Включить сервер
server_setting: 'Включите stratum-сервер или измените больше настроек, выбрав %{settings} внизу экрана. Для изменения настроек запущенного сервера потребуется перезапуск приложения.' server_setting: 'Включите stratum-сервер или измените больше настроек, выбрав %{settings} внизу экрана. Для изменения настроек запущенного сервера потребуется перезапуск приложения.'
info: 'Сервер майнинга запущен, вы можете изменить его настройки, выбрав %{settings} внизу экрана. Данные обновляются, когда устройства подключены.' info: 'Сервер майнинга запущен, вы можете изменить его настройки, выбрав %{settings} внизу экрана. Данные обновляются, когда устройства подключены.'
no_ip_addresses: В вашей системе отсутствуют доступные IP адреса, запуск stratum-сервера невозможен, проверьте ваше подключение к сети.
port_unavailable: Указанный порт недоступен port_unavailable: Указанный порт недоступен
rewards_wallet: Кошелёк для наград rewards_wallet: Кошелёк для наград
server: Stratum-сервер server: Stratum-сервер
@ -71,14 +71,20 @@ network_mining:
connected: Подключен connected: Подключен
disconnected: Отключен disconnected: Отключен
network_settings: network_settings:
server: Сервер
ip_address: IP Адрес ip_address: IP Адрес
port: Порт port: Порт
change_port: Изменить порт change_port: Изменить порт
enter_value: 'Введите значение:' enter_value: 'Введите значение:'
server:
title: Сервер
enable: Включить
disable: Выключить
restart: Перезапустить
api_ip_address: API IP Адрес
modal: modal:
cancel: Отмена cancel: Отмена
save: Сохранить save: Сохранить
confirmation: Подтверждение
modal_exit: modal_exit:
description: Вы уверены, что хотите выйти из приложения? description: Вы уверены, что хотите выйти из приложения?
exit: Выход exit: Выход

View file

@ -97,7 +97,7 @@ impl Navigator {
/// Set exit confirmation [`Modal`] with provided [NAVIGATOR_STATE] lock. /// Set exit confirmation [`Modal`] with provided [NAVIGATOR_STATE] lock.
fn show_exit_modal_nav(mut w_nav: RwLockWriteGuard<Navigator>) { fn show_exit_modal_nav(mut w_nav: RwLockWriteGuard<Navigator>) {
let m = Modal::new(Self::EXIT_MODAL).title(t!("modal_exit.exit")); let m = Modal::new(Self::EXIT_MODAL).title(t!("modal.confirmation"));
w_nav.modal = Some(m); w_nav.modal = Some(m);
} }

View file

@ -29,4 +29,4 @@ mod network_settings;
mod network_metrics; mod network_metrics;
mod network_mining; mod network_mining;
mod settings_stratum; mod settings_stratum;
mod settings_node_server; mod settings_node;

View file

@ -105,7 +105,7 @@ impl Network {
egui::TopBottomPanel::bottom("network_tabs") egui::TopBottomPanel::bottom("network_tabs")
.frame(egui::Frame { .frame(egui::Frame {
outer_margin: Margin::same(5.0), outer_margin: Margin::same(5.0),
.. Default::default() ..Default::default()
}) })
.show_inside(ui, |ui| { .show_inside(ui, |ui| {
self.draw_tabs(ui); self.draw_tabs(ui);
@ -116,7 +116,7 @@ impl Network {
stroke: View::DEFAULT_STROKE, stroke: View::DEFAULT_STROKE,
inner_margin: Margin::same(4.0), inner_margin: Margin::same(4.0),
fill: Colors::WHITE, fill: Colors::WHITE,
.. Default::default() ..Default::default()
}) })
.show_inside(ui, |ui| { .show_inside(ui, |ui| {
self.current_tab.ui(ui, cb); self.current_tab.ui(ui, cb);
@ -246,21 +246,22 @@ impl Network {
.size(16.0) .size(16.0)
.color(Colors::INACTIVE_TEXT) .color(Colors::INACTIVE_TEXT)
); );
ui.add_space(10.0); ui.add_space(10.0);
View::button(ui, t!("network.enable_node"), Colors::GOLD, || { View::button(ui, t!("network.enable_node"), Colors::GOLD, || {
Node::start(); Node::start();
}); });
ui.add_space(2.0); ui.add_space(2.0);
Self::autorun_node_checkbox(ui);
});
}
let autostart: bool = Settings::app_config_to_read().auto_start_node; /// Draw checkbox with setting to run node on app launch.
View::checkbox(ui, autostart, t!("network.autorun"), || { pub fn autorun_node_checkbox(ui: &mut egui::Ui) {
let mut w_app_config = Settings::app_config_to_update(); let autostart: bool = Settings::app_config_to_read().auto_start_node;
w_app_config.auto_start_node = !autostart; View::checkbox(ui, autostart, t!("network.autorun"), || {
w_app_config.save(); let mut w_app_config = Settings::app_config_to_update();
}); w_app_config.auto_start_node = !autostart;
w_app_config.save();
}); });
} }
@ -277,6 +278,17 @@ impl Network {
addresses addresses
} }
/// Show message when IP addresses are not available at system.
pub fn no_ip_address_ui(ui: &mut egui::Ui) {
ui.vertical_centered(|ui| {
ui.label(RichText::new(t!("network.no_ip_addresses"))
.size(16.0)
.color(Colors::INACTIVE_TEXT)
);
ui.add_space(6.0);
});
}
/// Check whether a port is available on the provided host. /// Check whether a port is available on the provided host.
pub fn is_port_available(host: &str, port: u16) -> bool { pub fn is_port_available(host: &str, port: u16) -> bool {
let ip_addr = Ipv4Addr::from_str(host).unwrap(); let ip_addr = Ipv4Addr::from_str(host).unwrap();

View file

@ -13,7 +13,7 @@
// limitations under the License. // limitations under the License.
use chrono::{DateTime, NaiveDateTime, Utc}; use chrono::{DateTime, NaiveDateTime, Utc};
use egui::{RichText, Rounding, ScrollArea, Stroke, Ui}; use egui::{RichText, Rounding, ScrollArea, Stroke};
use grin_servers::DiffBlock; use grin_servers::DiffBlock;
use crate::gui::Colors; use crate::gui::Colors;
@ -140,7 +140,7 @@ impl NetworkTab for NetworkMetrics {
); );
} }
fn on_modal_ui(&mut self, ui: &mut Ui, modal: &Modal, cb: &dyn PlatformCallbacks) {} fn on_modal_ui(&mut self, ui: &mut egui::Ui, modal: &Modal, cb: &dyn PlatformCallbacks) {}
} }
const DIFF_BLOCK_UI_HEIGHT: f32 = 76.60; const DIFF_BLOCK_UI_HEIGHT: f32 = 76.60;

View file

@ -77,7 +77,7 @@ impl NetworkTab for NetworkMining {
ui.add_space(4.0); ui.add_space(4.0);
// Show button to enable stratum server if port is available. // Show button to enable stratum server if port is available.
if self.stratum_server_setup.stratum_port_available { if self.stratum_server_setup.is_stratum_port_available {
ui.add_space(6.0); ui.add_space(6.0);
View::button(ui, t!("network_mining.enable_server"), Colors::GOLD, || { View::button(ui, t!("network_mining.enable_server"), Colors::GOLD, || {
Node::start_stratum_server(); Node::start_stratum_server();

View file

@ -13,7 +13,7 @@
// limitations under the License. // limitations under the License.
use eframe::epaint::Stroke; use eframe::epaint::Stroke;
use egui::{RichText, Rounding, ScrollArea, Ui}; use egui::{RichText, Rounding, ScrollArea};
use grin_servers::PeerStats; use grin_servers::PeerStats;
use crate::gui::Colors; use crate::gui::Colors;
@ -182,13 +182,13 @@ impl NetworkTab for NetworkNode {
}); });
} }
fn on_modal_ui(&mut self, ui: &mut Ui, modal: &Modal, cb: &dyn PlatformCallbacks) {} fn on_modal_ui(&mut self, ui: &mut egui::Ui, modal: &Modal, cb: &dyn PlatformCallbacks) {}
} }
fn draw_peer_stats(ui: &mut egui::Ui, peer: &PeerStats, rounding: [bool; 2]) { fn draw_peer_stats(ui: &mut egui::Ui, peer: &PeerStats, rounding: [bool; 2]) {
ui.vertical(|ui| { ui.vertical(|ui| {
let mut rect = ui.available_rect_before_wrap(); let mut rect = ui.available_rect_before_wrap();
rect.set_height(78.0); rect.set_height(77.3);
ui.painter().rect( ui.painter().rect(
rect, rect,
@ -251,6 +251,6 @@ fn draw_peer_stats(ui: &mut egui::Ui, peer: &PeerStats, rounding: [bool; 2]) {
// Add space after last item // Add space after last item
if rounding[1] { if rounding[1] {
ui.add_space(3.0); ui.add_space(2.0);
} }
} }

View file

@ -12,16 +12,15 @@
// See the License for the specific language governing permissions and // See the License for the specific language governing permissions and
// limitations under the License. // limitations under the License.
use egui::Ui; use egui::ScrollArea;
use grin_core::global::ChainTypes;
use crate::gui::Colors;
use crate::gui::icons::COMPUTER_TOWER;
use crate::gui::platform::PlatformCallbacks; use crate::gui::platform::PlatformCallbacks;
use crate::gui::views::{Modal, NetworkTab, NetworkTabType, View}; use crate::gui::views::{Modal, NetworkTab, NetworkTabType};
use crate::Settings; use crate::gui::views::settings_node::NodeSetup;
#[derive(Default)] #[derive(Default)]
pub struct NetworkSettings; pub struct NetworkSettings {
node_setup: NodeSetup
}
impl NetworkTab for NetworkSettings { impl NetworkTab for NetworkSettings {
fn get_type(&self) -> NetworkTabType { fn get_type(&self) -> NetworkTabType {
@ -29,13 +28,15 @@ impl NetworkTab for NetworkSettings {
} }
fn ui(&mut self, ui: &mut egui::Ui, cb: &dyn PlatformCallbacks) { fn ui(&mut self, ui: &mut egui::Ui, cb: &dyn PlatformCallbacks) {
View::sub_title(ui, format!("{} {}", COMPUTER_TOWER, t!("network_settings.server"))); ScrollArea::vertical()
View::horizontal_line(ui, Colors::ITEM_STROKE); .id_source("network_settings")
ui.add_space(4.0); .auto_shrink([false; 2])
.show(ui, |ui| {
self.node_setup.ui(ui, cb);
});
} }
fn on_modal_ui(&mut self, ui: &mut Ui, modal: &Modal, cb: &dyn PlatformCallbacks) { fn on_modal_ui(&mut self, ui: &mut egui::Ui, modal: &Modal, cb: &dyn PlatformCallbacks) {
} }
} }

View file

@ -0,0 +1,183 @@
// Copyright 2023 The Grim Developers
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
use std::net::IpAddr;
use std::str::FromStr;
use egui::RichText;
use crate::gui::Colors;
use crate::gui::icons::COMPUTER_TOWER;
use crate::gui::platform::PlatformCallbacks;
use crate::gui::views::{Network, View};
use crate::node::{Node, NodeConfig};
/// Integrated node server setup ui section.
pub struct NodeSetup {
/// API IP address to be used inside edit modal.
api_address_edit: String,
/// API port to be used inside edit modal.
api_port_edit: String,
/// Flag to check if API port is available inside edit modal.
api_port_available_edit: bool,
/// Flag to check if API port is available from saved config value.
pub(crate) api_port_available: bool,
/// API secret to be used inside edit modal.
api_secret_edit: String,
/// Foreign API secret to be used inside edit modal.
foreign_api_secret_edit: String,
/// Future Time Limit to be used inside edit modal.
ftl_edit: String,
}
impl Default for NodeSetup {
fn default() -> Self {
let (api_address, api_port) = NodeConfig::get_api_address_port();
let is_api_port_available = Network::is_port_available(api_address.as_str(), api_port);
Self {
api_address_edit: api_address,
api_port_edit: api_port.to_string(),
api_port_available_edit: is_api_port_available,
api_port_available: is_api_port_available,
api_secret_edit: "".to_string(),
foreign_api_secret_edit: "".to_string(),
ftl_edit: "".to_string(),
}
}
}
const SECRET_SYMBOLS: &'static str = "••••••••••••";
impl NodeSetup {
pub const API_PORT_MODAL: &'static str = "stratum_port";
pub fn ui(&mut self, ui: &mut egui::Ui, cb: &dyn PlatformCallbacks) {
View::sub_title(ui, format!("{} {}", COMPUTER_TOWER, t!("network_settings.server.title")));
View::horizontal_line(ui, Colors::ITEM_STROKE);
ui.add_space(4.0);
// Show loading indicator or controls to stop/start/restart node.
if Node::is_stopping() || Node::is_restarting() || Node::is_starting() {
ui.vertical_centered(|ui| {
ui.add_space(6.0);
View::small_loading_spinner(ui);
});
} else {
if Node::is_running() {
ui.scope(|ui| {
// Setup spacing between buttons.
ui.spacing_mut().item_spacing = egui::Vec2::new(8.0, 0.0);
ui.add_space(6.0);
ui.columns(2, |columns| {
columns[0].vertical_centered_justified(|ui| {
View::button(ui, t!("network_settings.server.disable"), Colors::GOLD, || {
Node::stop(false);
});
});
columns[1].vertical_centered_justified(|ui| {
View::button(ui, t!("network_settings.server.restart"), Colors::GOLD, || {
Node::restart();
});
});
});
});
} else {
ui.add_space(6.0);
ui.vertical_centered(|ui| {
View::button(ui, t!("network_settings.server.enable"), Colors::GOLD, || {
Node::start();
});
});
}
}
ui.add_space(4.0);
ui.vertical_centered(|ui| {
Network::autorun_node_checkbox(ui);
});
ui.add_space(4.0);
let addrs = Network::get_ip_list();
// Show error message when IP addresses are not available on the system.
if addrs.is_empty() {
Network::no_ip_address_ui(ui);
ui.add_space(4.0);
} else {
View::horizontal_line(ui, Colors::ITEM_STROKE);
ui.add_space(4.0);
ui.vertical_centered(|ui| {
ui.label(RichText::new(t!("network_settings.server.api_ip_address"))
.size(16.0)
.color(Colors::GRAY)
);
ui.add_space(6.0);
});
// Show API IP address setup.
self.api_ip_address_setup_ui(ui, addrs)
}
}
/// Show API IP address setup.
fn api_ip_address_setup_ui(&mut self, ui: &mut egui::Ui, addrs: Vec<IpAddr>) {
let (addr, port) = NodeConfig::get_api_address_port();
let saved_ip_addr = &IpAddr::from_str(addr.as_str()).unwrap();
let mut selected_addr = saved_ip_addr;
// Set first IP address as current if saved is not present at system.
if !addrs.contains(selected_addr) {
selected_addr = addrs.get(0).unwrap();
}
// Show available IP addresses on the system.
let _ = addrs.chunks(2).map(|x| {
if x.len() == 2 {
ui.columns(2, |columns| {
let addr0 = x.get(0).unwrap();
columns[0].vertical_centered(|ui| {
View::radio_value(ui,
&mut selected_addr,
addr0,
addr0.to_string());
});
let addr1 = x.get(1).unwrap();
columns[1].vertical_centered(|ui| {
View::radio_value(ui,
&mut selected_addr,
addr1,
addr1.to_string());
})
});
} else {
let addr = x.get(0).unwrap();
View::radio_value(ui,
&mut selected_addr,
addr,
addr.to_string());
}
ui.add_space(10.0);
}).collect::<Vec<_>>();
// Save stratum server address at config if it was changed and check port availability.
if saved_ip_addr != selected_addr {
NodeConfig::save_api_server_address_port(selected_addr.to_string(), port.to_string());
let available = Network::is_port_available(selected_addr.to_string().as_str(), port);
self.api_port_available = available;
}
}
}

View file

@ -1,16 +0,0 @@
// Copyright 2023 The Grim Developers
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
// /// Integrated node server setup ui section.
// struct

View file

@ -25,15 +25,15 @@ use crate::node::NodeConfig;
/// Stratum server setup ui section. /// Stratum server setup ui section.
pub struct StratumServerSetup { pub struct StratumServerSetup {
/// Stratum address to be used inside edit modal. /// Stratum IP address to be used inside edit modal.
stratum_address_edit: String, stratum_address_edit: String,
/// Stratum port to be used inside edit modal. /// Stratum port to be used inside edit modal.
stratum_port_edit: String, stratum_port_edit: String,
/// Flag to check if stratum port is available inside edit modal. /// Flag to check if stratum port is available inside edit modal.
port_available_edit: bool, stratum_port_available_edit: bool,
/// Flag to check if stratum port is available from saved config value. /// Flag to check if stratum port is available from saved config value.
pub(crate) stratum_port_available: bool pub(crate) is_stratum_port_available: bool
} }
impl Default for StratumServerSetup { impl Default for StratumServerSetup {
@ -43,8 +43,8 @@ impl Default for StratumServerSetup {
Self { Self {
stratum_address_edit: stratum_address, stratum_address_edit: stratum_address,
stratum_port_edit: stratum_port.to_string(), stratum_port_edit: stratum_port.to_string(),
port_available_edit: is_port_available, stratum_port_available_edit: is_port_available,
stratum_port_available: is_port_available is_stratum_port_available: is_port_available
} }
} }
} }
@ -61,13 +61,7 @@ impl StratumServerSetup {
// Show error message when IP addresses are not available on the system. // Show error message when IP addresses are not available on the system.
let addrs = Network::get_ip_list(); let addrs = Network::get_ip_list();
if addrs.is_empty() { if addrs.is_empty() {
ui.vertical_centered(|ui| { Network::no_ip_address_ui(ui);
ui.label(RichText::new(t!("network_mining.no_ip_addresses"))
.size(16.0)
.color(Colors::INACTIVE_TEXT)
);
ui.add_space(6.0);
});
return; return;
} }
@ -96,7 +90,7 @@ impl StratumServerSetup {
// Setup values for modal. // Setup values for modal.
self.stratum_address_edit = stratum_address.clone(); self.stratum_address_edit = stratum_address.clone();
self.stratum_port_edit = stratum_port.to_string(); self.stratum_port_edit = stratum_port.to_string();
self.port_available_edit = Network::is_port_available( self.stratum_port_available_edit = Network::is_port_available(
stratum_address.as_str(), stratum_address.as_str(),
stratum_port stratum_port
); );
@ -111,7 +105,7 @@ impl StratumServerSetup {
ui.add_space(14.0); ui.add_space(14.0);
// Show error when stratum server port is unavailable. // Show error when stratum server port is unavailable.
if !self.stratum_port_available { if !self.is_stratum_port_available {
ui.label(RichText::new(t!("network_mining.port_unavailable")) ui.label(RichText::new(t!("network_mining.port_unavailable"))
.size(16.0) .size(16.0)
.color(Colors::RED)); .color(Colors::RED));
@ -147,7 +141,7 @@ impl StratumServerSetup {
} }
// Show error when specified port is unavailable. // Show error when specified port is unavailable.
if !self.port_available_edit { if !self.stratum_port_available_edit {
ui.add_space(12.0); ui.add_space(12.0);
ui.label(RichText::new(t!("network_mining.port_unavailable")) ui.label(RichText::new(t!("network_mining.port_unavailable"))
.size(16.0) .size(16.0)
@ -177,16 +171,16 @@ impl StratumServerSetup {
self.stratum_address_edit.as_str(), self.stratum_address_edit.as_str(),
port_parse.unwrap() port_parse.unwrap()
); );
self.port_available_edit = is_available; self.stratum_port_available_edit = is_available;
// Save port at config if it's available. // Save port at config if it's available.
if self.port_available_edit { if self.stratum_port_available_edit {
NodeConfig::save_stratum_address_port( NodeConfig::save_stratum_address_port(
self.stratum_address_edit.clone(), self.stratum_address_edit.clone(),
self.stratum_port_edit.clone() self.stratum_port_edit.clone()
); );
self.stratum_port_available = true; self.is_stratum_port_available = true;
cb.hide_keyboard(); cb.hide_keyboard();
modal.close(); modal.close();
} }
@ -238,11 +232,11 @@ impl StratumServerSetup {
ui.add_space(10.0); ui.add_space(10.0);
}).collect::<Vec<_>>(); }).collect::<Vec<_>>();
// Save stratum server address at config if it was changed. // Save stratum server address at config if it was changed and check port availability.
if saved_ip_addr != selected_addr { if saved_ip_addr != selected_addr {
NodeConfig::save_stratum_address_port(selected_addr.to_string(), port.to_string()); NodeConfig::save_stratum_address_port(selected_addr.to_string(), port.to_string());
let available = Network::is_port_available(selected_addr.to_string().as_str(), port); let available = Network::is_port_available(selected_addr.to_string().as_str(), port);
self.stratum_port_available = available; self.is_stratum_port_available = available;
} }
} }
} }

View file

@ -43,7 +43,7 @@ impl View {
/// Show and cut long text with character. /// Show and cut long text with character.
pub fn ellipsize_text(ui: &mut egui::Ui, text: String, size: f32, color: Color32) { pub fn ellipsize_text(ui: &mut egui::Ui, text: String, size: f32, color: Color32) {
let mut job = LayoutJob::single_section(text, TextFormat { let mut job = LayoutJob::single_section(text, TextFormat {
font_id: FontId::proportional(size), color, .. Default::default() font_id: FontId::proportional(size), color, ..Default::default()
}); });
job.wrap = TextWrapping { job.wrap = TextWrapping {
max_rows: 1, max_rows: 1,
@ -201,7 +201,7 @@ impl View {
/// Draw small gold loading spinner. /// Draw small gold loading spinner.
pub fn small_loading_spinner(ui: &mut egui::Ui) { pub fn small_loading_spinner(ui: &mut egui::Ui) {
Spinner::new().size(48.0).color(Colors::GOLD).ui(ui); Spinner::new().size(42.0).color(Colors::GOLD).ui(ui);
} }
/// Draw the button that looks like checkbox with callback on check. /// Draw the button that looks like checkbox with callback on check.
@ -210,6 +210,7 @@ impl View {
true => { (format!("{} {}", CHECK_SQUARE, text), Colors::TEXT_BUTTON) } true => { (format!("{} {}", CHECK_SQUARE, text), Colors::TEXT_BUTTON) }
false => { (format!("{} {}", SQUARE, text), Colors::TEXT) } false => { (format!("{} {}", SQUARE, text), Colors::TEXT) }
}; };
let br = Button::new(RichText::new(text_value).size(18.0).color(color)) let br = Button::new(RichText::new(text_value).size(18.0).color(color))
.frame(false) .frame(false)
.stroke(Stroke::NONE) .stroke(Stroke::NONE)

View file

@ -151,12 +151,6 @@ impl Node {
loop { loop {
if Self::is_restarting() { if Self::is_restarting() {
// Clean server stats.
{
let mut w_stats = NODE_STATE.stats.write().unwrap();
*w_stats = None;
}
// Stop the server. // Stop the server.
server.stop(); server.stop();