2016-11-16 02:56:29 +11:00
|
|
|
# frozen_string_literal: true
|
2017-05-02 10:14:47 +10:00
|
|
|
# == Schema Information
|
|
|
|
#
|
|
|
|
# Table name: favourites
|
|
|
|
#
|
2018-04-23 19:29:17 +10:00
|
|
|
# id :bigint(8) not null, primary key
|
2017-05-02 10:14:47 +10:00
|
|
|
# created_at :datetime not null
|
|
|
|
# updated_at :datetime not null
|
2018-04-23 19:29:17 +10:00
|
|
|
# account_id :bigint(8) not null
|
|
|
|
# status_id :bigint(8) not null
|
2017-05-02 10:14:47 +10:00
|
|
|
#
|
2016-11-16 02:56:29 +11:00
|
|
|
|
2016-08-18 01:56:23 +10:00
|
|
|
class Favourite < ApplicationRecord
|
2016-11-10 03:48:44 +11:00
|
|
|
include Paginable
|
2016-03-25 12:13:30 +11:00
|
|
|
|
2018-02-10 09:04:47 +11:00
|
|
|
update_index('statuses#status', :status) if Chewy.enabled?
|
|
|
|
|
2018-01-20 06:56:47 +11:00
|
|
|
belongs_to :account, inverse_of: :favourites
|
2018-05-30 10:50:23 +10:00
|
|
|
belongs_to :status, inverse_of: :favourites
|
2016-02-24 05:17:37 +11:00
|
|
|
|
2016-11-22 00:59:13 +11:00
|
|
|
has_one :notification, as: :activity, dependent: :destroy
|
|
|
|
|
2016-09-01 21:21:48 +10:00
|
|
|
validates :status_id, uniqueness: { scope: :account_id }
|
|
|
|
|
2016-12-22 21:34:05 +11:00
|
|
|
before_validation do
|
2017-04-17 23:54:33 +10:00
|
|
|
self.status = status.reblog if status&.reblog?
|
2016-12-22 21:34:05 +11:00
|
|
|
end
|
2018-05-30 10:50:23 +10:00
|
|
|
|
|
|
|
after_create :increment_cache_counters
|
|
|
|
after_destroy :decrement_cache_counters
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def increment_cache_counters
|
|
|
|
if association(:status).loaded?
|
|
|
|
status.update_attribute(:favourites_count, status.favourites_count + 1)
|
|
|
|
else
|
|
|
|
Status.where(id: status_id).update_all('favourites_count = COALESCE(favourites_count, 0) + 1')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def decrement_cache_counters
|
|
|
|
return if association(:status).loaded? && (status.marked_for_destruction? || status.marked_for_mass_destruction?)
|
|
|
|
|
|
|
|
if association(:status).loaded?
|
|
|
|
status.update_attribute(:favourites_count, [status.favourites_count - 1, 0].max)
|
|
|
|
else
|
|
|
|
Status.where(id: status_id).update_all('favourites_count = GREATEST(COALESCE(favourites_count, 0) - 1, 0)')
|
|
|
|
end
|
|
|
|
end
|
2016-02-24 05:17:37 +11:00
|
|
|
end
|