mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-20 22:42:53 -05:00
3e40637cd4
closes #4439 - adds basic get helper which works with the current API - allows theme developers to make requests against the API - supports block params and @error message - includes 100% test coverage using posts ---- The `{{#get}}` helper is an asynchronous block helper which allows for making requests for data from the API. This allows theme developers to customise the data which can be shown on a particular page of a blog. Requests can be made to the posts, tags or users API endpoints: ``` {{#get "posts" limit="3"}} {{#foreach posts}} <a href="{{url}}">{{title}}</a> {{/foreach}} {{/get}} ``` The `{{#get}}` helper must be used as a block helper, it supports `{{else}}` logic, for when no data matching the request is available or if an error has occurred: ``` {{#get "posts" tag="photo"}} ... {{else}} {{#if @error}} <p>Something went wrong: {{@error}}</p> {{else}} <p>No posts found</p> {{/if}} {{/get}} ``` The helper also supports block params, meaning the data it outputs can be given a different name: ``` {{#get "posts" featured="true" as |featured|}} {{#foreach featured}} ... {{/foreach}} {{/get}} ``` Please Note: At present asynchronous helpers cannot be nested.
131 lines
5 KiB
JavaScript
131 lines
5 KiB
JavaScript
var hbs = require('express-hbs'),
|
|
Promise = require('bluebird'),
|
|
errors = require('../errors'),
|
|
utils = require('./utils'),
|
|
coreHelpers = {},
|
|
registerHelpers;
|
|
|
|
// Pre-load settings data:
|
|
// - activeTheme
|
|
// - permalinks
|
|
|
|
if (!utils.isProduction) {
|
|
hbs.handlebars.logger.level = 0;
|
|
}
|
|
|
|
coreHelpers.asset = require('./asset');
|
|
coreHelpers.author = require('./author');
|
|
coreHelpers.body_class = require('./body_class');
|
|
coreHelpers.content = require('./content');
|
|
coreHelpers.date = require('./date');
|
|
coreHelpers.encode = require('./encode');
|
|
coreHelpers.excerpt = require('./excerpt');
|
|
coreHelpers.foreach = require('./foreach');
|
|
coreHelpers.get = require('./get');
|
|
coreHelpers.ghost_foot = require('./ghost_foot');
|
|
coreHelpers.ghost_head = require('./ghost_head');
|
|
coreHelpers.image = require('./image');
|
|
coreHelpers.is = require('./is');
|
|
coreHelpers.has = require('./has');
|
|
coreHelpers.meta_description = require('./meta_description');
|
|
coreHelpers.meta_title = require('./meta_title');
|
|
coreHelpers.navigation = require('./navigation');
|
|
coreHelpers.pagination = require('./pagination');
|
|
coreHelpers.plural = require('./plural');
|
|
coreHelpers.post_class = require('./post_class');
|
|
coreHelpers.prev_post = require('./prev_next');
|
|
coreHelpers.next_post = require('./prev_next');
|
|
coreHelpers.tags = require('./tags');
|
|
coreHelpers.title = require('./title');
|
|
coreHelpers.url = require('./url');
|
|
|
|
// Specialist helpers for certain templates
|
|
coreHelpers.input_password = require('./input_password');
|
|
coreHelpers.page_url = require('./page_url');
|
|
coreHelpers.pageUrl = require('./page_url').deprecated;
|
|
|
|
coreHelpers.helperMissing = function (arg) {
|
|
if (arguments.length === 2) {
|
|
return undefined;
|
|
}
|
|
errors.logError('Missing helper: "' + arg + '"');
|
|
};
|
|
|
|
// Register an async handlebars helper for a given handlebars instance
|
|
function registerAsyncHelper(hbs, name, fn) {
|
|
hbs.registerAsyncHelper(name, function (context, options, cb) {
|
|
// Handle the case where we only get context and cb
|
|
if (!cb) {
|
|
cb = options;
|
|
options = undefined;
|
|
}
|
|
|
|
// Wrap the function passed in with a when.resolve so it can return either a promise or a value
|
|
Promise.resolve(fn.call(this, context, options)).then(function (result) {
|
|
cb(result);
|
|
}).catch(function (err) {
|
|
errors.logAndThrowError(err, 'registerAsyncThemeHelper: ' + name);
|
|
});
|
|
});
|
|
}
|
|
|
|
// Register a handlebars helper for themes
|
|
function registerThemeHelper(name, fn) {
|
|
hbs.registerHelper(name, fn);
|
|
}
|
|
|
|
// Register an async handlebars helper for themes
|
|
function registerAsyncThemeHelper(name, fn) {
|
|
registerAsyncHelper(hbs, name, fn);
|
|
}
|
|
|
|
// Register a handlebars helper for admin
|
|
function registerAdminHelper(name, fn) {
|
|
coreHelpers.adminHbs.registerHelper(name, fn);
|
|
}
|
|
|
|
registerHelpers = function (adminHbs) {
|
|
// Expose hbs instance for admin
|
|
coreHelpers.adminHbs = adminHbs;
|
|
|
|
// Register theme helpers
|
|
registerThemeHelper('asset', coreHelpers.asset);
|
|
registerThemeHelper('author', coreHelpers.author);
|
|
registerThemeHelper('content', coreHelpers.content);
|
|
registerThemeHelper('title', coreHelpers.title);
|
|
registerThemeHelper('date', coreHelpers.date);
|
|
registerThemeHelper('encode', coreHelpers.encode);
|
|
registerThemeHelper('excerpt', coreHelpers.excerpt);
|
|
registerThemeHelper('foreach', coreHelpers.foreach);
|
|
registerThemeHelper('is', coreHelpers.is);
|
|
registerThemeHelper('input_password', coreHelpers.input_password);
|
|
registerThemeHelper('has', coreHelpers.has);
|
|
registerThemeHelper('navigation', coreHelpers.navigation);
|
|
registerThemeHelper('page_url', coreHelpers.page_url);
|
|
registerThemeHelper('pageUrl', coreHelpers.pageUrl);
|
|
registerThemeHelper('pagination', coreHelpers.pagination);
|
|
registerThemeHelper('tags', coreHelpers.tags);
|
|
registerThemeHelper('plural', coreHelpers.plural);
|
|
registerThemeHelper('url', coreHelpers.url);
|
|
registerThemeHelper('image', coreHelpers.image);
|
|
|
|
// Async theme helpers
|
|
registerAsyncThemeHelper('body_class', coreHelpers.body_class);
|
|
registerAsyncThemeHelper('ghost_foot', coreHelpers.ghost_foot);
|
|
registerAsyncThemeHelper('ghost_head', coreHelpers.ghost_head);
|
|
registerAsyncThemeHelper('meta_description', coreHelpers.meta_description);
|
|
registerAsyncThemeHelper('meta_title', coreHelpers.meta_title);
|
|
registerAsyncThemeHelper('post_class', coreHelpers.post_class);
|
|
registerAsyncThemeHelper('next_post', coreHelpers.next_post);
|
|
registerAsyncThemeHelper('prev_post', coreHelpers.prev_post);
|
|
registerAsyncThemeHelper('get', coreHelpers.get);
|
|
|
|
// Register admin helpers
|
|
registerAdminHelper('asset', coreHelpers.asset);
|
|
registerAdminHelper('input_password', coreHelpers.input_password);
|
|
};
|
|
|
|
module.exports = coreHelpers;
|
|
module.exports.loadCoreHelpers = registerHelpers;
|
|
module.exports.registerThemeHelper = registerThemeHelper;
|
|
module.exports.registerAsyncThemeHelper = registerAsyncThemeHelper;
|