mirror of
https://github.com/flarum/framework.git
synced 2024-12-13 15:13:42 +08:00
c28307903b
HTMLBars goodness! Since there was some breakage and a lot of fiddling around to get some things working, I took this opportunity to do a big cleanup of the whole Ember app. I accidentally worked on some new features too :3 Note that the app is still broken right now, pending on https://github.com/emberjs/ember.js/issues/10401 Cleanup: - Restructuring of components - Consolidation of some stuff into mixins, cleanup of some APIs that will be public - Change all instances of .property() / .observes() / .on() to Ember.computed() / Ember.observer() / Ember.on() respectively (I think it is more readable) - More comments - Start conforming to a code style (2 spaces for indentation) New features: - Post hiding/restoring - Mark individual discussions as read by clicking - Clicking on a read discussion jumps to the end - Mark all discussions as read - Progressively mark the discussion as read as the page is scrolled - Unordered list post formatting - Post permalink popup Demo once that Ember regression is fixed!
31 lines
1.0 KiB
JavaScript
31 lines
1.0 KiB
JavaScript
import Ember from 'ember';
|
|
|
|
export default Ember.View.extend({
|
|
didInsertElement: function() {
|
|
this.updateTitle();
|
|
var scrollTop = this.get('controller.scrollTop');
|
|
$(window).scrollTop(scrollTop);
|
|
|
|
var lastDiscussion = this.get('controller.lastDiscussion');
|
|
if (lastDiscussion) {
|
|
var $discussion = $('.index-area .discussion-summary[data-id='+lastDiscussion.get('id')+']');
|
|
if ($discussion.length) {
|
|
var indexTop = $('#header').outerHeight();
|
|
var discussionTop = $discussion.offset().top;
|
|
if (discussionTop < scrollTop + indexTop || discussionTop + $discussion.outerHeight() > scrollTop + $(window).height()) {
|
|
$(window).scrollTop(discussionTop - indexTop);
|
|
}
|
|
}
|
|
}
|
|
},
|
|
|
|
willDestroyElement: function() {
|
|
this.set('controller.scrollTop', $(window).scrollTop());
|
|
},
|
|
|
|
updateTitle: Ember.observer('controller.searchQuery', function() {
|
|
var q = this.get('controller.searchQuery');
|
|
this.get('controller.controllers.application').set('pageTitle', q ? '"'+q+'"' : '');
|
|
})
|
|
});
|