2015-02-13 07:22:32 +03:00
|
|
|
import Ember from 'ember';
|
2016-01-04 19:50:18 +03:00
|
|
|
import ActiveLinkWrapper from 'ghost/mixins/active-link-wrapper';
|
2015-06-13 17:34:09 +03:00
|
|
|
|
2016-01-19 16:03:27 +03:00
|
|
|
const {
|
|
|
|
$,
|
|
|
|
Component,
|
|
|
|
computed,
|
|
|
|
inject: {service}
|
|
|
|
} = Ember;
|
2015-10-28 14:36:45 +03:00
|
|
|
const {alias, equal} = computed;
|
|
|
|
|
2016-01-04 19:50:18 +03:00
|
|
|
export default Component.extend(ActiveLinkWrapper, {
|
2015-06-13 17:34:09 +03:00
|
|
|
tagName: 'li',
|
2016-01-04 19:50:18 +03:00
|
|
|
classNameBindings: ['isFeatured:featured', 'isPage:page'],
|
2014-03-02 18:30:35 +04:00
|
|
|
|
2015-06-13 17:34:09 +03:00
|
|
|
post: null,
|
2015-08-28 13:52:38 +03:00
|
|
|
previewIsHidden: false,
|
2015-06-13 17:34:09 +03:00
|
|
|
|
2015-10-28 14:36:45 +03:00
|
|
|
isFeatured: alias('post.featured'),
|
|
|
|
isPage: alias('post.page'),
|
|
|
|
isPublished: equal('post.status', 'published'),
|
2014-06-16 09:44:07 +04:00
|
|
|
|
2016-01-19 16:03:27 +03:00
|
|
|
ghostPaths: service(),
|
2014-06-16 09:44:07 +04:00
|
|
|
|
2015-10-28 14:36:45 +03:00
|
|
|
authorName: computed('post.author.name', 'post.author.email', function () {
|
2015-06-13 17:34:09 +03:00
|
|
|
return this.get('post.author.name') || this.get('post.author.email');
|
|
|
|
}),
|
|
|
|
|
2015-10-28 14:36:45 +03:00
|
|
|
authorAvatar: computed('post.author.image', function () {
|
2016-01-14 19:25:29 +03:00
|
|
|
return this.get('post.author.image') || `${this.get('ghostPaths.subdir')}/ghost/img/user-image.png`;
|
2015-06-13 17:34:09 +03:00
|
|
|
}),
|
|
|
|
|
2015-10-28 14:36:45 +03:00
|
|
|
authorAvatarBackground: computed('authorAvatar', function () {
|
2015-11-21 01:45:43 +03:00
|
|
|
return Ember.String.htmlSafe(`background-image: url(${this.get('authorAvatar')})`);
|
2015-06-13 17:34:09 +03:00
|
|
|
}),
|
|
|
|
|
2015-10-28 14:36:45 +03:00
|
|
|
viewOrEdit: computed('previewIsHidden', function () {
|
2015-08-28 13:52:38 +03:00
|
|
|
return this.get('previewIsHidden') ? 'editor.edit' : 'posts.post';
|
|
|
|
}),
|
|
|
|
|
2015-10-28 14:36:45 +03:00
|
|
|
click() {
|
2015-06-13 17:34:09 +03:00
|
|
|
this.sendAction('onClick', this.get('post'));
|
|
|
|
},
|
2014-09-10 05:22:11 +04:00
|
|
|
|
2015-10-28 14:36:45 +03:00
|
|
|
doubleClick() {
|
2015-06-13 17:34:09 +03:00
|
|
|
this.sendAction('onDoubleClick', this.get('post'));
|
2014-09-10 05:22:11 +04:00
|
|
|
},
|
|
|
|
|
2015-10-28 14:36:45 +03:00
|
|
|
didInsertElement() {
|
2015-11-15 14:06:49 +03:00
|
|
|
this._super(...arguments);
|
2015-06-13 17:34:09 +03:00
|
|
|
this.addObserver('active', this, this.scrollIntoView);
|
2014-10-27 23:29:27 +03:00
|
|
|
},
|
2015-06-13 17:34:09 +03:00
|
|
|
|
2015-10-28 14:36:45 +03:00
|
|
|
willDestroyElement() {
|
2015-11-15 14:06:49 +03:00
|
|
|
this._super(...arguments);
|
2015-06-13 17:34:09 +03:00
|
|
|
this.removeObserver('active', this, this.scrollIntoView);
|
|
|
|
},
|
|
|
|
|
2015-10-28 14:36:45 +03:00
|
|
|
scrollIntoView() {
|
2014-10-27 23:29:27 +03:00
|
|
|
if (!this.get('active')) {
|
|
|
|
return;
|
|
|
|
}
|
2015-06-13 17:34:09 +03:00
|
|
|
|
2015-10-28 14:36:45 +03:00
|
|
|
let element = this.$();
|
|
|
|
let offset = element.offset().top;
|
|
|
|
let elementHeight = element.height();
|
|
|
|
let container = $('.js-content-scrollbox');
|
|
|
|
let containerHeight = container.height();
|
|
|
|
let currentScroll = container.scrollTop();
|
|
|
|
let isBelowTop, isAboveBottom, isOnScreen;
|
2014-10-27 23:29:27 +03:00
|
|
|
|
|
|
|
isAboveBottom = offset < containerHeight;
|
|
|
|
isBelowTop = offset > elementHeight;
|
2014-09-10 05:22:11 +04:00
|
|
|
|
2014-10-27 23:29:27 +03:00
|
|
|
isOnScreen = isBelowTop && isAboveBottom;
|
|
|
|
|
|
|
|
if (!isOnScreen) {
|
|
|
|
// Scroll so that element is centered in container
|
|
|
|
// 40 is the amount of padding on the container
|
|
|
|
container.clearQueue().animate({
|
|
|
|
scrollTop: currentScroll + offset - 40 - containerHeight / 2
|
|
|
|
});
|
|
|
|
}
|
2015-06-03 05:56:42 +03:00
|
|
|
}
|
2014-03-04 00:18:10 +04:00
|
|
|
});
|