-
Notifications
You must be signed in to change notification settings - Fork 4.3k
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
Script Modules API: update the code and move it to the compat/wordpress-6.5 folder #57778
Conversation
This pull request has changed or added PHP files. Please confirm whether these changes need to be synced to WordPress Core, and therefore featured in the next release of WordPress. If so, it is recommended to create a new Trac ticket and submit a pull request to the WordPress Core Github repository soon after this pull request is merged. If you're unsure, you can always ask for help in the #core-editor channel in WordPress Slack. Thank you! ❤️ View changed files❔ lib/compat/wordpress-6.5/class-wp-script-modules.php ❔ lib/compat/wordpress-6.5/scripts-modules.php ❔ lib/experimental/script-modules.php ❔ lib/compat/wordpress-6.5/class-wp-navigation-block-renderer.php ❔ lib/experimental/interactivity-api/modules.php ❔ lib/load.php |
Let's wait until a final decision on the naming has been made to merge this. |
I was about to say the same. |
|
a5017bc
to
c850f71
Compare
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.
We still need to keep gutenberg_register_module
, gutenberg_enqueue_module
and gutenberg_dequeue_module
for at least a couple of versions in Gutenberg, in case someone was already using it.
I don't know how to do deprecation notices in WordPress, but if that is possible, we should add them.
c850f71
to
c454a02
Compare
This could be an example about how to do it. I'll update it. gutenberg/lib/block-supports/duotone.php Line 188 in c454a02
Works like a charm! |
I was able to reproduce locally using wp-env with this PR checked out and using latest wordpress-develop for core and using PHP 7.0. This did not have any problem for me using the default PHP version. I had a {
"core": "../../wordpress-develop/build",
"phpVersion": "7.0"
} I pushed a fix, feel free to do what you like with it. I suspect that in PHP 7 it's parsing the entire file so it sees the class name even though it looks like there's an early return. |
Thanks @sirreal!
Any clue why returning early was not working on this file, but it seems to work fine in other files? if ( class_exists( 'WP_Script_Modules' ) ) {
return;
} |
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.
Ok, this should be ready to go, but the e2e tests are failing because this hasn't been committed to WordPress Core yet:
We have to wait until that happens to be able to merge.
Now that WordPress/wordpress-develop#5931 has been committed to Core (thanks @youknowriad!) the tests pass and we can merge this. @c4rl0sbr4v0 can you take a final look before I merge? |
Not really and that worries me 😅 I'd like to do some more experimentation but can't invest the time right now. All versions of PHP seem to see the class in the same file when there's an early return. The safest thing would be to avoid that pattern completely. See this example: <?php
if ( class_exists( 'A' ) ) {
echo "EXISTS A\n";
return;
} else {
echo "NO EXISTS A\n";
}
class A {} This prints "EXISTS A" in every PHP version. I'm not sure why the "early return" ever works without errors.
That mentions functions but I assume that also applies to classes, but 🤷 it's not very clear. |
I removed some "we" in the docs, as is a common review in WordPress Core. Nothing special, apart from that, it's OK to merge this once tests are done. |
I've seen in other parts of the project that contributors add that bail out in both |
Yep. I still see it working in other places just fine 🙂 Something must be going on, but 🤷♂️ |
Nope, it seems like it's just functions that are problematic. I'm really not sure what's going on with that one case in certain PHP versions. |
Because they don't seem to work: #57778 (comment)
* Initial SDP version * Rename `initialState` to `state` * Fix incorrect package * Properly remove the SDP during the e2e tests * Update multiline comments to fit WP standards * Add @access private to WP_Interactivity_API_Directives_Processor * Remove array check and rename bookmarks in WP_Interactivity_API_Directives_Processor * Dont print config/state if it's empty * Add failing test for </ > * Add missing `object` word * Missing indentation on ternary conditionals * Improve namespace extraction from directive value * Move modified properties to the end in set_style_property * Replace tabindex comment * Remove filter after processing and bump priority * Replace own is_void with HTML API one * Missing ternary indentation * Avoid early returns Because they don't seem to work: #57778 (comment) * Update wp_register_script_module function * Replaces some incorrect docblock comments with block comments * Fix indent ternaries (again) * Add more info about how extract_directive_value behaves * Add more edge cases * Improve wp_interactivity_process_directives_of_interactive_blocks comment --------- Co-authored-by: Carlos Bravo <carlos.bravo@automattic.com>
} | ||
wp_register_script_module( | ||
'@wordpress/block-library/file-block', | ||
gutenberg_url( '/build/interactivity/file.min.js' ), |
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.
Hey folks, this is breaking the package update in Core. The block library php files are copied as is into WordPress Core. Meaning we should ensure they work there without changes.
These Gutenberg specific function calls are there for not something we should be using. I see that the previous versions had these being the IS_GUTENBERG_PLUGIN to solve that.
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.
Opsss. Our bad. I'll open a PR right away!
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.
Do you want us to release a 17.6.1 RC with the fix?
cc: @c4rl0sbr4v0
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.
We will do a RC2. We don't need a 17.6.1 yet, as 17.6 won't be released until next week 😅
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.
There you go:
I noticed this PR was merged after I raised the PHP Sync Tracking Issue for WP 6.5 and has changed PHP files that may need backporting to WP Core. Please forgive the ping, but I marked as |
This has already been backported in all the PRs related to the Script Modules API. (I reported it yesterday here but I forgot to add the backport label here, sorry 🙏). |
I removed the |
There's an issue about the |
Thank you for the detailed updates @luisherranz |
What?
Modules API has been approved in Core. But was as experimental instead of 6.5 compat folder.