geoblacklight 1.9.1 → 2.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (135) hide show
  1. checksums.yaml +4 -4
  2. data/.circleci/config.yml +2 -2
  3. data/.rubocop.yml +4 -14
  4. data/.rubocop_todo.yml +51 -48
  5. data/README.md +3 -0
  6. data/Rakefile +1 -2
  7. data/app/assets/javascripts/geoblacklight/basemaps.js +3 -3
  8. data/app/assets/javascripts/geoblacklight/downloaders/downloader.js +1 -1
  9. data/app/assets/javascripts/geoblacklight/geoblacklight.js +1 -1
  10. data/app/assets/javascripts/geoblacklight/modules/download.js +1 -1
  11. data/app/assets/javascripts/geoblacklight/modules/home.js +3 -2
  12. data/app/assets/javascripts/geoblacklight/modules/util.js +8 -0
  13. data/app/assets/javascripts/geoblacklight/templates/index_map_download.hbs +19 -0
  14. data/app/assets/javascripts/geoblacklight/templates/index_map_info.hbs +15 -13
  15. data/app/assets/javascripts/geoblacklight/viewers/esri/dynamic_map_layer.js +3 -3
  16. data/app/assets/javascripts/geoblacklight/viewers/esri/feature_layer.js +4 -2
  17. data/app/assets/javascripts/geoblacklight/viewers/index_map.js +20 -12
  18. data/app/assets/javascripts/geoblacklight/viewers/map.js +2 -1
  19. data/app/assets/javascripts/geoblacklight/viewers/wms.js +1 -5
  20. data/app/assets/stylesheets/geoblacklight/_blacklight_overrides.scss +43 -0
  21. data/app/assets/stylesheets/geoblacklight/_geoblacklight.scss +4 -1
  22. data/app/assets/stylesheets/geoblacklight/application.scss +0 -1
  23. data/app/assets/stylesheets/geoblacklight/modules/downloads.scss +33 -13
  24. data/app/assets/stylesheets/geoblacklight/modules/home.scss +22 -19
  25. data/app/assets/stylesheets/geoblacklight/modules/icon-customization.scss +1 -1
  26. data/app/assets/stylesheets/geoblacklight/modules/index_maps.scss +7 -0
  27. data/app/assets/stylesheets/geoblacklight/modules/item.scss +7 -8
  28. data/app/assets/stylesheets/geoblacklight/modules/metadata.scss +9 -0
  29. data/app/assets/stylesheets/geoblacklight/modules/relations.scss +15 -0
  30. data/app/assets/stylesheets/geoblacklight/modules/results.scss +7 -2
  31. data/app/assets/stylesheets/geoblacklight/modules/sidebar.scss +60 -0
  32. data/app/assets/stylesheets/geoblacklight/modules/toolbar.scss +55 -35
  33. data/app/controllers/download_controller.rb +5 -4
  34. data/app/controllers/relation_controller.rb +11 -1
  35. data/app/helpers/carto_helper.rb +2 -9
  36. data/app/helpers/geoblacklight_helper.rb +15 -28
  37. data/app/models/concerns/geoblacklight/solr_document.rb +4 -0
  38. data/app/models/concerns/geoblacklight/spatial_search_behavior.rb +18 -1
  39. data/app/presenters/geoblacklight/document_presenter.rb +2 -2
  40. data/app/views/catalog/_document_action.html.erb +2 -2
  41. data/app/views/catalog/_document_split.html.erb +5 -3
  42. data/app/views/catalog/_downloads_secondary.html.erb +39 -0
  43. data/app/views/catalog/_facet_tag_layout.html.erb +1 -1
  44. data/app/views/catalog/_home_text.html.erb +30 -38
  45. data/app/views/catalog/_index_split_default.html.erb +1 -2
  46. data/app/views/catalog/_metadata.html.erb +3 -3
  47. data/app/views/catalog/_show_default_attribute_table.html.erb +16 -14
  48. data/app/views/catalog/_show_default_viewer_container.html.erb +5 -3
  49. data/app/views/catalog/_show_default_viewer_information.html.erb +3 -1
  50. data/app/views/catalog/_show_downloads.html.erb +12 -9
  51. data/app/views/catalog/_show_tools.html.erb +25 -0
  52. data/app/views/catalog/_web_services.html.erb +1 -1
  53. data/app/views/catalog/_web_services_wfs.html.erb +1 -1
  54. data/app/views/catalog/_web_services_wms.html.erb +1 -1
  55. data/app/views/catalog/index.html.erb +9 -8
  56. data/app/views/relation/_ancestors.html.erb +2 -2
  57. data/app/views/relation/_descendants.html.erb +3 -3
  58. data/app/views/relation/index.html.erb +8 -8
  59. data/app/views/shared/_header_navbar.html.erb +28 -17
  60. data/config/locales/geoblacklight.en.yml +2 -2
  61. data/geoblacklight.gemspec +5 -4
  62. data/lib/generators/geoblacklight/install_generator.rb +3 -12
  63. data/lib/generators/geoblacklight/templates/Procfile +3 -0
  64. data/lib/generators/geoblacklight/templates/catalog_controller.rb +33 -5
  65. data/lib/generators/geoblacklight/templates/package.json +14 -0
  66. data/lib/generators/geoblacklight/templates/settings.yml +15 -1
  67. data/lib/generators/geoblacklight/templates/webpacker.yml +67 -0
  68. data/lib/generators/geoblacklight/webpacker_generator.rb +35 -0
  69. data/lib/geoblacklight.rb +2 -4
  70. data/lib/geoblacklight/controller_override.rb +27 -22
  71. data/lib/geoblacklight/engine.rb +0 -1
  72. data/lib/geoblacklight/version.rb +1 -1
  73. data/lib/tasks/geoblacklight.rake +18 -0
  74. data/schema/geoblacklight-schema.md +72 -59
  75. data/schema/geometry-type-values.md +1 -0
  76. data/schema/references.md +22 -0
  77. data/schema/schema-commentary.md +198 -0
  78. data/schema/subjects.md +41 -0
  79. data/schema/type-values.md +4 -2
  80. data/solr/conf/core.properties +5 -0
  81. data/solr/conf/schema.xml +11 -1
  82. data/solr/conf/solrconfig.xml +1 -1
  83. data/spec/controllers/catalog_controller_spec.rb +17 -1
  84. data/spec/factories/user.rb +2 -2
  85. data/spec/features/download_layer_spec.rb +19 -15
  86. data/spec/features/esri_viewer_spec.rb +2 -2
  87. data/spec/features/home_page_spec.rb +6 -2
  88. data/spec/features/index_map_spec.rb +15 -25
  89. data/spec/features/layer_opacity_spec.rb +1 -1
  90. data/spec/features/layer_preview_spec.rb +3 -2
  91. data/spec/features/linkified_attribute_table_spec.rb +3 -4
  92. data/spec/features/relations_spec.rb +1 -1
  93. data/spec/features/search_bar_spec.rb +2 -2
  94. data/spec/features/search_results_map_spec.rb +2 -2
  95. data/spec/features/search_results_overlap_ratio_spec.rb +55 -0
  96. data/spec/features/search_spec.rb +13 -0
  97. data/spec/features/show_page_metadata_spec.rb +1 -1
  98. data/spec/features/sms_spec.rb +15 -0
  99. data/spec/features/split_view.html.erb_spec.rb +24 -15
  100. data/spec/features/web_services_modal_spec.rb +0 -2
  101. data/spec/fixtures/solr_documents/README.md +38 -0
  102. data/spec/fixtures/solr_documents/esri-image-map-layer.json +39 -18
  103. data/spec/fixtures/solr_documents/index-map-polygon-no-downloadurl.json +37 -0
  104. data/spec/fixtures/solr_documents/index-map-polygon.json +37 -0
  105. data/spec/fixtures/solr_documents/{point_index_map.json → index_map_point.json} +1 -1
  106. data/spec/fixtures/solr_documents/princeton-child1.json +30 -0
  107. data/spec/fixtures/solr_documents/princeton-child2.json +30 -0
  108. data/spec/fixtures/solr_documents/princeton-parent.json +25 -0
  109. data/spec/helpers/carto_helper_spec.rb +1 -20
  110. data/spec/helpers/geoblacklight_helper_spec.rb +4 -22
  111. data/spec/lib/geoblacklight/document_presenter_spec.rb +1 -1
  112. data/spec/lib/geoblacklight/geoblacklight_helper_behavior_spec.rb +1 -1
  113. data/spec/models/concerns/geoblacklight/spatial_search_behavior_spec.rb +10 -0
  114. data/spec/spec_helper.rb +6 -3
  115. data/spec/teaspoon_env.rb +31 -1
  116. data/spec/test_app_templates/lib/generators/test_app_generator.rb +5 -0
  117. data/spec/test_app_templates/solr_documents +1 -0
  118. data/spec/views/catalog/_show_downloads.html.erb_spec.rb +1 -1
  119. data/spec/views/catalog/_show_tools.html.erb_spec.rb +39 -0
  120. data/template.rb +4 -2
  121. data/vendor/assets/images/layers-2x.png +0 -0
  122. data/vendor/assets/images/layers.png +0 -0
  123. data/vendor/assets/images/marker-icon-2x.png +0 -0
  124. data/vendor/assets/images/marker-icon.png +0 -0
  125. data/vendor/assets/images/marker-shadow.png +0 -0
  126. data/vendor/assets/javascripts/esri-leaflet.js.map +1 -0
  127. data/vendor/assets/javascripts/leaflet-src.js.map +1 -0
  128. data/vendor/assets/javascripts/leaflet.js.erb +13922 -0
  129. data/vendor/assets/stylesheets/leaflet.css +635 -0
  130. metadata +87 -33
  131. data/app/assets/stylesheets/geoblacklight/modules/twitter-typeahead.scss +0 -14
  132. data/app/views/catalog/_search_form_no_navbar.html.erb +0 -22
  133. data/app/views/catalog/_show_default.html.erb +0 -13
  134. data/app/views/catalog/_upper_metadata.html.erb +0 -20
  135. data/spec/fixtures/solr_documents/umn_metro_result2.json +0 -39
@@ -1,2 +1,2 @@
1
1
  <%= yield %>
2
- <%= link_to t('blacklight.search.facets.more'), facet_catalog_path(display_facet.name), class: 'more_facets_link' %>
2
+ <%= link_to t('blacklight.search.facets.more_html'), facet_catalog_path(display_facet.name), class: 'more_facets_link' %>
@@ -1,49 +1,41 @@
1
- <div class='jumbotron'>
2
- <div class='home-search-area'>
3
- <%= content_tag :h2, t('geoblacklight.home.headline') %>
4
- <%= content_tag :h3, t('geoblacklight.home.search_heading') %>
5
- <div class='row'>
6
- <div class='col-md-6 col-md-offset-3'>
7
- <%= render_search_form_no_navbar %>
8
- </div>
9
- </div>
10
- </div>
11
- </div>
12
-
13
1
  <div class='container'>
14
- <div class='row'>
15
- <div class='col-md-6'>
16
- <%= content_tag :h3, t('geoblacklight.home.category_heading'), class: 'text-center' %>
17
- <div class='category-block'>
18
- <div class='category-icon'>
19
- <span class='glyphicon glyphicon-home'></span>
2
+ <div class='row text-center'>
3
+ <div class='col-sm'>
4
+ <%= content_tag :h3, t('geoblacklight.home.category_heading') %>
5
+ <div class='row'>
6
+ <div class='category-block col-sm'>
7
+ <div class='category-icon'>
8
+ <span class='fa fa-home'></span>
9
+ </div>
10
+ <%= content_tag :h4, t('geoblacklight.home.institution') %>
11
+ <%= render_facet_tags [Settings.FIELDS.PROVENANCE] %>
20
12
  </div>
21
- <%= content_tag :h4, t('geoblacklight.home.institution'), class: 'text-center' %>
22
- <%= render_facet_tags [Settings.FIELDS.PROVENANCE] %>
23
- </div>
24
- <div class='category-block'>
25
- <div class='category-icon'>
26
- <span class='glyphicon glyphicon-download'></span>
13
+ <div class='category-block col-sm'>
14
+ <div class='category-icon'>
15
+ <span class='fa fa-arrow-circle-down'></span>
16
+ </div>
17
+ <%= content_tag :h4, t('geoblacklight.home.data_type') %>
18
+ <%= render_facet_tags [Settings.FIELDS.GEOM_TYPE] %>
27
19
  </div>
28
- <%= content_tag :h4, t('geoblacklight.home.data_type'), class: 'text-center' %>
29
- <%= render_facet_tags [Settings.FIELDS.GEOM_TYPE] %>
30
20
  </div>
31
- <div class='category-block'>
32
- <div class='category-icon'>
33
- <span class='glyphicon glyphicon-globe'></span>
21
+ <div class='row'>
22
+ <div class='category-block col-sm'>
23
+ <div class='category-icon'>
24
+ <span class='fa fa-globe'></span>
25
+ </div>
26
+ <%= content_tag :h4, t('geoblacklight.home.placename') %>
27
+ <%= render_facet_tags [Settings.FIELDS.SPATIAL_COVERAGE] %>
34
28
  </div>
35
- <%= content_tag :h4, t('geoblacklight.home.placename'), class: 'text-center' %>
36
- <%= render_facet_tags [Settings.FIELDS.SPATIAL_COVERAGE] %>
37
- </div>
38
- <div class='category-block'>
39
- <div class='category-icon'>
40
- <span class='glyphicon glyphicon-tags'></span>
29
+ <div class='category-block col-sm'>
30
+ <div class='category-icon'>
31
+ <span class='fa fa-tags'></span>
32
+ </div>
33
+ <%= content_tag :h4, t('geoblacklight.home.subject') %>
34
+ <%= render_facet_tags [Settings.FIELDS.SUBJECT] %>
41
35
  </div>
42
- <%= content_tag :h4, t('geoblacklight.home.subject'), class: 'text-center' %>
43
- <%= render_facet_tags [Settings.FIELDS.SUBJECT] %>
44
36
  </div>
45
37
  </div>
46
- <div class='col-md-6 text-center'>
38
+ <div class='col-sm'>
47
39
  <%= content_tag :h3, t('geoblacklight.home.map_heading') %>
48
40
  <%= content_tag :div, '', id: 'map', data: { map: 'home', 'catalog-path'=> search_catalog_path , 'map-bbox' => params[:bbox], basemap: geoblacklight_basemap, leaflet_options: leaflet_options } %>
49
41
  </div>
@@ -9,7 +9,7 @@
9
9
  <span class="document-counter">
10
10
  <%= t('blacklight.search.documents.counter', :counter => counter) if counter %>
11
11
  </span>
12
- <%= link_to_document document, document_show_link_field(document), counter: counter, title: document[blacklight_config.index.title_field] %>
12
+ <%= link_to_document document, counter: counter, title: document[blacklight_config.index.title_field] %>
13
13
  </h3>
14
14
 
15
15
  <div class='col-md-12 more-info-area'>
@@ -20,4 +20,3 @@
20
20
  </div>
21
21
  </div>
22
22
  <% end %>
23
-
@@ -1,11 +1,11 @@
1
- <% document ||= @document %>
1
+ <% document ||= @documents.first %>
2
2
 
3
3
  <div class='metadata-view'>
4
4
  <div class="container-fluid">
5
5
  <ul class="nav nav-pills" role="tablist">
6
6
  <% document.references.shown_metadata.each do |metadata| %>
7
- <li role="presentation" class="<%= first_metadata?(document, metadata) ? 'active' : nil %>">
8
- <a class="pill-metadata"
7
+ <li role="presentation" class="nav-item">
8
+ <a class="pill-metadata nav-link <%= first_metadata?(document, metadata) ? 'active' : nil %>"
9
9
  href="#<%= metadata.type %>"
10
10
  aria-controls="<%= metadata.type %>"
11
11
  role="tab"
@@ -1,17 +1,19 @@
1
1
  <% if show_attribute_table? %>
2
- <div id='table-container' class='col-md-12'>
3
- <table id="attribute-table" class="table table-hover table-condensed table-responsive table-striped table-bordered col-md-12">
4
- <thead>
5
- <tr>
6
- <th><%= t('geoblacklight.show.attribute') %></th>
7
- <th><%= t('geoblacklight.show.value') %></th>
8
- </tr>
9
- </thead>
10
- <tbody class='attribute-table-body'>
11
- <tr>
12
- <td class='default-text' colspan='2'><em><%= t('geoblacklight.show.click_map') %></em></td>
13
- </tr>
14
- </tbody>
15
- </table>
2
+ <div class='row'>
3
+ <div id='table-container' class='col-md-12'>
4
+ <table id="attribute-table" class="table table-hover table-condensed table-striped table-bordered col-md-12">
5
+ <thead>
6
+ <tr>
7
+ <th><%= t('geoblacklight.show.attribute') %></th>
8
+ <th><%= t('geoblacklight.show.value') %></th>
9
+ </tr>
10
+ </thead>
11
+ <tbody class='attribute-table-body'>
12
+ <tr>
13
+ <td class='default-text' colspan='2'><em><%= t('geoblacklight.show.click_map') %></em></td>
14
+ </tr>
15
+ </tbody>
16
+ </table>
17
+ </div>
16
18
  </div>
17
19
  <% end %>
@@ -1,5 +1,7 @@
1
1
  <% document ||= @document %>
2
- <div id='viewer-container' class="col-md-12">
3
- <%= content_tag :div, id: 'map', data: { map: 'item', protocol: document.viewer_protocol.camelize, url: document.viewer_endpoint, 'layer-id' => document.wxs_identifier, 'map-bbox' => document.bounding_box_as_wsen, 'catalog-path'=> search_catalog_path, available: document_available?, inspect: show_attribute_table?, basemap: geoblacklight_basemap, leaflet_options: leaflet_options } do %>
4
- <% end %>
2
+ <div class='row'>
3
+ <div id='viewer-container' class="col-md-12">
4
+ <%= content_tag :div, id: 'map', data: { map: 'item', protocol: document.viewer_protocol.camelize, url: document.viewer_endpoint, 'layer-id' => document.wxs_identifier, 'map-bbox' => document.bounding_box_as_wsen, 'catalog-path'=> search_catalog_path, available: document_available?, inspect: show_attribute_table?, basemap: geoblacklight_basemap, leaflet_options: leaflet_options } do %>
5
+ <% end %>
6
+ </div>
5
7
  </div>
@@ -1,2 +1,4 @@
1
- <div class='viewer-information col-md-4'>
1
+ <div class='row'>
2
+ <div class='viewer-information col-sm-12'>
3
+ </div>
2
4
  </div>
@@ -2,21 +2,22 @@
2
2
 
3
3
  <% if document_downloadable? %>
4
4
  <% if document.direct_download.present? || document.hgl_download.present? || document.iiif_download.present? %>
5
- <div class="panel panel-default downloads">
6
- <div class="panel-heading">
7
- <h3 class="h5"><%= t('geoblacklight.download.download').pluralize %></h3>
5
+ <div class="card downloads">
6
+ <div class="card-header">
7
+ <h2><%= t('geoblacklight.download.download').pluralize %></h2>
8
8
  </div>
9
9
 
10
- <ul class="list-group list-group-flush">
10
+ <ul class="list-group list-group-flush js-download-list">
11
11
  <%= render 'downloads_primary' %>
12
12
  </ul>
13
13
  </div>
14
14
  <% end %>
15
15
 
16
16
  <% if document.download_types.present? %>
17
- <div class="panel panel-default exports">
18
- <div class="panel-heading">
19
- <h3 class="h5"><%= t('geoblacklight.download.export_formats') %></h3>
17
+ <div class="card exports">
18
+ <div class="card-header">
19
+
20
+ <h2><%= t('geoblacklight.download.export_formats') %></h2>
20
21
  </div>
21
22
 
22
23
  <ul class="list-group list-group-flush">
@@ -25,7 +26,9 @@
25
26
  </div>
26
27
  <% end %>
27
28
  <% elsif document.restricted? && document.same_institution? %>
28
- <div class='panel-body'>
29
- <%= link_to t('geoblacklight.tools.login_to_view'), new_user_session_path(referrer: request.original_url) %>
29
+ <div class="card authentication">
30
+ <div class="card-header">
31
+ <%= link_to t('geoblacklight.tools.login_to_view'), new_user_session_path(referrer: request.original_url), class: ['btn', 'btn-default'] %>
32
+ </div>
30
33
  </div>
31
34
  <% end %>
@@ -0,0 +1,25 @@
1
+ <%-
2
+ # Compare with render_document_functions_partial helper, and
3
+ # _document_functions partial. BL actually has two groups
4
+ # of document-related tools. "document functions" by default
5
+ # contains Bookmark functionality shown on both results and
6
+ # item view. While "document tools" contains external export type
7
+ # functions by default only on detail.
8
+ -%>
9
+ <% if show_doc_actions? %>
10
+ <div class="card show-tools">
11
+ <div class="card-header">
12
+ <h2><%= t('blacklight.tools.title') %></h2>
13
+ </div>
14
+
15
+ <ul class="list-group list-group-flush">
16
+ <%= render_show_doc_actions @document do |config, inner| %>
17
+ <% if inner.present? %>
18
+ <li class="list-group-item <%= config.key %>">
19
+ <%= inner %>
20
+ </li>
21
+ <% end %>
22
+ <% end %>
23
+ </ul>
24
+ </div>
25
+ <% end %>
@@ -1,4 +1,4 @@
1
- <% document ||= @document %>
1
+ <% document ||= @documents.first %>
2
2
 
3
3
  <% document.references.refs.each do |reference| %>
4
4
  <% if Settings.WEBSERVICES_SHOWN.include? reference.type.to_s %>
@@ -1,4 +1,4 @@
1
- <% document ||= @document %>
1
+ <% document ||= @documents.first %>
2
2
 
3
3
  <%= render partial: 'web_services_default', locals: { reference: reference } %>
4
4
 
@@ -1,4 +1,4 @@
1
- <% document ||= @document %>
1
+ <% document ||= @documents.first %>
2
2
 
3
3
  <%= render partial: 'web_services_default', locals: { reference: reference } %>
4
4
 
@@ -1,12 +1,13 @@
1
+ <% content_for(:sidebar) do %>
2
+ <% if has_search_parameters? %>
3
+ <%= render 'search_sidebar' %>
4
+ <% end %>
5
+ <% end %>
6
+
1
7
  <% unless has_search_parameters? %>
2
8
  <%# if there are no input/search related params, display the "home" partial -%>
3
9
  <%= render 'home' %>
10
+ <%= render 'shared/sitelinks_search_box' %>
4
11
  <% else %>
5
- <div id="sidebar" class="col-md-3 col-sm-4">
6
- <%= render 'search_sidebar' %>
7
- </div>
8
-
9
- <div id="content" class="col-md-9 col-sm-8">
10
- <%= render 'search_results' %>
11
- </div>
12
- <% end %>
12
+ <%= render 'search_results' %>
13
+ <% end %>
@@ -1,8 +1,8 @@
1
- <li>
1
+ <li class="list-group-item relations-ancestors">
2
2
  <b><%= t('geoblacklight.relations.ancestor') %></b>
3
3
  </li>
4
4
  <% @relations.ancestors['docs'].each do |ancestor| %>
5
- <li>
5
+ <li class="list-group-item">
6
6
  <%= link_to solr_document_path(ancestor['layer_slug_s']) do %>
7
7
  <span class='geoblacklight geoblacklight-relations-ancestor'></span> <%= ancestor['dc_title_s'] %>
8
8
  <% end %>
@@ -1,15 +1,15 @@
1
- <li>
1
+ <li class="list-group-item relations-descendants">
2
2
  <b><%= t('geoblacklight.relations.descendant', count: @relations.descendants['numFound']) %></b>
3
3
  </li>
4
4
  <% @relations.descendants['docs'][0..2].each do |descendant| %>
5
- <li>
5
+ <li class="list-group-item">
6
6
  <%= link_to solr_document_path(descendant['layer_slug_s']) do %>
7
7
  <span class='geoblacklight geoblacklight-relations-descendant'></span> <%= descendant['dc_title_s'] %>
8
8
  <% end %>
9
9
  </li>
10
10
  <% end %>
11
11
  <% unless (@relations.descendants['numFound'].to_i <= 3) %>
12
- <li>
12
+ <li class="list-group-item">
13
13
  <%= link_to search_catalog_path({f: {"#{Settings.FIELDS.SOURCE}" => [@relations.search_id]}}) do %>
14
14
  <%= t('geoblacklight.relations.browse_all', count: @relations.descendants['numFound']) %>
15
15
  <% end %>
@@ -1,13 +1,13 @@
1
1
  <% unless @relations.empty? %>
2
- <div class="panel panel-default show-tools">
3
- <div class="panel-heading">
2
+ <div class="card relations">
3
+ <div class="card-header">
4
4
  <%= t('geoblacklight.relations.title') %>
5
5
  </div>
6
- <div class="panel-body">
7
- <ul class="nav">
8
- <%= render 'ancestors' unless @relations.ancestors['numFound'].to_i == 0 %>
9
- <%= render 'descendants' unless @relations.descendants['numFound'].to_i == 0 %>
10
- </ul>
11
- </div>
6
+
7
+ <ul class="list-group list-group-flush">
8
+ <%= render 'ancestors' unless @relations.ancestors['numFound'].to_i == 0 %>
9
+ <%= render 'descendants' unless @relations.descendants['numFound'].to_i == 0 %>
10
+ </ul>
11
+
12
12
  </div>
13
13
  <% end %>
@@ -1,25 +1,36 @@
1
- <div id="header-navbar" class="navbar navbar-inverse navbar-static-top" role="navigation">
2
- <div class="container">
3
- <div class="navbar-header">
4
- <button type="button" class="navbar-toggle" data-toggle="collapse" data-target="#user-util-collapse">
5
- <span class="sr-only">Toggle navigation</span>
6
- <span class="icon-bar"></span>
7
- <span class="icon-bar"></span>
8
- <span class="icon-bar"></span>
1
+ <nav class="navbar navbar-expand-md navbar-dark bg-dark topbar" role="navigation">
2
+ <div class="<%= container_classes %>">
3
+ <%= link_to application_name, root_path, class: 'mb-0 navbar-brand' %>
4
+ <button class="navbar-toggler navbar-toggler-right" type="button" data-toggle="collapse" data-target="#user-util-collapse" aria-controls="user-util-collapse" aria-expanded="false" aria-label="Toggle navigation">
5
+ <span class="navbar-toggler-icon"></span>
9
6
  </button>
10
- <%= link_to application_name, root_path, class: "navbar-brand" %>
11
- </div>
12
7
 
13
- <div class="collapse navbar-collapse" id="user-util-collapse">
14
- <%= render :partial=>'/user_util_links' %>
8
+ <div class="collapse navbar-collapse justify-content-md-end" id="user-util-collapse">
9
+ <%= render 'shared/user_util_links' %>
15
10
  </div>
16
11
  </div>
17
- </div>
12
+ </nav>
18
13
 
19
- <% if controller_name == 'catalog' && has_search_parameters? %>
20
- <div id="search-navbar" class="navbar navbar-default navbar-static-top" role="navigation">
21
- <div class="container">
14
+ <% if controller_name == 'catalog' && (has_search_parameters? || params[:action] == 'show') %>
15
+ <div class="navbar-search navbar navbar-light bg-faded" role="navigation">
16
+ <div class="<%= container_classes %> stuff">
22
17
  <%= render_search_bar %>
23
18
  </div>
24
19
  </div>
25
- <% end %>
20
+ <% else %>
21
+ <div class='geobl-homepage-masthead jumbotron'>
22
+ <div class='d-flex justify-content-center'>
23
+ <%= content_tag :h2, t('geoblacklight.home.headline'), class: 'text-center' %>
24
+ </div>
25
+ <div class='d-flex justify-content-center'>
26
+ <%= content_tag :h3, t('geoblacklight.home.search_heading'), class: 'text-center' %>
27
+ </div>
28
+ <div class='row justify-content-md-center'>
29
+ <div class='col-md-6 col-sm-12'>
30
+ <div class='navbar-search'>
31
+ <%= render_search_bar %>
32
+ </div>
33
+ </div>
34
+ </div>
35
+ </div>
36
+ <% end %>
@@ -15,7 +15,7 @@ en:
15
15
  error_with_url: 'Sorry, the requested file could not be downloaded. Try downloading it directly from: %{link}'
16
16
  export_formats: 'Export Formats'
17
17
  export_link: 'Export'
18
- export_shapefile_link: 'EPSG:4326 Shapefile'
18
+ export_shapefile_link: 'Shapefile'
19
19
  export_kmz_link: 'KMZ'
20
20
  export_geojson_link: 'GeoJSON'
21
21
  home:
@@ -28,7 +28,7 @@ en:
28
28
  placename: 'Placename'
29
29
  subject: 'Subject'
30
30
  tools:
31
- login_to_view: 'Login to view and download'
31
+ login_to_view: 'Login to View and Download'
32
32
  open_carto: 'Open in Carto'
33
33
  formats:
34
34
  arcgrid: 'ArcGRID'
@@ -20,8 +20,7 @@ Gem::Specification.new do |spec|
20
20
  spec.required_rubygems_version = '>= 2.5.2'
21
21
 
22
22
  spec.add_dependency 'rails', '~> 5.0'
23
- spec.add_dependency 'blacklight', '~> 6.11'
24
- spec.add_dependency 'leaflet-rails', '~> 1.3.0'
23
+ spec.add_dependency 'blacklight', '~> 7.0'
25
24
  spec.add_dependency 'font-awesome-rails'
26
25
  spec.add_dependency 'config'
27
26
  spec.add_dependency 'faraday'
@@ -29,14 +28,15 @@ Gem::Specification.new do |spec|
29
28
  spec.add_dependency 'coderay'
30
29
  spec.add_dependency 'geoblacklight-icons', '>= 0.2'
31
30
  spec.add_dependency 'deprecation'
32
- spec.add_dependency 'geo_combine', '>= 0.3'
31
+ spec.add_dependency 'geo_combine', '~> 0.4'
33
32
  spec.add_dependency 'mime-types'
34
33
  spec.add_dependency 'handlebars_assets'
34
+ spec.add_dependency 'webpacker', '~> 3.5'
35
35
 
36
36
  spec.add_development_dependency 'solr_wrapper'
37
37
  spec.add_development_dependency 'rails-controller-testing'
38
38
  spec.add_development_dependency 'rspec-rails', '~> 3.1'
39
- spec.add_development_dependency 'engine_cart', '~> 1.0'
39
+ spec.add_development_dependency 'engine_cart', '~> 2.0'
40
40
  spec.add_development_dependency 'capybara', '>= 2.5.0'
41
41
  spec.add_development_dependency 'selenium-webdriver'
42
42
  spec.add_development_dependency 'chromedriver-helper'
@@ -45,4 +45,5 @@ Gem::Specification.new do |spec|
45
45
  spec.add_development_dependency 'bixby'
46
46
  spec.add_development_dependency 'coveralls'
47
47
  spec.add_development_dependency 'simplecov', '~> 0.16'
48
+ spec.add_development_dependency 'foreman'
48
49
  end
@@ -36,6 +36,9 @@ module Geoblacklight
36
36
 
37
37
  append_to_file 'config/initializers/assets.rb',
38
38
  "\nRails.application.config.assets.precompile += %w( favicon.ico )\n"
39
+
40
+ append_to_file 'config/initializers/assets.rb',
41
+ "\nRails.application.config.assets.paths << Rails.root.join('vendor', 'assets', 'images')\n"
39
42
  end
40
43
 
41
44
  def create_blacklight_catalog
@@ -80,18 +83,6 @@ module Geoblacklight
80
83
  FileUtils.mkdir_p('tmp/cache/downloads') unless File.directory?('tmp/cache/downloads')
81
84
  end
82
85
 
83
- # Necessary for bootstrap-sass 3.2
84
- def inject_sprockets
85
- blacklight_css = Dir['app/assets/stylesheets/blacklight.scss'].first
86
- if blacklight_css
87
- insert_into_file blacklight_css, before: "@import 'bootstrap';" do
88
- "@import 'bootstrap-sprockets';\n"
89
- end
90
- else
91
- say_status 'warning', 'Can not find blacklight.scss, did not insert our require', :red
92
- end
93
- end
94
-
95
86
  def disable_turbolinks
96
87
  gsub_file('app/assets/javascripts/application.js', %r{\/\/= require turbolinks}, '')
97
88
  end