[% USE Koha %]
[% USE KohaDates %]
[% USE Branches %]
+[% PROCESS 'member-main-address-style.inc' %]
[% PROCESS 'member-alt-address-style.inc' %]
+[% PROCESS 'member-alt-contact-style.inc' %]
+[% PROCESS 'patron_restrictions.inc' %]
[% SET footerjs = 1 %]
[% INCLUDE 'doc-head-open.inc' %]
- <title>Koha › Patrons ›
+ <title>
[% UNLESS blocking_error %]
[% IF ( opadd ) %]
Add patron
Modify patron
[% END %]
[% INCLUDE 'patron-title.inc' no_html = 1 %]
- [% IF categoryname %]([% categoryname | html %])[% END %]
- [% END %]
+ [% IF patron_category %]([% patron_category.description | html %])[% END %]
+ [% END %] › Patrons › Koha
</title>
<style>
legend:hover {
</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>
- [% UNLESS blocking_error %]
- ›
- [% IF (firstname || surname ) %]
- <a href="/cgi-bin/koha/members/moremember.pl?borrowernumber=[% borrowernumber | uri %]">
- [% INCLUDE 'patron-title.inc' %]
- </a> ›
- [% END %]
- <strong>
- [% IF ( opadd ) %]
- Add patron
- [% ELSIF ( opduplicate ) %]
- Duplicate patron
- [% ELSE %]
- Modify patron
+ [% WRAPPER 'header.inc' %]
+ [% INCLUDE 'patron-search-header.inc' %]
+ [% END %]
+
+ [% WRAPPER 'sub-header.inc' %]
+ <nav id="breadcrumbs" aria-label="Breadcrumb" class="breadcrumb">
+ <ol>
+ <li>
+ <a href="/cgi-bin/koha/mainpage.pl">Home</a>
+ </li>
+
+ [% IF blocking_error %]
+ <li>
+ <a href="/cgi-bin/koha/members/members-home.pl">Patrons</a>
+ </li>
+ [% ELSE %]
+ <li>
+ <a href="/cgi-bin/koha/members/members-home.pl">Patrons</a>
+ </li>
+ [% IF (borrower_data.firstname || borrower_data.surname ) %]
+ <li>
+ <a href="/cgi-bin/koha/members/moremember.pl?borrowernumber=[% borrowernumber | uri %]">
+ [% INCLUDE 'patron-title.inc' %]
+ </a>
+ </li>
[% END %]
- [% IF categoryname %]([% categoryname | html %])[% END %]
- </strong>
- [% END %]
- </div> <!-- /#breadcrumbs -->
+ <li>
+ <a href="#" aria-current="page">
+ [% IF ( opadd ) %]
+ <span>Add patron</span>
+ [% ELSIF ( opduplicate ) %]
+ <span>Duplicate patron</span>
+ [% ELSE %]
+ <span>Modify patron</span>
+ [% END %]
+ [% IF patron_category %]
+ ([% patron_category.description | html %])
+ [% END %]
+ </a>
+ </li>
+ [% END %]
+ </ol>
+ </nav> <!-- /#breadcrumbs -->
+ [% END %]
<div class="main container-fluid">
<div class="row">
- [% IF messages %]
- [% FOR message IN messages %]
+ [% IF borrower_data.messages %]
+ [% FOR message IN borrower_data.messages %]
[% SWITCH message.error %]
[% CASE 'error_on_insert_patron' %]
<div class="dialog alert">Something went wrong when creating the patron. Check the logs.</div>
[% CASE 'error_on_update_patron' %]
<div class="dialog alert">Something went wrong when updating the patron. Check the logs.</div>
- [% CASE %]Unhandled error: [% message.error | html %]
+ [% CASE %]<div class="dialog alert">Unhandled error: [% message.error | html %]</div>
[% END %]
[% END %]
[% END %]
[% UNLESS ( no_add ) %]
<h1>
[% IF ( opadd ) %]
- Add patron
+ <span>Add patron</span>
[% ELSIF ( opduplicate ) %]
- Duplicate patron
+ <span>Duplicate patron</span>
[% ELSE %]
- Modify patron
+ <span>Modify patron</span>
[% END %]
[% INCLUDE 'patron-title.inc' %]
- [% IF categoryname %]([% categoryname | html %])[% END %]
+ [% IF patron_category %]([% patron_category.description | html %])[% END %]
</h1>
[% IF quickadd && opadd && !check_member %]
[% IF ( ERROR_password_mismatch ) %]
<li id="ERROR_password_mismatch">Passwords do not match.</li>
[% END %]
+ [% IF ( ERROR_password_expiration_date ) %]
+ <li id="ERROR_dateexpiry">Password expiration date is invalid.</li>
+ [% END %]
[% IF ( ERROR_extended_unique_id_failed ) %]
<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 %]
<input type="checkbox" id="toggle_hidden_fields" title="These fields are collapsed by default by the CollapseFieldsPatronAddForm system preference"><strong>Show collapsed fields:</strong>
[% FOREACH field IN fieldstohide.split(',') %]
[% SWITCH field %]
- [% CASE 'identity' %] Organization/Patron identity |
- [% CASE 'guarantor' %] Guarantor information |
- [% CASE 'primary_address' %] Main address |
- [% CASE 'primary_contact' %] Contact information |
- [% CASE 'alt_address' %] Alternate address |
- [% CASE 'alt_contact' %] Alternate contact |
- [% CASE 'lib_mgmt' %] Library management |
- [% CASE 'lib_setup' %] Library setup |
- [% CASE 'login' %] OPAC/Staff login |
- [% CASE 'flags' %] Patron account flags |
- [% CASE 'debarments' %] Patron restrictions |
- [% CASE 'housebound' %] Housebound roles |
- [% CASE 'additional' %] Additional attributes and identifiers |
- [% CASE 'messaging' %] Patron messaging preferences |
+ [% CASE 'identity' %] <span>Patron identity</span> |
+ [% CASE 'guarantor' %] <span>Guarantor information</span> |
+ [% CASE 'primary_address' %] <span>Main address</span> |
+ [% CASE 'primary_contact' %] <span>Contact information</span> |
+ [% CASE 'alt_address' %] <span>Alternate address</span> |
+ [% CASE 'alt_contact' %] <span>Alternate contact</span> |
+ [% CASE 'lib_mgmt' %] <span>Library management</span> |
+ [% CASE 'lib_setup' %] <span>Library setup</span> |
+ [% CASE 'login' %] <span>OPAC/Staff interface login</span> |
+ [% CASE 'flags' %] <span>Patron account flags</span> |
+ [% CASE 'debarments' %] <span>Patron restrictions</span> |
+ [% CASE 'housebound' %] <span>Housebound roles</span> |
+ [% CASE 'additional' %] <span>Additional attributes and identifiers</span> |
+ [% CASE 'messaging' %] <span>Patron messaging preferences</span> |
[% END %]
[% END %]
</p>
[% END %]
<!-- field always hidden in different form (1,2,3) -->
<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 %]" />
[% ELSE %]
<input type="hidden" name="op" value="save" />
[% 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 | html %]" />
+ [%# Only put the card number if we arent showing it in the form later %]
+ [% IF borrower_data.cardnumber %]
+ <input type="hidden" name="cardnumber" value="[% borrower_data.cardnumber | html %]" />
[% END %]
[% END %]
[% END %]
[% IF ( step_1 ) %]
- [% UNLESS notitle && nosurname && nofirstname && nodateofbirth && noinitials && noothernames &&nosex %]
+ [% UNLESS notitle && nosurname && nofirstname && nomiddle_name && nodateofbirth && noinitials && noothernames &&nosex && nopronouns %]
<fieldset class="rows" id="memberentry_identity">
- <legend id="identity_lgd">[% IF ( I ) %]Organization [% ELSE %]Patron [% END %]identity</legend>
+ <legend id="identity_lgd">[% IF ( patron_category.category_type == 'I' ) %]<span>Organization</span> [% ELSE %]<span>Patron</span> [% END %]<span>identity</span></legend>
<ol>
- [% UNLESS ( I ) %]
+ [% UNLESS ( patron_category.category_type == 'I' ) %]
[% UNLESS notitle %]
[% IF Koha.Preference('BorrowersTitles') %]
<li>
[% UNLESS nosurname %]
<li>
- [% IF ( I ) %]
+ [% IF ( patron_category.category_type == 'I' ) %]
<label for="surname" class="required">
Name:
</label>
[% END %]
[% IF ( uppercasesurnames ) %]
- <input style="text-transform:uppercase;" type="text" id="surname" name="surname" size="20" value="[% surname | html %]" />
+ <input style="text-transform:uppercase;" type="text" id="surname" name="surname" size="20" value="[% borrower_data.surname | html %]" />
[% ELSE %]
- <input type="text" id="surname" name="surname" size="20" value="[% surname | html %]" />
+ <input type="text" id="surname" name="surname" size="20" value="[% borrower_data.surname | html %]" />
[% END %]
[% IF ( mandatorysurname ) %]
<span class="required">Required</span>
</li>
[% END # /UNLESS nosurname %]
- [% UNLESS ( I ) %]
+ [% UNLESS ( patron_category.category_type == 'I' ) %]
[% UNLESS nofirstname %]
<li>
[% IF ( mandatoryfirstname ) %]
[% END %]
First name:
</label>
- <input type="text" id="firstname" name="firstname" size="20" value="[% firstname | html UNLESS opduplicate %]" />
+ <input type="text" id="firstname" name="firstname" size="20" value="[% borrower_data.firstname | html UNLESS opduplicate %]" />
[% IF ( mandatoryfirstname ) %]
<span class="required">Required</span>
[% END %]
</li>
[% END #/UNLESS nofirstname %]
+ [% UNLESS nomiddle_name %]
+ <li>
+ [% IF ( mandatorymiddle_name ) %]
+ <label for="middle_name" class="required">
+ [% ELSE %]
+ <label for="middle_name">
+ [% END %]
+ Middle name:
+ </label>
+ <input type="text" id="middle_name" name="middle_name" size="20" value="[% borrower_data.middle_name | html UNLESS opduplicate %]" />
+ [% IF ( mandatorymiddle_name ) %]
+ <span class="required">Required</span>
+ [% END %]
+ </li>
+ [% END #/UNLESS nomiddle_name %]
[% UNLESS nodateofbirth %]
<li>
[% IF ( mandatorydateofbirth ) %]
[% END %]
Date of birth:
</label>
- <input type="text" id="dateofbirth" name="dateofbirth" size="20" value="[% dateofbirth | html UNLESS opduplicate %]" class="datepicker" />
+ <input type="text" id="dateofbirth" name="dateofbirth" size="20" value="[% borrower_data.dateofbirth | html UNLESS opduplicate %]" class="flatpickr" data-flatpickr-pastinclusive="true" />
[% IF ( mandatorydateofbirth ) %]
<span class="required">Required</span>
[% END %]
[% IF ( ERROR_dateofbirth ) %]
<span class="required">(Error)</span>
[% END %]
- <div class="hint">[% INCLUDE 'date-format.inc' %]</div>
+ <div id="dateofbirth_hint" class="hint">[% INCLUDE 'date-format.inc' %]</div>
</li>
[% END # /UNLESS nodateofbirth %]
[% UNLESS noinitials %]
[% END %]
Initials:
</label>
- <input type="text" id="initials" name="initials" size="20" value="[% initials | html UNLESS opduplicate %]" />
+ <input type="text" id="initials" name="initials" size="20" value="[% borrower_data.initials | html UNLESS opduplicate %]" />
[% IF ( mandatoryinitials ) %]
<span class="required">Required</span>
[% END %]
</li>
[% END # /UNLESS noinitials %]
+ [% UNLESS nopronouns %]
+ <li>
+ [% IF ( mandatorypronouns ) %]
+ <label for="pronouns" class="required">
+ [% ELSE %]
+ <label for="pronouns">
+ [% END %]
+ Pronouns:
+ </label>
+ <input type="text" id="pronouns" name="pronouns" size="20" value="[% borrower_data.pronouns | html UNLESS opduplicate %]" />
+ [% IF ( mandatorypronouns ) %]
+ <span class="required">Required</span>
+ [% END %]
+ </li>
+ [% END # /UNLESS nopronouns %]
[% END #/UNLESS ( I ) %]
[% UNLESS noothernames %]
<li>
[% END %]
Other name:
</label>
- <input type="text" id="othernames" name="othernames" size="20" value="[% othernames | html UNLESS opduplicate %]" />
+ <input type="text" id="othernames" name="othernames" size="20" value="[% borrower_data.othernames | html UNLESS opduplicate %]" />
[% IF ( mandatoryothernames ) %]
<span class="required">Required</span>
[% END %]
- [% IF ( I ) %]<input type="hidden" name="sex" value="N" />[% END %]
+ [% IF ( patron_category.category_type == 'I' ) %]<input type="hidden" name="sex" value="N" />[% END %]
</li>
[% END #/UNLESS noothernames %]
- [% UNLESS ( I ) %]
+ [% UNLESS ( patron_category.category_type == 'I' ) %]
[% UNLESS nosex %]
<li class="radio">
[% UNLESS ( opduplicate ) %]
[% IF ( female ) %]
- <label for="sex-female"><input type="radio" name="sex" id="sex-female" value="F" checked="checked" /> Female</label>
+ <label for="sex-female"><input type="radio" name="sex" id="sex-female" value="F" checked="checked" /><span class="patronsex-female"> Female</span></label>
[% ELSE %]
- <label for="sex-female"><input type="radio" name="sex" id="sex-female" value="F" /> Female</label>
+ <label for="sex-female"><input type="radio" name="sex" id="sex-female" value="F" /><span class="patronsex-female"> Female</span></label>
[% END %]
[% IF ( male ) %]
- <label for="sex-male"><input type="radio" name="sex" id="sex-male" value="M" checked="checked" /> Male</label>
+ <label for="sex-male"><input type="radio" name="sex" id="sex-male" value="M" checked="checked" /><span class="patronsex-male"> Male</span></label>
[% ELSE %]
- <label for="sex-male"><input type="radio" name="sex" id="sex-male" value="M" /> Male</label>
+ <label for="sex-male"><input type="radio" name="sex" id="sex-male" value="M" /><span class="patronsex-male"> Male</span></label>
+ [% END %]
+ [% IF ( other ) %]
+ <label for="sex-other"><input type="radio" name="sex" id="sex-other" value="O" checked="checked" /><span class="patronsex-other"> Other</span></label>
+ [% ELSE %]
+ <label for="sex-other"><input type="radio" name="sex" id="sex-other" value="O" /><span class="patronsex-other"> Other</span></label>
[% END %]
[% IF ( none ) %]
- <label for="sex-none"><input type="radio" name="sex" id="sex-none" value="" checked="checked" /> None specified</label>
+ <label for="sex-none"><input type="radio" name="sex" id="sex-none" value="" checked="checked" /><span class="patronsex-none"> None specified</span></label>
[% ELSE %]
- <label for="sex-none"><input type="radio" name="sex" id="sex-none" value="" /> None specified</label>
+ <label for="sex-none"><input type="radio" name="sex" id="sex-none" value="" /><span class="patronsex-none"> None specified</span></label>
[% END %]
[% ELSE %]
- <label for="sex-female">Female </label><input type="radio" name="sex" id="sex-female" value="F" />
- <label for="sex-male">Male </label><input type="radio" name="sex" id="sex-male" value="M" />
- <label for="sex-none">None specified </label><input type="radio" name="sex" id="sex-none" value="" checked="checked" />
+ <label for="sex-female"><span class="patronsex-female">Female </span></label><input type="radio" name="sex" id="sex-female" value="F" />
+ <label for="sex-male"><span class="patronsex-male">Male </span></label><input type="radio" name="sex" id="sex-male" value="M" />
+ <label for="sex-other"><span class="patronsex-other">Other </span></label><input type="radio" name="sex" id="sex-other" value="O" />
+ <label for="sex-none"><span class="patronsex-none">None specified </span></label><input type="radio" name="sex" id="sex-none" value="" checked="checked" />
[% END # /UNLESS ( opduplicate )%]
</li>
[% END # /UNLESS nosex %]
[% IF show_guarantor || guarantor %]
[% SET possible_relationships = Koha.Preference('borrowerRelationship') %]
- <span id="memberentry_guarantor_anchor">
+ <div id="memberentry_guarantor_anchor">
<fieldset id="memberentry_guarantor" class="rows">
- <legend>Guarantor information</legend>
+ <legend>Patron guarantor</legend>
- <span id="guarantor_relationships">
+ <div id="guarantor_relationships">
[% FOREACH r IN relationships %]
- <fieldset class="rows">
+ <fieldset>
<ol>
- [% IF category_type == 'I' %]
+ [% IF patron_category.category_type == 'I' %]
<li class="guarantor-details" data-borrowernumber="[% r.guarantor_id | $raw %]">
- <span class="label">Organization #:</span> [% IF ( r.guarantor_id ) %] <a href="/cgi-bin/koha/members/moremember.pl?borrowernumber=[% r.guarantor_id | uri %]" target="blank">[% r.guarantor_id | html %]</a>[% END %]
+ <span class="label">Organization:</span>
+ [% INCLUDE 'patron-title.inc' patron=r.guarantor hide_patron_infos_if_needed=1 %]
</li>
-
<li>
- <label for="guarantor_surname">Organization name: </label>
- <span>[% r.guarantor.surname | html %]</span>
+ <span class="label">Relationship:</span>
+ <span>[% r.relationship | html %]</span>
</li>
[% ELSE %]
<li class="guarantor-details" data-borrowernumber="[% r.guarantor_id | $raw %]">
- <span class="label">Patron card number:</span>
- <a href="/cgi-bin/koha/members/moremember.pl?borrowernumber=[% r.guarantor_id | uri %]" target="blank">[% r.guarantor.cardnumber | html %]</a>
+ <span class="label">Guarantor:</span>
+ [% INCLUDE 'patron-title.inc' patron=r.guarantor hide_patron_infos_if_needed=1 %]
</li>
-
- [% IF r.guarantor.surname %]
- <li>
- <label for="guarantor_surname">Surname: </label>
- <span>[% r.guarantor.surname | html %]</span>
- </li>
- [% END %]
-
- [% IF r.guarantor.firstname %]
- <li>
- <label for="guarantor_firstname">First name: </label>
- <span>[% r.guarantor.firstname | html %]</span>
- </li>
- [% END %]
-
<li>
- <label for="relationship">Relationship: </label>
+ <span class="label">Relationship:</span>
<span>[% r.relationship | html %]</span>
</li>
</fieldset>
[% END # END relationships foreach %]
[% IF guarantor && (!relationships) %]
- <fieldset class="rows">
+ <fieldset class="guarantor">
<ol>
<li class="guarantor-details" data-borrowernumber="0">
- <span class="label">Patron card number:</span>
- <a href="/cgi-bin/koha/members/moremember.pl?borrowernumber=[% guarantor.borrowernumber | uri %]" target="blank">[% guarantor.cardnumber | html %]</a>
+ <span class="label">Guarantor:</span>
+ <a href="/cgi-bin/koha/members/moremember.pl?borrowernumber=[% guarantor.borrowernumber | uri %]" target="blank">[% guarantor.firstname | html %] [% guarantor.surname | html %] ([% guarantor.cardnumber | html %])</a>
<input type="hidden" class="new_guarantor_id" name="new_guarantor_id" value="[% guarantor.borrowernumber | html %]"/>
</li>
- <li>
- <label for="guarantor_surname">Surname: </label>
- <span class="new_guarantor_surname_text">[% guarantor.surname | html %]</span>
- </li>
-
- <li>
- <label for="guarantor_firstname">First name: </label>
- <span class="new_guarantor_firstname_text">[% guarantor.firstname | html %]</span>
- </li>
-
- <li>
- <label for="guarantor_relationship">Relationship: </label>
- <select class="new_guarantor_relationship" name="new_guarantor_relationship">
- [% FOREACH pr IN possible_relationships.split('\|') %]
- <option value="[% pr | html %]">[% pr | html %]</option>
+ [% IF possible_relationships %]
+ <li>
+ [% UNLESS empty_relationship_allowed %]
+ <label for="guarantor_relationship" class="required">Relationship: </label>
+ <select class="new_guarantor_relationship" name="new_guarantor_relationship" required="required">
+ [% ELSE %]
+ <label for="guarantor_relationship">Relationship: </label>
+ <select class="new_guarantor_relationship" name="new_guarantor_relationship">
[% END %]
- </select>
- </li>
+ <option value="" selected>Empty option</option>
+ [% FOREACH pr IN possible_relationships.split('\|') %]
+ [% IF pr != "" %]
+ <option value="[% pr | html %]">[% pr | html %]</option>
+ [% END %]
+ [% END %]
+ </select>
+ [% UNLESS empty_relationship_allowed %]
+ <span class="required">Required</span>
+ [% END %]
+ </li>
+ [% ELSE %]
+ <input type="hidden" name="new_guarantor_relationship" value="" />
+ [% END %]
<li>
<label for="guarantor_cancel"> </label>
- <span><a href="#" class="guarantor_cancel">Remove</a></span>
+ <span><a href="#" class="guarantor_cancel"><i class="fa fa-trash" aria-hidden="true"></i> Remove</a></span>
</li>
</ol>
</fieldset>
[% END %]
- </span> <!-- #/guarantor_relationships -->
+ </div> <!-- #/guarantor_relationships -->
- <fieldset class="rows guarantor" id="guarantor_template">
+ <fieldset class="guarantor" id="guarantor_template">
<ol>
<li class="guarantor-details" data-borrowernumber="0">
- <span class="label">Patron card number:</span>
- <span class="new_guarantor_id_text"></span>
+ <span class="label">Guarantor:</span>
+ <a class="new_guarantor_link" href="#" target="blank">
+ <span class="new_guarantor_firstname_text"></span> <span class="new_guarantor_surname_text"></span>
+ (<span class="new_guarantor_id_text"></span>)
+ </a>
<input type="hidden" class="new_guarantor_id" name="new_guarantor_id" value=""/>
</li>
- <li>
- <label for="guarantor_surname">Surname: </label>
- <span class="new_guarantor_surname_text"></span>
- </li>
-
- <li>
- <label for="guarantor_firstname">First name: </label>
- <span class="new_guarantor_firstname_text"></span>
- </li>
-
- <li>
- <label for="guarantor_relationship">Relationship: </label>
- <select class="new_guarantor_relationship" name="new_guarantor_relationship">
- [% FOREACH pr IN possible_relationships.split('\|') %]
- <option value="[% pr | html %]">[% pr | html %]</option>
+ [% IF possible_relationships %]
+ <li>
+ [% UNLESS empty_relationship_allowed %]
+ <label for="guarantor_relationship" class="required">Relationship: </label>
+ <select class="new_guarantor_relationship" name="new_guarantor_relationship" required="required">
+ [% ELSE %]
+ <label for="guarantor_relationship">Relationship: </label>
+ <select class="new_guarantor_relationship" name="new_guarantor_relationship">
[% END %]
- </select>
- </li>
+ <option value="" selected></option>
+ [% FOREACH pr IN possible_relationships.split('\|') %]
+ [% IF pr != "" %]
+ <option value="[% pr | html %]">[% pr | html %]</option>
+ [% END %]
+ [% END %]
+ </select>
+ [% UNLESS empty_relationship_allowed %]
+ <span class="required">Required</span>
+ [% END %]
+ </li>
+ [% ELSE %]
+ <input type="hidden" name="new_guarantor_relationship" value="" />
+ [% END %]
<li>
<label for="guarantor_cancel"> </label>
- <span><a href="#" class="guarantor_cancel">Remove</a></span>
+ <span><a href="#" class="guarantor_cancel"><i class="fa fa-trash"></i> Remove</a></span>
</li>
</ol>
</fieldset>
<input name="guarantor_firstname" id="guarantor_firstname" type="hidden" />
<li>
- <a href="#" id="guarantor_search" class="btn btn-default"><i class="fa fa-plus"></i> Search to add</a>
+ <a href="#" id="guarantor_search" class="btn btn-default"><i class="fa fa-plus"></i> Add guarantor</a>
</li>
- [% IF relationships && Koha.Preference('AllowStaffToSetCheckoutsVisibilityForGuarantor') %]
+ [% IF Koha.Preference('AllowStaffToSetCheckoutsVisibilityForGuarantor') %]
<li>
<label for="privacy_guarantor_checkouts">Show checkouts to guarantors</label>
<select name="privacy_guarantor_checkouts" id="privacy_guarantor_checkouts">
- [% IF privacy_guarantor_checkouts %]
+ [% IF borrower_data.privacy_guarantor_checkouts %]
<option value="0">No</option>
<option value="1" selected>Yes</option>
[% ELSE %]
<div class="hint">Allow guarantors of this patron to view this patron's checkouts from the OPAC</div>
</li>
[% END %]
- [% IF relationships && Koha.Preference('AllowStaffToSetFinesVisibilityForGuarantor') %]
+ [% IF Koha.Preference('AllowStaffToSetFinesVisibilityForGuarantor') %]
<li>
<label for="privacy_guarantor_fines">Show fines to guarantors</label>
<select name="privacy_guarantor_fines" id="privacy_guarantor_fines">
- [% IF privacy_guarantor_fines %]
+ [% IF borrower_data.privacy_guarantor_fines %]
<option value="0">No</option>
<option value="1" selected>Yes</option>
[% ELSE %]
[% END %]
</ol>
</fieldset> <!-- /#memberentry_guarantor -->
- </span> <!-- #/memberentry_guarantor_anchor -->
+ </div> <!-- #/memberentry_guarantor_anchor -->
+
+ [% UNLESS nocontactname && nocontactfirstname && norelationship %]
+ <fieldset class="rows" id="non_patron_guarantor">
+ <legend>Non-patron guarantor</legend>
+ <ol>
+ [% UNLESS nocontactname %]
+ <li>
+ [% IF ( mandatorycontactname ) %]
+ <label for="contactname" class="required">
+ [% ELSE %]
+ <label for="contactname">
+ [% END %]
+ Guarantor surname:
+ </label>
+ <input type="text" id="contactname" name="contactname" value="[% patron.contactname | html %]" />
+ [% IF ( mandatorycontactname ) %]
+ <span class="required">Required</span>
+ [% END %]
+ <div class="hint">Non-patron guarantor surname</div>
+ </li>
+ [% END # /UNLESS nocontactname %]
+
+ [% UNLESS nocontactfirstname %]
+ <li>
+ [% IF ( mandatorycontactfirstname ) %]
+ <label for="contactfirstname" class="required">
+ [% ELSE %]
+ <label for="contactfirstname">
+ [% END %]
+ Guarantor first name:
+ </label>
+ <input type="text" id="contactfirstname" name="contactfirstname" value="[% patron.contactfirstname | html %]" />
+ [% IF ( mandatorycontactfirstname ) %]
+ <span class="required">Required</span>
+ [% END %]
+ <div class="hint">Non-patron guarantor first name</div>
+ </li>
+ [% END # /UNLESS noaltcontactfirstname %]
+
+ [% UNLESS norelationship %]
+ [% IF possible_relationships %]
+ <li>
+ <label for="relationship">Relationship: </label>
+ <select class="relationship" name="relationship">
+ <option value=""></option>
+ [% FOREACH pr IN possible_relationships.split('\|') %]
+ [% IF pr == borrower_data.relationship %]
+ <option value="[% pr | html %]" selected="selected">[% pr | html %]</option>
+ [% ELSE %]
+ <option value="[% pr | html %]">[% pr | html %]</option>
+ [% END %]
+ [% END %]
+ </select>
+ </li>
+ [% END #/IF possible_relationships %]
+ [% END # /UNLESS norelationship %]
+ </ol>
+ </fieldset> <!-- /#non_patron_guarantor -->
+ [% END # /UNLESS nocontactname && nocontactfirstname && norelationship %]
[% END # /IF show_guarantor || guarantor %]
[% 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 %]
+ [% PROCESS 'main-address-style' %]
[% END # /UNLESS nostreet && nocity etc group%]
[% UNLESS nophone && nophonepro && nomobile && noemail && noemailpro && nofax %]
<fieldset class="rows" id="memberentry_contact">
- <legend id="contact_lgd">Contact</legend>
+ <legend id="contact_lgd">Contact information</legend>
<ol>
- [% UNLESS nocontactname %]
- <li>
- [% IF ( mandatorycontactname ) %]
- <label for="contactname" class="required">
- [% ELSE %]
- <label for="contactname">
- [% END %]
- Guarantor surname:
- </label>
- <input type="text" id="contactname" name="contactname" value="[% patron.contactname | html %]" />
- [% IF ( mandatorycontactname ) %]
- <span class="required">Required</span>
- [% END %]
- <div class="hint">Non-patron guarantor surname</div>
- </li>
- [% END # /UNLESS nocontactname %]
-
- [% UNLESS nocontactfirstname %]
- <li>
- [% IF ( mandatorycontactfirstname ) %]
- <label for="contactfirstname" class="required">
- [% ELSE %]
- <label for="contactfirstname">
- [% END %]
- Guarantor first name:
- </label>
- <input type="text" id="contactfirstname" name="contactfirstname" value="[% patron.contactfirstname | html %]" />
- [% IF ( mandatorycontactfirstname ) %]
- <span class="required">Required</span>
- [% END %]
- <div class="hint">Non-patron guarantor first name</div>
- </li>
- [% END # /UNLESS noaltcontactfirstname %]
-
- [% UNLESS norelationship %]
- [% IF possible_relationships %]
- <li>
- <label for="relationship">Relationship: </label>
- <select class="relationship" name="relationship">
- <option value=""></option>
- [% FOREACH pr IN possible_relationships.split('\|') %]
- [% IF pr == relationship %]
- <option value="[% pr | html %]" selected="selected">[% pr | html %]</option>
- [% ELSE %]
- <option value="[% pr | html %]">[% pr | html %]</option>
- [% END %]
- [% END %]
- </select>
- </li>
- [% END #/IF possible_relationships %]
- [% END # /UNLESS norelationship %]
-
[% UNLESS nophone %]
<li>
[% IF ( mandatoryphone ) %]
[% END %]
Primary email:
</label>
+ [% IF ( NoUpdateEmail ) %]
+ <input type="text" id="email" name="email" size="45" value="[% patron.email | html %]" disabled="disabled" />
+ [% ELSE %]
<input type="text" id="email" name="email" size="45" value="[% patron.email | html %]" />
+ [% END %]
[% IF ( mandatoryemail ) %]
<span class="required">Required</span>
[% END %]
[% END %]
Secondary email:
</label>
+ [% IF ( NoUpdateEmail ) %]
+ <input type="text" id="emailpro" name="emailpro" size="45" value="[% patron.emailpro | html %]" disabled="disabled"/>
+ [% ELSE %]
<input type="text" id="emailpro" name="emailpro" size="45" value="[% patron.emailpro | html %]" />
+ [% END %]
[% IF ( mandatoryemailpro ) %]
<span class="required">Required</span>
[% END %]
</li>
- [% END # /UNLESS noemailpro %]
+ [% END #/UNLESS noemailpro %]
[% UNLESS nofax %]
<li>
[% END %]
</li>
[% END #/UNLESS nofax %]
+
+ [% UNLESS noprimary_contact_method %]
+ <li>
+ [% IF mandatoryprimary_contact_method %]
+ <label for="primary_contact_method" class="required">
+ [% ELSE %]
+ <label for="primary_contact_method">
+ [% END %]
+ Main contact method: </label>
+
+ <select id="primary_contact_method" name="primary_contact_method">
+ <option value=""></option>
+ [% UNLESS nophone %]
+ [% IF ( borrower_data.primary_contact_method == 'phone' ) %]
+ <option value="phone" selected="selected">Primary phone</option>
+ [% ELSE %]
+ <option value="phone">Primary phone</option>
+ [% END %]
+ [% END %]
+ [% UNLESS nophonepro %]
+ [% IF ( borrower_data.primary_contact_method == 'phonepro' ) %]
+ <option value="phonepro" selected="selected">Secondary phone</option>
+ [% ELSE %]
+ <option value="phonepro">Secondary phone</option>
+ [% END %]
+ [% END %]
+ [% UNLESS nomobile %]
+ [% IF ( borrower_data.primary_contact_method == 'mobile' ) %]
+ <option value="mobile" selected="selected">Other phone</option>
+ [% ELSE %]
+ <option value="mobile">Other phone</option>
+ [% END %]
+ [% END %]
+ [% UNLESS noemail %]
+ [% IF ( borrower_data.primary_contact_method == 'email' ) %]
+ <option value="email" selected="selected">Primary email</option>
+ [% ELSE %]
+ <option value="email">Primary email</option>
+ [% END %]
+ [% END %]
+ [% UNLESS noemailpro %]
+ [% IF ( borrower_data.primary_contact_method == 'emailpro' ) %]
+ <option value="emailpro" selected="selected">Secondary email</option>
+ [% ELSE %]
+ <option value="emailpro">Secondary email</option>
+ [% END %]
+ [% END %]
+ [% UNLESS nofax %]
+ [% IF ( borrower_data.primary_contact_method == 'fax' ) %]
+ <option value="fax" selected="selected">Fax</option>
+ [% ELSE %]
+ <option value="fax">Fax</option>
+ [% END %]
+ [% END %]
+ </select>
+ [% IF mandatoryprimary_contact_method %]
+ <span class="required">Required</span>
+ [% END %]
+ </li>
+ [% END %]
</ol>
</fieldset> <!-- /#memberentry_contact -->
[% END # hide fieldset %]
[% 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 %]
- [% INCLUDE 'member-alt-contact-style-us.inc' %]
- [% END %]
+ [% PROCESS 'alt-contact-style' %]
[% END # UNLESS noaltcontactsurname && noaltcontactfirstname etc %]
[% END # /IF ( step_2 ) %]
<!-- 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 | html %]" maxlength="[% maxlength_cardnumber | html %]" />
+ <input type="text" id="cardnumber" name="cardnumber" size="20" value="[% borrower_data.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 | html %]" maxlength="[% maxlength_cardnumber | html %]" />
+ <input type="text" id="cardnumber" name="cardnumber" size="20" value="[% borrower_data.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 | html %]" />
+ <input type="text" id="cardnumber" name="cardnumber" size="20" value="[% borrower_data.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 %]" />
+ <input type="text" id="cardnumber" name="cardnumber" size="20" value="[% borrower_data.cardnumber | html %]" />
[% IF mandatorycardnumber %]
<span class="required">Required</span>
[% END %]
[% 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>
+ <br/><span class="error">AutoMemberNum is set to enabled, but card number is marked as mandatory in BorrowerMandatoryField: auto calc has been disabled.</span>
[% ELSE %]
<br/>Leave blank for auto calc during registration
[% END %]
[% UNLESS nobranchcode %]
<li>
<label for="libraries" class="required">Library:</label>
- <select name="branchcode" size="1" id="libraries">
+ <select name="branchcode" id="libraries">
[% PROCESS options_for_libraries libraries => Branches.all( selected => userbranch, only_from_group => 1 ) %]
</select>
<span class="required">Required</span>
<li>
<label for="categorycode_entry" class="required">Category: </label>
<select id="categorycode_entry" name="categorycode">
- [% FOREACH typeloo IN typeloop %]
- [% FOREACH categoryloo IN typeloo.categoryloop %]
- [% IF ( loop.first ) %]
- [% IF ( typeloo.typename_C ) %]<optgroup label="Child">[% END %]
- [% IF ( typeloo.typename_A ) %]<optgroup label="Adult">[% END %]
- [% IF ( typeloo.typename_S ) %]<optgroup label="Staff">[% END %]
- [% IF ( typeloo.typename_I ) %]<optgroup label="Organization">[% END %]
- [% IF ( typeloo.typename_P ) %]<optgroup label="Professional">[% END %]
- [% IF ( typeloo.typename_X ) %]<optgroup label="Statistical">[% END %]
- [% END %]
- [% IF ( categoryloo.categorycodeselected ) %]
- <option value="[% categoryloo.categorycode | html %]" selected="selected" data-typename="[% typeloo.typename | html %]">[% categoryloo.categoryname | html %]</option>
+ [% FOREACH category_type IN patron_categories.keys %]
+ [% SWITCH category_type %]
+ [% CASE 'C' %]
+ <optgroup label="Child">
+ [% CASE 'A' %]
+ <optgroup label="Adult">
+ [% CASE 'S' %]
+ <optgroup label="Staff">
+ [% CASE 'I' %]
+ <optgroup label="Organization">
+ [% CASE 'P' %]
+ <optgroup label="Professional">
+ [% CASE 'X' %]
+ <optgroup label="Statistical">
+ [% CASE %]
+ <optgroup label="Unknown">
+ [% END %]
+ [% FOREACH category IN patron_categories.$category_type %]
+ [% IF category.categorycode == patron_category.categorycode %]
+ <option value="[% category.categorycode | html %]" selected="selected" data-pwd-length="[% category.effective_min_password_length | html %]" data-pwd-strong="[% category.effective_require_strong_password | html %]" data-typename="[% category_type | html %]">[% category.description | html %]</option>
[% ELSE %]
- <option value="[% categoryloo.categorycode | html %]" data-typename="[% typeloo.typename | html %]">[% categoryloo.categoryname | html %]</option>
+ <option value="[% category.categorycode | html %]" data-pwd-length="[% category.effective_min_password_length | html %]" data-pwd-strong="[% category.effective_require_strong_password | html %]" data-typename="[% category_type | html %]">[% category.description | html %]</option>
[% END %]
- [% IF ( loop.last ) %]
- </optgroup>
- [% END %]
- [% END # /FOREACH categoryloo %]
- [% END # /FOREACH typeloo %]
+ [% END %]
+ </optgroup>
+ [% END %]
</select>
<span class="required">Required</span>
</li>
[% END %]
Sort 1:
</label>
- [% PROCESS 'av-build-dropbox.inc' name="sort1", category="Bsort1", default=sort1, empty=1, size = 20 %]
+ [% PROCESS 'av-build-dropbox.inc' name="sort1", category="Bsort1", default=borrower_data.sort1, empty=1, size = 20 %]
[% IF ( mandatorysort1 ) %]
<span class="required">Required</span>
[% END %]
[% END %]
Sort 2:
</label>
- [% PROCESS 'av-build-dropbox.inc' name="sort2", category="Bsort2", default=sort2, empty=1, size = 20 %]
+ [% PROCESS 'av-build-dropbox.inc' name="sort2", category="Bsort2", default=borrower_data.sort2, empty=1, size = 20 %]
[% IF ( mandatorysort2 ) %]
<span class="required">Required</span>
[% END %]
<label for="yes-autorenew_checkouts">
Allow auto-renewal of items:
</label>
- [% IF ( autorenew_checkouts || opadd ) %]
+ [% IF ( borrower_data.autorenew_checkouts || opadd ) %]
<label for="yes-autorenew_checkouts">
Yes
<input type="radio" id="yes-autorenew_checkouts" name="autorenew_checkouts" value="1" checked="checked" />
<li>
<label for="checkprevcheckout">Check for previous checkouts: </label>
<select name="checkprevcheckout" id="checkprevcheckout">
- [% IF ( checkprevcheckout == 'yes' ) %]
+ [% IF ( borrower_data.checkprevcheckout == 'yes' ) %]
<option value="yes" selected="selected">Yes if settings allow it</option>
<option value="no">No if settings allow it</option>
<option value="inherit">Inherit from settings</option>
- [% ELSIF ( checkprevcheckout == 'no' ) %]
+ [% ELSIF ( borrower_data.checkprevcheckout == 'no' ) %]
<option value="yes">Yes if settings allow it</option>
<option value="no" selected="selected">No if settings allow it</option>
<option value="inherit">Inherit from settings</option>
[% FOR language IN languages %]
[% FOR sublanguage IN language.sublanguages_loop %]
[% IF language.plural %]
- [% IF sublanguage.rfc4646_subtag == lang %]
+ [% IF sublanguage.rfc4646_subtag == borrower_data.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 %]
+ [% IF sublanguage.rfc4646_subtag == borrower_data.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>
[% UNLESS nodateenrolled && noopacnote && noborrowernotes %]
<fieldset class="rows" id="memberentry_subscription">
- <legend id="library_setup_lgd">Library set-up</legend><ol>
+ <legend id="library_setup_lgd">Library setup</legend><ol>
[% UNLESS nodateenrolled %]
<li>
[% IF ( mandatorydateenrolled ) %]
[% END %]
Registration date:
</label>
- <input type="text" id="from" name="dateenrolled" maxlength="10" size="10" value="[% dateenrolled | html %]" class="datepickerfrom" />
+ <input type="text" id="from" name="dateenrolled" maxlength="10" size="10" value="[% borrower_data.dateenrolled | html %]" class="flatpickr" data-date_to="to" />
[% IF ( mandatorydateenrolled ) %]
<span class="required">Required</span>
[% END %]
Expiry date (leave blank for auto calc):
</label>
[% UNLESS ( opadd ) %]
- <input type="text" id="to" name="dateexpiry" maxlength="10" size="10" value="[% dateexpiry | html UNLESS opduplicate %]" class="datepickerto" />
+ <input type="text" id="to" name="dateexpiry" maxlength="10" size="10" value="[% borrower_data.dateexpiry | html UNLESS opduplicate %]" class="flatpickr" />
[% ELSE %]
- <input type="text" id="to" name="dateexpiry" maxlength="10" size="10" value="[% dateexpiry | html %]" class="datepickerto" />
+ <input type="text" id="to" name="dateexpiry" maxlength="10" size="10" value="[% borrower_data.dateexpiry | html %]" class="flatpickr" />
[% END %]
[% IF ( mandatorydateexpiry ) %]
<span class="required">Required</span>
[% END %]
OPAC note:
</label>
- <textarea id="opacnote" name="opacnote" cols="55" rows="5">[% opacnote | html UNLESS opduplicate %]</textarea>
+ <textarea id="opacnote" name="opacnote" cols="55" rows="5">[% borrower_data.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 %]
Circulation note:
</label>
- <textarea id="borrowernotes" name="borrowernotes" cols="55" rows="5">[% borrowernotes | html UNLESS opduplicate %]</textarea>
+ <textarea id="borrowernotes" name="borrowernotes" cols="55" rows="5">[% borrower_data.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>
</fieldset> <!-- /#memberentry_subscription -->
[% END # hide fieldset %]
- [% UNLESS nouserid && nopassword %]
+ [% UNLESS nouserid && nopassword && !CanUpdatePasswordExpiration %]
<fieldset class="rows" id="memberentry_userid">
- <legend id="opac_staff_login_lgd">OPAC/Staff login</legend>
+ <legend id="opac_staff_login_lgd">OPAC/Staff interface login</legend>
<ol>
[% UNLESS nouserid %]
<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 | html %]" />
+ <input type="text" id="userid" name="userid" size="20" disabled="disabled" value="[% borrower_data.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 | html %]" />
+ <input type="text" id="userid" name="userid" size="20" value="[% borrower_data.userid | html %]" />
[% END %]
[% END # /IF ( NoUpdateLogin ) %]
[% 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 | html %]" />
+ <input type="password" id="password" name="password" size="20" disabled="disabled" value="[% borrower_data.password | html %]" />
[% END %]
[% ELSE %]
[% IF ( opduplicate ) %]
- <input type="password" id="password" name="password" size="20" />
+ <input type="password" id="password" name="password" size="20" autocomplete="new-password" />
[% ELSE %]
- <input type="password" id="password" name="password" size="20" value="[% password | html %]" />
+ <input type="password" id="password" name="password" size="20" autocomplete="new-password" value="[% borrower_data.password | html %]" />
[% END %]
[% END # /IF ( NoUpdateLogin ) %]
[% ELSE # IF ( opadd ) %]
- [% IF ( password ) %]
+ [% IF ( borrower_data.password ) %]
[% IF ( NoUpdateLogin ) %]
<input type="password" id="password" name="password" size="20" disabled="disabled" value="****" />
[% ELSE %]
[% IF ( opduplicate ) %]
- <input type="password" id="password" name="password" size="20" />
+ <input type="password" id="password" name="password" autocomplete="new-password" size="20" />
[% ELSE %]
<input type="password" id="password" name="password" size="20" value="****" />
[% END %]
[% IF ( NoUpdateLogin ) %]
<input type="password" id="password" name="password" size="20" disabled="disabled" value="" />
[% ELSE %]
- <input type="password" id="password" name="password" size="20" value="" />
+ <input type="password" id="password" name="password" size="20" autocomplete="new-password" value="" />
[% END %]
[% END # /IF ( password ) %]
[% END # /IF ( opadd ) %]
[% 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>
+ <div class="hint">Minimum password length: [% patron.category.effective_min_password_length | html %]</div>
</li>
<li>
[% 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 | html %]" />
+ <input type="password" id="password2" name="password2" size="20" disabled="disabled" value="[% borrower_data.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 | html %]" />
+ <input type="password" id="password2" name="password2" size="20" value="[% borrower_data.password | html %]" />
[% END %]
[% END %]
[% ELSE # IF ( opadd ) %]
- [% IF ( password ) %]
+ [% IF ( borrower_data.password ) %]
[% IF ( NoUpdateLogin ) %]
<input type="password" id="password2" name="password2" size="20" disabled="disabled" value="****" />
[% ELSE %]
[% END %]
</li>
[% END # /UNLESS nopassword %]
+ [% UNLESS ( !CanUpdatePasswordExpiration ) %]
+ <li>
+ <label for="password_expiration_date">Password expiration date:</label>
+ <input type="text" id="password_expiration_date" name="password_expiration_date" maxlength="10" size="10" value="[% password_expiration_date | html %]" class="flatpickr" />
+ </li>
+ [% END %]
</ol>
</fieldset> <!-- /#memberentry_userid -->
- [% END # UNLESS nouserid && nopassword %]
+ [% END # UNLESS nouserid && nopassword && !CanUpdatePasswordExpiration %]
<!--this zones are not necessary in modif mode -->
- [% UNLESS ( opadd || opduplicate ) %]
+ [% UNLESS ( opadd || opduplicate || ( nogonenoaddress && nolost ) ) %]
<fieldset class="rows" id="memberentry_account_flags">
<legend id="account_flags_lgd">Patron account flags</legend>
<ol class="radio">
- [% FOREACH flagloo IN flagloop %]
+ [% UNLESS nogonenoaddress %]
<li>
- <label class="radio" for="yes[% flagloo.name | html %]">
- [% IF ( flagloo.key == 'gonenoaddress' ) %]Gone no address:[% END %]
- [% IF ( flagloo.key == 'lost' ) %]Lost card:[% END %]
+ [% IF mandatorygonenoaddress %]
+ <label class="radio required" for="yesgonenoaddress">
+ [% ELSE %]
+ <label class="radio" for="yesgonenoaddress">
+ [% END %]
+ Gone no address:
</label>
[% IF CAN_user_circulate_manage_restrictions %]
- <label for="yes[% flagloo.name | html %]">
- [% IF ( flagloo.yes ) %]
- <input type="radio" id="yes[% flagloo.name | html %]" name="[% flagloo.name | html %]" value="1" checked="checked" />
+ <label for="yesgonenoaddress">
+ [% IF ( borrower_data.gonenoaddress ) %]
+ <input type="radio" id="yesgonenoaddress" name="gonenoaddress" value="1" checked="checked" />
[% ELSE %]
- <input type="radio" id="yes[% flagloo.name | html %]" name="[% flagloo.name | html %]" value="1" />
+ <input type="radio" id="yesgonenoaddress" name="gonenoaddress" value="1" />
[% END %]
Yes
</label>
- <label for="no[% flagloo.name | html %]">
- [% IF ( flagloo.no ) %]
- <input type="radio" id="no[% flagloo.name | html %]" name="[% flagloo.name | html %]" value="0" checked="checked"/>
+ <label for="nogonenoaddress">
+ [% IF ( borrower_data.gonenoaddress ) %]
+ <input type="radio" id="nogonenoaddress" name="gonenoaddress" value="0" />
[% ELSE %]
- <input type="radio" id="no[% flagloo.name | html %]" name="[% flagloo.name | html %]" value="0" />
+ <input type="radio" id="nogonenoaddress" name="gonenoaddress" value="0" checked="checked"/>
[% END %]
No
</label>
[% ELSE %]
- [% IF flagloo.yes %]Yes[% ELSE %]No[% END %]
+ [% IF borrower_data.gonenoaddress %]<span>Yes</span>[% ELSE %]<span>No</span>[% END %]
[% END # /IF CAN_user_circulate_manage_restrictions %]
+ [% IF mandatorygonenoaddress %]
+ <span class="required">Required</span>
+ [% END %]
</li>
- [% END # /FOREACH flagloo %]
+
+ [% END # /UNLESS nogonenoaddress %]
+ [% UNLESS nolost %]
+ <li>
+ [% IF mandatorylost %]
+ <label class="radio required" for="yeslost">
+ [% ELSE %]
+ <label class="radio" for="yeslost">
+ [% END %]
+ Lost card:
+ </label>
+ [% IF CAN_user_circulate_manage_restrictions %]
+ <label for="yeslost">
+ [% IF ( borrower_data.lost ) %]
+ <input type="radio" id="yeslost" name="lost" value="1" checked="checked" />
+ [% ELSE %]
+ <input type="radio" id="yeslost" name="lost" value="1" />
+ [% END %]
+ Yes
+ </label>
+ <label for="nolost">
+ [% IF ( borrower_data.lost ) %]
+ <input type="radio" id="nolost" name="lost" value="0" />
+ [% ELSE %]
+ <input type="radio" id="nolost" name="lost" value="0" checked="checked"/>
+ [% END %]
+ No
+ </label>
+ [% ELSE %]
+ [% IF borrower_data.lost %]<span>Yes</span>[% ELSE %]<span>No</span>[% END %]
+ [% END # /IF CAN_user_circulate_manage_restrictions %]
+ [% IF mandatorylost %]
+ <span class="required">Required</span>
+ [% END %]
+ </li>
+ [% END # /UNLESS nogonenoaddress %]
</ol>
</fieldset> <!-- /#memberentry_account_flags -->
</thead>
<tbody>
[% FOREACH d IN debarments %]
+ [% dtype = d.type %]
<tr>
- <td>[% d.type | html %]</td>
+ <td>[% restriction_types.$dtype.display_text | html %]</td>
<td>
[% IF d.comment.search('OVERDUES_PROCESS') %]
Restriction added by overdues process [% d.comment.remove('OVERDUES_PROCESS ') | $raw %]
[% IF d.expiration %]
[% d.expiration | $KohaDates %]
[% ELSE %]
- <i>Indefinite</i>
+ <em>Indefinite</em>
[% END %]
</td>
<td>[% d.created | $KohaDates %]</td>
<input type="hidden" id="add_debarment" name="add_debarment" value="0" />
<legend id="manual_restriction_lgd">Add manual restriction</legend>
<ol>
+ [% IF Koha.Preference('PatronRestrictionTypes') %]
+ <li>
+ <label for="debarred_type">Type:</label>
+ <select name="debarred_type">
+ [% FOREACH code IN restriction_types.keys %]
+ [% IF !restriction_types.$code.is_system %]
+ [% IF restriction_types.$code.is_default %]
+ <option value="[% code | html %]" selected>[% PROCESS restriction_type_description restriction=restriction_types.$code %]</option>
+ [% ELSE %]
+ <option value="[% code | html %]">[% PROCESS restriction_type_description restriction=restriction_types.$code %]</option>
+ [% END %]
+ [% END %]
+ [% END %]
+ </select>
+ </li>
+ [% END %]
<li>
<label for="debarred_comment">Comment: </label>
<input type="text" id="debarred_comment" name="debarred_comment" />
</li>
<li>
<label for="debarred_expiration">Expiration: </label>
- <input name="debarred_expiration" id="debarred_expiration" size="10" value="" class="datepicker" type="text" />
+ <input name="debarred_expiration" id="debarred_expiration" size="10" value="" class="flatpickr" type="text" />
<a href="#" id="clear_debarred_expiration">Clear date</a>
</li>
</ol>
[% END %]
[% FOREACH patron_attribute IN pa_loo.items %]
<li data-category_code="[% patron_attribute.category_code | html %]">
- <label for="[% patron_attribute.form_id | html %]">
- [% patron_attribute.description | html %]:
- </label>
+ [% IF patron_attribute.mandatory %]
+ <label for="[% patron_attribute.form_id | html %]" class="required" required="required">[% patron_attribute.description | html %]: </label>
+ [% ELSE %]
+ <label for="[% patron_attribute.form_id | html %]">[% patron_attribute.description | html %]: </label>
+ [% END %]
[% IF ( patron_attribute.use_dropdown ) %]
- <select id="[% patron_attribute.form_id | html %]" name="[% patron_attribute.form_id | html %]">
+ [% IF patron_attribute.mandatory %]
+ <select id="[% patron_attribute.form_id | html %]" name="[% patron_attribute.form_id | html %]" required="required">
+ [% ELSE %]
+ <select id="[% patron_attribute.form_id | html %]" name="[% patron_attribute.form_id | html %]">
+ [% END %]
<option value=""></option>
[% FOREACH auth_val_loo IN patron_attribute.auth_val_loop %]
[% IF auth_val_loo.authorised_value == patron_attribute.value %]
[% END %]
</select>
[% ELSE %]
+ [% IF patron_attribute.mandatory %]
+ <textarea rows="2" cols="30" id="[% patron_attribute.form_id | html %]" name="[% patron_attribute.form_id | html %]" required="required">[% patron_attribute.value | html %]</textarea>
+ [% ELSE %]
<textarea rows="2" cols="30" id="[% patron_attribute.form_id | html %]" name="[% patron_attribute.form_id | html %]">[% patron_attribute.value | html %]</textarea>
+ [% END %]
[% END # /IF ( patron_attribute.use_dropdown ) %]
<input type="hidden" id="[% patron_attribute.form_id | html %]_code" name="[% patron_attribute.form_id | html %]_code" value="[% patron_attribute.code | html %]" />
<a href="#" class="clear_attribute"><i class="fa fa-fw fa-trash"></i> Clear</a>
[% IF ( patron_attribute.repeatable ) %]
<a href="#" class="clone_attribute"><i class="fa fa-fw fa-plus"></i> New</a>
[% END %]
+ [% IF patron_attribute.mandatory %]<span class="required">Required</span>[% END %]
</li>
[% END # /FOREACH patron_attribute %]
[% IF pa_loo.class %]</fieldset>[% END %]
<p>
<label for="SMSnumber">SMS number:</label>
<input type="text" id="SMSnumber" name="SMSnumber" value="[% SMSnumber | html %]" />
- <span class="hint">SMS number should be in the format 1234567890 or +11234567890</span>
+ <span class="hint sms_number_help">Please enter numbers only. Prefix the number with + or 00 if including the country code.</span>
</p>
- [% UNLESS nosms_provider_id %]
+ [% IF SMSSendDriver == 'Email' && !nosms_provider_id %]
<p>
<label for="sms_provider_id">SMS provider:</label>
<select id="sms_provider_id" name="sms_provider_id">
<option value="">Unknown</option>
[% FOREACH s IN sms_providers %]
- [% IF s.id == sms_provider_id %]
+ [% IF s.id == borrower_data.sms_provider_id %]
<option value="[% s.id | html %]" selected="selected">[% s.name | html %]</option>
[% ELSE %]
<option value="[% s.id | html %]">[% s.name | html %]</option>
$("legend").click(function(){
$(this).nextAll().toggle();
$("#messaging_prefs_loading").hide();
+ $("#guarantor_template").hide();
});
$("#saverecord").css({ 'margin-left': 0 });
stickyClass: "floating"
});
- [% IF categorycode %]
- update_category_code( "[% categorycode | html %]" );
+ [% IF borrower_data.categorycode %]
+ update_category_code( "[% borrower_data.categorycode | html %]" );
[% ELSE %]
if ( $("#categorycode_entry").length > 0 ){
var category_code = $("#categorycode_entry").find("option:selected").val();
}
$(toggle_from).each(function() {
var input_label = $(this).attr('for');
- if ( input_label == 'sex-male' || input_label == 'sex-none' || input_label == 'sex-female' ) {
+ if ( input_label == 'sex-male' || input_label == 'sex-none' || input_label == 'sex-female' || input_label == 'sex-other' ) {
$(toggle_to+"[for='"+input_label+"']").next().prop('checked', $(this).next().prop('checked') );
return;
}
});
});
- 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 () {
input_label='title';
}
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 %]
+ let orig_li = $(this).parent();
+ if( orig_li.attr('class') == 'radio' ){
+ let new_field = orig_li.clone();
+ new_field.children('label').each(function(){
+ let child_input = $(this).children('input');
+ child_input.attr("id",child_input.attr("id") + "_quick_add");
+ });
+ new_field.appendTo("#quick_add_list");
+ } else {
+ let orig_input_id = orig_li.children("input,textarea,select").attr("id");
+ let new_field = orig_li.clone();
+ new_field.children("#"+orig_input_id).attr("id",orig_input_id + "_quick_add");
+ new_field.appendTo("#quick_add_list");
+ [% UNLESS mandatorypassword %]
+ if( input_label == 'password' ){
+ let orig_p2 = $("#entryform label[for='password2']").parent();
+ let new_p2 = orig_p2.clone();
+ new_p2.find('input[id="password2"]').attr("id","password2_quick_add");
+ new_p2.appendTo("#quick_add_list");
+ }
+ [% END %]
+ }
}
});
if ( $("#memberentry_guarantor").length ) {
</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' %]
+ [% PROCESS 'password_check.inc' new_password => 'password', category_selector => '#categorycode_entry', minPasswordLength => patron.category.effective_min_password_length, RequireStrongPassword => patron.category.effective_require_strong_password %]
[% END %]
[% INCLUDE 'intranet-bottom.inc' %]