ui: qr scan and accounts modals module, parsing messages fix
This commit is contained in:
parent
fe5aca6f0e
commit
7cedebc70e
7 changed files with 202 additions and 136 deletions
|
@ -13,20 +13,19 @@
|
||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
|
|
||||||
use std::time::Duration;
|
use std::time::Duration;
|
||||||
use egui::{Align, Id, Layout, Margin, RichText, ScrollArea};
|
use egui::{Align, Id, Layout, Margin, RichText};
|
||||||
use egui::scroll_area::ScrollBarVisibility;
|
|
||||||
use grin_chain::SyncStatus;
|
use grin_chain::SyncStatus;
|
||||||
use grin_core::core::amount_to_hr_string;
|
use grin_core::core::amount_to_hr_string;
|
||||||
|
|
||||||
use crate::AppConfig;
|
use crate::AppConfig;
|
||||||
use crate::gui::Colors;
|
use crate::gui::Colors;
|
||||||
use crate::gui::icons::{ARROWS_CLOCKWISE, BRIDGE, CHAT_CIRCLE_TEXT, COPY, FOLDER_USER, GEAR_FINE, GRAPH, PACKAGE, POWER, SCAN, SPINNER, USERS_THREE};
|
use crate::gui::icons::{ARROWS_CLOCKWISE, BRIDGE, CHAT_CIRCLE_TEXT, FOLDER_USER, GEAR_FINE, GRAPH, PACKAGE, POWER, SCAN, SPINNER, USERS_THREE};
|
||||||
use crate::gui::platform::PlatformCallbacks;
|
use crate::gui::platform::PlatformCallbacks;
|
||||||
use crate::gui::views::{CameraContent, Modal, Content, View};
|
use crate::gui::views::{Modal, Content, View};
|
||||||
use crate::gui::views::types::{ModalPosition, QrScanResult};
|
use crate::gui::views::types::{ModalPosition, QrScanResult};
|
||||||
use crate::gui::views::wallets::{WalletTransactions, WalletMessages, WalletTransport};
|
use crate::gui::views::wallets::{WalletTransactions, WalletMessages, WalletTransport};
|
||||||
use crate::gui::views::wallets::types::{GRIN, WalletTab, WalletTabType};
|
use crate::gui::views::wallets::types::{GRIN, WalletTab, WalletTabType};
|
||||||
use crate::gui::views::wallets::wallet::accounts::WalletAccounts;
|
use crate::gui::views::wallets::wallet::modals::{WalletAccountsModal, WalletScanModal};
|
||||||
use crate::gui::views::wallets::wallet::WalletSettings;
|
use crate::gui::views::wallets::wallet::WalletSettings;
|
||||||
use crate::node::Node;
|
use crate::node::Node;
|
||||||
use crate::wallet::{Wallet, WalletConfig};
|
use crate::wallet::{Wallet, WalletConfig};
|
||||||
|
@ -35,12 +34,10 @@ use crate::wallet::types::WalletData;
|
||||||
/// Selected and opened wallet content.
|
/// Selected and opened wallet content.
|
||||||
pub struct WalletContent {
|
pub struct WalletContent {
|
||||||
/// Wallet accounts [`Modal`] content.
|
/// Wallet accounts [`Modal`] content.
|
||||||
accounts_modal_content: Option<WalletAccounts>,
|
accounts_modal_content: Option<WalletAccountsModal>,
|
||||||
|
|
||||||
/// Camera content for QR scan [`Modal`].
|
/// QR code scan [`Modal`] content.
|
||||||
camera_content: CameraContent,
|
scan_modal_content: Option<WalletScanModal>,
|
||||||
/// QR code scan result
|
|
||||||
qr_scan_result: Option<QrScanResult>,
|
|
||||||
|
|
||||||
/// Current tab content to show.
|
/// Current tab content to show.
|
||||||
pub current_tab: Box<dyn WalletTab>,
|
pub current_tab: Box<dyn WalletTab>,
|
||||||
|
@ -57,8 +54,7 @@ impl WalletContent {
|
||||||
pub fn new(data: Option<String>) -> Self {
|
pub fn new(data: Option<String>) -> Self {
|
||||||
let mut content = Self {
|
let mut content = Self {
|
||||||
accounts_modal_content: None,
|
accounts_modal_content: None,
|
||||||
camera_content: CameraContent::default(),
|
scan_modal_content: None,
|
||||||
qr_scan_result: None,
|
|
||||||
current_tab: Box::new(WalletTransactions::default()),
|
current_tab: Box::new(WalletTransactions::default()),
|
||||||
};
|
};
|
||||||
// Provide data to messages.
|
// Provide data to messages.
|
||||||
|
@ -180,7 +176,7 @@ impl WalletContent {
|
||||||
/// Draw [`Modal`] content for this ui container.
|
/// Draw [`Modal`] content for this ui container.
|
||||||
fn modal_content_ui(&mut self,
|
fn modal_content_ui(&mut self,
|
||||||
ui: &mut egui::Ui,
|
ui: &mut egui::Ui,
|
||||||
wallet: &mut Wallet,
|
wallet: &Wallet,
|
||||||
cb: &dyn PlatformCallbacks) {
|
cb: &dyn PlatformCallbacks) {
|
||||||
match Modal::opened() {
|
match Modal::opened() {
|
||||||
None => {}
|
None => {}
|
||||||
|
@ -194,9 +190,36 @@ impl WalletContent {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
QR_CODE_SCAN_MODAL => {
|
QR_CODE_SCAN_MODAL => {
|
||||||
|
if let Some(content) = self.scan_modal_content.as_mut() {
|
||||||
Modal::ui(ui.ctx(), |ui, modal| {
|
Modal::ui(ui.ctx(), |ui, modal| {
|
||||||
self.scan_qr_modal_ui(ui, wallet, modal, cb);
|
content.ui(ui, wallet, modal, cb, |result| {
|
||||||
|
match result {
|
||||||
|
QrScanResult::Slatepack(message) => {
|
||||||
|
modal.close();
|
||||||
|
let msg = Some(message.to_string());
|
||||||
|
let messages = WalletMessages::new(msg);
|
||||||
|
self.current_tab = Box::new(messages);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
QrScanResult::Address(receiver) => {
|
||||||
|
let balance = wallet.get_data()
|
||||||
|
.unwrap()
|
||||||
|
.info
|
||||||
|
.amount_currently_spendable;
|
||||||
|
if balance > 0 {
|
||||||
|
modal.close();
|
||||||
|
let mut transport = WalletTransport::default();
|
||||||
|
let rec = Some(receiver.to_string());
|
||||||
|
transport.show_send_tor_modal(cb, rec);
|
||||||
|
self.current_tab = Box::new(transport);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
_ => {}
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
_ => {}
|
_ => {}
|
||||||
}
|
}
|
||||||
|
@ -219,8 +242,7 @@ impl WalletContent {
|
||||||
ui.allocate_ui_with_layout(rect.size(), Layout::right_to_left(Align::Center), |ui| {
|
ui.allocate_ui_with_layout(rect.size(), Layout::right_to_left(Align::Center), |ui| {
|
||||||
// Draw button to scan QR code.
|
// Draw button to scan QR code.
|
||||||
View::item_button(ui, View::item_rounding(0, 2, true), SCAN, None, || {
|
View::item_button(ui, View::item_rounding(0, 2, true), SCAN, None, || {
|
||||||
self.qr_scan_result = None;
|
self.scan_modal_content = Some(WalletScanModal::default());
|
||||||
self.camera_content.clear_state();
|
|
||||||
// Show QR code scan modal.
|
// Show QR code scan modal.
|
||||||
Modal::new(QR_CODE_SCAN_MODAL)
|
Modal::new(QR_CODE_SCAN_MODAL)
|
||||||
.position(ModalPosition::CenterTop)
|
.position(ModalPosition::CenterTop)
|
||||||
|
@ -232,7 +254,7 @@ impl WalletContent {
|
||||||
|
|
||||||
// Draw button to show list of accounts.
|
// Draw button to show list of accounts.
|
||||||
View::item_button(ui, View::item_rounding(1, 3, true), USERS_THREE, None, || {
|
View::item_button(ui, View::item_rounding(1, 3, true), USERS_THREE, None, || {
|
||||||
self.accounts_modal_content = Some(WalletAccounts::new(wallet.accounts()));
|
self.accounts_modal_content = Some(WalletAccountsModal::new(wallet.accounts()));
|
||||||
// Show account list modal.
|
// Show account list modal.
|
||||||
Modal::new(ACCOUNT_LIST_MODAL)
|
Modal::new(ACCOUNT_LIST_MODAL)
|
||||||
.position(ModalPosition::CenterTop)
|
.position(ModalPosition::CenterTop)
|
||||||
|
@ -299,113 +321,6 @@ impl WalletContent {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Draw QR code scan [`Modal`] content.
|
|
||||||
fn scan_qr_modal_ui(&mut self,
|
|
||||||
ui: &mut egui::Ui,
|
|
||||||
wallet: &mut Wallet,
|
|
||||||
modal: &Modal,
|
|
||||||
cb: &dyn PlatformCallbacks) {
|
|
||||||
// Show scan result if exists or show camera content while scanning.
|
|
||||||
if let Some(result) = &self.qr_scan_result {
|
|
||||||
let mut result_text = result.text();
|
|
||||||
View::horizontal_line(ui, Colors::item_stroke());
|
|
||||||
ui.add_space(3.0);
|
|
||||||
ScrollArea::vertical()
|
|
||||||
.id_source(Id::from("qr_scan_result_input").with(wallet.get_config().id))
|
|
||||||
.scroll_bar_visibility(ScrollBarVisibility::AlwaysHidden)
|
|
||||||
.max_height(128.0)
|
|
||||||
.auto_shrink([false; 2])
|
|
||||||
.show(ui, |ui| {
|
|
||||||
ui.add_space(7.0);
|
|
||||||
egui::TextEdit::multiline(&mut result_text)
|
|
||||||
.font(egui::TextStyle::Small)
|
|
||||||
.desired_rows(5)
|
|
||||||
.interactive(false)
|
|
||||||
.desired_width(f32::INFINITY)
|
|
||||||
.show(ui);
|
|
||||||
ui.add_space(6.0);
|
|
||||||
});
|
|
||||||
ui.add_space(2.0);
|
|
||||||
View::horizontal_line(ui, Colors::item_stroke());
|
|
||||||
ui.add_space(10.0);
|
|
||||||
|
|
||||||
// Show copy button.
|
|
||||||
ui.vertical_centered(|ui| {
|
|
||||||
let copy_text = format!("{} {}", COPY, t!("copy"));
|
|
||||||
View::button(ui, copy_text, Colors::button(), || {
|
|
||||||
cb.copy_string_to_buffer(result_text.to_string());
|
|
||||||
self.qr_scan_result = None;
|
|
||||||
modal.close();
|
|
||||||
});
|
|
||||||
});
|
|
||||||
ui.add_space(10.0);
|
|
||||||
View::horizontal_line(ui, Colors::item_stroke());
|
|
||||||
ui.add_space(6.0);
|
|
||||||
} else if let Some(result) = self.camera_content.qr_scan_result() {
|
|
||||||
cb.stop_camera();
|
|
||||||
self.camera_content.clear_state();
|
|
||||||
match &result {
|
|
||||||
QrScanResult::Slatepack(message) => {
|
|
||||||
// Redirect to messages to handle parsed message.
|
|
||||||
let mut messages =
|
|
||||||
WalletMessages::new(Some(message.to_string()));
|
|
||||||
messages.parse_message(wallet);
|
|
||||||
modal.close();
|
|
||||||
self.current_tab = Box::new(messages);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
QrScanResult::Address(receiver) => {
|
|
||||||
if wallet.get_data().unwrap().info.amount_currently_spendable > 0 {
|
|
||||||
// Redirect to send amount with Tor.
|
|
||||||
let mut transport = WalletTransport::default();
|
|
||||||
modal.close();
|
|
||||||
transport.show_send_tor_modal(cb, Some(receiver.to_string()));
|
|
||||||
self.current_tab = Box::new(transport);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
_ => {}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Set result and rename modal title.
|
|
||||||
self.qr_scan_result = Some(result);
|
|
||||||
Modal::set_title(t!("scan_result"));
|
|
||||||
} else {
|
|
||||||
ui.add_space(6.0);
|
|
||||||
self.camera_content.ui(ui, cb);
|
|
||||||
ui.add_space(6.0);
|
|
||||||
}
|
|
||||||
|
|
||||||
if self.qr_scan_result.is_some() {
|
|
||||||
// Setup spacing between buttons.
|
|
||||||
ui.spacing_mut().item_spacing = egui::Vec2::new(8.0, 0.0);
|
|
||||||
|
|
||||||
ui.columns(2, |columns| {
|
|
||||||
columns[0].vertical_centered_justified(|ui| {
|
|
||||||
View::button(ui, t!("close"), Colors::white_or_black(false), || {
|
|
||||||
self.qr_scan_result = None;
|
|
||||||
modal.close();
|
|
||||||
});
|
|
||||||
});
|
|
||||||
columns[1].vertical_centered_justified(|ui| {
|
|
||||||
View::button(ui, t!("repeat"), Colors::white_or_black(false), || {
|
|
||||||
Modal::set_title(t!("scan_qr"));
|
|
||||||
self.qr_scan_result = None;
|
|
||||||
cb.start_camera();
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
ui.vertical_centered_justified(|ui| {
|
|
||||||
View::button(ui, t!("modal.cancel"), Colors::white_or_black(false), || {
|
|
||||||
cb.stop_camera();
|
|
||||||
modal.close();
|
|
||||||
});
|
|
||||||
});
|
|
||||||
}
|
|
||||||
ui.add_space(6.0);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Draw tab buttons in the bottom of the screen.
|
/// Draw tab buttons in the bottom of the screen.
|
||||||
fn tabs_ui(&mut self, ui: &mut egui::Ui) {
|
fn tabs_ui(&mut self, ui: &mut egui::Ui) {
|
||||||
ui.scope(|ui| {
|
ui.scope(|ui| {
|
||||||
|
|
|
@ -378,7 +378,6 @@ impl WalletMessages {
|
||||||
// Parse Slatepack message resetting message error.
|
// Parse Slatepack message resetting message error.
|
||||||
if buf != previous {
|
if buf != previous {
|
||||||
self.parse_message(wallet);
|
self.parse_message(wallet);
|
||||||
self.parse_message(wallet);
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
@ -405,7 +404,7 @@ impl WalletMessages {
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Parse message input making operation based on incoming status.
|
/// Parse message input making operation based on incoming status.
|
||||||
pub fn parse_message(&mut self, wallet: &Wallet) {
|
fn parse_message(&mut self, wallet: &Wallet) {
|
||||||
self.message_error.clear();
|
self.message_error.clear();
|
||||||
self.message_edit = self.message_edit.trim().to_string();
|
self.message_edit = self.message_edit.trim().to_string();
|
||||||
if self.message_edit.is_empty() {
|
if self.message_edit.is_empty() {
|
||||||
|
|
|
@ -29,4 +29,4 @@ pub use transport::WalletTransport;
|
||||||
mod content;
|
mod content;
|
||||||
pub use content::WalletContent;
|
pub use content::WalletContent;
|
||||||
|
|
||||||
mod accounts;
|
mod modals;
|
|
@ -25,8 +25,8 @@ use crate::gui::views::wallets::wallet::types::GRIN;
|
||||||
use crate::wallet::types::WalletAccount;
|
use crate::wallet::types::WalletAccount;
|
||||||
use crate::wallet::{Wallet, WalletConfig};
|
use crate::wallet::{Wallet, WalletConfig};
|
||||||
|
|
||||||
/// Wallet accounts content.
|
/// Wallet accounts [`Modal`] content.
|
||||||
pub struct WalletAccounts {
|
pub struct WalletAccountsModal {
|
||||||
/// List of wallet accounts.
|
/// List of wallet accounts.
|
||||||
accounts: Vec<WalletAccount>,
|
accounts: Vec<WalletAccount>,
|
||||||
/// Flag to check if account is creating.
|
/// Flag to check if account is creating.
|
||||||
|
@ -37,7 +37,7 @@ pub struct WalletAccounts {
|
||||||
account_creation_error: bool,
|
account_creation_error: bool,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Default for WalletAccounts {
|
impl Default for WalletAccountsModal {
|
||||||
fn default() -> Self {
|
fn default() -> Self {
|
||||||
Self {
|
Self {
|
||||||
accounts: vec![],
|
accounts: vec![],
|
||||||
|
@ -48,7 +48,7 @@ impl Default for WalletAccounts {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl WalletAccounts {
|
impl WalletAccountsModal {
|
||||||
/// Create new instance from wallet accounts.
|
/// Create new instance from wallet accounts.
|
||||||
pub fn new(accounts: Vec<WalletAccount>) -> Self {
|
pub fn new(accounts: Vec<WalletAccount>) -> Self {
|
||||||
Self {
|
Self {
|
||||||
|
@ -62,7 +62,7 @@ impl WalletAccounts {
|
||||||
/// Draw [`Modal`] content.
|
/// Draw [`Modal`] content.
|
||||||
pub fn ui(&mut self,
|
pub fn ui(&mut self,
|
||||||
ui: &mut egui::Ui,
|
ui: &mut egui::Ui,
|
||||||
wallet: &mut Wallet,
|
wallet: &Wallet,
|
||||||
modal: &Modal,
|
modal: &Modal,
|
||||||
cb: &dyn PlatformCallbacks) {
|
cb: &dyn PlatformCallbacks) {
|
||||||
if self.account_creating {
|
if self.account_creating {
|
||||||
|
@ -180,7 +180,7 @@ const ACCOUNT_ITEM_HEIGHT: f32 = 75.0;
|
||||||
/// Draw account item.
|
/// Draw account item.
|
||||||
fn account_item_ui(ui: &mut egui::Ui,
|
fn account_item_ui(ui: &mut egui::Ui,
|
||||||
modal: &Modal,
|
modal: &Modal,
|
||||||
wallet: &mut Wallet,
|
wallet: &Wallet,
|
||||||
acc: &WalletAccount,
|
acc: &WalletAccount,
|
||||||
index: usize,
|
index: usize,
|
||||||
size: usize) {
|
size: usize) {
|
19
src/gui/views/wallets/wallet/modals/mod.rs
Normal file
19
src/gui/views/wallets/wallet/modals/mod.rs
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
// Copyright 2024 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.
|
||||||
|
|
||||||
|
mod accounts;
|
||||||
|
pub use accounts::*;
|
||||||
|
|
||||||
|
mod scan;
|
||||||
|
pub use scan::*;
|
133
src/gui/views/wallets/wallet/modals/scan.rs
Normal file
133
src/gui/views/wallets/wallet/modals/scan.rs
Normal file
|
@ -0,0 +1,133 @@
|
||||||
|
// Copyright 2024 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 egui::scroll_area::ScrollBarVisibility;
|
||||||
|
use egui::{Id, ScrollArea};
|
||||||
|
|
||||||
|
use crate::gui::Colors;
|
||||||
|
use crate::gui::icons::COPY;
|
||||||
|
use crate::gui::platform::PlatformCallbacks;
|
||||||
|
use crate::gui::views::{CameraContent, Modal, View};
|
||||||
|
use crate::gui::views::types::QrScanResult;
|
||||||
|
use crate::wallet::Wallet;
|
||||||
|
|
||||||
|
/// QR code scan [`Modal`] content.
|
||||||
|
pub struct WalletScanModal {
|
||||||
|
/// Camera content for QR scan [`Modal`].
|
||||||
|
camera_content: Option<CameraContent>,
|
||||||
|
/// QR code scan result
|
||||||
|
qr_scan_result: Option<QrScanResult>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Default for WalletScanModal {
|
||||||
|
fn default() -> Self {
|
||||||
|
Self {
|
||||||
|
camera_content: None,
|
||||||
|
qr_scan_result: None,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl WalletScanModal {
|
||||||
|
/// Draw [`Modal`] content.
|
||||||
|
pub fn ui(&mut self,
|
||||||
|
ui: &mut egui::Ui,
|
||||||
|
wallet: &Wallet,
|
||||||
|
modal: &Modal,
|
||||||
|
cb: &dyn PlatformCallbacks,
|
||||||
|
mut on_result: impl FnMut(&QrScanResult)) {
|
||||||
|
// Show scan result if exists or show camera content while scanning.
|
||||||
|
if let Some(result) = &self.qr_scan_result {
|
||||||
|
let mut result_text = result.text();
|
||||||
|
View::horizontal_line(ui, Colors::item_stroke());
|
||||||
|
ui.add_space(3.0);
|
||||||
|
ScrollArea::vertical()
|
||||||
|
.id_source(Id::from("qr_scan_result_input").with(wallet.get_config().id))
|
||||||
|
.scroll_bar_visibility(ScrollBarVisibility::AlwaysHidden)
|
||||||
|
.max_height(128.0)
|
||||||
|
.auto_shrink([false; 2])
|
||||||
|
.show(ui, |ui| {
|
||||||
|
ui.add_space(7.0);
|
||||||
|
egui::TextEdit::multiline(&mut result_text)
|
||||||
|
.font(egui::TextStyle::Small)
|
||||||
|
.desired_rows(5)
|
||||||
|
.interactive(false)
|
||||||
|
.desired_width(f32::INFINITY)
|
||||||
|
.show(ui);
|
||||||
|
ui.add_space(6.0);
|
||||||
|
});
|
||||||
|
ui.add_space(2.0);
|
||||||
|
View::horizontal_line(ui, Colors::item_stroke());
|
||||||
|
ui.add_space(10.0);
|
||||||
|
|
||||||
|
// Show copy button.
|
||||||
|
ui.vertical_centered(|ui| {
|
||||||
|
let copy_text = format!("{} {}", COPY, t!("copy"));
|
||||||
|
View::button(ui, copy_text, Colors::button(), || {
|
||||||
|
cb.copy_string_to_buffer(result_text.to_string());
|
||||||
|
self.qr_scan_result = None;
|
||||||
|
modal.close();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
ui.add_space(10.0);
|
||||||
|
View::horizontal_line(ui, Colors::item_stroke());
|
||||||
|
ui.add_space(6.0);
|
||||||
|
} else if let Some(result) = self.camera_content.get_or_insert(CameraContent::default())
|
||||||
|
.qr_scan_result() {
|
||||||
|
cb.stop_camera();
|
||||||
|
self.camera_content = None;
|
||||||
|
on_result(&result);
|
||||||
|
|
||||||
|
// Set result and rename modal title.
|
||||||
|
self.qr_scan_result = Some(result);
|
||||||
|
Modal::set_title(t!("scan_result"));
|
||||||
|
} else {
|
||||||
|
ui.add_space(6.0);
|
||||||
|
self.camera_content.as_mut().unwrap().ui(ui, cb);
|
||||||
|
ui.add_space(6.0);
|
||||||
|
}
|
||||||
|
|
||||||
|
if self.qr_scan_result.is_some() {
|
||||||
|
// Setup spacing between buttons.
|
||||||
|
ui.spacing_mut().item_spacing = egui::Vec2::new(8.0, 0.0);
|
||||||
|
|
||||||
|
ui.columns(2, |columns| {
|
||||||
|
columns[0].vertical_centered_justified(|ui| {
|
||||||
|
View::button(ui, t!("close"), Colors::white_or_black(false), || {
|
||||||
|
self.qr_scan_result = None;
|
||||||
|
self.camera_content = None;
|
||||||
|
modal.close();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
columns[1].vertical_centered_justified(|ui| {
|
||||||
|
View::button(ui, t!("repeat"), Colors::white_or_black(false), || {
|
||||||
|
Modal::set_title(t!("scan_qr"));
|
||||||
|
self.qr_scan_result = None;
|
||||||
|
self.camera_content = Some(CameraContent::default());
|
||||||
|
cb.start_camera();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
ui.vertical_centered_justified(|ui| {
|
||||||
|
View::button(ui, t!("modal.cancel"), Colors::white_or_black(false), || {
|
||||||
|
cb.stop_camera();
|
||||||
|
self.camera_content = None;
|
||||||
|
modal.close();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
ui.add_space(6.0);
|
||||||
|
}
|
||||||
|
}
|
|
@ -471,7 +471,7 @@ impl Wallet {
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Set active account from provided label.
|
/// Set active account from provided label.
|
||||||
pub fn set_active_account(&mut self, label: &String) -> Result<(), Error> {
|
pub fn set_active_account(&self, label: &String) -> Result<(), Error> {
|
||||||
let mut api = Owner::new(self.instance.clone().unwrap(), None);
|
let mut api = Owner::new(self.instance.clone().unwrap(), None);
|
||||||
controller::owner_single_use(None, None, Some(&mut api), |api, m| {
|
controller::owner_single_use(None, None, Some(&mut api), |api, m| {
|
||||||
api.set_active_account(m, label)?;
|
api.set_active_account(m, label)?;
|
||||||
|
|
Loading…
Reference in a new issue