Blurry

Plugins: write an Jinja filter plugin

Blurry makes it easy to add custom Jinja filters to your site. What is a Jinja filter? From the Jinja docs:

Filters are Python functions that take the value to the left of the filter as the first argument and produce a new value. Arguments passed to the filter are passed after the value.

For example, the filter {{ 42|myfilter(23) }} is called behind the scenes as myfilter(42, 23).

Example: "stars"

This function outputs a number of Unicode stars corresponding to the input, rounding to the nearest half-star.

import math

STAR_EMPTY = "☆"
STAR_FILLED = "★"
STAR_HALF_FILLED = "⯪"


def float_to_stars(num: float, max: int = 5) -> str:
    whole_stars = math.floor(num) * STAR_FILLED
    part_star = STAR_HALF_FILLED if num - len(whole_stars) > 0 else ""
    non_empty_stars = f"{whole_stars}{part_star}"

    return f"{non_empty_stars:{STAR_EMPTY}{'<'}{max}}"

To use it, add the appropriate plugin syntax to your pyproject.toml file:

[tool.poetry.plugins."blurry.jinja_filter_plugins"]
stars = "{{ yourproject }}:float_to_stars"