5 [% USE TablesSettings %]
6 [% USE AuthorisedValues %]
10 [% INCLUDE 'doc-head-open.inc' %]
11 <title>Koha › Circulation › Holds to pull</title>
12 [% INCLUDE 'doc-head-close.inc' %]
15 <body id="circ_pendingreserves" class="circ">
16 [% INCLUDE 'header.inc' %]
17 [% INCLUDE 'circ-search.inc' %]
20 <div id="breadcrumbs"><a href="/cgi-bin/koha/mainpage.pl">Home</a> › <a href="/cgi-bin/koha/circ/circulation-home.pl">Circulation</a> › Holds to pull</div>
22 <div class="main container-fluid">
24 <div class="col-sm-10 col-sm-push-2">
27 [% FOR m IN messages %]
28 <div class="dialog [% m.type | html %]">
30 [% CASE 'letter_enqueued' %]
31 <span>The notice has been correctly enqueued.</span>
32 [% CASE 'no_email_address' %]
33 <span>The patron does not have an email address defined.</span>
34 [% CASE 'no_template_notice' %]
35 <span>There is no notice template with a code 'CANCEL_HOLD_ON_LOST' defined in your system.</span>
36 [% CASE 'hold_cancelled' %]
37 <span>The hold has been correctly cancelled.</span>
38 [% CASE 'hold_placed_at_biblio_level' %]
39 <span>The hold has been placed on biblio level. It is not possible to determine the item to mark as lost.</span>
46 <h2>Holds to pull placed between [% from | $KohaDates %] and [% to | $KohaDates %]</h2>
47 <h3>Reported on [% todaysdate | $KohaDates %]</h3>
48 <p>The following holds have not been filled. Please retrieve them and check them in.</p>
49 <div id="searchresults">
54 <th>Pull this many items</th>
55 <th>Items available</th>
56 <th>Patrons with holds</th>
58 <th class="anti-the">Title</th>
59 <th class="string-sort">Libraries</th>
60 <th>Available barcodes</th>
61 <th>Available call numbers</th>
62 <th>Available copy numbers</th>
63 <th>Available enumeration</th>
64 <th class="string-sort">Available item types</th>
65 <th class="string-sort">Available locations</th>
66 <th class="title-string">Earliest hold date</th>
71 [% FOREACH hold_info IN holds_info %]
73 [% SET patron = hold_info.patron %]
74 [% SET item = hold_info.item %]
75 [% SET hold = hold_info.hold %]
77 [% SET biblio = hold_info.biblio %]
78 <td><p><strong>[% hold_info.pull_count | html %]</strong></p></td>
79 <td>[% hold_info.items_count | html %]</td>
80 <td>[% hold_info.patrons_count | html %]</td>
81 <td><a href="/cgi-bin/koha/members/moremember.pl?borrowernumber=[% patron.borrowernumber | uri %]">[% patron.firstname | html %] [% patron.surname | html %]</a></td>
84 [% INCLUDE 'biblio-title.inc' biblio=biblio link = 1 %]
86 [% IF ( biblio.author ) %]<p> by [% biblio.author | html %]</p>[% END %]
87 [% IF ( biblio.biblioitem.editionstatement ) %]<p>[% biblio.biblioitem.editionstatement | html %]</p>[% END %]
88 [% IF ( biblio.biblioitem.publicationyear ) %]<p>[% biblio.biblioitem.publicationyear | html %]</p>[% END %]
98 [% IF ( hold_info.holdingbranches.size ) %]
100 [% FOREACH holdingbranch IN hold_info.holdingbranches %]
101 <li>[% Branches.GetName ( holdingbranch ) | html %]</li>
107 [% IF ( hold_info.barcodes.size ) %]
108 [% SET barcode = hold_info.barcodes.first %]
109 [% IF ( hold_info.itemnumber ) %]Only [% barcode | html %][% ELSE %][% barcode | html %] or any available.[% END %]
113 [% IF ( hold_info.callnumbers.size ) %]
115 [% FOREACH callnumber IN hold_info.callnumbers %]
117 [% callnumber | html %]
124 [% IF ( hold_info.copynumbers.size ) %]
126 [% FOREACH copyno IN hold_info.copynumbers %]
135 [% IF ( hold_info.enumchrons.size ) %]
137 [% FOREACH enumchron IN hold_info.enumchrons %]
139 [% enumchron | html %]
147 [% FOREACH type IN hold_info.itemtypes %]
148 <li>[% ItemTypes.GetDescription( type ) | html %]</li>
154 [% FOREACH loc IN hold_info.locations %]
155 <li>[% AuthorisedValues.GetDescriptionByKohaField( kohafield => 'items.location', authorised_value => loc ) | html %]</li>
160 <span title="[% hold.reservedate | html %]">[% hold.reservedate | $KohaDates %] in [% Branches.GetName ( hold.branchcode ) | html %]</span>
163 <form name="cancelReserve" action="/cgi-bin/koha/circ/pendingreserves.pl" method="post">
164 <input type="hidden" name="op" value="cancel_reserve" />
165 <input type="hidden" name="reserve_id" value="[% hold.reserve_id | html %]" />
167 [% SET hold_cancellation = AuthorisedValues.GetAuthValueDropbox('HOLD_CANCELLATION') %]
168 [% IF hold_cancellation %]
169 <div class="form-group">
170 <label for="cancellation-reason">Cancellation reason:</label>
171 <select class="cancellation-reason" name="cancellation-reason" id="cancellation-reason">
172 <option value="">No reason given</option>
173 [% FOREACH reason IN hold_cancellation %]
174 <option value="[% reason.authorised_value | html %]">[% reason.lib | html %]</option>
180 [% IF item.holdingbranch != item.homebranch %]
181 <input class="btn btn-default" type="submit" value="Cancel hold and return to : [% Branches.GetName( item.homebranch ) | html %]" />
183 <input class="btn btn-default" type="submit" value="Cancel hold" />
187 [% IF Koha.Preference('CanMarkHoldsToPullAsLost') != 'do_not_allow' %]
188 [% IF hold.itemnumber %]
189 <form name="cancelReserve" action="/cgi-bin/koha/circ/pendingreserves.pl" method="post">
190 <input type="hidden" name="reserve_id" value="[% hold.reserve_id | html %]" />
191 [% IF Koha.Preference('CanMarkHoldsToPullAsLost') == 'allow' %]
192 <input type="hidden" name="op" value="mark_as_lost" />
193 <input type="submit" value="Mark item as lost" />
194 [% ELSIF Koha.Preference('CanMarkHoldsToPullAsLost') == 'allow_and_notify' %]
195 <input type="hidden" name="op" value="mark_as_lost_and_notify" />
196 <input type="submit" value="Mark lost and notify patron" />
200 <span>Biblio level hold.</span>
209 <td><input type="text" class="filter" data-column_num="0" placeholder="Pull this many items" style="width:95%"/></td>
210 <td><input type="text" class="filter" data-column_num="1" placeholder="Items available" style="width:95%"/></td>
211 <td><input type="text" class="filter" data-column_num="2" placeholder="Patron holds" style="width:95%"/></td>
212 <td><input type="text" class="filter" data-column_num="3" placeholder="Patron name" style="width:95%"/></td>
213 <td><input type="text" class="filter" data-column_num="4" placeholder="Title" style="width:95%"/></td>
214 <td id="homebranchfilter"></td>
216 <td><input type="text" class="filter" data-column_num="7" placeholder="Call number" style="width:95%"/></td>
217 <td><input type="text" class="filter" data-column_num="8" placeholder="Available copy" style="width:95%"/></td>
218 <td><input type="text" class="filter" data-column_num="9" placeholder="Available enumeration" style="width:95%"/></td>
219 <td id="itemtype-filter"></td>
220 <td id="locationfilter"></td>
227 <strong>No items found.</strong>
233 </div> <!-- /.col-sm-10.col-sm-push-2 -->
235 <div class="col-sm-2 col-sm-pull-10">
240 <form action="/cgi-bin/koha/circ/pendingreserves.pl" method="post" >
241 <fieldset class="brief">
242 <h4>Refine results</h4>
248 <input type="text" size="10" id="from" name="from" value="[% from | $KohaDates %]" class="datepickerfrom" />
253 <input type="text" size="10" id="to" name="to" value="[% to | $KohaDates %]" class="datepickerto" />
257 [% IF ( HoldsToPullEndDate ) %]
258 <p><em>(Inclusive, default is [% HoldsToPullStartDate | html %] days ago to [% HoldsToPullEndDate | html %] days ahead. Set other date ranges as needed.)</em></p>
260 <p><em>(Inclusive, default is [% HoldsToPullStartDate | html %] days ago to today. Set other date ranges as needed.)</em></p>
263 <fieldset class="action"><input type="submit" name="run_report" value="Submit" class="submit"/></fieldset>
269 </div> <!-- /.col-sm-2.col-sm-pull-10 -->
270 </div> <!-- /.row -->
272 [% MACRO jsinclude BLOCK %]
273 [% INCLUDE 'calendar.inc' %]
274 [% INCLUDE 'datatables.inc' %]
275 [% INCLUDE 'columns_settings.inc' %]
277 $(document).ready(function() {
278 var columns_settings = [% TablesSettings.GetColumns('circ', 'holds', 'holds-to-pull', 'json') | $raw %];
279 var holdst = KohaTable("holdst", {
280 "sPaginationType": "full_numbers"
281 }, columns_settings);
282 holdst.fnAddFilters("filter");
283 [%# add separateData function to cleanse jQuery select lists by breaking apart strings glued with BR tags and then de-duplicating any repeated library codes %]
284 function separateData ( ColumnData ){
286 var new_array = new Array();
287 for ( j=0 ; j<cD.length ; j++ ) {
288 var split_array = cD[j].split(/\n/gi);
289 for ( k=0 ; k<split_array.length ; k++ ){
290 var str = $.trim(split_array[k].replace(/[\n\r]/g, ''));
291 if ($.inArray(str, new_array) == -1 && str.length > 0 ) {
299 [%# add SeparateData function into createSelect function, so that it does the createSelect on clean data %]
300 function createSelect( data ) {
301 data = separateData(data);
302 var r='<select style="width:99%"><option value="">' + _("None") + '</option>', i, len=data.length;
303 var regex = /(<([^>]+)>)/ig; // Remove html tags
304 for ( i=0 ; i<len ; i++ ) {
305 var cell_val = data[i].replace(regex, '');
306 if ( cell_val.length < 1 ) continue;
307 r += '<option value="'+cell_val+'">'+cell_val+'</option>';
309 return r+'</select>';
311 $("#homebranchfilter").each( function () {
312 $(this).html( createSelect( holdst.fnGetColumnData(5) ) );
313 $('select', this).change( function () {
314 holdst.fnFilter( $(this).child().val(), 5 );
317 $("#itemtype-filter").each( function () {
318 $(this).html( createSelect( holdst.fnGetColumnData(10) ) );
319 $('select', this).change( function () {
320 holdst.fnFilter( $(this).val(), 10 );
323 $("#locationfilter").each( function () {
324 $(this).html( createSelect( holdst.fnGetColumnData(11) ) );
325 $('select', this).change( function () {
326 holdst.fnFilter( $(this).val(), 11 );
333 [% INCLUDE 'intranet-bottom.inc' %]