commonwealth-vlr-engine 0.0.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.gitignore +91 -0
- data/.gitmodules +3 -0
- data/Gemfile +20 -0
- data/LICENSE +202 -0
- data/README.md +38 -0
- data/Rakefile +43 -0
- data/app/assets/images/commonwealth-vlr-engine/bplLoginButton.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/dc_audio-icon.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/dc_collection-icon.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/dc_image-icon.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/dc_institution-icon.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/dc_moving-image-icon.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/dc_text-icon.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/facebookLoginButton.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/loading-wdl-grid.gif +0 -0
- data/app/assets/images/commonwealth-vlr-engine/loading-wdl.gif +0 -0
- data/app/assets/images/commonwealth-vlr-engine/loading.gif +0 -0
- data/app/assets/images/commonwealth-vlr-engine/openseadragon/fullpage_grouphover.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/openseadragon/fullpage_hover.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/openseadragon/fullpage_pressed.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/openseadragon/fullpage_rest.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/openseadragon/home_grouphover.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/openseadragon/home_hover.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/openseadragon/home_pressed.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/openseadragon/home_rest.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/openseadragon/next_grouphover.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/openseadragon/next_hover.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/openseadragon/next_pressed.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/openseadragon/next_rest.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/openseadragon/previous_grouphover.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/openseadragon/previous_hover.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/openseadragon/previous_pressed.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/openseadragon/previous_rest.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/openseadragon/rotateleft_grouphover.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/openseadragon/rotateleft_hover.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/openseadragon/rotateleft_pressed.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/openseadragon/rotateleft_rest.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/openseadragon/rotateright_grouphover.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/openseadragon/rotateright_hover.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/openseadragon/rotateright_pressed.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/openseadragon/rotateright_rest.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/openseadragon/zoomin_grouphover.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/openseadragon/zoomin_hover.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/openseadragon/zoomin_pressed.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/openseadragon/zoomin_rest.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/openseadragon/zoomout_grouphover.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/openseadragon/zoomout_hover.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/openseadragon/zoomout_pressed.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/openseadragon/zoomout_rest.png +0 -0
- data/app/assets/images/commonwealth-vlr-engine/vlr_logo_img.png +0 -0
- data/app/assets/javascripts/blacklight_gallery.js +1 -0
- data/app/assets/javascripts/blacklight_google_analytics/blacklight_google_analytics.js.erb +165 -0
- data/app/assets/javascripts/bootstrap-accessibility-plugin/bootstrap-accessibility.js +586 -0
- data/app/assets/javascripts/commonwealth-vlr-engine.js +22 -0
- data/app/assets/javascripts/commonwealth-vlr-engine/collection_facets.js +5 -0
- data/app/assets/javascripts/commonwealth-vlr-engine/disable_dropdown_nav.js +21 -0
- data/app/assets/javascripts/commonwealth-vlr-engine/feedback_alerts.js.erb +19 -0
- data/app/assets/javascripts/commonwealth-vlr-engine/folder_tools.js +26 -0
- data/app/assets/javascripts/commonwealth-vlr-engine/multi_img_viewer.js.erb +20 -0
- data/app/assets/javascripts/commonwealth-vlr-engine/ocr_search_utils.js.erb +32 -0
- data/app/assets/javascripts/commonwealth-vlr-engine/volumes_list.js +5 -0
- data/app/assets/javascripts/openseadragon.js +2 -0
- data/app/assets/javascripts/respond/respond.min.js +6 -0
- data/app/assets/javascripts/wdl-viewer/fd-slider.js +1303 -0
- data/app/assets/javascripts/wdl-viewer/jquery-deparam.js +113 -0
- data/app/assets/javascripts/wdl-viewer/jquery.ba-throttle-debounce.min.js +9 -0
- data/app/assets/javascripts/wdl-viewer/jquery.hammer.min.js +7 -0
- data/app/assets/javascripts/wdl-viewer/modernizr-wdl.min.js +3 -0
- data/app/assets/javascripts/wdl-viewer/wdl-search.js +33 -0
- data/app/assets/javascripts/wdl-viewer/wdl-viewer_commonwealth.js +1147 -0
- data/app/assets/stylesheets/blacklight_advanced_search.css +5 -0
- data/app/assets/stylesheets/blacklight_gallery.css +1 -0
- data/app/assets/stylesheets/blacklight_maps.css +1 -0
- data/app/assets/stylesheets/bootstrap-accessibility-plugin/bootstrap-accessibility.css +105 -0
- data/app/assets/stylesheets/commonwealth-vlr-engine/advanced_search.scss +139 -0
- data/app/assets/stylesheets/commonwealth-vlr-engine/basic_search.scss +47 -0
- data/app/assets/stylesheets/commonwealth-vlr-engine/book_viewer.scss +576 -0
- data/app/assets/stylesheets/commonwealth-vlr-engine/carousel.scss +94 -0
- data/app/assets/stylesheets/commonwealth-vlr-engine/cmmnwlth_defaults.scss +45 -0
- data/app/assets/stylesheets/commonwealth-vlr-engine/cmmnwlth_shared.scss +75 -0
- data/app/assets/stylesheets/commonwealth-vlr-engine/collections.scss +563 -0
- data/app/assets/stylesheets/commonwealth-vlr-engine/commonwealth-vlr-engine.css +32 -0
- data/app/assets/stylesheets/commonwealth-vlr-engine/facets.scss +111 -0
- data/app/assets/stylesheets/commonwealth-vlr-engine/feedback.scss +10 -0
- data/app/assets/stylesheets/commonwealth-vlr-engine/folders.scss +276 -0
- data/app/assets/stylesheets/commonwealth-vlr-engine/footer.scss +47 -0
- data/app/assets/stylesheets/commonwealth-vlr-engine/header.scss +329 -0
- data/app/assets/stylesheets/commonwealth-vlr-engine/home.scss +269 -0
- data/app/assets/stylesheets/commonwealth-vlr-engine/index.scss +580 -0
- data/app/assets/stylesheets/commonwealth-vlr-engine/institutions.scss +246 -0
- data/app/assets/stylesheets/commonwealth-vlr-engine/pages.scss +31 -0
- data/app/assets/stylesheets/commonwealth-vlr-engine/search_inside.scss +172 -0
- data/app/assets/stylesheets/commonwealth-vlr-engine/searches.scss +55 -0
- data/app/assets/stylesheets/commonwealth-vlr-engine/show.scss +840 -0
- data/app/assets/stylesheets/commonwealth-vlr-engine/signin.scss +43 -0
- data/app/assets/stylesheets/commonwealth-vlr-engine/users.scss +18 -0
- data/app/assets/stylesheets/commonwealth-vlr-engine/vlr_dependencies.css +8 -0
- data/app/assets/stylesheets/ie_fixes.css +16 -0
- data/app/assets/stylesheets/openseadragon.css +1 -0
- data/app/assets/stylesheets/wdl-viewer/fd-slider.min.css +2 -0
- data/app/controllers/blacklight_advanced_search/advanced_controller.rb +66 -0
- data/app/controllers/bookmarks_controller.rb +38 -0
- data/app/controllers/collections_controller.rb +128 -0
- data/app/controllers/commonwealth_vlr_engine/application_controller.rb +8 -0
- data/app/controllers/feedback_controller.rb +39 -0
- data/app/controllers/folder_items_actions_controller.rb +72 -0
- data/app/controllers/folder_items_controller.rb +90 -0
- data/app/controllers/folders_controller.rb +132 -0
- data/app/controllers/iiif_manifest_controller.rb +74 -0
- data/app/controllers/image_viewer_controller.rb +34 -0
- data/app/controllers/institutions_controller.rb +62 -0
- data/app/controllers/ocr_search_controller.rb +78 -0
- data/app/controllers/pages_controller.rb +5 -0
- data/app/controllers/users/omniauth_callbacks_controller.rb +10 -0
- data/app/controllers/users/registrations_controller.rb +3 -0
- data/app/controllers/users/sessions_controller.rb +3 -0
- data/app/controllers/users_controller.rb +27 -0
- data/app/helpers/blacklight_maps_helper.rb +3 -0
- data/app/helpers/collections_helper.rb +3 -0
- data/app/helpers/commonwealth_vlr_engine/application_helper.rb +200 -0
- data/app/helpers/commonwealth_vlr_engine/blacklight_helper.rb +35 -0
- data/app/helpers/commonwealth_vlr_engine/blacklight_url_helper.rb +53 -0
- data/app/helpers/commonwealth_vlr_engine/catalog_helper.rb +414 -0
- data/app/helpers/commonwealth_vlr_engine/collections_helper_behavior.rb +19 -0
- data/app/helpers/commonwealth_vlr_engine/component_helper.rb +22 -0
- data/app/helpers/commonwealth_vlr_engine/facets_helper.rb +20 -0
- data/app/helpers/commonwealth_vlr_engine/feedback_helper_behavior.rb +14 -0
- data/app/helpers/commonwealth_vlr_engine/folders_helper_behavior.rb +9 -0
- data/app/helpers/commonwealth_vlr_engine/image_viewer_helper_behavior.rb +14 -0
- data/app/helpers/commonwealth_vlr_engine/institutions_helper_behavior.rb +31 -0
- data/app/helpers/commonwealth_vlr_engine/layout_helper.rb +22 -0
- data/app/helpers/commonwealth_vlr_engine/ocr_search_helper_behavior.rb +48 -0
- data/app/helpers/commonwealth_vlr_engine/pages_helper_behavior.rb +38 -0
- data/app/helpers/commonwealth_vlr_engine/vlr_blacklight_maps_helper_behavior.rb +59 -0
- data/app/helpers/feedback_helper.rb +3 -0
- data/app/helpers/folders_helper.rb +3 -0
- data/app/helpers/image_viewer_helper.rb +3 -0
- data/app/helpers/institutions_helper.rb +3 -0
- data/app/helpers/ocr_search_helper.rb +3 -0
- data/app/helpers/pages_helper.rb +3 -0
- data/app/mailers/notifier.rb +5 -0
- data/app/models/carousel_slide.rb +7 -0
- data/app/models/record_mailer.rb +18 -0
- data/app/models/user.rb +15 -0
- data/app/views/advanced/_advanced_search_date.html.erb +23 -0
- data/app/views/advanced/_advanced_search_facets.html.erb +5 -0
- data/app/views/advanced/_advanced_search_fields.html.erb +39 -0
- data/app/views/advanced/_advanced_search_form.html.erb +51 -0
- data/app/views/advanced/_advanced_search_help.html.erb +13 -0
- data/app/views/advanced/_facet_layout.html.erb +9 -0
- data/app/views/advanced/_facet_limit.html.erb +15 -0
- data/app/views/advanced/index.html.erb +29 -0
- data/app/views/blacklight_advanced_search/_facet_limit.html.erb +12 -0
- data/app/views/bookmarks/_tools.html.erb +25 -0
- data/app/views/bookmarks/index.html.erb +64 -0
- data/app/views/bookmarks/update.js.erb +1 -0
- data/app/views/bpluser/folders/_folder.html.erb +36 -0
- data/app/views/catalog/_add_this.html.erb +10 -0
- data/app/views/catalog/_az_links.html.erb +15 -0
- data/app/views/catalog/_basic_search.html.erb +67 -0
- data/app/views/catalog/_citation.html.erb +50 -0
- data/app/views/catalog/_constraints.html.erb +26 -0
- data/app/views/catalog/_document_collections_gallery.html.erb +7 -0
- data/app/views/catalog/_facet_limit_series.html.erb +21 -0
- data/app/views/catalog/_facets.html.erb +31 -0
- data/app/views/catalog/_facets_series.html.erb +4 -0
- data/app/views/catalog/_folder_item_control.html.erb +64 -0
- data/app/views/catalog/_index_collections_gallery.html.erb +12 -0
- data/app/views/catalog/_index_gallery.html.erb +11 -0
- data/app/views/catalog/_index_header_default.html.erb +22 -0
- data/app/views/catalog/_index_list_collection.html.erb +33 -0
- data/app/views/catalog/_index_list_default.html.erb +13 -0
- data/app/views/catalog/_index_map_institutions.html.erb +10 -0
- data/app/views/catalog/_index_masonry.html.erb +8 -0
- data/app/views/catalog/_index_slideshow.html.erb +18 -0
- data/app/views/catalog/_more_like_this.html.erb +9 -0
- data/app/views/catalog/_opengraph.html.erb +16 -0
- data/app/views/catalog/_previous_next_doc.html.erb +22 -0
- data/app/views/catalog/_results_pagination.html.erb +9 -0
- data/app/views/catalog/_search_form.html.erb +23 -0
- data/app/views/catalog/_search_header.html.erb +5 -0
- data/app/views/catalog/_show_default.html.erb +75 -0
- data/app/views/catalog/_show_main_content.html.erb +27 -0
- data/app/views/catalog/_show_more_like_this.html.erb +15 -0
- data/app/views/catalog/_show_partials/_show_book_viewer_link.html.erb +25 -0
- data/app/views/catalog/_show_partials/_show_default_img.html.erb +32 -0
- data/app/views/catalog/_show_partials/_show_default_metadata.html.erb +486 -0
- data/app/views/catalog/_show_partials/_show_default_simple_img_viewer.html.erb +45 -0
- data/app/views/catalog/_show_partials/_show_downloads.html.erb +14 -0
- data/app/views/catalog/_show_partials/_show_flagged_notice.html.erb +29 -0
- data/app/views/catalog/_show_partials/_show_multi_img.html.erb +42 -0
- data/app/views/catalog/_show_partials/_show_multi_img_pagination.html.erb +20 -0
- data/app/views/catalog/_show_partials/_show_oai_item_img.html.erb +5 -0
- data/app/views/catalog/_show_partials/_show_oai_item_link.html.erb +8 -0
- data/app/views/catalog/_show_partials/_show_prev_next_carousel_links.html.erb +17 -0
- data/app/views/catalog/_show_partials/_show_volumes.html.erb +52 -0
- data/app/views/catalog/_show_sidebar.html.erb +1 -0
- data/app/views/catalog/_show_tools.html.erb +42 -0
- data/app/views/catalog/_zero_results.html.erb +20 -0
- data/app/views/catalog/email.html.erb +6 -0
- data/app/views/catalog/index.html.erb +17 -0
- data/app/views/catalog/metadata_view.html.erb +7 -0
- data/app/views/catalog/show.html.erb +13 -0
- data/app/views/collections/_search_form_collection.html.erb +23 -0
- data/app/views/collections/index.html.erb +30 -0
- data/app/views/collections/show.html.erb +116 -0
- data/app/views/devise/confirmations/new.html.erb +14 -0
- data/app/views/devise/mailer/reset_password_instructions.html.erb +13 -0
- data/app/views/devise/passwords/edit.html.erb +33 -0
- data/app/views/devise/passwords/new.html.erb +31 -0
- data/app/views/devise/registrations/edit.html.erb +83 -0
- data/app/views/devise/registrations/new.html.erb +53 -0
- data/app/views/devise/sessions/new.html.erb +75 -0
- data/app/views/devise/shared/_links.erb +29 -0
- data/app/views/feedback/complete.html.erb +9 -0
- data/app/views/feedback/show.html.erb +61 -0
- data/app/views/folder_items/create.js.erb +1 -0
- data/app/views/folder_items/destroy.js.erb +1 -0
- data/app/views/folder_items/item_actions.js.erb +2 -0
- data/app/views/folder_items/update.js.erb +1 -0
- data/app/views/folders/_in_folder.html.erb +2 -0
- data/app/views/folders/_new_edit_form_fields.html.erb +36 -0
- data/app/views/folders/edit.html.erb +25 -0
- data/app/views/folders/index.html.erb +73 -0
- data/app/views/folders/new.html.erb +27 -0
- data/app/views/folders/public_list.html.erb +44 -0
- data/app/views/folders/show.html.erb +98 -0
- data/app/views/image_viewer/_book_viewer_help.html.erb +125 -0
- data/app/views/image_viewer/_render_book_viewer.html.erb +185 -0
- data/app/views/image_viewer/book_viewer.html.erb +57 -0
- data/app/views/image_viewer/show.js.erb +19 -0
- data/app/views/institutions/_intro_text.html.erb +1 -0
- data/app/views/institutions/_map_institutions_search.html.erb +9 -0
- data/app/views/institutions/_search_form_institution.html.erb +24 -0
- data/app/views/institutions/index.html.erb +31 -0
- data/app/views/institutions/show.html.erb +104 -0
- data/app/views/layouts/_google_analytics.html.erb +9 -0
- data/app/views/layouts/book_viewer.html.erb +37 -0
- data/app/views/layouts/commonwealth-vlr-engine.html.erb +59 -0
- data/app/views/notifier/feedback.text.erb +6 -0
- data/app/views/ocr_search/_index_ocr_list.html.erb +17 -0
- data/app/views/ocr_search/_search_form_ocr.html.erb +23 -0
- data/app/views/ocr_search/_snippets_more.html.erb +15 -0
- data/app/views/ocr_search/_zero_results_ocr.html.erb +9 -0
- data/app/views/ocr_search/index.html.erb +49 -0
- data/app/views/pages/_carousel.html.erb +46 -0
- data/app/views/pages/_home_partials/_banner.html.erb +23 -0
- data/app/views/pages/_home_partials/_browse.html.erb +55 -0
- data/app/views/pages/_home_partials/_context.html.erb +24 -0
- data/app/views/pages/_home_partials/_home_content.html.erb +14 -0
- data/app/views/pages/about.html.erb +10 -0
- data/app/views/pages/about_site.html.erb +6 -0
- data/app/views/pages/explore.html.erb +32 -0
- data/app/views/pages/home.html.erb +3 -0
- data/app/views/record_mailer/email_record.text.erb +7 -0
- data/app/views/saved_searches/index.html.erb +60 -0
- data/app/views/search_history/index.html.erb +59 -0
- data/app/views/shared/_error_messages.html.erb +9 -0
- data/app/views/shared/_flash_msg_maintenance.html.erb +6 -0
- data/app/views/shared/_folder_item_actions.html.erb +66 -0
- data/app/views/shared/_folder_tools.html.erb +4 -0
- data/app/views/shared/_footer.html.erb +14 -0
- data/app/views/shared/_header_navbar.html.erb +34 -0
- data/app/views/shared/_nav_links.html.erb +58 -0
- data/app/views/shared/_search_form_header.html.erb +16 -0
- data/app/views/shared/_tools.html.erb +14 -0
- data/app/views/shared/_user_util_links.html.erb +43 -0
- data/app/views/users/show.html.erb +33 -0
- data/commonwealth-vlr-engine.gemspec +47 -0
- data/config/initializers/patch_blacklight_advanced_search.rb +74 -0
- data/config/initializers/patch_blacklight_maps.rb +20 -0
- data/config/jetty.yml +7 -0
- data/config/locales/commonwealth-vlr-engine.en.yml +463 -0
- data/config/routes.rb +92 -0
- data/lib/commonwealth-vlr-engine.rb +55 -0
- data/lib/commonwealth-vlr-engine/commonwealth_search_builder.rb +66 -0
- data/lib/commonwealth-vlr-engine/controller.rb +69 -0
- data/lib/commonwealth-vlr-engine/controller_override.rb +238 -0
- data/lib/commonwealth-vlr-engine/engine.rb +40 -0
- data/lib/commonwealth-vlr-engine/finder.rb +285 -0
- data/lib/commonwealth-vlr-engine/iiif_manifest.rb +189 -0
- data/lib/commonwealth-vlr-engine/notifier.rb +33 -0
- data/lib/commonwealth-vlr-engine/pages.rb +33 -0
- data/lib/commonwealth-vlr-engine/render_constraints_override.rb +57 -0
- data/lib/commonwealth-vlr-engine/route_sets.rb +49 -0
- data/lib/commonwealth-vlr-engine/routes.rb +21 -0
- data/lib/commonwealth-vlr-engine/version.rb +3 -0
- data/lib/generators/commonwealth_vlr_engine/controller_generator.rb +92 -0
- data/lib/generators/commonwealth_vlr_engine/environment_generator.rb +49 -0
- data/lib/generators/commonwealth_vlr_engine/install_generator.rb +57 -0
- data/lib/generators/commonwealth_vlr_engine/localassets_generator.rb +29 -0
- data/lib/generators/commonwealth_vlr_engine/model_generator.rb +65 -0
- data/lib/generators/commonwealth_vlr_engine/routes_generator.rb +39 -0
- data/lib/generators/commonwealth_vlr_engine/templates/commonwealth_vlr_engine.css.scss +4 -0
- data/lib/generators/commonwealth_vlr_engine/templates/config/contact_emails.yml.sample +13 -0
- data/lib/generators/commonwealth_vlr_engine/templates/config/fedora.yml.sample +6 -0
- data/lib/generators/commonwealth_vlr_engine/templates/config/geojson_static_file.yml.sample +11 -0
- data/lib/generators/commonwealth_vlr_engine/templates/config/google_analytics.yml.sample +10 -0
- data/lib/generators/commonwealth_vlr_engine/templates/config/iiif_server.yml.sample +10 -0
- data/lib/generators/commonwealth_vlr_engine/templates/config/initializers/a_load_commonwealth_vlr_configs.rb +14 -0
- data/lib/generators/commonwealth_vlr_engine/templates/config/initializers/devise.rb +269 -0
- data/lib/generators/commonwealth_vlr_engine/templates/config/initializers/secret_token.rb +8 -0
- data/lib/generators/commonwealth_vlr_engine/templates/config/locales/blacklight.en.yml +44 -0
- data/lib/generators/commonwealth_vlr_engine/templates/config/locales/devise.en.yml +12 -0
- data/lib/generators/commonwealth_vlr_engine/templates/config/omniauth-facebook.yml.sample +14 -0
- data/lib/generators/commonwealth_vlr_engine/templates/config/omniauth-polaris.yml.sample +20 -0
- data/lib/generators/commonwealth_vlr_engine/templates/config/vlr.yml +13 -0
- data/lib/generators/commonwealth_vlr_engine/yml_generator.rb +29 -0
- data/lib/railties/commonwealth_vlr_engine.rake +6 -0
- data/solr_conf/conf/schema.xml +476 -0
- data/solr_conf/conf/solrconfig.xml +286 -0
- data/spec/controllers/catalog_controller_spec.rb +67 -0
- data/spec/controllers/collections_controller_spec.rb +127 -0
- data/spec/controllers/feedback_controller_spec.rb +51 -0
- data/spec/controllers/folder_items_actions_controller_spec.rb +99 -0
- data/spec/controllers/folder_items_controller_spec.rb +90 -0
- data/spec/controllers/folders_controller_spec.rb +368 -0
- data/spec/controllers/iiif_manifest_controller_spec.rb +85 -0
- data/spec/controllers/image_viewer_controller_spec.rb +50 -0
- data/spec/controllers/institutions_controller_spec.rb +64 -0
- data/spec/controllers/ocr_search_controller_spec.rb +71 -0
- data/spec/controllers/pages_controller_spec.rb +58 -0
- data/spec/controllers/users_controller_spec.rb +62 -0
- data/spec/features/catalog/_az_links_spec.rb +27 -0
- data/spec/features/catalog/_show_partials/_show_book_viewer_link_spec.rb +47 -0
- data/spec/features/catalog/_show_partials/_show_default_simple_img_viewer_spec.rb +19 -0
- data/spec/features/catalog/_show_partials/_show_flagged_notice_spec.rb +23 -0
- data/spec/features/catalog/_show_partials/_show_multi_img_spec.rb +18 -0
- data/spec/features/catalog/_show_partials/_show_volumes_spec.rb +24 -0
- data/spec/features/collections/index_spec.rb +35 -0
- data/spec/features/feedback/show_spec.rb +47 -0
- data/spec/features/image_viewer/book_viewer_spec.rb +67 -0
- data/spec/features/institutions/index_spec.rb +31 -0
- data/spec/features/institutions/map_view_spec.rb +37 -0
- data/spec/features/more_like_this_search_spec.rb +23 -0
- data/spec/features/ocr_search/index_spec.rb +89 -0
- data/spec/fixtures/sample_rss_feed.xml +56 -0
- data/spec/fixtures/sample_solr_documents.yml +2748 -0
- data/spec/helpers/application_helper_spec.rb +114 -0
- data/spec/helpers/catalog_helper_spec.rb +386 -0
- data/spec/helpers/collections_helper_spec.rb +28 -0
- data/spec/helpers/component_helper_spec.rb +34 -0
- data/spec/helpers/folders_helper_spec.rb +31 -0
- data/spec/helpers/image_viewer_helper_spec.rb +15 -0
- data/spec/helpers/institutions_helper_spec.rb +53 -0
- data/spec/helpers/ocr_search_helper_spec.rb +70 -0
- data/spec/helpers/pages_helper_spec.rb +21 -0
- data/spec/lib/commonwealth-vlr-engine/commonwealth_search_builder_spec.rb +101 -0
- data/spec/lib/commonwealth-vlr-engine/controller_override_spec.rb +41 -0
- data/spec/lib/commonwealth-vlr-engine/controller_spec.rb +33 -0
- data/spec/lib/commonwealth-vlr-engine/finder_spec.rb +140 -0
- data/spec/lib/commonwealth-vlr-engine/iiif_manifest_spec.rb +157 -0
- data/spec/lib/commonwealth-vlr-engine/render_constraints_override_spec.rb +97 -0
- data/spec/mailers/notifier_spec.rb +31 -0
- data/spec/models/carousel_slide_spec.rb +38 -0
- data/spec/spec_helper.rb +40 -0
- data/spec/tasks/vlr_engine_rake_spec.rb +28 -0
- data/spec/test_app_templates/lib/generators/test_app_generator.rb +23 -0
- data/tasks/vlr_engine.rake +46 -0
- metadata +788 -0
@@ -0,0 +1,25 @@
|
|
1
|
+
<% @page_title = t('blacklight.folders.edit_folder') + " - " + application_name %>
|
2
|
+
<div class="col-sm-9">
|
3
|
+
<div id="breadcrumb">
|
4
|
+
<ul class="breadcrumb">
|
5
|
+
<li>
|
6
|
+
<%= link_to(t('blacklight.users.account_heading'), current_user) %>
|
7
|
+
<span class="divider"><%= t('blacklight.breadcrumb.separator') %></span>
|
8
|
+
</li>
|
9
|
+
<li>
|
10
|
+
<%= link_to(t('blacklight.folders.list_title'), folders_path) %>
|
11
|
+
<span class="divider"><%= t('blacklight.breadcrumb.separator') %></span>
|
12
|
+
</li>
|
13
|
+
<li class="active">
|
14
|
+
<%= t('blacklight.folders.edit_folder') + ': ' + @folder.title %>
|
15
|
+
</li>
|
16
|
+
</ul>
|
17
|
+
</div>
|
18
|
+
<div id="edit_folder" class="folder_container">
|
19
|
+
|
20
|
+
<h2><%= t('blacklight.folders.edit_folder') + ': ' + @folder.title %></h2>
|
21
|
+
|
22
|
+
<%= render 'new_edit_form_fields', :form_object => @folder, :submit_button_text => 'Update folder' %>
|
23
|
+
|
24
|
+
</div>
|
25
|
+
</div>
|
@@ -0,0 +1,73 @@
|
|
1
|
+
<% @page_title = t('blacklight.folders.list_title') + " - " + application_name %>
|
2
|
+
<div class="col-sm-9">
|
3
|
+
|
4
|
+
<div id="breadcrumb">
|
5
|
+
<ul class="breadcrumb">
|
6
|
+
<% if current_user %>
|
7
|
+
<li>
|
8
|
+
<%= link_to(t('blacklight.users.account_heading'), current_user) %>
|
9
|
+
<span class="divider"><%= t('blacklight.breadcrumb.separator') %></span>
|
10
|
+
</li>
|
11
|
+
<% end %>
|
12
|
+
<li class="active">
|
13
|
+
<%= t('blacklight.folders.list_title') %>
|
14
|
+
</li>
|
15
|
+
</ul>
|
16
|
+
</div>
|
17
|
+
|
18
|
+
<h2>
|
19
|
+
<%= t('blacklight.folders.list_title') %>
|
20
|
+
<small id="add_folder">
|
21
|
+
<%= link_to(
|
22
|
+
content_tag(:span, '', :class=>'glyphicon glyphicon-plus') + ' add folder',
|
23
|
+
new_folder_path,
|
24
|
+
:id => 'create_folder_link',
|
25
|
+
:class => 'btn btn-primary btn-sm'
|
26
|
+
) %>
|
27
|
+
</small>
|
28
|
+
</h2>
|
29
|
+
|
30
|
+
<% if current_or_guest_user.blank? %>
|
31
|
+
|
32
|
+
<% redirect to login %>
|
33
|
+
|
34
|
+
<% else %>
|
35
|
+
|
36
|
+
<div id="user_folders" class="folder_container">
|
37
|
+
<p><%= t('blacklight.folders.intro') %></p>
|
38
|
+
<ul id="user_folder_list">
|
39
|
+
<li>
|
40
|
+
<h4>
|
41
|
+
<%= link_to t('blacklight.bookmarks.title'), bookmarks_path, :class => "folder_title" %>
|
42
|
+
<small class="folder_visibility">
|
43
|
+
<% if current_user %>
|
44
|
+
<%= content_tag(:span, '', :class => 'glyphicon glyphicon-lock') %>
|
45
|
+
<span class="visibility_private">private</span>
|
46
|
+
<% end %>
|
47
|
+
</small>
|
48
|
+
</h4>
|
49
|
+
<div class="folder_status">
|
50
|
+
<span class="folder_item_count">
|
51
|
+
<%= pluralize(current_or_guest_user.bookmarks.length.to_s,
|
52
|
+
'item') %>
|
53
|
+
</span>
|
54
|
+
</div>
|
55
|
+
<%= t('blacklight.bookmarks.description') %>
|
56
|
+
</li>
|
57
|
+
<% unless @folders.blank? %>
|
58
|
+
<%= render @folders %>
|
59
|
+
<% end %>
|
60
|
+
</ul>
|
61
|
+
</div>
|
62
|
+
|
63
|
+
|
64
|
+
<% end %>
|
65
|
+
|
66
|
+
</div>
|
67
|
+
<div class="col-sm-3">
|
68
|
+
<div id="public_folders_sidebar" class="well well-sm">
|
69
|
+
<ul>
|
70
|
+
<li><%= link_to 'View all shared folders', public_folders_path %></li>
|
71
|
+
</ul>
|
72
|
+
</div>
|
73
|
+
</div>
|
@@ -0,0 +1,27 @@
|
|
1
|
+
<% @page_title = t('blacklight.folders.add_folder') + " - " + application_name %>
|
2
|
+
<div class="col-sm-9">
|
3
|
+
|
4
|
+
<div id="breadcrumb">
|
5
|
+
<ul class="breadcrumb">
|
6
|
+
<li>
|
7
|
+
<%= link_to(t('blacklight.users.account_heading'), current_user) %>
|
8
|
+
<span class="divider"><%= t('blacklight.breadcrumb.separator') %></span>
|
9
|
+
</li>
|
10
|
+
<li>
|
11
|
+
<%= link_to(t('blacklight.folders.list_title'), folders_path) %>
|
12
|
+
<span class="divider"><%= t('blacklight.breadcrumb.separator') %></span>
|
13
|
+
</li>
|
14
|
+
<li class="active">
|
15
|
+
<%= t('blacklight.folders.add_folder') %>
|
16
|
+
</li>
|
17
|
+
</ul>
|
18
|
+
</div>
|
19
|
+
|
20
|
+
<div id="new_folder" class="folder_container">
|
21
|
+
|
22
|
+
<h2><%= t('blacklight.folders.add_folder') %></h2>
|
23
|
+
|
24
|
+
<%= render 'new_edit_form_fields', :form_object => @folder, :submit_button_text => 'Create Folder' %>
|
25
|
+
|
26
|
+
</div>
|
27
|
+
</div>
|
@@ -0,0 +1,44 @@
|
|
1
|
+
<% @page_title = t('blacklight.folders.public_list.title') + " - " + application_name %>
|
2
|
+
<div class="col-sm-9">
|
3
|
+
|
4
|
+
<div id="breadcrumb">
|
5
|
+
<ul class="breadcrumb">
|
6
|
+
<% if current_user %>
|
7
|
+
<li>
|
8
|
+
<%= link_to(t('blacklight.users.account_heading'), current_user) %>
|
9
|
+
<span class="divider"><%= t('blacklight.breadcrumb.separator') %></span>
|
10
|
+
</li>
|
11
|
+
<% end %>
|
12
|
+
<li>
|
13
|
+
<%= link_to(t('blacklight.folders.list_title'), folders_path) %>
|
14
|
+
<span class="divider"><%= t('blacklight.breadcrumb.separator') %></span>
|
15
|
+
</li>
|
16
|
+
<li class="active">
|
17
|
+
<%= t('blacklight.folders.public_list.title') %>
|
18
|
+
</li>
|
19
|
+
</ul>
|
20
|
+
</div>
|
21
|
+
|
22
|
+
<h2>
|
23
|
+
<%= t('blacklight.folders.public_list.title') %>
|
24
|
+
<small id="add_folder">
|
25
|
+
<%= link_to(
|
26
|
+
content_tag(:span, '', :class => 'glyphicon glyphicon-plus') + ' add folder',
|
27
|
+
new_folder_path,
|
28
|
+
:id => 'create_folder_link',
|
29
|
+
:class => 'btn btn-primary btn-sm'
|
30
|
+
) %>
|
31
|
+
</small>
|
32
|
+
</h2>
|
33
|
+
|
34
|
+
<div id="user_folders" class="folder_container">
|
35
|
+
<p><%= t('blacklight.folders.public_list.intro') %></p>
|
36
|
+
<ul id="user_folder_list" class="public_folders">
|
37
|
+
<% unless @folders.blank? %>
|
38
|
+
<%= render @folders %>
|
39
|
+
<% end %>
|
40
|
+
</ul>
|
41
|
+
</div>
|
42
|
+
|
43
|
+
</div>
|
44
|
+
|
@@ -0,0 +1,98 @@
|
|
1
|
+
<% @page_title = @folder.title + " - " + application_name %>
|
2
|
+
|
3
|
+
<%= javascript_include_tag 'commonwealth-vlr-engine/folder_tools' %>
|
4
|
+
|
5
|
+
<div id="content" class="folder_show_container col-sm-9">
|
6
|
+
|
7
|
+
<div id="breadcrumb">
|
8
|
+
<ul class="breadcrumb">
|
9
|
+
<% if current_user %>
|
10
|
+
<li>
|
11
|
+
<%= link_to(t('blacklight.users.account_heading'), current_user) %>
|
12
|
+
<span class="divider"><%= t('blacklight.breadcrumb.separator') %></span>
|
13
|
+
</li>
|
14
|
+
<% end %>
|
15
|
+
<li>
|
16
|
+
<%= link_to(t('blacklight.folders.list_title'), folders_path) %>
|
17
|
+
<span class="divider"><%= t('blacklight.breadcrumb.separator') %></span>
|
18
|
+
</li>
|
19
|
+
<% unless current_user and current_user.folders.include?(@folder) %>
|
20
|
+
<li>
|
21
|
+
<%= link_to(t('blacklight.folders.public_list.title'), public_folders_path) %>
|
22
|
+
<span class="divider"><%= t('blacklight.breadcrumb.separator') %></span>
|
23
|
+
</li>
|
24
|
+
<% end %>
|
25
|
+
<li class="active">
|
26
|
+
<%= @folder.title %>
|
27
|
+
</li>
|
28
|
+
</ul>
|
29
|
+
</div>
|
30
|
+
|
31
|
+
<h2>
|
32
|
+
<%= @folder.title %>
|
33
|
+
<% if current_user && folder_belongs_to_user %>
|
34
|
+
<small id="folder_tools">
|
35
|
+
<div class="folder_visibility">
|
36
|
+
<% if @folder.visibility == 'public' %>
|
37
|
+
<%= content_tag(:span, '', :class => 'glyphicon glyphicon-eye-open') %>
|
38
|
+
<span class="visibility_public"><%= @folder.visibility %></span>
|
39
|
+
<% else %>
|
40
|
+
<%= content_tag(:span, '', :class => 'glyphicon glyphicon-lock') %>
|
41
|
+
<span class="visibility_private"><%= @folder.visibility %></span>
|
42
|
+
<% end %>
|
43
|
+
</div>
|
44
|
+
<%= link_to(content_tag(:span,'',:class=>'glyphicon glyphicon-pencil') + ' ' + t('blacklight.folders.edit'),
|
45
|
+
edit_folder_path(@folder),
|
46
|
+
:class => 'btn btn-default btn-sm',
|
47
|
+
:title => 'edit this folder') %>
|
48
|
+
<%= link_to(content_tag(:span,'',:class=>'glyphicon glyphicon-trash') + ' ' + t('blacklight.folders.delete.delete'),
|
49
|
+
@folder,
|
50
|
+
:class => 'btn btn-default btn-sm',
|
51
|
+
:method => :delete,
|
52
|
+
:data => { :confirm => t('blacklight.folders.delete.confirm') },
|
53
|
+
:title => t('blacklight.folders.delete.delete')) %>
|
54
|
+
<%# if @folder_items.length > 0 %>
|
55
|
+
<%# link_to(content_tag(:span,'',:class=>'glyphicon glyphicon-remove') + ' ' + t('blacklight.folder_items.clear.action'),
|
56
|
+
clear_folder_items_path,
|
57
|
+
:class => 'btn btn-default btn-sm',
|
58
|
+
:method => :delete,
|
59
|
+
:data => { :confirm => t('blacklight.folder_items.clear.confirm') }) %>
|
60
|
+
<%# end %>
|
61
|
+
</small>
|
62
|
+
<% end %>
|
63
|
+
</h2>
|
64
|
+
|
65
|
+
<%# render 'shared/tools' %>
|
66
|
+
<% if @folder.description %>
|
67
|
+
<div id="folder_description">
|
68
|
+
<%= @folder.description %>
|
69
|
+
</div>
|
70
|
+
<% end %>
|
71
|
+
|
72
|
+
<% unless @folder_items.empty? %>
|
73
|
+
|
74
|
+
<%= render 'catalog/sort_and_per_page' %>
|
75
|
+
|
76
|
+
<%= form_tag selected_folder_items_actions_path, :method => :put, :id => "item_actions_form" do %>
|
77
|
+
|
78
|
+
<%= render :partial => 'shared/folder_item_actions' %>
|
79
|
+
|
80
|
+
<%= render_document_index %>
|
81
|
+
|
82
|
+
<% end %>
|
83
|
+
|
84
|
+
<%= render 'catalog/results_pagination' %>
|
85
|
+
|
86
|
+
<% else %>
|
87
|
+
<div id="empty_folder" class="well">
|
88
|
+
<h5><%= t('blacklight.folders.empty') %></h5>
|
89
|
+
<p><%= t('blacklight.folders.help.add_items') %></p>
|
90
|
+
</div>
|
91
|
+
|
92
|
+
<% end %>
|
93
|
+
|
94
|
+
</div>
|
95
|
+
|
96
|
+
<div id="sidebar" class="col-sm-3 folder_facets">
|
97
|
+
<%# render 'catalog/search_sidebar' %>
|
98
|
+
</div><!--/well -->
|
@@ -0,0 +1,125 @@
|
|
1
|
+
<div id="help" class="">
|
2
|
+
<div>
|
3
|
+
<div>
|
4
|
+
<div>
|
5
|
+
<h2>
|
6
|
+
How to use this reader
|
7
|
+
</h2>
|
8
|
+
<p>
|
9
|
+
<i class="fa fa-search"></i> <strong>Search</strong>: search the text of this item<br/>
|
10
|
+
<i class="fa fa-plus"></i> <strong>Zoom</strong>: view a page in greater detail<br/>
|
11
|
+
<i class="fa fa-th-large"></i> <strong>Page List</strong>: view a list of pages for easy navigation<br/>
|
12
|
+
<i class="fa fa-book"></i> <strong>Read</strong>: flip through the pages of the item
|
13
|
+
</p>
|
14
|
+
<section class="keyboard-controls">
|
15
|
+
<h3>
|
16
|
+
Keyboard Navigation
|
17
|
+
</h3>
|
18
|
+
<table>
|
19
|
+
<tr>
|
20
|
+
<th>
|
21
|
+
Go to next page
|
22
|
+
</th>
|
23
|
+
<td>
|
24
|
+
<kbd>Page Down</kbd>, <kbd>spacebar</kbd>, <kbd>j</kbd>
|
25
|
+
</td>
|
26
|
+
</tr>
|
27
|
+
<tr>
|
28
|
+
<th>
|
29
|
+
Go to previous page
|
30
|
+
</th>
|
31
|
+
<td>
|
32
|
+
<kbd>Page Up</kbd>, <kbd>shift+spacebar</kbd>, <kbd>k</kbd>
|
33
|
+
</td>
|
34
|
+
</tr>
|
35
|
+
<tr>
|
36
|
+
<th>
|
37
|
+
Display the 'search inside' form
|
38
|
+
</th>
|
39
|
+
<td>
|
40
|
+
<kbd>q</kbd>
|
41
|
+
</td>
|
42
|
+
</tr>
|
43
|
+
<tr class="requires-rotation">
|
44
|
+
<th>Rotate Left</th>
|
45
|
+
<td>
|
46
|
+
<kbd>alt+left arrow</kbd>
|
47
|
+
</td>
|
48
|
+
</tr>
|
49
|
+
<tr class="requires-rotation">
|
50
|
+
<th>Rotate Right</th>
|
51
|
+
<td>
|
52
|
+
<kbd>alt+right arrow</kbd>
|
53
|
+
</td>
|
54
|
+
</tr>
|
55
|
+
<tr>
|
56
|
+
<th>
|
57
|
+
Switch to page list view
|
58
|
+
</th>
|
59
|
+
<td>
|
60
|
+
<kbd>p</kbd>
|
61
|
+
</td>
|
62
|
+
</tr>
|
63
|
+
<tr class="requires-fullscreen">
|
64
|
+
<th>
|
65
|
+
Enter fullscreen mode
|
66
|
+
</th>
|
67
|
+
<td>
|
68
|
+
<kbd>f</kbd>
|
69
|
+
</td>
|
70
|
+
</tr>
|
71
|
+
<tr>
|
72
|
+
<th>
|
73
|
+
Display help
|
74
|
+
</th>
|
75
|
+
<td>
|
76
|
+
<kbd>?</kbd>
|
77
|
+
</td>
|
78
|
+
</tr>
|
79
|
+
</table>
|
80
|
+
</section>
|
81
|
+
<section class="touch-controls">
|
82
|
+
<h3>
|
83
|
+
Touch Controls
|
84
|
+
</h3>
|
85
|
+
<table>
|
86
|
+
<tr>
|
87
|
+
<th>
|
88
|
+
Go to next page
|
89
|
+
</th>
|
90
|
+
<td>
|
91
|
+
Swipe across screen to the right, or<br>
|
92
|
+
Tap on right edge of screen
|
93
|
+
</td>
|
94
|
+
</tr>
|
95
|
+
<tr>
|
96
|
+
<th>
|
97
|
+
Go to previous page
|
98
|
+
</th>
|
99
|
+
<td>
|
100
|
+
Swipe across screen to the left, or<br>
|
101
|
+
Tap on left edge of screen
|
102
|
+
</td>
|
103
|
+
</tr>
|
104
|
+
<tr>
|
105
|
+
<th>
|
106
|
+
Switch to grid view
|
107
|
+
</th>
|
108
|
+
<td>
|
109
|
+
Tap "Page List" <i class="fa fa-th-large"></i>
|
110
|
+
</td>
|
111
|
+
</tr>
|
112
|
+
<tr>
|
113
|
+
<th>
|
114
|
+
Zoom in on a page
|
115
|
+
</th>
|
116
|
+
<td>
|
117
|
+
Tap "Zoom" <i class="fa fa-plus"></i>
|
118
|
+
</td>
|
119
|
+
</tr>
|
120
|
+
</table>
|
121
|
+
</section>
|
122
|
+
</div>
|
123
|
+
</div>
|
124
|
+
</div>
|
125
|
+
</div>
|
@@ -0,0 +1,185 @@
|
|
1
|
+
<%# wdl-viewer JS to render book viewer %>
|
2
|
+
<%# adapted from https://github.com/LibraryOfCongress/wdl-viewer/examples %>
|
3
|
+
<script type="text/javascript">
|
4
|
+
Modernizr.load([
|
5
|
+
{
|
6
|
+
test: Modernizr.inputtypes.range && Modernizr.history,
|
7
|
+
nope: [
|
8
|
+
/* https://github.com/freqdec/fd-slider */
|
9
|
+
'<%= stylesheet_path('wdl-viewer/fd-slider.min') %>',
|
10
|
+
'<%= javascript_path('wdl-viewer/fd-slider') %>'
|
11
|
+
],
|
12
|
+
callback: function(id, testResult) {
|
13
|
+
if ("fdSlider" in window && typeof(fdSlider.onDomReady) != "undefined") {
|
14
|
+
fdSlider.onDomReady();
|
15
|
+
};
|
16
|
+
}
|
17
|
+
},
|
18
|
+
{
|
19
|
+
test: Modernizr.history,
|
20
|
+
complete: function() {
|
21
|
+
// Slightly wonky double check but callback: won't fire if you don't load anything
|
22
|
+
// and this keeps polyfills in one place:
|
23
|
+
if (!Modernizr.history) {
|
24
|
+
window.history.replaceState = function (state, title, url) {
|
25
|
+
if (document.location.href == url || document.location.pathname == url) {
|
26
|
+
return;
|
27
|
+
} else {
|
28
|
+
document.location.href = url;
|
29
|
+
}
|
30
|
+
}
|
31
|
+
// Force page navigation rather than simply updating the current anchor:
|
32
|
+
$('.next.page, .previous.page').on('click', function (evt) {
|
33
|
+
document.location.href = this.href;
|
34
|
+
document.location.reload();
|
35
|
+
})
|
36
|
+
} else {
|
37
|
+
$(".next.page").on("click", function () {
|
38
|
+
$viewer.trigger("goto-next-page"); return false;
|
39
|
+
})
|
40
|
+
$(".previous.page").on("click", function () {
|
41
|
+
$viewer.trigger("goto-previous-page"); return false;
|
42
|
+
})
|
43
|
+
}
|
44
|
+
}
|
45
|
+
},
|
46
|
+
{
|
47
|
+
test: Modernizr.touch,
|
48
|
+
yep: ['<%= javascript_path('wdl-viewer/jquery.hammer.min') %>'],
|
49
|
+
complete: function(id, testResult) {
|
50
|
+
if (Modernizr.touch && typeof(jQuery.fn.hammer) !== "undefined") {
|
51
|
+
$(window).hammer()
|
52
|
+
.on("swipeleft", function () { $viewer.trigger("goto-next-page"); })
|
53
|
+
.on("swiperight", function () { $viewer.trigger("goto-previous-page"); });
|
54
|
+
|
55
|
+
var lastTimeoutId;
|
56
|
+
|
57
|
+
var viewer = document.getElementById("viewer");
|
58
|
+
// By default, touchmove events as fired when attempting rotation can cause Mobile
|
59
|
+
// Safari to "bounce" the viewport, displaying the standard gray background, which is
|
60
|
+
// quite unpleasant in the middle of a rotation:
|
61
|
+
document.ontouchmove = function(evt) {
|
62
|
+
if (viewer.dataset.activeView != "grid") {
|
63
|
+
evt.preventDefault();
|
64
|
+
}
|
65
|
+
}
|
66
|
+
|
67
|
+
$("#pages").hammer()
|
68
|
+
.on("tap", function (evt) {
|
69
|
+
if (evt.gesture.center.pageX < 50) {
|
70
|
+
$viewer.trigger("goto-previous-page");
|
71
|
+
} else if ($(window).width() - evt.gesture.center.pageX < 50) {
|
72
|
+
$viewer.trigger("goto-next-page");
|
73
|
+
} else {
|
74
|
+
$viewer.trigger("toggle-chrome");
|
75
|
+
}
|
76
|
+
|
77
|
+
if (lastTimeoutId) {
|
78
|
+
window.clearTimeout(lastTimeoutId);
|
79
|
+
}
|
80
|
+
|
81
|
+
lastTimeoutId = window.setTimeout(function () {
|
82
|
+
$viewer.trigger("hide-chrome");
|
83
|
+
}, 6000);
|
84
|
+
})
|
85
|
+
.on("pinchout", function (evt) {
|
86
|
+
if (Math.abs(evt.gesture.rotation) < 20 && evt.gesture.scale > 3.0) {
|
87
|
+
$viewer.trigger("open-seadragon");
|
88
|
+
evt.preventDefault();
|
89
|
+
}
|
90
|
+
})
|
91
|
+
.on("rotate", function (evt) {
|
92
|
+
$viewer.trigger("set-rotation", evt.gesture.rotation);
|
93
|
+
evt.preventDefault();
|
94
|
+
});
|
95
|
+
|
96
|
+
$viewer.on("page-changed", function () {
|
97
|
+
$viewer.trigger("hide-chrome");
|
98
|
+
});
|
99
|
+
}
|
100
|
+
}
|
101
|
+
}
|
102
|
+
]);
|
103
|
+
|
104
|
+
function generateImageUrl(group, index, maxEdge) {
|
105
|
+
// return the pid for the given index
|
106
|
+
var pid = image_files[index-1];
|
107
|
+
return image_server + pid + "/full/pct:30/0/default.jpg"
|
108
|
+
}
|
109
|
+
|
110
|
+
// hijacking this function to return IIIF info.json as tileSource
|
111
|
+
function generateDziUrl(group, index) {
|
112
|
+
var pid = image_files[index-1];
|
113
|
+
return image_server + pid + '/info.json';
|
114
|
+
}
|
115
|
+
|
116
|
+
// use thumbnail300 datastream for thumbnails
|
117
|
+
function generateThumbUrl(group, index) {
|
118
|
+
var pid = image_files[index-1];
|
119
|
+
return '<%= datastream_disseminator_url('xyz', 'thumbnail300') %>'.replace("xyz", pid)
|
120
|
+
}
|
121
|
+
|
122
|
+
// return JSON coords datastream URL
|
123
|
+
function generateWordCoordsUrl(group, index) {
|
124
|
+
var pid = image_files[index-1];
|
125
|
+
return '<%= datastream_disseminator_url('xyz', 'djvuCoords') %>'.replace("xyz", pid)
|
126
|
+
}
|
127
|
+
|
128
|
+
var bookmark = document.location.hash.match(/^#(\d+)\/(\d+)$/);
|
129
|
+
|
130
|
+
var image_server = "<%= IIIF_SERVER['url'] %>";
|
131
|
+
|
132
|
+
var image_files = <%= image_files.to_json.html_safe %>;
|
133
|
+
|
134
|
+
var $window = $(window),
|
135
|
+
$viewer = $("#viewer").wdlViewer({
|
136
|
+
pageGroups: {"1": <%= image_files.count %>}, // List of groups and the last index value in each
|
137
|
+
pageUrlTemplate: "#1/{index}",
|
138
|
+
imageUrlTemplate: generateImageUrl,
|
139
|
+
dziUrlTemplate: generateDziUrl,
|
140
|
+
placeholderSrc: "<%= image_path('commonwealth-vlr-engine/loading-wdl-grid.gif') %>",
|
141
|
+
initialView: "page",
|
142
|
+
seadragonPrefixUrl: '', // "/assets/commonwealth-vlr-engine/openseadragon/"
|
143
|
+
seadragonNavImages: $.parseJSON('<%= osd_nav_images('commonwealth-vlr-engine/openseadragon').html_safe %>'),
|
144
|
+
thumbUrlTemplate: generateThumbUrl,
|
145
|
+
fts: <%= @document[:identifier_ia_id_ssi] ? 'true' : 'false' %>,
|
146
|
+
wordCoordinatesUrlTemplate: generateWordCoordsUrl,
|
147
|
+
ocrSearchPath: "<%= ocr_search_path %>"
|
148
|
+
});
|
149
|
+
/* this makes the text on the controls disappear!
|
150
|
+
if (Modernizr.fontface) {
|
151
|
+
$viewer.find(".controls button, .toolbar a.page").each(function () {
|
152
|
+
var $this = $(this);
|
153
|
+
$this
|
154
|
+
.attr("title", $.trim($this.text()))
|
155
|
+
.empty(); // Clearing the button avoids a Chrome bug which mispositions the icon text
|
156
|
+
});
|
157
|
+
}
|
158
|
+
*/
|
159
|
+
$("input,select").removeAttr("disabled");
|
160
|
+
|
161
|
+
// Help browsers which don't support <link rel="prefetch">:
|
162
|
+
$viewer.trigger("prefetch-adjacent-pages");
|
163
|
+
|
164
|
+
$viewer.on("page-changed", function () {
|
165
|
+
// If you use Google Analytics:
|
166
|
+
// _gaq.push(['_trackPageview', document.location.pathname]);
|
167
|
+
});
|
168
|
+
|
169
|
+
$window.on("resize", function () {
|
170
|
+
/*
|
171
|
+
This works around IE<9's lack of any support for viewport units and WebKit not correctly
|
172
|
+
recalculating them after a window resize (see https://bugs.webkit.org/show_bug.cgi?id=114690)
|
173
|
+
*/
|
174
|
+
$("#pages img").css({
|
175
|
+
"max-height": $window.height(),
|
176
|
+
"max-width": $window.width()
|
177
|
+
});
|
178
|
+
|
179
|
+
$viewer.find("h1").css("max-width", $window.width() - 20);
|
180
|
+
}).trigger("resize");
|
181
|
+
|
182
|
+
if (bookmark) {
|
183
|
+
$viewer.trigger("goto-page", [bookmark[1], bookmark[2]]);
|
184
|
+
}
|
185
|
+
</script>
|