From 735b906afccc6bacfe8e4f5ca4decbbfebb6dc09 Mon Sep 17 00:00:00 2001 From: Joen A <1204802+jasmussen@users.noreply.github.com> Date: Thu, 22 Feb 2024 14:24:11 +0100 Subject: [PATCH 01/32] Fix group block description regression. (#59271) --- packages/block-library/src/group/editor.scss | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/block-library/src/group/editor.scss b/packages/block-library/src/group/editor.scss index 297658713f4591..7ea432f30f0168 100644 --- a/packages/block-library/src/group/editor.scss +++ b/packages/block-library/src/group/editor.scss @@ -65,7 +65,6 @@ margin: 0; } .components-placeholder__instructions { - text-align: center; margin-bottom: 18px; } .wp-block-group-placeholder__variations svg { @@ -92,6 +91,7 @@ .components-placeholder { min-height: auto; padding: $grid-unit-30; + align-items: center; } .is-small, .is-medium { From 38d7cb6ea5d1acf2e4aee7778472dada3df7cfb4 Mon Sep 17 00:00:00 2001 From: David Arenas Date: Thu, 22 Feb 2024 15:02:53 +0100 Subject: [PATCH 02/32] Interactivity API: Prevent unwanted subscriptions to inherited context props (#59273) * Add failing test * Fix subscription issue * Fix typo Co-authored-by: Carlos Bravo <37012961+c4rl0sbr4v0@users.noreply.github.com> * Change multiline comment to block comment Co-authored-by: Carlos Bravo <37012961+c4rl0sbr4v0@users.noreply.github.com> * Update test name Co-authored-by: Carlos Bravo <37012961+c4rl0sbr4v0@users.noreply.github.com> --------- Co-authored-by: DAreRodz Co-authored-by: c4rl0sbr4v0 --- .../directive-context/render.php | 26 +++++++++++++++++++ .../directive-context/view.js | 18 +++++++++++++ packages/interactivity/src/directives.js | 15 ++++++----- .../interactivity/directive-context.spec.ts | 23 ++++++++++++++++ 4 files changed, 76 insertions(+), 6 deletions(-) diff --git a/packages/e2e-tests/plugins/interactive-blocks/directive-context/render.php b/packages/e2e-tests/plugins/interactive-blocks/directive-context/render.php index 25d2bbc692efdf..6b20b2dba8376e 100644 --- a/packages/e2e-tests/plugins/interactive-blocks/directive-context/render.php +++ b/packages/e2e-tests/plugins/interactive-blocks/directive-context/render.php @@ -170,3 +170,29 @@
+ +
+ +
+ + +
+
diff --git a/packages/e2e-tests/plugins/interactive-blocks/directive-context/view.js b/packages/e2e-tests/plugins/interactive-blocks/directive-context/view.js index 2267868713c41b..fd061100fca641 100644 --- a/packages/e2e-tests/plugins/interactive-blocks/directive-context/view.js +++ b/packages/e2e-tests/plugins/interactive-blocks/directive-context/view.js @@ -88,3 +88,21 @@ const { actions } = store( 'directive-context-navigate', { }, }, } ); + +store( 'directive-context-watch', { + actions: { + increment: () => { + const ctx = getContext(); + ctx.counter = ctx.counter + 1; + }, + }, + callbacks: { + countChanges: () => { + const ctx = getContext(); + // Subscribe to changes in counter. + // eslint-disable-next-line no-unused-expressions + ctx.counter; + ctx.changes = ctx.changes + 1; + }, + }, +}); diff --git a/packages/interactivity/src/directives.js b/packages/interactivity/src/directives.js index 67ad50a4595807..d04c1a1f74d3ed 100644 --- a/packages/interactivity/src/directives.js +++ b/packages/interactivity/src/directives.js @@ -39,13 +39,12 @@ const descriptor = Reflect.getOwnPropertyDescriptor; const proxifyContext = ( current, inherited = {} ) => new Proxy( current, { get: ( target, k ) => { - // Subscribe to the inherited and current props. - const inheritedProp = inherited[ k ]; + // Always subscribe to prop changes in the current context. const currentProp = target[ k ]; // Return the inherited prop when missing in target. if ( ! ( k in target ) && k in inherited ) { - return inheritedProp; + return inherited[ k ]; } // Proxify plain objects that are not listed in `ignore`. @@ -54,11 +53,15 @@ const proxifyContext = ( current, inherited = {} ) => ! contextAssignedObjects.get( target )?.has( k ) && isPlainObject( peek( target, k ) ) ) { - return proxifyContext( currentProp, inheritedProp ); + return proxifyContext( currentProp, inherited[ k ] ); } - // For other cases, return the value from target. - return currentProp; + /* + * For other cases, return the value from target, also subscribing + * to changes in the parent context when the current prop is + * not defined. + */ + return k in target ? currentProp : inherited[ k ]; }, set: ( target, k, value ) => { const obj = diff --git a/test/e2e/specs/interactivity/directive-context.spec.ts b/test/e2e/specs/interactivity/directive-context.spec.ts index 3a566e7c2d9619..85341774c2af4e 100644 --- a/test/e2e/specs/interactivity/directive-context.spec.ts +++ b/test/e2e/specs/interactivity/directive-context.spec.ts @@ -313,4 +313,27 @@ test.describe( 'data-wp-context', () => { await select2.click(); await expect( selected ).toHaveText( 'Text 2' ); } ); + + test( 'should not subscribe to parent context props if those also exist in child', async ( { + page, + } ) => { + const counterParent = page.getByTestId( 'counter parent' ); + const counterChild = page.getByTestId( 'counter child' ); + const changes = page.getByTestId( 'counter changes' ); + + await expect( counterParent ).toHaveText( '0' ); + await expect( counterChild ).toHaveText( '0' ); + // The first render counts, so the changes counter starts at 1. + await expect( changes ).toHaveText( '1' ); + + await counterParent.click(); + await expect( counterParent ).toHaveText( '1' ); + await expect( counterChild ).toHaveText( '0' ); + await expect( changes ).toHaveText( '1' ); + + await counterChild.click(); + await expect( counterParent ).toHaveText( '1' ); + await expect( counterChild ).toHaveText( '1' ); + await expect( changes ).toHaveText( '2' ); + } ); } ); From 2e1d805fa04feba4f609f25153316b71573cfe59 Mon Sep 17 00:00:00 2001 From: Matias Benedetto Date: Thu, 22 Feb 2024 11:16:02 -0300 Subject: [PATCH 03/32] Font collection pagination: add min height to avoid infinite number (#59241) * Add min height to avoid infinite number * improve syntax Co-authored-by: Aki Hamano <54422211+t-hamano@users.noreply.github.com> --------- Co-authored-by: matiasbenedetto Co-authored-by: t-hamano Co-authored-by: carolinan --- .../global-styles/font-library-modal/font-collection.js | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/packages/edit-site/src/components/global-styles/font-library-modal/font-collection.js b/packages/edit-site/src/components/global-styles/font-library-modal/font-collection.js index 6236ea8fe3f246..b792a5c8246c0c 100644 --- a/packages/edit-site/src/components/global-styles/font-library-modal/font-collection.js +++ b/packages/edit-site/src/components/global-styles/font-library-modal/font-collection.js @@ -41,6 +41,9 @@ const DEFAULT_CATEGORY = { slug: 'all', name: _x( 'All', 'font categories' ), }; + +const MIN_WINDOW_HEIGHT = 500; + function FontCollection( { slug } ) { const requiresPermission = slug === 'google-fonts'; @@ -118,7 +121,8 @@ function FontCollection( { slug } ) { // NOTE: The height of the font library modal unavailable to use for rendering font family items is roughly 417px // The height of each font family item is 61px. - const pageSize = Math.floor( ( window.innerHeight - 417 ) / 61 ); + const windowHeight = Math.max( window.innerHeight, MIN_WINDOW_HEIGHT ); + const pageSize = Math.floor( ( windowHeight - 417 ) / 61 ); const totalPages = Math.ceil( fonts.length / pageSize ); const itemsStart = ( page - 1 ) * pageSize; const itemsLimit = page * pageSize; From c915f0baef2474f96ff2cdc4de94db6be90323fa Mon Sep 17 00:00:00 2001 From: Aki Hamano <54422211+t-hamano@users.noreply.github.com> Date: Thu, 22 Feb 2024 23:19:15 +0900 Subject: [PATCH 04/32] URLPopover: restore min-width style (#59274) --- packages/block-editor/src/components/url-popover/style.scss | 1 + 1 file changed, 1 insertion(+) diff --git a/packages/block-editor/src/components/url-popover/style.scss b/packages/block-editor/src/components/url-popover/style.scss index df4e10fe13d534..324d82d4183aab 100644 --- a/packages/block-editor/src/components/url-popover/style.scss +++ b/packages/block-editor/src/components/url-popover/style.scss @@ -58,6 +58,7 @@ text-overflow: ellipsis; white-space: nowrap; margin-right: $grid-unit-10; + min-width: 150px; // Avoids the popover from growing too wide when the URL is long. // See https://github.com/WordPress/gutenberg/issues/58599 max-width: $modal-min-width; From 34c94319042b20cf463973fd5f4de6e58ca67132 Mon Sep 17 00:00:00 2001 From: Carlos Bravo <37012961+c4rl0sbr4v0@users.noreply.github.com> Date: Thu, 22 Feb 2024 16:21:54 +0100 Subject: [PATCH 05/32] Interactiviy API Docs: Merge Interactivity docs to keep consistency with other packages. (#59270) * Merge Interactivity docs * Rephrase some sentences * Move again to docs folder * Fix links * Use toc file for handbook migration: * Address feedback Co-authored-by: c4rl0sbr4v0 Co-authored-by: fabiankaegy Co-authored-by: DAreRodz --- docs/manifest.json | 6 + packages/interactivity/README.md | 133 ++++++++++++++---- .../interactivity/docs/1-getting-started.md | 87 ------------ packages/interactivity/docs/README.md | 33 ----- .../{2-api-reference.md => api-reference.md} | 16 +-- ...png => interactivity-state-directives.png} | Bin .../docs/assets/store-server-client.png | Bin 156828 -> 0 bytes packages/interactivity/docs/toc.json | 8 ++ 8 files changed, 128 insertions(+), 155 deletions(-) delete mode 100644 packages/interactivity/docs/1-getting-started.md delete mode 100644 packages/interactivity/docs/README.md rename packages/interactivity/docs/{2-api-reference.md => api-reference.md} (97%) rename packages/interactivity/docs/assets/{state-directives.png => interactivity-state-directives.png} (100%) delete mode 100644 packages/interactivity/docs/assets/store-server-client.png create mode 100644 packages/interactivity/docs/toc.json diff --git a/docs/manifest.json b/docs/manifest.json index 84c7da42aa8b20..638c5d2b16c83d 100644 --- a/docs/manifest.json +++ b/docs/manifest.json @@ -1679,6 +1679,12 @@ "markdown_source": "../packages/interactivity/README.md", "parent": "packages" }, + { + "title": "API Reference", + "slug": "packages-interactivity-api-reference", + "markdown_source": "../packages/interactivity/docs/api-reference.md", + "parent": "packages-interactivity" + }, { "title": "@wordpress/interface", "slug": "packages-interface", diff --git a/packages/interactivity/README.md b/packages/interactivity/README.md index 0ea49bdea0782f..a0fddb9a42bf28 100644 --- a/packages/interactivity/README.md +++ b/packages/interactivity/README.md @@ -1,62 +1,141 @@ # Interactivity API -> **Warning** -> **This package is only available in Gutenberg** at the moment and not in WordPress Core as it is still very experimental, and very likely to change. +> **Note** +> This package enables the API shared at [Proposal: The Interactivity API – A better developer experience in building interactive blocks](https://make.wordpress.org/core/2023/03/30/proposal-the-interactivity-api-a-better-developer-experience-in-building-interactive-blocks/). As part of an [Open Source project](https://developer.wordpress.org/block-editor/getting-started/faq/#the-gutenberg-project), participation is encouraged in testing this API providing feedback at the [discussions in GitHub](https://github.com/WordPress/gutenberg/discussions/categories/interactivity-api). + +The Interactivity API is available at WordPress Core from version 6.5 [Merge announcement](https://make.wordpress.org/core/2024/02/19/merge-announcement-interactivity-api/) + +These Core blocks are already powered by thi API: +- Search +- Query +- Navigation +- File + +## Installation > **Note** -> This package enables the API shared at [Proposal: The Interactivity API – A better developer experience in building interactive blocks](https://make.wordpress.org/core/2023/03/30/proposal-the-interactivity-api-a-better-developer-experience-in-building-interactive-blocks/). As part of an [Open Source project](https://developer.wordpress.org/block-editor/getting-started/faq/#the-gutenberg-project) we encourage participation in helping shape this API and the [discussions in GitHub](https://github.com/WordPress/gutenberg/discussions/categories/interactivity-api) is the best place to engage. +> This step is only required if you are using this API outside of WordPress. +> +> Within WordPress, the package is already bundled in Core, so all you need to do to ensure it is loaded, by adding `wp-interactivity` to the dependency array of the module script. +> +>This happens automatically when you use the dependency extraction Webpack plugin that is used in tools like wp-scripts. + +Install the module: + +```bash +npm install @wordpress/interactivity --save +``` + +_This package assumes that your code will run in an **ES2015+** environment. If you're using an environment that has limited or no support for such language features and APIs, you should include [the polyfill shipped in `@wordpress/babel-preset-default`](https://github.com/WordPress/gutenberg/tree/HEAD/packages/babel-preset-default#polyfill) in your code._ + +## Quick Start Guide -This package can be tested, but it's still very experimental. -The Interactivity API is [being used in some core blocks](https://github.com/search?q=repo%3AWordPress%2Fgutenberg%20%40wordpress%2Finteractivity&type=code) but its use is still very limited. +### Table of Contents +- [Quick Start Guide](#quick-start-guide) + - [1. Scaffold an interactive block](#1-scaffold-an-interactive-block) + - [2. Generate the build](#2-generate-the-build) + - [3. Use it in your WordPress installation ](#3-use-it-in-your-wordpress-installation) +- [Requirements of the Interactivity API](#requirements-of-the-interactivity-aPI) + - [A local WordPress installation](#a-local-wordpress-installation) + - [Latest vesion of Gutenberg](#latest-vesion-of-gutenberg) + - [Node.js](#nodejs) + - [Code requirements](#code-requirements) + - [Add `interactivity` support to `block.json`](#add-interactivity-support-to-blockjson) + - [Add `wp-interactive` directive to a DOM element](#add-wp-interactive-directive-to-a-dom-element) -## Frequently Asked Questions +#### 1. Scaffold an interactive block -At this point, some of the questions you have about the Interactivity API may be: +A WordPress plugin that registers an interactive block (using the Interactivity API) by using a [template](https://www.npmjs.com/package/@wordpress/create-block-interactive-template) can be scaffolded with the `@wordpress/create-block` command. -### What is this? +``` +npx @wordpress/create-block@latest my-first-interactive-block --template @wordpress/create-block-interactive-template +``` -This is the base of a new standard to create interactive blocks. Read [the proposal](https://make.wordpress.org/core/2023/03/30/proposal-the-interactivity-api-a-better-developer-experience-in-building-interactive-blocks/) to learn more about this. +#### 2. Generate the build -### Can I use it? +When the plugin folder is generated, the build process needs to be launched to get a working version of the interactive block that can be used in WordPress. -You can test it, but it's still very experimental. +``` +cd my-first-interactive-block && npm start +``` -### How do I get started? +#### 3. Use it in your WordPress installation -The best place to start with the Interactivity API is this [**Getting started guide**](https://github.com/WordPress/gutenberg/blob/trunk/packages/interactivity/docs/1-getting-started.md). There you'll will find a very quick start guide and the current requirements of the Interactivity API. +If you have a local WordPress installation already running, you can launch the commands above inside the `plugins` folder of that installation. If not, you can use [`wp-now`](https://github.com/WordPress/playground-tools/tree/trunk/packages/wp-now) to launch a WordPress site with the plugin installed by executing from the generated folder (and from a different terminal window or tab) the following command -### Where can I ask questions? +``` +npx @wp-now/wp-now start +``` -The [“Interactivity API” category](https://github.com/WordPress/gutenberg/discussions/categories/interactivity-api) in Gutenberg repo discussions is the best place to ask questions about the Interactivity API. +At this point you should be able to insert the "My First Interactive Block" block into any post, and see how it behaves in the frontend when published. -### Where can I share my feedback about the API? +### Requirements of the Interactivity API -The [“Interactivity API” category](https://github.com/WordPress/gutenberg/discussions/categories/interactivity-api) in Gutenberg repo discussions is also the best place to share your feedback about the Interactivity API. +To start working with the Interactivity API you'll need to have a [proper WordPress development environment for blocks](https://developer.wordpress.org/block-editor/getting-started/devenv/) and some specific code in your block, which should include: -## Installation +#### A local 6.5 WordPress installation -Install the module: +You can use [the tools to set your local WordPress environment](https://developer.wordpress.org/block-editor/getting-started/devenv/#wordpress-development-site) you feel more comfortable with. -```bash -npm install @wordpress/interactivity --save +To get quickly started, [`wp-now`](https://www.npmjs.com/package/@wp-now/wp-now) is the easiest way to get a WordPress site up and running locally. + +Interactivity API is included in Core in WordPress 6.5, for versions below, you'll need to have Gutenberg 17.5 or higher version installed and activated in your WordPress installation. + +#### Node.js + +Block development requires [Node](https://nodejs.org/en), so you'll need to have Node installed and running on your machine. Any version modern should work, but please check the minimum version requirements if you run into any issues with any of the Node.js tools used in WordPress development. + +#### Code requirements + +##### Add `interactivity` support to `block.json` + +To indicate that the block [supports](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/) the Interactivity API features, add `"interactivity": true` to the `supports` attribute of the block's `block.json` + +``` +"supports": { + "interactivity": true +}, ``` -_This package assumes that your code will run in an **ES2015+** environment. If you're using an environment that has limited or no support for such language features and APIs, you should include [the polyfill shipped in `@wordpress/babel-preset-default`](https://github.com/WordPress/gutenberg/tree/HEAD/packages/babel-preset-default#polyfill) in your code._ +##### Add `wp-interactive` directive to a DOM element + +To "activate" the Interactivity API in a DOM element (and its children), add the [`wp-interactive` directive](./docs/api-reference.md#wp-interactive) to it from `render.php` or `save.js` -## Docs & Examples -**[Interactivity API Documentation](https://github.com/WordPress/gutenberg/tree/trunk/packages/interactivity/docs)** is the best place to learn about this proposal. Although it's still in progress, some key pages are already available: +```html +
+ +
+``` -- **[Getting Started Guide](https://github.com/WordPress/gutenberg/blob/trunk/packages/interactivity/docs/1-getting-started.md)**: Follow this Getting Started guide to learn how to scaffold a new project and create your first interactive blocks. -- **[API Reference](https://github.com/WordPress/gutenberg/blob/trunk/packages/interactivity/docs/2-api-reference.md)**: Check this page for technical detailed explanations and examples of the directives and the store. +## API Reference + +To take a deep dive in how the API works internally, the list of Directives, and how Store works, click [here](https://developer.wordpress.org/block-editor/reference-guides/packages/packages-interactivity/packages-interactivity-api-reference/). + +## Docs & Examples Here you have some more resources to learn/read more about the Interactivity API: - **[Interactivity API Discussions](https://github.com/WordPress/gutenberg/discussions/52882)** +- [Merge announcement](https://make.wordpress.org/core/2024/02/19/merge-announcement-interactivity-api/) - [Proposal: The Interactivity API – A better developer experience in building interactive blocks](https://make.wordpress.org/core/2023/03/30/proposal-the-interactivity-api-a-better-developer-experience-in-building-interactive-blocks/) - Developer Hours sessions ([Americas](https://www.youtube.com/watch?v=RXNoyP2ZiS8&t=664s) & [APAC/EMEA](https://www.youtube.com/watch?v=6ghbrhyAcvA)) - [wpmovies.dev](http://wpmovies.dev/) demo and its [wp-movies-demo](https://github.com/WordPress/wp-movies-demo) repo -

Code is Poetry.

+There's a Tracking Issue opened to ease the coordination of the work related to the Interactivity API Docs: **[Documentation for the Interactivity API - Tracking Issue #53296](https://github.com/WordPress/gutenberg/issues/53296)** + + +## Get Involved + +As part of an [Open Source project](https://developer.wordpress.org/block-editor/getting-started/faq/#the-gutenberg-project) participation is encouraged in helping shape this API and its Docs. The [discussions](https://github.com/WordPress/gutenberg/discussions/categories/interactivity-api) and [issues](https://github.com/WordPress/gutenberg/labels/%5BFeature%5D%20Interactivity%20API) in GitHub are the best place to engage. + +If you are willing to help with the documentation, please add a comment to [#51928](https://github.com/WordPress/gutenberg/discussions/51928) to coordinate everyone's efforts. + + +## License + +Interactivity API proposal, as part of Gutenberg and the WordPress project is free software, and is released under the terms of the GNU General Public License version 2 or (at your option) any later version. See [LICENSE.md](https://github.com/WordPress/gutenberg/blob/trunk/LICENSE.md) for complete license. + +

Code is Poetry.

diff --git a/packages/interactivity/docs/1-getting-started.md b/packages/interactivity/docs/1-getting-started.md deleted file mode 100644 index 4e8c1086da695d..00000000000000 --- a/packages/interactivity/docs/1-getting-started.md +++ /dev/null @@ -1,87 +0,0 @@ -# Getting started with the Interactivity API - -To get started with the Interactivity API, you can follow this [**Quick Start Guide**](#quick-start-guide) by taking into account the [current requirements of the Interactivity API](#requirements-of-the-interactivity-api) (especially the need for Gutenberg 16.2 or later). - -## Table of Contents - -- [Quick Start Guide](#quick-start-guide) - - [1. Scaffold an interactive block](#1-scaffold-an-interactive-block) - - [2. Generate the build](#2-generate-the-build) - - [3. Use it in your WordPress installation ](#3-use-it-in-your-wordpress-installation) -- [Requirements of the Interactivity API](#requirements-of-the-interactivity-aPI) - - [A local WordPress installation](#a-local-wordpress-installation) - - [Latest vesion of Gutenberg](#latest-vesion-of-gutenberg) - - [Node.js](#nodejs) - - [Code requirements](#code-requirements) - - [Add `interactivity` support to `block.json`](#add-interactivity-support-to-blockjson) - - [Add `wp-interactive` directive to a DOM element](#add-wp-interactive-directive-to-a-dom-element) - -## Quick Start Guide - -#### 1. Scaffold an interactive block - -We can scaffold a WordPress plugin that registers an interactive block (using the Interactivity API) by using a [template](https://www.npmjs.com/package/@wordpress/create-block-interactive-template) with the `@wordpress/create-block` command. - -``` -npx @wordpress/create-block@latest my-first-interactive-block --template @wordpress/create-block-interactive-template -``` - -#### 2. Generate the build - -When the plugin folder is generated, we should launch the build process to get the final version of the interactive block that can be used from WordPress. - -``` -cd my-first-interactive-block && npm start -``` - -#### 3. Use it in your WordPress installation - -If you have a local WordPress installation already running, you can launch the commands above inside the `plugins` folder of that installation. If not, you can use [`wp-now`](https://github.com/WordPress/playground-tools/tree/trunk/packages/wp-now) to launch a WordPress site with the plugin installed by executing from the generated folder (and from a different terminal window or tab) the following command - -``` -npx @wp-now/wp-now start -``` - -At this point you should be able to insert the "My First Interactive Block" block into any post, and see how it behaves in the frontend when published. - -> **Note** -> We recommend you to also check the [API Reference](./2-api-reference.md) docs for your first exploration of the Interactivity API - -## Requirements of the Interactivity API - -To start working with the Interactivity API you'll need to have a [proper WordPress development environment for blocks](https://developer.wordpress.org/block-editor/getting-started/devenv/) and some specific code in your block, which should include: - -#### A local 6.5 WordPress installation - -You can use [the tools to set your local WordPress environment](https://developer.wordpress.org/block-editor/getting-started/devenv/#wordpress-development-site) you feel more comfortable with. - -To get quickly started, [`wp-now`](https://www.npmjs.com/package/@wp-now/wp-now) is the easiest way to get a WordPress site up and running locally. - -Interactivity API is included in Core in WordPress 6.5, for versions below, you'll need to have Gutenberg 17.5 or higher version installed and activated in your WordPress installation. - -#### Node.js - -Block development requires [Node](https://nodejs.org/en), so you'll need to have Node installed and running on your machine. Any version modern should work, but please check the minimum version requirements if you run into any issues with any of the Node.js tools used in WordPress development. - -#### Code requirements - -##### Add `interactivity` support to `block.json` - -To indicate that our block [supports](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/) the Interactivity API features, we do so by adding `"interactivity": true` to the `supports` attribute of our block's `block.json` - -``` -"supports": { - "interactivity": true -}, -``` - -##### Add `wp-interactive` directive to a DOM element - -To "activate" the Interactivity API in a DOM element (and its children) we add the [`wp-interactive` directive](./2-api-reference.md#wp-interactive) to it from our `render.php` or `save.js` - - -```html -
- -
-``` diff --git a/packages/interactivity/docs/README.md b/packages/interactivity/docs/README.md deleted file mode 100644 index e63ed6b82e4201..00000000000000 --- a/packages/interactivity/docs/README.md +++ /dev/null @@ -1,33 +0,0 @@ -# Interactivity API Docs - -👋 Hi! Welcome to the Interactivity API documentation. - - -> Interactivity API is a current [proposal](https://make.wordpress.org/core/2023/03/30/proposal-the-interactivity-api-a-better-developer-experience-in-building-interactive-blocks/) that **is only available in Gutenberg** at the moment and not in WordPress Core as it is still very experimental, and very likely to change. - -> As part of an [Open Source project](https://developer.wordpress.org/block-editor/getting-started/faq/#the-gutenberg-project) we encourage participation in helping shape this API and its Docs. The [discussions](https://github.com/WordPress/gutenberg/discussions/categories/interactivity-api) and [issues](https://github.com/WordPress/gutenberg/labels/%5BFeature%5D%20Interactivity%20API) in GitHub are the best place to engage. - - -## Quick start - -The best place to start with the Interactivity API is this [**Getting started guide**](1-getting-started.md). There you'll will find a very quick start guide and the current requirements of the Interactivity API. - -## Take a deep dive - -At the [**API Reference**](2-api-reference.md) page you'll find detailed technical descriptions for the *Directives* and *Store* which are the main elements of the Interactivity API. - -You can also check [Getting Started - and other learning resources](https://github.com/WordPress/gutenberg/discussions/52894) among other [discussions in GitHub](https://github.com/WordPress/gutenberg/discussions/categories/interactivity-api) to learn more on this proposal. - -## Get Involved - -Feel free to open pull requests to improve any part of these docs, or to add other sections or files to the docs. - -If you are willing to help with the documentation, please add a comment to [#51928](https://github.com/WordPress/gutenberg/discussions/51928), and we'll coordinate everyone's efforts. - -There's a Tracking Issue opened to ease the coordination of the work related to the Interactivity API Docs: **[Documentation for the Interactivity API - Tracking Issue #53296](https://github.com/WordPress/gutenberg/issues/53296)** - -## License - -Interactivity API proposal, as part of Gutenberg and the WordPress project is free software, and is released under the terms of the GNU General Public License version 2 or (at your option) any later version. See [LICENSE.md](https://github.com/WordPress/gutenberg/blob/trunk/LICENSE.md) for complete license. - -

Code is Poetry.

diff --git a/packages/interactivity/docs/2-api-reference.md b/packages/interactivity/docs/api-reference.md similarity index 97% rename from packages/interactivity/docs/2-api-reference.md rename to packages/interactivity/docs/api-reference.md index fa06bae4fedf88..7ca73c03fe2349 100644 --- a/packages/interactivity/docs/2-api-reference.md +++ b/packages/interactivity/docs/api-reference.md @@ -7,7 +7,7 @@ To add interactivity to blocks using the Interactivity API, developers can use: DOM elements are connected to data stored in the state and context through directives. If data in the state or context change directives will react to those changes, updating the DOM accordingly (see [diagram](https://excalidraw.com/#json=T4meh6lltJh6TCX51NTIu,DmIhxYSGFTL_ywZFbsmuSw)). -![State & Directives](assets/state-directives.png) +![State & Directives](./assets/interactivity-state-directives.png) ## Table of Contents @@ -69,7 +69,7 @@ Directives can also be injected dynamically using the [HTML Tag Processor](https ### List of Directives -With directives, we can directly manage interactions related to things such as side effects, state, event handlers, attributes or content. +With directives, you can directly manage interactions related to things such as side effects, state, event handlers, attributes or content. #### `wp-interactive` @@ -659,7 +659,7 @@ It would generate the following output: ``` -The prop that holds the item in the context can be changed by passing a suffix to the directive name. In the following example, we change the default prop `item` to `greeting`. +The prop that holds the item in the context can be changed by passing a suffix to the directive name. In the following example, the default prop changes from `item` to `greeting`. ```html