From 45d5eaa98b380fcc8f2eab71d82fdee15b1beb68 Mon Sep 17 00:00:00 2001 From: Thomas Roberts Date: Wed, 27 Oct 2021 14:07:57 +0100 Subject: [PATCH 1/6] Deprecate __experimental_woocommerce_blocks_checkout_order_processed --- src/StoreApi/Routes/Checkout.php | 28 +++++++++++++++++++++++++++- 1 file changed, 27 insertions(+), 1 deletion(-) diff --git a/src/StoreApi/Routes/Checkout.php b/src/StoreApi/Routes/Checkout.php index 6c8603f79c1..32a8302d42c 100644 --- a/src/StoreApi/Routes/Checkout.php +++ b/src/StoreApi/Routes/Checkout.php @@ -246,8 +246,34 @@ protected function get_route_post_response( \WP_REST_Request $request ) { * @internal This Hook is experimental and may change or be removed. * @param \WC_Order $order Order object. + * @depreacted x.x.x */ - do_action( '__experimental_woocommerce_blocks_checkout_order_processed', $this->order ); + do_action_deprecated( + '__experimental_woocommerce_blocks_checkout_order_processed', + $this->order, + 'x.x.x', + 'woocommerce_blocks_checkout_order_processed', + sprintf( + 'This action was deprecated in WooCommerce Blocks version %s. Please use woocommerce_blocks_checkout_order_processed instead.', + 'x.x.x' + ) + ); + + /** + * Fires before an order is processed by the Checkout Block/Store API. + * + * This hook informs extensions that $order has completed processing and is ready for payment. + * + * This is similar to existing core hook woocommerce_checkout_order_processed. We're using a new action: + * - To keep the interface focused (only pass $order, not passing request data). + * - This also explicitly indicates these orders are from checkout block/StoreAPI. + * + * @see https://github.com/woocommerce/woocommerce-gutenberg-products-block/pull/3238 + * @example See docs/examples/checkout-order-processed.md + + * @param \WC_Order $order Order object. + */ + do_action( 'woocommerce_blocks_checkout_order_processed', $this->order ); /** * Process the payment and return the results. From 138c5ff779b5ea0df85254bf285d2bfc4ec92d4d Mon Sep 17 00:00:00 2001 From: Thomas Roberts Date: Wed, 27 Oct 2021 14:59:35 +0100 Subject: [PATCH 2/6] Update docs to reflect new hook name I also mentioned this hook is deprecated in the experimental interfaces doc. --- bin/hook-docs/data/actions.json | 62 ++++++------- ...ature-flags-and-experimental-interfaces.md | 2 +- docs/examples/checkout-order-processed.md | 2 +- docs/extensibility/actions.md | 93 +++++++++---------- 4 files changed, 76 insertions(+), 83 deletions(-) diff --git a/bin/hook-docs/data/actions.json b/bin/hook-docs/data/actions.json index e2c756c207a..dd2ec957bc0 100644 --- a/bin/hook-docs/data/actions.json +++ b/bin/hook-docs/data/actions.json @@ -1,39 +1,6 @@ { "$schema": "https://raw.githubusercontent.com/johnbillion/wp-hooks-generator/0.6.1/schema.json", "hooks": [ - { - "name": "__experimental_woocommerce_blocks_checkout_order_processed", - "file": "StoreApi/Routes/Checkout.php", - "type": "action", - "doc": { - "description": "Fires before an order is processed by the Checkout Block/Store API.", - "long_description": "This hook informs extensions that $order has completed processing and is ready for payment.\n This is similar to existing core hook woocommerce_checkout_order_processed. We're using a new action: - To keep the interface focused (only pass $order, not passing request data). - This also explicitly indicates these orders are from checkout block/StoreAPI.", - "tags": [ - { - "name": "see", - "content": "", - "refers": "https://github.com/woocommerce/woocommerce-gutenberg-products-block/pull/3238" - }, - { - "name": "example", - "content": "docs/examples/checkout-order-processed.md" - }, - { - "name": "internal", - "content": "This Hook is experimental and may change or be removed." - }, - { - "name": "param", - "content": "Order object.", - "types": [ - "\\WC_Order" - ], - "variable": "$order" - } - ], - "long_description_html": "

This hook informs extensions that $order has completed processing and is ready for payment.

This is similar to existing core hook woocommerce_checkout_order_processed. We're using a new action:

" - } - }, { "name": "__experimental_woocommerce_blocks_checkout_update_order_from_request", "file": "StoreApi/Routes/Checkout.php", @@ -208,6 +175,35 @@ "long_description_html": "" } }, + { + "name": "woocommerce_blocks_checkout_order_processed", + "file": "StoreApi/Routes/Checkout.php", + "type": "action", + "doc": { + "description": "Fires before an order is processed by the Checkout Block/Store API.", + "long_description": "This hook informs extensions that $order has completed processing and is ready for payment.\n This is similar to existing core hook woocommerce_checkout_order_processed. We're using a new action: - To keep the interface focused (only pass $order, not passing request data). - This also explicitly indicates these orders are from checkout block/StoreAPI.", + "tags": [ + { + "name": "see", + "content": "", + "refers": "https://github.com/woocommerce/woocommerce-gutenberg-products-block/pull/3238" + }, + { + "name": "example", + "content": "docs/examples/checkout-order-processed.md" + }, + { + "name": "param", + "content": "Order object.", + "types": [ + "\\WC_Order" + ], + "variable": "$order" + } + ], + "long_description_html": "

This hook informs extensions that $order has completed processing and is ready for payment.

This is similar to existing core hook woocommerce_checkout_order_processed. We're using a new action:

" + } + }, { "name": "woocommerce_blocks_enqueue_cart_block_scripts_after", "file": "BlockTypes/Cart.php", diff --git a/docs/blocks/feature-flags-and-experimental-interfaces.md b/docs/blocks/feature-flags-and-experimental-interfaces.md index 784a78bf356..598fd458d51 100644 --- a/docs/blocks/feature-flags-and-experimental-interfaces.md +++ b/docs/blocks/feature-flags-and-experimental-interfaces.md @@ -86,7 +86,7 @@ We also have individual features or code blocks behind a feature flag, this is a - `__experimental_woocommerce_blocks_payment_gateway_features_list` hook that allows modification of the features supported by PayPal Standard. ([experimental hook](https://github.com/woocommerce/woocommerce-gutenberg-products-block/blob/4cedb65367be0d1c4c1f9dd9c016e3b1325cf92e/src/Payments/Integrations/PayPal.php#L86)). - `__experimental_woocommerce_blocks_checkout_update_order_meta` hook when the draft order has been created or updated from the cart and is now ready for extensions to modify the metadata ([experimental hook](https://github.com/woocommerce/woocommerce-gutenberg-products-block/pull/3686/files#diff-af2c90fa556cc086b780c8fad99b68373d87fd6007e6e2ff1b4c68ebe9ccb551R377-R393)). - `__experimental_woocommerce_blocks_checkout_update_order_from_request` hook gives extensions the chance to update orders based on the data in the request ([experimental hook](https://github.com/woocommerce/woocommerce-gutenberg-products-block/blob/d469a45d572f2c52d7917707c492dfb905ddfac0/src/StoreApi/Routes/Checkout.php#L466-L477)). -- `__experimental_woocommerce_blocks_checkout_order_processed` hook when order has completed processing and is ready for payment ([experimental hook](https://github.com/woocommerce/woocommerce-gutenberg-products-block/blob/accd1bbf402e043b9fc322f118ab614ba7437c92/src/StoreApi/Routes/Checkout.php#L237)). +- **Deprecated** - `__experimental_woocommerce_blocks_checkout_order_processed` hook when order has completed processing and is ready for payment ([deprecated experimental hook](https://github.com/woocommerce/woocommerce-gutenberg-products-block/blob/accd1bbf402e043b9fc322f118ab614ba7437c92/src/StoreApi/Routes/Checkout.php#L237)). [Deprecated in PR 5014](https://github.com/woocommerce/woocommerce-gutenberg-products-block/pull/5014). - `__experimental_woocommerce_blocks_add_data_attributes_to_namespace` hook that allows 3PD to add a namespace of blocks to receive block attributes as `data-` attributes ([experimental property](https://github.com/woocommerce/woocommerce-gutenberg-products-block/blob/4a1ee97eb97011458174e93e44a9b7ad2f10ca36/src/BlockTypesController.php#L88)). - `__experimental_woocommerce_blocks_add_data_attributes_to_block` hook that allows 3PD to add a block to recieve block attributes as `data-` attributes ([experimental property](https://github.com/woocommerce/woocommerce-gutenberg-products-block/blob/4a1ee97eb97011458174e93e44a9b7ad2f10ca36/src/BlockTypesController.php#L97)). diff --git a/docs/examples/checkout-order-processed.md b/docs/examples/checkout-order-processed.md index fd2bbdfdc74..b3260a288b2 100644 --- a/docs/examples/checkout-order-processed.md +++ b/docs/examples/checkout-order-processed.md @@ -5,5 +5,5 @@ function my_function_callback( $order ) { $order->save(); } -add_action( '__experimental_woocommerce_blocks_checkout_order_processed', 'my_function_callback', 10 ); +add_action( 'woocommerce_blocks_checkout_order_processed', 'my_function_callback', 10 ); ``` diff --git a/docs/extensibility/actions.md b/docs/extensibility/actions.md index b72f14fc525..60d706e0659 100644 --- a/docs/extensibility/actions.md +++ b/docs/extensibility/actions.md @@ -7,7 +7,6 @@ ## Table of Contents - - [__experimental_woocommerce_blocks_checkout_order_processed](#__experimental_woocommerce_blocks_checkout_order_processed) - [__experimental_woocommerce_blocks_checkout_update_order_from_request](#__experimental_woocommerce_blocks_checkout_update_order_from_request) - [__experimental_woocommerce_blocks_checkout_update_order_meta](#__experimental_woocommerce_blocks_checkout_update_order_meta) - [woocommerce_add_to_cart](#woocommerce_add_to_cart) @@ -15,6 +14,7 @@ - [woocommerce_blocks_cart_enqueue_data](#woocommerce_blocks_cart_enqueue_data) - [woocommerce_blocks_cart_enqueue_data](#woocommerce_blocks_cart_enqueue_data-1) - [woocommerce_blocks_checkout_enqueue_data](#woocommerce_blocks_checkout_enqueue_data) + - [woocommerce_blocks_checkout_order_processed](#woocommerce_blocks_checkout_order_processed) - [woocommerce_blocks_enqueue_cart_block_scripts_after](#woocommerce_blocks_enqueue_cart_block_scripts_after) - [woocommerce_blocks_enqueue_cart_block_scripts_before](#woocommerce_blocks_enqueue_cart_block_scripts_before) - [woocommerce_blocks_enqueue_checkout_block_scripts_after](#woocommerce_blocks_enqueue_checkout_block_scripts_after) @@ -30,53 +30,6 @@ --- -## __experimental_woocommerce_blocks_checkout_order_processed - - -Fires before an order is processed by the Checkout Block/Store API. - -```php -do_action( '__experimental_woocommerce_blocks_checkout_order_processed', \WC_Order $order ) -``` - - -**Note: This Hook is experimental and may change or be removed.** - -### Description - -

This hook informs extensions that $order has completed processing and is ready for payment.

This is similar to existing core hook woocommerce_checkout_order_processed. We're using a new action:

- -### Parameters - -| Argument | Type | Description | -| -------- | ---- | ----------- | -| $order | \WC_Order | Order object. | - -### Example - -```php -// The action callback function. -function my_function_callback( $order ) { - // Do something with the $order object. - $order->save(); -} - -add_action( '__experimental_woocommerce_blocks_checkout_order_processed', 'my_function_callback', 10 ); -``` - - -### Related - - - - https://github.com/woocommerce/woocommerce-gutenberg-products-block/pull/3238 - -### Source - - -File: [StoreApi/Routes/Checkout.php](../src/StoreApi/Routes/Checkout.php) - ---- - ## __experimental_woocommerce_blocks_checkout_update_order_from_request @@ -242,6 +195,50 @@ File: [BlockTypes/Checkout.php](../src/BlockTypes/Checkout.php) --- +## woocommerce_blocks_checkout_order_processed + + +Fires before an order is processed by the Checkout Block/Store API. + +```php +do_action( 'woocommerce_blocks_checkout_order_processed', \WC_Order $order ) +``` + +### Description + +

This hook informs extensions that $order has completed processing and is ready for payment.

This is similar to existing core hook woocommerce_checkout_order_processed. We're using a new action:

+ +### Parameters + +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $order | \WC_Order | Order object. | + +### Example + +```php +// The action callback function. +function my_function_callback( $order ) { + // Do something with the $order object. + $order->save(); +} + +add_action( 'woocommerce_blocks_checkout_order_processed', 'my_function_callback', 10 ); +``` + + +### Related + + + - https://github.com/woocommerce/woocommerce-gutenberg-products-block/pull/3238 + +### Source + + +File: [StoreApi/Routes/Checkout.php](../src/StoreApi/Routes/Checkout.php) + +--- + ## woocommerce_blocks_enqueue_cart_block_scripts_after From c020c0dc74b1d0d7984599b7b2ba9b27e10b7b60 Mon Sep 17 00:00:00 2001 From: Thomas Roberts Date: Wed, 27 Oct 2021 15:20:35 +0100 Subject: [PATCH 3/6] Update deprecated tag in docblock --- src/StoreApi/Routes/Checkout.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/StoreApi/Routes/Checkout.php b/src/StoreApi/Routes/Checkout.php index 32a8302d42c..ea94a3bb07f 100644 --- a/src/StoreApi/Routes/Checkout.php +++ b/src/StoreApi/Routes/Checkout.php @@ -246,7 +246,7 @@ protected function get_route_post_response( \WP_REST_Request $request ) { * @internal This Hook is experimental and may change or be removed. * @param \WC_Order $order Order object. - * @depreacted x.x.x + * @depreacted Deprecated since version x.x.x, use woocommerce_blocks_checkout_order_processed instead. */ do_action_deprecated( '__experimental_woocommerce_blocks_checkout_order_processed', From 5ec6845cb9f2f659917c6f70c16f35685c09ac2f Mon Sep 17 00:00:00 2001 From: Thomas Roberts Date: Wed, 27 Oct 2021 15:34:32 +0100 Subject: [PATCH 4/6] Fix typo in deprecated docblock --- src/StoreApi/Routes/Checkout.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/StoreApi/Routes/Checkout.php b/src/StoreApi/Routes/Checkout.php index ea94a3bb07f..857d930e06e 100644 --- a/src/StoreApi/Routes/Checkout.php +++ b/src/StoreApi/Routes/Checkout.php @@ -246,7 +246,7 @@ protected function get_route_post_response( \WP_REST_Request $request ) { * @internal This Hook is experimental and may change or be removed. * @param \WC_Order $order Order object. - * @depreacted Deprecated since version x.x.x, use woocommerce_blocks_checkout_order_processed instead. + * @deprecated Deprecated since version x.x.x, use woocommerce_blocks_checkout_order_processed instead. */ do_action_deprecated( '__experimental_woocommerce_blocks_checkout_order_processed', From 43c6473b2e7e408911cc7702cab5e7629edb97a5 Mon Sep 17 00:00:00 2001 From: Thomas Roberts Date: Wed, 27 Oct 2021 16:39:55 +0100 Subject: [PATCH 5/6] Send args to do_action_deprecated in an array --- src/StoreApi/Routes/Checkout.php | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/StoreApi/Routes/Checkout.php b/src/StoreApi/Routes/Checkout.php index 857d930e06e..6994ed345ba 100644 --- a/src/StoreApi/Routes/Checkout.php +++ b/src/StoreApi/Routes/Checkout.php @@ -250,7 +250,9 @@ protected function get_route_post_response( \WP_REST_Request $request ) { */ do_action_deprecated( '__experimental_woocommerce_blocks_checkout_order_processed', - $this->order, + array( + $this->order, + ), 'x.x.x', 'woocommerce_blocks_checkout_order_processed', sprintf( From f4d45197597c24adae8577595168c1f4811ca116 Mon Sep 17 00:00:00 2001 From: Thomas Roberts Date: Thu, 28 Oct 2021 14:56:16 +0100 Subject: [PATCH 6/6] Amend deprecated tag and add version numbers --- src/StoreApi/Routes/Checkout.php | 9 +++------ 1 file changed, 3 insertions(+), 6 deletions(-) diff --git a/src/StoreApi/Routes/Checkout.php b/src/StoreApi/Routes/Checkout.php index 6994ed345ba..eb214a93f07 100644 --- a/src/StoreApi/Routes/Checkout.php +++ b/src/StoreApi/Routes/Checkout.php @@ -246,19 +246,16 @@ protected function get_route_post_response( \WP_REST_Request $request ) { * @internal This Hook is experimental and may change or be removed. * @param \WC_Order $order Order object. - * @deprecated Deprecated since version x.x.x, use woocommerce_blocks_checkout_order_processed instead. + * @deprecated 6.3.0 Use woocommerce_blocks_checkout_order_processed instead. */ do_action_deprecated( '__experimental_woocommerce_blocks_checkout_order_processed', array( $this->order, ), - 'x.x.x', + '6.3.0', 'woocommerce_blocks_checkout_order_processed', - sprintf( - 'This action was deprecated in WooCommerce Blocks version %s. Please use woocommerce_blocks_checkout_order_processed instead.', - 'x.x.x' - ) + 'This action was deprecated in WooCommerce Blocks version 6.3.0. Please use woocommerce_blocks_checkout_order_processed instead.' ); /**