2 series_tags = ['440', '490', '800', '810', '811', '830', '694'];
7 IF attrs.hl_display_fields.series_title.size;
8 FOREACH s IN attrs.hl_display_fields.series_title;
9 search_term = s.value.replace('[#"^$\+\-,\.:;&|\[\]()]', ' ').replace('\s+$', '') | html;
11 url = mkurl(ctx.opac_root _ '/results',
12 { qtype=>'series', query=>search_term }, stop_parms.merge(expert_search_parms, general_search_parms, browse_search_parms, facet_search_parms)
14 series = '<a href="' _ url _ '">' _ s.highlight _ '</a> ';
18 FOR tag IN series_tags;
19 FOR node IN ctx.marc_xml.findnodes('//*[@tag="' _ tag _ '"]');
23 FOR subfield IN node.childNodes;
24 NEXT UNLESS subfield.nodeName == "subfield";
25 code = subfield.getAttribute('code');
27 linked_fields = [subfield.textContent()];
28 target_field = node.getAttribute('tag');
31 NEXT UNLESS code.match('[a-z]');
32 # at this point, we actually have a partial term to use.
33 single_term = subfield.textContent | html;
34 all_terms.push(subfield.textContent.replace('[#"^$\+\-,\.:;&|\[\]()]', ' '));
35 total_term = all_terms.join(" ").replace('\s+$', '');
37 url = mkurl(ctx.opac_root _ '/results',
38 { qtype=>'series', query=>total_term }, stop_parms.merge(expert_search_parms, general_search_parms, browse_search_parms, facet_search_parms)
40 series = series _ '<a href="' _ url _ '">' _ single_term _ '</a> ';
42 FOREACH link880 IN graphics;
43 link = link880.value | html;
44 series = series _ '<div class="graphic880"' _ link880.dir _ '>' _ link _ '</div>';
52 <li class='rdetail_series_value'>[% entry %]</li>
57 [%- series_anchors = PROCESS render_series;
58 IF series_anchors.length > 0; %]
59 <h2 class='rdetail_related_series'>[% l('Search for related items by series') %]</h2>