+[% USE raw %]
+[% USE Asset %]
[% USE Koha %]
[% USE KohaDates %]
+[% USE Branches %]
+[% USE ItemTypes %]
+[% USE Price %]
+
+[% SET borrower_club_enrollments = logged_in_user.get_club_enrollments(1) %]
+[% SET borrower_enrollable_clubs = logged_in_user.get_enrollable_clubs(1,1) %]
[% INCLUDE 'doc-head-open.inc' %]
-<title>[% IF ( LibraryNameTitle ) %][% LibraryNameTitle %][% ELSE %]Koha online[% END %] catalog › Your library home</title>
+<title>[% IF ( LibraryNameTitle ) %][% LibraryNameTitle | html %][% ELSE %]Koha online[% END %] catalog › Your library home</title>
[% INCLUDE 'doc-head-close.inc' %]
[% BLOCK cssinclude %][% END %]
</head>
[% INCLUDE 'bodytag.inc' bodyid='opac-user' bodyclass='scrollto' %]
[% INCLUDE 'masthead.inc' %]
+[% IF Koha.Preference('AmazonAssocTag') %]
+ [% AmazonAssocTag = '?tag=' _ Koha.Preference('AmazonAssocTag') | html %]
+[% ELSE %]
+ [% AmazonAssocTag = '' | html %]
+[% END %]
+
<div class="main">
<ul class="breadcrumb">
<li><a href="/cgi-bin/koha/opac-main.pl">Home</a> <span class="divider">›</span></li>
- <li><a href="/cgi-bin/koha/opac-user.pl">[% INCLUDE 'patron-title.inc' category_type = BORROWER_INFO.category_type firstname = BORROWER_INFO.firstname surname = BORROWER_INFO.surname othernames = BORROWER_INFO.othernames cardnumber = BORROWER_INFO.cardnumber %]</a> <span class="divider">›</span></li>
+ <li><a href="/cgi-bin/koha/opac-user.pl">[% INCLUDE 'patron-title.inc' patron = logged_in_user %]</a> <span class="divider">›</span></li>
<li><a href="#">Your summary</a></li>
</ul>
</div>
<div class="span10">
<div id="userdetails" class="maincontent">
- [% IF ( bor_messages ) %]
- <div class="alert alert-info">
- <h3>Messages for you</h3>
- <ul>
- [% FOREACH bor_messages_loo IN bor_messages_loop %]
- <li>
- <strong>[% bor_messages_loo.message %]</strong><br>
- <i>Written on [% bor_messages_loo.message_date | $KohaDates %] by [% bor_messages_loo.branchname %]</i>
- </li>
- [% END %]
- [% IF ( opacnote ) %]<li>[% opacnote %]</li>[% END %]
- </ul>
- </div>
- [% END # / IF bor_messages %]
- <h2>Hello, [% INCLUDE 'patron-title.inc' category_type = BORROWER_INFO.category_type firstname = BORROWER_INFO.firstname surname = BORROWER_INFO.surname othernames = BORROWER_INFO.othernames cardnumber = BORROWER_INFO.cardnumber %]
+ [% INCLUDE 'opac-note.inc' %]
+
+ <h2>Hello, [% INCLUDE 'patron-title.inc' patron = logged_in_user %]
</h2>
- <p><a href="/cgi-bin/koha/opac-main.pl?logout.x=1">Click here if you're not [% BORROWER_INFO.title %] [% INCLUDE 'patron-title.inc' category_type = BORROWER_INFO.category_type firstname = BORROWER_INFO.firstname surname = BORROWER_INFO.surname othernames = BORROWER_INFO.othernames cardnumber = BORROWER_INFO.cardnumber %]</a></p>
+ <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>
[% 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 %]
</div>
[% END %]
- [% IF ( BORROWER_INFO.warndeparture ) %]
+ [% IF ( borrower.warndeparture ) %]
<div class="alert" id="warndeparture">
- <strong>Please note:</strong><span> Your card will expire on <span id="warndeparture_date">[% BORROWER_INFO.warndeparture | $KohaDates %]</span>. Please contact the library for more information.</span>
- [% IF ( BORROWER_INFO.returnbeforeexpiry ) %]<span id="warndeparture_returnbeforeexpiry"> Also note that you must return all checked out items before your card expires.</span>[% END %]
+ <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>
+ [% IF ( borrower.returnbeforeexpiry ) %]<span id="warndeparture_returnbeforeexpiry"> Also note that you must return all checked out items before your card expires.</span>[% END %]
</div>
[% END %]
- [% IF ( BORROWER_INFO.warnexpired ) %]
+ [% IF ( borrower.warnexpired ) %]
<div class="alert" id="warnexpired">
- <strong>Please note: </strong><span>Your account has expired as of [% BORROWER_INFO.warnexpired | $KohaDates %]. Please contact the library if you wish to renew your account.</span>
+ <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>
</div>
[% END %]
[% IF ( RENEW_ERROR ) %]
<div class="dialog alert">
<strong>Please note:</strong>
- <span>
Your loan renewal failed because of the following reason(s):
- [% FOREACH error IN RENEW_ERROR.split('\|') %]
- [% IF error == 'card_expired' %]
- Your account has expired. Please contact the library for more information.
- [% ELSIF error == 'too_many' %]
- You have renewed this item the maximum number of times allowed.
- [% ELSIF error == 'on_reserve' %]
- This item is on hold for another patron.
+ <ul>
+ [% FOREACH error IN RENEW_ERROR.split('\|') %]
+ [% IF error == 'card_expired' %]
+ <li>Your account has expired. Please contact the library for more information.</li>
+ [% ELSIF error == 'too_many' %]
+ <li>You have renewed this item the maximum number of times allowed.</li>
+ [% ELSIF error == 'too_soon' %]
+ <li>It is too soon after the checkout date for this item to be renewed.</li>
+ [% ELSIF error == 'on_reserve' %]
+ <li>This item is on hold for another borrower.</li>
+ [% END %]
[% END %]
- [% END %]
- </span>
+ </ul>
</div>
[% END %]
<div class="alert">
<ul>
[% IF ( userdebarred ) %]
- <li id="userdebarred"><strong>Please note:</strong> Your account has been frozen[% IF ( BORROWER_INFO.userdebarreddate ) %] until <span id="userdebarred_date">[% BORROWER_INFO.userdebarreddate | $KohaDates %]</span>[% END %][% IF ( BORROWER_INFO.debarredcomment ) %] with the comment <span id="userdebarred_comment">"[% BORROWER_INFO.debarredcomment %]"</span>[% END %]. Usually the reason for freezing an account is old overdues or damage fees. If <a href="/cgi-bin/koha/opac-user.pl">your account page</a> shows your account to be clear, please contact the library.</li>
+ [% IF ( discharge_available ) %]
+ <li id="discharged">
+ <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>
+ </li>
+ [% ELSE %]
+ <li id="userdebarred"><strong>Please note:</strong> Your account has been frozen.
+ [% IF ( borrower.debarredcomment ) %]
+ Comment:
+ <span id="userdebarred_comment">
+ <strong>
+ [% IF borrower.debarredcomment.search('OVERDUES_PROCESS') %]
+ Restriction added by overdues process [% borrower.debarredcomment.remove('OVERDUES_PROCESS ') | html_line_break %]
+ [% ELSE %]
+ [% borrower.debarredcomment | html_line_break %]
+ [% END %]
+ </strong>
+ </span>
+ [% END %]
+ [% IF ( borrower.userdebarreddate && debarred_date != '9999-12-31' ) %]
+ End date:
+ <span id="userdebarred_date">[% borrower.userdebarreddate | $KohaDates %]</span>
+ [% END %]
+
+ <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>
+ [% END %]
[% END %]
- [% IF ( BORROWER_INFO.gonenoaddress ) %]
- <li id="gonenoaddress"><strong>Please note:</strong> According to our records, we don't have up-to-date [% UNLESS OPACPatronDetails %]<a href="/cgi-bin/koha/opac-userupdate.pl">contact information</a>[% ELSE %]contact information[% END %] on file. Please contact the library[% IF OPACPatronDetails %] or use the <a href="/cgi-bin/koha/opac-userupdate.pl">online update form</a> to submit current information (<em>Please note:</em> there may be a delay in restoring your account if you submit online)[% END %].</li>
+ [% IF ( borrower.gonenoaddress ) %]
+ <li id="gonenoaddress"><strong>Please note:</strong> According to our records, we don't have up-to-date contact information. Please contact the library.
+ <a href="/cgi-bin/koha/opac-memberentry.pl">[% IF ( Koha.Preference('OPACPatronDetails') ) %]Update your contact information[% ELSE %]Go to your contact information[% END %]</a>
+ [% IF ( Koha.Preference('OPACPatronDetails') ) %]<em>(Please note: there may be a delay in restoring your account if you submit online.)</em>[% END %]
+ </li>
[% END %]
- [% IF ( BORROWER_INFO.lost ) %]
- <li id="lost"><strong>Please note: </strong> Your library card has been marked as lost or stolen. If this is an error, please contact the library.</li>
+ [% IF ( borrower.lost ) %]
+ <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>
[% END %]
- [% IF ( renewal_blocked_fines ) && ( OpacRenewalAllowed ) %]
- <li id="renewal_blocked_fines"><strong>Please note: </strong> Since you have <a href="/cgi-bin/koha/opac-account.pl">[% IF renewal_blocked_fines != "0.00" %] more than <span id="renewal_blocked_fines_amount">[% renewal_blocked_fines %]</span> in [% END %] fines</a>, you cannot renew your books online. Please pay your fines if you wish to renew your books.</li>
+ [% IF ( renewal_blocked_fines.defined ) && ( OpacRenewalAllowed ) %]
+ <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 %]
[% END %]
</ul>
</div>
[% END # / IF patron_flagged %]
- [% SET OPACMySummaryNote = Koha.Preference('OPACMySummaryNote') %]
- [% IF OPACMySummaryNote %][% OPACMySummaryNote %][% END %]
+ <div class="alert alert-info" id="notesaved" style="display:none;"></div>
+
+ [% IF OPACMySummaryNote %][% Koha.Preference('OPACMySummaryNote') | $raw %][% END %]
<div id="opac-user-views" class="toptabs">
<ul>
- <li><a href="#opac-user-checkouts">Checked out ([% issues_count %])</a></li>
- [% IF ( overdues_count ) %]<li><a href="#opac-user-overdues">Overdue ([% overdues_count %])</a></li>[% END %]
+ <li><a href="#opac-user-checkouts">Checked out ([% issues_count | html %])</a></li>
+ [% IF relatives %]<li><a href="#opac-user-relative-issues">Relatives' checkouts</a></li>[% END %]
+ [% IF ( overdues_count ) %]<li><a href="#opac-user-overdues">Overdue ([% overdues_count | html %])</a></li>[% END %]
[% IF ( OPACFinesTab ) %]
- [% IF ( BORROWER_INF.amountoverfive ) %]<li><a href="#opac-user-fines">Fines ([% BORROWER_INF.amountoutstanding %])</a></li>[% END %]
- [% IF ( BORROWER_INF.amountoverzero ) %]<li><a href="#opac-user-fines">Fines ([% BORROWER_INF.amountoutstanding %])</a></li>[% END %]
- [% IF ( BORROWER_INF.amountlessthanzero ) %]<li><a href="#opac-user-fines">Credits ([% BORROWER_INF.amountoutstanding %])</a></li>[% END %]
+ [% IF ( borrower.amountoverfive ) %]<li><a href="#opac-user-fines">Fines ([% amountoutstanding | $Price %])</a></li>[% END %]
+ [% IF ( borrower.amountoverzero ) %]<li><a href="#opac-user-fines">Fines ([% amountoutstanding | $Price %])</a></li>[% END %]
+ [% IF ( borrower.amountlessthanzero ) %]<li><a href="#opac-user-fines">Credits ([% amountoutstanding | $Price %])</a></li>[% END %]
+ [% END %]
+
+ [% IF borrower_club_enrollments.count || borrower_enrollable_clubs.count %]
+ <li>
+ <a id="opac-user-clubs-tab-link" href="#opac-user-clubs">
+ Clubs ([% borrower_club_enrollments.count || 0 | html %]/[% borrower_enrollable_clubs.count || 0 | html %])
+ </a>
+ </li>
+ [% END %]
+
+ [% IF ( RESERVES.count ) %]<li><a href="#opac-user-holds">Holds ([% RESERVES.count | html %])</a></li>[% END %]
+ [% 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 %]
+ [% IF ( OverDriveCirculation ) %]
+ <li><a href="#opac-user-overdrive">OverDrive Account</a></li>
+ [% END %]
+ [% IF ( RecordedBooksCirculation ) %]
+ <li><a href="#opac-user-recordedbooks">RecordedBooks Account</a></li>
[% END %]
- [% IF ( waiting_count ) %][% IF ( BORROWER_INF.atdestination ) %]<li><a href="#opac-user-waiting">Waiting ([% waiting_count %])</a></li>[% END %][% END %]
- [% IF ( reserves_count ) %]<li><a href="#opac-user-holds">Holds ([% reserves_count %])</a></li>[% END %]
</ul>
+ <div id="opac-user-overdrive">
+ </div>
+ <div id="opac-user-recordedbooks">
+ </div>
<div id="opac-user-checkouts">
[% IF ( issues_count ) %]
<form id="renewselected" action="/cgi-bin/koha/opac-renew.pl" method="post">
- <input type="hidden" name="borrowernumber" value="[% borrowernumber %]">
+ <input type="hidden" name="borrowernumber" value="[% borrowernumber | html %]">
<input type="hidden" name="from" value="opac_user" />
<table id="checkoutst" class="table table-bordered table-striped">
- <caption>[% issues_count %] Item(s) checked out</caption>
+ <caption>[% issues_count | html %] Item(s) checked out</caption>
<thead>
<tr>
[% IF ( JacketImages ) %]<th class="nosort"> </th>[% END %]
<th class="anti-the">Title</th>
+ <th>Author</th>
<th class="title-string psort">Due</th>
[% UNLESS ( item_level_itypes ) %]
<th>Item type</th>
[% IF ( show_barcode ) %]
<th>Barcode</th>
[% END %]
- <th>Call No.</th>
- [% IF ( OpacRenewalAllowed && !( borrower.is_expired && borrower.BlockExpiredPatronOpacActions ) ) %]
+ <th>Call no.</th>
+ [% IF ( OpacRenewalAllowed && !( logged_in_user.is_expired && logged_in_user.category.effective_BlockExpiredPatronOpacActions ) ) %]
<th class="nosort">Renew</th>
[% END %]
[% IF ( OPACFinesTab ) %]
[% IF ( OPACMySummaryHTML ) %]
<th class="nosort">Links</th>
[% END %]
+ [% IF ( Koha.Preference('AllowCheckoutNotes') ) %]
+ <th class="nosort">Note</th>
+ [% END %]
</tr>
</thead>
<tbody>
[% IF ( OPACAmazonCoverImages ) %]
[% IF ( ISSUE.normalized_isbn ) %]
- <a href="http://www.amazon.com/gp/reader/[% ISSUE.normalized_isbn %]/ref=sib_dp_pt/002-7879865-0184864#reader-link" title="View on Amazon.com"><img src="https://images-na.ssl-images-amazon.com/images/P/[% ISSUE.normalized_isbn %].01.THUMBZZZ.jpg" alt="View on Amazon.com" class="item-thumbnail"/></a>
+ <a href="http://www.amazon.com/gp/reader/[% ISSUE.normalized_isbn | html %][% AmazonAssocTag | html %]#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>
[% ELSE %]
<a href="#"><span class="no-image">No cover image available</span></a>
[% END %]
[% IF ( GoogleJackets ) %]
[% IF ( ISSUE.normalized_isbn ) %]
- <div style="display:block;" title="Click to view in Google Books" class="[% ISSUE.normalized_isbn %]" id="gbs-thumbnail[% loop.count %]"></div>
+ <div style="display:block;" title="Click to view in Google Books" class="[% ISSUE.normalized_isbn | html %]" id="gbs-thumbnail[% loop.count | html %]"></div>
[% ELSE %]
<a href="http://books.google.com/books?q=[% ISSUE.title |url %]"><span class="no-image">No cover image available</span></a>
[% END %]
[% END %]
[% IF ( BakerTaylorEnabled ) %]
- [% bt_id = ( ISSUE.normalized_upc || ISSUE.normalized_isbn ) %]
+ [% bt_id = ( ISSUE.normalized_upc || ISSUE.normalized_isbn ) | html %]
[% IF ( bt_id ) %]
- <a href="https://[% BakerTaylorBookstoreURL |html %][% bt_id %]"><img alt="See Baker & Taylor" src="[% BakerTaylorImageURL |html %][% bt_id %]" /></a>
+ <a href="https://[% BakerTaylorBookstoreURL | html %][% bt_id | html %]"><img alt="See Baker & Taylor" src="[% BakerTaylorImageURL | html %][% bt_id | html %]" /></a>
[% ELSE %]
<span class="no-image">No cover image available</span><!-- BakerTaylor needs normalized_upc or normalized_isbn! -->
[% END %]
[% END %]
[% IF ( SyndeticsEnabled && SyndeticsCoverImages ) %]
- [% IF ( using_https ) %]
- <img src="https://secure.syndetics.com/index.aspx?isbn=[% ISSUE.normalized_isbn %]/SC.GIF&client=[% SyndeticsClientCode %]&type=xw10&upc=[% ISSUE.normalized_upc %]&oclc=[% ISSUE.normalized_oclc %]" alt="" class="item-thumbnail" />
- [% ELSE %]
- <img src="http://www.syndetics.com/index.aspx?isbn=[% ISSUE.normalized_isbn %]/SC.GIF&client=[% SyndeticsClientCode %]&type=xw10&upc=[% ISSUE.normalized_upc %]&oclc=[% ISSUE.normalized_oclc %]" alt="" class="item-thumbnail" />
- [% END %]
+ <img src="https://secure.syndetics.com/index.aspx?isbn=[% ISSUE.normalized_isbn | html %]/SC.GIF&client=[% SyndeticsClientCode | html %]&type=xw10&upc=[% ISSUE.normalized_upc | html %]&oclc=[% ISSUE.normalized_oclc | html %]" alt="" class="item-thumbnail" />
[% END %]
</td>[% END # / IF JacketImages %]
<td class="title">
- <a class="title" href="/cgi-bin/koha/opac-detail.pl?biblionumber=[% ISSUE.biblionumber %]">[% ISSUE.title |html %] [% FOREACH subtitl IN ISSUE.subtitle %] [% subtitl.subfield %][% END %]</a>
- <span class="item-details">[% ISSUE.author %]</span>
+ <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>
+ [% IF ( ISSUE.enumchron ) %] [% ISSUE.enumchron | html %][% END %]
</td>
+
+ <td class="author">[% ISSUE.author | html %]</td>
[% IF ( ISSUE.overdue ) %]
<td class="date_due overdue">
- <span title="[% ISSUE.date_due %]">
+ <span title="[% ISSUE.date_due | html %]">
<span class="tdlabel">Date due:</span>
- [% ISSUE.date_due_sql | $KohaDates as_due_date => 1 %]
+ [% ISSUE.date_due | $KohaDates as_due_date => 1 | html %]
</span>
</td>
[% ELSE %]
<td class="date_due">
- <span title="[% ISSUE.date_due %]">
+ <span title="[% ISSUE.date_due | html %]">
<span class="tdlabel">Date due:</span>
- [% ISSUE.date_due_sql | $KohaDates as_due_date => 1 %]
+ [% ISSUE.date_due | $KohaDates as_due_date => 1 | html %]
</span>
</td>
[% END %]
<td class="itype">
<span class="tdlabel">Item type:</span>
[% IF ( ISSUE.imageurl ) %]
- <img src="[% ISSUE.imageurl %]" title="[% ISSUE.description %]" alt="[% ISSUE.description %]" />
- [% END %] [% ISSUE.description %]
+ <img src="[% ISSUE.imageurl | html %]" title="[% ISSUE.description | html %]" alt="[% ISSUE.description | html %]" />
+ [% END %] [% ISSUE.description | html %]
</td>
[% END %]
[% IF ( show_barcode ) %]
<td class="barcode">
<span class="tdlabel">Barcode:</span>
- [% ISSUE.barcode %]
+ [% ISSUE.barcode | html %]
</td>
[% END %]
<td class="call_no">
- <span class="tdlabel">Call number:</span>
- [% ISSUE.itemcallnumber %]
+ <span class="tdlabel">Call no.:</span>
+ [% ISSUE.itemcallnumber | html %]
</td>
- [% IF ( OpacRenewalAllowed && !( borrower.is_expired && borrower.BlockExpiredPatronOpacActions ) ) %]
+ [% IF ( OpacRenewalAllowed && !( logged_in_user.is_expired && logged_in_user.category.effective_BlockExpiredPatronOpacActions ) ) %]
<td class="renew">
[% IF ISSUE.renewed %]<span class="blabel label-success">Renewed!</span><br />[% END %]
[% IF ( ISSUE.status ) %]
[% IF ( canrenew ) %]
- <input type="checkbox" name="item" value="[% ISSUE.itemnumber %]"/> <a href="/cgi-bin/koha/opac-renew.pl?from=opac_user&item=[% ISSUE.itemnumber %]&borrowernumber=[% ISSUE.borrowernumber %]">Renew</a>
+ <input type="checkbox" name="item" value="[% ISSUE.itemnumber | html %]"/> <a href="/cgi-bin/koha/opac-renew.pl?from=opac_user&item=[% ISSUE.itemnumber | html %]&borrowernumber=[% ISSUE.borrowernumber | html %]">Renew</a>
[% END %]
- <span class="renewals">([% ISSUE.renewsleft %] of [% ISSUE.renewsallowed %] renewals remaining)</span>
+ [% IF ISSUE.renewalfee > 0 %]
+ <span class="renewalfee">Fee for item type '[% ItemTypes.GetDescription( ISSUE.renewalitemtype) | html %]': [% ISSUE.renewalfee | $Price %]</span>
+ [% END %]
+ <span class="renewals">([% ISSUE.renewsleft | html %] of [% ISSUE.renewsallowed | html %] renewals remaining)</span>
+ [% ELSIF ( ISSUE.on_reserve ) %]
+ Not renewable <span class="renewals">(on hold)</span>
[% ELSIF ( ISSUE.too_many ) %]
Not renewable
[% ELSIF ( ISSUE.norenew_overdue ) %]
Not allowed <span class="renewals">(overdue)</span>
+ [% ELSIF ( ISSUE.auto_too_late ) %]
+ No longer renewable
+ [% ELSIF ISSUE.auto_too_much_oweing %]
+ Automatic renewal failed, you have unpaid fines.
+ <span class="renewals">([% ISSUE.renewsleft | html %] of [% ISSUE.renewsallowed | html %] renewals remaining)</span>
+ [% ELSIF ISSUE.auto_account_expired %]
+ Automatic renewal failed, your account is expired.
+ <span class="renewals">([% ISSUE.renewsleft | html %] of [% ISSUE.renewsallowed | html %] renewals remaining)</span>
[% ELSIF ( ISSUE.auto_renew || ISSUE.auto_too_soon ) %]
Automatic renewal
- <span class="renewals">([% ISSUE.renewsleft %] of [% ISSUE.renewsallowed %] renewals remaining)</span>
+ <span class="renewals">([% ISSUE.renewsleft | html %] of [% ISSUE.renewsallowed | html %] renewals remaining)</span>
[% ELSIF ( ISSUE.too_soon ) %]
- No renewal before [% ISSUE.soonestrenewdate %]
- <span class="renewals">([% ISSUE.renewsleft %] of [% ISSUE.renewsallowed %] renewals remaining)</span>
- [% ELSIF ( ISSUE.on_reserve ) %]
- <span class="renewals">(On hold)</span>
+ No renewal before [% ISSUE.soonestrenewdate | html %]
+ <span class="renewals">([% ISSUE.renewsleft | html %] of [% ISSUE.renewsallowed | html %] renewals remaining)</span>
[% END %]
</td>
[% END %]
<td class="fines">
<span class="tdlabel">Fines:</span>
[% IF ( ISSUE.charges ) %]
- Yes
+ Yes (Item overdue or lost)
+ [% ELSIF ( ISSUE.rentalfines ) %]
+ Yes (Rental fees)
[% ELSE %]
No
[% END %]
</td>
[% END %]
[% IF ( OPACMySummaryHTML ) %]
- <td class="links">[% ISSUE.MySummaryHTML %]</td>
+ <td class="links">[% ISSUE.MySummaryHTML | $raw %]</td>
+ [% END %]
+ [% IF ( Koha.Preference('AllowCheckoutNotes') ) %]
+ <td class="note">
+ <input type="text" name="note" data-issue_id="[% ISSUE.issue_id | html %]" data-origvalue="[% ISSUE.note | html %]" value="[% ISSUE.note | html %]" readonly>
+ <a class="btn" name="js_submitnote" id="save_[% ISSUE.issue_id | html %]" style="display:none;">Submit note</a>
+ <a class="btn" name="nonjs_submitnote" href="/cgi-bin/koha/opac-issue-note.pl?issue_id=[% ISSUE.issue_id | url %]">Edit / Create note</a>
+ </td>
[% END %]
</tr>
[% END # /FOREACH ISSUES %]
</tbody>
</table>
- [% IF ( canrenew && !userdebarred && OpacRenewalAllowed && !( borrower.is_expired && borrower.BlockExpiredPatronOpacActions ) ) %]
+ [% IF ( canrenew && !userdebarred && OpacRenewalAllowed && !( logged_in_user.is_expired && logged_in_user.category.effective_BlockExpiredPatronOpacActions ) ) %]
<input type="submit" class="btn" value="Renew selected" />
[% END %]
</form>
- [% IF ( canrenew && !userdebarred && OpacRenewalAllowed && !( borrower.is_expired && borrower.BlockExpiredPatronOpacActions ) ) %]
+ [% IF ( canrenew && !userdebarred && OpacRenewalAllowed && !( logged_in_user.is_expired && logged_in_user.category.effective_BlockExpiredPatronOpacActions ) ) %]
<form id="renewall" action="/cgi-bin/koha/opac-renew.pl" method="post">
<input type="hidden" name="from" value="opac_user" />
- <input type="hidden" name="borrowernumber" value="[% borrowernumber %]" />
+ <input type="hidden" name="borrowernumber" value="[% borrowernumber | html %]" />
[% FOREACH ISSUE IN ISSUES %]
- <input type="hidden" name="item" value="[% ISSUE.itemnumber %]" />
+ <input type="hidden" name="item" value="[% ISSUE.itemnumber | html %]" />
[% END %]
<input type="submit" class="btn" value="Renew all" />
</form>
[% END %]
+ <p><a href="opac-ics.pl">Download as iCal/.ics file</a></p>
[% ELSE %]
<table class="table table-bordered table-striped">
<tr><td>You have nothing checked out</td></tr>
[% END # IF issues_count %]
</div> <!-- / .opac-user-checkouts -->
+ [% IF borrower_club_enrollments.count || borrower_enrollable_clubs.count %]
+ <div id="opac-user-clubs">
+ Loading...
+ </div>
+ [% END %]
+
[% IF ( OPACFinesTab ) %]
<!-- FINES BOX -->
- [% IF BORROWER_INFO.amountoverfive %]
+ [% IF borrower.amountoverfive %]
<div id="opac-user-fines"> <h3>Fines and charges</h3>
<table class="table table-bordered table-striped">
<thead><tr><th colspan="2">Amount</th></tr></thead>
<tbody>
<tr>
<td>You currently owe fines and charges amounting to:</td>
- <td><a href="/cgi-bin/koha/opac-account.pl">[% BORROWER_INFO.amountoutstanding %]</a></td>
+ <td><a href="/cgi-bin/koha/opac-account.pl">[% amountoutstanding | $Price %]</a></td>
</tr>
</tbody>
</table>
</div>
[% END %]
- [% IF BORROWER_INFO.amountoverzero %]
+ [% IF borrower.amountoverzero %]
<div id="opac-user-fines"> <h3>Fines and charges</h3>
<table class="table table-bordered table-striped">
<thead><tr><th colspan="2">Amount</th></tr></thead>
<tbody>
<tr>
<td>You currently owe fines and charges amounting to:</td>
- <td><a href="/cgi-bin/koha/opac-account.pl">[% BORROWER_INFO.amountoutstanding %]</a></td>
+ <td><a href="/cgi-bin/koha/opac-account.pl">[% amountoutstanding | $Price %]</a></td>
</tr>
</tbody>
</table>
</div>
[% END %]
- [% IF BORROWER_INFO.amountlessthanzero %]
+ [% IF borrower.amountlessthanzero %]
<div id="opac-user-fines"> <h3>Credits</h3>
<table class="table table-bordered table-striped">
<thead><tr><th colspan="2">Amount</th></tr></thead>
<tbody>
<tr>
- <td>You have a credit of:</td><td><a href="/cgi-bin/koha/opac-account.pl">[% BORROWER_INFO.amountoutstanding %]</a></td>
+ <td>You have a credit of:</td><td><a href="/cgi-bin/koha/opac-account.pl">[% amountoutstanding | $Price %]</a></td>
</tr>
</tbody>
</table>
[% END %]
[% END # / OPACFinesTab %]
- [% IF ( waiting_count && atdestination ) %]
- <div id="opac-user-waiting">
- <table id="waitingt" class="table table-bordered table-striped">
- <caption>Holds waiting</caption>
+ [% IF relatives %]
+ <div id="opac-user-relative-issues">
+ <table id="opac-user-relative-issues-table" class="table table-bordered table-striped">
<thead>
<tr>
<th class="anti-the">Title</th>
- <th>Hold date</th>
- <th>Pick up library</th>
+ <th>Due</th>
+ <th>Barcode</th>
+ <th>Call no.</th>
+ <th class="psort">Relative</th>
</tr>
</thead>
+
<tbody>
- [% FOREACH WAITIN IN WAITING %]
- <tr>
- <td><img src="[% themelang %]/images/[% WAITIN.itemtype %].gif" alt="[% WAITIN.itemtype %]" title="[% WAITIN.itemtype %]" /></td>
- <td>
- <a class="title" href="opac-detail.pl?biblionumber=[% WAITIN.biblionumber %]">
- [% WAITIN.waiting_title %] [% FOREACH subtitl IN WAITIN.subtitle %] [% subtitl.subfield %][% END %]
- </a>
- <span class="item-details">
- [% WAITIN.author %]
- </span></td>
- <td>
- <span class="tdlabel">Hold date:</span>
- [% WAITIN.reservedate | $KohaDates %]</td>
- <td>
- [% IF ( WAITIN.atdestination ) %]
- <strong>Waiting</strong> at [% WAITIN.branch %]
- [% ELSE %]
- In transit from [% WAITIN.holdingbranch %] to [% WAITIN.branch %]
- [% END %]
- </td>
- </tr>
+ [% FOREACH r IN relatives %]
+ [% FOREACH i IN r.issues %]
+ <tr>
+ <td>
+ <a href="/cgi-bin/koha/opac-detail.pl?biblionumber=[% i.item.biblio.biblionumber | html %]">
+ [% i.item.biblio.title | html %][% IF ( i.item.enumchron ) %] [% i.item.enumchron | html %][% END %]
+ </a>
+ </td>
+
+ <td>
+ [% i.date_due | $KohaDates %]
+ </td>
+
+ <td>
+ [% i.item.barcode | html %]
+ </td>
+
+ <td>
+ [% i.item.itemcallnumber | html %]
+ </td>
+
+ <td>
+ [% r.firstname | html %] [% r.surname | html %]
+ </td>
+ </tr>
+ [% END %]
[% END %]
</tbody>
</table>
- </div> <!-- /#opac-user-waiting -->
- [% END # waiting_count && atdestination %]
-
+ </div>
+ [% END %]
[% IF ( overdues_count ) %]
<div id="opac-user-overdues">
<table id="overduest" class="table table-bordered table-striped">
- <caption>Overdues <span class="count">([% overdues_count %] total)</span></caption>
+ <caption>Overdues <span class="count">([% overdues_count | html %] total)</span></caption>
<!-- OVERDUES TABLE ROWS -->
<thead>
<tr>
<td class="jacketcell">
[% IF ( OPACAmazonCoverImages ) %]
[% IF ( OVERDUE.normalized_isbn ) %]
- <a href="http://www.amazon.com/gp/reader/[% OVERDUE.normalized_isbn %]/ref=sib_dp_pt/002-7879865-0184864#reader-link" title="View on Amazon.com"><img src="https://images-na.ssl-images-amazon.com/images/P/[% OVERDUE.normalized_isbn %].01.THUMBZZZ.jpg" alt="View on Amazon.com" class="item-thumbnail" /></a>
+ <a href="http://www.amazon.com/gp/reader/[% OVERDUE.normalized_isbn | html %][% AmazonAssocTag | html %]#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>
[% ELSE %]
<a href="#"><span class="no-image">No cover image available</span></a>
[% END %]
[% IF ( GoogleJackets ) %]
[% IF ( OVERDUE.normalized_isbn ) %]
- <div style="display:block;" title="Click to view in Google Books" class="[% OVERDUE.normalized_isbn %]" id="gbs-thumbnail[% loop.count %]"></div>
+ <div style="display:block;" title="Click to view in Google Books" class="[% OVERDUE.normalized_isbn | html %]" id="gbs-thumbnail[% loop.count | html %]"></div>
[% ELSE %]
<a href="http://books.google.com/books?q=[% OVERDUE.title |url %]"><span class="no-image">No cover image available</span></a>
[% END %]
[% END %]
[% IF ( BakerTaylorEnabled ) %]
- [% bt_id = ( OVERDUE.normalized_upc || OVERDUE.normalized_isbn ) %]
+ [% bt_id = ( OVERDUE.normalized_upc || OVERDUE.normalized_isbn ) | html %]
[% IF ( bt_id ) %]
- <a href="https://[% BakerTaylorBookstoreURL |html %][% bt_id %]"><img alt="See Baker & Taylor" src="[% BakerTaylorImageURL |html %][% bt_id %]" /></a>
+ <a href="https://[% BakerTaylorBookstoreURL | html %][% bt_id | html %]"><img alt="See Baker & Taylor" src="[% BakerTaylorImageURL | html %][% bt_id | html %]" /></a>
[% ELSE %]
<span class="no-image">No cover image available</span><!-- BakerTaylor needs normalized_upc or normalized_isbn! -->
[% END %]
[% END %]
[% IF ( SyndeticsCoverImages ) %]
- [% IF ( using_https ) %]
- <img src="https://secure.syndetics.com/index.aspx?isbn=[% OVERDUE.normalized_isbn %]/SC.GIF&client=[% SyndeticsClientCode %]&upc=[% OVERDUE.normalized_upc %]&oclc=[% OVERDUE.normalized_oclc %]&type=xw10" alt="" class="item-thumbnail" />
- [% ELSE %]
- <img src="http://www.syndetics.com/index.aspx?isbn=[% OVERDUE.normalized_isbn %]/SC.GIF&client=[% SyndeticsClientCode %]&upc=[% OVERDUE.normalized_upc %]&oclc=[% OVERDUE.normalized_oclc %]&type=xw10" alt="" class="item-thumbnail" />
- [% END %]
+ <img src="https://secure.syndetics.com/index.aspx?isbn=[% OVERDUE.normalized_isbn | html %]/SC.GIF&client=[% SyndeticsClientCode | html %]&upc=[% OVERDUE.normalized_upc | html %]&oclc=[% OVERDUE.normalized_oclc | html %]&type=xw10" alt="" class="item-thumbnail" />
[% END %]
</td>
[% END # /IF jacketcell %]
<td>
- <a class="title" href="/cgi-bin/koha/opac-detail.pl?bib=[% OVERDUE.biblionumber %]">[% OVERDUE.title |html %] [% FOREACH subtitl IN OVERDUE.subtitle %] [% subtitl.subfield %][% END %]
+ <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 %]
</a>
- <span class="item-details">[% OVERDUE.author %]</span></td>
+ <span class="item-details">[% OVERDUE.author | html %]</span></td>
[% UNLESS ( item_level_itypes ) %]
<td>
[% IF ( OVERDUE.imageurl ) %]
- <img src="[% OVERDUE.imageurl %]" title="[% OVERDUE.description %]" alt="[% OVERDUE.description %]" />
- [% END %] [% OVERDUE.description %]
+ <img src="[% OVERDUE.imageurl | html %]" title="[% OVERDUE.description | html %]" alt="[% OVERDUE.description | html %]" />
+ [% END %] [% OVERDUE.description | html %]
</td>
[% END %]
[% IF ( show_barcode ) %]
<td>
<span class="tdlabel">Barcode:</span>
- [% OVERDUE.barcode %]
+ [% OVERDUE.barcode | html %]
</td>
[% END %]
<td>
- <span class="tdlabel">Call number:</span>
- [% OVERDUE.itemcallnumber %]
+ <span class="tdlabel">Call no.:</span>
+ [% OVERDUE.itemcallnumber | html %]
</td>
<td>
- <span title="[% OVERDUE.date_due %]">
+ <span title="[% OVERDUE.date_due | html %]">
<span class="tdlabel">Date due:</span>
- [% OVERDUE.date_due_sql | $KohaDates as_due_date => 1 %]
+ [% OVERDUE.date_due | $KohaDates as_due_date => 1 | html %]
</span>
</td>
[% IF ( OpacRenewalAllowed ) %]
Account frozen
[% ELSIF ( OVERDUE.status ) %]
[% IF ( canrenew ) %]
- <a href="/cgi-bin/koha/opac-renew.pl?from=opac_user&item=[% OVERDUE.itemnumber %]&bornum=[% OVERDUE.borrowernumber %]">Renew</a>
+ <a href="/cgi-bin/koha/opac-renew.pl?from=opac_user&item=[% OVERDUE.itemnumber | html %]&bornum=[% OVERDUE.borrowernumber | html %]">Renew</a>
[% END %]
- <span class="renewals">([% OVERDUE.renewsleft %] of [% OVERDUE.renewsallowed %] renewals remaining)</span>
+ <span class="renewals">([% OVERDUE.renewsleft | html %] of [% OVERDUE.renewsallowed | html %] renewals remaining)</span>
[% ELSIF ( OVERDUE.norenew_overdue ) %]
Not allowed<span class="renewals">(overdue)</span>
[% ELSIF ( OVERDUE.onreserve ) %]
[% END # /overdues_count %]
- [% IF ( reserves_count ) %]
+ [% IF ( RESERVES.count ) %]
<div id="opac-user-holds">
<table id="holdst" class="table table-bordered table-striped">
- <caption>Holds <span class="count">([% reserves_count %] total)</span></caption>
+ <caption>Holds <span class="count">([% RESERVES.count | html %] total)</span></caption>
<!-- RESERVES TABLE ROWS -->
<thead>
<tr>
<th class="anti-the">Title</th>
- <th class="psort">Placed on</th>
- <th>Expires on</th>
- <th>Pick up location</th>
[% IF ( showpriority ) %]
- <th>Priority</th>
+ <th class="title-string">Placed on</th>
+ [% ELSE %]
+ <th class="psort title-string">Placed on</th>
+ [% END %]
+ <th class="title-string">Expires on</th>
+ [% UNLESS( singleBranchMode) %]
+ <th>Pick up location</th>
+ [% END %]
+ [% IF ( showpriority ) %]
+ <th class="psort">Priority</th>
[% END %]
<th>Status</th>
[% IF SuspendHoldsOpac %]
<tr>
[% END %]
<td class="title">
- <a class="title" href="/cgi-bin/koha/opac-detail.pl?biblionumber=[% RESERVE.biblionumber %]">
- [% RESERVE.biblio.title %]
- [% FOREACH subtitl IN RESERVE.biblio.subtitle %]
- [% subtitl.subfield %]
+ <a class="title" href="/cgi-bin/koha/opac-detail.pl?biblionumber=[% RESERVE.biblionumber | html %]">
+ [% RESERVE.biblio.title | html %]
+ [% FOREACH s IN RESERVE.biblio.subtitles %]
+ [% s | html %]
[% END %]
- [% RESERVE.item.enumchron %]
+ [% RESERVE.item.enumchron | html %]
</a>
- [% RESERVE.biblio.author %]
+ [% RESERVE.biblio.author | html %]
</td>
<td class="reservedate">
- <span title="[% RESERVE.reservedate %]">
+ <span title="[% RESERVE.reservedate | html %]">
<span class="tdlabel">Hold date:</span>
[% RESERVE.reservedate | $KohaDates %]
</span>
<td class="expirationdate">
[% IF ! RESERVE.found %]
[% IF ( RESERVE.expirationdate ) %]
- <span>
+ <span title="[% RESERVE.expirationdate | html %]">
<span class="tdlabel">Expiration:</span>
[% RESERVE.expirationdate | $KohaDates %]
</span>
[% ELSE %]
- <span class="tdlabel">Expiration:</span>
- Never expires
+ <span title="0000-00-00">
+ <span class="tdlabel">Expiration:</span>
+ Never expires
+ </span>
[% END %]
[% ELSE %]
- -
+ <span title="0000-00-00">-</span>
[% END %]
</td>
- <td class="branch">
- <span class="tdlabel">Pick up location:</span>
- [% RESERVE.branch.branchname %]
- </td>
+ [% UNLESS( singleBranchMode) %]
+ <td class="branch">
+ <span class="tdlabel">Pick up location:</span>
+ [% RESERVE.branch.branchname | html %]
+ </td>
+ [% END %]
[% IF ( showpriority ) %]
- <td class="priority">
+ <td data-order="[% RESERVE.priority | html %]" class="priority">
<span class="tdlabel">Priority:</span>
- [% RESERVE.priority %]
+ [% RESERVE.priority | html %]
</td>
[% END %]
<td class="status">
[% IF ( RESERVE.is_waiting ) %]
[% IF ( RESERVE.is_at_destination ) %]
[% IF ( RESERVE.found ) %]
- Item waiting at <b> [% RESERVE.branch.branchname %]</b>
+ Item waiting at <b> [% RESERVE.branch.branchname | html %]</b>
[% IF ( RESERVE.waitingdate ) %]
since [% RESERVE.waitingdate | $KohaDates %]
- [% IF RESERVE.waiting_expires_on %]
- until [% RESERVE.waiting_expires_on | $KohaDates %]
+ [% IF RESERVE.expirationdate %]
+ until [% RESERVE.expirationdate | $KohaDates %]
[% END %]
[% END %]
- <input type="hidden" name="pickup" value="[% RESERVE.branchcode %]" />
+ <input type="hidden" name="pickup" value="[% RESERVE.branchcode | html %]" />
[% ELSE %]
- Item waiting to be pulled from <b> [% RESERVE.wbrname %]</b>
+ Item waiting to be pulled from <b> [% Branches.GetName( RESERVE.branchcode ) | html %]</b>
[% END %]
[% ELSE %]
- Item in transit to <b> [% RESERVE.wbrname %]</b> <input type="hidden" name="pickup" value="[% RESERVE.wbrcd %]" />
+ Item in transit to <b> [% Branches.GetName( RESERVE.branchcode ) | html %]</b> <input type="hidden" name="pickup" value="[% RESERVE.branchcode | html %]" />
[% END %]
[% ELSE %]
[% IF ( RESERVE.is_in_transit ) %]
- Item in transit from <b> [% RESERVE.frombranch %]</b> since
- [% RESERVE.datesent | $KohaDates %]
+ [% SET transfer = RESERVE.item.get_transfer %]
+ Item in transit from <b> [% Branches.GetName( transfer.frombranch ) | html %]</b> since
+ [% transfer.datesent | $KohaDates %]
[% ELSIF ( RESERVE.suspend ) %]
- Suspended [% IF ( RESERVE.suspend_until ) %] until [% RESERVE.suspend_until %] [% END %]
+ Suspended [% IF ( RESERVE.suspend_until ) %] until [% RESERVE.suspend_until | html %] [% END %]
[% ELSE %]
- Pending
+ [% IF RESERVE.itemtype %]
+ Pending for next available item of item type '[% ItemTypes.GetDescription( RESERVE.itemtype ) | html %]'
+ [% ELSE %]
+ Pending
+ [% END %]
[% END %]
[% END %]
</td>
[% IF SuspendHoldsOpac %]
<td>
- [% IF ( RESERVE.is_cancelable ) %]
+ [% IF ( RESERVE.is_cancelable_from_opac ) %]
[% IF RESERVE.suspend %]
<form class="form-inline" action="/cgi-bin/koha/opac-modrequest-suspend.pl" method="post">
- <input type="hidden" name="reserve_id" value="[% RESERVE.reserve_id %]" />
- <button class="btn btn-link" type="submit" name="submit"><i class="icon-play"></i> Resume</button>
+ <input type="hidden" name="reserve_id" value="[% RESERVE.reserve_id | html %]" />
+ <button class="btn btn-link" type="submit" name="submit"><i class="fa fa-play"></i> Resume</button>
</form>
[% ELSE %]
[% IF AutoResumeSuspendedHolds %]
- <a class="btn btn-link js-show" href="#suspendModal[% RESERVE.reserve_id %]" role="button" data-toggle="modal"><i class="icon-pause"></i> Suspend</a>
+ <a class="btn btn-link js-show" href="#suspendModal[% RESERVE.reserve_id | html %]" role="button" data-toggle="modal"><i class="fa fa-pause"></i> Suspend</a>
[% # hold suspend modal form %]
- <div id="suspendModal[% RESERVE.reserve_id %]" class="modal-nojs" tabindex="-1" role="dialog" aria-labelledby="suspendModal[% RESERVE.reserve_id %]Label" aria-hidden="true">
+ <div id="suspendModal[% RESERVE.reserve_id | html %]" class="modal-nojs" tabindex="-1" role="dialog" aria-labelledby="suspendModal[% RESERVE.reserve_id | html %]Label" aria-hidden="true">
<form class="form-inline" action="/cgi-bin/koha/opac-modrequest-suspend.pl" method="post">
<div class="modal-header">
<button type="button" class="closebtn" data-dismiss="modal" aria-hidden="true">×</button>
[% IF RESERVE.suspend %]
- <h3 id="suspendModal[% RESERVE.reserve_id %]Label">Resume your hold on <i>[% RESERVE.reserves_title %]</i></h3>
+ <h3 id="suspendModal[% RESERVE.reserve_id | html %]Label">Resume your hold on <i>[% RESERVE.biblio.title | html %]</i></h3>
[% ELSE %]
- <h3 id="suspendModal[% RESERVE.reserve_id %]Label">Suspend your hold on <i>[% RESERVE.reserves_title %]</i></h3>
+ <h3 id="suspendModal[% RESERVE.reserve_id | html %]Label">Suspend your hold on <i>[% RESERVE.biblio.title | html %]</i></h3>
[% END %]
</div>
<div class="modal-body">
- <input type="hidden" name="reserve_id" value="[% RESERVE.reserve_id %]" />
- <label for="suspend_until_[% RESERVE.reserve_id %]">Suspend until:</label>
- <input name="suspend_until" id="suspend_until_[% RESERVE.reserve_id %]" class="suspend-until" size="10" />
+ <input type="hidden" name="reserve_id" value="[% RESERVE.reserve_id | html %]" />
+ <label for="suspend_until_[% RESERVE.reserve_id | html %]">Suspend until:</label>
+ <input type="text" name="suspend_until" id="suspend_until_[% RESERVE.reserve_id | html %]" class="suspend-until" size="10" />
[% INCLUDE 'date-format.inc' %]
- <p class="js-show"><a href="#" onclick="document.getElementById('suspend_until_[% RESERVE.reserve_id %]').value='';return false;">Clear date to suspend indefinitely</a></p>
+ <p class="js-show"><a href="#" onclick="document.getElementById('suspend_until_[% RESERVE.reserve_id | html %]').value='';return false;">Clear date to suspend indefinitely</a></p>
<button class="btn btn-mini js-hide" type="submit" name="submit">Suspend</button>
</div>
<div class="modal-footer">
<a href="#" data-dismiss="modal" aria-hidden="true" class="cancel">Cancel</a>
</div>
</form>
- </div> <!-- /#suspendModal[% RESERVE.reserve_id %] -->
+ </div> <!-- /#suspendModal[% RESERVE.reserve_id | html %] -->
[% ELSE %]
<form class="form-inline" action="/cgi-bin/koha/opac-modrequest-suspend.pl" method="post">
- <input type="hidden" name="reserve_id" value="[% RESERVE.reserve_id %]" />
- <button class="btn btn-link" type="submit" name="submit"><i class="icon-pause"></i> Suspend</button>
+ <input type="hidden" name="reserve_id" value="[% RESERVE.reserve_id | html %]" />
+ <button class="btn btn-link" type="submit" name="submit"><i class="fa fa-pause"></i> Suspend</button>
</form>
[% END # / IF AutoResumeSuspendedHolds %]
[% END # / IF RESERVE.suspend %]
- [% END # / IF ( RESERVE.is_cancelable )%]
+ [% END # / IF ( RESERVE.is_cancelable_from_opac )%]
</td>
[% END # / IF SuspendHoldsOpac %]
<td class="modify">
- [% IF ( RESERVE.is_cancelable ) %]
+ [% IF ( RESERVE.is_cancelable_from_opac ) %]
<form action="/cgi-bin/koha/opac-modrequest.pl" method="post">
- <input type="hidden" name="biblionumber" value="[% RESERVE.biblionumber %]" />
- <input type="hidden" name="reserve_id" value="[% RESERVE.reserve_id %]" />
- <button type="submit" name="submit" class="btn btn-mini btn-danger" onclick="return confirmDelete(MSG_CONFIRM_DELETE_HOLD);"><i class="icon-remove icon-white"></i> Cancel</button></form>
+ <input type="hidden" name="biblionumber" value="[% RESERVE.biblionumber | html %]" />
+ <input type="hidden" name="reserve_id" value="[% RESERVE.reserve_id | html %]" />
+ <button type="submit" name="submit" class="btn btn-xs btn-danger" onclick="return confirmDelete(MSG_CONFIRM_DELETE_HOLD);"><i class="fa fa-remove"></i> Cancel</button></form>
[% END %]
</td>
</tr>
[% IF SuspendHoldsOpac %]
<div>
<form class="form-inline" action="/cgi-bin/koha/opac-modrequest-suspend.pl" method="post">
- <button type="submit" name="submit" class="btn" onclick="return confirmDelete(MSG_CONFIRM_SUSPEND_HOLDS);"><i class="icon-pause"></i> Suspend all holds</button>
+ <button type="submit" name="submit" class="btn" onclick="return confirmDelete(MSG_CONFIRM_SUSPEND_HOLDS);"><i class="fa fa-pause"></i> Suspend all holds</button>
<input type="hidden" name="suspend" value="1" />
[% IF AutoResumeSuspendedHolds %]
<label for="suspend_until"> until </label>
- <input name="suspend_until" id="suspend_until" class="suspend-until" readonly="readonly" size="10" />
+ <input type="text" name="suspend_until" id="suspend_until" class="suspend-until" readonly="readonly" size="10" />
<a href="#" style="font-size:85%;text-decoration:none;" onclick="document.getElementById('suspend_until').value='';return false;">Clear date to suspend indefinitely</a>
[% END %]
</form>
<br/>
<div>
<form action="/cgi-bin/koha/opac-modrequest-suspend.pl" method="post">
- <button type="submit" name="submit" class="btn" onclick="return confirmDelete(MSG_CONFIRM_RESUME_HOLDS);"><i class="icon-play"></i> Resume all suspended holds</button>
+ <button type="submit" name="submit" class="btn" onclick="return confirmDelete(MSG_CONFIRM_RESUME_HOLDS);"><i class="fa fa-play"></i> Resume all suspended holds</button>
<input type="hidden" name="suspend" value="0" />
</form>
</div>
[% END %]
</div> <!-- / #opac-user-holds -->
- [% END # / #reserves_count %]
+ [% END # / #RESERVES.count %]
+
+ [% IF Koha.Preference('ArticleRequests') %]
+ <div id="opac-user-article-requests">
+ [% IF logged_in_user.article_requests_current.count %]
+ <table id="article-requests-table" class="table table-bordered table-striped">
+ <caption>Article requests <span class="count">([% logged_in_user.article_requests_current.count | html %] total)</span></caption>
+ <thead>
+ <tr>
+ <th class="anti-the article-request-record-title">Record title</th>
+ <th class="psort article-request-created-on">Placed on</th>
+ <th class="anti-the article-request-title">Title</th>
+ <th class="article-request-author">Author</th>
+ <th class="article-request-volume">Volume</th>
+ <th class="article-request-issue">Issue</th>
+ <th class="article-request-date">Date</th>
+ <th class="article-request-pages">Pages</th>
+ <th class="article-request-chapters">Chapters</th>
+ <th class="article-request-patron-notes">Notes</th>
+ <th class="article-request-status">Status</th>
+ <th class="article-request-branchcode">Pickup library</th>
+ <th class="nosort article-request-cancel"> </th>
+ </tr>
+ </thead>
+
+ <tbody>
+ [% FOREACH ar IN logged_in_user.article_requests_current %]
+ <td class="article-request-record-title">
+ <a class="article-request-title" href="/cgi-bin/koha/opac-detail.pl?biblionumber=[% ar.biblionumber | html %]">
+ [% ar.biblio.title | html %]
+ [% ar.item.enumchron | html %]
+ </a>
+ [% ar.biblio.author | html %]
+ [% IF ar.itemnumber %] <i>(only [% ar.item.barcode | html %])</i>[% END %]
+ </td>
+
+ <td class="article-request-created_on">
+ [% ar.created_on | $KohaDates %]
+ </td>
+
+ <td class="article-request-title">
+ [% ar.title | html %]
+ </td>
+
+ <td class="article-request-author">
+ [% ar.author | html %]
+ </td>
+
+ <td class="article-request-volume">
+ [% ar.volume | html %]
+ </td>
+
+ <td class="article-request-issue">
+ [% ar.issue | html %]
+ </td>
+
+ <td class="article-request-date">
+ [% ar.date | html %]
+ </td>
+
+ <td class="article-request-pages">
+ [% ar.pages | html %]
+ </td>
+
+ <td class="article-request-chapters">
+ [% ar.chapters | html %]
+ </td>
+
+ <td class="article-request-patron-notes">
+ [% ar.patron_notes | html %]
+ </td>
+
+ <td class="article-request-status">
+ [% IF ar.status == 'PENDING' %]
+ Pending
+ [% ELSIF ar.status == 'PROCESSING' %]
+ Processing
+ [% ELSIF ar.status == 'COMPLETED' %]
+ Completed
+ [% ELSIF ar.status == 'CANCELED' %]
+ Canceled
+ [% END %]
+ </td>
+
+ <td class="article-request-branchcode">
+ [% ar.branch.branchname | html %]
+ </td>
+
+ <td class="article-request-cancel">
+ <span class="tdlabel">Cancel:</span>
+ <a class="btn btn-xs btn-danger" href="opac-article-request-cancel.pl?id=[% ar.id | html %]" onclick="return confirmDelete(MSG_CONFIRM_DELETE_ARTREQ);"><i class="fa fa-remove"></i> Cancel</a>
+ </td>
+ </tr>
+ [% END %]
+ </tbody>
+ </table>
+ [% ELSE %]
+ <table class="table table-bordered table-striped">
+ <tr><td>You have no article requests currently.</td></tr>
+ </table>
+ [% END # IF article_requests_current.count %]
+ </div> <!-- / #opac-user-article-requests -->
+ [% END %]
+
</div> <!-- /#opac-user-views -->
</div> <!-- /#userdetails -->
</div> <!-- /.span10 -->
</div> <!-- /.container-fluid -->
</div> <!-- /#main -->
+[% IF ( OverDriveCirculation ) %]
+[% INCLUDE 'overdrive-checkout.inc' %]
+[% END %]
+[% IF ( RecordedBooksCirculation ) %]
+[% INCLUDE 'recordedbooks-checkout.inc' %]
+[% END %]
+
[% INCLUDE 'opac-bottom.inc' %]
[% BLOCK jsinclude %]
[% INCLUDE 'calendar.inc' %]
[% INCLUDE 'datatables.inc' %]
- <script type="text/JavaScript">
+ <script>
//<![CDATA[
+ var MSG_CONFIRM_DELETE_ARTREQ = _("Are you sure you want to cancel this article request?");
var MSG_CONFIRM_DELETE_HOLD = _("Are you sure you want to cancel this hold?");
var MSG_CONFIRM_SUSPEND_HOLDS = _("Are you sure you want to suspend all holds?");
var MSG_CONFIRM_RESUME_HOLDS = _("Are you sure you want to resume all suspended holds?");
$(".js-hide").hide();
$(".modal-nojs").addClass("modal").addClass("hide").removeClass("modal-nojs");
$(".suspend-until").prop("readonly",1);
- var dTables = $("#checkoutst,#holdst,#overduest");
+
+ var dTables = $("#checkoutst,#holdst,#overduest,#opac-user-relative-issues-table");
dTables.each(function(){
var thIndex = $(this).find("th.psort").index();
$(this).dataTable($.extend(true, {}, dataTablesDefaults, {
- "aaSorting" : [[ thIndex, 'asc' ]],
- "aoColumnDefs": [
- { "aTargets": [ "nosort" ],"bSortable": false,"bSearchable": false },
- { "sType": "anti-the", "aTargets" : [ "anti-the" ] },
- { "sType": "title-string", "aTargets" : [ "title-string" ] }
+ "sorting" : [[ thIndex, 'asc' ]],
+ "columnDefs": [
+ { "targets": [ "nosort" ],"sortable": false,"searchable": false },
+ { "type": "anti-the", "targets" : [ "anti-the" ] },
+ { "type": "title-string", "targets" : [ "title-string" ] }
]
}));
});
e.preventDefault();
$("#renewall").submit();
});
- [% IF ( canrenew && !userdebarred && OpacRenewalAllowed && !( borrower.is_expired && borrower.BlockExpiredPatronOpacActions ) ) %]
+ [% IF ( canrenew && !userdebarred && OpacRenewalAllowed && !( logged_in_user.is_expired && logged_in_user.category.effective_BlockExpiredPatronOpacActions ) ) %]
$("#checkoutst caption").append("<div id=\"renewcontrols\"><a id=\"renewselected_link\" href=\"#\">"+_("Renew selected")+"</a> <a id=\"renewall_link\" href=\"#\">"+_("Renew all")+"</a></div>");
[% END %]
[% END %]
+ [% IF ( Koha.Preference('AllowCheckoutNotes') ) %]
+
+ /* If JS enabled, show button, otherwise show link to redirect to a page where note can be submitted */
+ $("a[name='nonjs_submitnote']").hide();
+
+ $("input[name='note']").prop('readonly', false);
+ $("input[name='note']").keypress(function(e){
+ /* prevent submitting of renewselected form */
+ if(e.which == 13)
+ e.preventDefault();
+ });
+
+ $("input[name='note']").keyup(function(e){
+ var $btn_save = $('#save_'+$(this).data('issue_id'));
+ var origvalue = $(this).data('origvalue');
+ var value = $(this).val();
+
+ if(origvalue != value) {
+ if(origvalue != "")
+ $btn_save.text(_("Submit changes"));
+ else
+ $btn_save.text(_("Submit note"));
+ $btn_save.show();
+ } else {
+ $btn_save.hide();
+ }
+ });
+
+ $("a[name='js_submitnote']").click(function(e){
+ var $self = $(this);
+ var title = $(this).parent().siblings('.title').html();
+ var $noteinput = $(this).siblings('input[name="note"]').first();
+
+ var ajaxData = {
+ 'action': 'issuenote',
+ 'issue_id': $noteinput.data('issue_id'),
+ 'note': $noteinput.val(),
+ };
+
+ $.ajax({
+ url: '/cgi-bin/koha/svc/checkout_notes/',
+ type: 'POST',
+ dataType: 'json',
+ data: ajaxData,
+ })
+ .done(function(data) {
+ var message = "";
+ if(data.status == 'saved') {
+ $("#notesaved").removeClass("alert-error");
+ $("#notesaved").addClass("alert-info");
+ $noteinput.data('origvalue', data.note);
+ $noteinput.val(data.note);
+ message = "<p>" + _("Your note about %s has been saved and sent to the library.").format(title) + "</p>";
+ message += "<p style=\"font-style:italic;\">" + data.note + "</p>";
+ $self.hide();
+ } else if(data.status == 'removed') {
+ $("#notesaved").removeClass("alert-error");
+ $("#notesaved").addClass("alert-info");
+ $noteinput.data('origvalue', "");
+ $noteinput.val("");
+ message = "<p>" + _("Your note about %s was removed.").format(title) + "</p>";
+ $self.hide();
+ } else {
+ $("#notesaved").removeClass("alert-info");
+ $("#notesaved").addClass("alert-error");
+ message = "<p>" + _("Your note about %s could not be saved.").format(title) + "</p>";
+ message += "<p style=\"font-weight:bold;\">" + _("Something went wrong. The note has not been saved") + "</p>";
+ }
+ $("#notesaved").html(message);
+ })
+ .fail(function(data) {
+ $("#notesaved").removeClass("alert-info");
+ $("#notesaved").addClass("alert-error");
+ var message = "<p style=\"font-weight:bold;\">" + _("Something went wrong. The note has not been saved") + "</p>";
+ $("#notesaved").html(message);
+ })
+ .always(function() {
+ $("#notesaved").show();
+ });
+ });
+ [% END %]
+
$( ".suspend-until" ).datepicker({ minDate: 1 }); // Require that "until date" be in the future
+
+ if ( $('#opac-user-clubs').length ) {
+ $('#opac-user-clubs-tab-link').on('click', function() {
+ $('#opac-user-clubs').text(_("Loading..."));
+ $('#opac-user-clubs').load('/cgi-bin/koha/clubs/clubs-tab.pl?borrowernumber=[% borrowernumber | html %]');
+ });
+ }
});
//]]>
</script>
+ [% IF Koha.Preference('OverDriveCirculation') %]
+ [% Asset.js("js/overdrive.js") | $raw %]
+ <script>
+ var OD_password_required = [% IF Koha.Preference('OverDrivePasswordRequired') %]1[% ELSE %]0[% END %];
+ $(document).ready(function() {
+ [% IF ( overdrive_error ) %]
+ KOHA.OverDriveCirculation.display_error("#opac-user-overdrive", "[% overdrive_error.dquote | html %]");
+ [% END %]
+
+ [% IF ( overdrive_tab ) %]
+ $("#opac-user-views").tabs("select", "#opac-user-overdrive");
+ [% END %]
+
+ $("#opac-user-overdrive").each( function() {
+ KOHA.OverDriveCirculation.display_account_details(this);
+ } );
+ });
+ </script>
+ [% END %]
+ [% IF RecordedBooksCirculation %]
+ [% Asset.js("js/recordedbooks.js") | $raw %]
+ <script type="text/JavaScript">
+ $(document).ready(function() {
+ [% IF ( recordedbooks_error ) %]
+ KOHA.RecordedBooks.display_error("#opac-user-recordedbooks", "[% recordedbooks_error.dquote | html %]");
+ [% END %]
+ [% IF ( recordedbooks_tab ) %]
+ $("#opac-user-views").tabs("select", "#opac-user-recordedbooks");
+ [% END %]
+ $("#opac-user-recordedbooks").each( function() {
+ KOHA.RecordedBooks.display_account_details(this);
+ } );
+ });
+ </script>
+ [% END %]
[% END %]