iced-yoda/style/src/container.rs

63 lines
1.7 KiB
Rust
Raw Normal View History

2022-11-10 01:10:28 +01:00
//! Change the appearance of a container.
2024-01-10 02:58:40 +01:00
use crate::core::{Background, BorderRadius, Color, Pixels};
/// The appearance of a container.
#[derive(Debug, Clone, Copy)]
pub struct Appearance {
2022-11-10 01:10:28 +01:00
/// The text [`Color`] of the container.
pub text_color: Option<Color>,
2022-11-10 01:10:28 +01:00
/// The [`Background`] of the container.
pub background: Option<Background>,
2022-11-10 01:10:28 +01:00
/// The border radius of the container.
pub border_radius: BorderRadius,
2022-11-10 01:10:28 +01:00
/// The border width of the container.
pub border_width: f32,
2022-11-10 01:10:28 +01:00
/// The border [`Color`] of the container.
2020-01-05 18:38:03 +01:00
pub border_color: Color,
}
2024-01-10 02:58:40 +01:00
impl Appearance {
/// Derives a new [`Appearance`] with a border of the given [`Color`] and
/// `width`.
pub fn with_border(
self,
color: impl Into<Color>,
width: impl Into<Pixels>,
) -> Self {
Self {
border_color: color.into(),
border_width: width.into().0,
..self
}
}
/// Derives a new [`Appearance`] with the given [`Background`].
pub fn with_background(self, background: impl Into<Background>) -> Self {
Self {
background: Some(background.into()),
..self
}
}
}
impl std::default::Default for Appearance {
fn default() -> Self {
Self {
text_color: None,
background: None,
border_radius: 0.0.into(),
border_width: 0.0,
border_color: Color::TRANSPARENT,
}
}
}
/// A set of rules that dictate the [`Appearance`] of a container.
pub trait StyleSheet {
2022-11-10 01:10:28 +01:00
/// The supported style of the [`StyleSheet`].
type Style: Default;
/// Produces the [`Appearance`] of a container.
fn appearance(&self, style: &Self::Style) -> Appearance;
}