Jonathan Druart
1d0d5f1398
There are certainly hundred of places where they are not escaped... Test plan: Create a patron with "Arun <script>alert('code injection');</script>" in some of the fields. Signed-off-by: Chris Cormack <chris@bigballofwax.co.nz> Signed-off-by: Katrin Fischer <katrin.fischer@bsz-bw.de> Signed-off-by: Brendan Gallagher <brendan@bywatersolutions.com>
589 lines
24 KiB
Text
589 lines
24 KiB
Text
[% USE Koha %]
|
|
[% USE Branches %]
|
|
[% USE KohaDates %]
|
|
[% USE AuthorisedValues %]
|
|
[% USE ColumnsSettings %]
|
|
[% IF Koha.Preference('ExportRemoveFields') OR Koha.Preference('ExportWithCsvProfile') %]
|
|
[% SET exports_enabled = 1 %]
|
|
[% END %]
|
|
[% INCLUDE 'doc-head-open.inc' %]
|
|
<title>Koha › Patrons ›
|
|
[% IF ( unknowuser ) %]
|
|
Patron does not exist
|
|
[% ELSE %]
|
|
Patron details for [% INCLUDE 'patron-title.inc' %]
|
|
[% END %]
|
|
</title>
|
|
[% INCLUDE 'doc-head-close.inc' %]
|
|
[% INCLUDE 'calendar.inc' %]
|
|
<link rel="stylesheet" type="text/css" href="[% interface %]/[% theme %]/css/datatables.css" />
|
|
[% INCLUDE 'datatables.inc' %]
|
|
[% INCLUDE 'columns_settings.inc' %]
|
|
[% INCLUDE 'strings.inc' %]
|
|
<script type="text/javascript" src="[% interface %]/lib/jquery/plugins/jquery.checkboxes.min.js"></script>
|
|
<script type="text/javascript" src="[% interface %]/lib/jquery/plugins/jquery-ui-timepicker-addon.min.js"></script>
|
|
[% INCLUDE 'timepicker.inc' %]
|
|
<script type="text/javascript" src="[% interface %]/lib/jquery/plugins/jquery.dataTables.rowGrouping.js"></script>
|
|
<script type="text/javascript" src="[% interface %]/[% theme %]/js/pages/circulation.js"></script>
|
|
<script type="text/javascript" src="[% interface %]/[% theme %]/js/checkouts.js"></script>
|
|
<script type="text/javascript" src="[% interface %]/[% theme %]/js/holds.js"></script>
|
|
<script type="text/JavaScript">
|
|
//<![CDATA[
|
|
/* Set some variable needed in circulation.js */
|
|
var interface = "[% interface %]";
|
|
var theme = "[% theme %]";
|
|
var borrowernumber = "[% borrowernumber %]";
|
|
var branchcode = "[% Branches.GetLoggedInBranchcode() %]";
|
|
var exports_enabled = "[% exports_enabled %]";
|
|
var AllowCirculate = [% (CAN_user_circulate_circulate_remaining_permissions)? 1 : 0 %]
|
|
var AllowRenewalLimitOverride = [% (CAN_user_circulate_override_renewals && Koha.Preference('AllowRenewalLimitOverride') )? 1: 0 %];
|
|
var script = "moremember";
|
|
var relatives_borrowernumbers = new Array();
|
|
[% FOREACH b IN relatives_borrowernumbers %]
|
|
relatives_borrowernumbers.push("[% b %]");
|
|
[% END %]
|
|
|
|
var MSG_EXPORT_SELECT_CHECKOUTS = _("You must select checkout(s) to export");
|
|
|
|
columns_settings = [% ColumnsSettings.GetColumns( 'members', 'moremember', 'issues-table', 'json' ) %]
|
|
|
|
$(document).ready(function() {
|
|
$('#finesholdsissues').tabs({
|
|
// Correct table sizing for tables hidden in tabs
|
|
// http://www.datatables.net/examples/api/tabs_and_scrolling.html
|
|
"show": function(event, ui) {
|
|
var oTable = $('div.dataTables_wrapper>table', ui.panel).dataTable();
|
|
if ( oTable.length > 0 ) {
|
|
oTable.fnAdjustColumnSizing();
|
|
}
|
|
},
|
|
"activate": function( event, ui ) {
|
|
$('#'+ui.newTab.context.id).click();
|
|
}
|
|
} );
|
|
$("#holdst").dataTable($.extend(true, {}, dataTablesDefaults, {
|
|
"sDom": 't',
|
|
"aoColumnDefs": [
|
|
{ "aTargets": [ -1,-2 ], "bSortable": false, "bSearchable": false }
|
|
],
|
|
"aoColumns": [
|
|
{ "sType": "title-string" },{ "sType": "anti-the" },null,null,null,null,null,null
|
|
],
|
|
"bPaginate": false
|
|
}));
|
|
[% IF ( picture ) %]
|
|
// new YAHOO.widget.Button("delpicture"); // FIXME: formatting mismatch between YUI and normal button
|
|
$('#delpicture').click(function(){
|
|
return confirm(_("Are you sure you want to delete this patron image? This cannot be undone."));
|
|
});
|
|
$('#manage-patron-image').find("input[value*=Upload]").click(function(){
|
|
if($("#uploadfile").val() == ""){
|
|
alert(_("Please choose a file to upload"));
|
|
return false;
|
|
}
|
|
return confirm(_("Are you sure you want to replace the current patron image? This cannot be undone."));
|
|
});[% END %]
|
|
|
|
$("#suspend_until").datepicker({
|
|
onClose: function(dateText, inst) {
|
|
validate_date(dateText, inst);
|
|
},
|
|
minDate: 1, // require that hold suspended until date is after today
|
|
}).on("change", function(e, value) {
|
|
if ( ! is_valid_date( $(this).val() ) ) {$(this).val("");}
|
|
});
|
|
|
|
$("#view_restrictions").on("click",function(){
|
|
$('#debarments-tab-link').click();
|
|
});
|
|
});
|
|
function uncheck_sibling(me){
|
|
nodename=me.getAttribute("name");
|
|
if (nodename =="barcodes[]"){
|
|
var Node=me.parentNode.previousSibling;
|
|
while (Node.nodeName!="TD"){Node=Node.previousSibling}
|
|
var Nodes=Node.childNodes;
|
|
for (var i=0;i < Nodes.length;i++){
|
|
if (Nodes[i].nodeName=="INPUT" && Nodes[i].getAttribute("type")=="checkbox"){
|
|
Nodes[i].checked=false;
|
|
}
|
|
}
|
|
|
|
}else {
|
|
var Node=me.parentNode.nextSibling;
|
|
while (Node.nodeName!="TD"){Node=Node.nextSibling}
|
|
var Nodes=Node.childNodes;
|
|
for (var i=0;i<Nodes.length;i++){
|
|
if (Nodes[i].nodeName=="INPUT" && Nodes[i].getAttribute("type")=="checkbox"){
|
|
Nodes[i].checked=false;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
function validate1(date) {
|
|
var today = new Date();
|
|
if ( date < today ) {
|
|
return true;
|
|
} else {
|
|
return false;
|
|
}
|
|
};
|
|
//]]>
|
|
</script>
|
|
|
|
</head>
|
|
<body id="pat_moremember" class="pat">
|
|
[% INCLUDE 'header.inc' %]
|
|
[% INCLUDE 'patron-search.inc' %]
|
|
|
|
<div id="breadcrumbs">
|
|
<a href="/cgi-bin/koha/mainpage.pl">Home</a>
|
|
› <a href="/cgi-bin/koha/members/members-home.pl">Patrons</a>
|
|
› [% IF ( unknowuser ) %]Patron does not exist[% ELSE %]Patron details for [% INCLUDE 'patron-title.inc' %][% END %]
|
|
</div>
|
|
|
|
<div id="doc3" class="yui-t2">
|
|
|
|
<div id="bd">
|
|
<div id="yui-main">
|
|
<div class="yui-b">
|
|
|
|
[% UNLESS ( unknowuser ) %]
|
|
[% INCLUDE 'members-toolbar.inc' %]
|
|
[% END %]
|
|
|
|
[% IF ( error ) %]
|
|
<div class="dialog alert">
|
|
[% IF ( error == 'CANT_DELETE_STAFF' ) %]
|
|
<h3>Unable to delete staff user</h3>
|
|
<p>Insufficient privileges.</p>
|
|
[% END %]
|
|
[% IF ( error == 'CANT_DELETE_YOURSELF' ) %]
|
|
<h3>Not allowed to delete own account</h3>
|
|
<p>Deleting your own account would lock you out of Koha.</p>
|
|
[% END %]
|
|
[% IF ( error == 'CANT_DELETE_OTHERLIBRARY' ) %]
|
|
<h3>Unable to delete patrons from other libraries with current settings</h3>
|
|
<p>Insufficient privileges.</p>
|
|
[% END %]
|
|
[% IF ( error == 'CANT_DELETE' ) %]
|
|
<h3>Unable to delete patron</h3>
|
|
<p>Insufficient privileges.</p>
|
|
[% END %]
|
|
</div>
|
|
[% END %]
|
|
<div class="yui-g">
|
|
|
|
[% IF ( unknowuser ) %]
|
|
<div class="dialog message">This patron does not exist. <a href="/cgi-bin/koha/members/members-home.pl">Find another patron?</a></div>
|
|
[% ELSE %]
|
|
[% IF ( was_renewed ) %]<div class="dialog message">Patron's account has been renewed until [% dateexpiry | $KohaDates %]</div>[% END %]
|
|
|
|
[% IF fines %]
|
|
[% INCLUDE 'blocked-fines.inc' %]
|
|
[% END %]
|
|
|
|
[% IF ( flagged ) %]
|
|
<div id="circmessages" class="circmessage attention">
|
|
<ul>
|
|
[% IF ( userdebarred ) %]
|
|
<li class="blocker">Patron's account is restricted
|
|
[% IF ( userdebarreddate ) %]
|
|
until [% userdebarreddate %]
|
|
[% END %]
|
|
|
|
[% IF ( debarredcomment ) %]
|
|
with the explanation: <i>
|
|
[% IF debarredcomment.search('OVERDUES_PROCESS') %]
|
|
Restriction added by overdues process [% debarredcomment.remove('OVERDUES_PROCESS ') | html_line_break %]
|
|
[% ELSE %]
|
|
[% debarredcomment | html_line_break %]
|
|
[% END %]
|
|
</i>
|
|
[% END %]
|
|
<a href="#reldebarments" id="view_restrictions">View restrictions</a>
|
|
</li>
|
|
[% END %]
|
|
[% IF ( gonenoaddress ) %]<li class="blocker">Patron's address is in doubt.</li>[% END %]
|
|
[% IF ( lost ) %]<li class="blocker">Patron's card has been reported lost.</li>[% END %]
|
|
</ul>
|
|
</div>
|
|
[% END %]
|
|
|
|
<h3>[% UNLESS ( I ) %]
|
|
[% title | html %] [% firstname | html %] [% END %] [% surname | html %] ([% cardnumber | html %])</h3>
|
|
<div class="yui-u first">
|
|
<div id="patron-information" style="padding : .5em;">
|
|
|
|
[% UNLESS ( I ) %][% IF ( othernames ) %]“[% othernames | html %]”[% END %]
|
|
|
|
<div class = "address">
|
|
[% IF Koha.Preference( 'AddressFormat' ) %]
|
|
[% INCLUDE "member-display-address-style-${ Koha.Preference( 'AddressFormat' ) }.inc" %]
|
|
[% ELSE %]
|
|
[% INCLUDE 'member-display-address-style-us.inc' %]
|
|
[% END %]
|
|
</div>
|
|
|
|
<div class="rows">
|
|
<ol>
|
|
[% IF ( I ) %]
|
|
[% IF ( phonepro ) %]<li><span class="label">Organization phone: </span><a href="tel:[% phonepro %]">[% phonepro | html %]</a></li>[% END %]
|
|
[% IF ( emailpro ) %]<li class="email"><span class="label">Organization email: </span>[% emailpro | html %]</li>[% END %]
|
|
[% ELSE %]
|
|
[% IF ( phone ) %]<li><span class="label">Primary phone: </span><a href="tel:[% phone %]">[% phone | html %]</a></li>[% END %]
|
|
[% IF ( phonepro ) %]<li><span class="label">Secondary phone: </span><a href="tel:[% phonepro %]">[% phonepro | html %]</a></li>[% END %]
|
|
[% IF ( mobile ) %]<li><span class="label">Other phone: </span><a href="tel:[% mobile %]">[% mobile | html %]</a></li>[% END %]
|
|
[% END %]
|
|
|
|
[% IF ( P ) %]
|
|
[% IF ( phone ) %]<li><span class="label">Primary phone: </span><a href="tel:[% phone %]">[% phone | html %]</a></li>[% END %]
|
|
[% IF ( mobile ) %]<li><span class="label">Other phone: </span><a href="tel:[% mobile %]">[% mobile | html %]</a></li>[% END %]
|
|
[% END %]
|
|
[% IF ( fax ) %]<li><span class="label">Fax: </span>[% fax %]</li>[% END %]
|
|
[% UNLESS ( I ) %]
|
|
[% IF ( email ) %]<li class="email"><span class="label">Primary email:</span><a title="[% email %]" href="mailto:[% email | url %]">[% email | html %]</a></li>[% END %]
|
|
[% IF ( emailpro ) %]<li class="email"><span class="label">Secondary email: </span><a title="[% emailpro %]" href="mailto:[% emailpro | url %]">[% emailpro | html %]</a></li>[% END %]
|
|
[% END %]
|
|
[% IF ( initials ) %]<li><span class="label">Initials: </span>[% initials %]</li>[% END %]
|
|
[% IF ( dateofbirth ) %]<li><span class="label">Date of birth:</span>[% dateofbirth | $KohaDates %] ([% age %] years)</li>[% END %]
|
|
[% IF ( sex ) %]<li><span class="label">Gender:</span>
|
|
[% IF ( sex == 'F' ) %]Female[% ELSIF ( sex == 'M' ) %]Male[% ELSE %][% sex %][% END %]
|
|
</li>[% END %][% END %]
|
|
[% IF guarantees %]
|
|
<li>
|
|
<span class="label">Guarantees:</span>
|
|
<ul>
|
|
[% FOREACH guarantee IN guarantees %]
|
|
<li><a href="/cgi-bin/koha/members/moremember.pl?borrowernumber=[% guarantee.borrowernumber %]">[% guarantee.firstname | html %] [% guarantee.surname | html %]</a></li>
|
|
[% END %]
|
|
</ul>
|
|
</li>
|
|
[% ELSIF guarantor %]
|
|
<li>
|
|
<span class="label">Guarantor:</span>
|
|
[% IF guarantor.borrowernumber %]
|
|
<a href="/cgi-bin/koha/members/moremember.pl?borrowernumber=[% guarantor.borrowernumber %]">[% guarantor.firstname | html %] [% guarantor.surname | html %]</a>
|
|
[% ELSE %]
|
|
[% guarantor.firstname | html %] [% guarantor.surname | html %]
|
|
[% END %]
|
|
</li>
|
|
[% END %]
|
|
</ol>
|
|
</div>
|
|
<div class="action">
|
|
[% IF ( guarantor.borrowernumber ) %]
|
|
<a href="memberentry.pl?op=modify&borrowernumber=[% borrowernumber %]&step=1&guarantorid=[% guarantor.borrowernumber %]">Edit</a>
|
|
[% ELSE %]
|
|
<a href="memberentry.pl?op=modify&borrowernumber=[% borrowernumber %]&step=1">Edit</a>
|
|
[% END %]</div>
|
|
|
|
</div>
|
|
|
|
<!-- Begin Upload Patron Image Section -->
|
|
|
|
<div id="manage-patron-image">
|
|
[% IF ( patronimages ) %]
|
|
[% IF ( CAN_user_tools_batch_upload_patron_images ) %]
|
|
<form method="post" action="/cgi-bin/koha/tools/picture-upload.pl" enctype="multipart/form-data">
|
|
<fieldset class="brief">
|
|
[% IF ( picture ) %]
|
|
<legend>Manage patron image</legend>
|
|
<div class="hint">To update the image for [% title | html %] [% surname | html %], select a new image file and click 'Upload.' <br />Click the 'Delete' button to remove the current image.
|
|
[% ELSE %]
|
|
<legend>Upload patron image</legend>
|
|
<div class="hint">[% title %] [% firstname | html %] [% surname | html %] does not currently have an image available. To import an image for [% title %] [% surname | html %], enter the name of an image file to upload.
|
|
[% END %]
|
|
<br />Only PNG, GIF, JPEG, XPM formats are supported.
|
|
</div>
|
|
<input type="hidden" id="image" name="filetype" value="image" />
|
|
<input type="hidden" id="cardnumber" name="cardnumber" value="[% cardnumber | html %]" />
|
|
<input type="hidden" name="borrowernumber" value="[% borrowernumber %]" />
|
|
<ol>
|
|
<li>
|
|
<label for="uploadfile">Select the file to upload: </label><input type="file" id="uploadfile" name="uploadfile" />
|
|
</li>
|
|
</ol>
|
|
<fieldset class="action">
|
|
<input type="hidden" name="csrf_token" value="[% csrf_token %]" />
|
|
<input type="submit" value="Upload" class="submit" />
|
|
<input name="op" type="hidden" value="Upload" />
|
|
[% IF ( picture ) %]<a id="delpicture" href="/cgi-bin/koha/tools/picture-upload.pl?op=Delete&borrowernumber=[% borrowernumber %]&csrf_token=[% csrf_token %]" class="delete">Delete</a>[% END %]
|
|
</fieldset>
|
|
</fieldset>
|
|
</form>
|
|
[% END %]
|
|
[% END %]
|
|
</div>
|
|
|
|
<!-- End Upload Patron Image Section -->
|
|
|
|
[% IF ( ExtendedPatronAttributes ) %]
|
|
[% UNLESS ( no_patron_attribute_types ) %]
|
|
<div id="patron-extended-attributes" style="padding-top: 1em;">
|
|
<h3>Additional attributes and identifiers</h3>
|
|
[% FOREACH attribute IN attributes_loop %]
|
|
[% IF attribute.class %]
|
|
<div id="aai_[% attribute.class %]" class="rows">
|
|
[% ELSE %]
|
|
<div id="aai" class="rows">
|
|
[% END %]
|
|
<h4>[% attribute.lib %]</h4>
|
|
<ol>
|
|
[% FOREACH item IN attribute.items %]
|
|
<li>
|
|
<span class="label">[% item.description %]: </span>
|
|
[% IF ( item.value_description ) %]
|
|
[% item.value_description %]
|
|
[% ELSE %]
|
|
[% item.value| html_line_break %]
|
|
[% END %]
|
|
</li>
|
|
[% END %]
|
|
</ol>
|
|
</div>
|
|
[% END %]
|
|
</div>
|
|
<div class="action"><a href="memberentry.pl?op=modify&borrowernumber=[% borrowernumber %]&step=4">Edit</a></div>
|
|
[% END %]
|
|
[% END %]
|
|
|
|
[% IF ( EnhancedMessagingPreferences ) %]
|
|
<div id="patron-messaging-prefs" style="padding-top: 1em;">
|
|
<h3>Patron messaging preferences</h3>
|
|
[% INCLUDE 'messaging-preference-form.inc' %]
|
|
[% IF ( SMSSendDriver ) %]
|
|
<div class="rows"> <ol><li><span class="label">SMS number:</span><a href="sms:[% SMSnumber %]">[% SMSnumber %]</a>
|
|
</li></ol></div>
|
|
[% END %]
|
|
</div>
|
|
<div class="action"><a href="memberentry.pl?op=modify&borrowernumber=[% borrowernumber %]&step=5">Edit</a></div>
|
|
[% END %]
|
|
|
|
</div>
|
|
<div class="yui-u">
|
|
<div id="patron-library-details">
|
|
<h3>Library use</h3>
|
|
<div class="rows">
|
|
<ol>
|
|
<li><span class="label">Card number: </span>[% cardnumber %]</li>
|
|
<li><span class="label">Borrowernumber: </span> [% borrowernumber %]</li>
|
|
<li><span class="label">Category: </span>[% description %] ([% categorycode %])</li>
|
|
<li><span class="label">Registration date: </span>[% dateenrolled | $KohaDates %]</li>
|
|
|
|
<li><span class="label">Expiration date: </span>
|
|
[% IF ( was_renewed ) %]
|
|
<strong class="reregistrinfo">[% dateexpiry | $KohaDates %]</strong>
|
|
[% ELSE %]
|
|
[% dateexpiry | $KohaDates %]
|
|
[% END %]
|
|
</li>
|
|
|
|
<li><span class="label">Library: </span>[% branchname %]</li>
|
|
|
|
[% IF ( OPACPrivacy ) %]<li><span class="label">Privacy Pref:</span>
|
|
[% IF ( privacy0 ) %]Forever[% END %]
|
|
[% IF ( privacy1 ) %]Default[% END %]
|
|
[% IF ( privacy2 ) %]Never[% END %]
|
|
</li>[% END %]
|
|
|
|
<li>
|
|
<span class="label">Show checkouts to guarantor</span>
|
|
[% IF privacy_guarantor_checkouts %]
|
|
Yes
|
|
[% ELSE %]
|
|
No
|
|
[% END %]
|
|
</li>
|
|
|
|
[% IF ( sort1 ) %]<li><span class="label">Sort field 1:</span>[% AuthorisedValues.GetByCode('Bsort1', sort1) %]</li>[% END %]
|
|
[% IF ( sort2 ) %]<li><span class="label">Sort field 2:</span>[% AuthorisedValues.GetByCode('Bsort2', sort2) %]</li>[% END %]
|
|
<li><span class="label">Username: </span>[% userid %]</li>
|
|
<li><span class="label">Password: </span>
|
|
[% IF ( password ) %]
|
|
*******
|
|
[% ELSE %]
|
|
<span class="problem"><a href="/cgi-bin/koha/members/member-password.pl?member=[% borrowernumber %]">Undefined</a></span>
|
|
[% END %]
|
|
</li>
|
|
[% IF ( borrowernotes ) %]<li><span class="label">Circulation note: </span>[% borrowernotes %]</li>[% END %]
|
|
[% IF ( opacnote ) %]<li><span class="label">OPAC note:</span>[% opacnote %]</li>[% END %]
|
|
[% IF Koha.Preference( 'NorwegianPatronDBEnable' ) == 1 %]
|
|
[% IF ( sync == 1 ) %]
|
|
<li><span class="label">Activate sync: </span>Yes</li>
|
|
[% IF ( syncstatus ) %]<li><span class="label">Sync status: </span>[% syncstatus %]</li>[% END %]
|
|
[% IF ( lastsync ) %]<li><span class="label">Last sync: </span>[% lastsync | $KohaDates %]</li>[% END %]
|
|
[% ELSE %]
|
|
<li><span class="label">Activate sync: </span>No</li>
|
|
[% END %]
|
|
[% END %]
|
|
[% IF ( Koha.Preference('CheckPrevCheckout') == 'softyes' || Koha.Preference('CheckPrevCheckout') == 'softno' ) %]
|
|
<li><span class="label">Check previous checkouts: </span>
|
|
[% IF ( checkprevcheckout == 'yes' ) %]
|
|
Yes
|
|
[% ELSIF ( checkprevcheckout == 'no' ) %]
|
|
No
|
|
[% ELSE %]
|
|
Inherited
|
|
[% END %]
|
|
</li>
|
|
[% END %]
|
|
</ol>
|
|
</div>
|
|
</div>
|
|
<div class="action"><a href="memberentry.pl?op=modify&borrowernumber=[% borrowernumber %]&step=3">Edit</a></div>
|
|
|
|
[% UNLESS ( I ) %]
|
|
<div id="patron-alternate-address" style="padding-top: 1em;">
|
|
<h3>Alternate address</h3>
|
|
|
|
[% IF Koha.Preference( 'AddressFormat' ) %]
|
|
[% INCLUDE "member-display-alt-address-style-${ Koha.Preference( 'AddressFormat' ) }.inc" %]
|
|
[% ELSE %]
|
|
[% INCLUDE 'member-display-alt-address-style-us.inc' %]
|
|
[% END %]
|
|
|
|
<div class="rows"> <ol>
|
|
[% IF ( B_phone ) %]<li><span class="label">Phone: </span><a href="tel:[% B_phone %]">[% B_phone %]</a></li>[% END %]
|
|
[% IF ( B_email ) %]<li class="email"><span class="label">Email: </span><a title="[% B_email %]" href="mailto:[% B_email %]">[% B_email %]</a></li>[% END %]
|
|
[% IF ( contactnote ) %]<li><span class="label">Contact note: </span> [% contactnote %]</li>[% END %]
|
|
</ol>
|
|
</div>
|
|
</div>
|
|
<div class="action"><a href="memberentry.pl?op=modify&borrowernumber=[% borrowernumber %]&step=6">Edit</a></div>
|
|
[% END %]
|
|
|
|
<div id="patron-alternative-contact" style="padding-top: 1em;">
|
|
<h3>Alternative contact</h3>
|
|
<div class="rows"> <ol><li><span class="label">Surname: </span>[% altcontactsurname | html %]</li>
|
|
<li><span class="label">First name: </span>[% altcontactfirstname | html %]</li>
|
|
<li><span class="label">Address: </span>[% altcontactaddress1 | html %]</li>
|
|
<li><span class="label">Address 2: </span>[% altcontactaddress2 | html %]</li>
|
|
<li><span class="label">City: </span>[% altcontactaddress3 | html %]</li>
|
|
[% IF ( altcontactstate ) %]<li><span class="label">State: </span>[% altcontactstate | html %]</li>[% END %]
|
|
<li><span class="label">ZIP/Postal code: </span>[% altcontactzipcode | html %]</li>
|
|
[% IF ( altcontactcountry ) %]<li><span class="label">Country: </span>[% altcontactcountry | html %]</li>[% END %]
|
|
[% IF ( altcontactphone ) %]<li><span class="label">Phone: </span><a href="tel:[% altcontactphone | url %]">[% altcontactphone | html %]</a></li>[% END %]
|
|
</ol></div>
|
|
</div>
|
|
<div class="action"><a href="memberentry.pl?op=modify&borrowernumber=[% borrowernumber %]&step=2">Edit</a></div>
|
|
|
|
</div>
|
|
</div>
|
|
|
|
<div id="finesholdsissues" class="toptabs">
|
|
<ul>
|
|
<li><a href="#checkouts">[% issuecount %] Checkout(s)</a></li>
|
|
[% IF relatives_issues_count %]
|
|
<li><a href="#relatives-issues" id="relatives-issues-tab">Relatives' checkouts</a></li>
|
|
[% END %]
|
|
<li><a href="#finesandcharges">Fines & Charges</a></li>
|
|
<li>
|
|
[% IF ( holds_count ) %]
|
|
<a href="#reserves" id="holds-tab">[% holds_count %] Hold(s)</a>
|
|
[% ELSE %]
|
|
<a href="#reserves" id="holds-tab">0 Holds</a>
|
|
[% END %]
|
|
</li>
|
|
<li><a id="debarments-tab-link" href="#reldebarments">[% debarments.size %] Restrictions</a></li>
|
|
</ul>
|
|
|
|
[% INCLUDE "checkouts-table.inc" %]
|
|
|
|
[% IF ( relatives_issues_count ) %]
|
|
<div id="relatives-issues">
|
|
<table id="relatives-issues-table" style="width: 100% !Important;">
|
|
<thead>
|
|
<tr>
|
|
<th scope="col">Due date hidden not formatted</th>
|
|
<th scope="col">Due date</th>
|
|
<th scope="col">Title</th>
|
|
<th scope="col">Item type</th>
|
|
<th scope="col">Location</th>
|
|
<th scope="col">Checked out on</th>
|
|
<th scope="col">Checked out from</th>
|
|
<th scope="col">Call no</th>
|
|
<th scope="col">Charge</th>
|
|
<th scope="col">Fine</th>
|
|
<th scope="col">Price</th>
|
|
<th scope="col">Patron</th>
|
|
</tr>
|
|
</thead>
|
|
</table>
|
|
</div>
|
|
[% END %]
|
|
|
|
<div id="finesandcharges">
|
|
[% IF ( totaldue_raw ) %]
|
|
<p>Total due: [% totaldue %]</p>
|
|
[% ELSE %]
|
|
<p>No outstanding charges</p>
|
|
[% END %]
|
|
</div>
|
|
|
|
[% INCLUDE borrower_debarments.inc %]
|
|
|
|
<div id="reserves">
|
|
[% IF ( holds_count ) %]
|
|
<form action="/cgi-bin/koha/reserve/modrequest.pl" method="post">
|
|
<input type="hidden" name="from" value="circ" />
|
|
<table id="holds-table" style="width: 100% !Important;">
|
|
<thead>
|
|
<tr>
|
|
<th>Hold date</th>
|
|
<th>Title</th>
|
|
<th>Call number</th>
|
|
<th>Barcode</th>
|
|
<th>Pickup at</th>
|
|
<th>Expiration</th>
|
|
<th>Priority</th>
|
|
<th>Delete?</th>
|
|
<th>Suspend?</th>
|
|
</tr>
|
|
</thead>
|
|
</table>
|
|
|
|
<fieldset class="action">
|
|
<input type="submit" class="cancel" name="submit" value="Cancel marked holds" />
|
|
</fieldset>
|
|
</form>
|
|
|
|
[% IF SuspendHoldsIntranet %]
|
|
<fieldset class="action">
|
|
<form action="/cgi-bin/koha/reserve/modrequest_suspendall.pl" method="post">
|
|
<input type="hidden" name="from" value="borrower" />
|
|
<input type="hidden" name="borrowernumber" value="[% borrowernumber %]" />
|
|
<input type="submit" value="Suspend all holds" />
|
|
|
|
[% IF AutoResumeSuspendedHolds %]
|
|
<label for="suspend_until">until</label>
|
|
<input type="text" size="10" id="suspend_until" name="suspend_until datepicker"/>
|
|
<span class="hint">Specify date on which to resume [% INCLUDE 'date-format.inc' %]: </span>
|
|
[% END %]
|
|
</form>
|
|
</fieldset>
|
|
|
|
<fieldset class="action">
|
|
<form action="/cgi-bin/koha/reserve/modrequest_suspendall.pl" method="post">
|
|
<input type="hidden" name="from" value="borrower" />
|
|
<input type="hidden" name="borrowernumber" value="[% borrowernumber %]" />
|
|
<input type="hidden" name="suspend" value="0" />
|
|
<input type="submit" value="Resume all suspended holds" />
|
|
</form>
|
|
</fieldset>
|
|
[% END # IF SuspendHoldsIntranet %]
|
|
|
|
[% ELSE %]<p>Patron has nothing on hold.</p>[% END %]
|
|
</div>
|
|
|
|
</div>
|
|
[% END %] <!-- unknowuser -->
|
|
|
|
|
|
</div>
|
|
</div>
|
|
<div class="yui-b">
|
|
[% INCLUDE 'circ-menu.inc' %]
|
|
</div>
|
|
</div>
|
|
[% INCLUDE 'intranet-bottom.inc' %]
|