curate 0.0.1 → 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (250) hide show
  1. data/LICENSE +14 -0
  2. data/app/controllers/application_controller.rb +69 -0
  3. data/app/controllers/catalog_controller.rb +336 -0
  4. data/app/controllers/classify_concerns_controller.rb +29 -0
  5. data/app/controllers/common_objects_controller.rb +27 -0
  6. data/app/controllers/curation_concern/base_controller.rb +26 -0
  7. data/app/controllers/curation_concern/generic_files_controller.rb +82 -0
  8. data/app/controllers/dashboard_controller.rb +85 -0
  9. data/app/controllers/downloads_controller.rb +22 -0
  10. data/app/controllers/errors_controller.rb +19 -0
  11. data/app/controllers/help_requests_controller.rb +38 -0
  12. data/app/controllers/terms_of_service_agreements_controller.rb +44 -0
  13. data/app/controllers/welcome_controller.rb +14 -0
  14. data/app/helpers/application_helper.rb +89 -0
  15. data/app/helpers/blacklight_helper.rb +19 -0
  16. data/app/helpers/common_objects_helper.rb +5 -0
  17. data/app/inputs/multi_value_input.rb +71 -0
  18. data/app/models/access_right.rb +53 -0
  19. data/app/models/classify_concern.rb +30 -0
  20. data/app/models/contributor_agreement.rb +58 -0
  21. data/app/models/digital_object_identifier.rb +83 -0
  22. data/app/models/doi_config.rb +26 -0
  23. data/app/models/help_request.rb +34 -0
  24. data/app/models/mint_doi.rb +51 -0
  25. data/app/models/mint_purl.rb +40 -0
  26. data/app/models/object_access.rb +17 -0
  27. data/app/models/purl.rb +18 -0
  28. data/app/models/purl_config.rb +10 -0
  29. data/app/models/repo_object.rb +24 -0
  30. data/app/models/solr_document.rb +35 -0
  31. data/app/repository_datastreams/file_content_datastream.rb +36 -0
  32. data/app/repository_models/curation_concern/embargoable.rb +43 -0
  33. data/app/repository_models/curation_concern/with_access_right.rb +31 -0
  34. data/app/repository_models/generic_file.rb +36 -0
  35. data/app/services/anti_virus_scanner.rb +28 -0
  36. data/app/services/curation_concern.rb +22 -0
  37. data/app/services/curation_concern/base_actor.rb +48 -0
  38. data/app/services/curation_concern/generic_file_actor.rb +38 -0
  39. data/app/validators/future_date_validator.rb +19 -0
  40. data/app/views/_footer.html.erb +19 -0
  41. data/app/views/_ga.html.erb +6 -0
  42. data/app/views/_logo.html.erb +34 -0
  43. data/app/views/_masthead.html.erb +34 -0
  44. data/app/views/catalog/_bookmark_control.html.erb +25 -0
  45. data/app/views/catalog/_bookmark_form.html.erb +8 -0
  46. data/app/views/catalog/_citation.html.erb +11 -0
  47. data/app/views/catalog/_constraints.html.erb +6 -0
  48. data/app/views/catalog/_constraints_element.html.erb +20 -0
  49. data/app/views/catalog/_delete_partials/_default.html.erb +29 -0
  50. data/app/views/catalog/_did_you_mean.html.erb +10 -0
  51. data/app/views/catalog/_document.html.erb +19 -0
  52. data/app/views/catalog/_document_list.html.erb +2 -0
  53. data/app/views/catalog/_edit_partials/_default.html.erb +58 -0
  54. data/app/views/catalog/_edit_partials/_default_details.html.erb +13 -0
  55. data/app/views/catalog/_email_form.html.erb +11 -0
  56. data/app/views/catalog/_facet_layout.html.erb +12 -0
  57. data/app/views/catalog/_facet_limit.html.erb +19 -0
  58. data/app/views/catalog/_facet_selected.html.erb +12 -0
  59. data/app/views/catalog/_facets.html.erb +5 -0
  60. data/app/views/catalog/_folder_control.html.erb +12 -0
  61. data/app/views/catalog/_home.html.erb +2 -0
  62. data/app/views/catalog/_home_text.html.erb +10 -0
  63. data/app/views/catalog/_index_default.html.erb +11 -0
  64. data/app/views/catalog/_index_partials/_default_group.html.erb +37 -0
  65. data/app/views/catalog/_marc_view.html.erb +33 -0
  66. data/app/views/catalog/_opensearch_response_metadata.html.erb +2 -0
  67. data/app/views/catalog/_previous_next_doc.html.erb +6 -0
  68. data/app/views/catalog/_refworks_form.html.erb +7 -0
  69. data/app/views/catalog/_results_pagination.html.erb +6 -0
  70. data/app/views/catalog/_search_form.html.erb +20 -0
  71. data/app/views/catalog/_show_default.html.erb +9 -0
  72. data/app/views/catalog/_show_partials/_default.html.erb +22 -0
  73. data/app/views/catalog/_show_partials/_default_details.html.erb +15 -0
  74. data/app/views/catalog/_show_partials/_facets.html.erb +52 -0
  75. data/app/views/catalog/_show_sidebar.html.erb +1 -0
  76. data/app/views/catalog/_show_tools.html.erb +46 -0
  77. data/app/views/catalog/_sms_form.html.erb +21 -0
  78. data/app/views/catalog/_sort_and_per_page.html.erb +38 -0
  79. data/app/views/catalog/_uva_tabs.html.erb +10 -0
  80. data/app/views/catalog/about.html.erb +0 -0
  81. data/app/views/catalog/citation.html.erb +1 -0
  82. data/app/views/catalog/email.erb +1 -0
  83. data/app/views/catalog/endnote.endnote.erb +1 -0
  84. data/app/views/catalog/index.atom.builder +109 -0
  85. data/app/views/catalog/index.html.erb +55 -0
  86. data/app/views/catalog/index.rss.builder +19 -0
  87. data/app/views/catalog/librarian_view.html.erb +3 -0
  88. data/app/views/catalog/opensearch.json.erb +0 -0
  89. data/app/views/catalog/opensearch.xml.builder +10 -0
  90. data/app/views/catalog/send_email_record.erb +0 -0
  91. data/app/views/catalog/show.endnote.erb +1 -0
  92. data/app/views/catalog/show.html.erb +40 -0
  93. data/app/views/catalog/show.refworks.erb +1 -0
  94. data/app/views/catalog/sms.erb +1 -0
  95. data/app/views/classify_concerns/new.html.erb +24 -0
  96. data/app/views/common_objects/_generic_file.html.erb +0 -0
  97. data/app/views/common_objects/_senior_thesis.html.erb +2 -0
  98. data/app/views/common_objects/show.html.erb +11 -0
  99. data/app/views/common_objects/show_stub_information.html.erb +13 -0
  100. data/app/views/curation_concern/_content_license.html.erb +16 -0
  101. data/app/views/curation_concern/_contributor_agreement.html.erb +27 -0
  102. data/app/views/curation_concern/_doi.html.erb +43 -0
  103. data/app/views/curation_concern/_media_display.html.erb +1 -0
  104. data/app/views/curation_concern/_permission.html.erb +39 -0
  105. data/app/views/curation_concern/_related_files.html.erb +46 -0
  106. data/app/views/curation_concern/generic_files/_attributes.html.erb +63 -0
  107. data/app/views/curation_concern/generic_files/_form.html.erb +57 -0
  108. data/app/views/curation_concern/generic_files/edit.html.erb +5 -0
  109. data/app/views/curation_concern/generic_files/new.html.erb +5 -0
  110. data/app/views/curation_concern/generic_files/show.html.erb +12 -0
  111. data/app/views/curation_concern/senior_theses/_attributes.html.erb +13 -0
  112. data/app/views/curation_concern/senior_theses/_form.html.erb +88 -0
  113. data/app/views/curation_concern/senior_theses/edit.html.erb +15 -0
  114. data/app/views/curation_concern/senior_theses/new.html.erb +14 -0
  115. data/app/views/curation_concern/senior_theses/show.html.erb +18 -0
  116. data/app/views/dashboard/_constraints.html.erb +22 -0
  117. data/app/views/dashboard/_did_you_mean.html.erb +26 -0
  118. data/app/views/dashboard/_document_list.html.erb +20 -0
  119. data/app/views/dashboard/_facet_layout.html.erb +27 -0
  120. data/app/views/dashboard/_facet_limit.html.erb +35 -0
  121. data/app/views/dashboard/_facet_pagination.html.erb +25 -0
  122. data/app/views/dashboard/_facet_selected.html.erb +28 -0
  123. data/app/views/dashboard/_facets.html.erb +22 -0
  124. data/app/views/dashboard/_index_partials/_default_group.html.erb +37 -0
  125. data/app/views/dashboard/_index_partials/_list_files.html.erb +66 -0
  126. data/app/views/dashboard/_index_partials/_thumbnail_display.html.erb +0 -0
  127. data/app/views/dashboard/_results_pagination.html.erb +22 -0
  128. data/app/views/dashboard/_search_form.html.erb +36 -0
  129. data/app/views/dashboard/_show_partials/_default.html.erb +38 -0
  130. data/app/views/dashboard/_show_partials/_default_details.html.erb +31 -0
  131. data/app/views/dashboard/_show_partials/_facets.html.erb +103 -0
  132. data/app/views/dashboard/_sort_and_per_page.html.erb +18 -0
  133. data/app/views/dashboard/facet.html.erb +38 -0
  134. data/app/views/dashboard/get_related_file.html.erb +4 -0
  135. data/app/views/dashboard/index.html.erb +60 -0
  136. data/app/views/errors/401.html.erb +5 -0
  137. data/app/views/errors/404.html.erb +16 -0
  138. data/app/views/errors/500.html.erb +10 -0
  139. data/app/views/help_requests/new.html.erb +60 -0
  140. data/app/views/layouts/application.html.erb +14 -0
  141. data/app/views/layouts/boilerplate.html.erb +28 -0
  142. data/app/views/layouts/common_objects.html.erb +45 -0
  143. data/app/views/layouts/curate_nd.html.erb +55 -0
  144. data/app/views/layouts/curate_nd/1_column.html.erb +22 -0
  145. data/app/views/layouts/curate_nd/2_column.html.erb +26 -0
  146. data/app/views/layouts/curate_nd/catalog.html.erb +22 -0
  147. data/app/views/layouts/curate_nd/dashboard.html.erb +22 -0
  148. data/app/views/layouts/hydra-head.html.erb +95 -0
  149. data/app/views/shared/_action_bar.html.erb +30 -0
  150. data/app/views/shared/_flash_message.html.erb +9 -0
  151. data/app/views/shared/_site_search.html.erb +18 -0
  152. data/app/views/terms_of_service_agreements/new.html.erb +136 -0
  153. data/app/views/welcome/index.html.erb +21 -0
  154. data/app/workers/characterize_job.rb +4 -0
  155. data/app/workers/doi_worker.rb +16 -0
  156. data/config/routes.rb +35 -0
  157. data/lib/curate.rb +6 -0
  158. data/lib/curate/engine.rb +46 -0
  159. data/lib/curate/version.rb +1 -1
  160. data/spec/abilities/generic_file_abilities_spec.rb +55 -0
  161. data/spec/controllers/application_controller_spec.rb +38 -0
  162. data/spec/controllers/classify_concerns_controller_spec.rb +36 -0
  163. data/spec/controllers/common_objects_controller_spec.rb +112 -0
  164. data/spec/controllers/curation_concern/base_controller_spec.rb +14 -0
  165. data/spec/controllers/curation_concern/generic_files_controller_spec.rb +156 -0
  166. data/spec/controllers/dashboard_controller_spec.rb +85 -0
  167. data/spec/controllers/downloads_controller_spec.rb +42 -0
  168. data/spec/controllers/help_requests_controller_spec.rb +42 -0
  169. data/spec/controllers/terms_of_service_agreements_controller_spec.rb +30 -0
  170. data/spec/controllers/welcome_controller_spec.rb +10 -0
  171. data/spec/dummy/app/models/solr_document.rb +4 -0
  172. data/spec/dummy/app/models/user.rb +13 -0
  173. data/spec/dummy/config/application.rb +8 -1
  174. data/spec/dummy/config/database.yml +21 -22
  175. data/spec/dummy/config/doi.yml +11 -0
  176. data/spec/dummy/config/fedora.yml +20 -0
  177. data/spec/dummy/config/initializers/devise.rb +232 -0
  178. data/spec/dummy/config/initializers/hydra_config.rb +41 -0
  179. data/spec/dummy/config/initializers/mailboxer.rb +17 -0
  180. data/spec/dummy/config/initializers/redis_config.rb +45 -0
  181. data/spec/dummy/config/initializers/sufia.rb +66 -0
  182. data/spec/dummy/config/purl.yml +15 -0
  183. data/spec/dummy/config/redis.yml +6 -0
  184. data/spec/dummy/config/role_map_ci.yml +15 -0
  185. data/spec/dummy/config/role_map_cucumber.yml +10 -0
  186. data/spec/dummy/config/role_map_development.yml +12 -0
  187. data/spec/dummy/config/role_map_pre_production.yml +2 -0
  188. data/spec/dummy/config/role_map_production.yml +2 -0
  189. data/spec/dummy/config/role_map_test.yml +15 -0
  190. data/spec/dummy/config/routes.rb +4 -55
  191. data/spec/dummy/config/solr.yml +17 -0
  192. data/spec/dummy/db/migrate/20130130142162_create_purl.rb +55 -0
  193. data/spec/dummy/db/migrate/20130312135359_create_help_requests.rb +22 -0
  194. data/spec/dummy/db/migrate/20130408165008_create_users.rb +11 -0
  195. data/spec/dummy/db/migrate/20130408165009_acts_as_follower_migration.rb +31 -0
  196. data/spec/dummy/db/migrate/20130408165010_add_social_to_users.rb +27 -0
  197. data/spec/dummy/db/migrate/20130408165011_create_single_use_links.rb +12 -0
  198. data/spec/dummy/db/migrate/20130408165012_add_ldap_attrs_to_user.rb +41 -0
  199. data/spec/dummy/db/migrate/20130408165013_add_avatars_to_users.rb +23 -0
  200. data/spec/dummy/db/migrate/20130408165014_create_checksum_audit_logs.rb +34 -0
  201. data/spec/dummy/db/migrate/20130408165015_create_version_committers.rb +29 -0
  202. data/spec/dummy/db/migrate/20130408165016_add_groups_to_users.rb +25 -0
  203. data/spec/dummy/db/migrate/20130408165017_create_local_authorities.rb +64 -0
  204. data/spec/dummy/db/migrate/20130408165018_create_trophies.rb +10 -0
  205. data/spec/dummy/db/migrate/20130408165022_create_mailboxer.mailboxer_engine.rb +62 -0
  206. data/spec/dummy/db/migrate/20130408165023_add_notified_object.mailboxer_engine.rb +18 -0
  207. data/spec/dummy/db/migrate/20130408165024_add_notification_code.mailboxer_engine.rb +14 -0
  208. data/spec/dummy/db/migrate/20130408165025_add_attachments.mailboxer_engine.rb +10 -0
  209. data/spec/dummy/db/migrate/20130408165026_rename_receipts_read.mailboxer_engine.rb +10 -0
  210. data/spec/dummy/db/schema.rb +197 -0
  211. data/spec/dummy/db/test.sqlite3 +0 -0
  212. data/spec/dummy/fedora_conf/conf/development/fedora.fcfg +953 -0
  213. data/spec/dummy/fedora_conf/conf/test/fedora.fcfg +953 -0
  214. data/spec/dummy/log/development.log +1791 -0
  215. data/spec/dummy/log/test.log +176333 -0
  216. data/spec/dummy/solr_conf/conf/schema.xml +692 -0
  217. data/spec/dummy/solr_conf/conf/solrconfig.xml +299 -0
  218. data/spec/dummy/solr_conf/solr.xml +35 -0
  219. data/spec/factories/create_curation_concern.rb +11 -0
  220. data/spec/factories/create_generic_file.rb +36 -0
  221. data/spec/factories/help_requests.rb +10 -0
  222. data/spec/factories/mock_curation_concerns.rb +4 -0
  223. data/spec/factories/users.rb +8 -0
  224. data/spec/helpers/application_helper_spec.rb +139 -0
  225. data/spec/helpers/common_objects_helper_spec.rb +9 -0
  226. data/spec/models/access_right_spec.rb +47 -0
  227. data/spec/models/classify_concern_spec.rb +30 -0
  228. data/spec/models/contributor_agreement_spec.rb +45 -0
  229. data/spec/models/digital_object_identifier_spec.rb +50 -0
  230. data/spec/models/help_request_spec.rb +5 -0
  231. data/spec/models/mint_doi_spec.rb +79 -0
  232. data/spec/models/mint_purl_spec.rb +38 -0
  233. data/spec/models/object_access_spec.rb +24 -0
  234. data/spec/models/purl_spec.rb +22 -0
  235. data/spec/models/repo_object_spec.rb +39 -0
  236. data/spec/repository_models/curation_concern/embargoable_spec.rb +69 -0
  237. data/spec/repository_models/generic_file_spec.rb +38 -0
  238. data/spec/services/anti_virus_scanner_spec.rb +26 -0
  239. data/spec/services/curation_concern/base_actor_spec.rb +28 -0
  240. data/spec/services/curation_concern/generic_file_actor_spec.rb +75 -0
  241. data/spec/services/curation_concern_spec.rb +34 -0
  242. data/spec/spec_helper.rb +54 -1
  243. data/spec/support/environment_override.rb +17 -0
  244. data/spec/support/matchers/raise_rescue_response_type_matcher.rb +42 -0
  245. data/spec/support/mock_curation_concern.rb +61 -0
  246. data/spec/support/shared/shared_examples_is_embargoable.rb +9 -0
  247. data/spec/support/shared/shared_examples_with_access_rights.rb +33 -0
  248. data/spec/workers/characterize_job_spec.rb +26 -0
  249. metadata +686 -10
  250. data/MIT-LICENSE +0 -20
@@ -0,0 +1,33 @@
1
+ <h1>Librarian View</h1>
2
+ <div id="marc_view">
3
+ <% fields = @document.to_marc.find_all{|f| ('000'..'999') === f.tag } %>
4
+ <div class="field">LEADER <%= @document.to_marc.leader %></div>
5
+ <%- fields.each do |field| -%>
6
+ <%- unless field.tag.to_s == "940" -%>
7
+ <div class="field">
8
+ <div class="tag_ind">
9
+ <span class="tag">
10
+ <%= h(field.tag) %>
11
+ </span>
12
+ <%- if field.is_a?(MARC::ControlField) -%>
13
+ <span class="control_field_values">
14
+ <%= h(field.value) %>
15
+ </span>
16
+ <%- else -%>
17
+ <div class="ind1">
18
+ <%= !field.indicator1.blank? ? field.indicator1 : "&nbsp;&nbsp;".html_safe -%>
19
+ </div>
20
+ <div class="ind2">
21
+ <%= !field.indicator2.blank? ? field.indicator2 : "&nbsp;&nbsp;".html_safe -%>
22
+ </div>
23
+ </div>
24
+ <div class="subfields">
25
+ <%- field.each do |sub| -%>
26
+ <span class="sub_code"><%= h(sub.code) %>|</span> <%= h(sub.value) %>
27
+ <%- end -%>
28
+ <%- end -%>
29
+ </div>
30
+ </div>
31
+ <%- end-%>
32
+ <%- end -%>
33
+ </div>
@@ -0,0 +1,2 @@
1
+ <!-- Suppressing opensearch tags (to maintain html5 validity) by overriding views/catalog/_opensearch_response_metadata.html.erb with an empty file. To undo this, just delete the file. -->
2
+
@@ -0,0 +1,6 @@
1
+ <% if @previous_document || @next_document %>
2
+ <div id="previousNextDocument">
3
+ <%= link_to_previous_document(@previous_document) %>
4
+ <%= link_to_next_document(@next_document) %>
5
+ </div>
6
+ <% end %>
@@ -0,0 +1,7 @@
1
+ <%= form_tag "http://www.refworks.com/express/expressimport.asp?vendor=#{application_name}&filter=MARC%20Format&encoding=65001", :name => "refworks", :target => "_blank" do %>
2
+
3
+ <%= hidden_field_tag "ImportData", render_refworks_texts(documents) %>
4
+ <%= submit_tag "Export to Refworks", :class => 'submit'%>
5
+ <%= link_to_function "Export to Refworks", "document.refworks.submit();" %>
6
+ <% end %>
7
+
@@ -0,0 +1,6 @@
1
+ <% if paginate_params(@response).num_pages > 1 %>
2
+ <div class="pager">
3
+ <%= paginate_rsolr_response @response, :outer_window => 2, :theme => 'blacklight' %>
4
+ <div class="clearfix"></div>
5
+ </div><!-- /pager -->
6
+ <% end %>
@@ -0,0 +1,20 @@
1
+ <%= form_tag catalog_index_path, :method => :get, :id => "search-form-header" do %>
2
+ <fieldset>
3
+ <legend class="accessible-hidden">Search <%=t('sufia.product_name')%></legend>
4
+ <%= label_tag :catalog_search, t('sufia.search.form.q.label'), :class => "accessible-hidden" %>
5
+ <%= text_field_tag(
6
+ :q,
7
+ params[:q],
8
+ :class => "q input-xlarge search-query",
9
+ :id => "catalog_search",
10
+ :placeholder => t('sufia.search.form.q.placeholder'),
11
+ :size => "30",
12
+ :tabindex => "1",
13
+ :type => "search",
14
+ )%>
15
+ <%= search_as_hidden_fields(:omit_keys => [:q, :search_field, :qt, :page]).html_safe %>
16
+ <button type="submit" class="btn btn-primary" id="search-submit-header" tabindex="2">
17
+ <i class="icon-search icon-white"></i> Go
18
+ </button>
19
+ </fieldset>
20
+ <% end %>
@@ -0,0 +1,9 @@
1
+ <%# default partial to display solr document fields in catalog show view -%>
2
+ <dl class="defList">
3
+ <% document_show_fields.each do |solr_fname, field| -%>
4
+ <% if document.has? solr_fname %>
5
+ <dt class="blacklight-<%= solr_fname.parameterize %>"><%= render_document_show_field_label :field => solr_fname %></dt>
6
+ <dd class="blacklight-<%= solr_fname.parameterize %>"><%= render_document_show_field_value :document => document, :field => solr_fname %></dd>
7
+ <% end -%>
8
+ <% end -%>
9
+ </dl>
@@ -0,0 +1,22 @@
1
+ <%# default partial to display solr document fields in catalog show view -%>
2
+
3
+
4
+ <div class="document_viewer" id="cover_container">
5
+ <dl class="defList">
6
+ <dt>ID: </dt>
7
+ <dd><%= render_document_show_field_value(:document=>document, :field=>"id") %></dd>
8
+ <dt>Download:</dt>
9
+ <dd id="downloads">
10
+ <ul>
11
+ <% %>
12
+ </ul>
13
+ </dd>
14
+ <dt>Copyright: </dt>
15
+ <dd><%= render_document_show_field_value(:document=>document, :field=>"rights_t") %></dd>
16
+ </dl>
17
+ </div>
18
+ <div class="<%= params[:action]%>_details">
19
+ <%= render :partial => "#{params[:controller]}/_#{params[:action]}_partials/default_details", :locals => {:document => document}%>
20
+ </div>
21
+
22
+ <%= async_load_tag(hydra_asset_downloads_path(params[:id]), 'downloads') %>
@@ -0,0 +1,15 @@
1
+ <%# default partial to display solr document fields in catalog show view -%>
2
+ <div>
3
+ <dl class="defList">
4
+ <dt>Date: </dt>
5
+ <dd><%= render_document_show_field_value(:document=>document, :field=>"date_t") %></dd>
6
+ <dt>Title: </dt>
7
+ <dd><%= render_document_show_field_value(:document=>document, :field=>"title_t") %></dd>
8
+ <dt>Document Type: </dt>
9
+ <dd><%= render_document_show_field_value(:document=>document, :field=>"medium_t") %></dd>
10
+ <dt>Location: </dt>
11
+ <dd><%= render_document_show_field_value(:document=>document, :field=>"location_t") %></dd>
12
+ <dt>Date: </dt>
13
+ <dd><%= render_document_show_field_value(:document=>document, :field=>"date_t") %></dd>
14
+ </dl>
15
+ </div>
@@ -0,0 +1,52 @@
1
+ <% facets_display_heading ||= "" %>
2
+ <% # main container for facets/limits menu -%>
3
+ <div id="facets">
4
+ <h2><%=h facets_display_heading %></h2>
5
+ <% facet_field_names.each do |solr_fname| %>
6
+ <div>
7
+ <% display_facet = @response.facets.detect {|f| f.name == solr_fname} -%>
8
+ <%#- raise solr_fname.inspect unless display_facet -%>
9
+ <% if display_facet && display_facet.items.length > 0 %>
10
+ <h3 class="facet_selected"><%= facet_field_labels[solr_fname] -%></h3>
11
+ <ul>
12
+ <% item_counter = 0 %>
13
+ <% display_facet.items.each do |item| -%>
14
+ <% if item.hits > 0 %>
15
+ <% facet_count_for_value = facet_value_hits(@facet_lookup, solr_fname, item.value) %>
16
+ <% if facet_in_params? solr_fname, item.value %>
17
+ <li>
18
+ <span class="selected"><%= h(item.value) %> (<%= format_num facet_count_for_value %>)</span>
19
+ <% link_options = remove_facet_params(solr_fname, item.value, params).merge!Hash["controller" => "catalog", :action=> "index"] %>
20
+ [<%= link_to 'remove', url_for(link_options), :class=>'remove' %>]
21
+ </li>
22
+ <% else %>
23
+ <%- if item_counter > Blacklight.config[:facet_more_num]-1 -%>
24
+ <li class="more">
25
+ <%- else -%>
26
+ <li>
27
+ <%- end -%>
28
+ <% link_options = add_facet_params(solr_fname, item.value).merge!Hash["controller" => "catalog", :action=> "index"] %>
29
+ <%= link_to h(item.value), url_for(link_options) %> (<%= format_num facet_count_for_value %>)
30
+ </li>
31
+ <% end -%>
32
+ <% end -%>
33
+ <% item_counter += 1 %>
34
+ <% end %>
35
+ <%= display_facet.items.length > Blacklight.config[:facet_more_num] ? "<li class='more_li'><a href='' class='more_link' title='more #{pluralize(2, facet_field_labels[solr_fname])[2..-1].downcase}'>more<span class='off_screen'> #{pluralize(2, facet_field_labels[solr_fname])[2..-1].downcase}</span></a></li>" : "" %>
36
+ <%= display_facet.items.length > Blacklight.config[:facet_more_num] ? "<li class='less_li' style='display:none;'><a href='' class='more_link' title='less #{pluralize(2, facet_field_labels[solr_fname])[2..-1].downcase}'>less<span class='off_screen'> #{pluralize(2, facet_field_labels[solr_fname])[2..-1].downcase}</span></a></li>" : "" %>
37
+ </ul>
38
+ <% end %>
39
+ </div>
40
+ <% end %>
41
+ </div>
42
+ <script type="text/javascript">
43
+ $(".more").toggle();
44
+ $('.more_link').each(function(){
45
+ $(this).click(function(){
46
+ $(this).parent().parent().children("li.more").toggle();
47
+ $(this).parent().parent().children("li.more_li").toggle();
48
+ $(this).parent().parent().children("li.less_li").toggle();
49
+ return false;
50
+ });
51
+ });
52
+ </script>
@@ -0,0 +1 @@
1
+ <p><%= link_back_to_catalog %></p>
@@ -0,0 +1,46 @@
1
+ <%-
2
+ # Compare with render_document_functions_partial helper, and
3
+ # _document_functions partial. BL actually has two groups
4
+ # of document-related tools. "document functions" by default
5
+ # contains Bookmark/Folder functionality shown on both results and
6
+ # item view. While "document tools" contains external export type
7
+ # functions by default only on detail.
8
+ -%>
9
+ <ul class="tools">
10
+
11
+ <% if (@document.respond_to?(:export_as_mla_citation_txt) || @document.respond_to?(:export_as_apa_citation_txt)) %>
12
+ <li class="cite">
13
+ <%= link_to "Cite This", citation_catalog_path(:id => @document), {:id => 'citeLink', :name => 'citation', :class => 'lightboxLink'} %>
14
+ </li>
15
+ <% end %>
16
+
17
+ <% if @document.export_formats.keys.include?( :refworks_marc_txt ) %>
18
+ <li class="refworks">
19
+ <%= link_to "Export to RefWorks", refworks_export_url(:id => @document) %>
20
+ </li>
21
+ <% end %>
22
+
23
+ <% if @document.export_formats.keys.include?( :endnote ) %>
24
+ <li class="endnote">
25
+ <%= link_to "Export to EndNote", catalog_path(@document, :format => 'endnote') %>
26
+ </li>
27
+ <% end %>
28
+
29
+ <% if @document.respond_to?( :to_email_text ) %>
30
+ <li class="email">
31
+ <%= link_to "Email This", email_catalog_path(:id => @document), {:id => 'emailLink', :name => 'email', :class => 'lightboxLink'} %>
32
+ </li>
33
+ <%- end -%>
34
+ <%- if @document.respond_to?( :to_sms_text ) -%>
35
+ <li class="sms">
36
+ <%= link_to "SMS This", sms_catalog_path(:id => @document), {:id => 'smsLink', :name => 'sms', :class => 'lightboxLink'} %>
37
+ </li>
38
+ <%- end -%>
39
+
40
+ <% if @document.respond_to?(:to_marc) %>
41
+ <li class="librarian_view">
42
+ <%= link_to "Librarian View", librarian_view_catalog_path(@document), {:id => 'librarianLink', :name => 'librarian_view', :class => 'lightboxLink'} %>
43
+ </li>
44
+ <% end %>
45
+
46
+ </ul>
@@ -0,0 +1,21 @@
1
+ <% carriers =
2
+ {
3
+ 'Please select your carrier' => '',
4
+ 'AT&T' => 'att',
5
+ 'Verizon' => 'verizon',
6
+ 'T Mobile' => 'tmobile',
7
+ 'Sprint' => 'sprint',
8
+ 'Nextel' => 'nextel',
9
+ 'Virgin Mobile' => 'vmobile',
10
+ 'Alltel' => 'alltel',
11
+ 'Cricket' => 'cricket'
12
+ }
13
+ %>
14
+ <h1>SMS This</h1>
15
+ <%= form_tag url_for(:action => 'send_email_record', :style => 'sms'), :id => 'sms_form', :method => :post do %>
16
+ <%= label_tag(:to, "Phone Number:") %><br/>
17
+ <%= text_field_tag :sms_to %><br/>
18
+ <%= label_tag(:carrier, "Carrier:") %><br/>
19
+ <%= select_tag(:carrier, options_for_select(carriers, '')) %><br/>
20
+ <%= submit_tag "Send" %>
21
+ <% end %>
@@ -0,0 +1,38 @@
1
+ <% unless @response.response['numFound'] < 2 %>
2
+ <%# kind of hacky way to get this to work on catalog and folder controllers. May be able to simple do {:action=>"index"} but I'm not sure -%>
3
+ <%= form_tag params[:controller] == "folder" ? folder_index_path : catalog_index_path, :method => :get, :class => "well form-inline" do %>
4
+
5
+ <div class="sorting">
6
+ <%= label_tag :sort, "Sort by" %>
7
+ <%= select_tag(
8
+ :sort,
9
+ options_for_select(
10
+ sort_fields,
11
+ h(params[:sort])
12
+ ),
13
+ :class => "input-medium"
14
+ )%>
15
+
16
+ <%= label_tag(:per_page) do %>
17
+ Show
18
+ <%= select_tag(
19
+ :per_page,
20
+ options_for_select(
21
+ ['10', '20', '50', '100'],
22
+ h(params[:per_page])
23
+ ),
24
+ :title => "Number of results to display per page",
25
+ :class => "input-small"
26
+ )%>
27
+ per page
28
+ <% end %>
29
+
30
+ <%= search_as_hidden_fields(:omit_keys => [:per_page, :sort]) %>
31
+
32
+ <button class="btn btn-primary pull-right">
33
+ <i class="icon-refresh icon-white"></i> Update
34
+ </button>
35
+ </div>
36
+
37
+ <% end %>
38
+ <% end %>
@@ -0,0 +1,10 @@
1
+ <ul>
2
+ <li>
3
+ <% display_class = (!params[:home_context] || params[:home_context]=='authors') ? 'class="selected"' : '' %>
4
+ <a <%= display_class %> href="/catalog?home_context=authors">Authors</a>
5
+ </li>
6
+ <li>
7
+ <% display_class = params[:home_context]=='journals' ? 'class="selected"' : '' %>
8
+ <a <%= display_class %> href="/catalog?home_context=journals">Journals</a>
9
+ </li>
10
+ </ul>
File without changes
@@ -0,0 +1 @@
1
+ <%= render :partial => 'citation' -%>
@@ -0,0 +1 @@
1
+ <%= render :partial => 'email_form' %>
@@ -0,0 +1 @@
1
+ <%= render_endnote_texts(@documents) %>
@@ -0,0 +1,109 @@
1
+ require 'base64'
2
+ page_info = paginate_params(@response)
3
+
4
+ xml.instruct!(:xml, :encoding => "UTF-8")
5
+
6
+ xml.feed("xmlns" => "http://www.w3.org/2005/Atom",
7
+ "xmlns:opensearch"=>"http://a9.com/-/spec/opensearch/1.1/") do
8
+
9
+ xml.title application_name + " Search Results"
10
+ # an author is required, so we'll just use the app name
11
+ xml.author { xml.name application_name }
12
+
13
+ xml.link "rel" => "self", "href" => url_for(params.merge(:only_path => false))
14
+ xml.link "rel" => "alternate", "href" => url_for(params.merge(:only_path => false, :format => "html")), "type" => "text/html"
15
+ xml.id url_for(params.merge(:only_path => false, :format => "html", :content_format => nil, "type" => "text/html"))
16
+
17
+ # Navigational and context links
18
+
19
+ xml.link( "rel" => "next",
20
+ "href" => url_for(params.merge(:only_path => false, :page => (page_info.current_page + 1).to_s))
21
+ ) if page_info.num_pages > page_info.current_page
22
+
23
+ xml.link( "rel" => "previous",
24
+ "href" => url_for(params.merge(:only_path => false, :page => (page_info.current_page - 1).to_s))
25
+ ) if page_info.current_page > 1
26
+
27
+ xml.link( "rel" => "first",
28
+ "href" => url_for(params.merge(:only_path => false, :page => "1")))
29
+
30
+ xml.link( "rel" => "last",
31
+ "href" => url_for(params.merge(:only_path => false, :page => page_info.num_pages.to_s)))
32
+
33
+ # "search" doesn't seem to actually be legal, but is very common, and
34
+ # used as an example in opensearch docs
35
+ xml.link( "rel" => "search",
36
+ "type" => "application/opensearchdescription+xml",
37
+ "href" => url_for(:controller=>'catalog',:action => 'opensearch', :format => 'xml', :only_path => false))
38
+
39
+ # opensearch response elements
40
+ xml.opensearch :totalResults, @response.total.to_s
41
+ xml.opensearch :startIndex, @response.start.to_s
42
+ xml.opensearch :itemsPerPage, page_info.limit_value
43
+ xml.opensearch :Query, :role => "request", :searchTerms => params[:q], :startPage => page_info.current_page
44
+
45
+
46
+ # updated is required, for now we'll just set it to now, sorry
47
+ xml.updated Time.now.strftime("%Y-%m-%dT%H:%M:%SZ")
48
+
49
+ @document_list.each do |doc|
50
+ xml.entry do
51
+ xml.title doc.to_semantic_values[:title][0] || doc.id
52
+
53
+ # updated is required, for now we'll just set it to now, sorry
54
+ xml.updated Time.now.strftime("%Y-%m-%dT%H:%M:%SZ")
55
+
56
+ xml.link "rel" => "alternate", "type" => "text/html", "href" => catalog_url(doc)
57
+ # add other doc-specific formats, atom only lets us have one per
58
+ # content type, so the first one in the list wins.
59
+ xml << render_link_rel_alternates(doc, :unique => true)
60
+
61
+ xml.id catalog_url(doc[:id])
62
+
63
+
64
+ if doc.to_semantic_values[:author][0]
65
+ xml.author { xml.name(doc.to_semantic_values[:author][0]) }
66
+ end
67
+
68
+ with_format("html") do
69
+ xml.summary "type" => "html" do
70
+ xml.text! render_document_partial(doc, :index)
71
+ end
72
+ end
73
+
74
+ #If they asked for a format, give it to them.
75
+ if (params["content_format"] &&
76
+ doc.export_formats[params["content_format"].to_sym])
77
+
78
+ type = doc.export_formats[params["content_format"].to_sym][:content_type]
79
+
80
+ xml.content :type => type do |content_element|
81
+ data = doc.export_as(params["content_format"])
82
+
83
+ # encode properly. See:
84
+ # http://tools.ietf.org/html/rfc4287#section-4.1.3.3
85
+ type = type.downcase
86
+ if (type.downcase =~ /\+|\/xml$/)
87
+ # xml, just put it right in
88
+ content_element << data
89
+ elsif (type.downcase =~ /text\//)
90
+ # text, escape
91
+ content_element.text! data
92
+ else
93
+ #something else, base64 encode it
94
+ content_element << Base64.encode64(data)
95
+ end
96
+ end
97
+
98
+ end
99
+
100
+
101
+ end
102
+ end
103
+
104
+ end
105
+
106
+
107
+
108
+
109
+
@@ -0,0 +1,55 @@
1
+ <% content_for :page_title, "#{application_name} Search Results" %>
2
+ <% content_for :page_header do %>
3
+
4
+ <div class="row">
5
+
6
+ <div class="span8">
7
+ <h2>Search <%=t('sufia.product_name') %></h2>
8
+ </div>
9
+
10
+ <div class="span4 page-search">
11
+ <%= render 'shared/site_search' %>
12
+ </div>
13
+
14
+ </div>
15
+
16
+ <% end %>
17
+
18
+ <% content_for :sidebar do %>
19
+
20
+ <%= render 'facets' %>
21
+
22
+ <% end %>
23
+
24
+ <% if has_search_parameters? %>
25
+ <h3>Search Results</h3>
26
+ <div class="alert alert-info search-constraints">
27
+ <i class="icon-search icon-large"></i>
28
+ You searched for:
29
+ <%= render_constraints(params) %>
30
+ </div>
31
+
32
+ <%= render :partial => 'did_you_mean' %>
33
+ <%= render :partial => 'facet_selected' %>
34
+
35
+ <div class="row">
36
+ <div class="span6">
37
+ <%= render_pagination_info @response, :entry_name=>'item' %>
38
+ <%= render 'sort_and_per_page' %>
39
+ </div>
40
+ <div class="span3 emphatic-action-area">
41
+ <%= link_to "New Search", catalog_index_path, :id=>"startOverLink", :class=>"btn btn-primary pull-right" %>
42
+ </div>
43
+ </div>
44
+
45
+ <%= render 'results_pagination' %>
46
+
47
+ <%= render 'document_list' %>
48
+
49
+ <%= render 'results_pagination' %>
50
+
51
+ <% else %>
52
+
53
+ <%= render 'home' %>
54
+
55
+ <% end %>