Class: TaxonNameRelationship::OriginalCombination
- Inherits:
-
TaxonNameRelationship
- Object
- ActiveRecord::Base
- ApplicationRecord
- TaxonNameRelationship
- TaxonNameRelationship::OriginalCombination
- Defined in:
- app/models/taxon_name_relationship/original_combination.rb
Overview
Discussion (MJY, DD, 1/9/15) - It may be that this is semantically identical to Combination, and that we can infer the difference, i.e. functionality might get simplified/merged in the future.
Conclusion- remains fixed as is, Combination becomes citable, Protonym not.
Direct Known Subclasses
OriginalForm, OriginalGenus, OriginalSpecies, OriginalSubform, OriginalSubgenus, OriginalSubspecies, OriginalSubvariety, OriginalVariety
Defined Under Namespace
Classes: OriginalForm, OriginalGenus, OriginalSpecies, OriginalSubform, OriginalSubgenus, OriginalSubspecies, OriginalSubvariety, OriginalVariety
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
- .nomenclatural_priority ⇒ Object
-
.order_index ⇒ Object
TODO: Why only ICN?.
Instance Method Summary collapse
-
#applicable_rank ⇒ Symbol
The rank this relationship applies to as a symbol.
-
#combination_name(name_gender = nil) ⇒ Hash
Like { genus: [nil, ‘Aus’] … } the elements of the original combination name for this instance TODO: reconcile this with <>_name_elements for other combinations.
-
#monominal_prefix ⇒ String?
String should be included in Protonym::.
-
#object_status ⇒ Object
String the status inferred by the relationship to the object name.
- #object_status_connector_to_subject ⇒ Object
- #set_cached_names_for_taxon_names ⇒ Object protected
- #set_cached_original_combination ⇒ Object protected
-
#subject_status ⇒ Object
String the status inferred by the relationship to the subject name.
- #subject_status_connector_to_object ⇒ Object
- #sv_coordinated_taxa_object ⇒ Object protected
- #sv_validate_priority ⇒ Object protected
Methods inherited from TaxonNameRelationship
assignable, collect_descendants_and_itself_to_s, collect_descendants_to_s, collect_to_s, disjoint_object_classes, disjoint_subject_classes, disjoint_taxon_name_relationships, #dwc_occurrences, gbif_status_of_object, gbif_status_of_subject, #is_combination?, #is_invalidating?, nomen_uri, #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_coordinated_taxa, #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_required_relationships, #sv_validate_seniority, #type_class, #type_class=, #type_name, valid_object_ranks, 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
Class Method Details
.nomenclatural_priority ⇒ Object
13 14 15 |
# File 'app/models/taxon_name_relationship/original_combination.rb', line 13 def self.nomenclatural_priority :reverse end |
.order_index ⇒ Object
TODO: Why only ICN?
24 25 26 |
# File 'app/models/taxon_name_relationship/original_combination.rb', line 24 def self.order_index RANKS.index(::ICN_LOOKUP[self.name.demodulize.underscore.humanize.downcase.gsub('original ', '')]) end |
Instance Method Details
#applicable_rank ⇒ Symbol
Returns the rank this relationship applies to as a symbol.
19 20 21 |
# File 'app/models/taxon_name_relationship/original_combination.rb', line 19 def applicable_rank self.class.name.demodulize.underscore.humanize.downcase.gsub('original ', '').to_sym end |
#combination_name(name_gender = nil) ⇒ Hash
Returns like { genus: [nil, ‘Aus’] … } the elements of the original combination name for this instance TODO: reconcile this with <>_name_elements for other combinations. TODO: reconcile this format with that of full_name_hash.
63 64 65 66 67 68 69 70 71 72 73 74 75 |
# File 'app/models/taxon_name_relationship/original_combination.rb', line 63 def combination_name(name_gender = nil) elements = [monominal_prefix] if subject_taxon_name.verbatim_name.present? && name_gender.nil? elements.push subject_taxon_name.verbatim_name else elements.push subject_taxon_name.genderized_name(name_gender) end elements.push('[sic]') if subject_taxon_name.cached_misspelling elements[1] = "(#{elements[1]})" if applicable_rank == :subgenus return {applicable_rank => elements} end |
#monominal_prefix ⇒ String?
Returns String should be included in Protonym::.
54 55 56 |
# File 'app/models/taxon_name_relationship/original_combination.rb', line 54 def monominal_prefix nil end |
#object_status ⇒ Object
Returns String the status inferred by the relationship to the object name.
44 45 46 |
# File 'app/models/taxon_name_relationship/original_combination.rb', line 44 def object_status 'in original combination with ' + self.type_name.demodulize.underscore.humanize.downcase end |
#object_status_connector_to_subject ⇒ Object
28 29 30 |
# File 'app/models/taxon_name_relationship/original_combination.rb', line 28 def object_status_connector_to_subject ' with' end |
#set_cached_names_for_taxon_names ⇒ Object (protected)
84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 |
# File 'app/models/taxon_name_relationship/original_combination.rb', line 84 def set_cached_names_for_taxon_names begin TaxonName.transaction do t = object_taxon_name t.send(:set_cached) t.send(:set_cached_original_combination) t.send(:set_cached_original_combination_html) # t.update_columns( # cached_original_combination: t.get_original_combination, # cached_original_combination_html: t.get_original_combination_html, # # cached_author_year: t.get_author_and_year, # is done in set_cached!! # ) end end true end |
#set_cached_original_combination ⇒ Object (protected)
102 103 104 |
# File 'app/models/taxon_name_relationship/original_combination.rb', line 102 def set_cached_original_combination self.object_taxon_name.update_cached_original_combinations end |
#subject_status ⇒ Object
Returns String the status inferred by the relationship to the subject name.
34 35 36 |
# File 'app/models/taxon_name_relationship/original_combination.rb', line 34 def subject_status 'as ' + self.type_name.demodulize.underscore.humanize.downcase end |
#subject_status_connector_to_object ⇒ Object
38 39 40 |
# File 'app/models/taxon_name_relationship/original_combination.rb', line 38 def subject_status_connector_to_object ' of' end |
#sv_coordinated_taxa_object ⇒ Object (protected)
114 115 116 |
# File 'app/models/taxon_name_relationship/original_combination.rb', line 114 def sv_coordinated_taxa_object true # not applicable end |
#sv_validate_priority ⇒ Object (protected)
106 107 108 109 110 111 112 |
# File 'app/models/taxon_name_relationship/original_combination.rb', line 106 def sv_validate_priority date1 = self.subject_taxon_name.cached_nomenclature_date date2 = self.object_taxon_name.cached_nomenclature_date if !!date1 && !!date2 && date1 > date2 && subject_invalid_statuses.empty? soft_validations.add(:type, "#{self.subject_status.capitalize} #{self.subject_taxon_name.} should not be younger than #{self.object_taxon_name.}") end end |