List subcategories on categories page

This commit is contained in:
Robin Ward 2013-10-31 18:02:24 -04:00
parent 5a78c1cb34
commit b93ca1089e
9 changed files with 70 additions and 7 deletions

View File

@ -34,6 +34,10 @@ Discourse.CategoryList.reopenClass({
c.parentCategory = list.findBy('id', c.parent_category_id); c.parentCategory = list.findBy('id', c.parent_category_id);
} }
if (c.subcategory_ids) {
c.subcategories = c.subcategory_ids.map(function(scid) { return list.findBy('id', parseInt(scid, 10)); });
}
if (c.featured_user_ids) { if (c.featured_user_ids) {
c.featured_users = c.featured_user_ids.map(function(u) { c.featured_users = c.featured_user_ids.map(function(u) {
return users[u]; return users[u];

View File

@ -26,7 +26,7 @@ Discourse.ListCategoriesRoute = Discourse.Route.extend({
model: function() { model: function() {
var listTopicsController = this.controllerFor('listTopics'); var listTopicsController = this.controllerFor('listTopics');
if (listTopicsController) listTopicsController.set('content', null); if (listTopicsController) { listTopicsController.set('content', null); }
return this.controllerFor('list').load('categories'); return this.controllerFor('list').load('categories');
}, },

View File

@ -56,6 +56,19 @@
</tr> </tr>
{{/each}} {{/each}}
{{#if subcategories}}
<tr>
<td>
<div class='subcategories'>
{{i18n categories.subcategories}}
{{#each subcategory in subcategories}}
{{categoryLink subcategory}}
{{/each}}
</div>
</td>
</tr>
{{/if}}
</table> </table>
<footer class="clearfix"> <footer class="clearfix">
<figure title="{{i18n year_desc}}">{{number topics_year}} <figcaption>{{i18n category.this_year}}</figcaption></figure> <figure title="{{i18n year_desc}}">{{number topics_year}} <figcaption>{{i18n category.this_year}}</figcaption></figure>

View File

@ -37,6 +37,15 @@
{{{description_excerpt}}} {{{description_excerpt}}}
</div> </div>
{{/if}} {{/if}}
{{#if subcategories}}
<div class='subcategories'>
{{i18n categories.subcategories}}
{{#each subcategory in subcategories}}
{{categoryLink subcategory}}
{{/each}}
</div>
{{/if}}
</td> </td>
<td class='num'>{{number topic_count}}</td> <td class='num'>{{number topic_count}}</td>
<td class='num'>{{number post_count}}</td> <td class='num'>{{number post_count}}</td>

View File

@ -235,9 +235,23 @@
tbody td { tbody td {
padding-bottom: 20px; padding-bottom: 20px;
} }
td.category {
padding-top: 15px;
}
.category{ .category{
position: relative; position: relative;
width: 55%; width: 55%;
.subcategories {
margin-top: 10px;
.badge-category {
font-size: 12px;
padding: 4px;
}
}
.featured-users { .featured-users {
position: absolute; position: absolute;
right: 18px; right: 18px;
@ -287,7 +301,7 @@
#topic-list tbody tr:nth-child(even) { #topic-list tbody tr:nth-child(even) {
background-color: $white; background-color: $white;
} }
.badge-category { th .badge-category {
float: left; float: left;
margin: 1px 4px 0 0; margin: 1px 4px 0 0;
} }

View File

@ -75,7 +75,7 @@ class Category < ActiveRecord::Base
# permission is just used by serialization # permission is just used by serialization
# we may consider wrapping this in another spot # we may consider wrapping this in another spot
attr_accessor :displayable_topics, :permission attr_accessor :displayable_topics, :permission, :subcategory_ids
def self.scoped_to_permissions(guardian, permission_types) def self.scoped_to_permissions(guardian, permission_types)

View File

@ -61,6 +61,23 @@ class CategoryList
@categories = @categories.to_a @categories = @categories.to_a
subcategories = {}
to_delete = Set.new
@categories.each do |c|
if c.parent_category_id.present?
subcategories[c.parent_category_id] ||= []
subcategories[c.parent_category_id] << c.id
to_delete << c
end
end
if subcategories.present?
@categories.each do |c|
c.subcategory_ids = subcategories[c.id]
end
@categories.delete_if {|c| to_delete.include?(c) }
end
if latest_post_only? if latest_post_only?
@all_topics = [] @all_topics = []
@categories.each do |c| @categories.each do |c|

View File

@ -5,7 +5,8 @@ class CategoryDetailedSerializer < BasicCategorySerializer
:topics_month, :topics_month,
:topics_year, :topics_year,
:description_excerpt, :description_excerpt,
:is_uncategorized :is_uncategorized,
:subcategory_ids
has_many :featured_users, serializer: BasicUserSerializer has_many :featured_users, serializer: BasicUserSerializer
has_many :displayable_topics, serializer: ListableTopicSerializer, embed: :objects, key: :topics has_many :displayable_topics, serializer: ListableTopicSerializer, embed: :objects, key: :topics
@ -38,4 +39,8 @@ class CategoryDetailedSerializer < BasicCategorySerializer
PrettyText.excerpt(description,300) if description PrettyText.excerpt(description,300) if description
end end
def include_subcategory_ids?
subcategory_ids.present?
end
end end

View File

@ -192,6 +192,7 @@ en:
latest: "Latest" latest: "Latest"
latest_by: "latest by" latest_by: "latest by"
toggle_ordering: "toggle ordering control" toggle_ordering: "toggle ordering control"
subcategories: "Subcategories:"
user: user:
said: "{{username}} said:" said: "{{username}} said:"