Passwords: New UI for install screen.

Also synchronises the use of `pw_weak` as an input name and removes trailing
periods from checkbox labels.

Props MikeHansenMe, adamsilverstein, obenland.
See #32589.


Built from https://develop.svn.wordpress.org/trunk@33246


git-svn-id: http://core.svn.wordpress.org/trunk@33218 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
Konstantin Obenland 2015-07-13 22:22:24 +00:00
parent 8ef2cd1537
commit 7e3f0cf45e
9 changed files with 161 additions and 62 deletions

View File

@ -121,7 +121,6 @@ textarea {
.form-table td { .form-table td {
margin-bottom: 9px; margin-bottom: 9px;
padding: 10px 0 10px 20px; padding: 10px 0 10px 20px;
border-bottom: 8px solid #fff;
font-size: 14px; font-size: 14px;
vertical-align: top vertical-align: top
} }
@ -171,7 +170,7 @@ submit {
.form-table.install-success td { .form-table.install-success td {
vertical-align: middle; vertical-align: middle;
padding: 16px 0 10px 20px; padding: 16px 0 16px 20px;
} }
.form-table.install-success td p { .form-table.install-success td p {
@ -198,36 +197,64 @@ submit {
font-family: Consolas, Monaco, monospace; font-family: Consolas, Monaco, monospace;
} }
.wp-hide-pw > .dashicons {
line-height: inherit;
}
#pass-strength-result { #pass-strength-result {
background-color: #eee; background-color: #eee;
border-color: #ddd !important; border: 1px solid #ddd;
border-style: solid; -webkit-box-sizing: border-box;
border-width: 1px; -moz-box-sizing: border-box;
margin: 5px 0 5px 5px; box-sizing: border-box;
padding: 5px; opacity: 0;
padding: 3px 5px;
text-align: center; text-align: center;
width: 200px; width: 218px;
display: none;
}
#pass-strength-result.bad {
background-color: #ffb78c;
border-color: #ff853c !important;
}
#pass-strength-result.good {
background-color: #ffec8b;
border-color: #ffcc00 !important;
} }
#pass-strength-result.short { #pass-strength-result.short {
background-color: #ffa0a0; background-color: #ffa0a0;
border-color: #f04040 !important; border-color: #f04040;
opacity: 1;
}
#pass-strength-result.bad {
background-color: #ffb78c;
border-color: #ff853c;
opacity: 1;
}
#pass-strength-result.good {
background-color: #ffec8b;
border-color: #fc0;
opacity: 1;
} }
#pass-strength-result.strong { #pass-strength-result.strong {
background-color: #c3ff88; background-color: #c3ff88;
border-color: #8dff1c !important; border-color: #8dff1c;
opacity: 1;
}
[name="admin_password"].short {
border-color: #f04040;
}
[name="admin_password"].bad {
border-color: #ff853c;
}
[name="admin_password"].good {
border-color: #fc0;
}
[name="admin_password"].strong {
border-color: #8dff1c;
}
.pw-weak {
display: none;
} }
.message { .message {
@ -374,6 +401,11 @@ body.language-chooser {
vertical-align: top; vertical-align: top;
} }
.button-secondary.hide-if-no-js,
.hide-if-no-js {
display: none;
}
/** /**
* HiDPI Displays * HiDPI Displays
*/ */

File diff suppressed because one or more lines are too long

View File

@ -121,7 +121,6 @@ textarea {
.form-table td { .form-table td {
margin-bottom: 9px; margin-bottom: 9px;
padding: 10px 20px 10px 0; padding: 10px 20px 10px 0;
border-bottom: 8px solid #fff;
font-size: 14px; font-size: 14px;
vertical-align: top vertical-align: top
} }
@ -171,7 +170,7 @@ submit {
.form-table.install-success td { .form-table.install-success td {
vertical-align: middle; vertical-align: middle;
padding: 16px 20px 10px 0; padding: 16px 20px 16px 0;
} }
.form-table.install-success td p { .form-table.install-success td p {
@ -198,36 +197,64 @@ submit {
font-family: Consolas, Monaco, monospace; font-family: Consolas, Monaco, monospace;
} }
.wp-hide-pw > .dashicons {
line-height: inherit;
}
#pass-strength-result { #pass-strength-result {
background-color: #eee; background-color: #eee;
border-color: #ddd !important; border: 1px solid #ddd;
border-style: solid; -webkit-box-sizing: border-box;
border-width: 1px; -moz-box-sizing: border-box;
margin: 5px 5px 5px 0; box-sizing: border-box;
padding: 5px; opacity: 0;
padding: 3px 5px;
text-align: center; text-align: center;
width: 200px; width: 218px;
display: none;
}
#pass-strength-result.bad {
background-color: #ffb78c;
border-color: #ff853c !important;
}
#pass-strength-result.good {
background-color: #ffec8b;
border-color: #ffcc00 !important;
} }
#pass-strength-result.short { #pass-strength-result.short {
background-color: #ffa0a0; background-color: #ffa0a0;
border-color: #f04040 !important; border-color: #f04040;
opacity: 1;
}
#pass-strength-result.bad {
background-color: #ffb78c;
border-color: #ff853c;
opacity: 1;
}
#pass-strength-result.good {
background-color: #ffec8b;
border-color: #fc0;
opacity: 1;
} }
#pass-strength-result.strong { #pass-strength-result.strong {
background-color: #c3ff88; background-color: #c3ff88;
border-color: #8dff1c !important; border-color: #8dff1c;
opacity: 1;
}
[name="admin_password"].short {
border-color: #f04040;
}
[name="admin_password"].bad {
border-color: #ff853c;
}
[name="admin_password"].good {
border-color: #fc0;
}
[name="admin_password"].strong {
border-color: #8dff1c;
}
.pw-weak {
display: none;
} }
.message { .message {
@ -374,6 +401,11 @@ body.language-chooser {
vertical-align: top; vertical-align: top;
} }
.button-secondary.hide-if-no-js,
.hide-if-no-js {
display: none;
}
/** /**
* HiDPI Displays * HiDPI Displays
*/ */

File diff suppressed because one or more lines are too long

View File

@ -72,6 +72,7 @@ function display_header( $body_classes = '' ) {
<title><?php _e( 'WordPress &rsaquo; Installation' ); ?></title> <title><?php _e( 'WordPress &rsaquo; Installation' ); ?></title>
<?php <?php
wp_admin_css( 'install', true ); wp_admin_css( 'install', true );
wp_admin_css( 'dashicons', true );
?> ?>
</head> </head>
<body class="wp-core-ui<?php echo $body_classes ?>"> <body class="wp-core-ui<?php echo $body_classes ?>">
@ -128,16 +129,44 @@ function display_setup_form( $error = null ) {
</td> </td>
</tr> </tr>
<?php if ( ! $user_table ) : ?> <?php if ( ! $user_table ) : ?>
<tr> <tr class="form-field form-required user-pass1-wrap">
<th scope="row"> <th scope="row">
<label for="pass1"><?php _e('Password, twice'); ?></label> <label for="pass1">
<p><?php _e('A password will be automatically generated for you if you leave this blank.'); ?></p> <?php _e( 'Password' ); ?>
<span class="description hide-if-js"><?php _e( '(required)' ); ?></span>
</label>
</th> </th>
<td> <td>
<input name="admin_password" type="password" id="pass1" size="25" value="" /> <button type="button" class="button button-secondary wp-generate-pw hide-if-no-js"><?php _e( 'Show password' ); ?></button>
<p><input name="admin_password2" type="password" id="pass2" size="25" value="" /></p> <div class="wp-pwd hide-if-js">
<div id="pass-strength-result"><?php _e('Strength indicator'); ?></div> <?php $initial_password = wp_generate_password( 24 ); ?>
<p><?php echo wp_get_password_hint(); ?></p> <input type="password" name="admin_password" id="pass1" class="regular-text" autocomplete="off" data-reveal="1" data-pw="<?php echo esc_attr( $initial_password ); ?>" />
<button type="button" class="button button-secondary wp-hide-pw hide-if-no-js" data-toggle="0">
<span class="dashicons dashicons-visibility"></span>
<span class="text">hide</span>
</button>
<div id="pass-strength-result"></div>
</div>
<p><span class="description hide-if-no-js"><?php _e( 'A password reset link will be sent to you via email.' ); ?></span></p>
</td>
</tr>
<tr class="form-field form-required user-pass2-wrap hide-if-js">
<th scope="row">
<label for="pass2"><?php _e( 'Repeat Password' ); ?>
<span class="description"><?php _e( '(required)' ); ?></span>
</label>
</th>
<td>
<input name="admin_password2" type="password" id="pass2" autocomplete="off" />
</td>
</tr>
<tr class="pw-weak">
<th scope="row"><?php _e( 'Confirm Password' ); ?></th>
<td>
<label>
<input type="checkbox" name="pw_weak" class="pw-checkbox" />
<?php _e( 'Confirm use of weak password' ); ?>
</label>
</td> </td>
</tr> </tr>
<?php endif; ?> <?php endif; ?>
@ -148,10 +177,10 @@ function display_setup_form( $error = null ) {
</tr> </tr>
<tr> <tr>
<th scope="row"><?php _e( 'Privacy' ); ?></th> <th scope="row"><?php _e( 'Privacy' ); ?></th>
<td colspan="2"><label><input type="checkbox" name="blog_public" id="blog_public" value="1" <?php checked( $blog_public ); ?> /> <?php _e( 'Allow search engines to index this site.' ); ?></label></td> <td colspan="2"><label><input type="checkbox" name="blog_public" id="blog_public" value="1" <?php checked( $blog_public ); ?> /> <?php _e( 'Allow search engines to index this site' ); ?></label></td>
</tr> </tr>
</table> </table>
<p class="step"><input type="submit" name="Submit" value="<?php esc_attr_e( 'Install WordPress' ); ?>" class="button button-large" /></p> <p class="step"><?php submit_button( __( 'Install WordPress' ), 'large', 'Submit', false, array( 'id' => 'submit' ) ); ?></p>
<input type="hidden" name="language" value="<?php echo isset( $_REQUEST['language'] ) ? esc_attr( $_REQUEST['language'] ) : ''; ?>" /> <input type="hidden" name="language" value="<?php echo isset( $_REQUEST['language'] ) ? esc_attr( $_REQUEST['language'] ) : ''; ?>" />
</form> </form>
<?php <?php
@ -323,5 +352,10 @@ if ( !wp_is_mobile() ) {
<?php } ?> <?php } ?>
<?php wp_print_scripts( 'user-profile' ); ?> <?php wp_print_scripts( 'user-profile' ); ?>
<?php wp_print_scripts( 'language-chooser' ); ?> <?php wp_print_scripts( 'language-chooser' ); ?>
<script type="text/javascript">
jQuery( function( $ ) {
$( '.hide-if-no-js' ).removeClass( 'hide-if-no-js' );
} );
</script>
</body> </body>
</html> </html>

View File

@ -483,8 +483,8 @@ if ( $show_password_fields ) :
<tr class="pw-weak"> <tr class="pw-weak">
<th><?php _e( 'Confirm Password' ); ?></th> <th><?php _e( 'Confirm Password' ); ?></th>
<td> <td>
<label for="pw-weak"> <label for="pw_weak">
<input type="checkbox" name="pw-weak" class="pw-checkbox" id="pw-weak" /> <input type="checkbox" name="pw_weak" class="pw-checkbox" id="pw-weak" />
<?php _e( 'Confirm use of weak password' ); ?> <?php _e( 'Confirm use of weak password' ); ?>
</label> </label>
</td> </td>

View File

@ -394,7 +394,7 @@ if ( apply_filters( 'show_password_fields', true ) ) : ?>
<th scope="row"> <th scope="row">
<label for="pass1"> <label for="pass1">
<?php _e( 'Password' ); ?> <?php _e( 'Password' ); ?>
<span class="description hide-if-js"><?php /* translators: password input field */_e( '(required)' ); ?></span> <span class="description hide-if-js"><?php _e( '(required)' ); ?></span>
</label> </label>
</th> </th>
<td> <td>
@ -413,7 +413,7 @@ if ( apply_filters( 'show_password_fields', true ) ) : ?>
</td> </td>
</tr> </tr>
<tr class="form-field form-required user-pass2-wrap hide-if-js"> <tr class="form-field form-required user-pass2-wrap hide-if-js">
<th scope="row"><label for="pass2"><?php _e( 'Repeat Password' ); ?> <span class="description"><?php /* translators: password input field */_e('(required)'); ?></span></label></th> <th scope="row"><label for="pass2"><?php _e( 'Repeat Password' ); ?> <span class="description"><?php _e( '(required)' ); ?></span></label></th>
<td> <td>
<input name="pass2" type="password" id="pass2" autocomplete="off" /> <input name="pass2" type="password" id="pass2" autocomplete="off" />
</td> </td>
@ -423,7 +423,7 @@ if ( apply_filters( 'show_password_fields', true ) ) : ?>
<td> <td>
<label for="pw-weak"> <label for="pw-weak">
<input type="checkbox" name="pw-weak" class="pw-checkbox" id="pw-weak" /> <input type="checkbox" name="pw-weak" class="pw-checkbox" id="pw-weak" />
<?php _e( 'Confirm use of weak password.' ); ?> <?php _e( 'Confirm use of weak password' ); ?>
</label> </label>
</td> </td>
</tr> </tr>

View File

@ -2107,8 +2107,9 @@ function wp_rand( $min = 0, $max = 0 ) {
$rnd_value .= sha1($rnd_value); $rnd_value .= sha1($rnd_value);
$rnd_value .= sha1($rnd_value . $seed); $rnd_value .= sha1($rnd_value . $seed);
$seed = md5($seed . $rnd_value); $seed = md5($seed . $rnd_value);
if ( ! defined( 'WP_SETUP_CONFIG' ) ) if ( ! defined( 'WP_SETUP_CONFIG' ) && ! defined( 'WP_INSTALLING' ) ) {
set_transient('random_seed', $seed); set_transient( 'random_seed', $seed );
}
} }
// Take the first 8 digits for our value // Take the first 8 digits for our value

View File

@ -4,7 +4,7 @@
* *
* @global string $wp_version * @global string $wp_version
*/ */
$wp_version = '4.3-beta2-33245'; $wp_version = '4.3-beta2-33246';
/** /**
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema. * Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.