feat(theme): allow hex colors for themes (#1536)
* feat(theme): allow hex colors for themes * feat(theme): allow hex strings to start with # * fix: fix formatting issue * fix: remove debug print statement * fix: apply clippy suggestion for # code Co-authored-by: ramonGonzEdu <rg2872079@gmail.com>
This commit is contained in:
parent
59d753dc2f
commit
b3fab84557
1 changed files with 71 additions and 2 deletions
|
|
@ -1,5 +1,8 @@
|
||||||
use serde::{Deserialize, Serialize};
|
use serde::{
|
||||||
use std::collections::HashMap;
|
de::{Error, Visitor},
|
||||||
|
Deserialize, Deserializer, Serialize, Serializer,
|
||||||
|
};
|
||||||
|
use std::{collections::HashMap, fmt};
|
||||||
|
|
||||||
use super::options::Options;
|
use super::options::Options;
|
||||||
use crate::shared::detect_theme_hue;
|
use crate::shared::detect_theme_hue;
|
||||||
|
|
@ -48,6 +51,71 @@ pub struct PaletteFromYaml {
|
||||||
pub enum PaletteColorFromYaml {
|
pub enum PaletteColorFromYaml {
|
||||||
Rgb((u8, u8, u8)),
|
Rgb((u8, u8, u8)),
|
||||||
EightBit(u8),
|
EightBit(u8),
|
||||||
|
Hex(HexColor),
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Clone, Copy, Debug, PartialEq, Eq, Hash)]
|
||||||
|
pub struct HexColor(u8, u8, u8);
|
||||||
|
|
||||||
|
impl From<HexColor> for (u8, u8, u8) {
|
||||||
|
fn from(e: HexColor) -> (u8, u8, u8) {
|
||||||
|
let HexColor(r, g, b) = e;
|
||||||
|
(r, g, b)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub struct HexColorVisitor();
|
||||||
|
|
||||||
|
impl<'de> Visitor<'de> for HexColorVisitor {
|
||||||
|
type Value = HexColor;
|
||||||
|
|
||||||
|
fn expecting(&self, formatter: &mut fmt::Formatter) -> fmt::Result {
|
||||||
|
write!(formatter, "a hex color in the format #RGB or #RRGGBB")
|
||||||
|
}
|
||||||
|
|
||||||
|
fn visit_str<E>(self, s: &str) -> Result<Self::Value, E>
|
||||||
|
where
|
||||||
|
E: Error,
|
||||||
|
{
|
||||||
|
if let Some(stripped) = s.strip_prefix('#') {
|
||||||
|
return self.visit_str(stripped);
|
||||||
|
}
|
||||||
|
|
||||||
|
if s.len() == 3 {
|
||||||
|
Ok(HexColor(
|
||||||
|
u8::from_str_radix(&s[0..1], 16).map_err(E::custom)? * 0x11,
|
||||||
|
u8::from_str_radix(&s[1..2], 16).map_err(E::custom)? * 0x11,
|
||||||
|
u8::from_str_radix(&s[2..3], 16).map_err(E::custom)? * 0x11,
|
||||||
|
))
|
||||||
|
} else if s.len() == 6 {
|
||||||
|
Ok(HexColor(
|
||||||
|
u8::from_str_radix(&s[0..2], 16).map_err(E::custom)?,
|
||||||
|
u8::from_str_radix(&s[2..4], 16).map_err(E::custom)?,
|
||||||
|
u8::from_str_radix(&s[4..6], 16).map_err(E::custom)?,
|
||||||
|
))
|
||||||
|
} else {
|
||||||
|
Err(Error::custom(
|
||||||
|
"Hex color must be of form \"#RGB\" or \"#RRGGBB\"",
|
||||||
|
))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'de> Deserialize<'de> for HexColor {
|
||||||
|
fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
|
||||||
|
where
|
||||||
|
D: Deserializer<'de>,
|
||||||
|
{
|
||||||
|
deserializer.deserialize_str(HexColorVisitor())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
impl Serialize for HexColor {
|
||||||
|
fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
|
||||||
|
where
|
||||||
|
S: Serializer,
|
||||||
|
{
|
||||||
|
serializer.serialize_str(format!("{:02X}{:02X}{:02X}", self.0, self.1, self.2).as_str())
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Default for PaletteColorFromYaml {
|
impl Default for PaletteColorFromYaml {
|
||||||
|
|
@ -109,6 +177,7 @@ impl From<PaletteColorFromYaml> for PaletteColor {
|
||||||
match yaml {
|
match yaml {
|
||||||
PaletteColorFromYaml::Rgb(color) => PaletteColor::Rgb(color),
|
PaletteColorFromYaml::Rgb(color) => PaletteColor::Rgb(color),
|
||||||
PaletteColorFromYaml::EightBit(color) => PaletteColor::EightBit(color),
|
PaletteColorFromYaml::EightBit(color) => PaletteColor::EightBit(color),
|
||||||
|
PaletteColorFromYaml::Hex(color) => PaletteColor::Rgb(color.into()),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Reference in a new issue