blacklight-spotlight 3.0.0.rc4 → 3.0.0.rc5

Sign up to get free protection for your applications and to get access to all the features.
Files changed (169) hide show
  1. checksums.yaml +4 -4
  2. data/app/assets/images/blacklight/close.svg +1 -0
  3. data/app/assets/images/blacklight/zoom_in.svg +1 -0
  4. data/app/assets/images/blacklight/zoom_out.svg +1 -0
  5. data/app/assets/javascripts/spotlight/admin/blocks/uploaded_items_block.js +8 -1
  6. data/app/assets/javascripts/spotlight/admin/catalog_edit.js +13 -47
  7. data/app/assets/javascripts/spotlight/admin/exhibit_tag_autocomplete.js +37 -0
  8. data/app/assets/javascripts/spotlight/admin/{reindex_monitor.js → progress_monitor.js} +25 -4
  9. data/app/assets/javascripts/spotlight/admin/sir-trevor/locales.js +1 -1
  10. data/app/assets/javascripts/spotlight/user/zpr_links.js.erb +29 -14
  11. data/app/assets/stylesheets/spotlight/_browse.scss +8 -0
  12. data/app/assets/stylesheets/spotlight/_catalog.scss +30 -4
  13. data/app/assets/stylesheets/spotlight/_exhibit_admin.scss +9 -0
  14. data/app/assets/stylesheets/spotlight/_modals.scss +3 -0
  15. data/app/assets/stylesheets/spotlight/_nestable.scss +8 -0
  16. data/app/assets/stylesheets/spotlight/_spotlight.scss +2 -0
  17. data/app/assets/stylesheets/spotlight/_view_larger.scss +22 -0
  18. data/app/assets/stylesheets/spotlight/typeahead.css +23 -23
  19. data/app/builders/spotlight/bootstrap_breadcrumbs_builder.rb +4 -2
  20. data/app/controllers/concerns/spotlight/catalog.rb +7 -1
  21. data/app/controllers/spotlight/browse_controller.rb +5 -0
  22. data/app/controllers/spotlight/bulk_actions_controller.rb +62 -0
  23. data/app/controllers/spotlight/bulk_updates_controller.rb +67 -0
  24. data/app/controllers/spotlight/catalog_controller.rb +5 -7
  25. data/app/controllers/spotlight/dashboards_controller.rb +2 -1
  26. data/app/controllers/spotlight/featured_images_controller.rb +1 -1
  27. data/app/controllers/spotlight/job_trackers_controller.rb +17 -0
  28. data/app/controllers/spotlight/tags_controller.rb +39 -5
  29. data/app/helpers/spotlight/application_helper.rb +1 -1
  30. data/app/helpers/spotlight/job_trackers_helper.rb +31 -0
  31. data/app/helpers/spotlight/pages_helper.rb +0 -7
  32. data/app/helpers/spotlight/roles_helper.rb +1 -1
  33. data/app/jobs/concerns/spotlight/gather_documents.rb +35 -0
  34. data/app/jobs/concerns/spotlight/job_tracking.rb +40 -23
  35. data/app/jobs/spotlight/add_tags_job.rb +31 -0
  36. data/app/jobs/spotlight/add_uploads_from_csv.rb +2 -4
  37. data/app/jobs/spotlight/change_visibility_job.rb +33 -0
  38. data/app/jobs/spotlight/process_bulk_updates_csv_job.rb +82 -0
  39. data/app/jobs/spotlight/reindex_exhibit_job.rb +5 -2
  40. data/app/jobs/spotlight/reindex_job.rb +35 -23
  41. data/app/jobs/spotlight/remove_tags_job.rb +31 -0
  42. data/app/jobs/spotlight/rename_sidecar_field_job.rb +1 -0
  43. data/app/jobs/spotlight/rename_tags_job.rb +33 -0
  44. data/app/models/concerns/spotlight/exhibit_analytics.rb +2 -6
  45. data/app/models/concerns/spotlight/exhibit_documents.rb +2 -2
  46. data/app/models/concerns/spotlight/resources/web.rb +1 -1
  47. data/app/models/concerns/spotlight/solr_document.rb +1 -1
  48. data/app/models/concerns/spotlight/solr_document/atomic_updates.rb +2 -2
  49. data/app/models/concerns/spotlight/user.rb +5 -1
  50. data/app/models/sir_trevor_rails/blocks/uploaded_items_block.rb +4 -0
  51. data/app/models/spotlight/ability.rb +6 -2
  52. data/app/models/spotlight/attachment.rb +1 -1
  53. data/app/models/spotlight/{reindex_progress.rb → background_job_progress.rb} +8 -7
  54. data/app/models/spotlight/blacklight_configuration.rb +17 -6
  55. data/app/models/spotlight/bulk_update.rb +8 -0
  56. data/app/models/spotlight/exhibit.rb +2 -1
  57. data/app/models/spotlight/feature_page.rb +0 -2
  58. data/app/models/spotlight/featured_image.rb +7 -1
  59. data/app/models/spotlight/field_metadata.rb +4 -8
  60. data/app/models/spotlight/job_tracker.rb +11 -2
  61. data/app/models/spotlight/page.rb +1 -3
  62. data/app/models/spotlight/resource.rb +4 -4
  63. data/app/models/spotlight/resources/iiif_harvester.rb +2 -2
  64. data/app/models/spotlight/resources/iiif_service.rb +8 -1
  65. data/app/models/spotlight/resources/upload.rb +2 -2
  66. data/app/models/spotlight/role.rb +1 -2
  67. data/app/presenters/spotlight/iiif_manifest_presenter.rb +1 -1
  68. data/app/services/spotlight/bulk_updates_csv_template_service.rb +93 -0
  69. data/app/services/spotlight/etl/executor.rb +1 -3
  70. data/app/services/spotlight/iiif_resource_resolver.rb +1 -1
  71. data/app/uploaders/spotlight/bulk_updates_uploader.rb +7 -0
  72. data/app/uploaders/spotlight/featured_image_uploader.rb +1 -1
  73. data/app/views/catalog/_add_tags.html.erb +28 -0
  74. data/app/views/catalog/_bulk_actions.html.erb +12 -0
  75. data/app/views/catalog/_change_visibility.html.erb +35 -0
  76. data/app/views/catalog/_curator_actions.html.erb +3 -0
  77. data/app/views/catalog/_remove_tags.html.erb +37 -0
  78. data/app/views/spotlight/bulk_updates/_download.html.erb +23 -0
  79. data/app/views/spotlight/bulk_updates/_overview.html.erb +1 -0
  80. data/app/views/spotlight/bulk_updates/_progress_panel.html.erb +19 -0
  81. data/app/views/spotlight/bulk_updates/_upload.html.erb +12 -0
  82. data/app/views/spotlight/bulk_updates/edit.html.erb +37 -0
  83. data/app/views/spotlight/catalog/_admin_header.html.erb +1 -1
  84. data/app/views/spotlight/catalog/_edit_default.html.erb +2 -2
  85. data/app/views/spotlight/catalog/_reindex_progress_panel.html.erb +1 -1
  86. data/app/views/spotlight/custom_fields/_form.html.erb +1 -1
  87. data/app/views/spotlight/custom_search_fields/_form.html.erb +1 -1
  88. data/app/views/spotlight/dashboards/_reindexing_activity.html.erb +1 -1
  89. data/app/views/spotlight/exhibits/_exhibit_card.html.erb +1 -1
  90. data/app/views/spotlight/job_trackers/show.html.erb +79 -0
  91. data/app/views/spotlight/pages/_form.html.erb +2 -2
  92. data/app/views/spotlight/resources/_form.html.erb +1 -1
  93. data/app/views/spotlight/resources/csv_upload/_form.html.erb +1 -1
  94. data/app/views/spotlight/resources/iiif/_form.html.erb +1 -1
  95. data/app/views/spotlight/resources/json_upload/_form.html.erb +2 -2
  96. data/app/views/spotlight/resources/upload/_form.html.erb +1 -1
  97. data/app/views/spotlight/shared/_curation_sidebar.html.erb +3 -0
  98. data/app/views/spotlight/sir_trevor/blocks/_browse_group_categories_block.html.erb +3 -3
  99. data/app/views/spotlight/sir_trevor/blocks/_solr_documents_block.html.erb +3 -3
  100. data/app/views/spotlight/sir_trevor/blocks/_solr_documents_carousel_block.html.erb +2 -2
  101. data/app/views/spotlight/sir_trevor/blocks/_solr_documents_features_block.html.erb +2 -2
  102. data/app/views/spotlight/sir_trevor/blocks/_solr_documents_grid_block.html.erb +2 -2
  103. data/app/views/spotlight/sir_trevor/blocks/_uploaded_items_block.html.erb +4 -0
  104. data/app/views/spotlight/tags/_tag.html.erb +24 -0
  105. data/app/views/spotlight/tags/index.html.erb +12 -16
  106. data/app/views/spotlight/translations/show.yaml.yamlbuilder +6 -0
  107. data/config/i18n-tasks.yml +1 -0
  108. data/config/locales/spotlight.en.yml +169 -10
  109. data/config/routes.rb +28 -1
  110. data/db/migrate/20210126123041_create_events.rb +1 -1
  111. data/db/migrate/20210305070001_remove_class_from_sirtrevor_image_blocks.rb +20 -0
  112. data/db/migrate/20210305171150_create_bulk_updates.rb +9 -0
  113. data/lib/generators/spotlight/templates/config/initializers/riiif.rb +7 -5
  114. data/lib/generators/spotlight/templates/config/initializers/spotlight_initializer.rb +1 -1
  115. data/lib/generators/spotlight/templates/solr/config/schema.xml +1 -1
  116. data/lib/migration/iiif.rb +3 -3
  117. data/lib/spotlight/engine.rb +14 -0
  118. data/lib/spotlight/version.rb +1 -1
  119. data/spec/controllers/spotlight/bulk_actions_controller_spec.rb +124 -0
  120. data/spec/controllers/spotlight/bulk_updates_controller_spec.rb +77 -0
  121. data/spec/controllers/spotlight/catalog_controller_spec.rb +12 -12
  122. data/spec/controllers/spotlight/featured_images_controller_spec.rb +3 -3
  123. data/spec/controllers/spotlight/job_trackers_controller_spec.rb +37 -0
  124. data/spec/controllers/spotlight/tags_controller_spec.rb +5 -1
  125. data/spec/examples.txt +1495 -1443
  126. data/spec/factories/bulk_updates.rb +15 -0
  127. data/spec/factories/exhibits.rb +4 -0
  128. data/spec/factories/job_trackers.rb +2 -0
  129. data/spec/factories/users.rb +27 -8
  130. data/spec/features/add_items_spec.rb +1 -1
  131. data/spec/features/bulk_actions_spec.rb +72 -0
  132. data/spec/features/catalog_spec.rb +1 -0
  133. data/spec/features/import_exhibit_spec.rb +5 -1
  134. data/spec/features/javascript/blocks/solr_documents_block_spec.rb +3 -3
  135. data/spec/features/javascript/blocks/uploaded_items_block_spec.rb +27 -1
  136. data/spec/features/site_users_management_spec.rb +4 -4
  137. data/spec/fixtures/bulk-update-template.csv +57 -0
  138. data/spec/fixtures/updated-bulk-update-template-w-tags.csv +4 -0
  139. data/spec/fixtures/updated-bulk-update-template.csv +4 -0
  140. data/spec/helpers/spotlight/application_helper_spec.rb +0 -1
  141. data/spec/helpers/spotlight/pages_helper_spec.rb +0 -15
  142. data/spec/helpers/spotlight/roles_helper_spec.rb +1 -1
  143. data/spec/i18n_spec.rb +1 -0
  144. data/spec/jobs/spotlight/add_tags_job_spec.rb +34 -0
  145. data/spec/jobs/spotlight/add_uploads_from_csv_spec.rb +4 -1
  146. data/spec/jobs/spotlight/change_visibility_job_spec.rb +30 -0
  147. data/spec/jobs/spotlight/process_bulk_updates_csv_job_spec.rb +78 -0
  148. data/spec/jobs/spotlight/reindex_job_spec.rb +4 -1
  149. data/spec/jobs/spotlight/remove_tags_job_spec.rb +39 -0
  150. data/spec/lib/migration/iiif_spec.rb +1 -1
  151. data/spec/models/spotlight/ability_spec.rb +27 -0
  152. data/spec/models/spotlight/{reindex_progress_spec.rb → background_job_progress_spec.rb} +15 -2
  153. data/spec/models/spotlight/blacklight_configuration_spec.rb +8 -3
  154. data/spec/models/spotlight/exhibit_spec.rb +1 -1
  155. data/spec/models/spotlight/featured_image_spec.rb +1 -1
  156. data/spec/models/spotlight/resource_spec.rb +23 -0
  157. data/spec/models/spotlight/solr_document/atomic_updates_spec.rb +10 -0
  158. data/spec/services/spotlight/bulk_updates_csv_template_service_spec.rb +26 -0
  159. data/spec/test_app_templates/Gemfile.extra +1 -0
  160. data/spec/uploaders/spotlight/featured_image_uploader_spec.rb +2 -2
  161. data/spec/views/spotlight/catalog/_edit_default.html.erb_spec.rb +1 -1
  162. data/spec/views/spotlight/dashboards/_reindexing_activity.html.erb_spec.rb +2 -0
  163. data/spec/views/spotlight/job_trackers/show.html.erb_spec.rb +65 -0
  164. data/spec/views/spotlight/tags/index.html.erb_spec.rb +5 -2
  165. metadata +80 -17
  166. data/app/assets/images/blacklight/add_circle.svg +0 -1
  167. data/app/assets/images/blacklight/custom_fullscreen.svg +0 -1
  168. data/app/assets/images/blacklight/remove_circle.svg +0 -1
  169. data/app/assets/images/blacklight/resize_small.svg +0 -1
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 55231336b3b4a0eae1abdd68bbeb8ede968d5ffbe4359f29f83a3a27124a4b05
4
- data.tar.gz: b2f2bfc6230b5081493484393a26670961486217b64b7a96b9659979eab64381
3
+ metadata.gz: 8e21e66d81a96d330d76726b9a41e44ea7495653b75d9d5b211f4a607cc4afec
4
+ data.tar.gz: 9f6cc613d234db387773a9b80ae7a72e7c3610ab01996a116df4997668dc0703
5
5
  SHA512:
6
- metadata.gz: c3d2a9d1203e0950c79844e4fad0b2083e3cc8d1b63a357ce47a2760ac48b13ec9c2f4e2f0890add8a533d71f61bf7a96a684b74710c564b3e17d919635b592a
7
- data.tar.gz: 842054ed3d1c5d46c5c6f9bb3180efdf83feee8f1bf44ae607865d6bea2f9d4589e1b19990cbb53a65ba4249fd5794dca213830be71b055a28b69e188b29dde7
6
+ metadata.gz: dc889b0bf136bde52dcb6e8d99776be47261cff5e4310ad3297018e77d5d25818f46df0d874ac379dfa91f8177a648135e84f4ef0ee5810c30bc3d87c90caed8
7
+ data.tar.gz: efe143a5c7125d9b6d18aa972d2a1c4357cf2c42f34ed62c0b2b402af4d16c6473087c63b3cb605a07127edb2f65a0d038772037bb7560ca5497a734f6b89bfd
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" height="24" viewBox="0 0 24 24" width="24"><path d="M0 0h24v24H0V0z" fill="none"/><path d="M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12 19 6.41z"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" height="24" viewBox="0 0 24 24" width="24"><path d="M0 0h24v24H0V0z" fill="none"/><path d="M15.5 14h-.79l-.28-.27C15.41 12.59 16 11.11 16 9.5 16 5.91 13.09 3 9.5 3S3 5.91 3 9.5 5.91 16 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19l-4.99-5zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14zm.5-7H9v2H7v1h2v2h1v-2h2V9h-2z"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" height="24" viewBox="0 0 24 24" width="24"><path d="M0 0h24v24H0V0z" fill="none"/><path d="M15.5 14h-.79l-.28-.27C15.41 12.59 16 11.11 16 9.5 16 5.91 13.09 3 9.5 3S3 5.91 3 9.5 5.91 16 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19l-4.99-5zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14zM7 9h5v1H7V9z"/></svg>
@@ -130,9 +130,16 @@ SirTrevor.Blocks.UploadedItems = (function(){
130
130
  '</div>',
131
131
  '<input type="file" id="uploaded_item_url" name="file[file_0][file_data]" />',
132
132
  '</div>',
133
+ '<div class="col-md-4">',
134
+ '<input name="<%= zpr_key %>" type="hidden" value="false" />',
135
+ '<input name="<%= zpr_key %>" id="<%= formId(zpr_key) %>" data-key="<%= zpr_key %>" type="checkbox" value="true" />',
136
+ '<label for="<%= formId(zpr_key) %>"><%= i18n.t("blocks:solr_documents:zpr:title") %></label>',
137
+ '</div>',
133
138
  '</div>',
134
139
  '<%= text_area() %>',
135
140
  '</div>'
136
- ].join("\n")
141
+ ].join("\n"),
142
+
143
+ zpr_key: 'zpr_link'
137
144
  });
138
145
  })();
@@ -1,50 +1,16 @@
1
1
  Spotlight.onLoad(function() {
2
- if($('#solr_document_exhibit_tag_list').length > 0) {
3
- // By default tags input binds on page ready to [data-role=tagsinput],
4
- // however, that doesn't work with Turbolinks. So we init manually:
5
- $('#solr_document_exhibit_tag_list').tagsinput();
6
-
7
- var tags = new Bloodhound({
8
- datumTokenizer: function(d) { return Bloodhound.tokenizers.whitespace(d.name); },
9
- queryTokenizer: Bloodhound.tokenizers.whitespace,
10
- limit: 100,
11
- prefetch: {
12
- url: $('#solr_document_exhibit_tag_list').data('autocomplete_url'),
13
- ttl: 1,
14
- filter: function(list) {
15
- return $.map(list, function(tag) { return { name: tag }; });
16
- }
2
+ $(".visiblity_toggle").blCheckboxSubmit({
3
+ //css_class is added to elements added, plus used for id base
4
+ cssClass: "toggle_visibility",
5
+ //success is called at the end of the ajax success callback
6
+ success: function (isPublic){
7
+ // We store the selector of the label to toggle in a data attribute in the form
8
+ var docTarget = $($(this).data("label-toggle-target"));
9
+ if ( isPublic ) {
10
+ docTarget.removeClass("blacklight-private");
11
+ } else {
12
+ docTarget.addClass("blacklight-private");
17
13
  }
18
- });
19
-
20
- tags.initialize();
21
-
22
- $('#solr_document_exhibit_tag_list').tagsinput('input').typeahead({highlight: true, hint: false}, {
23
- name: 'tags',
24
- displayKey: 'name',
25
- source: tags.ttAdapter()
26
- }).bind('typeahead:selected', $.proxy(function (obj, datum) {
27
- $('#solr_document_exhibit_tag_list').tagsinput('add', datum.name);
28
- $('#solr_document_exhibit_tag_list').tagsinput('input').typeahead('val', '');
29
- })).bind('blur', function() {
30
- $('#solr_document_exhibit_tag_list').tagsinput('add', $('#solr_document_exhibit_tag_list').tagsinput('input').typeahead('val'));
31
- $('#solr_document_exhibit_tag_list').tagsinput('input').typeahead('val', '');
32
- });
33
- }
34
-
35
- $(".visiblity_toggle").blCheckboxSubmit({
36
- //css_class is added to elements added, plus used for id base
37
- cssClass: "toggle_visibility",
38
- //success is called at the end of the ajax success callback
39
- success: function (isPublic){
40
- // We store the selector of the label to toggle in a data attribute in the form
41
- var docTarget = $($(this).data("label-toggle-target"));
42
- if ( isPublic ) {
43
- docTarget.removeClass("blacklight-private");
44
- } else {
45
- docTarget.addClass("blacklight-private");
46
- }
47
- }
48
- });
49
-
14
+ }
15
+ });
50
16
  });
@@ -0,0 +1,37 @@
1
+ Spotlight.onLoad(function() {
2
+ $('[data-autocomplete-tag="true"]').each(function(_i, el) {
3
+ var $el = $(el);
4
+ // By default tags input binds on page ready to [data-role=tagsinput],
5
+ // however, that doesn't work with Turbolinks. So we init manually:
6
+ $el.tagsinput();
7
+
8
+ var tags = new Bloodhound({
9
+ datumTokenizer: function(d) { return Bloodhound.tokenizers.whitespace(d.name); },
10
+ queryTokenizer: Bloodhound.tokenizers.whitespace,
11
+ limit: 100,
12
+ prefetch: {
13
+ url: $el.data('autocomplete-url'),
14
+ ttl: 1,
15
+ filter: function(list) {
16
+ // Let the dom know that the response has been returned
17
+ $el.attr('data-autocomplete-fetched', true);
18
+ return $.map(list, function(tag) { return { name: tag }; });
19
+ }
20
+ }
21
+ });
22
+
23
+ tags.initialize();
24
+
25
+ $el.tagsinput('input').typeahead({highlight: true, hint: false}, {
26
+ name: 'tags',
27
+ displayKey: 'name',
28
+ source: tags.ttAdapter()
29
+ }).bind('typeahead:selected', $.proxy(function (obj, datum) {
30
+ $el.tagsinput('add', datum.name);
31
+ $el.tagsinput('input').typeahead('val', '');
32
+ })).bind('blur', function() {
33
+ $el.tagsinput('add', $el.tagsinput('input').typeahead('val'));
34
+ $el.tagsinput('input').typeahead('val', '');
35
+ });
36
+ });
37
+ });
@@ -1,9 +1,9 @@
1
1
  Spotlight.onLoad(function() {
2
- $('[data-behavior="reindex-monitor"]').reindexMonitor();
2
+ $('[data-behavior="progress-panel"]').progressMonitor();
3
3
  });
4
4
 
5
5
  (function($) {
6
- $.fn.reindexMonitor = function() {
6
+ $.fn.progressMonitor = function() {
7
7
  var monitorElements = this;
8
8
  var defaultRefreshRate = 3000;
9
9
  var panelContainer;
@@ -11,6 +11,7 @@ Spotlight.onLoad(function() {
11
11
 
12
12
  $(monitorElements).each(function() {
13
13
  panelContainer = $(this);
14
+ panelContainer.hide();
14
15
  var monitorUrl = panelContainer.data('monitorUrl');
15
16
  var refreshRate = panelContainer.data('refreshRate') || defaultRefreshRate;
16
17
  pollers.push(
@@ -48,10 +49,14 @@ Spotlight.onLoad(function() {
48
49
  function updateMonitorPanel(data) {
49
50
  panelStartDate().text(data.started_at);
50
51
  panelCurrentDate().text(data.updated_at);
51
- panelCompleted().text(data.completed);
52
+ panelCompletedDate().text(data.updated_at);
53
+ panelCurrent().text(data.completed);
54
+ setPanelCompleted(data.finished);
52
55
  updatePanelTotals(data);
53
56
  updatePanelErrorMessage(data);
54
57
  updateProgressBar(data);
58
+
59
+ panelContainer.show();
55
60
  }
56
61
 
57
62
  function updateProgressBar(data) {
@@ -104,11 +109,17 @@ Spotlight.onLoad(function() {
104
109
  .find('[data-behavior="date"]');
105
110
  }
106
111
 
112
+ function panelCompletedDate() {
113
+ return monitorPanel()
114
+ .find('[data-behavior="monitor-completed"]')
115
+ .find('[data-behavior="date"]');
116
+ }
117
+
107
118
  function panelTotals() {
108
119
  return monitorPanel().find('[data-behavior="total"]');
109
120
  }
110
121
 
111
- function panelCompleted() {
122
+ function panelCurrent() {
112
123
  return monitorPanel()
113
124
  .find('[data-behavior="monitor-current"]')
114
125
  .find('[data-behavior="completed"]');
@@ -122,6 +133,16 @@ Spotlight.onLoad(function() {
122
133
  return monitorPanel().find('[data-behavior="monitor-error"]');
123
134
  }
124
135
 
136
+ function setPanelCompleted(finished) {
137
+ var panel = monitorPanel().find('[data-behavior="monitor-completed"]');
138
+
139
+ if (finished) {
140
+ panel.show();
141
+ } else {
142
+ panel.hide();
143
+ }
144
+ }
145
+
125
146
  return this;
126
147
  };
127
148
  })(jQuery);
@@ -72,7 +72,7 @@ SirTrevor.Locales.en.blocks = $.extend(SirTrevor.Locales.en.blocks, {
72
72
  secondary: "Secondary caption"
73
73
  },
74
74
  zpr: {
75
- title: 'Display ZPR link'
75
+ title: 'Offer "View larger" option'
76
76
  }
77
77
  },
78
78
 
@@ -1,29 +1,44 @@
1
1
  Spotlight.onLoad(function(){
2
2
  $('.zpr-link').on('click', function() {
3
- $('#blacklight-modal .modal-content').html('<div id="osd-modal-container"></div>');
3
+ var modalDialog = $('#blacklight-modal .modal-dialog');
4
+ var modalContent = modalDialog.find('.modal-content')
5
+ modalDialog.removeClass('modal-lg')
6
+ modalDialog.addClass('modal-xl')
7
+ modalContent.html('<div id="osd-modal-container"></div>');
4
8
  var controls = [
5
- '<div class="controls">',
6
- ' <a id="osd-zoom-in"><%= Blacklight::Icon.new('add_circle').file_source.strip %></a>',
7
- ' <a id="osd-zoom-out"><%= Blacklight::Icon.new('remove_circle').file_source.strip %></a>',
8
- ' <a id="osd-home"><%= Blacklight::Icon.new('resize_small').file_source.strip %></a>',
9
- ' <a id="osd-full-page"><%= Blacklight::Icon.new('custom_fullscreen').file_source.strip %></a>',
9
+ '<div class="controls d-flex justify-content-center justify-content-md-end">',
10
+ ' <div class="custom-close-controls pr-3 pt-3">',
11
+ ' <button type="button" class="btn btn-dark" data-dismiss="modal" aria-hidden="true"><%= Blacklight::Icon.new('close').file_source.strip %></button>',
12
+ ' </div>',
13
+ ' <div class="zoom-controls mb-3 mr-md-3">',
14
+ ' <button id="osd-zoom-in" type="button" class="btn btn-dark"><%= Blacklight::Icon.new('zoom_in').file_source.strip %></button>',
15
+ ' <button id="osd-zoom-out" type="button" class="btn btn-dark"><%= Blacklight::Icon.new('zoom_out').file_source.strip %></button>',
16
+ ' </div>',
17
+ ' <div id="empty-div-required-by-osd"></div>',
10
18
  '</div>'
11
19
  ].join("\n");
12
20
 
13
- $('#osd-modal-container').append(controls);
21
+
14
22
  $('#osd-modal-container').append('<div id="osd-div"></div>');
15
- $('#osd-div').css('height', '400px');
23
+ $('#osd-modal-container').append(controls);
16
24
 
17
25
  $('#blacklight-modal').modal('show');
26
+
27
+ $('#blacklight-modal').one('hidden.bs.modal', function (event) {
28
+ modalDialog.removeClass('modal-xl')
29
+ modalDialog.addClass('modal-lg')
30
+ });
18
31
 
19
32
  OpenSeadragon({
20
33
  id: 'osd-div',
21
- zoomInButton: "osd-zoom-in",
22
- zoomOutButton: "osd-zoom-out",
23
- homeButton: "osd-home",
24
- fullPageButton: "osd-full-page",
25
- nextButton: "osd-next",
26
- previousButton: "osd-previous",
34
+ zoomInButton: "osd-zoom-in",
35
+ zoomOutButton: "osd-zoom-out",
36
+ // This is a hack where OpenSeadragon (if using mapped buttons) requires you
37
+ // to map all of the buttons.
38
+ homeButton: "empty-div-required-by-osd",
39
+ fullPageButton: "empty-div-required-by-osd",
40
+ nextButton: "empty-div-required-by-osd",
41
+ previousButton: "empty-div-required-by-osd",
27
42
  tileSources: [$(this).data('iiif-tilesource')]
28
43
  })
29
44
  });
@@ -38,6 +38,14 @@ $image-overlay-max-height: 300px;
38
38
  }
39
39
  }
40
40
 
41
+ #main-container .browse-group-navigation.nav {
42
+ margin-bottom: $spacer;
43
+
44
+ .nav-link {
45
+ margin-bottom: $spacer * .75;
46
+ }
47
+ }
48
+
41
49
  .browse-landing {
42
50
  text-align: center;
43
51
  // Placeholder for vertically alignment - might already be available from use in another feature
@@ -73,7 +73,6 @@ form.edit_solr_document {
73
73
  .bootstrap-tagsinput {
74
74
  @extend .clearfix;
75
75
  cursor: text;
76
- display: block;
77
76
  }
78
77
  .bg-warning.form-text {
79
78
  font-size: 0.9em;
@@ -82,6 +81,7 @@ form.edit_solr_document {
82
81
  }
83
82
 
84
83
  .bootstrap-tagsinput {
84
+ display: block;
85
85
  .twitter-typeahead {
86
86
  width: auto;
87
87
  }
@@ -117,9 +117,35 @@ form.edit_solr_document {
117
117
  @extend .clearfix;
118
118
  }
119
119
 
120
- #save-this-search {
121
- float:left;
122
- margin-right: $spacer * 0.1;
120
+ #sortAndPerPage {
121
+ align-items: flex-end;
122
+ }
123
+
124
+ .search-widgets {
125
+ align-items: flex-start;
126
+ display: flex;
127
+ @media (min-width: breakpoint-min("md")) {
128
+ justify-content: flex-end;
129
+ }
130
+ flex-wrap: wrap;
131
+ width: 60%;
132
+ margin-left: -1 * $spacer * 0.1;
133
+
134
+ .btn, .btn-group {
135
+ margin-left: $spacer * 0.1;
136
+ margin-top: $spacer * 0.25;
137
+ }
138
+ }
139
+
140
+ .curator-actions {
141
+ align-items: flex-start;
142
+ display: flex;
143
+ @media (min-width: breakpoint-min("md")) {
144
+ justify-content: flex-end;
145
+ }
146
+ order: -1;
147
+ width: 100%;
148
+ margin-left: -1 * $spacer * 0.1;
123
149
  }
124
150
 
125
151
  #document,
@@ -70,3 +70,12 @@
70
70
  display: inline;
71
71
  }
72
72
  }
73
+
74
+ .download-csv {
75
+ align-items: flex-end;
76
+ display: flex;
77
+
78
+ .btn-primary {
79
+ margin-bottom: $spacer;
80
+ }
81
+ }
@@ -0,0 +1,3 @@
1
+ .modal-body .form-check-label {
2
+ margin-bottom: 0.5rem;
3
+ }
@@ -114,3 +114,11 @@ tr.dd-item {
114
114
  .dd3-content .card-header {
115
115
  padding: .5rem 1rem
116
116
  }
117
+
118
+ .dd3-content.tag {
119
+ .dd3-handle {
120
+ display: none;
121
+ }
122
+
123
+ padding-left: 0;
124
+ }
@@ -19,6 +19,7 @@
19
19
  @import "spotlight/featured_browse_categories_block";
20
20
  @import "spotlight/item_text_block";
21
21
  @import "spotlight/uploaded_items_block";
22
+ @import "spotlight/modals";
22
23
  @import "spotlight/multi_image_selector";
23
24
  @import "spotlight/multi_up_item_grid";
24
25
  @import "spotlight/slideshow_block";
@@ -33,6 +34,7 @@
33
34
  @import "spotlight/collapse_toggle";
34
35
  @import "spotlight/translations";
35
36
  @import "spotlight/utilities";
37
+ @import "spotlight/view_larger";
36
38
  @import "spotlight/accessibility";
37
39
 
38
40
 
@@ -0,0 +1,22 @@
1
+ #osd-modal-container {
2
+ .controls {
3
+ .custom-close-controls {
4
+ position: absolute;
5
+ right: 0;
6
+ top: 0;
7
+ }
8
+
9
+ .zoom-controls {
10
+ bottom: 0;
11
+ position: absolute;
12
+ z-index: 999;
13
+ }
14
+ svg {
15
+ fill: $white;
16
+ }
17
+ }
18
+ #osd-div {
19
+ background: $gray-700;
20
+ height: calc(100vh - 80px);
21
+ }
22
+ }
@@ -41,37 +41,37 @@
41
41
  .tt-suggestion {
42
42
  font-size: 18px;
43
43
  line-height: 24px;
44
- padding: 3px 20px 3px 100px;
44
+ padding: 3px 1rem 3px 1rem;
45
45
  margin-bottom: 1em;
46
46
 
47
47
  &.tt-cursor {
48
48
  color: #fff;
49
49
  background-color: #0097cf;
50
50
  }
51
- p {
52
- margin: 0;
53
- }
54
- .document-thumbnail {
55
- float: left;
56
- width: 60px;
57
- padding: 0;
58
- margin: 0;
59
- margin-left: -80px;
60
- position: relative;
51
+ }
52
+ }
53
+
54
+ .tt-dataset-tags {
55
+ p {
56
+ white-space: nowrap !important;
57
+ }
58
+ }
61
59
 
62
- img {
63
- max-width: 60px;
64
- max-height: 60px;
65
- }
60
+ .autocomplete-item {
61
+ display: flex;
62
+
63
+ p {
64
+ margin: 0;
65
+ }
66
+ .document-thumbnail {
67
+ margin-right: 1rem;
68
+ min-width: 60px;
69
+ padding: 0;
70
+ width: 60px;
66
71
 
67
- img:hover {
68
- position: absolute;
69
- right: -3px;
70
- top: -3px;
71
- max-width: 160px;
72
- max-height: 100px;
73
- border: 3px solid theme-colors("info");
74
- }
72
+ img {
73
+ max-width: 60px;
74
+ max-height: 60px;
75
75
  }
76
76
  }
77
77
  }