Bug 22553: Unchecking a subpermission does not uncheck the top level permission
[koha.git] / koha-tmpl / intranet-tmpl / prog / en / modules / members / member-password.tt
1 [% USE raw %]
2 [% USE Asset %]
3 [% USE Koha %]
4 [% USE Branches %]
5 [% SET footerjs = 1 %]
6 [% INCLUDE 'doc-head-open.inc' %]
7 <title>Koha &rsaquo; Patrons &rsaquo; [% IF ( newpassword ) %]Password updated [% ELSE %]Update password for [% patron.surname | html %], [% patron.firstname | html %][% END %]</title>
8 [% INCLUDE 'doc-head-close.inc' %]
9 </head>
10
11 <body id="pat_member-password" class="pat">
12 [% INCLUDE 'header.inc' %]
13 [% INCLUDE 'patron-search.inc' %]
14
15 <div id="breadcrumbs"><a href="/cgi-bin/koha/mainpage.pl">Home</a> &rsaquo; <a href="/cgi-bin/koha/members/members-home.pl">Patrons</a>  &rsaquo; <a href="/cgi-bin/koha/members/moremember.pl?borrowernumber=[% patron.borrowernumber | html %]">[% patron.firstname | html %] [% patron.surname | html %]</a> &rsaquo; [% IF ( newpassword ) %]Password Updated[% ELSE %]Change username and/or password[% END %]</div>
16
17 <div class="main container-fluid">
18     <div class="row">
19         <div class="col-sm-10 col-sm-push-2">
20             <main>
21
22 [% INCLUDE 'members-toolbar.inc' %]
23
24 [% IF ( newpassword ) %]
25 <h1>Password Updated</h1>
26
27 [% ELSE %]
28
29 <form method="post" id="changepasswordf" action="/cgi-bin/koha/members/member-password.pl">
30 <input type="hidden" name="destination" value="[% destination | html %]" />
31 <input type="hidden" name="borrowernumber" id="borrowernumber" value="[% patron.borrowernumber | html %]" />
32         [% IF ( errormsg ) %]
33                 <div class="dialog alert">
34                 <h4>The following errors have occurred:</h4>
35                 <ul>
36                 [% IF ( BADUSERID ) %]
37         <li>You have entered a username that already exists. Please choose another one.</li>
38                 [% END %]
39         [% IF ( ERROR_password_too_short ) %]
40             <li id="ERROR_short_password">Password must be at least [% Koha.Preference('minPasswordLength') | html %] characters long.</li>
41         [% END %]
42         [% IF ( ERROR_password_too_weak ) %]
43             <li id="ERROR_weak_password">Password must contain at least one digit, one lowercase and one uppercase.</li>
44         [% END %]
45         [% IF ( ERROR_password_has_whitespaces ) %]
46             <li id="ERROR_weak_password">Password must not contain leading or trailing whitespaces.</li>
47         [% END %]
48                 [% IF ( NOPERMISSION ) %]
49                 <li>You do not have permission to edit this patron's login information.</li>
50                 [% END %]
51                 [% IF ( NOMATCH ) %]
52                 <li><strong>The passwords entered do not match</strong>. Please re-enter the new password.</li>
53                 [% END %]
54                 </ul>
55                 </div>
56         [% END %]
57
58
59     <fieldset class="brief"><legend>Change username and/or password for [% patron.firstname | html %] [% patron.surname | html %]</legend>
60         <ol>
61     <li><label for="newuserid">New username:</label>
62     <input type="hidden" name="member" value="[% patron.borrowernumber | html %]" /><input type="text" id="newuserid" name="newuserid" size="20" value="[% patron.userid | html %]" /></li>
63     [% SET password_pattern = ".{" _ Koha.Preference('minPasswordLength') _ ",}" %]
64     [% IF Koha.Preference('RequireStrongPassword') %]
65         [% SET password_pattern = '(?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{' _ Koha.Preference('minPasswordLength') _ ',}' %]
66     [% END %]
67     <li>
68         <label for="newpassword">New password:</label>
69         <div class="hint">Koha cannot display existing passwords. Leave the field blank to leave password unchanged.</div>
70         <input name="newpassword"  id="newpassword" type="password" size="20" />
71     </li>
72     <li>
73         <label for="newpassword2">Confirm new password:</label>
74         <input name="newpassword2"  id="newpassword2" type="password" size="20" />
75     </li>
76         </ol>
77 </fieldset>
78     <fieldset class="action">
79         <input type="hidden" name="csrf_token" value="[% csrf_token | html %]" />
80         <input type="submit" value="Save" />
81         <a class="cancel" href="/cgi-bin/koha/members/moremember.pl?borrowernumber=[% patron.borrowernumber | html %]">Cancel</a>
82     </fieldset>
83 </form>[% END %]
84
85
86 <div class="loading hide"><strong>Processing...</strong><img src="[% interface | html %]/[% theme | html %]/img/loading.gif" alt="" /></div>
87
88             </main>
89         </div> <!-- /.col-sm-10.col-sm-push-2 -->
90
91         <div class="col-sm-2 col-sm-pull-10">
92             <aside>
93                 [% INCLUDE 'circ-menu.inc' %]
94             </aside>
95         </div> <!-- /.col-sm-2.col-sm-pull-10 -->
96     </div> <!-- /.row -->
97
98 [% MACRO jsinclude BLOCK %]
99     [% Asset.js("js/members-menu.js") | $raw %]
100     <script>
101         function generate_password() {
102             // Always generate a strong password
103             var chars = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
104             var length = [% Koha.Preference('minPasswordLength') | html %];
105             if ( length < 8 ) length = 8;
106             var password='';
107             for ( var i = 0 ; i < length ; i++){
108                 password += chars.charAt(Math.floor(Math.random()*chars.length));
109             }
110             return password;
111         }
112         $(document).ready(function() {
113             $("body").on('click', "#fillrandom",function(e) {
114                 e.preventDefault();
115                 var password = '';
116                 var pattern_regex = /(?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{[% Koha.Preference('minPasswordLength') | html %],}/;
117                 while ( ! pattern_regex.test( password ) ) {
118                     password = generate_password();
119                 }
120                 $("#newpassword").val(password);
121                 $("#newpassword").attr('type', 'text');
122                 $("#newpassword2").val(password);
123                 $("#newpassword2").attr('type', 'text');
124             });
125             $("div.hint").eq(0).after(" <div class=\"hint\"><a href=\"#\" id=\"fillrandom\">"+_("Click to fill with a randomly generated suggestion. ")+"<strong>"+_("Passwords will be displayed as text")+"</strong>.</a></div>");
126
127             $(document).ajaxStart(function () {
128                 $("input[name^=newpassword]").hide();
129                 $("label[for=newpassword2]").hide();
130                 $(".hint:last").after($(".loading").show());
131             });
132             $(document).ajaxStop(function () {
133                 $("input[name^=newpassword]").show();
134                 $("label[for=newpassword2]").show();
135                 $(".loading").hide();
136                 $("label.error").hide();
137             });
138             [% IF NOMATCH %]
139                 $("#newpassword").addClass('focus');
140             [% END %]
141
142             $("#changepasswordf").validate({
143                 rules: {
144                     newpassword: {
145                         password_strong: true,
146                         password_no_spaces: true
147                     },
148                     newpassword2: {
149                         password_match: true
150                     }
151                 }
152             });
153         });
154     </script>
155     [% PROCESS 'password_check.inc' %]
156     [% PROCESS 'add_password_check' new_password => 'newpassword' %]
157 [% END %]
158
159 [% INCLUDE 'intranet-bottom.inc' %]