Coding Standards: Improve readability of `wp-admin/options-permalink.php`.

Includes: 
* Wrapping longer lines and reducing alignment levels to fit more data on the screen.
* Restoring `esc_attr()` for input values, which may include translatable parts.
* Adding comments to closing `</div>` tags and PHP `endif` statements.
* Reducing the context switching between HTML and PHP.
* Balancing PHP conditionals to better reflect the structure.
* Removing repeated function calls to improve performance.
* Renaming some variables for clarity and consistency.

Follow-up to [470], [601], [963], [1227], [1664], [2746], [3029], [6976], [7230], [11350], [14051], [14553], [21891], [34691], [34749], [37747], [38066], [41182], [41986], [42343], [43571], [48710], [50830], [51892], [53706].

See #55647.
Built from https://develop.svn.wordpress.org/trunk@53710


git-svn-id: http://core.svn.wordpress.org/trunk@53269 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
Sergey Biryukov 2022-07-16 16:20:10 +00:00
parent a65abecc15
commit 033728a0b7
6 changed files with 251 additions and 186 deletions

View File

@ -1086,7 +1086,6 @@ table.form-table td .updated p {
.form-table.permalink-structure .structure-selection .row > div { .form-table.permalink-structure .structure-selection .row > div {
max-width: calc(100% - 24px); max-width: calc(100% - 24px);
margin-right: 4px;
display: inline-flex; display: inline-flex;
flex-direction: column; flex-direction: column;
} }

File diff suppressed because one or more lines are too long

View File

@ -1085,7 +1085,6 @@ table.form-table td .updated p {
.form-table.permalink-structure .structure-selection .row > div { .form-table.permalink-structure .structure-selection .row > div {
max-width: calc(100% - 24px); max-width: calc(100% - 24px);
margin-left: 4px;
display: inline-flex; display: inline-flex;
flex-direction: column; flex-direction: column;
} }

File diff suppressed because one or more lines are too long

View File

@ -73,10 +73,11 @@ $home_path = get_home_path();
$iis7_permalinks = iis7_supports_permalinks(); $iis7_permalinks = iis7_supports_permalinks();
$permalink_structure = get_option( 'permalink_structure' ); $permalink_structure = get_option( 'permalink_structure' );
$prefix = ''; $index_php_prefix = '';
$blog_prefix = ''; $blog_prefix = '';
if ( ! got_url_rewrite() ) { if ( ! got_url_rewrite() ) {
$prefix = '/index.php'; $index_php_prefix = '/index.php';
} }
/* /*
@ -85,7 +86,9 @@ if ( ! got_url_rewrite() ) {
* network. If the `permalink_structure` option has been changed to remove this * network. If the `permalink_structure` option has been changed to remove this
* base prefix, WordPress core can no longer account for the possible collision. * base prefix, WordPress core can no longer account for the possible collision.
*/ */
if ( is_multisite() && ! is_subdomain_install() && is_main_site() && 0 === strpos( $permalink_structure, '/blog/' ) ) { if ( is_multisite() && ! is_subdomain_install() && is_main_site()
&& 0 === strpos( $permalink_structure, '/blog/' )
) {
$blog_prefix = '/blog'; $blog_prefix = '/blog';
} }
@ -107,8 +110,9 @@ if ( isset( $_POST['permalink_structure'] ) || isset( $_POST['category_base'] )
if ( ! empty( $permalink_structure ) ) { if ( ! empty( $permalink_structure ) ) {
$permalink_structure = preg_replace( '#/+#', '/', '/' . str_replace( '#', '', $permalink_structure ) ); $permalink_structure = preg_replace( '#/+#', '/', '/' . str_replace( '#', '', $permalink_structure ) );
if ( $prefix && $blog_prefix ) {
$permalink_structure = $prefix . preg_replace( '#^/?index\.php#', '', $permalink_structure ); if ( $index_php_prefix && $blog_prefix ) {
$permalink_structure = $index_php_prefix . preg_replace( '#^/?index\.php#', '', $permalink_structure );
} else { } else {
$permalink_structure = $blog_prefix . $permalink_structure; $permalink_structure = $blog_prefix . $permalink_structure;
} }
@ -143,7 +147,9 @@ if ( isset( $_POST['permalink_structure'] ) || isset( $_POST['category_base'] )
} }
if ( $iis7_permalinks ) { if ( $iis7_permalinks ) {
if ( ( ! file_exists( $home_path . 'web.config' ) && win_is_writable( $home_path ) ) || win_is_writable( $home_path . 'web.config' ) ) { if ( ( ! file_exists( $home_path . 'web.config' )
&& win_is_writable( $home_path ) ) || win_is_writable( $home_path . 'web.config' )
) {
$writable = true; $writable = true;
} else { } else {
$writable = false; $writable = false;
@ -151,7 +157,9 @@ if ( $iis7_permalinks ) {
} elseif ( $is_nginx ) { } elseif ( $is_nginx ) {
$writable = false; $writable = false;
} else { } else {
if ( ( ! file_exists( $home_path . '.htaccess' ) && is_writable( $home_path ) ) || is_writable( $home_path . '.htaccess' ) ) { if ( ( ! file_exists( $home_path . '.htaccess' )
&& is_writable( $home_path ) ) || is_writable( $home_path . '.htaccess' )
) {
$writable = true; $writable = true;
} else { } else {
$writable = false; $writable = false;
@ -222,79 +230,57 @@ require_once ABSPATH . 'wp-admin/admin-header.php';
</p> </p>
<?php <?php
if ( is_multisite() && ! is_subdomain_install() && is_main_site() && 0 === strpos( $permalink_structure, '/blog/' ) ) { if ( is_multisite() && ! is_subdomain_install() && is_main_site()
&& 0 === strpos( $permalink_structure, '/blog/' )
) {
$permalink_structure = preg_replace( '|^/?blog|', '', $permalink_structure ); $permalink_structure = preg_replace( '|^/?blog|', '', $permalink_structure );
$category_base = preg_replace( '|^/?blog|', '', $category_base ); $category_base = preg_replace( '|^/?blog|', '', $category_base );
$tag_base = preg_replace( '|^/?blog|', '', $tag_base ); $tag_base = preg_replace( '|^/?blog|', '', $tag_base );
} }
$structures = array( $default_structures = array(
0 => '', 0 => '',
1 => $prefix . '/%year%/%monthnum%/%day%/%postname%/', 1 => $index_php_prefix . '/%year%/%monthnum%/%day%/%postname%/',
2 => $prefix . '/%year%/%monthnum%/%postname%/', 2 => $index_php_prefix . '/%year%/%monthnum%/%postname%/',
3 => $prefix . '/' . _x( 'archives', 'sample permalink base' ) . '/%post_id%', 3 => $index_php_prefix . '/' . _x( 'archives', 'sample permalink base' ) . '/%post_id%',
4 => $prefix . '/%postname%/', 4 => $index_php_prefix . '/%postname%/',
); );
$inputs = array( $url_base = get_option( 'home' ) . $blog_prefix . $index_php_prefix;
$default_structure_inputs = array(
0 => array( 0 => array(
'id' => 'plain', 'id' => 'plain',
'label' => __( 'Plain' ), 'label' => __( 'Plain' ),
'example' => get_option( 'home' ) . '/?p=123', 'example' => get_option( 'home' ) . '/?p=123',
'value' => $structures[0], 'value' => $default_structures[0],
), ),
1 => array( 1 => array(
'id' => 'day-name', 'id' => 'day-name',
'label' => __( 'Day and name' ), 'label' => __( 'Day and name' ),
'example' => get_option( 'home' ) . $blog_prefix . $prefix . '/' . gmdate( 'Y' ) . '/' . gmdate( 'm' ) . '/' . gmdate( 'd' ) . '/' . _x( 'sample-post', 'sample permalink structure' ) . '/', 'example' => $url_base . '/' . gmdate( 'Y/m/d' ) . '/' . _x( 'sample-post', 'sample permalink structure' ) . '/',
'value' => $structures[1], 'value' => $default_structures[1],
), ),
2 => array( 2 => array(
'id' => 'month-name', 'id' => 'month-name',
'label' => __( 'Month and name' ), 'label' => __( 'Month and name' ),
'example' => get_option( 'home' ) . $blog_prefix . $prefix . '/' . gmdate( 'Y' ) . '/' . gmdate( 'm' ) . '/' . _x( 'sample-post', 'sample permalink structure' ) . '/', 'example' => $url_base . '/' . gmdate( 'Y/m' ) . '/' . _x( 'sample-post', 'sample permalink structure' ) . '/',
'value' => $structures[2], 'value' => $default_structures[2],
), ),
3 => array( 3 => array(
'id' => 'day-numeric', 'id' => 'day-numeric',
'label' => __( 'Numeric' ), 'label' => __( 'Numeric' ),
'example' => get_option( 'home' ) . $blog_prefix . $prefix . '/' . _x( 'archives', 'sample permalink base' ) . '/123', 'example' => $url_base . '/' . _x( 'archives', 'sample permalink base' ) . '/123',
'value' => $structures[3], 'value' => $default_structures[3],
), ),
4 => array( 4 => array(
'id' => 'post-name', 'id' => 'post-name',
'label' => __( 'Post name' ), 'label' => __( 'Post name' ),
'example' => get_option( 'home' ) . $blog_prefix . $prefix . '/' . _x( 'sample-post', 'sample permalink structure' ) . '/', 'example' => $url_base . '/' . _x( 'sample-post', 'sample permalink structure' ) . '/',
'value' => $structures[4], 'value' => $default_structures[4],
), ),
); );
?>
<h2 class="title"><?php _e( 'Common Settings' ); ?></h2>
<table class="form-table permalink-structure" role="presentation">
<tbody>
<tr>
<th scope="row"><?php _e( 'Permalink structure' ); ?></th>
<td>
<fieldset class="structure-selection">
<legend class="screen-reader-text"><?php _e( 'Permalink structure' ); ?></legend>
<?php
foreach ( $inputs as $structure_id => $structure_values ) {
$input_markup = '<div class="row">';
$input_markup .= '<input id="permalink-input-' . $structure_values['id'] . '" name="selection" aria-describedby="permalink-' . $structure_values['id'] . '" type="radio" value="' . $structure_values['value'] . '" ' . checked( $structure_values['value'], $permalink_structure, false ) . ' />';
$input_markup .= '<div><label for="permalink-input-' . $structure_values['id'] . '">' . $structure_values['label'] . '</label>';
$input_markup .= '<p><code id="permalink-' . $structure_values['id'] . '">' . $structure_values['example'] . '</code></p>';
$input_markup .= '</div>';
$input_markup .= '</div>';
echo $input_markup;
}
?>
<div class="row">
<input id="custom_selection" name="selection" type="radio" value="custom" <?php checked( ! in_array( $permalink_structure, $structures, true ) ); ?> /><div><label for="custom_selection"><?php _e( 'Custom Structure' ); ?></label>
<p><label for="permalink_structure" class="screen-reader-text"><?php _e( 'Customize permalink structure by selecting available tags' ); ?></label><span class="code"><code id="permalink-custom"><?php echo get_option( 'home' ) . $blog_prefix; ?></code><input name="permalink_structure" id="permalink_structure" type="text" value="<?php echo esc_attr( $permalink_structure ); ?>" aria-describedby="permalink-custom" class="regular-text code" /></span></p>
<div class="available-structure-tags hide-if-no-js">
<div id="custom_selection_updated" aria-live="assertive" class="screen-reader-text"></div>
<?php
$available_tags = array( $available_tags = array(
/* translators: %s: Permalink structure tag. */ /* translators: %s: Permalink structure tag. */
'year' => __( '%s (The year of the post, four digits, for example 2004.)' ), 'year' => __( '%s (The year of the post, four digits, for example 2004.)' ),
@ -328,13 +314,58 @@ $inputs = array(
$available_tags = apply_filters( 'available_permalink_structure_tags', $available_tags ); $available_tags = apply_filters( 'available_permalink_structure_tags', $available_tags );
/* translators: %s: Permalink structure tag. */ /* translators: %s: Permalink structure tag. */
$structure_tag_added = __( '%s added to permalink structure' ); $tag_added = __( '%s added to permalink structure' );
/* translators: %s: Permalink structure tag. */ /* translators: %s: Permalink structure tag. */
$structure_tag_already_used = __( '%s (already used in permalink structure)' ); $tag_already_used = __( '%s (already used in permalink structure)' );
if ( ! empty( $available_tags ) ) :
?> ?>
<h2 class="title"><?php _e( 'Common Settings' ); ?></h2>
<table class="form-table permalink-structure" role="presentation">
<tbody>
<tr>
<th scope="row"><?php _e( 'Permalink structure' ); ?></th>
<td>
<fieldset class="structure-selection">
<legend class="screen-reader-text"><?php _e( 'Permalink structure' ); ?></legend>
<?php foreach ( $default_structure_inputs as $input ) : ?>
<div class="row">
<input id="permalink-input-<?php echo $input['id']; ?>"
name="selection" aria-describedby="permalink-<?php echo $input['id']; ?>"
type="radio" value="<?php echo esc_attr( $input['value'] ); ?>"
<?php checked( $input['value'], $permalink_structure ); ?>
/>
<div>
<label for="permalink-input-<?php echo $input['id']; ?>"><?php echo $input['label']; ?></label>
<p>
<code id="permalink-<?php echo $input['id']; ?>"><?php echo $input['example']; ?></code>
</p>
</div>
</div><!-- .row -->
<?php endforeach; ?>
<div class="row">
<input id="custom_selection"
name="selection" type="radio" value="custom"
<?php checked( ! in_array( $permalink_structure, $default_structures, true ) ); ?>
/>
<div>
<label for="custom_selection"><?php _e( 'Custom Structure' ); ?></label>
<p>
<label for="permalink_structure" class="screen-reader-text">
<?php _e( 'Customize permalink structure by selecting available tags' ); ?>
</label>
<span class="code">
<code id="permalink-custom"><?php echo $url_base; ?></code>
<input name="permalink_structure" id="permalink_structure"
type="text" value="<?php echo esc_attr( $permalink_structure ); ?>"
aria-describedby="permalink-custom" class="regular-text code"
/>
</span>
</p>
<div class="available-structure-tags hide-if-no-js">
<div id="custom_selection_updated" aria-live="assertive" class="screen-reader-text"></div>
<?php if ( ! empty( $available_tags ) ) : ?>
<fieldset> <fieldset>
<legend><?php _e( 'Available tags:' ); ?></legend> <legend><?php _e( 'Available tags:' ); ?></legend>
<ul role="list"> <ul role="list">
@ -343,8 +374,8 @@ $inputs = array(
<button type="button" <button type="button"
class="button button-secondary" class="button button-secondary"
aria-label="<?php echo esc_attr( sprintf( $explanation, $tag ) ); ?>" aria-label="<?php echo esc_attr( sprintf( $explanation, $tag ) ); ?>"
data-added="<?php echo esc_attr( sprintf( $structure_tag_added, $tag ) ); ?>" data-added="<?php echo esc_attr( sprintf( $tag_added, $tag ) ); ?>"
data-used="<?php echo esc_attr( sprintf( $structure_tag_already_used, $tag ) ); ?>"> data-used="<?php echo esc_attr( sprintf( $tag_already_used, $tag ) ); ?>">
<?php echo '%' . $tag . '%'; ?> <?php echo '%' . $tag . '%'; ?>
</button> </button>
</li> </li>
@ -352,10 +383,10 @@ $inputs = array(
</ul> </ul>
</fieldset> </fieldset>
<?php endif; ?> <?php endif; ?>
</div><!-- .available-structure-tags -->
</div> </div>
</div> </div><!-- .row -->
</div> </fieldset><!-- .structure-selection -->
</fieldset>
</td> </td>
</tr> </tr>
</tbody> </tbody>
@ -364,19 +395,38 @@ $inputs = array(
<h2 class="title"><?php _e( 'Optional' ); ?></h2> <h2 class="title"><?php _e( 'Optional' ); ?></h2>
<p> <p>
<?php <?php
printf(
/* translators: %s: Placeholder that must come at the start of the URL. */ /* translators: %s: Placeholder that must come at the start of the URL. */
printf( __( 'If you like, you may enter custom structures for your category and tag URLs here. For example, using <code>topics</code> as your category base would make your category links like <code>%s/topics/uncategorized/</code>. If you leave these blank the defaults will be used.' ), get_option( 'home' ) . $blog_prefix . $prefix ); __( 'If you like, you may enter custom structures for your category and tag URLs here. For example, using <code>topics</code> as your category base would make your category links like <code>%s/topics/uncategorized/</code>. If you leave these blank the defaults will be used.' ),
$url_base
);
?> ?>
</p> </p>
<table class="form-table" role="presentation"> <table class="form-table" role="presentation">
<tr> <tr>
<th><label for="category_base"><?php /* translators: Prefix for category permalinks. */ _e( 'Category base' ); ?></label></th> <th>
<td><?php echo $blog_prefix; ?> <input name="category_base" id="category_base" type="text" value="<?php echo esc_attr( $category_base ); ?>" class="regular-text code" /></td> <label for="category_base">
<?php /* translators: Prefix for category permalinks. */ _e( 'Category base' ); ?>
</label>
</th>
<td>
<?php echo $blog_prefix; ?>
<input name="category_base" id="category_base" type="text"
value="<?php echo esc_attr( $category_base ); ?>" class="regular-text code"
/>
</td>
</tr> </tr>
<tr> <tr>
<th><label for="tag_base"><?php _e( 'Tag base' ); ?></label></th> <th>
<td><?php echo $blog_prefix; ?> <input name="tag_base" id="tag_base" type="text" value="<?php echo esc_attr( $tag_base ); ?>" class="regular-text code" /></td> <label for="tag_base"><?php _e( 'Tag base' ); ?></label>
</th>
<td>
<?php echo $blog_prefix; ?>
<input name="tag_base" id="tag_base" type="text"
value="<?php echo esc_attr( $tag_base ); ?>" class="regular-text code"
/>
</td>
</tr> </tr>
<?php do_settings_fields( 'permalink', 'optional' ); ?> <?php do_settings_fields( 'permalink', 'optional' ); ?>
</table> </table>
@ -385,7 +435,8 @@ printf( __( 'If you like, you may enter custom structures for your category and
<?php submit_button(); ?> <?php submit_button(); ?>
</form> </form>
<?php if ( ! is_multisite() ) { ?>
<?php if ( ! is_multisite() ) : ?>
<?php <?php
if ( $iis7_permalinks ) : if ( $iis7_permalinks ) :
if ( isset( $_POST['submit'] ) && $permalink_structure && ! $using_index_permalinks && ! $writable ) : if ( isset( $_POST['submit'] ) && $permalink_structure && ! $using_index_permalinks && ! $writable ) :
@ -406,7 +457,13 @@ printf( __( 'If you like, you may enter custom structures for your category and
</p> </p>
<form action="options-permalink.php" method="post"> <form action="options-permalink.php" method="post">
<?php wp_nonce_field( 'update-permalink' ); ?> <?php wp_nonce_field( 'update-permalink' ); ?>
<p><label for="rules"><?php _e( 'Rewrite rules:' ); ?></label><br /><textarea rows="9" class="large-text readonly" name="rules" id="rules" readonly="readonly" aria-describedby="iis-description-a"><?php echo esc_textarea( $wp_rewrite->iis7_url_rewrite_rules() ); ?></textarea></p> <p>
<label for="rules"><?php _e( 'Rewrite rules:' ); ?></label><br />
<textarea rows="9" class="large-text readonly"
name="rules" id="rules" readonly="readonly"
aria-describedby="iis-description-a"
><?php echo esc_textarea( $wp_rewrite->iis7_url_rewrite_rules() ); ?></textarea>
</p>
</form> </form>
<p> <p>
<?php <?php
@ -432,7 +489,13 @@ printf( __( 'If you like, you may enter custom structures for your category and
</p> </p>
<form action="options-permalink.php" method="post"> <form action="options-permalink.php" method="post">
<?php wp_nonce_field( 'update-permalink' ); ?> <?php wp_nonce_field( 'update-permalink' ); ?>
<p><label for="rules"><?php _e( 'Rewrite rules:' ); ?></label><br /><textarea rows="18" class="large-text readonly" name="rules" id="rules" readonly="readonly" aria-describedby="iis-description-b"><?php echo esc_textarea( $wp_rewrite->iis7_url_rewrite_rules( true ) ); ?></textarea></p> <p>
<label for="rules"><?php _e( 'Rewrite rules:' ); ?></label><br />
<textarea rows="18" class="large-text readonly"
name="rules" id="rules" readonly="readonly"
aria-describedby="iis-description-b"
><?php echo esc_textarea( $wp_rewrite->iis7_url_rewrite_rules( true ) ); ?></textarea>
</p>
</form> </form>
<p> <p>
<?php <?php
@ -443,12 +506,10 @@ printf( __( 'If you like, you may enter custom structures for your category and
); );
?> ?>
</p> </p>
<?php endif; ?> <?php endif; // End if 'web.config' exists. ?>
<?php endif; ?> <?php endif; // End if $_POST['submit'] && ! $writable. ?>
<?php <?php else : ?>
else : <?php if ( $permalink_structure && ! $using_index_permalinks && ! $writable && $htaccess_update_required ) : ?>
if ( $permalink_structure && ! $using_index_permalinks && ! $writable && $htaccess_update_required ) :
?>
<p id="htaccess-description"> <p id="htaccess-description">
<?php <?php
printf( printf(
@ -463,12 +524,18 @@ else :
</p> </p>
<form action="options-permalink.php" method="post"> <form action="options-permalink.php" method="post">
<?php wp_nonce_field( 'update-permalink' ); ?> <?php wp_nonce_field( 'update-permalink' ); ?>
<p><label for="rules"><?php _e( 'Rewrite rules:' ); ?></label><br /><textarea rows="8" class="large-text readonly" name="rules" id="rules" readonly="readonly" aria-describedby="htaccess-description"><?php echo esc_textarea( $wp_rewrite->mod_rewrite_rules() ); ?></textarea></p> <p>
<label for="rules"><?php _e( 'Rewrite rules:' ); ?></label><br />
<textarea rows="8" class="large-text readonly"
name="rules" id="rules" readonly="readonly"
aria-describedby="htaccess-description"
><?php echo esc_textarea( $wp_rewrite->mod_rewrite_rules() ); ?></textarea>
</p>
</form> </form>
<?php endif; ?> <?php endif; // End if ! $writable && $htaccess_update_required. ?>
<?php endif; ?> <?php endif; // End if $iis7_permalinks. ?>
<?php } // End if ! is_multisite(). ?> <?php endif; // End if ! is_multisite(). ?>
</div> </div><!-- .wrap -->
<?php require_once ABSPATH . 'wp-admin/admin-footer.php'; ?> <?php require_once ABSPATH . 'wp-admin/admin-footer.php'; ?>

View File

@ -16,7 +16,7 @@
* *
* @global string $wp_version * @global string $wp_version
*/ */
$wp_version = '6.1-alpha-53709'; $wp_version = '6.1-alpha-53710';
/** /**
* 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.