diff --git src/wp-admin/js/password-strength-meter.js src/wp-admin/js/password-strength-meter.js
index 2ac7e86..f42699a 100644
|
|
var passwordStrength; |
18 | 18 | if (password1 != password2 && password2 && password2.length > 0) |
19 | 19 | return 5; |
20 | 20 | |
| 21 | if ( 'undefined' === typeof window.zxcvbn ) { |
| 22 | // Password strength unknown |
| 23 | return -1; |
| 24 | } |
| 25 | |
21 | 26 | var result = zxcvbn( password1, blacklist ); |
22 | 27 | return result.score; |
23 | 28 | }, |
diff --git src/wp-admin/js/user-profile.js src/wp-admin/js/user-profile.js
index 5ec77bc..3a37f2d 100644
|
|
|
30 | 30 | function generatePassword() { |
31 | 31 | if ( typeof zxcvbn !== 'function' ) { |
32 | 32 | setTimeout( generatePassword, 50 ); |
33 | | } else { |
| 33 | return; |
| 34 | } else if ( ! $pass1.val() ) { |
| 35 | // zxcvbn loaded before user entered password. |
34 | 36 | $pass1.val( $pass1.data( 'pw' ) ); |
35 | 37 | $pass1.trigger( 'pwupdate' ).trigger( 'wp-check-valid-field' ); |
36 | | if ( 1 !== parseInt( $toggleButton.data( 'start-masked' ), 10 ) ) { |
37 | | $pass1Wrap.addClass( 'show-password' ); |
38 | | } else { |
39 | | $toggleButton.trigger( 'click' ); |
40 | | } |
41 | 38 | } |
| 39 | else { |
| 40 | // zxcvbn loaded after the user entered password, check strength. |
| 41 | check_pass_strength(); |
| 42 | showOrHideWeakPasswordCheckbox(); |
| 43 | } |
| 44 | |
| 45 | if ( 1 !== parseInt( $toggleButton.data( 'start-masked' ), 10 ) ) { |
| 46 | $pass1Wrap.addClass( 'show-password' ); |
| 47 | } else { |
| 48 | $toggleButton.trigger( 'click' ); |
| 49 | } |
| 50 | |
| 51 | // Once zxcvbn loads, passwords strength is known. |
| 52 | $( '#pw-weak-text-label' ).html( userProfileL10n.warnWeak ); |
42 | 53 | } |
43 | 54 | |
44 | 55 | function bindPass1() { |
45 | | var passStrength = $('#pass-strength-result')[0]; |
46 | | |
47 | 56 | currentPass = $pass1.val(); |
48 | 57 | |
49 | 58 | $pass1Wrap = $pass1.parent(); |
… |
… |
|
82 | 91 | $pass1Text.val( currentPass ); |
83 | 92 | } |
84 | 93 | $pass1.add( $pass1Text ).removeClass( 'short bad good strong' ); |
85 | | |
86 | | if ( passStrength.className ) { |
87 | | $pass1.add( $pass1Text ).addClass( passStrength.className ); |
88 | | if ( 'short' === passStrength.className || 'bad' === passStrength.className ) { |
89 | | if ( ! $weakCheckbox.prop( 'checked' ) ) { |
90 | | $submitButtons.prop( 'disabled', true ); |
91 | | } |
92 | | $weakRow.show(); |
93 | | } else { |
94 | | $submitButtons.prop( 'disabled', false ); |
95 | | $weakRow.hide(); |
96 | | } |
97 | | } |
| 94 | showOrHideWeakPasswordCheckbox(); |
98 | 95 | } ); |
99 | 96 | } |
100 | 97 | |
… |
… |
|
289 | 286 | strength = wp.passwordStrength.meter( pass1, wp.passwordStrength.userInputBlacklist(), pass1 ); |
290 | 287 | |
291 | 288 | switch ( strength ) { |
| 289 | case -1: |
| 290 | $( '#pass-strength-result' ).addClass( 'bad' ).html( pwsL10n.unknown ); |
| 291 | break; |
292 | 292 | case 2: |
293 | 293 | $('#pass-strength-result').addClass('bad').html( pwsL10n.bad ); |
294 | 294 | break; |
… |
… |
|
306 | 306 | } |
307 | 307 | } |
308 | 308 | |
| 309 | function showOrHideWeakPasswordCheckbox() { |
| 310 | var passStrength = $('#pass-strength-result')[0]; |
| 311 | |
| 312 | if ( passStrength.className ) { |
| 313 | $pass1.add( $pass1Text ).addClass( passStrength.className ); |
| 314 | if ( 'short' === passStrength.className || 'bad' === passStrength.className ) { |
| 315 | if ( ! $weakCheckbox.prop( 'checked' ) ) { |
| 316 | $submitButtons.prop( 'disabled', true ); |
| 317 | } |
| 318 | $weakRow.show(); |
| 319 | } else { |
| 320 | $submitButtons.prop( 'disabled', false ); |
| 321 | $weakRow.hide(); |
| 322 | } |
| 323 | } |
| 324 | } |
| 325 | |
309 | 326 | $(document).ready( function() { |
310 | 327 | var $colorpicker, $stylesheet, user_id, current_user_id, |
311 | 328 | select = $( '#display_name' ); |
diff --git src/wp-admin/user-edit.php src/wp-admin/user-edit.php
index 46ac066..83b886f 100644
|
|
if ( $show_password_fields = apply_filters( 'show_password_fields', true, $profi |
531 | 531 | <td> |
532 | 532 | <label> |
533 | 533 | <input type="checkbox" name="pw_weak" class="pw-checkbox" /> |
534 | | <?php _e( 'Confirm use of weak password' ); ?> |
| 534 | <span id="pw-weak-text-label"><?php _e( 'Confirm use of potentially weak password' ); ?></span> |
535 | 535 | </label> |
536 | 536 | </td> |
537 | 537 | </tr> |
diff --git src/wp-includes/script-loader.php src/wp-includes/script-loader.php
index e111842..2a6b433 100644
|
|
function wp_default_scripts( &$scripts ) { |
379 | 379 | |
380 | 380 | $scripts->add( 'password-strength-meter', "/wp-admin/js/password-strength-meter$suffix.js", array( 'jquery', 'zxcvbn-async' ), false, 1 ); |
381 | 381 | did_action( 'init' ) && $scripts->localize( 'password-strength-meter', 'pwsL10n', array( |
| 382 | 'unknown' => _x( 'Password strength unknown', 'password strength' ), |
382 | 383 | 'short' => _x( 'Very weak', 'password strength' ), |
383 | 384 | 'bad' => _x( 'Weak', 'password strength' ), |
384 | 385 | 'good' => _x( 'Medium', 'password strength' ), |
… |
… |
function wp_default_scripts( &$scripts ) { |
389 | 390 | $scripts->add( 'user-profile', "/wp-admin/js/user-profile$suffix.js", array( 'jquery', 'password-strength-meter', 'wp-util' ), false, 1 ); |
390 | 391 | did_action( 'init' ) && $scripts->localize( 'user-profile', 'userProfileL10n', array( |
391 | 392 | 'warn' => __( 'Your new password has not been saved.' ), |
| 393 | 'warnWeak' => __( 'Confirm use of weak password.' ), |
392 | 394 | 'show' => __( 'Show' ), |
393 | 395 | 'hide' => __( 'Hide' ), |
394 | 396 | 'cancel' => __( 'Cancel' ), |