ui: optimize network content panels and paddings

This commit is contained in:
ardocrat 2023-08-11 01:02:08 +03:00
parent 3632d002e7
commit e024dc34c6
5 changed files with 106 additions and 69 deletions

View file

@ -12,7 +12,7 @@
// See the License for the specific language governing permissions and
// limitations under the License.
use egui::{RichText, ScrollArea};
use egui::{RichText, ScrollArea, Stroke};
use egui::style::Margin;
use crate::AppConfig;
@ -27,9 +27,8 @@ use crate::wallet::ExternalConnection;
/// Network content.
pub struct NetworkContent {
/// Current tab content to show.
current_tab: Box<dyn NetworkTab>,
/// Current integrated node tab content.
node_tab_content: Box<dyn NetworkTab>,
/// Connections content.
connections: ConnectionsContent
}
@ -37,7 +36,7 @@ pub struct NetworkContent {
impl Default for NetworkContent {
fn default() -> Self {
Self {
current_tab: Box::new(NetworkNode::default()),
node_tab_content: Box::new(NetworkNode::default()),
connections: ConnectionsContent::default(),
}
}
@ -51,9 +50,9 @@ impl NetworkContent {
// Show title panel.
self.title_ui(ui, frame, show_connections, cb);
// Show bottom tabs.
if !show_connections {
egui::TopBottomPanel::bottom("network_tabs")
// Show integrated node tabs content.
egui::TopBottomPanel::bottom("node_tabs_panel")
.resizable(false)
.frame(egui::Frame {
fill: Colors::FILL,
inner_margin: Margin {
@ -64,33 +63,67 @@ impl NetworkContent {
},
..Default::default()
})
.show_inside(ui, |ui| {
.show_animated_inside(ui, !show_connections, |ui| {
self.tabs_ui(ui);
});
}
// Show current node tab content.
egui::SidePanel::right("node_tab_content_panel")
.resizable(false)
.exact_width(ui.available_width())
.frame(egui::Frame {
stroke: View::DEFAULT_STROKE,
..Default::default()
})
.show_animated_inside(ui, !show_connections, |ui| {
egui::CentralPanel::default()
.frame(egui::Frame {
fill: Colors::WHITE,
stroke: View::DEFAULT_STROKE,
inner_margin: Margin {
left: View::get_left_inset() + 4.0,
right: View::far_right_inset_margin(ui, frame) + 4.0,
top: 3.0,
bottom: if show_connections {
View::get_bottom_inset() + 4.0
} else {
4.0
},
},
fill: if show_connections {
Colors::BUTTON
} else {
Colors::WHITE
bottom: 4.0,
},
..Default::default()
})
.show_inside(ui, |ui| {
if show_connections {
self.node_tab_content.ui(ui, frame, cb);
});
});
let content_width = ui.available_width();
// Show connections content.
egui::CentralPanel::default()
.frame(egui::Frame {
stroke: if show_connections{
View::DEFAULT_STROKE
} else {
Stroke::NONE
},
inner_margin: Margin {
left: if show_connections {
View::get_left_inset() + 4.0
} else {
0.0
},
right: if show_connections {
View::far_right_inset_margin(ui, frame) + 4.0
} else {
0.0
},
top: 3.0,
bottom: View::get_bottom_inset() + 4.0,
},
fill: Colors::BUTTON,
..Default::default()
})
.show_inside(ui, |ui| {
if !show_connections {
return;
}
ScrollArea::vertical()
.id_source("connections_content")
.auto_shrink([false; 2])
@ -106,15 +139,10 @@ impl NetworkContent {
rect.set_width(width);
ui.allocate_ui(rect.size(), |ui| {
// Show connections content.
self.connections.ui(ui, frame, cb);
});
});
});
} else {
// Show current tab content.
self.current_tab.ui(ui, frame, cb);
}
});
// Redraw after delay if node is not syncing to update stats.
@ -132,26 +160,26 @@ impl NetworkContent {
ui.style_mut().spacing.button_padding = egui::vec2(0.0, 8.0);
// Draw tab buttons.
let current_type = self.current_tab.get_type();
let current_type = self.node_tab_content.get_type();
ui.columns(4, |columns| {
columns[0].vertical_centered_justified(|ui| {
View::tab_button(ui, DATABASE, current_type == NetworkTabType::Node, || {
self.current_tab = Box::new(NetworkNode::default());
self.node_tab_content = Box::new(NetworkNode::default());
});
});
columns[1].vertical_centered_justified(|ui| {
View::tab_button(ui, GAUGE, current_type == NetworkTabType::Metrics, || {
self.current_tab = Box::new(NetworkMetrics::default());
self.node_tab_content = Box::new(NetworkMetrics::default());
});
});
columns[2].vertical_centered_justified(|ui| {
View::tab_button(ui, FACTORY, current_type == NetworkTabType::Mining, || {
self.current_tab = Box::new(NetworkMining::default());
self.node_tab_content = Box::new(NetworkMining::default());
});
});
columns[3].vertical_centered_justified(|ui| {
View::tab_button(ui, FADERS, current_type == NetworkTabType::Settings, || {
self.current_tab = Box::new(NetworkSettings::default());
self.node_tab_content = Box::new(NetworkSettings::default());
});
});
});
@ -165,7 +193,7 @@ impl NetworkContent {
show_connections: bool,
cb: &dyn PlatformCallbacks) {
// Setup values for title panel.
let title_text = self.current_tab.get_type().title().to_uppercase();
let title_text = self.node_tab_content.get_type().title().to_uppercase();
let subtitle_text = Node::get_sync_status_text();
let not_syncing = Node::not_syncing();
let title_content = if !show_connections {

View file

@ -59,6 +59,8 @@ impl NetworkTab for NetworkMetrics {
let stats = server_stats.as_ref().unwrap();
ui.add_space(1.0);
// Show emission info.
View::sub_title(ui, format!("{} {}", COINS, t!("network_metrics.emission")));
ui.columns(3, |columns| {

View file

@ -73,11 +73,14 @@ impl NetworkTab for NetworkMining {
.id_source("stratum_setup_scroll")
.auto_shrink([false; 2])
.show(ui, |ui| {
ui.add_space(1.0);
self.stratum_server_setup.ui(ui, frame, cb);
});
return;
}
ui.add_space(1.0);
// Show stratum mining server info.
View::sub_title(ui, format!("{} {}", HARD_DRIVES, t!("network_mining.server")));
ui.columns(2, |columns| {

View file

@ -51,6 +51,8 @@ impl NetworkTab for NetworkNode {
.id_source("integrated_node")
.auto_shrink([false; 2])
.show(ui, |ui| {
ui.add_space(1.0);
// Show header info.
View::sub_title(ui, format!("{} {}", FLOW_ARROW, t!("network_node.header")));
ui.columns(2, |columns| {

View file

@ -92,6 +92,8 @@ impl NetworkTab for NetworkSettings {
.id_source("network_settings")
.auto_shrink([false; 2])
.show(ui, |ui| {
ui.add_space(1.0);
// Draw node setup section.
self.node.ui(ui, frame, cb);