+[% USE raw %]
+[% USE Asset %]
[% USE Koha %]
[% USE KohaDates %]
[% USE Branches %]
+[% SET footerjs = 1 %]
[% INCLUDE 'doc-head-open.inc' %]
-<title>Koha › Patrons › [% IF ( opadd ) %]Add[% ELSIF ( opduplicate ) %]Duplicate[% ELSE %] Modify[% END %] patron [% IF (firstname) %][% firstname %] [% END %][% IF (surname) %][% surname %] [% END %]([%IF ( categoryname ) %][% categoryname %][% ELSE %][% IF ( I ) %]Organization[% END %][% IF ( A ) %]Adult[% END %][% IF ( C ) %]Child[% END %][% IF ( P ) %]Professional[% END %][% IF ( S ) %]Staff[% END %][% END %])</title>
+<title>Koha › Patrons ›
+ [% UNLESS blocking_error %]
+ [% IF ( opadd ) %]Add
+ [% ELSIF ( opduplicate ) %]Duplicate
+ [% ELSE %] Modify
+ [% END %] patron
+ [% IF (firstname) %][% firstname | html %] [% END %]
+ [% IF (surname) %][% surname | html %] [% END %]
+ ([%IF categoryname %][% categoryname | html %][% ELSE %][% IF ( I ) %]Organization[% END %][% IF ( A ) %]Adult[% END %][% IF ( C ) %]Child[% END %][% IF ( P ) %]Professional[% END %][% IF ( S ) %]Staff[% END %][% END %])
+ [% END %]
+</title>
[% INCLUDE 'doc-head-close.inc' %]
-<script type="text/javascript" src="[% interface %]/lib/jquery/plugins/jquery.fixFloat.js"></script>
-[% INCLUDE 'calendar.inc' %]
-<script type="text/javascript">
-//<![CDATA[
-$(document).ready(function() {
-
- $("#saverecord").css({ 'margin-left': 0 });
- var original_offset = $("#toolbar").position().top;
- var additional_height = $("#filters").height();
- $('#toolbar').fixFloat({ 'originalOffset': original_offset - additional_height });
- $("#filteraction_on").on("click", function(){
- $(window).off('scroll');
- $("#toolbar").css({ top: original_offset });
- $('#toolbar').fixFloat({ 'originalOffset': original_offset });
- });
- $("#filteraction_off").on("click", function(){
- $(window).off('scroll');
- $("#toolbar").css({ top: original_offset - additional_height});
- $('#toolbar').fixFloat({ 'originalOffset': original_offset - additional_height });
- })
-
- [% IF categorycode %]
- update_category_code( "[% categorycode %]" );
- [% ELSE %]
- if ( $("#categorycode_entry").length > 0 ){
- var category_code = $("#categorycode_entry").find("option:selected").val();
- update_category_code( category_code );
- }
- [% END %]
-});
-
-$(document).ready(function() {
-
- var toggle_quick_add = $(".toggle_quick_add");
- $(toggle_quick_add).click(function(e){
- toggle_quick_add.toggle();
- e.preventDefault();
- var toggle_to = '';
- var toggle_from = '';
- if( $("#entryform:visible").length ) {
- toggle_to = "#quick_add_form label";
- toggle_from = "#entryform label";
- } else {
- toggle_to="#entryform label";
- toggle_from = "#quick_add_form label";
- }
- $(toggle_from).each(function() {
- var input_label = $(this).attr('for');
- if ( input_label == 'sex-male' || input_label == 'sex-none' || input_label == 'sex-female' ) {
- $(toggle_to+"[for='"+input_label+"']").next().prop('checked', $(this).next().prop('checked') );
- return;
- }
- if( $(this).next().val() != '' ) {
- $(toggle_to+"[for='"+input_label+"']").next().val( $(this).next().val() );
- }
- });
-
- $(".toggler").toggle();
- });
-
- $("#save_quick_add").click(function(){
- $("#quick_add_form").validate();
- if( $("#quick_add_form").valid()){
- $('.toggle_quick_add').click();
- $('#saverecord').click();
- }
- else {return false;}
- });
- $("#saverecord").click(function(){
- if( check_form_borrowers() ){
- $("#entryform").submit();
- }
- });
-
-});
-
- var MSG_SEPARATOR = _("Separator must be / in field %s");
- var MSG_INCORRECT_DAY = _("Invalid day entered in field %s");
- var MSG_INCORRECT_MONTH = _("Invalid month entered in field %s");
- var MSG_INCORRECT_YEAR = _("Invalid year entered in field %s");
- var MSG_DUPLICATE_PATRON = _("Warning: Duplicate patron");
- var MSG_DUPLICATE_ORGANIZATION = _("Warning: Duplicate organization");
- var MSG_LATE_EXPIRY = _("Warning: Expiration date falls before enrollment date");
- var MSG_DUPLICATE_SUSPICION = _("Please confirm whether this is a duplicate patron");
- var MSG_PASSWORD_MISMATCH = _("The passwords entered do not match");
- var MSG_PASSWORD_CONTAINS_TRAILING_SPACES = _("Password contains leading and/or trailing spaces.");
- var MSG_MONTH = _("%s month")
- var MSG_MONTHS = _("%s months")
- var MSG_YEAR = _("%s year")
- var MSG_YEARS = _("%s years")
- var LABEL_CHANGE = _("Change");
- var LABEL_SET_TO_PATRON = _("Set to patron");
- var LABEL_AGE = _("Age");
-
-//]]>
-</script>
-<script type="text/javascript" src="[% interface %]/[% theme %]/js/members.js"></script>
</head>
+
<body id="pat_memberentrygen" 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 (firstname || surname ) %] <a href="/cgi-bin/koha/members/moremember.pl?borrowernumber=[% borrowernumber %]">[% IF (firstname) %][% firstname | html %] [% END %][% IF (surname) %][% surname | html %] [% END %]</a> ›[% END %]
-<strong>[% IF ( opadd ) %]Add[% ELSIF ( opduplicate ) %]Duplicate[% ELSE %] Modify[% END %] patron ([%IF ( categoryname ) %][% categoryname %][% ELSE %][% IF ( I ) %]Organization[% END %][% IF ( A ) %]Adult[% END %][% IF ( C ) %]Child[% END %][% IF ( P ) %]Professional[% END %][% IF ( S ) %]Staff[% END %][% END %])</strong>
+<div id="breadcrumbs">
+ <a href="/cgi-bin/koha/mainpage.pl">Home</a> › <a href="/cgi-bin/koha/members/members-home.pl">Patrons</a>
+ [% UNLESS blocking_error %]
+ ›[% IF (firstname || surname ) %] <a href="/cgi-bin/koha/members/moremember.pl?borrowernumber=[% borrowernumber | uri %]">[% IF (firstname) %][% firstname | html %] [% END %][% IF (surname) %][% surname | html %] [% END %]</a> ›[% END %]
+<strong>[% IF ( opadd ) %]Add[% ELSIF ( opduplicate ) %]Duplicate[% ELSE %] Modify[% END %] patron ([%IF ( categoryname ) %][% categoryname | html %][% ELSE %][% IF ( I ) %]Organization[% END %][% IF ( A ) %]Adult[% END %][% IF ( C ) %]Child[% END %][% IF ( P ) %]Professional[% END %][% IF ( S ) %]Staff[% END %][% END %])</strong>
+ [% END %]
</div>
-[% IF ( opadd ) %]<div id="doc" class="yui-t7">[% ELSE %]<div id="doc3" class="yui-t2">[% END %]
- <div id="bd">
- <div id="yui-main">
- <div class="yui-b">
+<div class="main container-fluid">
+ <div class="row">
+ [% IF ( opadd ) %]
+ <div class="col-md-10 col-md-offset-1 col-lg-8 col-lg-offset-2">
+ [% ELSE %]
+ <div class="col-sm-10 col-sm-push-2">
+ [% END %]
+ <main class="clearfix">
+ [% INCLUDE 'blocking_errors.inc' %]
+
[% IF error_alert %]
[% IF ( error_alert == "no_email" ) %]
- <div class="error">This member has no email</div>
+ <div class="dialog alert">This member has no email</div>
[% ELSE %]
- <div class="error">[% error_alert %]</div>
+ <div class="dialog alert">[% error_alert | html %]</div>
[% END %]
[% END %]
[% IF info_alert %]
[% INCLUDE 'noadd-warnings.inc' %]
[% UNLESS ( no_add ) %]
- <h1>[% IF ( opadd ) %]Add[% ELSIF ( opduplicate ) %]Duplicate[% ELSE %] Modify[% END %] patron [% IF (firstname) %][% firstname | html %] [% END %][% IF (surname) %][% surname | html %] [% END %]([%IF ( categoryname ) %][% categoryname %][% ELSE %][% IF ( I ) %]Organization[% END %][% IF ( A ) %]Adult[% END %][% IF ( C ) %]Child[% END %][% IF ( P ) %]Professional[% END %][% IF ( S ) %]Staff[% END %][% END %])</h1>
+ <h1>[% IF ( opadd ) %]Add[% ELSIF ( opduplicate ) %]Duplicate[% ELSE %] Modify[% END %] patron [% IF (firstname) %][% firstname | html %] [% END %][% IF (surname) %][% surname | html %] [% END %]([%IF ( categoryname ) %][% categoryname | html %][% ELSE %][% IF ( I ) %]Organization[% END %][% IF ( A ) %]Adult[% END %][% IF ( C ) %]Child[% END %][% IF ( P ) %]Professional[% END %][% IF ( S ) %]Staff[% END %][% END %])</h1>
[% IF quickadd && opadd && !check_member %]
<a href="#" class="toggle_quick_add"><i class="fa fa-plus-square"></i> Show full form</a>
[% IF ( check_member ) %]
<div class="dialog alert">
<h3>Duplicate patron record?</h3>
- <p><a class="popup" href="#" onclick="Dopop('moremember.pl?print=brief&borrowernumber=[% check_member %]');return false;" >View existing record</a></p>
- <form action="/cgi-bin/koha/members/memberentry.pl" method="get">
- <input type="hidden" name="op" value="modify" />
- <input type="hidden" name="borrowernumber" value="[% check_member %]" />
- <input type="hidden" name="csrf_token" value="[% csrf_token %]" />
- <button type="submit" class="new"><i class="fa fa-pencil"></i> It is a duplicate.
- Edit existing record</button>
- </form>
-
- <form name="form" action="/cgi-bin/koha/members/memberentry.pl" method="post" autocomplete="off">
- <input type="hidden" name="nodouble" value="1" />
- <input type="hidden" name="csrf_token" value="[% csrf_token %]" />
- <button type="submit" class="new"><i class="fa fa-plus"></i> Not a duplicate.
+ <p><a class="popup" href="#" onclick="Dopop('moremember.pl?print=brief&borrowernumber=[% check_member | html %]');return false;" >View existing record</a></p>
+ <button id="duplicate" type="submit" class="new"><i class="fa fa-pencil"></i> It is a duplicate.
+ Edit existing record</button>
+
+ <button type="submit" id="not-duplicate" class="new"><i class="fa fa-plus"></i> Not a duplicate.
Save as new record</button>
</div>
[% END %]
[% END %]
[% IF ( ERROR_age_limitations ) %]
<li id="ERROR_age_limitations">Patron's age is incorrect for their category.
- Ages allowed are [% age_low %]-[% age_high %].</li>
+ Ages allowed are [% age_low | html %]-[% age_high | html %].</li>
[% END %]
[% IF ( ERROR_branch ) %]
<li id="ERROR_branch">Library is invalid.</li>
[% IF ( ERROR_dateexpiry ) %]
<li id="ERROR_dateexpiry">Date of expiration is invalid.</li>
[% END %]
- [% IF ( ERROR_short_password ) %]
- <li id="ERROR_short_password">Password must be at least [% minPasswordLength %] characters long.</li>
- [% END %]
+ [% IF ( ERROR_password_too_short ) %]
+ <li id="ERROR_short_password">Password must be at least [% minPasswordLength | html %] characters long.</li>
+ [% END %]
+ [% IF ( ERROR_password_too_weak ) %]
+ <li id="ERROR_weak_password">Password must contain at least one digit, one lowercase and one uppercase.</li>
+ [% END %]
+ [% IF ( ERROR_password_has_whitespaces ) %]
+ <li id="ERROR_weak_password">Password must not contain leading or trailing whitespaces.</li>
+ [% END %]
[% IF ( ERROR_password_mismatch ) %]
<li id="ERROR_password_mismatch">Passwords do not match.</li>
[% END %]
[% IF ( ERROR_extended_unique_id_failed ) %]
- <li id="ERROR_extended_unique_id_failed"><strong>[% ERROR_extended_unique_id_failed_description %]:</strong> Attribute value "[% ERROR_extended_unique_id_failed_value %]" is already in use by another patron record.</li>
+ <li id="ERROR_extended_unique_id_failed"><strong>[% ERROR_extended_unique_id_failed_description | html %]:</strong> Attribute value "[% ERROR_extended_unique_id_failed_value | html %]" is already in use by another patron record.</li>
[% END %]
[% IF ERROR_bad_email %]
<li id="ERROR_bad_email">The primary email is invalid.</li>
<div id="toolbar" class="btn-toolbar">
[% UNLESS ( check_member ) %]
[% IF quickadd && opadd %]
- <button class="btn btn-small toggler" id="save_quick_add" name="save"><i class="fa fa-save"></i> Save</button>
+ <button class="btn btn-default btn-sm toggler" id="save_quick_add" name="save"><i class="fa fa-save"></i> Save</button>
[% END %]
- <button class="btn btn-small toggler" id="saverecord" name="save" ><i class="fa fa-save"></i> Save</button>
+ <button class="btn btn-default btn-sm toggler" id="saverecord" name="save" ><i class="fa fa-save"></i> Save</button>
[% IF opadd %]
- <a class="btn btn-small" href="/cgi-bin/koha/members/member.pl" class="toggler save_entryform">
+ <a class="btn btn-default btn-sm" href="/cgi-bin/koha/members/member.pl" class="toggler save_entryform">
[% ELSE %]
- <a class="btn btn-small" href="/cgi-bin/koha/members/moremember.pl?borrowernumber=[% borrowernumber %]">
+ <a class="btn btn-default btn-sm" href="/cgi-bin/koha/members/moremember.pl?borrowernumber=[% borrowernumber | html %]">
[% END %]
<i class="fa fa-times"></i> Cancel
</a>
[% END %]
</div>
-[% UNLESS ( check_member ) %]<form name="form" id="entryform" action="/cgi-bin/koha/members/memberentry.pl" method="post" autocomplete="off" class="toggler" >
-<input type="hidden" name="nodouble" value="[% nodouble %]" /> [% END %]
+<form name="form" id="entryform" action="/cgi-bin/koha/members/memberentry.pl" method="post" autocomplete="off" class="toggler" >
+[% UNLESS ( check_member ) %]
+ <input type="hidden" name="nodouble" value="[% nodouble | html %]" />
+[% END %]
<!-- field always hidden in different form (1,2,3) -->
-<input type="hidden" name="BorrowerMandatoryField" value="[% BorrowerMandatoryField %]" />
-<input type="hidden" name="category_type" value="[% category_type %]" />
-<input type="hidden" name="updtype" value="[% updtype %]" />
-<input type="hidden" name="destination" value="[% destination %]" />
-<input type="hidden" name="check_member" value="[% check_member %]" />
-<input type="hidden" name="borrowernumber" value="[% UNLESS opduplicate %][% borrowernumber %][% END %]" />
-<input type="hidden" name="nodouble" value="[% UNLESS opduplicate %][% nodouble %][% END %]" />
-<input type="hidden" name="csrf_token" value="[% csrf_token %]" />
-[% IF ( step ) %]<input type="hidden" name="step" value="[% step %]" />[% END %]
+<input type="hidden" name="BorrowerMandatoryField" value="[% BorrowerMandatoryField | html %]" />
+<input type="hidden" name="category_type" value="[% category_type | html %]" />
+<input type="hidden" name="updtype" value="[% updtype | html %]" />
+<input type="hidden" name="destination" value="[% destination | html %]" />
+<input type="hidden" name="check_member" value="[% check_member | html %]" />
+<input type="hidden" name="borrowernumber" value="[% borrowernumber | html UNLESS opduplicate %]" />
+<input type="hidden" name="nodouble" value="[% nodouble | html UNLESS opduplicate %]" />
+<input type="hidden" name="csrf_token" value="[% csrf_token | html %]" />
+[% IF ( step ) %]<input type="hidden" name="step" value="[% step | html %]" />[% END %]
[% IF ( opadd ) %]<input type="hidden" name="op" value="insert" />
[% ELSIF ( opduplicate ) %]
<input type="hidden" name="op" value="insert" />
[% ELSE %]
<input type="hidden" name="op" value="save" />
-[% IF step == 4 || step == 5 || step == 6 || step == 2 || step == 1 %]
+[% IF step == 4 || step == 5 || step == 6 || step == 2 || step == 1 || step == 7 %]
[%# Only put the cardnumber if we arent showing it in the form later %]
[% IF cardnumber %]
-<input type="hidden" name="cardnumber" value="[% cardnumber %]" />
+<input type="hidden" name="cardnumber" value="[% cardnumber | html %]" />
[% END %]
[% END %]
[% END %]
<option value=""></option>
[% FOREACH t IN Koha.Preference('BorrowersTitles').split('\|') %]
[% IF btitle == t %]
- <option value="[% t %]" selected="selected">[% t %]</option>
+ <option value="[% t | html %]" selected="selected">[% t | html %]</option>
[% ELSE %]
- <option value="[% t %]">[% t %]</option>
+ <option value="[% t | html %]">[% t | html %]</option>
[% END %]
[% END %]
</select>
[% END %]
[% UNLESS nosurname %]
<li>
- [% IF ( mandatorysurname ) %]
- <label for="surname" class="required">
- [% ELSE %]
- <label for="surname">
- [% END %]
- Surname: </label>
+
+ [% IF ( I ) %]
+ <label for="surname" class="required">
+ Name:
+ </label>
+ [% ELSE %]
+ [% IF ( mandatorysurname ) %]
+ <label for="surname" class="required">
+ [% ELSE %]
+ <label for="surname">
+ [% END %]
+ Surname: </label>
+ [% END %]
+
[% IF ( uppercasesurnames ) %]
- <input style="text-transform:uppercase;" type="text" id="surname" name="surname" size="20" value="[% surname %]" />
+ <input style="text-transform:uppercase;" type="text" id="surname" name="surname" size="20" value="[% surname | html %]" />
[% ELSE %]
- <input type="text" id="surname" name="surname" size="20" value="[% surname %]" />
+ <input type="text" id="surname" name="surname" size="20" value="[% surname | html %]" />
[% END %]
[% IF ( mandatorysurname ) %]<span class="required">Required</span>[% END %]
</li>
<label for="firstname">
[% END %]
First name: </label>
- <input type="text" id="firstname" name="firstname" size="20" value="[% UNLESS opduplicate %][% firstname | html %][% END %]" />
+ <input type="text" id="firstname" name="firstname" size="20" value="[% firstname | html UNLESS opduplicate %]" />
[% IF ( mandatoryfirstname ) %]<span class="required">Required</span>[% END %]
</li>
[% END %]
[% END %]
Date of birth: </label>
- <input type="text" id="dateofbirth" name="dateofbirth" size="20" onchange="write_age();" value="[% UNLESS opduplicate %][% dateofbirth %][% END %]" class="datepicker" />
+ <input type="text" id="dateofbirth" name="dateofbirth" size="20" onchange="write_age();" value="[% dateofbirth | html UNLESS opduplicate %]" class="datepicker" />
[% IF ( mandatorydateofbirth ) %]<span class="required">Required</span>[% END %]
[% IF ( ERROR_dateofbirth ) %]<span class="required">(Error)</span>[% END %]
<label for="initials">
[% END %]
Initials: </label>
- <input type="text" id="initials" name="initials" size="20" value="[% UNLESS opduplicate %][% initials | html %][% END %]" />
+ <input type="text" id="initials" name="initials" size="20" value="[% initials | html UNLESS opduplicate %]" />
[% IF ( mandatoryinitials ) %]<span class="required">Required</span>[% END %]
</li>
[% END %]
<label for="othernames">
[% END %]
Other name: </label>
- <input type="text" id="othernames" name="othernames" size="20" value="[% UNLESS opduplicate %][% othernames | html %][% END %]" />
+ <input type="text" id="othernames" name="othernames" size="20" value="[% othernames | html UNLESS opduplicate %]" />
[% IF ( mandatoryothernames ) %]<span class="required">Required</span>[% END %]
[% IF ( I ) %]<input type="hidden" name="sex" value="N" />[% END %]
</li>
[% UNLESS ( opduplicate ) %]
[% IF ( female ) %]
- <label for="sex-female">Female </label><input type="radio" name="sex" id="sex-female" value="F" checked="checked" />
+ <label for="sex-female"><input type="radio" name="sex" id="sex-female" value="F" checked="checked" /> Female</label>
[% ELSE %]
- <label for="sex-female">Female </label><input type="radio" name="sex" id="sex-female" value="F" />
+ <label for="sex-female"><input type="radio" name="sex" id="sex-female" value="F" /> Female</label>
[% END %]
[% IF ( male ) %]
- <label for="sex-male">Male </label><input type="radio" name="sex" id="sex-male" value="M" checked="checked" />
+ <label for="sex-male"><input type="radio" name="sex" id="sex-male" value="M" checked="checked" /> Male</label>
[% ELSE %]
- <label for="sex-male">Male </label><input type="radio" name="sex" id="sex-male" value="M" />
+ <label for="sex-male"><input type="radio" name="sex" id="sex-male" value="M" /> Male</label>
[% END %]
[% IF ( none ) %]
- <label for="sex-none">None specified </label><input type="radio" name="sex" id="sex-none" value="" checked="checked" />
+ <label for="sex-none"><input type="radio" name="sex" id="sex-none" value="" checked="checked" /> None specified</label>
[% ELSE %]
- <label for="sex-none">None specified </label><input type="radio" name="sex" id="sex-none" value="" />
+ <label for="sex-none"><input type="radio" name="sex" id="sex-none" value="" /> None specified</label>
[% END %]
[% ELSE %]
<label for="sex-female">Female </label><input type="radio" name="sex" id="sex-female" value="F" />
[% END # hide fieldset %]
[% IF ( showguarantor ) %]
- <input type="hidden" id="guarantorid" name="guarantorid" value="[% guarantorid %]" />
+ <input type="hidden" id="guarantorid" name="guarantorid" value="[% guarantorid | html %]" />
[% UNLESS step_6 %]
- <input type="hidden" name="branchcode" value="[% branchcode %]" />
+ <input type="hidden" name="branchcode" value="[% branchcode | html %]" />
[% END %]
<fieldset id="memberentry_guarantor" class="rows">
<legend id="guarantor_lgd">Guarantor information</legend>
[% ELSE %]
<li id="contact-details" style="display: none">
[% END %]
- <span class="label">Organization #:</span> [% IF ( guarantorid ) %] <a href="/cgi-bin/koha/members/moremember.pl?borrowernumber=[% guarantorid %]" target="blank">[% guarantorid %]</a>[% END %]
+ <span class="label">Organization #:</span> [% IF ( guarantorid ) %] <a href="/cgi-bin/koha/members/moremember.pl?borrowernumber=[% guarantorid | uri %]" target="blank">[% guarantorid | html %]</a>[% END %]
</li>
<li>
<label for="contactname">Organization name: </label>
[% IF ( guarantorid ) %]
- <span>[% contactname %]</span>
+ <span>[% contactname | html %]</span>
<input name="contactname" id="contactname" type="hidden" size="20" value="[% contactname | html %]" />
[% ELSE %]
<input name="contactname" id="contactname" type="text" size="20" value="[% contactname | html %]" />
[% ELSE %]
<li id="contact-details" style="display: none">
[% END %]
- <span class="label">Patron #:</span> [% IF ( guarantorid ) %] <a href="/cgi-bin/koha/members/moremember.pl?borrowernumber=[% guarantorid %]" target="blank">[% guarantorid %]</a>[% END %]
+ <span class="label">Patron #:</span>
+ [% IF guarantorid %]
+ [% IF logged_in_user.can_see_patron_infos( guarantor ) %]
+ <a href="/cgi-bin/koha/members/moremember.pl?borrowernumber=[% guarantorid | uri %]" target="blank">[% guarantorid | html %]</a>
+ [% ELSE %]
+ [% guarantorid | html %]
+ [% END %]
+ [% END %]
</li>
[% UNLESS nocontactname %]
<li>
<label for="contactname">Surname: </label>
[% IF ( guarantorid ) %]
- <span>[% contactname %]</span>
+ <span>[% contactname | html %]</span>
<input name="contactname" id="contactname" type="hidden" size="20" value="[% contactname | html %]" />
[% ELSE %]
<input name="contactname" id="contactname" type="text" size="20" value="[% contactname | html %]" />
<li>
<label for="contactfirstname">First name: </label>
[% IF ( guarantorid ) %]
- <span>[% contactfirstname %]</span>
+ <span>[% contactfirstname | html %]</span>
<input name="contactfirstname" id="contactfirstname" type="hidden" size="20" value="[% contactfirstname | html %]" />
[% ELSE %]
<input name="contactfirstname" id="contactfirstname" type="text" size="20" value="[% contactfirstname | html %]" />
<select name="relationship" id="relationship" >
[% FOREACH relshiploo IN relshiploop %]
[% IF ( relshiploo.selected ) %]
- <option value="[% relshiploo.relationship %]" selected="selected" >[% relshiploo.relationship %]</option>
+ <option value="[% relshiploo.relationship | html %]" selected="selected" >[% relshiploo.relationship | html %]</option>
[% ELSE %]
- <option value="[% relshiploo.relationship %]">[% relshiploo.relationship %]</option>
+ <option value="[% relshiploo.relationship | html %]">[% relshiploo.relationship | html %]</option>
[% END %]
[% END %]
</select>
[% END %]
[% UNLESS noaddress && noaddress2 && nocity && nostate && nozipcode && nocountry %]
- [% IF Koha.Preference( 'AddressFormat' ) %]
- [% INCLUDE "member-main-address-style-${ Koha.Preference( 'AddressFormat' ) }.inc" %]
- [% ELSE %]
- [% INCLUDE 'member-main-address-style-us.inc' %]
- [% END %]
+ [% SWITCH Koha.Preference( 'AddressFormat' ) %]
+ [% CASE 'de' %]
+ [% INCLUDE 'member-main-address-style-de.inc' %]
+ [% CASE # us %]
+ [% INCLUDE 'member-main-address-style-us.inc' %]
+ [% END %]
[% END # nostreet && nocity etc group%]
[% UNLESS nophone && nophonepro && nomobile && noemail && noemailpro && nofax %]
[% IF ( step_6 ) %]
[% UNLESS noB_address && noB_address2 && noB_city && noB_zipcode && noB_state && noB_country &&nocontactnote && noB_phone && noB_email %]
- [% IF Koha.Preference( 'AddressFormat' ) %]
- [% INCLUDE "member-alt-address-style-${ Koha.Preference( 'AddressFormat' ) }.inc" %]
- [% ELSE %]
+ [% SWITCH Koha.Preference( 'AddressFormat' ) %]
+ [% CASE 'de' %]
+ [% INCLUDE 'member-alt-address-style-de.inc' %]
+ [% CASE # us %]
[% INCLUDE 'member-alt-address-style-us.inc' %]
- [% END %]
+ [% END %]
+
[% END # UNLESS noB_address && noB_city && noB_state && noB_phone && noB_email %]
[% END %]
[% IF ( step_2 ) %]
[% UNLESS noaltcontactsurname && noaltcontactfirstname && noaltcontactaddress1 && noaltcontactaddress2 && noaltcontactaddress3 && noaltcontactstate && noaltcontactzipcode && noaltcontactcountry && noaltcontactphone %]
- [% IF Koha.Preference( 'AddressFormat' ) %]
- [% INCLUDE "member-alt-contact-style-${ Koha.Preference( 'AddressFormat' ) }.inc" %]
- [% ELSE %]
+ [% SWITCH Koha.Preference( 'AddressFormat' ) %]
+ [% CASE 'de' %]
+ [% INCLUDE 'member-alt-contact-style-de.inc' %]
+ [% CASE # us %]
[% INCLUDE 'member-alt-contact-style-us.inc' %]
- [% END %]
+ [% END %]
[% END # UNLESS noaltcontactsurname && noaltcontactfirstname etc %]
[% END %]
<legend id="library_management_lgd">Library management</legend><ol>
[% UNLESS nocardnumber %]
<li>
- [% IF mandatorycardnumber and not autoMemberNum %]
+ [% IF mandatorycardnumber %]
<label for="cardnumber" class="required">
[% ELSE %]
<label for="cardnumber" class="validated">
[% END %]
- [% IF autoMemberNum %]
- Card number<br>(<u>leave blank for auto calc during registration</u>): </label>
- [% ELSE %]
- Card number: </label>
- [% END %]
+ Card number: </label>
+
+ <!-- NOTE: div.hint closing tag isn't on the same line -->
[% IF minlength_cardnumber == maxlength_cardnumber %]
- <input type="text" id="cardnumber" name="cardnumber" size="20" value="[% cardnumber | html %]" minlength="[% minlength_cardnumber %]" maxlength="[% maxlength_cardnumber %]" />
- [% IF mandatorycardnumber and not autoMemberNum %]<span class="required">Required</span>[% END %]
- <div class="hint">Card number must be exactly [% minlength_cardnumber %] characters.</div>
+ <input type="text" id="cardnumber" name="cardnumber" size="20" value="[% cardnumber | html %]" minlength="[% minlength_cardnumber | html %]" maxlength="[% maxlength_cardnumber | html %]" />
+ [% IF mandatorycardnumber %]<span class="required">Required</span>[% END %]<span id="cn_max" class="required">Card number must not be more than [% maxlength_cardnumber | html %] characters.</span>
+ <div class="hint">Card number must be exactly [% minlength_cardnumber | html %] characters.
[% ELSIF minlength_cardnumber && maxlength_cardnumber %]
- <input type="text" id="cardnumber" name="cardnumber" size="20" value="[% cardnumber | html %]" minlength="[% minlength_cardnumber %]" maxlength="[% maxlength_cardnumber %]" />
- [% IF mandatorycardnumber and not autoMemberNum %]<span class="required">Required</span>[% END %]
- <div class="hint">Card number must be between [% minlength_cardnumber %] and [% maxlength_cardnumber %] characters.</div>
+ <input type="text" id="cardnumber" name="cardnumber" size="20" value="[% cardnumber | html %]" minlength="[% minlength_cardnumber | html %]" maxlength="[% maxlength_cardnumber | html %]" />
+ [% IF mandatorycardnumber %]<span class="required">Required</span>[% END %]<span id="cn_max" class="required">Card number must not be more than [% maxlength_cardnumber | html %] characters.</span>
+ <div class="hint">Card number must be between [% minlength_cardnumber | html %] and [% maxlength_cardnumber | html %] characters.
[% ELSIF maxlength_cardnumber %]
- <input type="text" id="cardnumber" name="cardnumber" size="20" value="[% cardnumber | html %]" maxlength="[% maxlength_cardnumber %]" />
- [% IF mandatorycardnumber and not autoMemberNum %]<span class="required">Required</span>[% END %]
- <div class="hint">Card number can be up to [% maxlength_cardnumber %] characters.</div>
+ <input type="text" id="cardnumber" name="cardnumber" size="20" value="[% cardnumber | html %]" maxlength="[% maxlength_cardnumber | html %]" />
+ [% IF mandatorycardnumber %]<span class="required">Required</span>[% END %]<span id="cn_max" class="required">Card number must not be more than [% maxlength_cardnumber | html %] characters.</span>
+ <div class="hint">Card number can be up to [% maxlength_cardnumber | html %] characters.
[% ELSE %]
<input type="text" id="cardnumber" name="cardnumber" size="20" value="[% cardnumber | html %]" />
- [% IF mandatorycardnumber and not autoMemberNum %]<span class="required">Required</span>[% END %]
- <div class="hint">There is no minimum or maximum character length.</div>
+ [% IF mandatorycardnumber %]<span class="required">Required</span>[% END %]
+ <div class="hint">There is no minimum or maximum character length.
+ [% END %]
+ [% IF autoMemberNum %]
+ [% IF mandatorycardnumber %]
+ <br/><span class="error">AutoMemberNum is set to enabled, but cardnumber is marked as mandatory in BorrowerMandatoryField: auto calc has been disabled.</span>
+ [% ELSE %]
+ <br/>Leave blank for auto calc during registration
+ [% END %]
[% END %]
+ </div><!--/hint div -->
</li>
[% END %]
[% UNLESS nobranchcode %]
<li>
<label for="libraries" class="required">Library:</label>
<select name="branchcode" size="1" id="libraries">
- [% PROCESS options_for_libraries libraries => Branches.all( selected => userbranch ) %]
+ [% PROCESS options_for_libraries libraries => Branches.all( selected => userbranch, only_from_group => 1 ) %]
</select>
<span class="required">Required</span>
</li>
[% IF ( typeloo.typename_X ) %]<optgroup label="Statistical">[% END %]
[% END %]
[% IF ( categoryloo.categorycodeselected ) %]
- <option value="[% categoryloo.categorycode %]" selected="selected" data-typename="[% typeloo.typename %]">[% categoryloo.categoryname %]</option>
+ <option value="[% categoryloo.categorycode | html %]" selected="selected" data-typename="[% typeloo.typename | html %]">[% categoryloo.categoryname | html %]</option>
[% ELSE %]
- <option value="[% categoryloo.categorycode %]" data-typename="[% typeloo.typename %]">[% categoryloo.categoryname %]</option>
+ <option value="[% categoryloo.categorycode | html %]" data-typename="[% typeloo.typename | html %]">[% categoryloo.categoryname | html %]</option>
[% END %]
[% IF ( loop.last ) %]
</optgroup>
[% IF ( mandatorysort2 ) %]<span class="required">Required</span>[% END %]
</li>
[% END %]
- [% IF ( Koha.Preference( 'NorwegianPatronDBEnable' ) == 1 ) %]
- <li>
- <label for="sort2">Sync with the Norwegian national patron database:</label>
- [% IF ( sync == 0 ) %]
- <input type="radio" id="sync" name="sync" value="1"> Yes
- <input type="radio" id="sync" name="sync" value="0" checked> No
- [% ELSE %]
- <input type="radio" id="sync" name="sync" value="1" checked> Yes
- <input type="radio" id="sync" name="sync" value="0"> No
- [% END %]
- </li>
- [% END %]
[% IF ( Koha.Preference('CheckPrevCheckout') == 'softyes' || Koha.Preference('CheckPrevCheckout') == 'softno' ) %]
<li><label for="checkprevcheckout">Check for previous checkouts: </label>
<select name="checkprevcheckout" id="checkprevcheckout">
</select>
</li>
[% END %]
+ [% IF Koha.Preference('TranslateNotices') %]
+ <li>
+ <label for="lang">Preferred language for notices: </label>
+ <select id="lang" name="lang">
+ <option value="default">Default</option>
+ [% FOR language IN languages %]
+ [% FOR sublanguage IN language.sublanguages_loop %]
+ [% IF language.plural %]
+ [% IF sublanguage.rfc4646_subtag == lang %]
+ <option value="[% sublanguage.rfc4646_subtag | html %]" selected="selected">[% sublanguage.native_description | html %] [% sublanguage.region_description | html %] ([% sublanguage.rfc4646_subtag | html %])</option>
+ [% ELSE %]
+ <option value="[% sublanguage.rfc4646_subtag | html %]">[% sublanguage.native_description | html %] [% sublanguage.region_description | html %] ([% sublanguage.rfc4646_subtag | html %])</option>
+ [% END %]
+ [% ELSE %]
+ [% IF sublanguage.rfc4646_subtag == lang %]
+ <option value="[% sublanguage.rfc4646_subtag | html %]" selected="selected">[% sublanguage.native_description | html %] ([% sublanguage.rfc4646_subtag | html %])</option>
+ [% ELSE %]
+ <option value="[% sublanguage.rfc4646_subtag | html %]">[% sublanguage.native_description | html %] ([% sublanguage.rfc4646_subtag | html %])</option>
+ [% END %]
+ [% END %]
+ [% END %]
+ [% END %]
+ </select>
+ </li>
+ [% END %]
</ol>
</fieldset>
[% UNLESS nodateenrolled && noopacnote && noborrowernotes %]
[% END %]
Registration date: </label>
[% IF ( dateformat == "metric" ) %]
- <input type="text" id="from" name="dateenrolled" maxlength="10" size="10" onchange="CheckDate(document.form.dateenrolled);check_manip_date('verify');" value="[% dateenrolled %]" class="datepickerfrom" />
+ <input type="text" id="from" name="dateenrolled" maxlength="10" size="10" onchange="CheckDate(document.form.dateenrolled);check_manip_date('verify');" value="[% dateenrolled | html %]" class="datepickerfrom" />
[% ELSE %]
- <input type="text" id="from" name="dateenrolled" maxlength="10" size="10" value="[% dateenrolled %]" class="datepickerfrom" />
+ <input type="text" id="from" name="dateenrolled" maxlength="10" size="10" value="[% dateenrolled | html %]" class="datepickerfrom" />
[% END %]
[% IF ( mandatorydateenrolled ) %]<span class="required">Required</span>[% END %]
[% IF ( ERROR_dateenrolled ) %]<span class="required">(Error)</span>[% END %]
Expiry date (leave blank for auto calc): </label>
[% IF ( dateformat == "metric" ) %]
[% UNLESS ( opadd ) %]
- <input type="text" id="to" name="dateexpiry" maxlength="10" size="10" onchange="CheckDate(document.form.dateexpiry);check_manip_date('verify');" value="[% UNLESS opduplicate %][% dateexpiry %][% END %]" class="datepickerto" />
+ <input type="text" id="to" name="dateexpiry" maxlength="10" size="10" onchange="CheckDate(document.form.dateexpiry);check_manip_date('verify');" value="[% dateexpiry | html UNLESS opduplicate %]" class="datepickerto" />
[% ELSE %]
<input type="text" id="to" name="dateexpiry" maxlength="10" size="10" onchange="CheckDate(document.form.dateexpiry);check_manip_date('verify');" class="datepickerto" />
[% END %]
[% ELSE %]
[% UNLESS ( opadd ) %]
- <input type="text" id="to" name="dateexpiry" maxlength="10" size="10" value="[% UNLESS opduplicate %][% dateexpiry %][% END %]" class="datepickerto" />
+ <input type="text" id="to" name="dateexpiry" maxlength="10" size="10" value="[% dateexpiry | html UNLESS opduplicate %]" class="datepickerto" />
[% ELSE %]
- <input type="text" id="to" name="dateexpiry" maxlength="10" size="10" class="datepickerto" />
+ <input type="text" id="to" name="dateexpiry" maxlength="10" size="10" value="[% dateexpiry | html %]" class="datepickerto" />
[% END %]
[% END %]
[% IF ( mandatorydateexpiry ) %]<span class="required">Required</span>[% END %]
<label for="opacnote">
[% END %]
OPAC note: </label>
- <textarea id="opacnote" name="opacnote" cols="55" rows="5">[% UNLESS opduplicate %][% opacnote | html %][% END %]</textarea>
+ <textarea id="opacnote" name="opacnote" cols="55" rows="5">[% opacnote | html UNLESS opduplicate %]</textarea>
<div class="hint">This message appears on this patron's user page in the OPAC</div>
[% IF ( mandatoryopacnote ) %]<span class="required">Required</span>[% END %]
</li>
<label for="borrowernotes">
[% END %]
Circulation note: </label>
- <textarea id="borrowernotes" name="borrowernotes" cols="55" rows="5">[% UNLESS opduplicate %][% borrowernotes | html %][% END %]</textarea>
+ <textarea id="borrowernotes" name="borrowernotes" cols="55" rows="5">[% borrowernotes | html UNLESS opduplicate %]</textarea>
<div class="hint">This message displays when checking out to this patron</div>
[% IF ( mandatoryborrowernotes ) %]<span class="required">Required</span>[% END %]
</li>
[% IF ( opduplicate ) %]
<input type="text" id="userid" name="userid" size="20" disabled="disabled" />
[% ELSE %]
- <input type="text" id="userid" name="userid" size="20" disabled="disabled" value="[% userid %]" />
+ <input type="text" id="userid" name="userid" size="20" disabled="disabled" value="[% userid | html %]" />
[% END %]
[% ELSE %]
[% IF ( opduplicate ) %]
<input type="text" id="userid" name="userid" size="20" value="" />
[% ELSE %]
- <input type="text" id="userid" name="userid" size="20" value="[% userid %]" />
+ <input type="text" id="userid" name="userid" size="20" value="[% userid | html %]" />
[% END %]
[% END %]
[% IF ( opduplicate ) %]
<input type="password" id="password" name="password" size="20" disabled="disabled" />
[% ELSE %]
- <input type="password" id="password" name="password" size="20" disabled="disabled" value="[% password %]" />
+ <input type="password" id="password" name="password" size="20" disabled="disabled" value="[% password | html %]" />
[% END %]
[% ELSE %]
[% IF ( opduplicate ) %]
<input type="password" id="password" name="password" size="20" />
[% ELSE %]
- <input type="password" id="password" name="password" size="20" value="[% password %]" />
+ <input type="password" id="password" name="password" size="20" value="[% password | html %]" />
[% END %]
[% END %]
[% ELSE %]
[% END %]
[% END %]
[% END %]
- [% IF ( mandatorypassword ) %]<span class="required">Required</span>[% END %][% IF ( ERROR_short_password ) %]<span class="required">Password is too short</span>[% END %]
-[% IF ( minPasswordLength ) %]<div class="hint">Minimum password length: [% minPasswordLength %]</div>[% END %]
+ [% IF ( mandatorypassword ) %]<span class="required">Required</span>[% END %]
+ [% IF ( ERROR_password_too_short ) %]<span class="required">Password is too short</span>[% END %]
+ [% IF ( ERROR_password_too_weak ) %]<span class="required">Password is too weak</span>[% END %]
+ [% IF ( ERROR_password_has_whitespaces ) %]<span class="required">Password has leading or trailing whitespaces</span>[% END %]
+ <div class="hint">Minimum password length: [% minPasswordLength | html %]</div>
</li>
<li>
[% IF ( mandatorypassword ) %]
[% IF ( opduplicate ) %]
<input type="password" id="password2" name="password2" size="20" disabled="disabled" />
[% ELSE %]
- <input type="password" id="password2" name="password2" size="20" disabled="disabled" value="[% password %]" />
+ <input type="password" id="password2" name="password2" size="20" disabled="disabled" value="[% password | html %]" />
[% END %]
[% ELSE %]
[% IF ( opduplicate ) %]
<input type="password" id="password2" name="password2" size="20" />
[% ELSE %]
- <input type="password" id="password2" name="password2" size="20" value="[% password %]" />
+ <input type="password" id="password2" name="password2" size="20" value="[% password | html %]" />
[% END %]
[% END %]
[% ELSE %]
<legend id="account_flags_lgd">Patron account flags</legend>
<ol class="radio">
[% FOREACH flagloo IN flagloop %]
- <li><label class="radio" for="yes[% flagloo.name %]">
+ <li><label class="radio" for="yes[% flagloo.name | html %]">
[% IF ( flagloo.key == 'gonenoaddress' ) %]Gone no address:[% END %]
[% IF ( flagloo.key == 'lost' ) %]Lost card:[% END %]
</label>
[% IF CAN_user_circulate_manage_restrictions %]
- <label for="yes[% flagloo.name %]">Yes </label>
+ <label for="yes[% flagloo.name | html %]">
[% IF ( flagloo.yes ) %]
- <input type="radio" id="yes[% flagloo.name %]" name="[% flagloo.name %]" value="1" checked="checked" />
+ <input type="radio" id="yes[% flagloo.name | html %]" name="[% flagloo.name | html %]" value="1" checked="checked" />
[% ELSE %]
- <input type="radio" id="yes[% flagloo.name %]" name="[% flagloo.name %]" value="1" />
+ <input type="radio" id="yes[% flagloo.name | html %]" name="[% flagloo.name | html %]" value="1" />
[% END %]
- <label for="no[% flagloo.name %]">No </label>
+ Yes </label>
+ <label for="no[% flagloo.name | html %]">
[% IF ( flagloo.no ) %]
- <input type="radio" id="no[% flagloo.name %]" name="[% flagloo.name %]" value="0" checked="checked"/>
+ <input type="radio" id="no[% flagloo.name | html %]" name="[% flagloo.name | html %]" value="0" checked="checked"/>
[% ELSE %]
- <input type="radio" id="no[% flagloo.name %]" name="[% flagloo.name %]" value="0" />
+ <input type="radio" id="no[% flagloo.name | html %]" name="[% flagloo.name | html %]" value="0" />
[% END %]
+ No </label>
[% ELSE %]
[% IF flagloo.yes %]Yes[% ELSE %]No[% END %]
[% END %]
<th>Type</th>
<th>Comment</th>
<th>Expiration</th>
- [% IF CAN_user_borrowers && CAN_user_circulate_manage_restrictions %]
+ <th>Created</th>
+ [% IF CAN_user_borrowers_edit_borrowers && CAN_user_circulate_manage_restrictions %]
<th>Remove?</th>
[% END %]
</tr>
<tbody>
[% FOREACH d IN debarments %]
<tr>
- <td>[% d.type %]</td>
+ <td>[% d.type | html %]</td>
<td>
[% IF d.comment.search('OVERDUES_PROCESS') %]
- Restriction added by overdues process [% d.comment.remove('OVERDUES_PROCESS ') %]
+ Restriction added by overdues process [% d.comment.remove('OVERDUES_PROCESS ') | $raw %]
[% ELSE %]
- [% d.comment %]
+ [% d.comment | $raw %]
[% END %]
</td>
<td>[% IF d.expiration %] [% d.expiration | $KohaDates %] [% ELSE %] <i>Indefinite</i> [% END %]</td>
- [% IF CAN_user_borrowers && CAN_user_circulate_manage_restrictions %]
+ <td>[% d.created | $KohaDates %]</td>
+ [% IF CAN_user_borrowers_edit_borrowers && CAN_user_circulate_manage_restrictions %]
<td>
- <input type="checkbox" id="debarment_[% d.borrower_debarment_id %]" name="remove_debarment" value="[% d.borrower_debarment_id %]" />
+ <input type="checkbox" id="debarment_[% d.borrower_debarment_id | html %]" name="remove_debarment" value="[% d.borrower_debarment_id | html %]" />
</td>
[% END %]
</tr>
<p>Patron is currently unrestricted.</p>
[% END %]
- [% IF CAN_user_borrowers && CAN_user_circulate_manage_restrictions %]
+ [% IF CAN_user_borrowers_edit_borrowers && CAN_user_circulate_manage_restrictions %]
<p><a href="#" id="add_manual_restriction">Add manual restriction</a></p>
<fieldset id="manual_restriction_form">
<input type="hidden" id="add_debarment" name="add_debarment" value="0" />
<legend id="manual_restriction_lgd">Add manual restriction</legend>
<ol>
<li><label for="debarred_comment">Comment: </label><input type="text" id="debarred_comment" name="debarred_comment" onchange="$('#add_debarment').val(1);" /></li>
- <li><label for="debarred_expiration">Expiration: </label><input name="debarred_expiration" id="debarred_expiration" size="10" value="" class="datepicker" onchange="$('#add_debarment').val(1);" />
+ <li><label for="debarred_expiration">Expiration: </label><input name="debarred_expiration" id="debarred_expiration" size="10" value="" class="datepicker" onchange="$('#add_debarment').val(1);" type="text" />
<a href='javascript:void(0)' onclick="$('#debarred_expiration').val('');">Clear date</a></li>
</ol>
[% END %]
-[% IF ( step_4 ) %]
+[% IF ( step_7 ) %]
[% IF Koha.Preference('HouseboundModule') %]
<fieldset class="rows" id="memberentry_housebound_roles">
<legend id="housebound_roles">Housebound roles</legend>
</ol>
</fieldset>
[% END # hide fieldset %]
+[% END # IF step_7 %]
+
+[% IF ( step_4 ) %]
[% IF ( ExtendedPatronAttributes ) %][% UNLESS ( no_patron_attribute_types ) %]
<fieldset class="rows" id="memberentry_patron_attributes">
<legend id="patron_attributes_lgd">Additional attributes and identifiers</legend>
<input type="hidden" name="setting_extended_patron_attributes" value="1" />
[% FOREACH pa_loo IN patron_attributes %]
- [% IF pa_loo.class %]
- <fieldset id="aai_[% pa_loo.class %]">
- <legend id="[% pa_loo.class %]_lgd">[% pa_loo.lib %]</legend>
- [% END %]
<ol class="attributes_table">
+ [% IF pa_loo.class %]
+ <fieldset id="aai_[% pa_loo.class | html %]">
+ <legend id="[% pa_loo.class | html %]_lgd">[% pa_loo.lib | html %]</legend>
+ [% END %]
[% FOREACH patron_attribute IN pa_loo.items %]
- <li data-category_code="[% patron_attribute.category_code %]">
- <label for="[% patron_attribute.form_id %]">[% patron_attribute.description %]: </label>
- <input type="hidden" id="[% patron_attribute.form_id %]_code" name="[% patron_attribute.form_id %]_code" value="[% patron_attribute.code |html %]" />
+ <li data-category_code="[% patron_attribute.category_code | html %]">
+ <label for="[% patron_attribute.form_id | html %]">[% patron_attribute.description | html %]: </label>
[% IF ( patron_attribute.use_dropdown ) %]
- <select id="[% patron_attribute.form_id %]" name="[% patron_attribute.form_id %]">
+ <select id="[% patron_attribute.form_id | html %]" name="[% patron_attribute.form_id | html %]">
<option value=""></option>
[% FOREACH auth_val_loo IN patron_attribute.auth_val_loop %]
[% IF auth_val_loo.authorised_value == patron_attribute.value %]
- <option value="[% auth_val_loo.authorised_value %]" selected="selected">
- [% auth_val_loo.lib %]
+ <option value="[% auth_val_loo.authorised_value | html %]" selected="selected">
+ [% auth_val_loo.lib | html %]
</option>
[% ELSE %]
- <option value="[% auth_val_loo.authorised_value %]" >
- [% auth_val_loo.lib %]
+ <option value="[% auth_val_loo.authorised_value | html %]" >
+ [% auth_val_loo.lib | html %]
</option>
[% END %]
[% END %]
</select>
[% ELSE %]
- <textarea rows="2" cols="30" id="[% patron_attribute.form_id %]" name="[% patron_attribute.form_id %]">[% patron_attribute.value %]</textarea>
+ <textarea rows="2" cols="30" id="[% patron_attribute.form_id | html %]" name="[% patron_attribute.form_id | html %]">[% patron_attribute.value | html %]</textarea>
[% END %]
+ <input type="hidden" id="[% patron_attribute.form_id | html %]_code" name="[% patron_attribute.form_id | html %]_code" value="[% patron_attribute.code | html %]" />
<a href="#" onclick="clear_entry(this); return false;"><i class="fa fa-fw fa-trash"></i> Clear</a>
[% IF ( patron_attribute.repeatable ) %]
<a href="#" onclick="clone_entry(this); return false;"><i class="fa fa-fw fa-plus"></i> New</a>
[% END %]
</li>
[% END %]
+ [% IF pa_loo.class %]</fieldset>[% END %]
</ol>
- [% IF pa_loo.class %]</fieldset>[% END %]
[% END %]
</fieldset>
[% END %][% END %][% END %]
[% IF ( step_5 ) %][% IF ( EnhancedMessagingPreferences ) %]
<fieldset class="rows" id="memberentry_messaging_prefs">
<legend id="patron_messaging_prefs_lgd">Patron messaging preferences</legend>
- [% IF ( opadd ) %]
- <!-- handle changing prefs if creating new patron and changing
- the patron category
- -->
- <script type="text/javascript">//<![CDATA[
- $(document).ready(function(){
- var message_prefs_dirty = false;
- $('#memberentry_messaging_prefs > *').change(function() {
- message_prefs_dirty = true;
- });
- $('#categorycode_entry').change(function() {
- var categorycode = $(this).val();
- if (message_prefs_dirty) {
- if (!confirm(_("Change messaging preferences to default for this category?"))) {
- return;
- }
- }
- $.getJSON('/cgi-bin/koha/members/default_messageprefs.pl?categorycode=' + categorycode,
- function(data) {
- $.each(data.messaging_preferences, function(i, item) {
- var attrid = item.message_attribute_id;
- var transports = ['email', 'rss', 'sms'];
- $.each(transports, function(j, transport) {
- if (item['transports_' + transport] == 1) {
- $('#' + transport + attrid).prop('checked', true);
- } else {
- $('#' + transport + attrid).prop('checked', false);
- }
- });
- if (item.digest && item.digest != ' ') {
- $('#digest' + attrid).prop('checked', true);
- } else {
- $('#digest' + attrid).prop('checked', false);
- }
- if (item.takes_days == '1') {
- $('[name=' + attrid + '-DAYS]').val('' + item.days_in_advance);
- }
- });
- message_prefs_dirty = false;
- }
- );
- });
- });
- //]]>
- </script>
- [% END %]
+ <div id="messaging_prefs_loading" class="form-message" style="display:none">
+ <img src="[% interface | html %]/[% theme | html %]/img/spinner-small.gif" alt="" /> Loading new messaging defaults
+ </div>
<input type="hidden" name="setting_messaging_prefs" value="1" />
[% INCLUDE 'messaging-preference-form.inc' %]
[% IF ( SMSSendDriver ) %]
<p><label for="SMSnumber">SMS number:</label>
- <input type="text" id="SMSnumber" name="SMSnumber" value="[% SMSnumber %]" />
+ <input type="text" id="SMSnumber" name="SMSnumber" value="[% SMSnumber | html %]" />
</p>
+ [% UNLESS nosms_provider_id %]
<p>
<label for="sms_provider_id">SMS provider:</label>
- <select id="sms_provider_id" name="sms_provider_id"/>
+ <select id="sms_provider_id" name="sms_provider_id">
<option value="">Unknown</option>
[% FOREACH s IN sms_providers %]
[% IF s.id == sms_provider_id %]
- <option value="[% s.id %]" selected="selected">[% s.name %]</option>
+ <option value="[% s.id | html %]" selected="selected">[% s.name | html %]</option>
[% ELSE %]
- <option value="[% s.id %]">[% s.name %]</option>
+ <option value="[% s.id | html %]">[% s.name | html %]</option>
[% END %]
[% END %]
</select>
</p>
+ [% END %]
[% END %]
</fieldset>
[% END %] [% END %]
</ol>
</fieldset>
</form>
+[% END %]
+
+[% END %]
+ </main>
+ </div> <!-- /.col-sm-10.col-sm-push-2 -->
+
+ [% UNLESS ( opadd ) %]
+ <div class="col-sm-2 col-sm-pull-10">
+ <aside>
+ [% INCLUDE 'circ-menu.inc' %]
+ </aside>
+ </div> <!-- /.col-sm-2.col-sm-pull-10 -->
+ [% END %]
+ </div> <!-- /.row -->
+
+[% MACRO jsinclude BLOCK %]
+ [% Asset.js("lib/jquery/plugins/jquery.fixFloat.js") | $raw %]
+ [% INCLUDE 'calendar.inc' %]
+ [% INCLUDE 'str/members-menu.inc' %]
+ [% Asset.js("js/members-menu.js") | $raw %]
<script>
- $(document).ready(function () {
-
- $("#entryform,#saverecord").hide();
- [% q_add_f = Koha.Preference('PatronQuickAddFields').split('\|') %]
- var qaddfields = [[% FOREACH field IN q_add_f.unique %]"[% field %]",[% END %]];
- var skipped_fields = ["contactname","contactfirstname","relationship"]; //Guarantor form is pulled as a whole, ignore individual fields
- $("#entryform label").each(function () {
- var input_label = $(this).attr('for');
- if ( input_label == 'sex-female' ) {
- input_label='sex';
+ $(document).ready(function() {
+
+ $("#saverecord").css({ 'margin-left': 0 });
+ var original_offset = $("#toolbar").position().top;
+ var additional_height = $("#filters").height();
+ $('#toolbar').fixFloat({ 'originalOffset': original_offset });
+ $("#filteraction_on").on("click", function(){
+ $(window).off('scroll');
+ $("#toolbar").css({ top: original_offset + additional_height });
+ $('#toolbar').fixFloat({ 'originalOffset': original_offset + additional_height });
+ });
+ $("#filteraction_off").on("click", function(){
+ $(window).off('scroll');
+ $("#toolbar").css({ top: original_offset });
+ $('#toolbar').fixFloat({ 'originalOffset': original_offset });
+ })
+
+ [% IF categorycode %]
+ update_category_code( "[% categorycode | html %]" );
+ [% ELSE %]
+ if ( $("#categorycode_entry").length > 0 ){
+ var category_code = $("#categorycode_entry").find("option:selected").val();
+ update_category_code( category_code );
}
- else if ( input_label == 'btitle' ) {
- input_label='title';
+ [% END %]
+ });
+
+ function update_cardnumber_warning(size){
+ var max_len = [% maxlength_cardnumber | html %];
+ if ( size >= max_len ) {
+ $("#cn_max").show();
+ } else {
+ $("#cn_max").hide();
+ }
+ }
+
+ $(document).ready(function() {
+ $("#cn_max").hide();
+ var content;
+ $("#cardnumber").on("keydown", function(e){
+ content = $(this).val();
+ });
+ $("#cardnumber").on("keyup", function(e){
+ // .val() will return the value of the input after the key has been released
+ var l = $(this).val().length;
+ if ( l == content.length + 1 ) { l--; }
+ update_cardnumber_warning(l);
+ });
+ $("#cardnumber").bind("paste", function(e){
+ var pastedData = e.originalEvent.clipboardData.getData('text');
+ update_cardnumber_warning(pastedData.length - 1);
+ } );
+ var toggle_quick_add = $(".toggle_quick_add");
+ $(toggle_quick_add).click(function(e){
+ toggle_quick_add.toggle();
+ e.preventDefault();
+ var toggle_to = '';
+ var toggle_from = '';
+ if( $("#entryform:visible").length ) {
+ toggle_to = "#quick_add_form label";
+ toggle_from = "#entryform label";
+ } else {
+ toggle_to="#entryform label";
+ toggle_from = "#quick_add_form label";
}
- if ( skipped_fields.indexOf( input_label ) != -1 ) { input_label=""; }
- if( qaddfields.indexOf( input_label ) != -1 || $(this).attr('class') == 'required' ){
- $(this).parent().clone().appendTo("#quick_add_list");
- if( input_label == 'password') $("#entryform label[for='password2']").parent().clone().appendTo("#quick_add_list");
+ $(toggle_from).each(function() {
+ var input_label = $(this).attr('for');
+ if ( input_label == 'sex-male' || input_label == 'sex-none' || input_label == 'sex-female' ) {
+ $(toggle_to+"[for='"+input_label+"']").next().prop('checked', $(this).next().prop('checked') );
+ return;
+ }
+ $(toggle_to+"[for='"+input_label+"']").next().val( $(this).next().val() );
+ });
+
+ $(".toggler").toggle();
+ });
+
+ $("#save_quick_add").click(function(){
+ $("#quick_add_form").validate();
+ if( $("#quick_add_form").valid()){
+ $('.toggle_quick_add').click();
+ $('#saverecord').click();
}
+ else {return false;}
});
- if( $("#memberentry_guarantor").length ) {
- $("#memberentry_guarantor").clone().appendTo("#quick_add_list").css("margin",0);
- $("#quick_add_form #memberentry_guarantor").append("<p>" + _("Note: Quick add guarantor form populates address fields in full form") + "</p>");
- $("#quick_add_list #guarantordelete").prop('id','qagd');
+
+ $("#saverecord").click(function(){
+ if( check_form_borrowers() ){
+ $("#entryform").submit();
}
- $("#qagd").click(function() { $("#guarantordelete").click(); });
- $("#quick_add_form").show();
+ });
+
+ $('#duplicate').on('click', function() {
+ $("input[name='op']").val('modify');
+ $("input[name='borrowernumber']").val('[% check_member | html %]');
+ $("input[name='check_member']").val('');
+ $('#entryform').submit();
+ });
+
+ $('#not-duplicate').on('click', function() {
+ $("input[name='nodouble']").val('1');
+ $('#entryform').submit();
+ });
});
+
+ var MSG_SEPARATOR = _("Separator must be / in field %s");
+ var MSG_INCORRECT_DAY = _("Invalid day entered in field %s");
+ var MSG_INCORRECT_MONTH = _("Invalid month entered in field %s");
+ var MSG_INCORRECT_YEAR = _("Invalid year entered in field %s");
+ var MSG_DUPLICATE_PATRON = _("Warning: Duplicate patron");
+ var MSG_DUPLICATE_ORGANIZATION = _("Warning: Duplicate organization");
+ var MSG_LATE_EXPIRY = _("Warning: Expiration date falls before enrollment date");
+ var MSG_DUPLICATE_SUSPICION = _("Please confirm whether this is a duplicate patron");
+ var MSG_MONTH = _("%s month")
+ var MSG_MONTHS = _("%s months")
+ var MSG_YEAR = _("%s year")
+ var MSG_YEARS = _("%s years")
+ var LABEL_CHANGE = _("Change");
+ var LABEL_SET_TO_PATRON = _("Set to patron");
+ var LABEL_AGE = _("Age");
+ var MSG_MESSAGING_DFEAULTS = _("Change messaging preferences to default for this category?");
+
+ [% IF quickadd && opadd && !check_member %]
+ $(document).ready(function () {
+
+ $("#entryform,#saverecord").hide();
+ [% q_add_f = Koha.Preference('PatronQuickAddFields').split('\|') %]
+ var qaddfields = [[% FOREACH field IN q_add_f.unique %]"[% field | html %]",[% END %]];
+ var skipped_fields = ["contactname","contactfirstname","relationship"]; //Guarantor form is pulled as a whole, ignore individual fields
+ $("#entryform label").each(function () {
+ var input_label = $(this).attr('for');
+ if ( input_label == 'sex-female' ) {
+ input_label='sex';
+ }
+ else if ( input_label == 'btitle' ) {
+ input_label='title';
+ }
+ if ( skipped_fields.indexOf( input_label ) != -1 ) { input_label=""; }
+ if( qaddfields.indexOf( input_label ) != -1 || $(this).attr('class') == 'required' ){
+ $(this).parent().clone().appendTo("#quick_add_list");
+ [% UNLESS mandatorypassword %]
+ if( input_label == 'password' ) $("#entryform label[for='password2']").parent().clone().appendTo("#quick_add_list");
+ [% END %]
+ }
+ });
+ if( $("#memberentry_guarantor").length ) {
+ $("#memberentry_guarantor").clone().appendTo("#quick_add_list").css("margin",0);
+ $("#quick_add_form #memberentry_guarantor").append("<p>" + _("Note: Quick add guarantor form populates address fields in full form") + "</p>");
+ $("#quick_add_list #guarantordelete").prop('id','qagd');
+ }
+ $("#qagd").click(function() { $("#guarantordelete").click(); });
+ $("#quick_add_form").show();
+ });
+ [% END %]
+
</script>
+ [% Asset.js("js/members.js") | $raw %]
+ [% Asset.js("js/messaging-preference-form.js") | $raw %]
+ [% PROCESS 'password_check.inc' %]
+ [% PROCESS 'add_password_check' new_password => 'password' %]
[% END %]
-</div>
-</div>
-[% UNLESS ( opadd ) %]<div class="yui-b">
-[% INCLUDE 'members-menu.inc' %]
-</div>[% END %]
-[% END %]
-</div>
[% INCLUDE 'intranet-bottom.inc' %]
-