You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

51 lines
1.5 KiB

  1. # frozen_string_literal: true
  2. # == Schema Information
  3. #
  4. # Table name: favourites
  5. #
  6. # id :bigint(8) not null, primary key
  7. # created_at :datetime not null
  8. # updated_at :datetime not null
  9. # account_id :bigint(8) not null
  10. # status_id :bigint(8) not null
  11. #
  12. class Favourite < ApplicationRecord
  13. include Paginable
  14. update_index('statuses#status', :status) if Chewy.enabled?
  15. belongs_to :account, inverse_of: :favourites
  16. belongs_to :status, inverse_of: :favourites
  17. has_one :notification, as: :activity, dependent: :destroy
  18. validates :status_id, uniqueness: { scope: :account_id }
  19. before_validation do
  20. self.status = status.reblog if status&.reblog?
  21. end
  22. after_create :increment_cache_counters
  23. after_destroy :decrement_cache_counters
  24. private
  25. def increment_cache_counters
  26. if association(:status).loaded?
  27. status.update_attribute(:favourites_count, status.favourites_count + 1)
  28. else
  29. Status.where(id: status_id).update_all('favourites_count = COALESCE(favourites_count, 0) + 1')
  30. end
  31. end
  32. def decrement_cache_counters
  33. return if association(:status).loaded? && (status.marked_for_destruction? || status.marked_for_mass_destruction?)
  34. if association(:status).loaded?
  35. status.update_attribute(:favourites_count, [status.favourites_count - 1, 0].max)
  36. else
  37. Status.where(id: status_id).update_all('favourites_count = GREATEST(COALESCE(favourites_count, 0) - 1, 0)')
  38. end
  39. end
  40. end