egui-toast

Latest version Documentation MIT

Toast notifications for the egui library.

Toast types

Quick start

cargo run --example demo

```rust let mut toasts = Toasts::new() .anchor((300.0, 300.0)) .direction(egui::Direction::BottomUp) .aligntoend(true);

if ui.button("Add toast").clicked() { toasts.info("Hello, World!", Duration::from_secs(5)); }

// or toasts.warning("Hello, World!", ToastOptions { showicon: true, ..ToastOptions::withduration(Duration::fromsecs(5)) }); // or toasts.add(Toast { text: "Hello, World!".into(), kind: ToastKind::Error, options: Duration::fromsecs(5).into() });

// Show all toasts toasts.show(ctx); ```

Customization

Look of the notifications can be fully customized.

```rust const MYCUSTOMTOAST: u32 = 0;

fn mycustomtoastcontents(ui: &mut Ui, toast: &mut Toast) -> Response { egui::Frame::default() .fill(Color32::fromrgb(33, 150, 243)) .inner_margin(Margin::same(12.0)) .rounding(4.0) .show(ui, |ui| { ui.label(toast.text.clone().color(Color32::WHITE));

        if ui.button("Close me").clicked() {
            toast.close();
        }
    }).response

}

let mut toasts = Toasts::new() .customcontents(MYCUSTOMTOAST, mycustomtoastcontents);

if ui.button("Add toast").clicked() { toasts.add(Toast { text: "Hello, World!".into(), kind: ToastKind::Custom(MYCUSTOMTOAST), options: ToastOptions::default() }); }

toasts.show(ctx); ```