-
Notifications
You must be signed in to change notification settings - Fork 106
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
Partytown support #176
Comments
Thanks for this proposal @luisherranz... cc: @westonruter who maintains the PWA plugin |
@luisherranz I would like to take this one. Can you please assign it to me? |
Hey @thelovekesh, great to hear that 🙂 I don't have permission to add assignees, but Weston or someone else will do it. What approach are you going to follow? |
Sorry for the late reply @luisherranz. I was working around an approach to show users an option, to enable Execute third-party scripts in Worker thread . Once it enables, enqueue the party town script in the head. Now idea is to append wp_enqueue_script(
'non-critical-script',
plugins_url( 'non-critical-script.js', __FILE__ ),
array('partytown'),
'1.0.0'
); Expected output: // Loaded in Partytown Web Worker
<script type="text/partytown" src="/wp-content/plugins/labs/non-critical-script.js?ver=1.0.0"></script> But appending the type attribute based on script dependency will be the best approach?
Related to exposing a filter to configure partytown, I agree with the approach suggested above 👍🏼 |
I have created a POC for testing this functionality. Steps to use these plugins:
require_once plugin_dir_path( __FILE__ ) . 'examples/counter.php';
require_once plugin_dir_path( __FILE__ ) . 'examples/get-request.php';
require_once plugin_dir_path( __FILE__ ) . 'examples/post-request.php'; 1.mp4I have used the approach discussed in #176 (comment) |
Wow! That's awesome Lovekesh. I've just tested and it works great 😄 👏
I don't know, to be honest. @adamsilverstein, what do you think? What alternatives do we have? (until we have something like #168). @thelovekesh: Will you be willing to submit a PR to add it as a module so it can be tested by all the users of this plugin? That way it's also easier for other members of the Performance Team to contribute to the code 🙂 |
Thank you @luisherranz ! Glad you liked it.
Of course, I will raise the PR ASAP probably by Monday so that team can release it in upcoming version very soon. |
@luisherranz I have raised the PR to add this as a module. Please have a look and let me know your thoughts. |
Hi @thelovekesh , awesome work! I tried locally and it works for the second and third test, but not for the first test (the only thats enqueue a script). When I click the button it not increment the counter. Furthermore, basing on the official doc (for the second and third tests), I see that the script changes in |
@thelovekesh I add that I tried it on a Wordpress clean installation (same theme of you and with only your plugin active). Thank you! |
I tried it too and I have the same result as @alessandrocarrera. Is anything new about this and PR #271 ? :) |
Thanks for testing, @alessandrocarrera and @erip2! @thelovekesh Are you able to take a look? |
Hello @alessandrocarrera @erip2 If I am not mistaken, you have tried to work with the POC plugin . To enable partytown with that plugin you first have to allow partytown in the plugin's settings( To avoid such confusions in future I will enable partytown setting in the POC plugin by default 👍🏼 @bethanylang I have tested and confirmed that functionally is fully working on both the POC plugin and raised PR. |
I did enable this option. |
@thelovekesh me, too. |
@erip2 @alessandrocarrera Can you try this on a fresh installation without the performance plugin? Also please check if it's enqueueing the Edit: |
Trying in my theme, but now none of the examples work. Can confirm that the The window.partytown returns:
I should note that I haven't installed the "Performance Lab" plugin. Trying it in the plugin with |
@erip2 I think in your case either the service worker is not registered correctly or is unable to intercept dom events. You can find a similar issue here - QwikDev/partytown#107 |
Are you testing this with |
I've just finished some research on the sandboxing capabilities of Partytown, which hadn't before been documented. I just blogged a writeup: Sandboxing with Partytown |
Very interesting, Weston. Thanks for sharing. |
Hello, I'm new to this and I'm trying to optimize WordPress with the Partytown plugin. I have installed and activated it in the settings, I can see it in the source code, but it has not been applied to third-party scripts and my performance numbers in PageSpeed are still the same. |
I saw now this ticket but an year ago I did an experimental plugin that just enable all the js registered for partytown in wordpress https://github.com/CodeAtCode/wp-partytown Probably the only thing to do is update the assets that aren't updated since a while. So maybe can be interesting to have a dedicated plugin as it is too much effort for the performance plugin (in a previous PR there was some doubt about that is a beta project etc)? |
Description
I'm opening this issue to discuss how WordPress could take advantage of Partytown to improve its performance.
What is Partytown?
Partytown is a library to execute scripts inside a Web Worker and off the main thread. Its main goal is to increase the site's performance freeing the main thread by offloading non-critical scripts to a Web Worker. It acts as a bridge between the Web Worker and the DOM in a way that is 100% transparent to the executed script.
How does Partytown work?
Scripts use the type
"text/partytown"
to avoid running in the main thread. Partytown loads those scripts inside a Web Worker that has a proxied version of all the DOM APIs. When the script access a DOM API, the proxy intercepts it and uses one of these two implementations:If neither Atomics nor Service Workers are available, Partytown just runs the scripts in the main thread.
It's probably worth noting that when a script executed inside a Partytown Web Worker adds a new script (using APIs like
document.createElement('script')
), that script is also added inside of the Web Worker and not leaked to the main thread.More information about how it works in their official docs.
Partytown tradeoffs
fetch()
, so they need to have CORS headers (or they need to use a proxy).event.preventDefault()
will have no effect.More info about the tradeoffs in their official docs.
Restricted access to DOM APIs
Because scripts executed with Partytown are sandboxed and it controls the bridge, site owners can increase the security/control over those scripts by allowing or denying access to the DOM APIs on a per-API basis.
I don't think Partytown has an API to control this yet, but they have mentioned it several times.
Partytown Status
Partytown is still a young project. It moved from Alpha to Beta on 5th Jan 2022.
Goals
Proposals
1. Add a
worker-partytown
strategy onwp_enqueue_script
Following @adamsilverstein proposal of a
strategy
parameter onwp_enqueue_script
(#168), plugin developers could simply opt-in to execute any script in a Partytown Web Worker by using theworker-partytown
strategy.There could be other worker strategies as well, so I'd suggest using
worker-partytown
for this one. For exampleworker-dom
for WorkerDOM or simplyworker
for a regular Web Worker.With this API, plugins could start offering the Web Worker option to their users:
We could expose a filter to allow plugins to configure Partytown:
2. Partytown module/plugin
Create a module that exposes a user interface to let the site admins configure which services they want to execute inside a Partytown Web Worker.
We could add integrations one by one, making sure Partytown supports those services. If necessary, it should also take care of configuring the forwarded events.
Integrations could use regular expressions to find the scripts in the HTML and add the
type="text/partytown"
attribute to the script tag. For example, identify scripts withhttps://www.google-analytics.com/analytics.js
and/orga(...)
for Google Analytics.If this module is successful, we could export its functionality to a Partytown plugin.
Service Worker integration
We would probably want to integrate it with the PWA plugin and only add the Service Worker directly if the PWA plugin is not present.
The text was updated successfully, but these errors were encountered: