mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-06 22:40:14 -05:00
Merge pull request #3861 from cobbspur/metas
Added correct contextual Meta Titles and Descriptions
This commit is contained in:
commit
5856cdd67e
2 changed files with 110 additions and 29 deletions
|
@ -542,21 +542,31 @@ coreHelpers.ghost_foot = function (options) {
|
|||
coreHelpers.meta_title = function (options) {
|
||||
/*jshint unused:false*/
|
||||
var title = '',
|
||||
blog;
|
||||
blog,
|
||||
page,
|
||||
pageString = '';
|
||||
|
||||
if (_.isString(this.relativeUrl)) {
|
||||
blog = config.theme();
|
||||
if (!this.relativeUrl || this.relativeUrl === '/' || this.relativeUrl === '' || this.relativeUrl.match(/\/page/)) {
|
||||
|
||||
page = this.relativeUrl.match(/\/page\/(\d+)/);
|
||||
|
||||
if (page) {
|
||||
pageString = ' - Page ' + page[1];
|
||||
}
|
||||
|
||||
if (!this.relativeUrl || this.relativeUrl === '/' || this.relativeUrl === '') {
|
||||
title = blog.title;
|
||||
} else if (this.author) {
|
||||
title = this.author.name + pageString + ' - ' + blog.title;
|
||||
} else if (this.tag) {
|
||||
title = this.tag.name + pageString + ' - ' + blog.title;
|
||||
} else if (this.post) {
|
||||
title = this.post.title;
|
||||
} else if (this.tag) {
|
||||
title = this.tag.name + ' - ' + blog.title;
|
||||
} else if (this.author) {
|
||||
title = this.author.name + ' - ' + blog.title;
|
||||
} else {
|
||||
title = blog.title + pageString;
|
||||
}
|
||||
}
|
||||
|
||||
return filters.doFilter('meta_title', title).then(function (title) {
|
||||
title = title || '';
|
||||
return title.trim();
|
||||
|
@ -569,10 +579,12 @@ coreHelpers.meta_description = function (options) {
|
|||
blog;
|
||||
|
||||
if (_.isString(this.relativeUrl)) {
|
||||
if (!this.relativeUrl || this.relativeUrl === '/' || this.relativeUrl === '' || this.relativeUrl.match(/\/page/)) {
|
||||
blog = config.theme();
|
||||
blog = config.theme();
|
||||
if (!this.relativeUrl || this.relativeUrl === '/' || this.relativeUrl === '') {
|
||||
description = blog.description;
|
||||
} else {
|
||||
} else if (this.author) {
|
||||
description = /\/page\//.test(this.relativeUrl) ? '' : this.author.bio;
|
||||
} else if (this.tag || this.post || /\/page\//.test(this.relativeUrl)) {
|
||||
description = '';
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1144,7 +1144,7 @@ describe('Core Helpers', function () {
|
|||
should.exist(handlebars.helpers.meta_title);
|
||||
});
|
||||
|
||||
it('can return blog title', function (done) {
|
||||
it('returns correct title for homepage', function (done) {
|
||||
helpers.meta_title.call({relativeUrl: '/'}).then(function (rendered) {
|
||||
should.exist(rendered);
|
||||
String(rendered).should.equal('Ghost');
|
||||
|
@ -1153,37 +1153,66 @@ describe('Core Helpers', function () {
|
|||
}).catch(done);
|
||||
});
|
||||
|
||||
it('can return title of a post', function (done) {
|
||||
it('returns correct title for paginated page', function (done) {
|
||||
helpers.meta_title.call({relativeUrl: '/page/2/'}).then(function (rendered) {
|
||||
should.exist(rendered);
|
||||
String(rendered).should.equal('Ghost - Page 2');
|
||||
|
||||
done();
|
||||
}).catch(done);
|
||||
});
|
||||
|
||||
it('returns correct title for a post', function (done) {
|
||||
var post = {relativeUrl: '/nice-post', post: {title: 'Post Title'}};
|
||||
helpers.meta_title.call(post).then(function (rendered) {
|
||||
should.exist(rendered);
|
||||
String(rendered).should.equal('Post Title');
|
||||
|
||||
done();
|
||||
}).then(null, done);
|
||||
}).catch(done);
|
||||
});
|
||||
|
||||
it('can return title for a tag page', function (done) {
|
||||
it('returns correct title for a tag page', function (done) {
|
||||
var tag = {relativeUrl: '/tag/rasper-red', tag: {name: 'Rasper Red'}};
|
||||
helpers.meta_title.call(tag).then(function (rendered) {
|
||||
should.exist(rendered);
|
||||
String(rendered).should.equal('Rasper Red - Ghost');
|
||||
|
||||
done();
|
||||
}).then(null, done);
|
||||
}).catch(done);
|
||||
});
|
||||
|
||||
it('can return title for an author page', function (done) {
|
||||
it('returns correct title for a paginated tag page', function (done) {
|
||||
var tag = {relativeUrl: '/tag/rasper-red/page/2/', tag: {name: 'Rasper Red'}};
|
||||
helpers.meta_title.call(tag).then(function (rendered) {
|
||||
should.exist(rendered);
|
||||
String(rendered).should.equal('Rasper Red - Page 2 - Ghost');
|
||||
|
||||
done();
|
||||
}).catch(done);
|
||||
});
|
||||
|
||||
it('returns correct title for an author page', function (done) {
|
||||
var author = {relativeUrl: '/author/donald', author: {name: 'Donald Duck'}};
|
||||
helpers.meta_title.call(author).then(function (rendered) {
|
||||
should.exist(rendered);
|
||||
String(rendered).should.equal('Donald Duck - Ghost');
|
||||
|
||||
done();
|
||||
}).then(null, done);
|
||||
}).catch(done);
|
||||
});
|
||||
|
||||
it('can return escaped title of a post', function (done) {
|
||||
it('returns correct title for a paginated author page', function (done) {
|
||||
var author = {relativeUrl: '/author/donald/page/2/', author: {name: 'Donald Duck'}};
|
||||
helpers.meta_title.call(author).then(function (rendered) {
|
||||
should.exist(rendered);
|
||||
String(rendered).should.equal('Donald Duck - Page 2 - Ghost');
|
||||
|
||||
done();
|
||||
}).catch(done);
|
||||
});
|
||||
|
||||
it('returns correctly escaped title of a post', function (done) {
|
||||
var post = {relativeUrl: '/nice-escaped-post', post: {title: 'Post Title "</>'}};
|
||||
helpers.meta_title.call(post).then(function (rendered) {
|
||||
should.exist(rendered);
|
||||
|
@ -1193,15 +1222,6 @@ describe('Core Helpers', function () {
|
|||
}).catch(done);
|
||||
});
|
||||
|
||||
it('can return tag name', function (done) {
|
||||
var post = {relativeUrl: '/tag/foo', tag: {name: 'foo'}};
|
||||
helpers.meta_title.call(post).then(function (rendered) {
|
||||
should.exist(rendered);
|
||||
String(rendered).should.equal('foo - Ghost');
|
||||
|
||||
done();
|
||||
}).catch(done);
|
||||
});
|
||||
});
|
||||
|
||||
describe('meta_description helper', function () {
|
||||
|
@ -1210,7 +1230,7 @@ describe('Core Helpers', function () {
|
|||
should.exist(handlebars.helpers.meta_description);
|
||||
});
|
||||
|
||||
it('can return blog description', function (done) {
|
||||
it('returns correct blog description', function (done) {
|
||||
helpers.meta_description.call({relativeUrl: '/'}).then(function (rendered) {
|
||||
should.exist(rendered);
|
||||
String(rendered).should.equal('Just a blogging platform.');
|
||||
|
@ -1219,7 +1239,56 @@ describe('Core Helpers', function () {
|
|||
}).catch(done);
|
||||
});
|
||||
|
||||
it('can return empty description on post', function (done) {
|
||||
it('returns empty description on paginated page', function (done) {
|
||||
helpers.meta_description.call({relativeUrl: '/page/2/'}).then(function (rendered) {
|
||||
should.exist(rendered);
|
||||
String(rendered).should.equal('');
|
||||
|
||||
done();
|
||||
}).catch(done);
|
||||
});
|
||||
|
||||
it('returns empty description for a tag page', function (done) {
|
||||
var tag = {relativeUrl: '/tag/rasper-red', tag: {name: 'Rasper Red'}};
|
||||
helpers.meta_description.call(tag).then(function (rendered) {
|
||||
should.exist(rendered);
|
||||
String(rendered).should.equal('');
|
||||
|
||||
done();
|
||||
}).catch(done);
|
||||
});
|
||||
|
||||
it('returns empty description for a paginated tag page', function (done) {
|
||||
var tag = {relativeUrl: '/tag/rasper-red/page/2/', tag: {name: 'Rasper Red'}};
|
||||
helpers.meta_description.call(tag).then(function (rendered) {
|
||||
should.exist(rendered);
|
||||
String(rendered).should.equal('');
|
||||
|
||||
done();
|
||||
}).catch(done);
|
||||
});
|
||||
|
||||
it('returns correct description for an author page', function (done) {
|
||||
var author = {relativeUrl: '/author/donald', author: {bio: 'I am a Duck.'}};
|
||||
helpers.meta_description.call(author).then(function (rendered) {
|
||||
should.exist(rendered);
|
||||
String(rendered).should.equal('I am a Duck.');
|
||||
|
||||
done();
|
||||
}).catch(done);
|
||||
});
|
||||
|
||||
it('returns empty description for a paginated author page', function (done) {
|
||||
var author = {relativeUrl: '/author/donald/page/2/', author: {name: 'Donald Duck'}};
|
||||
helpers.meta_description.call(author).then(function (rendered) {
|
||||
should.exist(rendered);
|
||||
String(rendered).should.equal('');
|
||||
|
||||
done();
|
||||
}).catch(done);
|
||||
});
|
||||
|
||||
it('returns empty description on post', function (done) {
|
||||
var post = {relativeUrl: '/nice-post', post: {title: 'Post Title'}};
|
||||
helpers.meta_description.call(post).then(function (rendered) {
|
||||
should.exist(rendered);
|
||||
|
|
Loading…
Reference in a new issue