WIP: Tags which are not allowed in a category showing in drop down.
This commit is contained in:
parent
323efcab71
commit
8fd0414cdf
|
@ -1,4 +1,5 @@
|
||||||
import { setting } from 'discourse/lib/computed';
|
import { setting } from 'discourse/lib/computed';
|
||||||
|
import computed from 'ember-addons/ember-computed-decorators';
|
||||||
|
|
||||||
export default Ember.Component.extend({
|
export default Ember.Component.extend({
|
||||||
classNameBindings: [':tag-drop', 'tag::no-category', 'tags:has-drop','categoryStyle','tagClass'],
|
classNameBindings: [':tag-drop', 'tag::no-category', 'tags:has-drop','categoryStyle','tagClass'],
|
||||||
|
@ -10,13 +11,14 @@ export default Ember.Component.extend({
|
||||||
|
|
||||||
tagName: 'li',
|
tagName: 'li',
|
||||||
|
|
||||||
tags: function() {
|
@computed('site.top_tags')
|
||||||
if (this.siteSettings.tags_sort_alphabetically && Discourse.Site.currentProp('top_tags')) {
|
tags(topTags) {
|
||||||
return Discourse.Site.currentProp('top_tags').sort();
|
if (this.siteSettings.tags_sort_alphabetically && topTags) {
|
||||||
|
return topTags.sort();
|
||||||
} else {
|
} else {
|
||||||
return Discourse.Site.currentProp('top_tags');
|
return topTags;
|
||||||
}
|
}
|
||||||
}.property('site.top_tags'),
|
},
|
||||||
|
|
||||||
iconClass: function() {
|
iconClass: function() {
|
||||||
if (this.get('expanded')) { return "fa fa-caret-down"; }
|
if (this.get('expanded')) { return "fa fa-caret-down"; }
|
||||||
|
|
|
@ -67,6 +67,9 @@ export default (filter, params) => {
|
||||||
return findTopicList(this.store, this.topicTrackingState, listFilter, findOpts, extras).then(list => {
|
return findTopicList(this.store, this.topicTrackingState, listFilter, findOpts, extras).then(list => {
|
||||||
TopicList.hideUniformCategory(list, category);
|
TopicList.hideUniformCategory(list, category);
|
||||||
this.set('topics', list);
|
this.set('topics', list);
|
||||||
|
if (list.topic_list.tags) {
|
||||||
|
Discourse.Site.currentProp('top_tags', list.topic_list.tags);
|
||||||
|
}
|
||||||
return list;
|
return list;
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
|
@ -23,10 +23,21 @@ class Tag < ActiveRecord::Base
|
||||||
.where("topics.category_id = ?", category.id)
|
.where("topics.category_id = ?", category.id)
|
||||||
end
|
end
|
||||||
|
|
||||||
def self.top_tags(limit_arg=nil)
|
def self.top_tags(limit_arg: nil, category: nil)
|
||||||
self.tags_by_count_query(limit: limit_arg || SiteSetting.max_tags_in_filter_list)
|
limit = limit_arg || SiteSetting.max_tags_in_filter_list
|
||||||
.count
|
|
||||||
.map {|name, count| name}
|
tags =
|
||||||
|
if category
|
||||||
|
self.category_tags_by_count_query(category, limit: limit)
|
||||||
|
else
|
||||||
|
self.tags_by_count_query(limit: limit)
|
||||||
|
end
|
||||||
|
|
||||||
|
tags.count.map {|name, _| name}
|
||||||
|
end
|
||||||
|
|
||||||
|
def self.include_tags?
|
||||||
|
SiteSetting.tagging_enabled && SiteSetting.show_filter_by_tag
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -13,7 +13,8 @@ class TopicList
|
||||||
:draft_sequence,
|
:draft_sequence,
|
||||||
:filter,
|
:filter,
|
||||||
:for_period,
|
:for_period,
|
||||||
:per_page
|
:per_page,
|
||||||
|
:tags
|
||||||
|
|
||||||
def initialize(filter, current_user, topics, opts=nil)
|
def initialize(filter, current_user, topics, opts=nil)
|
||||||
@filter = filter
|
@filter = filter
|
||||||
|
@ -21,17 +22,25 @@ class TopicList
|
||||||
@topics_input = topics
|
@topics_input = topics
|
||||||
@opts = opts || {}
|
@opts = opts || {}
|
||||||
|
|
||||||
|
if @opts[:category]
|
||||||
|
@category = Category.find_by(id: @opts[:category_id])
|
||||||
|
end
|
||||||
|
|
||||||
preloaded_custom_fields << DiscourseTagging::TAGS_FIELD_NAME if SiteSetting.tagging_enabled
|
preloaded_custom_fields << DiscourseTagging::TAGS_FIELD_NAME if SiteSetting.tagging_enabled
|
||||||
end
|
end
|
||||||
|
|
||||||
def preload_key
|
def tags
|
||||||
if @opts[:category]
|
opts = @category ? { category: @category } : {}
|
||||||
c = Category.where(id: @opts[:category_id]).first
|
Tag.top_tags(opts)
|
||||||
return "topic_list_#{c.url.sub(/^\//, '')}/l/#{@filter}" if c
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def preload_key
|
||||||
|
if @category
|
||||||
|
"topic_list_#{@category.url.sub(/^\//, '')}/l/#{@filter}"
|
||||||
|
else
|
||||||
"topic_list_#{@filter}"
|
"topic_list_#{@filter}"
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|
||||||
# Lazy initialization
|
# Lazy initialization
|
||||||
def topics
|
def topics
|
||||||
|
|
|
@ -84,7 +84,7 @@ class CategorySerializer < BasicCategorySerializer
|
||||||
end
|
end
|
||||||
|
|
||||||
def allowed_tags
|
def allowed_tags
|
||||||
object.tags.pluck(:name)
|
Tag.top_tags(category: object)
|
||||||
end
|
end
|
||||||
|
|
||||||
def include_allowed_tag_groups?
|
def include_allowed_tag_groups?
|
||||||
|
@ -94,5 +94,4 @@ class CategorySerializer < BasicCategorySerializer
|
||||||
def allowed_tag_groups
|
def allowed_tag_groups
|
||||||
object.tag_groups.pluck(:name)
|
object.tag_groups.pluck(:name)
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -98,15 +98,16 @@ class SiteSerializer < ApplicationSerializer
|
||||||
def include_tags_filter_regexp?
|
def include_tags_filter_regexp?
|
||||||
SiteSetting.tagging_enabled
|
SiteSetting.tagging_enabled
|
||||||
end
|
end
|
||||||
|
|
||||||
def tags_filter_regexp
|
def tags_filter_regexp
|
||||||
DiscourseTagging::TAGS_FILTER_REGEXP.source
|
DiscourseTagging::TAGS_FILTER_REGEXP.source
|
||||||
end
|
end
|
||||||
|
|
||||||
def include_top_tags?
|
def include_top_tags?
|
||||||
SiteSetting.tagging_enabled && SiteSetting.show_filter_by_tag
|
Tag.include_tags?
|
||||||
end
|
end
|
||||||
|
|
||||||
def top_tags
|
def top_tags
|
||||||
Tag.top_tags
|
Tag.top_tags
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -24,11 +24,6 @@ class TopicListSerializer < ApplicationSerializer
|
||||||
end
|
end
|
||||||
|
|
||||||
def include_tags?
|
def include_tags?
|
||||||
SiteSetting.tagging_enabled && SiteSetting.show_filter_by_tag
|
Tag.include_tags?
|
||||||
end
|
end
|
||||||
|
|
||||||
def tags
|
|
||||||
Tag.top_tags
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -9,7 +9,6 @@ require_dependency 'topic_query_sql'
|
||||||
require_dependency 'avatar_lookup'
|
require_dependency 'avatar_lookup'
|
||||||
|
|
||||||
class TopicQuery
|
class TopicQuery
|
||||||
# Could be rewritten to %i if Ruby 1.9 is no longer supported
|
|
||||||
VALID_OPTIONS = %i(except_topic_ids
|
VALID_OPTIONS = %i(except_topic_ids
|
||||||
exclude_category_ids
|
exclude_category_ids
|
||||||
limit
|
limit
|
||||||
|
@ -460,7 +459,6 @@ class TopicQuery
|
||||||
|
|
||||||
if @options[:tags] && @options[:tags].size > 0
|
if @options[:tags] && @options[:tags].size > 0
|
||||||
result = result.joins(:tags)
|
result = result.joins(:tags)
|
||||||
|
|
||||||
# ANY of the given tags:
|
# ANY of the given tags:
|
||||||
if @options[:tags][0].is_a?(Integer)
|
if @options[:tags][0].is_a?(Integer)
|
||||||
result = result.where("tags.id in (?)", @options[:tags])
|
result = result.where("tags.id in (?)", @options[:tags])
|
||||||
|
|
|
@ -36,4 +36,28 @@ describe TopicList do
|
||||||
expect(topic_list.preloaded_custom_fields).to eq(Set.new([DiscourseTagging::TAGS_FIELD_NAME]))
|
expect(topic_list.preloaded_custom_fields).to eq(Set.new([DiscourseTagging::TAGS_FIELD_NAME]))
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
describe '#tags' do
|
||||||
|
let(:tag) { Fabricate(:tag, topics: [topic]) }
|
||||||
|
let(:other_tag) { Fabricate(:tag, topics: [topic]) }
|
||||||
|
|
||||||
|
it 'should return the right tags' do
|
||||||
|
output = [tag.name, other_tag.name]
|
||||||
|
expect(topic_list.tags.sort).to eq(output.sort)
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'when topic list is filtered by category' do
|
||||||
|
let(:category) { Fabricate(:category) }
|
||||||
|
let(:topic) { Fabricate(:topic, category: category) }
|
||||||
|
let(:tag) { Fabricate(:tag, topics: [topic], categories: [category]) }
|
||||||
|
let(:topic_list) { TopicList.new('latest', topic.user, [topic], { category: category.id, category_id: category.id }) }
|
||||||
|
|
||||||
|
it 'should only return tags allowed in the category' do
|
||||||
|
other_tag
|
||||||
|
output = [tag.name]
|
||||||
|
|
||||||
|
expect(topic_list.tags).to eq(output)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in New Issue