hyrax 2.0.3 → 2.1.0.beta1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (703) hide show
  1. checksums.yaml +4 -4
  2. data/.eslintrc +0 -1
  3. data/.github/CONTRIBUTING.md +1 -1
  4. data/.rubocop.yml +8 -4
  5. data/.rubocop_fixme.yml +20 -2
  6. data/.travis.yml +3 -3
  7. data/README.md +12 -4
  8. data/app/actors/hyrax/actors/abstract_actor.rb +1 -1
  9. data/app/actors/hyrax/actors/apply_permission_template_actor.rb +17 -1
  10. data/app/actors/hyrax/actors/attach_members_actor.rb +2 -2
  11. data/app/actors/hyrax/actors/collections_membership_actor.rb +147 -12
  12. data/app/actors/hyrax/actors/create_with_remote_files_actor.rb +15 -9
  13. data/app/actors/hyrax/actors/default_admin_set_actor.rb +3 -3
  14. data/app/actors/hyrax/actors/file_set_actor.rb +10 -6
  15. data/app/actors/hyrax/actors/interpret_visibility_actor.rb +1 -1
  16. data/app/assets/javascripts/hyrax.js +13 -7
  17. data/app/assets/javascripts/hyrax/admin/admin_set_controls.es6 +5 -3
  18. data/app/assets/javascripts/hyrax/admin/collection_type/participants.es6 +13 -0
  19. data/app/assets/javascripts/hyrax/admin/collection_type/settings.es6 +60 -0
  20. data/app/assets/javascripts/hyrax/admin/collection_type_controls.es6 +15 -0
  21. data/app/assets/javascripts/hyrax/app.js.erb +29 -7
  22. data/app/assets/javascripts/hyrax/autocomplete.es6 +10 -5
  23. data/app/assets/javascripts/hyrax/autocomplete/default.es6 +1 -1
  24. data/app/assets/javascripts/hyrax/autocomplete/linked_data.es6 +1 -1
  25. data/app/assets/javascripts/hyrax/autocomplete/{work.es6 → resource.es6} +10 -4
  26. data/app/assets/javascripts/hyrax/collection_types.es6 +65 -0
  27. data/app/assets/javascripts/hyrax/collections.js +168 -3
  28. data/app/assets/javascripts/hyrax/collections/editor.es6 +7 -1
  29. data/app/assets/javascripts/hyrax/collections_forms.js +108 -0
  30. data/app/assets/javascripts/hyrax/editor.es6 +17 -3
  31. data/app/assets/javascripts/hyrax/fileupload.js +1 -0
  32. data/app/assets/javascripts/hyrax/relationships.js +2 -1
  33. data/app/assets/javascripts/hyrax/relationships/confirm_remove_dialog.es6 +45 -0
  34. data/app/assets/javascripts/hyrax/relationships/control.es6 +25 -10
  35. data/app/assets/javascripts/hyrax/relationships/registry.es6 +28 -25
  36. data/app/assets/javascripts/hyrax/relationships/registry_entry.es6 +40 -33
  37. data/app/assets/javascripts/hyrax/relationships/resource.es6 +10 -0
  38. data/app/assets/javascripts/hyrax/select_collection_type.es6 +39 -0
  39. data/app/assets/javascripts/hyrax/{per_page.es6 → sort_and_per_page.es6} +1 -1
  40. data/app/assets/javascripts/hyrax/tabbed_form.es6 +35 -0
  41. data/app/assets/stylesheets/_bootstrap-default-overrides.scss +15 -0
  42. data/app/assets/stylesheets/fileupload/jquery.fileupload-ui.scss +6 -0
  43. data/app/assets/stylesheets/hyrax/_accessibility.scss +16 -0
  44. data/app/assets/stylesheets/hyrax/_catalog.scss +88 -1
  45. data/app/assets/stylesheets/hyrax/_collection_types.scss +53 -0
  46. data/app/assets/stylesheets/hyrax/_collections.scss +616 -22
  47. data/app/assets/stylesheets/hyrax/_featured.scss +16 -0
  48. data/app/assets/stylesheets/hyrax/_file-listing.scss +9 -2
  49. data/app/assets/stylesheets/hyrax/_forms.scss +46 -0
  50. data/app/assets/stylesheets/hyrax/_home-page.scss +10 -0
  51. data/app/assets/stylesheets/hyrax/_hyrax.scss +3 -2
  52. data/app/assets/stylesheets/hyrax/_positioning.scss +0 -11
  53. data/app/assets/stylesheets/hyrax/_recent.scss +26 -0
  54. data/app/assets/stylesheets/hyrax/_representative-media.scss +7 -0
  55. data/app/assets/stylesheets/hyrax/_select_collection_type.scss +45 -0
  56. data/app/assets/stylesheets/hyrax/_select_work_type.scss +0 -4
  57. data/app/assets/stylesheets/hyrax/_styles.scss +2 -17
  58. data/app/assets/stylesheets/hyrax/_variables.scss +2 -2
  59. data/app/assets/stylesheets/hyrax/_viewer.scss +8 -0
  60. data/app/assets/stylesheets/hyrax/_work-show.scss +44 -6
  61. data/app/assets/stylesheets/hyrax/dashboard.scss +7 -2
  62. data/app/authorities/qa/authorities/collections.rb +30 -0
  63. data/app/builders/hyrax/manifest_helper.rb +36 -0
  64. data/app/controllers/concerns/hyrax/admin/stats_behavior.rb +1 -1
  65. data/app/controllers/concerns/hyrax/admin/users_controller_behavior.rb +1 -1
  66. data/app/controllers/concerns/hyrax/collections_controller_behavior.rb +37 -40
  67. data/app/controllers/concerns/hyrax/controller.rb +0 -9
  68. data/app/controllers/concerns/hyrax/themed_layout_controller.rb +4 -1
  69. data/app/controllers/concerns/hyrax/works_controller_behavior.rb +22 -11
  70. data/app/controllers/hyrax/admin/admin_sets_controller.rb +24 -15
  71. data/app/controllers/hyrax/admin/appearances_controller.rb +1 -1
  72. data/app/controllers/hyrax/admin/collection_type_participants_controller.rb +44 -0
  73. data/app/controllers/hyrax/admin/collection_types_controller.rb +97 -0
  74. data/app/controllers/hyrax/admin/features_controller.rb +1 -1
  75. data/app/controllers/hyrax/admin/permission_template_accesses_controller.rb +55 -13
  76. data/app/controllers/hyrax/admin/permission_templates_controller.rb +66 -23
  77. data/app/controllers/hyrax/admin/workflow_roles_controller.rb +1 -1
  78. data/app/controllers/hyrax/admin/workflows_controller.rb +1 -1
  79. data/app/controllers/hyrax/batch_edits_controller.rb +1 -1
  80. data/app/controllers/hyrax/batch_uploads_controller.rb +1 -1
  81. data/app/controllers/hyrax/citations_controller.rb +3 -12
  82. data/app/controllers/hyrax/collections_controller.rb +8 -9
  83. data/app/controllers/hyrax/content_blocks_controller.rb +1 -1
  84. data/app/controllers/hyrax/dashboard/collection_members_controller.rb +73 -0
  85. data/app/controllers/hyrax/dashboard/collections_controller.rb +210 -54
  86. data/app/controllers/hyrax/dashboard/nest_collections_controller.rb +106 -0
  87. data/app/controllers/hyrax/dashboard/profiles_controller.rb +1 -1
  88. data/app/controllers/hyrax/dashboard/works_controller.rb +1 -9
  89. data/app/controllers/hyrax/dashboard_controller.rb +1 -1
  90. data/app/controllers/hyrax/file_sets_controller.rb +7 -75
  91. data/app/controllers/hyrax/my/collections_controller.rb +26 -1
  92. data/app/controllers/hyrax/my/works_controller.rb +16 -1
  93. data/app/controllers/hyrax/my_controller.rb +5 -19
  94. data/app/controllers/hyrax/notifications_controller.rb +1 -1
  95. data/app/controllers/hyrax/pages_controller.rb +3 -2
  96. data/app/controllers/hyrax/stats_controller.rb +3 -0
  97. data/app/controllers/hyrax/transfers_controller.rb +1 -1
  98. data/app/forms/hyrax/forms/admin/appearance.rb +2 -2
  99. data/app/forms/hyrax/forms/admin/collection_type_form.rb +24 -0
  100. data/app/forms/hyrax/forms/admin/collection_type_participant_form.rb +16 -0
  101. data/app/forms/hyrax/forms/admin_set_form.rb +1 -1
  102. data/app/forms/hyrax/forms/batch_edit_form.rb +28 -7
  103. data/app/forms/hyrax/forms/collection_form.rb +71 -13
  104. data/app/forms/hyrax/forms/dashboard/nest_collection_form.rb +98 -0
  105. data/app/forms/hyrax/forms/permission_template_form.rb +13 -13
  106. data/app/forms/hyrax/forms/work_form.rb +58 -14
  107. data/app/helpers/hyrax/ability_helper.rb +3 -0
  108. data/app/helpers/hyrax/citations_behaviors/formatters/chicago_formatter.rb +3 -10
  109. data/app/helpers/hyrax/collections_helper.rb +10 -2
  110. data/app/helpers/hyrax/dashboard_helper_behavior.rb +0 -4
  111. data/app/helpers/hyrax/hyrax_helper_behavior.rb +19 -5
  112. data/app/helpers/hyrax/trophy_helper.rb +0 -1
  113. data/app/indexers/hyrax/indexes_workflow.rb +1 -1
  114. data/app/indexers/hyrax/repository_reindexer.rb +19 -0
  115. data/app/jobs/hyrax/application_job.rb +1 -1
  116. data/app/jobs/import_export_job.rb +1 -1
  117. data/app/jobs/user_edit_profile_event_job.rb +1 -1
  118. data/app/models/admin_set.rb +5 -2
  119. data/app/models/collection_branding_info.rb +39 -0
  120. data/app/models/concerns/hyrax/ability.rb +26 -49
  121. data/app/models/concerns/hyrax/ability/admin_set_ability.rb +40 -0
  122. data/app/models/concerns/hyrax/ability/collection_ability.rb +40 -0
  123. data/app/models/concerns/hyrax/ability/collection_type_ability.rb +16 -0
  124. data/app/models/concerns/hyrax/ability/permission_template_ability.rb +18 -0
  125. data/app/models/concerns/hyrax/ability/solr_document_ability.rb +18 -0
  126. data/app/models/concerns/hyrax/collection_behavior.rb +86 -3
  127. data/app/models/concerns/hyrax/collection_nesting.rb +41 -0
  128. data/app/models/concerns/hyrax/file_set/belongs_to_works.rb +0 -15
  129. data/app/models/concerns/hyrax/file_set_behavior.rb +0 -1
  130. data/app/models/concerns/hyrax/has_rendering.rb +11 -0
  131. data/app/models/concerns/hyrax/human_readable_type.rb +3 -0
  132. data/app/models/concerns/hyrax/solr_document/metadata.rb +3 -0
  133. data/app/models/concerns/hyrax/solr_document_behavior.rb +8 -2
  134. data/app/models/concerns/hyrax/user.rb +11 -6
  135. data/app/models/concerns/hyrax/with_events.rb +12 -6
  136. data/app/models/concerns/hyrax/work_behavior.rb +3 -1
  137. data/app/models/hyrax/batch_create_operation.rb +1 -1
  138. data/app/models/hyrax/collection_type.rb +155 -0
  139. data/app/models/hyrax/collection_type_participant.rb +39 -0
  140. data/app/models/hyrax/operation.rb +14 -2
  141. data/app/models/hyrax/permission_template.rb +23 -1
  142. data/app/models/hyrax/permission_template_access.rb +56 -7
  143. data/app/models/hyrax/uploaded_file.rb +4 -1
  144. data/app/models/sipity/workflow.rb +6 -4
  145. data/app/presenters/hyrax/admin/workflow_role_presenter.rb +3 -3
  146. data/app/presenters/hyrax/admin_set_options_presenter.rb +1 -1
  147. data/app/presenters/hyrax/admin_set_presenter.rb +16 -0
  148. data/app/presenters/hyrax/collection_options_presenter.rb +1 -0
  149. data/app/presenters/hyrax/collection_presenter.rb +134 -6
  150. data/app/presenters/hyrax/displays_image.rb +39 -0
  151. data/app/presenters/hyrax/file_set_presenter.rb +1 -4
  152. data/app/presenters/hyrax/fixity_status_presenter.rb +2 -2
  153. data/app/presenters/hyrax/homepage_presenter.rb +20 -0
  154. data/app/presenters/hyrax/menu_presenter.rb +2 -1
  155. data/app/presenters/hyrax/select_collection_type_list_presenter.rb +42 -0
  156. data/app/presenters/hyrax/select_collection_type_presenter.rb +11 -0
  157. data/app/presenters/hyrax/select_type_presenter.rb +13 -4
  158. data/app/presenters/hyrax/work_show_presenter.rb +52 -1
  159. data/app/renderers/hyrax/renderers/attribute_renderer.rb +1 -1
  160. data/app/renderers/hyrax/renderers/license_attribute_renderer.rb +1 -1
  161. data/app/renderers/hyrax/renderers/rights_statement_attribute_renderer.rb +3 -2
  162. data/app/search_builders/hyrax/admin_admin_set_member_search_builder.rb +10 -1
  163. data/app/search_builders/hyrax/admin_set_search_builder.rb +9 -2
  164. data/app/search_builders/hyrax/collection_member_search_builder.rb +21 -8
  165. data/app/search_builders/hyrax/collection_search_builder.rb +37 -0
  166. data/app/search_builders/hyrax/dashboard/collections_search_builder.rb +42 -0
  167. data/app/search_builders/hyrax/dashboard/managed_search_filters.rb +24 -0
  168. data/app/search_builders/hyrax/dashboard/nested_collections_search_builder.rb +123 -0
  169. data/app/search_builders/hyrax/dashboard/works_search_builder.rb +18 -0
  170. data/app/search_builders/hyrax/filter_suppressed_with_roles.rb +5 -1
  171. data/app/search_builders/hyrax/my/collections_search_builder.rb +20 -3
  172. data/app/search_builders/hyrax/nested_collections_parent_search_builder.rb +27 -0
  173. data/app/search_builders/hyrax/search_filters.rb +8 -0
  174. data/app/services/hyrax/adapters/nesting_index_adapter.rb +192 -0
  175. data/app/services/hyrax/admin_set_create_service.rb +3 -2
  176. data/app/services/hyrax/admin_set_member_service.rb +40 -0
  177. data/app/services/hyrax/batch_create_failure_service.rb +4 -3
  178. data/app/services/hyrax/collection_types/create_service.rb +143 -0
  179. data/app/services/hyrax/collection_types/permissions_service.rb +233 -0
  180. data/app/services/hyrax/collections/collection_member_service.rb +91 -0
  181. data/app/services/hyrax/collections/managed_collections_service.rb +16 -0
  182. data/app/services/hyrax/collections/migration_service.rb +81 -0
  183. data/app/services/hyrax/collections/nested_collection_persistence_service.rb +26 -0
  184. data/app/services/hyrax/collections/nested_collection_query_service.rb +187 -0
  185. data/app/services/hyrax/collections/permissions_create_service.rb +71 -0
  186. data/app/services/hyrax/collections/permissions_service.rb +234 -0
  187. data/app/services/hyrax/collections_service.rb +3 -3
  188. data/app/services/hyrax/default_middleware_stack.rb +35 -0
  189. data/app/services/hyrax/file_set_fixity_check_service.rb +1 -1
  190. data/app/services/hyrax/graph_exporter.rb +19 -15
  191. data/app/services/hyrax/iiif_authorization_service.rb +19 -0
  192. data/app/services/hyrax/multiple_membership_checker.rb +78 -0
  193. data/app/services/hyrax/noid.rb +1 -3
  194. data/app/services/hyrax/qa_select_service.rb +11 -2
  195. data/app/services/hyrax/workflow/status_list_service.rb +1 -1
  196. data/app/services/hyrax/working_directory.rb +0 -8
  197. data/app/services/hyrax/works/managed_works_service.rb +16 -0
  198. data/app/views/_flash_msg.html.erb +1 -1
  199. data/app/views/_masthead.html.erb +0 -1
  200. data/app/views/catalog/_document.html.erb +3 -1
  201. data/app/views/catalog/_document_list.html.erb +2 -2
  202. data/app/views/catalog/_index_header_list_collection.html.erb +4 -3
  203. data/app/views/catalog/_index_header_list_default.html.erb +3 -3
  204. data/app/views/catalog/_index_list_default.html.erb +29 -14
  205. data/app/views/catalog/_thumbnail_list_collection.html.erb +3 -4
  206. data/app/views/catalog/_thumbnail_list_default.html.erb +5 -3
  207. data/app/views/hyrax/admin/admin_sets/_form.html.erb +2 -1
  208. data/app/views/hyrax/admin/admin_sets/_form_participant_table.html.erb +1 -1
  209. data/app/views/hyrax/admin/admin_sets/_form_participants.html.erb +1 -1
  210. data/app/views/hyrax/admin/admin_sets/_show_document_list_row.html.erb +3 -3
  211. data/app/views/hyrax/admin/admin_sets/edit.html.erb +1 -1
  212. data/app/views/hyrax/admin/collection_types/_form.html.erb +61 -0
  213. data/app/views/hyrax/admin/collection_types/_form_metadata.html.erb +2 -0
  214. data/app/views/hyrax/admin/collection_types/_form_metadata_admin_set.html.erb +2 -0
  215. data/app/views/hyrax/admin/collection_types/_form_participant_table.html.erb +26 -0
  216. data/app/views/hyrax/admin/collection_types/_form_participants.html.erb +62 -0
  217. data/app/views/hyrax/admin/collection_types/_form_settings.html.erb +39 -0
  218. data/app/views/hyrax/admin/collection_types/edit.html.erb +10 -0
  219. data/app/views/hyrax/admin/collection_types/index.html.erb +88 -0
  220. data/app/views/hyrax/admin/collection_types/new.html.erb +10 -0
  221. data/app/views/hyrax/base/_attribute_rows.html.erb +1 -0
  222. data/app/views/hyrax/base/_citations.html.erb +10 -6
  223. data/app/views/hyrax/base/_form_child_work_relationships.html.erb +22 -29
  224. data/app/views/hyrax/base/_form_files.html.erb +29 -16
  225. data/app/views/hyrax/base/_form_media.html.erb +1 -0
  226. data/app/views/hyrax/base/_form_member_of_collections.html.erb +44 -6
  227. data/app/views/hyrax/base/_form_metadata.html.erb +0 -3
  228. data/app/views/hyrax/base/_form_progress.html.erb +2 -1
  229. data/app/views/hyrax/base/_form_relationships.html.erb +3 -2
  230. data/app/views/hyrax/base/_form_rendering.html.erb +14 -0
  231. data/app/views/hyrax/base/_form_representative.html.erb +2 -2
  232. data/app/views/hyrax/base/_form_share.html.erb +44 -41
  233. data/app/views/hyrax/base/_form_thumbnail.html.erb +2 -2
  234. data/app/views/hyrax/base/_guts4form.html.erb +2 -2
  235. data/app/views/hyrax/base/_member.html.erb +3 -4
  236. data/app/views/hyrax/base/_metadata.html.erb +1 -5
  237. data/app/views/hyrax/base/_relationships.html.erb +1 -1
  238. data/app/views/hyrax/base/_relationships_parent_row.html.erb +1 -1
  239. data/app/views/hyrax/base/_representative_media.html.erb +8 -2
  240. data/app/views/hyrax/base/_work_title.erb +14 -7
  241. data/app/views/hyrax/base/_work_type.html.erb +4 -0
  242. data/app/views/hyrax/base/_workflow_actions.html.erb +7 -7
  243. data/app/views/hyrax/base/_workflow_actions_widget.erb +4 -2
  244. data/app/views/hyrax/base/show.html.erb +35 -26
  245. data/app/views/hyrax/batch_edits/edit.html.erb +1 -1
  246. data/app/views/hyrax/collections/_collection_description.erb +1 -1
  247. data/app/views/hyrax/collections/_default_group.html.erb +9 -11
  248. data/app/views/hyrax/collections/_list_collections.html.erb +19 -12
  249. data/app/views/hyrax/collections/_paginate.html.erb +5 -4
  250. data/app/views/hyrax/collections/_search_form.html.erb +1 -1
  251. data/app/views/hyrax/collections/_search_results.html.erb +0 -2
  252. data/app/views/hyrax/collections/_show_descriptions.html.erb +7 -6
  253. data/app/views/hyrax/collections/_show_document_list.html.erb +3 -3
  254. data/app/views/hyrax/collections/_show_document_list_row.html.erb +3 -3
  255. data/app/views/hyrax/collections/_show_parent_collections.html.erb +41 -0
  256. data/app/views/hyrax/collections/_sort_and_per_page.html.erb +16 -24
  257. data/app/views/hyrax/collections/_subcollection_list.html.erb +13 -0
  258. data/app/views/hyrax/collections/_view_type_group.html.erb +1 -1
  259. data/app/views/hyrax/collections/show.html.erb +120 -31
  260. data/app/views/hyrax/dashboard/collections/_button_for_batch_delete_collection.html.erb +4 -0
  261. data/app/views/hyrax/dashboard/collections/_button_for_remove_selected_from_collection.html.erb +0 -1
  262. data/app/views/hyrax/dashboard/collections/_button_for_update_collection.html.erb +1 -1
  263. data/app/views/hyrax/dashboard/collections/_button_remove_from_collection.html.erb +1 -1
  264. data/app/views/hyrax/dashboard/collections/_collection_title.html.erb +25 -0
  265. data/app/views/hyrax/dashboard/collections/_document_list.html.erb +1 -5
  266. data/app/views/hyrax/dashboard/collections/_edit_actions.html.erb +2 -2
  267. data/app/views/hyrax/dashboard/collections/_flash_msg.html.erb +9 -0
  268. data/app/views/hyrax/dashboard/collections/_form.html.erb +46 -24
  269. data/app/views/hyrax/dashboard/collections/_form_branding.html.erb +153 -0
  270. data/app/views/hyrax/dashboard/collections/_form_default_group_delt.html.erb +27 -0
  271. data/app/views/hyrax/dashboard/collections/_form_discovery.html.erb +18 -0
  272. data/app/views/hyrax/dashboard/collections/_form_share.html.erb +69 -81
  273. data/app/views/hyrax/dashboard/collections/_form_share_table.html.erb +31 -0
  274. data/app/views/hyrax/dashboard/collections/_list_collections.html.erb +54 -37
  275. data/app/views/hyrax/dashboard/collections/_modal_remove_from_collection.html.erb +17 -0
  276. data/app/views/hyrax/dashboard/collections/_modal_remove_sub_collection.html.erb +17 -0
  277. data/app/views/hyrax/dashboard/collections/_show_actions.html.erb +27 -21
  278. data/app/views/hyrax/dashboard/collections/_show_add_items_actions.html.erb +25 -0
  279. data/app/views/hyrax/dashboard/collections/_show_document_list.html.erb +4 -3
  280. data/app/views/hyrax/dashboard/collections/_show_document_list_row.html.erb +6 -5
  281. data/app/views/hyrax/dashboard/collections/_show_parent_collection_row.html.erb +6 -0
  282. data/app/views/hyrax/dashboard/collections/_show_parent_collections.html.erb +37 -0
  283. data/app/views/hyrax/dashboard/collections/_show_subcollection_actions.html.erb +26 -0
  284. data/app/views/hyrax/dashboard/collections/_sort_and_per_page.html.erb +28 -27
  285. data/app/views/hyrax/dashboard/collections/_subcollection_list.html.erb +21 -0
  286. data/app/views/hyrax/dashboard/collections/_work_action_menu.html.erb +1 -1
  287. data/app/views/hyrax/dashboard/collections/edit.html.erb +8 -31
  288. data/app/views/hyrax/dashboard/collections/new.html.erb +2 -3
  289. data/app/views/hyrax/dashboard/collections/show.html.erb +102 -35
  290. data/app/views/hyrax/dashboard/sidebar/_configuration.html.erb +5 -0
  291. data/app/views/hyrax/dashboard/sidebar/_repository_content.html.erb +0 -5
  292. data/app/views/hyrax/dashboard/sidebar/_tasks.html.erb +10 -0
  293. data/app/views/hyrax/dashboard/works/_default_group.html.erb +1 -0
  294. data/app/views/hyrax/dashboard/works/_list_works.html.erb +4 -0
  295. data/app/views/hyrax/file_sets/_extra_fields_modal.html.erb +1 -1
  296. data/app/views/hyrax/file_sets/_form.html.erb +2 -2
  297. data/app/views/hyrax/file_sets/_show_characterization_details.html.erb +1 -1
  298. data/app/views/hyrax/file_sets/media_display/_image.html.erb +3 -5
  299. data/app/views/hyrax/file_sets/media_display/_office_document.html.erb +3 -5
  300. data/app/views/hyrax/file_sets/media_display/_pdf.html.erb +3 -5
  301. data/app/views/hyrax/homepage/_featured.html.erb +5 -5
  302. data/app/views/hyrax/homepage/_featured_fields.html.erb +10 -14
  303. data/app/views/hyrax/homepage/_featured_works.html.erb +1 -1
  304. data/app/views/hyrax/homepage/_home_content.html.erb +2 -2
  305. data/app/views/hyrax/homepage/_recent_document.html.erb +14 -12
  306. data/app/views/hyrax/homepage/_recently_uploaded.html.erb +2 -6
  307. data/app/views/hyrax/homepage/index.html.erb +4 -2
  308. data/app/views/hyrax/my/_admin_set_action_menu.html.erb +54 -0
  309. data/app/views/hyrax/my/_collection_action_menu.html.erb +41 -9
  310. data/app/views/hyrax/my/_facet_pivot.html.erb +26 -0
  311. data/app/views/hyrax/my/_search_header.html.erb +1 -15
  312. data/app/views/hyrax/my/_sort_and_per_page.html.erb +12 -13
  313. data/app/views/hyrax/my/_work_action_menu.html.erb +17 -15
  314. data/app/views/hyrax/my/collections/_batch_actions.html.erb +5 -0
  315. data/app/views/hyrax/my/collections/_default_group.html.erb +21 -12
  316. data/app/views/hyrax/my/collections/_list_collections.html.erb +57 -35
  317. data/app/views/hyrax/my/collections/_modal_add_subcollection.html.erb +38 -0
  318. data/app/views/hyrax/my/collections/_modal_add_to_collection.html.erb +31 -0
  319. data/app/views/hyrax/my/collections/_modal_add_to_collection_deny.html.erb +12 -0
  320. data/app/views/hyrax/my/collections/_modal_add_to_collection_permission_deny.html.erb +12 -0
  321. data/app/views/hyrax/my/collections/_modal_collection_types_to_create.html.erb +36 -0
  322. data/app/views/hyrax/my/collections/_modal_delete_admin_set_deny.html.erb +12 -0
  323. data/app/views/hyrax/my/collections/_modal_delete_collection.html.erb +19 -0
  324. data/app/views/hyrax/my/collections/_modal_delete_collection_deny.html.erb +14 -0
  325. data/app/views/hyrax/my/collections/_modal_delete_deny.html.erb +14 -0
  326. data/app/views/hyrax/my/collections/_modal_delete_empty_collection.html.erb +18 -0
  327. data/app/views/hyrax/my/collections/_modal_delete_selected_collections.html.erb +17 -0
  328. data/app/views/hyrax/my/collections/_modal_edit_deny.html.erb +14 -0
  329. data/app/views/hyrax/my/collections/_tabs.html.erb +3 -3
  330. data/app/views/hyrax/my/collections/index.html.erb +46 -21
  331. data/app/views/hyrax/my/works/_batch_actions.html.erb +14 -0
  332. data/app/views/hyrax/my/works/_default_group.html.erb +10 -12
  333. data/app/views/hyrax/my/works/_tabs.html.erb +1 -1
  334. data/app/views/hyrax/my/works/index.html.erb +7 -5
  335. data/app/views/hyrax/notifications/_notifications.html.erb +3 -3
  336. data/app/views/hyrax/permissions/confirm_access.html.erb +1 -1
  337. data/app/views/hyrax/stats/file.html.erb +1 -1
  338. data/app/views/hyrax/stats/work.html.erb +1 -1
  339. data/app/views/hyrax/transfers/_received.html.erb +1 -1
  340. data/app/views/hyrax/transfers/_sent.html.erb +1 -1
  341. data/app/views/hyrax/uploads/_js_templates_branding.html.erb +120 -0
  342. data/app/views/hyrax/users/_activity_log.html.erb +3 -3
  343. data/app/views/kaminari/blacklight_compact/_paginator.html.erb +23 -0
  344. data/app/views/layouts/hyrax.html.erb +9 -11
  345. data/app/views/layouts/{dashboard.html.erb → hyrax/dashboard.html.erb} +0 -0
  346. data/app/views/shared/_select_work_type_modal.html.erb +25 -26
  347. data/config/features.rb +4 -0
  348. data/config/initializers/hyrax_callbacks.rb +2 -2
  349. data/config/initializers/samvera-nesting_indexer_initializer.rb +15 -0
  350. data/config/locales/hyrax.de.yml +364 -79
  351. data/config/locales/hyrax.en.yml +874 -584
  352. data/config/locales/hyrax.es.yml +323 -35
  353. data/config/locales/hyrax.fr.yml +323 -39
  354. data/config/locales/hyrax.it.yml +322 -39
  355. data/config/locales/hyrax.pt-BR.yml +317 -39
  356. data/config/locales/hyrax.zh.yml +420 -142
  357. data/config/routes.rb +17 -0
  358. data/hyrax.gemspec +58 -57
  359. data/lib/generators/hyrax/assets_generator.rb +2 -4
  360. data/lib/generators/hyrax/clamav_generator.rb +0 -2
  361. data/lib/generators/hyrax/config_generator.rb +0 -2
  362. data/lib/generators/hyrax/install_generator.rb +12 -3
  363. data/lib/generators/hyrax/riiif_generator.rb +54 -0
  364. data/lib/generators/hyrax/templates/app/assets/images/us_404.svg +91 -0
  365. data/lib/generators/hyrax/templates/config/initializers/hyrax.rb +48 -3
  366. data/lib/generators/hyrax/templates/config/initializers/riiif.rb +26 -0
  367. data/lib/generators/hyrax/templates/config/locales/hyrax.en.yml +4 -4
  368. data/lib/generators/hyrax/templates/config/locales/hyrax.fr.yml +0 -4
  369. data/lib/generators/hyrax/templates/db/migrate/20170808160431_create_collection_types.rb.erb +17 -0
  370. data/lib/generators/hyrax/templates/db/migrate/20170808160432_update_collection_type_column_names.rb.erb +9 -0
  371. data/lib/generators/hyrax/templates/db/migrate/20170810190549_update_collection_type_column_options.rb.erb +9 -0
  372. data/lib/generators/hyrax/templates/db/migrate/20170816180307_create_collection_branding_infos.rb.erb +15 -0
  373. data/lib/generators/hyrax/templates/db/migrate/20170817152654_create_collection_type_participants.rb.erb +11 -0
  374. data/lib/generators/hyrax/templates/db/migrate/20170821152307_rename_admin_set_id_to_source_id.rb.erb +5 -0
  375. data/lib/generators/hyrax/templates/db/migrate/20171103080032_add_collection_type_sharing_options.rb.erb +5 -0
  376. data/lib/generators/hyrax/templates/db/seeds.rb +226 -22
  377. data/lib/generators/hyrax/work/templates/controller.rb.erb +1 -1
  378. data/lib/generators/hyrax/work/templates/feature_spec.rb.erb +37 -1
  379. data/lib/generators/hyrax/work/templates/form.rb.erb +1 -0
  380. data/lib/generators/hyrax/work/templates/indexer.rb.erb +0 -1
  381. data/lib/generators/hyrax/work/templates/locale.de.yml.erb +1 -1
  382. data/lib/generators/hyrax/work/templates/locale.en.yml.erb +1 -1
  383. data/lib/generators/hyrax/work/templates/locale.es.yml.erb +1 -1
  384. data/lib/generators/hyrax/work/templates/locale.fr.yml.erb +1 -1
  385. data/lib/generators/hyrax/work/templates/locale.it.yml.erb +1 -1
  386. data/lib/generators/hyrax/work/templates/locale.pt-BR.yml.erb +1 -1
  387. data/lib/generators/hyrax/work/templates/locale.zh.yml.erb +1 -1
  388. data/lib/generators/hyrax/work/templates/model.rb.erb +0 -2
  389. data/lib/hyrax.rb +1 -1
  390. data/lib/hyrax/configuration.rb +96 -7
  391. data/lib/hyrax/engine.rb +5 -4
  392. data/lib/hyrax/rails/routes.rb +1 -1
  393. data/lib/hyrax/version.rb +1 -1
  394. data/lib/tasks/default_admin_set.rake +5 -3
  395. data/lib/tasks/default_collection_type.rake +19 -0
  396. data/lib/tasks/migrate.rake +8 -0
  397. data/spec/abilities/ability_spec.rb +4 -1
  398. data/spec/abilities/admin_set_ability_spec.rb +172 -0
  399. data/spec/abilities/collection_ability_spec.rb +194 -0
  400. data/spec/abilities/collection_type_ability_spec.rb +72 -0
  401. data/spec/abilities/file_set_abilities_spec.rb +3 -3
  402. data/spec/abilities/generic_work_abilities_spec.rb +5 -5
  403. data/spec/abilities/permission_template_ability_spec.rb +145 -0
  404. data/spec/abilities/solr_document_ability_spec.rb +27 -0
  405. data/spec/actors/hyrax/actors/apply_permission_template_actor_spec.rb +96 -28
  406. data/spec/actors/hyrax/actors/collections_membership_actor_spec.rb +283 -15
  407. data/spec/actors/hyrax/actors/create_with_remote_files_actor_spec.rb +7 -7
  408. data/spec/actors/hyrax/actors/default_admin_set_actor_spec.rb +1 -1
  409. data/spec/actors/hyrax/actors/file_actor_spec.rb +0 -1
  410. data/spec/actors/hyrax/actors/file_set_actor_spec.rb +8 -6
  411. data/spec/actors/hyrax/actors/generic_work_actor_spec.rb +11 -39
  412. data/spec/actors/hyrax/actors/interpret_visibility_actor_spec.rb +15 -15
  413. data/spec/actors/hyrax/actors/model_actor_spec.rb +0 -2
  414. data/spec/authorities/qa/authorities/collections_spec.rb +68 -0
  415. data/spec/channels/hyrax/application_cable/channel_spec.rb +1 -1
  416. data/spec/channels/hyrax/application_cable/connection_spec.rb +1 -1
  417. data/spec/channels/hyrax/notifications_channel_spec.rb +1 -1
  418. data/spec/controllers/catalog_controller_spec.rb +1 -1
  419. data/spec/controllers/hyrax/admin/admin_sets_controller_spec.rb +27 -1
  420. data/spec/controllers/hyrax/admin/collection_type_participants_controller_spec.rb +152 -0
  421. data/spec/controllers/hyrax/admin/collection_types_controller_spec.rb +320 -0
  422. data/spec/controllers/hyrax/admin/permission_template_accesses_controller_spec.rb +68 -29
  423. data/spec/controllers/hyrax/admin/permission_templates_controller_spec.rb +37 -10
  424. data/spec/controllers/hyrax/admin/strategies_controller_spec.rb +2 -13
  425. data/spec/controllers/hyrax/admin/workflow_roles_controller_spec.rb +52 -2
  426. data/spec/controllers/hyrax/batch_edits_controller_spec.rb +75 -4
  427. data/spec/controllers/hyrax/batch_uploads_controller_spec.rb +2 -2
  428. data/spec/controllers/hyrax/collections_controller_spec.rb +15 -6
  429. data/spec/controllers/hyrax/content_blocks_controller_spec.rb +5 -5
  430. data/spec/controllers/hyrax/dashboard/collection_members_controller_spec.rb +408 -0
  431. data/spec/controllers/hyrax/dashboard/collections_controller_spec.rb +114 -18
  432. data/spec/controllers/hyrax/dashboard/nest_collections_controller_spec.rb +360 -0
  433. data/spec/controllers/hyrax/dashboard/profiles_controller_spec.rb +2 -2
  434. data/spec/controllers/hyrax/dashboard/works_controller_spec.rb +1 -1
  435. data/spec/controllers/hyrax/downloads_controller_spec.rb +3 -3
  436. data/spec/controllers/hyrax/featured_work_lists_controller_spec.rb +2 -2
  437. data/spec/controllers/hyrax/file_sets_controller_spec.rb +8 -136
  438. data/spec/controllers/hyrax/fixity_checks_controller_spec.rb +1 -1
  439. data/spec/controllers/hyrax/generic_works_controller_spec.rb +64 -2
  440. data/spec/controllers/hyrax/homepage_controller_spec.rb +1 -1
  441. data/spec/controllers/hyrax/my/works_controller_spec.rb +4 -1
  442. data/spec/controllers/hyrax/pages_controller_spec.rb +11 -11
  443. data/spec/controllers/hyrax/users_controller_spec.rb +1 -1
  444. data/spec/controllers/hyrax/workflow_actions_controller_spec.rb +1 -1
  445. data/spec/conversions/power_converters/polymorphic_type_spec.rb +2 -2
  446. data/spec/conversions/power_converters/sipity_agent_spec.rb +1 -1
  447. data/spec/conversions/power_converters/sipity_role_spec.rb +1 -1
  448. data/spec/conversions/power_converters/sipity_workflow_state_spec.rb +1 -1
  449. data/spec/factories/admin_sets.rb +3 -3
  450. data/spec/factories/collection_branding_infos.rb +11 -0
  451. data/spec/factories/collection_type_participants.rb +8 -0
  452. data/spec/factories/collection_types.rb +104 -0
  453. data/spec/factories/collections.rb +323 -0
  454. data/spec/factories/collections_factory.rb +106 -3
  455. data/spec/factories/file_sets.rb +2 -2
  456. data/spec/factories/generic_works.rb +22 -14
  457. data/spec/factories/object_id.rb +6 -0
  458. data/spec/factories/permission_templates.rb +46 -8
  459. data/spec/factories/users.rb +1 -1
  460. data/spec/factory_tests/collections_factory_spec.rb +211 -0
  461. data/spec/features/admin_spec.rb +1 -1
  462. data/spec/features/batch_create_spec.rb +1 -1
  463. data/spec/features/batch_edit_spec.rb +0 -1
  464. data/spec/features/browse_catalog_spec.rb +1 -3
  465. data/spec/features/browse_dashboard_works_spec.rb +0 -1
  466. data/spec/features/collection_multi_membership_spec.rb +188 -0
  467. data/spec/features/collection_spec.rb +45 -7
  468. data/spec/features/collection_type_spec.rb +338 -0
  469. data/spec/features/create_child_work_spec.rb +1 -1
  470. data/spec/features/create_work_admin_spec.rb +44 -0
  471. data/spec/features/create_work_spec.rb +1 -1
  472. data/spec/features/dashboard/all_works.rb +1 -1
  473. data/spec/features/dashboard/collection_spec.rb +724 -115
  474. data/spec/features/delete_work_spec.rb +1 -1
  475. data/spec/features/edit_file_spec.rb +1 -1
  476. data/spec/features/edit_work_spec.rb +1 -1
  477. data/spec/features/embargo_spec.rb +1 -1
  478. data/spec/features/homepage_spec.rb +3 -3
  479. data/spec/features/lease_spec.rb +1 -1
  480. data/spec/features/notifications_spec.rb +2 -2
  481. data/spec/features/ownership_transfer_spec.rb +1 -2
  482. data/spec/features/proxy_spec.rb +1 -1
  483. data/spec/features/search_spec.rb +12 -11
  484. data/spec/features/static_pages_spec.rb +1 -1
  485. data/spec/features/users_spec.rb +1 -1
  486. data/spec/features/work_generator_spec.rb +1 -1
  487. data/spec/features/work_show_spec.rb +4 -4
  488. data/spec/features/workflow_roles_spec.rb +1 -1
  489. data/spec/features/workflow_state_changes_spec.rb +2 -2
  490. data/spec/forms/hyrax/forms/admin/collection_type_form_spec.rb +106 -0
  491. data/spec/forms/hyrax/forms/admin/collection_type_participant_form_spec.rb +10 -0
  492. data/spec/forms/hyrax/forms/admin_set_form_spec.rb +1 -1
  493. data/spec/forms/hyrax/forms/batch_edit_form_spec.rb +1 -1
  494. data/spec/forms/hyrax/forms/batch_upload_form_spec.rb +1 -0
  495. data/spec/forms/hyrax/forms/collection_form_spec.rb +52 -4
  496. data/spec/forms/hyrax/forms/dashboard/nest_collection_form_spec.rb +159 -0
  497. data/spec/forms/hyrax/forms/permission_template_form_spec.rb +15 -12
  498. data/spec/forms/hyrax/forms/work_form_spec.rb +61 -12
  499. data/spec/forms/hyrax/forms/workflow_action_form_spec.rb +1 -1
  500. data/spec/forms/hyrax/generic_work_form_spec.rb +6 -3
  501. data/spec/helpers/hyrax/ability_helper_spec.rb +11 -0
  502. data/spec/helpers/hyrax/collections_helper_spec.rb +17 -39
  503. data/spec/helpers/hyrax/content_block_helper_spec.rb +1 -1
  504. data/spec/helpers/{dashboard_helper_spec.rb → hyrax/dashboard_helper_behavior_spec.rb} +1 -12
  505. data/spec/helpers/hyrax/trophy_helper_spec.rb +1 -1
  506. data/spec/helpers/hyrax_helper_spec.rb +0 -3
  507. data/spec/indexers/hyrax/generic_work_indexer_spec.rb +4 -4
  508. data/spec/indexers/hyrax/repository_reindexer_spec.rb +8 -0
  509. data/spec/javascripts/relationships_control_spec.js.coffee +3 -3
  510. data/spec/javascripts/settings_spec.js +73 -0
  511. data/spec/jobs/user_edit_profile_event_job_spec.rb +1 -1
  512. data/spec/lib/hyrax/configuration_spec.rb +16 -0
  513. data/spec/models/admin_set_spec.rb +42 -4
  514. data/spec/models/collection_branding_info_spec.rb +61 -0
  515. data/spec/models/collection_spec.rb +228 -3
  516. data/spec/models/concerns/hyrax/collection_nesting_spec.rb +64 -0
  517. data/spec/models/file_set_spec.rb +4 -4
  518. data/spec/models/generic_work_spec.rb +1 -1
  519. data/spec/models/hyrax/batch_create_operation_spec.rb +59 -0
  520. data/spec/models/hyrax/collection_type_participant_spec.rb +43 -0
  521. data/spec/models/hyrax/collection_type_spec.rb +235 -0
  522. data/spec/models/hyrax/operation_spec.rb +27 -1
  523. data/spec/models/hyrax/permission_template_access_spec.rb +128 -5
  524. data/spec/models/hyrax/permission_template_spec.rb +85 -29
  525. data/spec/models/hyrax/user_usage_stats_spec.rb +1 -1
  526. data/spec/models/hyrax/work_behavior_spec.rb +12 -2
  527. data/spec/models/sipity/agent_spec.rb +1 -1
  528. data/spec/models/sipity/comment_spec.rb +1 -1
  529. data/spec/models/sipity/entity_spec.rb +3 -3
  530. data/spec/models/sipity/entity_specific_responsibility_spec.rb +1 -1
  531. data/spec/models/sipity/notifiable_context_spec.rb +1 -1
  532. data/spec/models/sipity/notification_recipient_spec.rb +1 -1
  533. data/spec/models/sipity/notification_spec.rb +1 -1
  534. data/spec/models/sipity/role_spec.rb +1 -1
  535. data/spec/models/sipity/workflow_action_spec.rb +1 -1
  536. data/spec/models/sipity/workflow_responsibility_spec.rb +1 -1
  537. data/spec/models/sipity/workflow_role_spec.rb +1 -1
  538. data/spec/models/sipity/workflow_spec.rb +7 -7
  539. data/spec/models/sipity/workflow_state_action_permission_spec.rb +1 -1
  540. data/spec/models/sipity/workflow_state_action_spec.rb +1 -1
  541. data/spec/models/sipity/workflow_state_spec.rb +1 -1
  542. data/spec/models/solr_document_spec.rb +24 -0
  543. data/spec/models/user_mailbox_spec.rb +0 -2
  544. data/spec/models/user_spec.rb +7 -7
  545. data/spec/presenters/hyrax/admin/users_presenter_spec.rb +2 -2
  546. data/spec/presenters/hyrax/admin_set_options_presenter_spec.rb +7 -7
  547. data/spec/presenters/hyrax/admin_set_presenter_spec.rb +20 -0
  548. data/spec/presenters/hyrax/collection_options_presenter_spec.rb +2 -0
  549. data/spec/presenters/hyrax/collection_presenter_spec.rb +375 -6
  550. data/spec/presenters/hyrax/file_set_presenter_spec.rb +124 -5
  551. data/spec/presenters/hyrax/inspect_work_presenter_spec.rb +1 -1
  552. data/spec/presenters/hyrax/menu_presenter_spec.rb +5 -0
  553. data/spec/presenters/hyrax/select_collection_type_list_presenter_spec.rb +59 -0
  554. data/spec/presenters/hyrax/select_collection_type_presenter_spec.rb +10 -0
  555. data/spec/presenters/hyrax/select_type_presenter_spec.rb +12 -0
  556. data/spec/presenters/hyrax/work_show_presenter_spec.rb +116 -1
  557. data/spec/presenters/hyrax/workflow_presenter_spec.rb +1 -1
  558. data/spec/renderers/hyrax/renderers/attribute_renderer_spec.rb +6 -6
  559. data/spec/renderers/hyrax/renderers/date_attribute_renderer_spec.rb +2 -2
  560. data/spec/renderers/hyrax/renderers/external_link_attribute_renderer_spec.rb +1 -1
  561. data/spec/renderers/hyrax/renderers/faceted_attribute_renderer_spec.rb +2 -2
  562. data/spec/renderers/hyrax/renderers/license_attribute_renderer_spec.rb +2 -2
  563. data/spec/renderers/hyrax/renderers/linked_attribute_renderer_spec.rb +2 -2
  564. data/spec/renderers/hyrax/renderers/rights_statement_attribute_renderer_spec.rb +10 -1
  565. data/spec/requests/riiif_spec.rb +32 -0
  566. data/spec/routing/collection_permission_templates_routes_spec.rb +31 -0
  567. data/spec/routing/collection_types_routes.rb +35 -0
  568. data/spec/routing/dashboard_routes_spec.rb +37 -0
  569. data/spec/routing/route_spec.rb +4 -10
  570. data/spec/search_builders/hyrax/admin_admin_set_member_search_builder_spec.rb +2 -2
  571. data/spec/search_builders/hyrax/admin_set_search_builder_spec.rb +4 -40
  572. data/spec/search_builders/hyrax/collection_member_search_builder_spec.rb +53 -0
  573. data/spec/search_builders/hyrax/collection_search_builder_spec.rb +74 -0
  574. data/spec/search_builders/hyrax/dashboard/collections_search_builder_spec.rb +92 -0
  575. data/spec/search_builders/hyrax/dashboard/nested_collections_search_builder_spec.rb +85 -0
  576. data/spec/search_builders/hyrax/dashboard/works_search_builder_spec.rb +44 -0
  577. data/spec/search_builders/hyrax/my/collections_search_builder_spec.rb +35 -0
  578. data/spec/search_builders/hyrax/work_search_builder_spec.rb +47 -10
  579. data/spec/services/hyrax/adapters/nesting_index_adapter_spec.rb +191 -0
  580. data/spec/services/hyrax/admin_set_create_service_spec.rb +6 -2
  581. data/spec/services/hyrax/admin_set_member_service_spec.rb +21 -0
  582. data/spec/services/hyrax/batch_create_failure_service_spec.rb +6 -2
  583. data/spec/services/hyrax/collection_types/create_service_spec.rb +91 -0
  584. data/spec/services/hyrax/collection_types/permissions_service_spec.rb +297 -0
  585. data/spec/services/hyrax/collections/collection_member_service_spec.rb +49 -0
  586. data/spec/services/hyrax/collections/managed_collections_service_spec.rb +17 -0
  587. data/spec/services/hyrax/collections/migration_service_spec.rb +280 -0
  588. data/spec/services/hyrax/collections/nested_collection_persistence_service_spec.rb +28 -0
  589. data/spec/services/hyrax/collections/nested_collection_query_service_spec.rb +353 -0
  590. data/spec/services/hyrax/collections/permissions_create_service_spec.rb +41 -0
  591. data/spec/services/hyrax/collections/permissions_service_spec.rb +278 -0
  592. data/spec/services/hyrax/collections_service_spec.rb +30 -8
  593. data/spec/services/hyrax/embargo_service_spec.rb +26 -5
  594. data/spec/services/hyrax/iiif_authorization_service_spec.rb +43 -0
  595. data/spec/services/hyrax/multiple_membership_checker_spec.rb +155 -0
  596. data/spec/services/hyrax/qa_select_service_spec.rb +8 -2
  597. data/spec/services/hyrax/workflow/notification_configuration_parameter_spec.rb +1 -1
  598. data/spec/services/hyrax/workflow/notification_generator_spec.rb +1 -1
  599. data/spec/services/hyrax/workflow/permission_generator_spec.rb +1 -1
  600. data/spec/services/hyrax/workflow/permission_query_spec.rb +2 -2
  601. data/spec/services/hyrax/workflow/status_list_service_spec.rb +1 -1
  602. data/spec/services/hyrax/workflow/workflow_factory_spec.rb +1 -1
  603. data/spec/services/hyrax/workflow/workflow_schema_spec.rb +1 -1
  604. data/spec/services/hyrax/works/managed_works_service_spec.rb +17 -0
  605. data/spec/spec_helper.rb +34 -4
  606. data/spec/support/features/session_helpers.rb +1 -1
  607. data/spec/support/matchers/collection_type_property_matchers.rb +29 -0
  608. data/spec/test_app_templates/lib/generators/test_app_generator.rb +64 -24
  609. data/spec/views/_flash_msg.html.erb_spec.rb +0 -2
  610. data/spec/views/_user_util_links.html.erb_spec.rb +0 -2
  611. data/spec/views/catalog/_index_list_default.html.erb_spec.rb +9 -9
  612. data/spec/views/hyrax/admin/admin_sets/_form_participant_table.html.erb_spec.rb +42 -20
  613. data/spec/views/hyrax/admin/collection_types/_form.html.erb_spec.rb +43 -0
  614. data/spec/views/hyrax/admin/collection_types/_form_metadata.html.erb_spec.rb +27 -0
  615. data/spec/views/hyrax/admin/collection_types/_form_metadata_admin_set.html.erb_spec.rb +27 -0
  616. data/spec/views/hyrax/admin/collection_types/_form_participants.html.erb_spec.rb +16 -0
  617. data/spec/views/hyrax/admin/collection_types/_form_participants_table.html.erb_spec.rb +73 -0
  618. data/spec/views/hyrax/admin/collection_types/_form_settings.html.erb_spec.rb +106 -0
  619. data/spec/views/hyrax/admin/collection_types/index.html.erb_spec.rb +41 -0
  620. data/spec/views/hyrax/admin/users/index.html.erb_spec.rb +1 -1
  621. data/spec/views/hyrax/base/_form.html.erb_spec.rb +18 -42
  622. data/spec/views/hyrax/base/_form_child_work_relationships.html.erb_spec.rb +11 -22
  623. data/spec/views/hyrax/base/_form_files.html.erb_spec.rb +38 -0
  624. data/spec/views/hyrax/base/_form_progress.html.erb_spec.rb +1 -1
  625. data/spec/views/hyrax/base/_form_relationships.html.erb_spec.rb +1 -2
  626. data/spec/views/hyrax/base/_form_rendering.html.erb_spec.rb +18 -0
  627. data/spec/views/hyrax/base/file_manager.html.erb_spec.rb +1 -1
  628. data/spec/views/hyrax/base/show.html.erb_spec.rb +24 -5
  629. data/spec/views/hyrax/collections/_show_descriptions.html.erb_spec.rb +1 -1
  630. data/spec/views/hyrax/collections/_show_parent_collections.html.erb_spec.rb +124 -0
  631. data/spec/views/hyrax/collections/_sort_and_per_page.html.erb_spec.rb +60 -0
  632. data/spec/views/hyrax/collections/_subcollection_list.html.erb_spec.rb +39 -0
  633. data/spec/views/hyrax/collections/show.html.erb_spec.rb +20 -23
  634. data/spec/views/hyrax/dashboard/_sidebar.html.erb_spec.rb +14 -9
  635. data/spec/views/hyrax/dashboard/collections/_form.html.erb_spec.rb +5 -1
  636. data/spec/views/hyrax/dashboard/collections/_form_branding.html.erb_spec.rb +23 -0
  637. data/spec/views/hyrax/dashboard/collections/_form_discovery.erb_spec.rb +67 -0
  638. data/spec/views/hyrax/dashboard/collections/_form_share.erb_spec.rb +13 -34
  639. data/spec/views/hyrax/dashboard/collections/_form_share_table.html.erb_spec.rb +108 -0
  640. data/spec/views/hyrax/dashboard/collections/_show_actions.html.erb_spec.rb +64 -0
  641. data/spec/views/hyrax/dashboard/collections/_show_add_items_actions.html.erb_spec.rb +44 -0
  642. data/spec/views/hyrax/dashboard/collections/_show_descriptions.html.erb_spec.rb +1 -1
  643. data/spec/views/hyrax/dashboard/collections/_show_parent_collection_row.html.erb_spec.rb +23 -0
  644. data/spec/views/hyrax/dashboard/collections/_show_parent_collections.html.erb_spec.rb +118 -0
  645. data/spec/views/hyrax/dashboard/collections/_show_subcollection_actions.html.erb_spec.rb +62 -0
  646. data/spec/views/hyrax/dashboard/collections/_sort_and_per_page.html.erb_spec.rb +60 -0
  647. data/spec/views/hyrax/dashboard/collections/_subcollection_list.html.erb_spec.rb +63 -0
  648. data/spec/views/hyrax/dashboard/collections/_work_action_menu.html.erb_spec.rb +18 -0
  649. data/spec/views/hyrax/dashboard/collections/edit.html.erb_spec.rb +5 -13
  650. data/spec/views/hyrax/dashboard/collections/show.html.erb_spec.rb +86 -9
  651. data/spec/views/hyrax/file_sets/_show_actions.html.erb_spec.rb +1 -1
  652. data/spec/views/hyrax/homepage/_featured_works.html.erb_spec.rb +1 -1
  653. data/spec/views/hyrax/homepage/index.html.erb_spec.rb +14 -5
  654. data/spec/views/hyrax/my/_collection_action_menu.html.erb_spec.rb +65 -0
  655. data/spec/views/hyrax/my/_search_header.html.erb_spec.rb +6 -6
  656. data/spec/views/hyrax/my/_work_action_menu.html.erb_spec.rb +6 -4
  657. data/spec/views/hyrax/my/collections/_list_collections.html.erb_spec.rb +90 -22
  658. data/spec/views/hyrax/my/works/index.html.erb_spec.rb +3 -1
  659. data/spec/views/hyrax/users/_user_info.html.erb_spec.rb +16 -18
  660. data/spec/views/pages/show.html.erb_spec.rb +1 -1
  661. data/spec/views/shared/select_work_type_modal.html.erb_spec.rb +36 -10
  662. data/tasks/hyrax_dev.rake +27 -4
  663. data/template.rb +2 -1
  664. metadata +578 -290
  665. data/.solr_wrapper +0 -6
  666. data/app/assets/javascripts/hyrax/relationships/work.es6 +0 -7
  667. data/app/assets/javascripts/hyrax/workflow_actions_affix.js +0 -14
  668. data/app/assets/stylesheets/hyrax/_work_editor.scss +0 -17
  669. data/app/controllers/concerns/hyrax/parent_container.rb +0 -35
  670. data/app/helpers/dashboard_helper.rb +0 -3
  671. data/app/services/hyrax/parent_service.rb +0 -19
  672. data/app/views/catalog/_show_partials/_default.html.erb +0 -21
  673. data/app/views/catalog/_show_partials/_default_details.html.erb +0 -15
  674. data/app/views/catalog/_show_partials/_facets.html.erb +0 -52
  675. data/app/views/hyrax/base/_browse_everything.html.erb +0 -6
  676. data/app/views/hyrax/base/_find_work_widget.html.erb +0 -10
  677. data/app/views/hyrax/dashboard/collections/_form_default_group.html.erb +0 -25
  678. data/app/views/hyrax/dashboard/collections/_form_permission.html.erb +0 -24
  679. data/app/views/hyrax/file_sets/jq_upload.json.jbuilder +0 -8
  680. data/solr/config/_rest_managed.json +0 -3
  681. data/solr/config/admin-extra.html +0 -31
  682. data/solr/config/elevate.xml +0 -36
  683. data/solr/config/mapping-ISOLatin1Accent.txt +0 -246
  684. data/solr/config/protwords.txt +0 -21
  685. data/solr/config/schema.xml +0 -366
  686. data/solr/config/scripts.conf +0 -24
  687. data/solr/config/solrconfig.xml +0 -322
  688. data/solr/config/spellings.txt +0 -2
  689. data/solr/config/stopwords.txt +0 -58
  690. data/solr/config/stopwords_en.txt +0 -58
  691. data/solr/config/synonyms.txt +0 -31
  692. data/solr/config/xslt/example.xsl +0 -132
  693. data/solr/config/xslt/example_atom.xsl +0 -67
  694. data/solr/config/xslt/example_rss.xsl +0 -66
  695. data/solr/config/xslt/luke.xsl +0 -337
  696. data/spec/abilities/admin_set_abilities_spec.rb +0 -15
  697. data/spec/abilities/collection_abilities_spec.rb +0 -51
  698. data/spec/features/admin_admin_set_spec.rb +0 -30
  699. data/spec/helpers/hyrax/citations_behaviors/formatters/chicago_formatter_spec.rb +0 -10
  700. data/spec/services/hyrax/parent_service_spec.rb +0 -11
  701. data/spec/support/uploaded_file_monkeypatch.rb +0 -6
  702. data/spec/views/hyrax/base/_browse_everything.html.erb_spec.rb +0 -17
  703. data/spec/views/hyrax/base/_find_work_widget.html.erb_spec.rb +0 -20
@@ -1,7 +1,7 @@
1
1
  module Hyrax
2
2
  module Admin
3
3
  class FeaturesController < Flipflop::FeaturesController
4
- layout 'dashboard'
4
+ with_themed_layout 'dashboard'
5
5
 
6
6
  before_action do
7
7
  authorize! :manage, Hyrax::Feature
@@ -5,32 +5,74 @@ module Hyrax
5
5
 
6
6
  def destroy
7
7
  ActiveRecord::Base.transaction do
8
- @permission_template_access.destroy
8
+ @permission_template_access.destroy if valid_delete?
9
9
  remove_access!
10
10
  end
11
11
 
12
12
  if @permission_template_access.destroyed?
13
- redirect_to hyrax.edit_admin_admin_set_path(admin_set_id,
14
- anchor: 'participants'),
15
- notice: translate('participants', scope: 'hyrax.admin.admin_sets.form.permission_update_notices')
13
+ after_destroy_success
16
14
  else
17
- redirect_to hyrax.edit_admin_admin_set_path(admin_set_id,
18
- anchor: 'participants'),
19
- alert: @permission_template_access.errors.full_messages.to_sentence
20
-
15
+ after_destroy_error
21
16
  end
22
17
  end
23
18
 
24
19
  private
25
20
 
26
- # @return [String] the identifier for the AdminSet for the currently loaded resource
27
- def admin_set_id
28
- @admin_set_id ||= @permission_template_access.permission_template.admin_set_id
21
+ # This is a controller validation rather than a model validation
22
+ # because we don't want to prevent the ability to remove the whole
23
+ # PermissionTemplate and all of its associated PermissionTemplateAccesses
24
+ # @return [Boolean] true if it's valid
25
+ def valid_delete?
26
+ return true unless @permission_template_access.admin_group?
27
+ @permission_template_access.errors[:base] <<
28
+ t('hyrax.admin.admin_sets.form.permission_destroy_errors.admin_group')
29
+ false
30
+ end
31
+
32
+ def update_access(manage_changed:)
33
+ permission_template_form.update_access(manage_changed: manage_changed)
34
+ end
35
+
36
+ def after_destroy_success
37
+ if source.admin_set?
38
+ redirect_to hyrax.edit_admin_admin_set_path(source_id,
39
+ anchor: 'participants'),
40
+ notice: translate('participants', scope: 'hyrax.admin.admin_sets.form.permission_update_notices')
41
+ elsif source.collection?
42
+ redirect_to hyrax.edit_dashboard_collection_path(source_id,
43
+ anchor: 'sharing'),
44
+ notice: translate('sharing', scope: 'hyrax.dashboard.collections.form.permission_update_notices')
45
+ end
46
+ end
47
+
48
+ def after_destroy_error
49
+ if source.admin_set?
50
+ redirect_to hyrax.edit_admin_admin_set_path(source_id,
51
+ anchor: 'participants'),
52
+ alert: @permission_template_access.errors.full_messages.to_sentence
53
+ elsif source.collection?
54
+ redirect_to hyrax.edit_dashboard_collection_path(source_id,
55
+ anchor: 'sharing'),
56
+ alert: @permission_template_access.errors.full_messages.to_sentence
57
+ end
58
+ end
59
+
60
+ delegate :source_id, to: :permission_template
61
+
62
+ def source
63
+ @source ||= ::SolrDocument.find(source_id)
29
64
  end
30
65
 
31
66
  def remove_access!
32
- Forms::PermissionTemplateForm.new(@permission_template_access.permission_template)
33
- .remove_access!(@permission_template_access)
67
+ permission_template_form.remove_access!(@permission_template_access)
68
+ end
69
+
70
+ def permission_template_form
71
+ @permission_template_form ||= Forms::PermissionTemplateForm.new(permission_template)
72
+ end
73
+
74
+ def permission_template
75
+ @permission_template ||= @permission_template_access.permission_template
34
76
  end
35
77
  end
36
78
  end
@@ -1,31 +1,62 @@
1
1
  module Hyrax
2
2
  module Admin
3
3
  class PermissionTemplatesController < ApplicationController
4
- load_and_authorize_resource find_by: 'admin_set_id',
5
- id_param: 'admin_set_id',
6
- class: 'Hyrax::PermissionTemplate'
7
-
8
- # Override the default prefixes so that we use the collection partals.
9
- def self.local_prefixes
10
- ["hyrax/admin/admin_sets"]
11
- end
4
+ before_action :find_permission_template
5
+ authorize_resource class: 'Hyrax::PermissionTemplate', instance_name: :permission_template
12
6
 
13
7
  def update
14
8
  update_info = form.update(update_params)
15
9
  if update_info[:updated] == true # Ensure we redirect to currently active tab with the appropriate notice
16
- redirect_to(edit_admin_admin_set_path(params[:admin_set_id], anchor: current_tab),
17
- notice: translate(update_info[:content_tab], scope: 'hyrax.admin.admin_sets.form.permission_update_notices'))
10
+ redirect_to_edit_path(update_info)
18
11
  else
19
- # When we have invalid data, we are redirecting because to render, we need to set an AdminSetForm
20
- # (because we are rendering admin set forms)
21
- # TODO: [Jeremy Friesen says: We need to better consolidate the form logic of admin sets and permission templates
22
- redirect_to(edit_admin_admin_set_path(params[:admin_set_id], anchor: current_tab),
23
- alert: translate(update_info[:error_code], scope: 'hyrax.admin.admin_sets.form.permission_update_errors'))
12
+ redirect_to_edit_path_with_error(update_info)
24
13
  end
25
14
  end
26
15
 
27
16
  private
28
17
 
18
+ # Override the default prefixes so that we use the correct partials.
19
+ def _prefixes
20
+ if admin_set?
21
+ @_prefixes ||= super + ['hyrax/admin/admin_sets']
22
+ elsif collection?
23
+ @_prefixes ||= super + ['hyrax/dashboard/collections']
24
+ end
25
+ end
26
+
27
+ # We need to do this manually instead of using load_and_authorize_resource
28
+ # because the id we are looking for is different when using an admin set vs. collection
29
+ def find_permission_template
30
+ if admin_set?
31
+ @permission_template = PermissionTemplate.find_by(source_id: params[:admin_set_id])
32
+ elsif collection?
33
+ @permission_template = PermissionTemplate.find_by(source_id: params[:collection_id])
34
+ end
35
+ end
36
+
37
+ def redirect_to_edit_path(update_info)
38
+ if admin_set?
39
+ redirect_to(edit_admin_admin_set_path(params[:admin_set_id], anchor: current_tab),
40
+ notice: translate(update_info[:content_tab], scope: 'hyrax.admin.admin_sets.form.permission_update_notices'))
41
+ elsif collection?
42
+ redirect_to(edit_dashboard_collection_path(params[:collection_id], anchor: current_tab),
43
+ notice: translate(update_info[:content_tab], scope: 'hyrax.dashboard.collections.form.permission_update_notices'))
44
+ end
45
+ end
46
+
47
+ def redirect_to_edit_path_with_error(update_info)
48
+ # When we have invalid data, we are redirecting because to render, we need to set an AdminSetForm
49
+ # (because we are rendering admin set forms)
50
+ # TODO: [Jeremy Friesen says: We need to better consolidate the form logic of admin sets and permission templates
51
+ if admin_set?
52
+ redirect_to(edit_admin_admin_set_path(params[:admin_set_id], anchor: current_tab),
53
+ alert: translate(update_info[:error_code], scope: 'hyrax.admin.admin_sets.form.permission_update_errors'))
54
+ elsif collection?
55
+ redirect_to(edit_dashboard_collection_path(params[:collection_id], anchor: current_tab),
56
+ alert: translate(update_info[:error_code], scope: 'hyrax.dashboard.collections.form.permission_update_errors'))
57
+ end
58
+ end
59
+
29
60
  def form
30
61
  Forms::PermissionTemplateForm.new(@permission_template)
31
62
  end
@@ -38,14 +69,26 @@ module Hyrax
38
69
 
39
70
  # @return [String] the name of the current UI tab to show
40
71
  def current_tab
41
- pt = params[:permission_template]
42
- @current_tab ||= if pt[:access_grants_attributes].present?
43
- 'participants'
44
- elsif pt[:workflow_id].present?
45
- 'workflow'
46
- else
47
- 'visibility'
48
- end
72
+ if collection?
73
+ @current_tab ||= 'sharing'
74
+ else
75
+ pt = params[:permission_template]
76
+ @current_tab ||= if pt[:access_grants_attributes].present?
77
+ 'participants'
78
+ elsif pt[:workflow_id].present?
79
+ 'workflow'
80
+ else
81
+ 'visibility'
82
+ end
83
+ end
84
+ end
85
+
86
+ def admin_set?
87
+ params['admin_set_id'].present?
88
+ end
89
+
90
+ def collection?
91
+ params['collection_id'].present?
49
92
  end
50
93
  end
51
94
  end
@@ -2,7 +2,7 @@ module Hyrax
2
2
  module Admin
3
3
  class WorkflowRolesController < ApplicationController
4
4
  before_action :require_permissions
5
- layout 'dashboard'
5
+ with_themed_layout 'dashboard'
6
6
 
7
7
  def index
8
8
  add_breadcrumb t(:'hyrax.controls.home'), root_path
@@ -2,7 +2,7 @@ module Hyrax
2
2
  # Presents a list of works in workflow
3
3
  class Admin::WorkflowsController < ApplicationController
4
4
  before_action :ensure_authorized!
5
- layout 'dashboard'
5
+ with_themed_layout 'dashboard'
6
6
  class_attribute :deposited_workflow_state_name
7
7
 
8
8
  # Works that are in this workflow state (see workflow json template) are excluded from the
@@ -25,7 +25,7 @@ module Hyrax
25
25
  end
26
26
 
27
27
  def after_destroy_collection
28
- redirect_to_return_controller unless request.xhr?
28
+ redirect_back fallback_location: hyrax.batch_edits_path
29
29
  end
30
30
 
31
31
  def check_for_empty!
@@ -15,7 +15,7 @@ module Hyrax
15
15
  # We use BatchUploadItem as a null stand-in curation_concern_type.
16
16
  # The actual permission is checked dynamically during #create.
17
17
 
18
- layout 'dashboard'
18
+ with_themed_layout 'dashboard'
19
19
 
20
20
  # The permissions to create a batch are not as important as the permissions for the concern being batched.
21
21
  # @note we don't call `authorize!` directly, since `authorized_models` already checks `user.can? :create, ...`
@@ -4,7 +4,9 @@ module Hyrax
4
4
  include Breadcrumbs
5
5
  include SingularSubresourceController
6
6
 
7
- layout :decide_layout
7
+ # Overrides decide_layout from WorksControllerBehavior
8
+ with_themed_layout '1_column'
9
+
8
10
  before_action :build_breadcrumbs, only: [:work, :file]
9
11
 
10
12
  def work
@@ -25,16 +27,5 @@ module Hyrax
25
27
  def show_presenter
26
28
  WorkShowPresenter
27
29
  end
28
-
29
- def decide_layout
30
- case action_name
31
- when 'work', 'file'
32
- theme
33
- else
34
- # Not currently used in this controller, but left here to
35
- # support dashboard-based work views which are ticketed
36
- 'dashboard'
37
- end
38
- end
39
30
  end
40
31
  end
@@ -2,11 +2,9 @@ module Hyrax
2
2
  class CollectionsController < ApplicationController
3
3
  include CollectionsControllerBehavior
4
4
  include BreadcrumbsForCollections
5
- layout :decide_layout
5
+ with_themed_layout :decide_layout
6
6
  load_and_authorize_resource except: [:index, :show, :create], instance_name: :collection
7
7
 
8
- self.theme = 'hyrax/1_column'
9
-
10
8
  # Renders a JSON response with a list of files in this collection
11
9
  # This is used by the edit form to populate the thumbnail_id dropdown
12
10
  def files
@@ -23,12 +21,13 @@ module Hyrax
23
21
  end
24
22
 
25
23
  def decide_layout
26
- case action_name
27
- when 'show'
28
- theme
29
- else
30
- 'dashboard'
31
- end
24
+ layout = case action_name
25
+ when 'show'
26
+ '1_column'
27
+ else
28
+ 'dashboard'
29
+ end
30
+ File.join(theme, layout)
32
31
  end
33
32
  end
34
33
  end
@@ -1,7 +1,7 @@
1
1
  module Hyrax
2
2
  class ContentBlocksController < ApplicationController
3
3
  load_and_authorize_resource
4
- layout 'dashboard'
4
+ with_themed_layout 'dashboard'
5
5
 
6
6
  def edit
7
7
  add_breadcrumb t(:'hyrax.controls.home'), root_path
@@ -0,0 +1,73 @@
1
+ module Hyrax
2
+ module Dashboard
3
+ ## Shows a list of all collections to the admins
4
+ class CollectionMembersController < Hyrax::My::CollectionsController
5
+ before_action :filter_docs_with_read_access!
6
+
7
+ include Hyrax::Collections::AcceptsBatches
8
+
9
+ def after_update
10
+ respond_to do |format|
11
+ format.html { redirect_to success_return_path, notice: t('hyrax.dashboard.my.action.collection_update_success') }
12
+ format.json { render json: @collection, status: :updated, location: dashboard_collection_path(@collection) }
13
+ end
14
+ end
15
+
16
+ def after_update_error(err_msg)
17
+ respond_to do |format|
18
+ format.html { redirect_to err_return_path, alert: err_msg }
19
+ format.json { render json: @collection.errors, status: :unprocessable_entity }
20
+ end
21
+ end
22
+
23
+ def update_members
24
+ err_msg = validate
25
+ after_update_error(err_msg) if err_msg.present?
26
+ return if err_msg.present?
27
+
28
+ members = collection.add_member_objects batch_ids
29
+ messages = members.collect { |member| member.errors.full_messages }.flatten
30
+ if messages.size == members.size
31
+ after_update_error(messages.uniq.join(', '))
32
+ elsif messages.present?
33
+ flash[:error] = messages.uniq.join(', ')
34
+ after_update
35
+ else
36
+ after_update
37
+ end
38
+ end
39
+
40
+ private
41
+
42
+ def validate
43
+ return t('hyrax.dashboard.my.action.members_no_access') if batch_ids.blank?
44
+ return t('hyrax.dashboard.my.action.collection_deny_add_members') unless current_ability.can?(:deposit, collection)
45
+ return t('hyrax.dashboard.my.action.add_to_collection_only') unless member_action == "add" # should never happen
46
+ end
47
+
48
+ def success_return_path
49
+ dashboard_collection_path(collection_id)
50
+ end
51
+
52
+ def err_return_path
53
+ dashboard_collections_path
54
+ end
55
+
56
+ def collection_id
57
+ params[:id]
58
+ end
59
+
60
+ def collection
61
+ @collection ||= Collection.find(collection_id)
62
+ end
63
+
64
+ def batch_ids
65
+ params[:batch_document_ids]
66
+ end
67
+
68
+ def member_action
69
+ params[:collection][:members]
70
+ end
71
+ end
72
+ end
73
+ end
@@ -5,9 +5,9 @@ module Hyrax
5
5
  include Blacklight::AccessControls::Catalog
6
6
  include Blacklight::Base
7
7
  include BreadcrumbsForCollections
8
- layout 'dashboard'
8
+ with_themed_layout 'dashboard'
9
9
 
10
- before_action :filter_docs_with_read_access!, except: :show
10
+ before_action :filter_docs_with_read_access!, except: [:show, :edit]
11
11
  before_action :remove_select_something_first_flash, except: :show
12
12
 
13
13
  include Hyrax::Collections::AcceptsBatches
@@ -17,9 +17,6 @@ module Hyrax
17
17
  # include the display_trophy_link view helper method
18
18
  helper Hyrax::TrophyHelper
19
19
 
20
- # This is needed as of BL 3.7
21
- copy_blacklight_config_from(::CatalogController)
22
-
23
20
  # Catch permission errors
24
21
  rescue_from Hydra::AccessDenied, CanCan::AccessDenied, with: :deny_collection_access
25
22
 
@@ -29,13 +26,7 @@ module Hyrax
29
26
  class_attribute :presenter_class,
30
27
  :form_class,
31
28
  :single_item_search_builder_class,
32
- :member_search_builder_class
33
-
34
- alias collection_search_builder_class single_item_search_builder_class
35
- deprecation_deprecate collection_search_builder_class: "use single_item_search_builder_class instead"
36
-
37
- alias collection_member_search_builder_class member_search_builder_class
38
- deprecation_deprecate collection_member_search_builder_class: "use member_search_builder_class instead"
29
+ :membership_service_class
39
30
 
40
31
  self.presenter_class = Hyrax::CollectionPresenter
41
32
 
@@ -44,12 +35,10 @@ module Hyrax
44
35
  # The search builder to find the collection
45
36
  self.single_item_search_builder_class = SingleCollectionSearchBuilder
46
37
  # The search builder to find the collections' members
47
- self.member_search_builder_class = Hyrax::CollectionMemberSearchBuilder
38
+ self.membership_service_class = Collections::CollectionMemberService
48
39
 
49
40
  load_and_authorize_resource except: [:index, :create], instance_name: :collection
50
41
 
51
- before_action :ensure_admin!, only: :index # index for All Collections; see also Hyrax::My::CollectionsController #index for My Collections
52
-
53
42
  def deny_collection_access(exception)
54
43
  if exception.action == :edit
55
44
  redirect_to(url_for(action: 'show'), alert: 'You do not have sufficient privileges to edit this document')
@@ -62,20 +51,27 @@ module Hyrax
62
51
  end
63
52
 
64
53
  def new
54
+ # Coming from the UI, a collection type id should always be present. Coming from the API, if a collection type id is not specified,
55
+ # use the default collection type (provides backward compatibility with versions < Hyrax 2.1.0)
56
+ collection_type_id = params[:collection_type_id].presence || default_collection_type.id
57
+ @collection.collection_type_gid = CollectionType.find(collection_type_id).gid
65
58
  add_breadcrumb t(:'hyrax.controls.home'), root_path
66
59
  add_breadcrumb t(:'hyrax.dashboard.breadcrumbs.admin'), hyrax.dashboard_path
67
- add_breadcrumb t(:'hyrax.collections.new.header'), hyrax.new_dashboard_collection_path
60
+ add_breadcrumb t('.header', type_title: @collection.collection_type.title), request.path
68
61
  @collection.apply_depositor_metadata(current_user.user_key)
69
62
  form
70
63
  end
71
64
 
72
65
  def show
66
+ banner_info = CollectionBrandingInfo.where(collection_id: @collection.id.to_s).where(role: "banner")
67
+ @banner_file = "/" + banner_info.first.local_path.split("/")[-4..-1].join("/") unless banner_info.empty?
68
+
73
69
  presenter
74
70
  query_collection_members
75
71
  end
76
72
 
77
73
  def edit
78
- query_collection_members
74
+ member_works
79
75
  # this is used to populate the "add to a collection" action for the members
80
76
  @user_collections = find_collections_for_form
81
77
  form
@@ -83,9 +79,13 @@ module Hyrax
83
79
 
84
80
  def after_create
85
81
  form
82
+ set_default_permissions
83
+ # if we are creating the new collection as a subcollection (via the nested collections controller),
84
+ # we pass the parent_id through a hidden field in the form and link the two after the create.
85
+ link_parent_collection(params[:parent_id]) unless params[:parent_id].nil?
86
86
  respond_to do |format|
87
87
  ActiveFedora::SolrService.instance.conn.commit
88
- format.html { redirect_to dashboard_collection_path(@collection), notice: 'Collection was successfully created.' }
88
+ format.html { redirect_to edit_dashboard_collection_path(@collection), notice: t('hyrax.dashboard.my.action.collection_create_success') }
89
89
  format.json { render json: @collection, status: :created, location: dashboard_collection_path(@collection) }
90
90
  end
91
91
  end
@@ -104,10 +104,13 @@ module Hyrax
104
104
  # collection is saved without a value for `has_model.`
105
105
  @collection = ::Collection.new
106
106
  authorize! :create, @collection
107
-
108
- @collection.attributes = collection_params.except(:members)
107
+ # Coming from the UI, a collection type gid should always be present. Coming from the API, if a collection type gid is not specified,
108
+ # use the default collection type (provides backward compatibility with versions < Hyrax 2.1.0)
109
+ @collection.collection_type_gid = params[:collection_type_gid].presence || default_collection_type.gid
110
+ @collection.attributes = collection_params.except(:members, :parent_id, :collection_type_gid)
109
111
  @collection.apply_depositor_metadata(current_user.user_key)
110
112
  add_members_to_collection unless batch.empty?
113
+ @collection.visibility = Hydra::AccessControls::AccessRight::VISIBILITY_TEXT_VALUE_PRIVATE unless @collection.discoverable?
111
114
  if @collection.save
112
115
  after_create
113
116
  else
@@ -116,11 +119,8 @@ module Hyrax
116
119
  end
117
120
 
118
121
  def after_update
119
- if flash[:notice].nil?
120
- flash[:notice] = 'Collection was successfully updated.'
121
- end
122
122
  respond_to do |format|
123
- format.html { redirect_to dashboard_collection_path(@collection) }
123
+ format.html { redirect_to update_referer, notice: t('hyrax.dashboard.my.action.collection_update_success') }
124
124
  format.json { render json: @collection, status: :updated, location: dashboard_collection_path(@collection) }
125
125
  end
126
126
  end
@@ -135,8 +135,19 @@ module Hyrax
135
135
  end
136
136
 
137
137
  def update
138
+ unless params[:update_collection].nil?
139
+ process_banner_input
140
+ process_logo_input
141
+ end
142
+
138
143
  process_member_changes
144
+ @collection.visibility = Hydra::AccessControls::AccessRight::VISIBILITY_TEXT_VALUE_PRIVATE unless @collection.discoverable?
145
+ visiblity_updated = (@collection.visibility != collection_params[:visibility])
139
146
  if @collection.update(collection_params.except(:members))
147
+ # added because the collection indexing happens before Hydra::AccessControls::Permission is
148
+ # saved, and the after_update_index callback in the nested_relationship_reindexer removes the
149
+ # permissions from the collection's Solr document.
150
+ @collection.update_index if visiblity_updated
140
151
  after_update
141
152
  else
142
153
  after_update_error
@@ -147,7 +158,7 @@ module Hyrax
147
158
  respond_to do |format|
148
159
  format.html do
149
160
  redirect_to my_collections_path,
150
- notice: "Collection #{id} was successfully deleted"
161
+ notice: t('hyrax.dashboard.my.action.collection_delete_success', id: id)
151
162
  end
152
163
  format.json { head :no_content, location: my_collections_path }
153
164
  end
@@ -156,7 +167,7 @@ module Hyrax
156
167
  def after_destroy_error(id)
157
168
  respond_to do |format|
158
169
  format.html do
159
- flash[:notice] = "Collection #{id} could not be deleted"
170
+ flash[:notice] = t('hyrax.dashboard.my.action.collection_delete_fail', id: id)
160
171
  render :edit, status: :unprocessable_entity
161
172
  end
162
173
  format.json { render json: { id: id }, status: :unprocessable_entity, location: dashboard_collection_path(@collection) }
@@ -185,11 +196,116 @@ module Hyrax
185
196
  end
186
197
 
187
198
  def search_builder_class
188
- Hyrax::CollectionSearchBuilder
199
+ Hyrax::Dashboard::CollectionsSearchBuilder
189
200
  end
190
201
 
191
202
  private
192
203
 
204
+ def default_collection_type
205
+ Hyrax::CollectionType.find_or_create_default_collection_type
206
+ end
207
+
208
+ def link_parent_collection(parent_id)
209
+ parent = ActiveFedora::Base.find(parent_id)
210
+ Hyrax::Collections::NestedCollectionPersistenceService.persist_nested_collection_for(parent: parent, child: @collection)
211
+ end
212
+
213
+ def uploaded_files(uploaded_file_ids)
214
+ return [] if uploaded_file_ids.empty?
215
+ UploadedFile.find(uploaded_file_ids)
216
+ end
217
+
218
+ def update_referer
219
+ return edit_dashboard_collection_path(@collection) + (params[:referer_anchor] || '') if params[:stay_on_edit]
220
+ dashboard_collection_path(@collection)
221
+ end
222
+
223
+ def process_banner_input
224
+ return update_existing_banner if params["banner_unchanged"] == "true"
225
+ remove_banner
226
+ uploaded_file_ids = params["banner_files"]
227
+ add_new_banner(uploaded_file_ids) if uploaded_file_ids
228
+ end
229
+
230
+ def update_existing_banner
231
+ banner_info = CollectionBrandingInfo.where(collection_id: @collection.id.to_s).where(role: "banner")
232
+ banner_info.first.save(banner_info.first.local_path, false)
233
+ end
234
+
235
+ def add_new_banner(uploaded_file_ids)
236
+ f = uploaded_files(uploaded_file_ids).first
237
+ banner_info = CollectionBrandingInfo.new(
238
+ collection_id: @collection.id,
239
+ filename: File.split(f.file_url).last,
240
+ role: "banner",
241
+ alt_txt: "",
242
+ target_url: ""
243
+ )
244
+ banner_info.save f.file_url
245
+ end
246
+
247
+ def remove_banner
248
+ banner_info = CollectionBrandingInfo.where(collection_id: @collection.id.to_s).where(role: "banner")
249
+ banner_info.delete_all unless banner_info.nil?
250
+ end
251
+
252
+ def update_logo_info(uploaded_file_id, alttext, linkurl)
253
+ logo_info = CollectionBrandingInfo.where(collection_id: @collection.id.to_s).where(role: "logo").where(local_path: uploaded_file_id.to_s)
254
+ logo_info.first.alt_text = alttext
255
+ logo_info.first.target_url = linkurl
256
+ logo_info.first.local_path = uploaded_file_id
257
+ logo_info.first.save(uploaded_file_id, false)
258
+ end
259
+
260
+ def create_logo_info(uploaded_file_id, alttext, linkurl)
261
+ file = uploaded_files(uploaded_file_id)
262
+ logo_info = CollectionBrandingInfo.new(
263
+ collection_id: @collection.id,
264
+ filename: File.split(file.file_url).last,
265
+ role: "logo",
266
+ alt_txt: alttext,
267
+ target_url: linkurl
268
+ )
269
+ logo_info.save file.file_url
270
+ logo_info
271
+ end
272
+
273
+ def remove_redundant_files(public_files)
274
+ # remove any public ones that were not included in the selection.
275
+ logos_info = CollectionBrandingInfo.where(collection_id: @collection.id.to_s).where(role: "logo")
276
+ logos_info.each do |logo_info|
277
+ logo_info.delete(logo_info.local_path) unless public_files.include? logo_info.local_path
278
+ logo_info.destroy unless public_files.include? logo_info.local_path
279
+ end
280
+ end
281
+
282
+ def process_logo_records(uploaded_file_ids)
283
+ public_files = []
284
+ uploaded_file_ids.each_with_index do |ufi, i|
285
+ if ufi.include?('public')
286
+ update_logo_info(ufi, params["alttext"][i], params["linkurl"][i])
287
+ public_files << ufi
288
+ else # brand new one, insert in the database
289
+ logo_info = create_logo_info(ufi, params["alttext"][i], params["linkurl"][i])
290
+ public_files << logo_info.local_path
291
+ end
292
+ end
293
+ public_files
294
+ end
295
+
296
+ def process_logo_input
297
+ uploaded_file_ids = params["logo_files"]
298
+ public_files = []
299
+
300
+ if uploaded_file_ids.nil?
301
+ remove_redundant_files public_files
302
+ return
303
+ end
304
+
305
+ public_files = process_logo_records uploaded_file_ids
306
+ remove_redundant_files public_files
307
+ end
308
+
193
309
  # run a solr query to get the collections the user has access to edit
194
310
  # @return [Array] a list of the user's collections
195
311
  def find_collections_for_form
@@ -217,41 +333,34 @@ module Hyrax
217
333
  single_item_search_builder_class.new(self).with(params.except(:q, :page))
218
334
  end
219
335
 
220
- alias collection_search_builder single_item_search_builder
221
- deprecation_deprecate collection_search_builder: "use single_item_search_builder instead"
222
-
223
- # Instantiates the search builder that builds a query for items that are
224
- # members of the current collection. This is used in the show view.
225
- def member_search_builder
226
- @member_search_builder ||= member_search_builder_class.new(self)
227
- end
228
-
229
- alias collection_member_search_builder member_search_builder
230
- deprecation_deprecate collection_member_search_builder: "use member_search_builder instead"
231
-
232
336
  def collection_params
337
+ @participants = extract_old_style_permission_attributes(params[:collection])
233
338
  form_class.model_attributes(params[:collection])
234
339
  end
235
340
 
236
- # Queries Solr for members of the collection.
237
- # Populates @response and @member_docs similar to Blacklight Catalog#index populating @response and @documents
238
- def query_collection_members
239
- params[:q] = params[:cq]
240
- @response = repository.search(query_for_collection_members)
241
- @member_docs = @response.documents
341
+ def extract_old_style_permission_attributes(attributes)
342
+ # TODO: REMOVE in 3.0 - part of deprecation of permission attributes
343
+ Deprecation.warn(self, "passing in permissions with a new collection is deprecated and will be removed from Hyrax 3.0 ()") # TODO: elr - add alternative in ()
344
+ permissions = attributes.delete("permissions_attributes")
345
+ return [] unless permissions
346
+ participants = []
347
+ permissions.each do |p|
348
+ access = access(p)
349
+ participants << { agent_type: agent_type(p), agent_id: p["name"], access: access } if access
350
+ end
351
+ participants
242
352
  end
243
353
 
244
- # @return <Hash> a representation of the solr query that find the collection members
245
- def query_for_collection_members
246
- member_search_builder.with(params_for_members_query).query
354
+ def agent_type(permission)
355
+ # TODO: REMOVE in 3.0 - part of deprecation of permission attributes
356
+ return 'group' if permission["type"] == 'group'
357
+ 'user'
247
358
  end
248
359
 
249
- # You can override this method if you need to provide additional inputs to the search
250
- # builder. For example:
251
- # search_field: 'all_fields'
252
- # @return <Hash> the inputs required for the collection member search builder
253
- def params_for_members_query
254
- params.merge(q: params[:cq])
360
+ def access(permission)
361
+ # TODO: REMOVE in 3.0 - part of deprecation of permission attributes
362
+ return Hyrax::PermissionTemplateAccess::MANAGE if permission["access"] == 'edit'
363
+ return Hyrax::PermissionTemplateAccess::VIEW if permission["access"] == 'read'
255
364
  end
256
365
 
257
366
  def process_member_changes
@@ -305,6 +414,53 @@ module Hyrax
305
414
  def form
306
415
  @form ||= form_class.new(@collection, current_ability, repository)
307
416
  end
417
+
418
+ def set_default_permissions
419
+ additional_grants = @participants # Grants converted from older versions (< Hyrax 2.1.0) where share was edit or read access instead of managers, depositors, and viewers
420
+ Collections::PermissionsCreateService.create_default(collection: @collection, creating_user: current_user, grants: additional_grants)
421
+ end
422
+
423
+ def query_collection_members
424
+ member_works
425
+ member_subcollections if collection.collection_type.nestable?
426
+ parent_collections if collection.collection_type.nestable? && action_name == 'show'
427
+ end
428
+
429
+ # Instantiate the membership query service
430
+ def collection_member_service
431
+ @collection_member_service ||= membership_service_class.new(scope: self, collection: collection, params: params_for_query)
432
+ end
433
+
434
+ def member_works
435
+ @response = collection_member_service.available_member_works
436
+ @member_docs = @response.documents
437
+ @members_count = @response.total
438
+ end
439
+
440
+ def member_subcollections
441
+ results = collection_member_service.available_member_subcollections
442
+ @subcollection_solr_response = results
443
+ @subcollection_docs = results.documents
444
+ @subcollection_count = @presenter.nil? ? 0 : @subcollection_count = @presenter.subcollection_count = results.total
445
+ end
446
+
447
+ def parent_collections
448
+ page = params[:parent_collection_page].to_i
449
+ query = Hyrax::Collections::NestedCollectionQueryService
450
+ collection.parent_collections = query.parent_collections(child: collection_object, scope: self, page: page)
451
+ end
452
+
453
+ def collection_object
454
+ action_name == 'show' ? Collection.find(collection.id) : collection
455
+ end
456
+
457
+ # You can override this method if you need to provide additional
458
+ # inputs to the search builder. For example:
459
+ # search_field: 'all_fields'
460
+ # @return <Hash> the inputs required for the collection member search builder
461
+ def params_for_query
462
+ params.merge(q: params[:cq])
463
+ end
308
464
  end
309
465
  end
310
466
  end