fix(toast): match toast to design
This commit is contained in:
parent
76667418d8
commit
a268a98311
2 changed files with 40 additions and 11 deletions
|
|
@ -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()
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -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();
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue