mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-04 17:04:59 +03:00
Allow domain name to be referenced on an external page in the navigation.
closes #6939 - added a test for the specific issue - modified the url generation to allow the url in an external pages slug
This commit is contained in:
parent
7b098e085a
commit
696a06fa00
@ -204,11 +204,11 @@ function urlFor(context, data, absolute) {
|
|||||||
baseUrl = getBaseUrl(secure);
|
baseUrl = getBaseUrl(secure);
|
||||||
hostname = baseUrl.split('//')[1] + ghostConfig.paths.subdir;
|
hostname = baseUrl.split('//')[1] + ghostConfig.paths.subdir;
|
||||||
if (urlPath.indexOf(hostname) > -1
|
if (urlPath.indexOf(hostname) > -1
|
||||||
&& urlPath.indexOf('.' + hostname) === -1
|
&& !urlPath.split(hostname)[0].match(/\.|mailto:/)) {
|
||||||
&& urlPath.indexOf('mailto:') !== 0) {
|
|
||||||
// make link relative to account for possible
|
// make link relative to account for possible
|
||||||
// mismatch in http/https etc, force absolute
|
// mismatch in http/https etc, force absolute
|
||||||
// do not do so if link is a subdomain of blog url
|
// do not do so if link is a subdomain of blog url
|
||||||
|
// or if hostname is inside of the slug
|
||||||
urlPath = urlPath.split(hostname)[1];
|
urlPath = urlPath.split(hostname)[1];
|
||||||
if (urlPath.substring(0, 1) !== '/') {
|
if (urlPath.substring(0, 1) !== '/') {
|
||||||
urlPath = '/' + urlPath;
|
urlPath = '/' + urlPath;
|
||||||
|
@ -364,6 +364,12 @@ describe('Config', function () {
|
|||||||
testData = {nav: {url: '#this-anchor'}};
|
testData = {nav: {url: '#this-anchor'}};
|
||||||
config.urlFor(testContext, testData).should.equal('#this-anchor');
|
config.urlFor(testContext, testData).should.equal('#this-anchor');
|
||||||
|
|
||||||
|
testData = {nav: {url: 'http://some-external-page.com/my-ghost-blog.com'}};
|
||||||
|
config.urlFor(testContext, testData).should.equal('http://some-external-page.com/my-ghost-blog.com');
|
||||||
|
|
||||||
|
testData = {nav: {url: 'http://some-external-page.com/stuff-my-ghost-blog.com-around'}};
|
||||||
|
config.urlFor(testContext, testData).should.equal('http://some-external-page.com/stuff-my-ghost-blog.com-around');
|
||||||
|
|
||||||
configUtils.set({url: 'http://my-ghost-blog.com/blog'});
|
configUtils.set({url: 'http://my-ghost-blog.com/blog'});
|
||||||
testData = {nav: {url: 'http://my-ghost-blog.com/blog/short-and-sweet/'}};
|
testData = {nav: {url: 'http://my-ghost-blog.com/blog/short-and-sweet/'}};
|
||||||
config.urlFor(testContext, testData).should.equal('http://my-ghost-blog.com/blog/short-and-sweet/');
|
config.urlFor(testContext, testData).should.equal('http://my-ghost-blog.com/blog/short-and-sweet/');
|
||||||
|
Loading…
Reference in New Issue
Block a user