handlebars-helpers
Version:
More than 130 Handlebars helpers in ~20 categories. Helpers can be used with Assemble, Generate, Verb, Ghost, gulp-handlebars, grunt-handlebars, consolidate, or any node.js/Handlebars project.
173 lines (155 loc) • 3.95 kB
JavaScript
var util = require('handlebars-utils');
var path = require('path');
var utils = require('./utils');
var helpers = module.exports;
/**
* Get the directory path segment from the given `filepath`.
*
* ```handlebars
* {{absolute "docs/toc.md"}}
* <!-- results in: 'docs' -->
* ```
* @param {String} `ext`
* @return {String}
* @api public
*/
helpers.absolute = function(filepath, options) {
options = options || {data: {}};
var context = util.options(this, options);
var ctx = Object.assign({}, options.data.root, context);
var cwd = ctx.cwd || process.cwd();
return path.resolve(cwd, filepath);
};
/**
* Get the directory path segment from the given `filepath`.
*
* ```handlebars
* {{dirname "docs/toc.md"}}
* <!-- results in: 'docs' -->
* ```
* @param {String} `ext`
* @return {String}
* @api public
*/
helpers.dirname = function(filepath, options) {
if (typeof filepath !== 'string') {
throw new TypeError(utils.expectedType('filepath', 'string', filepath));
}
return path.dirname(filepath);
};
/**
* Get the relative filepath from `a` to `b`.
*
* ```handlebars
* {{relative a b}}
* ```
* @param {String} `a`
* @param {String} `b`
* @return {String}
* @api public
*/
helpers.relative = function(a, b) {
if (typeof a !== 'string') {
throw new TypeError(utils.expectedType('first path', 'string', a));
}
if (typeof b !== 'string') {
throw new TypeError(utils.expectedType('second path', 'string', b));
}
return utils.relative(a, b);
};
/**
* Get the file extension from the given `filepath`.
*
* ```handlebars
* {{basename "docs/toc.md"}}
* <!-- results in: 'toc.md' -->
* ```
* @param {String} `ext`
* @return {String}
* @api public
*/
helpers.basename = function(filepath) {
if (typeof filepath !== 'string') {
throw new TypeError(utils.expectedType('filepath', 'string', filepath));
}
return path.basename(filepath);
};
/**
* Get the "stem" from the given `filepath`.
*
* ```handlebars
* {{stem "docs/toc.md"}}
* <!-- results in: 'toc' -->
* ```
* @param {String} `filepath`
* @return {String}
* @api public
*/
helpers.stem = function(filepath) {
if (typeof filepath !== 'string') {
throw new TypeError(utils.expectedType('filepath', 'string', filepath));
}
return path.basename(filepath, path.extname(filepath));
};
/**
* Get the file extension from the given `filepath`.
*
* ```handlebars
* {{extname "docs/toc.md"}}
* <!-- results in: '.md' -->
* ```
* @param {String} `filepath`
* @return {String}
* @api public
*/
helpers.extname = function(filepath) {
if (typeof filepath !== 'string') {
throw new TypeError(utils.expectedType('filepath', 'string', filepath));
}
return path.extname(filepath);
};
/**
* Resolve an absolute path from the given `filepath`.
*
* ```handlebars
* {{resolve "docs/toc.md"}}
* <!-- results in: '/User/dev/docs/toc.md' -->
* ```
* @param {String} `filepath`
* @return {String}
* @api public
*/
helpers.resolve = function(filepath) {
var args = [].slice.call(arguments);
var opts = util.options(this, args.pop());
var cwd = path.resolve(opts.cwd || process.cwd());
args.unshift(cwd);
return path.resolve.apply(path, args);
};
/**
* Get specific (joined) segments of a file path by passing a
* range of array indices.
*
* ```handlebars
* {{segments "a/b/c/d" "2" "3"}}
* <!-- results in: 'c/d' -->
*
* {{segments "a/b/c/d" "1" "3"}}
* <!-- results in: 'b/c/d' -->
*
* {{segments "a/b/c/d" "1" "2"}}
* <!-- results in: 'b/c' -->
* ```
*
* @param {String} `filepath` The file path to split into segments.
* @return {String} Returns a single, joined file path.
* @api public
*/
helpers.segments = function(filepath, a, b) {
if (typeof filepath !== 'string') {
throw new TypeError(utils.expectedType('filepath', 'string', filepath));
}
var segments = filepath.split(/[\\\/]+/);
return segments.slice(a, b).join('/');
};
;