-
Notifications
You must be signed in to change notification settings - Fork 383
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add checking for whether AMP query var is defined too late for Reader themes #4999
Changes from 6 commits
d2c53e6
463bb86
52efa80
018d8d8
f3f27ad
ee88672
7574646
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -5,7 +5,10 @@ | |
* @package AMP | ||
*/ | ||
|
||
use AmpProject\AmpWP\AmpSlugCustomizationWatcher; | ||
use AmpProject\AmpWP\Option; | ||
use AmpProject\AmpWP\QueryVars; | ||
use AmpProject\AmpWP\Services; | ||
|
||
/** | ||
* AMP_Options_Menu class. | ||
|
@@ -134,6 +137,9 @@ public function add_menu_items() { | |
public function render_theme_support() { | ||
$theme_support = AMP_Options_Manager::get_option( Option::THEME_SUPPORT ); | ||
|
||
/** @var AmpSlugCustomizationWatcher $amp_slug_customization_watcher */ | ||
$amp_slug_customization_watcher = Services::get( 'amp_slug_customization_watcher' ); | ||
|
||
/* translators: %s: URL to the documentation. */ | ||
$standard_description = sprintf( __( 'The active theme integrates AMP as the framework for your site by using its templates and styles to render webpages. This means your site is <b>AMP-first</b> and your canonical URLs are AMP! Depending on your theme/plugins, a varying level of <a href="%s">development work</a> may be required.', 'amp' ), esc_url( 'https://amp-wp.org/documentation/developing-wordpress-amp-sites/' ) ); | ||
/* translators: %s: URL to the documentation. */ | ||
|
@@ -205,15 +211,51 @@ public function render_theme_support() { | |
<dd> | ||
<p><?php echo wp_kses_post( $reader_description ); ?></p> | ||
|
||
<p> | ||
<?php | ||
/* translators: %s is the reader theme */ | ||
echo esc_html( sprintf( __( 'The "%s" theme is currently selected in the wizard. The ability to change it from the admin screen will come soon.', 'amp' ), AMP_Options_Manager::get_option( Option::READER_THEME ) ) ); | ||
?> | ||
</p> | ||
<div class="notice notice-info notice-alt inline"> | ||
<p> | ||
<?php | ||
/* translators: %s is the reader theme */ | ||
echo esc_html( sprintf( __( 'The "%s" theme is currently selected in the wizard. The ability to change it from the admin screen will come soon.', 'amp' ), AMP_Options_Manager::get_option( Option::READER_THEME ) ) ); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I'm wondering if we should show the theme name here instead of its slug 🤔. I doubt the typical user would be familiar with the slugs for the installed themes, and in some cases the theme slug might not easily identify the theme in question. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Agreed. This is just temporary since all of this will be eliminated with the work that @johnwatkins0 is doing. |
||
?> | ||
</p> | ||
</div> | ||
|
||
<?php if ( AMP_Options_Manager::get_option( Option::READER_THEME ) === get_template() ) : ?> | ||
<p><?php esc_html_e( 'The currently-selected Reader theme is the same as the active theme. This means that Reader mode is disabled since it is no different from Transitional mode at this point.', 'amp' ); ?></p> | ||
<div class="notice notice-info notice-alt inline"> | ||
<p><?php esc_html_e( 'The currently-selected Reader theme is the same as the active theme. This means that Reader mode is disabled since it is no different from Transitional mode at this point.', 'amp' ); ?></p> | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Should we put warnings above informational notices? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Agreed. This is just temporary since all of this will be eliminated with the work that @johnwatkins0 is doing. |
||
</div> | ||
<?php endif; ?> | ||
|
||
<?php if ( $amp_slug_customization_watcher->did_customize_late() ) : ?> | ||
<div class="notice notice-warning notice-alt inline"> | ||
<p> | ||
<?php | ||
echo wp_kses_post( | ||
sprintf( | ||
/* translators: 1: customized AMP query var, 2: default AMP query var */ | ||
esc_html__( 'Warning: You customized your AMP query var too late. This means that Reader themes will not be available to you. You customized it to be %1$s instead of the default %2$s.', 'amp' ), | ||
sprintf( '“<code>%s</code>”', esc_html( amp_get_slug() ) ), | ||
sprintf( '“<code>%s</code>”', QueryVars::AMP ) | ||
) | ||
); | ||
?> | ||
</p> | ||
</div> | ||
<?php elseif ( $amp_slug_customization_watcher->did_customize_early() ) : ?> | ||
<div class="notice notice-info notice-alt inline"> | ||
<p> | ||
<?php | ||
echo wp_kses_post( | ||
sprintf( | ||
/* translators: 1: customized AMP query var, 2: default AMP query var */ | ||
esc_html__( 'You customized your query var to be %1$s instead of the default %2$s.', 'amp' ), | ||
sprintf( '“<code>%s</code>”', esc_html( amp_get_slug() ) ), | ||
sprintf( '“<code>%s</code>”', QueryVars::AMP ) | ||
) | ||
); | ||
?> | ||
</p> | ||
</div> | ||
<?php endif; ?> | ||
</dd> | ||
</dl> | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,96 @@ | ||
<?php | ||
/** | ||
* Class AmpSlugCustomizationWatcher. | ||
* | ||
* @package AmpProject\AmpWP | ||
*/ | ||
|
||
namespace AmpProject\AmpWP; | ||
|
||
use AmpProject\AmpWP\Infrastructure\Registerable; | ||
use AmpProject\AmpWP\Infrastructure\Service; | ||
|
||
/** | ||
* Service for redirecting mobile users to the AMP version of a page. | ||
* | ||
* @package AmpProject\AmpWP | ||
*/ | ||
final class AmpSlugCustomizationWatcher implements Service, Registerable { | ||
|
||
/** | ||
* Whether the slug was customized early (at plugins_loaded action, priority 8). | ||
* | ||
* @var bool | ||
*/ | ||
protected $is_customized_early = false; | ||
|
||
/** | ||
* Whether the slug was customized early (at after_setup_theme action, priority 4). | ||
* | ||
* @var bool | ||
*/ | ||
protected $is_customized_late = false; | ||
|
||
/** | ||
* Register. | ||
*/ | ||
public function register() { | ||
// This is at priority 8 because ReaderThemeLoader::override_theme runs at priority 9, which in turn runs right | ||
// before _wp_customize_include at priority 10. A slug is customized early if it is customized at priority 8. | ||
add_action( 'plugins_loaded', [ $this, 'determine_early_customization' ], 8 ); | ||
} | ||
|
||
/** | ||
* Whether the slug was customized early (at plugins_loaded action, priority 8). | ||
* | ||
* @return bool | ||
*/ | ||
public function did_customize_early() { | ||
return $this->is_customized_early; | ||
} | ||
|
||
/** | ||
* Whether the slug was customized early (at after_setup_theme action, priority 4). | ||
* | ||
* @return bool | ||
*/ | ||
public function did_customize_late() { | ||
return $this->is_customized_late; | ||
} | ||
|
||
/** | ||
* Determine if the slug was customized early. | ||
* | ||
* Early customization happens by plugins_loaded action at priority 8; this is required in order for the slug to be | ||
* used by `ReaderThemeLoader::override_theme()` which runs at priority 9; this method in turn must run before | ||
* before `_wp_customize_include()` which runs at plugins_loaded priority 10. At that point the current theme gets | ||
* determined, so for Reader themes to apply the logic in `ReaderThemeLoader` must run beforehand. | ||
*/ | ||
public function determine_early_customization() { | ||
if ( QueryVars::AMP !== amp_get_slug() ) { | ||
$this->is_customized_early = true; | ||
} else { | ||
add_action( 'after_setup_theme', [ $this, 'determine_late_customization' ], 4 ); | ||
} | ||
} | ||
|
||
/** | ||
* Determine if the slug was defined late. | ||
* | ||
* Late slug customization often happens when a theme itself defines `AMP_QUERY_VAR`. This is too late for the plugin | ||
* to be able to offer Reader themes which must have `AMP_QUERY_VAR` defined by plugins_loaded priority 9. Also, | ||
* defining `AMP_QUERY_VAR` is fundamentally incompatible since loading a Reader theme means preventing the original | ||
* theme from ever being loaded, and thus the theme's customized `AMP_QUERY_VAR` will never be read. | ||
* | ||
* This method must run before `amp_after_setup_theme()` which runs at the after_setup_theme action priority 5. In | ||
* this function, the `amp_get_slug()` function is called which will then set the query var for the remainder of the | ||
* request. | ||
* | ||
* @see amp_after_setup_theme() | ||
*/ | ||
public function determine_late_customization() { | ||
if ( QueryVars::AMP !== amp_get_slug() ) { | ||
$this->is_customized_late = true; | ||
} | ||
} | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
An error occurred on this line while testing. To reproduce:
Looks like this a regression. Could we add a test to catch this, @johnwatkins0?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
As for a suggested fix:
@johnwatkins0 If you're able to identify a simpler fix that would be great 😄.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah, I caught this and fixed it on my branch. I would disregard it on this branch.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sounds good.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
FWIW, I do
(themes || []).reduce
, although I don't feel great about it.