From f54993483f180a78e565b939e232514237a6f260 Mon Sep 17 00:00:00 2001 From: ardocrat Date: Tue, 15 Aug 2023 21:20:20 +0300 Subject: [PATCH] ui: optimize panels width --- src/gui/views/network/content.rs | 17 +++++-------- src/gui/views/views.rs | 19 ++++++++++++++ src/gui/views/wallets/content.rs | 19 ++++++-------- src/gui/views/wallets/creation/creation.rs | 29 ++++++---------------- src/gui/views/wallets/wallet/content.rs | 11 +------- src/gui/views/wallets/wallet/settings.rs | 14 ++--------- 6 files changed, 42 insertions(+), 67 deletions(-) diff --git a/src/gui/views/network/content.rs b/src/gui/views/network/content.rs index 55942b3..9dbd597 100644 --- a/src/gui/views/network/content.rs +++ b/src/gui/views/network/content.rs @@ -93,8 +93,6 @@ impl NetworkContent { }); }); - let content_width = ui.available_width(); - // Show connections content. egui::CentralPanel::default() .frame(egui::Frame { @@ -130,15 +128,12 @@ impl NetworkContent { .show(ui, |ui| { ui.add_space(1.0); ui.vertical_centered(|ui| { - // Setup wallet list width. - let mut rect = ui.available_rect_before_wrap(); - let mut width = ui.available_width(); - if !Root::is_dual_panel_mode(frame) { - width = f32::min(width, Root::SIDE_PANEL_WIDTH * 1.4) - } - rect.set_width(width); - - ui.allocate_ui(rect.size(), |ui| { + let max_width = if !Root::is_dual_panel_mode(frame) { + Root::SIDE_PANEL_WIDTH * 1.3 + } else { + ui.available_width() + }; + View::max_width_ui(ui, max_width, |ui| { self.connections.ui(ui, frame, cb); }); }); diff --git a/src/gui/views/views.rs b/src/gui/views/views.rs index 8422479..b85716c 100644 --- a/src/gui/views/views.rs +++ b/src/gui/views/views.rs @@ -33,6 +33,25 @@ impl View { /// Stroke for hovered items and buttons. pub const HOVER_STROKE: Stroke = Stroke { width: 1.0, color: Colors::ITEM_HOVER }; + /// Draw content with maximum width value. + pub fn max_width_ui(ui: &mut egui::Ui, + max_width: f32, + add_content: impl FnOnce(&mut egui::Ui)) { + // Setup content width. + let mut width = ui.available_width(); + if width == 0.0 { + return; + } + let mut rect = ui.available_rect_before_wrap(); + width = f32::min(width, max_width); + rect.set_width(width); + + // Draw content. + ui.allocate_ui(rect.size(), |ui| { + (add_content)(ui); + }); + } + /// Callback on Enter key press event. pub fn on_enter_key(ui: &mut egui::Ui, cb: impl FnOnce()) { if ui.ctx().input(|i| i.key_pressed(egui::Key::Enter)) { diff --git a/src/gui/views/wallets/content.rs b/src/gui/views/wallets/content.rs index 8b74d2b..7b858af 100644 --- a/src/gui/views/wallets/content.rs +++ b/src/gui/views/wallets/content.rs @@ -228,7 +228,7 @@ impl WalletsContent { // Setup title. let title_content = if self.wallets.is_selected_open() && (!dual_panel - || (dual_panel && !show_list)) { + || (dual_panel && !show_list)) && !create_wallet { let title_text = self.wallet_content.current_tab.get_type().name().to_uppercase(); if self.wallet_content.current_tab.get_type() == WalletTabType::Settings { TitleType::Single(TitleContentType::Title(title_text)) @@ -332,17 +332,12 @@ impl WalletsContent { .show(ui, |ui| { ui.vertical_centered(|ui| { // Setup wallet list width. - let mut rect = ui.available_rect_before_wrap(); - let mut width = ui.available_width(); - if !dual_panel { - width = f32::min(width, Root::SIDE_PANEL_WIDTH * 1.4) - } - if width == 0.0 { - return; - } - rect.set_width(width); - - ui.allocate_ui(rect.size(), |ui| { + let max_width = if !dual_panel { + Root::SIDE_PANEL_WIDTH * 1.3 + } else { + ui.available_width() + }; + View::max_width_ui(ui, max_width, |ui| { let mut list = self.wallets.list().clone(); // Remove deleted wallet from the list. list.retain(|w| !w.is_deleted()); diff --git a/src/gui/views/wallets/creation/creation.rs b/src/gui/views/wallets/creation/creation.rs index 2838107..03b0875 100644 --- a/src/gui/views/wallets/creation/creation.rs +++ b/src/gui/views/wallets/creation/creation.rs @@ -95,17 +95,7 @@ impl WalletCreation { .show_inside(ui, |ui| { ui.vertical_centered(|ui| { ui.vertical_centered(|ui| { - // Setup content width. - let available_width = ui.available_width(); - if available_width == 0.0 { - return; - } - let mut rect = ui.available_rect_before_wrap(); - let width = f32::min(available_width, Root::SIDE_PANEL_WIDTH * 2.0); - rect.set_width(width); - - // Draw step control content. - ui.allocate_ui(rect.size(), |ui| { + View::max_width_ui(ui, Root::SIDE_PANEL_WIDTH * 2.0, |ui| { self.step_control_ui(ui, on_create); }); }); @@ -137,17 +127,12 @@ impl WalletCreation { .auto_shrink([false; 2]) .show(ui, |ui| { ui.vertical_centered(|ui| { - // Setup content width. - let available_width = ui.available_width(); - if available_width == 0.0 { - return; - } - let mut rect = ui.available_rect_before_wrap(); - let width = f32::min(available_width, Root::SIDE_PANEL_WIDTH * 2.0); - rect.set_width(width); - - // Draw step content. - ui.allocate_ui(rect.size(), |ui| { + let max_width = if self.step == Some(Step::SetupConnection) { + Root::SIDE_PANEL_WIDTH * 1.3 + } else { + Root::SIDE_PANEL_WIDTH * 2.0 + }; + View::max_width_ui(ui, max_width, |ui| { self.step_content_ui(ui, frame, cb); }); }); diff --git a/src/gui/views/wallets/wallet/content.rs b/src/gui/views/wallets/wallet/content.rs index b748385..2475b75 100644 --- a/src/gui/views/wallets/wallet/content.rs +++ b/src/gui/views/wallets/wallet/content.rs @@ -59,17 +59,8 @@ impl WalletContent { }) .show_animated_inside(ui, !Self::block_navigation_on_sync(wallet), |ui| { ui.vertical_centered(|ui| { - // Setup tabs width. - let available_width = ui.available_width(); - if available_width == 0.0 { - return; - } - let mut rect = ui.available_rect_before_wrap(); - let width = f32::min(available_width, Root::SIDE_PANEL_WIDTH * 1.3); - rect.set_width(width); - // Draw wallet tabs. - ui.allocate_ui(rect.size(), |ui| { + View::max_width_ui(ui, Root::SIDE_PANEL_WIDTH * 1.3, |ui| { self.tabs_ui(ui); }); }); diff --git a/src/gui/views/wallets/wallet/settings.rs b/src/gui/views/wallets/wallet/settings.rs index c78a16f..436c6c4 100644 --- a/src/gui/views/wallets/wallet/settings.rs +++ b/src/gui/views/wallets/wallet/settings.rs @@ -15,7 +15,7 @@ use egui::{Id, ScrollArea}; use crate::gui::platform::PlatformCallbacks; -use crate::gui::views::Root; +use crate::gui::views::{Root, View}; use crate::gui::views::wallets::setup::{CommonSetup, ConnectionSetup, RecoverySetup}; use crate::gui::views::wallets::wallet::types::{WalletTab, WalletTabType}; use crate::gui::views::wallets::wallet::WalletContent; @@ -64,17 +64,7 @@ impl WalletTab for WalletSettings { .auto_shrink([false; 2]) .show(ui, |ui| { ui.vertical_centered(|ui| { - // Setup tab content width. - let available_width = ui.available_width(); - if available_width == 0.0 { - return; - } - let mut rect = ui.available_rect_before_wrap(); - let width = f32::min(available_width, Root::SIDE_PANEL_WIDTH * 1.3); - rect.set_width(width); - - // Draw current tab content. - ui.allocate_ui(rect.size(), |ui| { + View::max_width_ui(ui, Root::SIDE_PANEL_WIDTH * 1.3, |ui| { // Show common wallet setup. self.common_setup.ui(ui, frame, wallet, cb); // Show wallet connections setup.