Module: MakeTaggable::Taggable::Collection::ClassMethods
- Defined in:
- lib/make_taggable/taggable/collection.rb
Instance Method Summary collapse
-
#all_tag_counts(options = {}) ⇒ Object
Calculate the tag counts for all tags.
-
#all_tags(options = {}) ⇒ Object
Calculate the tag names.
- #initialize_make_taggable_collection ⇒ Object
- #make_taggable(*args) ⇒ Object
- #safe_to_sql(relation) ⇒ Object
- #tag_counts_on(context, options = {}) ⇒ Object
- #tags_on(context, options = {}) ⇒ Object
Instance Method Details
#all_tag_counts(options = {}) ⇒ Object
Calculate the tag counts for all tags.
90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 |
# File 'lib/make_taggable/taggable/collection.rb', line 90 def all_tag_counts( = {}) = .dup .assert_valid_keys :start_at, :end_at, :conditions, :at_least, :at_most, :order, :limit, :on, :id ## Generate conditions: [:conditions] = sanitize_sql([:conditions]) if [:conditions] ## Generate scope: tagging_scope = MakeTaggable::Tagging.select("#{MakeTaggable::Tagging.table_name}.tag_id, COUNT(#{MakeTaggable::Tagging.table_name}.tag_id) AS tags_count") tag_scope = MakeTaggable::Tag.select("#{MakeTaggable::Tag.table_name}.*, #{MakeTaggable::Tagging.table_name}.tags_count AS count").order([:order]).limit([:limit]) # Current model is STI descendant, so add type checking to the join condition unless descends_from_active_record? taggable_join = "INNER JOIN #{table_name} ON #{table_name}.#{primary_key} = #{MakeTaggable::Tagging.table_name}.taggable_id" taggable_join << " AND #{table_name}.#{inheritance_column} = '#{name}'" tagging_scope = tagging_scope.joins(taggable_join) end # Conditions tagging_conditions().each { |condition| tagging_scope = tagging_scope.where(condition) } tag_scope = tag_scope.where([:conditions]) # GROUP BY and HAVING clauses: having = ["COUNT(#{MakeTaggable::Tagging.table_name}.tag_id) > 0"] having.push sanitize_sql(["COUNT(#{MakeTaggable::Tagging.table_name}.tag_id) >= ?", .delete(:at_least)]) if [:at_least] having.push sanitize_sql(["COUNT(#{MakeTaggable::Tagging.table_name}.tag_id) <= ?", .delete(:at_most)]) if [:at_most] having = having.compact.join(" AND ") group_columns = "#{MakeTaggable::Tagging.table_name}.tag_id" unless [:id] # Append the current scope to the scope, because we can't use scope(:find) in RoR 3.0 anymore: tagging_scope = generate_tagging_scope_in_clause(tagging_scope, table_name, primary_key) end tagging_scope = tagging_scope.group(group_columns).having(having) tag_scope_joins(tag_scope, tagging_scope) end |
#all_tags(options = {}) ⇒ Object
Calculate the tag names. To be used when you don’t need tag counts and want to avoid the taggable joins.
55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 |
# File 'lib/make_taggable/taggable/collection.rb', line 55 def ( = {}) = .dup .assert_valid_keys :start_at, :end_at, :conditions, :order, :limit, :on ## Generate conditions: [:conditions] = sanitize_sql([:conditions]) if [:conditions] ## Generate scope: tagging_scope = MakeTaggable::Tagging.select("#{MakeTaggable::Tagging.table_name}.tag_id") tag_scope = MakeTaggable::Tag.select("#{MakeTaggable::Tag.table_name}.*").order([:order]).limit([:limit]) # Joins and conditions tagging_conditions().each { |condition| tagging_scope = tagging_scope.where(condition) } tag_scope = tag_scope.where([:conditions]) group_columns = "#{MakeTaggable::Tagging.table_name}.tag_id" # Append the current scope to the scope, because we can't use scope(:find) in RoR 3.0 anymore: tagging_scope = generate_tagging_scope_in_clause(tagging_scope, table_name, primary_key).group(group_columns) tag_scope_joins(tag_scope, tagging_scope) end |
#initialize_make_taggable_collection ⇒ Object
9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 |
# File 'lib/make_taggable/taggable/collection.rb', line 9 def initialize_make_taggable_collection tag_types.map(&:to_s).each do |tag_type| class_eval <<-RUBY, __FILE__, __LINE__ + 1 def self.#{tag_type.singularize}_counts(options={}) tag_counts_on('#{tag_type}', options) end def #{tag_type.singularize}_counts(options = {}) tag_counts_on('#{tag_type}', options) end def top_#{tag_type}(limit = 10) tag_counts_on('#{tag_type}', order: 'count desc', limit: limit.to_i) end def self.top_#{tag_type}(limit = 10) tag_counts_on('#{tag_type}', order: 'count desc', limit: limit.to_i) end RUBY end end |
#make_taggable(*args) ⇒ Object
31 32 33 34 |
# File 'lib/make_taggable/taggable/collection.rb', line 31 def make_taggable(*args) super(*args) initialize_make_taggable_collection end |
#safe_to_sql(relation) ⇒ Object
130 131 132 |
# File 'lib/make_taggable/taggable/collection.rb', line 130 def safe_to_sql(relation) connection.respond_to?(:unprepared_statement) ? connection.unprepared_statement { relation.to_sql } : relation.to_sql end |
#tag_counts_on(context, options = {}) ⇒ Object
36 37 38 |
# File 'lib/make_taggable/taggable/collection.rb', line 36 def tag_counts_on(context, = {}) all_tag_counts(.merge({on: context.to_s})) end |
#tags_on(context, options = {}) ⇒ Object
40 41 42 |
# File 'lib/make_taggable/taggable/collection.rb', line 40 def (context, = {}) (.merge({on: context.to_s})) end |