Class: TaxonNameRelationship::CurrentCombination

Inherits:
TaxonNameRelationship show all
Defined in:
app/models/taxon_name_relationship/current_combination.rb

Overview

The class relationships used to indication current combination for plant names

Constant Summary

Constants included from SoftValidation

SoftValidation::ANCESTORS_WITH_SOFT_VALIDATIONS

Instance Attribute Summary

Attributes inherited from TaxonNameRelationship

#no_cached, #object_taxon_name_id, #project_id, #subject_taxon_name_id, #type

Class Method Summary collapse

Instance Method Summary collapse

Methods inherited from TaxonNameRelationship

collect_descendants_and_itself_to_s, collect_descendants_to_s, collect_to_s, descendants, disjoint_object_classes, disjoint_subject_classes, disjoint_taxon_name_relationships, gbif_status_of_object, gbif_status_of_subject, #is_combination?, #is_invalidating?, nomen_uri, nomenclatural_priority, #nomenclature_date, #object_properties, #object_status_tag, parent, required_taxon_name_relationships, #subject_and_object_in_same_project, #subject_invalid_statuses, #subject_properties, #subject_status_tag, #sv_fix_combination_relationship, #sv_fix_coordinated_object_taxa, #sv_fix_coordinated_subject_taxa, #sv_fix_not_specific_relationship, #sv_fix_objective_synonym_relationship, #sv_fix_subject_parent_update, #sv_not_specific_relationship, #sv_objective_synonym_relationship, #sv_specific_relationship, #sv_synonym_linked_to_valid_name, #sv_synonym_relationship, #sv_validate_disjoint_object, #sv_validate_disjoint_relationships, #sv_validate_disjoint_subject, #sv_validate_priority, #sv_validate_required_relationships, #sv_validate_seniority, #type_class, #type_class=, #type_name, valid_subject_ranks, #validate_object_and_subject_both_protonyms, #validate_object_must_equal_subject_for_uncertain_placement, #validate_rank_group, #validate_subject_and_object_are_not_identical, #validate_subject_and_object_ranks, #validate_subject_and_object_share_code, #validate_type, #validate_uniqueness_of_typification_object

Methods included from SoftValidation

#clear_soft_validations, #fix_for, #fix_soft_validations, #soft_fixed?, #soft_valid?, #soft_validate, #soft_validated?, #soft_validations, #soft_validators

Methods included from Shared::IsData

#errors_excepting, #full_error_messages_excepting, #identical, #is_community?, #is_destroyable?, #is_editable?, #is_in_use?, #is_in_users_projects?, #metamorphosize, #similar

Methods included from Shared::Notes

#concatenated_notes_string, #reject_notes

Methods included from Shared::Citations

#cited?, #mark_citations_for_destruction, #nomenclature_date, #origin_citation_source_id, #reject_citations, #requires_citation?, #sources_by_topic_id

Methods included from Housekeeping

#has_polymorphic_relationship?

Methods inherited from ApplicationRecord

transaction_with_retry

Class Method Details

.assignableObject



45
46
47
# File 'app/models/taxon_name_relationship/current_combination.rb', line 45

def self.assignable
  true
end

.assignment_methodObject



49
50
51
# File 'app/models/taxon_name_relationship/current_combination.rb', line 49

def self.assignment_method
  :combination_in_current_combination
end

.inverse_assignment_methodObject

as.



54
55
56
# File 'app/models/taxon_name_relationship/current_combination.rb', line 54

def self.inverse_assignment_method
  :protonym_in_current_combination
end

.valid_object_ranksObject

right_side



41
42
43
# File 'app/models/taxon_name_relationship/current_combination.rb', line 41

def self.valid_object_ranks
  GENUS_AND_SPECIES_RANK_NAMES_ICN
end

Instance Method Details

#object_is_protonymObject (protected)



76
77
78
# File 'app/models/taxon_name_relationship/current_combination.rb', line 76

def object_is_protonym
  errors.add(:object_taxon_name, 'Must be a protonym') if object_taxon_name.type == 'Combination'
end

#object_statusObject

Returns String the status inferred by the relationship to the object name.

Returns:

  • String the status inferred by the relationship to the object name



20
21
22
# File 'app/models/taxon_name_relationship/current_combination.rb', line 20

def object_status
  'has current combination '
end

#object_status_connector_to_subjectObject

Returns String.

Returns:

  • String



36
37
38
# File 'app/models/taxon_name_relationship/current_combination.rb', line 36

def object_status_connector_to_subject
  ' of'
end

#set_cached_names_for_taxon_namesObject (protected)



60
61
62
63
64
65
66
67
68
69
70
# File 'app/models/taxon_name_relationship/current_combination.rb', line 60

def set_cached_names_for_taxon_names
  begin
    TaxonName.transaction do
      t = object_taxon_name
      t.update_columns(
        cached_author_year: t.get_author_and_year,
        cached_nomenclature_date: t.nomenclature_date)
    end
  end
  true
end

#subject_is_combinationObject (protected)



72
73
74
# File 'app/models/taxon_name_relationship/current_combination.rb', line 72

def subject_is_combination
  errors.add(:subject_taxon_name, 'Must be a combination') unless subject_taxon_name.type == 'Combination'
end

#subject_statusObject

Returns String the status inferred by the relationship to the subject name.

Returns:

  • String the status inferred by the relationship to the subject name



26
27
28
# File 'app/models/taxon_name_relationship/current_combination.rb', line 26

def subject_status
  'current combination '
end

#subject_status_connector_to_objectObject

Returns String.

Returns:

  • String



31
32
33
# File 'app/models/taxon_name_relationship/current_combination.rb', line 31

def subject_status_connector_to_object
  ''
end

#sv_classification_matches_current_combinationObject (protected)



88
89
90
91
92
93
94
95
96
# File 'app/models/taxon_name_relationship/current_combination.rb', line 88

def sv_classification_matches_current_combination
  c = subject_taxon_name.protonyms_by_rank
  return true if c.empty? || c.count == 1
  t1 = c[c.keys[-2]]

  if object_taxon_name.parent_id != t1.id
    soft_validations.add(:object_taxon_name_id, "Current combination <i>#{subject_taxon_name.cached}</i> is conflicting with the parent of protonym <i>#{object_taxon_name.cached}</i>")
  end
end

#sv_coordinated_taxaObject (protected)



84
85
86
# File 'app/models/taxon_name_relationship/current_combination.rb', line 84

def sv_coordinated_taxa
  true # not applicable
end

#sv_coordinated_taxa_objectObject (protected)



80
81
82
# File 'app/models/taxon_name_relationship/current_combination.rb', line 80

def sv_coordinated_taxa_object
  true # not applicable
end