Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/iantsch/wp-hbs-engine
Renders Handlebars templates within your WordPress Theme/Plugin
https://github.com/iantsch/wp-hbs-engine
handlebars lightncandy wordpress wordpress-plugin
Last synced: 3 months ago
JSON representation
Renders Handlebars templates within your WordPress Theme/Plugin
- Host: GitHub
- URL: https://github.com/iantsch/wp-hbs-engine
- Owner: iantsch
- License: mit
- Created: 2018-02-23T23:57:24.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2019-09-16T19:36:37.000Z (over 5 years ago)
- Last Synced: 2024-10-11T13:44:08.815Z (3 months ago)
- Topics: handlebars, lightncandy, wordpress, wordpress-plugin
- Language: PHP
- Size: 11.7 KB
- Stars: 4
- Watchers: 1
- Forks: 5
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# WordPress Handlebars Engine
[![licence](https://img.shields.io/badge/licence-MIT-blue.svg?style=flat-square)]() [![tag](https://img.shields.io/badge/tag-v0.0.1-lightgrey.svg?style=flat-square)]()
Renders Handlebars/Moustache templates within your WordPress Theme/Plugin. Handlebars rendering is powered by [LightnCandy](https://github.com/zordius/lightncandy). Tested with WordPress 5.2.3
## Installation
You can install this (must-use) plugin two ways### Via Composer
If you load your dependenies via Composer you can load this plugin with
```sh
$ php composer require iantsch/wp-hbs-engine
```### Via Download
Download/fork this repository and copy the plugin-folder into `wp-content/plugins/`.
If you visit your Plugin section in the `wp-admin` area, activate it and you are good to go.### Troubleshoots
You need to load the `zordius/lightncandy` dependency via composer. Install composer and run `$ composer install` in the `wp-content/plugins/wp-hbs-engine` folder.
The plugin needs a folder with write permissions for caching the handlebar files. It tries to create the folder `wp-content/plugins/wp-hbs-engine/cache`.
The plugin will try to load partials from the default folder `src/templates/partials` within your current theme. If the folder does not exist please add it (or use the filter hook to adapt).
## Usage
Setup and modify the render engine to your needs in your ``functions.php`` or your plugin
```php
add_filter('MBT/Engine/Handlebars/Helpers', function($helpers) {
$helpers['__'] = function($string) {
return __($string, 'mbt');
};
$helpers['permalink'] = 'get_permalink';
$helpers['content'] = function() {
return apply_filters('the_content', get_the_content());
};
return $helpers;
});
```In your theme call it like a WordPress function.
```php
global $post;
while (have_posts()){
the_post();
$data = (array) $post;
the_hbs_template('article', $data);
}
```In your ``article.hbs`` it is [handlebarsjs.com](https://handlebarsjs.com) syntax
```hbs
{{this.post_title}}
{{{content}}}
{{__ 'Click'}}
```## API
#### get_hbs_template
| Parameter | Type | Description |
|---|---|---|
| ``$template`` | string | template name |
| ``$data`` | string | associative array with all the needed data for the template |
| ``$templateDir`` | string \| boolean | absolutee path to template entry directory, defaults to ``/src/templates/`` in current theme |
| ``$cacheDir`` | string \| boolean | absolute path to caching directory, defaults to ``/cache/`` in plugins folder |
*Returns*: ``$html`` - the rendered HTML output#### the_hbs_template
| Parameter | Type | Description |
|---|---|---|
| ``$template`` | string | template name |
| ``$data`` | string | associative array with all the needed data for the template |
| ``$templateDir`` | string \| boolean | absolutee path to template entry directory, defaults to ``/src/templates/`` in current theme |
| ``$cacheDir`` | string \| boolean | absolute path to caching directory, defaults to ``/cache/`` in plugins folder |
echoes the rendered HTML output
## HooksThere are several hooks to modify and adapt the render engine
### Filters
#### MBT/Engine/Handlebars/Extension
| Parameter | Type | Description |
|---|---|---|
| ``$extension`` | string | file extension, default: ``hbs`` |
*Returns*: ``$extension`` - file extension of your handlebar templates
#### MBT/Engine/Handlebars/Helpers
| Parameter | Type | Description |
|---|---|---|
| ``$helpers`` | array | associative array with callback functions for the implemented helpers |
| ``$this`` | object | Current instance of Handlebars engine |
*Returns*: ``$helpers`` - array of handlebars helper
#### MBT/Engine/Handlebars/Flags
| Parameter | Type | Description |
|---|---|---|
| ``$flags`` | int | bitwise flags used by LightnCandy |
| ``$this`` | object | Current instance of Handlebars engine |
*Returns*: ``$flags`` - LightnCandy Flags
#### MBT/Engine/Handlebars/Partials
| Parameter | Type | Description |
|---|---|---|
| ``$partials`` | array | associative array with the relative path to the partials |
| ``$this`` | object | Current instance of Handlebars engine |
*Returns*: ``$partials`` - array of available partials
#### MBT/Engine/Handlebars/DefaultData
| Parameter | Type | Description |
|---|---|---|
| ``$defaultData`` | array | fallback data for the template |
| ``$template`` | string | template name |
*Returns*: ``$defaultData`` - fallback data for the template
#### MBT/Engine/Handlebars/Data
| Parameter | Type | Description |
|---|---|---|
| ``$data`` | array | associative array with all the needed data for the template |
| ``$template`` | string | template name |
*Returns*: ``$data`` - the data for the template
#### MBT/Engine/Handlebars/Html
| Parameter | Type | Description |
|---|---|---|
| ``$html`` | string | rendered HTML output (with data) |
| ``$template`` | string | template name |
| ``$data`` | array | data used to render output |
*Returns*: ``$html`` - the rendered HTML output### Actions
#### MBT/Engine/Handlebars/Init
| Parameter | Type | Description |
|---|---|---|
| ``$this`` | object | Current instance of Handlebars engine |## Credits
[@iantsch](https://twitter.com/iantsch) - [web developer](https://mbt.wien) behind this and other projects.