From 8d96df213bd03efcb6c1f15d30d59cb48cf4f0ed Mon Sep 17 00:00:00 2001 From: John Parris Date: Mon, 13 Nov 2023 10:22:34 -0500 Subject: [PATCH] refactor: Restore wp_calculate_image_srcset callback. Adjust logic in image_source_srcset_replacement --- .../includes/replacement/callbacks.php | 47 +++++++++++++------ .../integration/ReplacementCallbacksTests.php | 4 ++ 2 files changed, 36 insertions(+), 15 deletions(-) diff --git a/plugins/faustwp/includes/replacement/callbacks.php b/plugins/faustwp/includes/replacement/callbacks.php index dc0a3b576..0115469f2 100644 --- a/plugins/faustwp/includes/replacement/callbacks.php +++ b/plugins/faustwp/includes/replacement/callbacks.php @@ -89,6 +89,7 @@ function image_source_replacement( $content ) { return preg_replace( $patterns, "src=\"{$site_url}/", $content ); } +add_filter( 'wp_calculate_image_srcset', __NAMESPACE__ . '\\image_source_srcset_replacement' ); /** * Callback for WordPress 'the_content' filter to replace paths to media. * @@ -97,23 +98,39 @@ function image_source_replacement( $content ) { * @return string One or more arrays of source data. */ function image_source_srcset_replacement( $sources ) { - if ( is_image_source_replacement_enabled() ) { - $frontend_uri = faustwp_get_setting( 'frontend_uri' ); - $site_url = site_url(); - - if ( is_array( $sources ) ) { - // For urls with no domain or the frontend domain, replace with the wp site_url. - $patterns = array( - "#^{$frontend_uri}/#", - '#^/#', - ); - foreach ( $sources as $width => $source ) { - $sources[ $width ]['url'] = preg_replace( $patterns, "$site_url/", $sources[ $width ]['url'] ); - } - } + $use_wp_domain_for_media = use_wp_domain_for_media(); + $frontend_uri = faustwp_get_setting( 'frontend_uri' ); + $site_url = site_url(); + + /** + * For urls with no domain or the frontend domain, replace with the WP site_url. + * This was the default replacement pattern until Faust 1.2, at which point this + * was adjusted to correct replacement bugs. + */ + $patterns = array( + "#^{$site_url}/#", + '#^/#', + ); - return $sources; + $replacement = $frontend_uri; + + /** + * If using WP domain for media and a frontend URL is encountered, rewrite it to WP URL. + */ + if ( $use_wp_domain_for_media ) { + $patterns = array( + "#^{$frontend_uri}/#", + '#^/#', + ); + $replacement = $site_url; } + + if ( is_array( $sources ) ) { + foreach ( $sources as $width => $source ) { + $sources[ $width ]['url'] = preg_replace( $patterns, "$replacement/", $source['url'] ); + } + } + return $sources; } diff --git a/plugins/faustwp/tests/integration/ReplacementCallbacksTests.php b/plugins/faustwp/tests/integration/ReplacementCallbacksTests.php index 6450558de..de3f4be75 100644 --- a/plugins/faustwp/tests/integration/ReplacementCallbacksTests.php +++ b/plugins/faustwp/tests/integration/ReplacementCallbacksTests.php @@ -64,6 +64,10 @@ public function test_wpseo_xml_sitemap_post_url_filter() { $this->assertSame( 10, has_action( 'wpseo_xml_sitemap_post_url', 'WPE\FaustWP\Replacement\yoast_sitemap_post_url' ) ); } + public function test_wp_calculate_image_srcset_filter(): void { + self::assertSame( 10, has_action( 'wp_calculate_image_srcset', 'WPE\FaustWP\Replacement\image_source_srcset_replacement' ) ); + } + /** * Tests content_replacement() returns original value when content replacement is not enabled. */