mirror of
https://github.com/flarum/framework.git
synced 2025-01-07 19:13:37 +08:00
65 lines
1.9 KiB
JavaScript
65 lines
1.9 KiB
JavaScript
|
import Ember from 'ember';
|
||
|
|
||
|
export default Ember.Route.extend({
|
||
|
|
||
|
queryParams: {
|
||
|
start: {replace: true}
|
||
|
},
|
||
|
|
||
|
renderTemplate: function() {
|
||
|
this.render();
|
||
|
this.render('discussion-sidebar', {
|
||
|
into: 'application',
|
||
|
outlet: 'sidebar'
|
||
|
});
|
||
|
},
|
||
|
|
||
|
model: function(params) {
|
||
|
return this.store.find('discussion', params.id);
|
||
|
},
|
||
|
|
||
|
resetController: function(controller) {
|
||
|
// Whenever we exit the discussion view, or transition to a different
|
||
|
// discussion, we want to reset the query params so that they don't stick.
|
||
|
controller.set('start', '1');
|
||
|
controller.set('searchQuery', '');
|
||
|
controller.set('loaded', false);
|
||
|
controller.set('postStream', null);
|
||
|
},
|
||
|
|
||
|
setupController: function(controller, model) {
|
||
|
controller.setup(model);
|
||
|
|
||
|
this.controllerFor('application').set('showDiscussionStream', true);
|
||
|
this.controllerFor('discussions').set('paned', true);
|
||
|
this.controllerFor('discussions').set('current', model);
|
||
|
},
|
||
|
|
||
|
actions: {
|
||
|
|
||
|
queryParamsDidChange: function(params) {
|
||
|
// We're only interested in changes to the ?start param, and we're
|
||
|
// not interested if nothing has actually changed. If the start
|
||
|
// param has changed, we want to tell the controller to load posts
|
||
|
// near it.
|
||
|
if (! params.start || params.start == this.get('controller.start') || ! this.get('controller.loaded')) {
|
||
|
return;
|
||
|
}
|
||
|
this.get('controller').send('jumpToNumber', params.start);
|
||
|
},
|
||
|
|
||
|
willTransition: function(transition) {
|
||
|
// If we're going to transition out, we need to abort any unfinished
|
||
|
// AJAX requests. We need to do this because sometimes a transition
|
||
|
// to another discussion will happen very rapidly (i.e. when using
|
||
|
// the arrow buttons on the result stream.) If a previous
|
||
|
// discussion's posts finish loading while displaying a new
|
||
|
// discussion, strange things will happen.
|
||
|
this.store.adapterFor('discussion').xhr.forEach(function(xhr) {
|
||
|
xhr.abort();
|
||
|
});
|
||
|
}
|
||
|
|
||
|
}
|
||
|
});
|