Skip to content

Commit

Permalink
feat(whiskers): add css_* functions as filters (#230)
Browse files Browse the repository at this point in the history
Co-authored-by: backwardspy <backwardspy@pigeon.life>
  • Loading branch information
uncenter and backwardspy authored May 27, 2024
1 parent 6e70c09 commit e2e7f22
Show file tree
Hide file tree
Showing 4 changed files with 86 additions and 13 deletions.
6 changes: 5 additions & 1 deletion whiskers/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -178,8 +178,12 @@ These types are designed to closely match the [palette.json](https://github.com/
| `sub` | Subtract a value from a color | `red \| sub(hue=30)` => `#d30f9b` |
| `mod` | Modify a color | `red \| mod(lightness=80)` => `#f8a0b3` |
| `mix` | Mix two colors together | `red \| mix(color=base, amount=0.5)` => `#e08097` |
| `urlencode_lzma` | Serialize an object into a URL-safe string with LZMA compression | `red \| urlencode_lzma()` => `#ff6666` |
| `urlencode_lzma` | Serialize an object into a URL-safe string with LZMA compression | `red \| urlencode_lzma` => `#ff6666` |
| `trunc` | Truncate a number to a certain number of places | `1.123456 \| trunc(places=3)` => `1.123` |
| `css_rgb` | Convert a color to an RGB CSS string | `red \| css_rgb` => `rgb(210, 15, 57)` |
| `css_rgba` | Convert a color to an RGBA CSS string | `red \| css_rgba` => `rgba(210, 15, 57, 1.00)` |
| `css_hsl` | Convert a color to an HSL CSS string | `red \| css_hsl` => `hsl(347, 87%, 44%)` |
| `css_hsla` | Convert a color to an HSLA CSS string | `red \| css_hsla` => `hsla(347, 87%, 44%, 1.00)` |

> [!NOTE]
> You also have access to all of Tera's own built-in filters and functions.
Expand Down
36 changes: 36 additions & 0 deletions whiskers/src/filters.rs
Original file line number Diff line number Diff line change
Expand Up @@ -132,3 +132,39 @@ pub fn trunc(
)?;
Ok(tera::to_value(format!("{value:.places$}"))?)
}

pub fn css_rgb(
value: &tera::Value,
_args: &HashMap<String, tera::Value>,
) -> Result<tera::Value, tera::Error> {
let color: Color = tera::from_value(value.clone())?;
let color: css_colors::RGB = (&color).into();
Ok(tera::to_value(color.to_string())?)
}

pub fn css_rgba(
value: &tera::Value,
_args: &HashMap<String, tera::Value>,
) -> Result<tera::Value, tera::Error> {
let color: Color = tera::from_value(value.clone())?;
let color: css_colors::RGBA = (&color).into();
Ok(tera::to_value(color.to_string())?)
}

pub fn css_hsl(
value: &tera::Value,
_args: &HashMap<String, tera::Value>,
) -> Result<tera::Value, tera::Error> {
let color: Color = tera::from_value(value.clone())?;
let color: css_colors::HSL = (&color).into();
Ok(tera::to_value(color.to_string())?)
}

pub fn css_hsla(
value: &tera::Value,
_args: &HashMap<String, tera::Value>,
) -> Result<tera::Value, tera::Error> {
let color: Color = tera::from_value(value.clone())?;
let color: css_colors::HSLA = (&color).into();
Ok(tera::to_value(color.to_string())?)
}
33 changes: 21 additions & 12 deletions whiskers/src/markdown.rs
Original file line number Diff line number Diff line change
Expand Up @@ -104,7 +104,7 @@ fn table_format() -> String {
));
}

result.push_str("### Filters\n\n");
result.push_str("\n### Filters\n\n");
result.push_str("| Name | Description | Examples |\n");
result.push_str("|------|-------------|----------|\n");
for filter in templating::all_filters() {
Expand All @@ -116,17 +116,26 @@ fn table_format() -> String {
"None".to_string()
} else {
filter.examples.first().map_or_else(String::new, |example| {
format!(
"`{value} \\| {name}({input})` => `{output}`",
value = example.value,
name = filter.name,
input = example
.inputs
.iter()
.map(|(k, v)| format!("{k}={v}"))
.join(", "),
output = example.output
)
if example.inputs.is_empty() {
format!(
"`{value} \\| {name}` => `{output}`",
value = example.value,
name = filter.name,
output = example.output
)
} else {
format!(
"`{value} \\| {name}({input})` => `{output}`",
value = example.value,
name = filter.name,
input = example
.inputs
.iter()
.map(|(k, v)| format!("{k}={v}"))
.join(", "),
output = example.output
)
}
})
}
));
Expand Down
24 changes: 24 additions & 0 deletions whiskers/src/templating.rs
Original file line number Diff line number Diff line change
Expand Up @@ -50,6 +50,10 @@ pub fn make_engine() -> tera::Tera {
tera.register_filter("urlencode_lzma", filters::urlencode_lzma);
tera.register_filter("trunc", filters::trunc);
tera.register_filter("mix", filters::mix);
tera.register_filter("css_rgb", filters::css_rgb);
tera.register_filter("css_rgba", filters::css_rgba);
tera.register_filter("css_hsl", filters::css_hsl);
tera.register_filter("css_hsla", filters::css_hsla);
tera.register_function("if", functions::if_fn);
tera.register_function("object", functions::object);
tera.register_function("css_rgb", functions::css_rgb);
Expand Down Expand Up @@ -148,6 +152,26 @@ pub fn all_filters() -> Vec<Filter> {
description: "Truncate a number to a certain number of places".to_string(),
examples: vec![filter_example!(1.123456 | trunc(places=3) => "1.123")],
},
Filter {
name: "css_rgb".to_string(),
description: "Convert a color to an RGB CSS string".to_string(),
examples: vec![filter_example!(red | css_rgb => "rgb(210, 15, 57)")],
},
Filter {
name: "css_rgba".to_string(),
description: "Convert a color to an RGBA CSS string".to_string(),
examples: vec![filter_example!(red | css_rgba => "rgba(210, 15, 57, 1.00)")],
},
Filter {
name: "css_hsl".to_string(),
description: "Convert a color to an HSL CSS string".to_string(),
examples: vec![filter_example!(red | css_hsl => "hsl(347, 87%, 44%)")],
},
Filter {
name: "css_hsla".to_string(),
description: "Convert a color to an HSLA CSS string".to_string(),
examples: vec![filter_example!(red | css_hsla => "hsla(347, 87%, 44%, 1.00)")],
},
]
}

Expand Down

0 comments on commit e2e7f22

Please sign in to comment.