Skip to content

Commit

Permalink
fix(open_graph-helper): pass all pretty_urls options
Browse files Browse the repository at this point in the history
- by utilizing prettyUrls() of hexo-util
- to support pretty_urls.trailing_html
  • Loading branch information
curbengh committed Dec 19, 2019
1 parent 4c86aac commit 7037ba5
Show file tree
Hide file tree
Showing 2 changed files with 44 additions and 14 deletions.
12 changes: 3 additions & 9 deletions lib/plugins/helper/open_graph.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

const urlFn = require('url');
const moment = require('moment');
const { encodeURL, htmlTag, stripHTML, escapeHTML } = require('hexo-util');
const { htmlTag, prettyUrls, stripHTML, escapeHTML } = require('hexo-util');
const localeMap = {
'en': 'en_US',
'de': 'de_DE',
Expand Down Expand Up @@ -44,7 +44,7 @@ function openGraphHelper(options = {}) {
let keywords = page.keywords || (page.tags && page.tags.length ? page.tags : undefined) || config.keywords;
const title = options.title || page.title || config.title;
const type = options.type || (this.is_post() ? 'article' : 'website');
let url = options.url || this.url;
const url = prettyUrls(options.url || this.url || config.url, config.pretty_urls);
const siteName = options.site_name || config.title;
const twitterCard = options.twitter_card || 'summary';
const date = options.date !== false ? options.date || page.date : false;
Expand Down Expand Up @@ -82,12 +82,6 @@ function openGraphHelper(options = {}) {
result += og('og:type', type);
result += og('og:title', title);

if (url) {
if (config.pretty_urls.trailing_index === false) {
url = url.replace(/index\.html$/, '');
}
url = encodeURL(url);
}
result += og('og:url', url);

result += og('og:site_name', siteName);
Expand All @@ -113,7 +107,7 @@ function openGraphHelper(options = {}) {
if (!urlFn.parse(path).host) {
// resolve `path`'s absolute path relative to current page's url
// `path` can be both absolute (starts with `/`) or relative.
return urlFn.resolve(url || config.url, path);
return urlFn.resolve(url, path);
}

return path;
Expand Down
46 changes: 41 additions & 5 deletions test/scripts/helpers/open_graph.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

const moment = require('moment');
const cheerio = require('cheerio');
const { encodeURL } = require('hexo-util');
const { escapeHTML } = require('hexo-util');

describe('open_graph', () => {
const Hexo = require('../../../lib/hexo');
Expand Down Expand Up @@ -34,7 +34,7 @@ describe('open_graph', () => {
}).should.eql([
meta({property: 'og:type', content: 'website'}),
meta({property: 'og:title', content: hexo.config.title}),
meta({property: 'og:url'}),
meta({property: 'og:url', content: escapeHTML(hexo.config.url)}),
meta({property: 'og:site_name', content: hexo.config.title}),
meta({property: 'og:locale', content: 'en_US'}),
meta({property: 'article:published_time', content: post.date.toISOString()}),
Expand Down Expand Up @@ -117,7 +117,7 @@ describe('open_graph', () => {
result.should.contain(meta({property: 'og:url', content: 'https://hexo.io/bar'}));
});

it('url - should not ends with index.html', () => {
it('url - pretty_urls.trailing_index', () => {
hexo.config.pretty_urls.trailing_index = false;
const result = openGraph.call({
page: {},
Expand All @@ -128,11 +128,47 @@ describe('open_graph', () => {

const $ = cheerio.load(result);

$('meta[property="og:url"]').attr('content').endsWith('index.html').should.be.false;
$('meta[property="og:url"]').attr('content').endsWith('index.html').should.eql(false);

hexo.config.pretty_urls.trailing_index = true;
});

it('url - pretty_urls.trailing_html', () => {
hexo.config.pretty_urls.trailing_html = false;
const result = openGraph.call({
page: {},
config: hexo.config,
is_post: isPost,
url: 'http://yoursite.com/page/about.html'
});

const $ = cheerio.load(result);

$('meta[property="og:url"]').attr('content').endsWith('.html').should.eql(false);

hexo.config.pretty_urls.trailing_html = true;
});

it('url - null pretty_urls', () => {
hexo.config.pretty_urls = null;
const url = 'http://yoursite.com/page/about.html';
const result = openGraph.call({
page: {},
config: hexo.config,
is_post: isPost,
url
});

const $ = cheerio.load(result);

$('meta[property="og:url"]').attr('content').should.eql(url);

hexo.config.pretty_urls = {
trailing_index: true,
trailing_html: true
};
});

it('url - IDN', () => {
const ctx = {
page: {},
Expand All @@ -143,7 +179,7 @@ describe('open_graph', () => {

const result = openGraph.call(ctx);

result.should.contain(meta({property: 'og:url', content: encodeURL(ctx.url)}));
result.should.contain(meta({property: 'og:url', content: escapeHTML(ctx.url)}));
});

it('images - content', () => {
Expand Down

0 comments on commit 7037ba5

Please sign in to comment.