2.0.0
We are very excited about this v2.0 release of the official AMP plugin for WordPress! Lots of work went into this release, and it is loaded with many improvements and new capabilities in the areas of usability, performance, and flexibility. Originally this was going to be v1.6 but due the major changes we decided it warranted a major version bump.
For the full list of changes in this release, please see the 2.0 milestone, with 141 closed issues and 174 merged pull requests.
The key highlighted features in this release include:
- Expanded Reader Mode with full-site coverage (rather than being limited to singular posts and pages as in legacy Reader mode), template and design variations from selecting alternate themes to better match your site's brand, and support for standard WordPress features like nav menus, custom logo, and commenting.
- Onboarding Wizard and revamped Settings Screen which make configuring the plugin more intuitive, explaining the three template modes (Standard, Transitional, Reader), and indicating which may work best for the site and for the user's technical ability.
- Plugin Suppression to provide administrators with a new option for how to deal with plugins that cause validation errors by turning off selected plugins when generating AMP pages.
- Mobile Redirection to facilitate sites in Transitional/Reader modes where AMP intended to be used as the mobile version of the site.
- Improved Developer Tools allowing validation to be turned off for users who don't want it and improving validation workflow for users who do.
Read on for the full details.
Changelog
Expanded Reader Mode
Reader mode now allows for any AMP-compatible theme to be used to serve AMP pages, rather than just the legacy post templates. This allows for long-requested features including nav menus, logos, commenting, and template design variations. It also makes it possible to serve all URLs of a Reader-mode site in AMP, as opposed to just singular posts. The old Reader mode AMP post templates are still available as a "Legacy" theme which is not going away, but it remains limited to serving AMP for singular posts.
To recap the modes: in Standard mode, there is one theme and one version of the site; Standard mode is AMP-first, where there are no AMP-specific URLs as AMP is the canonical (and only) version of the site. In Transitional mode, there is still one theme but there are two versions of the site, where each canonical non-AMP URL may have a separate paired AMP version. Reader mode takes this a step further: the site has two themes, and the active theme is used for canonical non-AMP URLs and the Reader theme is used for AMP URLs. The Standard mode is the recommended mode since it means desktop and mobile visitors both get the speed benefits of AMP and there is less to maintain with only one version/theme on the site. Reader mode is a good choice when the active theme is not AMP-compatible and thus not suitable for Standard or Transitional. Transitional is useful in cases where a partially AMP-compatible theme is used, and the user either wants to do development to make the site fully AMP compatible (i.e. transition to AMP-first), or simply wants a simpler setup.
If at any time the active theme is switched to be the same as the one selected for Reader mode, then the plugin automatically switches from Reader mode to Transitional mode. This is because the site now will behave as if Transitional mode was selected since Reader mode involves two separate themes being used.
When a Reader theme is selected, the Themes screen in the admin will show both the primary theme and the Reader theme as both being active.
The paired browsing feature of the plugin remains limited to sites in Transitional mode, as it doesn't make much sense to see the AMP and non-AMP versions side-by-side if two different themes are being used.
When serving an AMP page with the theme selected in the new Reader mode (i.e. non Legacy), all of the standard WordPress theme hooks are used to extend the templates. So to add something to the footer, use the wp_footer
action instead of amp_post_template_footer
. Actions prefixed with amp_post_template_*
are limited to the legacy Reader theme templates. To know which version should be used in a given site, use current_theme_supports('amp')
which will return true if an AMP page must be served without the legacy theme.
Note: The old legacy Reader mode templates from v0.3 are now marked as deprecated. So if you're using amp_backcompat_use_v03_templates()
, then you should really be migrating to using the current legacy Reader templates, or better still switch to using Reader themes. #5218
AMP Customizer for Reader Mode
When a Reader theme is selected, there will then be two versions of the Customizer available: the default Customizer for the active theme, and the AMP Customizer for the AMP Reader theme. Since in Standard and Transitional modes only one theme is used, only one version of the Customizer will be used. The AMP Customizer can be accessed via the Customize link in the admin bar on an AMP page, or via the admin menu, or via the AMP settings screen. The fact the Customizer is currently editing the AMP version of the site is clearly displayed, along with a link to switch to the main non-AMP Customizer. The AMP Customizer opens with the “Tablet” device being selected for preview by default; this viewport corresponds to the screen size of modern smartphones and it doesn't make sense to default to preview the Desktop viewport size since the vast majority of visitors to AMP pages will be on mobile devices when Reader mode (or Transitional mode) is enabled.
In the AMP Customizer, you can assign the same nav menus used in your active theme to nav menu locations used in the Reader theme. There is also be the ability to copy the theme modifications from the active theme over to the Reader theme so you can preview and tweak how the logo, background color, header, and other settings look in the Reader theme prior to publishing. Any Customizer control for general site options (like the Site Title) include a notification indicating they also apply to the non-AMP version of the site. The Additional CSS section of the Customizer allows you to tweak the styles of the Reader theme separately from the Additional CSS modifying the styles of the active theme. Note that widgets are not supported on AMP pages with a Reader theme, so the Widgets panel of the AMP Customizer is removed. The Homepage Settings section is also removed since it exclusively contains global site options that are not specific to the AMP version of the site. The Themes panel is also removed in the AMP Customizer; switching Reader themes currently must be done from the AMP settings screen.
When the “Legacy” Reader theme is selected, there is only a single version of the Customizer is available; the AMP panel in the Customizer here remains for making changes to the appearance of the legacy post templates.
Non-AMP Customizer | AMP Customizer for Reader theme |
---|---|
Initialization in Reader Mode
When a Reader theme is selected, a request for an AMP page will cause the Reader theme to be loaded instead of the active theme. This is using the same logic the Customizer uses to switch themes during preview. An important implication of this is that if you have custom post types, taxonomies, blocks, or shortcodes—these must be registered in plugins instead of your theme in order for them to be available on AMP pages. It is already a best practice to do such registration in plugins, but WordPress does not enforce it. The plugin will soon also provide a theme scanning capability which will detect whether the active theme is doing any such registrations in order to warn you before activating a Reader theme (see #4795).
Loading a Reader theme on an AMP request happens at the plugins_loaded
action (at priority 9). The Reader theme is loaded this early to ensure it can be accessed in the Customizer and that all of the theme's functionality can be initialized properly. If you customize the query param used for AMP URLs to be different from the default of amp
(via the amp_query_var
filter) then you must do this in a plugin before this plugins_loaded
action occurs. Otherwise, you will not be able to select a Reader theme other than Legacy. Reader themes require the use of a URL query param (e.g. ?amp=1
) as opposed to an endpoint (e.g. /amp/
), though we intend to improve the customization of this in the future (see #2204).
Adding Reader Themes
By default any of the core themes may be selected for Reader mode (except for the non-responsive Twenty Ten). The plugin will likely add more AMP-compatible ecosystem themes to the default list in the future, but if you'd like to include a custom AMP-compatible theme to the list there is a filter to do so, for example:
add_filter( 'amp_reader_themes', function ( $reader_themes ) {
$reader_themes[] = [
'name' => 'Neve',
'slug' => 'neve',
'preview_url' => 'https://wp-themes.com/neve',
'screenshot_url' => 'https://i0.wp.com/themes.svn.wordpress.org/neve/2.7.5/screenshot.png?w=1144&strip=all',
'homepage' => 'https://themeisle.com/themes/neve/',
'description' => 'This is a non-core theme.',
];
return $reader_themes;
} );
In addition using the amp_reader_themes
filter, themes can also mark themselves as AMP-compatible. Installed themes can include themselves in the list by adding AMP: true
to their style.css
. Additionally, they can provide a screenshot-mobile.png
(or screenshot-mobile.jpg
) alongside the theme's normal screenshot.png
for better presentation in the list of Reader themes. #5222, #5230
Issues and pull requests related to Reader mode: #2044, #4560, #4476, #4708, #4478, #4708, #4475, #4475, #4984, #4784, #5037, #5019, #5008, #4999, #5028, #5060, #5039, #5137, #5041, #5077, #5107, #5076, #5136, #5159, #5070, #5159, #5102, #5170, #5212, #5257, #5258, #5270
Onboarding Wizard
Upon activating the AMP plugin, a banner is displayed on the plugins screen prompting the user to go through an onboarding wizard which guides the user through the configuration flow of the plugin. After an initial welcome screen, users are asked whether they have technical experience. Based on the answer to that question, the plugin recommends which template mode is likely best for the user considering their experience and the currently active theme. When selecting Reader mode, a collection of themes are then presented for serving AMP pages (by default all the core themes). The selected theme will be installed if it is not already; if it cannot be installed, the theme will not be selectable and a message will indicate it must be installed separately. A summary screen then confirms to the user how the plugin is configured, and if in Transitional or Reader mode, they can decide whether or not they want to redirect mobile visitors to the AMP version if available. Lastly, on the final screen the AMP version of the site is presented in an iframe
with links for them to browse around the site or open the AMP Customizer to make changes to the design.
The following screenshots depict the onboarding flow sequence:
Screen | Screenshot |
---|---|
Welcome | |
Technical Expertise Question | |
Template Mode Selection | |
Reader Theme Selection | |
Summary | |
Done |
Issues and pull requests related to the Onboarding Wizard: #1288, #4699, #4700, #4765, #4702, #4800, #4703, #4909, #4709, #4710, #4990, #4705, #4833, #4706, #4900, #4707, #4954, #4718, #4741, #4801, #4945, #4811, #4837, #4812, #4859, #4827, #4828, #4922, #4943, #4961, #4963, #4962, #4966, #4971, #4973, #4972, #4980, #4974, #4975, #5016, #5038, #5024, #5033, #5017, #5067, #5045, #5092, #5086, #5123, #5127, #5128, #4684, #4871, #5116, #5124, #5125, #5082, #5092, #5048, #5139, #5114, #5118, #5100, #5071, #5142, #5143, #5147, #5164, #5192, #5148, #5149, #5151, #5193, #5211, #5234, #5235, #5280
Settings Screen
The AMP Settings screen has been completely rewritten to reuse the same components which are also used in the wizard. These changes greatly improve the presentation of the settings and the user experience for making changes. It is also possible to reopen the configuration wizard from the Settings screen at any time.
There is also now a Settings link in the AMP admin bar menu.
The analytics page nas also been merged into a revamped Analytics section on the settings screen. Vendor type checking is now added, as well as the vendor being optional for in-house analytics. Better guidance is now offered when adding analytics for googleanalytics
or gtag
. #5013, #5155, #5190, #5216, #5199, #5200
Here's how the settings screen looks now, though a few more tweaks are planned for 2.0 final:
Issues and pull requests related to the Settings Screen: #4704, #4998, #5015, #5044, #5046, #5018, #5049, #5043, #5020, #5042, #4993, #5058, #5059, #5013, #5155, #5264, #5265
Mobile Redirection
Originally AMP stood for “Accelerated Mobile Pages” but this is no longer the case as AMP is actually a fully responsive Web framework, and AMP-powered sites can bring a user-first experience to users on both desktop and mobile. Ideally a website would be built AMP-first leveraging the plugin's Standard mode so that desktop and mobile visitors get the same performance and user experience benefits of AMP, while also reducing the site owner burden to maintain two separate versions of a site, as AMP pages can be fully styled using responsive design. Nevertheless, it is on mobile devices where an AMP experience is most important, and AMP remains a popular option to ensure mobile visitors get a great UX. This harkens back to the days before responsive web design when “m-dot” sites with adaptive design were standard. And a common request from plugin users has been for the provision of a mechanism to redirect mobile visitors from the canonical version to the non-AMP version of a page automatically. As of v2.0, site owners can configure the AMP plugin to automatically redirect mobile visitors to the AMP version of the site.
On the plugin settings screen, there is a new toggle for enabling automatic mobile redirection. This is only available when a site is in Transitional or Reader modes (i.e. paired AMP modes) since in Standard mode there is no separate AMP version to redirect to. When on the AMP version, a new “Exit mobile version” link appears in the footer of the page. The link text of which can be filtered via amp_mobile_version_switcher_link_text
and the default GitHub-inspired gray styling and system UI font can be turned off via add_filter( 'amp_mobile_version_switcher_styles_used', '__return_false' )
. The link takes the user to the same URL but with ?amp
replaced with ?noamp=mobile
. This query parameter prevents redirection back to the AMP version and it suspends automatic redirection for the remainder of the browsing session. To return to the AMP version, a similarly-styled link in the footer of the non-AMP version of the page is added for mobile visitors. The old “Exit Reader Mode” link which previously appeared in the header of the legacy Reader mode templates has been eliminated in favor of this new footer link (see #4573).
When mobile redirection is enabled, AMP-to-AMP linking is automatically enabled. This ensures that navigating around the AMP version of the site will not result in the user constantly having to wait for a redirect from the non-AMP to the AMP version. To facilitate indicating which links should be rewritten to point to the AMP versions, an amp_to_amp_linking_element_excluded
filter is added which allows opting out of AMP-to-AMP linking on a per-link basis; previously an array of all such link URLs had to be supplied via the amp_to_amp_excluded_urls
filter. Any links which are excluded from AMP-to-AMP linking will automatically include ?noamp=mobile
added to them to prevent any possible undesirable redirection to the AMP version. See #4913.
In addition to AMP-to-AMP linking, the non-AMP version of the page now includes a rel=alternate
link pointing to the AMP version alongside the existing rel=amphtml
link.
Footer Link on AMP Pages | Footer Link on Non-AMP Pages |
---|---|
Client-side vs Server-side Redirection
By default the AMP plugin uses JavaScript injected as early as possible at the wp_head
action on a non-AMP page to detect whether the user is on a mobile device, and if so, stop loading the page and redirect to the AMP version. JavaScript is used by default because it is the most compatible with the various server stacks and caching layers that a WordPress site may be running on. Nevertheless, JavaScript redirection is slower than redirecting server-side with an HTTP response from PHP. If you can ensure your page caching will vary responses by the user agent in the same way as wp_is_mobile()
does, then you may opt-in to server-side redirection via the PHP code: add_filter( 'amp_mobile_client_side_redirection', '__return_false' )
. There is also an amp_pre_is_mobile
filter which can be used to short-circuit the server-side mobile user agent detection if the mobile determination has already been made. When server-side redirection is enabled, the Vary: User-Agent
response header is sent.
The user agent strings used in wp_is_mobile()
were copied into the AMP plugin in order to be used in both client-side and server-side redirection. If you want to customize the user agents used to identify mobile visitors, you may use the amp_mobile_user_agents
filter. For example:
add_filter( 'amp_mobile_user_agents', function( $user_agents ) {
$user_agents[] = 'Eyeglasses';
$user_agents[] = '/wear|watch/i';
return $user_agents;
} );
Issues and pull requests related to Mobile Redirection: #4479, #4796, #4913, #4987, #5194, #5080, #4968, #5088, #5203, #5214, #5251, #5255
Developer Tools
Before v2.0, the AMP plugin Developer Tools were enabled for all users who have permission to edit posts. Having them enabled means that validation error notices would be shown in the editor and validation information would be shown in the admin bar. Exposing the validation status and errors is great for technically savvy users that can do something about the information presented. But, that information was disconcerting (and annoying) to users who had no possibility of doing anything about the issues, or that do not understand what they mean. We received many requests on our support forum to make the plugin more user friendly by having the flexibility of hiding these.
Toggling Developer Tools
Developer Tools are now limited to being available to administrators by default. This means that when a user with another role (e.g. author) edits a post, they will no longer be presented with AMP validation error notices. Additionally, there will not be additional latency to wait for a loopback request to be performed to obtain the validation results. Users with Developer Tools disabled will no longer see the "Validated URLs" or "Error Index" admin menu items, and they will no longer be told of the AMP validation status in the admin bar when viewing an AMP. When a user goes through the onboarding wizard and they indicate they don't have technical experience, then Developer Tools will be turned off for them.
Developer Tools are now available in Reader mode whereas before they were disabled. The feedback we have received is that most users do not wish to see the validation error notices because they don't have the desire or ability to fix the issues. Administrators, in contrast, are able to deactivate plugins which are causing validation errors, or upload new plugins which fix the AMP incompatibilities. Administrators who do not wish to see validation errors can also turn off Developer Tools in their user profile. Notice that when Developer Tools are turned off, the plugin will soon still perform validation in the background and alert administrators even who have Developer Tools turned off via Site Health; for more see #1756.
Admin bar with Dev Tools turned off | Admin bar with Dev Tools turned on |
---|---|
Developer Tools are made available to users who have the new amp_validate
meta capability which maps to manage_options
by default. If a site needs to grant access to users with the editor role, for example, this can be done with a map_meta_cap
filter like so:
add_filter(
'map_meta_cap',
function ( $caps, $cap, $user_id ) {
if ( 'amp_validate' === $cap && user_can( $user_id, 'edit_others_posts' ) ) {
$position = array_search( $cap, $caps, true );
if ( false !== $position ) {
$caps[ $position ] = 'edit_others_posts';
}
}
return $caps;
},
10,
3
);
Issues and pull requests related to toggling Developer Tools: #2673, #4480, #4955, #4986
Developer Tools Validation Screens
The validation workflows and the presentation of validation information to users has been greatly improved in this release:
- Changing the status of a single validation error no longer causes all other validation errors to be marked as reviewed (i.e. removal of the orange unmoderated styling). A new “Reviewed” column is added to the validated URL screen next to the “Status” column so that the status (removed vs kept) can be manipulated independently from whether a validation error has been reviewed. #3725, #4382, #4941, #5000
- Validation status icons now use Dashicons rather than emoji and colorized versions of the AMP logo; the use of the logo was especially problematic for accessibility purposes and because the green version can be confused with the Jetpack logo. #3726, #4382, #4940, #4942
Reviewed Removed Markup | Unreviewed Removed Markup | Invalid Markup Kept |
---|---|---|
- Delete parsed stylesheets from
amp_validated_url
posts once they become stale (older than 1 week). This reduces a lot of database storage. Restoring stylesheet information for a validated URL can be done by just re-checking the URL. #5132, #5150 - Theme and plugin versions are now included in determining whether a validated URL is stale. #3474, #5031, #4657
- Expose fatal errors that occur while validating a URL. #4580, #4542
- Suppress validation errors that may occur from fatal errors being displayed. #4747, #4746
- Prevent automatically redirecting AMP pages with kept invalid markup to the non-AMP version when the authenticated user has Developer Tools enabled. #4626, #4796
- Prevent other plugins from erroneously adding row actions and metaboxes to validation screens. #4448, #4534
- Prevent scoping total error index count in admin menu. #5144
- Indicate reviewed status when viewing an individual validation error. #4805, #5196
- Ensure paired browsing
template_include
filter overrides other filters. #5198 - Apply
https_local_ssl_verify
filters forsslverify
in validation loopback requests. #2287, #5237 - Remove checkbox column from error index since bulk actions removed. #5266
- Only show fatal errors on Validated URL screen when
WP_DEBUG_DISPLAY
is enabled. #5243
Plugin Suppression
Before v2.0, when users had a plugin that is not AMP compatible, the AMP plugin would flag the validation errors encountered, and the user would have the ability to suppress the output of the invalid markup. This had to be done on an error-by-error basis, which can be very tedious. Furthermore, this action would only prevent the invalid markup to be generated but other valid markup would be left in place, potentially resulting in half-broken plugin functionality on AMP pages. The possible resolutions were:
- Determine the invalid markup is OK to be removed and mark it as reviewed.
- Try to create a plugin shim that fixes the AMP incompatibility.
- Switch to a different plugin that is AMP-compatible.
In some cases, however, none of these may be good options. A specific plugin may be adding essential functionality which needs to be fully functional on non-AMP pages. Simply marking validation errors for invalid markup as being OK to remove still means that markup is causing validation errors even though reviewed errors are no longer being flagged in the admin bar. Also, many plugins do not have graceful fallbacks for when JavaScript is turned off, so removing the invalid markup may result in a broken page.
A new option is now available: the AMP plugin now includes "Plugin Suppression" functionality. When validation errors are caused by a plugin, the plugin will appear highlighted in the list of active plugins in the new Plugin Suppression section of the AMP settings screen. In the table of plugins, each row includes the plugin name, author, and description with a summary of the validation errors the plugin is causing (if any). Each row also includes a dropdown with allow you to mark the plugin either as “Active” or “Suppressed”.
When a plugin is suppressed, as soon as it is determined an AMP page is being served, plugins are suppressed by:
- Unhooking filters and actions whose callbacks are defined in the plugin (including hooking into
wp_enqueue_scripts
). - Overriding shortcodes with plugin-defined callbacks to just
__return_empty_string
. - Overriding widgets with plugin-defined callbacks to just
__return_null
. In addition to this, the display is also blocked with thewidget_display_callback
filter to ensure widgets rendered withthe_widget()
are accounted for. - Overriding dynamic blocks with plugin-defined callbacks to just
__return_empty_string
and to also nullify the frontendstyle
andscript
.
When a plugin is suppressed, the Plugin Suppression table will indicate when the plugin was suppressed and who suppressed it. When the plugin has been updated since the time it was suppressed, this is also indicated, giving you a chance to see if the plugin changelog may have indicate the AMP incompatibility has been fixed or else that you can re-check the plugin for AMP incompatibilities.
Issues and pull requests related to Plugin Suppression: #4477, #3474, #4657, #5014, #5040, #4889, #5009, #5126, #5133, #5145, #5158
Template Mode Selection and Template Availability
- Decouple supported post types from whether all templates are supported. All templates can now be enabled to serve AMP, but specific post types can be still excluded from AMP. Additionally, a
amp_supportable_post_types
filter is introduced which allows you to add/remove which post types are even offered for being enabled as AMP, other than this being a fixed set of allpublic
post types. #5050, #5053
Serve all templates as AMP | Serve select templates as AMP |
---|---|
- Eliminate the use of
amp
theme support to programmatically force whether Standard or Transitional mode is active. The database option now controls the mode, with anyamp
theme support just informing the default value mode when first activating the plugin. If you are doingremove_theme_support('amp')
this will no longer disable AMP for the response. #5010 - Discontinue referring to the
amp
theme supportsupported_templates
argument (andamp_supportable_templates
filter) to force AMP to be enabled forall
templates or for select templates. This flag is largely obsolete, as its only purpose now is to configure the initial behavior of the plugin once activated in that it can specify that all templates should have AMP enabled or rather a certain subset of templates should be supported. Once activated, the user can now override the enabled templates based on the site's needs. #2724, #5010 - Similarly to the supported templates and
amp
theme support, post types now no longer depend onamp
post type support to be added to be served as AMP. The post type support's sole purpose is just to ensure AMP is enabled by default for a post type. After plugin activation, regardless of whetheramp
support has been registered for a post type programmatically, the user can decide which post types should be enabled for AMP. #5010 - When a theme declares
amp
theme support, default topaired
beingtrue
meaning that the theme works in Transitional mode or for templates to have AMP turned off. This is practically how almost any theme has to be written, and thus thepaired
flag is largely meaningless. Supplyingpaired
asfalse
is an indication the theme prefers Standard mode, but with Bento AMP this will become less relevant. #2724, #5010 - Refactor conditional checks in
is_amp_endpoint()
and improve guidance when_doing_it_wrong()
. #4525, #4574, #5165, #5195 - To go along with
amp_is_endpoint()
(formerlyis_amp_endpoint()
) there is also anamp_is_available()
function which can be used to determine whether there is an AMP version available for the current (non-AMP) page. #4619, #4796 - When a site is in Standard mode and a user has Developer Tools enabled, a “View with AMP disabled” menu item is added to the AMP admin bar menu which allows administrators to see what the URL looks like with AMP disabled. This is useful for debugging and checking theme/plugin compatibility. #4796
Optimizer
- Implement transformer in Optimizer to ensure that
media
,sizes
, andheights
attributes do not block server-side rendering (SSR). #4213, #4214, #4439, #4482 - Add documentation for Optimizer. #4216, #4613, #4840
- Add locking of release branches to specific versions of Optimizer. #4826
- Fix failing Optimizer spec tests with ID generation. #4798, #4799
- Reverse style traversal when turning sizes attribute into CSS. #5263
Initialization
- Move
amp_is_enabled
filter to apply inamp_bootstrap_plugin()
so that plugins can short-circuit all services from initializing. 👉 Please note that adding this filter now must be done before theplugins_loaded
action! This is a backwards-incompatible change. Previously the filter was applied atafter_setup_theme
, and_doing_it_wrong()
will now fire if a filter tries to disable AMP too late. #5152, #5153 - Prevent finishing template rendering initialization if not on frontend. #5197
- Eliminate regex used to determine if content from output buffer is a valid HTML document since done actions now used. #5217
- Abort AMP post-processing if an expected template actions are not triggered (e.g.
wp_head
andwp_footer
). #5202
Embeds
- Prevent
gallery
shortcodes form unexpectedly showing as carousels by default in Transitional/Standard mode (and when a Reader theme is selected). Allow gallery carousel to be turned off in legacy Reader mode, where it remains enabled by default. Prevent block validation errors from occurring when deactivating AMP plugin. Fix captions in carousel which contain markup. #4774, #4775 - Use
amp-embedly-card
instead ofamp-iframe
for TikTok. #4633, #4682, #5094 - Defer sanitizing core widgets until post-processing to ensure compatibility with
the_widget()
. This eliminates AMP-specific subclasses of a select number of core widgets. #4492, #4515 - Remove obsolete Vine and Hulu embed handlers. #4673, #5072, #5073
- Add missing context element for XPath when processing video shortcodes in Text widgets. #5066, #5074
Editor
- Removed the notice about AMP not being available when editing a post if the user does not have the capability to enable AMP for the post. When shown to admins, the notice is shown as informational rather than as a warning. #1864, #4593, #5010
- Fix “Enable AMP” toggle doesn't work when custom fields advanced panel is enabled. #4659, #4689
Sanitization and Conversion
- Discontinue removing
sizes
attribute when convertingimg
toamp-img
. #4606, #4548, #4622 - Ensure that multiple
denylist
patterns apply to CDATA. #4319, #4548 - Catch validation errors for implicit layout missing width and height. #4465, #4541
- Allow boolean attributes to repeat attribute name as attribute value (e.g.
disabled="disabled"
). #5156, #5157 - Cherry pick AMP validator spec update to fix validation of
loop
attribute foramp-bodymovin-animation
component. #5245, #5267
CSS
- Fix parsing of class names like
w-1/3
as used in selectors like.w-1\/3
, such as those used in TailwindCSS. #4609, #4610 - Update PHP-CSS-Parser library to prevent
var()
functions inside ofrgba()
from being dropped. #5023, #5081 - Prevent sanitization of Customizer preview styles, eliminating the use of
allow_dirty_styles
andallow_dirty_scripts
in favor of marking Customizer assets withdata-ampdevmode
. #4977, #4804, #5006, #5019 - Disable CSS tree shaking and CSS limit in Customizer preview. This applies to Standard mode and in the AMP Customizer for Reader mode. #5104, #5105
- Fix layout bug with navigation menu in Twenty Twelve by replacing focus selector with a common class selector when used in a descendant combinator. #5246, #5248
Parsing
- Ensure emoji AMP attribute can be restored if non-space whitespace used between attributes. #5098
- Restore
noscript
head elements immediately after parsing rather than at serialization to ensure that they are sanitized. #5097
Schema.org Metadata
- Supply
ImageObject
type forpublisher.logo
in Schema.org metadata as opposed to a bare URL string. #5121
Site Health
AMP Spec
- Update amphtml validator spec to 2004142326360. #4548
- Update amphtml validator spec to 2005050322002. #4701
- Update amphtml validator spec to 2005150002001. #4817
- Update amphtml validator spec to 2006112352000. #4892
- Update amphtml validator spec to commit 3aa007a (spec file rev 1060). #5075
Misc Bugfixes
- Make
amp_get_current_url()
more robust. #4807, #5051, #5219 - Remove escaping of title in legacy post templates. #5026
- Avoid version lock-in for libs for now. #5273
Infrastructure and Testing
- Renamed
phpcs.xml
to.phpcs.xml.dist
andphpunit.xml
tophpunit.xml.dist
. #1324, #4844 - Update PHPStan levels. #4377, #4732, #4380, #4685
- Update PHPStan. #4745, #4738, #5054, #5057
- Prevent building zips for PR if it's from a forked repository. #4872, #4873
- Use latest Gutenberg plugin version for tests. #4901
- Use latest PWA plugin version for tests. #4912
- Fix phpunit tests in WP 5.5. #5032
- Add PHP 8 as a build job on Travis; bump some jobs up to PHP 7.4. #4894
- Add PHP Compatibility testing to external libraries and use PSR-12 as baseline standard. #4655, #5084, #5085
Dependencies
Architecture
- Integrate a dependency injector. #4876, #4877, #4898, #4916
- Add
Option
class which contains constants for the AMP option keys. #4526, #4545
Performance
- Add
Server-Timing
metrics to backend code which will be sent with every response. In contrast to the previous implementation ofServer-Timing
, the new implementation only sends 5 entries with 1 digit of sub-millisecond precision, which will prevent the header from becoming too large. Full verboseServer-Timing
output is available when the user is logged-in as an admin. #4970, #5005, #5061
Documentation
- Generate documentation reference markdown by parsing source code. #5206, #5274
- Update readme with new content for the plugin page. #5160
- Move contributing docs to wiki. #4473, #4581, #4575, #4592, #4794
- Add
@internal
phpdoc tags to all classes, functions, and hooks not intended for developers to use. #5119, #5218 - The function
is_amp_endpoint()
has been renamed as AMP-prefixedamp_is_request()
andpost_supports_amp()
has been renamed asamp_is_post_supported()
. The old non-prefixed versions still exist, but they are soft-deprecated as aliases and won't be raising deprecation warnings. #5218, #5231 - The misnamed
amp_frontend_show_canonical
filter is also now marked as deprecated. #5218 - Update link to analytics documentation. #5262
- Add missing internal tags on deprecated code. #5261
- Annotate
AnalyticsOptionsSubmenu
class as internal. #5260 - Add missing
@internal
tag to function in bootstrap file. #5259 - Remove unused
REMOVED_SOURCES
constant. #5269
Removed
- Eliminate the use of 'master' branch name and whitelist/blacklist terminology. Remove long-deprecated
AMP_Blacklist_Sanitizer
. #4886, #4887, #4888, #4892, #4906, #4907, #4914, #4915 - Remove the unused
AMP_CUSTOMIZER_QUERY_VAR
constant (asamp_get_slug()
should be used instead). - Remove the long-deprecated
active_callback
argument toamp
theme support.
Props
Thanks to the many contributors who made this release possible through work on development, design, testing, project management, and more:
Alain Schlesser (schlessera), Alberto Medina (amedina), Hans Schuijff (hansschuijff), John Watkins (johnwatkins0), Joshua Wold (jwold), Kasper Myram (kmyram), Paola Stoyanova (PaolaStoyanova), Pascal Birchler (swissspidy), Pierre Gordon (pierlon), Piotr Delawski (delawski), Renee Johnson (ernee), Sjoerd Boerrigter (sboerrigter), Weston Ruter (westonruter)
Installation
Now available to install via WordPress.org.
You can also install the amp.zip
build linked below by uploading it in the WordPress admin.
To install as a Git submodule, consider 2.0.0-built.