/* global ajaxurl, pwsL10n, userProfileL10n */ (function($){ $(function(){ var pw_new = $('.user-pass1-wrap'), pw_line = pw_new.find('.wp-pwd'), pw_field = $('#pass1'), pw_field2 = $('#pass2'), pw_togglebtn = pw_new.find('.wp-hide-pw'), pw_generatebtn = pw_new.find('button.wp-generate-pw'), pw_cancelbtn = pw_new.find('button.wp-cancel-pw'), pw_2 = $('.user-pass2-wrap'), parentform = pw_new.closest('form'), pw_strength = $('#pass-strength-result'), pw_submitbtn_edit = $('#submit'), pw_submitbtn_new = $( '#createusersub' ), pw_checkbox = $('.pw-checkbox'), pw_weak = $('.pw-weak'), pw_update_lock = false, // Set up a text version of the password input newField = document.createElement( 'input'); newField.type = 'text'; var pwFieldText = $( newField ); if ( pw_field.length > 0 ) { pwFieldText .attr( { 'id': 'pass1-text', 'name': 'pass1-text', 'autocomplete': 'off' } ) .addClass( pw_field[0].className ) .data( 'pw', pw_field.data( 'pw' ) ) .val( pw_field.val() ); pw_field .wrap( '' ) .after( pwFieldText ); } var pwWrapper = pw_field.parent(); var generatePassword = window.generatePassword = function() { if ( typeof zxcvbn !== 'function' ) { setTimeout( generatePassword, 50 ); } else { pw_field.val( pw_field.data( 'pw' ) ); pw_field.trigger( 'propertychange' ); pwWrapper.addClass( 'show-password' ); } }; pw_2.hide(); pw_line.hide(); pw_togglebtn.show(); pw_generatebtn.show(); if ( pw_field.data( 'reveal' ) == 1 ) { generatePassword(); } parentform.on('submit', function(){ pw_update_lock = false; pw_field2.val( pw_field.val() ); pwWrapper.removeClass( 'show-password' ); }); pwFieldText.on( 'input', function(){ pw_field.val( pwFieldText.val() ); pw_field.trigger( 'propertychange' ); } ); pw_field.on('input propertychange', function(){ setTimeout( function(){ var cssClass = pw_strength.attr('class'); pwFieldText.val( pw_field.val() ); pw_field.add(pwFieldText).removeClass( 'short bad good strong' ); if ( 'undefined' !== typeof cssClass ) { pw_field.add(pwFieldText).addClass( cssClass ); if ( cssClass == 'short' || cssClass == 'bad' ) { if ( ! pw_checkbox.attr( 'checked' ) ) { pw_submitbtn_new.attr( 'disabled','disabled' ); pw_submitbtn_edit.attr( 'disabled','disabled' ); } pw_weak.show(); } else { pw_submitbtn_new.removeAttr( 'disabled' ); pw_submitbtn_edit.removeAttr( 'disabled' ); pw_weak.hide(); } } }, 1 ); } ); pw_checkbox.change( function() { if ( pw_checkbox.attr( 'checked' ) ) { pw_submitbtn_new.removeAttr( 'disabled' ); pw_submitbtn_edit.removeAttr( 'disabled' ); } else { pw_submitbtn_new.attr( 'disabled','disabled' ); pw_submitbtn_edit.attr( 'disabled','disabled' ); } } ); /** * Fix a LastPass mismatch issue, LastPass only changes pass2. * * This fixes the issue by copying any changes from the hidden * pass2 field to the pass1 field. */ pw_field2.on( 'input propertychange', function() { if ( pw_field2.val().length > 0 ) { pw_field.val( pw_field2.val() ); pw_field.trigger( 'propertychange' ); } } ); pw_new.on( 'click', 'button.wp-generate-pw', function(){ pw_update_lock = true; pw_generatebtn.hide(); pw_line.show(); generatePassword(); _.defer( function() { pwFieldText.focus(); if ( ! _.isUndefined( pwFieldText[0].setSelectionRange ) ) { pwFieldText[0].setSelectionRange( 0, 100 ); } }, 0 ); }); pw_submitbtn_edit.on( 'click', function() { pw_update_lock = false; }); pw_cancelbtn.on( 'click', function() { pw_update_lock = false; pw_generatebtn.show(); pw_line.hide(); }); pw_togglebtn.on( 'click', function() { var show = pw_togglebtn.attr( 'data-toggle' ); if ( show == 1 ) { pwWrapper.addClass( 'show-password' ); pw_togglebtn.attr({ 'data-toggle': 0, 'aria-label': userProfileL10n.ariaHide }) .find( '.text' ).text( userProfileL10n.hide ) ; pwFieldText.focus(); if ( ! _.isUndefined( pwFieldText[0].setSelectionRange ) ) { pwFieldText[0].setSelectionRange( 0, 100 ); } } else { pwWrapper.removeClass( 'show-password' ); pw_togglebtn.attr({ 'data-toggle': 1, 'aria-label': userProfileL10n.ariaShow }) .find( '.text' ).text( userProfileL10n.show ); pw_field.focus(); if ( ! _.isUndefined( pw_field[0].setSelectionRange ) ) { pw_field[0].setSelectionRange( 0, 100 ); } } }); /* Warn the user if password was generated but not saved */ $( window ).on( 'beforeunload', function() { if ( true === pw_update_lock ) { return userProfileL10n.warn; } } ); }); function check_pass_strength() { var pass1 = $('#pass1').val(), pass2 = $('#pass2').val(), strength; $('#pass-strength-result').removeClass('short bad good strong'); if ( ! pass1 ) { $('#pass-strength-result').html( ' ' ); return; } strength = wp.passwordStrength.meter( pass1, wp.passwordStrength.userInputBlacklist(), pass2 ); switch ( strength ) { case 2: $('#pass-strength-result').addClass('bad').html( pwsL10n.bad ); break; case 3: $('#pass-strength-result').addClass('good').html( pwsL10n.good ); break; case 4: $('#pass-strength-result').addClass('strong').html( pwsL10n.strong ); break; case 5: $('#pass-strength-result').addClass('short').html( pwsL10n.mismatch ); break; default: $('#pass-strength-result').addClass('short').html( pwsL10n['short'] ); } } $(document).ready( function() { var $colorpicker, $stylesheet, user_id, current_user_id, select = $( '#display_name' ); $('#pass1').val('').on( 'input propertychange', check_pass_strength ); $('#pass2').val('').on( 'input propertychange', check_pass_strength ); $('#pass-strength-result').show(); $('.color-palette').click( function() { $(this).siblings('input[name="admin_color"]').prop('checked', true); }); if ( select.length ) { $('#first_name, #last_name, #nickname').bind( 'blur.user_profile', function() { var dub = [], inputs = { display_nickname : $('#nickname').val() || '', display_username : $('#user_login').val() || '', display_firstname : $('#first_name').val() || '', display_lastname : $('#last_name').val() || '' }; if ( inputs.display_firstname && inputs.display_lastname ) { inputs.display_firstlast = inputs.display_firstname + ' ' + inputs.display_lastname; inputs.display_lastfirst = inputs.display_lastname + ' ' + inputs.display_firstname; } $.each( $('option', select), function( i, el ){ dub.push( el.value ); }); $.each(inputs, function( id, value ) { if ( ! value ) { return; } var val = value.replace(/<\/?[a-z][^>]*>/gi, ''); if ( inputs[id].length && $.inArray( val, dub ) === -1 ) { dub.push(val); $('