- new "show-footer" mixins - converted most of the routes to ES6 - FIX: handling of "indexStream" in user pages There will now be a footer on all the following pages - /exception - /about - /latest - /new - /unread - /starred - /top - /categories - /c/:category - /c/:category/l/latest - /c/:category/l/new - /c/:category/l/unread - /c/:category/l/top - /t/:topic/:id - /groups/:name/members - /user/activity - /user/activity/topics - /user/activity/posts - /user/activity/replies - /user/activity/likes-given - /user/activity/likes-received - /user/activity/bookmarks - /user/activity/starred - /user/badges - /user/notifications - /user/flagged-posts - /user/deleted-posts - /user/private-messages - /user/private-messages/mine - /user/private-messages/unread - /user/invited - /user/:username/preferences - /faq (static pages) - /badges - /badges/:id/:badge
57 lines
1.4 KiB
JavaScript
57 lines
1.4 KiB
JavaScript
/**
|
|
Represents a user's stream
|
|
|
|
@class UserPostsStream
|
|
@extends Discourse.Model
|
|
@namespace Discourse
|
|
@module Discourse
|
|
**/
|
|
Discourse.UserPostsStream = Discourse.Model.extend({
|
|
loaded: false,
|
|
|
|
_initialize: function () {
|
|
this.setProperties({
|
|
itemsLoaded: 0,
|
|
canLoadMore: true,
|
|
content: []
|
|
});
|
|
}.on("init"),
|
|
|
|
url: Discourse.computed.url("user.username_lower", "filter", "itemsLoaded", "/posts/%@/%@?offset=%@"),
|
|
|
|
filterBy: function (filter) {
|
|
if (this.get("loaded") && this.get("filter") === filter) { return Ember.RSVP.resolve(); }
|
|
|
|
this.setProperties({
|
|
filter: filter,
|
|
itemsLoaded: 0,
|
|
canLoadMore: true,
|
|
content: []
|
|
});
|
|
|
|
return this.findItems();
|
|
},
|
|
|
|
findItems: function () {
|
|
var self = this;
|
|
if (this.get("loading") || !this.get("canLoadMore")) { return Ember.RSVP.reject(); }
|
|
|
|
this.set("loading", true);
|
|
|
|
return Discourse.ajax(this.get("url"), { cache: false }).then(function (result) {
|
|
if (result) {
|
|
var posts = result.map(function (post) { return Discourse.AdminPost.create(post); });
|
|
self.get("content").pushObjects(posts);
|
|
self.setProperties({
|
|
loaded: true,
|
|
itemsLoaded: self.get("itemsLoaded") + posts.length,
|
|
canLoadMore: posts.length === 0 || posts.length < 60
|
|
});
|
|
}
|
|
}).finally(function () {
|
|
self.set("loading", false);
|
|
});
|
|
}
|
|
|
|
});
|