Profile: when clicking "Generate Password", toggling visibility, then canceling, ensure that the UI resets properly for when the "Generate Password" button is clicked again.

Props umesh.nevase.
Fixes #33897.


git-svn-id: https://develop.svn.wordpress.org/trunk@34539 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Scott Taylor 2015-09-25 13:53:04 +00:00
parent a160be35b1
commit 5e95cd1db5

View File

@ -98,26 +98,31 @@
} ); } );
} }
function resetToggle() {
$toggleButton
.data( 'toggle', 0 )
.attr({
'aria-label': userProfileL10n.ariaHide
})
.find( '.text' )
.text( userProfileL10n.hide )
.end()
.find( '.dashicons' )
.removeClass( 'dashicons-visibility' )
.addClass( 'dashicons-hidden' );
$pass1Text.focus();
$pass1Label.attr( 'for', 'pass1-text' );
}
function bindToggleButton() { function bindToggleButton() {
$toggleButton = $pass1Row.find('.wp-hide-pw'); $toggleButton = $pass1Row.find('.wp-hide-pw');
$toggleButton.show().on( 'click', function () { $toggleButton.show().on( 'click', function () {
if ( 1 === parseInt( $toggleButton.data( 'toggle' ), 10 ) ) { if ( 1 === parseInt( $toggleButton.data( 'toggle' ), 10 ) ) {
$pass1Wrap.addClass( 'show-password' ); $pass1Wrap.addClass( 'show-password' );
$toggleButton
.data( 'toggle', 0 )
.attr({
'aria-label': userProfileL10n.ariaHide
})
.find( '.text' )
.text( userProfileL10n.hide )
.end()
.find( '.dashicons' )
.removeClass('dashicons-visibility')
.addClass('dashicons-hidden');
$pass1Text.focus(); resetToggle();
$pass1Label.attr( 'for', 'pass1-text' );
if ( ! _.isUndefined( $pass1Text[0].setSelectionRange ) ) { if ( ! _.isUndefined( $pass1Text[0].setSelectionRange ) ) {
$pass1Text[0].setSelectionRange( 0, 100 ); $pass1Text[0].setSelectionRange( 0, 100 );
@ -234,6 +239,8 @@
$generateButton.show(); $generateButton.show();
$passwordWrapper.hide(); $passwordWrapper.hide();
resetToggle();
// Clear password field to prevent update // Clear password field to prevent update
$pass1.val( '' ).trigger( 'pwupdate' ); $pass1.val( '' ).trigger( 'pwupdate' );
$submitButtons.prop( 'disabled', false ); $submitButtons.prop( 'disabled', false );