RR: MessageDialog!

This commit is contained in:
Ward from fusion-voyager-3 2024-02-03 23:00:54 +03:00
parent d48c2e1062
commit cc916d1516
3 changed files with 23 additions and 5 deletions

View File

@ -62,7 +62,8 @@ pub fn first_setup(window: &adw::ApplicationWindow) {
// Initial Carousel // Initial Carousel
initial_carousel(&first_setup_carousel); initial_carousel(&first_setup_carousel);
internet_carousel(&first_setup_carousel, &internet_connected); internet_carousel(&first_setup_carousel, &internet_connected, &window);
update_carousel(&first_setup_carousel, &internet_connected); update_carousel(&first_setup_carousel, &internet_connected);
// Add file to window // Add file to window

View File

@ -14,8 +14,9 @@ use std::cell::RefCell;
use std::rc::Rc; use std::rc::Rc;
use std::borrow::Borrow as the_rc_borrow; use std::borrow::Borrow as the_rc_borrow;
use std::env; use std::env;
use gtk::gio::ffi::GAsyncReadyCallback;
pub fn internet_carousel(first_setup_carousel: &adw::Carousel, internet_connected: &Rc<RefCell<bool>>) { pub fn internet_carousel(first_setup_carousel: &adw::Carousel, internet_connected: &Rc<RefCell<bool>>, window: &adw::ApplicationWindow) {
let (internet_loop_sender, internet_loop_receiver) = async_channel::unbounded(); let (internet_loop_sender, internet_loop_receiver) = async_channel::unbounded();
let internet_loop_sender = internet_loop_sender.clone(); let internet_loop_sender = internet_loop_sender.clone();
@ -127,6 +128,18 @@ pub fn internet_carousel(first_setup_carousel: &adw::Carousel, internet_connecte
first_setup_internet_box.append(&first_setup_internet_button); first_setup_internet_box.append(&first_setup_internet_button);
first_setup_internet_box.append(&internet_buttons_box); first_setup_internet_box.append(&internet_buttons_box);
let first_setup_internet_skip_dialog = adw::MessageDialog::builder()
.heading("Skip Network Setup?")
.body("Skipping Network Setup will make many of the next steps unavailable!\nThis is NOT recommended.")
.transient_for(window)
.hide_on_close(true)
.build();
first_setup_internet_skip_dialog.add_response("skip_cancel", "Return to Network Setup");
first_setup_internet_skip_dialog.add_response("skip_confirm", "Just Skip!");
first_setup_internet_skip_dialog.set_response_appearance("skip_confirm", adw::ResponseAppearance::Destructive);
let internet_connected_status = internet_connected.clone(); let internet_connected_status = internet_connected.clone();
let internet_loop_context = MainContext::default(); let internet_loop_context = MainContext::default();
@ -167,7 +180,11 @@ pub fn internet_carousel(first_setup_carousel: &adw::Carousel, internet_connecte
first_setup_carousel.scroll_to(&first_setup_carousel.nth_page(2), true); first_setup_carousel.scroll_to(&first_setup_carousel.nth_page(2), true);
})); }));
internet_skip_button.connect_clicked(clone!(@weak first_setup_carousel => move |_| { internet_skip_button.connect_clicked(clone!(@weak first_setup_carousel, @weak first_setup_internet_skip_dialog => move |_| {
first_setup_internet_skip_dialog.choose(None::<&gio::Cancellable>, move |choice| {
if choice == "skip_confirm" {
first_setup_carousel.scroll_to(&first_setup_carousel.nth_page(2), true); first_setup_carousel.scroll_to(&first_setup_carousel.nth_page(2), true);
}
});
})); }));
} }

View File

@ -70,6 +70,6 @@ pub fn update_carousel(first_setup_carousel: &adw::Carousel, internet_connected:
})); }));
first_setup_start_button.connect_clicked(clone!(@strong internet_connected_status, @weak first_setup_carousel => move |_| { first_setup_start_button.connect_clicked(clone!(@strong internet_connected_status, @weak first_setup_carousel => move |_| {
println!("{}", internet_connected_status.borrow_mut()); first_setup_carousel.scroll_to(&first_setup_carousel.nth_page(4), true);
})); }));
} }