Standardize it so that all fields of type `text` are searchable with `search[<field>_matches]`. Before, the `<field>_matches` param was handled manually and some fields were left out or handled inconsistently. Now it applies to all columns of type `text`. This does a full-text search on the field, so for example, searching `/artist_commentaries?search[translated_description_matches]=smiling` will match translated commentaries containing either the word "smiling", "smiles", "smiled", or "smile". Note that this only applies to columns defined as type `text`, not to columns defined as `character varying`. The difference is that `text` is used for fields containing free-form natural language, such as comments, notes, forum posts, wiki pages, pool descriptions, etc, while `character varying` is used for short strings not containing free-form language, such as tag names, wiki page titles, urls, status fields, etc. API changes: * Add the `search[original_title_matches]`, `search[original_description_matches]`, `search[translated_title_matches]`, `search[translated_description_matches]` params to /artist_commentaries and /artist_commentary_versions. * Remove the `search[name_matches]` and `search[group_name_matches]` params from /artist_versions. * Remove the `search[title_matches]` param from /wiki_page_versions. * Change the `search[name_matches]` param on /pools, /favorite_groups, and /pool_versions to do a full-text search instead of a substring match.
70 lines
1.6 KiB
Ruby
70 lines
1.6 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class WikiPageVersion < ApplicationRecord
|
|
array_attribute :other_names
|
|
belongs_to :wiki_page
|
|
belongs_to_updater
|
|
belongs_to :tag, primary_key: :name, foreign_key: :title, optional: true
|
|
|
|
module SearchMethods
|
|
def search(params)
|
|
q = search_attributes(params, :id, :created_at, :updated_at, :title, :body, :other_names, :is_locked, :is_deleted, :updater, :wiki_page, :tag)
|
|
|
|
q.apply_default_order(params)
|
|
end
|
|
end
|
|
|
|
extend SearchMethods
|
|
|
|
def pretty_title
|
|
title.tr("_", " ")
|
|
end
|
|
|
|
def previous
|
|
@previous ||= WikiPageVersion.where("wiki_page_id = ? and id < ?", wiki_page_id, id).order("id desc").limit(1).to_a
|
|
@previous.first
|
|
end
|
|
|
|
def current
|
|
@current ||= WikiPageVersion.where(wiki_page_id: wiki_page_id).order("id desc").limit(1).to_a
|
|
@current.first
|
|
end
|
|
|
|
def self.status_fields
|
|
{
|
|
body: "Body",
|
|
other_names_changed: "OtherNames",
|
|
title: "Renamed",
|
|
was_deleted: "Deleted",
|
|
was_undeleted: "Undeleted",
|
|
}
|
|
end
|
|
|
|
def other_names_changed(type)
|
|
other = send(type)
|
|
((other_names - other.other_names) | (other.other_names - other_names)).length.positive?
|
|
end
|
|
|
|
def was_deleted(type)
|
|
other = send(type)
|
|
if type == "previous"
|
|
is_deleted && !other.is_deleted
|
|
else
|
|
!is_deleted && other.is_deleted
|
|
end
|
|
end
|
|
|
|
def was_undeleted(type)
|
|
other = send(type)
|
|
if type == "previous"
|
|
!is_deleted && other.is_deleted
|
|
else
|
|
is_deleted && !other.is_deleted
|
|
end
|
|
end
|
|
|
|
def self.available_includes
|
|
[:updater, :wiki_page, :tag]
|
|
end
|
|
end
|