umlaut 3.0.5 → 3.1.0.pre1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (385) hide show
  1. checksums.yaml +15 -0
  2. data/README.md +48 -5
  3. data/app/assets/images/umlaut_icons.png +0 -0
  4. data/app/assets/images/umlaut_icons/famfamfam-book-go.png +0 -0
  5. data/app/assets/images/{famfamfam/book_open.png → umlaut_icons/famfamfam-book-open.png} +0 -0
  6. data/app/assets/images/umlaut_icons/famfamfam-book.png +0 -0
  7. data/app/assets/images/{famfamfam/cross.png → umlaut_icons/famfamfam-cross.png} +0 -0
  8. data/app/assets/images/umlaut_icons/famfamfam-error.png +0 -0
  9. data/app/assets/images/umlaut_icons/famfamfam-help.png +0 -0
  10. data/app/assets/images/umlaut_icons/famfamfam-information.png +0 -0
  11. data/app/assets/images/umlaut_icons/famfamfam-link.png +0 -0
  12. data/app/assets/images/umlaut_icons/famfamfam-page-sound.png +0 -0
  13. data/app/assets/images/umlaut_icons/famfamfam-page-text.png +0 -0
  14. data/app/assets/images/umlaut_icons/famfamfam-page-up.png +0 -0
  15. data/app/assets/images/{famfamfam/page_white.png → umlaut_icons/famfamfam-page-white.png} +0 -0
  16. data/app/assets/images/{famfamfam/readme.html → umlaut_icons/famfamfam-readme.html} +0 -0
  17. data/app/assets/images/{famfamfam/tiny_cross.png → umlaut_icons/famfamfam-tiny-cross.png} +0 -0
  18. data/app/assets/images/{list_closed.png → umlaut_icons/list-closed.png} +0 -0
  19. data/app/assets/images/{list_open.png → umlaut_icons/list-open.png} +0 -0
  20. data/app/assets/javascripts/umlaut.js +5 -4
  21. data/app/assets/javascripts/umlaut/ajax_windows.js +41 -23
  22. data/app/assets/javascripts/umlaut/expand_contract_toggle.js +21 -29
  23. data/app/assets/javascripts/umlaut/load_permalink.js +26 -0
  24. data/app/assets/javascripts/umlaut/search_autocomplete.js +103 -44
  25. data/app/assets/stylesheets/umlaut.css.scss +19 -0
  26. data/app/assets/stylesheets/umlaut/_admin.scss +14 -0
  27. data/app/assets/stylesheets/umlaut/_az.scss +29 -0
  28. data/app/assets/stylesheets/umlaut/_forms.scss +31 -0
  29. data/app/assets/stylesheets/umlaut/_icons.scss +64 -0
  30. data/app/assets/stylesheets/umlaut/_layout.scss +52 -0
  31. data/app/assets/stylesheets/umlaut/_misc.scss +59 -0
  32. data/app/assets/stylesheets/umlaut/_mixins.scss +65 -0
  33. data/app/assets/stylesheets/umlaut/_modal.scss +4 -0
  34. data/app/assets/stylesheets/umlaut/_resolve.scss +308 -0
  35. data/app/assets/stylesheets/umlaut/_results.scss +34 -0
  36. data/app/assets/stylesheets/umlaut/_search.scss +14 -0
  37. data/app/assets/stylesheets/umlaut/_spinner.scss +12 -0
  38. data/app/assets/stylesheets/umlaut/_variables.scss +72 -0
  39. data/app/controllers/export_email_controller.rb +22 -39
  40. data/app/controllers/journal_tocs_controller +90 -0
  41. data/app/controllers/js_helper_controller.rb +2 -3
  42. data/app/controllers/link_router_controller.rb +32 -43
  43. data/app/controllers/open_search_controller.rb +3 -4
  44. data/app/controllers/resolve_controller.rb +68 -107
  45. data/app/controllers/resource_controller.rb +14 -20
  46. data/app/controllers/search_controller.rb +75 -94
  47. data/app/controllers/search_methods/README.md +28 -0
  48. data/app/controllers/search_methods/sfx4.rb +50 -119
  49. data/app/controllers/search_methods/sfx4_solr/README.md +57 -0
  50. data/app/controllers/search_methods/sfx4_solr/local.rb +40 -0
  51. data/app/controllers/search_methods/sfx4_solr/searcher.rb +90 -0
  52. data/app/controllers/store_controller.rb +24 -30
  53. data/app/controllers/umlaut/controller_behavior.rb +45 -17
  54. data/app/controllers/umlaut/error_handling.rb +20 -25
  55. data/{lib → app/controllers}/umlaut_configurable.rb +35 -21
  56. data/app/controllers/umlaut_controller.rb +43 -46
  57. data/app/helpers/emailer_helper.rb +9 -16
  58. data/app/helpers/export_email_helper.rb +8 -8
  59. data/app/helpers/open_search_helper.rb +2 -3
  60. data/app/helpers/resolve_helper.rb +130 -100
  61. data/app/helpers/search_helper.rb +17 -5
  62. data/app/helpers/umlaut/footer_helper.rb +1 -1
  63. data/app/helpers/umlaut/helper.rb +34 -0
  64. data/app/helpers/umlaut/html_head_helper.rb +12 -21
  65. data/{lib → app/mixin_logic}/marc_helper.rb +1 -1
  66. data/{lib → app/mixin_logic}/metadata_helper.rb +6 -5
  67. data/{lib → app/mixin_logic}/umlaut_http.rb +0 -0
  68. data/{lib → app/mixin_logic}/xml_schema_helper.rb +0 -0
  69. data/app/models/collection.rb +97 -95
  70. data/{lib → app/models}/hip3/bib.rb +0 -0
  71. data/{lib → app/models}/hip3/bib_searcher.rb +0 -0
  72. data/{lib → app/models}/hip3/custom_field_lookup.rb +0 -0
  73. data/{lib → app/models}/hip3/holding.rb +0 -0
  74. data/{lib → app/models}/hip3/item.rb +0 -0
  75. data/{lib → app/models}/hip3/receipt.rb +0 -0
  76. data/{lib → app/models}/hip3/serial_copy.rb +0 -0
  77. data/app/models/permalink.rb +3 -8
  78. data/app/models/referent.rb +29 -21
  79. data/app/models/request.rb +19 -8
  80. data/app/models/service_response.rb +24 -3
  81. data/app/models/service_store.rb +108 -39
  82. data/app/models/service_store.rb-NEW +73 -0
  83. data/app/models/service_wave.rb +2 -0
  84. data/app/models/sfx4/abstract/README.md +68 -0
  85. data/app/models/sfx4/abstract/az_extra_info.rb +44 -0
  86. data/app/models/sfx4/abstract/az_letter_group.rb +24 -0
  87. data/app/models/sfx4/abstract/az_title.rb +96 -0
  88. data/app/models/sfx4/abstract/az_title_search.rb +24 -0
  89. data/app/models/sfx4/abstract/base.rb +77 -0
  90. data/app/models/sfx4/global/base.rb +24 -0
  91. data/app/models/sfx4/global/kb_objects.rb +34 -0
  92. data/app/models/sfx4/local/az_extra_info.rb +7 -0
  93. data/app/models/sfx4/local/az_letter_group.rb +7 -0
  94. data/app/models/sfx4/local/az_title.rb +7 -0
  95. data/app/models/sfx4/local/az_title_search.rb +7 -0
  96. data/app/models/sfx4/local/base.rb +26 -0
  97. data/{lib → app/presentation}/section_renderer.rb +0 -12
  98. data/app/referent_filters/dissertation_catch.rb +67 -0
  99. data/{lib → app/referent_filters}/referent_filter.rb +0 -0
  100. data/{lib → app}/service_adaptors/ajax_export.rb +0 -0
  101. data/{lib → app}/service_adaptors/amazon.rb +2 -0
  102. data/{lib → app}/service_adaptors/blacklight.rb +22 -10
  103. data/{lib → app}/service_adaptors/book_finder.rb +0 -0
  104. data/{lib → app}/service_adaptors/bx.rb +0 -0
  105. data/{lib → app}/service_adaptors/cover_thing.rb +0 -0
  106. data/{lib → app}/service_adaptors/dummy_service.rb +0 -0
  107. data/{lib → app}/service_adaptors/elsevier_cover.rb +0 -0
  108. data/{lib → app}/service_adaptors/email_export.rb +0 -0
  109. data/{lib → app}/service_adaptors/ezproxy.rb +0 -0
  110. data/{lib → app}/service_adaptors/google_book_search.rb +0 -0
  111. data/app/service_adaptors/google_scholar_link.rb +71 -0
  112. data/{lib → app}/service_adaptors/gpo.rb +0 -0
  113. data/{lib → app}/service_adaptors/hathi_trust.rb +0 -0
  114. data/{lib → app}/service_adaptors/hip3_service.rb +0 -0
  115. data/{lib → app}/service_adaptors/hip_holding_search.rb +0 -0
  116. data/{lib → app}/service_adaptors/internet_archive.rb +0 -0
  117. data/{lib → app}/service_adaptors/isbn_db.rb +0 -0
  118. data/{lib → app}/service_adaptors/isi.rb +22 -13
  119. data/{lib → app}/service_adaptors/jcr.rb +0 -0
  120. data/{lib → app}/service_adaptors/opac.rb +0 -0
  121. data/{lib → app}/service_adaptors/open_library.rb +0 -0
  122. data/{lib → app}/service_adaptors/open_library_cover.rb +0 -0
  123. data/{lib → app}/service_adaptors/pubmed.rb +0 -0
  124. data/{lib → app}/service_adaptors/request_to_fixture.rb +0 -0
  125. data/{lib → app}/service_adaptors/scopus.rb +0 -0
  126. data/{lib → app/service_adaptors}/service.rb +3 -3
  127. data/{lib → app}/service_adaptors/sfx.rb +154 -11
  128. data/{lib → app}/service_adaptors/sfx_backchannel_record.rb +0 -0
  129. data/app/service_adaptors/tr_link.rb +267 -0
  130. data/app/service_adaptors/tr_links.rb +278 -0
  131. data/{lib → app}/service_adaptors/txt_holding_export.rb +0 -0
  132. data/{lib → app}/service_adaptors/ulrichs_cover.rb +0 -0
  133. data/{lib → app}/service_adaptors/ulrichs_link.rb +0 -0
  134. data/{lib → app}/service_adaptors/worldcat.rb +0 -0
  135. data/{lib → app}/service_adaptors/worldcat_identities.rb +0 -0
  136. data/app/views/admin/service_errors/_dispatched_service.html.erb +13 -13
  137. data/app/views/admin/service_errors/index.html.erb +11 -21
  138. data/app/views/export_email/email.html.erb +17 -2
  139. data/app/views/export_email/send_email.html.erb +2 -1
  140. data/app/views/export_email/send_txt.html.erb +2 -1
  141. data/app/views/export_email/txt.html.erb +30 -2
  142. data/app/views/layouts/umlaut.html.erb +29 -49
  143. data/app/views/resolve/_background_progress.html.erb +43 -50
  144. data/app/views/resolve/_background_updater.html.erb +23 -36
  145. data/app/views/resolve/_citation.html.erb +63 -87
  146. data/app/views/resolve/_compact_citation.html.erb +15 -33
  147. data/app/views/resolve/_cover_image.html.erb +34 -43
  148. data/app/views/resolve/_fulltext.html.erb +29 -50
  149. data/app/views/resolve/_help.html.erb +17 -14
  150. data/app/views/resolve/_holding.html.erb +65 -82
  151. data/app/views/resolve/_manually_entered_warning.html.erb +7 -0
  152. data/app/views/resolve/_modal.html.erb +19 -0
  153. data/app/views/resolve/_related_items.html.erb +20 -35
  154. data/app/views/resolve/_search_inside.html.erb +34 -57
  155. data/app/views/resolve/_section_display.html.erb +34 -46
  156. data/app/views/resolve/_section_heading.html.erb +17 -0
  157. data/app/views/resolve/_service_errors.html.erb +27 -28
  158. data/app/views/resolve/_standard_response_item.html.erb +42 -72
  159. data/app/views/resolve/background_status.html.erb +19 -23
  160. data/app/views/resolve/get_permalink.html.erb +6 -0
  161. data/app/views/resolve/index.html.erb +47 -73
  162. data/app/views/search/_a_to_z.html.erb +9 -6
  163. data/app/views/search/_citation.html.erb +73 -94
  164. data/app/views/search/_pager.html.erb +6 -6
  165. data/app/views/search/books.html.erb +34 -102
  166. data/app/views/search/journal_search.html.erb +53 -90
  167. data/app/views/search/journals.html.erb +73 -167
  168. data/app/views/umlaut/_header.html.erb +9 -0
  169. data/app/views/umlaut/error.html.erb +44 -44
  170. data/config/locales/en.yml +5 -0
  171. data/lib/{CronTab.rb → cron_tab.rb} +0 -0
  172. data/lib/generators/templates/umlaut_services.yml +57 -43
  173. data/lib/generators/umlaut/install_generator.rb +12 -0
  174. data/lib/service_adaptors/README.md +0 -0
  175. data/lib/tasks/umlaut.rake +8 -24
  176. data/lib/umlaut.rb +1 -21
  177. data/lib/umlaut/version.rb +1 -1
  178. data/test/README.md +75 -0
  179. data/test/dummy/app/controllers/umlaut_controller.rb +3 -3
  180. data/test/dummy/config/application.rb +3 -0
  181. data/test/dummy/config/sunspot.yml +20 -0
  182. data/test/dummy/config/travis_database.yml +96 -0
  183. data/test/dummy/config/umlaut_services.yml +16 -23
  184. data/test/dummy/db/migrate/20120927163304_sfx4_global.rb +26 -0
  185. data/test/dummy/db/migrate/20120927164040_sfx4_local.rb +54 -0
  186. data/test/dummy/tmp/cache/assets/BBA/6A0/sprockets%2F2a335471966f33256b321f8324041981 +0 -0
  187. data/test/dummy/tmp/cache/assets/C2A/410/sprockets%2Fd654b74912b4773a2534616863fb6565 +0 -0
  188. data/test/dummy/tmp/cache/assets/C45/A30/sprockets%2F39494895e462697b478d3d0c79298a26 +0 -0
  189. data/test/dummy/tmp/cache/assets/C49/730/sprockets%2F212d35831188417b5131e3e693aa69a6 +0 -0
  190. data/test/dummy/tmp/cache/assets/C55/1D0/sprockets%2F5af2f2a3403040f736981863fd278529 +0 -0
  191. data/test/dummy/tmp/cache/assets/C5A/A80/sprockets%2F2328c7370b56b4151776981a5f6d394e +0 -0
  192. data/test/dummy/tmp/cache/assets/C5F/340/sprockets%2F99692920160b7a279b86a80415b79db7 +0 -0
  193. data/test/dummy/tmp/cache/assets/C70/4D0/sprockets%2F034ad2036e623081bd352800786dfe80 +0 -0
  194. data/test/dummy/tmp/cache/assets/C80/980/sprockets%2Fc94807409c1523d43e18d25f35d93c41 +0 -0
  195. data/test/dummy/tmp/cache/assets/C94/E20/sprockets%2F19579abc248373f419b1c3e287d74598 +0 -0
  196. data/test/dummy/tmp/cache/assets/C98/330/sprockets%2F0c81574ba94abc10657315d4190c201f +0 -0
  197. data/test/dummy/tmp/cache/assets/CA4/440/sprockets%2F0feb4425db6319d7d0582192a503671b +0 -0
  198. data/test/dummy/tmp/cache/assets/CA7/E80/sprockets%2F33310f455a870eaedd6d938e30620714 +0 -0
  199. data/test/dummy/tmp/cache/assets/CB8/3C0/sprockets%2F697cd846490fda9f0e20c558320610f8 +0 -0
  200. data/test/dummy/tmp/cache/assets/CBF/B60/sprockets%2F08ca89671549936265dcb673bf02e36f +0 -0
  201. data/test/dummy/tmp/cache/assets/CC7/F10/sprockets%2F939637f806eef3f0f21584659458ab2e +0 -0
  202. data/test/dummy/tmp/cache/assets/CC9/9F0/sprockets%2F306166316e2cafd13c15e62b51a2339d +0 -0
  203. data/test/dummy/tmp/cache/assets/CD8/370/sprockets%2F357970feca3ac29060c1e3861e2c0953 +0 -0
  204. data/test/dummy/tmp/cache/assets/CF7/2B0/sprockets%2F25a7c73655bd3598173b39d9f98bcd46 +0 -0
  205. data/test/dummy/tmp/cache/assets/CF8/DA0/sprockets%2Ff5b8c8499d3da954d392fa57739503c5 +0 -0
  206. data/test/dummy/tmp/cache/assets/CF9/590/sprockets%2F096bcc45cd31b3796fa2121cd203215f +0 -0
  207. data/test/dummy/tmp/cache/assets/CFE/080/sprockets%2F37fe9f4255baddbd549a659914929398 +0 -0
  208. data/test/dummy/tmp/cache/assets/D04/CC0/sprockets%2Fe9c1b92f2e437e1bbbe020d718739220 +0 -0
  209. data/test/dummy/tmp/cache/assets/D0B/090/sprockets%2F58009091c95e3ac328c91c68fca30e0e +0 -0
  210. data/test/dummy/tmp/cache/assets/D1A/B50/sprockets%2F2db5892438129fe94da8429b8be114ec +0 -0
  211. data/test/dummy/tmp/cache/assets/D2D/1A0/sprockets%2F376426b4896a3cff7969ce6c7b387e0e +0 -0
  212. data/test/dummy/tmp/cache/assets/D32/A10/sprockets%2F13fe41fee1fe35b49d145bcc06610705 +0 -0
  213. data/test/dummy/tmp/cache/assets/D37/2B0/sprockets%2F40834fb07d7318c1fddd5003bd9e04f6 +0 -0
  214. data/test/dummy/tmp/cache/assets/D43/0D0/sprockets%2F682843a8d0795a5fbcfeb2f0c81727d0 +0 -0
  215. data/test/dummy/tmp/cache/assets/D46/F80/sprockets%2Fb15c08e749067d7aad9baf5e9388221c +0 -0
  216. data/test/dummy/tmp/cache/assets/D4E/1B0/sprockets%2Ff7cbd26ba1d28d48de824f0e94586655 +0 -0
  217. data/test/dummy/tmp/cache/assets/D5A/EA0/sprockets%2Fd771ace226fc8215a3572e0aa35bb0d6 +0 -0
  218. data/test/dummy/tmp/cache/assets/D6C/7D0/sprockets%2F8a05d6981ec0d38c51739bef0b3a9c2b +0 -0
  219. data/test/dummy/tmp/cache/assets/D6E/CF0/sprockets%2F5661c6e4f0cea86fe4523f27261aade5 +0 -0
  220. data/test/dummy/tmp/cache/assets/D94/FF0/sprockets%2F3b56a1aa77de0d570c38a4a9d5f4b1d6 +0 -0
  221. data/test/dummy/tmp/cache/assets/D97/6B0/sprockets%2Fb070e8c799d1a4ad5e62e0a1ae3b83e6 +0 -0
  222. data/test/dummy/tmp/cache/assets/D9A/2F0/sprockets%2Fbba0f4b972dc53c15ce6c8c1993b82a4 +0 -0
  223. data/test/dummy/tmp/cache/assets/D9C/860/sprockets%2Fec2d9f20b270d70e698ff33e53c21fca +0 -0
  224. data/test/dummy/tmp/cache/assets/DA6/A80/sprockets%2F92e26d8e58d5bcc8b8f6c25d1b05b9c1 +0 -0
  225. data/test/dummy/tmp/cache/assets/DA8/BB0/sprockets%2F0cf1c7e9f966dce425517c0e2a844efe +0 -0
  226. data/test/dummy/tmp/cache/assets/DA9/BC0/sprockets%2Fcb9062b73291befe5e5bf2a70978dec8 +0 -0
  227. data/test/dummy/tmp/cache/assets/DB6/ED0/sprockets%2Ff4482d9b9f76fb65eef16430bde2f8e6 +0 -0
  228. data/test/dummy/tmp/cache/assets/DDC/400/sprockets%2Fcffd775d018f68ce5dba1ee0d951a994 +0 -0
  229. data/test/dummy/tmp/cache/assets/DE8/790/sprockets%2Fd1333bde2b9aafcc712d11dd09ab35d8 +0 -0
  230. data/test/dummy/tmp/cache/assets/DF7/960/sprockets%2F99ac6db10b44a64fbba4ee847b35ba8b +0 -0
  231. data/test/dummy/tmp/cache/assets/DFD/300/sprockets%2Fabac9489cf7f1db8ef00d72a1571ee1e +0 -0
  232. data/test/dummy/tmp/cache/assets/E02/C10/sprockets%2F1463cadfce3fc70e61d482f9fcb75ac7 +0 -0
  233. data/test/dummy/tmp/cache/assets/E04/890/sprockets%2F2f5173deea6c795b8fdde723bb4b63af +0 -0
  234. data/test/dummy/tmp/cache/assets/E38/FE0/sprockets%2Fe1fc875efa817cbb94a5d8de25ea4e6b +0 -0
  235. data/test/dummy/tmp/cache/assets/E50/F00/sprockets%2Fec61afdbb1cc4df075e3dad46f0af571 +0 -0
  236. data/test/dummy/tmp/cache/assets/E5E/5F0/sprockets%2Feffaeb4d7f9bf4c0cc840ff320fde046 +0 -0
  237. data/test/dummy/tmp/cache/assets/E5F/960/sprockets%2Fdc007b6cad5c7ef08e33ec28cfff0ef6 +0 -0
  238. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_accordion.scssc +0 -0
  239. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_alerts.scssc +0 -0
  240. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_breadcrumbs.scssc +0 -0
  241. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_button-groups.scssc +0 -0
  242. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_buttons.scssc +0 -0
  243. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_carousel.scssc +0 -0
  244. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_close.scssc +0 -0
  245. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_code.scssc +0 -0
  246. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_component-animations.scssc +0 -0
  247. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_dropdowns.scssc +0 -0
  248. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_forms.scssc +0 -0
  249. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_grid.scssc +0 -0
  250. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_hero-unit.scssc +0 -0
  251. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_labels-badges.scssc +0 -0
  252. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_layouts.scssc +0 -0
  253. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_media.scssc +0 -0
  254. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_mixins.scssc +0 -0
  255. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_modals.scssc +0 -0
  256. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_navbar.scssc +0 -0
  257. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_navs.scssc +0 -0
  258. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_pager.scssc +0 -0
  259. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_pagination.scssc +0 -0
  260. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_popovers.scssc +0 -0
  261. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_progress-bars.scssc +0 -0
  262. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_reset.scssc +0 -0
  263. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_responsive-1200px-min.scssc +0 -0
  264. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_responsive-767px-max.scssc +0 -0
  265. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_responsive-768px-979px.scssc +0 -0
  266. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_responsive-navbar.scssc +0 -0
  267. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_responsive-utilities.scssc +0 -0
  268. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_scaffolding.scssc +0 -0
  269. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_sprites.scssc +0 -0
  270. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_tables.scssc +0 -0
  271. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_thumbnails.scssc +0 -0
  272. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_tooltip.scssc +0 -0
  273. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_type.scssc +0 -0
  274. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_utilities.scssc +0 -0
  275. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_variables.scssc +0 -0
  276. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/_wells.scssc +0 -0
  277. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/bootstrap.scssc +0 -0
  278. data/test/dummy/tmp/cache/sass/310d901c169042855feb8cf3903e1e2821d27f13/responsive.scssc +0 -0
  279. data/test/dummy/tmp/cache/sass/3af72421a0fbed39d3047687ca0ad6e6e5545041/_admin.scssc +0 -0
  280. data/test/dummy/tmp/cache/sass/3af72421a0fbed39d3047687ca0ad6e6e5545041/_az.scssc +0 -0
  281. data/test/dummy/tmp/cache/sass/3af72421a0fbed39d3047687ca0ad6e6e5545041/_base.scssc +0 -0
  282. data/test/dummy/tmp/cache/sass/3af72421a0fbed39d3047687ca0ad6e6e5545041/_forms.scssc +0 -0
  283. data/test/dummy/tmp/cache/sass/3af72421a0fbed39d3047687ca0ad6e6e5545041/_icons.scssc +0 -0
  284. data/test/dummy/tmp/cache/sass/3af72421a0fbed39d3047687ca0ad6e6e5545041/_misc.scssc +0 -0
  285. data/test/dummy/tmp/cache/sass/3af72421a0fbed39d3047687ca0ad6e6e5545041/_mixins.scssc +0 -0
  286. data/test/dummy/tmp/cache/sass/3af72421a0fbed39d3047687ca0ad6e6e5545041/_modal.scssc +0 -0
  287. data/test/dummy/tmp/cache/sass/3af72421a0fbed39d3047687ca0ad6e6e5545041/_resolve.scssc +0 -0
  288. data/test/dummy/tmp/cache/sass/3af72421a0fbed39d3047687ca0ad6e6e5545041/_results.scssc +0 -0
  289. data/test/dummy/tmp/cache/sass/3af72421a0fbed39d3047687ca0ad6e6e5545041/_search.scssc +0 -0
  290. data/test/dummy/tmp/cache/sass/3af72421a0fbed39d3047687ca0ad6e6e5545041/_spinner.scssc +0 -0
  291. data/test/dummy/tmp/cache/sass/3af72421a0fbed39d3047687ca0ad6e6e5545041/_variables.scssc +0 -0
  292. data/test/dummy/tmp/cache/sass/93d65682d6bddb0b2e6788c1232f4849af20a35e/bootstrap-responsive.scssc +0 -0
  293. data/test/dummy/tmp/cache/sass/93d65682d6bddb0b2e6788c1232f4849af20a35e/bootstrap.scssc +0 -0
  294. data/test/dummy/tmp/cache/sass/fb58c04fd15fcc38a8c4d91b7070bcfeaf1c3799/umlaut.css.scssc +0 -0
  295. data/test/fixtures/dispatched_services.yml +0 -4
  296. data/test/fixtures/permalinks.yml +23 -4
  297. data/test/fixtures/referent_values.yml +226 -1493
  298. data/test/fixtures/referents.yml +14 -137
  299. data/test/fixtures/requests.yml +22 -260
  300. data/test/fixtures/service_responses.yml +169 -5
  301. data/test/fixtures/sfx4/global/KB_OBJECTS.yml +46 -0
  302. data/test/fixtures/sfx4/local/AZ_EXTRA_INFO.yml +4802 -0
  303. data/test/fixtures/sfx4/local/AZ_LETTER_GROUP.yml +105 -0
  304. data/test/fixtures/sfx4/local/AZ_TITLE.yml +165 -0
  305. data/test/fixtures/sfx4/local/AZ_TITLE_SEARCH.yml +341 -0
  306. data/test/fixtures/sfx_urls.yml +3 -0
  307. data/test/functional/export_email_controller_test.rb +43 -0
  308. data/test/functional/link_router_controller_test.rb +16 -0
  309. data/test/functional/resolve_controller_test.rb +102 -0
  310. data/test/functional/search_controller_test.rb +40 -0
  311. data/test/functional/store_controller_test.rb +29 -0
  312. data/test/helper/list_with_limit_test.rb +90 -0
  313. data/test/integration/permalinks_test.rb +14 -0
  314. data/test/support/search_methods/test_case.rb +0 -0
  315. data/test/support/service_adaptors/test_case.rb +0 -0
  316. data/test/support/test_with_cassette.rb +37 -0
  317. data/test/test_helper.rb +76 -30
  318. data/test/unit/aws_product_sign_test.rb +2 -0
  319. data/test/unit/determine_services_test.rb +163 -0
  320. data/test/unit/google_book_search_test.rb +8 -25
  321. data/test/unit/google_scholar_link_test.rb +81 -0
  322. data/test/unit/internet_archive_test.rb +33 -0
  323. data/test/unit/permalink_test.rb +15 -0
  324. data/test/unit/service_store_test.rb +47 -0
  325. data/test/unit/service_test.rb +28 -13
  326. data/test/unit/sfx/sfx_target_roll_up_test.rb +369 -0
  327. data/test/unit/sfx4_search_test.rb +102 -0
  328. data/test/unit/sfx4_solr_search_test.rb +77 -0
  329. data/test/unit/sfx_test.rb +38 -0
  330. data/test/unit/worldcat_test.rb +7 -0
  331. data/test/vcr_cassettes/google_book_search/frankenstein_by_OCLC_number.yml +107 -0
  332. data/test/vcr_cassettes/internet_archive/momo_by_title_author.yml +116 -0
  333. data/test/vcr_cassettes/resolve/fulltext_with_edition_warning.yml +44 -0
  334. data/test/vcr_cassettes/resolve/no_holdings.yml +649 -0
  335. data/test/vcr_cassettes/resolve/nytimes_by_issn.yml +224 -0
  336. data/test/vcr_cassettes/sfx/nytimes_by_issn.yml +1395 -0
  337. data/test/vcr_cassettes/sfx4_solr/find_by_group.yml +109 -0
  338. data/test/vcr_cassettes/sfx4_solr/find_by_title_begins_with.yml +33 -0
  339. data/test/vcr_cassettes/sfx4_solr/find_by_title_contains.yml +34 -0
  340. data/test/vcr_cassettes/sfx4_solr/find_by_title_exact.yml +32 -0
  341. data/test/view/holding_test.rb +30 -0
  342. metadata +435 -179
  343. data/app/assets/images/export_bg_bot.gif +0 -0
  344. data/app/assets/images/export_bg_mid.gif +0 -0
  345. data/app/assets/images/export_bg_top.gif +0 -0
  346. data/app/assets/images/famfamfam/page_sound.gif +0 -0
  347. data/app/assets/images/famfamfam/page_text.gif +0 -0
  348. data/app/assets/images/famfamfam/page_up.gif +0 -0
  349. data/app/assets/images/ico_go.gif +0 -0
  350. data/app/assets/images/more_info.gif +0 -0
  351. data/app/assets/images/rails.png +0 -0
  352. data/app/assets/images/request.gif +0 -0
  353. data/app/assets/javascripts/umlaut/simple_visible_toggle.js +0 -8
  354. data/app/assets/stylesheets/umlaut.css +0 -900
  355. data/app/assets/stylesheets/umlaut/_background_progress_spinner.scss +0 -21
  356. data/app/assets/stylesheets/umlaut/_expand_contract.scss +0 -28
  357. data/app/controllers/search_methods/sfx3.rb +0 -148
  358. data/app/models/sfx_db.rb +0 -10
  359. data/app/models/sfx_db/az_additional_title.rb +0 -11
  360. data/app/models/sfx_db/az_letter_group.rb +0 -11
  361. data/app/models/sfx_db/az_title.rb +0 -40
  362. data/app/models/sfx_db/az_title_v2.rb +0 -34
  363. data/app/models/sfx_db/isbn.rb +0 -12
  364. data/app/models/sfx_db/issn.rb +0 -12
  365. data/app/models/sfx_db/object.rb +0 -35
  366. data/app/models/sfx_db/object_portfolio.rb +0 -6
  367. data/app/models/sfx_db/publisher.rb +0 -10
  368. data/app/models/sfx_db/sfx_db_base.rb +0 -58
  369. data/app/models/sfx_db/target.rb +0 -10
  370. data/app/models/sfx_db/target_service.rb +0 -10
  371. data/app/models/sfx_db/title.rb +0 -10
  372. data/app/views/export_email/_email.html.erb +0 -25
  373. data/app/views/export_email/_send_email.html.erb +0 -3
  374. data/app/views/export_email/_send_txt.html.erb +0 -3
  375. data/app/views/export_email/_txt.html.erb +0 -62
  376. data/lib/holding.rb +0 -32
  377. data/lib/opensearch_feed.rb +0 -398
  378. data/lib/opensearch_query.rb +0 -98
  379. data/lib/referent_filters/dissertation_catch.rb +0 -45
  380. data/lib/service_adaptors/journal_tocs.progress +0 -68
  381. data/lib/service_adaptors/primo_service.rb +0 -452
  382. data/lib/service_adaptors/primo_source.rb +0 -82
  383. data/lib/umlaut/default_configuration.rb +0 -5
  384. data/test/dummy/config/primo.yml +0 -271
  385. data/test/unit/primo_service_test.rb +0 -947
@@ -0,0 +1,34 @@
1
+ .umlaut-results {
2
+ @extend .umlaut-separator;
3
+ background-color: $umlautResultsBackgroundColor;
4
+ }
5
+
6
+ .umlaut-result {
7
+ background-color: $umlautResultItemBackgroundColor;
8
+ border-color: $umlautResultItemBorderColor;
9
+ margin-bottom: $baseLineHeight/2;
10
+ dl {
11
+ margin: 0;
12
+ dt, dd {
13
+ margin-bottom: $baseLineHeight/4;
14
+ }
15
+ }
16
+
17
+ padding: $umlautIndent;
18
+
19
+ .umlaut-citation-link {
20
+ text-align: right;
21
+ }
22
+ }
23
+
24
+ .umlaut-pagination {
25
+ font-size: 125%;
26
+ }
27
+
28
+ @media (max-width: 767px) {
29
+ .umlaut-result {
30
+ .umlaut-citation-link {
31
+ text-align: left;
32
+ }
33
+ }
34
+ }
@@ -0,0 +1,14 @@
1
+ .umlaut-search-form {
2
+ padding: 10px;
3
+ border: 1px solid $umlautSearchFormBorderColor;
4
+ background-color: $umlautSearchFormBackgroundColor;
5
+ margin-top: $baseLineHeight;
6
+ margin-bottom: $baseLineHeight;
7
+ @include border-radius($baseBorderRadius);
8
+ legend {
9
+ border-color: $umlautSearchFormBorderColor;
10
+ }
11
+ .row-fluid {
12
+ margin-bottom: $baseLineHeight;
13
+ }
14
+ }
@@ -0,0 +1,12 @@
1
+ .background_progress_spinner {
2
+ @extend .muted;
3
+ img {
4
+ vertical-align: top;
5
+ margin-top: 1px;
6
+ }
7
+ }
8
+
9
+ .umlaut-resource-info .background_progress_spinner {
10
+ padding-left: 24px;
11
+ padding-top: 8px;
12
+ }
@@ -0,0 +1,72 @@
1
+ // See also, possible umlaut theme over-ride of default bootstrap
2
+ // variables in umalut.scss
3
+
4
+ // Basic colors, all other colors by default are defined in terms of these
5
+ // Overall Border and Background
6
+ $umlautBorderColor: #c7c7c7 !default; //#d1d1d1
7
+ $umlautBackgroundColor: #f9f9f7 !default;
8
+ $umlautAltBackgroundColor: #e1e1e1 !default; // Sidebar and navbar #dadada
9
+ $umlautHighlightedBackgroundColor: white !default;
10
+ $umlautAvailableColor: #00CC33 !default; // Available Color, used for text
11
+ $umlautUnavailableColor: #FF3E00 !default; // Unavailable Color, used for text
12
+
13
+ // Closer to old Umlaut colors, for nostaligia or for a change:
14
+ // $umlautBorderColor: #ebb211;
15
+ // $umlautBackgroundColor: #fffdea;
16
+ // $umlautAltBackgroundColor: #fcf1d4;
17
+ // $umlautHighlightedBackgroundColor: white;
18
+ // $umlautHighlightedSectionBorderColor: #dedede;
19
+ // $umlautAvailableColor: #00CC33;
20
+ // $umlautUnavailableColor: red;
21
+
22
+ // And another possibility
23
+ // $umlautBackgroundColor: #FEF9ED; #f8f3ea
24
+ // $umlautAltBackgroundColor: #e1d3cc;
25
+ // $umlautBorderColor: darken($umlautAltBackgroundColor, 10%);
26
+ // $umlautHighlightedBackgroundColor: white;
27
+ // $umlautAvailableColor: #00CC33;
28
+ // $umlautUnavailableColor: red;
29
+
30
+
31
+ // container padding used for page margins/gutters and between columns.
32
+ // at large screens, sometimes *2.
33
+ $umlautContainerPadding: 20px !default;
34
+ $umlautContainerMaxWidth: 1100px !default;
35
+ // important that umlautIndent is exactly enough to indent past umlaut
36
+ // list item icons in hanging indents
37
+ $umlautIndent: 20px !default;
38
+ $umlautBorderRadiusExtraLarge: 12px !default;
39
+
40
+ // Header nav bar.
41
+ $umlautHeaderBackgroundColor: $umlautAltBackgroundColor !default;
42
+ $umlautHeaderBorderColor: $umlautBorderColor !default;
43
+ // Search Border and Background
44
+ $umlautSearchFormBackgroundColor: $umlautAltBackgroundColor !default;
45
+ $umlautSearchFormBorderColor: $umlautBorderColor !default;
46
+ // Search Results
47
+ $umlautResultsBackgroundColor: $umlautBackgroundColor !default;
48
+ $umlautResultItemBackgroundColor: $umlautAltBackgroundColor !default;
49
+ $umlautResultItemBorderColor: $umlautBorderColor !default;
50
+
51
+ // A-Z List input -- actual list of A,B..Z buttons
52
+ $umlautAzLinkColor: $linkColor !default;
53
+ $umlautAzBorderColor: $umlautBorderColor !default;
54
+ $umlautAzBackgroundColor: $umlautBackgroundColor !default;
55
+ $umlautAzHoverBackgroundColor: $umlautAltBackgroundColor !default;
56
+ // Auto Complete Border and Background
57
+ $umlautAutoCompleteBorderColor: $umlautAzBorderColor !default;
58
+ $umlautAutoCompleteBackgroundColor: $umlautHighlightedBackgroundColor !default;
59
+
60
+ // Resolve Border and Backgrounds
61
+ $umlautMainBackgroundColor: $umlautBackgroundColor !default;
62
+ $umlautSidebarBorderColor: $umlautBorderColor !default;
63
+ $umlautSidebarBackgroundColor: $umlautAltBackgroundColor !default;
64
+ // Highlighted Sections Border and Backgrounds
65
+ $umlautHighlightedSectionBorderColor: $umlautBorderColor !default;
66
+ $umlautHighlightedSectionBackgroundColor: $umlautHighlightedBackgroundColor !default;
67
+ // Resolve Errors Border and Backgrounds
68
+ $umlautResolveErrorBorderColor: $umlautBorderColor !default;
69
+ $umlautResolveErrorBackgroundColor: $umlautHighlightedBackgroundColor !default;
70
+ // Debug Info Border and Backgrounds
71
+ $umlautDebugInfoBorderColor: $umlautBorderColor !default;
72
+ $umlautDebugInfoBackgroundColor: $umlautHighlightedBackgroundColor !default;
@@ -1,77 +1,60 @@
1
1
  class ExportEmailController < UmlautController
2
-
2
+
3
3
  before_filter :load_objects
4
- layout Proc.new { |controller|
5
- if (controller.request.xhr? || controller.params["X-Requested-With"] == "XmlHttpRequest")
6
- nil
7
- else
8
- umlaut_config.layout
9
- end
10
- }
4
+ layout :search_layout_except_xhr
11
5
 
12
6
  def load_objects
13
7
  @svc_response = ServiceResponse.find(params[:id])
14
8
  @user_request = @svc_response.request if @svc_response
15
9
  end
16
-
17
- def email
18
- end
19
-
20
- def txt
21
- end
22
-
10
+
23
11
  def send_email
24
12
  @email = params[:email]
25
13
  @fulltexts = @user_request.get_service_type('fulltext', { :refresh=>true })
26
14
  @holdings = @user_request.get_service_type('holding', { :refresh=>true })
27
15
  if valid_email?
28
- Emailer.citation(@email, @user_request, @fulltexts, @holdings).deliver
29
- respond_to do |format|
30
- format.html { render }
31
- end
16
+ Emailer.citation(@email, @user_request, @fulltexts, @holdings).deliver
32
17
  else
33
- @partial = "email"
34
- flash[:error] = email_validation_error
35
- redirect_to params_preserve_xhr(params.merge(:action => "email"))
18
+ flash[:alert] = email_validation_error
19
+ render :email and return
36
20
  end
37
21
  end
38
-
22
+
39
23
  def send_txt
40
24
  @number = params[:number]
41
25
  # Remove any punctuation or spaces etc
42
26
  @number.gsub!(/[^\d]/, '') if @number
43
27
  @provider = params[:provider]
44
28
  @email = "#{@number}@#{@provider}" unless @number.nil? or @provider.nil?
45
- @holding_id = params[:holding]
29
+ @holding = params[:holding]
46
30
  if valid_txt_number? && valid_txt_holding?
47
- Emailer.short_citation(@email, @user_request, holding_location(@holding_id), call_number(@holding_id)).deliver
48
- render # send_txt.rhtml
49
- else
50
- flash[:error] = txt_validation_error
51
- redirect_to params_preserve_xhr(params.merge(:action => "txt"))
52
- end
31
+ Emailer.short_citation(@email, @user_request, holding_location(@holding), call_number(@holding)).deliver
32
+ else
33
+ flash[:alert] = txt_validation_error
34
+ render :txt and return
35
+ end
53
36
  end
54
-
37
+
55
38
  private
56
39
  def valid_txt_number?
57
- return (! @number.blank?) && @number.length == 10
40
+ ((not @number.blank?) && @number.length == 10)
58
41
  end
59
42
 
60
43
  def valid_txt_holding?
61
- return ! @holding_id.blank?
44
+ (not @holding.blank?)
62
45
  end
63
-
46
+
64
47
  def valid_email?
65
- return @email =~ /^([^@\s]+)@((?:[-a-z0-9]+\.)+[a-z]{2,})$/i
48
+ (@email =~ /^([^@\s]+)@((?:[-a-z0-9]+\.)+[a-z]{2,})$/i)
66
49
  end
67
-
50
+
68
51
  def txt_validation_error
69
52
  errors = []
70
53
  errors << "a valid number" unless valid_txt_number?
71
54
  errors << "the item you wish to send" unless valid_txt_holding?
72
55
  errors
73
56
  end
74
-
57
+
75
58
  def email_validation_error
76
59
  errors = []
77
60
  errors << "a valid email address"
@@ -81,11 +64,11 @@ class ExportEmailController < UmlautController
81
64
  def holding(id)
82
65
  return ServiceResponse.find(id) unless id.nil?
83
66
  end
84
-
67
+
85
68
  def holding_location(id)
86
69
  return holding(id).view_data[:collection_str] unless holding(id).nil?
87
70
  end
88
-
71
+
89
72
  def call_number(id)
90
73
  return holding(id).view_data[:call_number] unless holding(id).nil?
91
74
  end
@@ -0,0 +1,90 @@
1
+ # register an email address at: http://www.journaltocs.ac.uk/index.php?action=register
2
+
3
+ class JournalTocsController < UmlautController
4
+
5
+ def show
6
+ @issn = params["rft.issn"] || params["issn"]
7
+
8
+ if @issn.blank?
9
+ render :status => 500, :text => "Client must supply an ISSN"
10
+ return
11
+ end
12
+ @title = params["rft.title"] || params["title"]
13
+
14
+ fetcher = JournalTocsFetcher.new(@issn)
15
+ @results = fetcher.items
16
+
17
+ if @results.empty?
18
+ render :status => 404, :text => "No current articles available for #{@title} #{@issn}"
19
+ return
20
+ end
21
+
22
+ # direct to use our custom decorator
23
+ @results.each {|r| r.decorator = "JournalTocsController::ArticleDecorator" }
24
+
25
+ # No title given? Let's try to sniff one from the results.
26
+ if @title.blank?
27
+ @title = @results.first.try(:journal_title)
28
+ end
29
+
30
+
31
+ respond_to do |format|
32
+ format.html # journal_tocs/show.html.erb
33
+ format.atom do
34
+ render( :template => "bento_search/atom_results",
35
+ :locals => {
36
+ :atom_results => @results,
37
+ :feed_name => "Recent Articles from #{@title || @issn}",
38
+ :feed_author_name => "MyCorp"
39
+ }
40
+ )
41
+ end
42
+ end
43
+
44
+ end
45
+
46
+ # A article decorator from BentoSearch, where we customize our links:
47
+ # If we have enough info for an OpenURL, do a self-pointing OpenURL
48
+ # to us, set with redirect to fulltext. If there is not enough info
49
+ # for an openurl, no link at all at present.
50
+ #
51
+ # Possible enhancements: Refworks link. Find It link without auto redirect.
52
+ # link to publisher link if it's open access?
53
+ # link to publisher link through ezproxy even if it's not, on a wing and a prayer?
54
+ class ArticleDecorator < BentoSearch::StandardDecorator
55
+ def link
56
+ if sufficient_for_openurl?
57
+ _h.resolve_url + "?#{self.to_openurl_kev}&umlaut.skip_resolve_menu_for_type=fulltext"
58
+ else
59
+ nil
60
+ end
61
+ end
62
+
63
+ def sufficient_for_openurl?
64
+ doi.present? || (issn.present? && volume.present? && issue.present? && start_page.present?)
65
+ end
66
+
67
+ # We don't want to display format
68
+ def display_format
69
+ nil
70
+ end
71
+
72
+ # force display of complete date if present, even for journals.
73
+ def display_date
74
+ if self.publication_date
75
+ I18n.localize(self.publication_date, :format => "%d %b %Y")
76
+ elsif self.year
77
+ self.year.to_s
78
+ else
79
+ nil
80
+ end
81
+ end
82
+
83
+ end
84
+
85
+
86
+
87
+
88
+
89
+ end
90
+
@@ -1,10 +1,9 @@
1
1
  # Controller that just has one helper action for external sites using
2
- # our Javascript HTML updater stuff.
2
+ # our Javascript HTML updater stuff.
3
3
  class JsHelperController < UmlautController
4
4
 
5
5
  def loader
6
6
  @generate_urls_with_host = true
7
7
  render :template => "js_helper/loader.erb.js"
8
8
  end
9
-
10
- end
9
+ end
@@ -1,73 +1,62 @@
1
1
  # All clicks on a ServiceResponse are actually sent through this controller,
2
2
  # which redirects to actual destination. That allows statistic logging,
3
3
  # as well as special behavior (like EZProxy redirection, or showing in a
4
- # bannered frameset).
4
+ # bannered frameset).
5
5
  require 'cgi'
6
6
  class LinkRouterController < UmlautController
7
- def index
7
+ # Add resolve layout for handling errors.
8
+ layout :resolve_layout
8
9
 
9
- # Capture mysterious exception for better error reporting.
10
+ def index
11
+ # Capture mysterious exception for better error reporting.
10
12
  begin
11
13
  svc_response = ServiceResponse.find(params[:id])
12
- rescue ActiveRecord::RecordNotFound => exception
14
+ rescue ActiveRecord::RecordNotFound => exception
13
15
  # Usually this happens when it's a spider trying an old link. "go" links
14
16
  # don't stay good forever! Bad spider, ignoring our robots.txt.
15
- log_error_with_context(exception, :warn)
16
-
17
- raise exception# will be caught by top level rescue_from
17
+ log_error_with_context(exception, :warn)
18
+ raise exception# will be caught by top level rescue_from
18
19
  end
19
-
20
-
21
- @collection = self.create_collection
22
-
20
+ @collection = self.create_collection
23
21
  clickthrough = Clickthrough.new
24
22
  clickthrough.request_id = svc_response.request_id
25
23
  clickthrough.service_response_id = svc_response.id
26
24
  clickthrough.save
27
-
28
-
29
25
  redirect_to calculate_url_for_response(svc_response)
30
26
  end
31
-
32
- protected
33
-
34
-
35
-
27
+
36
28
  # Used to calculate a destination/target url for an Umlaut response item.
37
29
  #
38
30
  # Pass in a ServiceType join object (not actually a ServiceResponse, sorry)
39
31
  # Calculates the URL for it, and then runs our link_out_filters on it,
40
- # returning the final calculated url.
32
+ # returning the final calculated url.
41
33
  #
42
34
  # Also requires a rails 'params' object, since url calculation sometimes
43
35
  # depends on submitted HTTP params.
44
36
  #
45
37
  # Used from LinkController's index,
46
38
  def calculate_url_for_response(svc_response)
47
- svc = ServiceStore.instantiate_service!(svc_response.service_id, nil)
48
-
49
- destination = svc.response_url(svc_response, params)
50
-
51
- # if response_url returned a string, it's an external url and we're
52
- # done. If it's something else, usually a hash, then pass it to
53
- # url_for to generate a url.
54
- if destination.kind_of?(String)
55
- url = destination
56
-
57
- # Call link_out_filters, if neccesary.
58
- # These are services listed as task: link_out_filter in services.yml
59
- (1..9).each do |priority|
60
- @collection.link_out_service_level( priority ).each do |filter|
61
- filtered_url = filter.link_out_filter(url, svc_response)
62
- url = filtered_url if filtered_url
63
- end
39
+ svc = ServiceStore.instantiate_service!(svc_response.service_id, nil)
40
+ destination = svc.response_url(svc_response, params)
41
+
42
+ # if response_url returned a string, it's an external url and we're
43
+ # done. If it's something else, usually a hash, then pass it to
44
+ # url_for to generate a url.
45
+ if destination.kind_of?(String)
46
+ url = destination
47
+
48
+ # Call link_out_filters, if neccesary.
49
+ # These are services listed as task: link_out_filter in services.yml
50
+ (1..9).each do |priority|
51
+ @collection.link_out_service_level( priority ).each do |filter|
52
+ filtered_url = filter.link_out_filter(url, svc_response)
53
+ url = filtered_url if filtered_url
64
54
  end
65
- return url
66
- else
67
- return url_for(params_preserve_xhr(destination))
68
55
  end
56
+ return url
57
+ else
58
+ return url_for(params_preserve_xhr(destination))
59
+ end
69
60
  end
70
-
71
-
72
-
73
- end
61
+ protected :calculate_url_for_response
62
+ end