libcosmic/src/widget/warning.rs

78 lines
2.4 KiB
Rust
Raw Normal View History

2023-01-16 12:04:39 -07:00
// Copyright 2022 System76 <info@system76.com>
// SPDX-License-Identifier: MPL-2.0
use super::icon;
use crate::{theme, widget, Element, Renderer, Theme};
use apply::Apply;
use iced::{alignment, Alignment, Background, Color, Length};
2024-01-30 22:14:00 -05:00
use iced_core::{Border, Shadow};
use std::borrow::Cow;
2023-01-16 12:04:39 -07:00
#[must_use]
pub fn warning<'a, Message>(message: impl Into<Cow<'a, str>>) -> Warning<'a, Message> {
Warning {
message: message.into(),
on_close: None,
}
}
pub struct Warning<'a, Message> {
message: Cow<'a, str>,
on_close: Option<Message>,
}
impl<'a, Message: 'static + Clone> Warning<'a, Message> {
/// The message to emit on button press.
#[must_use]
pub fn on_close(mut self, message: Message) -> Self {
self.on_close = Some(message);
self
}
/// A custom button that has the desired default spacing and padding.
2024-01-30 22:14:00 -05:00
pub fn into_widget(self) -> widget::Container<'a, Message, crate::Theme, Renderer> {
let label = widget::container(crate::widget::text(self.message)).width(Length::Fill);
2023-01-16 12:04:39 -07:00
let close_button = icon::from_name("window-close-symbolic")
.size(16)
.apply(widget::button::icon)
.on_press_maybe(self.on_close);
2023-01-16 12:04:39 -07:00
widget::row::with_capacity(2)
.push(label)
.push(close_button)
2024-10-16 20:36:46 -04:00
.align_y(Alignment::Center)
.apply(widget::container)
2024-10-16 20:36:46 -04:00
.class(theme::Container::custom(warning_container))
.padding(10)
.align_y(alignment::Vertical::Center)
.width(Length::Fill)
2023-01-16 12:04:39 -07:00
}
}
impl<'a, Message: 'static + Clone> From<Warning<'a, Message>> for Element<'a, Message> {
fn from(warning: Warning<'a, Message>) -> Self {
Self::from(warning.into_widget())
}
}
Cosmic advanced text (#103) * wip: update to use cosmic-advanced-text * use cosmic-advanced-text branch of iced * fix: line height and spacing for segmented button and update to get svg fix * fix: spin button styling & spacing * update iced to fix segmented button border radius * feat: example improvements * feat: helper for loading fonts * feat: add focus style to button * fix: slider height and iced fixed * feat: hash icon width and height * cleanup * update ci * refactor: always use lazy feature of iced * update iced * update iced * cleanup & update iced * update iced: new slider & tiny-skia quad updates * update iced: fixes for tiny-skia quad rendering with edge case border radius * re-export iced_runtime & iced_widget * merge master * udpate iced * update iced * update iced * update iced * fix: make rectangle_tracker subscription only return update if there is some * feat: derive macro for loading a cosmic-config * feat (cosmic-config): iced subscription * fix (example): update to rectangle tracker subscription * fix (cosmic-config) * refactor(cosmic-config-derive): add support for types with generic parameters * fix (cosmic-config): feature gate updates for subscription helpers * feat: support for custom & system themes + move cosmic-theme to libcosmic * feat: sorta hacky way of creating header bars for libcosmic + update iced to get support for resizable windows in iced-sctk * update iced * update and reexport sctk * fix: applet border radius * feat (cosmic-theme): add id and name methods * fix(cosmic-theme): reexport palette from cosmic-theme * fix(cosmic-config-derive): allow use with reexported cosmic-config * feat: update iced with fix and refactor applet env vars * update iced
2023-05-30 12:03:15 -04:00
#[must_use]
2024-10-16 20:36:46 -04:00
pub fn warning_container(theme: &Theme) -> widget::container::Style {
let cosmic = theme.cosmic();
2024-10-16 20:36:46 -04:00
widget::container::Style {
icon_color: Some(theme.cosmic().warning.on.into()),
text_color: Some(theme.cosmic().warning.on.into()),
2023-01-16 12:04:39 -07:00
background: Some(Background::Color(theme.cosmic().warning_color().into())),
2024-01-30 22:14:00 -05:00
border: Border {
color: Color::TRANSPARENT,
width: 1.0,
radius: cosmic.corner_radii.radius_0.into(),
},
shadow: Shadow {
color: Color::TRANSPARENT,
offset: iced::Vector::new(0.0, 0.0),
blur_radius: 0.0,
},
2023-01-16 12:04:39 -07:00
}
}