6 releases

0.2.0 May 23, 2024
0.1.0 Nov 17, 2023
0.1.0-rc.3 Mar 24, 2023
0.1.0-rc.2 May 9, 2022
0.1.0-rc.1 Jun 9, 2021

#1353 in Web programming

Download history 2420/week @ 2024-11-18 2787/week @ 2024-11-25 5044/week @ 2024-12-02 4933/week @ 2024-12-09 2700/week @ 2024-12-16 966/week @ 2024-12-23 1523/week @ 2024-12-30 3590/week @ 2025-01-06 3470/week @ 2025-01-13 4013/week @ 2025-01-20 4235/week @ 2025-01-27 5094/week @ 2025-02-03 4998/week @ 2025-02-10 2443/week @ 2025-02-17 2694/week @ 2025-02-24 2422/week @ 2025-03-03

12,862 downloads per month
Used in 24 crates (21 directly)

MIT/Apache

1MB
14K SLoC

dyn_templates ci.svg crates.io docs.svg

This crate adds support for dynamic template rendering to Rocket. It automatically discovers templates, provides a Responder to render templates, and automatically reloads templates when compiled in debug mode. At present, it supports Handlebars and Tera.

Usage

  1. Enable the rocket_dyn_templates feature corresponding to your templating engine(s) of choice:

    [dependencies.rocket_dyn_templates]
    version = "0.2.0"
    features = ["handlebars", "tera"]
    
  2. Write your template files in Handlebars (.hbs) and/or Tera (.tera) in the configurable template_dir directory (default: {rocket_root}/templates).

  3. Attach Template::fairing() and return a Template using Template::render(), supplying the name of the template file minus the last two extensions:

    use rocket_dyn_templates::{Template, context};
    
    #[get("/")]
    fn index() -> Template {
        Template::render("template-name", context! { field: "value" })
    }
    
    #[launch]
    fn rocket() -> _ {
        rocket::build().attach(Template::fairing())
    }
    

See the crate docs for full details.

Dependencies

~15–47MB
~822K SLoC