Nothing
#' Render a template
#'
#' Data is passed to a template to render the final document.
#'
#' @param .x The template. Choices:
#' * A template string.
#' * A path to a template file (use [fs::path()]).
#' * A parsed template (use [parse_template()]).
#' @param ... <[`dynamic-dots`][rlang::dyn-dots]> Data passed to the template.
#'
#' By default, a length-1 vector is passed as a scalar variable. Use [I()] to
#' declare that a vector should be passed as an array variable. This preserves
#' a length-1 vector as an array.
#' @inheritParams parse
#' @return String containing rendered template.
#'
#' @seealso
#' * [parse_template()] supports parsing a template once and rendering multiple
#' times with different data variables.
#' * `vignette("template-syntax")` describes how to write templates.
#' @examples
#' # pass data as arguments
#' render("Hello {{ name }}!", name = "world")
#'
#' # pass length-1 vector as array
#' render("Hello {{ name.0 }}!", name = I("world"))
#'
#' # pass data programmatically
#' params <- list(name = "world")
#' render("Hello {{ name }}!", !!!params)
#'
#' # render template file
#' \dontrun{
#' render(fs::path("template.txt"), name = "world")
#' }
#' @export
render <- function(.x, ...) {
UseMethod("render")
}
#' @rdname render
#' @export
render.character <- function(.x, ..., .config = default_config()) {
render(parse_template(.x, .config), ...)
}
#' @rdname render
#' @export
render.fs_path <- function(.x, ..., .config = default_config()) {
render(parse_template(.x, .config), ...)
}
#' @rdname render
#' @export
render.jinjar_template <- function(.x, ...) {
with_catch_cpp_errors({
render_(attr(.x, "parsed"), encode(...))
})
}
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.