Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/gi/handlebars-ruby
A Ruby interface to the official JavaScript version of Handlebars.
https://github.com/gi/handlebars-ruby
handlebars ruby
Last synced: 3 days ago
JSON representation
A Ruby interface to the official JavaScript version of Handlebars.
- Host: GitHub
- URL: https://github.com/gi/handlebars-ruby
- Owner: gi
- License: mit
- Created: 2021-12-27T23:48:35.000Z (about 3 years ago)
- Default Branch: develop
- Last Pushed: 2022-02-18T01:02:47.000Z (almost 3 years ago)
- Last Synced: 2025-01-09T16:55:47.689Z (13 days ago)
- Topics: handlebars, ruby
- Language: Ruby
- Homepage:
- Size: 65.4 KB
- Stars: 5
- Watchers: 1
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
# Handlebars::Engine
[![Gem Version](https://badge.fury.io/rb/handlebars-engine.svg)](https://rubygems.org/gems/handlebars-engine)
[![CI Status](https://github.com/gi/handlebars-ruby/actions/workflows/ci.yml/badge.svg)](https://github.com/gi/handlebars-ruby/actions/workflows/ci.yml)
[![Test Coverage](https://api.codeclimate.com/v1/badges/45d98ad9e12ee3384161/test_coverage)](https://codeclimate.com/github/gi/handlebars-ruby/test_coverage)
[![Maintainability](https://api.codeclimate.com/v1/badges/45d98ad9e12ee3384161/maintainability)](https://codeclimate.com/github/gi/handlebars-ruby/maintainability)
[![MIT License](https://img.shields.io/badge/License-MIT-blue.svg)](LICENSE.txt)A complete interface to [Handlebars.js](https://handlebarsjs.com) for Ruby.
`Handlebars::Engine` provides a complete Ruby API for the official JavaScript
version of Handlebars, including the abilities to register Ruby blocks/procs as
Handlebars helper functions and to dynamically register partials.It uses [MiniRacer](https://github.com/rubyjs/mini_racer) for the bridge between
Ruby and the V8 JavaScript engine.`Handlebars::Engine` was created as a replacement for
[handlebars.rb](https://github.com/cowboyd/handlebars.rb).## Installation
Add this line to your application's Gemfile:
```ruby
gem 'handlebars-engine'
```And then execute:
$ bundle install
Or install it yourself as:
$ gem install handlebars-engine
## Usage
### Quick Start
```ruby
handlebars = Handlebars::Engine.new
template = handlebars.compile("{{firstname}} {{lastname}}")
template.call({ firstname: "Yehuda", lastname: "Katz" })
# => "Yehuda Katz"
```### Custom Helpers
Handlebars helpers can be accessed from any context in a template. You can
register a helper with the `register_helper` method:```ruby
handlebars = Handlebars::Engine.new
handlebars.register_helper(:loud) do |ctx, arg, opts|
arg.upcase
end
template = handlebars.compile("{{firstname}} {{loud lastname}}")
template.call({ firstname: "Yehuda", lastname: "Katz" })
# => "Yehuda KATZ"
```#### Helper Arguments
Helpers receive the current context as the first argument of the block.
```ruby
handlebars = Handlebars::Engine.new
handlebars.register_helper(:full_name) do |ctx, opts|
"#{ctx["firstname"]} #{ctx["lastname"]}"
end
template = handlebars.compile("{{full_name}}")
template.call({ firstname: "Yehuda", lastname: "Katz" })
# => "Yehuda Katz"
```Any arguments to the helper are included as individual positional arguments.
```ruby
handlebars = Handlebars::Engine.new
handlebars.register_helper(:join) do |ctx, *args, opts|
args.join(" ")
end
template = handlebars.compile("{{join firstname lastname}}")
template.call({ firstname: "Yehuda", lastname: "Katz" })
# => "Yehuda Katz"
```The last argument is a hash of options.
See https://handlebarsjs.com/guide/#custom-helpers.
### Block Helpers
Block helpers make it possible to define custom iterators and other
functionality that can invoke the passed block with a new context.Currently, there is a limitation with the underlying JavaScript engine: it does
not allow for reentrant calls from within attached Ruby functions: see
[MiniRacer#225](https://github.com/rubyjs/mini_racer/issues/225). Thus, the
block function returned to the helper (in `options.fn`) cannot be invoked.Thus, for block helpers, a string of JavaScript must define the helper function:
```ruby
handlebars = Handlebars::Engine.new
handlebars.register_helper(map: <<~JS)
function(...args) {
const ctx = this;
const opts = args.pop();
const items = args[0];
const separator = args[1];
const mapped = items.map((item) => opts.fn(item));
return mapped.join(separator);
}
JS
template = handlebars.compile("{{#map items '|'}}'{{this}}'{{/map}}")
template.call({ items: [1, 2, 3] })
# => "'1'|2'|'3'"
```See https://handlebarsjs.com/guide/#block-helpers.
### Partials
Handlebars partials allow for code reuse by creating shared templates.
You can register a partial using the `register_partial` method:
```ruby
handlebars = Handlebars::Engine.new
handlebars.register_partial(:person, "{{person.name}} is {{person.age}}.")
template = handlebars.compile("{{> person person=.}}")
template.call({ name: "Yehuda Katz", age: 20 })
# => "Yehuda Katz is 20."
```See https://handlebarsjs.com/guide/#partials.
See https://handlebarsjs.com/guide/partials.html.### Hooks
#### Helper Missing
This hook is called for a mustache or a block-statement when
* a simple mustache-expression is not a registered helper, *and*
* it is not a property of the current evaluation context.You can add custom handling for those situations by registering a helper with
the `register_helper_missing` method:```ruby
handlebars = Handlebars::Engine.new
handlebars.register_helper_missing do |ctx, *args, opts|
"Missing: #{opts["name"]}(#{args.join(", ")})"
endtemplate = handlebars.compile("{{foo 2 true}}")
template.call
# => "Missing: foo(2, true)"template = handlebars.compile("{{#foo true}}{{/foo}}")
template.call
# => "Missing: foo(true)"
```See https://handlebarsjs.com/guide/hooks.html#helpermissing.
##### Blocks
This hook is called for a block-statement when
* a block-expression calls a helper that is not registered, *and*
* the name is a property of the current evaluation context.You can add custom handling for those situations by registering a helper with
the `register_helper_missing` method (with a `:block` argument):```ruby
handlebars = Handlebars::Engine.new
handlebars.register_helper_missing(:block) do |ctx, *args, opts|
"Missing: #{opts["name"]}(#{args.join(", ")})"
endtemplate = handlebars.compile("{{#person}}{{name}}{{/person}}")
template.call({ person: { name: "Yehuda Katz" } })
# => "Missing: person"
```See https://handlebarsjs.com/guide/hooks.html#blockhelpermissing.
#### Partial Missing
This hook is called for a partial that is not registered.
```ruby
handlebars = Handlebars::Engine.new
handlebars.register_partial_missing do |name|
"partial: #{name}"
end
```Note: This is not a part of the offical Handlebars API. It is provided for
convenience.## Changelog
See [CHANGELOG.md](CHANGELOG.md) for more details.
## Contributing
Bug reports and pull requests are welcome on GitHub:
https://github.com/gi/handlebars-ruby.See [CONTRIBUTING.md](CONTRIBUTING.md) for more details.
## License
The gem is available as open source under the terms of the [MIT License](https://opensource.org/licenses/MIT).