2019-01-25 21:53:06 +08:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
class SystemNotification < ApplicationRecord
|
2019-02-13 20:06:14 +08:00
|
|
|
include PgSearch
|
2019-02-15 20:07:29 +08:00
|
|
|
|
|
|
|
scope :modals, -> { select(:modal_title, :modal_body, :id) }
|
2019-02-13 20:06:14 +08:00
|
|
|
# Full text postgreSQL search configuration
|
|
|
|
pg_search_scope :search_notifications, against: %i(title description),
|
|
|
|
using: {
|
|
|
|
tsearch: {
|
|
|
|
dictionary: 'english'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
# ignoring: :accents
|
|
|
|
|
2019-01-25 21:53:06 +08:00
|
|
|
has_many :user_system_notifications
|
|
|
|
has_many :users, through: :user_system_notifications
|
|
|
|
|
|
|
|
validates :title, :modal_title, :modal_body, :description,
|
2019-01-31 15:53:02 +08:00
|
|
|
:source_created_at, :source_id, :last_time_changed_at,
|
2019-01-25 21:53:06 +08:00
|
|
|
presence: true
|
2019-02-13 20:06:14 +08:00
|
|
|
|
2019-02-20 23:05:15 +08:00
|
|
|
validates :title, :description, :modal_title,
|
2019-02-13 20:06:14 +08:00
|
|
|
length: { maximum: Constants::NAME_MAX_LENGTH }
|
|
|
|
|
2019-02-20 23:05:15 +08:00
|
|
|
validates :modal_body,
|
|
|
|
length: { maximum: Constants::RICH_TEXT_MAX_LENGTH }
|
|
|
|
|
2019-02-13 20:06:14 +08:00
|
|
|
def self.last_notifications(
|
|
|
|
user,
|
|
|
|
query = nil
|
|
|
|
)
|
2019-04-24 14:04:47 +08:00
|
|
|
notifications = order(created_at: :DESC)
|
2019-02-13 20:06:14 +08:00
|
|
|
notifications = notifications.search_notifications(query) if query.present?
|
|
|
|
notifications.joins(:user_system_notifications)
|
|
|
|
.where('user_system_notifications.user_id = ?', user.id)
|
|
|
|
.select(
|
|
|
|
'system_notifications.id',
|
|
|
|
:title,
|
|
|
|
:description,
|
|
|
|
:last_time_changed_at,
|
2019-04-24 14:04:47 +08:00
|
|
|
:created_at,
|
2019-02-15 20:07:29 +08:00
|
|
|
'user_system_notifications.seen_at',
|
|
|
|
'user_system_notifications.read_at'
|
2019-02-13 20:06:14 +08:00
|
|
|
)
|
|
|
|
end
|
2019-02-04 21:33:22 +08:00
|
|
|
|
|
|
|
def self.last_sync_timestamp
|
|
|
|
# If no notifications are present, the created_at of the
|
|
|
|
# first user is used as the "initial sync time-point"
|
|
|
|
SystemNotification
|
|
|
|
.order(last_time_changed_at: :desc)
|
|
|
|
.first&.last_time_changed_at&.to_i ||
|
2019-04-25 15:18:26 +08:00
|
|
|
User.order(created_at: :asc).first&.created_at&.to_i
|
2019-02-04 21:33:22 +08:00
|
|
|
end
|
2019-01-25 21:53:06 +08:00
|
|
|
end
|