57 lines
1.4 KiB
Ruby
57 lines
1.4 KiB
Ruby
class ArtistVersion < ApplicationRecord
|
|
array_attribute :urls
|
|
array_attribute :other_names
|
|
|
|
belongs_to_updater
|
|
belongs_to :artist
|
|
delegate :visible?, :to => :artist
|
|
|
|
module SearchMethods
|
|
def for_user(user_id)
|
|
where("updater_id = ?", user_id)
|
|
end
|
|
|
|
def updater_name(name)
|
|
where("updater_id = (select _.id from users _ where lower(_.name) = ?)", name.mb_chars.downcase)
|
|
end
|
|
|
|
def search(params)
|
|
q = super
|
|
|
|
if params[:name].present?
|
|
q = q.where("name like ? escape E'\\\\'", params[:name].to_escaped_for_sql_like)
|
|
end
|
|
|
|
if params[:updater_name].present?
|
|
q = q.updater_name(params[:updater_name])
|
|
end
|
|
|
|
if params[:updater_id].present?
|
|
q = q.where(updater_id: params[:updater_id].split(",").map(&:to_i))
|
|
end
|
|
|
|
if params[:artist_id].present?
|
|
q = q.where(artist_id: params[:artist_id].split(",").map(&:to_i))
|
|
end
|
|
|
|
q = q.attribute_matches(:is_active, params[:is_active])
|
|
q = q.attribute_matches(:is_banned, params[:is_banned])
|
|
|
|
params[:order] ||= params.delete(:sort)
|
|
if params[:order] == "name"
|
|
q = q.order("artist_versions.name").default_order
|
|
else
|
|
q = q.apply_default_order(params)
|
|
end
|
|
|
|
q
|
|
end
|
|
end
|
|
|
|
extend SearchMethods
|
|
|
|
def previous
|
|
ArtistVersion.where("artist_id = ? and created_at < ?", artist_id, created_at).order("created_at desc").first
|
|
end
|
|
end
|