7 [% CASE 'barcode' %]<span>Barcode</span>
8 [% CASE 'itemcallnumber' %]<span>Call number</span>
9 [% CASE 'stocknumber' %]<span>Inventory number</span>
10 [% CASE 'title' %]<span>Title</span>
11 [% CASE 'author' %]<span>Author</span>
12 [% CASE 'publishercode' %]<span>Publisher</span>
13 [% CASE 'publicationyear' %]<span>Publication date</span>
14 [% CASE 'collectiontitle' %]<span>Collection</span>
15 [% CASE 'isbn' %]<span>ISBN</span>
16 [% CASE 'issn' %]<span>ISSN</span>
17 [% CASE 'homebranch' %]<span>Home library</span>
18 [% CASE 'holdingbranch' %]<span>Current location</span>
19 [% CASE 'All libraries' %]<span>All libraries</span>
20 [% CASE 'location' %]<span>Shelving location</span>
21 [% CASE 'All locations' %]<span>All locations</span>
22 [% CASE 'itype' %]<span>Item type</span>
23 [% CASE 'All item types' %]<span>All item types</span>
24 [% CASE 'ccode' %]<span>Collection code</span>
25 [% CASE 'All collection codes' %]<span>All collection codes</span>
26 [% CASE 'notforloan' %]<span>Status</span>
27 [% CASE 'All statuses' %]<span>All statuses</span>
28 [% CASE 'damaged' %]<span>Damaged</span>
29 [% CASE 'itemlost' %]<span>Lost</span>
30 [% CASE 'withdrawn' %]<span>Withdrawn</span>
34 [% BLOCK form_field_select %]
35 <div class="form-field form-field-select">
36 <label class="form-field-label" for="[% name | html %]">[% INCLUDE form_label label=name %]</label>
37 <select id="[% name | html %]_op" name="[% name | html %]_op">
38 <option value="=">is</option>
39 <option value="!=" >is not</option>
41 <select id="[% name | html %]" name="[% name | html %]" multiple="multiple" size="[% options.size < 4 ? options.size + 1 : 4 | html %]">
42 <option value="" selected="selected">
43 [% IF (empty_option) %][% INCLUDE form_label label=empty_option %][% ELSE %]<span>All</span>[% END %]
45 [% FOREACH option IN options %]
46 <option value="[% option.value | html %]">[% option.label | html %]</option>
52 [% BLOCK form_field_select_option %]
53 <option value="[% value | html %]">[% INCLUDE form_label label=value %]</option>
56 [% BLOCK form_field_select_text %]
57 <div class="form-field form-field-select-text">
58 <select name="c" class="form-field-conjunction" disabled="disabled">
59 <option value="and">AND</option>
60 <option value="or">OR</option>
62 <select name="f" class="form-field-column">
63 [% INCLUDE form_field_select_option value='barcode' %]
64 [% INCLUDE form_field_select_option value='itemcallnumber' %]
65 [% INCLUDE form_field_select_option value='stocknumber' %]
66 [% INCLUDE form_field_select_option value='title' %]
67 [% INCLUDE form_field_select_option value='author' %]
68 [% INCLUDE form_field_select_option value='publishercode' %]
69 [% INCLUDE form_field_select_option value='publicationyear' %]
70 [% INCLUDE form_field_select_option value='collectiontitle' %]
71 [% INCLUDE form_field_select_option value='isbn' %]
72 [% INCLUDE form_field_select_option value='issn' %]
73 [% IF items_search_fields.size %]
74 <optgroup label="Custom search fields">
75 [% FOREACH field IN items_search_fields %]
76 [% marcfield = field.tagfield %]
77 [% IF field.tagsubfield.defined AND field.tagsubfield != "" %]
78 [% marcfield = marcfield _ '$' _ field.tagsubfield %]
80 <option value="marc:[% marcfield | html %]" data-authorised-values-category="[% field.authorised_values_category | html %]">[% field.label | html %] ([% marcfield | html %])</option>
85 <input type="text" name="q" class="form-field-value" value="" />
86 <input type="hidden" name="op" value="like" />
90 [% BLOCK form_field_radio_yes_no %]
91 <div class="form-field">
92 <label class="form-field-label">[% INCLUDE form_label label=name %]:</label>
93 <input type="radio" name="[% name | html %]" id="[% name | html %]_indifferent" value="" checked="checked"/>
94 <label for="[% name | html %]_indifferent">Ignore</label>
95 <input type="radio" name="[% name | html %]" id="[% name | html %]_yes" value="yes" />
96 <label for="[% name | html %]_yes">Yes</label>
97 <input type="radio" name="[% name | html %]" id="[% name | html %]_no" value="no" />
98 <label for="[% name | html %]_no">No</label>
102 [%# We need to escape html characters for 'value' and 'label' %]
103 [%- BLOCK escape_html_value_label -%]
104 [%- SET escaped = [] -%]
105 [%- FOR e IN elts -%]
106 [%- value = BLOCK %][% e.value | html %][% END -%]
107 [%- label = BLOCK %][% e.label | html %][% END -%]
108 [%- escaped.push({ 'value' => value, 'label' => label }) -%]
110 [%- To.json(escaped) | $raw -%]
113 [%# Page starts here %]
115 [% SET footerjs = 1 %]
116 [% INCLUDE 'doc-head-open.inc' %]
117 <title>Koha › Catalog › Item search</title>
118 [% INCLUDE 'doc-head-close.inc' %]
119 [% Asset.css("css/itemsearchform.css") | $raw %]
122 <body id="catalog_itemsearch" class="catalog">
123 [% INCLUDE 'header.inc' %]
124 [% INCLUDE 'home-search.inc' %]
125 <div id="breadcrumbs">
126 <a href="/cgi-bin/koha/mainpage.pl">Home</a> › <a href="/cgi-bin/koha/catalogue/search.pl">Catalog</a> › Item search
129 <div class="main container-fluid">
131 <div class="col-md-10 col-md-offset-1 col-lg-8 col-lg-offset-2">
133 <div id="item-search-block">
135 <p><a href="/cgi-bin/koha/catalogue/search.pl">Go to advanced search</a></p>
136 <form action="/cgi-bin/koha/catalogue/itemsearch.pl" method="get" id="itemsearchform">
137 <div id="toolbar" class="btn-toolbar">
138 <fieldset class="action">
139 <div class="btn-group">
140 <button class="btn btn-default"><i class="fa fa-search"></i> Search</button>
145 [% INCLUDE form_field_select name="homebranch" options = branches empty_option = "All libraries" %]
146 [% INCLUDE form_field_select name="holdingbranch" options = branches empty_option = "All libraries" %]
147 [% IF locations.size %]
148 [% INCLUDE form_field_select name="location" options = locations empty_option = "All locations" %]
152 [% INCLUDE form_field_select name="itype" options = itemtypes empty_option = "All item types" %]
154 [% INCLUDE form_field_select name="ccode" options = ccodes empty_option = "All collection codes" %]
156 [% IF notforloans.size %]
157 [% INCLUDE form_field_select name="notforloan" options = notforloans empty_option = "All statuses" %]
159 [% IF itemlosts.size %]
160 [% INCLUDE form_field_select name="itemlost" options = itemlosts empty_option = "All statuses" %]
162 [% IF withdrawns.size %]
163 [% INCLUDE form_field_select name="withdrawn" options = withdrawns empty_option = "All statuses" %]
167 [% INCLUDE form_field_select_text %]
168 <p class="hint">You can use the following wildcard characters: % _</p>
169 <p class="hint">% matches any number of characters</p>
170 <p class="hint">_ matches only a single character</p>
173 <div class="form-field">
174 <label class="form-field-label" for="itemcallnumber_from">From call number:</label>
175 <input type="text" id="itemcallnumber_from" name="itemcallnumber_from" value="" />
176 <span class="hint">(inclusive)</span>
178 <div class="form-field">
179 <label class="form-field-label" for="itemcallnumber_to">To call number:</label>
180 <input type="text" id="itemcallnumber_to" name="itemcallnumber_to" value="" />
181 <span class="hint">(inclusive)</span>
183 [% INCLUDE form_field_radio_yes_no name="damaged" %]
184 <div class="form-field">
185 <label class="form-field-label" for="issues_op">Checkout count:</label>
186 <select id="issues_op" name="issues_op">
187 <option value=">">></option>
188 <option value="<"><</option>
189 <option value="=">=</option>
190 <option value="!=">!=</option>
192 <input type="text" name="issues" />
194 <div class="form-field">
195 <label class="form-field-label" for="datelastborrowed_op">Last checkout date:</label>
196 <select id="datelastborrowed_op" name="datelastborrowed_op">
197 <option value=">">After</option>
198 <option value="<">Before</option>
199 <option value="=">On</option>
201 <input type="text" name="datelastborrowed" />
202 <span class="hint">ISO Format (YYYY-MM-DD)</span>
206 <div class="form-field-radio">
207 <label>Output:</label>
208 <input type="radio" id="format-html" name="format" value="html" checked="checked" /> <label for="format-html">Screen</label>
209 <input type="radio" id="format-csv" name="format" value="csv" /> <label for="format-csv">CSV</label>
210 <input type="radio" id="format-barcodes" name="format" value="barcodes"/> <label for="format-barcodes">Barcodes file</label>
218 <div class="col-md-12">
219 <div id="results-wrapper"></div>
223 [% MACRO jsinclude BLOCK %]
224 [% INCLUDE 'datatables.inc' %]
225 [% Asset.js("lib/jquery/plugins/jquery.dataTables.columnFilter.js") | $raw %]
226 [% Asset.js("lib/hc-sticky.js") | $raw %]
228 var authorised_values = [% authorised_values_json | $raw %];
230 function loadAuthorisedValuesSelect(select) {
231 var selected = select.find('option:selected');
232 var category = selected.data('authorised-values-category');
233 var form_field_value = select.siblings('.form-field-value');
234 if (category && category in authorised_values) {
235 var values = authorised_values[category];
236 var html = '<select name="q" class="form-field-value">\n';
238 var value = values[i];
239 html += '<option value="' + value.authorised_value + '">' + value.lib + '</option>\n';
241 html += '</select>\n';
242 var new_form_field_value = $(html);
243 new_form_field_value.val(form_field_value.val());
244 form_field_value.replaceWith(new_form_field_value);
246 if (form_field_value.prop('tagName').toLowerCase() == 'select') {
247 html = '<input name="q" type="text" class="form-field-value" />';
248 var new_form_field_value = $(html);
249 form_field_value.replaceWith(new_form_field_value);
254 function addNewField( link ) {
255 var form_field = $('div.form-field-select-text').last();
256 var copy = form_field.clone(true);
257 copy.find('input,select').not('[type="hidden"]').each(function() {
260 copy.find('.form-field-conjunction').prop('disabled', false);
261 form_field.after(copy);
263 copy.find('select.form-field-column').change();
266 function submitForm($form) {
269 + ' <th id="items_title">' + _("Title") + '</th>'
270 + ' <th id="items_pubdate">' + _("Publication date") + '</th>'
271 + ' <th id="items_publisher">' + _("Publisher") + '</th>'
272 + ' <th id="items_collection">' + _("Collection") + '</th>'
273 + ' <th id="items_barcode">' + _("Barcode") + '</th>'
274 + ' <th id="items_callno">' + _("Call number") + '</th>'
275 + ' <th id="items_homebranch">' + _("Home library") + '</th>'
276 + ' <th id="items_holdingbranch">' + _("Current location") + '</th>'
277 + ' <th id="items_location">' + _("Shelving location") + '</th>'
278 + ' <th id="items_itype">' + _("Itemtype") + '</th>'
279 + ' <th id="item_inventoryno">' + _("Inventory number") + '</th>'
280 + ' <th id="items_status">' + _("Not for loan status") + '</th>'
281 + ' <th id="items_itemlost">' + _("Lost status") + '</th>'
282 + ' <th id="items_widthdrawn">' + _("Withdrawn status") + '</th>'
283 + ' <th id="items_checkouts">' + _("Checkouts") + '</th>'
287 + '<table id="results">'
288 + ' <thead>' + tr + tr + '</thead>'
292 var advSearchLink = $('<a>')
293 .attr('href', '/cgi-bin/koha/catalogue/search.pl')
294 .html(_("Go to advanced search"));
295 var editSearchLink = $('<a>')
297 .html(_("Edit search"))
298 .addClass('btn btn-default btn-xs')
299 .on('click', function(e) {
301 $('#item-search-block').show();
304 var csvExportLink = $('<a>')
306 .html(_("Export results to CSV"))
307 .addClass('btn btn-default btn-xs')
308 .on('click', function(e) {
310 $('#format-csv').prop('checked', true);
311 $('#itemsearchform').submit();
312 $('#format-html').prop('checked', true);
314 var barcodesExportLink = $('<a>')
316 .html(_("Export results to barcodes file"))
317 .addClass('btn btn-default btn-xs')
318 .on('click', function(e) {
320 $('#format-barcodes').prop('checked', true);
321 $('#itemsearchform').submit();
322 $('#format-html').prop('checked', true);
325 var editSearchAndExportLinks = $('<p>')
326 .append(editSearchLink)
328 .append(csvExportLink)
330 .append(barcodesExportLink);
332 var results_heading = $('<div>').addClass('results-heading')
333 .append("<h1>" + _("Item search results") + "</h1>")
334 .append($('<p>').append(advSearchLink))
335 .append(editSearchAndExportLinks);
336 $('#results-wrapper').empty()
337 .append(results_heading)
341 $form.find('select:not(:disabled) option:selected,input[type="text"]:not(:disabled),input[type="hidden"]:not(:disabled),input[type="radio"]:checked').each(function() {
342 if ( $(this).prop('tagName').toLowerCase() == 'option' ) {
343 var name = $(this).parents('select').first().attr('name');
344 var value = $(this).val();
345 params.push({ 'name': name, 'value': value });
347 params.push({ 'name': $(this).attr('name'), 'value': $(this).val() });
351 $('#results').dataTable($.extend(true, {}, dataTablesDefaults, {
355 'sAjaxSource': '/cgi-bin/koha/catalogue/itemsearch.pl',
356 'fnServerData': function(sSource, aoData, fnCallback) {
357 aoData.push( { 'name': 'format', 'value': 'json' } );
359 aoData.push(params[i]);
366 'success': function(json){
371 'sDom': '<"top pager"ilp>t<"bottom pager"ip>r',
373 { 'sName': 'title' },
374 { 'sName': 'publicationyear' },
375 { 'sName': 'publishercode' },
376 { 'sName': 'ccode' },
377 { 'sName': 'barcode' },
378 { 'sName': 'itemcallnumber' },
379 { 'sName': 'homebranch' },
380 { 'sName': 'holdingbranch' },
381 { 'sName': 'location' },
383 { 'sName': 'stocknumber' },
384 { 'sName': 'notforloan' },
385 { 'sName': 'itemlost' },
386 { 'sName': 'withdrawn' },
387 { 'sName': 'issues' },
388 { 'sName': 'checkbox', 'bSortable': false }
390 "sPaginationType": "full_numbers"
392 'sPlaceHolder': 'head:after',
398 { 'type': 'select', 'values': [% INCLUDE escape_html_value_label elts => ccodes %] },
404 { 'type': 'select', 'values': [% INCLUDE escape_html_value_label elts => branches %] },
405 { 'type': 'select', 'values': [% INCLUDE escape_html_value_label elts => branches %] },
406 [% IF locations.size %]
407 { 'type': 'select', 'values': [% INCLUDE escape_html_value_label elts => locations %] },
411 [% IF itemtypes.size %]
412 { 'type': 'select', 'values': [% INCLUDE escape_html_value_label elts => itemtypes %] },
417 [% IF notforloans.size %]
418 { 'type': 'select', 'values': [% INCLUDE escape_html_value_label elts => notforloans %] },
422 [% IF itemlosts.size %]
423 { 'type': 'select', 'values': [% INCLUDE escape_html_value_label elts => itemlosts %] },
427 [% IF withdrawns.size %]
428 { 'type': 'select', 'values': [% INCLUDE escape_html_value_label elts => withdrawns %] },
438 $(document).ready(function () {
439 Sticky = $("#toolbar");
441 stickTo: "#item-search-block",
442 stickyClass: "floating"
444 // Add the "New field" link.
445 var form_field = $('div.form-field-select-text').last()
446 var NEW_FIELD = _("New field");
447 var button_field_new = $('<a href="#" class="button-field-new" title="Add a new field"><i class="fa fa-plus"></i> ' + NEW_FIELD + '</a>');
448 button_field_new.click(function(e) {
450 addNewField( $(this) );
452 form_field.append(button_field_new);
454 // If a field is linked to an authorised values list, display the list.
455 $('div.form-field-select-text select[name="f"]').change(function() {
456 loadAuthorisedValuesSelect($(this));
459 // Prevent user to select the 'All ...' option with other options.
460 $('div.form-field-select').each(function() {
461 $(this).find('select').filter(':last').change(function() {
462 values = $(this).val();
463 if (values.length > 1) {
464 var idx = $.inArray('', values);
466 values.splice(idx, 1);
473 $('#itemsearchform').submit(function() {
474 var searchform = $(this);
475 var format = searchform.find('input[name="format"]:checked').val();
476 if (format == 'html') {
477 submitForm(searchform);
478 $("#item-search-block").hide();
486 [% INCLUDE 'intranet-bottom.inc' %]