mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-06 22:40:14 -05:00
Fixed frontend rendering of page resource
refs https://github.com/TryGhost/Toolbox/issues/332 - After removing the concept of a boolean "page: true" from the page/post resources frontend resource rendering didn't have enough information to pick the correct template - Resolved this issue through passing of additional "context" to the template picker. Something nicer should be worked on in the future, as context pattern feels dirty here.
This commit is contained in:
parent
44c72ddd81
commit
0c097f6532
6 changed files with 35 additions and 18 deletions
|
@ -10,11 +10,11 @@ module.exports = function body_class(options) { // eslint-disable-line camelcase
|
|||
const context = options.data.root.context || [];
|
||||
const obj = this.post || this.page;
|
||||
const tags = obj && obj.tags ? obj.tags : [];
|
||||
const isPage = !!(obj && obj.page);
|
||||
const isPage = !!(this.page);
|
||||
|
||||
if (context.includes('home')) {
|
||||
classes.push('home-template');
|
||||
} else if (context.includes('post') && obj) {
|
||||
} else if (context.includes('post') && obj && !isPage) {
|
||||
classes.push('post-template');
|
||||
} else if (context.includes('page') && obj && isPage) {
|
||||
classes.push('page-template');
|
||||
|
|
|
@ -46,12 +46,18 @@ function formatPageResponse(result) {
|
|||
*
|
||||
* @return {Object} containing page variables
|
||||
*/
|
||||
function formatResponse(post) {
|
||||
function formatResponse(post, context) {
|
||||
prepareContextResource(post);
|
||||
|
||||
return {
|
||||
let entry = {
|
||||
post: post
|
||||
};
|
||||
|
||||
if (context?.includes('page')) {
|
||||
entry.page = post;
|
||||
}
|
||||
|
||||
return entry;
|
||||
}
|
||||
|
||||
module.exports = {
|
||||
|
|
|
@ -13,6 +13,6 @@ module.exports = function renderEntry(req, res) {
|
|||
return function renderEntryClosure(entry) {
|
||||
// Format data 2 - 1 is in preview/entry
|
||||
// Render
|
||||
return renderer(req, res, formatResponse.entry(entry));
|
||||
return renderer(req, res, formatResponse.entry(entry, res.routerOptions?.context));
|
||||
};
|
||||
};
|
||||
|
|
|
@ -82,11 +82,11 @@ _private.getEntriesTemplateHierarchy = function getEntriesTemplateHierarchy(rout
|
|||
* @param {Object} postObject
|
||||
* @returns {String[]}
|
||||
*/
|
||||
_private.getEntryTemplateHierarchy = function getEntryTemplateHierarchy(postObject) {
|
||||
_private.getEntryTemplateHierarchy = function getEntryTemplateHierarchy(postObject, context) {
|
||||
const templateList = ['post'];
|
||||
let slugTemplate = 'post-' + postObject.slug;
|
||||
|
||||
if (postObject.page) {
|
||||
if (context === 'page') {
|
||||
templateList.unshift('page');
|
||||
slugTemplate = 'page-' + postObject.slug;
|
||||
}
|
||||
|
@ -141,8 +141,14 @@ _private.pickTemplate = function pickTemplate(templateList, fallback) {
|
|||
return template;
|
||||
};
|
||||
|
||||
_private.getTemplateForEntry = function getTemplateForEntry(postObject) {
|
||||
const templateList = _private.getEntryTemplateHierarchy(postObject);
|
||||
/**
|
||||
*
|
||||
* @param {Object} entry
|
||||
* @param {('post'|'page')} context
|
||||
* @returns
|
||||
*/
|
||||
_private.getTemplateForEntry = function getTemplateForEntry(entry, context) {
|
||||
const templateList = _private.getEntryTemplateHierarchy(entry, context);
|
||||
const fallback = templateList[templateList.length - 1];
|
||||
return _private.pickTemplate(templateList, fallback);
|
||||
};
|
||||
|
@ -184,7 +190,11 @@ module.exports.setTemplate = function setTemplate(req, res, data) {
|
|||
} else if (res.routerOptions.type === 'custom') {
|
||||
res._template = _private.pickTemplate(res.routerOptions.templates, res.routerOptions.defaultTemplate);
|
||||
} else if (res.routerOptions.type === 'entry') {
|
||||
res._template = _private.getTemplateForEntry(data.post);
|
||||
if (res.routerOptions?.context?.includes('page')) {
|
||||
res._template = _private.getTemplateForEntry(data.page, 'page');
|
||||
} else {
|
||||
res._template = _private.getTemplateForEntry(data.post, 'post');
|
||||
}
|
||||
} else {
|
||||
res._template = 'index';
|
||||
}
|
||||
|
|
|
@ -145,7 +145,11 @@ describe('{{body_class}} helper', function () {
|
|||
it('a static page with custom template (is now the same as one without)', function () {
|
||||
const rendered = callBodyClassWithContext(
|
||||
['page'],
|
||||
{relativeUrl: '/about', post: {page: true, slug: 'about'}}
|
||||
{
|
||||
relativeUrl: '/about',
|
||||
post: {slug: 'about'},
|
||||
page: {slug: 'about'}
|
||||
}
|
||||
);
|
||||
|
||||
rendered.string.should.equal('page-template page-about');
|
||||
|
|
|
@ -130,7 +130,7 @@ describe('templates', function () {
|
|||
it('will fall back to post even if no index.hbs', function () {
|
||||
hasTemplateStub.returns(false);
|
||||
|
||||
const view = _private.getTemplateForEntry({page: 1});
|
||||
const view = _private.getTemplateForEntry({title: 'hey'}, 'page');
|
||||
should.exist(view);
|
||||
view.should.eql('post');
|
||||
});
|
||||
|
@ -166,18 +166,16 @@ describe('templates', function () {
|
|||
|
||||
it('page without custom slug template', function () {
|
||||
const view = _private.getTemplateForEntry({
|
||||
page: 1,
|
||||
slug: 'contact'
|
||||
});
|
||||
}, 'page');
|
||||
should.exist(view);
|
||||
view.should.eql('page');
|
||||
});
|
||||
|
||||
it('page with custom slug template', function () {
|
||||
const view = _private.getTemplateForEntry({
|
||||
page: 1,
|
||||
slug: 'about'
|
||||
});
|
||||
}, 'page');
|
||||
should.exist(view);
|
||||
view.should.eql('page-about');
|
||||
});
|
||||
|
@ -219,9 +217,8 @@ describe('templates', function () {
|
|||
hasTemplateStub.withArgs('custom-about').returns(false);
|
||||
|
||||
const view = _private.getTemplateForEntry({
|
||||
page: 1,
|
||||
custom_template: 'custom-about'
|
||||
});
|
||||
}, 'page');
|
||||
should.exist(view);
|
||||
view.should.eql('page');
|
||||
});
|
||||
|
|
Loading…
Reference in a new issue