blacklight-spotlight 0.4.1 → 0.5.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +22 -8
- data/Rakefile +40 -39
- data/app/assets/javascripts/spotlight/blacklight_configuration.js +16 -0
- data/app/assets/javascripts/spotlight/blocks/resources_block.js +3 -1
- data/app/assets/stylesheets/spotlight/_blacklight_configuration.scss +2 -2
- data/app/assets/stylesheets/spotlight/_blacklight_overrides.scss +24 -0
- data/app/assets/stylesheets/spotlight/_header.scss +150 -47
- data/app/assets/stylesheets/spotlight/_pages.scss +62 -11
- data/app/assets/stylesheets/spotlight/_report_a_problem.scss +1 -0
- data/app/assets/stylesheets/spotlight/_spotlight.scss +1 -0
- data/app/builders/spotlight/bootstrap_breadcrumbs_builder.rb +28 -21
- data/app/controllers/spotlight/about_pages_controller.rb +25 -14
- data/app/controllers/spotlight/appearances_controller.rb +34 -30
- data/app/controllers/spotlight/application_controller.rb +2 -1
- data/app/controllers/spotlight/attachments_controller.rb +9 -7
- data/app/controllers/spotlight/browse_controller.rb +13 -9
- data/app/controllers/spotlight/catalog_controller.rb +179 -161
- data/app/controllers/spotlight/concerns/application_controller.rb +22 -20
- data/app/controllers/spotlight/concerns/catalog_search_context.rb +44 -0
- data/app/controllers/spotlight/confirmations_controller.rb +5 -2
- data/app/controllers/spotlight/contact_forms_controller.rb +13 -7
- data/app/controllers/spotlight/contacts_controller.rb +13 -4
- data/app/controllers/spotlight/custom_fields_controller.rb +48 -40
- data/app/controllers/spotlight/dashboards_controller.rb +17 -8
- data/app/controllers/spotlight/default_controller.rb +3 -1
- data/app/controllers/spotlight/exhibits_controller.rb +69 -62
- data/app/controllers/spotlight/feature_pages_controller.rb +21 -11
- data/app/controllers/spotlight/home_pages_controller.rb +6 -5
- data/app/controllers/spotlight/lock_controller.rb +3 -1
- data/app/controllers/spotlight/metadata_configurations_controller.rb +49 -0
- data/app/controllers/spotlight/pages_controller.rb +28 -18
- data/app/controllers/spotlight/resources/upload_controller.rb +53 -46
- data/app/controllers/spotlight/resources_controller.rb +9 -5
- data/app/controllers/spotlight/roles_controller.rb +26 -22
- data/app/controllers/spotlight/search_configurations_controller.rb +66 -0
- data/app/controllers/spotlight/searches_controller.rb +91 -82
- data/app/controllers/spotlight/solr_controller.rb +20 -13
- data/app/controllers/spotlight/tags_controller.rb +5 -3
- data/app/controllers/spotlight/versions_controller.rb +15 -12
- data/app/controllers/spotlight/view_configurations_controller.rb +17 -0
- data/app/helpers/spotlight/application_helper.rb +44 -32
- data/app/helpers/spotlight/browse_helper.rb +13 -1
- data/app/helpers/spotlight/crud_link_helpers.rb +22 -14
- data/app/helpers/spotlight/jcrop_helper.rb +4 -2
- data/app/helpers/spotlight/main_app_helpers.rb +45 -41
- data/app/helpers/spotlight/navbar_helper.rb +6 -0
- data/app/helpers/spotlight/pages_helper.rb +23 -15
- data/app/helpers/spotlight/roles_helper.rb +10 -4
- data/app/helpers/spotlight/search_configurations_helper.rb +22 -0
- data/app/helpers/spotlight/title_helper.rb +16 -13
- data/app/jobs/spotlight/add_uploads_from_csv.rb +13 -9
- data/app/jobs/spotlight/reindex_job.rb +9 -9
- data/app/jobs/spotlight/rename_sidecar_field_job.rb +3 -0
- data/app/mailers/spotlight/confirmation_mailer.rb +2 -0
- data/app/mailers/spotlight/indexing_complete_mailer.rb +4 -2
- data/app/models/ability.rb +3 -0
- data/app/models/concerns/spotlight/ar_light.rb +49 -25
- data/app/models/concerns/spotlight/blacklight_configuration_defaults.rb +25 -10
- data/app/models/concerns/spotlight/exhibit_analytics.rb +28 -0
- data/app/models/concerns/spotlight/image_derivatives.rb +25 -26
- data/app/models/concerns/spotlight/resources/open_graph.rb +23 -19
- data/app/models/concerns/spotlight/resources/web.rb +25 -24
- data/app/models/concerns/spotlight/solr_document.rb +40 -34
- data/app/models/concerns/spotlight/solr_document/active_model_concern.rb +29 -40
- data/app/models/concerns/spotlight/solr_document/atomic_updates.rb +22 -18
- data/app/models/concerns/spotlight/solr_document/finder.rb +23 -18
- data/app/models/concerns/spotlight/solr_document/spotlight_images.rb +43 -39
- data/app/models/concerns/spotlight/solr_document/uploaded_resource.rb +41 -29
- data/app/models/concerns/spotlight/user.rb +25 -19
- data/app/models/sir_trevor_rails/blocks/browse_block.rb +36 -30
- data/app/models/sir_trevor_rails/blocks/featured_pages_block.rb +24 -18
- data/app/models/sir_trevor_rails/blocks/oembed_block.rb +8 -4
- data/app/models/sir_trevor_rails/blocks/search_results_block.rb +29 -23
- data/app/models/sir_trevor_rails/blocks/solr_documents_block.rb +43 -42
- data/app/models/sir_trevor_rails/blocks/solr_documents_carousel_block.rb +16 -12
- data/app/models/sir_trevor_rails/blocks/solr_documents_embed_block.rb +7 -3
- data/app/models/sir_trevor_rails/blocks/solr_documents_features_block.rb +7 -3
- data/app/models/sir_trevor_rails/blocks/solr_documents_grid_block.rb +7 -3
- data/app/models/sir_trevor_rails/blocks/textable.rb +18 -18
- data/app/models/spotlight/ability.rb +32 -33
- data/app/models/spotlight/about_page.rb +3 -1
- data/app/models/spotlight/analytics/ga.rb +46 -27
- data/app/models/spotlight/attachment.rb +3 -1
- data/app/models/spotlight/blacklight_configuration.rb +146 -68
- data/app/models/spotlight/contact.rb +35 -30
- data/app/models/spotlight/contact_email.rb +6 -3
- data/app/models/spotlight/contact_form.rb +4 -3
- data/app/models/spotlight/custom_field.rb +41 -33
- data/app/models/spotlight/exhibit.rb +104 -130
- data/app/models/spotlight/feature_page.rb +9 -7
- data/app/models/spotlight/featured_image.rb +10 -10
- data/app/models/spotlight/field_metadata.rb +46 -0
- data/app/models/spotlight/home_page.rb +8 -5
- data/app/models/spotlight/lock.rb +4 -3
- data/app/models/spotlight/main_navigation.rb +9 -3
- data/app/models/spotlight/masthead.rb +17 -16
- data/app/models/spotlight/page.rb +16 -16
- data/app/models/spotlight/resource.rb +69 -22
- data/app/models/spotlight/resources/csv_upload.rb +8 -4
- data/app/models/spotlight/resources/upload.rb +68 -57
- data/app/models/spotlight/role.rb +30 -34
- data/app/models/spotlight/search.rb +74 -63
- data/app/models/spotlight/solr_document_sidecar.rb +17 -15
- data/app/serializers/spotlight/exhibit_export_serializer.rb +65 -29
- data/app/serializers/spotlight/page_representer.rb +10 -6
- data/app/uploaders/spotlight/attachment_uploader.rb +4 -6
- data/app/uploaders/spotlight/avatar_uploader.rb +4 -3
- data/app/uploaders/spotlight/featured_image_uploader.rb +15 -14
- data/app/uploaders/spotlight/item_uploader.rb +3 -1
- data/app/uploaders/spotlight/masthead_uploader.rb +4 -2
- data/app/views/catalog/_search_form.html.erb +24 -0
- data/app/views/shared/_browse_navbar.html.erb +1 -1
- data/app/views/shared/_exhibit_navbar.html.erb +1 -1
- data/app/views/spotlight/appearances/edit.html.erb +13 -45
- data/app/views/spotlight/catalog/_edit_default.html.erb +1 -1
- data/app/views/spotlight/custom_fields/_form.html.erb +1 -1
- data/app/views/spotlight/exhibits/edit.html.erb +4 -4
- data/app/views/spotlight/home_pages/_empty.html.erb +1 -3
- data/app/views/spotlight/home_pages/_page_options.html.erb +1 -1
- data/app/views/spotlight/{blacklight_configurations → metadata_configurations}/_metadata_field.html.erb +0 -0
- data/app/views/spotlight/{blacklight_configurations/edit_metadata_fields.html.erb → metadata_configurations/edit.html.erb} +1 -1
- data/app/views/spotlight/pages/show.html.erb +2 -2
- data/app/views/spotlight/search_configurations/_default_per_page.html.erb +5 -0
- data/app/views/spotlight/search_configurations/_document_index_view_types.html.erb +7 -0
- data/app/views/spotlight/search_configurations/_facets.html.erb +38 -0
- data/app/views/spotlight/search_configurations/_search_fields.html.erb +58 -0
- data/app/views/spotlight/search_configurations/_sort.html.erb +53 -0
- data/app/views/spotlight/search_configurations/edit.html.erb +46 -0
- data/app/views/spotlight/searches/_search.html.erb +1 -1
- data/app/views/spotlight/shared/_admin_sidebar.html.erb +0 -2
- data/app/views/spotlight/shared/_curation_sidebar.html.erb +2 -3
- data/app/views/spotlight/shared/_report_a_problem.html.erb +2 -2
- data/app/views/spotlight/sir_trevor/blocks/_oembed_block.html.erb +5 -1
- data/app/views/spotlight/sir_trevor/blocks/_solr_documents_block.html.erb +7 -5
- data/app/views/spotlight/sir_trevor/blocks/_solr_documents_carousel_block.html.erb +2 -2
- data/app/views/spotlight/sir_trevor/blocks/_solr_documents_embed_block.html.erb +7 -5
- data/app/views/spotlight/sir_trevor/blocks/_solr_documents_features_block.html.erb +2 -2
- data/app/views/spotlight/sir_trevor/blocks/_solr_documents_grid_block.html.erb +14 -9
- data/config/locales/spotlight.en.yml +94 -49
- data/config/routes.rb +11 -20
- data/db/migrate/20150410180014_add_taggings_counter_cache_to_tags.acts_as_taggable_on_engine.rb +15 -0
- data/db/migrate/20150410180015_add_missing_taggable_index.acts_as_taggable_on_engine.rb +10 -0
- data/db/migrate/20150410180016_change_collation_for_tag_names.acts_as_taggable_on_engine.rb +10 -0
- data/db/migrate/20150713160101_change_spotlight_searches_to_published.rb +5 -0
- data/db/migrate/20151016092343_remove_searchable_from_exhibit.rb +20 -0
- data/lib/blacklight/spotlight.rb +1 -1
- data/lib/generators/spotlight/install_generator.rb +27 -25
- data/lib/generators/spotlight/templates/catalog_controller.rb +7 -5
- data/lib/generators/spotlight/templates/jetty.rake +8 -2
- data/lib/generators/spotlight/templates/spotlight_helper.rb +3 -1
- data/lib/spotlight.rb +4 -2
- data/lib/spotlight/base.rb +21 -14
- data/lib/spotlight/catalog.rb +10 -9
- data/lib/spotlight/catalog/access_controls_enforcement.rb +30 -15
- data/lib/spotlight/config.rb +4 -2
- data/lib/spotlight/controller.rb +12 -11
- data/lib/spotlight/engine.rb +30 -22
- data/lib/spotlight/rails/routes.rb +7 -4
- data/lib/spotlight/version.rb +2 -1
- data/lib/tasks/spotlight_tasks.rake +56 -50
- data/spec/controllers/application_controller_spec.rb +13 -13
- data/spec/controllers/spotlight/about_pages_controller_spec.rb +63 -59
- data/spec/controllers/spotlight/appearances_controller_spec.rb +29 -24
- data/spec/controllers/spotlight/application_controller_spec.rb +3 -3
- data/spec/controllers/spotlight/attachments_controller_spec.rb +10 -10
- data/spec/controllers/spotlight/browse_controller_spec.rb +23 -25
- data/spec/controllers/spotlight/catalog_controller_spec.rb +82 -87
- data/spec/controllers/spotlight/confirmations_controller_spec.rb +13 -11
- data/spec/controllers/spotlight/contact_forms_controller_spec.rb +17 -12
- data/spec/controllers/spotlight/contacts_controller_spec.rb +36 -36
- data/spec/controllers/spotlight/custom_fields_controller_spec.rb +26 -26
- data/spec/controllers/spotlight/dashboards_controller_spec.rb +14 -14
- data/spec/controllers/spotlight/exhibits_controller_spec.rb +59 -54
- data/spec/controllers/spotlight/feature_pages_controller_spec.rb +59 -59
- data/spec/controllers/spotlight/home_pages_controller_spec.rb +28 -29
- data/spec/controllers/spotlight/metadata_configurations_controller_spec.rb +84 -0
- data/spec/controllers/spotlight/resources/upload_controller_spec.rb +42 -33
- data/spec/controllers/spotlight/resources_controller_spec.rb +25 -29
- data/spec/controllers/spotlight/roles_controller_spec.rb +37 -19
- data/spec/controllers/spotlight/search_configurations_controller_spec.rb +125 -0
- data/spec/controllers/spotlight/searches_controller_spec.rb +84 -63
- data/spec/controllers/spotlight/solr_controller_spec.rb +13 -14
- data/spec/controllers/spotlight/tags_controller_spec.rb +16 -16
- data/spec/controllers/spotlight/versions_controller_spec.rb +15 -18
- data/spec/controllers/spotlight/view_configurations_controller_spec.rb +31 -0
- data/spec/factories/contacts.rb +1 -3
- data/spec/factories/custom_fields.rb +2 -4
- data/spec/factories/exhibits.rb +4 -2
- data/spec/factories/pages.rb +8 -11
- data/spec/factories/resources.rb +4 -4
- data/spec/factories/searches.rb +10 -13
- data/spec/factories/tags.rb +0 -3
- data/spec/factories/users.rb +2 -4
- data/spec/features/about_page_spec.rb +19 -19
- data/spec/features/add_contacts_spec.rb +34 -34
- data/spec/features/add_custom_field_metadata_spec.rb +24 -26
- data/spec/features/add_item_bookmarklet_spec.rb +12 -12
- data/spec/features/browse_category_admin_spec.rb +39 -39
- data/spec/features/catalog_spec.rb +9 -10
- data/spec/features/confirm_email_spec.rb +10 -10
- data/spec/features/create_exhibit_spec.rb +18 -15
- data/spec/features/create_page_spec.rb +8 -8
- data/spec/features/curator_items.rb +3 -3
- data/spec/features/dashboard_spec.rb +15 -16
- data/spec/features/edit_contact_spec.rb +8 -10
- data/spec/features/edit_search_fields_spec.rb +79 -0
- data/spec/features/exhibits/add_tags_spec.rb +15 -16
- data/spec/features/exhibits/administration_spec.rb +25 -25
- data/spec/features/exhibits/custom_metadata_fields_spec.rb +41 -43
- data/spec/features/exhibits/edit_metadata_fields_spec.rb +19 -19
- data/spec/features/feature_page_spec.rb +49 -48
- data/spec/features/home_page_spec.rb +38 -38
- data/spec/features/import_exhibit_spec.rb +23 -20
- data/spec/features/item_admin_spec.rb +28 -29
- data/spec/features/javascript/about_page_admin_spec.rb +9 -9
- data/spec/features/javascript/block_controls_spec.rb +16 -18
- data/spec/features/javascript/blocks/featured_browse_categories_block_spec.rb +11 -12
- data/spec/features/javascript/blocks/featured_pages_block_spec.rb +12 -13
- data/spec/features/javascript/blocks/search_result_block_spec.rb +17 -17
- data/spec/features/javascript/blocks/solr_documents_block_spec.rb +67 -65
- data/spec/features/javascript/edit_in_place_spec.rb +30 -56
- data/spec/features/javascript/feature_page_admin_spec.rb +73 -59
- data/spec/features/javascript/home_page_edit_spec.rb +6 -6
- data/spec/features/javascript/metadata_admin_spec.rb +15 -15
- data/spec/features/javascript/multi_image_select_spec.rb +17 -18
- data/spec/features/javascript/preview_block_spec.rb +11 -12
- data/spec/features/javascript/rule_block_spec.rb +7 -7
- data/spec/features/javascript/search_config_admin_spec.rb +144 -0
- data/spec/features/javascript/search_context_spec.rb +41 -42
- data/spec/features/main_navigation_spec.rb +22 -22
- data/spec/features/metadata_admin_spec.rb +8 -8
- data/spec/features/multiple_exhibits_spec.rb +15 -17
- data/spec/features/report_a_problem_spec.rb +23 -17
- data/spec/features/site_masthead_spec.rb +46 -46
- data/spec/features/slideshow_spec.rb +8 -9
- data/spec/features/tags_admin_spec.rb +11 -11
- data/spec/features/upload_non_repository_item_spec.rb +32 -32
- data/spec/features/user_admin_spec.rb +7 -7
- data/spec/helpers/spotlight/application_helper_spec.rb +63 -56
- data/spec/helpers/spotlight/browse_helper_spec.rb +6 -6
- data/spec/helpers/spotlight/crud_link_helpers_spec.rb +58 -52
- data/spec/helpers/spotlight/main_app_helpers_spec.rb +44 -24
- data/spec/helpers/spotlight/navbar_helper_spec.rb +4 -4
- data/spec/helpers/spotlight/pages_helper_spec.rb +56 -37
- data/spec/helpers/spotlight/roles_helper_spec.rb +3 -3
- data/spec/helpers/spotlight/search_configurations_helper_spec.rb +24 -0
- data/spec/helpers/spotlight/title_helper_spec.rb +33 -35
- data/spec/jobs/spotlight/reindex_job_spec.rb +6 -6
- data/spec/jobs/spotlight/rename_sidecar_field_job_spec.rb +7 -7
- data/spec/lib/spotlight/catalog/access_controls_enforcement_spec.rb +41 -26
- data/spec/lib/spotlight/controller_spec.rb +10 -10
- data/spec/lib/spotlight/routes_spec.rb +4 -4
- data/spec/mailers/spotlight/indexing_complete_mailer_spec.rb +13 -13
- data/spec/models/sir_trevor_rails/blocks/solr_documents_block_spec.rb +8 -8
- data/spec/models/{spotlight/sir_trevor_blocks → sir_trevor_rails/blocks}/textable_spec.rb +7 -8
- data/spec/models/solr_document_spec.rb +49 -50
- data/spec/models/spotlight/ability_spec.rb +17 -20
- data/spec/models/spotlight/about_page_spec.rb +6 -6
- data/spec/models/spotlight/analytics/ga_spec.rb +2 -2
- data/spec/models/spotlight/blacklight_configuration_spec.rb +196 -133
- data/spec/models/spotlight/contact_email_spec.rb +28 -24
- data/spec/models/spotlight/contact_spec.rb +6 -7
- data/spec/models/spotlight/custom_field_spec.rb +51 -52
- data/spec/models/spotlight/exhibit_spec.rb +102 -60
- data/spec/models/spotlight/feature_page_spec.rb +32 -32
- data/spec/models/spotlight/featured_image_spec.rb +5 -5
- data/spec/models/spotlight/field_metadata_spec.rb +78 -0
- data/spec/models/spotlight/home_page_spec.rb +11 -20
- data/spec/models/spotlight/{spotlight_image_derivatives_spec.rb → image_derivatives_spec.rb} +2 -2
- data/spec/models/spotlight/main_navigation_spec.rb +7 -9
- data/spec/models/spotlight/masthead_spec.rb +6 -6
- data/spec/models/spotlight/page_spec.rb +26 -29
- data/spec/models/spotlight/resource_spec.rb +56 -26
- data/spec/models/spotlight/resources/open_graph_spec.rb +16 -18
- data/spec/models/spotlight/resources/upload_spec.rb +32 -35
- data/spec/models/spotlight/resources/web_spec.rb +9 -11
- data/spec/models/spotlight/role_spec.rb +20 -20
- data/spec/models/spotlight/search_spec.rb +32 -15
- data/spec/models/spotlight/solr_document/atomic_updates_spec.rb +34 -0
- data/spec/models/spotlight/{solr_document_images_spec.rb → solr_document/spotlight_images_spec.rb} +18 -10
- data/spec/models/spotlight/solr_document/uploaded_resource_spec.rb +52 -0
- data/spec/models/spotlight/solr_document_sidecar_spec.rb +3 -4
- data/spec/routing/spotlight/exhibit_catalog_spec.rb +5 -5
- data/spec/routing/spotlight/pages_routing_spec.rb +24 -25
- data/spec/serializers/spotlight/exhibit_export_serializer_spec.rb +88 -68
- data/spec/spec_helper.rb +13 -22
- data/spec/support/features/test_features_helpers.rb +50 -46
- data/spec/support/views/test_view_helpers.rb +1 -1
- data/spec/test_app_templates/Gemfile.extra +0 -1
- data/spec/test_app_templates/carrierwave.rb +2 -2
- data/spec/test_app_templates/catalog_controller.rb +42 -42
- data/spec/test_app_templates/lib/generators/test_app_generator.rb +20 -11
- data/spec/test_app_templates/spotlight_test.rake +3 -3
- data/spec/uploaders/spotlight/item_uploader_spec.rb +68 -0
- data/spec/views/_user_util_links.html.erb_spec.rb +14 -14
- data/spec/views/shared/_analytics.html.erb_spec.rb +4 -6
- data/spec/views/shared/_exhibit_masthead.html.erb_spec.rb +19 -20
- data/spec/views/shared/_exhibit_navbar.html.erb_spec.rb +129 -131
- data/spec/views/shared/_footer.html.erb_spec.rb +6 -7
- data/spec/views/shared/_header_navbar.html.erb_spec.rb +5 -5
- data/spec/views/spotlight/about_pages/_empty.html.erb_spec.rb +4 -4
- data/spec/views/spotlight/about_pages/_sidebar.html.erb_spec.rb +9 -11
- data/spec/views/spotlight/about_pages/index.html.erb_spec.rb +31 -28
- data/spec/views/spotlight/browse/_search.html.erb_spec.rb +6 -6
- data/spec/views/spotlight/browse/_sort_and_per_page.html.erb_spec.rb +10 -12
- data/spec/views/spotlight/browse/index.html.erb_spec.rb +6 -6
- data/spec/views/spotlight/browse/show.html.erb_spec.rb +19 -20
- data/spec/views/spotlight/catalog/_edit_default.html.erb_spec.rb +7 -7
- data/spec/views/spotlight/catalog/admin.html.erb_spec.rb +7 -7
- data/spec/views/spotlight/catalog/edit.html.erb_spec.rb +3 -6
- data/spec/views/spotlight/catalog/new.html.erb_spec.rb +8 -10
- data/spec/views/spotlight/contacts/edit.html.erb_spec.rb +8 -8
- data/spec/views/spotlight/dashboards/_analytics.html.erb_spec.rb +22 -22
- data/spec/views/spotlight/exhibits/edit.html.erb_spec.rb +7 -8
- data/spec/views/spotlight/feature_pages/_empty.html.erb_spec.rb +5 -5
- data/spec/views/spotlight/feature_pages/_sidebar.html.erb_spec.rb +24 -26
- data/spec/views/spotlight/home_pages/_empty.html.erb_spec.rb +13 -9
- data/spec/views/spotlight/home_pages/_sidebar.html.erb_spec.rb +6 -6
- data/spec/views/spotlight/metadata_configurations/_metadata_field.html.erb_spec.rb +26 -0
- data/spec/views/spotlight/metadata_configurations/edit.html.erb_spec.rb +22 -0
- data/spec/views/spotlight/pages/edit.html.erb_spec.rb +16 -16
- data/spec/views/spotlight/pages/index.html.erb_spec.rb +19 -17
- data/spec/views/spotlight/pages/new.html.erb_spec.rb +6 -6
- data/spec/views/spotlight/pages/show.html.erb_spec.rb +27 -28
- data/spec/views/spotlight/roles/index.html.erb_spec.rb +6 -6
- data/spec/views/spotlight/search_configurations/_search_fields.html.erb_spec.rb +54 -0
- data/spec/views/spotlight/search_configurations/_sort.html.erb_spec.rb +28 -0
- data/spec/views/spotlight/searches/_search.html.erb_spec.rb +20 -10
- data/spec/views/spotlight/searches/edit.html.erb_spec.rb +12 -11
- data/spec/views/spotlight/searches/index.html.erb_spec.rb +12 -7
- data/spec/views/spotlight/sir_trevor/blocks/_iframe_block.html.erb_spec.rb +7 -8
- data/spec/views/spotlight/sir_trevor/blocks/_rule_block.html.erb_spec.rb +4 -4
- data/spec/views/spotlight/sir_trevor/blocks/_solr_documents_block.html.erb_spec.rb +38 -0
- data/spec/views/spotlight/sir_trevor/blocks/_solr_documents_carousel_block.html.erb_spec.rb +7 -8
- data/spec/views/spotlight/sir_trevor/blocks/_solr_documents_embed_block.html.erb_spec.rb +18 -13
- data/spec/views/spotlight/sir_trevor/blocks/_solr_documents_features_block.html.erb_spec.rb +14 -12
- data/spec/views/spotlight/sir_trevor/blocks/_solr_documents_grid_block.html.erb_spec.rb +11 -12
- data/spec/views/spotlight/tags/index.html.erb_spec.rb +9 -9
- metadata +167 -83
- data/app/controllers/spotlight/blacklight_configurations_controller.rb +0 -101
- data/app/controllers/spotlight/resources/csv_controller.rb +0 -23
- data/app/forms/spotlight/appearance.rb +0 -86
- data/app/helpers/spotlight/attachments_helper.rb +0 -4
- data/app/helpers/spotlight/blacklight_configurations_helper.rb +0 -15
- data/app/jobs/spotlight/set_default_thumbnail_job.rb +0 -16
- data/app/models/spotlight/resources/csv.rb +0 -80
- data/app/uploaders/spotlight/csv_uploader.rb +0 -15
- data/app/views/spotlight/blacklight_configurations/edit_facet_fields.html.erb +0 -47
- data/app/views/spotlight/blacklight_configurations/edit_sort_fields.html.erb +0 -65
- data/app/views/spotlight/resources/csv/_form.html.erb +0 -17
- data/app/views/spotlight/resources/csv/new.html.erb +0 -3
- data/spec/controllers/spotlight/blacklight_configurations_controller_spec.rb +0 -167
- data/spec/features/edit_sort_fields_spec.rb +0 -42
- data/spec/features/exhibits/edit_facet_fields_spec.rb +0 -37
- data/spec/features/javascript/facet_admin_spec.rb +0 -36
- data/spec/features/search_facets_admin_spec.rb +0 -19
- data/spec/features/update_appearance_spec.rb +0 -58
- data/spec/helpers/spotlight/blacklight_configurations_helper_spec.rb +0 -12
- data/spec/models/spotlight/appearance_spec.rb +0 -33
- data/spec/models/spotlight/resources/csv_spec.rb +0 -101
- data/spec/models/spotlight/solr_document_atomic_updates_spec.rb +0 -29
- data/spec/models/spotlight/solr_document_uploaded_resource_spec.rb +0 -45
- data/spec/uploaders/item_uploader_spec.rb +0 -62
- data/spec/views/spotlight/blacklight_configuration/_metadata_field.html.erb_spec.rb +0 -27
- data/spec/views/spotlight/blacklight_configuration/edit_metadata_fields.html.erb_spec.rb +0 -23
- data/spec/views/spotlight/blacklight_configuration/edit_sort_fields.html.erb_spec.rb +0 -19
@@ -1,39 +1,44 @@
|
|
1
|
-
|
2
|
-
|
3
|
-
|
4
|
-
|
5
|
-
|
1
|
+
module Spotlight
|
2
|
+
##
|
3
|
+
# Exhibit curator contact information
|
4
|
+
class Contact < ActiveRecord::Base
|
5
|
+
belongs_to :exhibit, touch: true
|
6
|
+
scope :published, -> { where(show_in_sidebar: true) }
|
7
|
+
default_scope { order('weight ASC') }
|
8
|
+
serialize :contact_info, Hash
|
6
9
|
|
7
|
-
|
8
|
-
|
10
|
+
extend FriendlyId
|
11
|
+
friendly_id :name, use: [:slugged, :scoped, :finders], scope: :exhibit
|
9
12
|
|
10
|
-
|
13
|
+
mount_uploader :avatar, Spotlight::AvatarUploader
|
11
14
|
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
15
|
+
## carrierwave-crop doesn't want to store the crop points. we do.
|
16
|
+
# so instead of this:
|
17
|
+
# crop_uploaded :avatar ## Add this
|
18
|
+
# we do this:
|
19
|
+
after_save do
|
20
|
+
if avatar.present?
|
21
|
+
avatar.cache! unless avatar.cached?
|
22
|
+
avatar.store!
|
23
|
+
recreate_avatar_versions
|
24
|
+
end
|
21
25
|
end
|
22
|
-
end
|
23
26
|
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
+
before_save on: :create do
|
28
|
+
self.show_in_sidebar = true if show_in_sidebar.nil?
|
29
|
+
end
|
27
30
|
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
31
|
+
def self.fields
|
32
|
+
@fields ||= { title: { itemprop: 'jobTitle' },
|
33
|
+
location: { itemprop: 'workLocation' },
|
34
|
+
email: { helper: :render_contact_email_address },
|
35
|
+
telephone: {} }
|
36
|
+
end
|
37
|
+
|
38
|
+
protected
|
34
39
|
|
35
|
-
|
36
|
-
|
37
|
-
|
40
|
+
def should_generate_new_friendly_id?
|
41
|
+
name_changed?
|
42
|
+
end
|
38
43
|
end
|
39
44
|
end
|
@@ -1,4 +1,6 @@
|
|
1
1
|
module Spotlight
|
2
|
+
##
|
3
|
+
# Exhibit feedback contacts
|
2
4
|
class ContactEmail < ActiveRecord::Base
|
3
5
|
extend Devise::Models
|
4
6
|
devise :confirmable
|
@@ -16,14 +18,16 @@ module Spotlight
|
|
16
18
|
confirmation_sent_at > 3.days.ago if confirmation_sent_at?
|
17
19
|
end
|
18
20
|
|
19
|
-
protected
|
21
|
+
protected
|
20
22
|
|
21
23
|
def valid_email
|
22
24
|
begin
|
23
25
|
parsed = Mail::Address.new(email)
|
24
26
|
rescue Mail::Field::ParseError => e
|
27
|
+
Rails.logger.debug "Failed to parse email #{email}: #{e}"
|
25
28
|
end
|
26
|
-
|
29
|
+
|
30
|
+
errors.add :email, 'is not valid' if parsed.nil? || parsed.address != email || parsed.local == email
|
27
31
|
end
|
28
32
|
|
29
33
|
def send_devise_notification(notification, *args)
|
@@ -38,6 +42,5 @@ module Spotlight
|
|
38
42
|
def notification_mailer
|
39
43
|
Spotlight::ConfirmationMailer
|
40
44
|
end
|
41
|
-
|
42
45
|
end
|
43
46
|
end
|
@@ -1,6 +1,8 @@
|
|
1
1
|
require 'mail_form'
|
2
2
|
|
3
3
|
module Spotlight
|
4
|
+
##
|
5
|
+
# Exhibit feedback form
|
4
6
|
class ContactForm < MailForm::Base
|
5
7
|
attribute :current_exhibit
|
6
8
|
attribute :name, validate: false
|
@@ -15,9 +17,8 @@ module Spotlight
|
|
15
17
|
subject: "#{I18n.t(:'blacklight.application_name')} Contact Form",
|
16
18
|
to: current_exhibit.contact_emails.first,
|
17
19
|
from: %("#{name}" <#{email}>),
|
18
|
-
cc: current_exhibit.contact_emails.join(
|
20
|
+
cc: current_exhibit.contact_emails.join(', ')
|
19
21
|
}
|
20
22
|
end
|
21
|
-
|
22
23
|
end
|
23
|
-
end
|
24
|
+
end
|
@@ -1,28 +1,30 @@
|
|
1
1
|
module Spotlight
|
2
|
+
##
|
3
|
+
# Exhibit custom fields
|
2
4
|
class CustomField < ActiveRecord::Base
|
3
5
|
serialize :configuration, Hash
|
4
6
|
belongs_to :exhibit
|
5
|
-
|
7
|
+
|
6
8
|
extend FriendlyId
|
7
|
-
friendly_id :slug_candidates, use: [:slugged
|
8
|
-
|
9
|
-
scope :vocab, -> { where(field_type:
|
9
|
+
friendly_id :slug_candidates, use: [:slugged, :scoped, :finders], scope: :exhibit
|
10
|
+
|
11
|
+
scope :vocab, -> { where(field_type: 'vocab') }
|
10
12
|
|
11
13
|
before_save do
|
12
14
|
self.field ||= field_name
|
13
|
-
self.field_type ||=
|
15
|
+
self.field_type ||= 'text'
|
14
16
|
end
|
15
17
|
|
16
18
|
before_save do
|
17
|
-
if persisted?
|
19
|
+
if persisted? && field_type_changed?
|
18
20
|
old_field = self.field
|
19
21
|
self.field = field_name
|
20
22
|
|
21
|
-
if
|
22
|
-
|
23
|
-
f =
|
24
|
-
|
25
|
-
|
23
|
+
if blacklight_configuration && blacklight_configuration.index_fields.key?(old_field)
|
24
|
+
blacklight_configuration.index_fields_will_change!
|
25
|
+
f = blacklight_configuration.index_fields.delete(old_field)
|
26
|
+
blacklight_configuration.index_fields[field] = f
|
27
|
+
blacklight_configuration.save
|
26
28
|
end
|
27
29
|
|
28
30
|
Spotlight::RenameSidecarFieldJob.perform_later(exhibit, old_field, self.field)
|
@@ -30,45 +32,51 @@ module Spotlight
|
|
30
32
|
end
|
31
33
|
|
32
34
|
def label=(label)
|
33
|
-
configuration[
|
34
|
-
|
35
|
-
|
36
|
-
if conf.index_fields.has_key? field
|
37
|
-
conf.index_fields[field]['label'] = label
|
38
|
-
conf.save!
|
39
|
-
end
|
40
|
-
end
|
35
|
+
configuration['label'] = label
|
36
|
+
|
37
|
+
update_blacklight_configuration_label label
|
41
38
|
end
|
42
39
|
|
43
40
|
def label
|
44
|
-
conf = if field &&
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
41
|
+
conf = if field && blacklight_configuration && blacklight_configuration.index_fields.key?(field)
|
42
|
+
blacklight_configuration.index_fields[field].reverse_merge(configuration)
|
43
|
+
else
|
44
|
+
configuration
|
45
|
+
end
|
50
46
|
conf['label']
|
51
47
|
end
|
52
48
|
|
53
49
|
def short_description=(short_description)
|
54
|
-
configuration[
|
50
|
+
configuration['short_description'] = short_description
|
55
51
|
end
|
56
52
|
|
57
53
|
def short_description
|
58
|
-
configuration[
|
54
|
+
configuration['short_description']
|
59
55
|
end
|
60
56
|
|
61
57
|
def configured_to_display?
|
62
|
-
|
58
|
+
index_fields_config &&
|
59
|
+
index_fields_config['enabled'] &&
|
63
60
|
view_types.any? do |view|
|
64
61
|
index_fields_config[view.to_s]
|
65
62
|
end
|
66
|
-
end
|
67
63
|
end
|
68
64
|
|
69
65
|
protected
|
66
|
+
|
67
|
+
def blacklight_configuration
|
68
|
+
exhibit.blacklight_configuration if exhibit
|
69
|
+
end
|
70
|
+
|
71
|
+
def update_blacklight_configuration_label(label)
|
72
|
+
return unless field && blacklight_configuration && blacklight_configuration.index_fields.key?(field)
|
73
|
+
|
74
|
+
blacklight_configuration.index_fields[field]['label'] = label
|
75
|
+
blacklight_configuration.save
|
76
|
+
end
|
77
|
+
|
70
78
|
def field_name
|
71
|
-
"#{Spotlight::Engine.config.solr_fields.prefix}exhibit_#{
|
79
|
+
"#{Spotlight::Engine.config.solr_fields.prefix}exhibit_#{exhibit.to_param}_#{configuration['label'].parameterize}#{field_suffix}"
|
72
80
|
end
|
73
81
|
|
74
82
|
def field_suffix
|
@@ -76,7 +84,7 @@ module Spotlight
|
|
76
84
|
when 'vocab'
|
77
85
|
Spotlight::Engine.config.solr_fields.string_suffix
|
78
86
|
else
|
79
|
-
Spotlight::Engine.config.solr_fields.text_suffix
|
87
|
+
Spotlight::Engine.config.solr_fields.text_suffix
|
80
88
|
end
|
81
89
|
end
|
82
90
|
|
@@ -90,7 +98,8 @@ module Spotlight
|
|
90
98
|
|
91
99
|
def should_generate_new_friendly_id?
|
92
100
|
true
|
93
|
-
end
|
101
|
+
end
|
102
|
+
|
94
103
|
# Try building a slug based on the following fields in
|
95
104
|
# increasing order of specificity.
|
96
105
|
def slug_candidates
|
@@ -99,6 +108,5 @@ module Spotlight
|
|
99
108
|
:field
|
100
109
|
]
|
101
110
|
end
|
102
|
-
|
103
111
|
end
|
104
112
|
end
|
@@ -1,153 +1,127 @@
|
|
1
1
|
require 'mail'
|
2
|
-
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
after_destroy do
|
55
|
-
# Touch the default exhibit to ensure caching knows that
|
56
|
-
# the exhibits have changed.
|
57
|
-
Spotlight::Exhibit.default.touch
|
58
|
-
end
|
59
|
-
|
60
|
-
validates :title, presence: true
|
61
|
-
acts_as_tagger
|
62
|
-
has_many :owned_taggings, class_name: "ActsAsTaggableOn::Tagging", as: :tagger
|
63
|
-
accepts_nested_attributes_for :owned_taggings
|
64
|
-
|
65
|
-
def main_about_page
|
66
|
-
@main_about_page ||= about_pages.published.first
|
67
|
-
end
|
68
|
-
|
69
|
-
# Find or create the default exhibit
|
70
|
-
def self.default
|
71
|
-
self.find_or_create_by!(default: true) do |e|
|
72
|
-
e.title = 'Default exhibit'.freeze
|
2
|
+
module Spotlight
|
3
|
+
##
|
4
|
+
# Spotlight exhibit
|
5
|
+
class Exhibit < ActiveRecord::Base
|
6
|
+
include Spotlight::ExhibitAnalytics
|
7
|
+
|
8
|
+
extend FriendlyId
|
9
|
+
friendly_id :title, use: [:slugged, :finders]
|
10
|
+
validates :title, presence: true
|
11
|
+
|
12
|
+
acts_as_tagger
|
13
|
+
delegate :blacklight_config, to: :blacklight_configuration
|
14
|
+
serialize :facets, Array
|
15
|
+
|
16
|
+
# Note: friendly id associations need to be 'destroy'ed to reap the slug history
|
17
|
+
has_many :about_pages, extend: FriendlyId::FinderMethods
|
18
|
+
has_many :attachments, dependent: :destroy
|
19
|
+
has_many :contact_emails, dependent: :delete_all # These are the contacts who get "Contact us" emails
|
20
|
+
has_many :contacts, dependent: :delete_all # These are the contacts who appear in the sidebar
|
21
|
+
has_many :custom_fields, dependent: :delete_all
|
22
|
+
has_many :feature_pages, extend: FriendlyId::FinderMethods
|
23
|
+
has_many :main_navigations, dependent: :delete_all
|
24
|
+
has_many :owned_taggings, class_name: 'ActsAsTaggableOn::Tagging', as: :tagger
|
25
|
+
has_many :resources
|
26
|
+
has_many :roles, dependent: :delete_all
|
27
|
+
has_many :searches, dependent: :destroy, extend: FriendlyId::FinderMethods
|
28
|
+
has_many :solr_document_sidecars, dependent: :delete_all
|
29
|
+
has_many :users, through: :roles, class_name: '::User'
|
30
|
+
has_many :pages, dependent: :destroy
|
31
|
+
|
32
|
+
has_one :blacklight_configuration, class_name: 'Spotlight::BlacklightConfiguration', dependent: :delete
|
33
|
+
has_one :home_page
|
34
|
+
|
35
|
+
belongs_to :masthead, dependent: :destroy
|
36
|
+
belongs_to :thumbnail, class_name: 'Spotlight::FeaturedImage', dependent: :destroy
|
37
|
+
|
38
|
+
accepts_nested_attributes_for :about_pages, :attachments, :contacts, :custom_fields, :feature_pages,
|
39
|
+
:main_navigations, :owned_taggings, :resources, :searches, :solr_document_sidecars
|
40
|
+
accepts_nested_attributes_for :blacklight_configuration, :home_page, :masthead, :thumbnail, update_only: true
|
41
|
+
accepts_nested_attributes_for :contact_emails, reject_if: proc { |attr| attr['email'].blank? }
|
42
|
+
accepts_nested_attributes_for :roles, allow_destroy: true, reject_if: proc { |attr| attr['user_key'].blank? }
|
43
|
+
|
44
|
+
before_save :sanitize_description, if: :description_changed?
|
45
|
+
before_create :build_home_page
|
46
|
+
after_create :initialize_config
|
47
|
+
after_create :initialize_browse
|
48
|
+
after_create :initialize_main_navigation
|
49
|
+
|
50
|
+
after_destroy do
|
51
|
+
# Touch the default exhibit to ensure caching knows that
|
52
|
+
# the exhibits have changed.
|
53
|
+
Spotlight::Exhibit.default.touch
|
73
54
|
end
|
74
|
-
end
|
75
55
|
|
76
|
-
|
77
|
-
|
78
|
-
|
56
|
+
# Find or create the default exhibit
|
57
|
+
def self.default
|
58
|
+
self.find_or_create_by!(default: true) do |e|
|
59
|
+
e.title = 'Default exhibit'.freeze
|
60
|
+
end
|
61
|
+
end
|
79
62
|
|
80
|
-
|
81
|
-
|
82
|
-
|
63
|
+
def self.default?
|
64
|
+
where(default: true).any?
|
65
|
+
end
|
83
66
|
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
end
|
67
|
+
def main_about_page
|
68
|
+
@main_about_page ||= about_pages.published.first
|
69
|
+
end
|
88
70
|
|
89
|
-
|
90
|
-
|
91
|
-
|
71
|
+
def browse_categories?
|
72
|
+
searches.published.any?
|
73
|
+
end
|
92
74
|
|
93
|
-
|
94
|
-
|
95
|
-
|
75
|
+
def to_s
|
76
|
+
title
|
77
|
+
end
|
96
78
|
|
97
|
-
|
98
|
-
|
99
|
-
|
100
|
-
@analytics[start_date] ||= begin
|
101
|
-
analytics_provider.exhibit_data(path || self, start_date: start_date.ago)
|
79
|
+
def import(hash)
|
80
|
+
Spotlight::ExhibitExportSerializer.prepare(self).from_hash(hash)
|
81
|
+
self
|
102
82
|
end
|
103
|
-
|
104
|
-
|
105
|
-
|
106
|
-
return [] unless analytics_provider and analytics_provider.enabled?
|
107
|
-
|
108
|
-
@page_analytics ||= {}
|
109
|
-
@page_analytics[start_date] ||= begin
|
110
|
-
analytics_provider.page_data(path || self, start_date: start_date.ago)
|
83
|
+
|
84
|
+
def solr_data
|
85
|
+
{ :"#{Spotlight::Engine.config.solr_fields.prefix}spotlight_exhibit_slug_#{slug}#{Spotlight::Engine.config.solr_fields.boolean_suffix}" => true }
|
111
86
|
end
|
112
|
-
end
|
113
87
|
|
114
|
-
|
115
|
-
|
116
|
-
|
88
|
+
def reindex_later
|
89
|
+
Spotlight::ReindexJob.perform_later(self)
|
90
|
+
end
|
117
91
|
|
118
|
-
|
119
|
-
|
120
|
-
|
92
|
+
def uploaded_resource_fields
|
93
|
+
Spotlight::Engine.config.upload_fields
|
94
|
+
end
|
121
95
|
|
122
|
-
|
96
|
+
def searchable?
|
97
|
+
blacklight_config.search_fields.any? { |_k, v| v.enabled && v.include_in_simple_select != false }
|
98
|
+
end
|
123
99
|
|
124
|
-
|
125
|
-
self.blacklight_configuration ||= Spotlight::BlacklightConfiguration.create!
|
126
|
-
end
|
100
|
+
protected
|
127
101
|
|
128
|
-
|
129
|
-
|
102
|
+
def initialize_config
|
103
|
+
self.blacklight_configuration ||= Spotlight::BlacklightConfiguration.create!
|
104
|
+
end
|
130
105
|
|
131
|
-
|
132
|
-
|
133
|
-
end
|
106
|
+
def initialize_browse
|
107
|
+
return unless searches.blank?
|
134
108
|
|
135
|
-
|
136
|
-
|
137
|
-
self.main_navigations.create nav_type: nav_type, weight: weight
|
109
|
+
searches.create title: 'All Exhibit Items',
|
110
|
+
long_description: 'All items in this exhibit.'
|
138
111
|
end
|
139
|
-
end
|
140
112
|
|
141
|
-
|
142
|
-
|
143
|
-
|
113
|
+
def initialize_main_navigation
|
114
|
+
default_main_navigations.each_with_index do |nav_type, weight|
|
115
|
+
main_navigations.create nav_type: nav_type, weight: weight
|
116
|
+
end
|
117
|
+
end
|
144
118
|
|
145
|
-
|
146
|
-
|
147
|
-
|
119
|
+
def sanitize_description
|
120
|
+
self.description = ::Rails::Html::FullSanitizer.new.sanitize(description)
|
121
|
+
end
|
148
122
|
|
149
|
-
|
150
|
-
|
123
|
+
def default_main_navigations
|
124
|
+
Spotlight::Engine.config.exhibit_main_navigation.dup
|
125
|
+
end
|
151
126
|
end
|
152
|
-
|
153
127
|
end
|