hyrax 3.4.2 → 4.0.0.beta1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (435) hide show
  1. checksums.yaml +4 -4
  2. data/.circleci/config.yml +41 -61
  3. data/.dassie/Gemfile +4 -4
  4. data/.dassie/app/assets/javascripts/application.js +8 -4
  5. data/.dassie/app/assets/stylesheets/application.css +1 -1
  6. data/.dassie/app/assets/stylesheets/hyrax.scss +1 -2
  7. data/.dassie/app/controllers/application_controller.rb +1 -3
  8. data/.dassie/app/controllers/catalog_controller.rb +23 -19
  9. data/.dassie/app/models/user.rb +0 -3
  10. data/.dassie/config/application.rb +1 -1
  11. data/.dassie/config/initializers/riiif.rb +1 -1
  12. data/.dassie/db/schema.rb +5 -5
  13. data/.dassie/package.json +7 -7
  14. data/.engine_cart.yml +2 -39
  15. data/.env +1 -0
  16. data/.regen +2 -1
  17. data/.rubocop.yml +1 -1
  18. data/CONTRIBUTING.md +22 -24
  19. data/Dockerfile +1 -1
  20. data/Rakefile +0 -4
  21. data/app/actors/hyrax/actors/base_actor.rb +1 -1
  22. data/app/actors/hyrax/actors/create_with_remote_files_actor.rb +5 -11
  23. data/app/actors/hyrax/actors/file_actor.rb +9 -37
  24. data/app/actors/hyrax/actors/file_set_actor.rb +13 -62
  25. data/app/assets/javascripts/hyrax/app.js.erb +1 -1
  26. data/app/assets/javascripts/hyrax/batch.js +2 -2
  27. data/app/assets/javascripts/hyrax/batch_edit.js +4 -4
  28. data/app/assets/javascripts/hyrax/batch_select_all.js +13 -13
  29. data/app/assets/javascripts/hyrax/browse_everything.js +4 -2
  30. data/app/assets/javascripts/hyrax/collection_types.es6 +1 -1
  31. data/app/assets/javascripts/hyrax/collections/editor.es6 +5 -1
  32. data/app/assets/javascripts/hyrax/dashboard_actions.js +5 -5
  33. data/app/assets/javascripts/hyrax/editor/controlled_vocabulary.es6 +3 -3
  34. data/app/assets/javascripts/hyrax/editor.es6 +3 -3
  35. data/app/assets/javascripts/hyrax/facets.js +6 -4
  36. data/app/assets/javascripts/hyrax/file_manager/member.es6 +1 -1
  37. data/app/assets/javascripts/hyrax/file_manager/save_manager.es6 +2 -2
  38. data/app/assets/javascripts/hyrax/file_manager/sorting.es6 +2 -2
  39. data/app/assets/javascripts/hyrax/file_manager.es6 +2 -17
  40. data/app/assets/javascripts/hyrax/notification.es6 +1 -1
  41. data/app/assets/javascripts/hyrax/permissions/registry.es6 +4 -4
  42. data/app/assets/javascripts/hyrax/permissions/user_controls.es6 +3 -1
  43. data/app/assets/javascripts/hyrax/relationships/confirm_remove_dialog.es6 +1 -1
  44. data/app/assets/javascripts/hyrax/relationships/control.es6 +2 -2
  45. data/app/assets/javascripts/hyrax/relationships/registry_entry.es6 +1 -1
  46. data/app/assets/javascripts/hyrax/reports-buttons.js +9 -9
  47. data/app/assets/javascripts/hyrax/save_work/required_fields.es6 +1 -1
  48. data/app/assets/javascripts/hyrax/save_work/save_work_control.es6 +6 -6
  49. data/app/assets/javascripts/hyrax/save_work/uploaded_files.es6 +2 -2
  50. data/app/assets/javascripts/hyrax/single_use_links_manager.js +1 -1
  51. data/app/assets/javascripts/hyrax/skip_to_content.js +1 -1
  52. data/app/assets/javascripts/hyrax/sorting.js +1 -1
  53. data/app/assets/javascripts/hyrax/trophy.js +1 -1
  54. data/app/assets/javascripts/hyrax/uploader.js +3 -3
  55. data/app/assets/javascripts/hyrax.js +1 -19
  56. data/app/assets/stylesheets/_bootstrap-default-overrides.scss +4 -4
  57. data/app/assets/stylesheets/hyrax/_accessibility.scss +1 -1
  58. data/app/assets/stylesheets/hyrax/_badge.scss +7 -0
  59. data/app/assets/stylesheets/hyrax/_batch-edit.scss +8 -8
  60. data/app/assets/stylesheets/hyrax/_browse_everything_overrides.scss +1 -1
  61. data/app/assets/stylesheets/hyrax/_buttons.scss +31 -1
  62. data/app/assets/stylesheets/hyrax/_card.scss +10 -0
  63. data/app/assets/stylesheets/hyrax/_catalog.scss +22 -48
  64. data/app/assets/stylesheets/hyrax/_collection_types.scss +1 -1
  65. data/app/assets/stylesheets/hyrax/_collections.scss +13 -13
  66. data/app/assets/stylesheets/hyrax/_facets.scss +46 -0
  67. data/app/assets/stylesheets/hyrax/_featured.scss +1 -1
  68. data/app/assets/stylesheets/hyrax/_file-listing.scss +3 -3
  69. data/app/assets/stylesheets/hyrax/_file_manager.scss +17 -17
  70. data/app/assets/stylesheets/hyrax/_file_sets.scss +1 -1
  71. data/app/assets/stylesheets/hyrax/_file_upload.scss +4 -4
  72. data/app/assets/stylesheets/hyrax/_fixedsticky.scss +1 -1
  73. data/app/assets/stylesheets/hyrax/_footer.scss +3 -3
  74. data/app/assets/stylesheets/hyrax/_form-progress.scss +9 -9
  75. data/app/assets/stylesheets/hyrax/_form.scss +3 -4
  76. data/app/assets/stylesheets/hyrax/_forms.scss +62 -29
  77. data/app/assets/stylesheets/hyrax/_header.scss +0 -17
  78. data/app/assets/stylesheets/hyrax/_home-page.scss +13 -51
  79. data/app/assets/stylesheets/hyrax/_html.scss +11 -0
  80. data/app/assets/stylesheets/hyrax/_hyrax.scss +16 -14
  81. data/app/assets/stylesheets/hyrax/_nestable.scss +1 -1
  82. data/app/assets/stylesheets/hyrax/_select_work_type.scss +2 -2
  83. data/app/assets/stylesheets/hyrax/_styles.scss +9 -14
  84. data/app/assets/stylesheets/hyrax/_users.scss +2 -2
  85. data/app/assets/stylesheets/hyrax/_variables.scss +20 -1
  86. data/app/assets/stylesheets/hyrax/_work-show.scss +21 -13
  87. data/app/assets/stylesheets/hyrax/blacklight_gallery.scss +75 -2
  88. data/app/assets/stylesheets/hyrax/dashboard.scss +70 -95
  89. data/app/assets/stylesheets/hyrax/sidebar.scss +39 -19
  90. data/app/controllers/concerns/hyrax/collections_controller_behavior.rb +9 -0
  91. data/app/controllers/concerns/hyrax/works_controller_behavior.rb +4 -9
  92. data/app/controllers/hyrax/batch_edits_controller.rb +1 -1
  93. data/app/controllers/hyrax/dashboard/nest_collections_controller.rb +0 -32
  94. data/app/controllers/hyrax/file_sets_controller.rb +3 -0
  95. data/app/controllers/hyrax/homepage_controller.rb +0 -1
  96. data/app/controllers/hyrax/my_controller.rb +0 -6
  97. data/app/controllers/hyrax/single_use_links_controller.rb +1 -2
  98. data/app/forms/hyrax/forms/collection_form.rb +1 -1
  99. data/app/helpers/hyrax/facets_helper.rb +150 -0
  100. data/app/helpers/hyrax/hyrax_helper_behavior.rb +5 -5
  101. data/app/indexers/hyrax/basic_metadata_indexer.rb +3 -9
  102. data/app/jobs/characterize_job.rb +4 -7
  103. data/app/jobs/create_derivatives_job.rb +4 -2
  104. data/app/jobs/ingest_local_file_job.rb +5 -13
  105. data/app/jobs/inherit_permissions_job.rb +1 -5
  106. data/app/models/admin_set.rb +0 -8
  107. data/app/models/concerns/hyrax/collection_behavior.rb +1 -1
  108. data/app/models/concerns/hyrax/file_set_behavior.rb +1 -1
  109. data/app/models/concerns/hyrax/in_admin_set.rb +0 -7
  110. data/app/models/concerns/hyrax/user.rb +3 -3
  111. data/app/models/concerns/hyrax/work_behavior.rb +0 -1
  112. data/app/models/content_block.rb +0 -6
  113. data/app/models/hyrax/file_metadata.rb +1 -1
  114. data/app/models/hyrax/permission_template.rb +0 -35
  115. data/app/presenters/hyrax/admin/repository_object_presenter.rb +0 -2
  116. data/app/presenters/hyrax/collapsable_section_presenter.rb +2 -2
  117. data/app/presenters/hyrax/collection_presenter.rb +1 -1
  118. data/app/presenters/hyrax/fixity_status_presenter.rb +2 -2
  119. data/app/presenters/hyrax/menu_presenter.rb +1 -1
  120. data/app/presenters/hyrax/permission_badge.rb +7 -7
  121. data/app/presenters/hyrax/workflow_presenter.rb +1 -1
  122. data/app/renderers/hyrax/renderers/external_link_attribute_renderer.rb +1 -1
  123. data/app/search_builders/hyrax/deposit_search_builder.rb +1 -1
  124. data/app/search_builders/hyrax/nested_collections_parent_search_builder.rb +10 -1
  125. data/app/search_builders/hyrax/single_result.rb +1 -1
  126. data/app/search_builders/hyrax/stats/work_status_search_builder.rb +1 -1
  127. data/app/services/hyrax/adapters/nesting_index_adapter.rb +1 -1
  128. data/app/services/hyrax/collection_member_service.rb +1 -2
  129. data/app/services/hyrax/collections/search_service.rb +0 -1
  130. data/app/services/hyrax/custom_queries.rb +25 -0
  131. data/app/services/hyrax/file_set_csv_service.rb +1 -1
  132. data/app/services/hyrax/graph_exporter.rb +3 -8
  133. data/app/services/hyrax/iiif_authorization_service.rb +1 -1
  134. data/app/services/hyrax/listeners/file_metadata_listener.rb +0 -11
  135. data/app/services/hyrax/search_service.rb +1 -81
  136. data/app/services/hyrax/statistics/depositors/summary.rb +1 -3
  137. data/app/services/hyrax/valkyrie_upload.rb +13 -1
  138. data/app/services/hyrax/work_query_service.rb +1 -1
  139. data/app/services/hyrax/working_directory.rb +2 -0
  140. data/app/views/_controls.html.erb +14 -18
  141. data/app/views/_logo.html.erb +0 -1
  142. data/app/views/_masthead.html.erb +8 -18
  143. data/app/views/_user_util_links.html.erb +16 -18
  144. data/app/views/catalog/_document.html.erb +2 -2
  145. data/app/views/catalog/_document_list.html.erb +1 -1
  146. data/app/views/catalog/_facet_limit.html.erb +1 -1
  147. data/app/views/catalog/_index_gallery_collection_wrapper.html.erb +1 -1
  148. data/app/views/catalog/_index_header_list_collection.html.erb +2 -2
  149. data/app/views/catalog/_index_header_list_default.html.erb +1 -1
  150. data/app/views/catalog/_index_list_default.html.erb +7 -5
  151. data/app/views/catalog/_search_form.html.erb +13 -15
  152. data/app/views/catalog/_thumbnail_list_collection.html.erb +2 -2
  153. data/app/views/catalog/_thumbnail_list_default.html.erb +3 -3
  154. data/app/views/catalog/facet.html.erb +21 -0
  155. data/app/views/catalog/index.html.erb +6 -4
  156. data/app/views/hyrax/admin/admin_sets/_form.html.erb +16 -16
  157. data/app/views/hyrax/admin/admin_sets/_form_participant_table.html.erb +35 -33
  158. data/app/views/hyrax/admin/admin_sets/_form_participants.html.erb +9 -8
  159. data/app/views/hyrax/admin/admin_sets/_form_visibility.html.erb +24 -24
  160. data/app/views/hyrax/admin/admin_sets/_form_workflow.erb +5 -5
  161. data/app/views/hyrax/admin/admin_sets/_show_actions.html.erb +3 -3
  162. data/app/views/hyrax/admin/admin_sets/_show_document_list_row.html.erb +9 -9
  163. data/app/views/hyrax/admin/admin_sets/index.html.erb +3 -3
  164. data/app/views/hyrax/admin/admin_sets/show.html.erb +4 -4
  165. data/app/views/hyrax/admin/analytics/_date_range_form.html.erb +3 -3
  166. data/app/views/hyrax/admin/analytics/collection_reports/_custom_range.html.erb +3 -3
  167. data/app/views/hyrax/admin/analytics/collection_reports/_monthly_summary.html.erb +3 -3
  168. data/app/views/hyrax/admin/analytics/collection_reports/_summary.html.erb +3 -3
  169. data/app/views/hyrax/admin/analytics/collection_reports/_top_collections.html.erb +7 -7
  170. data/app/views/hyrax/admin/analytics/collection_reports/index.html.erb +6 -6
  171. data/app/views/hyrax/admin/analytics/collection_reports/show.html.erb +10 -10
  172. data/app/views/hyrax/admin/analytics/work_reports/_custom_range.html.erb +3 -3
  173. data/app/views/hyrax/admin/analytics/work_reports/_monthly_summary.html.erb +3 -3
  174. data/app/views/hyrax/admin/analytics/work_reports/_summary.html.erb +3 -3
  175. data/app/views/hyrax/admin/analytics/work_reports/_top_file_set_downloads.html.erb +5 -5
  176. data/app/views/hyrax/admin/analytics/work_reports/_top_works.html.erb +7 -7
  177. data/app/views/hyrax/admin/analytics/work_reports/_work_counts.html.erb +4 -4
  178. data/app/views/hyrax/admin/analytics/work_reports/_work_files.html.erb +5 -5
  179. data/app/views/hyrax/admin/analytics/work_reports/index.html.erb +7 -7
  180. data/app/views/hyrax/admin/analytics/work_reports/show.html.erb +10 -10
  181. data/app/views/hyrax/admin/appearances/show.html.erb +2 -2
  182. data/app/views/hyrax/admin/collection_types/_form.html.erb +24 -23
  183. data/app/views/hyrax/admin/collection_types/_form_appearance.html.erb +2 -2
  184. data/app/views/hyrax/admin/collection_types/_form_participants.html.erb +4 -4
  185. data/app/views/hyrax/admin/collection_types/_form_settings.html.erb +9 -9
  186. data/app/views/hyrax/admin/collection_types/index.html.erb +6 -6
  187. data/app/views/hyrax/admin/features/index.html.erb +3 -3
  188. data/app/views/hyrax/admin/stats/_new_users.html.erb +1 -1
  189. data/app/views/hyrax/admin/stats/show.html.erb +4 -6
  190. data/app/views/hyrax/admin/users/index.html.erb +3 -3
  191. data/app/views/hyrax/admin/workflow_roles/index.html.erb +8 -8
  192. data/app/views/hyrax/admin/workflows/index.html.erb +13 -13
  193. data/app/views/hyrax/base/_citations.html.erb +6 -6
  194. data/app/views/hyrax/base/_currently_shared.html.erb +3 -3
  195. data/app/views/hyrax/base/_file_manager_actions.html.erb +5 -3
  196. data/app/views/hyrax/base/_file_manager_member.html.erb +5 -5
  197. data/app/views/hyrax/base/_file_manager_member_resource_options.html.erb +6 -6
  198. data/app/views/hyrax/base/_file_manager_members.html.erb +1 -1
  199. data/app/views/hyrax/base/_file_manager_thumbnail.html.erb +1 -1
  200. data/app/views/hyrax/base/_form_child_work_relationships.html.erb +3 -3
  201. data/app/views/hyrax/base/_form_files.html.erb +9 -9
  202. data/app/views/hyrax/base/_form_member_of_collections.html.erb +3 -3
  203. data/app/views/hyrax/base/_form_metadata.html.erb +1 -1
  204. data/app/views/hyrax/base/_form_permission.html.erb +30 -20
  205. data/app/views/hyrax/base/_form_permission_under_embargo.html.erb +1 -1
  206. data/app/views/hyrax/base/_form_permission_under_lease.html.erb +1 -1
  207. data/app/views/hyrax/base/_form_progress.html.erb +6 -6
  208. data/app/views/hyrax/base/_form_relationships.html.erb +1 -1
  209. data/app/views/hyrax/base/_form_rendering.html.erb +1 -1
  210. data/app/views/hyrax/base/_form_representative.html.erb +1 -1
  211. data/app/views/hyrax/base/_form_share.html.erb +6 -6
  212. data/app/views/hyrax/base/_form_thumbnail.html.erb +1 -1
  213. data/app/views/hyrax/base/_form_visibility_component.html.erb +15 -15
  214. data/app/views/hyrax/base/_guts4form.html.erb +12 -20
  215. data/app/views/hyrax/base/_member.html.erb +1 -1
  216. data/app/views/hyrax/base/_metadata.html.erb +1 -1
  217. data/app/views/hyrax/base/_show_actions.html.erb +9 -9
  218. data/app/views/hyrax/base/_work_button_row.html.erb +16 -15
  219. data/app/views/hyrax/base/_workflow_actions.html.erb +10 -10
  220. data/app/views/hyrax/base/_workflow_actions_widget.erb +1 -1
  221. data/app/views/hyrax/base/file_manager.html.erb +4 -5
  222. data/app/views/hyrax/base/inspect_work.html.erb +1 -1
  223. data/app/views/hyrax/base/show.html.erb +12 -12
  224. data/app/views/hyrax/base/unavailable.html.erb +2 -2
  225. data/app/views/hyrax/batch_edits/_check_all.html.erb +0 -1
  226. data/app/views/hyrax/batch_edits/_delete_selected.html.erb +1 -1
  227. data/app/views/hyrax/batch_edits/edit.html.erb +26 -18
  228. data/app/views/hyrax/collections/_bookmark_control.html.erb +2 -2
  229. data/app/views/hyrax/collections/_list_collections.html.erb +6 -6
  230. data/app/views/hyrax/collections/_list_works.html.erb +3 -1
  231. data/app/views/hyrax/collections/_search_form.html.erb +4 -4
  232. data/app/views/hyrax/collections/_show_document_list_row.html.erb +5 -2
  233. data/app/views/hyrax/collections/_sort_and_per_page.html.erb +3 -3
  234. data/app/views/hyrax/collections/_view_type_group.html.erb +2 -2
  235. data/app/views/hyrax/contact_form/new.html.erb +12 -13
  236. data/app/views/hyrax/content_blocks/_form.html.erb +29 -23
  237. data/app/views/hyrax/content_blocks/templates/agreement.html.erb +3 -3
  238. data/app/views/hyrax/dashboard/_admin_sets.html.erb +22 -28
  239. data/app/views/hyrax/dashboard/_index_partials/_current_proxy_rights.html.erb +2 -2
  240. data/app/views/hyrax/dashboard/_index_partials/_proxy_rights.html.erb +4 -4
  241. data/app/views/hyrax/dashboard/_index_partials/_transfers.html.erb +2 -2
  242. data/app/views/hyrax/dashboard/_repository_growth.html.erb +28 -28
  243. data/app/views/hyrax/dashboard/_resource_type_graph.html.erb +4 -4
  244. data/app/views/hyrax/dashboard/_sidebar.html.erb +3 -3
  245. data/app/views/hyrax/dashboard/_tabs.html.erb +6 -2
  246. data/app/views/hyrax/dashboard/_user_activity.html.erb +22 -19
  247. data/app/views/hyrax/dashboard/_visibility_graph.html.erb +4 -4
  248. data/app/views/hyrax/dashboard/_work_type_graph.html.erb +4 -4
  249. data/app/views/hyrax/dashboard/collections/_batch_edits_actions.html.erb +1 -1
  250. data/app/views/hyrax/dashboard/collections/_bookmark_control.html.erb +2 -2
  251. data/app/views/hyrax/dashboard/collections/_edit_actions.html.erb +1 -1
  252. data/app/views/hyrax/dashboard/collections/_form.html.erb +30 -22
  253. data/app/views/hyrax/dashboard/collections/_form_branding.html.erb +19 -19
  254. data/app/views/hyrax/dashboard/collections/_form_discovery.html.erb +8 -4
  255. data/app/views/hyrax/dashboard/collections/_form_for_select_collection.html.erb +7 -7
  256. data/app/views/hyrax/dashboard/collections/_form_share.html.erb +11 -9
  257. data/app/views/hyrax/dashboard/collections/_form_share_table.html.erb +34 -31
  258. data/app/views/hyrax/dashboard/collections/_list_collections.html.erb +1 -1
  259. data/app/views/hyrax/dashboard/collections/_list_works.html.erb +3 -1
  260. data/app/views/hyrax/dashboard/collections/_modal_remove_from_collection.html.erb +1 -1
  261. data/app/views/hyrax/dashboard/collections/_modal_remove_sub_collection.html.erb +1 -1
  262. data/app/views/hyrax/dashboard/collections/_show_add_items_actions.html.erb +1 -1
  263. data/app/views/hyrax/dashboard/collections/_show_descriptions.html.erb +5 -3
  264. data/app/views/hyrax/dashboard/collections/_show_document_list_menu.html.erb +4 -4
  265. data/app/views/hyrax/dashboard/collections/_show_document_list_row.html.erb +12 -10
  266. data/app/views/hyrax/dashboard/collections/_show_parent_collection_row.html.erb +2 -2
  267. data/app/views/hyrax/dashboard/collections/_sort_and_per_page.html.erb +4 -4
  268. data/app/views/hyrax/dashboard/collections/_subcollection_list.html.erb +1 -1
  269. data/app/views/hyrax/dashboard/collections/_work_action_menu.html.erb +10 -10
  270. data/app/views/hyrax/dashboard/collections/show.html.erb +4 -4
  271. data/app/views/hyrax/dashboard/profiles/_edit_primary.html.erb +21 -21
  272. data/app/views/hyrax/dashboard/profiles/_trophy_edit.html.erb +5 -5
  273. data/app/views/hyrax/dashboard/profiles/_zotero.html.erb +2 -2
  274. data/app/views/hyrax/dashboard/profiles/edit.html.erb +2 -2
  275. data/app/views/hyrax/dashboard/profiles/show.html.erb +3 -3
  276. data/app/views/hyrax/dashboard/show_admin.html.erb +36 -34
  277. data/app/views/hyrax/dashboard/show_user.html.erb +16 -16
  278. data/app/views/hyrax/dashboard/sidebar/_activity.html.erb +10 -10
  279. data/app/views/hyrax/dashboard/sidebar/_configuration.html.erb +8 -8
  280. data/app/views/hyrax/dashboard/sidebar/_repository_content.html.erb +3 -1
  281. data/app/views/hyrax/dashboard/sidebar/_tasks.html.erb +5 -1
  282. data/app/views/hyrax/dashboard/works/_list_works.html.erb +4 -1
  283. data/app/views/hyrax/depositors/index.html.erb +2 -2
  284. data/app/views/hyrax/embargoes/edit.html.erb +11 -11
  285. data/app/views/hyrax/embargoes/index.html.erb +18 -6
  286. data/app/views/hyrax/file_sets/_actions.html.erb +5 -6
  287. data/app/views/hyrax/file_sets/_descriptions.html.erb +1 -1
  288. data/app/views/hyrax/file_sets/_extra_fields_modal.html.erb +1 -1
  289. data/app/views/hyrax/file_sets/_form.html.erb +1 -1
  290. data/app/views/hyrax/file_sets/_permission_form.html.erb +33 -29
  291. data/app/views/hyrax/file_sets/_show_actions.html.erb +2 -2
  292. data/app/views/hyrax/file_sets/_show_details.html.erb +27 -17
  293. data/app/views/hyrax/file_sets/_single_use_link_rows.html.erb +2 -2
  294. data/app/views/hyrax/file_sets/_single_use_links.html.erb +2 -2
  295. data/app/views/hyrax/file_sets/_versioning.html.erb +9 -9
  296. data/app/views/hyrax/file_sets/edit.html.erb +17 -11
  297. data/app/views/hyrax/file_sets/media_display/_image.html.erb +4 -4
  298. data/app/views/hyrax/file_sets/show.html.erb +2 -2
  299. data/app/views/hyrax/homepage/_announcement.html.erb +2 -2
  300. data/app/views/hyrax/homepage/_explore_collections.html.erb +6 -4
  301. data/app/views/hyrax/homepage/_featured_fields.html.erb +1 -1
  302. data/app/views/hyrax/homepage/_featured_works.html.erb +1 -1
  303. data/app/views/hyrax/homepage/_home_content.html.erb +24 -10
  304. data/app/views/hyrax/homepage/_marketing.html.erb +1 -1
  305. data/app/views/hyrax/homepage/_recent_document.html.erb +4 -1
  306. data/app/views/hyrax/homepage/_sortable_featured.html.erb +3 -3
  307. data/app/views/hyrax/homepage/index.html.erb +4 -4
  308. data/app/views/hyrax/leases/edit.html.erb +11 -11
  309. data/app/views/hyrax/leases/index.html.erb +18 -6
  310. data/app/views/hyrax/my/_admin_set_action_menu.html.erb +5 -5
  311. data/app/views/hyrax/my/_collection_action_menu.html.erb +6 -6
  312. data/app/views/hyrax/my/_constraints.html.erb +2 -2
  313. data/app/views/hyrax/my/_document_list.html.erb +1 -1
  314. data/app/views/hyrax/my/_facet_layout.html.erb +1 -2
  315. data/app/views/hyrax/my/_facet_limit.html.erb +4 -4
  316. data/app/views/hyrax/my/_facet_pagination.html.erb +1 -25
  317. data/app/views/hyrax/my/_facet_pivot.html.erb +1 -1
  318. data/app/views/hyrax/my/_facet_selected.html.erb +1 -1
  319. data/app/views/hyrax/my/_search_form.html.erb +7 -8
  320. data/app/views/hyrax/my/_sort_and_per_page.html.erb +10 -12
  321. data/app/views/hyrax/my/_work_action_menu.html.erb +4 -5
  322. data/app/views/hyrax/my/collections/_facets.html.erb +2 -2
  323. data/app/views/hyrax/my/collections/_list_collections.html.erb +1 -1
  324. data/app/views/hyrax/my/collections/_modal_add_subcollection.html.erb +2 -2
  325. data/app/views/hyrax/my/collections/_modal_add_to_collection.html.erb +2 -2
  326. data/app/views/hyrax/my/collections/_modal_collection_types_to_create.html.erb +5 -5
  327. data/app/views/hyrax/my/collections/_modal_delete_collection.html.erb +1 -1
  328. data/app/views/hyrax/my/collections/_modal_delete_empty_collection.html.erb +1 -1
  329. data/app/views/hyrax/my/collections/_modal_delete_selected_collections.html.erb +1 -1
  330. data/app/views/hyrax/my/collections/_tabs.html.erb +11 -4
  331. data/app/views/hyrax/my/collections/index.html.erb +3 -3
  332. data/app/views/hyrax/my/facet.html.erb +17 -16
  333. data/app/views/hyrax/my/index.html.erb +2 -2
  334. data/app/views/hyrax/my/works/_batch_actions.html.erb +1 -1
  335. data/app/views/hyrax/my/works/_facets.html.erb +2 -2
  336. data/app/views/hyrax/my/works/_list_works.html.erb +6 -7
  337. data/app/views/hyrax/my/works/_tabs.html.erb +6 -6
  338. data/app/views/hyrax/my/works/index.html.erb +20 -18
  339. data/app/views/hyrax/notifications/_notifications.html.erb +1 -1
  340. data/app/views/hyrax/notifications/index.html.erb +4 -4
  341. data/app/views/hyrax/operations/index.html.erb +1 -1
  342. data/app/views/hyrax/operations/show.html.erb +2 -2
  343. data/app/views/hyrax/pages/_form.html.erb +76 -64
  344. data/app/views/hyrax/permissions/confirm.html.erb +4 -4
  345. data/app/views/hyrax/permissions/confirm_access.html.erb +4 -4
  346. data/app/views/hyrax/stats/file.html.erb +1 -1
  347. data/app/views/hyrax/stats/work.html.erb +1 -1
  348. data/app/views/hyrax/transfers/_received.html.erb +4 -4
  349. data/app/views/hyrax/transfers/index.html.erb +8 -8
  350. data/app/views/hyrax/uploads/_js_templates.html.erb +14 -14
  351. data/app/views/hyrax/uploads/_js_templates_branding.html.erb +5 -5
  352. data/app/views/hyrax/uploads/_js_templates_versioning.html.erb +15 -15
  353. data/app/views/hyrax/users/_activity.html.erb +3 -3
  354. data/app/views/hyrax/users/_contributions.html.erb +3 -3
  355. data/app/views/hyrax/users/_left_sidebar.html.erb +1 -1
  356. data/app/views/hyrax/users/_profile_tabs.html.erb +16 -8
  357. data/app/views/hyrax/users/_search_form.html.erb +2 -2
  358. data/app/views/hyrax/users/_user.html.erb +5 -5
  359. data/app/views/hyrax/users/_user_info.html.erb +4 -4
  360. data/app/views/hyrax/users/_vitals.html.erb +3 -3
  361. data/app/views/hyrax/users/show.html.erb +2 -2
  362. data/app/views/layouts/hyrax/dashboard.html.erb +4 -4
  363. data/app/views/layouts/hyrax.html.erb +4 -3
  364. data/app/views/shared/_appearance_styles.html.erb +8 -8
  365. data/app/views/shared/_footer.html.erb +1 -1
  366. data/app/views/shared/_locale_picker.html.erb +5 -8
  367. data/app/views/shared/_nav_safety_modal.html.erb +2 -2
  368. data/app/views/shared/_select_work_type_modal.html.erb +2 -2
  369. data/config/locales/hyrax.de.yml +4 -4
  370. data/config/locales/hyrax.en.yml +4 -4
  371. data/config/locales/hyrax.es.yml +6 -6
  372. data/config/locales/hyrax.fr.yml +7 -7
  373. data/config/locales/hyrax.it.yml +6 -6
  374. data/config/locales/hyrax.pt-BR.yml +6 -6
  375. data/config/locales/hyrax.zh.yml +6 -6
  376. data/docker-compose.yml +2 -1
  377. data/documentation/developing-your-hyrax-based-app.md +1 -1
  378. data/documentation/legacyREADME.md +1 -1
  379. data/hyrax.gemspec +12 -21
  380. data/karma.conf.js +104 -0
  381. data/lib/generators/hyrax/assets_generator.rb +2 -5
  382. data/lib/generators/hyrax/install_generator.rb +9 -33
  383. data/lib/generators/hyrax/templates/catalog_controller.rb +20 -13
  384. data/lib/generators/hyrax/templates/config/initializers/riiif.rb +1 -1
  385. data/lib/generators/hyrax/templates/config/locales/hyrax.de.yml +1 -1
  386. data/lib/generators/hyrax/templates/config/locales/hyrax.en.yml +1 -1
  387. data/lib/generators/hyrax/templates/config/locales/hyrax.es.yml +1 -1
  388. data/lib/generators/hyrax/templates/config/locales/hyrax.fr.yml +1 -1
  389. data/lib/generators/hyrax/templates/config/locales/hyrax.it.yml +1 -1
  390. data/lib/generators/hyrax/templates/config/locales/hyrax.pt-BR.yml +1 -1
  391. data/lib/generators/hyrax/templates/config/locales/hyrax.zh.yml +1 -1
  392. data/lib/generators/hyrax/templates/hyrax.scss +1 -2
  393. data/lib/generators/hyrax/templates/package.json +7 -8
  394. data/lib/hyrax/configuration.rb +0 -40
  395. data/lib/hyrax/engine.rb +1 -2
  396. data/lib/hyrax/publisher.rb +0 -4
  397. data/lib/hyrax/specs/capybara.rb +5 -3
  398. data/lib/hyrax/transactions/container.rb +0 -54
  399. data/lib/hyrax/version.rb +1 -1
  400. data/lib/valkyrie/indexing/solr/indexing_adapter.rb +1 -1
  401. data/lib/wings/valkyrie/persister.rb +2 -1
  402. data/package.json +11 -0
  403. data/tasks/hyrax_dev.rake +32 -0
  404. data/template.rb +1 -1
  405. data/vendor/assets/javascripts/dataTables.bootstrap4.js +184 -0
  406. data/vendor/assets/javascripts/fileupload/jquery.fileupload-ui.js +1 -1
  407. data/vendor/assets/javascripts/fileupload/jquery.fileupload.js +2 -2
  408. data/vendor/assets/javascripts/fileupload/jquery.iframe-transport.js +1 -1
  409. data/vendor/assets/javascripts/handlebars.js +5214 -0
  410. data/vendor/assets/javascripts/jquery-ui.js +19057 -0
  411. data/vendor/assets/javascripts/jquery.dataTables.js +15336 -0
  412. data/vendor/assets/javascripts/morris/morris.min.js +9 -1
  413. data/vendor/assets/javascripts/morris/raphael-min.js +4 -6
  414. data/vendor/assets/javascripts/nestable.js +1 -1
  415. data/vendor/assets/stylesheets/dataTables.bootstrap4.css +307 -0
  416. data/vendor/assets/stylesheets/jquery-ui.css +1315 -0
  417. data/vendor/assets/stylesheets/morris.css +3 -0
  418. metadata +92 -172
  419. data/app/actors/hyrax/actors/initialize_workflow_actor.rb +0 -35
  420. data/app/helpers/hyrax/url_helper.rb +0 -13
  421. data/app/jobs/content_depositor_change_event_job.rb +0 -48
  422. data/app/models/concerns/hyrax/with_file_sets.rb +0 -17
  423. data/lib/hyrax/transactions/create_work.rb +0 -65
  424. data/lib/hyrax/transactions/destroy_work.rb +0 -28
  425. data/lib/hyrax/transactions/steps/apply_collection_permission_template.rb +0 -34
  426. data/lib/hyrax/transactions/steps/apply_permission_template.rb +0 -32
  427. data/lib/hyrax/transactions/steps/apply_visibility.rb +0 -41
  428. data/lib/hyrax/transactions/steps/destroy_work.rb +0 -27
  429. data/lib/hyrax/transactions/steps/ensure_permission_template.rb +0 -29
  430. data/lib/hyrax/transactions/steps/save_work.rb +0 -38
  431. data/lib/hyrax/transactions/update_work.rb +0 -19
  432. data/lib/wings/services/file_converter_service.rb +0 -19
  433. data/lib/wings/services/file_metadata_builder.rb +0 -94
  434. data/vendor/assets/javascripts/handlebars-v4.0.5.js +0 -4612
  435. data/vendor/assets/stylesheets/morris.js/0.5.1/morris.css +0 -2
@@ -93,19 +93,13 @@ module Hyrax
93
93
 
94
94
  def create_file_from_url(uri, file_name, auth_header)
95
95
  import_url = URI.decode_www_form_component(uri.to_s)
96
- use_valkyrie = false
97
- case curation_concern
98
- when Valkyrie::Resource
99
- file_set = Hyrax.persister.save(resource: Hyrax::FileSet.new(import_url: import_url, label: file_name))
100
- use_valkyrie = true
101
- else
102
- file_set = ::FileSet.new(import_url: import_url, label: file_name)
103
- end
104
- __create_file_from_url(file_set: file_set, uri: uri, auth_header: auth_header, use_valkyrie: use_valkyrie)
96
+ file_set = ::FileSet.new(import_url: import_url, label: file_name)
97
+
98
+ __create_file_from_url(file_set: file_set, uri: uri, auth_header: auth_header)
105
99
  end
106
100
 
107
- def __create_file_from_url(file_set:, uri:, auth_header:, use_valkyrie: Hyrax.config.use_valkyrie?)
108
- actor = file_set_actor_class.new(file_set, user, use_valkyrie: use_valkyrie)
101
+ def __create_file_from_url(file_set:, uri:, auth_header:)
102
+ actor = file_set_actor_class.new(file_set, user)
109
103
  actor.create_metadata(visibility: curation_concern.visibility)
110
104
  actor.attach_to_work(curation_concern)
111
105
  file_set.save! if file_set.respond_to?(:save!)
@@ -1,5 +1,4 @@
1
1
  # frozen_string_literal: true
2
- require 'wings/services/file_metadata_builder'
3
2
 
4
3
  module Hyrax
5
4
  module Actors
@@ -11,8 +10,7 @@ module Hyrax
11
10
  # @param [FileSet] file_set the parent FileSet
12
11
  # @param [Symbol, #to_sym] relation the type/use for the file
13
12
  # @param [User] user the user to record as the Agent acting upon the file
14
- def initialize(file_set, relation, user, use_valkyrie: Hyrax.config.query_index_from_valkyrie)
15
- @use_valkyrie = use_valkyrie
13
+ def initialize(file_set, relation, user)
16
14
  @file_set = file_set
17
15
  @relation = normalize_relation(relation)
18
16
  @user = user
@@ -25,7 +23,14 @@ module Hyrax
25
23
  # @see IngestJob
26
24
  # @todo create a job to monitor the temp directory (or in a multi-worker system, directories!) to prune old files that have made it into the repo
27
25
  def ingest_file(io)
28
- use_valkyrie ? perform_ingest_file_through_valkyrie(io) : perform_ingest_file_through_active_fedora(io)
26
+ Hydra::Works::AddFileToFileSet.call(file_set,
27
+ io,
28
+ relation,
29
+ versioning: false)
30
+ return false unless file_set.save
31
+ repository_file = related_file
32
+ create_version(repository_file, user)
33
+ CharacterizeJob.perform_later(file_set, repository_file.id, pathhint(io))
29
34
  end
30
35
 
31
36
  # Reverts file and spawns async job to characterize and create derivatives.
@@ -63,39 +68,6 @@ module Hyrax
63
68
  file_set.public_send(normalize_relation(relation)) || raise("No #{relation} returned for FileSet #{file_set.id}")
64
69
  end
65
70
 
66
- def perform_ingest_file_through_active_fedora(io)
67
- # Skip versioning because versions will be minted by VersionCommitter as necessary during save_characterize_and_record_committer.
68
- Hydra::Works::AddFileToFileSet.call(file_set,
69
- io,
70
- relation,
71
- versioning: false)
72
- return false unless file_set.save
73
- repository_file = related_file
74
- create_version(repository_file, user)
75
- CharacterizeJob.perform_later(file_set, repository_file.id, pathhint(io))
76
- end
77
-
78
- def perform_ingest_file_through_valkyrie(io) # rubocop:disable Metrics/AbcSize, Metrics/MethodLength
79
- Deprecation.warn "FileActor support for Valkyrie was experimental and " \
80
- "is slated to be removed in favor of WorkUploadsHandler."
81
- file =
82
- begin
83
- Hyrax.storage_adapter.upload(resource: file_set, file: io, original_filename: io.original_name, use: relation)
84
- rescue StandardError => err
85
- Rails.logger.error("Failed to save file_metadata through valkyrie: #{err.message}")
86
- return false
87
- end
88
- file_metadata = Hyrax.custom_queries.find_file_metadata_by(id: file.id)
89
- create_version(file_metadata, user)
90
-
91
- file_set.file_ids << file_metadata.id
92
- file_set.original_file_id = file_metadata.id
93
- Hyrax.persister.save(resource: file_set)
94
- Hyrax.publisher.publish('object.metadata.updated', object: file_set, user: user)
95
- CharacterizeJob.perform_later(file_set, file_metadata.id.to_s, pathhint(io))
96
- file_metadata
97
- end
98
-
99
71
  def normalize_relation(relation)
100
72
  use_valkyrie ? normalize_relation_for_valkyrie(relation) : normalize_relation_for_active_fedora(relation)
101
73
  end
@@ -4,10 +4,9 @@ module Hyrax
4
4
  # Actions are decoupled from controller logic so that they may be called from a controller or a background job.
5
5
  class FileSetActor # rubocop:disable Metrics/ClassLength
6
6
  include Lockable
7
- attr_reader :file_set, :user, :attributes, :use_valkyrie
7
+ attr_reader :file_set, :user, :attributes
8
8
 
9
- def initialize(file_set, user, use_valkyrie: Hyrax.config.query_index_from_valkyrie)
10
- @use_valkyrie = use_valkyrie
9
+ def initialize(file_set, user)
11
10
  @file_set = file_set
12
11
  @user = user
13
12
  end
@@ -71,42 +70,17 @@ module Hyrax
71
70
  def attach_to_work(work, file_set_params = {})
72
71
  acquire_lock_for(work.id) do
73
72
  # Ensure we have an up-to-date copy of the members association, so that we append to the end of the list.
74
- if valkyrie_object?(work)
75
- attach_to_valkyrie_work(work, file_set_params)
76
- else
77
- attach_to_af_work(work, file_set_params)
78
- end
73
+ work.reload unless work.new_record?
74
+ file_set.visibility = work.visibility unless assign_visibility?(file_set_params)
75
+ work.ordered_members << file_set
76
+ work.representative = file_set if work.representative_id.blank?
77
+ work.thumbnail = file_set if work.thumbnail_id.blank?
78
+ # Save the work so the association between the work and the file_set is persisted (head_id)
79
+ # NOTE: the work may not be valid, in which case this save doesn't do anything.
80
+ work.save
79
81
  Hyrax.config.callback.run(:after_create_fileset, file_set, user, warn: false)
80
82
  end
81
83
  end
82
- alias attach_file_to_work attach_to_work
83
- deprecation_deprecate attach_file_to_work: "use attach_to_work instead"
84
-
85
- def attach_to_valkyrie_work(work, file_set_params)
86
- work = Hyrax.query_service.find_by(id: work.id) unless work.new_record
87
- file_set.visibility = work.visibility unless assign_visibility?(file_set_params)
88
- fs = Hyrax.persister.save(resource: file_set)
89
- Hyrax.publisher.publish('object.metadata.updated', object: fs, user: user)
90
- work.member_ids << fs.id
91
- work.representative_id = fs.id if work.representative_id.blank?
92
- work.thumbnail_id = fs.id if work.thumbnail_id.blank?
93
- # Save the work so the association between the work and the file_set is persisted (head_id)
94
- # NOTE: the work may not be valid, in which case this save doesn't do anything.
95
- Hyrax.persister.save(resource: work)
96
- Hyrax.publisher.publish('object.metadata.updated', object: work, user: user)
97
- end
98
-
99
- # Adds a FileSet to the work using ore:Aggregations.
100
- def attach_to_af_work(work, file_set_params)
101
- work.reload unless work.new_record?
102
- file_set.visibility = work.visibility unless assign_visibility?(file_set_params)
103
- work.ordered_members << file_set
104
- work.representative = file_set if work.representative_id.blank?
105
- work.thumbnail = file_set if work.thumbnail_id.blank?
106
- # Save the work so the association between the work and the file_set is persisted (head_id)
107
- # NOTE: the work may not be valid, in which case this save doesn't do anything.
108
- work.save
109
- end
110
84
 
111
85
  # @param [String] revision_id the revision to revert to
112
86
  # @param [Symbol, #to_sym] relation
@@ -144,8 +118,7 @@ module Hyrax
144
118
  end
145
119
 
146
120
  def build_file_actor(relation)
147
- fs = use_valkyrie ? file_set.valkyrie_resource : file_set
148
- file_actor_class.new(fs, relation, user, use_valkyrie: use_valkyrie)
121
+ file_actor_class.new(file_set, relation, user)
149
122
  end
150
123
 
151
124
  # uses create! because object must be persisted to serialize for jobs
@@ -194,32 +167,10 @@ module Hyrax
194
167
  work.save!
195
168
  end
196
169
 
197
- # switches between using valkyrie to save or active fedora to save
198
170
  def perform_save(object)
199
- obj_to_save = object_to_act_on(object)
200
- if valkyrie_object?(obj_to_save)
201
- saved_resource = Hyrax.persister.save(resource: obj_to_save)
202
- # return the same type of object that was passed in
203
- saved_object_to_return = valkyrie_object?(object) ? saved_resource : Wings::ActiveFedoraConverter.new(resource: saved_resource).convert
204
- else
205
- obj_to_save.save
206
- saved_object_to_return = obj_to_save
207
- end
208
- saved_object_to_return
209
- end
210
-
211
- # if passed a resource or if use_valkyrie==true, object to act on is the valkyrie resource
212
- def object_to_act_on(object)
213
- return object if valkyrie_object?(object)
214
- use_valkyrie ? object.valkyrie_resource : object
215
- end
216
-
217
- # determine if the object is a valkyrie resource
218
- def valkyrie_object?(object)
219
- object.is_a? Valkyrie::Resource
171
+ object.save
172
+ object
220
173
  end
221
- # rubocop:enable Metrics/AbcSize
222
- # rubocop:enable Metrics/CyclomaticComplexity
223
174
  end
224
175
  end
225
176
  end
@@ -92,7 +92,7 @@ Hyrax = {
92
92
  // Popover help modals. Used on the user profile page.
93
93
  popovers: function () {
94
94
  $("a[data-toggle=popover]").popover({html: true})
95
- .click(function () {
95
+ .on("click", function () {
96
96
  return false;
97
97
  });
98
98
  },
@@ -1,10 +1,10 @@
1
1
  Blacklight.onLoad(function() {
2
- $('#show_addl_descriptions').click(function() {
2
+ $('#show_addl_descriptions').on('click', function() {
3
3
  $('#more_descriptions').show();
4
4
  $('#show_addl_descriptions').hide();
5
5
  return false;
6
6
  });
7
- $('#hide_addl_descriptions').click(function() {
7
+ $('#hide_addl_descriptions').on('click', function() {
8
8
  $('#more_descriptions').hide();
9
9
  $('#show_addl_descriptions').show();
10
10
  return false;
@@ -9,7 +9,7 @@ function batch_edit_init () {
9
9
  var key = Pair[0];
10
10
  var val = Pair[1];
11
11
  if (Result[key] != null) {
12
- if(!$.isArray(Result[key])) Result[key] = [Result[key]];
12
+ if(!Array.isArray(Result[key])) Result[key] = [Result[key]];
13
13
  Result[key].push(val);
14
14
  } else
15
15
  Result[key] = val;
@@ -159,9 +159,9 @@ function batch_edit_init () {
159
159
  setTimeout(ajaxManager.runNow(), 100);
160
160
  }
161
161
 
162
- $("#permissions_visibility_save").click(runSave);
163
- $("#permissions_roles_save").click(runSave);
164
- $(".field-save").click(runSave);
162
+ $("#permissions_visibility_save").on('click', runSave);
163
+ $("#permissions_roles_save").on( 'click', runSave);
164
+ $(".field-save").on('click', runSave);
165
165
  }
166
166
 
167
167
  Blacklight.onLoad(function() {
@@ -5,12 +5,12 @@
5
5
  var n = $(".batch_document_selector:checked").length;
6
6
  if ((n>0) || (forceOn)) {
7
7
  $('.batch-toggle').show();
8
- $('.batch-select-all').removeClass('hidden');
9
- $('#batch-edit').removeClass('hidden');
10
- } else if ( otherPage){
8
+ $('.batch-select-all').removeAttr("hidden");
9
+ $('#batch-edit').removeAttr("hidden");
10
+ } else if (otherPage){
11
11
  $('.batch-toggle').hide();
12
- $('.batch-select-all').addClass('hidden');
13
- $('#batch-edit').addClass('hidden');
12
+ $('.batch-select-all').attr("hidden", "");
13
+ $('#batch-edit').attr("hidden", "");
14
14
  }
15
15
  $("body").css("cursor", "auto");
16
16
  }
@@ -26,10 +26,10 @@
26
26
  function toggleStateBool (obj, state) {
27
27
  if (state){
28
28
  obj.attr("data-state", 'on');
29
- obj.find('a i').addClass('glyphicon glyphicon-ok');
29
+ obj.find('a i').addClass('fa fa-check');
30
30
  }else {
31
31
  obj.attr("data-state", 'off');
32
- obj.find('a i').removeClass('glyphicon glyphicon-ok');
32
+ obj.find('a i').removeClass('fa fa-check');
33
33
  }
34
34
 
35
35
  }
@@ -62,22 +62,22 @@
62
62
 
63
63
  Blacklight.onLoad(function() {
64
64
  // check the select all page cog menu item and select the entire page
65
- $("[data-behavior='batch-edit-select-page']").bind('click', function(e) {
65
+ $("[data-behavior='batch-edit-select-page']").on('click', function(e) {
66
66
  e.preventDefault();
67
67
  select_page(true);
68
68
  });
69
69
 
70
70
  // check the select none cog menu item and de-select the entire page
71
- $("[data-behavior='batch-edit-select-none']").bind('click', function(e) {
71
+ $("[data-behavior='batch-edit-select-none']").on('click', function(e) {
72
72
  e.preventDefault();
73
73
  select_page(false);
74
74
  });
75
75
 
76
76
  // check all check boxes
77
- $("#check_all").bind('click', check_all_page);
77
+ $("#check_all").on('click', check_all_page);
78
78
 
79
79
  // select/deselect all check boxes
80
- $("#checkAllBox").change(function () {
80
+ $("#checkAllBox").on('change', function () {
81
81
  $("input:checkbox").prop('checked', $(this).prop("checked"));
82
82
  });
83
83
 
@@ -87,12 +87,12 @@ Blacklight.onLoad(function() {
87
87
  });
88
88
 
89
89
  // toggle button on or off based on boxes being clicked
90
- $(".batch_document_selector").bind('click', function(e) {
90
+ $(".batch_document_selector").on('click', function(e) {
91
91
  toggleButtons();
92
92
  });
93
93
 
94
94
  // toggle the state of the select boxes in the cog menu if all buttons are
95
- $(".batch_document_selector").bind('click', function(e) {
95
+ $(".batch_document_selector").on('click', function(e) {
96
96
 
97
97
  // count the check boxes currently checked
98
98
  var selectedCount = $(".batch_document_selector:checked").length;
@@ -2,7 +2,7 @@
2
2
  //= require browse_everything/behavior
3
3
 
4
4
  // Show the files in the queue
5
- Blacklight.onLoad( function() {
5
+ function showBrowseEverythingFiles() {
6
6
  // We need to check this because https://github.com/samvera/browse-everything/issues/169
7
7
  if ($('#browse-btn').length > 0) {
8
8
  $('#browse-btn').browseEverything()
@@ -12,4 +12,6 @@ Blacklight.onLoad( function() {
12
12
  $.blueimp.fileupload.prototype.options.done.call($('#fileupload').fileupload(), evt, { result: { files: files }});
13
13
  })
14
14
  }
15
- });
15
+ }
16
+ $(document).on('click', '#browse-btn', showBrowseEverythingFiles);
17
+
@@ -86,7 +86,7 @@ export default class CollectionTypes {
86
86
  .remove();
87
87
  let defaultButton = $(event.target)
88
88
  .parent('div')
89
- .find('.btn-default');
89
+ .find('.btn-secondary');
90
90
  defaultButton.trigger('click');
91
91
  }
92
92
  });
@@ -15,8 +15,12 @@ export default class {
15
15
  }
16
16
 
17
17
  url() {
18
- let urlParts = window.location.pathname.split("/")
18
+ let urlParts = this.pathname().split("/")
19
19
  urlParts[urlParts.length - 1] = "files"
20
20
  return urlParts.join("/")
21
21
  }
22
+
23
+ pathname() {
24
+ return window.location.pathname
25
+ }
22
26
  }
@@ -1,6 +1,6 @@
1
1
  Blacklight.onLoad(function() {
2
2
  // toggle button on or off based on boxes being clicked
3
- $(".batch_document_selector, .batch_document_selector_all").bind('click', function(e) {
3
+ $(".batch_document_selector, .batch_document_selector_all").on('click', function(e) {
4
4
  var n = $(".batch_document_selector:checked").length;
5
5
  if (n>0 || ($('input#check_all').length && $('input#check_all')[0].checked)) {
6
6
  $('.sort-toggle').hide();
@@ -14,21 +14,21 @@ Blacklight.onLoad(function() {
14
14
  if (array.length > 1) {
15
15
  var docId = array[1];
16
16
  $("#detail_" + docId + " .expanded-details").slideToggle();
17
- $(item).toggleClass('glyphicon-chevron-right glyphicon-chevron-down');
17
+ $(item).toggleClass('fa-chevron-right fa-chevron-down');
18
18
  }
19
19
  }
20
20
 
21
21
  // show/hide more information on the dashboard when clicking
22
22
  // plus/minus
23
- $('.glyphicon-chevron-right').on('click', function() {
23
+ $('.fa-chevron-right').on('click', function() {
24
24
  show_details(this);
25
25
  return false;
26
26
  });
27
27
 
28
28
  $('a').filter( function() {
29
- return $(this).find('.glyphicon-chevron-right').length === 1;
29
+ return $(this).find('.fa-chevron-right').length === 1;
30
30
  }).on('click', function() {
31
- show_details($(this).find(".glyphicon-chevron-right")[0]);
31
+ show_details($(this).find(".fa-chevron-right")[0]);
32
32
  return false;
33
33
  });
34
34
 
@@ -1,4 +1,4 @@
1
- //= require handlebars-v4.0.5
1
+ //= require handlebars
2
2
 
3
3
  import { FieldManager } from 'hydra-editor/field_manager'
4
4
  import Handlebars from 'handlebars'
@@ -19,10 +19,10 @@ export default class ControlledVocabulary extends FieldManager {
19
19
  listClass: '.listing',
20
20
  inputTypeClass: '.controlled_vocabulary',
21
21
 
22
- addHtml: '<button type=\"button\" class=\"btn btn-link add\"><span class=\"glyphicon glyphicon-plus\"></span><span class="controls-add-text"></span></button>',
22
+ addHtml: '<button type=\"button\" class=\"btn btn-link add\"><span class=\"fa fa-plus\"></span><span class="controls-add-text"></span></button>',
23
23
  addText: 'Add another',
24
24
 
25
- removeHtml: '<button type=\"button\" class=\"btn btn-link remove\"><span class=\"glyphicon glyphicon-remove\"></span><span class="controls-remove-text"></span> <span class=\"sr-only\"> previous <span class="controls-field-name-text">field</span></span></button>',
25
+ removeHtml: '<button type=\"button\" class=\"btn btn-link remove\"><span class=\"fa fa-minus\"></span><span class="controls-remove-text"></span> <span class=\"sr-only\"> previous <span class="controls-field-name-text">field</span></span></button>',
26
26
  removeText: 'Remove',
27
27
 
28
28
  labelControls: true,
@@ -31,7 +31,7 @@ export default class {
31
31
  // Immediate feedback after work creation, editing.
32
32
  formInProgress() {
33
33
  $('[data-behavior~=work-form]').on('submit', function(event){
34
- $('.panel-footer').toggleClass('hidden');
34
+ $('.card-footer.save-progress').removeAttr("hidden");
35
35
  });
36
36
  }
37
37
 
@@ -82,9 +82,9 @@ export default class {
82
82
 
83
83
  sharingTabVisiblity(visible) {
84
84
  if (visible)
85
- this.sharingTabElement.removeClass('hidden')
85
+ this.sharingTabElement.removeAttr("hidden")
86
86
  else
87
- this.sharingTabElement.addClass('hidden')
87
+ this.sharingTabElement.attr("hidden","")
88
88
  }
89
89
 
90
90
  relationshipsControl() {
@@ -1,14 +1,16 @@
1
1
  Blacklight.onLoad(function() {
2
+ $(".facets-header button").find("span").addClass("fa fa-bars");
3
+
2
4
  /*
3
5
  * facets lists
4
6
  */
5
- $("li.expandable").click(function(){
7
+ $("li.expandable").on("click", function() {
6
8
  $(this).next("ul").slideToggle();
7
- $(this).find('i').toggleClass("glyphicon-chevron-right glyphicon-chevron-down");
9
+ $(this).find('i').toggleClass("fa-chevron-right fa-chevron-down");
8
10
  });
9
11
 
10
- $("li.expandable_new").click(function(){
11
- $(this).find('i').toggleClass("glyphicon-chevron-right glyphicon-chevron-down");
12
+ $("li.expandable_new").on("click", function() {
13
+ $(this).find('i').toggleClass("fa-chevron-right fa-chevron-down");
12
14
  });
13
15
 
14
16
  }); //end of Blacklight.onload
@@ -10,7 +10,7 @@ export class InputTracker {
10
10
  this.notifier = notifier
11
11
  this.element.data("initial-value", this.element.val())
12
12
  this.element.data("tracker", this)
13
- this.element.change(this.value_changed)
13
+ this.element.trigger("change", this.value_changed)
14
14
  }
15
15
 
16
16
  reset() {
@@ -6,7 +6,7 @@ export default class SaveManager {
6
6
 
7
7
  override_save_button() {
8
8
  Blacklight.onLoad(() => {
9
- this.save_button.click(this.clicked_save)
9
+ this.save_button.on('click', this.clicked_save)
10
10
  })
11
11
  }
12
12
 
@@ -24,7 +24,7 @@ export default class SaveManager {
24
24
  }
25
25
 
26
26
  check_button() {
27
- if(this.is_changed && this.save_button.selector.valueOf("data-action") === "*[data-action='save-actions']") {
27
+ if (this.is_changed) {
28
28
  this.save_button.removeClass("disabled")
29
29
  } else {
30
30
  this.save_button.addClass("disabled")
@@ -9,7 +9,7 @@ export default class SortManager {
9
9
  }
10
10
 
11
11
  initialize_sort() {
12
- this.element.sortable({handle: ".panel-heading"})
12
+ this.element.sortable({handle: ".card-header"})
13
13
  this.element.on("sortstop", this.stopped_sorting)
14
14
  this.element.on("sortstart", this.started_sorting)
15
15
  }
@@ -104,7 +104,7 @@ export default class SortManager {
104
104
 
105
105
  initialize_alpha_sort_button() {
106
106
  let that = this
107
- this.alpha_sort_button.click(function() { that.sort_alpha() } )
107
+ this.alpha_sort_button.on("click", function() { that.sort_alpha() } )
108
108
  }
109
109
 
110
110
  sort_alpha() {
@@ -5,7 +5,6 @@ export default class FileManager {
5
5
  constructor() {
6
6
  this.save_manager = this.initialize_save_manager()
7
7
  this.sorting()
8
- this.save_affix()
9
8
  this.member_tracking()
10
9
  this.sortable_placeholder()
11
10
  this.resource_form()
@@ -19,20 +18,6 @@ export default class FileManager {
19
18
  window.new_sort_manager = new SortManager(this.save_manager)
20
19
  }
21
20
 
22
- save_affix() {
23
- let tools = $("#file-manager-tools")
24
- if(tools.length > 0) {
25
- tools.affix({
26
- offset: {
27
- top: $("#file-manager-tools .actions").offset().top,
28
- bottom: function() {
29
- return $("#file-manager-extra-tools").outerHeight(true) + $("footer").outerHeight(true)
30
- }
31
- }
32
- })
33
- }
34
- }
35
-
36
21
  member_tracking() {
37
22
  let sm = this.save_manager
38
23
  $("li[data-reorder-id]").each(function(index, element) {
@@ -51,13 +36,13 @@ export default class FileManager {
51
36
  $("#resource-form").parent().data("file_manager_member", manager)
52
37
  // Track thumbnail ID hidden field
53
38
  new InputTracker($("*[data-member-link=thumbnail_id]"), manager)
54
- $("#sortable *[name=thumbnail_id]").change(function() {
39
+ $("#sortable *[name=thumbnail_id]").on("change", function() {
55
40
  let val = $("#sortable *[name=thumbnail_id]:checked").val()
56
41
  $("*[data-member-link=thumbnail_id]").val(val)
57
42
  $("*[data-member-link=thumbnail_id]").change()
58
43
  })
59
44
  new InputTracker($("*[data-member-link=representative_id]"), manager)
60
- $("#sortable *[name=representative_id]").change(function() {
45
+ $("#sortable *[name=representative_id]").on("change", function() {
61
46
  let val = $("#sortable *[name=representative_id]:checked").val()
62
47
  $("*[data-member-link=representative_id]").val(val)
63
48
  $("*[data-member-link=representative_id]").change()
@@ -19,7 +19,7 @@ export default class Notification {
19
19
  }
20
20
  else {
21
21
  this.counter.removeClass('invisible')
22
- this.counter.addClass('label-danger').removeClass('label-default')
22
+ this.counter.addClass('badge-danger').removeClass('badge-secondary')
23
23
  }
24
24
  }
25
25
  }
@@ -20,18 +20,18 @@ export class Registry {
20
20
 
21
21
  addError(message) {
22
22
  this.errorMessage.html(message);
23
- this.error.removeClass('hidden');
23
+ this.error.removeAttr("hidden");
24
24
  }
25
25
 
26
26
  reset() {
27
- this.error.addClass('hidden');
27
+ this.error.attr("hidden", "");
28
28
  }
29
29
 
30
30
  removePermission(evt) {
31
31
  evt.preventDefault();
32
32
  let button = $(evt.target);
33
33
  let container = button.closest('tr');
34
- container.addClass('hidden'); // do not show the block
34
+ container.attr("hidden", ""); // do not show the block
35
35
  this.addDestroyField(container, button.attr('data-index'));
36
36
  this.showPermissionNote();
37
37
  }
@@ -47,7 +47,7 @@ export class Registry {
47
47
  }
48
48
 
49
49
  showPermissionNote() {
50
- $('#save_perm_note').removeClass('hidden');
50
+ $('#save_perm_note').removeAttr("hidden");
51
51
  }
52
52
 
53
53
  addDestroyField(element, index) {
@@ -51,7 +51,9 @@ export class UserControls {
51
51
  }
52
52
 
53
53
  userName() {
54
- return this.userField.val()
54
+ if (this.userField.select2('data')) {
55
+ return this.userField.select2('data').text
56
+ }
55
57
  }
56
58
 
57
59
  addError(message) {
@@ -25,7 +25,7 @@ export default class ConfirmRemoveDialog {
25
25
  <div class="modal-content">
26
26
  <div class="modal-body">${this.text}</div>
27
27
  <div class="modal-footer">
28
- <button type="button" class="btn btn-default" data-dismiss="modal">${this.cancel}</button>
28
+ <button type="button" class="btn btn-secondary" data-dismiss="modal">${this.cancel}</button>
29
29
  <button type="button" class="btn btn-danger" data-behavior="submit">${this.remove}</button>
30
30
  </div>
31
31
  </div>
@@ -86,13 +86,13 @@ export default class RelationshipsControl {
86
86
  * @param {String} message the warning message text to set
87
87
  */
88
88
  setWarningMessage(message) {
89
- this.warning.text(message).removeClass("hidden");
89
+ this.warning.text(message).hidden= false;
90
90
  }
91
91
 
92
92
  /**
93
93
  * Hide the warning message on the appropriate row
94
94
  */
95
95
  hideWarningMessage(){
96
- this.warning.addClass("hidden");
96
+ this.warning.hidden= true;
97
97
  }
98
98
  }
@@ -38,7 +38,7 @@ export default class RegistryEntry {
38
38
  removeResource(evt) {
39
39
  evt.preventDefault();
40
40
  let button = $(evt.target);
41
- this.view.addClass('hidden'); // do not show the block
41
+ this.view.attr("hidden", ""); // do not show the block
42
42
  this.destroyed = true
43
43
  this.registry.showSaveNote();
44
44
  }