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:
parent
4f8dfd84b9
commit
c093187d34
|
@ -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) &&
|
||||
|
|
|
@ -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; });
|
||||
|
|
|
@ -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);
|
||||
},
|
||||
|
||||
|
|
|
@ -189,6 +189,8 @@ Ember.DiscourseLocation = Ember.Object.extend({
|
|||
popstateCallbacks.forEach(function(cb) {
|
||||
cb(url);
|
||||
});
|
||||
|
||||
self.set('poppedState',true);
|
||||
callback(url);
|
||||
});
|
||||
},
|
||||
|
|
|
@ -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() {
|
||||
|
|
Loading…
Reference in New Issue