fix(toast): match toast to design

This commit is contained in:
Jeremy Soller 2024-07-11 13:36:53 -06:00
parent 76667418d8
commit a268a98311
No known key found for this signature in database
GPG key ID: D02FD439211AF56F
2 changed files with 40 additions and 11 deletions

View file

@ -15,7 +15,7 @@ use widget::Toaster;
use crate::ext::CollectionWidget; use crate::ext::CollectionWidget;
use super::column; use super::column;
use super::{button, row, text}; use super::{button, icon, row, text};
mod widget; mod widget;
@ -27,18 +27,44 @@ pub fn toaster<'a, Message>(
where where
Message: From<ToastMessage> + Clone + 'static, Message: From<ToastMessage> + Clone + 'static,
{ {
let theme = crate::theme::active();
let cosmic_theme::Spacing {
space_xxxs,
space_xxs,
space_xs,
space_s,
space_m,
..
} = theme.cosmic().spacing;
let make_toast = |toast: &'a Toast<Message>| { let make_toast = |toast: &'a Toast<Message>| {
let row = row() let row = row()
.push(text(&toast.message)) .push(text(&toast.message))
.push_maybe(toast.action.as_ref().map(|action| { .push(
button::standard(&action.description).on_press(action.message.clone()) row()
})) .push_maybe(toast.action.as_ref().map(|action| {
.push(button::standard("close").on_press(ToastMessage(toast.id).into())) button::text(&action.description).on_press(action.message.clone())
.align_items(iced::Alignment::Center); }))
.push(
button::icon(
//TODO: include this in one place
icon::from_svg_bytes(
&include_bytes!("../../../res/icons/window-close-symbolic.svg")[..],
)
.symbolic(true),
)
.icon_size(16)
.on_press(ToastMessage(toast.id).into()),
)
.align_items(iced::Alignment::Center)
.spacing(space_xxs),
)
.align_items(iced::Alignment::Center)
.spacing(space_s);
container(row) container(row)
.padding(crate::theme::active().cosmic().space_xs()) .padding([space_xxs, space_s, space_xxs, space_m])
.style(crate::style::Container::Card) .style(crate::style::Container::Tooltip)
}; };
let col = toasts let col = toasts
@ -47,7 +73,7 @@ where
.rev() .rev()
.map(make_toast) .map(make_toast)
.fold(column::with_capacity(toasts.toasts.len()), Column::push) .fold(column::with_capacity(toasts.toasts.len()), Column::push)
.spacing(crate::theme::active().cosmic().space_xxxs()); .spacing(space_xxxs);
Toaster::new(col.into(), content.into(), toasts.toasts.is_empty()).into() Toaster::new(col.into(), content.into(), toasts.toasts.is_empty()).into()
} }

View file

@ -141,10 +141,13 @@ where
&'b mut self, &'b mut self,
state: &'b mut Tree, state: &'b mut Tree,
layout: Layout<'_>, layout: Layout<'_>,
_renderer: &Renderer, renderer: &Renderer,
) -> Option<overlay::Element<'b, Message, Theme, Renderer>> { ) -> Option<overlay::Element<'b, Message, Theme, Renderer>> {
//TODO: this hides the overlay of the content during the toast
if self.is_empty { if self.is_empty {
None self.content
.as_widget_mut()
.overlay(&mut state.children[0], layout, renderer)
} else { } else {
let bounds = layout.bounds(); let bounds = layout.bounds();