Bug 21772: Move OPAC holds and account tables into .inc
[koha.git] / koha-tmpl / opac-tmpl / bootstrap / en / modules / opac-user.tt
1 [% USE raw %]
2 [% USE Asset %]
3 [% USE Koha %]
4 [% USE KohaDates %]
5 [% USE Branches %]
6 [% USE ItemTypes %]
7 [% USE Price %]
8 [% SET AdlibrisEnabled = Koha.Preference('AdlibrisCoversEnabled') %]
9 [% SET AdlibrisURL = Koha.Preference('AdlibrisCoversURL') %]
10
11 [% SET borrower_club_enrollments =  logged_in_user.get_club_enrollments(1) %]
12 [% SET borrower_enrollable_clubs = logged_in_user.get_enrollable_clubs(1,1) %]
13
14 [% INCLUDE 'doc-head-open.inc' %]
15 <title>[% IF ( LibraryNameTitle ) %][% LibraryNameTitle | html %][% ELSE %]Koha online[% END %] catalog &rsaquo; Your library home</title>
16 [% INCLUDE 'doc-head-close.inc' %]
17 [% BLOCK cssinclude %][% END %]
18 </head>
19 [% INCLUDE 'bodytag.inc' bodyid='opac-user' bodyclass='scrollto' %]
20 [% INCLUDE 'masthead.inc' %]
21
22 [% IF Koha.Preference('AmazonAssocTag') %]
23     [% AmazonAssocTag = '?tag=' _ Koha.Preference('AmazonAssocTag') %]
24 [% ELSE %]
25     [% AmazonAssocTag = '' %]
26 [% END %]
27
28 <div class="main">
29     <ul class="breadcrumb">
30         <li><a href="/cgi-bin/koha/opac-main.pl">Home</a> <span class="divider">&rsaquo;</span></li>
31         <li><a href="/cgi-bin/koha/opac-user.pl">[% INCLUDE 'patron-title.inc' patron = logged_in_user %]</a> <span class="divider">&rsaquo;</span></li>
32         <li><a href="#">Your summary</a></li>
33     </ul>
34
35     <div class="container-fluid">
36         <div class="row-fluid">
37             <div class="span2">
38                 <div id="navigation">
39                     [% INCLUDE 'navigation.inc' IsPatronPage=1 %]
40                 </div>
41             </div>
42             <div class="span10">
43                 <div id="userdetails" class="maincontent">
44
45                     [% INCLUDE 'opac-note.inc' %]
46
47                     <h2>Hello, [% INCLUDE 'patron-title.inc' patron = logged_in_user %]
48                     </h2>
49
50                     <p><a href="/cgi-bin/koha/opac-main.pl?logout.x=1">Click here if you're not [% INCLUDE 'patron-title.inc' patron = logged_in_user %]</a></p>
51
52                     [% IF ( patronupdate ) %]<div class="alert alert-info"><h3>Thank you!</h3><p>Your corrections have been submitted to the library, and a staff member will update your record as soon as possible.</p></div>[% END %]
53
54                     [% IF failed_holds %]
55                         <div class="alert alert-info">
56                             <h3>Notice:</h3>
57                             <p>One or more holds were not placed due to existing holds.</p>
58                         </div>
59                     [% END %]
60
61                     [% IF ( borrower.warndeparture ) %]
62                         <div class="alert" id="warndeparture">
63                             <strong>Please note:</strong><span> Your card will expire on <span id="warndeparture_date">[% borrower.warndeparture | $KohaDates %]</span>. Please contact the library for more information.</span>
64                                 [% IF ( borrower.returnbeforeexpiry ) %]<span id="warndeparture_returnbeforeexpiry"> Also note that you must return all checked out items before your card expires.</span>[% END %]
65                         </div>
66                     [% END %]
67
68                     [% IF ( borrower.warnexpired ) %]
69                         <div class="alert" id="warnexpired">
70                             <strong>Please note: </strong><span>Your account has expired as of [% borrower.warnexpired | $KohaDates %]. Please contact the library if you wish to renew your account.</span>
71                         </div>
72                     [% END %]
73
74                     [% IF ( RENEW_ERROR ) %]
75                         <div class="dialog alert">
76                             <strong>Please note:</strong>
77                                 Your loan renewal failed because of the following reason(s):
78                                 <ul>
79                                     [% FOREACH error IN RENEW_ERROR.split('\|') %]
80                                         [% IF error == 'card_expired' %]
81                                             <li>Your account has expired. Please contact the library for more information.</li>
82                                         [% ELSIF error == 'too_many' %]
83                                             <li>You have renewed this item the maximum number of times allowed.</li>
84                                         [% ELSIF error == 'too_soon' %]
85                                             <li>It is too soon after the checkout date for this item to be renewed.</li>
86                                         [% ELSIF error == 'on_reserve' %]
87                                             <li>This item is on hold for another borrower.</li>
88                                         [% ELSIF error == 'item_denied_renewal' %]
89                                             <li>Item renewal is not allowed.</li>
90                                         [% END %]
91                                     [% END %]
92                                 </ul>
93                         </div>
94                     [% END %]
95
96                     [% IF ( patron_flagged ) %]
97                         <div class="alert">
98                             <ul>
99                                 [% IF ( userdebarred ) %]
100                                     [% IF ( discharge_available ) %]
101                                         <li id="discharged">
102                                             <strong>Please note:</strong> Your account is frozen because it has been discharged. <a href="/cgi-bin/koha/opac-discharge.pl?op=get">Get your discharge</a>
103                                         </li>
104                                     [% ELSE %]
105                                         <li id="userdebarred"><strong>Please note:</strong> Your account has been frozen.
106                                         [% IF ( borrower.debarredcomment ) %]
107                                             Comment:
108                                             <span id="userdebarred_comment">
109                                                 <strong>
110                                                     [% IF borrower.debarredcomment.search('OVERDUES_PROCESS') %]
111                                                         Restriction added by overdues process [% borrower.debarredcomment.remove('OVERDUES_PROCESS ') | html_line_break %]
112                                                     [% ELSE %]
113                                                         [% borrower.debarredcomment | html_line_break %]
114                                                     [% END %]
115                                                 </strong>
116                                             </span>
117                                         [% END %]
118                                         [% IF ( borrower.userdebarreddate && debarred_date != '9999-12-31' ) %]
119                                             End date:
120                                             <span id="userdebarred_date">[% borrower.userdebarreddate | $KohaDates %]</span>
121                                         [% END %]
122
123                                         <em>Usually the reason for freezing an account is old overdues or damage fees. If your account shows to be clear, please contact the library.</em> <a href="/cgi-bin/koha/opac-account.pl">Go to your account page</a></li>
124                                     [% END %]
125                                 [% END %]
126                                 [% IF ( borrower.gonenoaddress ) %]
127                                     <li id="gonenoaddress"><strong>Please note:</strong> According to our records, we don't have up-to-date contact information. Please contact the library.
128                                 <a href="/cgi-bin/koha/opac-memberentry.pl">[% IF ( Koha.Preference('OPACPatronDetails') ) %]Update your contact information[% ELSE %]Go to your contact information[% END %]</a>
129                                 [% IF ( Koha.Preference('OPACPatronDetails') ) %]<em>(Please note: there may be a delay in restoring your account if you submit online.)</em>[% END %]
130                                     </li>
131                                 [% END %]
132                                 [% IF ( borrower.lost ) %]
133                                     <li id="lost"><strong>Please note: </strong> Your library card has been marked as lost or stolen. <em>If this is an error, please contact the library.</em></li>
134                                 [% END %]
135                                 [% IF ( renewal_blocked_fines.defined ) && ( OpacRenewalAllowed ) %]
136                                     <li id="renewal_blocked_fines"><strong>Please note: </strong>You cannot renew your books online. Reason: [% IF ( renewal_blocked_fines ) > 0  %]Your fines exceed <span id="renewal_blocked_fines_amount">[% renewal_blocked_fines | $Price %]</span>.[% ELSE %]You have fines.[% END %]
137                                 [% END %]
138                             </ul>
139                         </div>
140                     [% END # / IF patron_flagged %]
141
142                     <div class="alert alert-info" id="notesaved" style="display:none;"></div>
143
144                     [% IF OPACMySummaryNote %][% Koha.Preference('OPACMySummaryNote') | $raw %][% END %]
145
146                     <div id="opac-user-views" class="toptabs">
147                         <ul>
148                             <li><a href="#opac-user-checkouts">Checked out ([% issues_count | html %])</a></li>
149                             [% IF relatives %]<li><a href="#opac-user-relative-issues">Relatives' checkouts</a></li>[% END %]
150                             [% IF ( overdues_count ) %]<li><a href="#opac-user-overdues">Overdue ([% overdues_count | html %])</a></li>[% END %]
151                             [% IF ( OPACFinesTab ) %]
152                                 [% IF ( borrower.amountoverfive ) %]<li><a href="#opac-user-fines">Fines ([% amountoutstanding | $Price %])</a></li>[% END %]
153                                 [% IF ( borrower.amountoverzero ) %]<li><a href="#opac-user-fines">Fines ([% amountoutstanding | $Price %])</a></li>[% END %]
154                                 [% IF ( borrower.amountlessthanzero ) %]<li><a href="#opac-user-fines">Credits ([% amountoutstanding | $Price %])</a></li>[% END %]
155                             [% END %]
156
157                             [% IF borrower_club_enrollments.count || borrower_enrollable_clubs.count %]
158                                 <li>
159                                     <a id="opac-user-clubs-tab-link" href="#opac-user-clubs">
160                                         Clubs ([% borrower_club_enrollments.count || 0 | html %]/[% borrower_enrollable_clubs.count || 0 | html %])
161                                     </a>
162                                 </li>
163                             [% END %]
164
165                             [% IF ( RESERVES.count ) %]<li><a href="#opac-user-holds">Holds ([% RESERVES.count | html %])</a></li>[% END %]
166                             [% IF Koha.Preference('ArticleRequests') && logged_in_user.article_requests_current %]<li><a href="#opac-user-article-requests">Article requests ([% logged_in_user.article_requests_current.count | html %])</a></li>[% END %]
167                             [% IF ( OverDriveCirculation ) %]
168                             <li><a href="#opac-user-overdrive">OverDrive Account</a></li>
169                             [% END %]
170                             [% IF ( RecordedBooksCirculation ) %]
171                             <li><a href="#opac-user-recordedbooks">RecordedBooks Account</a></li>
172                             [% END %]
173                         </ul>
174
175                         <div id="opac-user-overdrive">
176                         </div>
177                         <div id="opac-user-recordedbooks">
178                         </div>
179                         <div id="opac-user-checkouts">
180                             [% IF ( issues_count ) %]
181                                 <form id="renewselected" action="/cgi-bin/koha/opac-renew.pl" method="post">
182                                     <input type="hidden" name="borrowernumber" value="[% borrowernumber | html %]">
183                                     <input type="hidden" name="from" value="opac_user" />
184                                     <table id="checkoutst" class="table table-bordered table-striped">
185                                         <caption>[% issues_count | html %] Item(s) checked out</caption>
186                                         <thead>
187                                             <tr>
188                                                 [% IF ( JacketImages || AdlibrisEnabled ) %]<th class="nosort">&nbsp;</th>[% END %]
189                                                 <th class="anti-the">Title</th>
190                                                 <th>Author</th>
191                                                 <th class="title-string psort">Due</th>
192                                                 [% UNLESS ( item_level_itypes ) %]
193                                                     <th>Item type</th>
194                                                 [% END %]
195                                                 [% IF ( show_barcode ) %]
196                                                     <th>Barcode</th>
197                                                 [% END %]
198                                                     <th>Call no.</th>
199                                                 [% IF ( OpacRenewalAllowed && !( logged_in_user.is_expired && logged_in_user.category.effective_BlockExpiredPatronOpacActions ) ) %]
200                                                     <th class="nosort">Renew</th>
201                                                 [% END %]
202                                                 [% IF ( OPACFinesTab ) %]
203                                                     <th>Fines</th>
204                                                 [% END %]
205                                                 [% IF ( OPACMySummaryHTML ) %]
206                                                     <th class="nosort">Links</th>
207                                                 [% END %]
208                                                 [% IF ( Koha.Preference('AllowCheckoutNotes') ) %]
209                                                     <th class="nosort">Note</th>
210                                                 [% END %]
211                                             </tr>
212                                         </thead>
213                                         <tbody>
214                                             [% FOREACH ISSUE IN ISSUES %]
215                                                 [% IF ( ISSUE.overdue ) %]<tr class="overdue">[% ELSE %]<tr>[% END %]
216                                                 [% IF ( JacketImages || AdlibrisEnabled ) %]<td class="jacketcell">
217                                                     [% IF ( AdlibrisEnabled && ISSUE.normalized_isbn ) %]
218                                                         <a href="/cgi-bin/koha/opac-detail.pl?biblionumber=[% ISSUE.biblionumber | uri %]"><img src="[% AdlibrisURL | url %]?isbn=[% ISSUE.normalized_isbn | uri %]" class="adlibris-cover" alt="Adlibris cover image" /></a>
219                                                     [% END %]
220                                                     [% IF ( OPACAmazonCoverImages ) %]
221                                                         [% IF ( ISSUE.normalized_isbn ) %]
222                                                             <a href="http://www.amazon.com/gp/reader/[% ISSUE.normalized_isbn | uri %][% AmazonAssocTag | uri %]#reader-link" title="View on Amazon.com"><img src="https://images-na.ssl-images-amazon.com/images/P/[% ISSUE.normalized_isbn | html %].01.THUMBZZZ.jpg" alt="View on Amazon.com" class="item-thumbnail"/></a>
223                                                         [% ELSE %]
224                                                             <a href="#"><span class="no-image">No cover image available</span></a>
225                                                         [% END %]
226                                                     [% END %]
227
228                                                     [% IF ( GoogleJackets ) %]
229                                                         [% IF ( ISSUE.normalized_isbn ) %]
230                                                             <div style="display:block;" title="Click to view in Google Books" class="[% ISSUE.normalized_isbn | html %]" id="gbs-thumbnail[% loop.count | html %]"></div>
231                                                         [% ELSE %]
232                                                             <a href="http://books.google.com/books?q=[% ISSUE.title |url %]"><span class="no-image">No cover image available</span></a>
233                                                         [% END %]
234                                                     [% END %]
235
236                                                     [% IF ( BakerTaylorEnabled ) %]
237                                                         [% bt_id = ( ISSUE.normalized_upc || ISSUE.normalized_isbn ) %]
238                                                         [% IF ( bt_id ) %]
239                                                             <a href="https://[% BakerTaylorBookstoreURL | uri %][% bt_id | uri %]"><img alt="See Baker &amp; Taylor" src="[% BakerTaylorImageURL | html %][% bt_id | html %]" /></a>
240                                                         [% ELSE %]
241                                                             <span class="no-image">No cover image available</span><!-- BakerTaylor needs normalized_upc or normalized_isbn! -->
242                                                         [% END %]
243                                                     [% END %]
244
245                                                     [% IF ( SyndeticsEnabled && SyndeticsCoverImages ) %]
246                                                         <img src="https://secure.syndetics.com/index.aspx?isbn=[% ISSUE.normalized_isbn | html %]/SC.GIF&amp;client=[% SyndeticsClientCode | html %]&amp;type=xw10&amp;upc=[% ISSUE.normalized_upc | html %]&amp;oclc=[% ISSUE.normalized_oclc | html %]" alt="" class="item-thumbnail" />
247                                                     [% END %]
248
249                                                 </td>[% END # / IF JacketImages %]
250
251                                                 <td class="title">
252                                                     <a class="title" href="/cgi-bin/koha/opac-detail.pl?biblionumber=[% ISSUE.biblionumber | html %]">[% ISSUE.title | html %] [% FOREACH subtitl IN ISSUE.subtitle %] [% subtitl.subfield | html %][% END %]</a>
253                                                     [% IF ( ISSUE.enumchron ) %] [% ISSUE.enumchron | html %][% END %]
254                                                 </td>
255
256                                                 <td class="author">[% ISSUE.author | html %]</td>
257                                                 [% IF ( ISSUE.overdue ) %]
258                                                     <td class="date_due overdue">
259                                                         <span title="[% ISSUE.date_due | html %]">
260                                                             <span class="tdlabel">Date due:</span>
261                                                             [% ISSUE.date_due | $KohaDates  as_due_date => 1 %]
262                                                         </span>
263                                                     </td>
264                                                 [% ELSE %]
265                                                     <td class="date_due">
266                                                         <span title="[% ISSUE.date_due | html %]">
267                                                             <span class="tdlabel">Date due:</span>
268                                                             [% ISSUE.date_due | $KohaDates  as_due_date => 1 %]
269                                                         </span>
270                                                     </td>
271                                                 [% END %]
272                                                 [% UNLESS ( item_level_itypes ) %]
273                                                     <td class="itype">
274                                                         <span class="tdlabel">Item type:</span>
275                                                         [% IF ( ISSUE.imageurl ) %]
276                                                             <img src="[% ISSUE.imageurl | html %]" title="[% ISSUE.description | html %]" alt="[% ISSUE.description | html %]" />
277                                                         [% END %] [% ISSUE.description | html %]
278                                                     </td>
279                                                 [% END %]
280                                                 [% IF ( show_barcode ) %]
281                                                     <td class="barcode">
282                                                         <span class="tdlabel">Barcode:</span>
283                                                         [% ISSUE.barcode | html %]
284                                                     </td>
285                                                 [% END %]
286                                                 <td class="call_no">
287                                                     <span class="tdlabel">Call no.:</span>
288                                                     [% ISSUE.itemcallnumber | html %]
289                                                 </td>
290                                                 [% IF ( OpacRenewalAllowed && !( logged_in_user.is_expired && logged_in_user.category.effective_BlockExpiredPatronOpacActions ) ) %]
291                                                     <td class="renew">
292                                                     [% IF ISSUE.renewed %]<span class="blabel label-success">Renewed!</span><br />[% END %]
293                                                     [% IF ( ISSUE.status ) %]
294                                                         [% IF ( canrenew ) %]
295                                                             <input type="checkbox" name="item" value="[% ISSUE.itemnumber | uri %]"/> <a href="/cgi-bin/koha/opac-renew.pl?from=opac_user&amp;item=[% ISSUE.itemnumber | uri %]&amp;borrowernumber=[% ISSUE.borrowernumber | uri %]">Renew</a>
296                                                         [% END %]
297                                                         [% IF ISSUE.renewalfee > 0 %]
298                                                             <span class="renewalfee label label-warning">Fee for item type '[% ItemTypes.GetDescription( ISSUE.renewalitemtype) | html %]': [% ISSUE.renewalfee | $Price %]</span>
299                                                         [% END %]
300                                                         [% IF ISSUE.itemtype_object.rentalcharge_daily > 0 %]
301                                                             <span class="renewalfee label label-warning">[% ISSUE.itemtype_object.rentalcharge_daily | $Price %] per day</span>
302                                                         [% END %]
303                                                         [% IF ISSUE.itemtype_object.rentalcharge_hourly > 0 %]
304                                                             <span class="renewalfee label label-warning">[% ISSUE.itemtype_object.rentalcharge_hourly | $Price %] per hour</span>
305                                                         [% END %]
306                                                         <span class="renewals">([% ISSUE.renewsleft | html %] of [% ISSUE.renewsallowed | html %] renewals remaining)</span>
307                                                     [% ELSIF ( ISSUE.on_reserve ) %]
308                                                         Not renewable <span class="renewals">(on hold)</span>
309                                                     [% ELSIF ( ISSUE.too_many ) %]
310                                                         Not renewable
311                                                     [% ELSIF ( ISSUE.norenew_overdue ) %]
312                                                         Not allowed <span class="renewals">(overdue)</span>
313                                                     [% ELSIF ( ISSUE.auto_too_late ) %]
314                                                         No longer renewable
315                                                     [% ELSIF ISSUE.auto_too_much_oweing %]
316                                                         Automatic renewal failed, you have unpaid fines.
317                                                         <span class="renewals">([% ISSUE.renewsleft | html %] of [% ISSUE.renewsallowed | html %] renewals remaining)</span>
318                                                     [% ELSIF ISSUE.auto_account_expired %]
319                                                         Automatic renewal failed, your account is expired.
320                                                         <span class="renewals">([% ISSUE.renewsleft | html %] of [% ISSUE.renewsallowed | html %] renewals remaining)</span>
321                                                     [% ELSIF ( ISSUE.auto_renew || ISSUE.auto_too_soon ) %]
322                                                         Automatic renewal
323                                                         <span class="renewals">([% ISSUE.renewsleft | html %] of [% ISSUE.renewsallowed | html %] renewals remaining)</span>
324                                                     [% ELSIF ( ISSUE.too_soon ) %]
325                                                         No renewal before [% ISSUE.soonestrenewdate | html %]
326                                                         <span class="renewals">([% ISSUE.renewsleft | html %] of [% ISSUE.renewsallowed | html %] renewals remaining)</span>
327                                                     [% ELSIF ( ISSUE.item_denied_renewal ) %]
328                                                         Renewal not allowed
329                                                     [% END %]
330                                                     </td>
331                                                 [% END %]
332                                                 [% IF ( OPACFinesTab ) %]
333                                                     <td class="fines">
334                                                         <span class="tdlabel">Fines:</span>
335                                                         [% IF ( ISSUE.charges ) %]
336                                                             Yes (Item overdue or lost)
337                                                         [% ELSIF ( ISSUE.rentalfines ) %]
338                                                             Yes (Rental fees)
339                                                         [% ELSE %]
340                                                             No
341                                                         [% END %]
342                                                     </td>
343                                                 [% END %]
344                                                 [% IF ( OPACMySummaryHTML ) %]
345                                                     <td class="links">[% ISSUE.MySummaryHTML | $raw %]</td>
346                                                 [% END %]
347                                                 [% IF ( Koha.Preference('AllowCheckoutNotes') ) %]
348                                                     <td class="note">
349                                                         <input type="text" name="note" data-issue_id="[% ISSUE.issue_id | html %]" data-origvalue="[% ISSUE.note | html %]" value="[% ISSUE.note | html %]" readonly>
350                                                         <a class="btn" name="js_submitnote" id="save_[% ISSUE.issue_id | html %]" style="display:none;">Submit note</a>
351                                                         <a class="btn" name="nonjs_submitnote" href="/cgi-bin/koha/opac-issue-note.pl?issue_id=[% ISSUE.issue_id | url %]">Edit / Create note</a>
352                                                     </td>
353                                                 [% END %]
354                                             </tr>
355                                         [% END # /FOREACH ISSUES %]
356                                     </tbody>
357                                 </table>
358                                 [% IF ( canrenew && !userdebarred && OpacRenewalAllowed && !( logged_in_user.is_expired && logged_in_user.category.effective_BlockExpiredPatronOpacActions ) ) %]
359                                     <input type="submit" class="btn" value="Renew selected" />
360                                 [% END %]
361                                 </form>
362
363                                 [% IF ( canrenew && !userdebarred && OpacRenewalAllowed && !( logged_in_user.is_expired && logged_in_user.category.effective_BlockExpiredPatronOpacActions ) ) %]
364                                 <form id="renewall" action="/cgi-bin/koha/opac-renew.pl" method="post">
365                                     <input type="hidden" name="from" value="opac_user" />
366                                     <input type="hidden" name="borrowernumber" value="[% borrowernumber | html %]" />
367                                     [% FOREACH ISSUE IN ISSUES %]
368                                         <input type="hidden" name="item" value="[% ISSUE.itemnumber | html %]" />
369                                     [% END %]
370                                     <input type="submit" class="btn" value="Renew all" />
371                                 </form>
372                                 [% END %]
373                                 <p><a href="opac-ics.pl">Download as iCal/.ics file</a></p>
374                             [% ELSE %]
375                                 <table class="table table-bordered table-striped">
376                                     <tr><td>You have nothing checked out</td></tr>
377                                 </table>
378                             [% END # IF issues_count %]
379                         </div> <!-- / .opac-user-checkouts -->
380
381                         [% IF borrower_club_enrollments.count || borrower_enrollable_clubs.count %]
382                             <div id="opac-user-clubs">
383                                 Loading...
384                             </div>
385                         [% END %]
386
387                         [% IF ( OPACFinesTab ) %]
388                             <!-- FINES BOX -->
389                             [% IF borrower.amountoverfive %]
390                                 <div id="opac-user-fines"> <h3>Fines and charges</h3>
391                                     <table class="table table-bordered table-striped">
392                                         <thead><tr><th colspan="2">Amount</th></tr></thead>
393                                         <tbody>
394                                             <tr>
395                                                 <td>You currently owe fines and charges amounting to:</td>
396                                                 <td><a href="/cgi-bin/koha/opac-account.pl">[% amountoutstanding | $Price %]</a></td>
397                                             </tr>
398                                         </tbody>
399                                     </table>
400                                 </div>
401                             [% END %]
402
403                             [% IF borrower.amountoverzero %]
404                                <div id="opac-user-fines"> <h3>Fines and charges</h3>
405                                     <table class="table table-bordered table-striped">
406                                         <thead><tr><th colspan="2">Amount</th></tr></thead>
407                                         <tbody>
408                                             <tr>
409                                                 <td>You currently owe fines and charges amounting to:</td>
410                                                 <td><a href="/cgi-bin/koha/opac-account.pl">[% amountoutstanding | $Price %]</a></td>
411                                             </tr>
412                                         </tbody>
413                                     </table>
414                                 </div>
415                             [% END %]
416
417                             [% IF borrower.amountlessthanzero %]
418                                 <div id="opac-user-fines">  <h3>Credits</h3>
419                                     <table class="table table-bordered table-striped">
420                                         <thead><tr><th colspan="2">Amount</th></tr></thead>
421                                         <tbody>
422                                             <tr>
423                                                 <td>You have a credit of:</td><td><a href="/cgi-bin/koha/opac-account.pl">[% amountoutstanding | $Price %]</a></td>
424                                             </tr>
425                                         </tbody>
426                                     </table>
427                                 </div>
428                             [% END %]
429                         [% END # / OPACFinesTab %]
430
431                         [% IF relatives %]
432                             <div id="opac-user-relative-issues">
433                                 <table id="opac-user-relative-issues-table" class="table table-bordered table-striped">
434                                     <thead>
435                                         <tr>
436                                             <th class="anti-the">Title</th>
437                                             <th>Due</th>
438                                             <th>Barcode</th>
439                                             <th>Call no.</th>
440                                             <th class="psort">Relative</th>
441                                         </tr>
442                                     </thead>
443
444                                     <tbody>
445                                         [% FOREACH r IN relatives %]
446                                             [% FOREACH i IN r.issues %]
447                                                 <tr>
448                                                     <td>
449                                                         <a href="/cgi-bin/koha/opac-detail.pl?biblionumber=[% i.item.biblio.biblionumber | uri %]">
450                                                             [% i.item.biblio.title | html %][% IF ( i.item.enumchron ) %] [% i.item.enumchron | html %][% END %]
451                                                         </a>
452                                                     </td>
453
454                                                     <td>
455                                                         [% i.date_due | $KohaDates %]
456                                                     </td>
457
458                                                     <td>
459                                                         [% i.item.barcode | html %]
460                                                     </td>
461
462                                                     <td>
463                                                         [% i.item.itemcallnumber | html %]
464                                                     </td>
465
466                                                     <td>
467                                                         [% r.firstname | html %] [% r.surname | html %]
468                                                     </td>
469                                                 </tr>
470                                             [% END %]
471                                         [% END %]
472                                     </tbody>
473                                 </table>
474                             </div>
475                         [% END %]
476
477                         [% IF ( overdues_count ) %]
478                             <div id="opac-user-overdues">
479                                 <table id="overduest" class="table table-bordered table-striped">
480                                     <caption>Overdues <span class="count">([% overdues_count | html %] total)</span></caption>
481                                     <!-- OVERDUES TABLE ROWS -->
482                                     <thead>
483                                         <tr>
484                                             [% IF ( JacketImages || AdlibrisEnabled ) %]<th class="nosort">&nbsp;</th>[% END %]
485                                             <th class="anti-the">Title</th>
486                                             [% UNLESS ( item_level_itypes ) %]<th>Item type</th> [% END %]
487                                             [% IF ( show_barcode ) %]<th>Barcode</th>[% END %]
488                                             <th>Call no.</th>
489                                             <th class="title-string psort">Due</th>
490                                             [% IF ( OpacRenewalAllowed ) %]
491                                                 <th class="nosort">Renew</th>
492                                             [% END %]
493                                             [% IF ( OPACFinesTab ) %]
494                                                 <th>Fines</th>
495                                             [% END %]
496                                         </tr>
497                                     </thead>
498                                     <tbody>
499                                         [% FOREACH OVERDUE IN OVERDUES %]
500                                             <tr>
501                                                 [% IF ( JacketImages || AdlibrisEnabled ) %]
502                                                     <td class="jacketcell">
503                                                     [% IF ( AdlibrisEnabled && OVERDUE.normalized_isbn ) %]
504                                                         <a href="/cgi-bin/koha/opac-detail.pl?biblionumber=[% OVERDUE.biblionumber | uri %]"><img src="[% AdlibrisURL | url %]?isbn=[% OVERDUE.normalized_isbn | uri %]" class="adlibris-cover" alt="Adlibris cover image" /></a>
505                                                     [% END %]
506                                                     [% IF ( OPACAmazonCoverImages ) %]
507                                                         [% IF ( OVERDUE.normalized_isbn ) %]
508                                                             <a href="http://www.amazon.com/gp/reader/[% OVERDUE.normalized_isbn | uri %][% AmazonAssocTag | uri %]#reader-link" title="View on Amazon.com"><img src="https://images-na.ssl-images-amazon.com/images/P/[% OVERDUE.normalized_isbn | html %].01.THUMBZZZ.jpg" alt="View on Amazon.com" class="item-thumbnail" /></a>
509                                                         [% ELSE %]
510                                                             <a href="#"><span class="no-image">No cover image available</span></a>
511                                                         [% END %]
512                                                     [% END %]
513
514                                                     [% IF ( GoogleJackets ) %]
515                                                         [% IF ( OVERDUE.normalized_isbn ) %]
516                                                             <div style="display:block;" title="Click to view in Google Books" class="[% OVERDUE.normalized_isbn | html %]" id="gbs-thumbnail[% loop.count | html %]"></div>
517                                                         [% ELSE %]
518                                                             <a href="http://books.google.com/books?q=[% OVERDUE.title |url %]"><span class="no-image">No cover image available</span></a>
519                                                         [% END %]
520                                                     [% END %]
521
522                                                     [% IF ( BakerTaylorEnabled ) %]
523                                                         [% bt_id = ( OVERDUE.normalized_upc || OVERDUE.normalized_isbn ) %]
524                                                         [% IF ( bt_id ) %]
525                                                             <a href="https://[% BakerTaylorBookstoreURL | uri %][% bt_id | uri %]"><img alt="See Baker &amp; Taylor" src="[% BakerTaylorImageURL | html %][% bt_id | html %]" /></a>
526                                                         [% ELSE %]
527                                                             <span class="no-image">No cover image available</span><!-- BakerTaylor needs normalized_upc or normalized_isbn! -->
528                                                         [% END %]
529                                                     [% END %]
530
531                                                     [% IF ( SyndeticsCoverImages ) %]
532                                                         <img src="https://secure.syndetics.com/index.aspx?isbn=[% OVERDUE.normalized_isbn | html %]/SC.GIF&amp;client=[% SyndeticsClientCode | html %]&amp;upc=[% OVERDUE.normalized_upc | html %]&amp;oclc=[% OVERDUE.normalized_oclc | html %]&amp;type=xw10" alt="" class="item-thumbnail" />
533                                                     [% END %]
534                                                     </td>
535                                                 [% END # /IF jacketcell %]
536
537                                                 <td>
538                                                     <a class="title" href="/cgi-bin/koha/opac-detail.pl?bib=[% OVERDUE.biblionumber | html %]">[% OVERDUE.title | html %] [% FOREACH subtitl IN OVERDUE.subtitle %] [% subtitl.subfield | html %][% END %]
539                                                     </a>
540                                                     <span class="item-details">[% OVERDUE.author | html %]</span></td>
541
542                                                 [% UNLESS ( item_level_itypes ) %]
543                                                     <td>
544                                                         [% IF ( OVERDUE.imageurl ) %]
545                                                             <img src="[% OVERDUE.imageurl | html %]" title="[% OVERDUE.description | html %]" alt="[% OVERDUE.description | html %]" />
546                                                         [% END %] [% OVERDUE.description | html %]
547                                                     </td>
548                                                 [% END %]
549                                                 [% IF ( show_barcode ) %]
550                                                     <td>
551                                                         <span class="tdlabel">Barcode:</span>
552                                                         [% OVERDUE.barcode | html %]
553                                                     </td>
554                                                 [% END %]
555                                                 <td>
556                                                     <span class="tdlabel">Call no.:</span>
557                                                     [% OVERDUE.itemcallnumber | html %]
558                                                 </td>
559                                                 <td>
560                                                     <span title="[% OVERDUE.date_due | html %]">
561                                                         <span class="tdlabel">Date due:</span>
562                                                         [% OVERDUE.date_due | $KohaDates  as_due_date => 1 %]
563                                                     </span>
564                                                 </td>
565                                                 [% IF ( OpacRenewalAllowed ) %]
566                                                     <td>
567                                                         [% IF ( OVERDUE.debarred ) %]
568                                                             Account frozen
569                                                         [% ELSIF ( OVERDUE.status ) %]
570                                                             [% IF ( canrenew ) %]
571                                                                 <a href="/cgi-bin/koha/opac-renew.pl?from=opac_user&amp;item=[% OVERDUE.itemnumber | uri %]&amp;bornum=[% OVERDUE.borrowernumber | uri %]">Renew</a>
572                                                             [% END %]
573                                                                 <span class="renewals">([% OVERDUE.renewsleft | html %] of [% OVERDUE.renewsallowed | html %] renewals remaining)</span>
574                                                         [% ELSIF ( OVERDUE.norenew_overdue ) %]
575                                                             Not allowed<span class="renewals">(overdue)</span>
576                                                         [% ELSIF ( OVERDUE.onreserve ) %]
577                                                             On hold
578                                                         [% ELSE %]
579                                                             No renewals left
580                                                         [% END %]
581                                                     </td>
582                                                 [% END %]
583                                                 [% IF ( OPACFinesTab ) %]
584                                                     <td>
585                                                         <span class="tdlabel">Fines:</span>
586                                                         [% IF ( OVERDUE.charges ) %]
587                                                             Yes
588                                                         [% ELSE %]
589                                                             No
590                                                         [% END %]
591                                                     </td>
592                                                 [% END %]
593                                             </tr>
594                                         [% END %]
595                                     </tbody>
596                                 </table>
597                             </div> <!-- / #opac-user-overdues -->
598                         [% END # /overdues_count %]
599
600                         [% PROCESS 'holds-table.inc' HOLDS => RESERVES, SuspendHoldsOpac = SuspendHoldsOpac, showpriority = showpriority, AutoResumeSuspendedHolds = AutoResumeSuspendedHolds %]
601
602                         [% IF Koha.Preference('ArticleRequests') %]
603                             <div id="opac-user-article-requests">
604                                 [% IF logged_in_user.article_requests_current.count %]
605                                     <table id="article-requests-table" class="table table-bordered table-striped">
606                                         <caption>Article requests <span class="count">([% logged_in_user.article_requests_current.count | html %] total)</span></caption>
607                                         <thead>
608                                             <tr>
609                                                 <th class="anti-the article-request-record-title">Record title</th>
610                                                 <th class="psort article-request-created-on">Placed on</th>
611                                                 <th class="anti-the article-request-title">Title</th>
612                                                 <th class="article-request-author">Author</th>
613                                                 <th class="article-request-volume">Volume</th>
614                                                 <th class="article-request-issue">Issue</th>
615                                                 <th class="article-request-date">Date</th>
616                                                 <th class="article-request-pages">Pages</th>
617                                                 <th class="article-request-chapters">Chapters</th>
618                                                 <th class="article-request-patron-notes">Notes</th>
619                                                 <th class="article-request-status">Status</th>
620                                                 <th class="article-request-branchcode">Pickup library</th>
621                                                 <th class="nosort article-request-cancel">&nbsp;</th>
622                                             </tr>
623                                         </thead>
624
625                                         <tbody>
626                                         [% FOREACH ar IN logged_in_user.article_requests_current %]
627                                                 <td class="article-request-record-title">
628                                                     <a class="article-request-title" href="/cgi-bin/koha/opac-detail.pl?biblionumber=[% ar.biblionumber | html %]">
629                                                         [% ar.biblio.title | html %]
630                                                         [% ar.item.enumchron | html %]
631                                                     </a>
632                                                     [% ar.biblio.author | html %]
633                                                     [% IF ar.itemnumber %] <i>(only [% ar.item.barcode | html %])</i>[% END %]
634                                                 </td>
635
636                                                 <td class="article-request-created_on">
637                                                     [% ar.created_on | $KohaDates %]
638                                                 </td>
639
640                                                 <td class="article-request-title">
641                                                     [% ar.title | html %]
642                                                 </td>
643
644                                                 <td class="article-request-author">
645                                                     [% ar.author | html %]
646                                                 </td>
647
648                                                 <td class="article-request-volume">
649                                                     [% ar.volume | html %]
650                                                 </td>
651
652                                                 <td class="article-request-issue">
653                                                     [% ar.issue | html %]
654                                                 </td>
655
656                                                 <td class="article-request-date">
657                                                     [% ar.date | html %]
658                                                 </td>
659
660                                                 <td class="article-request-pages">
661                                                     [% ar.pages | html %]
662                                                 </td>
663
664                                                 <td class="article-request-chapters">
665                                                     [% ar.chapters | html %]
666                                                 </td>
667
668                                                 <td class="article-request-patron-notes">
669                                                     [% ar.patron_notes | html %]
670                                                 </td>
671
672                                                 <td class="article-request-status">
673                                                     [% IF ar.status == 'PENDING' %]
674                                                         Pending
675                                                     [% ELSIF ar.status == 'PROCESSING' %]
676                                                         Processing
677                                                     [% ELSIF ar.status == 'COMPLETED' %]
678                                                         Completed
679                                                     [% ELSIF ar.status == 'CANCELED' %]
680                                                         Canceled
681                                                     [% END %]
682                                                 </td>
683
684                                                 <td class="article-request-branchcode">
685                                                     [% ar.branch.branchname | html %]
686                                                 </td>
687
688                                                 <td class="article-request-cancel">
689                                                     <span class="tdlabel">Cancel:</span>
690                                                     <form action="/cgi-bin/koha/opac-article-request-cancel.pl" id="delete_article_request_[% ar.id | html %]">
691                                                         <input type="hidden" name="id" value="[% ar.id | html %]" />
692                                                         <button data-title="[% ar.biblio.title | html %] [% ar.item.enumchron | html %]" data-article-request_id="[% ar.id | html %]" type="submit" class="btn btn-sm btn-danger btn-delete-article-request"><i class="fa fa-remove"></i> Cancel</button>
693                                                     </form>
694                                                 </td>
695                                             </tr>
696                                         [% END %]
697                                     </tbody>
698                                 </table>
699                             [% ELSE %]
700                                 <table class="table table-bordered table-striped">
701                                     <tr><td>You have no article requests currently.</td></tr>
702                                 </table>
703                             [% END # IF article_requests_current.count %]
704                         </div> <!-- / #opac-user-article-requests -->
705                     [% END %]
706
707                     </div> <!-- /#opac-user-views -->
708                 </div> <!-- /#userdetails -->
709             </div> <!-- /.span10 -->
710         </div> <!-- /.row-fluid -->
711     </div> <!-- /.container-fluid -->
712 </div> <!-- /#main -->
713
714 [% IF ( OverDriveCirculation ) %]
715     [% INCLUDE 'overdrive-checkout.inc' %]
716     [% IF ( Koha.Preference('OverDrivePasswordRequired') ) %]
717         [% INCLUDE 'overdrive-login.inc' %]
718     [% END %]
719 [% END %]
720 [% IF ( RecordedBooksCirculation ) %]
721 [% INCLUDE 'recordedbooks-checkout.inc' %]
722 [% END %]
723
724 [% INCLUDE 'opac-bottom.inc' %]
725 [% BLOCK jsinclude %]
726     [% INCLUDE 'calendar.inc' %]
727     [% INCLUDE 'datatables.inc' %]
728     <script>
729
730         $(document).ready(function(){
731             $('#opac-user-views').tabs();
732             $(".js-show").show();
733             $(".js-hide").hide();
734             $(".modal-nojs").addClass("modal").addClass("hide").removeClass("modal-nojs");
735             $(".suspend-until").prop("readonly",1);
736
737             $(".btn-delete-hold").on("click", function(e){
738                 e.preventDefault();
739                 var hold_title = $(this).data("title");
740                 var reserve_id = $(this).data("reserve_id");
741                 var body = "<p><strong>" + hold_title + "</strong></p>";
742                 confirmModal( hold_title, _("Are you sure you want to cancel this hold?"), _("Yes, cancel hold"), _("No, do not cancel hold"), function( result ){
743                         if( result ){
744                             $("#delete_hold_" + reserve_id ).submit();
745                         }
746                     }
747                 );
748             });
749
750             $(".btn-delete-article-request").on("click", function(e){
751                 e.preventDefault();
752                 var hold_title = $(this).data("title");
753                 var article_request_id = $(this).data("article-request_id");
754                 var body = "<p><strong>" + hold_title + "</strong></p>";
755                 confirmModal( hold_title, _("Are you sure you want to cancel this article request?"), _("Yes, cancel article request"), _("No, do not cancel article request"), function( result ){
756                         if( result ){
757                             $("#delete_article_request_" + article_request_id ).submit();
758                         }
759                     }
760                 );
761             });
762
763             $("#suspend_all_submit").on("click", function(e){
764                 e.preventDefault();
765                 var title = _("Are you sure you want to suspend all holds?");
766                 var body = _("All holds will be suspended.");
767                 confirmModal( body, title, _("Yes, suspend all holds"), "", function( result ){
768                         if( result ){
769                             $("#suspend_all_holds").submit();
770                         }
771                     }
772                 );
773             });
774
775             $("#resume_all_submit").on("click", function(e){
776                 e.preventDefault();
777                 var title = _("Are you sure you want to resume all suspended holds?");
778                 var body = _("All holds will resume.");
779                 confirmModal( body, title, _("Yes, resume all holds"), _("No, do not resume holds"), function( result ){
780                         if( result ){
781                             $("#resume_all_holds").submit();
782                         }
783                     }
784                 );
785             });
786
787             var dTables = $("#checkoutst,#holdst,#overduest,#opac-user-relative-issues-table");
788             dTables.each(function(){
789                 var thIndex = $(this).find("th.psort").index();
790                 $(this).dataTable($.extend(true, {}, dataTablesDefaults, {
791                     "sorting" : [[ thIndex, 'asc' ]],
792                     "columnDefs": [
793                         { "targets": [ "nosort" ],"sortable": false,"searchable": false },
794                         { "type": "anti-the", "targets" : [ "anti-the" ] },
795                         { "type": "title-string", "targets" : [ "title-string" ] }
796                     ]
797                 }));
798             });
799
800             [% IF ( GoogleJackets ) %]KOHA.Google.GetCoverFromIsbn();[% END %]
801             [% IF ( OpacRenewalAllowed && canrenew && !userdebarred ) %]
802                 $("#renewselected").submit(function(){
803                     valid = false;
804                     $("input[type=checkbox]").each(function(){
805                         if($(this).is(':checked')){
806                             valid = true;
807                         }
808                     });
809                     if(!valid){
810                         alert(_("Nothing has been selected. Check the box for each item you want to renew"));
811                     }
812                     return valid;
813                 });
814                 $("body").on("click","#renewselected_link",function(e){
815                     e.preventDefault();
816                     $("#renewselected").submit();
817                 });
818                 $("body").on("click","#renewall_link",function(e){
819                     e.preventDefault();
820                     $("#renewall").submit();
821                 });
822                 [% IF ( canrenew && !userdebarred && OpacRenewalAllowed && !( logged_in_user.is_expired && logged_in_user.category.effective_BlockExpiredPatronOpacActions ) ) %]
823                     $("#checkoutst caption").append("<div id=\"renewcontrols\"><a id=\"renewselected_link\" href=\"#\">"+_("Renew selected")+"</a> <a id=\"renewall_link\" href=\"#\">"+_("Renew all")+"</a></div>");
824                 [% END %]
825             [% END %]
826
827             [% IF ( Koha.Preference('AllowCheckoutNotes') ) %]
828
829                 /* If JS enabled, show button, otherwise show link to redirect to a page where note can be submitted */
830                 $("a[name='nonjs_submitnote']").hide();
831
832                 $("input[name='note']").prop('readonly', false);
833                 $("input[name='note']").keypress(function(e){
834                     /* prevent submitting of renewselected form */
835                     if(e.which == 13)
836                         e.preventDefault();
837                 });
838
839                 $("input[name='note']").keyup(function(e){
840                     var $btn_save = $('#save_'+$(this).data('issue_id'));
841                     var origvalue = $(this).data('origvalue');
842                     var value = $(this).val();
843
844                     if(origvalue != value) {
845                         if(origvalue != "")
846                             $btn_save.text(_("Submit changes"));
847                         else
848                             $btn_save.text(_("Submit note"));
849                         $btn_save.show();
850                     } else {
851                         $btn_save.hide();
852                     }
853                 });
854
855                 $("a[name='js_submitnote']").click(function(e){
856                     var $self = $(this);
857                     var title = $(this).parent().siblings('.title').html();
858                     var $noteinput = $(this).siblings('input[name="note"]').first();
859
860                     var ajaxData = {
861                         'action': 'issuenote',
862                         'issue_id': $noteinput.data('issue_id'),
863                         'note': $noteinput.val(),
864                     };
865
866                     $.ajax({
867                         url: '/cgi-bin/koha/svc/checkout_notes/',
868                         type: 'POST',
869                         dataType: 'json',
870                         data: ajaxData,
871                     })
872                     .done(function(data) {
873                         var message = "";
874                         if(data.status == 'saved') {
875                             $("#notesaved").removeClass("alert-error");
876                             $("#notesaved").addClass("alert-info");
877                             $noteinput.data('origvalue', data.note);
878                             $noteinput.val(data.note);
879                             message = "<p>" + _("Your note about %s has been saved and sent to the library.").format(title) + "</p>";
880                             message += "<p style=\"font-style:italic;\">" + data.note + "</p>";
881                             $self.hide();
882                         } else if(data.status == 'removed') {
883                             $("#notesaved").removeClass("alert-error");
884                             $("#notesaved").addClass("alert-info");
885                             $noteinput.data('origvalue', "");
886                             $noteinput.val("");
887                             message = "<p>" + _("Your note about %s was removed.").format(title) + "</p>";
888                             $self.hide();
889                         } else {
890                             $("#notesaved").removeClass("alert-info");
891                             $("#notesaved").addClass("alert-error");
892                             message =  "<p>" + _("Your note about %s could not be saved.").format(title) + "</p>";
893                             message += "<p style=\"font-weight:bold;\">" + _("Something went wrong. The note has not been saved") + "</p>";
894                         }
895                         $("#notesaved").html(message);
896                     })
897                     .fail(function(data) {
898                         $("#notesaved").removeClass("alert-info");
899                         $("#notesaved").addClass("alert-error");
900                         var message = "<p style=\"font-weight:bold;\">" + _("Something went wrong. The note has not been saved") + "</p>";
901                         $("#notesaved").html(message);
902                     })
903                     .always(function() {
904                         $("#notesaved").show();
905                     });
906                 });
907             [% END %]
908
909             $( ".suspend-until" ).datepicker({ minDate: 1 }); // Require that "until date" be in the future
910
911             if ( $('#opac-user-clubs').length ) {
912                 $('#opac-user-clubs-tab-link').on('click', function() {
913                     $('#opac-user-clubs').text(_("Loading..."));
914                     $('#opac-user-clubs').load('/cgi-bin/koha/clubs/clubs-tab.pl?borrowernumber=[% borrowernumber | html %]');
915                 });
916             }
917         });
918         //]]>
919     </script>
920     [% IF Koha.Preference('OverDriveCirculation') %]
921     [% Asset.js("js/overdrive.js") | $raw %]
922     <script>
923     var OD_password_required = [% IF Koha.Preference('OverDrivePasswordRequired') %]1[% ELSE %]0[% END %];
924     $(document).ready(function() {
925         [% IF ( overdrive_error ) %]
926             KOHA.OverDriveCirculation.display_error("#opac-user-overdrive", "[% overdrive_error.dquote | html %]");
927         [% END %]
928
929         [% IF ( overdrive_tab ) %]
930             $("#opac-user-views").tabs("select", "#opac-user-overdrive");
931         [% END %]
932
933         $("#opac-user-overdrive").each( function() {
934             KOHA.OverDriveCirculation.display_account_details(this);
935         } );
936     });
937     </script>
938     [% END %]
939     [% IF RecordedBooksCirculation %]
940         [% Asset.js("js/recordedbooks.js") | $raw %]
941         <script type="text/JavaScript">
942             $(document).ready(function() {
943                 [% IF ( recordedbooks_error ) %]
944                     KOHA.RecordedBooks.display_error("#opac-user-recordedbooks", "[% recordedbooks_error.dquote | html %]");
945                 [% END %]
946                 [% IF ( recordedbooks_tab ) %]
947                     $("#opac-user-views").tabs("select", "#opac-user-recordedbooks");
948                 [% END %]
949                 $("#opac-user-recordedbooks").each( function() {
950                     KOHA.RecordedBooks.display_account_details(this);
951                 } );
952             });
953         </script>
954     [% END %]
955 [% END %]