diff --git a/app/assets/javascripts/discourse/controllers/group_controller.js b/app/assets/javascripts/discourse/controllers/group_controller.js
index 3fa523e0d8c..ca2af991e9c 100644
--- a/app/assets/javascripts/discourse/controllers/group_controller.js
+++ b/app/assets/javascripts/discourse/controllers/group_controller.js
@@ -7,6 +7,7 @@
@module Discourse
**/
Discourse.GroupController = Discourse.ObjectController.extend({
+ postsCount: null,
// It would be nice if bootstrap marked action lists as selected when their links
// were 'active' not the `li` tags.
diff --git a/app/assets/javascripts/discourse/models/group.js b/app/assets/javascripts/discourse/models/group.js
index 5d307de07cf..7448fecd089 100644
--- a/app/assets/javascripts/discourse/models/group.js
+++ b/app/assets/javascripts/discourse/models/group.js
@@ -154,6 +154,12 @@ Discourse.Group.reopenClass({
});
},
+ findPostsCount: function(name) {
+ return Discourse.ajax("/groups/" + name + "/posts_count.json").then(function(g) {
+ return g.posts_count;
+ });
+ },
+
find: function(name) {
return Discourse.ajax("/groups/" + name + ".json").then(function(g) {
return Discourse.Group.create(g.basic_group);
diff --git a/app/assets/javascripts/discourse/routes/group_route.js b/app/assets/javascripts/discourse/routes/group_route.js
index acbbbe823e2..28613085894 100644
--- a/app/assets/javascripts/discourse/routes/group_route.js
+++ b/app/assets/javascripts/discourse/routes/group_route.js
@@ -12,4 +12,17 @@ Discourse.GroupRoute = Discourse.Route.extend({
return Discourse.Group.find(params.name);
},
+ afterModel: function(model) {
+ var self = this;
+ return Discourse.Group.findPostsCount(model.get('name')).then(function (c) {
+ self.set('postsCount', c);
+ });
+ },
+
+ setupController: function(controller, model) {
+ controller.setProperties({
+ model: model,
+ postsCount: this.get('postsCount')
+ });
+ }
});
diff --git a/app/assets/javascripts/discourse/templates/group.js.handlebars b/app/assets/javascripts/discourse/templates/group.js.handlebars
index 97e47554f66..c4cff14ccca 100644
--- a/app/assets/javascripts/discourse/templates/group.js.handlebars
+++ b/app/assets/javascripts/discourse/templates/group.js.handlebars
@@ -1,10 +1,17 @@
- - {{#link-to 'group.index' model}}{{i18n groups.posts}}{{/link-to}}
- - {{#link-to 'group.members' model}}{{i18n groups.members}}{{/link-to}}
-
-
+
+ {{#link-to 'group.index' model}}{{i18n groups.posts}}
+ ({{postsCount}})
+ {{/link-to}}
+
+
+ {{#link-to 'group.members' model}}{{i18n groups.members}}
+ {{/link-to}}
+
+
+
diff --git a/app/controllers/groups_controller.rb b/app/controllers/groups_controller.rb
index c9fc37c5062..a57a5f2354d 100644
--- a/app/controllers/groups_controller.rb
+++ b/app/controllers/groups_controller.rb
@@ -6,10 +6,16 @@ class GroupsController < ApplicationController
render_serialized(group, BasicGroupSerializer)
end
+ def posts_count
+ group = Group.where(name: params.require(:group_id)).first
+ guardian.ensure_can_see!(group)
+ render json: {posts_count: group.posts_for(guardian).count}
+ end
+
def posts
group = Group.where(name: params.require(:group_id)).first
guardian.ensure_can_see!(group)
- posts = group.posts_for(guardian, params[:before_post_id])
+ posts = group.posts_for(guardian, params[:before_post_id]).limit(20)
render_serialized posts.to_a, GroupPostSerializer
end
diff --git a/app/models/group.rb b/app/models/group.rb
index d2f6cfb0d0e..52309ac581a 100644
--- a/app/models/group.rb
+++ b/app/models/group.rb
@@ -31,7 +31,7 @@ class Group < ActiveRecord::Base
validate :alias_level, inclusion: { in: ALIAS_LEVELS.values}
- def posts_for(guardian, before_post_id)
+ def posts_for(guardian, before_post_id=nil)
user_ids = group_users.map {|gu| gu.user_id}
result = Post.where(user_id: user_ids).includes(:user, :topic).references(:posts, :topics)
result = result.where('topics.archetype <> ?', Archetype.private_message)
@@ -46,7 +46,7 @@ class Group < ActiveRecord::Base
end
result = result.where('posts.id < ?', before_post_id) if before_post_id
- result.order('posts.created_at desc').limit(20)
+ result.order('posts.created_at desc')
end
def self.trust_group_ids
diff --git a/config/routes.rb b/config/routes.rb
index 4235cfbb32f..5e219b0230a 100644
--- a/config/routes.rb
+++ b/config/routes.rb
@@ -167,6 +167,7 @@ Discourse::Application.routes.draw do
resources :groups do
get 'members'
get 'posts'
+ get 'posts_count'
end
resources :posts do
diff --git a/spec/controllers/groups_controller_spec.rb b/spec/controllers/groups_controller_spec.rb
index ec217fb7151..d6c9c3704de 100644
--- a/spec/controllers/groups_controller_spec.rb
+++ b/spec/controllers/groups_controller_spec.rb
@@ -18,6 +18,21 @@ describe GroupsController do
end
end
+ describe "posts_count" do
+ it "ensures the group can be seen" do
+ Guardian.any_instance.expects(:can_see?).with(group).returns(false)
+ xhr :get, :posts_count, group_id: group.name
+ response.should_not be_success
+ end
+
+ it "performs the query and responds with JSON" do
+ Guardian.any_instance.expects(:can_see?).with(group).returns(true)
+ Group.any_instance.expects(:posts_for).returns(Group.none)
+ xhr :get, :posts_count, group_id: group.name
+ response.should be_success
+ end
+ end
+
describe "posts" do
it "ensures the group can be seen" do
Guardian.any_instance.expects(:can_see?).with(group).returns(false)
@@ -27,7 +42,7 @@ describe GroupsController do
it "calls `posts_for` and responds with JSON" do
Guardian.any_instance.expects(:can_see?).with(group).returns(true)
- Group.any_instance.expects(:posts_for).returns([])
+ Group.any_instance.expects(:posts_for).returns(Group.none)
xhr :get, :posts, group_id: group.name
response.should be_success
end