tags: update category cache whenever category changes.
Do `update_category_cache_for_all` in a callback instead of calling it manually everywhere.
This commit is contained in:
@@ -15,6 +15,8 @@ class Tag < ApplicationRecord
|
||||
validates :name, uniqueness: true, tag_name: true, on: :create
|
||||
validates_inclusion_of :category, in: TagCategory.category_ids
|
||||
|
||||
after_save :update_category_cache_for_all, if: :category_changed?
|
||||
|
||||
module ApiMethods
|
||||
def to_legacy_json
|
||||
return {
|
||||
@@ -221,8 +223,7 @@ class Tag < ApplicationRecord
|
||||
tag.update_category_cache
|
||||
|
||||
if category_id != tag.category && !tag.is_locked? && ((CurrentUser.is_builder? && tag.post_count < 10_000) || tag.post_count <= 50)
|
||||
tag.update_column(:category, category_id)
|
||||
tag.update_category_cache_for_all
|
||||
tag.update_attribute(:category, category_id)
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
@@ -173,7 +173,6 @@ class TagAlias < TagRelationship
|
||||
def ensure_category_consistency
|
||||
if antecedent_tag.category != consequent_tag.category && antecedent_tag.category != Tag.categories.general
|
||||
consequent_tag.update_attribute(:category, antecedent_tag.category)
|
||||
consequent_tag.update_category_cache_for_all
|
||||
end
|
||||
|
||||
true
|
||||
|
||||
Reference in New Issue
Block a user