mirror of
git://develop.git.wordpress.org/
synced 2025-04-04 20:23:27 +02:00
Widgets: Add filter to disable RSS widget icon.
Add a filter that disables output of the icon on RSS feed widgets. Improves accessibility by providing a path to prevent duplicate or invisible links. Props sabernhardt, Boniu91. Fixes #52224. git-svn-id: https://develop.svn.wordpress.org/trunk@52031 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
4f2ce0716c
commit
2ce222c92b
@ -229,6 +229,10 @@ input[type="checkbox"] {
|
||||
margin: 0;
|
||||
}
|
||||
|
||||
.widget_rss .widget-title .rsswidget:first-child:not(.rss-widget-title) {
|
||||
float: left;
|
||||
}
|
||||
|
||||
.search-form .search-submit {
|
||||
left: 3px;
|
||||
right: auto;
|
||||
|
@ -2662,7 +2662,7 @@ h2.widget-title {
|
||||
|
||||
/* RSS Widget */
|
||||
|
||||
.widget_rss .widget-title .rsswidget:first-child {
|
||||
.widget_rss .widget-title .rsswidget:first-child:not(.rss-widget-title) {
|
||||
float: right;
|
||||
}
|
||||
|
||||
|
@ -4286,7 +4286,7 @@ div.comment:first-of-type {
|
||||
|
||||
/* Widget: RSS ------------------------------- */
|
||||
|
||||
.widget_rss .widget-title a.rsswidget:first-of-type {
|
||||
.widget_rss .widget-title a.rsswidget:first-of-type:not(.rss-widget-title) {
|
||||
display: none;
|
||||
}
|
||||
|
||||
|
@ -4320,7 +4320,7 @@ div.comment:first-of-type {
|
||||
|
||||
/* Widget: RSS ------------------------------- */
|
||||
|
||||
.widget_rss .widget-title a.rsswidget:first-of-type {
|
||||
.widget_rss .widget-title a.rsswidget:first-of-type:not(.rss-widget-title) {
|
||||
display: none;
|
||||
}
|
||||
|
||||
|
@ -86,10 +86,31 @@ class WP_Widget_RSS extends WP_Widget {
|
||||
/** This filter is documented in wp-includes/widgets/class-wp-widget-pages.php */
|
||||
$title = apply_filters( 'widget_title', $title, $instance, $this->id_base );
|
||||
|
||||
$url = strip_tags( $url );
|
||||
$icon = includes_url( 'images/rss.png' );
|
||||
if ( $title ) {
|
||||
$title = '<a class="rsswidget" href="' . esc_url( $url ) . '"><img class="rss-widget-icon" style="border:0" width="14" height="14" src="' . esc_url( $icon ) . '" alt="RSS" /></a> <a class="rsswidget" href="' . esc_url( $link ) . '">' . esc_html( $title ) . '</a>';
|
||||
$feed_link = '';
|
||||
$feed_url = strip_tags( $url );
|
||||
$feed_icon = includes_url( 'images/rss.png' );
|
||||
$feed_link = sprintf(
|
||||
'<a class="rsswidget rss-widget-feed" href="%1$s"><img class="rss-widget-icon" style="border:0" width="14" height="14" src="%2$s" alt="%3$s"%4$s /></a> ',
|
||||
esc_url( $feed_url ),
|
||||
esc_url( $feed_icon ),
|
||||
esc_attr__( 'RSS' ),
|
||||
( wp_lazy_loading_enabled( 'img', 'rss_widget_feed_icon' ) ? ' loading="lazy"' : '' )
|
||||
);
|
||||
|
||||
/**
|
||||
* Filters the classic RSS widget's feed icon link.
|
||||
*
|
||||
* Themes can remove the icon link by using `add_filter( 'rss_widget_feed_link', '__return_false' );`.
|
||||
*
|
||||
* @since 5.9.0
|
||||
*
|
||||
* @param string $feed_link HTML for link to RSS feed.
|
||||
* @param array $instance Array of settings for the current widget.
|
||||
*/
|
||||
$feed_link = apply_filters( 'rss_widget_feed_link', $feed_link, $instance );
|
||||
|
||||
$title = $feed_link . '<a class="rsswidget rss-widget-title" href="' . esc_url( $link ) . '">' . esc_html( $title ) . '</a>';
|
||||
}
|
||||
|
||||
echo $args['before_widget'];
|
||||
|
@ -394,7 +394,7 @@ class WP_Test_REST_Widgets_Controller extends WP_Test_REST_Controller_Testcase {
|
||||
'id' => 'rss-1',
|
||||
'id_base' => 'rss',
|
||||
'sidebar' => 'sidebar-1',
|
||||
'rendered' => '<a class="rsswidget" href="https://wordpress.org/news/feed"><img class="rss-widget-icon" style="border:0" width="14" height="14" src="http://example.org/wp-includes/images/rss.png" alt="RSS" /></a> <a class="rsswidget" href="https://wordpress.org/news">RSS test</a><ul><li><a class=\'rsswidget\' href=\'https://wordpress.org/news/2020/12/introducing-learn-wordpress/\'>Introducing Learn WordPress</a></li><li><a class=\'rsswidget\' href=\'https://wordpress.org/news/2020/12/simone/\'>WordPress 5.6 “Simone”</a></li><li><a class=\'rsswidget\' href=\'https://wordpress.org/news/2020/12/state-of-the-word-2020/\'>State of the Word 2020</a></li><li><a class=\'rsswidget\' href=\'https://wordpress.org/news/2020/12/the-month-in-wordpress-november-2020/\'>The Month in WordPress: November 2020</a></li><li><a class=\'rsswidget\' href=\'https://wordpress.org/news/2020/12/wordpress-5-6-release-candidate-2/\'>WordPress 5.6 Release Candidate 2</a></li><li><a class=\'rsswidget\' href=\'https://wordpress.org/news/2020/11/wordpress-5-6-release-candidate/\'>WordPress 5.6 Release Candidate</a></li><li><a class=\'rsswidget\' href=\'https://wordpress.org/news/2020/11/wordpress-5-6-beta-4/\'>WordPress 5.6 Beta 4</a></li><li><a class=\'rsswidget\' href=\'https://wordpress.org/news/2020/11/wordpress-5-6-beta-3/\'>WordPress 5.6 Beta 3</a></li><li><a class=\'rsswidget\' href=\'https://wordpress.org/news/2020/11/the-month-in-wordpress-october-2020/\'>The Month in WordPress: October 2020</a></li><li><a class=\'rsswidget\' href=\'https://wordpress.org/news/2020/10/wordpress-5-5-3-maintenance-release/\'>WordPress 5.5.3 Maintenance Release</a></li></ul>',
|
||||
'rendered' => '<a class="rsswidget rss-widget-feed" href="https://wordpress.org/news/feed"><img class="rss-widget-icon" style="border:0" width="14" height="14" src="http://example.org/wp-includes/images/rss.png" alt="RSS" loading="lazy" /></a> <a class="rsswidget rss-widget-title" href="https://wordpress.org/news">RSS test</a><ul><li><a class=\'rsswidget\' href=\'https://wordpress.org/news/2020/12/introducing-learn-wordpress/\'>Introducing Learn WordPress</a></li><li><a class=\'rsswidget\' href=\'https://wordpress.org/news/2020/12/simone/\'>WordPress 5.6 “Simone”</a></li><li><a class=\'rsswidget\' href=\'https://wordpress.org/news/2020/12/state-of-the-word-2020/\'>State of the Word 2020</a></li><li><a class=\'rsswidget\' href=\'https://wordpress.org/news/2020/12/the-month-in-wordpress-november-2020/\'>The Month in WordPress: November 2020</a></li><li><a class=\'rsswidget\' href=\'https://wordpress.org/news/2020/12/wordpress-5-6-release-candidate-2/\'>WordPress 5.6 Release Candidate 2</a></li><li><a class=\'rsswidget\' href=\'https://wordpress.org/news/2020/11/wordpress-5-6-release-candidate/\'>WordPress 5.6 Release Candidate</a></li><li><a class=\'rsswidget\' href=\'https://wordpress.org/news/2020/11/wordpress-5-6-beta-4/\'>WordPress 5.6 Beta 4</a></li><li><a class=\'rsswidget\' href=\'https://wordpress.org/news/2020/11/wordpress-5-6-beta-3/\'>WordPress 5.6 Beta 3</a></li><li><a class=\'rsswidget\' href=\'https://wordpress.org/news/2020/11/the-month-in-wordpress-october-2020/\'>The Month in WordPress: October 2020</a></li><li><a class=\'rsswidget\' href=\'https://wordpress.org/news/2020/10/wordpress-5-5-3-maintenance-release/\'>WordPress 5.5.3 Maintenance Release</a></li></ul>',
|
||||
),
|
||||
array(
|
||||
'id' => 'testwidget',
|
||||
|
@ -94,7 +94,7 @@ class Tests_Widgets_wpWidgetRss extends WP_UnitTestCase {
|
||||
return array(
|
||||
'when url is given' => array(
|
||||
'url' => 'https://wordpress.org/news/feed/',
|
||||
'<section id="widget_rss-5" class="widget widget_rss"><h2><a class="rsswidget" href="https://wordpress.org/news/feed/">',
|
||||
'<section id="widget_rss-5" class="widget widget_rss"><h2><a class="rsswidget rss-widget-feed" href="https://wordpress.org/news/feed/">',
|
||||
),
|
||||
);
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user