1 [% PROCESS "opac/parts/misc_util.tt2";
5 ctx.result_start = 1 + ctx.page_size * page;
6 ctx.result_stop = ctx.page_size * (page + 1);
7 IF ctx.result_stop > ctx.hit_count; ctx.result_stop = ctx.hit_count; END;
9 result_count = ctx.result_start;
13 [% PROCESS "opac/parts/result/paginate.tt2" %]
14 [% ctx.results_count_header = PROCESS results_count_header;
15 ctx.results_count_header %]
17 <div id="result-bookbag-heading">
18 <div class="result-bookbag-name">[% ctx.bookbag.name | html %]</div>
19 <div class="result-bookbag-description">[% ctx.bookbag.description | html %]</div>
22 <div id="result_table_div">
23 <div class="facet_sidebar_hidden" id="facet_sidebar">
24 [%- IF ctx.is_staff %]
25 <h3 class="sr-only">[% l('Saved Searches') %]</h3>
26 [% INCLUDE "opac/parts/staff_saved_searches.tt2" %]
28 <h3 class="sr-only">[% l('Search Results facets') %]</h3>
29 [% INCLUDE 'opac/parts/result/facets.tt2' %]
30 <h3 class="sr-only">[% l('Search Results List') %]</h3>
32 <div id="result_block" class="result_block_visible">
34 <div id="record_selector_block" class="hidden">
35 <input type="checkbox" id="select_all_records"></input>
36 <label for="select_all_records">[% l('Select [_1] - [_2]', ctx.result_start, ctx.result_stop) %]</label>
37 <span id="selected_records_summary">
38 <a href="[% mkurl(ctx.opac_root _ '/mylist') %]" class="no-dec" rel="nofollow" vocab="">
39 <span id="selected_records_count">[% ctx.mylist.size %]</span>
40 [% IF ctx.mylist.size == 1; %]
41 [% l('selected title') %]
43 [% l('selected titles') %]
46 <span id="hit_selected_record_limit" class="hidden">Reached limit!</span>
48 <a id="clear_basket" href="#">[% l('Clear basket') %]</a>
51 <table id="result_table_table" title="[% l('Search Results') %]"
52 class="table_no_border_space table_no_cell_pad">
53 <thead class="sr-only">
55 <th>[% l('Search result number') %]</th>
56 <th>[% l('Book jacket cover art') %]</th>
57 <th>[% l('Item details and Actions') %]</th>
60 <tbody id="result_table">
61 [% FOR rec IN ctx.records;
63 attrs.marc_xml = rec.marc_xml;
64 attrs.mr_constituent_ids = [];
65 FOREACH mr_constituent_id IN rec.mr_constituent_ids;
66 attrs.mr_constituent_ids.push(mr_constituent_id);
68 PROCESS get_marc_attrs args=attrs;
70 attrs.title = attrs.title_extended;
72 # note: rec.id refers to the record identifier, regardless
73 # of the type of record. i.e. rec.id = mmr_id ? mmr_id : bre_id
75 IF rec.mr_constituent_count > 1;
76 # metarecords link to record list page
77 record_url_path = ctx.opac_root _ '/results';
78 add_parms = {metarecord => rec.mmr_id};
81 # for MR, bre_id refers to the master and in
82 # this case, only, record
83 record_url_path = ctx.opac_root _ '/record/' _ attrs.mr_constituent_ids.0;
84 add_parms = { badges => rec.badges.join(',') };
89 record_url_path = ctx.opac_root _ '/record/' _ rec.bre_id;
90 add_parms = { badges => rec.badges.join(',') };
96 # Do not pass "advanced params" to result detail code.
97 # Instead, pass the scrubed query in one-line form
98 del_parms = del_parms.merge(['query', 'bool',
99 'qtype', 'contains', '_adv']);
101 {query => ctx.naive_query_scrub(ctx.user_query)} );
103 is_selected = ctx.mylist.grep('^' _ rec.id _ '$').size;
105 <tr class="result_table_row [% IF is_selected %]result_table_row_selected[% END %]">
106 <td class="results_row_count" name="results_row_count">
107 [% IF !ctx.is_meta; %]
108 <input type="checkbox" id="select-[% rec.bre_id %]" name="selected_record"
109 [% IF is_selected %] checked="checked" [% END %]
110 title="[% l('Add to Basket') %]"
111 class="result_record_selector hidden" value="[% rec.bre_id %]"></input>
113 [% result_count; result_count = result_count + 1 %].
115 <td class='result_table_pic_header'>
116 <a href="[% mkurl(record_url_path, add_parms, del_parms); %]">
117 <img alt="[% l('Book cover') %]"
118 name='item_jacket' class='result_table_pic' width="55"
119 src='[% ctx.media_prefix %]/opac/extras/ac/jacket/small/r/[% rec.bre_id | uri %]' /></a><br />
121 <td class='result_table_title_cell' name='result_table_title_cell'>
122 <div class="result_metadata">
124 <abbr class="unapi-id"
125 title='tag:[% ctx.hostname %],[% date.format(date.now, '%Y') %]:metabib-metarecord/[% rec.mmr_id %]'>
128 <abbr class="unapi-id"
129 title='tag:[% ctx.hostname %],[% date.format(date.now, '%Y') %]:biblio-record_entry/[% rec.bre_id %]'>
132 <a class='record_title search_link' name='record_[% rec.id %]'
133 href="[% mkurl(record_url_path, add_parms, del_parms); %]"
134 [% html_text_attr('title', l('Display record details for "[_1]"', attrs.title)) %]>
135 [% IF attrs.hl.title; attrs.hl.title; ELSE; attrs.title | html; END %]
137 [% IF rec.mr_constituent_count.defined && rec.mr_constituent_count > 1 %]
138 <span title="[% l('This group contains [_1] records', rec.mr_constituent_count) %]">
139 ([% rec.mr_constituent_count %])
144 FOR entry IN attrs.graphic_titles;
145 FOR alt IN entry.graphic;
148 diratt = ' dir="' _ alt.dir _ '"';
151 <div class="graphic880"[% diratt %]>
152 [% alt.value | html %]
160 <a title="[% l("Perform an Author Search") %]"
161 class="record_author"
163 authorquery = attrs.author | replace('[#"^$\+\-,\.:;&|\[\]()]', ' ');
164 mkurl(ctx.opac_root _ '/results', {qtype => 'author', query => authorquery}, general_search_parms.merge(expert_search_parms, browse_search_parms, facet_search_parms))
165 -%]" rel="nofollow" vocab="">[% IF attrs.hl.author; attrs.hl.author; ELSE; attrs.author | html; END %]</a>
167 FOR entry IN attrs.graphic_authors;
168 FOR alt IN entry.graphic;
171 diratt = ' dir="' _ alt.dir _ '"';
174 <div class="graphic880"[% diratt %]>
175 [% alt.value | html %]
183 <div class='result_table_title_cell'>
184 [%- IF attrs.format_label; %]
185 [% FOR format IN attrs.all_formats %]
186 <img title="[% format.label | html %]"
187 alt="[% format.label | html %]"
188 src="[% format.icon %]" />
189 [% format.label | html %]
192 [%- UNLESS show_detail_view;
194 pubdate_clean = attrs.pubdate | html;
195 l(" ([_1])", pubdate_clean);
196 ELSIF attrs.copyright;
197 copyright_clean = attrs.copyright | html;
198 l(" ([_1])", copyright_clean);
203 [% IF rec.popularity > 0.0 AND ctx.hide_badge_scores != 'true' %]
205 <span><strong>[% l('Popularity:') %]</strong> [% rec.popularity %] / 5.0</span>
210 title="[% l('Record Holdings Summary') %]"
211 class="table_no_border_space table_no_cell_pad table_no_border results_info_table">
212 [% UNLESS rec.mmr_id OR show_detail_view %]
213 [% IF args.holdings.size > 0 %]
214 <tr name='bib_cn_list' class='result_table_title_cell'>
216 <strong>[% l('Call number:') %]</strong>
218 <td>[% args.holdings.0.label | html %]</td>
223 [%- IF show_detail_view -%]
224 <!-- These fields are visible when viewing the results page in 'detailed' mode -->
225 [% UNLESS rec.mmr_id %]
226 <!-- Do not show publication-specific information on a metarecord search results page -->
227 [% IF attrs.publisher %]
228 <tr name="results_pub_tr">
230 <strong>[% l('Publisher:') %]</strong>
232 <td>[% attrs.pubplace | html; %] [% attrs.publisher | html; %] [% attrs.pubdate | html; %]
234 FOR entry IN attrs.graphic_pubinfos;
235 FOR alt IN entry.graphic;
238 diratt = ' dir="' _ alt.dir _ '"';
241 <div class="graphic880"[% diratt %]>
242 [% alt.value | html %]
250 [% ELSIF attrs.producer %]
251 <tr name="results_pub_tr">
253 <strong>[% l('Producer:') %]</strong>
255 <td>[% attrs.prodplace | html; %] [% attrs.producer | html; %] [% attrs.proddate | html; %]</td>
257 [% ELSIF attrs.distributor %]
258 <tr name="results_pub_tr">
260 <strong>[% l('Distributor:') %]</strong>
262 <td>[% attrs.distplace | html; %] [% attrs.distributor | html; %] [% attrs.distdate | html; %]</td>
264 [% ELSIF attrs.manufacturer %]
265 <tr name="results_pub_tr">
267 <strong>[% l('Manufacturer:') %]</strong>
269 <td>[% attrs.manplace | html; %] [% attrs.manufacturer | html; %] [% attrs.mandate | html; %]</td>
272 [% IF attrs.isbns.size > 0 %]
273 <tr name="results_isbn_tr">
275 <strong>[% l('ISBN:') %]</strong>
277 <td>[% attrs.isbns.0 | html %]</td>
280 [%- IF attrs.issns.size > 0 %]
281 <tr name="results_issn_tr">
283 <strong>[% l('ISSN:') %]</strong>
285 <td>[% attrs.issns.0 | html %]</td>
288 [%- IF openurl.enabled == 'true';
289 FOREACH issn IN args.issns;
291 res_urls = ResolverResolver.resolve_issn(issn, openurl.baseurl);
292 FOREACH res IN res_urls;
294 <tr name="results_issn_tr">
296 <strong><a href="[% res.target_url %]">
297 [% res.public_name | html %]</a></strong>
299 <td>[% res.target_coverage | html %]
300 [%- IF res.target_embargo != '';
302 res.target_embargo | html;
311 [% IF attrs.edition %]
312 <tr name="results_edition_tr">
314 <strong>[% l('Edition:') %]</strong>
316 <td>[% attrs.edition | html %]
318 FOR entry IN attrs.graphic_editions;
319 FOR alt IN entry.graphic;
322 diratt = ' dir="' _ alt.dir _ '"';
325 <div class="graphic880"[% diratt %]>
326 [% alt.value | html %]
335 [% IF attrs.phys_desc %]
336 <tr name="results_phys_desc_tr">
337 <td nowrap="nowrap" valign="top">
338 <strong>[% l('Phys. Desc.:') %]</strong>
341 [% args.phys_desc | html %]
345 [% FOR uri IN args.uris %]
346 <tr name='bib_uri_list' class='result_table_title_cell'>
348 <strong>[% l('Electronic resource') %]</strong>
350 <td><a href="[% uri.href %]" class="uri_link" target="_blank">[% uri.link | html %]</a>[% ' - ' _ uri.note | html IF uri.note %]</td>
354 [%- IF args.holdings.size > 0;
355 FOREACH copy IN args.holdings;
356 IF copy.part_label != '';
362 <tr name='bib_cn_list' class='result_table_title_cell'>
364 <table title="[% l('Record Holdings Details') %]"
365 class='result_holdings_table'>
367 <th>[% l('Library') %]</th>
368 <th>[% l('Shelving location') %]</th>
369 <th>[% l('Call number') %]</th>
370 [%- IF has_parts == 'true'; %]
371 <th>[% l('Part') %]</th>
373 <th>[% l('Status') %]</th>
376 [% FOR copy IN args.holdings %]
379 [%- copy_info = copy;
380 INCLUDE "opac/parts/library_name_link.tt2"; %]
382 <td>[% copy.location | html %]</td>
383 <td>[% copy.label | html %]</td>
384 [%- IF has_parts == 'true'; %]
385 <td>[% copy.part_label %]</td>
387 <td>[% copy.status | html %]</td>
394 [%- has_parts = 'false';
397 [% END %] <!-- END detail_record_view -->
400 IF ebook_api.enabled == 'true';
401 INCLUDE "opac/parts/ebook_api/avail.tt2";
404 [% UNLESS rec.mmr_id;
405 PROCESS "opac/parts/result/copy_counts.tt2";
407 [% IF rec.user_circulated %]
408 <div class="result_item_circulated">
409 <img src="[% ctx.media_prefix %]/images/green_check.png[% ctx.cache_key %]" alt="[% l('Checked Out Before') %]"/>
410 <span>[% l('I have checked this item out before') %]</span>
415 FOR note IN ctx.bookbag_items_by_bre_id.$rec_id.notes %]
416 <div class="result-bookbag-item-note">
417 [% note.note | html %]
422 <div class="result_table_utils_cont">
423 <div class="result_table_utils">
424 [%- search_ou = ctx.search_ou;
425 num_holdable_copies = attrs.marc_xml.findnodes('//*[local-name()="holdings" and @has_holdable="true"]').size || 0;
426 IF ctx.place_unfillable ||
427 ( num_holdable_copies > 0
428 && (ctx.holds_block.enabled != 'true' || attrs.org_copy_counts.$search_ou.available == 0)
432 [% del_parms = ['tag','subfield','term','_special',
434 add_parms = {hold_target => rec.id,
435 hold_type => hold_type,
436 hold_source_page => mkurl()};
439 # Do not pass "advanced params" to hold code
440 # Instead, pass the scrubed query in one-line form
441 del_parms = del_parms.merge(['query', 'bool',
442 'qtype', 'contains', '_adv']);
444 {query => ctx.naive_query_scrub(ctx.user_query)});
447 <div class="results_aux_utils place_hold"><a
448 href="[% mkurl(ctx.opac_root _ '/place_hold',
449 add_parms, del_parms) %]"
450 [% html_text_attr('title', l('Place Hold on [_1]', attrs.title)) %]
451 class="no-dec" rel="nofollow" vocab=""><img
452 src="[% ctx.media_prefix %]/images/green_check.png[% ctx.cache_key %]"
453 alt=""/><span class="result_place_hold">[% l('Place Hold') %]</span></a>
457 [%- IF ebook_api.enabled == 'true' && args.ebook %]
458 <div id="[%- rec.id -%]_ebook_checkout" class="results_aux_utils result_util ebook_action hidden">
459 <a href="[% mkurl(ctx.opac_root _ '/myopac/ebook_checkout',
460 {title => args.ebook.ebook_id, vendor => args.ebook.vendor, action => 'checkout'},
461 ['query','tag','subfield','term','_special','sort','page']) %]"
462 [% html_text_attr('title', l('Check Out [_1]', attrs.title)) %]
463 class="no-dec" rel="nofollow" vocab=""><img
464 src="[% ctx.media_prefix %]/images/green_check.png[% ctx.cache_key %]"
465 alt=""/><span class="result_place_hold">[% l('Check Out E-Item') %]</span></a>
467 <div id="[%- rec.id -%]_ebook_place_hold" class="results_aux_utils result_util ebook_action hidden">
468 <a href="[% mkurl(ctx.opac_root _ '/myopac/ebook_place_hold',
469 {title => args.ebook.ebook_id, vendor => args.ebook.vendor, action => 'place_hold'},
470 ['query','tag','subfield','term','_special','sort','page']) %]"
471 [% html_text_attr('title', l('Place Hold on [_1]', attrs.title)) %]
472 class="no-dec" rel="nofollow" vocab=""><img
473 src="[% ctx.media_prefix %]/images/green_check.png[% ctx.cache_key %]"
474 alt=""/><span class="result_place_hold">[% l('Place Hold on E-Item') %]</span></a>
478 [% IF !ctx.is_meta %]
479 <div class="results_aux_utils result_util">
480 [% IF !ctx.is_staff %]
482 addhref = mkurl(ctx.opac_root _ '/mylist/add',
483 {record => rec.id, anchor => 'record_' _ rec.id}, 1);
484 delhref = mkurl(ctx.opac_root _ '/mylist/delete',
485 {record => rec.id, anchor => 'record_' _ rec.id}, 1);
487 <a href="[% addhref %]" id="mylist_add_[% rec.id %]"
488 data-recid="[% rec.id %]" data-action="add"
489 class="mylist_action [% IF ctx.mylist.grep('^' _ rec.id _ '$').size %]hidden[% END %]"
490 title="[% l("Add [_1] to basket", attrs.title) %]" rel="nofollow" vocab="">
491 <img src="[% ctx.media_prefix %]/images/add-to-cart.png[% ctx.cache_key %]" alt="" />
492 [% l("Add to basket") %]
494 <a href="[% delhref %]" id="mylist_delete_[% rec.id %]"
495 data-recid="[% rec.id %]" data-action="delete"
496 class="mylist_action [% IF !ctx.mylist.grep('^' _ rec.id _ '$').size %]hidden[% END %]"
497 title="[% l("Remove [_1] from basket", attrs.title) %]" rel="nofollow" vocab="">
498 <img src="[% ctx.media_prefix %]/images/add-to-cart.png[% ctx.cache_key %]" alt="" />
499 [% l("Remove from basket") %]
502 INCLUDE "opac/parts/bookbag_actions.tt2";
508 [% IF ENV.OILS_CONTENT_CAFE_USER %]
509 [% ident = attrs.isbn_clean || attrs.upc %]
510 <div class="results_aux_utils result_util">
512 [% html_text_attr('title', l('Reviews and More for [_1]', attrs.title)) %]
513 href="[% ctx.ext_proto %]://contentcafe2.btol.com/ContentCafeClient/ContentCafe.aspx?UserID=[%-
514 ENV.OILS_CONTENT_CAFE_USER %]&Password=[%-
515 ENV.OILS_CONTENT_CAFE_PASS %]&ItemKey=[% ident | uri %]&Options=Y" rel="nofollow" vocab="">
516 <img src='[% ctx.media_prefix %]/images/starz.png[% ctx.cache_key %]' alt="[% l('Ratings Icon') %]"/>
517 <span class="results_reviews">[% l('Reviews & More') %]</span>
527 [%- IF ENV.OILS_CHILIFRESH_ACCOUNT %]
530 <td align='center'> <!-- Chilifresh reviews link -->
531 <span class="chili_review" id="isbn_[% attrs.isbn_clean | html %]"> </span>
536 <td colspan='5'> <!-- Chilifresh reviews panel -->
537 <div id="chili_review_[% attrs.isbn_clean | html %]" style="display: none;" align="center"></div>
546 <div class="result_footer_nav1">
547 [% ctx.results_count_header %]
550 resultBlock = document.getElementById('result_block');
551 resultButton = document.getElementById('return_to_hits');
552 facetSidebar = document.getElementById('facet_sidebar');
553 facetButton = document.getElementById('refine_hits');
554 function getFacety() {
555 resultBlock.setAttribute('class', 'result_block_hidden');
556 resultButton.setAttribute('class', 'results_header_btns result_block_visible');
557 facetSidebar.setAttribute('class', 'facet_sidebar_visible');
558 facetButton.setAttribute('class', 'result_block_hidden');
559 window.location.hash = 'return_to_hits';
561 function getResulty() {
562 resultBlock.setAttribute('class', 'result_block_visible');
563 resultButton.setAttribute('class', 'result_block_hidden');
564 facetSidebar.setAttribute('class', 'facet_sidebar_hidden');
565 facetButton.setAttribute('class', 'results_header_btns result_block_visible');
566 window.location.hash = 'refine_hits';