Emi Matchu
d66f81c96b
This hasn't worked for a while anyway! Let's remove the bits of code where we deal with it, and the database field that signals it. (We also make a corresponding change in Impress 2020, so it doesn't crash trying to query based on the `prank` column.) I also ran this snippet to clear out all the Nebula stuff in the db: ```rb Color.transaction do nebula = Color.where(prank: true).find_by_name("Nebula") nebula.pet_types.includes(pet_states: :swf_assets).each do |pet_type| pet_type.pet_states.each do |pet_state| pet_state.parent_swf_asset_relationships.each do |psa| psa.swf_asset.destroy! psa.destroy! end pet_state.destroy! end pet_type.destroy! end nebula.destroy! end ```
38 lines
903 B
Ruby
38 lines
903 B
Ruby
class Color < ApplicationRecord
|
|
has_many :pet_types
|
|
|
|
scope :alphabetical, -> { order(:name) }
|
|
scope :basic, -> { where(basic: true) }
|
|
scope :standard, -> { where(standard: true) }
|
|
scope :nonstandard, -> { where(standard: false) }
|
|
|
|
validates :name, presence: true
|
|
|
|
def as_json(options={})
|
|
{id: id, name: name, human_name: human_name}
|
|
end
|
|
|
|
def human_name
|
|
if name
|
|
name.split(' ').map { |word| word.capitalize }.join(' ')
|
|
else
|
|
I18n.translate('colors.default_human_name')
|
|
end
|
|
end
|
|
|
|
def example_pet_type(preferred_species: nil)
|
|
preferred_species ||= Species.first
|
|
pet_types.order([Arel.sql("species_id = ? DESC"), preferred_species.id],
|
|
"species_id ASC").first
|
|
end
|
|
|
|
def default_gender_presentation
|
|
if name.downcase.ends_with? "boy"
|
|
:masc
|
|
elsif name.downcase.ends_with? "girl"
|
|
:fem
|
|
else
|
|
nil
|
|
end
|
|
end
|
|
end
|