sufia 7.2.0 → 7.3.0.rc1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.codeclimate.yml +2 -0
- data/.rubocop.yml +3 -0
- data/.rubocop_todo.yml +1 -2
- data/.travis.yml +0 -1
- data/Gemfile +2 -1
- data/README.md +23 -106
- data/app/actors/sufia/apply_permission_template_actor.rb +19 -0
- data/app/actors/sufia/create_with_remote_files_actor.rb +2 -2
- data/app/actors/sufia/default_admin_set_actor.rb +42 -0
- data/app/actors/sufia/interpret_visibility_actor.rb +115 -0
- data/app/assets/images/collection.png +0 -0
- data/app/assets/javascripts/sufia.js +6 -0
- data/app/assets/javascripts/sufia/admin/admin_set/participants.es6 +9 -0
- data/app/assets/javascripts/sufia/admin/admin_set/visibility.es6 +134 -0
- data/app/assets/javascripts/sufia/admin/admin_set_controls.es6 +11 -0
- data/app/assets/javascripts/sufia/app.js +27 -5
- data/app/assets/javascripts/sufia/autocomplete.es6 +15 -0
- data/app/assets/javascripts/sufia/autocomplete/work.es6 +29 -0
- data/app/assets/javascripts/sufia/dashboard_actions.js +2 -4
- data/app/assets/javascripts/sufia/save_work/save_work_control.es6 +14 -2
- data/app/assets/javascripts/sufia/save_work/uploaded_files.es6 +7 -2
- data/app/assets/javascripts/sufia/save_work/visibility_component.es6 +245 -4
- data/app/assets/javascripts/sufia/select_work_type.es6 +38 -0
- data/app/assets/javascripts/sufia/workflow_actions_affix.js +14 -0
- data/app/assets/stylesheets/sufia/_dashboard.scss +50 -29
- data/app/assets/stylesheets/sufia/_footer.scss +30 -0
- data/app/assets/stylesheets/sufia/_header.scss +3 -4
- data/app/assets/stylesheets/sufia/_home-page.scss +10 -8
- data/app/assets/stylesheets/sufia/_select_work_type.scss +43 -0
- data/app/assets/stylesheets/sufia/_sufia.scss +4 -1
- data/app/assets/stylesheets/sufia/_variables.scss +3 -0
- data/app/assets/stylesheets/sufia/admin.scss +66 -169
- data/app/assets/stylesheets/sufia/blacklight_gallery.scss +17 -0
- data/app/authorities/qa/authorities/find_works.rb +15 -0
- data/app/controllers/concerns/sufia/batch_edits_controller_behavior.rb +2 -1
- data/app/controllers/concerns/sufia/batch_uploads_controller_behavior.rb +26 -13
- data/app/controllers/concerns/sufia/collections_controller_behavior.rb +25 -0
- data/app/controllers/concerns/sufia/controller.rb +8 -0
- data/app/controllers/concerns/sufia/deny_access_override_behavior.rb +1 -1
- data/app/controllers/concerns/sufia/file_sets_controller_behavior.rb +5 -14
- data/app/controllers/concerns/sufia/homepage_controller_behavior.rb +2 -0
- data/app/controllers/concerns/sufia/users_controller_behavior.rb +18 -7
- data/app/controllers/concerns/sufia/works_controller_behavior.rb +13 -10
- data/app/controllers/my/collections_controller.rb +5 -0
- data/app/controllers/my/shares_controller.rb +5 -0
- data/app/controllers/my/works_controller.rb +5 -0
- data/app/controllers/stats_controller.rb +1 -1
- data/app/controllers/sufia/admin/admin_sets_controller.rb +20 -2
- data/app/controllers/sufia/admin/permission_template_accesses_controller.rb +15 -0
- data/app/controllers/sufia/admin/permission_templates_controller.rb +29 -0
- data/app/controllers/sufia/admin_controller.rb +2 -0
- data/app/controllers/sufia/trophies_controller.rb +0 -2
- data/app/forms/sufia/forms/admin_set_form.rb +19 -0
- data/app/forms/sufia/forms/batch_edit_form.rb +16 -6
- data/app/forms/sufia/forms/batch_upload_form.rb +3 -2
- data/app/forms/sufia/forms/permission_template_form.rb +115 -0
- data/app/forms/sufia/forms/work_form.rb +6 -0
- data/app/helpers/batch_edits_helper.rb +1 -1
- data/app/helpers/sufia/citations_behavior.rb +0 -5
- data/app/helpers/sufia/citations_behaviors/formatters.rb +0 -1
- data/app/helpers/sufia/sufia_helper_behavior.rb +38 -6
- data/app/indexers/sufia/collection_indexer.rb +6 -0
- data/app/jobs/batch_create_job.rb +7 -15
- data/app/models/batch_upload_item.rb +2 -0
- data/app/models/concerns/sufia/ability.rb +12 -1
- data/app/models/sufia/permission_template.rb +102 -0
- data/app/models/sufia/permission_template_access.rb +18 -0
- data/app/presenters/sufia/admin_set_presenter.rb +1 -1
- data/app/presenters/sufia/model_icon.rb +7 -0
- data/app/presenters/sufia/select_type_list_presenter.rb +37 -0
- data/app/presenters/sufia/select_type_presenter.rb +35 -0
- data/app/presenters/sufia/work_show_presenter.rb +0 -2
- data/app/search_builders/collection_search_builder.rb +0 -2
- data/app/search_builders/sufia/admin_set_search_builder.rb +24 -0
- data/app/search_builders/sufia/catalog_search_builder.rb +10 -4
- data/app/search_builders/sufia/find_works_search_builder.rb +44 -0
- data/app/search_builders/sufia/my_search_builder_behavior.rb +0 -4
- data/app/search_builders/sufia/my_works_search_builder.rb +1 -1
- data/app/services/sufia/actor_factory.rb +6 -2
- data/app/services/sufia/admin_set_create_service.rb +22 -0
- data/app/services/sufia/admin_set_service.rb +46 -16
- data/app/services/sufia/collection_thumbnail_path_service.rb +10 -0
- data/app/services/sufia/workflow/abstract_notification.rb +39 -0
- data/app/services/sufia/workflow/changes_required_notification.rb +22 -0
- data/app/services/sufia/workflow/complete_notification.rb +22 -0
- data/app/services/sufia/workflow/pending_review_notification.rb +21 -0
- data/app/services/sufia/workflow/workflow_by_admin_set_strategy.rb +15 -0
- data/app/views/_masthead.html.erb +4 -4
- data/app/views/_toolbar.html.erb +31 -9
- data/app/views/_user_util_links.html.erb +7 -7
- data/app/views/batch_edits/edit.html.erb +24 -12
- data/app/views/catalog/_thumbnail_list_collection.html.erb +1 -1
- data/app/views/collections/_form.html.erb +2 -2
- data/app/views/collections/_media_display.html.erb +1 -1
- data/app/views/curation_concerns/base/_find_work_widget.html.erb +16 -0
- data/app/views/curation_concerns/base/_form.html.erb +6 -0
- data/app/views/curation_concerns/base/_form_child_work_relationships.html.erb +1 -1
- data/app/views/curation_concerns/base/_form_metadata.html.erb +1 -1
- data/app/views/curation_concerns/base/_form_parent_work_relationships.html.erb +43 -0
- data/app/views/curation_concerns/base/_form_progress.html.erb +7 -4
- data/app/views/curation_concerns/base/_form_relationships.html.erb +6 -6
- data/app/views/curation_concerns/base/_form_share.html.erb +1 -2
- data/app/views/curation_concerns/base/_guts4form.html.erb +1 -1
- data/app/views/curation_concerns/base/_social_media.html.erb +1 -1
- data/app/views/curation_concerns/base/_workflow_actions_widget.erb +3 -0
- data/app/views/curation_concerns/base/edit.html.erb +1 -1
- data/app/views/curation_concerns/base/new.html.erb +1 -1
- data/app/views/curation_concerns/base/show.html.erb +4 -1
- data/app/views/curation_concerns/file_sets/_show_actions.html.erb +0 -3
- data/app/views/dashboard/_create_work_action.html.erb +20 -0
- data/app/views/dashboard/_index_partials/_heading_actions.html.erb +9 -22
- data/app/views/layouts/admin.html.erb +8 -68
- data/app/views/layouts/curation_concerns/1_column.html.erb +4 -31
- data/app/views/layouts/homepage.html.erb +15 -45
- data/app/views/layouts/sufia-dashboard.html.erb +1 -36
- data/app/views/layouts/sufia.html.erb +49 -0
- data/app/views/my/_document_list.html.erb +1 -1
- data/app/views/my/_facet_limit.html.erb +2 -2
- data/app/views/my/_index_partials/_default_group.html.erb +10 -10
- data/app/views/my/_index_partials/_list_collections.html.erb +1 -1
- data/app/views/my/_sort_and_per_page.html.erb +8 -8
- data/app/views/records/edit_fields/_rights.html.erb +0 -1
- data/app/views/shared/_footer.html.erb +1 -1
- data/app/views/shared/_select_work_type_modal.html.erb +34 -0
- data/app/views/sufia/admin/_collections.html.erb +31 -0
- data/app/views/sufia/admin/_sidebar.html.erb +35 -23
- data/app/views/sufia/admin/admin_sets/_form.html.erb +38 -15
- data/app/views/sufia/admin/admin_sets/_form_metadata.html.erb +2 -0
- data/app/views/sufia/admin/admin_sets/_form_participant_table.html.erb +21 -0
- data/app/views/sufia/admin/admin_sets/_form_participants.html.erb +68 -0
- data/app/views/sufia/admin/admin_sets/_form_visibility.html.erb +58 -0
- data/app/views/sufia/admin/admin_sets/index.html.erb +29 -33
- data/app/views/sufia/admin/admin_sets/show.html.erb +3 -0
- data/app/views/sufia/admin/show.html.erb +22 -19
- data/app/views/sufia/batch_uploads/_form.html.erb +2 -1
- data/app/views/sufia/homepage/index.html.erb +11 -3
- data/app/views/sufia/uploads/_js_templates.html.erb +15 -11
- data/app/views/users/_user_row.html.erb +10 -0
- data/app/views/users/index.html.erb +1 -12
- data/config/features.rb +2 -0
- data/config/locales/sufia.en.yml +122 -37
- data/config/routes.rb +4 -1
- data/db/migrate/20161021175854_create_permission_template.rb +11 -0
- data/db/migrate/20161021180154_create_permission_template_access.rb +11 -0
- data/db/migrate/20161116222307_add_release_to_permission_templates.rb +6 -0
- data/lib/generators/sufia/install_generator.rb +12 -3
- data/lib/generators/sufia/templates/catalog_controller.rb +3 -13
- data/lib/generators/sufia/templates/workflow.json.erb +65 -0
- data/lib/generators/sufia/upgrade700_generator.rb +1 -1
- data/lib/generators/sufia/work/templates/locale.en.yml.erb +37 -0
- data/lib/generators/sufia/{work_generator.rb → work/work_generator.rb} +25 -5
- data/lib/sufia.rb +0 -1
- data/lib/sufia/engine.rb +7 -0
- data/lib/sufia/move_all_works_to_admin_set.rb +8 -0
- data/lib/sufia/version.rb +1 -1
- data/lib/tasks/migrate.rake +8 -0
- data/spec/actors/sufia/apply_permission_template_actor_spec.rb +64 -0
- data/spec/actors/sufia/create_with_remote_files_actor_spec.rb +8 -0
- data/spec/actors/sufia/default_admin_set_actor_spec.rb +43 -0
- data/spec/actors/sufia/interpret_visibility_actor_spec.rb +266 -0
- data/spec/authorities/qa/authorities/find_works_spec.rb +55 -0
- data/spec/controllers/batch_edits_controller_spec.rb +1 -6
- data/spec/controllers/citations_controller_spec.rb +49 -10
- data/spec/controllers/collections_controller_spec.rb +39 -0
- data/spec/controllers/curation_concerns/generic_works_controller_spec.rb +22 -1
- data/spec/controllers/dashboard_controller_spec.rb +0 -8
- data/spec/controllers/depositors_controller_spec.rb +2 -2
- data/spec/controllers/downloads_controller_spec.rb +2 -2
- data/spec/controllers/my/collections_controller_spec.rb +5 -0
- data/spec/controllers/my/shares_controller_spec.rb +5 -0
- data/spec/controllers/my/works_controller_spec.rb +5 -0
- data/spec/controllers/stats_controller_spec.rb +1 -1
- data/spec/controllers/sufia/admin/admin_sets_controller_spec.rb +33 -5
- data/spec/controllers/sufia/admin/permission_template_accesses_controller_spec.rb +36 -0
- data/spec/controllers/sufia/admin/permission_templates_controller_spec.rb +46 -0
- data/spec/controllers/sufia/admin_controller_spec.rb +6 -0
- data/spec/controllers/sufia/batch_uploads_controller_spec.rb +40 -42
- data/spec/controllers/sufia/homepage_controller_spec.rb +14 -0
- data/spec/controllers/sufia/trophies_controller_spec.rb +17 -4
- data/spec/controllers/users_controller_spec.rb +13 -4
- data/spec/factories/permission_template_accesses.rb +5 -0
- data/spec/factories/permission_templates.rb +5 -0
- data/spec/factories/sipity_entities.rb +7 -0
- data/spec/factories/users.rb +4 -0
- data/spec/factories/workflow_states.rb +6 -0
- data/spec/factories/workflows.rb +5 -0
- data/spec/features/admin_admin_set_spec.rb +6 -4
- data/spec/features/batch_edit_spec.rb +0 -1
- data/spec/features/collection_spec.rb +4 -4
- data/spec/features/edit_work_spec.rb +1 -0
- data/spec/features/work_show_spec.rb +10 -0
- data/spec/forms/sufia/forms/admin_set_form_spec.rb +2 -1
- data/spec/forms/sufia/forms/batch_edit_form_spec.rb +30 -0
- data/spec/forms/sufia/forms/permission_template_form_spec.rb +196 -0
- data/spec/forms/sufia/forms/work_form_spec.rb +35 -1
- data/spec/helpers/batch_edits_helper_spec.rb +4 -4
- data/spec/helpers/blacklight_helper_spec.rb +1 -1
- data/spec/helpers/sufia_helper_spec.rb +39 -7
- data/spec/indexers/sufia/collection_indexer_spec.rb +12 -0
- data/spec/javascripts/autocomplete_spec.js.coffee +46 -6
- data/spec/javascripts/visibility_component_spec.js +491 -0
- data/spec/jobs/batch_create_job_spec.rb +27 -28
- data/spec/lib/sufia/arkivo_spec.rb +14 -0
- data/spec/lib/sufia/controlled_vocabulary/importer/downloader_spec.rb +31 -0
- data/spec/lib/sufia/move_all_works_to_admin_set_spec.rb +13 -0
- data/spec/lib/sufia/zotero_spec.rb +8 -0
- data/spec/models/sufia/ability_spec.rb +54 -14
- data/spec/models/sufia/permission_template_spec.rb +144 -0
- data/spec/models/sufia/user_usage_stats_spec.rb +8 -2
- data/spec/presenters/sufia/homepage_presenter_spec.rb +1 -1
- data/spec/presenters/sufia/select_type_list_presenter_spec.rb +26 -0
- data/spec/presenters/sufia/select_type_presenter_spec.rb +21 -0
- data/spec/search_builder/sufia/admin_set_search_builder_spec.rb +57 -0
- data/spec/search_builder/sufia/catalog_search_builder_spec.rb +40 -14
- data/spec/search_builder/sufia/find_works_search_builder_spec.rb +60 -0
- data/spec/search_builder/sufia/my_shares_search_builder_spec.rb +4 -1
- data/spec/search_builder/sufia/single_admin_set_search_builder_spec.rb +5 -1
- data/spec/services/sufia/actor_factory_spec.rb +13 -5
- data/spec/services/sufia/admin_set_create_service_spec.rb +27 -0
- data/spec/services/sufia/admin_set_service_spec.rb +104 -17
- data/spec/services/sufia/workflow/changes_required_notification_spec.rb +32 -0
- data/spec/services/sufia/workflow/complete_notification_spec.rb +32 -0
- data/spec/services/sufia/workflow/pending_review_notification_spec.rb +31 -0
- data/spec/services/sufia/workflow/workflow_by_admin_set_strategy_spec.rb +22 -0
- data/spec/spec_helper.rb +24 -5
- data/spec/support/proxies.rb +1 -1
- data/spec/test_app_templates/lib/generators/test_app_generator.rb +4 -0
- data/spec/views/_toolbar.html.erb_spec.rb +23 -6
- data/spec/views/batch_edits/edit.html.erb_spec.rb +7 -1
- data/spec/views/collections/_form_for_select_collection.html.erb_spec.rb +1 -3
- data/spec/views/curation_concerns/base/_find_work_widget.html.erb_spec.rb +22 -0
- data/spec/views/curation_concerns/base/_form.html.erb_spec.rb +7 -0
- data/spec/views/curation_concerns/base/_form_child_work_relationships.html.erb_spec.rb +1 -0
- data/spec/views/curation_concerns/base/_form_parent_work_relationships.html.erb_spec.rb +114 -0
- data/spec/views/curation_concerns/base/_form_progress.html.erb_spec.rb +3 -2
- data/spec/views/curation_concerns/base/_social_media.html.erb_spec.rb +1 -1
- data/spec/views/curation_concerns/base/edit.html.erb_spec.rb +1 -1
- data/spec/views/curation_concerns/base/show.html.erb_spec.rb +5 -1
- data/spec/views/curation_concerns/file_sets/_show_actions.html.erb_spec.rb +2 -2
- data/spec/views/dashboard/create_work_action.html.erb_spec.rb +27 -0
- data/spec/views/dashboard/index_spec.rb +7 -2
- data/spec/views/my/_sort_and_per_page.html.erb_spec.rb +33 -0
- data/spec/views/shared/select_work_type_modal.html.erb_spec.rb +32 -0
- data/spec/views/sufia/admin/admin_sets/_form.html.erb_spec.rb +18 -0
- data/spec/views/sufia/admin/admin_sets/_form_participants.html.erb_spec.rb +13 -0
- data/spec/views/sufia/admin/admin_sets/_form_visibility.html.erb_spec.rb +23 -0
- data/spec/views/sufia/batch_uploads/_form.html.erb_spec.rb +2 -12
- data/spec/views/sufia/homepage/index.html.erb_spec.rb +29 -8
- data/sufia.gemspec +5 -6
- data/tasks/sufia-dev.rake +6 -10
- data/template.rb +15 -0
- metadata +140 -28
- data/app/assets/stylesheets/sufia/widgets.css +0 -288
- data/app/helpers/sufia/citations_behaviors/formatters/endnote_formatter.rb +0 -49
- data/app/models/domain_term.rb +0 -4
- data/app/views/citations/file.html.erb +0 -0
- data/app/views/records/_rights_modal.html.erb +0 -1
- data/db/migrate/20160328222160_create_local_authorities.rb +0 -50
@@ -0,0 +1,17 @@
|
|
1
|
+
/* These styles are very specific to override the thumbnails from blacklight gallery */
|
2
|
+
|
3
|
+
.slideshow-documents {
|
4
|
+
.grid {
|
5
|
+
.document {
|
6
|
+
.thumbnail {
|
7
|
+
padding: 0;
|
8
|
+
|
9
|
+
a > img {
|
10
|
+
left: 0;
|
11
|
+
max-width: 100%;
|
12
|
+
top: 0;
|
13
|
+
}
|
14
|
+
}
|
15
|
+
}
|
16
|
+
}
|
17
|
+
}
|
@@ -0,0 +1,15 @@
|
|
1
|
+
module Qa::Authorities
|
2
|
+
class FindWorks < Qa::Authorities::Base
|
3
|
+
def search(_q, controller)
|
4
|
+
repo = CatalogController.new.repository
|
5
|
+
builder = Sufia::FindWorksSearchBuilder.new(controller)
|
6
|
+
response = repo.search(builder)
|
7
|
+
docs = response.documents
|
8
|
+
docs.map do |doc|
|
9
|
+
id = doc.id
|
10
|
+
title = doc.title
|
11
|
+
{ id: id, label: title, value: id }
|
12
|
+
end
|
13
|
+
end
|
14
|
+
end
|
15
|
+
end
|
@@ -48,7 +48,8 @@ module Sufia
|
|
48
48
|
end
|
49
49
|
|
50
50
|
def _prefixes
|
51
|
-
# This allows us to use the templates in curation_concerns/base
|
51
|
+
# This allows us to use the templates in curation_concerns/base, while prefering
|
52
|
+
# our local paths. Thus we are unable to just override `self.local_prefixes`
|
52
53
|
@_prefixes ||= super + ['curation_concerns/base']
|
53
54
|
end
|
54
55
|
|
@@ -5,28 +5,38 @@ module Sufia
|
|
5
5
|
include CurationConcerns::CurationConcernController
|
6
6
|
|
7
7
|
included do
|
8
|
-
self.
|
8
|
+
self.work_form_service = BatchUploadFormService
|
9
|
+
self.curation_concern_type = work_form_service.form_class.model_class # includes CanCan side-effects
|
10
|
+
# We use BatchUploadItem as a null stand-in curation_concern_type.
|
11
|
+
# The actual permission is checked dynamically during #create.
|
9
12
|
end
|
10
13
|
|
14
|
+
# The permissions to create a batch are not as important as the permissions for the concern being batched.
|
15
|
+
# @note we don't call `authorize!` directly, since `authorized_models` already checks `user.can? :create, ...`
|
11
16
|
def create
|
12
17
|
authenticate_user!
|
13
|
-
|
14
|
-
|
18
|
+
unsafe_pc = params.fetch(:batch_upload_item, {})[:payload_concern]
|
19
|
+
# Calling constantize on user params is disfavored (per brakeman), so we sanitize by matching it against an authorized model.
|
20
|
+
safe_pc = Sufia::SelectTypeListPresenter.new(current_user).authorized_models.map(&:to_s).find { |x| x == unsafe_pc }
|
21
|
+
raise CanCan::AccessDenied, "Cannot create an object of class '#{unsafe_pc}'" unless safe_pc
|
22
|
+
# authorize! :create, safe_pc
|
23
|
+
create_update_job(safe_pc)
|
24
|
+
flash[:notice] = t('sufia.works.create.after_create_html', application_name: view_context.application_name)
|
15
25
|
redirect_after_update
|
16
26
|
end
|
17
27
|
|
18
|
-
|
19
|
-
|
28
|
+
class BatchUploadFormService < CurationConcerns::WorkFormService
|
29
|
+
# Gives the class of the form.
|
30
|
+
def self.form_class(_curation_concern = nil)
|
20
31
|
::Sufia::Forms::BatchUploadForm
|
21
32
|
end
|
22
33
|
end
|
23
34
|
|
24
35
|
protected
|
25
36
|
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
self.class.form_class
|
37
|
+
def build_form
|
38
|
+
super
|
39
|
+
@form.payload_concern = params[:payload_concern]
|
30
40
|
end
|
31
41
|
|
32
42
|
def redirect_after_update
|
@@ -37,14 +47,17 @@ module Sufia
|
|
37
47
|
end
|
38
48
|
end
|
39
49
|
|
40
|
-
|
50
|
+
# @param [String] klass the name of the Sufia Work Class being created by the batch
|
51
|
+
# @note Cannot use a proper Class here because it won't serialize
|
52
|
+
def create_update_job(klass)
|
41
53
|
log = BatchCreateOperation.create!(user: current_user,
|
42
54
|
operation_type: "Batch Create")
|
55
|
+
# ActionController::Parameters are not serializable, so cast to a hash
|
43
56
|
BatchCreateJob.perform_later(current_user,
|
44
|
-
params[:title],
|
45
|
-
params[:resource_type],
|
57
|
+
params[:title].permit!.to_h,
|
58
|
+
params[:resource_type].permit!.to_h,
|
46
59
|
params[:uploaded_files],
|
47
|
-
attributes_for_actor,
|
60
|
+
attributes_for_actor.to_h.merge!(model: klass),
|
48
61
|
log)
|
49
62
|
end
|
50
63
|
|
@@ -14,6 +14,31 @@ module Sufia
|
|
14
14
|
|
15
15
|
protected
|
16
16
|
|
17
|
+
def after_destroy(id)
|
18
|
+
respond_to do |wants|
|
19
|
+
wants.html do
|
20
|
+
redirect_to sufia.dashboard_collections_path,
|
21
|
+
notice: "Collection #{id} was successfully deleted"
|
22
|
+
end
|
23
|
+
wants.json do
|
24
|
+
render json: { id: id, description: "Collection #{id} was successfully deleted" }
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|
28
|
+
|
29
|
+
def after_destroy_error(id)
|
30
|
+
respond_to do |wants|
|
31
|
+
wants.html do
|
32
|
+
flash[:notice] = "Collection #{id} could not be deleted"
|
33
|
+
render :edit, status: :unprocessable_entity
|
34
|
+
end
|
35
|
+
wants.json do
|
36
|
+
render json: { id: id, description: "Collection #{id} could not be deleted" },
|
37
|
+
status: :unprocessable_entity
|
38
|
+
end
|
39
|
+
end
|
40
|
+
end
|
41
|
+
|
17
42
|
def add_breadcrumb_for_controller
|
18
43
|
add_breadcrumb I18n.t('sufia.dashboard.my.collections'), sufia.dashboard_collections_path
|
19
44
|
end
|
@@ -2,8 +2,11 @@ module Sufia::Controller
|
|
2
2
|
extend ActiveSupport::Concern
|
3
3
|
|
4
4
|
included do
|
5
|
+
class_attribute :create_work_presenter_class
|
6
|
+
self.create_work_presenter_class = Sufia::SelectTypeListPresenter
|
5
7
|
# Adds Hydra behaviors into the application controller
|
6
8
|
include Hydra::Controller::ControllerBehavior
|
9
|
+
helper_method :create_work_presenter
|
7
10
|
end
|
8
11
|
|
9
12
|
def current_ability
|
@@ -14,4 +17,9 @@ module Sufia::Controller
|
|
14
17
|
def after_sign_in_path_for(_resource)
|
15
18
|
sufia.dashboard_index_path
|
16
19
|
end
|
20
|
+
|
21
|
+
# A presenter for selecting a work type to create
|
22
|
+
def create_work_presenter
|
23
|
+
@create_work_presenter ||= create_work_presenter_class.new(current_user)
|
24
|
+
end
|
17
25
|
end
|
@@ -1,6 +1,6 @@
|
|
1
1
|
module Sufia
|
2
2
|
module DenyAccessOverrideBehavior
|
3
|
-
# Overriding the default behavior from Hydra::Core::
|
3
|
+
# Overriding the default behavior from Hydra::Core::ControllerBehavior
|
4
4
|
def deny_access(exception)
|
5
5
|
if current_user && current_user.persisted?
|
6
6
|
redirect_to root_path, alert: exception.message
|
@@ -4,15 +4,6 @@ module Sufia
|
|
4
4
|
include Sufia::Breadcrumbs
|
5
5
|
|
6
6
|
included do
|
7
|
-
include Blacklight::Configurable
|
8
|
-
|
9
|
-
with_themed_layout '1_column'
|
10
|
-
|
11
|
-
copy_blacklight_config_from(CatalogController)
|
12
|
-
|
13
|
-
# actions: index, create, new, edit, show, update,
|
14
|
-
# destroy, permissions, citation, stats
|
15
|
-
|
16
7
|
# prepend this hook so that it comes before load_and_authorize
|
17
8
|
prepend_before_action :authenticate_user!, except: [:show, :citation, :stats]
|
18
9
|
before_action :build_breadcrumbs, only: [:show, :edit, :stats]
|
@@ -44,12 +35,12 @@ module Sufia
|
|
44
35
|
end
|
45
36
|
end
|
46
37
|
|
47
|
-
|
38
|
+
# This allows us to use the templates in curation_concerns/file_sets
|
39
|
+
def self.local_prefixes
|
40
|
+
['curation_concerns/file_sets']
|
41
|
+
end
|
48
42
|
|
49
|
-
|
50
|
-
# This allows us to use the templates in curation_concerns/file_sets
|
51
|
-
@_prefixes ||= ['curation_concerns/file_sets'] + super
|
52
|
-
end
|
43
|
+
protected
|
53
44
|
|
54
45
|
def initialize_edit_form
|
55
46
|
@version_list = version_list
|
@@ -12,13 +12,7 @@ module Sufia::UsersControllerBehavior
|
|
12
12
|
end
|
13
13
|
|
14
14
|
def index
|
15
|
-
|
16
|
-
base = User.where(*base_query)
|
17
|
-
unless query.blank?
|
18
|
-
base = base.where("#{Devise.authentication_keys.first} like lower(?) OR display_name like lower(?)", query, query)
|
19
|
-
end
|
20
|
-
@users = base.references(:trophies).order(sort_value).page(params[:page]).per(10)
|
21
|
-
|
15
|
+
@users = search(params[:uq])
|
22
16
|
respond_to do |format|
|
23
17
|
format.html
|
24
18
|
format.json { render json: @users.to_json }
|
@@ -68,6 +62,23 @@ module Sufia::UsersControllerBehavior
|
|
68
62
|
|
69
63
|
protected
|
70
64
|
|
65
|
+
# TODO: this should move to a service.
|
66
|
+
# Returns a list of users excluding the system users and guest_users
|
67
|
+
# @param query [String] the query string
|
68
|
+
def search(query)
|
69
|
+
clause = query.blank? ? nil : "%" + query.downcase + "%"
|
70
|
+
base = User.where(*base_query)
|
71
|
+
unless clause.blank?
|
72
|
+
base = base.where("#{Devise.authentication_keys.first} like lower(?) OR display_name like lower(?)", clause, clause)
|
73
|
+
end
|
74
|
+
base.where("#{Devise.authentication_keys.first} not in (?)",
|
75
|
+
[User.batch_user_key, User.audit_user_key])
|
76
|
+
.where(guest: false)
|
77
|
+
.references(:trophies)
|
78
|
+
.order(sort_value)
|
79
|
+
.page(params[:page]).per(10)
|
80
|
+
end
|
81
|
+
|
71
82
|
def user_params
|
72
83
|
params.require(:user).permit(:avatar, :facebook_handle, :twitter_handle,
|
73
84
|
:googleplus_handle, :linkedin_handle, :remove_avatar, :orcid)
|
@@ -9,8 +9,8 @@ module Sufia
|
|
9
9
|
end
|
10
10
|
|
11
11
|
module ClassMethods
|
12
|
-
# We don't want the
|
13
|
-
#
|
12
|
+
# We don't want the actions to occur until after the concern has been loaded and authorized
|
13
|
+
# @note this is a terribly side-effecty kludge
|
14
14
|
def curation_concern_type=(curation_concern_type)
|
15
15
|
super
|
16
16
|
before_action :build_breadcrumbs, only: [:edit, :show]
|
@@ -52,7 +52,7 @@ module Sufia
|
|
52
52
|
def after_create_response
|
53
53
|
respond_to do |wants|
|
54
54
|
wants.html do
|
55
|
-
flash[:notice] = t('sufia.works.
|
55
|
+
flash[:notice] = t('sufia.works.create.after_create_html', application_name: view_context.application_name)
|
56
56
|
redirect_to [main_app, curation_concern]
|
57
57
|
end
|
58
58
|
wants.json { render :show, status: :created, location: polymorphic_path([main_app, curation_concern]) }
|
@@ -62,13 +62,15 @@ module Sufia
|
|
62
62
|
def after_update_response
|
63
63
|
if permissions_changed? && curation_concern.file_sets.present?
|
64
64
|
redirect_to sufia.confirm_access_curation_concerns_permission_path(curation_concern)
|
65
|
-
elsif curation_concern.visibility_changed? && curation_concern.file_sets.present?
|
66
|
-
redirect_to main_app.confirm_curation_concerns_permission_path(curation_concern)
|
67
65
|
else
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
66
|
+
super
|
67
|
+
end
|
68
|
+
end
|
69
|
+
|
70
|
+
def after_destroy_response(title)
|
71
|
+
respond_to do |wants|
|
72
|
+
wants.html { redirect_to sufia.dashboard_works_path, notice: "Deleted #{title}" }
|
73
|
+
wants.json { render_json_response(response_type: :deleted, message: "Deleted #{curation_concern.id}") }
|
72
74
|
end
|
73
75
|
end
|
74
76
|
|
@@ -88,7 +90,8 @@ module Sufia
|
|
88
90
|
def add_breadcrumb_for_action
|
89
91
|
case action_name
|
90
92
|
when 'edit'.freeze
|
91
|
-
add_breadcrumb
|
93
|
+
add_breadcrumb curation_concern.to_s, main_app.polymorphic_path(curation_concern)
|
94
|
+
add_breadcrumb t('sufia.works.edit.breadcrumb'), request.path
|
92
95
|
when 'show'.freeze
|
93
96
|
add_breadcrumb presenter.to_s, main_app.polymorphic_path(presenter)
|
94
97
|
end
|
@@ -14,5 +14,10 @@ module My
|
|
14
14
|
def search_action_url(*args)
|
15
15
|
sufia.dashboard_collections_url(*args)
|
16
16
|
end
|
17
|
+
|
18
|
+
# The url of the "more" link for additional facet values
|
19
|
+
def search_facet_path(args = {})
|
20
|
+
sufia.dashboard_collections_facet_path(args[:id])
|
21
|
+
end
|
17
22
|
end
|
18
23
|
end
|
@@ -23,7 +23,7 @@ class StatsController < ApplicationController
|
|
23
23
|
when 'file'.freeze
|
24
24
|
add_breadcrumb I18n.t("sufia.file_set.browse_view"), main_app.curation_concerns_file_set_path(params["id"])
|
25
25
|
when 'work'.freeze
|
26
|
-
add_breadcrumb
|
26
|
+
add_breadcrumb @work.to_s, polymorphic_path(@work)
|
27
27
|
end
|
28
28
|
end
|
29
29
|
end
|
@@ -43,6 +43,7 @@ module Sufia
|
|
43
43
|
|
44
44
|
def update
|
45
45
|
if @admin_set.update(admin_set_params)
|
46
|
+
permission_template.update(permission_template_params)
|
46
47
|
redirect_to sufia.admin_admin_sets_path
|
47
48
|
else
|
48
49
|
setup_form
|
@@ -52,6 +53,9 @@ module Sufia
|
|
52
53
|
|
53
54
|
def create
|
54
55
|
if create_admin_set
|
56
|
+
permission_template_holder = permission_template
|
57
|
+
permission_template_holder.attributes = permission_template_params
|
58
|
+
permission_template_holder.save! # to create permission template on create
|
55
59
|
redirect_to sufia.admin_admin_sets_path
|
56
60
|
else
|
57
61
|
setup_form
|
@@ -59,6 +63,11 @@ module Sufia
|
|
59
63
|
end
|
60
64
|
end
|
61
65
|
|
66
|
+
def destroy
|
67
|
+
@admin_set.destroy
|
68
|
+
redirect_to sufia.admin_admin_sets_path, notice: t(:'sufia.admin.admin_sets.delete.notification')
|
69
|
+
end
|
70
|
+
|
62
71
|
# for the AdminSetService
|
63
72
|
def repository
|
64
73
|
repository_class.new(blacklight_config)
|
@@ -83,7 +92,7 @@ module Sufia
|
|
83
92
|
end
|
84
93
|
|
85
94
|
def create_admin_set
|
86
|
-
|
95
|
+
AdminSetCreateService.new(@admin_set, current_user).create
|
87
96
|
end
|
88
97
|
|
89
98
|
def setup_form
|
@@ -91,7 +100,12 @@ module Sufia
|
|
91
100
|
add_breadcrumb t(:'sufia.toolbar.admin.menu'), sufia.admin_path
|
92
101
|
add_breadcrumb t(:'sufia.admin.sidebar.admin_sets'), sufia.admin_admin_sets_path
|
93
102
|
add_breadcrumb action_breadcrumb, request.path
|
94
|
-
@form = form_class.new(@admin_set)
|
103
|
+
@form = form_class.new(@admin_set, permission_template)
|
104
|
+
end
|
105
|
+
|
106
|
+
# Find or create the permission_template object for this admin set
|
107
|
+
def permission_template
|
108
|
+
PermissionTemplate.find_or_initialize_by(admin_set_id: @admin_set.id)
|
95
109
|
end
|
96
110
|
|
97
111
|
def action_breadcrumb
|
@@ -110,5 +124,9 @@ module Sufia
|
|
110
124
|
def repository_class
|
111
125
|
blacklight_config.repository_class
|
112
126
|
end
|
127
|
+
|
128
|
+
def permission_template_params
|
129
|
+
{ "workflow_name" => params[:admin_set][:workflow_name] }
|
130
|
+
end
|
113
131
|
end
|
114
132
|
end
|
@@ -0,0 +1,15 @@
|
|
1
|
+
module Sufia
|
2
|
+
module Admin
|
3
|
+
class PermissionTemplateAccessesController < ApplicationController
|
4
|
+
load_and_authorize_resource class: 'Sufia::PermissionTemplateAccess'
|
5
|
+
|
6
|
+
def destroy
|
7
|
+
@permission_template_access.destroy
|
8
|
+
|
9
|
+
redirect_to sufia.edit_admin_admin_set_path(@permission_template_access.permission_template.admin_set_id,
|
10
|
+
anchor: 'participants'),
|
11
|
+
notice: 'Permissions updated'
|
12
|
+
end
|
13
|
+
end
|
14
|
+
end
|
15
|
+
end
|
@@ -0,0 +1,29 @@
|
|
1
|
+
module Sufia
|
2
|
+
module Admin
|
3
|
+
class PermissionTemplatesController < ApplicationController
|
4
|
+
before_action :load_template_for_admin_set
|
5
|
+
|
6
|
+
def update
|
7
|
+
authorize! :update, @permission_template
|
8
|
+
Forms::PermissionTemplateForm.new(@permission_template).update(update_params)
|
9
|
+
# Ensure we redirect to active tab
|
10
|
+
current_tab = params[:sufia_permission_template][:access_grants_attributes].present? ? 'participants' : 'visibility'
|
11
|
+
redirect_to sufia.edit_admin_admin_set_path(params[:admin_set_id], anchor: current_tab),
|
12
|
+
notice: 'Permissions updated'
|
13
|
+
end
|
14
|
+
|
15
|
+
private
|
16
|
+
|
17
|
+
# This sets the @permission_template so that CanCanCan doesn't have to.
|
18
|
+
def load_template_for_admin_set
|
19
|
+
@permission_template = Sufia::PermissionTemplate.find_by(admin_set_id: params[:admin_set_id])
|
20
|
+
end
|
21
|
+
|
22
|
+
def update_params
|
23
|
+
params.require(:sufia_permission_template)
|
24
|
+
.permit(:release_date, :release_period, :release_varies, :release_embargo, :visibility,
|
25
|
+
access_grants_attributes: [:access, :agent_id, :agent_type, :id])
|
26
|
+
end
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|