loadHandlebars()
The exported loadHandlebars()
function generates the equivalent of a handlebars
() function function that pulls templates from a specific directory.
It takes up to two parameters:
directoryPath: string
(required): absolute path to a directory containing Handlebars templatesoptionsDefault: object
(optional): any values to provide to use in the templates
loadHandlebars()
is useful when you have multiple calls to Handlebars templates interspersed amongst your files
creations
For example, this template uses two ../template/*.hbs
files relative to the template’s source file:
import { createTemplate } from "bingo";import { loadHandlebars } from "bingo-handlebars";
export default createTemplate({ about: { name: "My Handlebars Template" }, options: { owner: z.string(), repository: z.string(), }, async produce({ options }) { const handlebars = await loadHandlebars( path.join(import.meta.dirname, "../template"), options, );
return { files: { "package.json": handlebars("package.json.hbs"), "README.md": handlebars("README.md.hbs"), }, }; },});
Generated handlebars()
functions otherwise provide the same API as the exported handlebars()
.
Option Defaults
The optional optionsDefaults
parameter for loadHandlebars()
provides any options that should always be provided to templates.
Default options will be overridden by any options provided by the generated handlebars()
function.
For example, this template renders its package.json
with default options, but overrides its repository
value to be "other-repository"
:
import { createTemplate } from "bingo";import { loadHandlebars } from "bingo-handlebars";
export default createTemplate({ about: { name: "My Handlebars Template" }, options: { owner: z.string(), repository: z.string(), }, async produce({ options }) { const handlebars = await loadHandlebars( path.join(import.meta.dirname, "../template"), options, );
return { files: { "package.json": handlebars("package.json.hbs"), "README.md": handlebars("README.md.hbs", { repository: "other-repository", }), }, }; },});