curate 0.0.1 → 0.1.0
Sign up to get free protection for your applications and to get access to all the features.
- data/LICENSE +14 -0
- data/app/controllers/application_controller.rb +69 -0
- data/app/controllers/catalog_controller.rb +336 -0
- data/app/controllers/classify_concerns_controller.rb +29 -0
- data/app/controllers/common_objects_controller.rb +27 -0
- data/app/controllers/curation_concern/base_controller.rb +26 -0
- data/app/controllers/curation_concern/generic_files_controller.rb +82 -0
- data/app/controllers/dashboard_controller.rb +85 -0
- data/app/controllers/downloads_controller.rb +22 -0
- data/app/controllers/errors_controller.rb +19 -0
- data/app/controllers/help_requests_controller.rb +38 -0
- data/app/controllers/terms_of_service_agreements_controller.rb +44 -0
- data/app/controllers/welcome_controller.rb +14 -0
- data/app/helpers/application_helper.rb +89 -0
- data/app/helpers/blacklight_helper.rb +19 -0
- data/app/helpers/common_objects_helper.rb +5 -0
- data/app/inputs/multi_value_input.rb +71 -0
- data/app/models/access_right.rb +53 -0
- data/app/models/classify_concern.rb +30 -0
- data/app/models/contributor_agreement.rb +58 -0
- data/app/models/digital_object_identifier.rb +83 -0
- data/app/models/doi_config.rb +26 -0
- data/app/models/help_request.rb +34 -0
- data/app/models/mint_doi.rb +51 -0
- data/app/models/mint_purl.rb +40 -0
- data/app/models/object_access.rb +17 -0
- data/app/models/purl.rb +18 -0
- data/app/models/purl_config.rb +10 -0
- data/app/models/repo_object.rb +24 -0
- data/app/models/solr_document.rb +35 -0
- data/app/repository_datastreams/file_content_datastream.rb +36 -0
- data/app/repository_models/curation_concern/embargoable.rb +43 -0
- data/app/repository_models/curation_concern/with_access_right.rb +31 -0
- data/app/repository_models/generic_file.rb +36 -0
- data/app/services/anti_virus_scanner.rb +28 -0
- data/app/services/curation_concern.rb +22 -0
- data/app/services/curation_concern/base_actor.rb +48 -0
- data/app/services/curation_concern/generic_file_actor.rb +38 -0
- data/app/validators/future_date_validator.rb +19 -0
- data/app/views/_footer.html.erb +19 -0
- data/app/views/_ga.html.erb +6 -0
- data/app/views/_logo.html.erb +34 -0
- data/app/views/_masthead.html.erb +34 -0
- data/app/views/catalog/_bookmark_control.html.erb +25 -0
- data/app/views/catalog/_bookmark_form.html.erb +8 -0
- data/app/views/catalog/_citation.html.erb +11 -0
- data/app/views/catalog/_constraints.html.erb +6 -0
- data/app/views/catalog/_constraints_element.html.erb +20 -0
- data/app/views/catalog/_delete_partials/_default.html.erb +29 -0
- data/app/views/catalog/_did_you_mean.html.erb +10 -0
- data/app/views/catalog/_document.html.erb +19 -0
- data/app/views/catalog/_document_list.html.erb +2 -0
- data/app/views/catalog/_edit_partials/_default.html.erb +58 -0
- data/app/views/catalog/_edit_partials/_default_details.html.erb +13 -0
- data/app/views/catalog/_email_form.html.erb +11 -0
- data/app/views/catalog/_facet_layout.html.erb +12 -0
- data/app/views/catalog/_facet_limit.html.erb +19 -0
- data/app/views/catalog/_facet_selected.html.erb +12 -0
- data/app/views/catalog/_facets.html.erb +5 -0
- data/app/views/catalog/_folder_control.html.erb +12 -0
- data/app/views/catalog/_home.html.erb +2 -0
- data/app/views/catalog/_home_text.html.erb +10 -0
- data/app/views/catalog/_index_default.html.erb +11 -0
- data/app/views/catalog/_index_partials/_default_group.html.erb +37 -0
- data/app/views/catalog/_marc_view.html.erb +33 -0
- data/app/views/catalog/_opensearch_response_metadata.html.erb +2 -0
- data/app/views/catalog/_previous_next_doc.html.erb +6 -0
- data/app/views/catalog/_refworks_form.html.erb +7 -0
- data/app/views/catalog/_results_pagination.html.erb +6 -0
- data/app/views/catalog/_search_form.html.erb +20 -0
- data/app/views/catalog/_show_default.html.erb +9 -0
- data/app/views/catalog/_show_partials/_default.html.erb +22 -0
- data/app/views/catalog/_show_partials/_default_details.html.erb +15 -0
- data/app/views/catalog/_show_partials/_facets.html.erb +52 -0
- data/app/views/catalog/_show_sidebar.html.erb +1 -0
- data/app/views/catalog/_show_tools.html.erb +46 -0
- data/app/views/catalog/_sms_form.html.erb +21 -0
- data/app/views/catalog/_sort_and_per_page.html.erb +38 -0
- data/app/views/catalog/_uva_tabs.html.erb +10 -0
- data/app/views/catalog/about.html.erb +0 -0
- data/app/views/catalog/citation.html.erb +1 -0
- data/app/views/catalog/email.erb +1 -0
- data/app/views/catalog/endnote.endnote.erb +1 -0
- data/app/views/catalog/index.atom.builder +109 -0
- data/app/views/catalog/index.html.erb +55 -0
- data/app/views/catalog/index.rss.builder +19 -0
- data/app/views/catalog/librarian_view.html.erb +3 -0
- data/app/views/catalog/opensearch.json.erb +0 -0
- data/app/views/catalog/opensearch.xml.builder +10 -0
- data/app/views/catalog/send_email_record.erb +0 -0
- data/app/views/catalog/show.endnote.erb +1 -0
- data/app/views/catalog/show.html.erb +40 -0
- data/app/views/catalog/show.refworks.erb +1 -0
- data/app/views/catalog/sms.erb +1 -0
- data/app/views/classify_concerns/new.html.erb +24 -0
- data/app/views/common_objects/_generic_file.html.erb +0 -0
- data/app/views/common_objects/_senior_thesis.html.erb +2 -0
- data/app/views/common_objects/show.html.erb +11 -0
- data/app/views/common_objects/show_stub_information.html.erb +13 -0
- data/app/views/curation_concern/_content_license.html.erb +16 -0
- data/app/views/curation_concern/_contributor_agreement.html.erb +27 -0
- data/app/views/curation_concern/_doi.html.erb +43 -0
- data/app/views/curation_concern/_media_display.html.erb +1 -0
- data/app/views/curation_concern/_permission.html.erb +39 -0
- data/app/views/curation_concern/_related_files.html.erb +46 -0
- data/app/views/curation_concern/generic_files/_attributes.html.erb +63 -0
- data/app/views/curation_concern/generic_files/_form.html.erb +57 -0
- data/app/views/curation_concern/generic_files/edit.html.erb +5 -0
- data/app/views/curation_concern/generic_files/new.html.erb +5 -0
- data/app/views/curation_concern/generic_files/show.html.erb +12 -0
- data/app/views/curation_concern/senior_theses/_attributes.html.erb +13 -0
- data/app/views/curation_concern/senior_theses/_form.html.erb +88 -0
- data/app/views/curation_concern/senior_theses/edit.html.erb +15 -0
- data/app/views/curation_concern/senior_theses/new.html.erb +14 -0
- data/app/views/curation_concern/senior_theses/show.html.erb +18 -0
- data/app/views/dashboard/_constraints.html.erb +22 -0
- data/app/views/dashboard/_did_you_mean.html.erb +26 -0
- data/app/views/dashboard/_document_list.html.erb +20 -0
- data/app/views/dashboard/_facet_layout.html.erb +27 -0
- data/app/views/dashboard/_facet_limit.html.erb +35 -0
- data/app/views/dashboard/_facet_pagination.html.erb +25 -0
- data/app/views/dashboard/_facet_selected.html.erb +28 -0
- data/app/views/dashboard/_facets.html.erb +22 -0
- data/app/views/dashboard/_index_partials/_default_group.html.erb +37 -0
- data/app/views/dashboard/_index_partials/_list_files.html.erb +66 -0
- data/app/views/dashboard/_index_partials/_thumbnail_display.html.erb +0 -0
- data/app/views/dashboard/_results_pagination.html.erb +22 -0
- data/app/views/dashboard/_search_form.html.erb +36 -0
- data/app/views/dashboard/_show_partials/_default.html.erb +38 -0
- data/app/views/dashboard/_show_partials/_default_details.html.erb +31 -0
- data/app/views/dashboard/_show_partials/_facets.html.erb +103 -0
- data/app/views/dashboard/_sort_and_per_page.html.erb +18 -0
- data/app/views/dashboard/facet.html.erb +38 -0
- data/app/views/dashboard/get_related_file.html.erb +4 -0
- data/app/views/dashboard/index.html.erb +60 -0
- data/app/views/errors/401.html.erb +5 -0
- data/app/views/errors/404.html.erb +16 -0
- data/app/views/errors/500.html.erb +10 -0
- data/app/views/help_requests/new.html.erb +60 -0
- data/app/views/layouts/application.html.erb +14 -0
- data/app/views/layouts/boilerplate.html.erb +28 -0
- data/app/views/layouts/common_objects.html.erb +45 -0
- data/app/views/layouts/curate_nd.html.erb +55 -0
- data/app/views/layouts/curate_nd/1_column.html.erb +22 -0
- data/app/views/layouts/curate_nd/2_column.html.erb +26 -0
- data/app/views/layouts/curate_nd/catalog.html.erb +22 -0
- data/app/views/layouts/curate_nd/dashboard.html.erb +22 -0
- data/app/views/layouts/hydra-head.html.erb +95 -0
- data/app/views/shared/_action_bar.html.erb +30 -0
- data/app/views/shared/_flash_message.html.erb +9 -0
- data/app/views/shared/_site_search.html.erb +18 -0
- data/app/views/terms_of_service_agreements/new.html.erb +136 -0
- data/app/views/welcome/index.html.erb +21 -0
- data/app/workers/characterize_job.rb +4 -0
- data/app/workers/doi_worker.rb +16 -0
- data/config/routes.rb +35 -0
- data/lib/curate.rb +6 -0
- data/lib/curate/engine.rb +46 -0
- data/lib/curate/version.rb +1 -1
- data/spec/abilities/generic_file_abilities_spec.rb +55 -0
- data/spec/controllers/application_controller_spec.rb +38 -0
- data/spec/controllers/classify_concerns_controller_spec.rb +36 -0
- data/spec/controllers/common_objects_controller_spec.rb +112 -0
- data/spec/controllers/curation_concern/base_controller_spec.rb +14 -0
- data/spec/controllers/curation_concern/generic_files_controller_spec.rb +156 -0
- data/spec/controllers/dashboard_controller_spec.rb +85 -0
- data/spec/controllers/downloads_controller_spec.rb +42 -0
- data/spec/controllers/help_requests_controller_spec.rb +42 -0
- data/spec/controllers/terms_of_service_agreements_controller_spec.rb +30 -0
- data/spec/controllers/welcome_controller_spec.rb +10 -0
- data/spec/dummy/app/models/solr_document.rb +4 -0
- data/spec/dummy/app/models/user.rb +13 -0
- data/spec/dummy/config/application.rb +8 -1
- data/spec/dummy/config/database.yml +21 -22
- data/spec/dummy/config/doi.yml +11 -0
- data/spec/dummy/config/fedora.yml +20 -0
- data/spec/dummy/config/initializers/devise.rb +232 -0
- data/spec/dummy/config/initializers/hydra_config.rb +41 -0
- data/spec/dummy/config/initializers/mailboxer.rb +17 -0
- data/spec/dummy/config/initializers/redis_config.rb +45 -0
- data/spec/dummy/config/initializers/sufia.rb +66 -0
- data/spec/dummy/config/purl.yml +15 -0
- data/spec/dummy/config/redis.yml +6 -0
- data/spec/dummy/config/role_map_ci.yml +15 -0
- data/spec/dummy/config/role_map_cucumber.yml +10 -0
- data/spec/dummy/config/role_map_development.yml +12 -0
- data/spec/dummy/config/role_map_pre_production.yml +2 -0
- data/spec/dummy/config/role_map_production.yml +2 -0
- data/spec/dummy/config/role_map_test.yml +15 -0
- data/spec/dummy/config/routes.rb +4 -55
- data/spec/dummy/config/solr.yml +17 -0
- data/spec/dummy/db/migrate/20130130142162_create_purl.rb +55 -0
- data/spec/dummy/db/migrate/20130312135359_create_help_requests.rb +22 -0
- data/spec/dummy/db/migrate/20130408165008_create_users.rb +11 -0
- data/spec/dummy/db/migrate/20130408165009_acts_as_follower_migration.rb +31 -0
- data/spec/dummy/db/migrate/20130408165010_add_social_to_users.rb +27 -0
- data/spec/dummy/db/migrate/20130408165011_create_single_use_links.rb +12 -0
- data/spec/dummy/db/migrate/20130408165012_add_ldap_attrs_to_user.rb +41 -0
- data/spec/dummy/db/migrate/20130408165013_add_avatars_to_users.rb +23 -0
- data/spec/dummy/db/migrate/20130408165014_create_checksum_audit_logs.rb +34 -0
- data/spec/dummy/db/migrate/20130408165015_create_version_committers.rb +29 -0
- data/spec/dummy/db/migrate/20130408165016_add_groups_to_users.rb +25 -0
- data/spec/dummy/db/migrate/20130408165017_create_local_authorities.rb +64 -0
- data/spec/dummy/db/migrate/20130408165018_create_trophies.rb +10 -0
- data/spec/dummy/db/migrate/20130408165022_create_mailboxer.mailboxer_engine.rb +62 -0
- data/spec/dummy/db/migrate/20130408165023_add_notified_object.mailboxer_engine.rb +18 -0
- data/spec/dummy/db/migrate/20130408165024_add_notification_code.mailboxer_engine.rb +14 -0
- data/spec/dummy/db/migrate/20130408165025_add_attachments.mailboxer_engine.rb +10 -0
- data/spec/dummy/db/migrate/20130408165026_rename_receipts_read.mailboxer_engine.rb +10 -0
- data/spec/dummy/db/schema.rb +197 -0
- data/spec/dummy/db/test.sqlite3 +0 -0
- data/spec/dummy/fedora_conf/conf/development/fedora.fcfg +953 -0
- data/spec/dummy/fedora_conf/conf/test/fedora.fcfg +953 -0
- data/spec/dummy/log/development.log +1791 -0
- data/spec/dummy/log/test.log +176333 -0
- data/spec/dummy/solr_conf/conf/schema.xml +692 -0
- data/spec/dummy/solr_conf/conf/solrconfig.xml +299 -0
- data/spec/dummy/solr_conf/solr.xml +35 -0
- data/spec/factories/create_curation_concern.rb +11 -0
- data/spec/factories/create_generic_file.rb +36 -0
- data/spec/factories/help_requests.rb +10 -0
- data/spec/factories/mock_curation_concerns.rb +4 -0
- data/spec/factories/users.rb +8 -0
- data/spec/helpers/application_helper_spec.rb +139 -0
- data/spec/helpers/common_objects_helper_spec.rb +9 -0
- data/spec/models/access_right_spec.rb +47 -0
- data/spec/models/classify_concern_spec.rb +30 -0
- data/spec/models/contributor_agreement_spec.rb +45 -0
- data/spec/models/digital_object_identifier_spec.rb +50 -0
- data/spec/models/help_request_spec.rb +5 -0
- data/spec/models/mint_doi_spec.rb +79 -0
- data/spec/models/mint_purl_spec.rb +38 -0
- data/spec/models/object_access_spec.rb +24 -0
- data/spec/models/purl_spec.rb +22 -0
- data/spec/models/repo_object_spec.rb +39 -0
- data/spec/repository_models/curation_concern/embargoable_spec.rb +69 -0
- data/spec/repository_models/generic_file_spec.rb +38 -0
- data/spec/services/anti_virus_scanner_spec.rb +26 -0
- data/spec/services/curation_concern/base_actor_spec.rb +28 -0
- data/spec/services/curation_concern/generic_file_actor_spec.rb +75 -0
- data/spec/services/curation_concern_spec.rb +34 -0
- data/spec/spec_helper.rb +54 -1
- data/spec/support/environment_override.rb +17 -0
- data/spec/support/matchers/raise_rescue_response_type_matcher.rb +42 -0
- data/spec/support/mock_curation_concern.rb +61 -0
- data/spec/support/shared/shared_examples_is_embargoable.rb +9 -0
- data/spec/support/shared/shared_examples_with_access_rights.rb +33 -0
- data/spec/workers/characterize_job_spec.rb +26 -0
- metadata +686 -10
- 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 : " ".html_safe -%>
|
19
|
+
</div>
|
20
|
+
<div class="ind2">
|
21
|
+
<%= !field.indicator2.blank? ? field.indicator2 : " ".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,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,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 %>
|