diff options
| author | 2024-01-16 12:02:42 +0100 | |
|---|---|---|
| committer | 2024-01-16 12:02:42 +0100 | |
| commit | 534c7dd7b0bc515c31b6de87b4aa6a35b44c46a0 (patch) | |
| tree | 0ddc8f1b681cbade7e47293bd46a362896aa538a /style/src/theme | |
| parent | 17135cbd56316f31167eb62e026839450506573f (diff) | |
| parent | c4ba657de86d7606587dad5124f435141258f570 (diff) | |
| download | iced-534c7dd7b0bc515c31b6de87b4aa6a35b44c46a0.tar.gz iced-534c7dd7b0bc515c31b6de87b4aa6a35b44c46a0.tar.bz2 iced-534c7dd7b0bc515c31b6de87b4aa6a35b44c46a0.zip | |
Merge branch 'master' into update-winit
Diffstat (limited to '')
| -rw-r--r-- | style/src/theme.rs | 42 | ||||
| -rw-r--r-- | style/src/theme/palette.rs | 3 | 
2 files changed, 39 insertions, 6 deletions
| diff --git a/style/src/theme.rs b/style/src/theme.rs index 47010728..deccf455 100644 --- a/style/src/theme.rs +++ b/style/src/theme.rs @@ -23,6 +23,7 @@ use crate::toggler;  use iced_core::{Background, Color, Vector}; +use std::fmt;  use std::rc::Rc;  /// A built-in theme. @@ -38,18 +39,22 @@ pub enum Theme {  }  impl Theme { +    /// A list with all the defined themes. +    pub const ALL: &'static [Self] = &[Self::Light, Self::Dark]; +      /// Creates a new custom [`Theme`] from the given [`Palette`]. -    pub fn custom(palette: Palette) -> Self { -        Self::custom_with_fn(palette, palette::Extended::generate) +    pub fn custom(name: String, palette: Palette) -> Self { +        Self::custom_with_fn(name, palette, palette::Extended::generate)      }      /// Creates a new custom [`Theme`] from the given [`Palette`], with      /// a custom generator of a [`palette::Extended`].      pub fn custom_with_fn( +        name: String,          palette: Palette,          generate: impl FnOnce(Palette) -> palette::Extended,      ) -> Self { -        Self::Custom(Box::new(Custom::with_fn(palette, generate))) +        Self::Custom(Box::new(Custom::with_fn(name, palette, generate)))      }      /// Returns the [`Palette`] of the [`Theme`]. @@ -71,32 +76,51 @@ impl Theme {      }  } +impl fmt::Display for Theme { +    fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { +        match self { +            Self::Light => write!(f, "Light"), +            Self::Dark => write!(f, "Dark"), +            Self::Custom(custom) => custom.fmt(f), +        } +    } +} +  /// A [`Theme`] with a customized [`Palette`]. -#[derive(Debug, Clone, Copy, PartialEq)] +#[derive(Debug, Clone, PartialEq)]  pub struct Custom { +    name: String,      palette: Palette,      extended: palette::Extended,  }  impl Custom {      /// Creates a [`Custom`] theme from the given [`Palette`]. -    pub fn new(palette: Palette) -> Self { -        Self::with_fn(palette, palette::Extended::generate) +    pub fn new(name: String, palette: Palette) -> Self { +        Self::with_fn(name, palette, palette::Extended::generate)      }      /// Creates a [`Custom`] theme from the given [`Palette`] with      /// a custom generator of a [`palette::Extended`].      pub fn with_fn( +        name: String,          palette: Palette,          generate: impl FnOnce(Palette) -> palette::Extended,      ) -> Self {          Self { +            name,              palette,              extended: generate(palette),          }      }  } +impl fmt::Display for Custom { +    fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { +        write!(f, "{}", self.name) +    } +} +  /// The style of an application.  #[derive(Default)]  pub enum Application { @@ -383,6 +407,12 @@ pub enum Container {      Custom(Box<dyn container::StyleSheet<Style = Theme>>),  } +impl From<container::Appearance> for Container { +    fn from(appearance: container::Appearance) -> Self { +        Self::Custom(Box::new(move |_: &_| appearance)) +    } +} +  impl<T: Fn(&Theme) -> container::Appearance + 'static> From<T> for Container {      fn from(f: T) -> Self {          Self::Custom(Box::new(f)) diff --git a/style/src/theme/palette.rs b/style/src/theme/palette.rs index aaeb799d..76977a29 100644 --- a/style/src/theme/palette.rs +++ b/style/src/theme/palette.rs @@ -82,6 +82,8 @@ pub struct Extended {      pub success: Success,      /// The set of danger colors.      pub danger: Danger, +    /// Whether the palette is dark or not. +    pub is_dark: bool,  }  /// The built-in light variant of an [`Extended`] palette. @@ -113,6 +115,7 @@ impl Extended {                  palette.background,                  palette.text,              ), +            is_dark: is_dark(palette.background),          }      }  } | 
