From 06b2e1776c017717eb083cc4568882507bb6f013 Mon Sep 17 00:00:00 2001 From: Sergey Biryukov Date: Mon, 24 Sep 2018 20:57:47 +0000 Subject: [PATCH] Twenty Seventeen: Use a simple counter incremented with each call instead of `uniqid()` for generating unique IDs for HTML elements. Props westonruter. Fixes #44883. Built from https://develop.svn.wordpress.org/trunk@43659 git-svn-id: http://core.svn.wordpress.org/trunk@43488 1a063a9b-81f0-0310-95a4-ce76da25c4cd --- .../themes/twentyseventeen/functions.php | 24 +++++++++++++++++++ .../twentyseventeen/inc/icon-functions.php | 2 +- .../themes/twentyseventeen/searchform.php | 2 +- wp-includes/version.php | 2 +- 4 files changed, 27 insertions(+), 3 deletions(-) diff --git a/wp-content/themes/twentyseventeen/functions.php b/wp-content/themes/twentyseventeen/functions.php index f9152d55cd..6fe2449ed0 100644 --- a/wp-content/themes/twentyseventeen/functions.php +++ b/wp-content/themes/twentyseventeen/functions.php @@ -589,6 +589,30 @@ function twentyseventeen_widget_tag_cloud_args( $args ) { } add_filter( 'widget_tag_cloud_args', 'twentyseventeen_widget_tag_cloud_args' ); +/** + * Get unique ID. + * + * This is a PHP implementation of Underscore's uniqueId method. A static variable + * contains an integer that is incremented with each call. This number is returned + * with the optional prefix. As such the returned value is not universally unique, + * but it is unique across the life of the PHP process. + * + * @since Twenty Seventeen 1.8 + * @see wp_unique_id() Themes requiring WordPress 4.9.9 and greater should use this instead. + * + * @staticvar int $id_counter + * + * @param string $prefix Prefix for the returned ID. + * @return string Unique ID. + */ +function twentyseventeen_unique_id( $prefix = '' ) { + static $id_counter = 0; + if ( function_exists( 'wp_unique_id' ) ) { + return wp_unique_id( $prefix ); + } + return $prefix . (string) ++$id_counter; +} + /** * Implement the Custom Header feature. */ diff --git a/wp-content/themes/twentyseventeen/inc/icon-functions.php b/wp-content/themes/twentyseventeen/inc/icon-functions.php index 87572bcecd..2dee5f47f5 100644 --- a/wp-content/themes/twentyseventeen/inc/icon-functions.php +++ b/wp-content/themes/twentyseventeen/inc/icon-functions.php @@ -74,7 +74,7 @@ function twentyseventeen_get_svg( $args = array() ) { */ if ( $args['title'] ) { $aria_hidden = ''; - $unique_id = uniqid(); + $unique_id = twentyseventeen_unique_id(); $aria_labelledby = ' aria-labelledby="title-' . $unique_id . '"'; if ( $args['desc'] ) { diff --git a/wp-content/themes/twentyseventeen/searchform.php b/wp-content/themes/twentyseventeen/searchform.php index 519c879375..4a38cddafa 100644 --- a/wp-content/themes/twentyseventeen/searchform.php +++ b/wp-content/themes/twentyseventeen/searchform.php @@ -10,7 +10,7 @@ ?> - +