FIX: unread/new counts out of sync with tabs

We were serving cached lists of topics to non popstate reqs
This commit is contained in:
Sam 2014-09-09 16:56:20 +10:00
parent 4f8dfd84b9
commit c093187d34
5 changed files with 22 additions and 3 deletions

View File

@ -197,9 +197,12 @@ Discourse.TopicList.reopenClass({
**/
list: function(filter, params) {
var session = Discourse.Session.current(),
list = session.get('topicList'),
list = params["cache"] && session.get('topicList'),
tracking = Discourse.TopicTrackingState.current();
// only used to control caching
delete params["cache"];
return new Ember.RSVP.Promise(function(resolve) {
// Try to use the cached version
if (list && (list.get('filter') === filter) &&

View File

@ -52,6 +52,8 @@ export default function(filter, params) {
var findOpts = filterQueryParams(transaction.queryParams, params);
findOpts["cache"] = this.get("router.location.poppedState");
return Discourse.TopicList.list(listFilter, findOpts).then(function(list) {
// If all the categories are the same, we can hide them
var hideCategory = !list.get('topics').find(function (t) { return t.get('category') !== model; });

View File

@ -21,12 +21,15 @@ export default function(filter, extras) {
this.controllerFor('navigation/default').set('filterMode', filter);
},
model: function(data, transaction) {
model: function(data, transition) {
// attempt to stop early cause we need this to be called before .sync
Discourse.ScreenTrack.current().stop();
var findOpts = filterQueryParams(transaction.queryParams);
var findOpts = filterQueryParams(transition.queryParams);
findOpts["cache"] = this.get("router.location.poppedState");
return Discourse.TopicList.list(filter, findOpts);
},

View File

@ -189,6 +189,8 @@ Ember.DiscourseLocation = Ember.Object.extend({
popstateCallbacks.forEach(function(cb) {
cb(url);
});
self.set('poppedState',true);
callback(url);
});
},

View File

@ -19,6 +19,15 @@ Discourse.Route = Em.Route.extend({
activate: function() {
this._super();
Em.run.scheduleOnce('afterRender', Discourse.Route, 'cleanDOM');
// the chain of events sucks, we get an event from discourse location
// it goes ahead and sets it, then it call model, then it deactivates
// old route and activates new
//
// if we want to pin this on the location, we need to amend onUpdateURL
// to pass this in to the callback it gets, this would require ember
// API changes
this.set('router.location.poppedState', false);
},
redirectIfLoginRequired: function() {