Skip to content

👨🏻 Turn mustache templates into JSX output functions

Notifications You must be signed in to change notification settings

alanorozco/mustache-jsx

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

mustache-jsx

Turn mustache templates into JSX output functions.

Development

test

npm test

Runs all tests in test/*/input.mustache. Output file test/*/output.jsx is generated in directories that don't have it.

npm run test:update

Updates every *.jsx test output file.

repl

npm run serve

Runs a watch build and dev server with REPL on localhost:5000.

npm run dist

Builds into dist/

Output

Helpers

Other than JSX pragmas (createElement, Fragment), runnable templates expect a set of helper functions in scope:

view(key, ...scope)

view(key: string | null, ...scope: Object[]): any

Resolves a value from the view like mustache would:

  • key may be null if referencing the full scope (like {{.}})
  • ...scope is a sequence of object scopes, in order of lookup priority. The root object is used as fallback when key is not found in the scope (if there's no scope, it will use the root object).

section(value, callback)

section(
  value: any,
  callback: (item: any, index: number) => Renderable
): Renderable[]

A section, like {{#section}}. Returns a list of Renderables.

  • If value is an array, callback() loops over it.
  • If value is a single value, the callback is applied on it.
  • If value is falsy, or an empty array, the callback is not applied.

inverted(value)

inverted(value: any): boolean

Inversion of value: true if falsy or an empty array, like inverted mustache sections as {{^falsy}}:

inverted([]) && "the list is empty";

html(str)

html(str: string | null): Renderable

Takes an unescaped value (like {{& myHtml}}) and renders it onto the DOM.

About

👨🏻 Turn mustache templates into JSX output functions

Resources

Stars

Watchers

Forks

Contributors 3

  •  
  •  
  •