2015-02-12 21:22:32 -07:00
|
|
|
import Ember from 'ember';
|
2014-06-07 15:07:25 -04:00
|
|
|
import setScrollClassName from 'ghost/utils/set-scroll-classname';
|
|
|
|
|
2015-06-13 09:34:09 -05:00
|
|
|
export default Ember.Component.extend({
|
2014-06-07 15:07:25 -04:00
|
|
|
classNames: ['content-preview-content'],
|
|
|
|
|
2015-06-13 09:34:09 -05:00
|
|
|
content: null,
|
|
|
|
|
|
|
|
didRender: function () {
|
2014-06-07 15:07:25 -04:00
|
|
|
var el = this.$();
|
2015-06-13 09:34:09 -05:00
|
|
|
|
2014-06-07 15:07:25 -04:00
|
|
|
el.on('scroll', Ember.run.bind(el, setScrollClassName, {
|
|
|
|
target: el.closest('.content-preview'),
|
|
|
|
offset: 10
|
|
|
|
}));
|
|
|
|
},
|
|
|
|
|
2015-06-13 09:34:09 -05:00
|
|
|
didReceiveAttrs: function (options) {
|
|
|
|
// adjust when didReceiveAttrs gets both newAttrs and oldAttrs
|
|
|
|
if (options.newAttrs.content && this.get('content') !== options.newAttrs.content.value) {
|
|
|
|
let el = this.$();
|
2015-05-05 15:38:57 -04:00
|
|
|
|
2015-06-13 09:34:09 -05:00
|
|
|
if (el) {
|
|
|
|
el.closest('.content-preview').scrollTop(0);
|
|
|
|
}
|
2015-05-05 15:38:57 -04:00
|
|
|
}
|
2015-06-13 09:34:09 -05:00
|
|
|
},
|
2014-08-19 11:29:49 +01:00
|
|
|
|
2014-06-07 15:07:25 -04:00
|
|
|
willDestroyElement: function () {
|
|
|
|
var el = this.$();
|
2015-06-13 09:34:09 -05:00
|
|
|
|
2014-06-07 15:07:25 -04:00
|
|
|
el.off('scroll');
|
|
|
|
}
|
|
|
|
});
|