The documentation for WooCommerce Blocks has moved to the WooCommerce monorepo.
Please refer to the documentation in the new location as the files in this repository will no longer be updated and the repository will be archived.
Zip file for testing: woocommerce-gutenberg-products-block.zip
Related Products: hide the block outside of Single Product Template and Single Product block #10978
- Go to Single Product template
- Try to add "Related Products" and "Product Reviews" blocks
- Expected: they should be available in the inserter and should be added normally
- Save and go to frontend
- Verify there's no fatal error
- Go to Product Catalog template
- Try to add "Related Products" and "Product Reviews" blocks
- Expected: they should NOT be available in inserter
- Add Single Product block
- Try to add "Related Products" and "Product Reviews" in scope of Single Product block
- Expected: they should be available in the inserter and should be added normally
- Save and go to frontend
- Verify there's no fatal error
- Create new post
- Try to add "Related Products" and "Product Reviews" blocks
- Expected: they should NOT be available in inserter
- Add Single Product block
- Try to add "Related Products" and "Product Reviews" in scope of Single Product block
- Expected: they should NOT be available in inserter
Blockified Order Confirmation #10056
- Go to Appearance > Editor > Templates > Order Confirmation
- Convert the legacy order confirmation block to individual blocks using the "transform into blocks" button. Confirm the new blocks appear.
- Focus on each new block and confirm there is an appropriate icon, title, description, and style controls for each. Play around with text colours, background colours, and any other options available to ensure changes apply in the editor.
- Save changes.
- Go to the store frontend, add some items to the cart, and place an order.
- Confirm the confirmation page matches the styling you applied and all blocks are present. You can leave this tab open for testing.
- Edit the order confirmation page again. Remove some blocks, for example headings.
- Save changes, then refresh the confirmation page on the frontend. Confirm changes have applied.
- Add a downloadable product to your cart and complete checkout.
- The order confirmation page will be shown—no downloads will be visible. Leave this tab open.
- In a new tab, go to store admin and edit the order you just placed. Change its status to "processing". This will grant access to downloads.
- Go back to the confirmation page and refresh.
- Confirm the download section is now visible.
- Place an order as a logged in admin user. Leave the confirmation page open.
- Copy the page address.
- Open up a new incognito browser window, or better yet, using a different browser. Paste the URL from earlier.
- Confirm no order details are visible—you should only see some text and a login link as follows:
- Close all tabs and log out from your store.
- Place a new order as a guest. Confirm the order confirmation page shows some order details, but hides email address, payment method, and the full billing/shipping address. This is the limited view that guests can see.
- Leave the confirmation page open. Copy the page address.
- Open up a new incognito browser window, or better yet, using a different browser. Paste the URL from earlier.
- You should still see details if within 10 minutes of placing the order.
- Wait 10 minutes then refresh the page.
- Confirm you see a message asking you to either login or fill out the form to see order details as follows:
- Enter the incorrect email. See a notice rejecting the request "We were unable to verify the email address you provided. Please try again.".
- Enter the correct email. See limited order details.
- Edit the URL of the page to remove the order key. For example,
checkout/order-received/1772/?key=wc_order_GAE4XxQ4k7E77
would becomecheckout/order-received/1772
- You should no longer be able to provide your email and see order details. The key is required. You will see a generic message only.
Refactor Cart and Checkout Page Templates #10773
Before testing, take note of the frontend appearance of the cart/checkout pages.
- Using a non-block based theme such as Storefront, ensure your existing cart/checkout is unchanged as a result of testing.
- Use a block based theme such as Twenty Twenty Three
- Go to Appearance > Editor > Templates, navigate to both
Page: Cart
andPage: Checkout
. For both, click the three dots in the inspector and "revert customisations". This will remove any existing template customisations or past migration. - Visit the cart/checkout pages on the frontend and ensure the page contents matches the actual cart/checkout page content.
- Edit the contents of the checkout page, not the template, either from Admin > Pages or Admin > Appearance > Editor > Pages. After saving, confirm the changes are shown on the frontend.
- Go to Appearance > Editor > Templates and edit the Page: Checkout template. Edit something in the template. Save and confirm the frontend shows your change. When adding content to the template, make sure you're not within Group > Checkout Page, as this will save to the page not the template. Insert something after or outside of that group.
- Go to Appearance > Editor > Templates and edit the Page: Checkout template. Click the three dots in the side bar and "revert customisations". Ensure the frontend shows the same default template again without your changes.
- Switch to a block based theme with a custom cart/checkout template. For example FotaWP
- After activating the theme, view the checkout page. You should see a custom checkout template (this is from the theme).
- Switch back to Twenty Twenty Three—the previous template will be restored.
- Delete your main cart and checkout pages
- Go to WooCommerce > Status > Tools > and use the tool to recreate the default woocommerce pages
- Now if you go to the newly recreated Cart/Checkout pages you'll see a placeholder block which when focussed/clicked will look something like this (copy may differ):
- Ensure you see a shortcode cart/checkout on the frontend still.
- Go to Appearance > Editor > Templates and then Page: Cart and Page: Checkout. Both should show the placeholder.
- Go to Appearance > Editor > Pages and then the cart/checkout pages. Both should show the placeholder.
- Edit the page again. Click the classic shortcode placeholder then click the 'convert to blocks' button. Save and view the frontend. You should now see checkout blocks instead of the page content.
- Likewise, viewing the Templates + Pages in site editor should show the blocks.
- Go to WooCommerce > Settings > Advanced and ensure you see classic dropdowns for Cart and Checkout page selector. Compare this with a non blocks theme installation and ensure there are no differences.
- Edit Cart and Checkout pages, and changes the titles. Go back to the selectors and ensure it is reflected there.
- Edit Cart and Checkout pages permalinks. Ensure Cart and Checkout work on the selected URLs.
- Got to Appearance > Editor > Templates > Manage all templates
- Ensure that customizations are deleted for Cart and Checkout templates (if not click the 3 dots next to the template and delete them)
- Open the templates for each, then edit content with the page placeholder block. Save.
- Exit the site editor and open Cart and Checkout pages for each. Ensure you see the changes added in the site editor.
- Verify the changes are reflected on the Cart and Checkout by performing a test order.
- Create a fresh instance of JN with previous version of Woocommerce blocks and save some customisations to your cart/checkout page tenplates.
- Install and activate the zip file for this release.
- You should now see only one "Page: Checkout" template, and it should contain the customisations you previously made to checkout.
Fix: Password Protection not respected on single product template #10999
- Ensure you are using the Blockified Single Product Template.
- Create a product with password protection.
- Visit the Product.
- Ensure that the password form is added and the other blocks related to the Single Product Template are not visible.
Checkout Block: Prevent changes in the selected shipping method when new rates are added or removed #10457
- Enable local pickup.
- Go to the Checkout block page, and add an address for which you don't have a shipping zone defined without changing the selected shipping method.
- Confirm local pickup is selected as a shipping method for the address, and shipping is not available for the given address.
- In another tab, open shipping zones and add a new rate to your current zone.
- Refresh checkout.
- Confirm local pickup is selected as a shipping method for the address, and shipping is also available for the given address.
Product Collection: Transfer layout options from Toolbar to Inspector controls #10922
- Create a new post.
- Add the product collection block.
- Verify: In the sidebar settings, the options for layout should be visible with 'Grid' being the default selection. Refer to this screenshot for guidance:
- Verify: The products in the editor should be displayed in a grid view by default. Publish the post and ascertain that the grid view is maintained on the frontend.
- Change the layout setting to 'Stack'. Ensure that in the editor, products now appear in a single column. Save or update the post and check the frontend to confirm the single column display is applied there as well.
- Create a new post and add the product collection block.
- Open the sidebar settings and note the absence of a 'RESET' option in the layout menu, indicated in the screenshot:
- Change the layout from 'Grid' to 'Stack'. Open the settings menu again to find the 'RESET' button now visible, as shown here:
- Verify that clicking the 'RESET' button changes the layout back to 'Grid'. Similarly, clicking the 'Reset all' button should revert the layout to 'Grid'.
Single Product: Fix the Align setting #10977
Product Hero
pattern to a new page.- Change the
Align
to full. - Make sure the change is reflected on the front end.
Update postcode-validator
to 3.8.15 to validate "new" Taiwanese postcodes #10924
- Add an item to your cart.
- Go to the Checkout block.
- Enter your address and choose Taiwan as the country. Enter a postcode with 5 digits. (
12345
) verify there is no validation error. - Enter a postcode with 6 digits (
123456
), verify there is no validation error. - Check out successfully using a Taiwanese postcode.
Hide unexpected bullet point in Product Collection on Storefront #10945
- Use Storefront theme
- Create new post
- Add Product Collection block
- Make sure there are no bullet points before the products
- Publish the post and go to frontend
- Make sure there are no bullet points before the products
Before | After |
---|---|
Add custom regex for validating Nicaraguan postal codes #10928
- Add the Cart block to a test page.
- Enable the
Shipping calculator
in the Shipping inner block. - Add the Checkout block to another test page.
- Add a test product to the cart via the frontend.
- Navigate to the test page with the Cart block and click
Change address
in the Shipping section. - Select
Nicaragua
as the country and enter a 5-digit postal code (e.g.,13024
). - See that that validation passes.
- Navigate to the test page with the Checkout block.
- Repeat steps 6-7.
- Change the postal code to
01234
, and see that the validation fails. - Change the postal code to anything other than 5 digits, and see that the validation also fails.
Add pattern chooser in Product Collection #10876
- Go to Editor
- Add Product Collection blocks with different configiurations, e.g.
- one that inherits query from template
- one that has "On Sale" filter enabled with limited number of products per page
- one that shows handpicked products
- Focus on first Product Collection block you added and click "Choose pattern"
- Expected: Modal with 4 patterns is displayed
- Click some pattern
- Expected: Layout of Product Collection has changed reflecting what you chose, but the query settings are preserved (e.g. enabled inherit query from template or "On Sale" filter)
- Repeat for other Product Collection blocks.
patterns-demo.mov
BlockTemplatesController: Check that $attributes['theme'] value isset before operating on it #10879
- Load WooCommerce template parts in the Site Editor and check they are all there and load as expected.
- Customize the template parts (e.g. Checkout Header) and check this is reflect on the frontend.
- Clear the customizations, revisit the frontend and check they are expected.
Remove order and checkout order endpoints experimental flag #11022
- Test the Add an endpoint for getting pay for order orders and checkout order endpoints.
WooExpress: Fix Checkout and Cart Blocks Editor Crash #11024
You'll need a WooExpress site. You can create one for free from here.
To upload Woo Blocks ZIP file, you can either upgrade your WooExpress site or use the CLI.
- Go to
Appearance -> Editor -> Templates -> Checkout
(or Cart) - Clear customizations of the Checkout (or Cart) template if necessary and reload the page
- Click on
Edit
to access the template editor
- Within the Checkout (or Cart) template editor, open the
List View
and try to delete theGift Card Form
or theGift Card Totals
Blocks. UntickPrevent removal
under theUnlock
option:
- Ensure the
Gift Card Form
(orGift Card Totals
) Block isn't deleted (It's actually being reinserted each time we click onDelete)
)
- Try to delete the Checkout (or Cart) Block
- Ensure the Checkout (or Cart) Block is successfully deleted
Store Customization > Schedule an action to update the patterns content whenever the business description is changed #10956
- Install and activate the
woo-ai
plugin (it is available within the WooCommerce monorepo, under the plugins directory). - From your dashboard, head over to WooCommerce > Settings > Advanced > Features
- Fill out a description for your business and save
- Now head over to Tools > Scheduled Actions
- Search for the woocommerce_update_patterns_content hook
- Make sure the action was successfully scheduled:
- If the status is still Pending when you check, click on Run and ensure it is successfully executed. If the status is already Complete, no action is required as the process already finished successfully.
- Check your error log and make sure you don't see any PHP errors.
Store Customization > Create a new endpoint within Store API for updating patterns with AI-generated content #10881
-
Create a new JN install with both Jetpack and Woocommerce installed and activated.
-
In your wp-admin, you should see the following section for Jetpack:
- Click on "Set up Jetpack" and make sure the connection is successful:
- Using Postman or any other equivalent app, make a POST request to the following endpoint:
wp-json/wc/store/patterns
(e.g.https://outside-dwelling.jurassic.ninja/wp-json/wc/store/patterns
). Since you are not authenticated, you should get the following error:
- Now, we need to make sure the request works for admin users: you can do so by adding your credentials via Postman directly or, alternatively:
- From your admin screen, click on Tools > Plugin editor:
- Select the WooCommerce Blocks plugin and add the following within your woocommerce-blocks/woocommerce-gutenberg-products-block.php file:
function connect_to_endpoint() {
update_option( 'woocommerce_blocks_allow_ai_connection', true );
$request = new WP_REST_Request( 'POST', '/wc/store/patterns' );
$request->set_param( 'business_description', 'selling art' );
$response = rest_do_request( $request )->get_data();
error_log( print_r( $response, true ) );
}
add_action( 'admin_init', 'connect_to_endpoint' );
- Now access your JN install via SSH (you can copy the command for access over here:)
- Head over to your wp-content directory and tail the debug.log file. Example:
cd /srv/users/user964902c9/apps/{insert-your-jurassic-ninja-username-here}/public/wp-content
tail -f debug.log
-
Now go back to your browser and refresh the page in the main admin page e.g.
https://your-site.jurassic.ninja/wp-admin
-
Go back to your terminal and confirm that you can see the following response: