2016-11-15 10:56:29 -05:00
|
|
|
# frozen_string_literal: true
|
2017-05-01 20:14:47 -04:00
|
|
|
# == Schema Information
|
|
|
|
#
|
|
|
|
# Table name: favourites
|
|
|
|
#
|
2018-04-23 05:29:17 -04:00
|
|
|
# id :bigint(8) not null, primary key
|
2017-05-01 20:14:47 -04:00
|
|
|
# created_at :datetime not null
|
|
|
|
# updated_at :datetime not null
|
2018-04-23 05:29:17 -04:00
|
|
|
# account_id :bigint(8) not null
|
|
|
|
# status_id :bigint(8) not null
|
2017-05-01 20:14:47 -04:00
|
|
|
#
|
2016-11-15 10:56:29 -05:00
|
|
|
|
2016-08-17 11:56:23 -04:00
|
|
|
class Favourite < ApplicationRecord
|
2016-11-09 11:48:44 -05:00
|
|
|
include Paginable
|
2016-03-24 21:13:30 -04:00
|
|
|
|
2019-09-30 19:19:11 -04:00
|
|
|
update_index('statuses#status', :status)
|
2018-02-09 17:04:47 -05:00
|
|
|
|
2018-01-19 14:56:47 -05:00
|
|
|
belongs_to :account, inverse_of: :favourites
|
2018-05-29 20:50:23 -04:00
|
|
|
belongs_to :status, inverse_of: :favourites
|
2016-02-23 13:17:37 -05:00
|
|
|
|
2016-11-21 08:59:13 -05:00
|
|
|
has_one :notification, as: :activity, dependent: :destroy
|
|
|
|
|
2016-09-01 07:21:48 -04:00
|
|
|
validates :status_id, uniqueness: { scope: :account_id }
|
|
|
|
|
2016-12-22 05:34:05 -05:00
|
|
|
before_validation do
|
2017-04-17 09:54:33 -04:00
|
|
|
self.status = status.reblog if status&.reblog?
|
2016-12-22 05:34:05 -05:00
|
|
|
end
|
2018-05-29 20:50:23 -04:00
|
|
|
|
|
|
|
after_create :increment_cache_counters
|
|
|
|
after_destroy :decrement_cache_counters
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def increment_cache_counters
|
2018-08-17 21:03:23 -04:00
|
|
|
status&.increment_count!(:favourites_count)
|
2018-05-29 20:50:23 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
def decrement_cache_counters
|
2020-12-22 11:13:55 -05:00
|
|
|
return if association(:status).loaded? && status.marked_for_destruction?
|
2018-08-17 21:03:23 -04:00
|
|
|
status&.decrement_count!(:favourites_count)
|
2018-05-29 20:50:23 -04:00
|
|
|
end
|
2016-02-23 13:17:37 -05:00
|
|
|
end
|