2015-02-12 21:22:32 -07:00
|
|
|
import Ember from 'ember';
|
2014-11-28 10:15:48 +00:00
|
|
|
/*
|
|
|
|
Example usage:
|
|
|
|
{{gh-url-preview prefix="tag" slug=theSlugValue tagName="p" classNames="description"}}
|
|
|
|
*/
|
|
|
|
var urlPreview = Ember.Component.extend({
|
|
|
|
classNames: 'ghost-url-preview',
|
|
|
|
prefix: null,
|
|
|
|
slug: null,
|
|
|
|
|
2015-05-25 21:10:50 -05:00
|
|
|
config: Ember.inject.service(),
|
|
|
|
|
2015-01-29 17:05:16 +00:00
|
|
|
url: Ember.computed('slug', function () {
|
2014-11-28 10:15:48 +00:00
|
|
|
// Get the blog URL and strip the scheme
|
2015-05-25 21:10:50 -05:00
|
|
|
var blogUrl = this.get('config.blogUrl'),
|
2014-11-28 10:15:48 +00:00
|
|
|
noSchemeBlogUrl = blogUrl.substr(blogUrl.indexOf('://') + 3), // Remove `http[s]://`
|
|
|
|
|
|
|
|
// Get the prefix and slug values
|
|
|
|
prefix = this.get('prefix') ? this.get('prefix') + '/' : '',
|
2015-01-29 17:05:16 +00:00
|
|
|
slug = this.get('slug') ? this.get('slug') + '/' : '',
|
2014-11-28 10:15:48 +00:00
|
|
|
|
|
|
|
// Join parts of the URL together with slashes
|
2015-01-29 17:05:16 +00:00
|
|
|
theUrl = noSchemeBlogUrl + '/' + prefix + slug;
|
2014-11-28 10:15:48 +00:00
|
|
|
|
2015-01-29 17:05:16 +00:00
|
|
|
return theUrl;
|
|
|
|
})
|
2014-11-28 10:15:48 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
export default urlPreview;
|