UNPKG

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
'use strict'; 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('/'); };