Bug 26664: (QA follow-up) Add filters
[koha.git] / koha-tmpl / intranet-tmpl / prog / en / modules / tools / inventory.tt
1 [% USE raw %]
2 [% USE Asset %]
3 [% USE KohaDates %]
4 [% USE Branches %]
5 [% SET footerjs = 1 %]
6 [% INCLUDE 'doc-head-open.inc' %]
7 <title>Koha &rsaquo; Tools &rsaquo; Inventory</title>
8 [% INCLUDE 'doc-head-close.inc' %]
9 </head>
10
11 <body id="tools_inventory" class="tools">
12 [% INCLUDE 'header.inc' %]
13 [% INCLUDE 'cat-search.inc' %]
14
15 <div id="breadcrumbs"><a href="/cgi-bin/koha/mainpage.pl">Home</a> &rsaquo; <a href="/cgi-bin/koha/tools/tools-home.pl">Tools</a> &rsaquo; [% IF (loop) %]<a href="/cgi-bin/koha/tools/inventory.pl">Inventory</a> &rsaquo; Results[% ELSE %]Inventory[% END %]</div>
16
17 <div class="main container-fluid">
18     <div class="row">
19         <div class="col-sm-10 col-sm-push-2">
20             <main>
21
22     <h1>Inventory</h1>
23     [% IF (moddatecount) %]<div class="dialog message">[% moddatecount | html %] items modified : datelastseen set to [% date | $KohaDates %]</div>
24     <div class="dialog alert">Number of potential barcodes read: [% LinesRead | html %]</div>[% END %]
25     [% IF (errorfile) %]<div class="dialog alert">[% errorfile | html %] can't be opened</div>[% END %]
26     [% IF (err_length && err_length==1) %]<div class="dialog alert">There was 1 barcode that was too long.</div>[% END %]
27     [% IF (err_length && err_length>1) %]<div class="dialog alert">There were [% err_length | html %] barcodes that were too long.</div>[% END %]
28     [% IF (err_data && err_data==1) %]<div class="dialog alert">There was 1 barcode that contained at least one unprintable character.</div>[% END %]
29     [% IF (err_data && err_data>1) %]<div class="dialog alert">There were [% err_data | html %] barcodes that contained at least one unprintable character.</div>[% END %]
30     [% FOREACH error IN errorloop %]
31         <div class="dialog alert">
32             [% error.barcode | html %]
33             [% IF (error.ERR_BARCODE) %]: barcode not found[% END %]
34             [% IF (error.ERR_WTHDRAWN) %]: item withdrawn[% END %]
35             [% IF (error.ERR_ONLOAN_RET) %]: item was on loan. It was returned before marked as seen[% END %]
36             [% IF (error.ERR_ONLOAN_NOT_RET) %]: item was on loan. couldn't be returned.[% END %]
37         </div>
38     [% END %]
39        [% UNLESS op %]
40
41     <form method="post" id="inventory_form" action="/cgi-bin/koha/tools/inventory.pl" enctype="multipart/form-data">
42         <fieldset class="rows">
43           <legend>Use a barcode file</legend>
44           <ol>
45             <li><label for="uploadbarcodes">Barcode file: </label> <input type="file" id="uploadbarcodes" name="uploadbarcodes" />
46             <input type="button" id="resetuploadbarcodes" name="resetuploadbarcodes" value="Reset" /></li>
47           </ol>
48         </fieldset>
49         <fieldset class="rows">
50             <legend>Or scan items one by one</legend>
51             <ol>
52                 <li>
53                   <label for="barcodelist">Barcode list (one barcode per line): </label>
54                   <textarea rows="10" cols="30" id="barcodelist" name="barcodelist"></textarea>
55                 </li>
56             </ol>
57         </fieldset>
58         <fieldset class="rows">
59             <legend>Parameters</legend>
60             <ol>
61                 <li><label for="setdate">Set inventory date to:</label> <input type="text" id="setdate" name="setdate" value="[% today | $KohaDates %]" class="datepicker" disabled /></li>
62                 <li><label for="compareinv2barcd">Compare barcodes list to results: </label><input type="checkbox" name="compareinv2barcd" id="compareinv2barcd" disabled /></li>
63                 <li><label for="dont_checkin">Do not check in items scanned during inventory: </label><input type="checkbox" name="dont_checkin" id="dont_checkin" disabled /></li>
64                 <li><label for="out_of_order">Check barcodes list for items shelved out of order: </label><input type="checkbox" name="out_of_order" id="out_of_order" disabled /></li>
65             </ol>
66         </fieldset>
67         <fieldset class="rows">
68         <legend>Item location filters</legend>
69         <ol><li>
70         <label for="branch">Location: </label>
71             <input type="radio" name="branch" value="homebranch"> Home library</input>
72             <input type="radio" name="branch" value="holdingbranch"> Current library</input>
73         </li><li>
74         <label for="branchloop">Library: </label><select id="branchloop" name="branchcode" style="width:12em;">
75             <option value="">All libraries</option>
76             [% PROCESS options_for_libraries libraries => Branches.all( selected => branchcode, unfiltered => 1, ) %]
77         </select>
78         </li>
79         [% IF (authorised_values) %]
80         <li>
81             <label for="locationloop">Shelving location (items.location) is: </label>
82         <select id="locationloop" name="location">
83                 <option value="">Filter location</option>
84         [% FOREACH value IN authorised_values %]
85             [% IF (value.selected) %]
86                 <option value="[% value.authorised_value | html %]" selected="selected">[% value.lib | html %]</option>
87             [% ELSE %]
88                 <option value="[% value.authorised_value | html %]">[% value.lib | html %]</option>
89             [% END %]
90         [% END %]
91         </select>        </li>
92         [% END %]
93         <li>
94             <label for="minlocation">Item callnumber between: </label>
95                 <input type="text" name="minlocation" id="minlocation" value="[% minlocation | html %]" /> (items.itemcallnumber)  </li>
96            <li><label for="maxlocation">...and: </label>
97                 <input type="text" name="maxlocation" id="maxlocation" value="[% maxlocation | html %]" />
98            <li>
99             <label for="class_source">Callnumber classification scheme</label>
100             <select name="class_source">
101             [% FOREACH class_source IN class_sources %]
102                 [% IF class_source.cn_source == pref_class %]
103                 <option value="[% class_source.cn_source | html %]" selected="selected">[% class_source.description | html %] (default)</option>
104                 [% ELSE %]
105                 <option value="[% class_source.cn_source | html %]">[% class_source.description | html %]</option>
106                 [% END %]
107             [% END %]
108             </select>
109           </li>
110     </ol>
111     </fieldset>
112
113     <fieldset class="rows" id="optionalfilters">
114             <legend>Optional filters for inventory list or comparing barcodes</legend>
115             <br/>
116             <div id="statuses" style="display: block;">
117                   [% FOREACH status IN statuses %]
118                       [% IF (status.values) %]
119                           <fieldset style="float: left; padding: 5px; margin: 5px;text-align:right">
120                               <legend>[% status.fieldname | html %]</legend>
121                               <ul id="statuses-[% fieldname | html %]" style="display: inline;">
122                               [% FOREACH value IN status.values %]
123                                   [% IF (value.lib) %]
124                                     <li>
125                                     <label for="[% value.id | html %]">
126                                         [% IF ( status.fieldname == 'items.notforloan' && value.authorised_value == 0 && value.lib == '__IGNORE__' ) %]
127                                             For loan
128                                         [% ELSE %]
129                                             [% value.lib | html %]
130                                         [% END %]
131                                     </label>
132                                     <input type="checkbox" name="status-[% status.fieldname | html %]-[% value.authorised_value | html %]" id="[% value.authorised_value | html %]" />
133                                     </li>
134                                   [% END %]
135                               [% END %]
136                               </ul>
137                           </fieldset>
138                       [% END %]
139                   [% END %]
140                 </div>
141         <ol>
142         <li>
143             <br/>
144             <label for="datelastseen">Last inventory date:</label>
145             <input type="text" id="datelastseen" name="datelastseen" value="[% datelastseen | $KohaDates %]" class="datepicker" />
146             (Skip records marked as seen on or after this date.)
147         </li>
148         <li>
149             <label for="ignoreissued">Skip items on loan: </label>
150             [% IF (ignoreissued) %]
151                 <input type="checkbox" id="ignoreissued" name="ignoreissued" checked="checked" />
152             [% ELSE %]
153                 <input type="checkbox" id="ignoreissued" name="ignoreissued" />
154             [% END %]
155         </li>
156         <li>
157             <label for="ignore_waiting_holds">Skip items on hold awaiting pickup: </label>
158             <input type="checkbox" id="ignore_waiting_holds" name="ignore_waiting_holds" />
159         </li>
160         </ol>
161     </fieldset>
162
163         <fieldset class="rows">
164           <legend>Additional options</legend>
165           <ol>
166
167         <li>
168            <label for="CSVexport">Export to CSV file: </label>
169            <input type="checkbox" name="CSVexport" id="CSVexport" />
170         </li>
171         </ol>
172   </fieldset>
173             <input type="hidden" name="op" value="do_it" />
174
175             <fieldset class="action"><input type="submit" value="Submit" class="button" /></fieldset>
176     </form>
177
178     [% END %]
179     [% IF (op) %]
180     <form method="post" action="/cgi-bin/koha/tools/inventory.pl">
181     <input type="hidden" name="minlocation" value="[% minlocation | html %]" />
182     <input type="hidden" name="maxlocation" value="[% maxlocation | html %]" />
183     <input type="hidden" name="location" value="[% location | html %]" />
184     <input type="hidden" name="branchcode" value="[% branchcode | html %]" />
185     <input type="hidden" name="datelastseen" value="[% datelastseen | html %]" />
186
187     [% UNLESS uploadedbarcodesflag %]
188       <div><a href="#" class="checkall"><i class="fa fa-check"></i> Select all</a> <a href="#" class="clearall"><i class="fa fa-remove"></i> Clear all</a></div>
189     [% END %]
190
191     <table id="inventoryt">
192     <thead>
193         <tr>
194             [% UNLESS uploadedbarcodesflag %]<th>Seen</th>[% END %]
195             <th>Barcode</th>
196             <th>Call number</th>
197             <th>Library</th>
198             <th class="anti-the">Title</th>
199             <th>Not for loan</th>
200             <th>Lost</th>
201             <th>Damaged</th>
202             <th>Withdrawn</th>
203             <th class="title-string">Last seen</th>
204             <th>Problems</th>
205         </tr>
206     </thead>
207     <tbody>
208     [% FOREACH result IN loop %]
209         <tr>
210             [% UNLESS uploadedbarcodesflag %]
211               <td>
212                 <input type="checkbox" name="SEEN-[% result.itemnumber | html %]" value="1" />
213               </td>
214             [% END %]
215             <td>
216             [% result.barcode | html %]
217             </td>
218             <td>[% result.itemcallnumber | html %]</td>
219             <td>
220                 [% Branches.GetName( result.homebranch ) | html %]
221                 <span class="shelvingloc">[% result.location | html %]</span>
222             </td>
223             <td>
224                 <a href="/cgi-bin/koha/catalogue/detail.pl?biblionumber=[% result.biblionumber | uri %]" class="openWin">[% result.title | html %]</a>
225                 [% IF ( result.author ) %]
226                     by <span class="author">[% result.author | html %]</span>
227                 [% END %]
228             </td>
229             <td>
230             [% result.notforloan | html %]
231             </td>
232             <td>
233             [% result.itemlost | html %]
234             </td>
235             <td>
236             [% result.damaged | html %]
237             </td>
238             <td>
239             [% result.withdrawn | html %]
240             </td>
241             <td>
242                 <span title="[% result.datelastseen | html %]">[% result.datelastseen | $KohaDates%]</span>
243             </td>
244             <td>
245             [% FOREACH problem IN result.problems %]
246                 [% IF problem.key == 'wrongplace' %]
247                     Found in wrong place<br/>
248                 [% ELSIF problem.key == 'changestatus' %]
249                     Unknown not-for-loan status<br/>
250                 [% ELSIF problem.key == 'not_scanned' %]
251                     Missing (not scanned)<br/>
252                 [% ELSIF problem.key == 'checkedout' %]
253                     Still checked out<br/>
254                 [% ELSIF problem.key == 'no_barcode' %]
255                     No barcode<br/>
256                 [% ELSIF problem.key == 'out_of_order' %]
257                     Item may be shelved out of order<br/>
258                 [% END %]
259             [% END %]
260             </td>
261         </tr>
262     [% END %]
263     </tbody>
264     </table>
265     <div class="spacer"></div>
266     [% UNLESS uploadedbarcodesflag %]
267       <div style="padding : .3em 0"><a href="#" class="checkall"><i class="fa fa-check"></i> Select all</a> <a href="#" class="clearall"><i class="fa fa-remove"></i> Clear all</a></div>
268       <input type="submit" id="markseenandquit" value="Mark seen and quit" />
269       <input type="submit" value="Mark seen and continue &gt;&gt;" id="markseenandcontinuebutton" />
270       <input type="submit" value="Continue without marking &gt;&gt;" id="continuewithoutmarkingbutton" class="submit" />
271     [% END %]
272     </form>
273
274
275     [% END %]
276
277             </main>
278         </div> <!-- /.col-sm-10.col-sm-push-2 -->
279
280         <div class="col-sm-2 col-sm-pull-10">
281             <aside>
282                 [% INCLUDE 'tools-menu.inc' %]
283             </aside>
284         </div> <!-- .col-sm-2.col-sm-pull-10 -->
285      </div> <!-- /.row -->
286
287 [% MACRO jsinclude BLOCK %]
288     [% Asset.js("js/tools-menu.js") | $raw %]
289     [% INCLUDE 'datatables.inc' %]
290     [% INCLUDE 'calendar.inc' %]
291     <script type="text/javascript">
292         function checkForm() {
293             if ( $('#uploadbarcodes').val() && $('#barcodelist').val() ) {
294                 alert(_("You have uploaded a barcode file and scanned barcodes at the same time. Please choose one of the two options."));
295                 return false;
296             }
297             if ( $('#uploadbarcodes').val() || $('#barcodelist').val() ) {
298                 if ( !(
299                     $('#branchloop').val()   ||
300                     $('#locationloop').val() ||
301                     $('#minlocation').val()  ||
302                     $('#maxlocation').val()  ||
303                     $('#statuses input:checked').length
304                 ) ) {
305                     return confirm(
306                         _("You have not selected any catalog filters and are about to compare a file of barcodes to your entire catalog.") + "\n\n" +
307                         _("For large catalogs this can result in unexpected behavior") + "\n\n" +
308                         _("Are you sure you want to do this?")
309                     );
310                 }
311             }
312
313             return true;
314         }
315
316         function barcodesProvided() {
317             if( $("#uploadbarcodes").val() || $("#barcodelist").val() ) {
318                 $("#setdate").prop('disabled',false);
319                 $("#compareinv2barcd").prop('disabled',false);
320                 $("#compareinv2barcd").attr('checked',true); // default
321                 $("#dont_checkin").prop('disabled',false);
322                 $("#out_of_order").prop('disabled',false);
323                 if( $("#compareinv2barcd").attr('checked') ) {
324                     $("fieldset#optionalfilters").show();
325                     $("#ignoreissued").attr('checked',true); // default
326                 } else {
327                     $("fieldset#optionalfilters").hide();
328                     $("#ignoreissued").attr('checked',false);
329                 }
330             } else {
331                 $("#setdate").prop('disabled',true);
332                 $("#compareinv2barcd").prop('disabled',true);
333                 $("#compareinv2barcd").attr('checked',false);
334                 $("#dont_checkin").prop('disabled',true);
335                 $("#dont_checkin").attr('checked',false);
336                 $("#out_of_order").prop('disabled',true);
337                 $("#out_of_order").attr('checked',false);
338                 $("fieldset#optionalfilters").show();
339             }
340         }
341
342         $(document).ready(function(){
343             inventorydt = $('#inventoryt').dataTable($.extend(true, {}, dataTablesDefaults, {
344                 'sPaginationType': 'full_numbers',
345                 [% IF compareinv2barcd %]
346                     // sort on callnumber
347                     "aaSorting": [[ 1, "asc" ]],
348                 [% ELSE %]
349                     // first column contains checkboxes
350                     "aoColumnDefs": [
351                         { "sType": "anti-the", "aTargets" : [ "anti-the" ] },
352                         { "bSortable": false, "bSearchable": false, "aTargets": [ 0 ] },
353                         { "sType": "title-string", "aTargets" : [ "title-string" ] },
354                     ],
355                     // 3rd column is callnumber
356                     "aaSorting": [[ 2, "asc" ]],
357                 [% END %]
358                 'fnDrawCallback': function() {
359                     //bind the click handler script to the newly created elements held in the table
360                     $('.openWin').bind('click',function(e){
361                         e.preventDefault();
362                         openWindow(this.href,'marcview',800,600);
363                     });
364                 }
365             } ));
366
367
368             $("#continuewithoutmarkingbutton").click(function(){
369                 inventorydt.fnPageChange( 'next' );
370                 return false;
371             });
372
373             $("#markseenandcontinuebutton").click(function(){
374                 var param = '';
375                 $("input:checked").each(function() {
376                     param += "|" + $(this).attr('name');
377                 });
378                 $.post('/cgi-bin/koha/tools/ajax-inventory.pl', { seen: param });
379                 inventorydt.fnPageChange( 'next' );
380                 return false;
381             });
382
383             $("#markseenandquit").click(function(){
384                 var param = '';
385                 $("input:checked").each(function() {
386                     param += "|" + $(this).attr('name');
387                 });
388                 $.ajax({
389                   type: 'POST',
390                   url: '/cgi-bin/koha/tools/ajax-inventory.pl',
391                   data: { seen: param},
392                   async: false
393                 });
394                 document.location.href = '/cgi-bin/koha/tools/inventory.pl';
395                 return false;
396             });
397
398             var checkboxes = $("#inventoryt input:checkbox");
399             $(".checkall").click(function(e){
400                 e.preventDefault();
401                 checkboxes.each(function(){
402                     $(this).prop("checked", true);
403                 });
404             });
405             $(".clearall").click(function(e){
406                 e.preventDefault();
407                 checkboxes.each(function(){
408                     $(this).prop("checked", false);
409                 });
410             });
411             $("#inventory_form").on("submit",function(){
412                 return checkForm();
413             });
414
415             $("#resetuploadbarcodes").click(function() {
416                 $("#uploadbarcodes").val("");
417                 barcodesProvided();
418             });
419
420             // #uploadbarcodes and #compareinv2barcd determine the behavior of
421             // the controls within the barcode fieldset and the optional filters
422             $("#uploadbarcodes").change(barcodesProvided);
423             $("#barcodelist").on("change keyup paste", barcodesProvided);
424
425             $("#compareinv2barcd").click(function() {
426                 if( $("#compareinv2barcd").attr('checked') ) {
427                     $("fieldset#optionalfilters").show();
428                     $("#ignoreissued").attr('checked',true); // default
429                 } else {
430                     $("#ignoreissued").attr('checked',false);
431                     $("fieldset#optionalfilters").hide();
432                 }
433             });
434         });
435     </script>
436 [% END %]
437
438 [% INCLUDE 'intranet-bottom.inc' %]