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
- #cached_classified_as_tag(taxon_name) ⇒ Object
- #current_author_year(taxon_name) ⇒ String
- #descendant_browse_taxon_name_link(taxon_name, path = :browse_nomenclature_task_path) ⇒ 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
-
#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_for_select(taxon_name) ⇒ Object
- #taxon_name_gender_sentence_tag(taxon_name) ⇒ Object
- #taxon_name_inferred_combination_tag(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_names_search_form ⇒ Object
Instance Method Details
#ancestor_browse_taxon_name_link(taxon_name, path = :browse_nomenclature_task_path) ⇒ Object
301 302 303 304 305 306 307 308 309 310 |
# File 'app/helpers/taxon_names_helper.rb', line 301 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 |
#cached_classified_as_tag(taxon_name) ⇒ Object
196 197 198 |
# File 'app/helpers/taxon_names_helper.rb', line 196 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
96 97 98 99 |
# File 'app/helpers/taxon_names_helper.rb', line 96 def (taxon_name) return nil if taxon_name.nil? || taxon_name..nil? taxon_name. end |
#descendant_browse_taxon_name_link(taxon_name, path = :browse_nomenclature_task_path) ⇒ Object
312 313 314 315 316 317 318 319 320 321 |
# File 'app/helpers/taxon_names_helper.rb', line 312 def descendant_browse_taxon_name_link(taxon_name, path = :browse_nomenclature_task_path) text = 'Down' if taxon_name.descendants.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 |
#edit_original_combination_task_link(taxon_name) ⇒ Object
250 251 252 |
# File 'app/helpers/taxon_names_helper.rb', line 250 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
265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 |
# File 'app/helpers/taxon_names_helper.rb', line 265 def edit_taxon_name_link(taxon_name, target: nil) i = {'Combination': :combination, 'Protonym': :taxon_name}[taxon_name.type.to_sym] t = taxon_name. 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( content_tag( :span, 'Edit (task)', 'data-icon' => 'edit', class: 'small-icon' ), path, class: 'navigation-item', 'data-task' => 'new_taxon_name') else link_to(content_tag(:span, 'Edit', 'data-icon' => 'edit', 'class' => 'small-icon'), 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
255 256 257 258 259 260 261 262 263 |
# File 'app/helpers/taxon_names_helper.rb', line 255 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.
81 82 83 84 85 86 |
# File 'app/helpers/taxon_names_helper.rb', line 81 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.
72 73 74 75 76 77 |
# File 'app/helpers/taxon_names_helper.rb', line 72 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.
65 66 67 68 |
# File 'app/helpers/taxon_names_helper.rb', line 65 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
323 324 325 326 327 328 329 330 331 |
# File 'app/helpers/taxon_names_helper.rb', line 323 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.
90 91 92 93 |
# File 'app/helpers/taxon_names_helper.rb', line 90 def (taxon_name) return nil if taxon_name.nil? || taxon_name..nil? taxon_name. || '' end |
#original_taxon_name_link(taxon_name) ⇒ Object
227 228 229 230 |
# File 'app/helpers/taxon_names_helper.rb', line 227 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.
54 55 56 57 58 59 60 61 |
# File 'app/helpers/taxon_names_helper.rb', line 54 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)
237 238 239 |
# File 'app/helpers/taxon_names_helper.rb', line 237 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
333 334 335 336 337 338 339 340 341 342 |
# File 'app/helpers/taxon_names_helper.rb', line 333 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
288 289 290 291 292 293 294 295 296 297 298 299 |
# File 'app/helpers/taxon_names_helper.rb', line 288 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 |
#taxon_name_autocomplete_selected_tag(taxon_name) ⇒ String
Returns no HTML inside <input>.
33 34 35 |
# File 'app/helpers/taxon_names_helper.rb', line 33 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 |
# 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) ].compact.join(' ').html_safe end |
#taxon_name_browse_link(taxon_name) ⇒ Object
210 211 212 213 |
# File 'app/helpers/taxon_names_helper.rb', line 210 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_for_select(taxon_name) ⇒ Object
232 233 234 |
# File 'app/helpers/taxon_names_helper.rb', line 232 def taxon_name_for_select(taxon_name) taxon_name.name if taxon_name end |
#taxon_name_gender_sentence_tag(taxon_name) ⇒ Object
191 192 193 194 |
# File 'app/helpers/taxon_names_helper.rb', line 191 def taxon_name_gender_sentence_tag(taxon_name) return nil if taxon_name.nil? "The name is #{taxon_name.gender_name}." if taxon_name.gender_name end |
#taxon_name_inferred_combination_tag(taxon_name) ⇒ Object
182 183 184 185 186 187 188 189 |
# File 'app/helpers/taxon_names_helper.rb', line 182 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_latinization_tag(taxon_name) ⇒ Object
200 201 202 203 |
# File 'app/helpers/taxon_names_helper.rb', line 200 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
205 206 207 208 |
# File 'app/helpers/taxon_names_helper.rb', line 205 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)
359 360 361 362 363 364 365 |
# File 'app/helpers/taxon_names_helper.rb', line 359 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
47 48 49 50 |
# File 'app/helpers/taxon_names_helper.rb', line 47 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
344 345 346 347 348 349 350 351 352 353 354 355 |
# File 'app/helpers/taxon_names_helper.rb', line 344 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
215 216 217 218 219 220 221 222 223 224 225 |
# File 'app/helpers/taxon_names_helper.rb', line 215 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
42 43 44 45 |
# File 'app/helpers/taxon_names_helper.rb', line 42 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
242 243 244 |
# File 'app/helpers/taxon_names_helper.rb', line 242 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
37 38 39 40 |
# File 'app/helpers/taxon_names_helper.rb', line 37 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
110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 |
# File 'app/helpers/taxon_names_helper.rb', line 110 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, 'This name is valid/accepted.', class: :brief_status, data: {icon: :ok, 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
148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 |
# File 'app/helpers/taxon_names_helper.rb', line 148 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
144 145 146 |
# File 'app/helpers/taxon_names_helper.rb', line 144 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
101 102 103 104 105 106 107 108 |
# File 'app/helpers/taxon_names_helper.rb', line 101 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_names_search_form ⇒ Object
246 247 248 |
# File 'app/helpers/taxon_names_helper.rb', line 246 def taxon_names_search_form render '/taxon_names/quick_search_form' end |