blacklight 6.19.1 → 7.1.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.gitignore +1 -0
- data/.npmignore +23 -0
- data/.rubocop.yml +40 -16
- data/.rubocop_todo.yml +478 -382
- data/.solr_wrapper.yml +9 -2
- data/.travis.yml +23 -25
- data/CONTRIBUTING.md +48 -0
- data/Gemfile +3 -2
- data/README.md +22 -5
- data/Rakefile +3 -2
- data/VERSION +1 -1
- data/Vagrantfile +2 -0
- data/app/assets/images/blacklight/list.svg +1 -0
- data/app/assets/images/blacklight/search.svg +1 -0
- data/app/assets/javascripts/blacklight/blacklight.js +483 -57
- data/app/assets/stylesheets/blacklight/_balanced_list.scss +7 -12
- data/app/assets/stylesheets/blacklight/_blacklight_base.scss +18 -15
- data/app/assets/stylesheets/blacklight/_bookmark.scss +1 -13
- data/app/assets/stylesheets/blacklight/_bootstrap_overrides.scss +27 -0
- data/app/assets/stylesheets/blacklight/_constraints.scss +17 -25
- data/app/assets/stylesheets/blacklight/_controls.scss +8 -16
- data/app/assets/stylesheets/blacklight/_facets.scss +64 -93
- data/app/assets/stylesheets/blacklight/_header.scss +35 -48
- data/app/assets/stylesheets/blacklight/_icons.scss +35 -0
- data/app/assets/stylesheets/blacklight/_layout.scss +0 -10
- data/app/assets/stylesheets/blacklight/_mixins.scss +15 -0
- data/app/assets/stylesheets/blacklight/_modal.scss +9 -17
- data/app/assets/stylesheets/blacklight/_pagination.scss +4 -13
- data/app/assets/stylesheets/blacklight/_search_form.scss +7 -0
- data/app/assets/stylesheets/blacklight/_search_history.scss +5 -13
- data/app/assets/stylesheets/blacklight/_search_results.scss +9 -8
- data/app/assets/stylesheets/blacklight/_twitter_typeahead.scss +1 -2
- data/app/assets/stylesheets/blacklight/blacklight.scss +1 -1
- data/app/builders/blacklight/action_builder.rb +57 -0
- data/app/controllers/bookmarks_controller.rb +2 -2
- data/app/controllers/catalog_controller.rb +2 -2
- data/app/controllers/concerns/blacklight/base.rb +0 -33
- data/app/controllers/concerns/blacklight/bookmarks.rb +20 -30
- data/app/controllers/concerns/blacklight/catalog.rb +256 -210
- data/app/controllers/concerns/blacklight/controller.rb +102 -124
- data/app/controllers/concerns/blacklight/default_component_configuration.rb +12 -43
- data/app/controllers/concerns/blacklight/facet.rb +10 -2
- data/app/controllers/concerns/blacklight/search_context.rb +11 -11
- data/app/controllers/concerns/blacklight/search_fields.rb +4 -14
- data/app/controllers/concerns/blacklight/search_history.rb +1 -6
- data/app/controllers/concerns/blacklight/searchable.rb +17 -0
- data/app/controllers/concerns/blacklight/token_based_user.rb +5 -7
- data/app/helpers/blacklight/blacklight_helper_behavior.rb +36 -118
- data/app/helpers/blacklight/catalog_helper_behavior.rb +100 -89
- data/app/helpers/blacklight/component_helper_behavior.rb +21 -21
- data/app/helpers/blacklight/configuration_helper_behavior.rb +30 -58
- data/app/helpers/blacklight/facets_helper_behavior.rb +56 -52
- data/app/helpers/blacklight/hash_as_hidden_fields_helper_behavior.rb +9 -11
- data/app/helpers/blacklight/icon_helper_behavior.rb +18 -0
- data/app/helpers/blacklight/layout_helper_behavior.rb +3 -3
- data/app/helpers/blacklight/render_constraints_helper_behavior.rb +8 -6
- data/app/helpers/blacklight/render_partials_helper_behavior.rb +207 -0
- data/app/helpers/blacklight/search_history_constraints_helper_behavior.rb +19 -11
- data/app/helpers/blacklight/suggest_helper_behavior.rb +1 -0
- data/app/helpers/blacklight/url_helper_behavior.rb +50 -41
- data/app/{assets/javascripts → javascript}/blacklight/autocomplete.js +3 -2
- data/app/javascript/blacklight/bookmark_toggle.js +25 -0
- data/app/javascript/blacklight/checkbox_submit.js +134 -0
- data/app/{assets/javascripts → javascript}/blacklight/collapsable.js +1 -1
- data/app/javascript/blacklight/core.js +41 -0
- data/app/{assets/javascripts → javascript}/blacklight/facet_load.js +6 -6
- data/app/{assets/javascripts/blacklight/ajax_modal.js → javascript/blacklight/modal.js} +62 -64
- data/app/{assets/javascripts → javascript}/blacklight/search_context.js +10 -3
- data/app/models/blacklight/facet_paginator.rb +3 -3
- data/app/models/blacklight/icon.rb +58 -0
- data/app/models/blacklight/solr/facet_paginator.rb +3 -3
- data/app/models/blacklight/suggest_search.rb +1 -1
- data/app/models/bookmark.rb +5 -10
- data/app/models/concerns/blacklight/configurable.rb +13 -13
- data/app/models/concerns/blacklight/document.rb +23 -39
- data/app/models/concerns/blacklight/document/active_model_shim.rb +8 -11
- data/app/models/concerns/blacklight/document/cache_key.rb +1 -1
- data/app/models/concerns/blacklight/document/dublin_core.rb +2 -2
- data/app/models/concerns/blacklight/document/email.rb +5 -5
- data/app/models/concerns/blacklight/document/extensions.rb +5 -5
- data/app/models/concerns/blacklight/document/semantic_fields.rb +9 -9
- data/app/models/concerns/blacklight/document/sms.rb +3 -3
- data/app/models/concerns/blacklight/solr/document.rb +8 -8
- data/app/models/concerns/blacklight/user.rb +7 -6
- data/app/models/record_mailer.rb +8 -6
- data/app/models/search.rb +5 -7
- data/app/presenters/blacklight/document_presenter.rb +25 -140
- data/app/presenters/blacklight/field_presenter.rb +7 -5
- data/app/presenters/blacklight/index_presenter.rb +41 -70
- data/app/presenters/blacklight/json_presenter.rb +10 -14
- data/app/presenters/blacklight/link_alternate_presenter.rb +3 -1
- data/app/presenters/blacklight/rendering/abstract_step.rb +7 -5
- data/app/presenters/blacklight/rendering/helper_method.rb +10 -8
- data/app/presenters/blacklight/rendering/join.rb +5 -3
- data/app/presenters/blacklight/rendering/link_to_facet.rb +23 -19
- data/app/presenters/blacklight/rendering/microdata.rb +6 -3
- data/app/presenters/blacklight/rendering/pipeline.rb +7 -5
- data/app/presenters/blacklight/rendering/terminator.rb +2 -0
- data/app/presenters/blacklight/search_bar_presenter.rb +39 -0
- data/app/presenters/blacklight/show_presenter.rb +26 -72
- data/app/presenters/blacklight/thumbnail_presenter.rb +74 -0
- data/app/services/blacklight/document_factory.rb +13 -0
- data/app/services/blacklight/field_retriever.rb +26 -24
- data/app/services/blacklight/search_service.rb +153 -0
- data/app/values/blacklight/types.rb +31 -0
- data/app/views/blacklight/nav/_bookmark.html.erb +2 -2
- data/app/views/blacklight/nav/_search_history.html.erb +1 -1
- data/app/views/bookmarks/_tools.html.erb +2 -2
- data/app/views/bookmarks/index.html.erb +12 -13
- data/app/views/catalog/_bookmark_control.html.erb +26 -10
- data/app/views/catalog/_citation.html.erb +23 -18
- data/app/views/catalog/_constraints.html.erb +6 -7
- data/app/views/catalog/_constraints_element.html.erb +6 -6
- data/app/views/catalog/_did_you_mean.html.erb +1 -1
- data/app/views/catalog/{_document_default.atom.builder → _document.atom.builder} +19 -18
- data/app/views/catalog/_document.html.erb +5 -3
- data/app/views/catalog/{_document_default.rss.builder → _document.rss.builder} +2 -0
- data/app/views/catalog/_document_action.html.erb +2 -1
- data/app/views/catalog/_email_form.html.erb +8 -4
- data/app/views/catalog/_facet_group.html.erb +19 -0
- data/app/views/catalog/_facet_index_navigation.html.erb +5 -4
- data/app/views/catalog/_facet_layout.html.erb +6 -8
- data/app/views/catalog/_facet_limit.html.erb +3 -2
- data/app/views/catalog/_facet_pagination.html.erb +8 -8
- data/app/views/catalog/_facet_pivot.html.erb +2 -2
- data/app/views/catalog/_facets.html.erb +3 -21
- data/app/views/catalog/_field.json.jbuilder +10 -0
- data/app/views/catalog/{_group_default.html.erb → _group.html.erb} +1 -1
- data/app/views/catalog/_home_text.html.erb +32 -36
- data/app/views/catalog/_index.html.erb +10 -0
- data/app/views/catalog/{_index_header_default.html.erb → _index_header.html.erb} +3 -3
- data/app/views/catalog/_per_page_widget.html.erb +6 -7
- data/app/views/catalog/_previous_next_doc.html.erb +6 -14
- data/app/views/catalog/_results_pagination.html.erb +2 -2
- data/app/views/catalog/_search_form.html.erb +12 -8
- data/app/views/catalog/_search_header.html.erb +0 -3
- data/app/views/catalog/_search_results.html.erb +6 -2
- data/app/views/catalog/_show.html.erb +8 -0
- data/app/views/catalog/{_show_header_default.html.erb → _show_header.html.erb} +0 -0
- data/app/views/catalog/_show_main_content.html.erb +4 -4
- data/app/views/catalog/_show_more_like_this.html.erb +1 -1
- data/app/views/catalog/_show_sidebar.html.erb +10 -8
- data/app/views/catalog/_show_tools.html.erb +10 -21
- data/app/views/catalog/_sms_form.html.erb +8 -4
- data/app/views/catalog/_sort_and_per_page.html.erb +3 -3
- data/app/views/catalog/_sort_widget.html.erb +7 -7
- data/app/views/catalog/_thumbnail.html.erb +5 -0
- data/app/views/catalog/_view_type_group.html.erb +2 -2
- data/app/views/catalog/_zero_results.html.erb +1 -1
- data/app/views/catalog/citation.html.erb +1 -1
- data/app/views/catalog/citation.js.erb +1 -7
- data/app/views/catalog/email.html.erb +5 -3
- data/app/views/catalog/email_success.html.erb +12 -8
- data/app/views/catalog/facet.html.erb +10 -8
- data/app/views/catalog/facet.json.jbuilder +2 -0
- data/app/views/catalog/index.atom.builder +27 -29
- data/app/views/catalog/index.html.erb +9 -11
- data/app/views/catalog/index.json.jbuilder +84 -3
- data/app/views/catalog/index.rss.builder +8 -6
- data/app/views/catalog/opensearch.xml.builder +12 -10
- data/app/views/catalog/show.html.erb +11 -6
- data/app/views/catalog/show.json.jbuilder +21 -0
- data/app/views/catalog/sms.html.erb +3 -1
- data/app/views/catalog/sms_success.html.erb +12 -8
- data/app/views/kaminari/blacklight/_first_page.html.erb +2 -2
- data/app/views/kaminari/blacklight/_gap.html.erb +2 -2
- data/app/views/kaminari/blacklight/_last_page.html.erb +2 -2
- data/app/views/kaminari/blacklight/_next_page.html.erb +5 -5
- data/app/views/kaminari/blacklight/_page.html.erb +5 -3
- data/app/views/kaminari/blacklight/_prev_page.html.erb +4 -4
- data/app/views/kaminari/blacklight_compact/_paginator.html.erb +4 -4
- data/app/views/layouts/blacklight.html.erb +14 -41
- data/app/views/layouts/blacklight/base.html.erb +35 -0
- data/app/views/layouts/catalog_result.html.erb +11 -0
- data/app/views/record_mailer/email_record.text.erb +6 -5
- data/app/views/search_history/index.html.erb +16 -21
- data/app/views/{_flash_msg.html.erb → shared/_flash_msg.html.erb} +5 -3
- data/app/views/shared/_header_navbar.html.erb +8 -13
- data/app/views/shared/_modal.html.erb +6 -0
- data/app/views/shared/_user_util_links.html.erb +22 -0
- data/blacklight.gemspec +8 -11
- data/config/i18n-tasks.yml +17 -0
- data/config/locales/blacklight.de.yml +71 -82
- data/config/locales/blacklight.en.yml +15 -27
- data/config/locales/blacklight.es.yml +14 -26
- data/config/locales/blacklight.fr.yml +16 -33
- data/config/locales/blacklight.hu.yml +212 -0
- data/config/locales/blacklight.it.yml +15 -26
- data/config/locales/blacklight.nl.yml +212 -0
- data/config/locales/blacklight.pt-BR.yml +24 -29
- data/config/locales/blacklight.sq.yml +4 -28
- data/config/locales/blacklight.zh.yml +3 -25
- data/config/routes.rb +2 -10
- data/db/migrate/20140202020202_create_bookmarks.rb +0 -1
- data/db/migrate/20140320000000_add_polymorphic_type_to_bookmarks.rb +1 -1
- data/lib/blacklight.rb +6 -4
- data/lib/blacklight/abstract_repository.rb +9 -9
- data/lib/blacklight/configuration.rb +100 -88
- data/lib/blacklight/configuration/context.rb +12 -1
- data/lib/blacklight/configuration/facet_field.rb +16 -9
- data/lib/blacklight/configuration/field.rb +32 -3
- data/lib/blacklight/configuration/fields.rb +15 -17
- data/lib/blacklight/configuration/null_field.rb +2 -0
- data/lib/blacklight/configuration/search_field.rb +2 -2
- data/lib/blacklight/configuration/sort_field.rb +2 -2
- data/lib/blacklight/configuration/view_config.rb +4 -0
- data/lib/blacklight/engine.rb +10 -7
- data/lib/blacklight/exceptions.rb +4 -7
- data/lib/blacklight/{utils.rb → nested_open_struct_with_hash_access.rb} +9 -81
- data/lib/blacklight/open_struct_with_hash_access.rb +49 -0
- data/lib/blacklight/parameters.rb +1 -1
- data/lib/blacklight/routes/exportable.rb +1 -3
- data/lib/blacklight/routes/searchable.rb +3 -3
- data/lib/blacklight/runtime_registry.rb +2 -0
- data/lib/blacklight/search_builder.rb +28 -35
- data/lib/blacklight/search_state.rb +10 -8
- data/lib/blacklight/solr/repository.rb +4 -3
- data/lib/blacklight/solr/request.rb +1 -1
- data/lib/blacklight/solr/response.rb +29 -30
- data/lib/blacklight/solr/response/facets.rb +29 -31
- data/lib/blacklight/solr/response/group.rb +3 -3
- data/lib/blacklight/solr/response/group_response.rb +1 -1
- data/lib/blacklight/solr/response/more_like_this.rb +2 -2
- data/lib/blacklight/solr/response/response.rb +2 -2
- data/lib/blacklight/solr/response/spelling.rb +4 -3
- data/lib/blacklight/solr/search_builder_behavior.rb +27 -31
- data/lib/blacklight/version.rb +1 -1
- data/lib/generators/blacklight/assets_generator.rb +12 -12
- data/lib/generators/blacklight/controller_generator.rb +4 -5
- data/lib/generators/blacklight/document_generator.rb +1 -1
- data/lib/generators/blacklight/install_generator.rb +15 -34
- data/lib/generators/blacklight/search_builder_generator.rb +1 -1
- data/lib/generators/blacklight/{solr5_generator.rb → solr_generator.rb} +12 -6
- data/lib/generators/blacklight/templates/.solr_wrapper.yml +5 -0
- data/lib/generators/blacklight/templates/alternate_controller.rb +4 -4
- data/lib/generators/blacklight/templates/blacklight.scss +0 -2
- data/lib/generators/blacklight/templates/catalog_controller.rb +57 -50
- data/lib/generators/blacklight/templates/config/blacklight.yml +1 -13
- data/{solr → lib/generators/blacklight/templates/solr}/conf/_rest_managed.json +0 -0
- data/{solr → lib/generators/blacklight/templates/solr}/conf/admin-extra.html +0 -0
- data/{solr → lib/generators/blacklight/templates/solr}/conf/elevate.xml +0 -0
- data/{solr → lib/generators/blacklight/templates/solr}/conf/mapping-ISOLatin1Accent.txt +0 -0
- data/{solr → lib/generators/blacklight/templates/solr}/conf/protwords.txt +0 -0
- data/lib/generators/blacklight/templates/solr/conf/schema.xml +388 -0
- data/{solr → lib/generators/blacklight/templates/solr}/conf/scripts.conf +0 -0
- data/lib/generators/blacklight/templates/solr/conf/solrconfig.xml +195 -0
- data/{solr → lib/generators/blacklight/templates/solr}/conf/spellings.txt +0 -0
- data/{solr → lib/generators/blacklight/templates/solr}/conf/stopwords.txt +0 -0
- data/{solr → lib/generators/blacklight/templates/solr}/conf/stopwords_en.txt +0 -0
- data/{solr → lib/generators/blacklight/templates/solr}/conf/synonyms.txt +0 -0
- data/{solr → lib/generators/blacklight/templates/solr}/conf/xslt/example.xsl +0 -0
- data/{solr → lib/generators/blacklight/templates/solr}/conf/xslt/example_atom.xsl +0 -0
- data/{solr → lib/generators/blacklight/templates/solr}/conf/xslt/example_rss.xsl +0 -0
- data/{solr → lib/generators/blacklight/templates/solr}/conf/xslt/luke.xsl +0 -0
- data/lib/generators/blacklight/test_support_generator.rb +10 -10
- data/lib/generators/blacklight/user_generator.rb +5 -6
- data/lib/railties/blacklight.rake +7 -6
- data/package-lock.json +2793 -0
- data/package.json +30 -0
- data/spec/controllers/alternate_controller_spec.rb +5 -4
- data/spec/controllers/application_controller_spec.rb +1 -5
- data/spec/controllers/blacklight/base_spec.rb +6 -3
- data/spec/controllers/blacklight/catalog/component_configuration_spec.rb +11 -7
- data/spec/controllers/blacklight/facet_spec.rb +1 -2
- data/spec/controllers/blacklight/search_fields_spec.rb +25 -34
- data/spec/controllers/bookmarks_controller_spec.rb +17 -13
- data/spec/controllers/catalog_controller_spec.rb +332 -164
- data/spec/controllers/search_history_controller_spec.rb +6 -6
- data/spec/features/alternate_controller_spec.rb +4 -4
- data/spec/features/autocomplete_spec.rb +4 -2
- data/spec/features/bookmarks_spec.rb +10 -10
- data/spec/features/did_you_mean_spec.rb +7 -12
- data/spec/features/facets_spec.rb +16 -16
- data/spec/features/record_view_spec.rb +12 -18
- data/spec/features/search_context_spec.rb +6 -7
- data/spec/features/search_crawler_spec.rb +3 -5
- data/spec/features/search_filters_spec.rb +80 -80
- data/spec/features/search_formats_spec.rb +4 -5
- data/spec/features/search_history_spec.rb +6 -29
- data/spec/features/search_pagination_spec.rb +4 -2
- data/spec/features/search_results_spec.rb +14 -12
- data/spec/features/search_sort_spec.rb +2 -2
- data/spec/features/search_spec.rb +8 -9
- data/spec/features/sitelinks_search_box.rb +4 -4
- data/{solr → spec/fixtures}/sample_solr_documents.yml +688 -688
- data/spec/helpers/{configuration_helper_spec.rb → blacklight/configuration_helper_behavior_spec.rb} +97 -98
- data/spec/helpers/{facets_helper_spec.rb → blacklight/facets_helper_behavior_spec.rb} +72 -67
- data/spec/helpers/{hash_as_hidden_fields_spec.rb → blacklight/hash_as_hidden_fields_behavior_spec.rb} +2 -2
- data/spec/helpers/blacklight/icon_helper_behavior_spec.rb +10 -0
- data/spec/helpers/{layout_helper_spec.rb → blacklight/layout_helper_behavior_spec.rb} +5 -5
- data/spec/helpers/{render_constraints_helper_spec.rb → blacklight/render_constraints_helper_behavior_spec.rb} +10 -6
- data/spec/helpers/blacklight/render_partials_helper_behavior_spec.rb +92 -0
- data/spec/helpers/{search_history_constraints_helper_spec.rb → blacklight/search_history_constraints_helper_behavior_spec.rb} +29 -30
- data/spec/helpers/{suggest_helper_spec.rb → blacklight/suggest_helper_behavior_spec.rb} +9 -2
- data/spec/helpers/{url_helper_spec.rb → blacklight/url_helper_behavior_spec.rb} +61 -54
- data/spec/helpers/blacklight_helper_spec.rb +62 -151
- data/spec/helpers/catalog_helper_spec.rb +91 -98
- data/spec/i18n_spec.rb +18 -0
- data/spec/integration/generators/blacklight/{solr5_generator_spec.rb → solr_generator_spec.rb} +21 -13
- data/spec/lib/blacklight/configuration/facet_field_spec.rb +13 -0
- data/spec/lib/blacklight/configuration/field_spec.rb +15 -0
- data/spec/lib/blacklight/nested_open_struct_with_hash_access_spec.rb +17 -0
- data/spec/lib/blacklight/open_struct_with_hash_access_spec.rb +148 -0
- data/spec/lib/blacklight/parameters_spec.rb +4 -2
- data/spec/lib/blacklight/search_state_spec.rb +53 -36
- data/spec/lib/blacklight_spec.rb +14 -15
- data/spec/lib/tasks/blacklight_task_spec.rb +4 -6
- data/spec/models/blacklight/configurable_spec.rb +24 -27
- data/spec/models/blacklight/configuration/context_spec.rb +9 -10
- data/spec/models/blacklight/configuration_spec.rb +188 -165
- data/spec/models/blacklight/document/active_model_shim_spec.rb +15 -6
- data/spec/models/blacklight/document/cache_key_spec.rb +10 -3
- data/spec/models/blacklight/document/dublin_core_spec.rb +17 -20
- data/spec/models/blacklight/document/email_spec.rb +10 -10
- data/spec/models/blacklight/document/sms_spec.rb +10 -10
- data/spec/models/blacklight/document_spec.rb +10 -22
- data/spec/models/blacklight/facet_paginator_spec.rb +40 -30
- data/spec/models/blacklight/icon_spec.rb +58 -0
- data/spec/models/blacklight/search_builder_spec.rb +41 -26
- data/spec/models/blacklight/solr/document_spec.rb +224 -216
- data/spec/models/blacklight/solr/facet_paginator_spec.rb +6 -4
- data/spec/models/blacklight/solr/repository_spec.rb +50 -42
- data/spec/models/blacklight/solr/request_spec.rb +17 -18
- data/spec/models/blacklight/solr/response/facets_spec.rb +60 -60
- data/spec/models/blacklight/solr/response/group_response_spec.rb +16 -22
- data/spec/models/blacklight/solr/response/group_spec.rb +18 -25
- data/spec/models/blacklight/solr/response_spec.rb +69 -68
- data/spec/models/blacklight/solr/search_builder_spec.rb +150 -164
- data/spec/models/blacklight/suggest/response_spec.rb +2 -1
- data/spec/models/blacklight/suggest_search_spec.rb +4 -4
- data/spec/models/blacklight/user_spec.rb +9 -11
- data/spec/models/bookmark_spec.rb +7 -6
- data/spec/models/record_mailer_spec.rb +23 -21
- data/spec/models/search_spec.rb +19 -18
- data/spec/models/solr_document_spec.rb +33 -5
- data/spec/presenters/blacklight/document_presenter_spec.rb +86 -0
- data/spec/presenters/{index_presenter_spec.rb → blacklight/index_presenter_spec.rb} +25 -62
- data/spec/presenters/blacklight/json_presenter_spec.rb +59 -0
- data/spec/presenters/blacklight/link_alternate_presenter_spec.rb +3 -0
- data/spec/presenters/blacklight/search_bar_presenter_spec.rb +79 -0
- data/spec/presenters/{show_presenter_spec.rb → blacklight/show_presenter_spec.rb} +47 -62
- data/spec/presenters/pipeline_spec.rb +18 -11
- data/spec/presenters/thumbnail_presenter_spec.rb +174 -0
- data/spec/routing/catalog_routing_spec.rb +13 -15
- data/spec/services/blacklight/search_service_spec.rb +495 -0
- data/spec/spec_helper.rb +12 -24
- data/spec/support/features.rb +1 -1
- data/spec/support/features/session_helpers.rb +4 -4
- data/spec/test_app_templates/Gemfile.extra +2 -5
- data/spec/test_app_templates/lib/generators/test_app_generator.rb +12 -13
- data/spec/views/catalog/_constraints.html.erb_spec.rb +3 -6
- data/spec/views/catalog/_constraints_element.html.erb_spec.rb +17 -13
- data/spec/views/catalog/_document.html.erb_spec.rb +11 -11
- data/spec/views/catalog/_document_list.html.erb_spec.rb +2 -1
- data/spec/views/catalog/_facet_index_navigation.html.erb_spec.rb +5 -5
- data/spec/views/catalog/_facet_layout.html.erb_spec.rb +6 -6
- data/spec/views/catalog/_facets.html.erb_spec.rb +37 -16
- data/spec/views/catalog/{_index_default.erb_spec.rb → _index.html.erb_spec.rb} +14 -15
- data/spec/views/catalog/{_index_header_default.html.erb_spec.rb → _index_header.html.erb_spec.rb} +6 -9
- data/spec/views/catalog/_paginate_compact.html.erb_spec.rb +7 -30
- data/spec/views/catalog/_search_header.erb_spec.rb +1 -3
- data/spec/views/catalog/{_show_default.erb_spec.rb → _show.html.erb_spec.rb} +13 -14
- data/spec/views/catalog/_show_sidebar.erb_spec.rb +7 -10
- data/spec/views/catalog/_show_tools.html.erb_spec.rb +5 -5
- data/spec/views/catalog/_sort_and_per_page.html.erb_spec.rb +1 -2
- data/spec/views/catalog/_sort_widget.html.erb_spec.rb +3 -1
- data/spec/views/catalog/{_thumbnail_default.erb_spec.rb → _thumbnail.html.erb_spec.rb} +7 -9
- data/spec/views/catalog/_view_type_group.html.erb_spec.rb +12 -10
- data/spec/views/catalog/email_success.html.erb_spec.rb +8 -0
- data/spec/views/catalog/facet.html.erb_spec.rb +4 -3
- data/spec/views/catalog/facet.json.jbuilder_spec.rb +3 -2
- data/spec/views/catalog/index.atom.builder_spec.rb +11 -6
- data/spec/views/catalog/index.html.erb_spec.rb +6 -8
- data/spec/views/catalog/index.json.jbuilder_spec.rb +119 -26
- data/spec/views/catalog/opensearch.xml.builder_spec.rb +1 -1
- data/spec/views/catalog/show.html.erb_spec.rb +8 -8
- data/spec/views/catalog/show.json.jbuilder_spec.rb +40 -0
- data/spec/views/catalog/sms_success.html.erb_spec.rb +8 -0
- data/spec/views/{_user_util_links.html.erb_spec.rb → shared/_user_util_links.html.erb_spec.rb} +4 -7
- data/tasks/blacklight.rake +6 -6
- data/template.demo.rb +4 -12
- metadata +174 -207
- data/app/assets/javascripts/blacklight/autofocus.js +0 -16
- data/app/assets/javascripts/blacklight/bookmark_toggle.js +0 -23
- data/app/assets/javascripts/blacklight/checkbox_submit.js +0 -139
- data/app/assets/javascripts/blacklight/core.js +0 -30
- data/app/controllers/concerns/blacklight/request_builders.rb +0 -77
- data/app/controllers/concerns/blacklight/saved_searches.rb +0 -70
- data/app/controllers/concerns/blacklight/search_helper.rb +0 -161
- data/app/controllers/concerns/blacklight/suggest.rb +0 -25
- data/app/controllers/saved_searches_controller.rb +0 -4
- data/app/controllers/suggest_controller.rb +0 -4
- data/app/helpers/blacklight/deprecated_url_helper_behavior.rb +0 -57
- data/app/helpers/blacklight/render_partials_helper.rb +0 -205
- data/app/helpers/blacklight_configuration_helper.rb +0 -4
- data/app/helpers/blacklight_url_helper.rb +0 -4
- data/app/helpers/component_helper.rb +0 -4
- data/app/helpers/facets_helper.rb +0 -4
- data/app/helpers/hash_as_hidden_fields_helper.rb +0 -4
- data/app/helpers/layout_helper.rb +0 -4
- data/app/helpers/render_constraints_helper.rb +0 -4
- data/app/helpers/search_history_constraints_helper.rb +0 -4
- data/app/helpers/suggest_helper.rb +0 -4
- data/app/models/concerns/blacklight/solr/document/more_like_this.rb +0 -6
- data/app/views/_user_util_links.html.erb +0 -26
- data/app/views/blacklight/nav/_saved_searches.html.erb +0 -1
- data/app/views/catalog/_index_default.html.erb +0 -12
- data/app/views/catalog/_show_default.html.erb +0 -10
- data/app/views/catalog/_thumbnail_default.html.erb +0 -5
- data/app/views/saved_searches/index.html.erb +0 -32
- data/app/views/shared/_ajax_modal.html.erb +0 -6
- data/lib/generators/blacklight/solr4_generator.rb +0 -31
- data/lib/generators/blacklight/templates/config/jetty.yml +0 -13
- data/solr/conf/schema.xml +0 -629
- data/solr/conf/solrconfig.xml +0 -411
- data/spec/controllers/blacklight/search_helper_spec.rb +0 -489
- data/spec/controllers/saved_searches_controller_spec.rb +0 -32
- data/spec/controllers/suggest_controller_spec.rb +0 -17
- data/spec/features/saved_searches_spec.rb +0 -47
- data/spec/helpers/deprecated_url_helper_behavior_spec.rb +0 -101
- data/spec/lib/blacklight/utils_spec.rb +0 -167
- data/spec/models/blacklight/solr/document/more_like_this_spec.rb +0 -18
- data/spec/presenters/document_presenter_spec.rb +0 -438
- data/spec/support/backport_test.rb +0 -14
@@ -3,270 +3,316 @@ module Blacklight::Catalog
|
|
3
3
|
extend ActiveSupport::Concern
|
4
4
|
|
5
5
|
include Blacklight::Base
|
6
|
-
include Blacklight::DefaultComponentConfiguration
|
7
6
|
include Blacklight::Facet
|
7
|
+
include Blacklight::Searchable
|
8
8
|
|
9
9
|
# The following code is executed when someone includes blacklight::catalog in their
|
10
10
|
# own controller.
|
11
11
|
included do
|
12
12
|
if respond_to? :helper_method
|
13
|
-
helper_method :sms_mappings, :has_search_parameters
|
13
|
+
helper_method :sms_mappings, :has_search_parameters?, :facet_limit_for
|
14
14
|
end
|
15
15
|
|
16
16
|
helper Blacklight::Facet if respond_to? :helper
|
17
17
|
|
18
|
-
#
|
19
|
-
# the
|
20
|
-
rescue_from Blacklight::Exceptions::
|
18
|
+
# The index action will more than likely throw this one.
|
19
|
+
# Example: when the standard query parser is used, and a user submits a "bad" query.
|
20
|
+
rescue_from Blacklight::Exceptions::InvalidRequest, with: :handle_request_error
|
21
21
|
|
22
22
|
record_search_parameters
|
23
23
|
end
|
24
24
|
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
respond_to do |format|
|
30
|
-
format.html { store_preferred_view }
|
31
|
-
format.rss { render :layout => false }
|
32
|
-
format.atom { render :layout => false }
|
33
|
-
format.json do
|
34
|
-
@presenter = Blacklight::JsonPresenter.new(@response,
|
35
|
-
@document_list,
|
36
|
-
facets_from_request,
|
37
|
-
blacklight_config)
|
38
|
-
end
|
39
|
-
additional_response_formats(format)
|
40
|
-
document_export_formats(format)
|
41
|
-
end
|
42
|
-
end
|
25
|
+
# get search results from the solr index
|
26
|
+
def index
|
27
|
+
(@response, deprecated_document_list) = search_service.search_results
|
43
28
|
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
29
|
+
@document_list = ActiveSupport::Deprecation::DeprecatedObjectProxy.new(deprecated_document_list, 'The @document_list instance variable is deprecated; use @response.documents instead.')
|
30
|
+
|
31
|
+
respond_to do |format|
|
32
|
+
format.html { store_preferred_view }
|
33
|
+
format.rss { render layout: false }
|
34
|
+
format.atom { render layout: false }
|
35
|
+
format.json do
|
36
|
+
@presenter = Blacklight::JsonPresenter.new(@response,
|
37
|
+
blacklight_config)
|
52
38
|
end
|
39
|
+
additional_response_formats(format)
|
40
|
+
document_export_formats(format)
|
53
41
|
end
|
42
|
+
end
|
54
43
|
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
44
|
+
# get a single document from the index
|
45
|
+
# to add responses for formats other than html or json see _Blacklight::Document::Export_
|
46
|
+
def show
|
47
|
+
deprecated_response, @document = search_service.fetch(params[:id])
|
48
|
+
@response = ActiveSupport::Deprecation::DeprecatedObjectProxy.new(deprecated_response, 'The @response instance variable is deprecated; use @document.response instead.')
|
60
49
|
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
else
|
66
|
-
redirect_to blacklight_config.document_model.new(id: params[:id]), status: 303
|
67
|
-
end
|
50
|
+
respond_to do |format|
|
51
|
+
format.html { @search_context = setup_next_and_previous_documents }
|
52
|
+
format.json
|
53
|
+
additional_export_formats(@document, format)
|
68
54
|
end
|
55
|
+
end
|
69
56
|
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
raise ActionController::RoutingError, 'Not Found' unless @facet
|
74
|
-
@response = get_facet_field_response(@facet.key, params)
|
75
|
-
@display_facet = @response.aggregations[@facet.field]
|
76
|
-
@pagination = facet_paginator(@facet, @display_facet)
|
77
|
-
respond_to do |format|
|
78
|
-
format.html do
|
79
|
-
# Draw the partial for the "more" facet modal window:
|
80
|
-
return render layout: false if request.xhr?
|
81
|
-
# Otherwise draw the facet selector for users who have javascript disabled.
|
82
|
-
end
|
83
|
-
format.json
|
84
|
-
end
|
85
|
-
end
|
57
|
+
# get a single document from the index
|
58
|
+
def raw
|
59
|
+
raise(ActionController::RoutingError, 'Not Found') unless blacklight_config.raw_endpoint.enabled
|
86
60
|
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
61
|
+
_, @document = search_service.fetch(params[:id])
|
62
|
+
render json: @document
|
63
|
+
end
|
64
|
+
|
65
|
+
# updates the search counter (allows the show view to paginate)
|
66
|
+
def track
|
67
|
+
search_session['counter'] = params[:counter]
|
68
|
+
search_session['id'] = params[:search_id]
|
69
|
+
search_session['per_page'] = params[:per_page]
|
70
|
+
|
71
|
+
if params[:redirect] && (params[:redirect].starts_with?('/') || params[:redirect] =~ URI::DEFAULT_PARSER.make_regexp)
|
72
|
+
uri = URI.parse(params[:redirect])
|
73
|
+
path = uri.query ? "#{uri.path}?#{uri.query}" : uri.path
|
74
|
+
redirect_to path, status: 303
|
75
|
+
else
|
76
|
+
redirect_to({ action: :show, id: params[:id] }, status: 303)
|
93
77
|
end
|
78
|
+
end
|
94
79
|
|
95
|
-
|
96
|
-
|
80
|
+
# displays values and pagination links for a single facet field
|
81
|
+
def facet
|
82
|
+
@facet = blacklight_config.facet_fields[params[:id]]
|
83
|
+
raise ActionController::RoutingError, 'Not Found' unless @facet
|
84
|
+
|
85
|
+
@response = search_service.facet_field_response(@facet.key)
|
86
|
+
@display_facet = @response.aggregations[@facet.field]
|
87
|
+
@pagination = facet_paginator(@facet, @display_facet)
|
88
|
+
respond_to do |format|
|
89
|
+
format.html do
|
90
|
+
# Draw the partial for the "more" facet modal window:
|
91
|
+
return render layout: false if request.xhr?
|
92
|
+
# Otherwise draw the facet selector for users who have javascript disabled.
|
93
|
+
end
|
94
|
+
format.json
|
97
95
|
end
|
96
|
+
end
|
98
97
|
|
99
|
-
|
100
|
-
|
98
|
+
# method to serve up XML OpenSearch description and JSON autocomplete response
|
99
|
+
def opensearch
|
100
|
+
respond_to do |format|
|
101
|
+
format.xml { render layout: false }
|
102
|
+
format.json { render json: search_service.opensearch_response }
|
101
103
|
end
|
104
|
+
end
|
102
105
|
|
103
|
-
|
104
|
-
|
105
|
-
|
106
|
-
|
107
|
-
|
106
|
+
def suggest
|
107
|
+
respond_to do |format|
|
108
|
+
format.json do
|
109
|
+
render json: suggestions_service.suggestions
|
110
|
+
end
|
108
111
|
end
|
112
|
+
end
|
109
113
|
|
110
|
-
|
114
|
+
# @return [Array] first value is a Blacklight::Solr::Response and the second
|
115
|
+
# is a list of documents
|
116
|
+
def action_documents
|
117
|
+
search_service.fetch(Array(params[:id]))
|
118
|
+
end
|
111
119
|
|
112
|
-
|
113
|
-
|
114
|
-
|
120
|
+
def action_success_redirect_path
|
121
|
+
search_state.url_for_document(blacklight_config.document_model.new(id: params[:id]))
|
122
|
+
end
|
115
123
|
|
116
|
-
|
117
|
-
|
118
|
-
|
119
|
-
|
120
|
-
|
121
|
-
|
122
|
-
session[:preferred_view] = params[:view] if params[:view]
|
123
|
-
end
|
124
|
+
##
|
125
|
+
# Check if any search parameters have been set
|
126
|
+
# @return [Boolean]
|
127
|
+
def has_search_parameters?
|
128
|
+
params[:q].present? || params[:f].present? || params[:search_field].present?
|
129
|
+
end
|
124
130
|
|
125
|
-
|
126
|
-
|
127
|
-
|
128
|
-
|
129
|
-
|
130
|
-
|
131
|
-
|
132
|
-
|
133
|
-
|
134
|
-
|
135
|
-
|
136
|
-
|
137
|
-
|
138
|
-
|
139
|
-
|
140
|
-
|
141
|
-
|
142
|
-
|
143
|
-
|
144
|
-
|
145
|
-
|
146
|
-
end
|
147
|
-
end
|
131
|
+
DEFAULT_FACET_LIMIT = 10
|
132
|
+
|
133
|
+
# Look up facet limit for given facet_field. Will look at config, and
|
134
|
+
# if config is 'true' will look up from Solr @response if available. If
|
135
|
+
# no limit is available, returns nil. Used from #add_facetting_to_solr
|
136
|
+
# to supply f.fieldname.facet.limit values in solr request (no @response
|
137
|
+
# available), and used in display (with @response available) to create
|
138
|
+
# a facet paginator with the right limit.
|
139
|
+
def facet_limit_for(facet_field)
|
140
|
+
facet = blacklight_config.facet_fields[facet_field]
|
141
|
+
return if facet.blank?
|
142
|
+
|
143
|
+
if facet.limit && @response && @response.aggregations[facet.field]
|
144
|
+
limit = @response.aggregations[facet.field].limit
|
145
|
+
|
146
|
+
if limit.nil? # we didn't get or a set a limit, so infer one.
|
147
|
+
facet.limit if facet.limit != true
|
148
|
+
elsif limit == -1 # limit -1 is solr-speak for unlimited
|
149
|
+
nil
|
150
|
+
else
|
151
|
+
limit.to_i - 1 # we added 1 to find out if we needed to paginate
|
148
152
|
end
|
153
|
+
elsif facet.limit
|
154
|
+
facet.limit == true ? DEFAULT_FACET_LIMIT : facet.limit
|
149
155
|
end
|
156
|
+
end
|
150
157
|
|
151
|
-
|
152
|
-
# Render additional export formats for the show action, as provided by
|
153
|
-
# the document extension framework. See _Blacklight::Document::Export_
|
154
|
-
def additional_export_formats(document, format)
|
155
|
-
document.export_formats.each_key do | format_name |
|
156
|
-
format.send(format_name.to_sym) { render body: document.export_as(format_name), layout: false }
|
157
|
-
end
|
158
|
-
end
|
158
|
+
private
|
159
159
|
|
160
|
-
|
161
|
-
|
162
|
-
|
163
|
-
|
164
|
-
|
165
|
-
|
166
|
-
|
160
|
+
#
|
161
|
+
# non-routable methods ->
|
162
|
+
#
|
163
|
+
|
164
|
+
def render_sms_action?(_config, _options)
|
165
|
+
sms_mappings.present?
|
166
|
+
end
|
167
|
+
|
168
|
+
##
|
169
|
+
# If the params specify a view, then store it in the session. If the params
|
170
|
+
# do not specifiy the view, set the view parameter to the value stored in the
|
171
|
+
# session. This enables a user with a session to do subsequent searches and have
|
172
|
+
# them default to the last used view.
|
173
|
+
def store_preferred_view
|
174
|
+
session[:preferred_view] = params[:view] if params[:view]
|
175
|
+
end
|
176
|
+
|
177
|
+
##
|
178
|
+
# Render additional response formats for the index action, as provided by the
|
179
|
+
# blacklight configuration
|
180
|
+
# @param [Hash] format
|
181
|
+
# @note Make sure your format has a well known mime-type or is registered in config/initializers/mime_types.rb
|
182
|
+
# @example
|
183
|
+
# config.index.respond_to.txt = Proc.new { render plain: "A list of docs." }
|
184
|
+
def additional_response_formats format
|
185
|
+
blacklight_config.index.respond_to.each do |key, config|
|
186
|
+
format.send key do
|
187
|
+
case config
|
188
|
+
when false
|
189
|
+
raise ActionController::RoutingError, 'Not Found'
|
190
|
+
when Hash
|
191
|
+
render config
|
192
|
+
when Proc
|
193
|
+
instance_exec(&config)
|
194
|
+
when Symbol, String
|
195
|
+
send config
|
167
196
|
else
|
168
|
-
|
197
|
+
render({})
|
169
198
|
end
|
170
199
|
end
|
171
200
|
end
|
201
|
+
end
|
172
202
|
|
173
|
-
|
174
|
-
|
175
|
-
|
176
|
-
|
177
|
-
|
178
|
-
render
|
179
|
-
rescue ActionView::MissingTemplate
|
180
|
-
render plain: @response.documents.map { |x| x.export_as(format_name) if x.exports_as? format_name }.compact.join("\n"), layout: false
|
203
|
+
##
|
204
|
+
# Render additional export formats for the show action, as provided by
|
205
|
+
# the document extension framework. See _Blacklight::Document::Export_
|
206
|
+
def additional_export_formats(document, format)
|
207
|
+
document.export_formats.each_key do |format_name|
|
208
|
+
format.send(format_name.to_sym) { render body: document.export_as(format_name), layout: false }
|
181
209
|
end
|
210
|
+
end
|
182
211
|
|
183
|
-
|
184
|
-
|
185
|
-
|
186
|
-
|
187
|
-
|
212
|
+
##
|
213
|
+
# Try to render a response from the document export formats available
|
214
|
+
def document_export_formats format
|
215
|
+
format.any do
|
216
|
+
format_name = params.fetch(:format, '').to_sym
|
217
|
+
if @response.export_formats.include? format_name
|
218
|
+
render_document_export_format format_name
|
219
|
+
else
|
220
|
+
raise ActionController::UnknownFormat
|
221
|
+
end
|
188
222
|
end
|
223
|
+
end
|
189
224
|
|
190
|
-
|
191
|
-
|
192
|
-
|
193
|
-
|
194
|
-
|
195
|
-
|
196
|
-
|
197
|
-
|
198
|
-
|
199
|
-
|
200
|
-
# SMS action (this will render the appropriate view on GET requests and process the form and send the email on POST requests)
|
201
|
-
def sms_action documents
|
202
|
-
to = "#{params[:to].gsub(/[^\d]/, '')}@#{params[:carrier]}"
|
203
|
-
mail = RecordMailer.sms_record(documents, { :to => to }, url_options)
|
204
|
-
if mail.respond_to? :deliver_now
|
205
|
-
mail.deliver_now
|
206
|
-
else
|
207
|
-
mail.deliver
|
208
|
-
end
|
209
|
-
end
|
210
|
-
|
211
|
-
def validate_sms_params
|
212
|
-
if params[:to].blank?
|
213
|
-
flash[:error] = I18n.t('blacklight.sms.errors.to.blank')
|
214
|
-
elsif params[:carrier].blank?
|
215
|
-
flash[:error] = I18n.t('blacklight.sms.errors.carrier.blank')
|
216
|
-
elsif params[:to].gsub(/[^\d]/, '').length != 10
|
217
|
-
flash[:error] = I18n.t('blacklight.sms.errors.to.invalid', :to => params[:to])
|
218
|
-
elsif !sms_mappings.values.include?(params[:carrier])
|
219
|
-
flash[:error] = I18n.t('blacklight.sms.errors.carrier.invalid')
|
220
|
-
end
|
225
|
+
##
|
226
|
+
# Render the document export formats for a response
|
227
|
+
# First, try to render an appropriate template (e.g. index.endnote.erb)
|
228
|
+
# If that fails, just concatenate the document export responses with a newline.
|
229
|
+
def render_document_export_format format_name
|
230
|
+
render
|
231
|
+
rescue ActionView::MissingTemplate
|
232
|
+
render plain: @response.documents.map { |x| x.export_as(format_name) if x.exports_as? format_name }.compact.join("\n"), layout: false
|
233
|
+
end
|
221
234
|
|
222
|
-
|
223
|
-
|
235
|
+
# Overrides the Blacklight::Controller provided #search_action_url.
|
236
|
+
# By default, any search action from a Blacklight::Catalog controller
|
237
|
+
# should use the current controller when constructing the route.
|
238
|
+
def search_action_url options = {}
|
239
|
+
url_for(options.reverse_merge(action: 'index'))
|
240
|
+
end
|
224
241
|
|
225
|
-
|
226
|
-
|
242
|
+
# Email Action (this will render the appropriate view on GET requests and process the form and send the email on POST requests)
|
243
|
+
def email_action documents
|
244
|
+
mail = RecordMailer.email_record(documents, { to: params[:to], message: params[:message] }, url_options)
|
245
|
+
if mail.respond_to? :deliver_now
|
246
|
+
mail.deliver_now
|
247
|
+
else
|
248
|
+
mail.deliver
|
227
249
|
end
|
250
|
+
end
|
228
251
|
|
229
|
-
|
230
|
-
|
231
|
-
|
232
|
-
|
233
|
-
|
234
|
-
|
252
|
+
# SMS action (this will render the appropriate view on GET requests and process the form and send the email on POST requests)
|
253
|
+
def sms_action documents
|
254
|
+
to = "#{params[:to].gsub(/[^\d]/, '')}@#{params[:carrier]}"
|
255
|
+
mail = RecordMailer.sms_record(documents, { to: to }, url_options)
|
256
|
+
if mail.respond_to? :deliver_now
|
257
|
+
mail.deliver_now
|
258
|
+
else
|
259
|
+
mail.deliver
|
260
|
+
end
|
261
|
+
end
|
235
262
|
|
236
|
-
|
263
|
+
def validate_sms_params
|
264
|
+
if params[:to].blank?
|
265
|
+
flash[:error] = I18n.t('blacklight.sms.errors.to.blank')
|
266
|
+
elsif params[:carrier].blank?
|
267
|
+
flash[:error] = I18n.t('blacklight.sms.errors.carrier.blank')
|
268
|
+
elsif params[:to].gsub(/[^\d]/, '').length != 10
|
269
|
+
flash[:error] = I18n.t('blacklight.sms.errors.to.invalid', to: params[:to])
|
270
|
+
elsif !sms_mappings.value?(params[:carrier])
|
271
|
+
flash[:error] = I18n.t('blacklight.sms.errors.carrier.invalid')
|
237
272
|
end
|
238
273
|
|
239
|
-
|
240
|
-
|
241
|
-
|
242
|
-
|
243
|
-
|
244
|
-
|
245
|
-
|
246
|
-
|
247
|
-
|
248
|
-
|
249
|
-
|
250
|
-
|
251
|
-
|
252
|
-
respond_to do |format|
|
253
|
-
format.xml { render :xml => error_info, :status => 404 }
|
254
|
-
format.json { render :json => error_info, :status => 404 }
|
255
|
-
|
256
|
-
# default to HTML response, even for other non-HTML formats we don't
|
257
|
-
# neccesarily know about, seems to be consistent with what Rails4 does
|
258
|
-
# by default with uncaught ActiveRecord::RecordNotFound in production
|
259
|
-
format.any do
|
260
|
-
# use standard, possibly locally overridden, 404.html file. Even for
|
261
|
-
# possibly non-html formats, this is consistent with what Rails does
|
262
|
-
# on raising an ActiveRecord::RecordNotFound. Rails.root IS needed
|
263
|
-
# for it to work under testing, without worrying about CWD.
|
264
|
-
render :file => "#{Rails.root}/public/404.html", :status => 404, :layout => false, :content_type => 'text/html'
|
265
|
-
end
|
266
|
-
end
|
274
|
+
flash[:error].blank?
|
275
|
+
end
|
276
|
+
|
277
|
+
def sms_mappings
|
278
|
+
Blacklight::Engine.config.sms_mappings
|
279
|
+
end
|
280
|
+
|
281
|
+
def validate_email_params
|
282
|
+
if params[:to].blank?
|
283
|
+
flash[:error] = I18n.t('blacklight.email.errors.to.blank')
|
284
|
+
elsif !params[:to].match(Blacklight::Engine.config.email_regexp)
|
285
|
+
flash[:error] = I18n.t('blacklight.email.errors.to.invalid', to: params[:to])
|
267
286
|
end
|
268
287
|
|
269
|
-
|
270
|
-
|
288
|
+
flash[:error].blank?
|
289
|
+
end
|
290
|
+
|
291
|
+
def start_new_search_session?
|
292
|
+
action_name == "index"
|
293
|
+
end
|
294
|
+
|
295
|
+
def determine_layout
|
296
|
+
action_name == 'show' ? 'catalog_result' : super
|
297
|
+
end
|
298
|
+
|
299
|
+
# when a method throws a Blacklight::Exceptions::InvalidRequest, this method is executed.
|
300
|
+
def handle_request_error(exception)
|
301
|
+
# Rails own code will catch and give usual Rails error page with stack trace
|
302
|
+
raise exception if Rails.env.development? || Rails.env.test?
|
303
|
+
|
304
|
+
flash_notice = I18n.t('blacklight.search.errors.request_error')
|
305
|
+
|
306
|
+
# If there are errors coming from the index page, we want to trap those sensibly
|
307
|
+
|
308
|
+
if flash[:notice] == flash_notice
|
309
|
+
logger.error "Cowardly aborting rsolr_request_error exception handling, because we redirected to a page that raises another exception"
|
310
|
+
raise exception
|
271
311
|
end
|
312
|
+
|
313
|
+
logger.error exception
|
314
|
+
|
315
|
+
flash[:notice] = flash_notice
|
316
|
+
redirect_to search_action_url
|
317
|
+
end
|
272
318
|
end
|