Class: Geoblacklight::References

Inherits:
Object
  • Object
show all
Defined in:
lib/geoblacklight/references.rb

Overview

References is a geoblacklight-schema dct:references parser

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(document, reference_field = Settings.FIELDS.REFERENCES) ⇒ References

Returns a new instance of References.



8
9
10
11
12
# File 'lib/geoblacklight/references.rb', line 8

def initialize(document, reference_field = Settings.FIELDS.REFERENCES)
  @document = document
  @reference_field = reference_field
  @refs = parse_references.map { |ref| Reference.new(ref) }
end

Dynamic Method Handling

This class handles dynamic methods through the method_missing method

#method_missing(m, *args, &b) ⇒ Object (private)

Adds a call to references for defined URI keys



148
149
150
151
152
153
154
# File 'lib/geoblacklight/references.rb', line 148

def method_missing(m, *args, &b)
  if Geoblacklight::Constants::URI.key?(m)
    references m
  else
    super
  end
end

Instance Attribute Details

#reference_fieldObject (readonly)

Returns the value of attribute reference_field.



6
7
8
# File 'lib/geoblacklight/references.rb', line 6

def reference_field
  @reference_field
end

#refsObject (readonly)

Returns the value of attribute refs.



6
7
8
# File 'lib/geoblacklight/references.rb', line 6

def refs
  @refs
end

Instance Method Details

#download_typesHash?

Generated download types from wxs services

Returns:

  • (Hash, nil)


69
70
71
# File 'lib/geoblacklight/references.rb', line 69

def download_types
  downloads_by_format
end

#downloads_by_formatHash?

Download hash based off of format type

Returns:

  • (Hash, nil)


55
56
57
58
59
60
61
62
63
64
# File 'lib/geoblacklight/references.rb', line 55

def downloads_by_format
  case format
  when "Shapefile"
    vector_download_formats
  when "GeoTIFF"
    geotiff_download_formats
  when "ArcGRID"
    arcgrid_download_formats
  end
end

#esri_webservicesObject

Returns all of the Esri webservices for given set of references



75
76
77
78
79
# File 'lib/geoblacklight/references.rb', line 75

def esri_webservices
  %w[tiled_map_layer dynamic_map_layer feature_layer image_map_layer].filter_map do |layer_type|
    send(layer_type)
  end
end

#formatString

Accessor for a document’s file format

Returns:

  • (String)

    file format for the document



34
35
36
# File 'lib/geoblacklight/references.rb', line 34

def format
  @document.file_format
end

#preferred_downloadHash?

Preferred download (should be a file download)

Returns:

  • (Hash, nil)


48
49
50
# File 'lib/geoblacklight/references.rb', line 48

def preferred_download
  file_download if download.present?
end

#references(ref_type) ⇒ Geoblacklight::Reference

Parameters:

  • ref_type (String, Symbol)

Returns:



41
42
43
# File 'lib/geoblacklight/references.rb', line 41

def references(ref_type)
  @refs.find { |reference| reference.type == ref_type }
end

#shown_metadataGeoblacklight::Metadata::Base

Return only metadata for shown metadata



27
28
29
# File 'lib/geoblacklight/references.rb', line 27

def 
  @shown_metadata ||= .map { |ref| Geoblacklight::Metadata.instance(ref) }
end

#shown_metadata_refsGeoblacklight::Reference

Return only those metadata references which are exposed within the configuration



17
18
19
20
21
22
# File 'lib/geoblacklight/references.rb', line 17

def 
   = @refs.select { |ref| Settings.METADATA_SHOWN.include?(ref.type.to_s) }
  .sort do |u, v|
    Settings.METADATA_SHOWN.index(u.type.to_s) <=> Settings.METADATA_SHOWN.index(v.type.to_s)
  end
end