Trait gtk4::prelude::DialogExtManual[][src]

pub trait DialogExtManual: 'static {
    fn add_buttons(&self, buttons: &[(&str, ResponseType)]);
fn response_for_widget<P: IsA<Widget>>(&self, widget: &P) -> ResponseType;
fn run_future<'a>(
        &'a self
    ) -> Pin<Box<dyn Future<Output = ResponseType> + 'a>>;
fn run_async<F: FnOnce(&Self, ResponseType) + 'static>(&self, f: F); }

Required methods

Adds multiple buttons.

This is the same as calling DialogExt::add_button() repeatedly. The variable argument list should be None-terminated as with Dialog::with_buttons(). Each button must have both text and response ID.

first_button_text

button text

Gets the response id of a widget in the action area of a dialog.

widget

a widget in the action area of self

Returns

the response id of widget, or ResponseType::None if widget doesn’t have a response id set.

Shows the dialog and returns a Future that resolves to the ResponseType on response.

use gtk4::prelude::*;

let dialog = gtk4::MessageDialogBuilder::new()
   .buttons(gtk4::ButtonsType::OkCancel)
   .text("What is your answer?")
   .build();

let answer = dialog.run_future().await;
dialog.close();
println!("Answer: {:?}", answer);

Shows the dialog and calls the callback when a response has been received.

Important: this function isn’t blocking.

use gtk4::prelude::*;

let dialog = gtk4::MessageDialogBuilder::new()
   .buttons(gtk4::ButtonsType::OkCancel)
   .text("What is your answer?")
   .build();

dialog.run_async(|obj, answer| {
    obj.close();
    println!("Answer: {:?}", answer);
});

Implementors