Module: TaxonNamesHelper
- Defined in:
- app/helpers/taxon_names_helper.rb
Instance Method Summary collapse
- #ancestor_browse_taxon_name_link(taxon_name, path = :browse_nomenclature_task_path) ⇒ Object
- 
  
    
      #author_chart_data(author_data)  ⇒ Hash 
    
    
  
  
  
  
  
  
  
  
  
    Format author data for Chartkick column chart. 
- 
  
    
      #author_coauthorship_data(taxon_names)  ⇒ Hash 
    
    
  
  
  
  
  
  
  
  
  
    Calculate co-authorship relationships for Sankey diagram. 
- 
  
    
      #author_individual_chart_data(author_years)  ⇒ Array 
    
    
  
  
  
  
  
  
  
  
  
    Format individual author data for Chartkick column chart Scopes to min/max year observed per author. 
- #cached_classified_as_tag(taxon_name) ⇒ Object
- #current_author_year(taxon_name) ⇒ String
- 
  
    
      #defined_full_original_taxon_name_tag(taxon_name)  ⇒ String? 
    
    
  
  
  
  
  
  
  
  
  
    !! This is used in taxon_name attributes now! TODO: Refactor our logic for display contexts and value contexts to better reflect presence of data vs. 
- #descendant_browse_taxon_name_link(taxon_name, path = :browse_nomenclature_task_path) ⇒ Object
- #document_names_per_year(names) ⇒ Object
- #edit_original_combination_task_link(taxon_name) ⇒ Object
- #edit_taxon_name_link(taxon_name, target: nil) ⇒ Object
- 
  
    
      #edit_taxon_name_path_string(taxon_name)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    See #edit_object_path_string in navigation_helper.rb. 
- 
  
    
      #full_original_taxon_name_label(taxon_name)  ⇒ String 
    
    
  
  
  
  
  
  
  
  
  
    The name in original combination, with author year, without HTML. 
- 
  
    
      #full_original_taxon_name_tag(taxon_name)  ⇒ String 
    
    
  
  
  
  
  
  
  
  
  
    The name in original combination, with author year, with HTML. 
- 
  
    
      #full_taxon_name_tag(taxon_name)  ⇒ String 
    
    
  
  
  
  
  
  
  
  
  
    The current name/combination with author year, with HTML. 
- 
  
    
      #label_for_taxon_name(taxon_name)  ⇒ String 
    
    
  
  
  
  
  
  
  
  
  
    !! Unified deprecated taxon_name_name_string() here. 
- #next_sibling_browse_taxon_name_link(taxon_name, path = :browse_nomenclature_task_path) ⇒ Object
- 
  
    
      #original_author_year(taxon_name)  ⇒ String 
    
    
  
  
  
  
  
  
  
  
  
    Removes parens. 
- #original_taxon_name_link(taxon_name) ⇒ Object
- 
  
    
      #original_taxon_name_tag(taxon_name)  ⇒ String 
    
    
  
  
  
  
  
  
  
  
  
    The taxon name in original combination, without author year, with HTML. 
- 
  
    
      #parent_taxon_name_for_select(taxon_name)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    @taxon_name.parent.andand.display_name(:type => :for_select_list). 
- #previous_sibling_browse_taxon_name_link(taxon_name, path = :browse_nomenclature_task_path) ⇒ Object
- #rank_tag(taxon_name) ⇒ Object
- 
  
    
      #simple_hierarchy_tag(names, selected_names = nil)  ⇒ String 
    
    
  
  
  
  
  
  
  
  
  
    !! Does not try to sort names, works best in combination with ‘ancestrify: true` in ::Queries::TaxonNames::Filter TODO: there is some missalignment on the name matching, you’ll see some names that likely matched not linked. 
- 
  
    
      #summarize_authors_by_year(taxon_names)  ⇒ Hash 
    
    
  
  
  
  
  
  
  
  
  
    Summarize People instances through taxon_name_author roles per year. 
- 
  
    
      #taxon_name_autocomplete_selected_tag(taxon_name)  ⇒ String 
    
    
  
  
  
  
  
  
  
  
  
    No HTML inside <input>. 
- #taxon_name_autocomplete_tag(taxon_name, term) ⇒ Object
- #taxon_name_browse_link(taxon_name) ⇒ Object
- #taxon_name_decorator_status(taxon_name) ⇒ Object
- #taxon_name_for_select(taxon_name) ⇒ Object
- #taxon_name_gender_sentence_tag(taxon_name) ⇒ Object
- #taxon_name_inferred_combination_tag(taxon_name) ⇒ Object
- #taxon_name_inventory_stats(taxon_name) ⇒ Object
- #taxon_name_latinization_tag(taxon_name) ⇒ Object
- #taxon_name_link(taxon_name) ⇒ Object
- #taxon_name_link_path(taxon_name, path) ⇒ Object protected
- #taxon_name_original_combination_tag(taxon_name, css_class = [:feedback, 'feedback-notice', 'feedback-thin']) ⇒ Object
- #taxon_name_otus_links(taxon_name) ⇒ Object
- #taxon_name_parent_navigator_item_link(taxon_name, target = :taxon_name_path) ⇒ Object
- #taxon_name_parent_tag(taxon_name, css_class = [:feedback, 'feedback-secondary', 'feedback-thin']) ⇒ Object
- 
  
    
      #taxon_name_rank_select_tag(taxon_name: TaxonName.new, code: nil)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    TODO: Scope to code. 
- #taxon_name_rank_tag(taxon_name, css_class = [:feedback, 'feedback-info', 'feedback-thin']) ⇒ Object
- #taxon_name_short_status(taxon_name) ⇒ Object
- #taxon_name_short_status_label(taxon_name) ⇒ Object
- #taxon_name_status_label(taxon_name) ⇒ Object
- 
  
    
      #taxon_name_tag(taxon_name)  ⇒ String 
    
    
  
  
  
  
  
  
  
  
  
    The taxon name without author year, with HTML. 
- #taxon_name_type_short_tag(taxon_name) ⇒ Object
- #taxon_name_year_data_table(data, *attributes) ⇒ Object
- #taxon_names_by_year_count(names) ⇒ Object
- 
  
    
      #taxon_names_count_by_validity_and_year(scope = nil)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Perhaps a /lib/catalog method. 
- 
  
    
      #taxon_names_cumulative_count_by_validity_and_year(scope = nil)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Perhaps a /lib/catalog method. 
- #taxon_names_per_year(totals) ⇒ Object
- #taxon_names_search_form ⇒ Object
- #taxonomic_tree(taxon_name, include_ancestors = true, include_count = true) ⇒ Object
- #taxonomic_tree_ancestors(taxon_name, include_count) ⇒ Object
- #taxonomic_tree_descendants(taxon_name, include_count) ⇒ Object
- #taxonomic_tree_node(taxon_name, include_count) ⇒ Object
Instance Method Details
#ancestor_browse_taxon_name_link(taxon_name, path = :browse_nomenclature_task_path) ⇒ Object
| 320 321 322 323 324 325 326 327 328 329 | # File 'app/helpers/taxon_names_helper.rb', line 320 def ancestor_browse_taxon_name_link(taxon_name, path = :browse_nomenclature_task_path) text = 'Up' if taxon_name.ancestors.any? a = taxon_name.ancestors.first. text = object_tag(a) link_to(content_tag(:span, text, data: {icon: 'arrow-up'}, class: 'small-icon'), taxon_name_link_path(a, path), class: 'navigation-item', data: {arrow: 'ancestor'}) else content_tag(:div, content_tag(:span, text, class: 'small-icon', data: {icon: 'arrow-up'}), class: 'navigation-item disable') end end | 
#author_chart_data(author_data) ⇒ Hash
Format author data for Chartkick column chart
| 730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745 746 | # File 'app/helpers/taxon_names_helper.rb', line 730 def () = {} # Count unique authors per year .each do |person_id, | [:years].each_key do |year| [year] = ([year] || 0) + 1 end end # Return single series of unique author counts { data: [ { name: 'Unique Authors', data: } ] } end | 
#author_coauthorship_data(taxon_names) ⇒ Hash
Calculate co-authorship relationships for Sankey diagram
| 794 795 796 797 798 799 800 801 802 803 804 805 806 807 808 809 810 811 812 813 814 815 816 817 818 819 820 821 822 823 824 825 826 827 828 829 830 831 832 833 834 835 836 837 838 839 840 | # File 'app/helpers/taxon_names_helper.rb', line 794 def (taxon_names) = {} = {} # Find all taxon names with multiple authors taxon_names.left_joins(:taxon_name_authors).find_each do |taxon_name| = taxon_name..to_a next if .length < 2 # Store author names .each { || [.id] = .cached } # Count co-authorships (combinations of authors on same taxon name) .combination(2).each do |, | # Create consistent ordering for the pair source_id, target_id = [.id, .id].sort key = "#{source_id}-#{target_id}" [key] ||= { source_id: source_id, target_id: target_id, count: 0 } [key][:count] += 1 end end # Only include authors that have links = .values.flat_map { |link| [link[:source_id], link[:target_id]] }.uniq nodes_data = .select { |id, name| .include?(id) } # Create node array with indices for d3-sankey nodes = nodes_data.map.with_index { |(id, name), index| { id: index, name: name, person_id: id } } # Create id to index mapping id_to_index = {} nodes.each { |node| id_to_index[node[:person_id]] = node[:id] } # Convert links to use node indices links = .values.map do |link| { source: id_to_index[link[:source_id]], target: id_to_index[link[:target_id]], value: link[:count] } end { nodes: nodes, links: links } end | 
#author_individual_chart_data(author_years) ⇒ Array
Format individual author data for Chartkick column chart Scopes to min/max year observed per author
| 752 753 754 755 756 757 758 759 760 761 762 763 764 765 766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781 782 783 784 785 786 787 788 789 | # File 'app/helpers/taxon_names_helper.rb', line 752 def () return { data: [], width: '0px' } if .empty? valid_data = {} invalid_data = {} years = .keys.reject { |y| y == 'Unknown' }.sort min_year = years.min max_year = years.max if min_year && max_year (min_year..max_year).each do |year| if [year] valid_data[year] = [year][:valid] || 0 invalid_data[year] = [year][:invalid] || 0 else valid_data[year] = 0 invalid_data[year] = 0 end end end if ['Unknown'] valid_data['Unknown'] = ['Unknown'][:valid] || 0 invalid_data['Unknown'] = ['Unknown'][:invalid] || 0 end year_span = (max_year.to_i - min_year.to_i) chart_width = [120 + year_span * 20, 800].min { data: [ { name: 'Valid', data: valid_data }, { name: 'Invalid', data: invalid_data } ], width: "#{chart_width}px" } end | 
#cached_classified_as_tag(taxon_name) ⇒ Object
| 218 219 220 | # File 'app/helpers/taxon_names_helper.rb', line 218 def cached_classified_as_tag(taxon_name) taxon_name.cached_classified_as ? taxon_name.cached_classified_as.strip.html_safe : '' end | 
#current_author_year(taxon_name) ⇒ String
| 107 108 109 110 | # File 'app/helpers/taxon_names_helper.rb', line 107 def (taxon_name) return nil if taxon_name.nil? || taxon_name..nil? taxon_name. end | 
#defined_full_original_taxon_name_tag(taxon_name) ⇒ String?
!! This is used in taxon_name attributes now! TODO: Refactor our logic for display contexts and value contexts to better reflect presence of data vs. utility of report.
| 85 86 87 88 | # File 'app/helpers/taxon_names_helper.rb', line 85 def defined_full_original_taxon_name_tag(taxon_name) return nil if taxon_name.nil? || taxon_name.cached_original_combination_html.blank? full_original_taxon_name_tag(taxon_name) end | 
#descendant_browse_taxon_name_link(taxon_name, path = :browse_nomenclature_task_path) ⇒ Object
| 331 332 333 334 335 336 337 338 339 340 | # File 'app/helpers/taxon_names_helper.rb', line 331 def descendant_browse_taxon_name_link(taxon_name, path = :browse_nomenclature_task_path) text = 'Down' if taxon_name.descendants.unscope(:order).any? a = taxon_name.descendants.first. text = taxon_name_tag(a) link_to(content_tag(:span, text, data: {icon: 'arrow-down'}, class: 'small-icon'), taxon_name_link_path(a, path), class: 'navigation-item', data: {arrow: 'descendant'}) else content_tag(:div, content_tag(:span, text, class: 'small-icon', data: {icon: 'arrow-down'}), class: 'navigation-item disable') end end | 
#document_names_per_year(names) ⇒ Object
| 610 611 612 613 614 | # File 'app/helpers/taxon_names_helper.rb', line 610 def document_names_per_year(names) taxon_names_per_year( taxon_names_by_year_count(names) ) end | 
#edit_original_combination_task_link(taxon_name) ⇒ Object
| 272 273 274 | # File 'app/helpers/taxon_names_helper.rb', line 272 def edit_original_combination_task_link(taxon_name) link_to('Edit original combination', edit_protonym_original_combination_task_path(taxon_name)) if GENUS_AND_SPECIES_RANK_NAMES.include?(taxon_name.rank_string) end | 
#edit_taxon_name_link(taxon_name, target: nil) ⇒ Object
| 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 | # File 'app/helpers/taxon_names_helper.rb', line 287 def edit_taxon_name_link(taxon_name, target: nil) i = {'Combination': :combination, 'Protonym': :taxon_name}[taxon_name.type.to_sym] t = taxon_name. icon = content_tag(:span, '', data: { icon: 'edit' }, class: 'small-icon') case target when :edit_task path = case i when :taxon_name new_taxon_name_task_path(taxon_name_id: t.id) when :combination new_combination_task_path(taxon_name_id: t.id, literal: URI.encode_www_form_component(t.cached)) # only spaces should be an issue end link_to(safe_join([icon, 'Edit (task)'], ''), path, class: 'navigation-item', 'data-task' => 'new_taxon_name') else link_to(safe_join([icon, 'Edit'], ''), send("edit_#{i}_path}", taxon_name.), 'class' => 'navigation-item') end end | 
#edit_taxon_name_path_string(taxon_name) ⇒ Object
See #edit_object_path_string in navigation_helper.rb
| 277 278 279 280 281 282 283 284 285 | # File 'app/helpers/taxon_names_helper.rb', line 277 def edit_taxon_name_path_string(taxon_name) if taxon_name.type == 'Protonym' 'edit_taxon_name_path' elsif taxon_name.type == 'Combination' 'edit_combination_path' else nil end end | 
#full_original_taxon_name_label(taxon_name) ⇒ String
Returns the name in original combination, with author year, without HTML.
| 92 93 94 95 96 97 | # File 'app/helpers/taxon_names_helper.rb', line 92 def full_original_taxon_name_label(taxon_name) return nil if taxon_name.nil? || taxon_name.cached_original_combination.nil? [ taxon_name.cached_original_combination, taxon_name. ].compact.join(' ') end | 
#full_original_taxon_name_tag(taxon_name) ⇒ String
Returns the name in original combination, with author year, with HTML.
| 73 74 75 76 77 78 | # File 'app/helpers/taxon_names_helper.rb', line 73 def full_original_taxon_name_tag(taxon_name) return nil if taxon_name.nil? [ original_taxon_name_tag(taxon_name), (taxon_name) ].compact.join(' ').html_safe end | 
#full_taxon_name_tag(taxon_name) ⇒ String
Returns the current name/combination with author year, with HTML.
| 66 67 68 69 | # File 'app/helpers/taxon_names_helper.rb', line 66 def full_taxon_name_tag(taxon_name) return nil if taxon_name.nil? [taxon_name_tag(taxon_name), taxon_name.].compact.join(' ').html_safe end | 
#label_for_taxon_name(taxon_name) ⇒ String
!! Unified deprecated taxon_name_name_string() here
| 14 15 16 17 | # File 'app/helpers/taxon_names_helper.rb', line 14 def label_for_taxon_name(taxon_name) return nil if taxon_name.nil? [taxon_name.cached, taxon_name.].compact.join(' ') end | 
#next_sibling_browse_taxon_name_link(taxon_name, path = :browse_nomenclature_task_path) ⇒ Object
| 342 343 344 345 346 347 348 349 350 | # File 'app/helpers/taxon_names_helper.rb', line 342 def next_sibling_browse_taxon_name_link(taxon_name, path = :browse_nomenclature_task_path) text = 'Next' link_object = taxon_name.next_sibling if link_object.nil? content_tag(:div, content_tag(:span, text), class: 'navigation-item disable') else link_to(text, taxon_name_link_path(link_object, path), title: taxon_name_tag(link_object), class: 'navigation-item', data: { button: 'next' }) end end | 
#original_author_year(taxon_name) ⇒ String
Returns removes parens.
| 101 102 103 104 | # File 'app/helpers/taxon_names_helper.rb', line 101 def (taxon_name) return nil if taxon_name.nil? || taxon_name..nil? taxon_name. || '' end | 
#original_taxon_name_link(taxon_name) ⇒ Object
| 249 250 251 252 | # File 'app/helpers/taxon_names_helper.rb', line 249 def original_taxon_name_link(taxon_name) return nil if taxon_name.nil? [ link_to(original_taxon_name_tag(taxon_name).html_safe, browse_nomenclature_task_path(taxon_name_id: taxon_name.id)).html_safe, taxon_name.].compact.join(' ').html_safe end | 
#original_taxon_name_tag(taxon_name) ⇒ String
Returns the taxon name in original combination, without author year, with HTML.
| 55 56 57 58 59 60 61 62 | # File 'app/helpers/taxon_names_helper.rb', line 55 def original_taxon_name_tag(taxon_name) return nil if taxon_name.nil? if taxon_name.cached_original_combination_html.nil? taxon_name_tag(taxon_name) else taxon_name.cached_original_combination_html.html_safe end end | 
#parent_taxon_name_for_select(taxon_name) ⇒ Object
@taxon_name.parent.andand.display_name(:type => :for_select_list)
| 259 260 261 | # File 'app/helpers/taxon_names_helper.rb', line 259 def parent_taxon_name_for_select(taxon_name) taxon_name.parent ? taxon_name_for_select(taxon_name.parent) : nil end | 
#previous_sibling_browse_taxon_name_link(taxon_name, path = :browse_nomenclature_task_path) ⇒ Object
| 352 353 354 355 356 357 358 359 360 361 | # File 'app/helpers/taxon_names_helper.rb', line 352 def previous_sibling_browse_taxon_name_link(taxon_name, path = :browse_nomenclature_task_path) text = 'Previous' link_object = taxon_name.previous_sibling if link_object.nil? content_tag(:div, content_tag(:span, text), class: 'navigation-item disable') else link_to(text, taxon_name_link_path(link_object, path), class: 'navigation-item', data: { button: 'back' }) end end | 
#rank_tag(taxon_name) ⇒ Object
| 307 308 309 310 311 312 313 314 315 316 317 318 | # File 'app/helpers/taxon_names_helper.rb', line 307 def rank_tag(taxon_name) case taxon_name.type when 'Protonym' if taxon_name.rank_class taxon_name.rank.downcase else content_tag(:em, 'ERROR') end when 'Combination' content_tag(:em, 'Combination') end end | 
#simple_hierarchy_tag(names, selected_names = nil) ⇒ String
!! Does not try to sort names, works best in combination with ‘ancestrify: true` in ::Queries::TaxonNames::Filter TODO: there is some missalignment on the name matching, you’ll see some names that likely matched not linked.
| 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 | # File 'app/helpers/taxon_names_helper.rb', line 621 def simple_hierarchy_tag(names, selected_names = nil) match = [] if selected_names match = selected_names.select("CASE WHEN taxon_names.type = 'Protonym' THEN taxon_names.id ELSE taxon_names.cached_valid_taxon_name_id END as id").pluck(:id) end # taxon_names.cached as alias, \ objects = names.left_joins(:valid_taxon_name) .select("CASE WHEN taxon_names.type = 'Protonym' THEN taxon_names.id ELSE taxon_names.cached_valid_taxon_name_id END as id, \ CASE WHEN taxon_names.type = 'Protonym' THEN taxon_names.parent_id ELSE valid_taxon_names_taxon_names.parent_id END as parent_id, \ COALESCE(taxon_names.name, valid_taxon_names_taxon_names.name, valid_taxon_names_taxon_names.name, valid_taxon_Names_taxon_names.cached) as label") .order('parent_id, label') .distinct d = Utilities::Hierarchy.new(objects:, match:).to_a rows = [] d.each do |r| s = ' ' * r[3] * 10 # space a = (r[2] ? " [#{r[2]}]" : '') # alias if r[4] # matched rows.push s + link_to( tag.b(r[1] + a), browse_nomenclature_task_path(taxon_name_id: r[0])) else # unmatched rows.push s + r[1] + a end end rows.join('<br>').html_safe end | 
#summarize_authors_by_year(taxon_names) ⇒ Hash
Summarize People instances through taxon_name_author roles per year
| 701 702 703 704 705 706 707 708 709 710 711 712 713 714 715 716 717 718 719 720 721 722 723 724 725 | # File 'app/helpers/taxon_names_helper.rb', line 701 def (taxon_names) = {} taxon_names.left_joins(:taxon_name_authors).find_each do |taxon_name| year = taxon_name.cached_nomenclature_date&.year || 'Unknown' is_valid = taxon_name.cached_is_valid taxon_name..each do |person| next unless person = person.id [] ||= { name: person.cached, years: {} } [][:years][year] ||= { valid: 0, invalid: 0, total: 0 } if is_valid [][:years][year][:valid] += 1 else [][:years][year][:invalid] += 1 end [][:years][year][:total] += 1 end end end | 
#taxon_name_autocomplete_selected_tag(taxon_name) ⇒ String
Returns no HTML inside <input>.
| 34 35 36 | # File 'app/helpers/taxon_names_helper.rb', line 34 def taxon_name_autocomplete_selected_tag(taxon_name) label_for_taxon_name(taxon_name) end | 
#taxon_name_autocomplete_tag(taxon_name, term) ⇒ Object
| 19 20 21 22 23 24 25 26 27 28 29 30 | # File 'app/helpers/taxon_names_helper.rb', line 19 def taxon_name_autocomplete_tag(taxon_name, term) return nil if taxon_name.nil? klass = taxon_name.rank_class ? taxon_name.rank_class.nomenclatural_code : nil a = [ content_tag(:span, mark_tag(taxon_name., term), class: :klass), taxon_name_rank_tag(taxon_name), taxon_name_parent_tag(taxon_name), taxon_name_original_combination_tag(taxon_name), taxon_name_type_short_tag(taxon_name) # " [#{taxon_name.sml_t}]" ].compact.join(' ').html_safe end | 
#taxon_name_browse_link(taxon_name) ⇒ Object
| 232 233 234 235 | # File 'app/helpers/taxon_names_helper.rb', line 232 def taxon_name_browse_link(taxon_name) return nil if taxon_name.nil? [ link_to(taxon_name_tag(taxon_name), browse_nomenclature_task_path(taxon_name_id: taxon_name.id)).html_safe, taxon_name.].compact.join(' ').html_safe end | 
#taxon_name_decorator_status(taxon_name) ⇒ Object
| 196 197 198 199 200 201 202 | # File 'app/helpers/taxon_names_helper.rb', line 196 def taxon_name_decorator_status(taxon_name) return nil if taxon_name.nil? taxon_name.taxon_name_classifications .where(taxon_name_classifications: {type: TAXON_NAME_CLASSIFICATIONS_FOR_DECORATION}) .select('taxon_name_classifications.type') .map{|a| a.type.demodulize.underscore.gsub(/(\d+)/, ' \1').gsub('_', ' ').capitalize} end | 
#taxon_name_for_select(taxon_name) ⇒ Object
| 254 255 256 | # File 'app/helpers/taxon_names_helper.rb', line 254 def taxon_name_for_select(taxon_name) taxon_name.name if taxon_name end | 
#taxon_name_gender_sentence_tag(taxon_name) ⇒ Object
| 213 214 215 216 | # File 'app/helpers/taxon_names_helper.rb', line 213 def taxon_name_gender_sentence_tag(taxon_name) return nil if taxon_name.nil? "The name is #{taxon_name.cached_gender}." if taxon_name.cached_gender end | 
#taxon_name_inferred_combination_tag(taxon_name) ⇒ Object
| 204 205 206 207 208 209 210 211 | # File 'app/helpers/taxon_names_helper.rb', line 204 def taxon_name_inferred_combination_tag(taxon_name) return nil if taxon_name.nil? || taxon_name.is_combination? || taxon_name.is_valid? if taxon_name.is_protonym? return nil if taxon_name.cached_primary_homonym == taxon_name.cached_secondary_homonym end tag.span(tag.em('inferred combination'), class: :subtle) end | 
#taxon_name_inventory_stats(taxon_name) ⇒ Object
| 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 | # File 'app/helpers/taxon_names_helper.rb', line 376 def taxon_name_inventory_stats(taxon_name) # Code mostly by chatgpt 5 (with comment/naming revsisions) d = [] # Query 1. Get all ranks for ordering ranks = ::Queries::TaxonName::Filter .new(synonymify: true, descendants: false, taxon_name_id: taxon_name.id) .all .where(type: 'Protonym') .distinct .pluck(:rank_class) .compact .sort_by { |r| RANKS.index(r) || RANKS.length } return [] if ranks.empty? # Query 2. VALID valid = ::Queries::TaxonName::Filter.new( validity: true, descendants: false, taxon_name_id: taxon_name.id, taxon_name_type: 'Protonym' ).all valid_by_rank = valid .group('rank_class') .count # Query 3. VALID FOSSILS valid_fossil_names_by_rank = valid .joins(:taxon_name_classifications) .where(taxon_name_classifications: { type: TAXON_NAME_CLASSIFICATIONS_FOR_FOSSILS }) .group('rank_class') .count # Query 4. INVALID invalid_scope = ::Queries::TaxonName::Filter.new( descendants: false, synonymify: true, taxon_name_id: taxon_name.id, taxon_name_type: 'Protonym' ).all.that_is_invalid # Count invalid names at the rank of their valid name. invalid_by_rank = TaxonName .from("(#{invalid_scope.to_sql}) invalid") .joins('JOIN taxon_names valid ON valid.id = invalid.cached_valid_taxon_name_id') .group('valid.rank_class') .count # Query 5: Coordinatified OTU counts # In brief: Let S be the subtree of taxon_name. # 1) To each name in S, assign the rank of its valid name (may be itself). # 2) Coordinatify all otus corresponding to S (expand in both directions # from S via valid-name-of/invalid-name-of name in S). # 3) Join 2) to 1) via the expansion described in 2). # 4) Group that join by the valid rank assigned to elements of S in 1). # 5) Count by that valid rank. base_scope = ::Queries::TaxonName::Filter.new( descendants: false, taxon_name_id: taxon_name.id, taxon_name_type: 'Protonym' ).all # Count invalid names with their valid name's rank. valid_rank = TaxonName .from(base_scope, :tn) .joins('LEFT JOIN taxon_names valid ON valid.id = tn.cached_valid_taxon_name_id') .select( 'tn.id, COALESCE(valid.rank_class, tn.rank_class) AS valid_rank, tn.cached_is_valid'.squish ) otus_scope = ::Otu.where(taxon_name_id: valid_rank.except(:select).select('tn.id')) # This is a little janky, but it's what allows us to avoid an extra query # (and it gives project_id context). otus_coordinatified = ::Queries::Otu::Filter.new({}).coordinatify_result(otus_scope) rows = TaxonName .with(valid_rank:) .from(otus_coordinatified, :o) .joins('JOIN taxon_names tn ON tn.id = o.taxon_name_id') .joins('JOIN valid_rank vr ON tn.id = vr.id OR tn.cached_valid_taxon_name_id = vr.id') .group('vr.valid_rank') .pluck('vr.valid_rank', Arel.sql('COUNT(DISTINCT o.id)')) otu_by_rank = rows.each_with_object({}) { |(rank, cnt), h| h[rank] = cnt.to_i } # Stitch results per rank ranks.each do |rank_class| n = rank_class.safe_constantize.rank_name.to_sym valid = valid_by_rank[rank_class] || 0 valid_fossil = valid_fossil_names_by_rank[rank_class] || 0 invalid = invalid_by_rank[rank_class] || 0 taxa = otu_by_rank[rank_class] || 0 d << { rank: n, taxa: taxa, names: { valid: valid, valid_fossil: valid_fossil, valid_extant: valid - valid_fossil, invalid: invalid } } end d end | 
#taxon_name_latinization_tag(taxon_name) ⇒ Object
| 222 223 224 225 | # File 'app/helpers/taxon_names_helper.rb', line 222 def taxon_name_latinization_tag(taxon_name) list = taxon_name.taxon_name_classifications.with_type_array(LATINIZED_TAXON_NAME_CLASSIFICATION_NAMES).map(&:classification_label) content_tag(:span, "The word \"#{taxon_name.name}\" has the following Latin-based classifications: #{list.to_sentence}.", class: 'history__latinized_classifications') if list.any? end | 
#taxon_name_link(taxon_name) ⇒ Object
| 227 228 229 230 | # File 'app/helpers/taxon_names_helper.rb', line 227 def taxon_name_link(taxon_name) return nil if taxon_name.nil? link_to(taxon_name_tag(taxon_name), taxon_name.).html_safe end | 
#taxon_name_link_path(taxon_name, path) ⇒ Object (protected)
| 844 845 846 847 848 849 850 | # File 'app/helpers/taxon_names_helper.rb', line 844 def taxon_name_link_path(taxon_name, path) if path == :taxon_name_path send(path, taxon_name) else send(path, taxon_name_id: taxon_name.id) end end | 
#taxon_name_original_combination_tag(taxon_name, css_class = [:feedback, 'feedback-notice', 'feedback-thin']) ⇒ Object
| 48 49 50 51 | # File 'app/helpers/taxon_names_helper.rb', line 48 def taxon_name_original_combination_tag(taxon_name, css_class = [:feedback, 'feedback-notice', 'feedback-thin'] ) return nil if taxon_name.nil? || taxon_name.cached_original_combination.blank? content_tag(:span, taxon_name.cached_original_combination, class: css_class) end | 
#taxon_name_otus_links(taxon_name) ⇒ Object
| 363 364 365 366 367 368 369 370 371 372 373 374 | # File 'app/helpers/taxon_names_helper.rb', line 363 def taxon_name_otus_links(taxon_name) if taxon_name.otus.load.any? ('The following Otus are linked to this name: ' + content_tag(:ul, class: 'no_bullets') do taxon_name.otus.each do |o| concat(content_tag(:li, otu_link(o) )) end end.html_safe).html_safe else content_tag(:em, 'There are no Otus linked to this name.') end end | 
#taxon_name_parent_navigator_item_link(taxon_name, target = :taxon_name_path) ⇒ Object
| 237 238 239 240 241 242 243 244 245 246 247 | # File 'app/helpers/taxon_names_helper.rb', line 237 def taxon_name_parent_navigator_item_link(taxon_name, target = :taxon_name_path) return nil if taxon_name.nil? || target.nil? if target case target.to_sym when :taxon_name_path link_to(taxon_name_tag(taxon_name), taxon_name.) else link_to(taxon_name_tag(taxon_name), send(target, {taxon_name_id: taxon_name.id})) end end end | 
#taxon_name_parent_tag(taxon_name, css_class = [:feedback, 'feedback-secondary', 'feedback-thin']) ⇒ Object
| 43 44 45 46 | # File 'app/helpers/taxon_names_helper.rb', line 43 def taxon_name_parent_tag(taxon_name, css_class = [:feedback, 'feedback-secondary', 'feedback-thin'] ) return nil if taxon_name.nil? || taxon_name.parent_id.nil? content_tag(:span, taxon_name_tag(taxon_name.parent).html_safe, class: css_class) end | 
#taxon_name_rank_select_tag(taxon_name: TaxonName.new, code: nil) ⇒ Object
TODO: Scope to code
| 264 265 266 | # File 'app/helpers/taxon_names_helper.rb', line 264 def taxon_name_rank_select_tag(taxon_name: TaxonName.new, code: nil) select(:taxon_name, :rank_class, (RANKS_SELECT_OPTIONS, selected: taxon_name.rank_string) ) end | 
#taxon_name_rank_tag(taxon_name, css_class = [:feedback, 'feedback-info', 'feedback-thin']) ⇒ Object
| 38 39 40 41 | # File 'app/helpers/taxon_names_helper.rb', line 38 def taxon_name_rank_tag(taxon_name, css_class = [:feedback, 'feedback-info', 'feedback-thin'] ) return nil if taxon_name.nil? content_tag(:span, taxon_name.rank || 'Combination', class: css_class) end | 
#taxon_name_short_status(taxon_name) ⇒ Object
| 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 | # File 'app/helpers/taxon_names_helper.rb', line 121 def taxon_name_short_status(taxon_name) if taxon_name.is_combination? n = taxon_name.finest_protonym s = ['This name is subsequent combination of'] if n.is_valid? s += [ link_to(original_taxon_name_tag(n), browse_nomenclature_task_path(taxon_name_id: n.id)), (n), ] else v = n.valid_taxon_name s += [ original_taxon_name_tag(n), (n), 'whose valid/accepted name is', link_to(taxon_name_tag(v), browse_nomenclature_task_path(taxon_name_id: v.id) ), v. ] end (s.join(' ') + '.').html_safe else if taxon_name.is_valid? # taxon_name.unavailable_or_invalid? content_tag(:span, safe_join([ content_tag(:span, '',data: {icon: :ok, status: :valid }), content_tag(:span, 'This name is valid/accepted.', data: { status: :valid }) ], ''), class: :brief_status, data: { status: :valid }) else if taxon_name.is_ambiguously_invalid? tag.span('This name is not valid/accepted.'.html_safe, class: :brief_status, data: {icon: :attention, status: :invalid}) else tag.span("This name is not valid/accepted.<br>The valid name is #{taxon_name_browse_link(taxon_name.valid_taxon_name)}.".html_safe, class: :brief_status, data: {icon: :attention, status: :invalid}) end end end end | 
#taxon_name_short_status_label(taxon_name) ⇒ Object
| 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 | # File 'app/helpers/taxon_names_helper.rb', line 162 def taxon_name_short_status_label(taxon_name) if taxon_name.is_combination? n = taxon_name.finest_protonym s = ['This name is subsequent combination of'] if n.is_valid? s += [ original_taxon_name_tag(n), (n), ] else v = n.valid_taxon_name s += [ original_taxon_name_tag(n), (n), 'whose valid/accepted name is', taxon_name_tag(v), v. ] end (s.join(' ') + '.') else if taxon_name.is_valid? # taxon_name.unavailable_or_invalid? 'This name is valid/accepted.' else if taxon_name.is_ambiguously_invalid? 'This name is not valid/accepted.' else "This name is not valid/accepted. The valid name is #{taxon_name.valid_taxon_name.cached}." end end end end | 
#taxon_name_status_label(taxon_name) ⇒ Object
| 158 159 160 | # File 'app/helpers/taxon_names_helper.rb', line 158 def taxon_name_status_label(taxon_name) taxon_name.combined_statuses.collect{|s| s}.join('; ') end | 
#taxon_name_tag(taxon_name) ⇒ String
Returns the taxon name without author year, with HTML.
| 5 6 7 8 9 | # File 'app/helpers/taxon_names_helper.rb', line 5 def taxon_name_tag(taxon_name) return nil if taxon_name.nil? return taxon_name.name if taxon_name.new_record? taxon_name.cached_html.try(:html_safe) || taxon_name.name end | 
#taxon_name_type_short_tag(taxon_name) ⇒ Object
| 112 113 114 115 116 117 118 119 | # File 'app/helpers/taxon_names_helper.rb', line 112 def taxon_name_type_short_tag(taxon_name) return nil if taxon_name.nil? if taxon_name.is_valid? '✓'.html_safe # checkmark else taxon_name.type == 'Combination' ? '[c]' : '❌'.html_safe # c or X end end | 
#taxon_name_year_data_table(data, *attributes) ⇒ Object
| 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 | # File 'app/helpers/taxon_names_helper.rb', line 522 def taxon_name_year_data_table(data, *attributes) a = data[:data].first b = data[:data].second content_tag(:table, safe_join([ tag.thead( tag.tr( safe_join [tag.th('Year'), tag.th(a[:name]), tag.th(b[:name])] ) ), safe_join((data[:metadata][:min_year]..data[:metadata][:max_year]).collect{|y| tag.tr( safe_join([ tag.td(y), tag.td(a[:data][y]), tag.td(b[:data][y]) ]) ) }) ]), *attributes ) end | 
#taxon_names_by_year_count(names) ⇒ Object
| 605 606 607 608 | # File 'app/helpers/taxon_names_helper.rb', line 605 def taxon_names_by_year_count(names) t = names.select('EXTRACT(YEAR FROM taxon_names.cached_nomenclature_date) AS year, COUNT(*) AS count').group('year').inject({}){|hsh, r| hsh[r.year.to_i] = r.count; hsh} t end | 
#taxon_names_count_by_validity_and_year(scope = nil) ⇒ Object
Perhaps a /lib/catalog method
| 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 | # File 'app/helpers/taxon_names_helper.rb', line 491 def taxon_names_count_by_validity_and_year(scope = nil) return {} if scope.nil? invalid = taxon_names_by_year_count(scope.that_is_invalid) valid = taxon_names_by_year_count(scope.that_is_valid) min = [invalid.keys.sort.first, invalid.keys.sort.first].compact.sort.first || 0 max = [valid.keys.sort.last, valid.keys.sort.last].compact.sort.first || 0 min = 1759 if min < 1759 max = Time.current.year if max > Time.current.year invalid_data = {} valid_data = {} (min..max).each do |y| invalid_data[y] = invalid[y].present? ? invalid[y].to_i : 0 valid_data[y] = valid[y].present? ? valid[y].to_i : 0 end return { metadata: { max_year: max, min_year: min, }, data: [ { name: 'Valid', data: valid_data}, { name: 'Invalid', data: invalid_data} ] } end | 
#taxon_names_cumulative_count_by_validity_and_year(scope = nil) ⇒ Object
Perhaps a /lib/catalog method
| 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585 586 587 | # File 'app/helpers/taxon_names_helper.rb', line 548 def taxon_names_cumulative_count_by_validity_and_year(scope = nil) return {} if scope.nil? invalid = taxon_names_by_year_count(scope.that_is_invalid) valid = taxon_names_by_year_count(scope.that_is_valid) min = [invalid.keys.sort.first, invalid.keys.sort.first].compact.sort.first || 0 max = [valid.keys.sort.last, valid.keys.sort.last].compact.sort.first || 0 min = 1759 if min < 1759 max = Time.current.year if max > Time.current.year invalid_data = {} valid_data = {} invalid_total = 0 valid_total = 0 (min..max).each do |y| i = ( invalid[y].present? ? invalid[y].to_i : 0 ) v = ( valid[y].present? ? valid[y].to_i : 0 ) invalid_total += i valid_total += v invalid_data[y] = invalid_total valid_data[y] = valid_total end return { metadata: { max_year: max, min_year: min, }, data: [ { name: 'Valid', data: valid_data}, { name: 'Invalid', data: invalid_data} ] } end | 
#taxon_names_per_year(totals) ⇒ Object
| 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603 | # File 'app/helpers/taxon_names_helper.rb', line 589 def taxon_names_per_year(totals) min = totals.keys.sort.first || 0 max = totals.keys.sort.last || 0 min = 1759 if min < 1759 max = Time.current.year if max > Time.current.year data = {} (min..max).each do |y| data[y] = totals[y].present? ? totals[y].to_i : 0 end data end | 
#taxon_names_search_form ⇒ Object
| 268 269 270 | # File 'app/helpers/taxon_names_helper.rb', line 268 def taxon_names_search_form render '/taxon_names/quick_search_form' end | 
#taxonomic_tree(taxon_name, include_ancestors = true, include_count = true) ⇒ Object
| 684 685 686 687 688 689 690 691 692 693 694 695 | # File 'app/helpers/taxon_names_helper.rb', line 684 def taxonomic_tree(taxon_name, include_ancestors = true, include_count = true) node = { taxon_name: taxonomic_tree_node(taxon_name, include_count), descendants: taxonomic_tree_descendants(taxon_name, include_count) } if (include_ancestors) node[:ancestors] = taxonomic_tree_ancestors(taxon_name, include_count) end node end | 
#taxonomic_tree_ancestors(taxon_name, include_count) ⇒ Object
| 672 673 674 | # File 'app/helpers/taxon_names_helper.rb', line 672 def taxonomic_tree_ancestors(taxon_name, include_count) taxon_name.ancestor_protonyms.map { |ancestor| taxonomic_tree_node(ancestor, include_count) } end | 
#taxonomic_tree_descendants(taxon_name, include_count) ⇒ Object
| 676 677 678 679 680 681 682 | # File 'app/helpers/taxon_names_helper.rb', line 676 def taxonomic_tree_descendants(taxon_name, include_count) taxon_name.children .order(:name) .where(type: 'Protonym') .sort_by { |a| [RANKS.index(a.rank_string), a.cached, a. || ''] } .map { |child| taxonomic_tree_node(child, include_count) } end | 
#taxonomic_tree_node(taxon_name, include_count) ⇒ Object
| 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 | # File 'app/helpers/taxon_names_helper.rb', line 654 def taxonomic_tree_node(taxon_name, include_count) node = { id: taxon_name.id, label: taxon_name., is_valid: taxon_name.cached_is_valid, cached_valid_taxon_name_id: taxon_name.cached_valid_taxon_name_id, synonyms: taxon_name_synonyms_list(taxon_name).map { |syn| taxon_name_synonym_li(syn) }, leaf_node: taxon_name.descendants.unscope(:order).empty? } if include_count node[:valid_descendants] = taxon_name.descendants.unscope(:order).that_is_valid.count node[:invalid_descendants] = taxon_name.descendants.unscope(:order).that_is_invalid.count end node end |