async-helpers
Use async helpers in templates with engines that typically only handle sync helpers. Handlebars and Lodash have been tested.
Install
Install with npm:
$ npm install --save async-helpers
Usage
var asyncHelpers = require('async-helpers');
API
Create a new instance of AsyncHelpers
Params
options
{Object}: options to pass to instancereturns
{Object}: new AsyncHelpers instance
Example
var asyncHelpers = new AsyncHelpers();
Add a helper to the cache.
Params
name
{String}: Name of the helperfn
{Function}: Helper functionreturns
{Object}: Returns this
for chaining
Example
asyncHelpers.set('upper', function(str, cb) {
cb(null, str.toUpperCase());
});
Get all helpers or a helper with the given name.
Params
name
{String}: Optionally pass in a name of a helper to get.options
{Object}: Additional options to use.returns
{Function|Object}: Single helper function when name
is provided, otherwise object of all helpers
Example
var helpers = asyncHelpers.get();
var wrappedHelpers = asyncHelpers.get({wrap: true});
Wrap a helper with async handling capibilities.
Params
helper
{String}: Optionally pass the name of the helper to wrapreturns
{Function|Object}: Single wrapped helper function when name
is provided, otherwise object of all wrapped helpers.
Example
var wrappedHelper = asyncHelpers.wrap('upper');
var wrappedHelpers = asyncHelpers.wrap();
Reset all the stashed helpers.
returns
{Object}: Returns this
to enable chaining
Example
asyncHelpers.reset();
Resolve a stashed helper by the generated id. This is a generator function and should be used with co
Params
key
{String}: ID generated when from executing a wrapped helper.
Example
var upper = asyncHelpers.get('upper', {wrap: true});
var id = upper('doowb');
co(asyncHelpers.resolveId(id))
.then(console.log)
.catch(console.error);
After rendering a string using wrapped async helpers, use resolveIds
to invoke the original async helpers and replace the async ids with results from the async helpers.
Params
str
{String}: String containing async idscb
{Function}: Callback function accepting an err
and content
parameters.
Example
asyncHelpers.resolveIds(renderedString, function(err, content) {
if (err) return console.error(err);
console.log(content);
});
About
Related projects
- assemble: Get the rocks out of your socks! Assemble makes you fast at creating web projects… more | homepage
- co: generator async control flow goodness | homepage
- generate: Command line tool and developer framework for scaffolding out new GitHub projects. Generate offers the… more | homepage
- templates: System for creating and managing template collections, and rendering templates with any node.js template engine… more | homepage
- verb: Documentation generator for GitHub projects. Verb is extremely powerful, easy to use, and is used… more | homepage
Contributing
Pull requests and stars are always welcome. For bugs and feature requests, please create an issue.
Contributors
Building docs
(This document was generated by verb-generate-readme (a verb generator), please don't edit the readme directly. Any changes to the readme must be made in .verb.md.)
To generate the readme and API documentation with verb:
$ npm install -g verb verb-generate-readme && verb
Running tests
Install dev dependencies:
$ npm install -d && npm test
Author
Brian Woodward
License
Copyright © 2017, Brian Woodward.
Released under the MIT license.
This file was generated by verb-generate-readme, v0.4.1, on January 26, 2017.