Module: OtusHelper

Includes:
RecordNavigationHelper
Defined in:
app/helpers/otus_helper.rb

Instance Method Summary collapse

Methods included from RecordNavigationHelper

for

Instance Method Details

#add_aggregate_geo_json(otu, target) ⇒ Object



368
369
370
371
372
373
374
375
376
377
378
379
# File 'app/helpers/otus_helper.rb', line 368

def add_aggregate_geo_json(otu, target)
  h = target

  if g = aggregate_geo_json(otu, h)
    g['properties'] = {'aggregate': true}
    g['properties']['target'] = geojson_target_for_otu(otu)

    h['features'].push g
  end

  h
end

#add_distribution_geo_json(otu, target, seen_shapes = nil) ⇒ Object



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
488
489
490
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
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
# File 'app/helpers/otus_helper.rb', line 430

def add_distribution_geo_json(otu, target, seen_shapes = nil)
  h = target
  o = otu

  # internal target
  t = geojson_target_for_otu(otu)

  o.current_field_occurrences.where(is_absent: [nil, false]).each do |f|
    shape_key = seen_shapes && f.collecting_event&.geo_json_shape_key
    g = build_geo_json_feature_deduped(seen_shapes&.fetch(:field_occurrences), shape_key) do |skip_geometry|
      field_occurrence_to_geo_json_feature(f, skip_geometry:)
    end
    next unless g
    g['properties']['target'] = t
    h['features'].push g
  end

  o.current_collection_objects.each do |c|
    shape_key = seen_shapes && c.collecting_event&.geo_json_shape_key
    g = build_geo_json_feature_deduped(seen_shapes&.fetch(:collection_objects), shape_key) do |skip_geometry|
      collection_object_to_geo_json_feature(c, skip_geometry:)
    end
    next unless g
    g['properties']['target'] = t
    h['features'].push g
  end

  o.asserted_distributions.without_is_absent.each do |a|
    shape_key = seen_shapes && [a.asserted_distribution_shape_type, a.asserted_distribution_shape_id]
    g = build_geo_json_feature_deduped(seen_shapes&.fetch(:asserted_distributions), shape_key) do |skip_geometry|
      asserted_distribution_to_geo_json_feature(a, skip_geometry:)
    end
    next unless g
    g['properties']['target'] = t
    h['features'].push g
  end

  ba_ids = ::Queries::BiologicalAssociation::Filter.new(otu_query: { otu_id: [o.id] }).all.pluck(:id)
  unless ba_ids.empty?
    ::AssertedDistribution
      .where(
        asserted_distribution_object_type: 'BiologicalAssociation',
        asserted_distribution_object_id: ba_ids
      )
      .without_is_absent
      .each do |a|
        shape_key = seen_shapes && [a.asserted_distribution_shape_type, a.asserted_distribution_shape_id]
        g = build_geo_json_feature_deduped(seen_shapes&.fetch(:asserted_distributions), shape_key) do |skip_geometry|
          asserted_distribution_to_geo_json_feature(a, skip_geometry:)
        end
        next unless g
        g['properties']['target'] = t
        h['features'].push g
      end

    bag_ids = ::BiologicalAssociationsGraph
      .joins(:biological_associations_biological_associations_graphs)
      .where(biological_associations_biological_associations_graphs: { biological_association_id: ba_ids })
      .select(:id)

    unless bag_ids.empty?
      ::AssertedDistribution
        .where(
          asserted_distribution_object_type: 'BiologicalAssociationsGraph',
          asserted_distribution_object_id: bag_ids
        )
        .without_is_absent
        .each do |a|
          shape_key = seen_shapes && [a.asserted_distribution_shape_type, a.asserted_distribution_shape_id]
          g = build_geo_json_feature_deduped(seen_shapes&.fetch(:asserted_distributions), shape_key) do |skip_geometry|
            asserted_distribution_to_geo_json_feature(a, skip_geometry:)
          end
          next unless g
          g['properties']['target'] = t
          h['features'].push g
        end
    end
  end

  [
    [o.depictions, 'Depiction', :depiction_object_id],
    [o.conveyances, 'Conveyance', :conveyance_object_id],
    [o.observations, 'Observation', :observation_object_id],
  ].each do |related_records, object_type, _id_method|
    related_ids = related_records.map(&:id)
    next if related_ids.empty?

    ::AssertedDistribution
      .where(
        asserted_distribution_object_type: object_type,
        asserted_distribution_object_id: related_ids
      )
      .without_is_absent
      .each do |a|
        shape_key = seen_shapes && [a.asserted_distribution_shape_type, a.asserted_distribution_shape_id]
        g = build_geo_json_feature_deduped(seen_shapes&.fetch(:asserted_distributions), shape_key) do |skip_geometry|
          asserted_distribution_to_geo_json_feature(a, skip_geometry:)
        end
        next unless g
        g['properties']['target'] = t
        h['features'].push g
      end
  end

  o.type_materials.includes(:protonym).each do |e|
    next unless type_material_is_primary_type(e) && o.taxon_name.cached_is_valid

    shape_key = seen_shapes && e.collection_object&.collecting_event&.geo_json_shape_key
    g = build_geo_json_feature_deduped(seen_shapes&.fetch(:type_materials), shape_key) do |skip_geometry|
      type_material_to_geo_json_feature(e, skip_geometry:)
    end
    next unless g
    g['properties']['target'] = t
    h['features'].push g
  end

  h
end

#aggregate_geo_json(otu, target, cached_map_type = 'CachedMapItem::WebLevel1') ⇒ Object

TODO: cleanup



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
# File 'app/helpers/otus_helper.rb', line 397

def aggregate_geo_json(otu, target, cached_map_type = 'CachedMapItem::WebLevel1')
  h = target

  if gj = otu.cached_map_geo_json(cached_map_type)

    i =
      {
        **gj,
        # 'type' => gj['type'],  # 'Feature',

        'properties' => {
          'base' => geojson_target_for_otu(otu),
          #     'shape' => {
          #       'type' => cached_map_type,
          #       'id' => 99999 }, # was nil
          'updated_at' => 'foo' # last updated at on CachedMapItem scope, possibly
        }
      }

    if gj.keys.include?('coordinates')
      i['coordinates'] = gj['coordinates'] # was 'coordinates' TODO: might not work
    elsif gj.keys.include?('geometries')
      i['geometries'] = gj['geometries'] # was 'coordinates' TODO: might not work
    end

    i

  else
    nil
  end

end

Stub a smart link to browse OTUs

Parameters:

  • object (an instance of TaxonName or Otu)

    if TaxonName is provided JS UI will disambiguate if more options are possible



142
143
144
145
146
# File 'app/helpers/otus_helper.rb', line 142

def browse_otu_link(object)
  return nil if object.nil?
  otu = object.metamorphosize
  (:div, '', 'data-taxon-name' => object_tag(otu), 'data-redirect' => 'true', 'data-id' => otu.id, 'data-klass' => object.class.base_class.name.to_s, 'data-otu-button' => 'true')
end

#build_geo_json_feature_deduped(seen, shape_key) ⇒ Object (private)

Yields once with skip_geometry true or false depending on whether shape_key [shape_type, shape_id] has already been recorded in seen.

First occurrence of a shape: yields skip_geometry=false (full geometry fetched). The shape is recorded in seen only if the block returns a non-nil feature, so shapes that produce no feature (e.g. no geographic item) are never marked seen. Subsequent occurrences: yields skip_geometry=true (geometry skipped, nil in feature).

When seen or shape_key is nil (deduplication disabled or no shape available), yields skip_geometry=false unconditionally.



649
650
651
652
653
654
655
656
657
658
659
660
661
662
# File 'app/helpers/otus_helper.rb', line 649

def build_geo_json_feature_deduped(seen, shape_key)
  if seen.nil? || shape_key.nil? || shape_key.first.nil?
    return yield(false)
  end

  key = "#{shape_key[0]}_#{shape_key[1]}"
  if seen.key?(key)
    yield(true)
  else
    g = yield(false)
    seen[key] = true if g
    g
  end
end

Returns Hash { dwc_occurrence_id: [ image1, image2 ... ], ... }.

Returns:

  • Hash { dwc_occurrence_id: [ image1, image2 ... ], ... }



576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
# File 'app/helpers/otus_helper.rb', line 576

def dwc_gallery_data(otu, dwc_occurrence_id: [], pagination_headers: true)
  a = DwcOccurrence.scoped_by_otu(otu)
    .select(:id, :dwc_occurrence_object_id, :dwc_occurrence_object_type)

  dwc_ids = [dwc_occurrence_id].flatten.compact.uniq

  if dwc_ids.any?
    a = a.where(id: dwc_ids)
  end

  a = a.page(params[:page]).per(params[:per])

  # Somehwhat of a janky pattern, probably needs to be
  # moved into Controller.
  assign_pagination(a) if pagination_headers

  b = Image.with(dwc_scope: a)
    .joins('JOIN depictions d on d.image_id = images.id' )
    .joins("JOIN dwc_scope on d.depiction_object_id = dwc_scope.dwc_occurrence_object_id AND d.depiction_object_type = 'CollectionObject' AND dwc_scope.dwc_occurrence_object_type = 'CollectionObject'")
    .select('images.*, dwc_scope.id dwc_id')
    .distinct

  r = {}
  b.find_each do |o|
    r[o.dwc_id] ||= []
    r[o.dwc_id].push o
  end
  r
end

#geojson_for_otu(otu) ⇒ Object



350
351
352
353
354
355
356
357
358
# File 'app/helpers/otus_helper.rb', line 350

def geojson_for_otu(otu)
  {
    'type' => 'FeatureCollection',
    'features' => [],
    'properties' => {
      'target' => geojson_target_for_otu(otu)
    }
  }
end

#geojson_target_for_otu(otu) ⇒ Object



360
361
362
363
364
365
366
# File 'app/helpers/otus_helper.rb', line 360

def geojson_target_for_otu(otu)
  {
    'id' => otu.id,
    'label' => label_for_otu(otu),
    'type' => 'Otu'
  }
end

#label_for_otu(otu) ⇒ Object



55
56
57
58
59
60
# File 'app/helpers/otus_helper.rb', line 55

def label_for_otu(otu)
  return nil if otu.nil?
  [ label_for_taxon_name(otu.taxon_name),
    otu.name
  ].compact.join(': ')
end

#next_records(otu) ⇒ Array

Returns of OTUs.

Returns:

  • (Array)

    of OTUs



159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
# File 'app/helpers/otus_helper.rb', line 159

def next_records(otu)
  if otu.taxon_name_id
    o = []
    t = otu.taxon_name.next_sibling
    unless t.nil?
      while o.empty?
        break if t.nil?
        o = t.otus.to_a
        t = t.next_sibling
      end
    end
    o
  else
    super
  end
end

#otu_autocomplete_selected_tag(otu) ⇒ String

Returns no HTML inside .

Returns:

  • (String)

    no HTML inside



119
120
121
122
123
124
# File 'app/helpers/otus_helper.rb', line 119

def otu_autocomplete_selected_tag(otu)
  return nil if otu.nil? || (otu.new_record? && !otu.changed?)
  [otu.name,
   Utilities::Strings.nil_wrap('[',taxon_name_autocomplete_selected_tag(otu.taxon_name), ']')&.html_safe
  ].compact.join(' ')
end

#otu_autoselect_info(otu) ⇒ Object



28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
# File 'app/helpers/otus_helper.rb', line 28

def otu_autoselect_info(otu)
  return [] if otu.taxon_name_id.blank?
  r = [ ]

  t = otu.taxon_name

  if t && t.is_protonym?
    if t.is_genus_or_species_rank?
      r.push taxon_name_original_combination_tag(t)
    end

    if !t.is_valid?
      r.push taxon_name_now_tag(t.valid_taxon_name)
    end
  else
    r.push t.type
  end
  r
end

#otu_autoselect_tag(otu) ⇒ Object

HTML label for the autoselect dropdown (left-justified).



7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
# File 'app/helpers/otus_helper.rb', line 7

def otu_autoselect_tag(otu)
  return nil if otu.nil?
  if otu.taxon_name&.is_combination?
    if otu.name.present?
      return [
        otu.name,
        '=',
        tag.span( otu.taxon_name.cached_html_name_and_author_year.html_safe, class: :klass),
        TaxonNamesHelper::COMBINATION_MARK
      ].compact.join(' ')
    else
      return tag.span( otu.taxon_name.cached_html_name_and_author_year.html_safe, class: :klass)
    end
  else
    return  [
      otu.taxon_name&.cached_html,
      otu.name
    ].compact.join(' ')
  end
end

#otu_cached_map(otu, target, cached_map_type = 'CachedMapItem::WebLevel1', cache = true, force = false) ⇒ Object

NOT USED Caching the cached map



383
384
385
386
387
388
389
390
391
392
393
394
# File 'app/helpers/otus_helper.rb', line 383

def otu_cached_map(otu, target, cached_map_type = 'CachedMapItem::WebLevel1', cache = true, force = false)
  r = nil
  if force
    r = aggregate_geo_json(otu, target, cached_map_type)
  else
    # Check for map

    # TODO: extend with synced check
    if a = CachedMap.where(project_id: sessions_current_project_id).where(otu_id: otu.id, cached_map_type:  )
    end
  end
end

#otu_common_names_label(common_names, term = nil) ⇒ Object



88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
# File 'app/helpers/otus_helper.rb', line 88

def otu_common_names_label(common_names, term = nil)
  return nil if common_names.nil? || common_names.empty?

  if term.empty?
    return common_names.map(&:name).sort.join(', ')
  end

  prefix_matches = []
  wildcard_matches = []
  non_matches = []

  term = term.downcase
  # Regexp.escape turns each space into '\\ '.
  wildcard_term = Regexp.escape(term).gsub(/(\\ )+/, '.*')

  common_names.each do |o|
    name = o.name.downcase
    if name.start_with?(term)
      prefix_matches << name
    elsif name =~ /#{wildcard_term}/
      wildcard_matches << name
    else
      non_matches << name
    end
  end

  (prefix_matches.sort + wildcard_matches.sort + non_matches.sort).join(', ')
end

#otu_distribution(otu, children = true, cutoff = 200) ⇒ Object

TODO:

  • make properties universal type: 'Model', id: id, label:
  • merge origin_otu_id: id to reference coordinate OTUs

target:

type: Otu
label:
id

base: # one level above target (or one level below shape?!) type:

id:

shape: # Either GeographicArea or Georeference type id

Returns:

  • Hash A GeoJSON collection of distribution data in x parts need a to_geo_json for each object

    :asserted_distributions
      with shape
      without shapes
    :collection_objects
        with georeferences
        with GeographicAreas
    :type material
        with georeferences
        with GeographicAreas


250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
# File 'app/helpers/otus_helper.rb', line 250

def otu_distribution(otu, children = true, cutoff = 200)
  return {} if otu.nil?
  otus = if children
    otu.coordinate_otus_with_children
  else
    Otu.coordinate_otus(otu.id)
  end

  h = geojson_for_otu(otu)

  if otu.taxon_name && otu.taxon_name.is_protonym? && !otu.taxon_name.is_species_rank?
    add_aggregate_geo_json(otu, h)
  else
    otus = if children
            otu.coordinate_otus_with_children
          else
            Otu.coordinate_otus(otu.id)
          end

    # Batch-load everything the downstream helpers touch.
    otus = otus.includes(
      :taxon_name,
      current_field_occurrences: [
        :identifiers,
        { collecting_event: [ :georeferences, :geographic_area, :geographic_items ] }
      ],
      current_collection_objects: [
        :identifiers,
        { collecting_event: [ :georeferences, :geographic_area, :geographic_items ] }
      ],
      asserted_distributions: { asserted_distribution_shape: :geographic_items },
      type_materials: [
        { collection_object: [
            :identifiers,
            { collecting_event: [ :georeferences, :geographic_area, :geographic_items ] }
          ] }
      ]
    )

    seen_shapes = {
      field_occurrences: {},
      collection_objects: {},
      asserted_distributions: {},
      type_materials: {}
    }

    otus.each do |o|
      add_distribution_geo_json(o, h, seen_shapes)
    end
  end

  h
end

#otu_distribution_is_absent(otu, descendants: false) ⇒ Hash

Returns GeoJSON FeatureCollection of absent FieldOccurrences and AssertedDistributions for the OTU, its coordinate OTUs, and ancestor taxon names (traversed via TaxonNameHierarchies).

Parameters:

  • descendants (Boolean) (defaults to: false)

    when true, also include direct absents from descendant OTUs. Off by default: a descendant's absence does not propagate up to the OTU, and a sibling descendant's presence in the same region may contradict it. Use only when the caller wants a clade-wide visualization.

Returns:

  • (Hash)

    GeoJSON FeatureCollection of absent FieldOccurrences and AssertedDistributions for the OTU, its coordinate OTUs, and ancestor taxon names (traversed via TaxonNameHierarchies).



312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
# File 'app/helpers/otus_helper.rb', line 312

def otu_distribution_is_absent(otu, descendants: false)
  return {} if otu.nil?

  h = geojson_for_otu(otu)
  seen_shapes = {
    field_occurrences: {},
    asserted_distributions: {}
  }

  otus = descendants ? otu.coordinate_otus_with_children : Otu.coordinate_otus(otu.id)

  otus.each do |o|
    t = geojson_target_for_otu(o)

    o.absent_and_ancestor_absent_field_occurrences.each do |f|
      shape_key = f.collecting_event&.geo_json_shape_key
      g = build_geo_json_feature_deduped(seen_shapes[:field_occurrences], shape_key) do |skip_geometry|
        field_occurrence_to_geo_json_feature(f, skip_geometry:)
      end
      next unless g
      g['properties']['target'] = t
      h['features'].push g
    end

    o.absent_and_ancestor_absent_asserted_distributions.each do |a|
      shape_key = [a.asserted_distribution_shape_type, a.asserted_distribution_shape_id]
      g = build_geo_json_feature_deduped(seen_shapes[:asserted_distributions], shape_key) do |skip_geometry|
        asserted_distribution_to_geo_json_feature(a, skip_geometry:)
      end
      next unless g
      g['properties']['target'] = t
      h['features'].push g
    end
  end

  h
end

#otu_extended_autocomplete_tag(target, otu, common_names, term) ⇒ Object

Used exclusively in /api/v1/otus/autocomplete



71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
# File 'app/helpers/otus_helper.rb', line 71

def otu_extended_autocomplete_tag(target, otu, common_names, term)
  if target.kind_of?(Otu)
    t = otu_tag(target)
  else # TaxonName
    a = [ tag.span( full_taxon_name_tag(target).html_safe, class: :otu_tag_taxon_name, title: target.id) ]
    a.push taxon_name_type_short_tag(target)
    t = tag.span( a.compact.join(' ').html_safe, class: :otu_tag )
  end

  if common_names.present? && otu.present? &&
     (common_names_label = otu_common_names_label(common_names, term)).present?
    tag.span( "#{common_names_label} (#{t})".html_safe )
  else
    t
  end
end

#otu_key_inventory(otu) ⇒ Object



618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
# File 'app/helpers/otus_helper.rb', line 618

def otu_key_inventory(otu)
  return {
    observation_matrices: {
      scoped: serialize_matrices(otu.in_scope_observation_matrices),
      in: serialize_matrices(otu.observation_matrices)
    },
    leads: {
      scoped: otu.leads
        .where(parent_id: nil, is_public: true)
        .select(:id, :text)
        .map { |l| { id: l.id, text: l.text } },

      in: Lead.public_root_leads_for_leaf_otus(otu)
        .select(:id, :text)
        .map { |l| { id: l.id, text: l.text } }
    }
  }
end


126
127
128
129
# File 'app/helpers/otus_helper.rb', line 126

def otu_link(otu)
  return nil if otu.nil?
  link_to(otu_tag_elements(otu).join(' ').html_safe, otu)
end

#otu_tag(otu) ⇒ Object



48
49
50
51
52
53
# File 'app/helpers/otus_helper.rb', line 48

def otu_tag(otu)
  return nil if otu.nil?
  a = otu_tag_elements(otu)
  a.push taxon_name_type_short_tag(otu.taxon_name)
  (:span, a.compact.join(' ').html_safe, class: :otu_tag)
end

#otu_tag_elements(otu) ⇒ Object



62
63
64
65
66
67
68
# File 'app/helpers/otus_helper.rb', line 62

def otu_tag_elements(otu)
  return nil if otu.nil?
  [
    ( otu.taxon_name ? tag.span(otu.taxon_name.cached, class: :otu_tag_taxon_name, title: otu.taxon_name.id) : nil),
    ( otu.name ? (:span, otu.name, class: :otu_tag_otu_name, title: otu.id) : nil )
  ].compact
end


135
136
137
# File 'app/helpers/otus_helper.rb', line 135

def otus_link_list_tag(otus)
  otus.collect { |o| link_to(o.name, o) }.join(',')
end

#otus_radial(object) ⇒ Object



153
154
155
# File 'app/helpers/otus_helper.rb', line 153

def otus_radial(object)
  (:div, '', 'data-global-id' => object.to_global_id.to_s, 'data-otu-radial' => 'true')
end

#otus_radial_disambiguate(object) ⇒ Object



148
149
150
151
# File 'app/helpers/otus_helper.rb', line 148

def otus_radial_disambiguate(object)
  otu = object.metamorphosize
  (:div, '', 'data-taxon-name' => object_tag(otu), 'data-redirect' => 'false', 'data-id' => otu.id, 'data-klass' => object.class.base_class.name.to_s, 'data-otu-button' => 'true')
end

#otus_search_formObject



131
132
133
# File 'app/helpers/otus_helper.rb', line 131

def otus_search_form
  render('/otus/quick_search_form')
end

#parent_records(otu) ⇒ Object



197
198
199
# File 'app/helpers/otus_helper.rb', line 197

def parent_records(otu)
  otu.taxon_name&.parent&.otus&.all || []
end

#parents_by_nomenclature(otu) ⇒ Object

See also otus#ancestor_otu_ids ?



202
203
204
205
206
207
208
209
210
211
212
213
214
# File 'app/helpers/otus_helper.rb', line 202

def parents_by_nomenclature(otu)
  above = [ ]
  if otu.taxon_name_id
    TaxonName.ancestors_of(otu.taxon_name)
      .select('taxon_names.*, taxon_name_hierarchies.generations')
      .that_is_valid.joins(:otus)
      .distinct
      .reorder('taxon_name_hierarchies.generations DESC, taxon_names.cached_valid_taxon_name_id').each do |t|
        above.push [t.cached, t.otus.to_a] # TODO: to_a vs. pluck
      end
  end
  above
end

#previous_records(otu) ⇒ Array

Some OTUs don't have TaxonName, skip along until we hit one.

Returns:

  • (Array)

    of OTUs



180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
# File 'app/helpers/otus_helper.rb', line 180

def previous_records(otu)
  if otu.taxon_name_id
    o = []
    t = otu.taxon_name.previous_sibling
    unless t.nil?
      while o.empty?
        break if t.nil?
        o = t.otus.to_a
        t = t.previous_sibling
      end
    end
    o
  else
    super
  end
end

#ranked_otu_table(otus) ⇒ Object



549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
# File 'app/helpers/otus_helper.rb', line 549

def ranked_otu_table(otus)
  d = TaxonName.ranked_otus(otu_scope: otus, project_id: sessions_current_project_id)

  tbl = %w{otu_id order family genus species otu_name taxon_name taxon_name_author_year}
  output = StringIO.new
  output.puts ::CSV.generate_line(tbl, col_sep: "\t", encoding: Encoding::UTF_8)

  d.each do |o|
    output.puts ::CSV.generate_line(
      [
        o.id,
        o['order'],
        o['family'],
        o['genus'],
        o['species'],
        o.name,
        o.cached,
        o.cached_author_year
      ],
      col_sep: "\t", encoding: Encoding::UTF_8)
  end

  output.string
end

#serialize_matrices(scope) ⇒ Object



606
607
608
609
610
611
612
613
614
615
616
# File 'app/helpers/otus_helper.rb', line 606

def serialize_matrices(scope)
  scope
    .where(is_public: true)
    .map do |m|
      {
        id: m.id,
        name: m.name,
        is_media: m.is_media_matrix?
      }
    end
end