2021-05-25 01:58:05 +00:00
|
|
|
# `dyn_templates` [![ci.svg]][ci] [![crates.io]][crate] [![docs.svg]][crate docs]
|
|
|
|
|
|
|
|
[crates.io]: https://img.shields.io/crates/v/rocket_dyn_templates.svg
|
|
|
|
[crate]: https://crates.io/crates/rocket_dyn_templates
|
|
|
|
[docs.svg]: https://img.shields.io/badge/web-master-red.svg?style=flat&label=docs&colorB=d33847
|
2023-11-18 10:30:50 +00:00
|
|
|
[crate docs]: https://api.rocket.rs/master/rocket_dyn_templates
|
2023-11-21 15:29:44 +00:00
|
|
|
[ci.svg]: https://github.com/rwf2/Rocket/workflows/CI/badge.svg
|
|
|
|
[ci]: https://github.com/rwf2/Rocket/actions
|
2021-05-25 01:58:05 +00:00
|
|
|
|
|
|
|
This crate adds support for dynamic template rendering to Rocket. It
|
|
|
|
automatically discovers templates, provides a `Responder` to render templates,
|
2024-06-26 06:27:44 +00:00
|
|
|
and automatically reloads templates when compiled in debug mode. It supports [Handlebars], [Tera] and [MiniJinja].
|
2021-05-25 01:58:05 +00:00
|
|
|
|
|
|
|
[Tera]: https://docs.rs/crate/tera/1
|
2024-01-18 05:37:20 +00:00
|
|
|
[Handlebars]: https://docs.rs/crate/handlebars/5
|
2024-06-26 06:27:44 +00:00
|
|
|
[MiniJinja]: https://docs.rs/crate/minijinja/2.0.1
|
2021-05-25 01:58:05 +00:00
|
|
|
|
|
|
|
# Usage
|
|
|
|
|
|
|
|
1. Enable the `rocket_dyn_templates` feature corresponding to your templating
|
|
|
|
engine(s) of choice:
|
|
|
|
|
|
|
|
```toml
|
|
|
|
[dependencies.rocket_dyn_templates]
|
2023-11-03 23:26:07 +00:00
|
|
|
version = "0.1.0"
|
2024-06-26 06:27:44 +00:00
|
|
|
features = ["handlebars", "tera", "minijinja"]
|
2021-05-25 01:58:05 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
1. Write your template files in Handlebars (`.hbs`) and/or Tera (`.tera`) in
|
|
|
|
the configurable `template_dir` directory (default:
|
|
|
|
`{rocket_root}/templates`).
|
|
|
|
|
|
|
|
2. Attach `Template::fairing()` and return a `Template` using
|
|
|
|
`Template::render()`, supplying the name of the template file **minus the
|
|
|
|
last two extensions**:
|
|
|
|
|
|
|
|
```rust
|
2022-03-03 23:41:29 +00:00
|
|
|
use rocket_dyn_templates::{Template, context};
|
|
|
|
|
|
|
|
#[get("/")]
|
|
|
|
fn index() -> Template {
|
|
|
|
Template::render("template-name", context! { field: "value" })
|
|
|
|
}
|
2021-05-25 01:58:05 +00:00
|
|
|
|
|
|
|
#[launch]
|
|
|
|
fn rocket() -> _ {
|
|
|
|
rocket::build().attach(Template::fairing())
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
See the [crate docs] for full details.
|