From 8467d255a26b61cbd326fca6e8127d498280d412 Mon Sep 17 00:00:00 2001 From: Carlos Bravo <37012961+c4rl0sbr4v0@users.noreply.github.com> Date: Thu, 11 Aug 2022 12:57:43 +0200 Subject: [PATCH] Update the repo with the last changes done in WooCommerce Blocks plugin (#69) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * Use the archive-product template to render product attributes pages (#6776) * Bump mockery/mockery from 1.4.4 to 1.5.0 (#6703) Bumps [mockery/mockery](https://github.com/mockery/mockery) from 1.4.4 to 1.5.0. - [Release notes](https://github.com/mockery/mockery/releases) - [Changelog](https://github.com/mockery/mockery/blob/master/CHANGELOG.md) - [Commits](https://github.com/mockery/mockery/compare/1.4.4...1.5.0) --- updated-dependencies: - dependency-name: mockery/mockery dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Alba Rincón * Update dependency @types/jest to v27.5.2 (#6759) Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> * Ensure addresses sync when loading the checkout shipping address block (#6773) * Update pull_request_template.md * Add comment to prevent linting error on commented out code (#6789) * Update pull_request_template.md * Update dependency @types/wordpress__blocks to v11.0.5 (#6758) Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> * Update babel monorepo to v7.18.9 (#6719) Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> * Refactor external dispatch actions from being called inside useSelect (#6718) * refactor coupon functions outside of useSelect * fix test * Add new icon for mini cart block (#6784) * Add new icon for mini cart block (inserter). See https://github.com/woocommerce/woocommerce-blocks/issues/6617. * Adjust size of SVG The new SVG was rendering a little bit smaller than the original icon. Potentially because of the mask and the artboard size. This commit adjusts the size to render at the same size as the original version of the icon in the inserter. * add new action for customer updates (#6792) * Fix: Replace DropdownSelector with FormTokenField from Gutenberg (#6647) * Fix missing translations in inspector (#6737) * Try registering the "cart taxes" inner block Registering server side. This example isn't working, but I'm pushing to share it and see what's wrong with this implementation. * Fix registering the cart taxes inner block issue * Update translation script loading * Remove unnecessary JS translation The translation should work fine by getting the title & description from the `block.json` file * Put back the initial code in the 'Cart Taxes' inner block We didn't provide the correct `block.json` file path server side, that's why the `metadata` wasn't correctly registered * Generate `block.json`files for inner blocks This is the first step on fixing the missing translations of `metadata` in `block.json` files * Set the folder name exactly the same as the inner block name We are doing this first test for the `Cart taxes` inner block. The `Block` & its containing folder need to have the same name for: - Consistency - We use the `Block` name to get the file Path * Update imports after folder renaming * Get block name directly from the JSON metadata Getting the block name from the JSON metadata is less error prone than extracting it from the file path. And no need to rename all our `inner-blocks` to get the correct `block.json` path * Revert folder naming change of `Cart taxes` inner block Since we are getting the `block` name directly from the `block.json` metadata instead of extracting it from the file path, there is no need to keep their names in sync anymore * Fix missing translations for the `Cart Subtotal` Block * Register only the client-side settings on the client When the block is registered on the server, you only need to register the client-side settings on the client using the same block’s name. See [docs](https://github.com/WordPress/gutenberg/blob/trunk/docs/reference-guides/block-api/block-metadata.md#javascript-client-side). * Add schema validation to `block.json` Development is improved by using a defined schema definition file. Supported editors can provide help like tooltips, autocomplete, and schema validation. * Use the same `editor_script` as the parent block This prevents WordPress from generating script tags to inexistant inner blocks JS files * Add C&C inner blocks in Cart.php & Checkout.php This is a refactoring to keep the block types controller file less overloaded * Fix all Cart inner blocks missing translations * Create the "AbstractInnerBlock" class The "Inner Blocks" will use their parent's script, so no need to create new scripts for each one of them And, our "Inner Blocks" should always be registered using the metadata file * Update the "Inner Blocks" PHP classes * Fix PHP lint erros & update function description * Fix missing translations bug for all Checkout Inner Blocks * Update src/BlockTypes/Checkout.php Co-authored-by: Seghir Nadir * skip lazy loaded scripts Co-authored-by: Seghir Nadir * fix proceed to checkout button (#6804) * Remove compatibility notice from Mini Cart block (#6803) * Empty commit for release pull request * Update 8.2.0 changelog * Add 8.2.0 testing steps * Fix typo in 8.2.0 testing steps * Ensure package names display correctly if only one item is in package (#6815) * Check package length >= 1 to show package name * Check shipping rates length in order shipping packages slot * Fix TS error where boolean value could be undefined * Show items if there is more than one shipping rate * Ensure package names display correctly if only one item is in package (#6815) * Check package length >= 1 to show package name * Check shipping rates length in order shipping packages slot * Fix TS error where boolean value could be undefined * Show items if there is more than one shipping rate * Update 8.2.0 testing zip * Add option to hide/show price in Mini Cart block (#6796) * Add toggle control to sidebar in editor. Adds a visibility toggle in the Mini Cart block's sidebar editor settings for the block price. * Update name of hasVisiblePrice attrubite. Adjusts the name of the hasVisiblePrice attribute to hasHiddenPrice. This seems a bit easier to reason about, where we can set the default state of the visibility toggle to 'off'. * Add conditional price rendering to server side. Since this is a dynamic block, need to add the condidional attribute state to the server-side render callback. * Add price visibility setting to block frontend. We need to prevent pricec from rendering when hidden setting is active after the JS kicks in on the frontend (i.e., when the Mini Cart is interacted with by the user). * Fix logic error in frontend rendering conditional. * Add unit tests for both show/hide price states. * Bumping version strings to new version. * Remove empty element from changelog * Release: 8.2.0 (#6806) * Empty commit for release pull request * Update 8.2.0 changelog * Add 8.2.0 testing steps * Fix typo in 8.2.0 testing steps * Ensure package names display correctly if only one item is in package (#6815) * Check package length >= 1 to show package name * Check shipping rates length in order shipping packages slot * Fix TS error where boolean value could be undefined * Show items if there is more than one shipping rate * Update 8.2.0 testing zip * Bumping version strings to new version. * Remove empty element from changelog Co-authored-by: github-actions Co-authored-by: Albert Juhé Lluveras Co-authored-by: Thomas Roberts <5656702+opr@users.noreply.github.com> * Update version to 8.3.0-dev * Bump @wordpress/is-shallow-equal from 4.12.0 to 4.13.0 (#6710) Bumps [@wordpress/is-shallow-equal](https://github.com/WordPress/gutenberg/tree/HEAD/packages/is-shallow-equal) from 4.12.0 to 4.13.0. - [Release notes](https://github.com/WordPress/gutenberg/releases) - [Changelog](https://github.com/WordPress/gutenberg/blob/trunk/packages/is-shallow-equal/CHANGELOG.md) - [Commits](https://github.com/WordPress/gutenberg/commits/@wordpress/is-shallow-equal@4.13.0/packages/is-shallow-equal) --- updated-dependencies: - dependency-name: "@wordpress/is-shallow-equal" dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Luigi Teschio * Bump AbleLincoln/push-to-sftp from 1.0 to 1.2 (#6808) Bumps [AbleLincoln/push-to-sftp](https://github.com/AbleLincoln/push-to-sftp) from 1.0 to 1.2. - [Release notes](https://github.com/AbleLincoln/push-to-sftp/releases) - [Commits](https://github.com/AbleLincoln/push-to-sftp/compare/v1.0...v1.2) --- updated-dependencies: - dependency-name: AbleLincoln/push-to-sftp dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Luigi Teschio * Bump @wordpress/i18n from 4.12.0 to 4.14.0 (#6817) Bumps [@wordpress/i18n](https://github.com/WordPress/gutenberg/tree/HEAD/packages/i18n) from 4.12.0 to 4.14.0. - [Release notes](https://github.com/WordPress/gutenberg/releases) - [Changelog](https://github.com/WordPress/gutenberg/blob/trunk/packages/i18n/CHANGELOG.md) - [Commits](https://github.com/WordPress/gutenberg/commits/@wordpress/i18n@4.14.0/packages/i18n) --- updated-dependencies: - dependency-name: "@wordpress/i18n" dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Luigi Teschio * Bump yoast/phpunit-polyfills from 1.0.2 to 1.0.3 (#6704) Bumps [yoast/phpunit-polyfills](https://github.com/Yoast/PHPUnit-Polyfills) from 1.0.2 to 1.0.3. - [Release notes](https://github.com/Yoast/PHPUnit-Polyfills/releases) - [Changelog](https://github.com/Yoast/PHPUnit-Polyfills/blob/develop/CHANGELOG.md) - [Commits](https://github.com/Yoast/PHPUnit-Polyfills/compare/1.0.2...1.0.3) --- updated-dependencies: - dependency-name: yoast/phpunit-polyfills dependency-type: direct:development update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> * Bump github/codeql-action from 1 to 2 (#6700) Bumps [github/codeql-action](https://github.com/github/codeql-action) from 1 to 2. - [Release notes](https://github.com/github/codeql-action/releases) - [Changelog](https://github.com/github/codeql-action/blob/main/CHANGELOG.md) - [Commits](https://github.com/github/codeql-action/compare/v1...v2) --- updated-dependencies: - dependency-name: github/codeql-action dependency-type: direct:production update-type: version-update:semver-major ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Luigi Teschio * Bump johnbillion/wp-hooks-generator from 0.7.0 to 0.9.0 (#6705) Bumps [johnbillion/wp-hooks-generator](https://github.com/johnbillion/wp-hooks-generator) from 0.7.0 to 0.9.0. - [Release notes](https://github.com/johnbillion/wp-hooks-generator/releases) - [Commits](https://github.com/johnbillion/wp-hooks-generator/compare/0.7.0...0.9.0) --- updated-dependencies: - dependency-name: johnbillion/wp-hooks-generator dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Luigi Teschio * Bump @wordpress/wordcount from 3.12.0 to 3.13.0 (#6711) Bumps [@wordpress/wordcount](https://github.com/WordPress/gutenberg/tree/HEAD/packages/wordcount) from 3.12.0 to 3.13.0. - [Release notes](https://github.com/WordPress/gutenberg/releases) - [Changelog](https://github.com/WordPress/gutenberg/blob/trunk/packages/wordcount/CHANGELOG.md) - [Commits](https://github.com/WordPress/gutenberg/commits/@wordpress/wordcount@3.13.0/packages/wordcount) --- updated-dependencies: - dependency-name: "@wordpress/wordcount" dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> * Bump @typescript-eslint/parser from 5.30.5 to 5.31.0 (#6809) Bumps [@typescript-eslint/parser](https://github.com/typescript-eslint/typescript-eslint/tree/HEAD/packages/parser) from 5.30.5 to 5.31.0. - [Release notes](https://github.com/typescript-eslint/typescript-eslint/releases) - [Changelog](https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/parser/CHANGELOG.md) - [Commits](https://github.com/typescript-eslint/typescript-eslint/commits/v5.31.0/packages/parser) --- updated-dependencies: - dependency-name: "@typescript-eslint/parser" dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Luigi Teschio * Empty commit for release pull request * Ensure onChange is set for radio buttons in SavedPaymentMethodOptions (#6825) Co-authored-by: Seghir Nadir * delete renovate bot (#6824) * Bump @wordpress/api-fetch from 6.9.0 to 6.11.0 (#6833) Bumps [@wordpress/api-fetch](https://github.com/WordPress/gutenberg/tree/HEAD/packages/api-fetch) from 6.9.0 to 6.11.0. - [Release notes](https://github.com/WordPress/gutenberg/releases) - [Changelog](https://github.com/WordPress/gutenberg/blob/trunk/packages/api-fetch/CHANGELOG.md) - [Commits](https://github.com/WordPress/gutenberg/commits/@wordpress/api-fetch@6.11.0/packages/api-fetch) --- updated-dependencies: - dependency-name: "@wordpress/api-fetch" dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> * E2E: Try improving product list loading state detection and fix Site Editor URL (#6811) * e2e:try: detect loading state for product list * fix: always use site-editor.php * wait for price filter to be applied before checking the result * Update renovate configuration (#6836) * delete renovate bot * update renovate configuration * try now * Bump mini-css-extract-plugin from 1.3.6 to 1.6.2 (#6714) Bumps [mini-css-extract-plugin](https://github.com/webpack-contrib/mini-css-extract-plugin) from 1.3.6 to 1.6.2. - [Release notes](https://github.com/webpack-contrib/mini-css-extract-plugin/releases) - [Changelog](https://github.com/webpack-contrib/mini-css-extract-plugin/blob/master/CHANGELOG.md) - [Commits](https://github.com/webpack-contrib/mini-css-extract-plugin/compare/v1.3.6...v1.6.2) --- updated-dependencies: - dependency-name: mini-css-extract-plugin dependency-type: direct:development update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Luigi Teschio * Release: 8.2.1 (#6826) * Empty commit for release pull request * Update 8.2.1 changelog * Ensure onChange is set for radio buttons in SavedPaymentMethodOptions (#6825) Co-authored-by: Seghir Nadir * Add 8.2.1 testing steps * Bumping version strings to new version. Co-authored-by: github-actions Co-authored-by: Paulo Arromba <17236129+wavvves@users.noreply.github.com> Co-authored-by: Thomas Roberts <5656702+opr@users.noreply.github.com> Co-authored-by: Seghir Nadir * fix markdownlint violation (#6853) * Add missing label to dependabot configuration (#6848) * Fix: Compare action should update its original comment instead of a new comment (#6736) * Fix: flaky tests related to setMaxPrice (#6856) * Add font-weight option to Mini Cart block text (#6760) * Add font-weight option to Mini Cart button text. Need to repeat steps for icon SVG and cart item count. * Add font-weight controls to mini-cart item count. * Add better error handling to PHP style output. Ensure style value is set for style item in the get_font_weight_class_and_style attributes array before rendering it to the output. * Revert font-weight option for quantity badge. Per conversation with @vivialice, it looks better for now to keep the font weight adjustment capabilities to just the price and leave the cart icon and count as-is. * Move $typography_styles variable into markup fn. To resolve merge conflicts and get everything in it's proper place, this commit will move the $typography_styles variable into the get_cart_price_markup() function from #6796. * Fix: Attribute filter flaky test (#6862) * Fix: Override the description to prevent infinite loop (#6849) * Update billing address when shipping address gets change in Cart block (#6823) * Add Style Attributes Hooks to blocks/hooks Directory. (#6870) * Copy style-attributes file to desired directory. Add a copy of the style-attributes file in blocks/hooks to the desired base/hooks directory with the other hooks. * Remove relative imports in favor of global aliases Utilizes the custom global project aliases in place of using relative imports. Note: seeing some linting issues with the aliases. This seems to be the case elsewhere so it is likely not a blocker for this effort, however, it may be worth looking into as a follow-up. * Adjust all imports to use @woocommerce/base-hooks. Replace all instances of relative file paths to hooks/style-attributes to use the custom global alias. * Remove the hooks dir in `assets/js/blocks/`. Now that everything is using the `@woocommerce/base-hooks` custom global alias and we have the `style-attributes` hooks file in the base/hooks directory, we no longer need the `style-attributes` hooks file in the aforementioned `assets/js/blocks` directory. * Split style-attributes.ts out into separate files. Moved the four hooks in style-attributes.ts out into their own, separate hook file to be consistent with the rest of our custom hooks. Additionally, moved the helper function (parseStyle) out into a separate export in base/utils. * All Products block: Try hydrating * Enqueue script that adds custom element * Fix nomenclature * Use BHE hydration for All Products Block * Fix phpcs issues * Add block deprecation * Add StoreNoticesProvider wrapper back to frontend * Update blockRegistry implementation: - The registry is now the instance of a BlockRegistry class. - The BlockRegistry class has a `whenDefined()` method which is used to await the registration of a block with a given name. * Revert "Update blockRegistry implementation:" This reverts commit 8edc7b2f2115c21fb11dcee86e92d24017b4c305. Co-authored-by: Alba Rincón Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> Co-authored-by: Thomas Roberts <5656702+opr@users.noreply.github.com> Co-authored-by: Niels Lange Co-authored-by: Seghir Nadir Co-authored-by: Daniel W. Robert Co-authored-by: Tung Du Co-authored-by: Saad Tarhi Co-authored-by: github-actions Co-authored-by: Albert Juhé Lluveras Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: Luigi Teschio Co-authored-by: Paulo Arromba <17236129+wavvves@users.noreply.github.com> Co-authored-by: Tarun Vijwani Co-authored-by: Bernie Reiter Co-authored-by: Michal Czaplinski --- .github/compare-assets/index.js | 85 +- .github/dependabot.yml | 12 + .github/pull_request_template.md | 4 +- ...automate-team-review-assignment-config.yml | 2 +- .github/workflows/codeql-analysis.yml | 6 +- .github/workflows/generate-zip.yml | 2 +- .github/workflows/js-css-md-linting.yml | 4 + .../project-management-automations.yml | 3 + .../blocks/product-elements/button/block.js | 12 +- .../product-elements/category-list/block.tsx | 5 +- .../blocks/product-elements/image/block.js | 10 +- .../product-elements/image/test/block.test.js | 8 +- .../blocks/product-elements/price/block.js | 5 +- .../blocks/product-elements/rating/block.js | 10 +- .../product-elements/sale-badge/block.js | 12 +- .../product-elements/stock-indicator/block.js | 5 +- .../blocks/product-elements/summary/block.js | 5 +- .../blocks/product-elements/tag-list/block.js | 5 +- .../blocks/product-elements/title/block.tsx | 10 +- .../shipping-calculator/index.tsx | 4 +- .../shipping-rates-control/index.tsx | 6 +- .../components/dropdown-selector/index.js | 231 -- .../dropdown-selector/input-wrapper.js | 13 - .../components/dropdown-selector/input.js | 36 - .../base/components/dropdown-selector/menu.js | 59 - .../dropdown-selector/selected-chip.js | 26 - .../dropdown-selector/selected-value.js | 57 - .../components/dropdown-selector/style.scss | 176 -- .../components/form-token-field/index.tsx | 66 + .../form-token-field/stories/index.tsx | 41 + .../components/form-token-field/style.scss | 91 + .../components/form-token-field/vendor.scss | 12 + .../components/product-list/product-list.tsx | 6 +- .../hooks/cart/use-store-cart-coupons.ts | 171 +- assets/js/base/hooks/index.js | 4 + assets/js/base/hooks/use-border-props.ts | 32 + assets/js/base/hooks/use-color-props.ts | 30 + assets/js/base/hooks/use-spacing-props.ts | 28 + assets/js/base/hooks/use-typography-props.ts | 30 + assets/js/base/utils/index.js | 3 + assets/js/base/utils/parse-style.ts | 16 + assets/js/blocks/attribute-filter/block.tsx | 186 +- assets/js/blocks/attribute-filter/index.tsx | 2 +- assets/js/blocks/attribute-filter/preview.tsx | 6 + assets/js/blocks/attribute-filter/style.scss | 18 +- assets/js/blocks/attribute-filter/types.ts | 2 + assets/js/blocks/attribute-filter/utils.ts | 8 + .../saved-payment-method-options.js | 1 + .../block.json | 1 + .../index.tsx | 28 +- .../cart-express-payment-block/block.json | 1 + .../cart-express-payment-block/index.tsx | 3 +- .../inner-blocks/cart-items-block/block.json | 1 + .../inner-blocks/cart-items-block/index.tsx | 3 +- .../cart-line-items-block/block.json | 1 + .../cart-line-items-block/index.tsx | 3 +- .../cart-order-summary-block/block.json | 1 + .../cart-order-summary-block/index.tsx | 3 +- .../cart-order-summary-coupon-form/block.json | 1 + .../cart-order-summary-coupon-form/index.tsx | 28 +- .../cart-order-summary-discount/block.json | 1 + .../cart-order-summary-discount/index.tsx | 28 +- .../cart-order-summary-fee/block.json | 1 + .../cart-order-summary-fee/index.tsx | 3 +- .../cart-order-summary-heading/block.json | 1 + .../cart-order-summary-heading/index.tsx | 28 +- .../cart-order-summary-shipping/block.json | 1 + .../cart-order-summary-shipping/index.tsx | 30 +- .../cart-order-summary-subtotal/block.json | 1 + .../cart-order-summary-subtotal/index.tsx | 28 +- .../cart-order-summary-taxes/block.json | 1 + .../cart-order-summary-taxes/index.tsx | 3 +- .../inner-blocks/cart-totals-block/block.json | 1 + .../inner-blocks/cart-totals-block/index.tsx | 3 +- .../inner-blocks/empty-cart-block/block.json | 1 + .../inner-blocks/empty-cart-block/index.tsx | 3 +- .../inner-blocks/filled-cart-block/block.json | 1 + .../inner-blocks/filled-cart-block/index.tsx | 3 +- .../proceed-to-checkout-block/block.json | 1 + .../proceed-to-checkout-block/index.tsx | 3 +- .../checkout-actions-block/block.json | 1 + .../checkout-actions-block/index.tsx | 3 +- .../checkout-billing-address-block/block.json | 1 + .../checkout-billing-address-block/index.tsx | 3 +- .../block.json | 1 + .../index.tsx | 30 +- .../checkout-express-payment-block/block.json | 1 + .../checkout-express-payment-block/index.tsx | 3 +- .../checkout-fields-block/block.json | 1 + .../checkout-fields-block/index.tsx | 3 +- .../checkout-order-note-block/block.json | 1 + .../checkout-order-note-block/index.tsx | 3 +- .../checkout-order-summary-block/block.json | 1 + .../checkout-order-summary-block/index.tsx | 3 +- .../block.json | 1 + .../index.tsx | 28 +- .../block.json | 1 + .../index.tsx | 28 +- .../block.json | 1 + .../checkout-order-summary-discount/index.tsx | 28 +- .../checkout-order-summary-fee/block.json | 1 + .../checkout-order-summary-fee/index.tsx | 28 +- .../block.json | 1 + .../checkout-order-summary-shipping/index.tsx | 28 +- .../block.json | 1 + .../checkout-order-summary-subtotal/index.tsx | 28 +- .../checkout-order-summary-taxes/block.json | 1 + .../checkout-order-summary-taxes/index.tsx | 30 +- .../checkout-payment-block/block.json | 1 + .../checkout-payment-block/index.tsx | 3 +- .../block.json | 1 + .../checkout-shipping-address-block/block.tsx | 18 +- .../checkout-shipping-address-block/index.tsx | 3 +- .../block.json | 1 + .../checkout-shipping-methods-block/index.tsx | 3 +- .../checkout-terms-block/block.json | 1 + .../checkout-terms-block/index.tsx | 3 +- .../checkout-totals-block/block.json | 1 + .../checkout-totals-block/index.tsx | 3 +- assets/js/blocks/mini-cart/block.tsx | 41 +- .../blocks/mini-cart/component-frontend.tsx | 1 + assets/js/blocks/mini-cart/edit.tsx | 42 +- assets/js/blocks/mini-cart/index.tsx | 10 +- assets/js/blocks/mini-cart/test/block.js | 23 + .../cart-checkout-compatibility-notice.tsx | 2 +- assets/js/hooks/style-attributes.ts | 101 - assets/js/icons/index.js | 1 + assets/js/icons/library/mini-cart-alt.tsx | 39 + bin/add-doc-footer.sh | 2 +- bin/hook-docs/data/actions.json | 1521 +++++++------- bin/hook-docs/data/filters.json | 1863 +++++++++-------- bin/webpack-configs.js | 16 +- bin/webpack-entries.js | 2 + composer.json | 2 +- composer.lock | 162 +- docs/README.md | 1 + docs/contributors/README.md | 2 +- docs/contributors/components.md | 3 +- docs/contributors/contributing/README.md | 3 +- .../contributors/contributing/block-assets.md | 3 +- .../contributing/coding-guidelines.md | 3 +- .../contributing/css-build-system.md | 3 +- .../contributing/documentation-guidelines.md | 3 +- .../contributing/folder-structure.md | 3 +- .../contributing/getting-started.md | 3 +- .../contributing/javascript-build-system.md | 3 +- .../contributing/javascript-testing.md | 3 +- .../contributing/storybook-and-components.md | 3 +- docs/designers/theming/README.md | 3 +- .../theming/all-products-and-filters.md | 3 +- docs/designers/theming/cart-and-checkout.md | 3 +- .../theming/class-names-update-280.md | 3 +- .../theming/class-names-update-330.md | 3 +- .../theming/class-names-update-340.md | 3 +- .../theming/class-names-update-460.md | 3 +- docs/designers/theming/product-grid-270.md | 3 +- .../block-client-apis/README.md | 3 +- .../checkout/checkout-api.md | 3 +- .../checkout/checkout-flow-and-events.md | 3 +- .../block-client-apis/notices.md | 3 +- docs/internal-developers/blocks/README.md | 3 +- ...ature-flags-and-experimental-interfaces.md | 3 +- .../blocks/stock-reservation.md | 3 +- docs/internal-developers/templates/README.md | 3 +- .../templates/block-template-controller.md | 3 +- .../templates/classic-template.md | 3 +- docs/internal-developers/testing/README.md | 3 +- .../testing/cart-checkout/README.md | 3 +- .../testing/cart-checkout/compatibility.md | 3 +- .../testing/cart-checkout/coupons.md | 3 +- .../testing/cart-checkout/cross-browser.md | 2 +- .../testing/cart-checkout/editor.md | 3 +- .../testing/cart-checkout/general-flow.md | 3 +- .../testing/cart-checkout/items.md | 3 +- .../testing/cart-checkout/payment.md | 3 +- .../testing/cart-checkout/shipping.md | 3 +- .../testing/cart-checkout/taxes.md | 3 +- .../testing/releases/260.md | 3 +- .../testing/releases/261.md | 3 +- .../testing/releases/270.md | 3 +- .../testing/releases/271.md | 3 +- .../testing/releases/272.md | 3 +- .../testing/releases/280.md | 3 +- .../testing/releases/290.md | 3 +- .../testing/releases/300.md | 3 +- .../testing/releases/310.md | 3 +- .../testing/releases/320.md | 3 +- .../testing/releases/330.md | 3 +- .../testing/releases/340.md | 3 +- .../testing/releases/350.md | 3 +- .../testing/releases/360.md | 3 +- .../testing/releases/370.md | 3 +- .../testing/releases/371.md | 3 +- .../testing/releases/380.md | 3 +- .../testing/releases/390.md | 3 +- .../testing/releases/400.md | 3 +- .../testing/releases/410.md | 3 +- .../testing/releases/420.md | 3 +- .../testing/releases/430.md | 3 +- .../testing/releases/440.md | 3 +- .../testing/releases/450.md | 3 +- .../testing/releases/452.md | 3 +- .../testing/releases/460.md | 3 +- .../testing/releases/470.md | 3 +- .../testing/releases/480.md | 3 +- .../testing/releases/490.md | 3 +- .../testing/releases/491.md | 3 +- .../testing/releases/500.md | 3 +- .../testing/releases/510.md | 3 +- .../testing/releases/520.md | 3 +- .../testing/releases/530.md | 3 +- .../testing/releases/531.md | 3 +- .../testing/releases/532.md | 3 +- .../testing/releases/540.md | 3 +- .../testing/releases/550.md | 3 +- .../testing/releases/560.md | 3 +- .../testing/releases/570.md | 3 +- .../testing/releases/571.md | 3 +- .../testing/releases/572.md | 3 +- .../testing/releases/580.md | 3 +- .../testing/releases/590.md | 3 +- .../testing/releases/591.md | 3 +- .../testing/releases/600.md | 3 +- .../testing/releases/610.md | 3 +- .../testing/releases/620.md | 3 +- .../testing/releases/630.md | 3 +- .../testing/releases/631.md | 3 +- .../testing/releases/632.md | 3 +- .../testing/releases/633.md | 3 +- .../testing/releases/640.md | 3 +- .../testing/releases/650.md | 3 +- .../testing/releases/660.md | 3 +- .../testing/releases/670.md | 3 +- .../testing/releases/671.md | 3 +- .../testing/releases/672.md | 3 +- .../testing/releases/673.md | 3 +- .../testing/releases/680.md | 3 +- .../testing/releases/690.md | 3 +- .../testing/releases/700.md | 3 +- .../testing/releases/710.md | 3 +- .../testing/releases/720.md | 3 +- .../testing/releases/721.md | 3 +- .../testing/releases/722.md | 3 +- .../testing/releases/730.md | 3 +- .../testing/releases/740.md | 3 +- .../testing/releases/741.md | 3 +- .../testing/releases/742.md | 3 +- .../testing/releases/750.md | 3 +- .../testing/releases/760.md | 3 +- .../testing/releases/761.md | 3 +- .../testing/releases/762.md | 3 +- .../testing/releases/770.md | 3 +- .../testing/releases/780.md | 3 +- .../testing/releases/781.md | 3 +- .../testing/releases/782.md | 3 +- .../testing/releases/783.md | 3 +- .../testing/releases/790.md | 10 + .../testing/releases/800.md | 10 + .../testing/releases/810.md | 10 + .../testing/releases/820.md | 155 ++ .../testing/releases/821.md | 26 + .../testing/releases/README.md | 5 +- .../testing/smoke-testing.md | 3 +- .../testing/when-to-employ-e2e-testing.md | 3 +- .../translations/README.md | 3 +- .../translations/translation-basics.md | 3 +- .../translations/translation-loading.md | 3 +- .../translations/translation-management.md | 3 +- ...translations-for-lazy-loaded-components.md | 3 +- .../translations-in-FSE-templates.md | 3 +- .../translations-in-JS-TS-files.md | 3 +- .../translations/translations-in-PHP-files.md | 3 +- .../extensibility/README.md | 3 +- .../checkout-block/available-filters.md | 3 +- .../checkout-block/available-slot-fills.md | 3 +- .../checkout-block/dom-events.md | 3 +- .../checkout-block/integration-interface.md | 3 +- .../checkout-block/slot-fills.md | 3 +- .../checkout-flow-and-events.md | 3 +- .../filtering-payment-methods.md | 3 +- .../payment-method-integration.md | 3 +- .../extensibility/hooks/actions.md | 370 ++-- .../extensibility/hooks/filters.md | 452 ++-- .../rest-api/available-endpoints-to-extend.md | 3 +- .../rest-api/extend-rest-api-add-data.md | 3 +- .../rest-api/extend-rest-api-formatters.md | 3 +- .../rest-api/extend-rest-api-new-endpoint.md | 3 +- .../rest-api/extend-rest-api-update-cart.md | 3 +- package-lock.json | 602 +++--- package.json | 22 +- packages/checkout/README.md | 3 +- packages/checkout/blocks-registry/README.md | 3 +- packages/checkout/components/README.md | 3 +- .../order-shipping-packages/index.js | 3 +- packages/checkout/filter-registry/README.md | 3 +- packages/checkout/slot/README.md | 3 +- packages/checkout/utils/README.md | 3 +- readme.txt | 31 +- renovate.json | 37 - src/BlockTemplatesController.php | 6 + src/BlockTypes/AbstractInnerBlock.php | 57 + src/BlockTypes/AbstractProductGrid.php | 9 + src/BlockTypes/Cart.php | 31 + .../CartAcceptedPaymentMethodsBlock.php | 14 + src/BlockTypes/CartExpressPaymentBlock.php | 14 + src/BlockTypes/CartItemsBlock.php | 14 + src/BlockTypes/CartLineItemsBlock.php | 14 + src/BlockTypes/CartOrderSummaryBlock.php | 14 + .../CartOrderSummaryCouponFormBlock.php | 14 + .../CartOrderSummaryDiscountBlock.php | 14 + src/BlockTypes/CartOrderSummaryFeeBlock.php | 14 + .../CartOrderSummaryHeadingBlock.php | 14 + .../CartOrderSummaryShippingBlock.php | 14 + .../CartOrderSummarySubtotalBlock.php | 14 + src/BlockTypes/CartOrderSummaryTaxesBlock.php | 14 + src/BlockTypes/CartTotalsBlock.php | 14 + src/BlockTypes/Checkout.php | 36 + src/BlockTypes/CheckoutActionsBlock.php | 14 + .../CheckoutBillingAddressBlock.php | 14 + .../CheckoutContactInformationBlock.php | 14 + .../CheckoutExpressPaymentBlock.php | 14 + src/BlockTypes/CheckoutFieldsBlock.php | 14 + src/BlockTypes/CheckoutOrderNoteBlock.php | 14 + src/BlockTypes/CheckoutOrderSummaryBlock.php | 14 + .../CheckoutOrderSummaryCartItemsBlock.php | 14 + .../CheckoutOrderSummaryCouponFormBlock.php | 14 + .../CheckoutOrderSummaryDiscountBlock.php | 14 + .../CheckoutOrderSummaryFeeBlock.php | 14 + .../CheckoutOrderSummaryShippingBlock.php | 14 + .../CheckoutOrderSummarySubtotalBlock.php | 14 + .../CheckoutOrderSummaryTaxesBlock.php | 14 + src/BlockTypes/CheckoutPaymentBlock.php | 14 + .../CheckoutShippingAddressBlock.php | 14 + .../CheckoutShippingMethodsBlock.php | 14 + src/BlockTypes/CheckoutTermsBlock.php | 14 + src/BlockTypes/CheckoutTotalsBlock.php | 14 + src/BlockTypes/EmptyCartBlock.php | 14 + src/BlockTypes/FilledCartBlock.php | 14 + src/BlockTypes/MiniCart.php | 24 +- src/BlockTypes/ProceedToCheckoutBlock.php | 26 + src/BlockTypesController.php | 7 +- src/Domain/Bootstrap.php | 8 + src/Package.php | 2 +- src/StoreApi/README.md | 3 +- src/StoreApi/Routes/V1/Checkout.php | 8 + src/StoreApi/docs/cart-coupons.md | 3 +- src/StoreApi/docs/cart-items.md | 3 +- src/StoreApi/docs/cart.md | 3 +- src/StoreApi/docs/checkout.md | 3 +- src/StoreApi/docs/guiding-principles.md | 5 +- src/StoreApi/docs/nonce-tokens.md | 3 +- src/StoreApi/docs/product-attribute-terms.md | 3 +- src/StoreApi/docs/product-attributes.md | 3 +- src/StoreApi/docs/product-collection-data.md | 3 +- src/StoreApi/docs/products.md | 3 +- src/Templates/ProductAttributeTemplate.php | 39 + src/Utils/BlocksWpQuery.php | 19 - src/Utils/StyleAttributesUtils.php | 22 + tests/e2e/specs/backend/mini-cart.test.js | 65 +- .../filter-products-by-attribute.test.ts | 9 +- .../shopper/filter-products-by-price.test.ts | 17 +- tests/e2e/utils.js | 38 +- woocommerce-gutenberg-products-block.php | 2 +- 363 files changed, 5178 insertions(+), 3848 deletions(-) delete mode 100644 assets/js/base/components/dropdown-selector/index.js delete mode 100644 assets/js/base/components/dropdown-selector/input-wrapper.js delete mode 100644 assets/js/base/components/dropdown-selector/input.js delete mode 100644 assets/js/base/components/dropdown-selector/menu.js delete mode 100644 assets/js/base/components/dropdown-selector/selected-chip.js delete mode 100644 assets/js/base/components/dropdown-selector/selected-value.js delete mode 100644 assets/js/base/components/dropdown-selector/style.scss create mode 100644 assets/js/base/components/form-token-field/index.tsx create mode 100644 assets/js/base/components/form-token-field/stories/index.tsx create mode 100644 assets/js/base/components/form-token-field/style.scss create mode 100644 assets/js/base/components/form-token-field/vendor.scss create mode 100644 assets/js/base/hooks/use-border-props.ts create mode 100644 assets/js/base/hooks/use-color-props.ts create mode 100644 assets/js/base/hooks/use-spacing-props.ts create mode 100644 assets/js/base/hooks/use-typography-props.ts create mode 100644 assets/js/base/utils/parse-style.ts delete mode 100644 assets/js/hooks/style-attributes.ts create mode 100644 assets/js/icons/library/mini-cart-alt.tsx create mode 100644 docs/internal-developers/testing/releases/820.md create mode 100644 docs/internal-developers/testing/releases/821.md delete mode 100644 renovate.json create mode 100644 src/BlockTypes/AbstractInnerBlock.php create mode 100644 src/BlockTypes/CartAcceptedPaymentMethodsBlock.php create mode 100644 src/BlockTypes/CartExpressPaymentBlock.php create mode 100644 src/BlockTypes/CartItemsBlock.php create mode 100644 src/BlockTypes/CartLineItemsBlock.php create mode 100644 src/BlockTypes/CartOrderSummaryBlock.php create mode 100644 src/BlockTypes/CartOrderSummaryCouponFormBlock.php create mode 100644 src/BlockTypes/CartOrderSummaryDiscountBlock.php create mode 100644 src/BlockTypes/CartOrderSummaryFeeBlock.php create mode 100644 src/BlockTypes/CartOrderSummaryHeadingBlock.php create mode 100644 src/BlockTypes/CartOrderSummaryShippingBlock.php create mode 100644 src/BlockTypes/CartOrderSummarySubtotalBlock.php create mode 100644 src/BlockTypes/CartOrderSummaryTaxesBlock.php create mode 100644 src/BlockTypes/CartTotalsBlock.php create mode 100644 src/BlockTypes/CheckoutActionsBlock.php create mode 100644 src/BlockTypes/CheckoutBillingAddressBlock.php create mode 100644 src/BlockTypes/CheckoutContactInformationBlock.php create mode 100644 src/BlockTypes/CheckoutExpressPaymentBlock.php create mode 100644 src/BlockTypes/CheckoutFieldsBlock.php create mode 100644 src/BlockTypes/CheckoutOrderNoteBlock.php create mode 100644 src/BlockTypes/CheckoutOrderSummaryBlock.php create mode 100644 src/BlockTypes/CheckoutOrderSummaryCartItemsBlock.php create mode 100644 src/BlockTypes/CheckoutOrderSummaryCouponFormBlock.php create mode 100644 src/BlockTypes/CheckoutOrderSummaryDiscountBlock.php create mode 100644 src/BlockTypes/CheckoutOrderSummaryFeeBlock.php create mode 100644 src/BlockTypes/CheckoutOrderSummaryShippingBlock.php create mode 100644 src/BlockTypes/CheckoutOrderSummarySubtotalBlock.php create mode 100644 src/BlockTypes/CheckoutOrderSummaryTaxesBlock.php create mode 100644 src/BlockTypes/CheckoutPaymentBlock.php create mode 100644 src/BlockTypes/CheckoutShippingAddressBlock.php create mode 100644 src/BlockTypes/CheckoutShippingMethodsBlock.php create mode 100644 src/BlockTypes/CheckoutTermsBlock.php create mode 100644 src/BlockTypes/CheckoutTotalsBlock.php create mode 100644 src/BlockTypes/EmptyCartBlock.php create mode 100644 src/BlockTypes/FilledCartBlock.php create mode 100644 src/BlockTypes/ProceedToCheckoutBlock.php create mode 100644 src/Templates/ProductAttributeTemplate.php diff --git a/.github/compare-assets/index.js b/.github/compare-assets/index.js index 132da4ff6b5..764c9388864 100644 --- a/.github/compare-assets/index.js +++ b/.github/compare-assets/index.js @@ -51,7 +51,45 @@ const runner = async () => { .filter( Boolean ) ); + let reportCommentId; + + { + const currentComments = await octokit.rest.issues.listComments( { + owner, + repo, + issue_number: payload.pull_request.number, + } ); + + if ( + Array.isArray( currentComments.data ) && + currentComments.data.length > 0 + ) { + const comment = currentComments.data.find( + ( comment ) => + comment.body.includes( 'Script Dependencies Report' ) && + comment.user.login === 'github-actions[bot]' + ); + + if ( comment ) { + reportCommentId = comment.id; + } + } + } + if ( Object.keys( changes ).length === 0 ) { + if ( reportCommentId ) { + await octokit.rest.issues.updateComment( { + owner, + repo, + comment_id: reportCommentId, + body: + '# Script Dependencies Report' + + '\n\n' + + 'There is no changed script dependency between this branch and trunk.' + + '\n\n' + + '__This comment was automatically generated by the `./github/compare-assets` action.__', + } ); + } return; } @@ -82,24 +120,35 @@ const runner = async () => { } ); - await octokit.rest.issues.createComment( { - owner, - repo, - issue_number: payload.pull_request.number, - body: - '# Script Dependencies Report' + - '\n\n' + - 'The `compare-assets` action has detected some changed script dependencies between this branch and ' + - 'trunk. Please review and confirm the following are correct before merging.' + - '\n\n' + - '| Script Handle | Added | Removed | |' + - '\n' + - '| ------------- | ------| ------- | -- |' + - '\n' + - reportContent + - '\n\n' + - '__This comment was automatically generated by the `./github/compare-assets` action.__', - } ); + const commentBody = + '# Script Dependencies Report' + + '\n\n' + + 'The `compare-assets` action has detected some changed script dependencies between this branch and ' + + 'trunk. Please review and confirm the following are correct before merging.' + + '\n\n' + + '| Script Handle | Added | Removed | |' + + '\n' + + '| ------------- | ------| ------- | -- |' + + '\n' + + reportContent + + '\n\n' + + '__This comment was automatically generated by the `./github/compare-assets` action.__'; + + if ( reportCommentId ) { + await octokit.rest.issues.updateComment( { + owner, + repo, + comment_id: reportCommentId, + body: commentBody, + } ); + } else { + await octokit.rest.issues.createComment( { + owner, + repo, + issue_number: payload.pull_request.number, + body: commentBody, + } ); + } } catch ( error ) { setFailed( error.message ); } diff --git a/.github/dependabot.yml b/.github/dependabot.yml index acc64ee99f3..e6d8a18f8a5 100644 --- a/.github/dependabot.yml +++ b/.github/dependabot.yml @@ -7,6 +7,10 @@ updates: schedule: interval: 'monthly' open-pull-requests-limit: 10 + labels: + - "skip-changelog" + - "type: dependencies" + - "github_actions" # Maintain dependencies for npm - package-ecosystem: 'npm' @@ -14,6 +18,10 @@ updates: schedule: interval: 'weekly' open-pull-requests-limit: 10 + labels: + - "skip-changelog" + - "type: dependencies" + - "javascript" # Maintain dependencies for Composer - package-ecosystem: 'composer' @@ -21,3 +29,7 @@ updates: schedule: interval: 'weekly' open-pull-requests-limit: 10 + labels: + - "skip-changelog" + - "type: dependencies" + - "php" diff --git a/.github/pull_request_template.md b/.github/pull_request_template.md index 9d4e2555ecd..3ce0c5026d7 100644 --- a/.github/pull_request_template.md +++ b/.github/pull_request_template.md @@ -18,8 +18,8 @@ Fixes # #### Other Checks -- [ ] This PR adds/removes a feature flag & I've updated [this doc](../docs/blocks/feature-flags-and-experimental-interfaces.md) . -- [ ] This PR adds/removes an experimental interfaces and I've updated [this doc](../docs/blocks/feature-flags-and-experimental-interfaces.md) +- [ ] This PR adds/removes a feature flag & I've updated [this doc](https://github.com/woocommerce/woocommerce-blocks/blob/trunk/docs/internal-developers/blocks/feature-flags-and-experimental-interfaces.md). +- [ ] This PR adds/removes an experimental interfaces and I've updated [this doc](https://github.com/woocommerce/woocommerce-blocks/blob/trunk/docs/internal-developers/blocks/feature-flags-and-experimental-interfaces.md). - [ ] I tagged two reviewers because this PR makes queries to the database or I think it might have some security impact. ### Screenshots diff --git a/.github/workflows/automate-team-review-assignment-config.yml b/.github/workflows/automate-team-review-assignment-config.yml index e372fda62e5..76c242d7ea6 100644 --- a/.github/workflows/automate-team-review-assignment-config.yml +++ b/.github/workflows/automate-team-review-assignment-config.yml @@ -5,7 +5,7 @@ on: jobs: add-reviews: - if: github.event.pull_request.draft == false + if: github.event.pull_request.draft == false && github.actor != 'dependabot[bot]' runs-on: ubuntu-latest steps: - name: Check config and assign reviews diff --git a/.github/workflows/codeql-analysis.yml b/.github/workflows/codeql-analysis.yml index c7fa303101e..3a28bd571c9 100644 --- a/.github/workflows/codeql-analysis.yml +++ b/.github/workflows/codeql-analysis.yml @@ -43,7 +43,7 @@ jobs: # Initializes the CodeQL tools for scanning. - name: Initialize CodeQL - uses: github/codeql-action/init@v1 + uses: github/codeql-action/init@v2 with: languages: ${{ matrix.language }} # If you wish to specify custom queries, you can do so here or in a config file. @@ -54,7 +54,7 @@ jobs: # Autobuild attempts to build any compiled languages (C/C++, C#, or Java). # If this step fails, then you should remove it and run the build manually (see below) - name: Autobuild - uses: github/codeql-action/autobuild@v1 + uses: github/codeql-action/autobuild@v2 # ℹ️ Command-line programs to run using the OS shell. # 📚 https://git.io/JvXDl @@ -68,4 +68,4 @@ jobs: # make release - name: Perform CodeQL Analysis - uses: github/codeql-action/analyze@v1 + uses: github/codeql-action/analyze@v2 diff --git a/.github/workflows/generate-zip.yml b/.github/workflows/generate-zip.yml index a9add0f59bc..7105ef1e15a 100644 --- a/.github/workflows/generate-zip.yml +++ b/.github/workflows/generate-zip.yml @@ -38,7 +38,7 @@ jobs: run: mv woocommerce-gutenberg-products-block.zip wc-blocks-pr-release__temp/woocommerce-gutenberg-products-block-${{ github.event.pull_request.number }}.zip - name: Transfer ZIP file via SFTP - uses: AbleLincoln/push-to-sftp@v1.0 + uses: AbleLincoln/push-to-sftp@v1.2 with: host: ${{ secrets.FTP_HOST }} port: 22 diff --git a/.github/workflows/js-css-md-linting.yml b/.github/workflows/js-css-md-linting.yml index 05c8688437a..5285fd1fc98 100644 --- a/.github/workflows/js-css-md-linting.yml +++ b/.github/workflows/js-css-md-linting.yml @@ -4,6 +4,10 @@ on: pull_request: push: branches: [trunk] +permissions: + actions: write + checks: write + pull-requests: read jobs: # cache node and modules diff --git a/.github/workflows/project-management-automations.yml b/.github/workflows/project-management-automations.yml index 88a93f6cb79..b76c2a96a3a 100644 --- a/.github/workflows/project-management-automations.yml +++ b/.github/workflows/project-management-automations.yml @@ -5,6 +5,9 @@ on: issues: types: [edited] name: Project management automations +permissions: + pull-requests: write + actions: write jobs: project-management-automation: runs-on: ubuntu-latest diff --git a/assets/js/atomic/blocks/product-elements/button/block.js b/assets/js/atomic/blocks/product-elements/button/block.js index 39502458492..4283ae68c7d 100644 --- a/assets/js/atomic/blocks/product-elements/button/block.js +++ b/assets/js/atomic/blocks/product-elements/button/block.js @@ -8,6 +8,12 @@ import { useStoreEvents, useStoreAddToCart, } from '@woocommerce/base-context/hooks'; +import { + useBorderProps, + useColorProps, + useTypographyProps, + useSpacingProps, +} from '@woocommerce/base-hooks'; import { decodeEntities } from '@wordpress/html-entities'; import { CART_URL } from '@woocommerce/block-settings'; import { getSetting } from '@woocommerce/settings'; @@ -21,12 +27,6 @@ import { withProductDataContext } from '@woocommerce/shared-hocs'; * Internal dependencies */ import './style.scss'; -import { - useBorderProps, - useColorProps, - useTypographyProps, - useSpacingProps, -} from '../../../../hooks/style-attributes'; /** * Product Button Block Component. diff --git a/assets/js/atomic/blocks/product-elements/category-list/block.tsx b/assets/js/atomic/blocks/product-elements/category-list/block.tsx index afbf64c5914..01d017d420a 100644 --- a/assets/js/atomic/blocks/product-elements/category-list/block.tsx +++ b/assets/js/atomic/blocks/product-elements/category-list/block.tsx @@ -7,6 +7,7 @@ import { useInnerBlockLayoutContext, useProductDataContext, } from '@woocommerce/shared-context'; +import { useColorProps, useTypographyProps } from '@woocommerce/base-hooks'; import { isEmpty } from 'lodash'; import { withProductDataContext } from '@woocommerce/shared-hocs'; import { HTMLAttributes } from 'react'; @@ -16,10 +17,6 @@ import { HTMLAttributes } from 'react'; */ import './style.scss'; import { Attributes } from './types'; -import { - useColorProps, - useTypographyProps, -} from '../../../../hooks/style-attributes'; type Props = Attributes & HTMLAttributes< HTMLDivElement >; diff --git a/assets/js/atomic/blocks/product-elements/image/block.js b/assets/js/atomic/blocks/product-elements/image/block.js index d5c296036b9..f9554e6e599 100644 --- a/assets/js/atomic/blocks/product-elements/image/block.js +++ b/assets/js/atomic/blocks/product-elements/image/block.js @@ -10,6 +10,11 @@ import { useInnerBlockLayoutContext, useProductDataContext, } from '@woocommerce/shared-context'; +import { + useBorderProps, + useSpacingProps, + useTypographyProps, +} from '@woocommerce/base-hooks'; import { withProductDataContext } from '@woocommerce/shared-hocs'; import { useStoreEvents } from '@woocommerce/base-context/hooks'; @@ -18,11 +23,6 @@ import { useStoreEvents } from '@woocommerce/base-context/hooks'; */ import ProductSaleBadge from './../sale-badge/block'; import './style.scss'; -import { - useBorderProps, - useSpacingProps, - useTypographyProps, -} from '../../../../hooks/style-attributes'; /** * Product Image Block Component. diff --git a/assets/js/atomic/blocks/product-elements/image/test/block.test.js b/assets/js/atomic/blocks/product-elements/image/test/block.test.js index 529fbe2b625..5e989a161ad 100644 --- a/assets/js/atomic/blocks/product-elements/image/test/block.test.js +++ b/assets/js/atomic/blocks/product-elements/image/test/block.test.js @@ -9,13 +9,7 @@ import { ProductDataContextProvider } from '@woocommerce/shared-context'; */ import { Block } from '../block'; -jest.mock( '@woocommerce/block-settings', () => ( { - ...jest.requireActual( '@woocommerce/block-settings' ), - __esModule: true, - PLACEHOLDER_IMG_SRC: 'placeholder.jpg', -} ) ); - -jest.mock( '../../../../../hooks/style-attributes', () => ( { +jest.mock( '@woocommerce/base-hooks', () => ( { __esModule: true, useBorderProps: jest.fn( () => ( { className: '', diff --git a/assets/js/atomic/blocks/product-elements/price/block.js b/assets/js/atomic/blocks/product-elements/price/block.js index 3831aa10be6..b57fc475dc9 100644 --- a/assets/js/atomic/blocks/product-elements/price/block.js +++ b/assets/js/atomic/blocks/product-elements/price/block.js @@ -9,15 +9,12 @@ import { useInnerBlockLayoutContext, useProductDataContext, } from '@woocommerce/shared-context'; +import { useColorProps, useTypographyProps } from '@woocommerce/base-hooks'; import { withProductDataContext } from '@woocommerce/shared-hocs'; /** * Internal dependencies */ -import { - useColorProps, - useTypographyProps, -} from '../../../../hooks/style-attributes'; /** * Product Price Block Component. diff --git a/assets/js/atomic/blocks/product-elements/rating/block.js b/assets/js/atomic/blocks/product-elements/rating/block.js index de62fec7ee7..a42c78f1a02 100644 --- a/assets/js/atomic/blocks/product-elements/rating/block.js +++ b/assets/js/atomic/blocks/product-elements/rating/block.js @@ -8,17 +8,17 @@ import { useInnerBlockLayoutContext, useProductDataContext, } from '@woocommerce/shared-context'; +import { + useColorProps, + useSpacingProps, + useTypographyProps, +} from '@woocommerce/base-hooks'; import { withProductDataContext } from '@woocommerce/shared-hocs'; /** * Internal dependencies */ import './style.scss'; -import { - useColorProps, - useSpacingProps, - useTypographyProps, -} from '../../../../hooks/style-attributes'; /** * Product Rating Block Component. diff --git a/assets/js/atomic/blocks/product-elements/sale-badge/block.js b/assets/js/atomic/blocks/product-elements/sale-badge/block.js index 6786c818b31..d44cab0a773 100644 --- a/assets/js/atomic/blocks/product-elements/sale-badge/block.js +++ b/assets/js/atomic/blocks/product-elements/sale-badge/block.js @@ -9,18 +9,18 @@ import { useInnerBlockLayoutContext, useProductDataContext, } from '@woocommerce/shared-context'; +import { + useBorderProps, + useColorProps, + useSpacingProps, + useTypographyProps, +} from '@woocommerce/base-hooks'; import { withProductDataContext } from '@woocommerce/shared-hocs'; /** * Internal dependencies */ import './style.scss'; -import { - useBorderProps, - useColorProps, - useSpacingProps, - useTypographyProps, -} from '../../../../hooks/style-attributes'; /** * Product Sale Badge Block Component. diff --git a/assets/js/atomic/blocks/product-elements/stock-indicator/block.js b/assets/js/atomic/blocks/product-elements/stock-indicator/block.js index 66b1d56aa89..90b487dd7c1 100644 --- a/assets/js/atomic/blocks/product-elements/stock-indicator/block.js +++ b/assets/js/atomic/blocks/product-elements/stock-indicator/block.js @@ -8,16 +8,13 @@ import { useInnerBlockLayoutContext, useProductDataContext, } from '@woocommerce/shared-context'; +import { useColorProps, useTypographyProps } from '@woocommerce/base-hooks'; import { withProductDataContext } from '@woocommerce/shared-hocs'; /** * Internal dependencies */ import './style.scss'; -import { - useColorProps, - useTypographyProps, -} from '../../../../hooks/style-attributes'; /** * Product Stock Indicator Block Component. diff --git a/assets/js/atomic/blocks/product-elements/summary/block.js b/assets/js/atomic/blocks/product-elements/summary/block.js index aa387969df6..6c500339278 100644 --- a/assets/js/atomic/blocks/product-elements/summary/block.js +++ b/assets/js/atomic/blocks/product-elements/summary/block.js @@ -10,16 +10,13 @@ import { useInnerBlockLayoutContext, useProductDataContext, } from '@woocommerce/shared-context'; +import { useColorProps, useTypographyProps } from '@woocommerce/base-hooks'; import { withProductDataContext } from '@woocommerce/shared-hocs'; /** * Internal dependencies */ import './style.scss'; -import { - useColorProps, - useTypographyProps, -} from '../../../../hooks/style-attributes'; /** * Product Summary Block Component. diff --git a/assets/js/atomic/blocks/product-elements/tag-list/block.js b/assets/js/atomic/blocks/product-elements/tag-list/block.js index 39d3aad3381..6ec795a276a 100644 --- a/assets/js/atomic/blocks/product-elements/tag-list/block.js +++ b/assets/js/atomic/blocks/product-elements/tag-list/block.js @@ -8,6 +8,7 @@ import { useInnerBlockLayoutContext, useProductDataContext, } from '@woocommerce/shared-context'; +import { useColorProps, useTypographyProps } from '@woocommerce/base-hooks'; import { isEmpty } from 'lodash'; import { withProductDataContext } from '@woocommerce/shared-hocs'; @@ -15,10 +16,6 @@ import { withProductDataContext } from '@woocommerce/shared-hocs'; * Internal dependencies */ import './style.scss'; -import { - useColorProps, - useTypographyProps, -} from '../../../../hooks/style-attributes'; /** * Product Tag List Block Component. diff --git a/assets/js/atomic/blocks/product-elements/title/block.tsx b/assets/js/atomic/blocks/product-elements/title/block.tsx index 7070803b976..2d1fdd107c1 100644 --- a/assets/js/atomic/blocks/product-elements/title/block.tsx +++ b/assets/js/atomic/blocks/product-elements/title/block.tsx @@ -11,17 +11,17 @@ import { isFeaturePluginBuild } from '@woocommerce/block-settings'; import { withProductDataContext } from '@woocommerce/shared-hocs'; import ProductName from '@woocommerce/base-components/product-name'; import { useStoreEvents } from '@woocommerce/base-context/hooks'; +import { + useSpacingProps, + useTypographyProps, + useColorProps, +} from '@woocommerce/base-hooks'; /** * Internal dependencies */ import './style.scss'; import { Attributes } from './types'; -import { - useSpacingProps, - useTypographyProps, - useColorProps, -} from '../../../../hooks/style-attributes'; type Props = Attributes & HTMLAttributes< HTMLDivElement >; diff --git a/assets/js/base/components/cart-checkout/shipping-calculator/index.tsx b/assets/js/base/components/cart-checkout/shipping-calculator/index.tsx index e159a9eec6b..63e7bc8a38d 100644 --- a/assets/js/base/components/cart-checkout/shipping-calculator/index.tsx +++ b/assets/js/base/components/cart-checkout/shipping-calculator/index.tsx @@ -21,7 +21,8 @@ const ShippingCalculator = ( { }, addressFields = [ 'country', 'state', 'city', 'postcode' ], }: ShippingCalculatorProps ): JSX.Element => { - const { shippingAddress, setShippingAddress } = useCustomerData(); + const { shippingAddress, setShippingAddress, setBillingAddress } = + useCustomerData(); return (
{ setShippingAddress( newAddress ); + setBillingAddress( newAddress ); onUpdate( newAddress ); } } /> diff --git a/assets/js/base/components/cart-checkout/shipping-rates-control/index.tsx b/assets/js/base/components/cart-checkout/shipping-rates-control/index.tsx index 405f7b218f3..eea684b19ff 100644 --- a/assets/js/base/components/cart-checkout/shipping-rates-control/index.tsx +++ b/assets/js/base/components/cart-checkout/shipping-rates-control/index.tsx @@ -63,8 +63,8 @@ const Packages = ( { key={ packageId } packageId={ packageId } packageData={ packageData } - collapsible={ collapsible } - collapse={ collapse } + collapsible={ !! collapsible } + collapse={ !! collapse } showItems={ showItems || packageData?.shipping_rates?.length > 1 } @@ -167,6 +167,7 @@ const ShippingRatesControl = ( { ShippingRatesControlPackage, }, context, + shippingRates, }; const { isEditor } = useEditorContext(); @@ -192,6 +193,7 @@ const ShippingRatesControl = ( { /> 1 } packages={ shippingRates } noResultsMessage={ noResultsMessage } renderOption={ renderOption } diff --git a/assets/js/base/components/dropdown-selector/index.js b/assets/js/base/components/dropdown-selector/index.js deleted file mode 100644 index 1a6080106bf..00000000000 --- a/assets/js/base/components/dropdown-selector/index.js +++ /dev/null @@ -1,231 +0,0 @@ -/** - * External dependencies - */ -import PropTypes from 'prop-types'; -import { useCallback, useRef } from '@wordpress/element'; -import classNames from 'classnames'; -import Downshift from 'downshift'; -import { __, sprintf } from '@wordpress/i18n'; - -/** - * Internal dependencies - */ -import DropdownSelectorInput from './input'; -import DropdownSelectorInputWrapper from './input-wrapper'; -import DropdownSelectorMenu from './menu'; -import DropdownSelectorSelectedChip from './selected-chip'; -import DropdownSelectorSelectedValue from './selected-value'; -import './style.scss'; - -/** - * Component used to show an input box with a dropdown with suggestions. - * - * @param {Object} props Incoming props for the component. - * @param {string} props.attributeLabel Label for the attributes. - * @param {string} props.className CSS class used. - * @param {import('react').CSSProperties} props.style CSS style object used. - * @param {Array} props.checked Which items are checked. - * @param {string} props.inputLabel Label used for the input. - * @param {boolean} props.isDisabled Whether the input is disabled or not. - * @param {boolean} props.isLoading Whether the input is loading. - * @param {boolean} props.multiple Whether multi-select is allowed. - * @param {function():any} props.onChange Function to be called when onChange event fires. - * @param {Array} props.options The option values to show in the select. - * @param {boolean} [props.isCaseSensitive=false] Whether the dropdown search should be case-sensitive. - */ -const DropdownSelector = ( { - attributeLabel = '', - className, - style = {}, - checked = [], - inputLabel = '', - isDisabled = false, - isLoading = false, - multiple = false, - onChange = () => {}, - options = [], - isCaseSensitive = false, -} ) => { - const inputRef = useRef( null ); - - const classes = classNames( - className, - 'wc-block-dropdown-selector', - 'wc-block-components-dropdown-selector', - { - 'is-disabled': isDisabled, - 'is-loading': isLoading, - } - ); - - /** - * State reducer for the downshift component. - * See: https://github.com/downshift-js/downshift#statereducer - */ - const stateReducer = useCallback( - ( state, changes ) => { - switch ( changes.type ) { - case Downshift.stateChangeTypes.keyDownEnter: - case Downshift.stateChangeTypes.clickItem: - return { - ...changes, - highlightedIndex: state.highlightedIndex, - isOpen: multiple, - inputValue: '', - }; - case Downshift.stateChangeTypes.blurInput: - case Downshift.stateChangeTypes.mouseUp: - return { - ...changes, - inputValue: state.inputValue, - }; - default: - return changes; - } - }, - [ multiple ] - ); - - return ( - - { ( { - getInputProps, - getItemProps, - getLabelProps, - getMenuProps, - highlightedIndex, - inputValue, - isOpen, - openMenu, - } ) => ( -
0, - 'is-open': isOpen, - } ) } - style={ style } - > - { /* eslint-disable-next-line jsx-a11y/label-has-for */ } - - inputRef.current.focus() } - > - { checked.map( ( value ) => { - const option = options.find( - ( o ) => o.value === value - ); - - if ( ! option ) { - return null; - } - - const onRemoveItem = ( val ) => { - onChange( val ); - inputRef.current.focus(); - }; - - return multiple ? ( - - ) : ( - inputRef.current.focus() } - onRemoveItem={ onRemoveItem } - option={ option } - /> - ); - } ) } - { - onChange( val ); - inputRef.current.focus(); - } } - placeholder={ - checked.length > 0 && multiple - ? null - : sprintf( - /* translators: %s attribute name. */ - __( - 'Any %s', - 'woo-gutenberg-products-block' - ), - attributeLabel - ) - } - tabIndex={ - // When it's a single selector and there is one element selected, - // we make the input non-focusable with the keyboard because it's - // visually hidden. The input is still rendered, though, because it - // must be possible to focus it when pressing the select value chip. - ! multiple && checked.length > 0 ? '-1' : '0' - } - value={ inputValue } - /> - - { isOpen && ! isDisabled && ( - { - let optionName = option.name; - let nameQuery = inputValue?.trim(); - if ( ! isCaseSensitive ) { - optionName = optionName.toLowerCase(); - nameQuery = nameQuery?.toLowerCase(); - } - return ( - ! nameQuery || - optionName.includes( nameQuery ) - ); - } ) } - /> - ) } -
- ) } -
- ); -}; - -DropdownSelector.propTypes = { - attributeLabel: PropTypes.string, - checked: PropTypes.array, - className: PropTypes.string, - inputLabel: PropTypes.string, - isDisabled: PropTypes.bool, - isLoading: PropTypes.bool, - limit: PropTypes.number, - onChange: PropTypes.func, - options: PropTypes.arrayOf( - PropTypes.shape( { - label: PropTypes.node.isRequired, - value: PropTypes.string.isRequired, - } ) - ), - isCaseSensitive: PropTypes.bool, -}; - -export default DropdownSelector; diff --git a/assets/js/base/components/dropdown-selector/input-wrapper.js b/assets/js/base/components/dropdown-selector/input-wrapper.js deleted file mode 100644 index 4391c1e9bb9..00000000000 --- a/assets/js/base/components/dropdown-selector/input-wrapper.js +++ /dev/null @@ -1,13 +0,0 @@ -const DropdownSelectorInputWrapper = ( { children, onClick } ) => { - return ( - /* eslint-disable-next-line jsx-a11y/click-events-have-key-events, jsx-a11y/no-static-element-interactions */ -
- { children } -
- ); -}; - -export default DropdownSelectorInputWrapper; diff --git a/assets/js/base/components/dropdown-selector/input.js b/assets/js/base/components/dropdown-selector/input.js deleted file mode 100644 index abb3cd73101..00000000000 --- a/assets/js/base/components/dropdown-selector/input.js +++ /dev/null @@ -1,36 +0,0 @@ -const DropdownSelectorInput = ( { - checked, - getInputProps, - inputRef, - isDisabled, - onFocus, - onRemoveItem, - placeholder, - tabIndex, - value, -} ) => { - return ( - 0 - ) { - onRemoveItem( checked[ checked.length - 1 ] ); - } - }, - placeholder, - tabIndex, - } ) } - /> - ); -}; - -export default DropdownSelectorInput; diff --git a/assets/js/base/components/dropdown-selector/menu.js b/assets/js/base/components/dropdown-selector/menu.js deleted file mode 100644 index 43c4c25be39..00000000000 --- a/assets/js/base/components/dropdown-selector/menu.js +++ /dev/null @@ -1,59 +0,0 @@ -/** - * External dependencies - */ -import { __, sprintf } from '@wordpress/i18n'; -import classNames from 'classnames'; - -const DropdownSelectorMenu = ( { - checked, - getItemProps, - getMenuProps, - highlightedIndex, - options, -} ) => { - return ( -
    - { options.map( ( option, index ) => { - const selected = checked.includes( option.value ); - return ( - // eslint-disable-next-line react/jsx-key -
  • - { option.label } -
  • - ); - } ) } -
- ); -}; - -export default DropdownSelectorMenu; diff --git a/assets/js/base/components/dropdown-selector/selected-chip.js b/assets/js/base/components/dropdown-selector/selected-chip.js deleted file mode 100644 index 3510451292f..00000000000 --- a/assets/js/base/components/dropdown-selector/selected-chip.js +++ /dev/null @@ -1,26 +0,0 @@ -/** - * External dependencies - */ -import { __, sprintf } from '@wordpress/i18n'; -import { RemovableChip } from '@woocommerce/base-components/chip'; - -const DropdownSelectorSelectedChip = ( { onRemoveItem, option } ) => { - return ( - { - onRemoveItem( option.value ); - } } - ariaLabel={ sprintf( - /* translators: %s is referring to the filter option being removed. */ - __( 'Remove %s filter', 'woo-gutenberg-products-block' ), - option.name - ) } - text={ option.label } - radius="large" - /> - ); -}; - -export default DropdownSelectorSelectedChip; diff --git a/assets/js/base/components/dropdown-selector/selected-value.js b/assets/js/base/components/dropdown-selector/selected-value.js deleted file mode 100644 index 35c34146192..00000000000 --- a/assets/js/base/components/dropdown-selector/selected-value.js +++ /dev/null @@ -1,57 +0,0 @@ -/** - * External dependencies - */ -import { __, sprintf } from '@wordpress/i18n'; -import { useEffect, useRef } from '@wordpress/element'; -import { Icon, closeSmall } from '@wordpress/icons'; - -const DropdownSelectorSelectedValue = ( { onClick, onRemoveItem, option } ) => { - const labelRef = useRef( null ); - - useEffect( () => { - labelRef.current.focus(); - }, [ labelRef ] ); - - return ( -
- - -
- ); -}; - -export default DropdownSelectorSelectedValue; diff --git a/assets/js/base/components/dropdown-selector/style.scss b/assets/js/base/components/dropdown-selector/style.scss deleted file mode 100644 index 8e314e348f6..00000000000 --- a/assets/js/base/components/dropdown-selector/style.scss +++ /dev/null @@ -1,176 +0,0 @@ -// 18px is the minimum input field line-height and 14px is the font-size of -// the drop down selector elements. - -$dropdown-selector-line-height: math.div(18, 14); - -.wc-block-components-dropdown-selector { - max-width: 300px; - position: relative; - width: 100%; -} - -.wc-block-components-dropdown-selector__input-wrapper { - background: #fff; - border: 1px solid $input-border-gray; - color: $input-text-active; - align-items: center; - border-radius: 4px; - cursor: text; - display: flex; - flex-wrap: wrap; - padding: 2px $gap-smaller; - - .is-disabled & { - background-color: $gray-200; - } - - .is-multiple.has-checked > & { - padding: 2px $gap-smallest; - } - - .is-open > & { - border-radius: 4px 4px 0 0; - } -} - -.wc-block-components-dropdown-selector__input { - @include font-size(small); - line-height: $dropdown-selector-line-height; - margin: em($gap-small * 0.25) 0; - min-width: 0; - padding: em($gap-smallest * 0.75) 0 em($gap-smallest * 0.75); - - .is-single & { - width: 100%; - - &:hover, - &:focus, - &:active { - outline: 0; - } - } - - .is-single.has-checked.is-open & { - margin-bottom: 1.5px; - margin-top: 1.5px; - } - - .is-single.has-checked:not(.is-open) & { - @include visually-hidden(); - // Fixes an issue in Firefox that `flex: wrap` in the container was making - // this element to still occupy one line. - position: absolute; - } - - .is-multiple & { - flex: 1; - min-width: 0; - } -} - -// Visually hide the input -.is-single .wc-block-components-dropdown-selector__input:first-child, -.is-multiple .wc-block-components-dropdown-selector__input { - background: transparent; - border: 0; - - &:hover, - &:focus, - &:active { - outline: 0; - } -} - -.wc-block-components-dropdown-selector { - // Reset -
); }; diff --git a/assets/js/blocks/mini-cart/index.tsx b/assets/js/blocks/mini-cart/index.tsx index 3c22edff442..61bc0f7d96c 100644 --- a/assets/js/blocks/mini-cart/index.tsx +++ b/assets/js/blocks/mini-cart/index.tsx @@ -2,7 +2,7 @@ * External dependencies */ import { __ } from '@wordpress/i18n'; -import { cart } from '@woocommerce/icons'; +import { miniCartAlt } from '@woocommerce/icons'; import { Icon } from '@wordpress/icons'; import { registerBlockType } from '@wordpress/blocks'; import type { BlockConfiguration } from '@wordpress/blocks'; @@ -19,7 +19,7 @@ const settings: BlockConfiguration = { icon: { src: ( ), @@ -38,6 +38,8 @@ const settings: BlockConfiguration = { fontSize: true, ...( isFeaturePluginBuild() && { __experimentalFontFamily: true, + __experimentalFontWeight: true, + __experimentalSkipSerialization: true, } ), }, }, @@ -56,6 +58,10 @@ const settings: BlockConfiguration = { type: 'string', default: 'none', }, + hasHiddenPrice: { + type: 'boolean', + default: false, + }, }, edit, diff --git a/assets/js/blocks/mini-cart/test/block.js b/assets/js/blocks/mini-cart/test/block.js index 08271a85b6e..54ff6096e88 100644 --- a/assets/js/blocks/mini-cart/test/block.js +++ b/assets/js/blocks/mini-cart/test/block.js @@ -5,6 +5,7 @@ import { act, render, screen, + queryByText, waitFor, waitForElementToBeRemoved, } from '@testing-library/react'; @@ -124,4 +125,26 @@ describe( 'Testing Mini Cart', () => { ).toBeInTheDocument() ); } ); + + it( 'renders cart price if "Hide Cart Price" setting is not enabled', async () => { + mockEmptyCart(); + render( ); + await waitFor( () => expect( fetchMock ).toHaveBeenCalled() ); + + await waitFor( () => + expect( screen.getByText( '$0.00' ) ).toBeInTheDocument() + ); + } ); + + it( 'does not render cart price if "Hide Cart Price" setting is enabled', async () => { + mockEmptyCart(); + const { container } = render( + + ); + await waitFor( () => expect( fetchMock ).toHaveBeenCalled() ); + + await waitFor( () => + expect( queryByText( container, '$0.00' ) ).not.toBeInTheDocument() + ); + } ); } ); diff --git a/assets/js/editor-components/compatibility-notices/cart-checkout-compatibility-notice.tsx b/assets/js/editor-components/compatibility-notices/cart-checkout-compatibility-notice.tsx index 69a0ffde2d7..9c71e98fbe3 100644 --- a/assets/js/editor-components/compatibility-notices/cart-checkout-compatibility-notice.tsx +++ b/assets/js/editor-components/compatibility-notices/cart-checkout-compatibility-notice.tsx @@ -14,7 +14,7 @@ import { useCompatibilityNotice } from './use-compatibility-notice'; import WooImage from './woo-image'; interface CartCheckoutCompatibilityNoticeProps { - blockName: 'cart' | 'checkout' | 'mini-cart'; + blockName: 'cart' | 'checkout'; } export function CartCheckoutCompatibilityNotice( { diff --git a/assets/js/hooks/style-attributes.ts b/assets/js/hooks/style-attributes.ts deleted file mode 100644 index 7abc5c956d8..00000000000 --- a/assets/js/hooks/style-attributes.ts +++ /dev/null @@ -1,101 +0,0 @@ -/* eslint-disable @wordpress/no-unsafe-wp-apis */ -/** - * External dependencies - */ -import { - __experimentalUseColorProps, - __experimentalGetSpacingClassesAndStyles, - __experimentalUseBorderProps, -} from '@wordpress/block-editor'; - -/** - * Internal dependencies - */ -import { isFeaturePluginBuild } from '../settings/blocks/feature-flags'; -import { isString, isObject } from '../types/type-guards'; -import { hasSpacingStyleSupport } from '../utils/global-style'; - -type WithClass = { - className: string; -}; - -type WithStyle = { - style: Record< string, unknown >; -}; - -const parseStyle = ( style: unknown ): Record< string, unknown > => { - if ( isString( style ) ) { - return JSON.parse( style ) || {}; - } - - if ( isObject( style ) ) { - return style; - } - - return {}; -}; - -export const useSpacingProps = ( attributes: unknown ): WithStyle => { - if ( ! isFeaturePluginBuild() || ! hasSpacingStyleSupport() ) { - return { - style: {}, - }; - } - const attributesObject = isObject( attributes ) ? attributes : {}; - const style = parseStyle( attributesObject.style ); - - return __experimentalGetSpacingClassesAndStyles( { - ...attributesObject, - style, - } ); -}; - -export const useTypographyProps = ( attributes: unknown ): WithStyle => { - const attributesObject = isObject( attributes ) ? attributes : {}; - const style = parseStyle( attributesObject.style ); - const typography = isObject( style.typography ) - ? ( style.typography as Record< string, unknown > ) - : {}; - - return { - style: { - fontSize: attributesObject.fontSize - ? `var(--wp--preset--font-size--${ attributesObject.fontSize })` - : typography.fontSize, - lineHeight: typography.lineHeight, - fontWeight: typography.fontWeight, - textTransform: typography.textTransform, - fontFamily: attributesObject.fontFamily, - }, - }; -}; - -export const useColorProps = ( attributes: unknown ): WithStyle & WithClass => { - if ( ! isFeaturePluginBuild() ) { - return { - className: '', - style: {}, - }; - } - - const attributesObject = isObject( attributes ) ? attributes : {}; - const style = parseStyle( attributesObject.style ); - - return __experimentalUseColorProps( { ...attributesObject, style } ); -}; - -export const useBorderProps = ( - attributes: unknown -): WithStyle & WithClass => { - if ( ! isFeaturePluginBuild() ) { - return { - className: '', - style: {}, - }; - } - - const attributesObject = isObject( attributes ) ? attributes : {}; - const style = parseStyle( attributesObject.style ); - - return __experimentalUseBorderProps( { ...attributesObject, style } ); -}; diff --git a/assets/js/icons/index.js b/assets/js/icons/index.js index 112f573f5d7..1dcedb31a23 100644 --- a/assets/js/icons/index.js +++ b/assets/js/icons/index.js @@ -11,3 +11,4 @@ export { default as toggle } from './library/toggle'; export { default as totals } from './library/totals'; export { default as woo } from './library/woo'; export { default as miniCart } from './library/mini-cart'; +export { default as miniCartAlt } from './library/mini-cart-alt'; diff --git a/assets/js/icons/library/mini-cart-alt.tsx b/assets/js/icons/library/mini-cart-alt.tsx new file mode 100644 index 00000000000..2e57b357f0d --- /dev/null +++ b/assets/js/icons/library/mini-cart-alt.tsx @@ -0,0 +1,39 @@ +/** + * External dependencies + */ +import { SVG } from '@wordpress/primitives'; + +const miniCartAlt = ( + + + + + + + + + + + + + +); + +export default miniCartAlt; diff --git a/bin/add-doc-footer.sh b/bin/add-doc-footer.sh index 5266bfe2e60..43d8d7ee558 100755 --- a/bin/add-doc-footer.sh +++ b/bin/add-doc-footer.sh @@ -6,7 +6,7 @@ function update_footer { [We'\''re hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20'$1') +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20'$1') ' diff --git a/bin/hook-docs/data/actions.json b/bin/hook-docs/data/actions.json index 8dd7578c4a6..6ec1005eb2e 100644 --- a/bin/hook-docs/data/actions.json +++ b/bin/hook-docs/data/actions.json @@ -1,718 +1,805 @@ { - "$schema": "https://raw.githubusercontent.com/johnbillion/wp-hooks-generator/0.7.3/schema.json", - "hooks": [ - { - "name": "woocommerce_add_to_cart", - "file": "StoreApi/Utilities/CartController.php", - "type": "action", - "doc": { - "description": "Fires when an item is added to the cart.", - "long_description": "This hook fires when an item is added to the cart. This is triggered from the Store API in this context, but WooCommerce core add to cart events trigger the same hook.", - "tags": [ - { - "name": "internal", - "content": "Matches action name in WooCommerce core." - }, - { - "name": "param", - "content": "ID of the item in the cart.", - "types": [ "string" ], - "variable": "$cart_id" - }, - { - "name": "param", - "content": "ID of the product added to the cart.", - "types": [ "integer" ], - "variable": "$product_id" - }, - { - "name": "param", - "content": "Quantity of the item added to the cart.", - "types": [ "integer" ], - "variable": "$request_quantity" - }, - { - "name": "param", - "content": "Variation ID of the product added to the cart.", - "types": [ "integer" ], - "variable": "$variation_id" - }, - { - "name": "param", - "content": "Array of variation data.", - "types": [ "array" ], - "variable": "$variation" - }, - { - "name": "param", - "content": "Array of other cart item data.", - "types": [ "array" ], - "variable": "$cart_item_data" - } - ], - "long_description_html": "

This hook fires when an item is added to the cart. This is triggered from the Store API in this context, but WooCommerce core add to cart events trigger the same hook.

" - }, - "args": 6 - }, - { - "name": "woocommerce_after_main_content", - "file": "BlockTypes/ClassicTemplate.php", - "type": "action", - "doc": { - "description": "Hook: woocommerce_after_main_content", - "long_description": "Called after rendering the main content for a product.", - "tags": [ - { - "name": "see", - "content": "Outputs closing DIV for the content (priority 10)", - "refers": "woocommerce_output_content_wrapper_end()" - } - ], - "long_description_html": "

Called after rendering the main content for a product.

" - }, - "args": 0 - }, - { - "name": "woocommerce_after_main_content", - "file": "BlockTypes/ClassicTemplate.php", - "type": "action", - "doc": { - "description": "Hook: woocommerce_after_main_content", - "long_description": "Called after rendering the main content for a product.", - "tags": [ - { - "name": "see", - "content": "Outputs closing DIV for the content (priority 10)", - "refers": "woocommerce_output_content_wrapper_end()" - } - ], - "long_description_html": "

Called after rendering the main content for a product.

" - }, - "args": 0 - }, - { - "name": "woocommerce_after_shop_loop", - "file": "BlockTypes/ClassicTemplate.php", - "type": "action", - "doc": { - "description": "Hook: woocommerce_after_shop_loop.", - "long_description": "", - "tags": [ - { - "name": "see", - "content": "Renders pagination (priority 10)", - "refers": "woocommerce_pagination()" - } - ], - "long_description_html": "" - }, - "args": 0 - }, - { - "name": "woocommerce_applied_coupon", - "file": "StoreApi/Utilities/CartController.php", - "type": "action", - "doc": { - "description": "Fires after a coupon has been applied to the cart.", - "long_description": "", - "tags": [ - { - "name": "internal", - "content": "Matches action name in WooCommerce core." - }, - { - "name": "param", - "content": "The coupon code that was applied.", - "types": [ "string" ], - "variable": "$coupon_code" - } - ], - "long_description_html": "" - }, - "args": 1 - }, - { - "name": "woocommerce_archive_description", - "file": "BlockTypes/ClassicTemplate.php", - "type": "action", - "doc": { - "description": "Hook: woocommerce_archive_description.", - "long_description": "", - "tags": [ - { - "name": "see", - "content": "Renders the taxonomy archive description (priority 10)", - "refers": "woocommerce_taxonomy_archive_description()" - }, - { - "name": "see", - "content": "Renders the product archive description (priority 10)", - "refers": "woocommerce_product_archive_description()" - } - ], - "long_description_html": "" - }, - "args": 0 - }, - { - "name": "woocommerce_before_main_content", - "file": "BlockTypes/ClassicTemplate.php", - "type": "action", - "doc": { - "description": "Hook: woocommerce_before_main_content", - "long_description": "Called before rendering the main content for a product.", - "tags": [ - { - "name": "see", - "content": "Outputs opening DIV for the content (priority 10)", - "refers": "woocommerce_output_content_wrapper()" - }, - { - "name": "see", - "content": "Outputs breadcrumb trail to the current product (priority 20)", - "refers": "woocommerce_breadcrumb()" - }, - { - "name": "see", - "content": "Outputs schema markup (priority 30)", - "refers": "WC_Structured_Data::generate_website_data()" - } - ], - "long_description_html": "

Called before rendering the main content for a product.

" - }, - "args": 0 - }, - { - "name": "woocommerce_before_main_content", - "file": "BlockTypes/ClassicTemplate.php", - "type": "action", - "doc": { - "description": "Hook: woocommerce_before_main_content", - "long_description": "Called before rendering the main content for a product.", - "tags": [ - { - "name": "see", - "content": "Outputs opening DIV for the content (priority 10)", - "refers": "woocommerce_output_content_wrapper()" - }, - { - "name": "see", - "content": "Outputs breadcrumb trail to the current product (priority 20)", - "refers": "woocommerce_breadcrumb()" - }, - { - "name": "see", - "content": "Outputs schema markup (priority 30)", - "refers": "WC_Structured_Data::generate_website_data()" - } - ], - "long_description_html": "

Called before rendering the main content for a product.

" - }, - "args": 0 - }, - { - "name": "woocommerce_before_shop_loop", - "file": "BlockTypes/ClassicTemplate.php", - "type": "action", - "doc": { - "description": "Hook: woocommerce_before_shop_loop.", - "long_description": "", - "tags": [ - { - "name": "see", - "content": "Render error notices (priority 10)", - "refers": "woocommerce_output_all_notices()" - }, - { - "name": "see", - "content": "Show number of results found (priority 20)", - "refers": "woocommerce_result_count()" - }, - { - "name": "see", - "content": "Show form to control sort order (priority 30)", - "refers": "woocommerce_catalog_ordering()" - } - ], - "long_description_html": "" - }, - "args": 0 - }, - { - "name": "woocommerce_blocks_cart_enqueue_data", - "file": "BlockTypes/MiniCart.php", - "type": "action", - "doc": { - "description": "Fires after cart block data is registered.", - "long_description": "", - "tags": [], - "long_description_html": "" - }, - "args": 0 - }, - { - "name": "woocommerce_blocks_cart_enqueue_data", - "file": "BlockTypes/Cart.php", - "type": "action", - "doc": { - "description": "Fires after cart block data is registered.", - "long_description": "", - "tags": [], - "long_description_html": "" - }, - "args": 0 - }, - { - "name": "woocommerce_blocks_checkout_enqueue_data", - "file": "BlockTypes/Checkout.php", - "type": "action", - "doc": { - "description": "Fires after checkout block data is registered.", - "long_description": "", - "tags": [], - "long_description_html": "" - }, - "args": 0 - }, - { - "name": "woocommerce_blocks_enqueue_cart_block_scripts_after", - "file": "BlockTypes/Cart.php", - "type": "action", - "doc": { - "description": "Fires after cart block scripts are enqueued.", - "long_description": "", - "tags": [], - "long_description_html": "" - }, - "args": 0 - }, - { - "name": "woocommerce_blocks_enqueue_cart_block_scripts_before", - "file": "BlockTypes/Cart.php", - "type": "action", - "doc": { - "description": "Fires before cart block scripts are enqueued.", - "long_description": "", - "tags": [], - "long_description_html": "" - }, - "args": 0 - }, - { - "name": "woocommerce_blocks_enqueue_checkout_block_scripts_after", - "file": "BlockTypes/Checkout.php", - "type": "action", - "doc": { - "description": "Fires after checkout block scripts are enqueued.", - "long_description": "", - "tags": [], - "long_description_html": "" - }, - "args": 0 - }, - { - "name": "woocommerce_blocks_enqueue_checkout_block_scripts_before", - "file": "BlockTypes/Checkout.php", - "type": "action", - "doc": { - "description": "Fires before checkout block scripts are enqueued.", - "long_description": "", - "tags": [], - "long_description_html": "" - }, - "args": 0 - }, - { - "name": "woocommerce_blocks_{$this->registry_identifier}_registration", - "file": "Integrations/IntegrationRegistry.php", - "type": "action", - "doc": { - "description": "Fires when the IntegrationRegistry is initialized.", - "long_description": "Runs before integrations are initialized allowing new integration to be registered for use. This should be used as the primary hook for integrations to include their scripts, styles, and other code extending the blocks.", - "tags": [ - { - "name": "param", - "content": "Instance of the IntegrationRegistry class which exposes the IntegrationRegistry::register() method.", - "types": [ - "\\Automattic\\WooCommerce\\Blocks\\Integrations\\IntegrationRegistry" - ], - "variable": "$this" - } - ], - "long_description_html": "

Runs before integrations are initialized allowing new integration to be registered for use. This should be used as the primary hook for integrations to include their scripts, styles, and other code extending the blocks.

" - }, - "args": 1 - }, - { - "name": "woocommerce_check_cart_items", - "file": "StoreApi/Utilities/CartController.php", - "type": "action", - "doc": { - "description": "Fires when cart items are being validated.", - "long_description": "Allow 3rd parties to validate cart items. This is a legacy hook from Woo core. This filter will be deprecated because it encourages usage of wc_add_notice. For the API we need to capture notices and convert to wp errors instead.", - "tags": [ - { - "name": "deprecated", - "content": "" - }, - { - "name": "internal", - "content": "Matches action name in WooCommerce core." - } - ], - "long_description_html": "

Allow 3rd parties to validate cart items. This is a legacy hook from Woo core. This filter will be deprecated because it encourages usage of wc_add_notice. For the API we need to capture notices and convert to wp errors instead.

" - }, - "args": 0 - }, - { - "name": "woocommerce_created_customer", - "file": "StoreApi/Routes/V1/Checkout.php", - "type": "action", - "doc": { - "description": "Fires after a customer account has been registered.", - "long_description": "This hook fires after customer accounts are created and passes the customer data.", - "tags": [ - { - "name": "internal", - "content": "Matches filter name in WooCommerce core." - }, - { - "name": "param", - "content": "New customer (user) ID.", - "types": [ "integer" ], - "variable": "$customer_id" - }, - { - "name": "param", - "content": "Array of customer (user) data.", - "types": [ "array" ], - "variable": "$new_customer_data" - }, - { - "name": "param", - "content": "The generated password for the account.", - "types": [ "string" ], - "variable": "$password_generated" - } - ], - "long_description_html": "

This hook fires after customer accounts are created and passes the customer data.

" - }, - "args": 3 - }, - { - "name": "woocommerce_no_products_found", - "file": "BlockTypes/ClassicTemplate.php", - "type": "action", - "doc": { - "description": "Hook: woocommerce_no_products_found.", - "long_description": "", - "tags": [ - { - "name": "see", - "content": "Default no products found content (priority 10)", - "refers": "wc_no_products_found()" - } - ], - "long_description_html": "" - }, - "args": 0 - }, - { - "name": "woocommerce_register_post", - "file": "StoreApi/Routes/V1/Checkout.php", - "type": "action", - "doc": { - "description": "Fires before a customer account is registered.", - "long_description": "This hook fires before customer accounts are created and passes the form data (username, email) and an array of errors.\n This could be used to add extra validation logic and append errors to the array.", - "tags": [ - { - "name": "internal", - "content": "Matches filter name in WooCommerce core." - }, - { - "name": "param", - "content": "Customer username.", - "types": [ "string" ], - "variable": "$username" - }, - { - "name": "param", - "content": "Customer email address.", - "types": [ "string" ], - "variable": "$user_email" - }, - { - "name": "param", - "content": "Error object.", - "types": [ "\\WP_Error" ], - "variable": "$errors" - } - ], - "long_description_html": "

This hook fires before customer accounts are created and passes the form data (username, email) and an array of errors.

This could be used to add extra validation logic and append errors to the array.

" - }, - "args": 3 - }, - { - "name": "woocommerce_rest_checkout_process_payment_with_context", - "file": "StoreApi/Routes/V1/Checkout.php", - "type": "action_reference", - "doc": { - "description": "Process payment with context.", - "long_description": "", - "tags": [ - { - "name": "hook", - "content": "woocommerce_rest_checkout_process_payment_with_context" - }, - { - "name": "throws", - "content": "If there is an error taking payment, an \\Exception object can be thrown with an error message.", - "types": [ "\\Exception" ] - }, - { - "name": "param", - "content": "Holds context for the payment, including order ID and payment method.", - "types": [ - "\\Automattic\\WooCommerce\\StoreApi\\Payments\\PaymentContext" - ], - "variable": "$context" - }, - { - "name": "param", - "content": "Result object for the transaction.", - "types": [ - "\\Automattic\\WooCommerce\\StoreApi\\Payments\\PaymentResult" - ], - "variable": "$payment_result" - } - ], - "long_description_html": "" - }, - "args": 1 - }, - { - "name": "woocommerce_shop_loop", - "file": "BlockTypes/ClassicTemplate.php", - "type": "action", - "doc": { - "description": "Hook: woocommerce_shop_loop.", - "long_description": "", - "tags": [], - "long_description_html": "" - }, - "args": 0 - }, - { - "name": "woocommerce_store_api_cart_errors", - "file": "StoreApi/Utilities/CartController.php", - "type": "action", - "doc": { - "description": "Fires an action to validate the cart.", - "long_description": "Functions hooking into this should add custom errors using the provided WP_Error instance.", - "tags": [ - { - "name": "example", - "content": "docs/examples/validate-cart.md" - }, - { - "name": "param", - "content": "WP_Error object.", - "types": [ "\\WP_Error" ], - "variable": "$errors" - }, - { - "name": "param", - "content": "Cart object.", - "types": [ "\\WC_Cart" ], - "variable": "$cart" - } - ], - "long_description_html": "

Functions hooking into this should add custom errors using the provided WP_Error instance.

" - }, - "args": 2 - }, - { - "name": "woocommerce_store_api_cart_update_customer_from_request", - "file": "StoreApi/Routes/V1/CartUpdateCustomer.php", - "type": "action", - "doc": { - "description": "Fires when the Checkout Block/Store API updates a customer from the API request data.", - "long_description": "", - "tags": [ - { - "name": "param", - "content": "Customer object.", - "types": [ "\\WC_Customer" ], - "variable": "$customer" - }, - { - "name": "param", - "content": "Full details about the request.", - "types": [ "\\WP_REST_Request" ], - "variable": "$request" - } - ], - "long_description_html": "" - }, - "args": 2 - }, - { - "name": "woocommerce_store_api_cart_update_order_from_request", - "file": "StoreApi/Routes/V1/AbstractCartRoute.php", - "type": "action", - "doc": { - "description": "Fires when the order is synced with cart data from a cart route.", - "long_description": "", - "tags": [ - { - "name": "param", - "content": "Order object.", - "types": [ "\\WC_Order" ], - "variable": "$draft_order" - }, - { - "name": "param", - "content": "Customer object.", - "types": [ "\\WC_Customer" ], - "variable": "$customer" - }, - { - "name": "param", - "content": "Full details about the request.", - "types": [ "\\WP_REST_Request" ], - "variable": "$request" - } - ], - "long_description_html": "" - }, - "args": 2 - }, - { - "name": "woocommerce_store_api_checkout_order_processed", - "file": "StoreApi/Routes/V1/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:

  • To keep the interface focused (only pass $order, not passing request data).
  • This also explicitly indicates these orders are from checkout block/StoreAPI.
" - }, - "args": 1 - }, - { - "name": "woocommerce_store_api_checkout_update_order_from_request", - "file": "StoreApi/Routes/V1/Checkout.php", - "type": "action", - "doc": { - "description": "Fires when the Checkout Block/Store API updates an order's from the API request data.", - "long_description": "This hook gives extensions the chance to update orders based on the data in the request. This can be used in conjunction with the ExtendSchema class to post custom data and then process it.", - "tags": [ - { - "name": "param", - "content": "Order object.", - "types": [ "\\WC_Order" ], - "variable": "$order" - }, - { - "name": "param", - "content": "Full details about the request.", - "types": [ "\\WP_REST_Request" ], - "variable": "$request" - } - ], - "long_description_html": "

This hook gives extensions the chance to update orders based on the data in the request. This can be used in conjunction with the ExtendSchema class to post custom data and then process it.

" - }, - "args": 2 - }, - { - "name": "woocommerce_store_api_checkout_update_order_meta", - "file": "StoreApi/Routes/V1/Checkout.php", - "type": "action", - "doc": { - "description": "Fires when the Checkout Block/Store API updates an order's meta data.", - "long_description": "This hook gives extensions the chance to add or update meta data on the $order. Throwing an exception from a callback attached to this action will make the Checkout Block render in a warning state, effectively preventing checkout.\n This is similar to existing core hook woocommerce_checkout_update_order_meta. 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/3686" - }, - { - "name": "param", - "content": "Order object.", - "types": [ "\\WC_Order" ], - "variable": "$order" - } - ], - "long_description_html": "

This hook gives extensions the chance to add or update meta data on the $order. Throwing an exception from a callback attached to this action will make the Checkout Block render in a warning state, effectively preventing checkout.

This is similar to existing core hook woocommerce_checkout_update_order_meta. 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.
" - }, - "args": 1 - }, - { - "name": "woocommerce_store_api_validate_add_to_cart", - "file": "StoreApi/Utilities/CartController.php", - "type": "action", - "doc": { - "description": "Fires during validation when adding an item to the cart via the Store API.", - "long_description": "Fire action to validate add to cart. Functions hooking into this should throw an \\Exception to prevent add to cart from happening.", - "tags": [ - { - "name": "param", - "content": "Product object being added to the cart.", - "types": [ "\\WC_Product" ], - "variable": "$product" - }, - { - "name": "param", - "content": "Add to cart request params including id, quantity, and variation attributes.", - "types": [ "array" ], - "variable": "$request" - } - ], - "long_description_html": "

Fire action to validate add to cart. Functions hooking into this should throw an \\Exception to prevent add to cart from happening.

" - }, - "args": 2 - }, - { - "name": "woocommerce_store_api_validate_cart_item", - "file": "StoreApi/Utilities/CartController.php", - "type": "action", - "doc": { - "description": "Fire action to validate add to cart. Functions hooking into this should throw an \\Exception to prevent add to cart from occurring.", - "long_description": "", - "tags": [ - { - "name": "param", - "content": "Product object being added to the cart.", - "types": [ "\\WC_Product" ], - "variable": "$product" - }, - { - "name": "param", - "content": "Cart item array.", - "types": [ "array" ], - "variable": "$cart_item" - } - ], - "long_description_html": "" - }, - "args": 2 - } - ] -} + "$schema": "https://raw.githubusercontent.com/johnbillion/wp-hooks-generator/0.7.0/schema.json", + "hooks": [ + { + "name": "woocommerce_add_to_cart", + "file": "StoreApi/Utilities/CartController.php", + "type": "action", + "doc": { + "description": "Fires when an item is added to the cart.", + "long_description": "This hook fires when an item is added to the cart. This is triggered from the Store API in this context, but WooCommerce core add to cart events trigger the same hook.", + "tags": [ + { + "name": "internal", + "content": "Matches action name in WooCommerce core." + }, + { + "name": "param", + "content": "ID of the item in the cart.", + "types": [ + "string" + ], + "variable": "$cart_id" + }, + { + "name": "param", + "content": "ID of the product added to the cart.", + "types": [ + "integer" + ], + "variable": "$product_id" + }, + { + "name": "param", + "content": "Quantity of the item added to the cart.", + "types": [ + "integer" + ], + "variable": "$request_quantity" + }, + { + "name": "param", + "content": "Variation ID of the product added to the cart.", + "types": [ + "integer" + ], + "variable": "$variation_id" + }, + { + "name": "param", + "content": "Array of variation data.", + "types": [ + "array" + ], + "variable": "$variation" + }, + { + "name": "param", + "content": "Array of other cart item data.", + "types": [ + "array" + ], + "variable": "$cart_item_data" + } + ], + "long_description_html": "

This hook fires when an item is added to the cart. This is triggered from the Store API in this context, but WooCommerce core add to cart events trigger the same hook.

" + }, + "args": 6 + }, + { + "name": "woocommerce_after_main_content", + "file": "BlockTypes/ClassicTemplate.php", + "type": "action", + "doc": { + "description": "Hook: woocommerce_after_main_content", + "long_description": "Called after rendering the main content for a product.", + "tags": [ + { + "name": "see", + "content": "Outputs closing DIV for the content (priority 10)", + "refers": "woocommerce_output_content_wrapper_end()" + } + ], + "long_description_html": "

Called after rendering the main content for a product.

" + }, + "args": 0 + }, + { + "name": "woocommerce_after_main_content", + "file": "BlockTypes/ClassicTemplate.php", + "type": "action", + "doc": { + "description": "Hook: woocommerce_after_main_content", + "long_description": "Called after rendering the main content for a product.", + "tags": [ + { + "name": "see", + "content": "Outputs closing DIV for the content (priority 10)", + "refers": "woocommerce_output_content_wrapper_end()" + } + ], + "long_description_html": "

Called after rendering the main content for a product.

" + }, + "args": 0 + }, + { + "name": "woocommerce_after_shop_loop", + "file": "BlockTypes/ClassicTemplate.php", + "type": "action", + "doc": { + "description": "Hook: woocommerce_after_shop_loop.", + "long_description": "", + "tags": [ + { + "name": "see", + "content": "Renders pagination (priority 10)", + "refers": "woocommerce_pagination()" + } + ], + "long_description_html": "" + }, + "args": 0 + }, + { + "name": "woocommerce_applied_coupon", + "file": "StoreApi/Utilities/CartController.php", + "type": "action", + "doc": { + "description": "Fires after a coupon has been applied to the cart.", + "long_description": "", + "tags": [ + { + "name": "internal", + "content": "Matches action name in WooCommerce core." + }, + { + "name": "param", + "content": "The coupon code that was applied.", + "types": [ + "string" + ], + "variable": "$coupon_code" + } + ], + "long_description_html": "" + }, + "args": 1 + }, + { + "name": "woocommerce_archive_description", + "file": "BlockTypes/ClassicTemplate.php", + "type": "action", + "doc": { + "description": "Hook: woocommerce_archive_description.", + "long_description": "", + "tags": [ + { + "name": "see", + "content": "Renders the taxonomy archive description (priority 10)", + "refers": "woocommerce_taxonomy_archive_description()" + }, + { + "name": "see", + "content": "Renders the product archive description (priority 10)", + "refers": "woocommerce_product_archive_description()" + } + ], + "long_description_html": "" + }, + "args": 0 + }, + { + "name": "woocommerce_before_main_content", + "file": "BlockTypes/ClassicTemplate.php", + "type": "action", + "doc": { + "description": "Hook: woocommerce_before_main_content", + "long_description": "Called before rendering the main content for a product.", + "tags": [ + { + "name": "see", + "content": "Outputs opening DIV for the content (priority 10)", + "refers": "woocommerce_output_content_wrapper()" + }, + { + "name": "see", + "content": "Outputs breadcrumb trail to the current product (priority 20)", + "refers": "woocommerce_breadcrumb()" + }, + { + "name": "see", + "content": "Outputs schema markup (priority 30)", + "refers": "WC_Structured_Data::generate_website_data()" + } + ], + "long_description_html": "

Called before rendering the main content for a product.

" + }, + "args": 0 + }, + { + "name": "woocommerce_before_main_content", + "file": "BlockTypes/ClassicTemplate.php", + "type": "action", + "doc": { + "description": "Hook: woocommerce_before_main_content", + "long_description": "Called before rendering the main content for a product.", + "tags": [ + { + "name": "see", + "content": "Outputs opening DIV for the content (priority 10)", + "refers": "woocommerce_output_content_wrapper()" + }, + { + "name": "see", + "content": "Outputs breadcrumb trail to the current product (priority 20)", + "refers": "woocommerce_breadcrumb()" + }, + { + "name": "see", + "content": "Outputs schema markup (priority 30)", + "refers": "WC_Structured_Data::generate_website_data()" + } + ], + "long_description_html": "

Called before rendering the main content for a product.

" + }, + "args": 0 + }, + { + "name": "woocommerce_before_shop_loop", + "file": "BlockTypes/ClassicTemplate.php", + "type": "action", + "doc": { + "description": "Hook: woocommerce_before_shop_loop.", + "long_description": "", + "tags": [ + { + "name": "see", + "content": "Render error notices (priority 10)", + "refers": "woocommerce_output_all_notices()" + }, + { + "name": "see", + "content": "Show number of results found (priority 20)", + "refers": "woocommerce_result_count()" + }, + { + "name": "see", + "content": "Show form to control sort order (priority 30)", + "refers": "woocommerce_catalog_ordering()" + } + ], + "long_description_html": "" + }, + "args": 0 + }, + { + "name": "woocommerce_blocks_cart_enqueue_data", + "file": "BlockTypes/Cart.php", + "type": "action", + "doc": { + "description": "Fires after cart block data is registered.", + "long_description": "", + "tags": [], + "long_description_html": "" + }, + "args": 0 + }, + { + "name": "woocommerce_blocks_cart_enqueue_data", + "file": "BlockTypes/MiniCart.php", + "type": "action", + "doc": { + "description": "Fires after cart block data is registered.", + "long_description": "", + "tags": [], + "long_description_html": "" + }, + "args": 0 + }, + { + "name": "woocommerce_blocks_checkout_enqueue_data", + "file": "BlockTypes/Checkout.php", + "type": "action", + "doc": { + "description": "Fires after checkout block data is registered.", + "long_description": "", + "tags": [], + "long_description_html": "" + }, + "args": 0 + }, + { + "name": "woocommerce_blocks_enqueue_cart_block_scripts_after", + "file": "BlockTypes/Cart.php", + "type": "action", + "doc": { + "description": "Fires after cart block scripts are enqueued.", + "long_description": "", + "tags": [], + "long_description_html": "" + }, + "args": 0 + }, + { + "name": "woocommerce_blocks_enqueue_cart_block_scripts_before", + "file": "BlockTypes/Cart.php", + "type": "action", + "doc": { + "description": "Fires before cart block scripts are enqueued.", + "long_description": "", + "tags": [], + "long_description_html": "" + }, + "args": 0 + }, + { + "name": "woocommerce_blocks_enqueue_checkout_block_scripts_after", + "file": "BlockTypes/Checkout.php", + "type": "action", + "doc": { + "description": "Fires after checkout block scripts are enqueued.", + "long_description": "", + "tags": [], + "long_description_html": "" + }, + "args": 0 + }, + { + "name": "woocommerce_blocks_enqueue_checkout_block_scripts_before", + "file": "BlockTypes/Checkout.php", + "type": "action", + "doc": { + "description": "Fires before checkout block scripts are enqueued.", + "long_description": "", + "tags": [], + "long_description_html": "" + }, + "args": 0 + }, + { + "name": "woocommerce_blocks_{$this->registry_identifier}_registration", + "file": "Integrations/IntegrationRegistry.php", + "type": "action", + "doc": { + "description": "Fires when the IntegrationRegistry is initialized.", + "long_description": "Runs before integrations are initialized allowing new integration to be registered for use. This should be used as the primary hook for integrations to include their scripts, styles, and other code extending the blocks.", + "tags": [ + { + "name": "param", + "content": "Instance of the IntegrationRegistry class which exposes the IntegrationRegistry::register() method.", + "types": [ + "\\Automattic\\WooCommerce\\Blocks\\Integrations\\IntegrationRegistry" + ], + "variable": "$this" + } + ], + "long_description_html": "

Runs before integrations are initialized allowing new integration to be registered for use. This should be used as the primary hook for integrations to include their scripts, styles, and other code extending the blocks.

" + }, + "args": 1 + }, + { + "name": "woocommerce_check_cart_items", + "file": "StoreApi/Utilities/CartController.php", + "type": "action", + "doc": { + "description": "Fires when cart items are being validated.", + "long_description": "Allow 3rd parties to validate cart items. This is a legacy hook from Woo core. This filter will be deprecated because it encourages usage of wc_add_notice. For the API we need to capture notices and convert to wp errors instead.", + "tags": [ + { + "name": "deprecated", + "content": "" + }, + { + "name": "internal", + "content": "Matches action name in WooCommerce core." + } + ], + "long_description_html": "

Allow 3rd parties to validate cart items. This is a legacy hook from Woo core. This filter will be deprecated because it encourages usage of wc_add_notice. For the API we need to capture notices and convert to wp errors instead.

" + }, + "args": 0 + }, + { + "name": "woocommerce_created_customer", + "file": "StoreApi/Routes/V1/Checkout.php", + "type": "action", + "doc": { + "description": "Fires after a customer account has been registered.", + "long_description": "This hook fires after customer accounts are created and passes the customer data.", + "tags": [ + { + "name": "internal", + "content": "Matches filter name in WooCommerce core." + }, + { + "name": "param", + "content": "New customer (user) ID.", + "types": [ + "integer" + ], + "variable": "$customer_id" + }, + { + "name": "param", + "content": "Array of customer (user) data.", + "types": [ + "array" + ], + "variable": "$new_customer_data" + }, + { + "name": "param", + "content": "The generated password for the account.", + "types": [ + "string" + ], + "variable": "$password_generated" + } + ], + "long_description_html": "

This hook fires after customer accounts are created and passes the customer data.

" + }, + "args": 3 + }, + { + "name": "woocommerce_no_products_found", + "file": "BlockTypes/ClassicTemplate.php", + "type": "action", + "doc": { + "description": "Hook: woocommerce_no_products_found.", + "long_description": "", + "tags": [ + { + "name": "see", + "content": "Default no products found content (priority 10)", + "refers": "wc_no_products_found()" + } + ], + "long_description_html": "" + }, + "args": 0 + }, + { + "name": "woocommerce_register_post", + "file": "StoreApi/Routes/V1/Checkout.php", + "type": "action", + "doc": { + "description": "Fires before a customer account is registered.", + "long_description": "This hook fires before customer accounts are created and passes the form data (username, email) and an array of errors.\n This could be used to add extra validation logic and append errors to the array.", + "tags": [ + { + "name": "internal", + "content": "Matches filter name in WooCommerce core." + }, + { + "name": "param", + "content": "Customer username.", + "types": [ + "string" + ], + "variable": "$username" + }, + { + "name": "param", + "content": "Customer email address.", + "types": [ + "string" + ], + "variable": "$user_email" + }, + { + "name": "param", + "content": "Error object.", + "types": [ + "\\WP_Error" + ], + "variable": "$errors" + } + ], + "long_description_html": "

This hook fires before customer accounts are created and passes the form data (username, email) and an array of errors.

This could be used to add extra validation logic and append errors to the array.

" + }, + "args": 3 + }, + { + "name": "woocommerce_rest_checkout_process_payment_with_context", + "file": "StoreApi/Routes/V1/Checkout.php", + "type": "action_reference", + "doc": { + "description": "Process payment with context.", + "long_description": "", + "tags": [ + { + "name": "hook", + "content": "woocommerce_rest_checkout_process_payment_with_context" + }, + { + "name": "throws", + "content": "If there is an error taking payment, an \\Exception object can be thrown with an error message.", + "types": [ + "\\Exception" + ] + }, + { + "name": "param", + "content": "Holds context for the payment, including order ID and payment method.", + "types": [ + "\\Automattic\\WooCommerce\\StoreApi\\Payments\\PaymentContext" + ], + "variable": "$context" + }, + { + "name": "param", + "content": "Result object for the transaction.", + "types": [ + "\\Automattic\\WooCommerce\\StoreApi\\Payments\\PaymentResult" + ], + "variable": "$payment_result" + } + ], + "long_description_html": "" + }, + "args": 1 + }, + { + "name": "woocommerce_shop_loop", + "file": "BlockTypes/ClassicTemplate.php", + "type": "action", + "doc": { + "description": "Hook: woocommerce_shop_loop.", + "long_description": "", + "tags": [], + "long_description_html": "" + }, + "args": 0 + }, + { + "name": "woocommerce_store_api_cart_errors", + "file": "StoreApi/Utilities/CartController.php", + "type": "action", + "doc": { + "description": "Fires an action to validate the cart.", + "long_description": "Functions hooking into this should add custom errors using the provided WP_Error instance.", + "tags": [ + { + "name": "example", + "content": "docs/examples/validate-cart.md" + }, + { + "name": "param", + "content": "WP_Error object.", + "types": [ + "\\WP_Error" + ], + "variable": "$errors" + }, + { + "name": "param", + "content": "Cart object.", + "types": [ + "\\WC_Cart" + ], + "variable": "$cart" + } + ], + "long_description_html": "

Functions hooking into this should add custom errors using the provided WP_Error instance.

" + }, + "args": 2 + }, + { + "name": "woocommerce_store_api_cart_update_customer_from_request", + "file": "StoreApi/Routes/V1/CartUpdateCustomer.php", + "type": "action", + "doc": { + "description": "Fires when the Checkout Block/Store API updates a customer from the API request data.", + "long_description": "", + "tags": [ + { + "name": "param", + "content": "Customer object.", + "types": [ + "\\WC_Customer" + ], + "variable": "$customer" + }, + { + "name": "param", + "content": "Full details about the request.", + "types": [ + "\\WP_REST_Request" + ], + "variable": "$request" + } + ], + "long_description_html": "" + }, + "args": 2 + }, + { + "name": "woocommerce_store_api_cart_update_order_from_request", + "file": "StoreApi/Routes/V1/AbstractCartRoute.php", + "type": "action", + "doc": { + "description": "Fires when the order is synced with cart data from a cart route.", + "long_description": "", + "tags": [ + { + "name": "param", + "content": "Order object.", + "types": [ + "\\WC_Order" + ], + "variable": "$draft_order" + }, + { + "name": "param", + "content": "Customer object.", + "types": [ + "\\WC_Customer" + ], + "variable": "$customer" + }, + { + "name": "param", + "content": "Full details about the request.", + "types": [ + "\\WP_REST_Request" + ], + "variable": "$request" + } + ], + "long_description_html": "" + }, + "args": 2 + }, + { + "name": "woocommerce_store_api_checkout_order_processed", + "file": "StoreApi/Routes/V1/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:

  • To keep the interface focused (only pass $order, not passing request data).
  • This also explicitly indicates these orders are from checkout block/StoreAPI.
" + }, + "args": 1 + }, + { + "name": "woocommerce_store_api_checkout_update_customer_from_request", + "file": "StoreApi/Routes/V1/Checkout.php", + "type": "action", + "doc": { + "description": "Fires when the Checkout Block/Store API updates a customer from the API request data.", + "long_description": "", + "tags": [ + { + "name": "param", + "content": "Customer object.", + "types": [ + "\\WC_Customer" + ], + "variable": "$customer" + }, + { + "name": "param", + "content": "Full details about the request.", + "types": [ + "\\WP_REST_Request" + ], + "variable": "$request" + } + ], + "long_description_html": "" + }, + "args": 2 + }, + { + "name": "woocommerce_store_api_checkout_update_order_from_request", + "file": "StoreApi/Routes/V1/Checkout.php", + "type": "action", + "doc": { + "description": "Fires when the Checkout Block/Store API updates an order's from the API request data.", + "long_description": "This hook gives extensions the chance to update orders based on the data in the request. This can be used in conjunction with the ExtendSchema class to post custom data and then process it.", + "tags": [ + { + "name": "param", + "content": "Order object.", + "types": [ + "\\WC_Order" + ], + "variable": "$order" + }, + { + "name": "param", + "content": "Full details about the request.", + "types": [ + "\\WP_REST_Request" + ], + "variable": "$request" + } + ], + "long_description_html": "

This hook gives extensions the chance to update orders based on the data in the request. This can be used in conjunction with the ExtendSchema class to post custom data and then process it.

" + }, + "args": 2 + }, + { + "name": "woocommerce_store_api_checkout_update_order_meta", + "file": "StoreApi/Routes/V1/Checkout.php", + "type": "action", + "doc": { + "description": "Fires when the Checkout Block/Store API updates an order's meta data.", + "long_description": "This hook gives extensions the chance to add or update meta data on the $order. Throwing an exception from a callback attached to this action will make the Checkout Block render in a warning state, effectively preventing checkout.\n This is similar to existing core hook woocommerce_checkout_update_order_meta. 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/3686" + }, + { + "name": "param", + "content": "Order object.", + "types": [ + "\\WC_Order" + ], + "variable": "$order" + } + ], + "long_description_html": "

This hook gives extensions the chance to add or update meta data on the $order. Throwing an exception from a callback attached to this action will make the Checkout Block render in a warning state, effectively preventing checkout.

This is similar to existing core hook woocommerce_checkout_update_order_meta. 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.
" + }, + "args": 1 + }, + { + "name": "woocommerce_store_api_validate_add_to_cart", + "file": "StoreApi/Utilities/CartController.php", + "type": "action", + "doc": { + "description": "Fires during validation when adding an item to the cart via the Store API.", + "long_description": "Fire action to validate add to cart. Functions hooking into this should throw an \\Exception to prevent add to cart from happening.", + "tags": [ + { + "name": "param", + "content": "Product object being added to the cart.", + "types": [ + "\\WC_Product" + ], + "variable": "$product" + }, + { + "name": "param", + "content": "Add to cart request params including id, quantity, and variation attributes.", + "types": [ + "array" + ], + "variable": "$request" + } + ], + "long_description_html": "

Fire action to validate add to cart. Functions hooking into this should throw an \\Exception to prevent add to cart from happening.

" + }, + "args": 2 + }, + { + "name": "woocommerce_store_api_validate_cart_item", + "file": "StoreApi/Utilities/CartController.php", + "type": "action", + "doc": { + "description": "Fire action to validate add to cart. Functions hooking into this should throw an \\Exception to prevent add to cart from occurring.", + "long_description": "", + "tags": [ + { + "name": "param", + "content": "Product object being added to the cart.", + "types": [ + "\\WC_Product" + ], + "variable": "$product" + }, + { + "name": "param", + "content": "Cart item array.", + "types": [ + "array" + ], + "variable": "$cart_item" + } + ], + "long_description_html": "" + }, + "args": 2 + } + ] +} \ No newline at end of file diff --git a/bin/hook-docs/data/filters.json b/bin/hook-docs/data/filters.json index e2efdd482aa..5b7991c02de 100644 --- a/bin/hook-docs/data/filters.json +++ b/bin/hook-docs/data/filters.json @@ -1,854 +1,1011 @@ { - "$schema": "https://raw.githubusercontent.com/johnbillion/wp-hooks-generator/0.7.3/schema.json", - "hooks": [ - { - "name": "__experimental_woocommerce_blocks_add_data_attributes_to_block", - "file": "BlockTypesController.php", - "type": "filter", - "doc": { - "description": "Filters the list of allowed Block Names", - "long_description": "This hook defines which block names should have block name and attribute data- attributes appended on render.", - "tags": [ - { - "name": "param", - "content": "List of namespaces.", - "types": [ "array" ], - "variable": "$allowed_namespaces" - } - ], - "long_description_html": "

This hook defines which block names should have block name and attribute data- attributes appended on render.

" - }, - "args": 1 - }, - { - "name": "__experimental_woocommerce_blocks_add_data_attributes_to_namespace", - "file": "BlockTypesController.php", - "type": "filter", - "doc": { - "description": "Filters the list of allowed block namespaces.", - "long_description": "This hook defines which block namespaces should have block name and attribute `data-` attributes appended on render.", - "tags": [ - { - "name": "param", - "content": "List of namespaces.", - "types": [ "array" ], - "variable": "$allowed_namespaces" - } - ], - "long_description_html": "

This hook defines which block namespaces should have block name and attribute data- attributes appended on render.

" - }, - "args": 1 - }, - { - "name": "__experimental_woocommerce_blocks_payment_gateway_features_list", - "file": "Payments/Integrations/PayPal.php", - "type": "filter", - "doc": { - "description": "Filter to control what features are available for each payment gateway.", - "long_description": "", - "tags": [ - { - "name": "example", - "content": "docs/examples/payment-gateways-features-list.md" - }, - { - "name": "param", - "content": "List of supported features.", - "types": [ "array" ], - "variable": "$features" - }, - { - "name": "param", - "content": "Gateway name.", - "types": [ "string" ], - "variable": "$name" - }, - { - "name": "return", - "content": "Updated list of supported features.", - "types": [ "array" ] - } - ], - "long_description_html": "" - }, - "args": 2 - }, - { - "name": "woocommerce_add_cart_item", - "file": "StoreApi/Utilities/CartController.php", - "type": "filter", - "doc": { - "description": "Filters the item being added to the cart.", - "long_description": "", - "tags": [ - { - "name": "internal", - "content": "Matches filter name in WooCommerce core." - }, - { - "name": "param", - "content": "Array of cart item data being added to the cart.", - "types": [ "array" ], - "variable": "$cart_item_data" - }, - { - "name": "param", - "content": "Id of the item in the cart.", - "types": [ "string" ], - "variable": "$cart_id" - }, - { - "name": "return", - "content": "Updated cart item data.", - "types": [ "array" ] - } - ], - "long_description_html": "" - }, - "args": 2 - }, - { - "name": "woocommerce_add_cart_item_data", - "file": "StoreApi/Utilities/CartController.php", - "type": "filter", - "doc": { - "description": "Filter cart item data for add to cart requests.", - "long_description": "", - "tags": [ - { - "name": "internal", - "content": "Matches filter name in WooCommerce core." - }, - { - "name": "param", - "content": "Array of other cart item data.", - "types": [ "array" ], - "variable": "$cart_item_data" - }, - { - "name": "param", - "content": "ID of the product added to the cart.", - "types": [ "integer" ], - "variable": "$product_id" - }, - { - "name": "param", - "content": "Variation ID of the product added to the cart.", - "types": [ "integer" ], - "variable": "$variation_id" - }, - { - "name": "param", - "content": "Quantity of the item added to the cart.", - "types": [ "integer" ], - "variable": "$quantity" - }, - { - "name": "return", - "content": "", - "types": [ "array" ] - } - ], - "long_description_html": "" - }, - "args": 4 - }, - { - "name": "woocommerce_add_to_cart_sold_individually_quantity", - "file": "StoreApi/Utilities/CartController.php", - "type": "filter", - "doc": { - "description": "Filter sold individually quantity for add to cart requests.", - "long_description": "", - "tags": [ - { - "name": "internal", - "content": "Matches filter name in WooCommerce core." - }, - { - "name": "param", - "content": "Defaults to 1.", - "types": [ "integer" ], - "variable": "$sold_individually_quantity" - }, - { - "name": "param", - "content": "Quantity of the item added to the cart.", - "types": [ "integer" ], - "variable": "$quantity" - }, - { - "name": "param", - "content": "ID of the product added to the cart.", - "types": [ "integer" ], - "variable": "$product_id" - }, - { - "name": "param", - "content": "Variation ID of the product added to the cart.", - "types": [ "integer" ], - "variable": "$variation_id" - }, - { - "name": "param", - "content": "Array of other cart item data.", - "types": [ "array" ], - "variable": "$cart_item_data" - }, - { - "name": "return", - "content": "", - "types": [ "integer" ] - } - ], - "long_description_html": "" - }, - "args": 5 - }, - { - "name": "woocommerce_add_to_cart_validation", - "file": "StoreApi/Utilities/CartController.php", - "type": "filter", - "doc": { - "description": "Filters if an item being added to the cart passed validation checks.", - "long_description": "Allow 3rd parties to validate if an item can be added to the cart. This is a legacy hook from Woo core. This filter will be deprecated because it encourages usage of wc_add_notice. For the API we need to capture notices and convert to exceptions instead.", - "tags": [ - { - "name": "deprecated", - "content": "" - }, - { - "name": "param", - "content": "True if the item passed validation.", - "types": [ "boolean" ], - "variable": "$passed_validation" - }, - { - "name": "param", - "content": "Product ID being validated.", - "types": [ "integer" ], - "variable": "$product_id" - }, - { - "name": "param", - "content": "Quantity added to the cart.", - "types": [ "integer" ], - "variable": "$quantity" - }, - { - "name": "param", - "content": "Variation ID being added to the cart.", - "types": [ "integer" ], - "variable": "$variation_id" - }, - { - "name": "param", - "content": "Variation data.", - "types": [ "array" ], - "variable": "$variation" - }, - { - "name": "return", - "content": "", - "types": [ "boolean" ] - } - ], - "long_description_html": "

Allow 3rd parties to validate if an item can be added to the cart. This is a legacy hook from Woo core. This filter will be deprecated because it encourages usage of wc_add_notice. For the API we need to capture notices and convert to exceptions instead.

" - }, - "args": 5 - }, - { - "name": "woocommerce_adjust_non_base_location_prices", - "file": "StoreApi/Utilities/ProductQuery.php", - "type": "filter", - "doc": { - "description": "Filters if taxes should be removed from locations outside the store base location.", - "long_description": "The woocommerce_adjust_non_base_location_prices filter can stop base taxes being taken off when dealing with out of base locations. e.g. If a product costs 10 including tax, all users will pay 10 regardless of location and taxes.", - "tags": [ - { - "name": "internal", - "content": "Matches filter name in WooCommerce core." - }, - { - "name": "param", - "content": "True by default.", - "types": [ "boolean" ], - "variable": "$adjust_non_base_location_prices" - }, - { - "name": "return", - "content": "", - "types": [ "boolean" ] - } - ], - "long_description_html": "

The woocommerce_adjust_non_base_location_prices filter can stop base taxes being taken off when dealing with out of base locations. e.g. If a product costs 10 including tax, all users will pay 10 regardless of location and taxes.

" - }, - "args": 1 - }, - { - "name": "woocommerce_admin_disabled", - "file": "InboxNotifications.php", - "type": "filter", - "doc": { - "description": "", - "long_description": "", - "tags": [], - "long_description_html": "" - }, - "args": 1 - }, - { - "name": "woocommerce_apply_individual_use_coupon", - "file": "StoreApi/Utilities/CartController.php", - "type": "filter", - "doc": { - "description": "Filter coupons to remove when applying an individual use coupon.", - "long_description": "", - "tags": [ - { - "name": "internal", - "content": "Matches filter name in WooCommerce core." - }, - { - "name": "param", - "content": "Array of coupons to remove from the cart.", - "types": [ "array" ], - "variable": "$coupons" - }, - { - "name": "param", - "content": "Coupon object applied to the cart.", - "types": [ "\\WC_Coupon" ], - "variable": "$coupon" - }, - { - "name": "param", - "content": "Array of applied coupons already applied to the cart.", - "types": [ "array" ], - "variable": "$applied_coupons" - }, - { - "name": "return", - "content": "", - "types": [ "array" ] - } - ], - "long_description_html": "" - }, - "args": 3 - }, - { - "name": "woocommerce_apply_with_individual_use_coupon", - "file": "StoreApi/Utilities/CartController.php", - "type": "filter", - "doc": { - "description": "Filters if a coupon can be applied alongside other individual use coupons.", - "long_description": "", - "tags": [ - { - "name": "internal", - "content": "Matches filter name in WooCommerce core." - }, - { - "name": "param", - "content": "Defaults to false.", - "types": [ "boolean" ], - "variable": "$apply_with_individual_use_coupon" - }, - { - "name": "param", - "content": "Coupon object applied to the cart.", - "types": [ "\\WC_Coupon" ], - "variable": "$coupon" - }, - { - "name": "param", - "content": "Individual use coupon already applied to the cart.", - "types": [ "\\WC_Coupon" ], - "variable": "$individual_use_coupon" - }, - { - "name": "param", - "content": "Array of applied coupons already applied to the cart.", - "types": [ "array" ], - "variable": "$applied_coupons" - }, - { - "name": "return", - "content": "", - "types": [ "boolean" ] - } - ], - "long_description_html": "" - }, - "args": 4 - }, - { - "name": "woocommerce_blocks_product_grid_is_cacheable", - "file": "BlockTypes/AbstractProductGrid.php", - "type": "filter", - "doc": { - "description": "Filters whether or not the product grid is cacheable.", - "long_description": "", - "tags": [ - { - "name": "param", - "content": "The list of script dependencies.", - "types": [ "boolean" ], - "variable": "$is_cacheable" - }, - { - "name": "param", - "content": "Query args for the products query passed to BlocksWpQuery.", - "types": [ "array" ], - "variable": "$query_args" - }, - { - "name": "return", - "content": "True to enable cache, false to disable cache.", - "types": [ "array" ] - } - ], - "long_description_html": "" - }, - "args": 2 - }, - { - "name": "woocommerce_blocks_product_grid_item_html", - "file": "BlockTypes/AbstractProductGrid.php", - "type": "filter", - "doc": { - "description": "Filters the HTML for products in the grid.", - "long_description": "", - "tags": [ - { - "name": "param", - "content": "Product grid item HTML.", - "types": [ "string" ], - "variable": "$html" - }, - { - "name": "param", - "content": "Product data passed to the template.", - "types": [ "array" ], - "variable": "$data" - }, - { - "name": "param", - "content": "Product object.", - "types": [ "\\WC_Product" ], - "variable": "$product" - }, - { - "name": "return", - "content": "Updated product grid item HTML.", - "types": [ "string" ] - } - ], - "long_description_html": "" - }, - "args": 3 - }, - { - "name": "woocommerce_blocks_register_script_dependencies", - "file": "Assets/Api.php", - "type": "filter", - "doc": { - "description": "Filters the list of script dependencies.", - "long_description": "", - "tags": [ - { - "name": "param", - "content": "The list of script dependencies.", - "types": [ "array" ], - "variable": "$dependencies" - }, - { - "name": "param", - "content": "The script's handle.", - "types": [ "string" ], - "variable": "$handle" - }, - { - "name": "return", - "content": "", - "types": [ "array" ] - } - ], - "long_description_html": "" - }, - "args": 2 - }, - { - "name": "woocommerce_cart_contents_changed", - "file": "StoreApi/Utilities/CartController.php", - "type": "filter", - "doc": { - "description": "Filters the entire cart contents when the cart changes.", - "long_description": "", - "tags": [ - { - "name": "internal", - "content": "Matches filter name in WooCommerce core." - }, - { - "name": "param", - "content": "Array of all cart items.", - "types": [ "array" ], - "variable": "$cart_contents" - }, - { - "name": "return", - "content": "Updated array of all cart items.", - "types": [ "array" ] - } - ], - "long_description_html": "" - }, - "args": 1 - }, - { - "name": "woocommerce_ga_disable_tracking", - "file": "Domain/Services/GoogleAnalytics.php", - "type": "filter", - "doc": { - "description": "Filter to disable Google Analytics tracking.", - "long_description": "", - "tags": [ - { - "name": "internal", - "content": "Matches filter name in GA extension." - }, - { - "name": "param", - "content": "If true, tracking will be disabled.", - "types": [ "boolean" ], - "variable": "$disable_tracking" - } - ], - "long_description_html": "" - }, - "args": 1 - }, - { - "name": "woocommerce_get_item_data", - "file": "StoreApi/Schemas/V1/CartItemSchema.php", - "type": "filter", - "doc": { - "description": "Filters cart item data.", - "long_description": "Filters the variation option name for custom option slugs.", - "tags": [ - { - "name": "internal", - "content": "Matches filter name in WooCommerce core." - }, - { - "name": "param", - "content": "Cart item data. Empty by default.", - "types": [ "array" ], - "variable": "$item_data" - }, - { - "name": "param", - "content": "Cart item array.", - "types": [ "array" ], - "variable": "$cart_item" - }, - { - "name": "return", - "content": "", - "types": [ "array" ] - } - ], - "long_description_html": "

Filters the variation option name for custom option slugs.

" - }, - "args": 2 - }, - { - "name": "woocommerce_new_customer_data", - "file": "StoreApi/Routes/V1/Checkout.php", - "type": "filter", - "doc": { - "description": "Filters customer data before a customer account is registered.", - "long_description": "This hook filters customer data. It allows user data to be changed, for example, username, password, email, first name, last name, and role.", - "tags": [ - { - "name": "param", - "content": "An array of customer (user) data.", - "types": [ "array" ], - "variable": "$customer_data" - }, - { - "name": "return", - "content": "", - "types": [ "array" ] - } - ], - "long_description_html": "

This hook filters customer data. It allows user data to be changed, for example, username, password, email, first name, last name, and role.

" - }, - "args": 1 - }, - { - "name": "woocommerce_registration_errors", - "file": "StoreApi/Routes/V1/Checkout.php", - "type": "filter", - "doc": { - "description": "Filters registration errors before a customer account is registered.", - "long_description": "This hook filters registration errors. This can be used to manipulate the array of errors before they are displayed.", - "tags": [ - { - "name": "internal", - "content": "Matches filter name in WooCommerce core." - }, - { - "name": "param", - "content": "Error object.", - "types": [ "\\WP_Error" ], - "variable": "$errors" - }, - { - "name": "param", - "content": "Customer username.", - "types": [ "string" ], - "variable": "$username" - }, - { - "name": "param", - "content": "Customer email address.", - "types": [ "string" ], - "variable": "$user_email" - }, - { - "name": "return", - "content": "", - "types": [ "\\WP_Error" ] - } - ], - "long_description_html": "

This hook filters registration errors. This can be used to manipulate the array of errors before they are displayed.

" - }, - "args": 3 - }, - { - "name": "woocommerce_shared_settings", - "file": "Assets/AssetDataRegistry.php", - "type": "filter", - "doc": { - "description": "Filters the array of shared settings.", - "long_description": "Low level hook for registration of new data late in the cycle. This is deprecated. Instead, use the data api:\n ```php Automattic\\WooCommerce\\Blocks\\Package::container()->get( Automattic\\WooCommerce\\Blocks\\Assets\\AssetDataRegistry::class )->add( $key, $value ) ```", - "tags": [ - { - "name": "deprecated", - "content": "" - }, - { - "name": "param", - "content": "Settings data.", - "types": [ "array" ], - "variable": "$data" - }, - { - "name": "return", - "content": "", - "types": [ "array" ] - } - ], - "long_description_html": "

Low level hook for registration of new data late in the cycle. This is deprecated. Instead, use the data api:

Automattic\\WooCommerce\\Blocks\\Package::container()->get( Automattic\\WooCommerce\\Blocks\\Assets\\AssetDataRegistry::class )->add( $key, $value )
" - }, - "args": 1 - }, - { - "name": "woocommerce_shipping_package_name", - "file": "StoreApi/Utilities/CartController.php", - "type": "filter", - "doc": { - "description": "Filters the shipping package name.", - "long_description": "", - "tags": [ - { - "name": "internal", - "content": "Matches filter name in WooCommerce core." - }, - { - "name": "param", - "content": "Shipping package name.", - "types": [ "string" ], - "variable": "$shipping_package_name" - }, - { - "name": "param", - "content": "Shipping package ID.", - "types": [ "string" ], - "variable": "$package_id" - }, - { - "name": "param", - "content": "Shipping package from WooCommerce.", - "types": [ "array" ], - "variable": "$package" - }, - { - "name": "return", - "content": "Shipping package name.", - "types": [ "string" ] - } - ], - "long_description_html": "" - }, - "args": 3 - }, - { - "name": "woocommerce_show_page_title", - "file": "BlockTypes/ClassicTemplate.php", - "type": "filter", - "doc": { - "description": "We need to load the scripts here because when using block templates wp_head() gets run after the block template. As a result we are trying to enqueue required scripts before we have even registered them.", - "long_description": "", - "tags": [ - { - "name": "see", - "content": "", - "refers": "https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/5328#issuecomment-989013447" - } - ], - "long_description_html": "" - }, - "args": 1 - }, - { - "name": "woocommerce_store_api_disable_nonce_check", - "file": "StoreApi/Routes/V1/AbstractCartRoute.php", - "type": "filter", - "doc": { - "description": "Filters the Store API nonce check.", - "long_description": "This can be used to disable the nonce check when testing API endpoints via a REST API client.", - "tags": [ - { - "name": "param", - "content": "If true, nonce checks will be disabled.", - "types": [ "boolean" ], - "variable": "$disable_nonce_check" - }, - { - "name": "return", - "content": "", - "types": [ "boolean" ] - } - ], - "long_description_html": "

This can be used to disable the nonce check when testing API endpoints via a REST API client.

" - }, - "args": 1 - }, - { - "name": "woocommerce_store_api_product_quantity_limit", - "file": "StoreApi/Utilities/QuantityLimits.php", - "type": "filter", - "doc": { - "description": "Filters the quantity limit for a product being added to the cart via the Store API.", - "long_description": "Filters the variation option name for custom option slugs.", - "tags": [ - { - "name": "param", - "content": "Quantity limit which defaults to 9999 unless sold individually.", - "types": [ "integer" ], - "variable": "$quantity_limit" - }, - { - "name": "param", - "content": "Product instance.", - "types": [ "\\WC_Product" ], - "variable": "$product" - }, - { - "name": "return", - "content": "", - "types": [ "integer" ] - } - ], - "long_description_html": "

Filters the variation option name for custom option slugs.

" - }, - "args": 2 - }, - { - "name": "woocommerce_store_api_product_quantity_{$value_type}", - "file": "StoreApi/Utilities/QuantityLimits.php", - "type": "filter", - "doc": { - "description": "Filters the quantity minimum for a cart item in Store API. This allows extensions to control the minimum qty of items already within the cart.", - "long_description": "The suffix of the hook will vary depending on the value being filtered. For example, minimum, maximum, multiple_of, editable.", - "tags": [ - { - "name": "param", - "content": "The value being filtered.", - "types": [ "mixed" ], - "variable": "$value" - }, - { - "name": "param", - "content": "The product object.", - "types": [ "\\WC_Product" ], - "variable": "$product" - }, - { - "name": "param", - "content": "The cart item if the product exists in the cart, or null.", - "types": [ "array", "null" ], - "variable": "$cart_item" - }, - { - "name": "return", - "content": "", - "types": [ "mixed" ] - } - ], - "long_description_html": "

The suffix of the hook will vary depending on the value being filtered. For example, minimum, maximum, multiple_of, editable.

" - }, - "args": 3 - }, - { - "name": "woocommerce_variation_option_name", - "file": "StoreApi/Schemas/V1/CartItemSchema.php", - "type": "filter", - "doc": { - "description": "Filters the variation option name.", - "long_description": "Filters the variation option name for custom option slugs.", - "tags": [ - { - "name": "internal", - "content": "Matches filter name in WooCommerce core." - }, - { - "name": "param", - "content": "The name to display.", - "types": [ "string" ], - "variable": "$value" - }, - { - "name": "param", - "content": "Unused because this is not a variation taxonomy.", - "types": [ "null" ], - "variable": "$unused" - }, - { - "name": "param", - "content": "Taxonomy or product attribute name.", - "types": [ "string" ], - "variable": "$taxonomy" - }, - { - "name": "param", - "content": "Product data.", - "types": [ "\\WC_Product" ], - "variable": "$product" - }, - { - "name": "return", - "content": "", - "types": [ "string" ] - } - ], - "long_description_html": "

Filters the variation option name for custom option slugs.

" - }, - "args": 4 - } - ] -} + "$schema": "https://raw.githubusercontent.com/johnbillion/wp-hooks-generator/0.7.0/schema.json", + "hooks": [ + { + "name": "__experimental_woocommerce_blocks_add_data_attributes_to_block", + "file": "BlockTypesController.php", + "type": "filter", + "doc": { + "description": "Filters the list of allowed Block Names", + "long_description": "This hook defines which block names should have block name and attribute data- attributes appended on render.", + "tags": [ + { + "name": "param", + "content": "List of namespaces.", + "types": [ + "array" + ], + "variable": "$allowed_namespaces" + } + ], + "long_description_html": "

This hook defines which block names should have block name and attribute data- attributes appended on render.

" + }, + "args": 1 + }, + { + "name": "__experimental_woocommerce_blocks_add_data_attributes_to_namespace", + "file": "BlockTypesController.php", + "type": "filter", + "doc": { + "description": "Filters the list of allowed block namespaces.", + "long_description": "This hook defines which block namespaces should have block name and attribute `data-` attributes appended on render.", + "tags": [ + { + "name": "param", + "content": "List of namespaces.", + "types": [ + "array" + ], + "variable": "$allowed_namespaces" + } + ], + "long_description_html": "

This hook defines which block namespaces should have block name and attribute data- attributes appended on render.

" + }, + "args": 1 + }, + { + "name": "__experimental_woocommerce_blocks_payment_gateway_features_list", + "file": "Payments/Integrations/PayPal.php", + "type": "filter", + "doc": { + "description": "Filter to control what features are available for each payment gateway.", + "long_description": "", + "tags": [ + { + "name": "example", + "content": "docs/examples/payment-gateways-features-list.md" + }, + { + "name": "param", + "content": "List of supported features.", + "types": [ + "array" + ], + "variable": "$features" + }, + { + "name": "param", + "content": "Gateway name.", + "types": [ + "string" + ], + "variable": "$name" + }, + { + "name": "return", + "content": "Updated list of supported features.", + "types": [ + "array" + ] + } + ], + "long_description_html": "" + }, + "args": 2 + }, + { + "name": "woocommerce_add_cart_item", + "file": "StoreApi/Utilities/CartController.php", + "type": "filter", + "doc": { + "description": "Filters the item being added to the cart.", + "long_description": "", + "tags": [ + { + "name": "internal", + "content": "Matches filter name in WooCommerce core." + }, + { + "name": "param", + "content": "Array of cart item data being added to the cart.", + "types": [ + "array" + ], + "variable": "$cart_item_data" + }, + { + "name": "param", + "content": "Id of the item in the cart.", + "types": [ + "string" + ], + "variable": "$cart_id" + }, + { + "name": "return", + "content": "Updated cart item data.", + "types": [ + "array" + ] + } + ], + "long_description_html": "" + }, + "args": 2 + }, + { + "name": "woocommerce_add_cart_item_data", + "file": "StoreApi/Utilities/CartController.php", + "type": "filter", + "doc": { + "description": "Filter cart item data for add to cart requests.", + "long_description": "", + "tags": [ + { + "name": "internal", + "content": "Matches filter name in WooCommerce core." + }, + { + "name": "param", + "content": "Array of other cart item data.", + "types": [ + "array" + ], + "variable": "$cart_item_data" + }, + { + "name": "param", + "content": "ID of the product added to the cart.", + "types": [ + "integer" + ], + "variable": "$product_id" + }, + { + "name": "param", + "content": "Variation ID of the product added to the cart.", + "types": [ + "integer" + ], + "variable": "$variation_id" + }, + { + "name": "param", + "content": "Quantity of the item added to the cart.", + "types": [ + "integer" + ], + "variable": "$quantity" + }, + { + "name": "return", + "content": "", + "types": [ + "array" + ] + } + ], + "long_description_html": "" + }, + "args": 4 + }, + { + "name": "woocommerce_add_to_cart_sold_individually_quantity", + "file": "StoreApi/Utilities/CartController.php", + "type": "filter", + "doc": { + "description": "Filter sold individually quantity for add to cart requests.", + "long_description": "", + "tags": [ + { + "name": "internal", + "content": "Matches filter name in WooCommerce core." + }, + { + "name": "param", + "content": "Defaults to 1.", + "types": [ + "integer" + ], + "variable": "$sold_individually_quantity" + }, + { + "name": "param", + "content": "Quantity of the item added to the cart.", + "types": [ + "integer" + ], + "variable": "$quantity" + }, + { + "name": "param", + "content": "ID of the product added to the cart.", + "types": [ + "integer" + ], + "variable": "$product_id" + }, + { + "name": "param", + "content": "Variation ID of the product added to the cart.", + "types": [ + "integer" + ], + "variable": "$variation_id" + }, + { + "name": "param", + "content": "Array of other cart item data.", + "types": [ + "array" + ], + "variable": "$cart_item_data" + }, + { + "name": "return", + "content": "", + "types": [ + "integer" + ] + } + ], + "long_description_html": "" + }, + "args": 5 + }, + { + "name": "woocommerce_add_to_cart_validation", + "file": "StoreApi/Utilities/CartController.php", + "type": "filter", + "doc": { + "description": "Filters if an item being added to the cart passed validation checks.", + "long_description": "Allow 3rd parties to validate if an item can be added to the cart. This is a legacy hook from Woo core. This filter will be deprecated because it encourages usage of wc_add_notice. For the API we need to capture notices and convert to exceptions instead.", + "tags": [ + { + "name": "deprecated", + "content": "" + }, + { + "name": "param", + "content": "True if the item passed validation.", + "types": [ + "boolean" + ], + "variable": "$passed_validation" + }, + { + "name": "param", + "content": "Product ID being validated.", + "types": [ + "integer" + ], + "variable": "$product_id" + }, + { + "name": "param", + "content": "Quantity added to the cart.", + "types": [ + "integer" + ], + "variable": "$quantity" + }, + { + "name": "param", + "content": "Variation ID being added to the cart.", + "types": [ + "integer" + ], + "variable": "$variation_id" + }, + { + "name": "param", + "content": "Variation data.", + "types": [ + "array" + ], + "variable": "$variation" + }, + { + "name": "return", + "content": "", + "types": [ + "boolean" + ] + } + ], + "long_description_html": "

Allow 3rd parties to validate if an item can be added to the cart. This is a legacy hook from Woo core. This filter will be deprecated because it encourages usage of wc_add_notice. For the API we need to capture notices and convert to exceptions instead.

" + }, + "args": 5 + }, + { + "name": "woocommerce_adjust_non_base_location_prices", + "file": "StoreApi/Utilities/ProductQuery.php", + "type": "filter", + "doc": { + "description": "Filters if taxes should be removed from locations outside the store base location.", + "long_description": "The woocommerce_adjust_non_base_location_prices filter can stop base taxes being taken off when dealing with out of base locations. e.g. If a product costs 10 including tax, all users will pay 10 regardless of location and taxes.", + "tags": [ + { + "name": "internal", + "content": "Matches filter name in WooCommerce core." + }, + { + "name": "param", + "content": "True by default.", + "types": [ + "boolean" + ], + "variable": "$adjust_non_base_location_prices" + }, + { + "name": "return", + "content": "", + "types": [ + "boolean" + ] + } + ], + "long_description_html": "

The woocommerce_adjust_non_base_location_prices filter can stop base taxes being taken off when dealing with out of base locations. e.g. If a product costs 10 including tax, all users will pay 10 regardless of location and taxes.

" + }, + "args": 1 + }, + { + "name": "woocommerce_admin_disabled", + "file": "InboxNotifications.php", + "type": "filter", + "doc": { + "description": "", + "long_description": "", + "tags": [], + "long_description_html": "" + }, + "args": 1 + }, + { + "name": "woocommerce_apply_individual_use_coupon", + "file": "StoreApi/Utilities/CartController.php", + "type": "filter", + "doc": { + "description": "Filter coupons to remove when applying an individual use coupon.", + "long_description": "", + "tags": [ + { + "name": "internal", + "content": "Matches filter name in WooCommerce core." + }, + { + "name": "param", + "content": "Array of coupons to remove from the cart.", + "types": [ + "array" + ], + "variable": "$coupons" + }, + { + "name": "param", + "content": "Coupon object applied to the cart.", + "types": [ + "\\WC_Coupon" + ], + "variable": "$coupon" + }, + { + "name": "param", + "content": "Array of applied coupons already applied to the cart.", + "types": [ + "array" + ], + "variable": "$applied_coupons" + }, + { + "name": "return", + "content": "", + "types": [ + "array" + ] + } + ], + "long_description_html": "" + }, + "args": 3 + }, + { + "name": "woocommerce_apply_with_individual_use_coupon", + "file": "StoreApi/Utilities/CartController.php", + "type": "filter", + "doc": { + "description": "Filters if a coupon can be applied alongside other individual use coupons.", + "long_description": "", + "tags": [ + { + "name": "internal", + "content": "Matches filter name in WooCommerce core." + }, + { + "name": "param", + "content": "Defaults to false.", + "types": [ + "boolean" + ], + "variable": "$apply_with_individual_use_coupon" + }, + { + "name": "param", + "content": "Coupon object applied to the cart.", + "types": [ + "\\WC_Coupon" + ], + "variable": "$coupon" + }, + { + "name": "param", + "content": "Individual use coupon already applied to the cart.", + "types": [ + "\\WC_Coupon" + ], + "variable": "$individual_use_coupon" + }, + { + "name": "param", + "content": "Array of applied coupons already applied to the cart.", + "types": [ + "array" + ], + "variable": "$applied_coupons" + }, + { + "name": "return", + "content": "", + "types": [ + "boolean" + ] + } + ], + "long_description_html": "" + }, + "args": 4 + }, + { + "name": "woocommerce_blocks_product_grid_is_cacheable", + "file": "BlockTypes/AbstractProductGrid.php", + "type": "filter", + "doc": { + "description": "Filters whether or not the product grid is cacheable.", + "long_description": "", + "tags": [ + { + "name": "param", + "content": "The list of script dependencies.", + "types": [ + "boolean" + ], + "variable": "$is_cacheable" + }, + { + "name": "param", + "content": "Query args for the products query passed to BlocksWpQuery.", + "types": [ + "array" + ], + "variable": "$query_args" + }, + { + "name": "return", + "content": "True to enable cache, false to disable cache.", + "types": [ + "array" + ] + } + ], + "long_description_html": "" + }, + "args": 2 + }, + { + "name": "woocommerce_blocks_product_grid_item_html", + "file": "BlockTypes/AbstractProductGrid.php", + "type": "filter", + "doc": { + "description": "Filters the HTML for products in the grid.", + "long_description": "", + "tags": [ + { + "name": "param", + "content": "Product grid item HTML.", + "types": [ + "string" + ], + "variable": "$html" + }, + { + "name": "param", + "content": "Product data passed to the template.", + "types": [ + "array" + ], + "variable": "$data" + }, + { + "name": "param", + "content": "Product object.", + "types": [ + "\\WC_Product" + ], + "variable": "$product" + }, + { + "name": "return", + "content": "Updated product grid item HTML.", + "types": [ + "string" + ] + } + ], + "long_description_html": "" + }, + "args": 3 + }, + { + "name": "woocommerce_blocks_register_script_dependencies", + "file": "Assets/Api.php", + "type": "filter", + "doc": { + "description": "Filters the list of script dependencies.", + "long_description": "", + "tags": [ + { + "name": "param", + "content": "The list of script dependencies.", + "types": [ + "array" + ], + "variable": "$dependencies" + }, + { + "name": "param", + "content": "The script's handle.", + "types": [ + "string" + ], + "variable": "$handle" + }, + { + "name": "return", + "content": "", + "types": [ + "array" + ] + } + ], + "long_description_html": "" + }, + "args": 2 + }, + { + "name": "woocommerce_cart_contents_changed", + "file": "StoreApi/Utilities/CartController.php", + "type": "filter", + "doc": { + "description": "Filters the entire cart contents when the cart changes.", + "long_description": "", + "tags": [ + { + "name": "internal", + "content": "Matches filter name in WooCommerce core." + }, + { + "name": "param", + "content": "Array of all cart items.", + "types": [ + "array" + ], + "variable": "$cart_contents" + }, + { + "name": "return", + "content": "Updated array of all cart items.", + "types": [ + "array" + ] + } + ], + "long_description_html": "" + }, + "args": 1 + }, + { + "name": "woocommerce_ga_disable_tracking", + "file": "Domain/Services/GoogleAnalytics.php", + "type": "filter", + "doc": { + "description": "Filter to disable Google Analytics tracking.", + "long_description": "", + "tags": [ + { + "name": "internal", + "content": "Matches filter name in GA extension." + }, + { + "name": "param", + "content": "If true, tracking will be disabled.", + "types": [ + "boolean" + ], + "variable": "$disable_tracking" + } + ], + "long_description_html": "" + }, + "args": 1 + }, + { + "name": "woocommerce_get_item_data", + "file": "StoreApi/Schemas/V1/CartItemSchema.php", + "type": "filter", + "doc": { + "description": "Filters cart item data.", + "long_description": "Filters the variation option name for custom option slugs.", + "tags": [ + { + "name": "internal", + "content": "Matches filter name in WooCommerce core." + }, + { + "name": "param", + "content": "Cart item data. Empty by default.", + "types": [ + "array" + ], + "variable": "$item_data" + }, + { + "name": "param", + "content": "Cart item array.", + "types": [ + "array" + ], + "variable": "$cart_item" + }, + { + "name": "return", + "content": "", + "types": [ + "array" + ] + } + ], + "long_description_html": "

Filters the variation option name for custom option slugs.

" + }, + "args": 2 + }, + { + "name": "woocommerce_new_customer_data", + "file": "StoreApi/Routes/V1/Checkout.php", + "type": "filter", + "doc": { + "description": "Filters customer data before a customer account is registered.", + "long_description": "This hook filters customer data. It allows user data to be changed, for example, username, password, email, first name, last name, and role.", + "tags": [ + { + "name": "param", + "content": "An array of customer (user) data.", + "types": [ + "array" + ], + "variable": "$customer_data" + }, + { + "name": "return", + "content": "", + "types": [ + "array" + ] + } + ], + "long_description_html": "

This hook filters customer data. It allows user data to be changed, for example, username, password, email, first name, last name, and role.

" + }, + "args": 1 + }, + { + "name": "woocommerce_registration_errors", + "file": "StoreApi/Routes/V1/Checkout.php", + "type": "filter", + "doc": { + "description": "Filters registration errors before a customer account is registered.", + "long_description": "This hook filters registration errors. This can be used to manipulate the array of errors before they are displayed.", + "tags": [ + { + "name": "internal", + "content": "Matches filter name in WooCommerce core." + }, + { + "name": "param", + "content": "Error object.", + "types": [ + "\\WP_Error" + ], + "variable": "$errors" + }, + { + "name": "param", + "content": "Customer username.", + "types": [ + "string" + ], + "variable": "$username" + }, + { + "name": "param", + "content": "Customer email address.", + "types": [ + "string" + ], + "variable": "$user_email" + }, + { + "name": "return", + "content": "", + "types": [ + "\\WP_Error" + ] + } + ], + "long_description_html": "

This hook filters registration errors. This can be used to manipulate the array of errors before they are displayed.

" + }, + "args": 3 + }, + { + "name": "woocommerce_shared_settings", + "file": "Assets/AssetDataRegistry.php", + "type": "filter", + "doc": { + "description": "Filters the array of shared settings.", + "long_description": "Low level hook for registration of new data late in the cycle. This is deprecated. Instead, use the data api:\n ```php Automattic\\WooCommerce\\Blocks\\Package::container()->get( Automattic\\WooCommerce\\Blocks\\Assets\\AssetDataRegistry::class )->add( $key, $value ) ```", + "tags": [ + { + "name": "deprecated", + "content": "" + }, + { + "name": "param", + "content": "Settings data.", + "types": [ + "array" + ], + "variable": "$data" + }, + { + "name": "return", + "content": "", + "types": [ + "array" + ] + } + ], + "long_description_html": "

Low level hook for registration of new data late in the cycle. This is deprecated. Instead, use the data api:

Automattic\\WooCommerce\\Blocks\\Package::container()->get( Automattic\\WooCommerce\\Blocks\\Assets\\AssetDataRegistry::class )->add( $key, $value )
" + }, + "args": 1 + }, + { + "name": "woocommerce_shipping_package_name", + "file": "StoreApi/Utilities/CartController.php", + "type": "filter", + "doc": { + "description": "Filters the shipping package name.", + "long_description": "", + "tags": [ + { + "name": "internal", + "content": "Matches filter name in WooCommerce core." + }, + { + "name": "param", + "content": "Shipping package name.", + "types": [ + "string" + ], + "variable": "$shipping_package_name" + }, + { + "name": "param", + "content": "Shipping package ID.", + "types": [ + "string" + ], + "variable": "$package_id" + }, + { + "name": "param", + "content": "Shipping package from WooCommerce.", + "types": [ + "array" + ], + "variable": "$package" + }, + { + "name": "return", + "content": "Shipping package name.", + "types": [ + "string" + ] + } + ], + "long_description_html": "" + }, + "args": 3 + }, + { + "name": "woocommerce_show_page_title", + "file": "BlockTypes/ClassicTemplate.php", + "type": "filter", + "doc": { + "description": "We need to load the scripts here because when using block templates wp_head() gets run after the block template. As a result we are trying to enqueue required scripts before we have even registered them.", + "long_description": "", + "tags": [ + { + "name": "see", + "content": "", + "refers": "https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/5328#issuecomment-989013447" + } + ], + "long_description_html": "" + }, + "args": 1 + }, + { + "name": "woocommerce_store_api_disable_nonce_check", + "file": "StoreApi/Routes/V1/AbstractCartRoute.php", + "type": "filter", + "doc": { + "description": "Filters the Store API nonce check.", + "long_description": "This can be used to disable the nonce check when testing API endpoints via a REST API client.", + "tags": [ + { + "name": "param", + "content": "If true, nonce checks will be disabled.", + "types": [ + "boolean" + ], + "variable": "$disable_nonce_check" + }, + { + "name": "return", + "content": "", + "types": [ + "boolean" + ] + } + ], + "long_description_html": "

This can be used to disable the nonce check when testing API endpoints via a REST API client.

" + }, + "args": 1 + }, + { + "name": "woocommerce_store_api_product_quantity_limit", + "file": "StoreApi/Utilities/QuantityLimits.php", + "type": "filter", + "doc": { + "description": "Filters the quantity limit for a product being added to the cart via the Store API.", + "long_description": "Filters the variation option name for custom option slugs.", + "tags": [ + { + "name": "param", + "content": "Quantity limit which defaults to 9999 unless sold individually.", + "types": [ + "integer" + ], + "variable": "$quantity_limit" + }, + { + "name": "param", + "content": "Product instance.", + "types": [ + "\\WC_Product" + ], + "variable": "$product" + }, + { + "name": "return", + "content": "", + "types": [ + "integer" + ] + } + ], + "long_description_html": "

Filters the variation option name for custom option slugs.

" + }, + "args": 2 + }, + { + "name": "woocommerce_store_api_product_quantity_{$value_type}", + "file": "StoreApi/Utilities/QuantityLimits.php", + "type": "filter", + "doc": { + "description": "Filters the quantity minimum for a cart item in Store API. This allows extensions to control the minimum qty of items already within the cart.", + "long_description": "The suffix of the hook will vary depending on the value being filtered. For example, minimum, maximum, multiple_of, editable.", + "tags": [ + { + "name": "param", + "content": "The value being filtered.", + "types": [ + "mixed" + ], + "variable": "$value" + }, + { + "name": "param", + "content": "The product object.", + "types": [ + "\\WC_Product" + ], + "variable": "$product" + }, + { + "name": "param", + "content": "The cart item if the product exists in the cart, or null.", + "types": [ + "array", + "null" + ], + "variable": "$cart_item" + }, + { + "name": "return", + "content": "", + "types": [ + "mixed" + ] + } + ], + "long_description_html": "

The suffix of the hook will vary depending on the value being filtered. For example, minimum, maximum, multiple_of, editable.

" + }, + "args": 3 + }, + { + "name": "woocommerce_variation_option_name", + "file": "StoreApi/Schemas/V1/CartItemSchema.php", + "type": "filter", + "doc": { + "description": "Filters the variation option name.", + "long_description": "Filters the variation option name for custom option slugs.", + "tags": [ + { + "name": "internal", + "content": "Matches filter name in WooCommerce core." + }, + { + "name": "param", + "content": "The name to display.", + "types": [ + "string" + ], + "variable": "$value" + }, + { + "name": "param", + "content": "Unused because this is not a variation taxonomy.", + "types": [ + "null" + ], + "variable": "$unused" + }, + { + "name": "param", + "content": "Taxonomy or product attribute name.", + "types": [ + "string" + ], + "variable": "$taxonomy" + }, + { + "name": "param", + "content": "Product data.", + "types": [ + "\\WC_Product" + ], + "variable": "$product" + }, + { + "name": "return", + "content": "", + "types": [ + "string" + ] + } + ], + "long_description_html": "

Filters the variation option name for custom option slugs.

" + }, + "args": 4 + } + ] +} \ No newline at end of file diff --git a/bin/webpack-configs.js b/bin/webpack-configs.js index b2e8374333d..9f16254afa7 100644 --- a/bin/webpack-configs.js +++ b/bin/webpack-configs.js @@ -2,6 +2,7 @@ * External dependencies */ const path = require( 'path' ); +const fs = require( 'fs' ); const { kebabCase } = require( 'lodash' ); const RemoveFilesPlugin = require( './remove-files-webpack-plugin' ); const MiniCssExtractPlugin = require( 'mini-css-extract-plugin' ); @@ -262,14 +263,19 @@ const getMainConfig = ( options = {} ) => { { from: './assets/js/blocks/**/block.json', to( { absoluteFilename } ) { - const blockName = absoluteFilename + /** + * Getting the block name from the JSON metadata is less error prone + * than extracting it from the file path. + */ + const JSONFile = fs.readFileSync( + path.resolve( __dirname, absoluteFilename ) + ); + const metadata = JSON.parse( JSONFile.toString() ); + const blockName = metadata.name .split( '/' ) - .at( -2 ); + .at( 1 ); return `./${ blockName }/block.json`; }, - globOptions: { - ignore: [ '**/inner-blocks/**' ], - }, }, ], } ), diff --git a/bin/webpack-entries.js b/bin/webpack-entries.js index b6e9d239f15..714dc064608 100644 --- a/bin/webpack-entries.js +++ b/bin/webpack-entries.js @@ -96,6 +96,8 @@ const entries = { './node_modules/wordpress-components/src/snackbar/style.scss', 'combobox-control-style': './node_modules/wordpress-components/src/combobox-control/style.scss', + 'form-token-field-style': + './node_modules/wordpress-components/src/form-token-field/style.scss', 'general-style': glob.sync( './assets/**/*.scss', { ignore: [ diff --git a/composer.json b/composer.json index 0f8839383d5..56a423a8ab5 100644 --- a/composer.json +++ b/composer.json @@ -19,7 +19,7 @@ "wp-phpunit/wp-phpunit": "^6.0", "woocommerce/woocommerce-sniffs": "0.1.0", "yoast/phpunit-polyfills": "^1.0", - "johnbillion/wp-hooks-generator": "^0.7.0", + "johnbillion/wp-hooks-generator": "^0.9.0", "mockery/mockery": "^1.4" }, "autoload": { diff --git a/composer.lock b/composer.lock index f2b0d409821..1a0acfea8f0 100644 --- a/composer.lock +++ b/composer.lock @@ -4,7 +4,7 @@ "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies", "This file is @generated automatically" ], - "content-hash": "850407a57ac7e6ccbae75e7a37a6b3a6", + "content-hash": "938acec166de3572a0884e7e81a9ba52", "packages": [ { "name": "automattic/jetpack-autoloader", @@ -282,29 +282,30 @@ }, { "name": "doctrine/instantiator", - "version": "1.4.0", + "version": "1.4.1", "source": { "type": "git", "url": "https://github.com/doctrine/instantiator.git", - "reference": "d56bf6102915de5702778fe20f2de3b2fe570b5b" + "reference": "10dcfce151b967d20fde1b34ae6640712c3891bc" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/doctrine/instantiator/zipball/d56bf6102915de5702778fe20f2de3b2fe570b5b", - "reference": "d56bf6102915de5702778fe20f2de3b2fe570b5b", + "url": "https://api.github.com/repos/doctrine/instantiator/zipball/10dcfce151b967d20fde1b34ae6640712c3891bc", + "reference": "10dcfce151b967d20fde1b34ae6640712c3891bc", "shasum": "" }, "require": { "php": "^7.1 || ^8.0" }, "require-dev": { - "doctrine/coding-standard": "^8.0", + "doctrine/coding-standard": "^9", "ext-pdo": "*", "ext-phar": "*", - "phpbench/phpbench": "^0.13 || 1.0.0-alpha2", - "phpstan/phpstan": "^0.12", - "phpstan/phpstan-phpunit": "^0.12", - "phpunit/phpunit": "^7.0 || ^8.0 || ^9.0" + "phpbench/phpbench": "^0.16 || ^1", + "phpstan/phpstan": "^1.4", + "phpstan/phpstan-phpunit": "^1", + "phpunit/phpunit": "^7.5 || ^8.5 || ^9.5", + "vimeo/psalm": "^4.22" }, "type": "library", "autoload": { @@ -331,7 +332,7 @@ ], "support": { "issues": "https://github.com/doctrine/instantiator/issues", - "source": "https://github.com/doctrine/instantiator/tree/1.4.0" + "source": "https://github.com/doctrine/instantiator/tree/1.4.1" }, "funding": [ { @@ -347,7 +348,7 @@ "type": "tidelift" } ], - "time": "2020-11-10T18:47:58+00:00" + "time": "2022-03-03T08:28:38+00:00" }, { "name": "erusev/parsedown", @@ -452,20 +453,21 @@ }, { "name": "johnbillion/wp-hooks-generator", - "version": "0.7.0", + "version": "0.9.0", "source": { "type": "git", - "url": "https://github.com/johnbillion/wp-hooks-generator.git", - "reference": "26027e46d5396afbeb5ed18b0cd6a75deb2f2996" + "url": "https://github.com/wp-hooks/generator.git", + "reference": "6c7f173d85452db52a59a3a6bb943cbe7d845cde" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/johnbillion/wp-hooks-generator/zipball/26027e46d5396afbeb5ed18b0cd6a75deb2f2996", - "reference": "26027e46d5396afbeb5ed18b0cd6a75deb2f2996", + "url": "https://api.github.com/repos/wp-hooks/generator/zipball/6c7f173d85452db52a59a3a6bb943cbe7d845cde", + "reference": "6c7f173d85452db52a59a3a6bb943cbe7d845cde", "shasum": "" }, "require": { - "johnbillion/wp-parser-lib": "^1", + "ext-libxml": "*", + "johnbillion/wp-parser-lib": "^1.3.0", "php": ">=7" }, "require-dev": { @@ -488,29 +490,30 @@ ], "description": "Generates a JSON representation of the WordPress actions and filters in your code", "support": { - "issues": "https://github.com/johnbillion/wp-hooks-generator/issues", - "source": "https://github.com/johnbillion/wp-hooks-generator/tree/0.7.0" + "issues": "https://github.com/wp-hooks/generator/issues", + "source": "https://github.com/wp-hooks/generator/tree/0.9.0" }, "funding": [ { - "url": "https://github.com/johnbillion", + "url": "https://github.com/sponsors/johnbillion", "type": "github" } ], - "time": "2021-11-10T17:22:21+00:00" + "abandoned": "wp-hooks/generator", + "time": "2022-07-03T12:35:07+00:00" }, { "name": "johnbillion/wp-parser-lib", - "version": "1.1.0", + "version": "1.3.0", "source": { "type": "git", "url": "https://github.com/johnbillion/wp-parser-lib.git", - "reference": "4fd13bebd7fc7ac6e3ab9a1abc95afb6d6447647" + "reference": "46ed07365f8bd22f1edc828f9cfeed0c0f2c7d07" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/johnbillion/wp-parser-lib/zipball/4fd13bebd7fc7ac6e3ab9a1abc95afb6d6447647", - "reference": "4fd13bebd7fc7ac6e3ab9a1abc95afb6d6447647", + "url": "https://api.github.com/repos/johnbillion/wp-parser-lib/zipball/46ed07365f8bd22f1edc828f9cfeed0c0f2c7d07", + "reference": "46ed07365f8bd22f1edc828f9cfeed0c0f2c7d07", "shasum": "" }, "require": { @@ -521,11 +524,11 @@ }, "type": "library", "autoload": { - "classmap": [ - "lib" - ], "files": [ "lib/runner.php" + ], + "classmap": [ + "lib" ] }, "notification-url": "https://packagist.org/downloads/", @@ -550,22 +553,22 @@ ], "support": { "issues": "https://github.com/johnbillion/wp-parser-lib/issues", - "source": "https://github.com/johnbillion/wp-parser-lib/tree/1.1.0" + "source": "https://github.com/johnbillion/wp-parser-lib/tree/1.3.0" }, - "time": "2021-01-06T22:49:12+00:00" + "time": "2022-01-27T13:57:08+00:00" }, { "name": "mockery/mockery", - "version": "1.4.4", + "version": "1.5.0", "source": { "type": "git", "url": "https://github.com/mockery/mockery.git", - "reference": "e01123a0e847d52d186c5eb4b9bf58b0c6d00346" + "reference": "c10a5f6e06fc2470ab1822fa13fa2a7380f8fbac" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/mockery/mockery/zipball/e01123a0e847d52d186c5eb4b9bf58b0c6d00346", - "reference": "e01123a0e847d52d186c5eb4b9bf58b0c6d00346", + "url": "https://api.github.com/repos/mockery/mockery/zipball/c10a5f6e06fc2470ab1822fa13fa2a7380f8fbac", + "reference": "c10a5f6e06fc2470ab1822fa13fa2a7380f8fbac", "shasum": "" }, "require": { @@ -622,43 +625,44 @@ ], "support": { "issues": "https://github.com/mockery/mockery/issues", - "source": "https://github.com/mockery/mockery/tree/1.4.4" + "source": "https://github.com/mockery/mockery/tree/1.5.0" }, - "time": "2021-09-13T15:28:59+00:00" + "time": "2022-01-20T13:18:17+00:00" }, { "name": "myclabs/deep-copy", - "version": "1.10.2", + "version": "1.11.0", "source": { "type": "git", "url": "https://github.com/myclabs/DeepCopy.git", - "reference": "776f831124e9c62e1a2c601ecc52e776d8bb7220" + "reference": "14daed4296fae74d9e3201d2c4925d1acb7aa614" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/myclabs/DeepCopy/zipball/776f831124e9c62e1a2c601ecc52e776d8bb7220", - "reference": "776f831124e9c62e1a2c601ecc52e776d8bb7220", + "url": "https://api.github.com/repos/myclabs/DeepCopy/zipball/14daed4296fae74d9e3201d2c4925d1acb7aa614", + "reference": "14daed4296fae74d9e3201d2c4925d1acb7aa614", "shasum": "" }, "require": { "php": "^7.1 || ^8.0" }, - "replace": { - "myclabs/deep-copy": "self.version" + "conflict": { + "doctrine/collections": "<1.6.8", + "doctrine/common": "<2.13.3 || >=3,<3.2.2" }, "require-dev": { - "doctrine/collections": "^1.0", - "doctrine/common": "^2.6", - "phpunit/phpunit": "^7.1" + "doctrine/collections": "^1.6.8", + "doctrine/common": "^2.13.3 || ^3.2.2", + "phpunit/phpunit": "^7.5.20 || ^8.5.23 || ^9.5.13" }, "type": "library", "autoload": { - "psr-4": { - "DeepCopy\\": "src/DeepCopy/" - }, "files": [ "src/DeepCopy/deep_copy.php" - ] + ], + "psr-4": { + "DeepCopy\\": "src/DeepCopy/" + } }, "notification-url": "https://packagist.org/downloads/", "license": [ @@ -674,7 +678,7 @@ ], "support": { "issues": "https://github.com/myclabs/DeepCopy/issues", - "source": "https://github.com/myclabs/DeepCopy/tree/1.10.2" + "source": "https://github.com/myclabs/DeepCopy/tree/1.11.0" }, "funding": [ { @@ -682,7 +686,7 @@ "type": "tidelift" } ], - "time": "2020-11-13T09:40:50+00:00" + "time": "2022-03-03T13:19:32+00:00" }, { "name": "nikic/php-parser", @@ -1269,16 +1273,16 @@ }, { "name": "phpunit/php-file-iterator", - "version": "3.0.5", + "version": "3.0.6", "source": { "type": "git", "url": "https://github.com/sebastianbergmann/php-file-iterator.git", - "reference": "aa4be8575f26070b100fccb67faabb28f21f66f8" + "reference": "cf1c2e7c203ac650e352f4cc675a7021e7d1b3cf" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/php-file-iterator/zipball/aa4be8575f26070b100fccb67faabb28f21f66f8", - "reference": "aa4be8575f26070b100fccb67faabb28f21f66f8", + "url": "https://api.github.com/repos/sebastianbergmann/php-file-iterator/zipball/cf1c2e7c203ac650e352f4cc675a7021e7d1b3cf", + "reference": "cf1c2e7c203ac650e352f4cc675a7021e7d1b3cf", "shasum": "" }, "require": { @@ -1317,7 +1321,7 @@ ], "support": { "issues": "https://github.com/sebastianbergmann/php-file-iterator/issues", - "source": "https://github.com/sebastianbergmann/php-file-iterator/tree/3.0.5" + "source": "https://github.com/sebastianbergmann/php-file-iterator/tree/3.0.6" }, "funding": [ { @@ -1325,7 +1329,7 @@ "type": "github" } ], - "time": "2020-09-28T05:57:25+00:00" + "time": "2021-12-02T12:48:52+00:00" }, { "name": "phpunit/php-invoker", @@ -1629,11 +1633,11 @@ } }, "autoload": { - "classmap": [ - "src/" - ], "files": [ "src/Framework/Assert/Functions.php" + ], + "classmap": [ + "src/" ] }, "notification-url": "https://packagist.org/downloads/", @@ -1973,16 +1977,16 @@ }, { "name": "sebastian/environment", - "version": "5.1.3", + "version": "5.1.4", "source": { "type": "git", "url": "https://github.com/sebastianbergmann/environment.git", - "reference": "388b6ced16caa751030f6a69e588299fa09200ac" + "reference": "1b5dff7bb151a4db11d49d90e5408e4e938270f7" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/environment/zipball/388b6ced16caa751030f6a69e588299fa09200ac", - "reference": "388b6ced16caa751030f6a69e588299fa09200ac", + "url": "https://api.github.com/repos/sebastianbergmann/environment/zipball/1b5dff7bb151a4db11d49d90e5408e4e938270f7", + "reference": "1b5dff7bb151a4db11d49d90e5408e4e938270f7", "shasum": "" }, "require": { @@ -2024,7 +2028,7 @@ ], "support": { "issues": "https://github.com/sebastianbergmann/environment/issues", - "source": "https://github.com/sebastianbergmann/environment/tree/5.1.3" + "source": "https://github.com/sebastianbergmann/environment/tree/5.1.4" }, "funding": [ { @@ -2032,20 +2036,20 @@ "type": "github" } ], - "time": "2020-09-28T05:52:38+00:00" + "time": "2022-04-03T09:37:03+00:00" }, { "name": "sebastian/exporter", - "version": "4.0.3", + "version": "4.0.4", "source": { "type": "git", "url": "https://github.com/sebastianbergmann/exporter.git", - "reference": "d89cc98761b8cb5a1a235a6b703ae50d34080e65" + "reference": "65e8b7db476c5dd267e65eea9cab77584d3cfff9" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/sebastianbergmann/exporter/zipball/d89cc98761b8cb5a1a235a6b703ae50d34080e65", - "reference": "d89cc98761b8cb5a1a235a6b703ae50d34080e65", + "url": "https://api.github.com/repos/sebastianbergmann/exporter/zipball/65e8b7db476c5dd267e65eea9cab77584d3cfff9", + "reference": "65e8b7db476c5dd267e65eea9cab77584d3cfff9", "shasum": "" }, "require": { @@ -2094,14 +2098,14 @@ } ], "description": "Provides the functionality to export PHP variables for visualization", - "homepage": "http://www.github.com/sebastianbergmann/exporter", + "homepage": "https://www.github.com/sebastianbergmann/exporter", "keywords": [ "export", "exporter" ], "support": { "issues": "https://github.com/sebastianbergmann/exporter/issues", - "source": "https://github.com/sebastianbergmann/exporter/tree/4.0.3" + "source": "https://github.com/sebastianbergmann/exporter/tree/4.0.4" }, "funding": [ { @@ -2109,7 +2113,7 @@ "type": "github" } ], - "time": "2020-09-28T05:24:23+00:00" + "time": "2021-11-11T14:18:36+00:00" }, { "name": "sebastian/global-state", @@ -2759,16 +2763,16 @@ }, { "name": "yoast/phpunit-polyfills", - "version": "1.0.2", + "version": "1.0.3", "source": { "type": "git", "url": "https://github.com/Yoast/PHPUnit-Polyfills.git", - "reference": "1a582ab1d91e86aa450340c4d35631a85314ff9f" + "reference": "5ea3536428944955f969bc764bbe09738e151ada" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/Yoast/PHPUnit-Polyfills/zipball/1a582ab1d91e86aa450340c4d35631a85314ff9f", - "reference": "1a582ab1d91e86aa450340c4d35631a85314ff9f", + "url": "https://api.github.com/repos/Yoast/PHPUnit-Polyfills/zipball/5ea3536428944955f969bc764bbe09738e151ada", + "reference": "5ea3536428944955f969bc764bbe09738e151ada", "shasum": "" }, "require": { @@ -2816,7 +2820,7 @@ "issues": "https://github.com/Yoast/PHPUnit-Polyfills/issues", "source": "https://github.com/Yoast/PHPUnit-Polyfills" }, - "time": "2021-10-03T08:40:26+00:00" + "time": "2021-11-23T01:37:03+00:00" } ], "aliases": [], diff --git a/docs/README.md b/docs/README.md index e14ac81e37e..c9d8cdfc9c8 100644 --- a/docs/README.md +++ b/docs/README.md @@ -149,3 +149,4 @@ The following tutorials from [developer.woocommerce.com](https://developer.wooco 🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/readme.md) + diff --git a/docs/contributors/README.md b/docs/contributors/README.md index d256dc943cd..2991aa4bbae 100644 --- a/docs/contributors/README.md +++ b/docs/contributors/README.md @@ -18,7 +18,7 @@ This folder contains documentation for developers and contributors looking to ge [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/contributors/README.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/contributors/README.md) diff --git a/docs/contributors/components.md b/docs/contributors/components.md index fa9abd58bf3..a24e1977007 100644 --- a/docs/contributors/components.md +++ b/docs/contributors/components.md @@ -48,6 +48,7 @@ If you're stuck, copy source of an existing story to get started. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/contributors/components.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/contributors/components.md) + diff --git a/docs/contributors/contributing/README.md b/docs/contributors/contributing/README.md index 55d0b624579..62fb54c25aa 100644 --- a/docs/contributors/contributing/README.md +++ b/docs/contributors/contributing/README.md @@ -18,6 +18,7 @@ This folder contains documentation for developers and contributors looking to ge [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/contributors/README.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/contributors/contributing/README.md) + diff --git a/docs/contributors/contributing/block-assets.md b/docs/contributors/contributing/block-assets.md index cfddd45939b..824748f0196 100644 --- a/docs/contributors/contributing/block-assets.md +++ b/docs/contributors/contributing/block-assets.md @@ -95,6 +95,7 @@ wc.wcSettings.getSetting( 'key' ); [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/contributors/block-assets.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/contributors/contributing/block-assets.md) + diff --git a/docs/contributors/contributing/coding-guidelines.md b/docs/contributors/contributing/coding-guidelines.md index 2543712cb6b..f55f5c624e0 100644 --- a/docs/contributors/contributing/coding-guidelines.md +++ b/docs/contributors/contributing/coding-guidelines.md @@ -179,6 +179,7 @@ Notice in the worst case scenario we would have increased selector specificity b [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/contributors/coding-guidelines.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/contributors/contributing/coding-guidelines.md) + diff --git a/docs/contributors/contributing/css-build-system.md b/docs/contributors/contributing/css-build-system.md index 6db18524f1d..67fbf1a8ff3 100644 --- a/docs/contributors/contributing/css-build-system.md +++ b/docs/contributors/contributing/css-build-system.md @@ -42,6 +42,7 @@ Webpack config is split between several files, some relevant ones for the CSS bu [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/contributors/css-build-system.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/contributors/contributing/css-build-system.md) + diff --git a/docs/contributors/contributing/documentation-guidelines.md b/docs/contributors/contributing/documentation-guidelines.md index aef44785bc9..1daca2aa9cb 100644 --- a/docs/contributors/contributing/documentation-guidelines.md +++ b/docs/contributors/contributing/documentation-guidelines.md @@ -165,6 +165,7 @@ When referencing other documentations, the corresponding document should be link [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/contributors/documentation-guidelines.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/contributors/contributing/documentation-guidelines.md) + diff --git a/docs/contributors/contributing/folder-structure.md b/docs/contributors/contributing/folder-structure.md index deef9ce84f7..e3adfe01a93 100644 --- a/docs/contributors/contributing/folder-structure.md +++ b/docs/contributors/contributing/folder-structure.md @@ -195,6 +195,7 @@ This file is inspired by the great work of @JustinyAhin and @gziolo in + diff --git a/docs/contributors/contributing/getting-started.md b/docs/contributors/contributing/getting-started.md index 46fe3c47911..be57c1c4326 100644 --- a/docs/contributors/contributing/getting-started.md +++ b/docs/contributors/contributing/getting-started.md @@ -156,6 +156,7 @@ To find out more about how to run automated JavaScript tests, check out the docu [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/contributors/getting-started.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/contributors/contributing/getting-started.md) + diff --git a/docs/contributors/contributing/javascript-build-system.md b/docs/contributors/contributing/javascript-build-system.md index 45e6bb6a2f3..caa7ace635c 100644 --- a/docs/contributors/contributing/javascript-build-system.md +++ b/docs/contributors/contributing/javascript-build-system.md @@ -72,6 +72,7 @@ Webpack config is split between several files: [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/contributors/javascript-build-system.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/contributors/contributing/javascript-build-system.md) + diff --git a/docs/contributors/contributing/javascript-testing.md b/docs/contributors/contributing/javascript-testing.md index dd3930b4e77..1db9410a351 100644 --- a/docs/contributors/contributing/javascript-testing.md +++ b/docs/contributors/contributing/javascript-testing.md @@ -140,6 +140,7 @@ In `./tests/e2e/specs`, verify for conditions like `if ( process.env.WP_VERSION [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/contributors/javascript-testing.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/contributors/contributing/javascript-testing.md) + diff --git a/docs/contributors/contributing/storybook-and-components.md b/docs/contributors/contributing/storybook-and-components.md index 19ebb692eb1..ba272102724 100644 --- a/docs/contributors/contributing/storybook-and-components.md +++ b/docs/contributors/contributing/storybook-and-components.md @@ -50,6 +50,7 @@ If you're stuck, copy source of an existing story to get started. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/contributors/storybook-and-components.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/contributors/contributing/storybook-and-components.md) + diff --git a/docs/designers/theming/README.md b/docs/designers/theming/README.md index a01eac6eb72..a24fec9e910 100644 --- a/docs/designers/theming/README.md +++ b/docs/designers/theming/README.md @@ -86,6 +86,7 @@ WooCommerce Blocks avoids using legacy unprefixed classes as much as possible. H [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/theming/product-grid-270.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/designers/theming/README.md) + diff --git a/docs/designers/theming/all-products-and-filters.md b/docs/designers/theming/all-products-and-filters.md index feba156e76e..c13f5efe641 100644 --- a/docs/designers/theming/all-products-and-filters.md +++ b/docs/designers/theming/all-products-and-filters.md @@ -34,6 +34,7 @@ Notice the code snippet above uses a CSS custom property, so the default color m [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/theming/product-grid-270.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/designers/theming/all-products-and-filters.md) + diff --git a/docs/designers/theming/cart-and-checkout.md b/docs/designers/theming/cart-and-checkout.md index 01c934f7ce0..a05fb09391d 100644 --- a/docs/designers/theming/cart-and-checkout.md +++ b/docs/designers/theming/cart-and-checkout.md @@ -84,6 +84,7 @@ By default, it uses a combination of black and white borders and shadows so it h [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/theming/product-grid-270.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/designers/theming/cart-and-checkout.md) + diff --git a/docs/designers/theming/class-names-update-280.md b/docs/designers/theming/class-names-update-280.md index af18655f877..0d8a8eb9e74 100644 --- a/docs/designers/theming/class-names-update-280.md +++ b/docs/designers/theming/class-names-update-280.md @@ -94,6 +94,7 @@ For example, given that `wc-block-error` changed to `wc-block-components-error` [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/theming/product-grid-270.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/designers/theming/class-names-update-280.md) + diff --git a/docs/designers/theming/class-names-update-330.md b/docs/designers/theming/class-names-update-330.md index d90cfd8ced4..53d452411b5 100644 --- a/docs/designers/theming/class-names-update-330.md +++ b/docs/designers/theming/class-names-update-330.md @@ -23,6 +23,7 @@ In [WooCommerce Blocks 3.3.0](https://developer.woocommerce.com/2020/09/02/wooco [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/theming/product-grid-270.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/designers/theming/class-names-update-330.md) + diff --git a/docs/designers/theming/class-names-update-340.md b/docs/designers/theming/class-names-update-340.md index a0e3dfd215e..e4b56b87df8 100644 --- a/docs/designers/theming/class-names-update-340.md +++ b/docs/designers/theming/class-names-update-340.md @@ -14,6 +14,7 @@ In [WooCommerce Blocks 3.4.0](https://developer.woocommerce.com/2020/09/15/wooco [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/theming/product-grid-270.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/designers/theming/class-names-update-340.md) + diff --git a/docs/designers/theming/class-names-update-460.md b/docs/designers/theming/class-names-update-460.md index abc0634cdc9..5862a1a47d0 100644 --- a/docs/designers/theming/class-names-update-460.md +++ b/docs/designers/theming/class-names-update-460.md @@ -17,6 +17,7 @@ In [WooCommerce Blocks 4.6.0](https://developer.woocommerce.com/2021/03/02/wooco [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/theming/product-grid-270.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/designers/theming/class-names-update-460.md) + diff --git a/docs/designers/theming/product-grid-270.md b/docs/designers/theming/product-grid-270.md index e637943e1d4..7c838685aee 100644 --- a/docs/designers/theming/product-grid-270.md +++ b/docs/designers/theming/product-grid-270.md @@ -49,6 +49,7 @@ _All Products_ block was updated so prices follow the same layout as the other p [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/theming/product-grid-270.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/designers/theming/product-grid-270.md) + diff --git a/docs/internal-developers/block-client-apis/README.md b/docs/internal-developers/block-client-apis/README.md index 2805d2016cc..e7f2d9a1ae0 100644 --- a/docs/internal-developers/block-client-apis/README.md +++ b/docs/internal-developers/block-client-apis/README.md @@ -16,6 +16,7 @@ For more details about extensibility points in the blocks, you can reference the [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/block-client-apis/README.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/block-client-apis/README.md) + diff --git a/docs/internal-developers/block-client-apis/checkout/checkout-api.md b/docs/internal-developers/block-client-apis/checkout/checkout-api.md index 8eab6de7e4c..3a91eab6631 100644 --- a/docs/internal-developers/block-client-apis/checkout/checkout-api.md +++ b/docs/internal-developers/block-client-apis/checkout/checkout-api.md @@ -120,6 +120,7 @@ The contract is established through props fed to the payment method components v [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/block-client-apis/checkout/checkout-api.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/block-client-apis/checkout/checkout-api.md) + diff --git a/docs/internal-developers/block-client-apis/checkout/checkout-flow-and-events.md b/docs/internal-developers/block-client-apis/checkout/checkout-flow-and-events.md index f21cea835eb..90c1cd653a2 100644 --- a/docs/internal-developers/block-client-apis/checkout/checkout-flow-and-events.md +++ b/docs/internal-developers/block-client-apis/checkout/checkout-flow-and-events.md @@ -482,6 +482,7 @@ This event emitter doesn't care about any registered observer response and will [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/extensibility/checkout-flow-and-events.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/block-client-apis/checkout/checkout-flow-and-events.md) + diff --git a/docs/internal-developers/block-client-apis/notices.md b/docs/internal-developers/block-client-apis/notices.md index cab47ce6dfa..5467ddd4a38 100644 --- a/docs/internal-developers/block-client-apis/notices.md +++ b/docs/internal-developers/block-client-apis/notices.md @@ -284,6 +284,7 @@ const CheckoutProcessor = () => { [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/block-client-apis/notices.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/block-client-apis/notices.md) + diff --git a/docs/internal-developers/blocks/README.md b/docs/internal-developers/blocks/README.md index 95f05c924fd..2600299a6ff 100644 --- a/docs/internal-developers/blocks/README.md +++ b/docs/internal-developers/blocks/README.md @@ -13,6 +13,7 @@ This folder contains documentation for specific Blocks and Blocks functionality. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/blocks/README.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/blocks/README.md) + diff --git a/docs/internal-developers/blocks/feature-flags-and-experimental-interfaces.md b/docs/internal-developers/blocks/feature-flags-and-experimental-interfaces.md index 4dc6d5453fa..7612c4bf82e 100644 --- a/docs/internal-developers/blocks/feature-flags-and-experimental-interfaces.md +++ b/docs/internal-developers/blocks/feature-flags-and-experimental-interfaces.md @@ -154,6 +154,7 @@ Current list of events: [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/blocks/feature-flags-and-experimental-interfaces.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/blocks/feature-flags-and-experimental-interfaces.md) + diff --git a/docs/internal-developers/blocks/stock-reservation.md b/docs/internal-developers/blocks/stock-reservation.md index 62859f7434e..c049e97d8e9 100644 --- a/docs/internal-developers/blocks/stock-reservation.md +++ b/docs/internal-developers/blocks/stock-reservation.md @@ -107,6 +107,7 @@ You can see that in both Checkouts, if stock cannot be reserved for all items in [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/blocks/stock-reservation.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/blocks/stock-reservation.md) + diff --git a/docs/internal-developers/templates/README.md b/docs/internal-developers/templates/README.md index a7aa56a9125..5ef2bdb8e87 100644 --- a/docs/internal-developers/templates/README.md +++ b/docs/internal-developers/templates/README.md @@ -61,6 +61,7 @@ The BlockTemplateController.php is primarily responsible for hooking into both W [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/templates/README.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/templates/README.md) + diff --git a/docs/internal-developers/templates/block-template-controller.md b/docs/internal-developers/templates/block-template-controller.md index 9694f859c82..ab191723f40 100644 --- a/docs/internal-developers/templates/block-template-controller.md +++ b/docs/internal-developers/templates/block-template-controller.md @@ -91,6 +91,7 @@ Void. This method does not return a value but rather sets up hooks to render blo [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/templates/block-template-controller.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/templates/block-template-controller.md) + diff --git a/docs/internal-developers/templates/classic-template.md b/docs/internal-developers/templates/classic-template.md index 42c5bdc9a87..dc4829f1255 100644 --- a/docs/internal-developers/templates/classic-template.md +++ b/docs/internal-developers/templates/classic-template.md @@ -16,6 +16,7 @@ From the `render()` method we inspect the `$attributes` object for a `template` [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/templates/classic-template.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/templates/classic-template.md) + diff --git a/docs/internal-developers/testing/README.md b/docs/internal-developers/testing/README.md index c807703d2e4..8e981d5f4e0 100644 --- a/docs/internal-developers/testing/README.md +++ b/docs/internal-developers/testing/README.md @@ -15,6 +15,7 @@ This folder contains documentation around manual testing of WooCommerce Blocks. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/README.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/README.md) + diff --git a/docs/internal-developers/testing/cart-checkout/README.md b/docs/internal-developers/testing/cart-checkout/README.md index d96bac3edb7..b262a1779a6 100644 --- a/docs/internal-developers/testing/cart-checkout/README.md +++ b/docs/internal-developers/testing/cart-checkout/README.md @@ -89,6 +89,7 @@ the Cart and Checkout shortcodes. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/cart-checkout/README.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/cart-checkout/README.md) + diff --git a/docs/internal-developers/testing/cart-checkout/compatibility.md b/docs/internal-developers/testing/cart-checkout/compatibility.md index 2c08ef1e47b..cc4c9559db0 100644 --- a/docs/internal-developers/testing/cart-checkout/compatibility.md +++ b/docs/internal-developers/testing/cart-checkout/compatibility.md @@ -24,6 +24,7 @@ Test the WooCommerce Blocks plugin against the versions as listed above. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/cart-checkout/cross-browser.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/cart-checkout/compatibility.md) + diff --git a/docs/internal-developers/testing/cart-checkout/coupons.md b/docs/internal-developers/testing/cart-checkout/coupons.md index 87b7d8ef847..8958a53842c 100644 --- a/docs/internal-developers/testing/cart-checkout/coupons.md +++ b/docs/internal-developers/testing/cart-checkout/coupons.md @@ -47,6 +47,7 @@ You will need to setup some types of coupon in order to test this. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/cart-checkout/coupons.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/cart-checkout/coupons.md) + diff --git a/docs/internal-developers/testing/cart-checkout/cross-browser.md b/docs/internal-developers/testing/cart-checkout/cross-browser.md index 18194754097..bcca5f9b832 100644 --- a/docs/internal-developers/testing/cart-checkout/cross-browser.md +++ b/docs/internal-developers/testing/cart-checkout/cross-browser.md @@ -15,7 +15,7 @@ The baseline for testing is: [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/cart-checkout/cross-browser.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/cart-checkout/cross-browser.md) diff --git a/docs/internal-developers/testing/cart-checkout/editor.md b/docs/internal-developers/testing/cart-checkout/editor.md index 7b18021e841..bbef7c0d759 100644 --- a/docs/internal-developers/testing/cart-checkout/editor.md +++ b/docs/internal-developers/testing/cart-checkout/editor.md @@ -17,6 +17,7 @@ [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/cart-checkout/editor.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/cart-checkout/editor.md) + diff --git a/docs/internal-developers/testing/cart-checkout/general-flow.md b/docs/internal-developers/testing/cart-checkout/general-flow.md index 2ced882d6cb..415c636b04c 100644 --- a/docs/internal-developers/testing/cart-checkout/general-flow.md +++ b/docs/internal-developers/testing/cart-checkout/general-flow.md @@ -29,6 +29,7 @@ This is a general flow of the main functionality of the blocks without going too [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/cart-checkout/general-flow.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/cart-checkout/general-flow.md) + diff --git a/docs/internal-developers/testing/cart-checkout/items.md b/docs/internal-developers/testing/cart-checkout/items.md index a77d8f54fb5..144b69abc3f 100644 --- a/docs/internal-developers/testing/cart-checkout/items.md +++ b/docs/internal-developers/testing/cart-checkout/items.md @@ -34,6 +34,7 @@ [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/cart-checkout/items.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/cart-checkout/items.md) + diff --git a/docs/internal-developers/testing/cart-checkout/payment.md b/docs/internal-developers/testing/cart-checkout/payment.md index 498824f6e6b..1c376125def 100644 --- a/docs/internal-developers/testing/cart-checkout/payment.md +++ b/docs/internal-developers/testing/cart-checkout/payment.md @@ -53,6 +53,7 @@ If you have a payment method available: [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/cart-checkout/payment.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/cart-checkout/payment.md) + diff --git a/docs/internal-developers/testing/cart-checkout/shipping.md b/docs/internal-developers/testing/cart-checkout/shipping.md index 36c58b0f456..18be93aa8ff 100644 --- a/docs/internal-developers/testing/cart-checkout/shipping.md +++ b/docs/internal-developers/testing/cart-checkout/shipping.md @@ -49,6 +49,7 @@ [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/cart-checkout/shipping.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/cart-checkout/shipping.md) + diff --git a/docs/internal-developers/testing/cart-checkout/taxes.md b/docs/internal-developers/testing/cart-checkout/taxes.md index cfae614e6d6..e10c1e8194d 100644 --- a/docs/internal-developers/testing/cart-checkout/taxes.md +++ b/docs/internal-developers/testing/cart-checkout/taxes.md @@ -30,6 +30,7 @@ [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/cart-checkout/taxes.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/cart-checkout/taxes.md) + diff --git a/docs/internal-developers/testing/releases/260.md b/docs/internal-developers/testing/releases/260.md index 66fa8d4ead0..b3bc55c650f 100644 --- a/docs/internal-developers/testing/releases/260.md +++ b/docs/internal-developers/testing/releases/260.md @@ -128,6 +128,7 @@ Support was added for showing category images in the Product Categories block. T [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/260.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/260.md) + diff --git a/docs/internal-developers/testing/releases/261.md b/docs/internal-developers/testing/releases/261.md index 73eb45247a2..c895fbb8593 100644 --- a/docs/internal-developers/testing/releases/261.md +++ b/docs/internal-developers/testing/releases/261.md @@ -24,6 +24,7 @@ _Note: assuming you are using a development site where you are okay with losing [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/261.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/261.md) + diff --git a/docs/internal-developers/testing/releases/270.md b/docs/internal-developers/testing/releases/270.md index 165e4443c29..227778a234b 100644 --- a/docs/internal-developers/testing/releases/270.md +++ b/docs/internal-developers/testing/releases/270.md @@ -106,6 +106,7 @@ You'll need to be logged in with a user that has saved payment methods. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/270.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/270.md) + diff --git a/docs/internal-developers/testing/releases/271.md b/docs/internal-developers/testing/releases/271.md index cccb8c658ff..2b5b27f9dbb 100644 --- a/docs/internal-developers/testing/releases/271.md +++ b/docs/internal-developers/testing/releases/271.md @@ -25,6 +25,7 @@ Zip file for testing: [woocommerce-gutenberg-products-block.zip](https://github. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/271.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/271.md) + diff --git a/docs/internal-developers/testing/releases/272.md b/docs/internal-developers/testing/releases/272.md index b5140a47a3c..71c1d9e2e8d 100644 --- a/docs/internal-developers/testing/releases/272.md +++ b/docs/internal-developers/testing/releases/272.md @@ -43,6 +43,7 @@ There are PHPUnit tests covering behaviour as well (including catching errors). [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/272.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/272.md) + diff --git a/docs/internal-developers/testing/releases/280.md b/docs/internal-developers/testing/releases/280.md index 18ad587730f..7efa54e802a 100644 --- a/docs/internal-developers/testing/releases/280.md +++ b/docs/internal-developers/testing/releases/280.md @@ -88,6 +88,7 @@ Zip file for testing: [woocommerce-gutenberg-products-block.zip](https://github. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/280.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/280.md) + diff --git a/docs/internal-developers/testing/releases/290.md b/docs/internal-developers/testing/releases/290.md index d5f420c5c90..47be324229d 100644 --- a/docs/internal-developers/testing/releases/290.md +++ b/docs/internal-developers/testing/releases/290.md @@ -21,6 +21,7 @@ In some languages, the `State` and `Country` drop-down menus in the checkout blo [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/290.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/290.md) + diff --git a/docs/internal-developers/testing/releases/300.md b/docs/internal-developers/testing/releases/300.md index da4f5c3ec84..9bc346b7ffa 100644 --- a/docs/internal-developers/testing/releases/300.md +++ b/docs/internal-developers/testing/releases/300.md @@ -141,6 +141,7 @@ Confirm that other payment methods still work correctly. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/300.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/300.md) + diff --git a/docs/internal-developers/testing/releases/310.md b/docs/internal-developers/testing/releases/310.md index cd2ef8ac18b..be85e09738a 100644 --- a/docs/internal-developers/testing/releases/310.md +++ b/docs/internal-developers/testing/releases/310.md @@ -81,6 +81,7 @@ Note: The below blocks only need tested for the feature plugin [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/310.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/310.md) + diff --git a/docs/internal-developers/testing/releases/320.md b/docs/internal-developers/testing/releases/320.md index f0fbce88dbd..449d475b80d 100644 --- a/docs/internal-developers/testing/releases/320.md +++ b/docs/internal-developers/testing/releases/320.md @@ -119,6 +119,7 @@ You will need Product Add-ons extension to test this. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/320.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/320.md) + diff --git a/docs/internal-developers/testing/releases/330.md b/docs/internal-developers/testing/releases/330.md index 8d033a1212d..0332c248ad9 100644 --- a/docs/internal-developers/testing/releases/330.md +++ b/docs/internal-developers/testing/releases/330.md @@ -64,6 +64,7 @@ The following enhancements shipped in WooCommerce Blocks 3.1.0 but were missed i [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/330.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/330.md) + diff --git a/docs/internal-developers/testing/releases/340.md b/docs/internal-developers/testing/releases/340.md index 7b3e70d0517..b5d6d09648c 100644 --- a/docs/internal-developers/testing/releases/340.md +++ b/docs/internal-developers/testing/releases/340.md @@ -93,6 +93,7 @@ Testing this change basically means verifying there are no regressions: [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/340.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/340.md) + diff --git a/docs/internal-developers/testing/releases/350.md b/docs/internal-developers/testing/releases/350.md index ab8ae5aea13..f38e2eb9964 100644 --- a/docs/internal-developers/testing/releases/350.md +++ b/docs/internal-developers/testing/releases/350.md @@ -71,6 +71,7 @@ In order to save a payment method with a user. Enable the WooCommerce Stripe plu [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/350.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/350.md) + diff --git a/docs/internal-developers/testing/releases/360.md b/docs/internal-developers/testing/releases/360.md index 30d9b9dd4db..8112b21fd72 100644 --- a/docs/internal-developers/testing/releases/360.md +++ b/docs/internal-developers/testing/releases/360.md @@ -64,6 +64,7 @@ _After:_ [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/360.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/360.md) + diff --git a/docs/internal-developers/testing/releases/370.md b/docs/internal-developers/testing/releases/370.md index bd8e8493520..07ff175ca59 100644 --- a/docs/internal-developers/testing/releases/370.md +++ b/docs/internal-developers/testing/releases/370.md @@ -84,6 +84,7 @@ Test all blocks in editor/frontend and verify there are no evident issues with i [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/370.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/370.md) + diff --git a/docs/internal-developers/testing/releases/371.md b/docs/internal-developers/testing/releases/371.md index f021a1be36d..9a2aa9fdb2a 100644 --- a/docs/internal-developers/testing/releases/371.md +++ b/docs/internal-developers/testing/releases/371.md @@ -41,6 +41,7 @@ As an alternative to (1), could also hack the JS REST request to always send `sh [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/371.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/371.md) + diff --git a/docs/internal-developers/testing/releases/380.md b/docs/internal-developers/testing/releases/380.md index 0fa7ebbeba7..1c617ffc1ec 100644 --- a/docs/internal-developers/testing/releases/380.md +++ b/docs/internal-developers/testing/releases/380.md @@ -26,6 +26,7 @@ Moves the rendering of address fields to a single file so that PhoneNumber (new [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/380.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/380.md) + diff --git a/docs/internal-developers/testing/releases/390.md b/docs/internal-developers/testing/releases/390.md index b189e34053c..412e987c72e 100644 --- a/docs/internal-developers/testing/releases/390.md +++ b/docs/internal-developers/testing/releases/390.md @@ -139,6 +139,7 @@ In a device compatible with express payment methods and a site with Stripe payme [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/390.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/390.md) + diff --git a/docs/internal-developers/testing/releases/400.md b/docs/internal-developers/testing/releases/400.md index c479d9eda9c..a4a834f6255 100644 --- a/docs/internal-developers/testing/releases/400.md +++ b/docs/internal-developers/testing/releases/400.md @@ -111,6 +111,7 @@ Testing: [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/400.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/400.md) + diff --git a/docs/internal-developers/testing/releases/410.md b/docs/internal-developers/testing/releases/410.md index 174ca02217d..f871f0440f2 100644 --- a/docs/internal-developers/testing/releases/410.md +++ b/docs/internal-developers/testing/releases/410.md @@ -189,6 +189,7 @@ Validation via Checkout [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/410.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/410.md) + diff --git a/docs/internal-developers/testing/releases/420.md b/docs/internal-developers/testing/releases/420.md index 9ca274775ff..1c9d0409cb4 100644 --- a/docs/internal-developers/testing/releases/420.md +++ b/docs/internal-developers/testing/releases/420.md @@ -26,6 +26,7 @@ Zip file for testing: [woocommerce-gutenberg-products-block.zip](https://github. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/420.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/420.md) + diff --git a/docs/internal-developers/testing/releases/430.md b/docs/internal-developers/testing/releases/430.md index 193cfac99e4..802ece54d29 100644 --- a/docs/internal-developers/testing/releases/430.md +++ b/docs/internal-developers/testing/releases/430.md @@ -66,6 +66,7 @@ WC Product Add-Ons: [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/430.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/430.md) + diff --git a/docs/internal-developers/testing/releases/440.md b/docs/internal-developers/testing/releases/440.md index 7d8e81e8632..40bd3f87d66 100644 --- a/docs/internal-developers/testing/releases/440.md +++ b/docs/internal-developers/testing/releases/440.md @@ -102,6 +102,7 @@ This is a regression test due to the changes made for Subscriptions Integration. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/440.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/440.md) + diff --git a/docs/internal-developers/testing/releases/450.md b/docs/internal-developers/testing/releases/450.md index 96321235cf8..27540d66720 100644 --- a/docs/internal-developers/testing/releases/450.md +++ b/docs/internal-developers/testing/releases/450.md @@ -144,6 +144,7 @@ In the frontend: [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/450.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/450.md) + diff --git a/docs/internal-developers/testing/releases/452.md b/docs/internal-developers/testing/releases/452.md index d5460a08eae..a9c569ea7cb 100644 --- a/docs/internal-developers/testing/releases/452.md +++ b/docs/internal-developers/testing/releases/452.md @@ -27,6 +27,7 @@ No changes. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/452.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/452.md) + diff --git a/docs/internal-developers/testing/releases/460.md b/docs/internal-developers/testing/releases/460.md index 2deb9dff640..ee7963cc037 100644 --- a/docs/internal-developers/testing/releases/460.md +++ b/docs/internal-developers/testing/releases/460.md @@ -80,6 +80,7 @@ The following are related to various changes impacting some existing flows so ju [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/460.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/460.md) + diff --git a/docs/internal-developers/testing/releases/470.md b/docs/internal-developers/testing/releases/470.md index d83d553b62e..04068226b0c 100644 --- a/docs/internal-developers/testing/releases/470.md +++ b/docs/internal-developers/testing/releases/470.md @@ -131,6 +131,7 @@ The following are related to various changes impacting some existing flows so ju [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/470.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/470.md) + diff --git a/docs/internal-developers/testing/releases/480.md b/docs/internal-developers/testing/releases/480.md index 74673a3c466..9da974c721f 100644 --- a/docs/internal-developers/testing/releases/480.md +++ b/docs/internal-developers/testing/releases/480.md @@ -70,6 +70,7 @@ The following are related to various changes impacting some existing flows so ju [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/480.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/480.md) + diff --git a/docs/internal-developers/testing/releases/490.md b/docs/internal-developers/testing/releases/490.md index e0e5a436c12..fbac5f913b9 100644 --- a/docs/internal-developers/testing/releases/490.md +++ b/docs/internal-developers/testing/releases/490.md @@ -114,6 +114,7 @@ The following are related to various changes impacting some existing flows so ju [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/490.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/490.md) + diff --git a/docs/internal-developers/testing/releases/491.md b/docs/internal-developers/testing/releases/491.md index 76c4cec3daa..5166a88950f 100644 --- a/docs/internal-developers/testing/releases/491.md +++ b/docs/internal-developers/testing/releases/491.md @@ -20,6 +20,7 @@ Zip file for testing: [woocommerce-gutenberg-products-block.zip](https://github. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/491.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/491.md) + diff --git a/docs/internal-developers/testing/releases/500.md b/docs/internal-developers/testing/releases/500.md index eac0b0f6b5e..c52794ff592 100644 --- a/docs/internal-developers/testing/releases/500.md +++ b/docs/internal-developers/testing/releases/500.md @@ -63,6 +63,7 @@ Optionally, because this is difficult to achieve, if you tab to an add to cart b [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/500.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/500.md) + diff --git a/docs/internal-developers/testing/releases/510.md b/docs/internal-developers/testing/releases/510.md index 4772cf9a83d..e49ca1ba9c1 100644 --- a/docs/internal-developers/testing/releases/510.md +++ b/docs/internal-developers/testing/releases/510.md @@ -28,6 +28,7 @@ Test both guest and logged in scenarios for the following: [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/510.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/510.md) + diff --git a/docs/internal-developers/testing/releases/520.md b/docs/internal-developers/testing/releases/520.md index 6e5367153f1..e255cdf303f 100644 --- a/docs/internal-developers/testing/releases/520.md +++ b/docs/internal-developers/testing/releases/520.md @@ -149,6 +149,7 @@ Do the testing steps for the following widgets: Product Search, Product Categori [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/520.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/520.md) + diff --git a/docs/internal-developers/testing/releases/530.md b/docs/internal-developers/testing/releases/530.md index 61398c16fe3..2dac02adf73 100644 --- a/docs/internal-developers/testing/releases/530.md +++ b/docs/internal-developers/testing/releases/530.md @@ -57,6 +57,7 @@ Zip file for testing: [woocommerce-gutenberg-products-block.zip](https://github. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/530.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/530.md) + diff --git a/docs/internal-developers/testing/releases/531.md b/docs/internal-developers/testing/releases/531.md index 01ad98e2185..a5c1de5694b 100644 --- a/docs/internal-developers/testing/releases/531.md +++ b/docs/internal-developers/testing/releases/531.md @@ -47,6 +47,7 @@ Zip file for testing: [woocommerce-gutenberg-products-block.zip](https://github. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/531.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/531.md) + diff --git a/docs/internal-developers/testing/releases/532.md b/docs/internal-developers/testing/releases/532.md index e850ff9b8c3..ba12a76b3be 100644 --- a/docs/internal-developers/testing/releases/532.md +++ b/docs/internal-developers/testing/releases/532.md @@ -20,6 +20,7 @@ No changes. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/532.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/532.md) + diff --git a/docs/internal-developers/testing/releases/540.md b/docs/internal-developers/testing/releases/540.md index 19f2067bacb..92f52cfb3c4 100644 --- a/docs/internal-developers/testing/releases/540.md +++ b/docs/internal-developers/testing/releases/540.md @@ -43,6 +43,7 @@ To test this properly you'll need Stripe setup locally in sandbox mode. You can [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/540.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/540.md) + diff --git a/docs/internal-developers/testing/releases/550.md b/docs/internal-developers/testing/releases/550.md index 20d894c6493..f553cd27296 100644 --- a/docs/internal-developers/testing/releases/550.md +++ b/docs/internal-developers/testing/releases/550.md @@ -57,6 +57,7 @@ Test in the widget editor: [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/550.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/550.md) + diff --git a/docs/internal-developers/testing/releases/560.md b/docs/internal-developers/testing/releases/560.md index f8f6b78787b..f6bcd986815 100644 --- a/docs/internal-developers/testing/releases/560.md +++ b/docs/internal-developers/testing/releases/560.md @@ -81,6 +81,7 @@ View the pagination rendered on the all products block and confirm the symbol ma [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/560.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/560.md) + diff --git a/docs/internal-developers/testing/releases/570.md b/docs/internal-developers/testing/releases/570.md index d9d2aa1e86b..43cdf53e3f9 100644 --- a/docs/internal-developers/testing/releases/570.md +++ b/docs/internal-developers/testing/releases/570.md @@ -100,6 +100,7 @@ Test with the Twenty Twenty-One theme active. You'll need a test product and a t [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/570.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/570.md) + diff --git a/docs/internal-developers/testing/releases/571.md b/docs/internal-developers/testing/releases/571.md index 9108e2eb6e2..d39c5cfae48 100644 --- a/docs/internal-developers/testing/releases/571.md +++ b/docs/internal-developers/testing/releases/571.md @@ -18,6 +18,7 @@ With Storefront and WP 5.8: [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/571.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/571.md) + diff --git a/docs/internal-developers/testing/releases/572.md b/docs/internal-developers/testing/releases/572.md index cd6740c6cb9..1c4ccaab9b8 100644 --- a/docs/internal-developers/testing/releases/572.md +++ b/docs/internal-developers/testing/releases/572.md @@ -27,6 +27,7 @@ With Storefront active: [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/572.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/572.md) + diff --git a/docs/internal-developers/testing/releases/580.md b/docs/internal-developers/testing/releases/580.md index c51ffb23d4b..d876f133e49 100644 --- a/docs/internal-developers/testing/releases/580.md +++ b/docs/internal-developers/testing/releases/580.md @@ -65,6 +65,7 @@ A new block was introduced for filtering products by stock: [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/580.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/580.md) + diff --git a/docs/internal-developers/testing/releases/590.md b/docs/internal-developers/testing/releases/590.md index af91d4f8154..aff83917c6e 100644 --- a/docs/internal-developers/testing/releases/590.md +++ b/docs/internal-developers/testing/releases/590.md @@ -55,6 +55,7 @@ Because of experimental work done during this release, we need to ensure no regr [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/590.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/590.md) + diff --git a/docs/internal-developers/testing/releases/591.md b/docs/internal-developers/testing/releases/591.md index c256fe0c351..f043b68ad3b 100644 --- a/docs/internal-developers/testing/releases/591.md +++ b/docs/internal-developers/testing/releases/591.md @@ -18,6 +18,7 @@ Zip file for testing: [woocommerce-gutenberg-products-block.zip](https://github. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/591.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/591.md) + diff --git a/docs/internal-developers/testing/releases/600.md b/docs/internal-developers/testing/releases/600.md index 86e5975a5d2..b11529fe3ab 100644 --- a/docs/internal-developers/testing/releases/600.md +++ b/docs/internal-developers/testing/releases/600.md @@ -200,6 +200,7 @@ In a block-based theme (ie: TT1 Blocks) with Gutenberg enabled: [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/600.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/600.md) + diff --git a/docs/internal-developers/testing/releases/610.md b/docs/internal-developers/testing/releases/610.md index 1affb187572..ca6942a0c53 100644 --- a/docs/internal-developers/testing/releases/610.md +++ b/docs/internal-developers/testing/releases/610.md @@ -53,6 +53,7 @@ Zip file for testing: [woocommerce-gutenberg-products-block.zip](https://github. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/610.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/610.md) + diff --git a/docs/internal-developers/testing/releases/620.md b/docs/internal-developers/testing/releases/620.md index 86871df62e5..17eda497a49 100644 --- a/docs/internal-developers/testing/releases/620.md +++ b/docs/internal-developers/testing/releases/620.md @@ -64,6 +64,7 @@ Zip file for testing: [woocommerce-gutenberg-products-block.zip](https://github. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/620.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/620.md) + diff --git a/docs/internal-developers/testing/releases/630.md b/docs/internal-developers/testing/releases/630.md index 9861f005bd0..11041cb000d 100644 --- a/docs/internal-developers/testing/releases/630.md +++ b/docs/internal-developers/testing/releases/630.md @@ -117,6 +117,7 @@ Example of button text for the Hand-picked Products block: [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/630.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/630.md) + diff --git a/docs/internal-developers/testing/releases/631.md b/docs/internal-developers/testing/releases/631.md index 8f25526d581..4aa6669c6df 100644 --- a/docs/internal-developers/testing/releases/631.md +++ b/docs/internal-developers/testing/releases/631.md @@ -20,6 +20,7 @@ Zip file for testing: [woocommerce-gutenberg-products-block.zip](https://github. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/631.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/631.md) + diff --git a/docs/internal-developers/testing/releases/632.md b/docs/internal-developers/testing/releases/632.md index 1cf621ee696..4b5c888f6ee 100644 --- a/docs/internal-developers/testing/releases/632.md +++ b/docs/internal-developers/testing/releases/632.md @@ -19,6 +19,7 @@ Zip file for testing: [woocommerce-gutenberg-products-block.zip](https://github. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/632.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/632.md) + diff --git a/docs/internal-developers/testing/releases/633.md b/docs/internal-developers/testing/releases/633.md index 7d22cfc9043..0d2a8d9e627 100644 --- a/docs/internal-developers/testing/releases/633.md +++ b/docs/internal-developers/testing/releases/633.md @@ -19,6 +19,7 @@ Zip file for testing: [woocommerce-gutenberg-products-block.zip](https://github. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/633.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/633.md) + diff --git a/docs/internal-developers/testing/releases/640.md b/docs/internal-developers/testing/releases/640.md index d3e479acaa2..c8c43d27a78 100644 --- a/docs/internal-developers/testing/releases/640.md +++ b/docs/internal-developers/testing/releases/640.md @@ -73,6 +73,7 @@ wc.blocksCheckout.__experimentalRegisterCheckoutFilters( 'my-test-extension', { [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/640.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/640.md) + diff --git a/docs/internal-developers/testing/releases/650.md b/docs/internal-developers/testing/releases/650.md index 31498f1cbf9..7ca058cd8dd 100644 --- a/docs/internal-developers/testing/releases/650.md +++ b/docs/internal-developers/testing/releases/650.md @@ -38,6 +38,7 @@ Zip file for testing: [woocommerce-gutenberg-products-block.zip](https://github. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/650.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/650.md) + diff --git a/docs/internal-developers/testing/releases/660.md b/docs/internal-developers/testing/releases/660.md index f96c52149cf..2b31edc2aa3 100644 --- a/docs/internal-developers/testing/releases/660.md +++ b/docs/internal-developers/testing/releases/660.md @@ -153,6 +153,7 @@ This requires Stripe and a saved payment method. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/660.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/660.md) + diff --git a/docs/internal-developers/testing/releases/670.md b/docs/internal-developers/testing/releases/670.md index 07afc4e45f7..354e9ff1e96 100644 --- a/docs/internal-developers/testing/releases/670.md +++ b/docs/internal-developers/testing/releases/670.md @@ -92,6 +92,7 @@ On an store with no products add the Query Monitor extension, then: [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/670.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/670.md) + diff --git a/docs/internal-developers/testing/releases/671.md b/docs/internal-developers/testing/releases/671.md index 272f3e29fde..0069c20cd82 100644 --- a/docs/internal-developers/testing/releases/671.md +++ b/docs/internal-developers/testing/releases/671.md @@ -20,6 +20,7 @@ Zip file for testing: [woocommerce-gutenberg-products-block.zip](https://github. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/671.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/671.md) + diff --git a/docs/internal-developers/testing/releases/672.md b/docs/internal-developers/testing/releases/672.md index 157eeb0f5b6..b49ef50ab3e 100644 --- a/docs/internal-developers/testing/releases/672.md +++ b/docs/internal-developers/testing/releases/672.md @@ -21,6 +21,7 @@ Note: This is mostly regression testing. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/672.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/672.md) + diff --git a/docs/internal-developers/testing/releases/673.md b/docs/internal-developers/testing/releases/673.md index e622b2f3814..a53474c887d 100644 --- a/docs/internal-developers/testing/releases/673.md +++ b/docs/internal-developers/testing/releases/673.md @@ -16,6 +16,7 @@ Zip file for testing: [woocommerce-gutenberg-products-block.zip](https://github. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/673.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/673.md) + diff --git a/docs/internal-developers/testing/releases/680.md b/docs/internal-developers/testing/releases/680.md index a8eca77ff0e..4349ee457d9 100644 --- a/docs/internal-developers/testing/releases/680.md +++ b/docs/internal-developers/testing/releases/680.md @@ -185,6 +185,7 @@ Install the [Stripe Payment Method Extension](https://github.com/woocommerce/woo [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/680.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/680.md) + diff --git a/docs/internal-developers/testing/releases/690.md b/docs/internal-developers/testing/releases/690.md index 52dc966cf0f..b674edb619a 100644 --- a/docs/internal-developers/testing/releases/690.md +++ b/docs/internal-developers/testing/releases/690.md @@ -71,6 +71,7 @@ Zip file for testing: [woocommerce-gutenberg-products-block.zip](https://github. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/690.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/690.md) + diff --git a/docs/internal-developers/testing/releases/700.md b/docs/internal-developers/testing/releases/700.md index 9a4a72f695f..8357524c244 100644 --- a/docs/internal-developers/testing/releases/700.md +++ b/docs/internal-developers/testing/releases/700.md @@ -127,6 +127,7 @@ The following components have been converted to TypeScript, hence they benefit f [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/700.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/700.md) + diff --git a/docs/internal-developers/testing/releases/710.md b/docs/internal-developers/testing/releases/710.md index f5d207f4330..5129c8fba27 100644 --- a/docs/internal-developers/testing/releases/710.md +++ b/docs/internal-developers/testing/releases/710.md @@ -77,6 +77,7 @@ Zip file for testing: [woocommerce-gutenberg-products-block.zip](https://github. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/710.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/710.md) + diff --git a/docs/internal-developers/testing/releases/720.md b/docs/internal-developers/testing/releases/720.md index 6c0602789ec..dd9fba21b07 100644 --- a/docs/internal-developers/testing/releases/720.md +++ b/docs/internal-developers/testing/releases/720.md @@ -51,6 +51,7 @@ These instructions use WooCommerce Subscriptions as this is known to use several [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/720.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/720.md) + diff --git a/docs/internal-developers/testing/releases/721.md b/docs/internal-developers/testing/releases/721.md index a90f87602e8..9efe03684e8 100644 --- a/docs/internal-developers/testing/releases/721.md +++ b/docs/internal-developers/testing/releases/721.md @@ -18,6 +18,7 @@ Zip file for testing: [woocommerce-gutenberg-products-block.zip](https://github. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/721.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/721.md) + diff --git a/docs/internal-developers/testing/releases/722.md b/docs/internal-developers/testing/releases/722.md index cc857555930..e501594009d 100644 --- a/docs/internal-developers/testing/releases/722.md +++ b/docs/internal-developers/testing/releases/722.md @@ -17,6 +17,7 @@ [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/722.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/722.md) + diff --git a/docs/internal-developers/testing/releases/730.md b/docs/internal-developers/testing/releases/730.md index 94499f05f93..d8fefb6a376 100644 --- a/docs/internal-developers/testing/releases/730.md +++ b/docs/internal-developers/testing/releases/730.md @@ -73,6 +73,7 @@ With Twenty Twenty-Two: [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/730.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/730.md) + diff --git a/docs/internal-developers/testing/releases/740.md b/docs/internal-developers/testing/releases/740.md index 398d1653d5b..2c2022774eb 100644 --- a/docs/internal-developers/testing/releases/740.md +++ b/docs/internal-developers/testing/releases/740.md @@ -79,6 +79,7 @@ Zip file for testing: [woocommerce-gutenberg-products-block.zip](https://github. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/740.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/740.md) + diff --git a/docs/internal-developers/testing/releases/741.md b/docs/internal-developers/testing/releases/741.md index d9c706f37ab..572e6b0bfea 100644 --- a/docs/internal-developers/testing/releases/741.md +++ b/docs/internal-developers/testing/releases/741.md @@ -17,6 +17,7 @@ Zip file for testing: [woocommerce-gutenberg-products-block.zip](https://github. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/741.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/741.md) + diff --git a/docs/internal-developers/testing/releases/742.md b/docs/internal-developers/testing/releases/742.md index a4c4fe6c996..ed6522ec7a8 100644 --- a/docs/internal-developers/testing/releases/742.md +++ b/docs/internal-developers/testing/releases/742.md @@ -26,6 +26,7 @@ [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/742.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/742.md) + diff --git a/docs/internal-developers/testing/releases/750.md b/docs/internal-developers/testing/releases/750.md index 980dffe58a4..bfa43bb4eb1 100644 --- a/docs/internal-developers/testing/releases/750.md +++ b/docs/internal-developers/testing/releases/750.md @@ -153,6 +153,7 @@ ln -s ~/Desktop/woocommerce wp-content/plugins/woocommerce [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/750.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/750.md) + diff --git a/docs/internal-developers/testing/releases/760.md b/docs/internal-developers/testing/releases/760.md index e1cda90316b..bba9afb2171 100644 --- a/docs/internal-developers/testing/releases/760.md +++ b/docs/internal-developers/testing/releases/760.md @@ -157,6 +157,7 @@ Prerequisites: [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/760.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/760.md) + diff --git a/docs/internal-developers/testing/releases/761.md b/docs/internal-developers/testing/releases/761.md index 17871b23d35..ab9e698100c 100644 --- a/docs/internal-developers/testing/releases/761.md +++ b/docs/internal-developers/testing/releases/761.md @@ -42,6 +42,7 @@ Zip file for testing: [woocommerce-gutenberg-products-block.zip](https://github. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/760.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/761.md) + diff --git a/docs/internal-developers/testing/releases/762.md b/docs/internal-developers/testing/releases/762.md index b318780dc3a..ef147fb7c5c 100644 --- a/docs/internal-developers/testing/releases/762.md +++ b/docs/internal-developers/testing/releases/762.md @@ -21,6 +21,7 @@ Zip file for testing: [woocommerce-gutenberg-products-block.zip](https://github. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/760.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/762.md) + diff --git a/docs/internal-developers/testing/releases/770.md b/docs/internal-developers/testing/releases/770.md index e3d1d203870..e647213bc4b 100644 --- a/docs/internal-developers/testing/releases/770.md +++ b/docs/internal-developers/testing/releases/770.md @@ -41,6 +41,7 @@ Zip file for testing: [woocommerce-gutenberg-products-block.zip](https://github. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/760.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/770.md) + diff --git a/docs/internal-developers/testing/releases/780.md b/docs/internal-developers/testing/releases/780.md index ae2ee54cae5..d4cdfb2b0ed 100644 --- a/docs/internal-developers/testing/releases/780.md +++ b/docs/internal-developers/testing/releases/780.md @@ -135,6 +135,7 @@ Zip file for testing: [woocommerce-gutenberg-products-block.zip](https://github. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/760.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/780.md) + diff --git a/docs/internal-developers/testing/releases/781.md b/docs/internal-developers/testing/releases/781.md index cf73facd23c..d740f99f452 100644 --- a/docs/internal-developers/testing/releases/781.md +++ b/docs/internal-developers/testing/releases/781.md @@ -21,6 +21,7 @@ Zip file for testing: [woocommerce-gutenberg-products-block.zip](https://github. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/760.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/781.md) + diff --git a/docs/internal-developers/testing/releases/782.md b/docs/internal-developers/testing/releases/782.md index f3b6f6479cb..3baeb981f6c 100644 --- a/docs/internal-developers/testing/releases/782.md +++ b/docs/internal-developers/testing/releases/782.md @@ -31,6 +31,7 @@ Zip file for testing: [woocommerce-gutenberg-products-block.zip](https://github. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/760.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/782.md) + diff --git a/docs/internal-developers/testing/releases/783.md b/docs/internal-developers/testing/releases/783.md index 7051303f18c..628948da763 100644 --- a/docs/internal-developers/testing/releases/783.md +++ b/docs/internal-developers/testing/releases/783.md @@ -21,6 +21,7 @@ Zip file for testing: [woocommerce-gutenberg-products-block.zip](https://github. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/760.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/783.md) + diff --git a/docs/internal-developers/testing/releases/790.md b/docs/internal-developers/testing/releases/790.md index 726007f74d5..fa3182f2800 100644 --- a/docs/internal-developers/testing/releases/790.md +++ b/docs/internal-developers/testing/releases/790.md @@ -81,3 +81,13 @@ Zip file for testing: [woocommerce-gutenberg-products-block.zip](https://github. 4. Add multiple items to your cart. 5. Go to the Checkout/Cart Block. 6. Ensure you see no errors. + + +--- + +[We're hiring!](https://woocommerce.com/careers/) Come work with us! + +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/790.md) + + + diff --git a/docs/internal-developers/testing/releases/800.md b/docs/internal-developers/testing/releases/800.md index 2f8bfa49c79..fcff35d3fcf 100644 --- a/docs/internal-developers/testing/releases/800.md +++ b/docs/internal-developers/testing/releases/800.md @@ -47,3 +47,13 @@ Zip file for testing: [woocommerce-gutenberg-products-block.zip](https://github. 10. Place your order. Check on the `Order received` page that the displayed **tax is actually added to the total**. 11. Go to `Edit Order`. Check that **taxes were applied correctly there as well**. 12. On the `Checkout` again, select `Flat rate`, using the same external address, and make sure **taxes are not applied**. + + +--- + +[We're hiring!](https://woocommerce.com/careers/) Come work with us! + +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/800.md) + + + diff --git a/docs/internal-developers/testing/releases/810.md b/docs/internal-developers/testing/releases/810.md index 0125c29c0f9..dd50f97e6d6 100644 --- a/docs/internal-developers/testing/releases/810.md +++ b/docs/internal-developers/testing/releases/810.md @@ -53,3 +53,13 @@ For each filter block (by Price, by Attribute, by Stock and Active filters) ensu 5. Add a product to the cart and go to the test page with the checkout block. 6. Clear all form fields, if they're pre-filled, and click on place order. 7. See the error messages with sufficient color contrast. + + +--- + +[We're hiring!](https://woocommerce.com/careers/) Come work with us! + +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/810.md) + + + diff --git a/docs/internal-developers/testing/releases/820.md b/docs/internal-developers/testing/releases/820.md new file mode 100644 index 00000000000..5df2aa2069a --- /dev/null +++ b/docs/internal-developers/testing/releases/820.md @@ -0,0 +1,155 @@ +# Testing notes and ZIP for release 8.2.0 + +Zip file for testing: [woocommerce-gutenberg-products-block.zip](https://github.com/woocommerce/woocommerce-blocks/files/9242756/woocommerce-gutenberg-products-block.zip) + +## Feature plugin and package inclusion in WooCommerce + +### Remove compatibility notice for Mini Cart block ([6803](https://github.com/woocommerce/woocommerce-blocks/pull/6803)) + +0. Make sure you have a blocks theme active (like Twenty Twenty-Two). +1. Clear the local storage of your browser. +2. Add the Mini Cart block to the header template part. +3. Don't see compatibility notice. +4. Create a new page > Add the Cart block to that page. +5. See the compatibility notice as normal. + +### Add new icon for mini cart block ([6784](https://github.com/woocommerce/woocommerce-blocks/pull/6784)) + +1. Make sure you have a blocks theme active (like Twenty Twenty-Two). +2. Navigate to **Appearance > Editor (Beta)** and add a Mini Cart block somewhere in your site. +3. Select the Mini Cart block in the editor and confirm the icon in the inserter and toolbar reflect the changes. + +| Before | After | +| ------ | ----- | +| ![CleanShot 2022-07-28 at 14 57 58](https://user-images.githubusercontent.com/481776/181622493-d618649c-e9ee-4649-9e10-a2aed6737fc5.png) | ![CleanShot 2022-07-28 at 15 31 41](https://user-images.githubusercontent.com/481776/181622516-4bade22f-944a-488e-aacc-6094afa97efe.png) | + +### Fix: Replace DropdownSelector with FormTokenField from Gutenberg ([6647](https://github.com/woocommerce/woocommerce-blocks/pull/6647)) + +1. Add the Filter Products by Attribute block and the All Products block into a post or page. +2. Change the display type of Filter Products by Attribute to `Dropdown`. +3. Ensure the block functions normally. +4. Enable the Filter button, and ensure the block functions normally. + +### Use the archive-product template to render product attributes pages ([6776](https://github.com/woocommerce/woocommerce-blocks/pull/6776)) + +1. Make sure you have a blocks theme active (like Twenty Twenty-Two). +2. Navigate to `Products` > `Attributes` and edit an existing one or create a new one. +3. Click the `Enable Archives` option and save, go back. +4. Click `Configure terms` next to your attribute. +5. Hover over one of the terms and click the `View` link of one of the attributes. +6. Check that the page is rendered with a header, a footer, and using a product grid. + +| Before | After | +| ------ | ----- | +| Screenshot 2022-07-27 at 16 38 51 | ![Screenshot 2022-07-27 at 16 38 41](https://user-images.githubusercontent.com/186112/181275933-3b712c54-1c6f-4578-8a25-659052cde175.png)| + +### All Products block: Migrate to block.json ([6754](https://github.com/woocommerce/woocommerce-blocks/pull/6754)) + +1. Add the All Products block to a post or page. +2. Verify it works as before in the editor and the frontend and there are no errors. + +### Start using block.json and convert to TS the Product by Category block ([6680](https://github.com/woocommerce/woocommerce-blocks/pull/6680)) + +Test that there are no regressions compared with the previous `Products by Category` block version. + +1. Create a page and add a `Products by Category` block. +2. Save the page and check it renders correctly the default config in the frontend. +3. Edit the page again and make some changes to the block (hiding some content, changing columns number, ordering, etc.). +4. Save the page and check it renders properly with the new config. + +### Start using block.json and convert to TS the Product Best Sellers block ([6683](https://github.com/woocommerce/woocommerce-blocks/pull/6683)) + +Test that there are no regressions compared with the previous `Product Best Sellers` block version. + +1. Create a page and add a `Product Best Sellers` block. +2. Save the page and check it renders correctly the default config in the frontend. +3. Edit the page again and make some changes to the block (hiding some content, changing columns number, ordering, etc.). +4. Save the page and check it renders properly with the new config. + +### Select the correct inner button for the "Featured Item" button to update its url ([6741](https://github.com/woocommerce/woocommerce-blocks/pull/6741)) + +1. Create a new page and add a `Featured Product` block. +2. Edit the block and select a different product. +3. Make sure the button URL on the block is updated to the new product link. +4. Duplicate the block and change the new block to a different product. +5. Make sure the button URL on the block is updated to the new product link. +6. Repeat 1-5 for the `Featured Category` block. + +### Fix: navigate through Mini Cart contents with keyboard ([6731](https://github.com/woocommerce/woocommerce-blocks/pull/6731)) + +1. In the site editor, add the Mini Cart block to your site header. +2. Edit the Mini Cart template part and add an image in the inner contents. +3. In the frontend, add some products to the Cart. +4. With the keyboard, open the Mini Cart. +5. With the Tab key try to navigate to the Mini Cart products. +6. Notice you can focus the Mini Cart products inner elements. + +### Fix: WooCommerce messages don't appear in block themes with Mini Cart block ([6728](https://github.com/woocommerce/woocommerce-blocks/pull/6728)) + +1. Switch to a block theme (ie: Twenty Twenty-Two), add the Mini Cart block to the header, and go to a product page. +2. Add the product to your cart. +3. Notice the add to cart success message is shown on the top of the page. + +### SearchListControl: Fix preserving case of original item ([6551](https://github.com/woocommerce/woocommerce-blocks/pull/6551)) + +1. Add a “Hand-picked Products” block to your page. +2. Type the name of one of your products with the incorrect case (e.g. if you have imported the sample data, type “hOoDiE”. +3. Make sure all matching products appear on the list. +4. Make sure all items on the list preserve their original case. + + +| Before | After | +| ------ | ----- | +| 172268138-7445fbf1-ad25-4716-8b5a-ee4b463af54b | ![Screenshot 2022-06-11 at 21 16 42](https://user-images.githubusercontent.com/1847066/173202019-aa3659e5-0dd4-454b-95bd-f2ead03ee40d.png) | + +## Feature plugin + +### Fix proceed to checkout button on Cart ([6804](https://github.com/woocommerce/woocommerce-blocks/pull/6804)) + +1. In a new page, insert Cart block. +2. Select Proceed to Checkout block. +3. In the sidebar, change the link to something else. +4. On frontend, add an item to cart, go that newly created cart page, and click the proceed to checkout button. +5. It should take you to your new page. + +### Ensure addresses sync correctly when loading the Checkout Shipping Address Block ([6773](https://github.com/woocommerce/woocommerce-blocks/pull/6773)) + +1. Add items to your cart. +2. Go to the Checkout Block +3. Uncheck "use shipping as billing" and fill out different addresses for shipping and billing. +4. Place the order and verify on the order confirmation screen that the addresses were different. +5. Add another item to your cart then go to the Checkout Block. +6. Leave "use shipping as billing" checked. +7. Place order, check the thank you page, ensure the billing and shipping addresses match. + +### Ensure shipping rate names show when multiple packages are used ([6753](https://github.com/woocommerce/woocommerce-blocks/pull/6753)) + +1. Install the ["Multiple Packages for WooCommerce" plugin](https://wordpress.org/plugins/multiple-packages-for-woocommerce/) +2. Navigate to WooCommerce -> Settings -> Multiple Packages +3. Adjust the settings to work based on "Per Product" +4. Add two/three/four different products to the cart and typically need shipping. +5. Go the checkout page and look at the shipping options, ensure there is a title for each one. +6. Disable the plugin and reload the Checkout Block, ensure the shipping section still looks OK. + +| Before | After | +| ------ | ----- | +| | image | + +### Fix missing translations in inspector ([6737](https://github.com/woocommerce/woocommerce-blocks/pull/6737)) + +1. Change your site language (I tested using French & NL) +2. Go to the C&C Blocks (Editor mode) +3. Select each inner block and make sure the `title` & `description` are translated in the inspector. See image below: + +![image](https://user-images.githubusercontent.com/14235870/181719689-f9decbdd-5bc6-4192-8612-4b2696a8d7c4.png) + + + +--- + +[We're hiring!](https://woocommerce.com/careers/) Come work with us! + +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/810.md) + + + diff --git a/docs/internal-developers/testing/releases/821.md b/docs/internal-developers/testing/releases/821.md new file mode 100644 index 00000000000..bd77494dd93 --- /dev/null +++ b/docs/internal-developers/testing/releases/821.md @@ -0,0 +1,26 @@ +# Testing notes and ZIP for release 8.2.1 + +Zip file for testing: [woocommerce-gutenberg-products-block.zip](https://github.com/woocommerce/woocommerce-blocks/files/9250889/woocommerce-gutenberg-products-block.zip) + +## Feature plugin + +### Ensure onChange is set for radio buttons in `SavedPaymentMethodOptions` ([6825](https://github.com/woocommerce/woocommerce-blocks/pull/6825)) + +1. Install Stripe, set it up so you can use it at Checkout. +2. Add items to your cart and go to checkout. Add a credit/debit card via stripe and choose `Save payment information to my account for future purchases.` +3. Check out. Repeat step 2 once more with a different card number. **Ensure the new card you use ends in four different numbers than the first one!** You can see test cards here: +4. Add items to your cart and go to checkout a third time. This time ensure you can switch between saved cards. + image +5. Check out successfully, and then go to the back end of your site. Go to the orders you made (WooCommerce -> Orders) and for each order check the payment method used (you'll need to follow this through to Stripe), and ensure the card number used matches the one you chose in the Checkout block. (Click the link on the order page) + image + + + +--- + +[We're hiring!](https://woocommerce.com/careers/) Come work with us! + +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/810.md) + + + diff --git a/docs/internal-developers/testing/releases/README.md b/docs/internal-developers/testing/releases/README.md index d63cff2c407..9a00db51f5e 100644 --- a/docs/internal-developers/testing/releases/README.md +++ b/docs/internal-developers/testing/releases/README.md @@ -83,6 +83,8 @@ Every release includes specific testing instructions for new features and bug fi - [7.9.0](./790.md) - [8.0.0](./800.md) - [8.1.0](./810.md) +- [8.2.0](./820.md) +- [8.2.1](./821.md) @@ -90,6 +92,7 @@ Every release includes specific testing instructions for new features and bug fi [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/releases/README.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/releases/README.md) + diff --git a/docs/internal-developers/testing/smoke-testing.md b/docs/internal-developers/testing/smoke-testing.md index 79882a90811..78570e4e5b8 100644 --- a/docs/internal-developers/testing/smoke-testing.md +++ b/docs/internal-developers/testing/smoke-testing.md @@ -286,6 +286,7 @@ In the `wp:woocommerce/product-search` substitute the URL used for the `action` [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/smoke-testing.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/smoke-testing.md) + diff --git a/docs/internal-developers/testing/when-to-employ-e2e-testing.md b/docs/internal-developers/testing/when-to-employ-e2e-testing.md index d2350991fc9..7ca73db3f73 100644 --- a/docs/internal-developers/testing/when-to-employ-e2e-testing.md +++ b/docs/internal-developers/testing/when-to-employ-e2e-testing.md @@ -20,6 +20,7 @@ An example of things that _should_ be tested with E2E tests: [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/when-to-employ-e2e-testing.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/testing/when-to-employ-e2e-testing.md) + diff --git a/docs/internal-developers/translations/README.md b/docs/internal-developers/translations/README.md index 073bdc708bb..2a4f7e5c931 100644 --- a/docs/internal-developers/translations/README.md +++ b/docs/internal-developers/translations/README.md @@ -16,6 +16,7 @@ This folder contains documentation around translation handling of WooCommerce Bl [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/README.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/translations/README.md) + diff --git a/docs/internal-developers/translations/translation-basics.md b/docs/internal-developers/translations/translation-basics.md index 95c6182bdbc..6ad575ac76f 100644 --- a/docs/internal-developers/translations/translation-basics.md +++ b/docs/internal-developers/translations/translation-basics.md @@ -54,6 +54,7 @@ See also + diff --git a/docs/internal-developers/translations/translation-loading.md b/docs/internal-developers/translations/translation-loading.md index ba75bbe4d0d..60812cafa74 100644 --- a/docs/internal-developers/translations/translation-loading.md +++ b/docs/internal-developers/translations/translation-loading.md @@ -303,6 +303,7 @@ add_filter( 'load_script_translation_file', 'load_woocommerce_core_json_translat [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/README.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/translations/translation-loading.md) + diff --git a/docs/internal-developers/translations/translation-management.md b/docs/internal-developers/translations/translation-management.md index 63fea00df68..e33a17d8f8b 100644 --- a/docs/internal-developers/translations/translation-management.md +++ b/docs/internal-developers/translations/translation-management.md @@ -69,6 +69,7 @@ See also + diff --git a/docs/internal-developers/translations/translations-for-lazy-loaded-components.md b/docs/internal-developers/translations/translations-for-lazy-loaded-components.md index 80b574ab974..d3ea9539c2e 100644 --- a/docs/internal-developers/translations/translations-for-lazy-loaded-components.md +++ b/docs/internal-developers/translations/translations-for-lazy-loaded-components.md @@ -145,6 +145,7 @@ Lazy-loading translations within the WooCommerce Blocks plugin changed over time [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/README.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/translations/translations-for-lazy-loaded-components.md) + diff --git a/docs/internal-developers/translations/translations-in-FSE-templates.md b/docs/internal-developers/translations/translations-in-FSE-templates.md index 25172100c76..97c83f30374 100644 --- a/docs/internal-developers/translations/translations-in-FSE-templates.md +++ b/docs/internal-developers/translations/translations-in-FSE-templates.md @@ -114,6 +114,7 @@ The PR for the implementation above can be found on + diff --git a/docs/internal-developers/translations/translations-in-JS-TS-files.md b/docs/internal-developers/translations/translations-in-JS-TS-files.md index 1205ee8e8e0..473f2f15a92 100644 --- a/docs/internal-developers/translations/translations-in-JS-TS-files.md +++ b/docs/internal-developers/translations/translations-in-JS-TS-files.md @@ -105,6 +105,7 @@ See also + diff --git a/docs/internal-developers/translations/translations-in-PHP-files.md b/docs/internal-developers/translations/translations-in-PHP-files.md index 5087a96ca22..9aa37bda548 100644 --- a/docs/internal-developers/translations/translations-in-PHP-files.md +++ b/docs/internal-developers/translations/translations-in-PHP-files.md @@ -197,6 +197,7 @@ See also . [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/testing/README.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/internal-developers/translations/translations-in-PHP-files.md) + diff --git a/docs/third-party-developers/extensibility/README.md b/docs/third-party-developers/extensibility/README.md index 47553617657..c831ffecdfc 100644 --- a/docs/third-party-developers/extensibility/README.md +++ b/docs/third-party-developers/extensibility/README.md @@ -52,6 +52,7 @@ In addition to the reference material below, [please see the `block-checkout` pa [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/extensibility/README.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/third-party-developers/extensibility/README.md) + diff --git a/docs/third-party-developers/extensibility/checkout-block/available-filters.md b/docs/third-party-developers/extensibility/checkout-block/available-filters.md index 36b7a6bb0f0..bf60fc7582a 100644 --- a/docs/third-party-developers/extensibility/checkout-block/available-filters.md +++ b/docs/third-party-developers/extensibility/checkout-block/available-filters.md @@ -268,6 +268,7 @@ The error will also be shown in your console. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/extensibility/available-filters.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/third-party-developers/extensibility/checkout-block/available-filters.md) + diff --git a/docs/third-party-developers/extensibility/checkout-block/available-slot-fills.md b/docs/third-party-developers/extensibility/checkout-block/available-slot-fills.md index d3f197bfc48..f0ce088a1b3 100644 --- a/docs/third-party-developers/extensibility/checkout-block/available-slot-fills.md +++ b/docs/third-party-developers/extensibility/checkout-block/available-slot-fills.md @@ -81,6 +81,7 @@ Checkout: [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/extensibility/available-slot-fills.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/third-party-developers/extensibility/checkout-block/available-slot-fills.md) + diff --git a/docs/third-party-developers/extensibility/checkout-block/dom-events.md b/docs/third-party-developers/extensibility/checkout-block/dom-events.md index c6f78c6c454..bdf2bf9568a 100644 --- a/docs/third-party-developers/extensibility/checkout-block/dom-events.md +++ b/docs/third-party-developers/extensibility/checkout-block/dom-events.md @@ -47,6 +47,7 @@ _Example usage in WC Blocks:_ Cart and Mini Cart blocks (via the `useStoreCart() [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/extensibility/dom-events.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/third-party-developers/extensibility/checkout-block/dom-events.md) + diff --git a/docs/third-party-developers/extensibility/checkout-block/integration-interface.md b/docs/third-party-developers/extensibility/checkout-block/integration-interface.md index 613a0072175..7565d6b5ac7 100644 --- a/docs/third-party-developers/extensibility/checkout-block/integration-interface.md +++ b/docs/third-party-developers/extensibility/checkout-block/integration-interface.md @@ -210,6 +210,7 @@ The value returned here is a plain old JavaScript object, keyed by the keys of t [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/extensibility/integration-interface.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/third-party-developers/extensibility/checkout-block/integration-interface.md) + diff --git a/docs/third-party-developers/extensibility/checkout-block/slot-fills.md b/docs/third-party-developers/extensibility/checkout-block/slot-fills.md index 4a1ea0489ef..ca58b301ac5 100644 --- a/docs/third-party-developers/extensibility/checkout-block/slot-fills.md +++ b/docs/third-party-developers/extensibility/checkout-block/slot-fills.md @@ -69,6 +69,7 @@ For this to work, your script must be enqueued after Cart and Checkout. You can [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/extensibility/slot-fills.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/third-party-developers/extensibility/checkout-block/slot-fills.md) + diff --git a/docs/third-party-developers/extensibility/checkout-payment-methods/checkout-flow-and-events.md b/docs/third-party-developers/extensibility/checkout-payment-methods/checkout-flow-and-events.md index 73f5b9baf06..3e772f4c5af 100644 --- a/docs/third-party-developers/extensibility/checkout-payment-methods/checkout-flow-and-events.md +++ b/docs/third-party-developers/extensibility/checkout-payment-methods/checkout-flow-and-events.md @@ -12,6 +12,7 @@ [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/extensibility/checkout-flow-and-events.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/third-party-developers/extensibility/checkout-payment-methods/checkout-flow-and-events.md) + diff --git a/docs/third-party-developers/extensibility/checkout-payment-methods/filtering-payment-methods.md b/docs/third-party-developers/extensibility/checkout-payment-methods/filtering-payment-methods.md index e2d918ba970..a19e5fea054 100644 --- a/docs/third-party-developers/extensibility/checkout-payment-methods/filtering-payment-methods.md +++ b/docs/third-party-developers/extensibility/checkout-payment-methods/filtering-payment-methods.md @@ -171,6 +171,7 @@ If you've added your payment method correctly with the correct `supports` values [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/extensibility/filtering-payment-methods.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/third-party-developers/extensibility/checkout-payment-methods/filtering-payment-methods.md) + diff --git a/docs/third-party-developers/extensibility/checkout-payment-methods/payment-method-integration.md b/docs/third-party-developers/extensibility/checkout-payment-methods/payment-method-integration.md index 895375bc7c9..a031f730920 100644 --- a/docs/third-party-developers/extensibility/checkout-payment-methods/payment-method-integration.md +++ b/docs/third-party-developers/extensibility/checkout-payment-methods/payment-method-integration.md @@ -244,6 +244,7 @@ As an example, you can see how the Stripe extension adds it's integration in thi [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/extensibility/payment-method-integration.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/third-party-developers/extensibility/checkout-payment-methods/payment-method-integration.md) + diff --git a/docs/third-party-developers/extensibility/hooks/actions.md b/docs/third-party-developers/extensibility/hooks/actions.md index 48f436d6e3a..a5c68419205 100644 --- a/docs/third-party-developers/extensibility/hooks/actions.md +++ b/docs/third-party-developers/extensibility/hooks/actions.md @@ -6,45 +6,49 @@ ## Table of Contents -- [woocommerce_add_to_cart](#woocommerce_add_to_cart) -- [woocommerce_after_main_content](#woocommerce_after_main_content) -- [woocommerce_after_shop_loop](#woocommerce_after_shop_loop) -- [woocommerce_applied_coupon](#woocommerce_applied_coupon) -- [woocommerce_archive_description](#woocommerce_archive_description) -- [woocommerce_before_main_content](#woocommerce_before_main_content) -- [woocommerce_before_shop_loop](#woocommerce_before_shop_loop) -- [woocommerce_blocks_cart_enqueue_data](#woocommerce_blocks_cart_enqueue_data) -- [woocommerce_blocks_checkout_enqueue_data](#woocommerce_blocks_checkout_enqueue_data) -- [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) -- [woocommerce_blocks_enqueue_checkout_block_scripts_before](#woocommerce_blocks_enqueue_checkout_block_scripts_before) -- [woocommerce*blocks*{\$this->registry_identifier}\_registration](#woocommerce_blocks_-this--registry_identifier-_registration) -- [woocommerce_check_cart_items](#-woocommerce_check_cart_items) -- [woocommerce_created_customer](#woocommerce_created_customer) -- [woocommerce_no_products_found](#woocommerce_no_products_found) -- [woocommerce_register_post](#woocommerce_register_post) -- [woocommerce_rest_checkout_process_payment_with_context](#woocommerce_rest_checkout_process_payment_with_context) -- [woocommerce_shop_loop](#woocommerce_shop_loop) -- [woocommerce_store_api_cart_errors](#woocommerce_store_api_cart_errors) -- [woocommerce_store_api_cart_update_customer_from_request](#woocommerce_store_api_cart_update_customer_from_request) -- [woocommerce_store_api_cart_update_order_from_request](#woocommerce_store_api_cart_update_order_from_request) -- [woocommerce_store_api_checkout_order_processed](#woocommerce_store_api_checkout_order_processed) -- [woocommerce_store_api_checkout_update_order_from_request](#woocommerce_store_api_checkout_update_order_from_request) -- [woocommerce_store_api_checkout_update_order_meta](#woocommerce_store_api_checkout_update_order_meta) -- [woocommerce_store_api_validate_add_to_cart](#woocommerce_store_api_validate_add_to_cart) -- [woocommerce_store_api_validate_cart_item](#woocommerce_store_api_validate_cart_item) + + - [woocommerce_add_to_cart](#woocommerce_add_to_cart) + - [woocommerce_after_main_content](#woocommerce_after_main_content) + - [woocommerce_after_shop_loop](#woocommerce_after_shop_loop) + - [woocommerce_applied_coupon](#woocommerce_applied_coupon) + - [woocommerce_archive_description](#woocommerce_archive_description) + - [woocommerce_before_main_content](#woocommerce_before_main_content) + - [woocommerce_before_shop_loop](#woocommerce_before_shop_loop) + - [woocommerce_blocks_cart_enqueue_data](#woocommerce_blocks_cart_enqueue_data) + - [woocommerce_blocks_checkout_enqueue_data](#woocommerce_blocks_checkout_enqueue_data) + - [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) + - [woocommerce_blocks_enqueue_checkout_block_scripts_before](#woocommerce_blocks_enqueue_checkout_block_scripts_before) + - [woocommerce_blocks_{$this->registry_identifier}_registration](#woocommerce_blocks_-this--registry_identifier-_registration) + - [woocommerce_check_cart_items](#-woocommerce_check_cart_items) + - [woocommerce_created_customer](#woocommerce_created_customer) + - [woocommerce_no_products_found](#woocommerce_no_products_found) + - [woocommerce_register_post](#woocommerce_register_post) + - [woocommerce_rest_checkout_process_payment_with_context](#woocommerce_rest_checkout_process_payment_with_context) + - [woocommerce_shop_loop](#woocommerce_shop_loop) + - [woocommerce_store_api_cart_errors](#woocommerce_store_api_cart_errors) + - [woocommerce_store_api_cart_update_customer_from_request](#woocommerce_store_api_cart_update_customer_from_request) + - [woocommerce_store_api_cart_update_order_from_request](#woocommerce_store_api_cart_update_order_from_request) + - [woocommerce_store_api_checkout_order_processed](#woocommerce_store_api_checkout_order_processed) + - [woocommerce_store_api_checkout_update_customer_from_request](#woocommerce_store_api_checkout_update_customer_from_request) + - [woocommerce_store_api_checkout_update_order_from_request](#woocommerce_store_api_checkout_update_order_from_request) + - [woocommerce_store_api_checkout_update_order_meta](#woocommerce_store_api_checkout_update_order_meta) + - [woocommerce_store_api_validate_add_to_cart](#woocommerce_store_api_validate_add_to_cart) + - [woocommerce_store_api_validate_cart_item](#woocommerce_store_api_validate_cart_item) --- ## woocommerce_add_to_cart + Fires when an item is added to the cart. ```php do_action( 'woocommerce_add_to_cart', string $cart_id, integer $product_id, integer $request_quantity, integer $variation_id, array $variation, array $cart_item_data ) ``` + **Note: Matches action name in WooCommerce core.** ### Description @@ -53,23 +57,25 @@ do_action( 'woocommerce_add_to_cart', string $cart_id, integer $product_id, inte ### Parameters -| Argument | Type | Description | -| ------------------ | ------- | ---------------------------------------------- | -| \$cart_id | string | ID of the item in the cart. | -| \$product_id | integer | ID of the product added to the cart. | -| \$request_quantity | integer | Quantity of the item added to the cart. | -| \$variation_id | integer | Variation ID of the product added to the cart. | -| \$variation | array | Array of variation data. | -| \$cart_item_data | array | Array of other cart item data. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $cart_id | string | ID of the item in the cart. | +| $product_id | integer | ID of the product added to the cart. | +| $request_quantity | integer | Quantity of the item added to the cart. | +| $variation_id | integer | Variation ID of the product added to the cart. | +| $variation | array | Array of variation data. | +| $cart_item_data | array | Array of other cart item data. | ### Source -- [StoreApi/Utilities/CartController.php](../../src/StoreApi/Utilities/CartController.php) + + - [StoreApi/Utilities/CartController.php](../../src/StoreApi/Utilities/CartController.php) --- ## woocommerce_after_main_content + Hook: woocommerce_after_main_content ```php @@ -82,17 +88,20 @@ do_action( 'woocommerce_after_main_content' ) ### See -- woocommerce_output_content_wrapper_end() - Outputs closing DIV for the content (priority 10) + + - woocommerce_output_content_wrapper_end() - Outputs closing DIV for the content (priority 10) ### Source -- [BlockTypes/ClassicTemplate.php](../../src/BlockTypes/ClassicTemplate.php) -- [BlockTypes/ClassicTemplate.php](../../src/BlockTypes/ClassicTemplate.php) + + - [BlockTypes/ClassicTemplate.php](../../src/BlockTypes/ClassicTemplate.php) + - [BlockTypes/ClassicTemplate.php](../../src/BlockTypes/ClassicTemplate.php) --- ## woocommerce_after_shop_loop + Hook: woocommerce_after_shop_loop. ```php @@ -101,38 +110,44 @@ do_action( 'woocommerce_after_shop_loop' ) ### See -- woocommerce_pagination() - Renders pagination (priority 10) + + - woocommerce_pagination() - Renders pagination (priority 10) ### Source -- [BlockTypes/ClassicTemplate.php](../../src/BlockTypes/ClassicTemplate.php) + + - [BlockTypes/ClassicTemplate.php](../../src/BlockTypes/ClassicTemplate.php) --- ## woocommerce_applied_coupon + Fires after a coupon has been applied to the cart. ```php do_action( 'woocommerce_applied_coupon', string $coupon_code ) ``` + **Note: Matches action name in WooCommerce core.** ### Parameters -| Argument | Type | Description | -| ------------- | ------ | --------------------------------- | -| \$coupon_code | string | The coupon code that was applied. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $coupon_code | string | The coupon code that was applied. | ### Source -- [StoreApi/Utilities/CartController.php](../../src/StoreApi/Utilities/CartController.php) + + - [StoreApi/Utilities/CartController.php](../../src/StoreApi/Utilities/CartController.php) --- ## woocommerce_archive_description + Hook: woocommerce_archive_description. ```php @@ -141,17 +156,20 @@ do_action( 'woocommerce_archive_description' ) ### See -- woocommerce_taxonomy_archive_description() - Renders the taxonomy archive description (priority 10) -- woocommerce_product_archive_description() - Renders the product archive description (priority 10) + + - woocommerce_taxonomy_archive_description() - Renders the taxonomy archive description (priority 10) + - woocommerce_product_archive_description() - Renders the product archive description (priority 10) ### Source -- [BlockTypes/ClassicTemplate.php](../../src/BlockTypes/ClassicTemplate.php) + + - [BlockTypes/ClassicTemplate.php](../../src/BlockTypes/ClassicTemplate.php) --- ## woocommerce_before_main_content + Hook: woocommerce_before_main_content ```php @@ -164,19 +182,22 @@ do_action( 'woocommerce_before_main_content' ) ### See -- woocommerce_output_content_wrapper() - Outputs opening DIV for the content (priority 10) -- woocommerce_breadcrumb() - Outputs breadcrumb trail to the current product (priority 20) -- WC_Structured_Data::generate_website_data() - Outputs schema markup (priority 30) + + - woocommerce_output_content_wrapper() - Outputs opening DIV for the content (priority 10) + - woocommerce_breadcrumb() - Outputs breadcrumb trail to the current product (priority 20) + - WC_Structured_Data::generate_website_data() - Outputs schema markup (priority 30) ### Source -- [BlockTypes/ClassicTemplate.php](../../src/BlockTypes/ClassicTemplate.php) -- [BlockTypes/ClassicTemplate.php](../../src/BlockTypes/ClassicTemplate.php) + + - [BlockTypes/ClassicTemplate.php](../../src/BlockTypes/ClassicTemplate.php) + - [BlockTypes/ClassicTemplate.php](../../src/BlockTypes/ClassicTemplate.php) --- ## woocommerce_before_shop_loop + Hook: woocommerce_before_shop_loop. ```php @@ -185,18 +206,21 @@ do_action( 'woocommerce_before_shop_loop' ) ### See -- woocommerce_output_all_notices() - Render error notices (priority 10) -- woocommerce_result_count() - Show number of results found (priority 20) -- woocommerce_catalog_ordering() - Show form to control sort order (priority 30) + + - woocommerce_output_all_notices() - Render error notices (priority 10) + - woocommerce_result_count() - Show number of results found (priority 20) + - woocommerce_catalog_ordering() - Show form to control sort order (priority 30) ### Source -- [BlockTypes/ClassicTemplate.php](../../src/BlockTypes/ClassicTemplate.php) + + - [BlockTypes/ClassicTemplate.php](../../src/BlockTypes/ClassicTemplate.php) --- ## woocommerce_blocks_cart_enqueue_data + Fires after cart block data is registered. ```php @@ -205,13 +229,15 @@ do_action( 'woocommerce_blocks_cart_enqueue_data' ) ### Source -- [BlockTypes/MiniCart.php](../../src/BlockTypes/MiniCart.php) -- [BlockTypes/Cart.php](../../src/BlockTypes/Cart.php) + + - [BlockTypes/Cart.php](../../src/BlockTypes/Cart.php) + - [BlockTypes/MiniCart.php](../../src/BlockTypes/MiniCart.php) --- ## woocommerce_blocks_checkout_enqueue_data + Fires after checkout block data is registered. ```php @@ -220,12 +246,14 @@ do_action( 'woocommerce_blocks_checkout_enqueue_data' ) ### Source -- [BlockTypes/Checkout.php](../../src/BlockTypes/Checkout.php) + + - [BlockTypes/Checkout.php](../../src/BlockTypes/Checkout.php) --- ## woocommerce_blocks_enqueue_cart_block_scripts_after + Fires after cart block scripts are enqueued. ```php @@ -234,12 +262,14 @@ do_action( 'woocommerce_blocks_enqueue_cart_block_scripts_after' ) ### Source -- [BlockTypes/Cart.php](../../src/BlockTypes/Cart.php) + + - [BlockTypes/Cart.php](../../src/BlockTypes/Cart.php) --- ## woocommerce_blocks_enqueue_cart_block_scripts_before + Fires before cart block scripts are enqueued. ```php @@ -248,12 +278,14 @@ do_action( 'woocommerce_blocks_enqueue_cart_block_scripts_before' ) ### Source -- [BlockTypes/Cart.php](../../src/BlockTypes/Cart.php) + + - [BlockTypes/Cart.php](../../src/BlockTypes/Cart.php) --- ## woocommerce_blocks_enqueue_checkout_block_scripts_after + Fires after checkout block scripts are enqueued. ```php @@ -262,12 +294,14 @@ do_action( 'woocommerce_blocks_enqueue_checkout_block_scripts_after' ) ### Source -- [BlockTypes/Checkout.php](../../src/BlockTypes/Checkout.php) + + - [BlockTypes/Checkout.php](../../src/BlockTypes/Checkout.php) --- ## woocommerce_blocks_enqueue_checkout_block_scripts_before + Fires before checkout block scripts are enqueued. ```php @@ -276,11 +310,13 @@ do_action( 'woocommerce_blocks_enqueue_checkout_block_scripts_before' ) ### Source -- [BlockTypes/Checkout.php](../../src/BlockTypes/Checkout.php) + + - [BlockTypes/Checkout.php](../../src/BlockTypes/Checkout.php) --- -## woocommerce*blocks*{\$this->registry_identifier}\_registration +## woocommerce_blocks_{$this->registry_identifier}_registration + Fires when the IntegrationRegistry is initialized. @@ -294,26 +330,30 @@ do_action( 'woocommerce_blocks_{$this->registry_identifier}_registration', \Auto ### Parameters -| Argument | Type | Description | -| -------- | --------------------------------------------------------------- | --------------------------------------------------------------------------------------------------- | -| \$this | \Automattic\WooCommerce\Blocks\Integrations\IntegrationRegistry | Instance of the IntegrationRegistry class which exposes the IntegrationRegistry::register() method. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $this | \Automattic\WooCommerce\Blocks\Integrations\IntegrationRegistry | Instance of the IntegrationRegistry class which exposes the IntegrationRegistry::register() method. | ### Source -- [Integrations/IntegrationRegistry.php](../../src/Integrations/IntegrationRegistry.php) + + - [Integrations/IntegrationRegistry.php](../../src/Integrations/IntegrationRegistry.php) --- ## ~~woocommerce_check_cart_items~~ + Fires when cart items are being validated. ```php do_action( 'woocommerce_check_cart_items' ) ``` + **Deprecated: This hook is deprecated and will be removed** + **Note: Matches action name in WooCommerce core.** ### Description @@ -322,18 +362,21 @@ do_action( 'woocommerce_check_cart_items' ) ### Source -- [StoreApi/Utilities/CartController.php](../../src/StoreApi/Utilities/CartController.php) + + - [StoreApi/Utilities/CartController.php](../../src/StoreApi/Utilities/CartController.php) --- ## woocommerce_created_customer + Fires after a customer account has been registered. ```php do_action( 'woocommerce_created_customer', integer $customer_id, array $new_customer_data, string $password_generated ) ``` + **Note: Matches filter name in WooCommerce core.** ### Description @@ -342,20 +385,22 @@ do_action( 'woocommerce_created_customer', integer $customer_id, array $new_cust ### Parameters -| Argument | Type | Description | -| -------------------- | ------- | --------------------------------------- | -| \$customer_id | integer | New customer (user) ID. | -| \$new_customer_data | array | Array of customer (user) data. | -| \$password_generated | string | The generated password for the account. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $customer_id | integer | New customer (user) ID. | +| $new_customer_data | array | Array of customer (user) data. | +| $password_generated | string | The generated password for the account. | ### Source -- [StoreApi/Routes/V1/Checkout.php](../../src/StoreApi/Routes/V1/Checkout.php) + + - [StoreApi/Routes/V1/Checkout.php](../../src/StoreApi/Routes/V1/Checkout.php) --- ## woocommerce_no_products_found + Hook: woocommerce_no_products_found. ```php @@ -364,22 +409,26 @@ do_action( 'woocommerce_no_products_found' ) ### See -- wc_no_products_found() - Default no products found content (priority 10) + + - wc_no_products_found() - Default no products found content (priority 10) ### Source -- [BlockTypes/ClassicTemplate.php](../../src/BlockTypes/ClassicTemplate.php) + + - [BlockTypes/ClassicTemplate.php](../../src/BlockTypes/ClassicTemplate.php) --- ## woocommerce_register_post + Fires before a customer account is registered. ```php do_action( 'woocommerce_register_post', string $username, string $user_email, \WP_Error $errors ) ``` + **Note: Matches filter name in WooCommerce core.** ### Description @@ -388,20 +437,22 @@ do_action( 'woocommerce_register_post', string $username, string $user_email, \W ### Parameters -| Argument | Type | Description | -| ------------ | --------- | ----------------------- | -| \$username | string | Customer username. | -| \$user_email | string | Customer email address. | -| \$errors | \WP_Error | Error object. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $username | string | Customer username. | +| $user_email | string | Customer email address. | +| $errors | \WP_Error | Error object. | ### Source -- [StoreApi/Routes/V1/Checkout.php](../../src/StoreApi/Routes/V1/Checkout.php) + + - [StoreApi/Routes/V1/Checkout.php](../../src/StoreApi/Routes/V1/Checkout.php) --- ## woocommerce_rest_checkout_process_payment_with_context + Process payment with context. ```php @@ -410,23 +461,26 @@ do_action_ref_array( 'woocommerce_rest_checkout_process_payment_with_context', [ ### Parameters -| Argument | Type | Description | -| ---------------- | -------------------------------------------------------- | --------------------------------------------------------------------- | -| \$context | \Automattic\WooCommerce\StoreApi\Payments\PaymentContext | Holds context for the payment, including order ID and payment method. | -| \$payment_result | \Automattic\WooCommerce\StoreApi\Payments\PaymentResult | Result object for the transaction. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $context | \Automattic\WooCommerce\StoreApi\Payments\PaymentContext | Holds context for the payment, including order ID and payment method. | +| $payment_result | \Automattic\WooCommerce\StoreApi\Payments\PaymentResult | Result object for the transaction. | ### Exceptions + `\Exception` If there is an error taking payment, an \Exception object can be thrown with an error message. ### Source -- [StoreApi/Routes/V1/Checkout.php](../../src/StoreApi/Routes/V1/Checkout.php) + + - [StoreApi/Routes/V1/Checkout.php](../../src/StoreApi/Routes/V1/Checkout.php) --- ## woocommerce_shop_loop + Hook: woocommerce_shop_loop. ```php @@ -435,12 +489,14 @@ do_action( 'woocommerce_shop_loop' ) ### Source -- [BlockTypes/ClassicTemplate.php](../../src/BlockTypes/ClassicTemplate.php) + + - [BlockTypes/ClassicTemplate.php](../../src/BlockTypes/ClassicTemplate.php) --- ## woocommerce_store_api_cart_errors + Fires an action to validate the cart. ```php @@ -453,13 +509,15 @@ do_action( 'woocommerce_store_api_cart_errors', \WP_Error $errors, \WC_Cart $car ### Parameters -| Argument | Type | Description | -| -------- | --------- | ---------------- | -| \$errors | \WP_Error | WP_Error object. | -| \$cart | \WC_Cart | Cart object. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $errors | \WP_Error | WP_Error object. | +| $cart | \WC_Cart | Cart object. | ### Example +# Validate Cart + ```php // The action callback function. function my_function_callback( $errors, $cart ) { @@ -473,14 +531,17 @@ function my_function_callback( $errors, $cart ) { add_action( 'woocommerce_store_api_cart_errors', 'my_function_callback', 10 ); ``` + ### Source -- [StoreApi/Utilities/CartController.php](../../src/StoreApi/Utilities/CartController.php) + + - [StoreApi/Utilities/CartController.php](../../src/StoreApi/Utilities/CartController.php) --- ## woocommerce_store_api_cart_update_customer_from_request + Fires when the Checkout Block/Store API updates a customer from the API request data. ```php @@ -489,19 +550,21 @@ do_action( 'woocommerce_store_api_cart_update_customer_from_request', \WC_Custom ### Parameters -| Argument | Type | Description | -| ---------- | ---------------- | ------------------------------- | -| \$customer | \WC_Customer | Customer object. | -| \$request | \WP_REST_Request | Full details about the request. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $customer | \WC_Customer | Customer object. | +| $request | \WP_REST_Request | Full details about the request. | ### Source -- [StoreApi/Routes/V1/CartUpdateCustomer.php](../../src/StoreApi/Routes/V1/CartUpdateCustomer.php) + + - [StoreApi/Routes/V1/CartUpdateCustomer.php](../../src/StoreApi/Routes/V1/CartUpdateCustomer.php) --- ## woocommerce_store_api_cart_update_order_from_request + Fires when the order is synced with cart data from a cart route. ```php @@ -510,20 +573,22 @@ do_action( 'woocommerce_store_api_cart_update_order_from_request', \WC_Order $dr ### Parameters -| Argument | Type | Description | -| ------------- | ---------------- | ------------------------------- | -| \$draft_order | \WC_Order | Order object. | -| \$customer | \WC_Customer | Customer object. | -| \$request | \WP_REST_Request | Full details about the request. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $draft_order | \WC_Order | Order object. | +| $customer | \WC_Customer | Customer object. | +| $request | \WP_REST_Request | Full details about the request. | ### Source -- [StoreApi/Routes/V1/AbstractCartRoute.php](../../src/StoreApi/Routes/V1/AbstractCartRoute.php) + + - [StoreApi/Routes/V1/AbstractCartRoute.php](../../src/StoreApi/Routes/V1/AbstractCartRoute.php) --- ## woocommerce_store_api_checkout_order_processed + Fires before an order is processed by the Checkout Block/Store API. ```php @@ -536,12 +601,14 @@ do_action( 'woocommerce_store_api_checkout_order_processed', \WC_Order $order ) ### Parameters -| Argument | Type | Description | -| -------- | --------- | ------------- | -| \$order | \WC_Order | Order object. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $order | \WC_Order | Order object. | ### Example +# Checkout Order Processed + ```php // The action callback function. function my_function_callback( $order ) { @@ -552,18 +619,45 @@ function my_function_callback( $order ) { add_action( 'woocommerce_blocks_checkout_order_processed', 'my_function_callback', 10 ); ``` + ### See -- https://github.com/woocommerce/woocommerce-gutenberg-products-block/pull/3238 + + - https://github.com/woocommerce/woocommerce-gutenberg-products-block/pull/3238 ### Source -- [StoreApi/Routes/V1/Checkout.php](../../src/StoreApi/Routes/V1/Checkout.php) + + - [StoreApi/Routes/V1/Checkout.php](../../src/StoreApi/Routes/V1/Checkout.php) + +--- + +## woocommerce_store_api_checkout_update_customer_from_request + + +Fires when the Checkout Block/Store API updates a customer from the API request data. + +```php +do_action( 'woocommerce_store_api_checkout_update_customer_from_request', \WC_Customer $customer, \WP_REST_Request $request ) +``` + +### Parameters + +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $customer | \WC_Customer | Customer object. | +| $request | \WP_REST_Request | Full details about the request. | + +### Source + + + - [StoreApi/Routes/V1/Checkout.php](../../src/StoreApi/Routes/V1/Checkout.php) --- ## woocommerce_store_api_checkout_update_order_from_request + Fires when the Checkout Block/Store API updates an order's from the API request data. ```php @@ -576,19 +670,21 @@ do_action( 'woocommerce_store_api_checkout_update_order_from_request', \WC_Order ### Parameters -| Argument | Type | Description | -| --------- | ---------------- | ------------------------------- | -| \$order | \WC_Order | Order object. | -| \$request | \WP_REST_Request | Full details about the request. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $order | \WC_Order | Order object. | +| $request | \WP_REST_Request | Full details about the request. | ### Source -- [StoreApi/Routes/V1/Checkout.php](../../src/StoreApi/Routes/V1/Checkout.php) + + - [StoreApi/Routes/V1/Checkout.php](../../src/StoreApi/Routes/V1/Checkout.php) --- ## woocommerce_store_api_checkout_update_order_meta + Fires when the Checkout Block/Store API updates an order's meta data. ```php @@ -601,22 +697,25 @@ do_action( 'woocommerce_store_api_checkout_update_order_meta', \WC_Order $order ### Parameters -| Argument | Type | Description | -| -------- | --------- | ------------- | -| \$order | \WC_Order | Order object. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $order | \WC_Order | Order object. | ### See -- https://github.com/woocommerce/woocommerce-gutenberg-products-block/pull/3686 + + - https://github.com/woocommerce/woocommerce-gutenberg-products-block/pull/3686 ### Source -- [StoreApi/Routes/V1/Checkout.php](../../src/StoreApi/Routes/V1/Checkout.php) + + - [StoreApi/Routes/V1/Checkout.php](../../src/StoreApi/Routes/V1/Checkout.php) --- ## woocommerce_store_api_validate_add_to_cart + Fires during validation when adding an item to the cart via the Store API. ```php @@ -629,19 +728,21 @@ do_action( 'woocommerce_store_api_validate_add_to_cart', \WC_Product $product, a ### Parameters -| Argument | Type | Description | -| --------- | ----------- | ---------------------------------------------------------------------------- | -| \$product | \WC_Product | Product object being added to the cart. | -| \$request | array | Add to cart request params including id, quantity, and variation attributes. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $product | \WC_Product | Product object being added to the cart. | +| $request | array | Add to cart request params including id, quantity, and variation attributes. | ### Source -- [StoreApi/Utilities/CartController.php](../../src/StoreApi/Utilities/CartController.php) + + - [StoreApi/Utilities/CartController.php](../../src/StoreApi/Utilities/CartController.php) --- ## woocommerce_store_api_validate_cart_item + Fire action to validate add to cart. Functions hooking into this should throw an \Exception to prevent add to cart from occurring. ```php @@ -650,23 +751,24 @@ do_action( 'woocommerce_store_api_validate_cart_item', \WC_Product $product, arr ### Parameters -| Argument | Type | Description | -| ----------- | ----------- | --------------------------------------- | -| \$product | \WC_Product | Product object being added to the cart. | -| \$cart_item | array | Cart item array. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $product | \WC_Product | Product object being added to the cart. | +| $cart_item | array | Cart item array. | ### Source -- [StoreApi/Utilities/CartController.php](../../src/StoreApi/Utilities/CartController.php) ---- + - [StoreApi/Utilities/CartController.php](../../src/StoreApi/Utilities/CartController.php) +--- --- [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/extensibility/actions.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/third-party-developers/extensibility/hooks/actions.md) + diff --git a/docs/third-party-developers/extensibility/hooks/filters.md b/docs/third-party-developers/extensibility/hooks/filters.md index 4bcf4033f71..1c6546e1227 100644 --- a/docs/third-party-developers/extensibility/hooks/filters.md +++ b/docs/third-party-developers/extensibility/hooks/filters.md @@ -6,36 +6,38 @@ ## Table of Contents -- [\_\_experimental_woocommerce_blocks_add_data_attributes_to_block](#__experimental_woocommerce_blocks_add_data_attributes_to_block) -- [\_\_experimental_woocommerce_blocks_add_data_attributes_to_namespace](#__experimental_woocommerce_blocks_add_data_attributes_to_namespace) -- [\_\_experimental_woocommerce_blocks_payment_gateway_features_list](#__experimental_woocommerce_blocks_payment_gateway_features_list) -- [woocommerce_add_cart_item](#woocommerce_add_cart_item) -- [woocommerce_add_cart_item_data](#woocommerce_add_cart_item_data) -- [woocommerce_add_to_cart_sold_individually_quantity](#woocommerce_add_to_cart_sold_individually_quantity) -- [woocommerce_add_to_cart_validation](#-woocommerce_add_to_cart_validation) -- [woocommerce_adjust_non_base_location_prices](#woocommerce_adjust_non_base_location_prices) -- [woocommerce_admin_disabled](#woocommerce_admin_disabled) -- [woocommerce_apply_individual_use_coupon](#woocommerce_apply_individual_use_coupon) -- [woocommerce_apply_with_individual_use_coupon](#woocommerce_apply_with_individual_use_coupon) -- [woocommerce_blocks_product_grid_is_cacheable](#woocommerce_blocks_product_grid_is_cacheable) -- [woocommerce_blocks_product_grid_item_html](#woocommerce_blocks_product_grid_item_html) -- [woocommerce_blocks_register_script_dependencies](#woocommerce_blocks_register_script_dependencies) -- [woocommerce_cart_contents_changed](#woocommerce_cart_contents_changed) -- [woocommerce_ga_disable_tracking](#woocommerce_ga_disable_tracking) -- [woocommerce_get_item_data](#woocommerce_get_item_data) -- [woocommerce_new_customer_data](#woocommerce_new_customer_data) -- [woocommerce_registration_errors](#woocommerce_registration_errors) -- [woocommerce_shared_settings](#-woocommerce_shared_settings) -- [woocommerce_shipping_package_name](#woocommerce_shipping_package_name) -- [woocommerce_show_page_title](#woocommerce_show_page_title) -- [woocommerce_store_api_disable_nonce_check](#woocommerce_store_api_disable_nonce_check) -- [woocommerce_store_api_product_quantity_limit](#woocommerce_store_api_product_quantity_limit) -- [woocommerce*store_api_product_quantity*{\$value_type}](#woocommerce_store_api_product_quantity_-value_type) -- [woocommerce_variation_option_name](#woocommerce_variation_option_name) + + - [__experimental_woocommerce_blocks_add_data_attributes_to_block](#__experimental_woocommerce_blocks_add_data_attributes_to_block) + - [__experimental_woocommerce_blocks_add_data_attributes_to_namespace](#__experimental_woocommerce_blocks_add_data_attributes_to_namespace) + - [__experimental_woocommerce_blocks_payment_gateway_features_list](#__experimental_woocommerce_blocks_payment_gateway_features_list) + - [woocommerce_add_cart_item](#woocommerce_add_cart_item) + - [woocommerce_add_cart_item_data](#woocommerce_add_cart_item_data) + - [woocommerce_add_to_cart_sold_individually_quantity](#woocommerce_add_to_cart_sold_individually_quantity) + - [woocommerce_add_to_cart_validation](#-woocommerce_add_to_cart_validation) + - [woocommerce_adjust_non_base_location_prices](#woocommerce_adjust_non_base_location_prices) + - [woocommerce_admin_disabled](#woocommerce_admin_disabled) + - [woocommerce_apply_individual_use_coupon](#woocommerce_apply_individual_use_coupon) + - [woocommerce_apply_with_individual_use_coupon](#woocommerce_apply_with_individual_use_coupon) + - [woocommerce_blocks_product_grid_is_cacheable](#woocommerce_blocks_product_grid_is_cacheable) + - [woocommerce_blocks_product_grid_item_html](#woocommerce_blocks_product_grid_item_html) + - [woocommerce_blocks_register_script_dependencies](#woocommerce_blocks_register_script_dependencies) + - [woocommerce_cart_contents_changed](#woocommerce_cart_contents_changed) + - [woocommerce_ga_disable_tracking](#woocommerce_ga_disable_tracking) + - [woocommerce_get_item_data](#woocommerce_get_item_data) + - [woocommerce_new_customer_data](#woocommerce_new_customer_data) + - [woocommerce_registration_errors](#woocommerce_registration_errors) + - [woocommerce_shared_settings](#-woocommerce_shared_settings) + - [woocommerce_shipping_package_name](#woocommerce_shipping_package_name) + - [woocommerce_show_page_title](#woocommerce_show_page_title) + - [woocommerce_store_api_disable_nonce_check](#woocommerce_store_api_disable_nonce_check) + - [woocommerce_store_api_product_quantity_limit](#woocommerce_store_api_product_quantity_limit) + - [woocommerce_store_api_product_quantity_{$value_type}](#woocommerce_store_api_product_quantity_-value_type) + - [woocommerce_variation_option_name](#woocommerce_variation_option_name) --- -## \_\_experimental_woocommerce_blocks_add_data_attributes_to_block +## __experimental_woocommerce_blocks_add_data_attributes_to_block + Filters the list of allowed Block Names @@ -49,17 +51,19 @@ apply_filters( '__experimental_woocommerce_blocks_add_data_attributes_to_block', ### Parameters -| Argument | Type | Description | -| -------------------- | ----- | ------------------- | -| \$allowed_namespaces | array | List of namespaces. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $allowed_namespaces | array | List of namespaces. | ### Source -- [BlockTypesController.php](../../src/BlockTypesController.php) + + - [BlockTypesController.php](../../src/BlockTypesController.php) --- -## \_\_experimental_woocommerce_blocks_add_data_attributes_to_namespace +## __experimental_woocommerce_blocks_add_data_attributes_to_namespace + Filters the list of allowed block namespaces. @@ -73,17 +77,19 @@ apply_filters( '__experimental_woocommerce_blocks_add_data_attributes_to_namespa ### Parameters -| Argument | Type | Description | -| -------------------- | ----- | ------------------- | -| \$allowed_namespaces | array | List of namespaces. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $allowed_namespaces | array | List of namespaces. | ### Source -- [BlockTypesController.php](../../src/BlockTypesController.php) + + - [BlockTypesController.php](../../src/BlockTypesController.php) --- -## \_\_experimental_woocommerce_blocks_payment_gateway_features_list +## __experimental_woocommerce_blocks_payment_gateway_features_list + Filter to control what features are available for each payment gateway. @@ -93,17 +99,20 @@ apply_filters( '__experimental_woocommerce_blocks_payment_gateway_features_list' ### Parameters -| Argument | Type | Description | -| ---------- | ------ | --------------------------- | -| \$features | array | List of supported features. | -| \$name | string | Gateway name. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $features | array | List of supported features. | +| $name | string | Gateway name. | ### Returns + `array` Updated list of supported features. ### Example +# Payment Gateway Featured List + ```php // The action callback function. function my_function_callback( $features, $gateway ) { @@ -117,106 +126,122 @@ function my_function_callback( $features, $gateway ) { add_filter( '__experimental_woocommerce_blocks_payment_gateway_features_list', 'my_function_callback', 10, 2 ); ``` + ### Source -- [Payments/Integrations/PayPal.php](../../src/Payments/Integrations/PayPal.php) + + - [Payments/Integrations/PayPal.php](../../src/Payments/Integrations/PayPal.php) --- ## woocommerce_add_cart_item + Filters the item being added to the cart. ```php apply_filters( 'woocommerce_add_cart_item', array $cart_item_data, string $cart_id ) ``` + **Note: Matches filter name in WooCommerce core.** ### Parameters -| Argument | Type | Description | -| ---------------- | ------ | ------------------------------------------------ | -| \$cart_item_data | array | Array of cart item data being added to the cart. | -| \$cart_id | string | Id of the item in the cart. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $cart_item_data | array | Array of cart item data being added to the cart. | +| $cart_id | string | Id of the item in the cart. | ### Returns + `array` Updated cart item data. ### Source -- [StoreApi/Utilities/CartController.php](../../src/StoreApi/Utilities/CartController.php) + + - [StoreApi/Utilities/CartController.php](../../src/StoreApi/Utilities/CartController.php) --- ## woocommerce_add_cart_item_data + Filter cart item data for add to cart requests. ```php apply_filters( 'woocommerce_add_cart_item_data', array $cart_item_data, integer $product_id, integer $variation_id, integer $quantity ) ``` + **Note: Matches filter name in WooCommerce core.** ### Parameters -| Argument | Type | Description | -| ---------------- | ------- | ---------------------------------------------- | -| \$cart_item_data | array | Array of other cart item data. | -| \$product_id | integer | ID of the product added to the cart. | -| \$variation_id | integer | Variation ID of the product added to the cart. | -| \$quantity | integer | Quantity of the item added to the cart. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $cart_item_data | array | Array of other cart item data. | +| $product_id | integer | ID of the product added to the cart. | +| $variation_id | integer | Variation ID of the product added to the cart. | +| $quantity | integer | Quantity of the item added to the cart. | ### Returns -`array` + +`array` ### Source -- [StoreApi/Utilities/CartController.php](../../src/StoreApi/Utilities/CartController.php) + + - [StoreApi/Utilities/CartController.php](../../src/StoreApi/Utilities/CartController.php) --- ## woocommerce_add_to_cart_sold_individually_quantity + Filter sold individually quantity for add to cart requests. ```php apply_filters( 'woocommerce_add_to_cart_sold_individually_quantity', integer $sold_individually_quantity, integer $quantity, integer $product_id, integer $variation_id, array $cart_item_data ) ``` + **Note: Matches filter name in WooCommerce core.** ### Parameters -| Argument | Type | Description | -| ---------------------------- | ------- | ---------------------------------------------- | -| \$sold_individually_quantity | integer | Defaults to 1. | -| \$quantity | integer | Quantity of the item added to the cart. | -| \$product_id | integer | ID of the product added to the cart. | -| \$variation_id | integer | Variation ID of the product added to the cart. | -| \$cart_item_data | array | Array of other cart item data. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $sold_individually_quantity | integer | Defaults to 1. | +| $quantity | integer | Quantity of the item added to the cart. | +| $product_id | integer | ID of the product added to the cart. | +| $variation_id | integer | Variation ID of the product added to the cart. | +| $cart_item_data | array | Array of other cart item data. | ### Returns -`integer` + +`integer` ### Source -- [StoreApi/Utilities/CartController.php](../../src/StoreApi/Utilities/CartController.php) + + - [StoreApi/Utilities/CartController.php](../../src/StoreApi/Utilities/CartController.php) --- ## ~~woocommerce_add_to_cart_validation~~ + Filters if an item being added to the cart passed validation checks. ```php apply_filters( 'woocommerce_add_to_cart_validation', boolean $passed_validation, integer $product_id, integer $quantity, integer $variation_id, array $variation ) ``` + **Deprecated: This hook is deprecated and will be removed** ### Description @@ -225,32 +250,36 @@ apply_filters( 'woocommerce_add_to_cart_validation', boolean $passed_validation, ### Parameters -| Argument | Type | Description | -| ------------------- | ------- | ------------------------------------- | -| \$passed_validation | boolean | True if the item passed validation. | -| \$product_id | integer | Product ID being validated. | -| \$quantity | integer | Quantity added to the cart. | -| \$variation_id | integer | Variation ID being added to the cart. | -| \$variation | array | Variation data. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $passed_validation | boolean | True if the item passed validation. | +| $product_id | integer | Product ID being validated. | +| $quantity | integer | Quantity added to the cart. | +| $variation_id | integer | Variation ID being added to the cart. | +| $variation | array | Variation data. | ### Returns -`boolean` + +`boolean` ### Source -- [StoreApi/Utilities/CartController.php](../../src/StoreApi/Utilities/CartController.php) + + - [StoreApi/Utilities/CartController.php](../../src/StoreApi/Utilities/CartController.php) --- ## woocommerce_adjust_non_base_location_prices + Filters if taxes should be removed from locations outside the store base location. ```php apply_filters( 'woocommerce_adjust_non_base_location_prices', boolean $adjust_non_base_location_prices ) ``` + **Note: Matches filter name in WooCommerce core.** ### Description @@ -259,91 +288,106 @@ apply_filters( 'woocommerce_adjust_non_base_location_prices', boolean $adjust_no ### Parameters -| Argument | Type | Description | -| --------------------------------- | ------- | ---------------- | -| \$adjust_non_base_location_prices | boolean | True by default. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $adjust_non_base_location_prices | boolean | True by default. | ### Returns -`boolean` + +`boolean` ### Source -- [StoreApi/Utilities/ProductQuery.php](../../src/StoreApi/Utilities/ProductQuery.php) + + - [StoreApi/Utilities/ProductQuery.php](../../src/StoreApi/Utilities/ProductQuery.php) --- ## woocommerce_admin_disabled + + + ```php apply_filters( 'woocommerce_admin_disabled' ) ``` ### Source -- [InboxNotifications.php](../../src/InboxNotifications.php) + + - [InboxNotifications.php](../../src/InboxNotifications.php) --- ## woocommerce_apply_individual_use_coupon + Filter coupons to remove when applying an individual use coupon. ```php apply_filters( 'woocommerce_apply_individual_use_coupon', array $coupons, \WC_Coupon $coupon, array $applied_coupons ) ``` + **Note: Matches filter name in WooCommerce core.** ### Parameters -| Argument | Type | Description | -| ----------------- | ---------- | ----------------------------------------------------- | -| \$coupons | array | Array of coupons to remove from the cart. | -| \$coupon | \WC_Coupon | Coupon object applied to the cart. | -| \$applied_coupons | array | Array of applied coupons already applied to the cart. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $coupons | array | Array of coupons to remove from the cart. | +| $coupon | \WC_Coupon | Coupon object applied to the cart. | +| $applied_coupons | array | Array of applied coupons already applied to the cart. | ### Returns -`array` + +`array` ### Source -- [StoreApi/Utilities/CartController.php](../../src/StoreApi/Utilities/CartController.php) + + - [StoreApi/Utilities/CartController.php](../../src/StoreApi/Utilities/CartController.php) --- ## woocommerce_apply_with_individual_use_coupon + Filters if a coupon can be applied alongside other individual use coupons. ```php apply_filters( 'woocommerce_apply_with_individual_use_coupon', boolean $apply_with_individual_use_coupon, \WC_Coupon $coupon, \WC_Coupon $individual_use_coupon, array $applied_coupons ) ``` + **Note: Matches filter name in WooCommerce core.** ### Parameters -| Argument | Type | Description | -| ---------------------------------- | ---------- | ----------------------------------------------------- | -| \$apply_with_individual_use_coupon | boolean | Defaults to false. | -| \$coupon | \WC_Coupon | Coupon object applied to the cart. | -| \$individual_use_coupon | \WC_Coupon | Individual use coupon already applied to the cart. | -| \$applied_coupons | array | Array of applied coupons already applied to the cart. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $apply_with_individual_use_coupon | boolean | Defaults to false. | +| $coupon | \WC_Coupon | Coupon object applied to the cart. | +| $individual_use_coupon | \WC_Coupon | Individual use coupon already applied to the cart. | +| $applied_coupons | array | Array of applied coupons already applied to the cart. | ### Returns -`boolean` + +`boolean` ### Source -- [StoreApi/Utilities/CartController.php](../../src/StoreApi/Utilities/CartController.php) + + - [StoreApi/Utilities/CartController.php](../../src/StoreApi/Utilities/CartController.php) --- ## woocommerce_blocks_product_grid_is_cacheable + Filters whether or not the product grid is cacheable. ```php @@ -352,23 +396,26 @@ apply_filters( 'woocommerce_blocks_product_grid_is_cacheable', boolean $is_cache ### Parameters -| Argument | Type | Description | -| -------------- | ------- | ---------------------------------------------------------- | -| \$is_cacheable | boolean | The list of script dependencies. | -| \$query_args | array | Query args for the products query passed to BlocksWpQuery. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $is_cacheable | boolean | The list of script dependencies. | +| $query_args | array | Query args for the products query passed to BlocksWpQuery. | ### Returns + `array` True to enable cache, false to disable cache. ### Source -- [BlockTypes/AbstractProductGrid.php](../../src/BlockTypes/AbstractProductGrid.php) + + - [BlockTypes/AbstractProductGrid.php](../../src/BlockTypes/AbstractProductGrid.php) --- ## woocommerce_blocks_product_grid_item_html + Filters the HTML for products in the grid. ```php @@ -377,24 +424,27 @@ apply_filters( 'woocommerce_blocks_product_grid_item_html', string $html, array ### Parameters -| Argument | Type | Description | -| --------- | ----------- | ------------------------------------ | -| \$html | string | Product grid item HTML. | -| \$data | array | Product data passed to the template. | -| \$product | \WC_Product | Product object. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $html | string | Product grid item HTML. | +| $data | array | Product data passed to the template. | +| $product | \WC_Product | Product object. | ### Returns + `string` Updated product grid item HTML. ### Source -- [BlockTypes/AbstractProductGrid.php](../../src/BlockTypes/AbstractProductGrid.php) + + - [BlockTypes/AbstractProductGrid.php](../../src/BlockTypes/AbstractProductGrid.php) --- ## woocommerce_blocks_register_script_dependencies + Filters the list of script dependencies. ```php @@ -403,77 +453,88 @@ apply_filters( 'woocommerce_blocks_register_script_dependencies', array $depende ### Parameters -| Argument | Type | Description | -| -------------- | ------ | -------------------------------- | -| \$dependencies | array | The list of script dependencies. | -| \$handle | string | The script's handle. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $dependencies | array | The list of script dependencies. | +| $handle | string | The script's handle. | ### Returns -`array` + +`array` ### Source -- [Assets/Api.php](../../src/Assets/Api.php) + + - [Assets/Api.php](../../src/Assets/Api.php) --- ## woocommerce_cart_contents_changed + Filters the entire cart contents when the cart changes. ```php apply_filters( 'woocommerce_cart_contents_changed', array $cart_contents ) ``` + **Note: Matches filter name in WooCommerce core.** ### Parameters -| Argument | Type | Description | -| --------------- | ----- | ------------------------ | -| \$cart_contents | array | Array of all cart items. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $cart_contents | array | Array of all cart items. | ### Returns + `array` Updated array of all cart items. ### Source -- [StoreApi/Utilities/CartController.php](../../src/StoreApi/Utilities/CartController.php) + + - [StoreApi/Utilities/CartController.php](../../src/StoreApi/Utilities/CartController.php) --- ## woocommerce_ga_disable_tracking + Filter to disable Google Analytics tracking. ```php apply_filters( 'woocommerce_ga_disable_tracking', boolean $disable_tracking ) ``` + **Note: Matches filter name in GA extension.** ### Parameters -| Argument | Type | Description | -| ------------------ | ------- | ----------------------------------- | -| \$disable_tracking | boolean | If true, tracking will be disabled. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $disable_tracking | boolean | If true, tracking will be disabled. | ### Source -- [Domain/Services/GoogleAnalytics.php](../../src/Domain/Services/GoogleAnalytics.php) + + - [Domain/Services/GoogleAnalytics.php](../../src/Domain/Services/GoogleAnalytics.php) --- ## woocommerce_get_item_data + Filters cart item data. ```php apply_filters( 'woocommerce_get_item_data', array $item_data, array $cart_item ) ``` + **Note: Matches filter name in WooCommerce core.** ### Description @@ -482,23 +543,26 @@ apply_filters( 'woocommerce_get_item_data', array $item_data, array $cart_item ) ### Parameters -| Argument | Type | Description | -| ----------- | ----- | --------------------------------- | -| \$item_data | array | Cart item data. Empty by default. | -| \$cart_item | array | Cart item array. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $item_data | array | Cart item data. Empty by default. | +| $cart_item | array | Cart item array. | ### Returns -`array` + +`array` ### Source -- [StoreApi/Schemas/V1/CartItemSchema.php](../../src/StoreApi/Schemas/V1/CartItemSchema.php) + + - [StoreApi/Schemas/V1/CartItemSchema.php](../../src/StoreApi/Schemas/V1/CartItemSchema.php) --- ## woocommerce_new_customer_data + Filters customer data before a customer account is registered. ```php @@ -511,28 +575,32 @@ apply_filters( 'woocommerce_new_customer_data', array $customer_data ) ### Parameters -| Argument | Type | Description | -| --------------- | ----- | --------------------------------- | -| \$customer_data | array | An array of customer (user) data. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $customer_data | array | An array of customer (user) data. | ### Returns -`array` + +`array` ### Source -- [StoreApi/Routes/V1/Checkout.php](../../src/StoreApi/Routes/V1/Checkout.php) + + - [StoreApi/Routes/V1/Checkout.php](../../src/StoreApi/Routes/V1/Checkout.php) --- ## woocommerce_registration_errors + Filters registration errors before a customer account is registered. ```php apply_filters( 'woocommerce_registration_errors', \WP_Error $errors, string $username, string $user_email ) ``` + **Note: Matches filter name in WooCommerce core.** ### Description @@ -541,30 +609,34 @@ apply_filters( 'woocommerce_registration_errors', \WP_Error $errors, string $use ### Parameters -| Argument | Type | Description | -| ------------ | --------- | ----------------------- | -| \$errors | \WP_Error | Error object. | -| \$username | string | Customer username. | -| \$user_email | string | Customer email address. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $errors | \WP_Error | Error object. | +| $username | string | Customer username. | +| $user_email | string | Customer email address. | ### Returns -`\WP_Error` + +`\WP_Error` ### Source -- [StoreApi/Routes/V1/Checkout.php](../../src/StoreApi/Routes/V1/Checkout.php) + + - [StoreApi/Routes/V1/Checkout.php](../../src/StoreApi/Routes/V1/Checkout.php) --- ## ~~woocommerce_shared_settings~~ + Filters the array of shared settings. ```php apply_filters( 'woocommerce_shared_settings', array $data ) ``` + **Deprecated: This hook is deprecated and will be removed** ### Description @@ -573,50 +645,57 @@ apply_filters( 'woocommerce_shared_settings', array $data ) ### Parameters -| Argument | Type | Description | -| -------- | ----- | -------------- | -| \$data | array | Settings data. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $data | array | Settings data. | ### Returns -`array` + +`array` ### Source -- [Assets/AssetDataRegistry.php](../../src/Assets/AssetDataRegistry.php) + + - [Assets/AssetDataRegistry.php](../../src/Assets/AssetDataRegistry.php) --- ## woocommerce_shipping_package_name + Filters the shipping package name. ```php apply_filters( 'woocommerce_shipping_package_name', string $shipping_package_name, string $package_id, array $package ) ``` + **Note: Matches filter name in WooCommerce core.** ### Parameters -| Argument | Type | Description | -| ----------------------- | ------ | ---------------------------------- | -| \$shipping_package_name | string | Shipping package name. | -| \$package_id | string | Shipping package ID. | -| \$package | array | Shipping package from WooCommerce. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $shipping_package_name | string | Shipping package name. | +| $package_id | string | Shipping package ID. | +| $package | array | Shipping package from WooCommerce. | ### Returns + `string` Shipping package name. ### Source -- [StoreApi/Utilities/CartController.php](../../src/StoreApi/Utilities/CartController.php) + + - [StoreApi/Utilities/CartController.php](../../src/StoreApi/Utilities/CartController.php) --- ## woocommerce_show_page_title + We need to load the scripts here because when using block templates wp_head() gets run after the block template. As a result we are trying to enqueue required scripts before we have even registered them. ```php @@ -625,16 +704,19 @@ apply_filters( 'woocommerce_show_page_title' ) ### See -- + + - https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/5328#issuecomment-989013447 ### Source -- [BlockTypes/ClassicTemplate.php](../../src/BlockTypes/ClassicTemplate.php) + + - [BlockTypes/ClassicTemplate.php](../../src/BlockTypes/ClassicTemplate.php) --- ## woocommerce_store_api_disable_nonce_check + Filters the Store API nonce check. ```php @@ -647,22 +729,25 @@ apply_filters( 'woocommerce_store_api_disable_nonce_check', boolean $disable_non ### Parameters -| Argument | Type | Description | -| --------------------- | ------- | --------------------------------------- | -| \$disable_nonce_check | boolean | If true, nonce checks will be disabled. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $disable_nonce_check | boolean | If true, nonce checks will be disabled. | ### Returns -`boolean` + +`boolean` ### Source -- [StoreApi/Routes/V1/AbstractCartRoute.php](../../src/StoreApi/Routes/V1/AbstractCartRoute.php) + + - [StoreApi/Routes/V1/AbstractCartRoute.php](../../src/StoreApi/Routes/V1/AbstractCartRoute.php) --- ## woocommerce_store_api_product_quantity_limit + Filters the quantity limit for a product being added to the cart via the Store API. ```php @@ -675,22 +760,25 @@ apply_filters( 'woocommerce_store_api_product_quantity_limit', integer $quantity ### Parameters -| Argument | Type | Description | -| ---------------- | ----------- | ------------------------------------------------------------- | -| \$quantity_limit | integer | Quantity limit which defaults to 99 unless sold individually. | -| \$product | \WC_Product | Product instance. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $quantity_limit | integer | Quantity limit which defaults to 9999 unless sold individually. | +| $product | \WC_Product | Product instance. | ### Returns -`integer` + +`integer` ### Source -- [StoreApi/Utilities/QuantityLimits.php](../../src/StoreApi/Utilities/QuantityLimits.php) + + - [StoreApi/Utilities/QuantityLimits.php](../../src/StoreApi/Utilities/QuantityLimits.php) --- -## woocommerce*store_api_product_quantity*{\$value_type} +## woocommerce_store_api_product_quantity_{$value_type} + Filters the quantity minimum for a cart item in Store API. This allows extensions to control the minimum qty of items already within the cart. @@ -704,30 +792,34 @@ apply_filters( 'woocommerce_store_api_product_quantity_{$value_type}', mixed $va ### Parameters -| Argument | Type | Description | -| ----------- | ----------- | --------------------------------------------------------- | -| \$value | mixed | The value being filtered. | -| \$product | \WC_Product | The product object. | -| \$cart_item | array, null | The cart item if the product exists in the cart, or null. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $value | mixed | The value being filtered. | +| $product | \WC_Product | The product object. | +| $cart_item | array, null | The cart item if the product exists in the cart, or null. | ### Returns -`mixed` + +`mixed` ### Source -- [StoreApi/Utilities/QuantityLimits.php](../../src/StoreApi/Utilities/QuantityLimits.php) + + - [StoreApi/Utilities/QuantityLimits.php](../../src/StoreApi/Utilities/QuantityLimits.php) --- ## woocommerce_variation_option_name + Filters the variation option name. ```php apply_filters( 'woocommerce_variation_option_name', string $value, null $unused, string $taxonomy, \WC_Product $product ) ``` + **Note: Matches filter name in WooCommerce core.** ### Description @@ -736,29 +828,31 @@ apply_filters( 'woocommerce_variation_option_name', string $value, null $unused, ### Parameters -| Argument | Type | Description | -| ---------- | ----------- | ------------------------------------------------ | -| \$value | string | The name to display. | -| \$unused | null | Unused because this is not a variation taxonomy. | -| \$taxonomy | string | Taxonomy or product attribute name. | -| \$product | \WC_Product | Product data. | +| Argument | Type | Description | +| -------- | ---- | ----------- | +| $value | string | The name to display. | +| $unused | null | Unused because this is not a variation taxonomy. | +| $taxonomy | string | Taxonomy or product attribute name. | +| $product | \WC_Product | Product data. | ### Returns -`string` + +`string` ### Source -- [StoreApi/Schemas/V1/CartItemSchema.php](../../src/StoreApi/Schemas/V1/CartItemSchema.php) ---- + - [StoreApi/Schemas/V1/CartItemSchema.php](../../src/StoreApi/Schemas/V1/CartItemSchema.php) +--- --- [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/extensibility/filters.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/third-party-developers/extensibility/hooks/filters.md) + diff --git a/docs/third-party-developers/extensibility/rest-api/available-endpoints-to-extend.md b/docs/third-party-developers/extensibility/rest-api/available-endpoints-to-extend.md index 962526fd4cc..483e8b809c1 100644 --- a/docs/third-party-developers/extensibility/rest-api/available-endpoints-to-extend.md +++ b/docs/third-party-developers/extensibility/rest-api/available-endpoints-to-extend.md @@ -59,6 +59,7 @@ The main products endpoint is extensible via ExtendSchema. The data is available [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/extensibility/available-endpoints-to-extend.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/third-party-developers/extensibility/rest-api/available-endpoints-to-extend.md) + diff --git a/docs/third-party-developers/extensibility/rest-api/extend-rest-api-add-data.md b/docs/third-party-developers/extensibility/rest-api/extend-rest-api-add-data.md index 5bbc5cb77da..94fdf02d5bc 100644 --- a/docs/third-party-developers/extensibility/rest-api/extend-rest-api-add-data.md +++ b/docs/third-party-developers/extensibility/rest-api/extend-rest-api-add-data.md @@ -334,6 +334,7 @@ You may wish to use our pre-existing Formatters to ensure your data is passed th [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/extensibility/extend-rest-api-add-data.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/third-party-developers/extensibility/rest-api/extend-rest-api-add-data.md) + diff --git a/docs/third-party-developers/extensibility/rest-api/extend-rest-api-formatters.md b/docs/third-party-developers/extensibility/rest-api/extend-rest-api-formatters.md index eaa1175489b..c3337397ef6 100644 --- a/docs/third-party-developers/extensibility/rest-api/extend-rest-api-formatters.md +++ b/docs/third-party-developers/extensibility/rest-api/extend-rest-api-formatters.md @@ -139,6 +139,7 @@ alert('bad script!') This “coffee” is very strong. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/extensibility/extend-rest-api-formatters.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/third-party-developers/extensibility/rest-api/extend-rest-api-formatters.md) + diff --git a/docs/third-party-developers/extensibility/rest-api/extend-rest-api-new-endpoint.md b/docs/third-party-developers/extensibility/rest-api/extend-rest-api-new-endpoint.md index 64811449949..b715a1dda9f 100644 --- a/docs/third-party-developers/extensibility/rest-api/extend-rest-api-new-endpoint.md +++ b/docs/third-party-developers/extensibility/rest-api/extend-rest-api-new-endpoint.md @@ -46,6 +46,7 @@ Extending a new endpoint is usually half the work, you will need to receive this [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/extensibility/extend-rest-api-new-endpoint.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/third-party-developers/extensibility/rest-api/extend-rest-api-new-endpoint.md) + diff --git a/docs/third-party-developers/extensibility/rest-api/extend-rest-api-update-cart.md b/docs/third-party-developers/extensibility/rest-api/extend-rest-api-update-cart.md index 818aaaa0245..0a87eb0e464 100644 --- a/docs/third-party-developers/extensibility/rest-api/extend-rest-api-update-cart.md +++ b/docs/third-party-developers/extensibility/rest-api/extend-rest-api-update-cart.md @@ -188,6 +188,7 @@ Now that this is registered, when the button is pressed, the `cart/extensions` e [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/extensibility/extend-rest-api-update-cart.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./docs/third-party-developers/extensibility/rest-api/extend-rest-api-update-cart.md) + diff --git a/package-lock.json b/package-lock.json index 6ecccf23812..546603c8e24 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,12 +1,12 @@ { "name": "@woocommerce/block-library", - "version": "8.2.0-dev", + "version": "8.3.0-dev", "lockfileVersion": 2, "requires": true, "packages": { "": { "name": "@woocommerce/block-library", - "version": "8.2.0-dev", + "version": "8.3.0-dev", "hasInstallScript": true, "license": "GPL-3.0+", "dependencies": { @@ -19,7 +19,7 @@ "@wordpress/primitives": "3.0.4", "@wordpress/server-side-render": "3.10.0", "@wordpress/url": "3.13.0", - "@wordpress/wordcount": "3.12.0", + "@wordpress/wordcount": "3.13.0", "classnames": "2.3.1", "compare-versions": "4.1.3", "config": "3.3.7", @@ -39,8 +39,8 @@ "@actions/core": "1.9.0", "@actions/github": "5.0.3", "@automattic/color-studio": "2.5.0", - "@babel/cli": "7.18.6", - "@babel/core": "7.18.6", + "@babel/cli": "7.18.9", + "@babel/core": "7.18.9", "@babel/plugin-proposal-class-properties": "7.18.6", "@babel/plugin-syntax-jsx": "7.18.6", "@babel/polyfill": "7.12.1", @@ -60,7 +60,7 @@ "@types/classnames": "2.3.0", "@types/dinero.js": "1.9.0", "@types/gtag.js": "0.0.10", - "@types/jest": "27.4.1", + "@types/jest": "27.5.2", "@types/jest-environment-puppeteer": "5.0.2", "@types/jquery": "3.5.14", "@types/lodash": "4.14.182", @@ -68,17 +68,17 @@ "@types/react": "17.0.47", "@types/react-dom": "17.0.17", "@types/wordpress__block-editor": "6.0.6", - "@types/wordpress__blocks": "11.0.3", + "@types/wordpress__blocks": "11.0.5", "@types/wordpress__compose": "4.0.1", "@types/wordpress__data": "4.6.11", "@types/wordpress__data-controls": "2.2.0", "@typescript-eslint/eslint-plugin": "5.30.5", - "@typescript-eslint/parser": "5.30.5", + "@typescript-eslint/parser": "5.31.0", "@woocommerce/api": "0.2.0", "@woocommerce/e2e-utils": "0.2.0", "@woocommerce/eslint-plugin": "2.0.0", "@woocommerce/woocommerce-rest-api": "1.0.1", - "@wordpress/api-fetch": "6.9.0", + "@wordpress/api-fetch": "6.11.0", "@wordpress/babel-preset-default": "6.14.0", "@wordpress/base-styles": "4.0.4", "@wordpress/block-editor": "8.2.0", @@ -93,8 +93,8 @@ "@wordpress/element": "4.0.4", "@wordpress/env": "4.9.0", "@wordpress/html-entities": "3.12.0", - "@wordpress/i18n": "4.12.0", - "@wordpress/is-shallow-equal": "4.12.0", + "@wordpress/i18n": "4.14.0", + "@wordpress/is-shallow-equal": "4.13.0", "@wordpress/prettier-config": "1.4.0", "@wordpress/scripts": "22.3.0", "autoprefixer": "10.4.7", @@ -137,7 +137,7 @@ "lodash": "4.17.21", "markdown-it": "13.0.1", "merge-config": "2.0.0", - "mini-css-extract-plugin": "1.3.6", + "mini-css-extract-plugin": "1.6.2", "patch-package": "6.4.7", "postcss": "8.4.14", "postcss-loader": "4.2.0", @@ -233,9 +233,9 @@ "dev": true }, "node_modules/@babel/cli": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/cli/-/cli-7.18.6.tgz", - "integrity": "sha512-jXNHoYCbxZ8rKy+2lyy0VjcaGxS4NPbN0qc95DjIiGZQL/mTNx3o2/yI0TG+X0VrrTuwmO7zH52T9NcNdbF9Uw==", + "version": "7.18.9", + "resolved": "https://registry.npmjs.org/@babel/cli/-/cli-7.18.9.tgz", + "integrity": "sha512-e7TOtHVrAXBJGNgoROVxqx0mathd01oJGXIDekRfxdrISnRqfM795APwkDtse9GdyPYivjg3iXiko3sF3W7f5Q==", "dev": true, "dependencies": { "@jridgewell/trace-mapping": "^0.3.8", @@ -290,20 +290,20 @@ } }, "node_modules/@babel/core": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.18.6.tgz", - "integrity": "sha512-cQbWBpxcbbs/IUredIPkHiAGULLV8iwgNRMFzvbhEXISp4f3rUUXE5+TIw6KwUWUR3DwyI6gmBRnmAtYaWehwQ==", + "version": "7.18.9", + "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.18.9.tgz", + "integrity": "sha512-1LIb1eL8APMy91/IMW+31ckrfBM4yCoLaVzoDhZUKSM4cu1L1nIidyxkCgzPAgrC5WEz36IPEr/eSeSF9pIn+g==", "dependencies": { "@ampproject/remapping": "^2.1.0", "@babel/code-frame": "^7.18.6", - "@babel/generator": "^7.18.6", - "@babel/helper-compilation-targets": "^7.18.6", - "@babel/helper-module-transforms": "^7.18.6", - "@babel/helpers": "^7.18.6", - "@babel/parser": "^7.18.6", + "@babel/generator": "^7.18.9", + "@babel/helper-compilation-targets": "^7.18.9", + "@babel/helper-module-transforms": "^7.18.9", + "@babel/helpers": "^7.18.9", + "@babel/parser": "^7.18.9", "@babel/template": "^7.18.6", - "@babel/traverse": "^7.18.6", - "@babel/types": "^7.18.6", + "@babel/traverse": "^7.18.9", + "@babel/types": "^7.18.9", "convert-source-map": "^1.7.0", "debug": "^4.1.0", "gensync": "^1.0.0-beta.2", @@ -9823,9 +9823,9 @@ } }, "node_modules/@types/jest": { - "version": "27.4.1", - "resolved": "https://registry.npmjs.org/@types/jest/-/jest-27.4.1.tgz", - "integrity": "sha512-23iPJADSmicDVrWk+HT58LMJtzLAnB2AgIzplQuq/bSrGaxCrlvRFjGbXmamnnk/mAmCdLStiGqggu28ocUyiw==", + "version": "27.5.2", + "resolved": "https://registry.npmjs.org/@types/jest/-/jest-27.5.2.tgz", + "integrity": "sha512-mpT8LJJ4CMeeahobofYWIjFo0xonRS/HfxnVEPMPFSQdGUt1uHCnoPT7Zhb+sjDU2wz0oKV0OLUR0WzrHNgfeA==", "dev": true, "dependencies": { "jest-matcher-utils": "^27.0.0", @@ -10248,9 +10248,9 @@ } }, "node_modules/@types/wordpress__blocks": { - "version": "11.0.3", - "resolved": "https://registry.npmjs.org/@types/wordpress__blocks/-/wordpress__blocks-11.0.3.tgz", - "integrity": "sha512-RdqPrwQB+m8noBAzhhMGadRLNwe1Z7DIhhQ4caoV2jshabAu5+vEMMz+vGNTmymc9GQv0QxxuuRjhe/l1iPx9g==", + "version": "11.0.5", + "resolved": "https://registry.npmjs.org/@types/wordpress__blocks/-/wordpress__blocks-11.0.5.tgz", + "integrity": "sha512-DO5PMIM+zhuLtLzykYD1Z92aBo7hoEpXbi9Rg3LwDeVphBDIBdU7T9t0hwJPVRCtAUZdzHwpq3dNPbx2yw2r2g==", "dev": true, "dependencies": { "@types/react": "*", @@ -10617,14 +10617,14 @@ } }, "node_modules/@typescript-eslint/parser": { - "version": "5.30.5", - "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-5.30.5.tgz", - "integrity": "sha512-zj251pcPXI8GO9NDKWWmygP6+UjwWmrdf9qMW/L/uQJBM/0XbU2inxe5io/234y/RCvwpKEYjZ6c1YrXERkK4Q==", + "version": "5.31.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-5.31.0.tgz", + "integrity": "sha512-UStjQiZ9OFTFReTrN+iGrC6O/ko9LVDhreEK5S3edmXgR396JGq7CoX2TWIptqt/ESzU2iRKXAHfSF2WJFcWHw==", "dev": true, "dependencies": { - "@typescript-eslint/scope-manager": "5.30.5", - "@typescript-eslint/types": "5.30.5", - "@typescript-eslint/typescript-estree": "5.30.5", + "@typescript-eslint/scope-manager": "5.31.0", + "@typescript-eslint/types": "5.31.0", + "@typescript-eslint/typescript-estree": "5.31.0", "debug": "^4.3.4" }, "engines": { @@ -10643,6 +10643,95 @@ } } }, + "node_modules/@typescript-eslint/parser/node_modules/@typescript-eslint/scope-manager": { + "version": "5.31.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-5.31.0.tgz", + "integrity": "sha512-8jfEzBYDBG88rcXFxajdVavGxb5/XKXyvWgvD8Qix3EEJLCFIdVloJw+r9ww0wbyNLOTYyBsR+4ALNGdlalLLg==", + "dev": true, + "dependencies": { + "@typescript-eslint/types": "5.31.0", + "@typescript-eslint/visitor-keys": "5.31.0" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/typescript-eslint" + } + }, + "node_modules/@typescript-eslint/parser/node_modules/@typescript-eslint/types": { + "version": "5.31.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-5.31.0.tgz", + "integrity": "sha512-/f/rMaEseux+I4wmR6mfpM2wvtNZb1p9hAV77hWfuKc3pmaANp5dLAZSiE3/8oXTYTt3uV9KW5yZKJsMievp6g==", + "dev": true, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/typescript-eslint" + } + }, + "node_modules/@typescript-eslint/parser/node_modules/@typescript-eslint/typescript-estree": { + "version": "5.31.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-5.31.0.tgz", + "integrity": "sha512-3S625TMcARX71wBc2qubHaoUwMEn+l9TCsaIzYI/ET31Xm2c9YQ+zhGgpydjorwQO9pLfR/6peTzS/0G3J/hDw==", + "dev": true, + "dependencies": { + "@typescript-eslint/types": "5.31.0", + "@typescript-eslint/visitor-keys": "5.31.0", + "debug": "^4.3.4", + "globby": "^11.1.0", + "is-glob": "^4.0.3", + "semver": "^7.3.7", + "tsutils": "^3.21.0" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/typescript-eslint" + }, + "peerDependenciesMeta": { + "typescript": { + "optional": true + } + } + }, + "node_modules/@typescript-eslint/parser/node_modules/@typescript-eslint/visitor-keys": { + "version": "5.31.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-5.31.0.tgz", + "integrity": "sha512-ZK0jVxSjS4gnPirpVjXHz7mgdOsZUHzNYSfTw2yPa3agfbt9YfqaBiBZFSSxeBWnpWkzCxTfUpnzA3Vily/CSg==", + "dev": true, + "dependencies": { + "@typescript-eslint/types": "5.31.0", + "eslint-visitor-keys": "^3.3.0" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/typescript-eslint" + } + }, + "node_modules/@typescript-eslint/parser/node_modules/semver": { + "version": "7.3.7", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.7.tgz", + "integrity": "sha512-QlYTucUYOews+WeEujDoEGziz4K6c47V/Bd+LjSSYcA94p+DmINdf7ncaUinThfvZyu13lN9OY1XDxt8C0Tw0g==", + "dev": true, + "dependencies": { + "lru-cache": "^6.0.0" + }, + "bin": { + "semver": "bin/semver.js" + }, + "engines": { + "node": ">=10" + } + }, "node_modules/@typescript-eslint/scope-manager": { "version": "5.30.5", "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-5.30.5.tgz", @@ -11254,34 +11343,26 @@ "node": ">=12" } }, - "node_modules/@wordpress/a11y/node_modules/@wordpress/i18n": { - "version": "4.13.0", - "resolved": "https://registry.npmjs.org/@wordpress/i18n/-/i18n-4.13.0.tgz", - "integrity": "sha512-25x0ylQzXxbaw3oM8afoahiPzzZfzikBNzkzlEJ4MuI9u61zmFedbkIrsmhXtYNlcZ/52RxeUcswHdVs4Hln9Q==", + "node_modules/@wordpress/api-fetch": { + "version": "6.11.0", + "resolved": "https://registry.npmjs.org/@wordpress/api-fetch/-/api-fetch-6.11.0.tgz", + "integrity": "sha512-C1HTWdJQ7ikhJ4mT+rONTODquJ/Xq5HteKak/VN+vf1VmLVfRX18wJ84kCAAZ83UNOIsE8EgjJrjJy//R+HWzg==", "dependencies": { "@babel/runtime": "^7.16.0", - "@wordpress/hooks": "^3.13.0", - "gettext-parser": "^1.3.1", - "lodash": "^4.17.21", - "memize": "^1.1.0", - "sprintf-js": "^1.1.1", - "tannin": "^1.2.0" - }, - "bin": { - "pot-to-php": "tools/pot-to-php.js" + "@wordpress/i18n": "^4.14.0", + "@wordpress/url": "^3.15.0" }, "engines": { "node": ">=12" } }, - "node_modules/@wordpress/api-fetch": { - "version": "6.9.0", - "resolved": "https://registry.npmjs.org/@wordpress/api-fetch/-/api-fetch-6.9.0.tgz", - "integrity": "sha512-H0IvLlisBcfKFa4tlMgtqFy7s7Iz3SSe6cEzqAAesK1fg+j3NewDP4fcQz5Ooo6pL+Y2A8oUM5dawjJctmsnAA==", + "node_modules/@wordpress/api-fetch/node_modules/@wordpress/url": { + "version": "3.15.0", + "resolved": "https://registry.npmjs.org/@wordpress/url/-/url-3.15.0.tgz", + "integrity": "sha512-LLlgCMbherqqnxAuK6kb997MKkzfnvkyQQ5RazBQKBn//RBXrW/w6BMVglm4QjV7L65N/IfqFd36QLZDMuiYDA==", "dependencies": { "@babel/runtime": "^7.16.0", - "@wordpress/i18n": "^4.12.0", - "@wordpress/url": "^3.13.0" + "remove-accents": "^0.4.2" }, "engines": { "node": ">=12" @@ -11803,7 +11884,7 @@ "@wordpress/compose": "^5.11.0", "@wordpress/deprecated": "^3.13.0", "@wordpress/element": "^4.11.0", - "@wordpress/is-shallow-equal": "^4.13.0", + "@wordpress/is-shallow-equal": "4.13.0", "@wordpress/priority-queue": "^2.13.0", "@wordpress/redux-routine": "^4.13.0", "equivalent-key-map": "^0.2.2", @@ -11860,7 +11941,7 @@ "@wordpress/deprecated": "^3.13.0", "@wordpress/dom": "^3.13.0", "@wordpress/element": "^4.11.0", - "@wordpress/is-shallow-equal": "^4.13.0", + "@wordpress/is-shallow-equal": "4.13.0", "@wordpress/keycodes": "^3.13.0", "@wordpress/priority-queue": "^2.13.0", "clipboard": "^2.0.8", @@ -11917,17 +11998,6 @@ "node": ">=12" } }, - "node_modules/@wordpress/data/node_modules/@wordpress/is-shallow-equal": { - "version": "4.13.0", - "resolved": "https://registry.npmjs.org/@wordpress/is-shallow-equal/-/is-shallow-equal-4.13.0.tgz", - "integrity": "sha512-oUoMbEZwnbd4nfEo6uxkvrNCc/LnqC9MIY6kK3iWtMhcykQNpbK3XY/i/NvJb+QpRf7U6XhXyw4//HcQv39iOA==", - "dependencies": { - "@babel/runtime": "^7.16.0" - }, - "engines": { - "node": ">=12" - } - }, "node_modules/@wordpress/date": { "version": "4.13.0", "resolved": "https://registry.npmjs.org/@wordpress/date/-/date-4.13.0.tgz", @@ -13966,9 +14036,9 @@ } }, "node_modules/@wordpress/hooks": { - "version": "3.13.0", - "resolved": "https://registry.npmjs.org/@wordpress/hooks/-/hooks-3.13.0.tgz", - "integrity": "sha512-N+82Dt3jsREtN0dCypehaWuwCjPOM3ljxyzVWULMDrIK9TaIvkunkHViIyoCkxWk3lolRRqh8XmD+ox/mF+n1A==", + "version": "3.14.0", + "resolved": "https://registry.npmjs.org/@wordpress/hooks/-/hooks-3.14.0.tgz", + "integrity": "sha512-bcQXql4A1VI6gnTdNzMjdHLGTpnf8oWOQ1r8B8fcvtOF3dKictxJPobarWxFbtVTQoegizZT/lPCMoLsnVJpug==", "dependencies": { "@babel/runtime": "^7.16.0" }, @@ -13989,12 +14059,12 @@ } }, "node_modules/@wordpress/i18n": { - "version": "4.12.0", - "resolved": "https://registry.npmjs.org/@wordpress/i18n/-/i18n-4.12.0.tgz", - "integrity": "sha512-UTccrAOZ03nszzlG74G+ZkMR/kK0PoS1fqFa8NRFAhHneYadJOnsgCCd5YgDAsN+tAKA6QM7RPmpQMwujvIbzA==", + "version": "4.14.0", + "resolved": "https://registry.npmjs.org/@wordpress/i18n/-/i18n-4.14.0.tgz", + "integrity": "sha512-46ryvPbh139RkLXQt8oey4aCcWo6HRKb1NLVHU4a4kJ4HRD/HLhAeTHKAMiZFWTg+QC1HZC32vGdEikqrpnlzQ==", "dependencies": { "@babel/runtime": "^7.16.0", - "@wordpress/hooks": "^3.12.0", + "@wordpress/hooks": "^3.14.0", "gettext-parser": "^1.3.1", "lodash": "^4.17.21", "memize": "^1.1.0", @@ -14022,9 +14092,9 @@ } }, "node_modules/@wordpress/is-shallow-equal": { - "version": "4.12.0", - "resolved": "https://registry.npmjs.org/@wordpress/is-shallow-equal/-/is-shallow-equal-4.12.0.tgz", - "integrity": "sha512-jlpHXPLJw0mG13bcbZIJwOd1DQozJ5+fbkkKA2JeTO5d5PXs44Rw6EYdGMLUU97B44UxIwVbaui7tJGOvzF8Dw==", + "version": "4.13.0", + "resolved": "https://registry.npmjs.org/@wordpress/is-shallow-equal/-/is-shallow-equal-4.13.0.tgz", + "integrity": "sha512-oUoMbEZwnbd4nfEo6uxkvrNCc/LnqC9MIY6kK3iWtMhcykQNpbK3XY/i/NvJb+QpRf7U6XhXyw4//HcQv39iOA==", "dependencies": { "@babel/runtime": "^7.16.0" }, @@ -14158,26 +14228,6 @@ "node": ">=12" } }, - "node_modules/@wordpress/keycodes/node_modules/@wordpress/i18n": { - "version": "4.13.0", - "resolved": "https://registry.npmjs.org/@wordpress/i18n/-/i18n-4.13.0.tgz", - "integrity": "sha512-25x0ylQzXxbaw3oM8afoahiPzzZfzikBNzkzlEJ4MuI9u61zmFedbkIrsmhXtYNlcZ/52RxeUcswHdVs4Hln9Q==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/hooks": "^3.13.0", - "gettext-parser": "^1.3.1", - "lodash": "^4.17.21", - "memize": "^1.1.0", - "sprintf-js": "^1.1.1", - "tannin": "^1.2.0" - }, - "bin": { - "pot-to-php": "tools/pot-to-php.js" - }, - "engines": { - "node": ">=12" - } - }, "node_modules/@wordpress/notices": { "version": "3.12.0", "resolved": "https://registry.npmjs.org/@wordpress/notices/-/notices-3.12.0.tgz", @@ -14236,7 +14286,7 @@ "@wordpress/deprecated": "^3.13.0", "@wordpress/dom": "^3.13.0", "@wordpress/element": "^4.11.0", - "@wordpress/is-shallow-equal": "^4.13.0", + "@wordpress/is-shallow-equal": "4.13.0", "@wordpress/keycodes": "^3.13.0", "@wordpress/priority-queue": "^2.13.0", "clipboard": "^2.0.8", @@ -14306,17 +14356,6 @@ "node": ">=12" } }, - "node_modules/@wordpress/plugins/node_modules/@wordpress/is-shallow-equal": { - "version": "4.13.0", - "resolved": "https://registry.npmjs.org/@wordpress/is-shallow-equal/-/is-shallow-equal-4.13.0.tgz", - "integrity": "sha512-oUoMbEZwnbd4nfEo6uxkvrNCc/LnqC9MIY6kK3iWtMhcykQNpbK3XY/i/NvJb+QpRf7U6XhXyw4//HcQv39iOA==", - "dependencies": { - "@babel/runtime": "^7.16.0" - }, - "engines": { - "node": ">=12" - } - }, "node_modules/@wordpress/plugins/node_modules/@wordpress/primitives": { "version": "3.11.0", "resolved": "https://registry.npmjs.org/@wordpress/primitives/-/primitives-3.11.0.tgz", @@ -14440,7 +14479,7 @@ "@wordpress/deprecated": "^3.13.0", "@wordpress/dom": "^3.13.0", "@wordpress/element": "^4.11.0", - "@wordpress/is-shallow-equal": "^4.13.0", + "@wordpress/is-shallow-equal": "4.13.0", "@wordpress/keycodes": "^3.13.0", "@wordpress/priority-queue": "^2.13.0", "clipboard": "^2.0.8", @@ -14497,37 +14536,6 @@ "node": ">=12" } }, - "node_modules/@wordpress/rich-text/node_modules/@wordpress/i18n": { - "version": "4.13.0", - "resolved": "https://registry.npmjs.org/@wordpress/i18n/-/i18n-4.13.0.tgz", - "integrity": "sha512-25x0ylQzXxbaw3oM8afoahiPzzZfzikBNzkzlEJ4MuI9u61zmFedbkIrsmhXtYNlcZ/52RxeUcswHdVs4Hln9Q==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/hooks": "^3.13.0", - "gettext-parser": "^1.3.1", - "lodash": "^4.17.21", - "memize": "^1.1.0", - "sprintf-js": "^1.1.1", - "tannin": "^1.2.0" - }, - "bin": { - "pot-to-php": "tools/pot-to-php.js" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/rich-text/node_modules/@wordpress/is-shallow-equal": { - "version": "4.13.0", - "resolved": "https://registry.npmjs.org/@wordpress/is-shallow-equal/-/is-shallow-equal-4.13.0.tgz", - "integrity": "sha512-oUoMbEZwnbd4nfEo6uxkvrNCc/LnqC9MIY6kK3iWtMhcykQNpbK3XY/i/NvJb+QpRf7U6XhXyw4//HcQv39iOA==", - "dependencies": { - "@babel/runtime": "^7.16.0" - }, - "engines": { - "node": ">=12" - } - }, "node_modules/@wordpress/rich-text/node_modules/rememo": { "version": "4.0.1", "resolved": "https://registry.npmjs.org/rememo/-/rememo-4.0.1.tgz", @@ -16158,7 +16166,7 @@ "@wordpress/hooks": "^3.13.0", "@wordpress/html-entities": "^3.13.0", "@wordpress/i18n": "^4.13.0", - "@wordpress/is-shallow-equal": "^4.13.0", + "@wordpress/is-shallow-equal": "4.13.0", "@wordpress/shortcode": "^3.13.0", "colord": "^2.7.0", "hpq": "^1.3.0", @@ -16200,7 +16208,7 @@ "@wordpress/hooks": "^3.13.0", "@wordpress/i18n": "^4.13.0", "@wordpress/icons": "^9.4.0", - "@wordpress/is-shallow-equal": "^4.13.0", + "@wordpress/is-shallow-equal": "4.13.0", "@wordpress/keycodes": "^3.13.0", "@wordpress/primitives": "^3.11.0", "@wordpress/rich-text": "^5.11.0", @@ -16241,7 +16249,7 @@ "@wordpress/deprecated": "^3.13.0", "@wordpress/dom": "^3.13.0", "@wordpress/element": "^4.11.0", - "@wordpress/is-shallow-equal": "^4.13.0", + "@wordpress/is-shallow-equal": "4.13.0", "@wordpress/keycodes": "^3.13.0", "@wordpress/priority-queue": "^2.13.0", "clipboard": "^2.0.8", @@ -16309,26 +16317,6 @@ "node": ">=12" } }, - "node_modules/@wordpress/server-side-render/node_modules/@wordpress/i18n": { - "version": "4.13.0", - "resolved": "https://registry.npmjs.org/@wordpress/i18n/-/i18n-4.13.0.tgz", - "integrity": "sha512-25x0ylQzXxbaw3oM8afoahiPzzZfzikBNzkzlEJ4MuI9u61zmFedbkIrsmhXtYNlcZ/52RxeUcswHdVs4Hln9Q==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/hooks": "^3.13.0", - "gettext-parser": "^1.3.1", - "lodash": "^4.17.21", - "memize": "^1.1.0", - "sprintf-js": "^1.1.1", - "tannin": "^1.2.0" - }, - "bin": { - "pot-to-php": "tools/pot-to-php.js" - }, - "engines": { - "node": ">=12" - } - }, "node_modules/@wordpress/server-side-render/node_modules/@wordpress/icons": { "version": "9.4.0", "resolved": "https://registry.npmjs.org/@wordpress/icons/-/icons-9.4.0.tgz", @@ -16342,17 +16330,6 @@ "node": ">=12" } }, - "node_modules/@wordpress/server-side-render/node_modules/@wordpress/is-shallow-equal": { - "version": "4.13.0", - "resolved": "https://registry.npmjs.org/@wordpress/is-shallow-equal/-/is-shallow-equal-4.13.0.tgz", - "integrity": "sha512-oUoMbEZwnbd4nfEo6uxkvrNCc/LnqC9MIY6kK3iWtMhcykQNpbK3XY/i/NvJb+QpRf7U6XhXyw4//HcQv39iOA==", - "dependencies": { - "@babel/runtime": "^7.16.0" - }, - "engines": { - "node": ">=12" - } - }, "node_modules/@wordpress/server-side-render/node_modules/@wordpress/primitives": { "version": "3.11.0", "resolved": "https://registry.npmjs.org/@wordpress/primitives/-/primitives-3.11.0.tgz", @@ -16673,9 +16650,9 @@ } }, "node_modules/@wordpress/wordcount": { - "version": "3.12.0", - "resolved": "https://registry.npmjs.org/@wordpress/wordcount/-/wordcount-3.12.0.tgz", - "integrity": "sha512-noYFwkpzq7uCG85mYFSZueKF+eMXx9vGc6pgY6NX5tKiSsVrcea/SWWuwJcAA3XOtXcDxElf0kzYm7vPOGo1bg==", + "version": "3.13.0", + "resolved": "https://registry.npmjs.org/@wordpress/wordcount/-/wordcount-3.13.0.tgz", + "integrity": "sha512-P0HJZ70BIqAXW5kUccHfSAD6xH/geTOwp5RhZdtyUAqnlj9UR3FPY71XG7EEc1CkCD82+0Bc+iw0wm+oV6PKIQ==", "dependencies": { "@babel/runtime": "^7.16.0" }, @@ -37552,9 +37529,9 @@ } }, "node_modules/mini-css-extract-plugin": { - "version": "1.3.6", - "resolved": "https://registry.npmjs.org/mini-css-extract-plugin/-/mini-css-extract-plugin-1.3.6.tgz", - "integrity": "sha512-t86rLnySRQgN2+58gAIARTEtnClLNZoC99shNrvQ960V/wB9n50AUKJyqly76/s4fT0zwaLFIDFZAW7aK25pvg==", + "version": "1.6.2", + "resolved": "https://registry.npmjs.org/mini-css-extract-plugin/-/mini-css-extract-plugin-1.6.2.tgz", + "integrity": "sha512-WhDvO3SjGm40oV5y26GjMJYjd2UMqrLAGKy5YS2/3QKJy2F7jgynuHTir/tgUUOiNQu5saXHdc8reo7YuhhT4Q==", "dev": true, "dependencies": { "loader-utils": "^2.0.0", @@ -51708,9 +51685,9 @@ "dev": true }, "@babel/cli": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/cli/-/cli-7.18.6.tgz", - "integrity": "sha512-jXNHoYCbxZ8rKy+2lyy0VjcaGxS4NPbN0qc95DjIiGZQL/mTNx3o2/yI0TG+X0VrrTuwmO7zH52T9NcNdbF9Uw==", + "version": "7.18.9", + "resolved": "https://registry.npmjs.org/@babel/cli/-/cli-7.18.9.tgz", + "integrity": "sha512-e7TOtHVrAXBJGNgoROVxqx0mathd01oJGXIDekRfxdrISnRqfM795APwkDtse9GdyPYivjg3iXiko3sF3W7f5Q==", "dev": true, "requires": { "@jridgewell/trace-mapping": "^0.3.8", @@ -51746,20 +51723,20 @@ "integrity": "sha512-HSmX4WZPPK3FUxYp7g2T6EyO8j96HlZJlxmKPSh6KAcqwyDrfx7hKjXpAW/0FhFfTJsR0Yt4lAjLI2coMptIHQ==" }, "@babel/core": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.18.6.tgz", - "integrity": "sha512-cQbWBpxcbbs/IUredIPkHiAGULLV8iwgNRMFzvbhEXISp4f3rUUXE5+TIw6KwUWUR3DwyI6gmBRnmAtYaWehwQ==", + "version": "7.18.9", + "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.18.9.tgz", + "integrity": "sha512-1LIb1eL8APMy91/IMW+31ckrfBM4yCoLaVzoDhZUKSM4cu1L1nIidyxkCgzPAgrC5WEz36IPEr/eSeSF9pIn+g==", "requires": { "@ampproject/remapping": "^2.1.0", "@babel/code-frame": "^7.18.6", - "@babel/generator": "^7.18.6", - "@babel/helper-compilation-targets": "^7.18.6", - "@babel/helper-module-transforms": "^7.18.6", - "@babel/helpers": "^7.18.6", - "@babel/parser": "^7.18.6", + "@babel/generator": "^7.18.9", + "@babel/helper-compilation-targets": "^7.18.9", + "@babel/helper-module-transforms": "^7.18.9", + "@babel/helpers": "^7.18.9", + "@babel/parser": "^7.18.9", "@babel/template": "^7.18.6", - "@babel/traverse": "^7.18.6", - "@babel/types": "^7.18.6", + "@babel/traverse": "^7.18.9", + "@babel/types": "^7.18.9", "convert-source-map": "^1.7.0", "debug": "^4.1.0", "gensync": "^1.0.0-beta.2", @@ -58975,9 +58952,9 @@ } }, "@types/jest": { - "version": "27.4.1", - "resolved": "https://registry.npmjs.org/@types/jest/-/jest-27.4.1.tgz", - "integrity": "sha512-23iPJADSmicDVrWk+HT58LMJtzLAnB2AgIzplQuq/bSrGaxCrlvRFjGbXmamnnk/mAmCdLStiGqggu28ocUyiw==", + "version": "27.5.2", + "resolved": "https://registry.npmjs.org/@types/jest/-/jest-27.5.2.tgz", + "integrity": "sha512-mpT8LJJ4CMeeahobofYWIjFo0xonRS/HfxnVEPMPFSQdGUt1uHCnoPT7Zhb+sjDU2wz0oKV0OLUR0WzrHNgfeA==", "dev": true, "requires": { "jest-matcher-utils": "^27.0.0", @@ -59396,9 +59373,9 @@ } }, "@types/wordpress__blocks": { - "version": "11.0.3", - "resolved": "https://registry.npmjs.org/@types/wordpress__blocks/-/wordpress__blocks-11.0.3.tgz", - "integrity": "sha512-RdqPrwQB+m8noBAzhhMGadRLNwe1Z7DIhhQ4caoV2jshabAu5+vEMMz+vGNTmymc9GQv0QxxuuRjhe/l1iPx9g==", + "version": "11.0.5", + "resolved": "https://registry.npmjs.org/@types/wordpress__blocks/-/wordpress__blocks-11.0.5.tgz", + "integrity": "sha512-DO5PMIM+zhuLtLzykYD1Z92aBo7hoEpXbi9Rg3LwDeVphBDIBdU7T9t0hwJPVRCtAUZdzHwpq3dNPbx2yw2r2g==", "dev": true, "requires": { "@types/react": "*", @@ -59685,15 +59662,67 @@ } }, "@typescript-eslint/parser": { - "version": "5.30.5", - "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-5.30.5.tgz", - "integrity": "sha512-zj251pcPXI8GO9NDKWWmygP6+UjwWmrdf9qMW/L/uQJBM/0XbU2inxe5io/234y/RCvwpKEYjZ6c1YrXERkK4Q==", + "version": "5.31.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-5.31.0.tgz", + "integrity": "sha512-UStjQiZ9OFTFReTrN+iGrC6O/ko9LVDhreEK5S3edmXgR396JGq7CoX2TWIptqt/ESzU2iRKXAHfSF2WJFcWHw==", "dev": true, "requires": { - "@typescript-eslint/scope-manager": "5.30.5", - "@typescript-eslint/types": "5.30.5", - "@typescript-eslint/typescript-estree": "5.30.5", + "@typescript-eslint/scope-manager": "5.31.0", + "@typescript-eslint/types": "5.31.0", + "@typescript-eslint/typescript-estree": "5.31.0", "debug": "^4.3.4" + }, + "dependencies": { + "@typescript-eslint/scope-manager": { + "version": "5.31.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-5.31.0.tgz", + "integrity": "sha512-8jfEzBYDBG88rcXFxajdVavGxb5/XKXyvWgvD8Qix3EEJLCFIdVloJw+r9ww0wbyNLOTYyBsR+4ALNGdlalLLg==", + "dev": true, + "requires": { + "@typescript-eslint/types": "5.31.0", + "@typescript-eslint/visitor-keys": "5.31.0" + } + }, + "@typescript-eslint/types": { + "version": "5.31.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-5.31.0.tgz", + "integrity": "sha512-/f/rMaEseux+I4wmR6mfpM2wvtNZb1p9hAV77hWfuKc3pmaANp5dLAZSiE3/8oXTYTt3uV9KW5yZKJsMievp6g==", + "dev": true + }, + "@typescript-eslint/typescript-estree": { + "version": "5.31.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-5.31.0.tgz", + "integrity": "sha512-3S625TMcARX71wBc2qubHaoUwMEn+l9TCsaIzYI/ET31Xm2c9YQ+zhGgpydjorwQO9pLfR/6peTzS/0G3J/hDw==", + "dev": true, + "requires": { + "@typescript-eslint/types": "5.31.0", + "@typescript-eslint/visitor-keys": "5.31.0", + "debug": "^4.3.4", + "globby": "^11.1.0", + "is-glob": "^4.0.3", + "semver": "^7.3.7", + "tsutils": "^3.21.0" + } + }, + "@typescript-eslint/visitor-keys": { + "version": "5.31.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-5.31.0.tgz", + "integrity": "sha512-ZK0jVxSjS4gnPirpVjXHz7mgdOsZUHzNYSfTw2yPa3agfbt9YfqaBiBZFSSxeBWnpWkzCxTfUpnzA3Vily/CSg==", + "dev": true, + "requires": { + "@typescript-eslint/types": "5.31.0", + "eslint-visitor-keys": "^3.3.0" + } + }, + "semver": { + "version": "7.3.7", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.7.tgz", + "integrity": "sha512-QlYTucUYOews+WeEujDoEGziz4K6c47V/Bd+LjSSYcA94p+DmINdf7ncaUinThfvZyu13lN9OY1XDxt8C0Tw0g==", + "dev": true, + "requires": { + "lru-cache": "^6.0.0" + } + } } }, "@typescript-eslint/scope-manager": { @@ -60210,34 +60239,29 @@ "@babel/runtime": "^7.16.0", "@wordpress/dom-ready": "^3.13.0", "@wordpress/i18n": "^4.13.0" + } + }, + "@wordpress/api-fetch": { + "version": "6.11.0", + "resolved": "https://registry.npmjs.org/@wordpress/api-fetch/-/api-fetch-6.11.0.tgz", + "integrity": "sha512-C1HTWdJQ7ikhJ4mT+rONTODquJ/Xq5HteKak/VN+vf1VmLVfRX18wJ84kCAAZ83UNOIsE8EgjJrjJy//R+HWzg==", + "requires": { + "@babel/runtime": "^7.16.0", + "@wordpress/i18n": "^4.14.0", + "@wordpress/url": "^3.15.0" }, "dependencies": { - "@wordpress/i18n": { - "version": "4.13.0", - "resolved": "https://registry.npmjs.org/@wordpress/i18n/-/i18n-4.13.0.tgz", - "integrity": "sha512-25x0ylQzXxbaw3oM8afoahiPzzZfzikBNzkzlEJ4MuI9u61zmFedbkIrsmhXtYNlcZ/52RxeUcswHdVs4Hln9Q==", + "@wordpress/url": { + "version": "3.15.0", + "resolved": "https://registry.npmjs.org/@wordpress/url/-/url-3.15.0.tgz", + "integrity": "sha512-LLlgCMbherqqnxAuK6kb997MKkzfnvkyQQ5RazBQKBn//RBXrW/w6BMVglm4QjV7L65N/IfqFd36QLZDMuiYDA==", "requires": { "@babel/runtime": "^7.16.0", - "@wordpress/hooks": "^3.13.0", - "gettext-parser": "^1.3.1", - "lodash": "^4.17.21", - "memize": "^1.1.0", - "sprintf-js": "^1.1.1", - "tannin": "^1.2.0" + "remove-accents": "^0.4.2" } } } }, - "@wordpress/api-fetch": { - "version": "6.9.0", - "resolved": "https://registry.npmjs.org/@wordpress/api-fetch/-/api-fetch-6.9.0.tgz", - "integrity": "sha512-H0IvLlisBcfKFa4tlMgtqFy7s7Iz3SSe6cEzqAAesK1fg+j3NewDP4fcQz5Ooo6pL+Y2A8oUM5dawjJctmsnAA==", - "requires": { - "@babel/runtime": "^7.16.0", - "@wordpress/i18n": "^4.12.0", - "@wordpress/url": "^3.13.0" - } - }, "@wordpress/autop": { "version": "3.12.0", "resolved": "https://registry.npmjs.org/@wordpress/autop/-/autop-3.12.0.tgz", @@ -60677,7 +60701,7 @@ "@wordpress/compose": "^5.11.0", "@wordpress/deprecated": "^3.13.0", "@wordpress/element": "^4.11.0", - "@wordpress/is-shallow-equal": "^4.13.0", + "@wordpress/is-shallow-equal": "4.13.0", "@wordpress/priority-queue": "^2.13.0", "@wordpress/redux-routine": "^4.13.0", "equivalent-key-map": "^0.2.2", @@ -60699,7 +60723,7 @@ "@wordpress/deprecated": "^3.13.0", "@wordpress/dom": "^3.13.0", "@wordpress/element": "^4.11.0", - "@wordpress/is-shallow-equal": "^4.13.0", + "@wordpress/is-shallow-equal": "4.13.0", "@wordpress/keycodes": "^3.13.0", "@wordpress/priority-queue": "^2.13.0", "clipboard": "^2.0.8", @@ -60740,14 +60764,6 @@ "react": "^17.0.2", "react-dom": "^17.0.2" } - }, - "@wordpress/is-shallow-equal": { - "version": "4.13.0", - "resolved": "https://registry.npmjs.org/@wordpress/is-shallow-equal/-/is-shallow-equal-4.13.0.tgz", - "integrity": "sha512-oUoMbEZwnbd4nfEo6uxkvrNCc/LnqC9MIY6kK3iWtMhcykQNpbK3XY/i/NvJb+QpRf7U6XhXyw4//HcQv39iOA==", - "requires": { - "@babel/runtime": "^7.16.0" - } } } }, @@ -62266,9 +62282,9 @@ } }, "@wordpress/hooks": { - "version": "3.13.0", - "resolved": "https://registry.npmjs.org/@wordpress/hooks/-/hooks-3.13.0.tgz", - "integrity": "sha512-N+82Dt3jsREtN0dCypehaWuwCjPOM3ljxyzVWULMDrIK9TaIvkunkHViIyoCkxWk3lolRRqh8XmD+ox/mF+n1A==", + "version": "3.14.0", + "resolved": "https://registry.npmjs.org/@wordpress/hooks/-/hooks-3.14.0.tgz", + "integrity": "sha512-bcQXql4A1VI6gnTdNzMjdHLGTpnf8oWOQ1r8B8fcvtOF3dKictxJPobarWxFbtVTQoegizZT/lPCMoLsnVJpug==", "requires": { "@babel/runtime": "^7.16.0" } @@ -62283,12 +62299,12 @@ } }, "@wordpress/i18n": { - "version": "4.12.0", - "resolved": "https://registry.npmjs.org/@wordpress/i18n/-/i18n-4.12.0.tgz", - "integrity": "sha512-UTccrAOZ03nszzlG74G+ZkMR/kK0PoS1fqFa8NRFAhHneYadJOnsgCCd5YgDAsN+tAKA6QM7RPmpQMwujvIbzA==", + "version": "4.14.0", + "resolved": "https://registry.npmjs.org/@wordpress/i18n/-/i18n-4.14.0.tgz", + "integrity": "sha512-46ryvPbh139RkLXQt8oey4aCcWo6HRKb1NLVHU4a4kJ4HRD/HLhAeTHKAMiZFWTg+QC1HZC32vGdEikqrpnlzQ==", "requires": { "@babel/runtime": "^7.16.0", - "@wordpress/hooks": "^3.12.0", + "@wordpress/hooks": "^3.14.0", "gettext-parser": "^1.3.1", "lodash": "^4.17.21", "memize": "^1.1.0", @@ -62307,9 +62323,9 @@ } }, "@wordpress/is-shallow-equal": { - "version": "4.12.0", - "resolved": "https://registry.npmjs.org/@wordpress/is-shallow-equal/-/is-shallow-equal-4.12.0.tgz", - "integrity": "sha512-jlpHXPLJw0mG13bcbZIJwOd1DQozJ5+fbkkKA2JeTO5d5PXs44Rw6EYdGMLUU97B44UxIwVbaui7tJGOvzF8Dw==", + "version": "4.13.0", + "resolved": "https://registry.npmjs.org/@wordpress/is-shallow-equal/-/is-shallow-equal-4.13.0.tgz", + "integrity": "sha512-oUoMbEZwnbd4nfEo6uxkvrNCc/LnqC9MIY6kK3iWtMhcykQNpbK3XY/i/NvJb+QpRf7U6XhXyw4//HcQv39iOA==", "requires": { "@babel/runtime": "^7.16.0" } @@ -62397,22 +62413,6 @@ "@babel/runtime": "^7.16.0", "@wordpress/i18n": "^4.13.0", "lodash": "^4.17.21" - }, - "dependencies": { - "@wordpress/i18n": { - "version": "4.13.0", - "resolved": "https://registry.npmjs.org/@wordpress/i18n/-/i18n-4.13.0.tgz", - "integrity": "sha512-25x0ylQzXxbaw3oM8afoahiPzzZfzikBNzkzlEJ4MuI9u61zmFedbkIrsmhXtYNlcZ/52RxeUcswHdVs4Hln9Q==", - "requires": { - "@babel/runtime": "^7.16.0", - "@wordpress/hooks": "^3.13.0", - "gettext-parser": "^1.3.1", - "lodash": "^4.17.21", - "memize": "^1.1.0", - "sprintf-js": "^1.1.1", - "tannin": "^1.2.0" - } - } } }, "@wordpress/notices": { @@ -62456,7 +62456,7 @@ "@wordpress/deprecated": "^3.13.0", "@wordpress/dom": "^3.13.0", "@wordpress/element": "^4.11.0", - "@wordpress/is-shallow-equal": "^4.13.0", + "@wordpress/is-shallow-equal": "4.13.0", "@wordpress/keycodes": "^3.13.0", "@wordpress/priority-queue": "^2.13.0", "clipboard": "^2.0.8", @@ -62508,14 +62508,6 @@ "@wordpress/primitives": "^3.11.0" } }, - "@wordpress/is-shallow-equal": { - "version": "4.13.0", - "resolved": "https://registry.npmjs.org/@wordpress/is-shallow-equal/-/is-shallow-equal-4.13.0.tgz", - "integrity": "sha512-oUoMbEZwnbd4nfEo6uxkvrNCc/LnqC9MIY6kK3iWtMhcykQNpbK3XY/i/NvJb+QpRf7U6XhXyw4//HcQv39iOA==", - "requires": { - "@babel/runtime": "^7.16.0" - } - }, "@wordpress/primitives": { "version": "3.11.0", "resolved": "https://registry.npmjs.org/@wordpress/primitives/-/primitives-3.11.0.tgz", @@ -62611,7 +62603,7 @@ "@wordpress/deprecated": "^3.13.0", "@wordpress/dom": "^3.13.0", "@wordpress/element": "^4.11.0", - "@wordpress/is-shallow-equal": "^4.13.0", + "@wordpress/is-shallow-equal": "4.13.0", "@wordpress/keycodes": "^3.13.0", "@wordpress/priority-queue": "^2.13.0", "clipboard": "^2.0.8", @@ -62653,28 +62645,6 @@ "react-dom": "^17.0.2" } }, - "@wordpress/i18n": { - "version": "4.13.0", - "resolved": "https://registry.npmjs.org/@wordpress/i18n/-/i18n-4.13.0.tgz", - "integrity": "sha512-25x0ylQzXxbaw3oM8afoahiPzzZfzikBNzkzlEJ4MuI9u61zmFedbkIrsmhXtYNlcZ/52RxeUcswHdVs4Hln9Q==", - "requires": { - "@babel/runtime": "^7.16.0", - "@wordpress/hooks": "^3.13.0", - "gettext-parser": "^1.3.1", - "lodash": "^4.17.21", - "memize": "^1.1.0", - "sprintf-js": "^1.1.1", - "tannin": "^1.2.0" - } - }, - "@wordpress/is-shallow-equal": { - "version": "4.13.0", - "resolved": "https://registry.npmjs.org/@wordpress/is-shallow-equal/-/is-shallow-equal-4.13.0.tgz", - "integrity": "sha512-oUoMbEZwnbd4nfEo6uxkvrNCc/LnqC9MIY6kK3iWtMhcykQNpbK3XY/i/NvJb+QpRf7U6XhXyw4//HcQv39iOA==", - "requires": { - "@babel/runtime": "^7.16.0" - } - }, "rememo": { "version": "4.0.1", "resolved": "https://registry.npmjs.org/rememo/-/rememo-4.0.1.tgz", @@ -63878,7 +63848,7 @@ "@wordpress/hooks": "^3.13.0", "@wordpress/html-entities": "^3.13.0", "@wordpress/i18n": "^4.13.0", - "@wordpress/is-shallow-equal": "^4.13.0", + "@wordpress/is-shallow-equal": "4.13.0", "@wordpress/shortcode": "^3.13.0", "colord": "^2.7.0", "hpq": "^1.3.0", @@ -63914,7 +63884,7 @@ "@wordpress/hooks": "^3.13.0", "@wordpress/i18n": "^4.13.0", "@wordpress/icons": "^9.4.0", - "@wordpress/is-shallow-equal": "^4.13.0", + "@wordpress/is-shallow-equal": "4.13.0", "@wordpress/keycodes": "^3.13.0", "@wordpress/primitives": "^3.11.0", "@wordpress/rich-text": "^5.11.0", @@ -63948,7 +63918,7 @@ "@wordpress/deprecated": "^3.13.0", "@wordpress/dom": "^3.13.0", "@wordpress/element": "^4.11.0", - "@wordpress/is-shallow-equal": "^4.13.0", + "@wordpress/is-shallow-equal": "4.13.0", "@wordpress/keycodes": "^3.13.0", "@wordpress/priority-queue": "^2.13.0", "clipboard": "^2.0.8", @@ -63998,20 +63968,6 @@ "@babel/runtime": "^7.16.0" } }, - "@wordpress/i18n": { - "version": "4.13.0", - "resolved": "https://registry.npmjs.org/@wordpress/i18n/-/i18n-4.13.0.tgz", - "integrity": "sha512-25x0ylQzXxbaw3oM8afoahiPzzZfzikBNzkzlEJ4MuI9u61zmFedbkIrsmhXtYNlcZ/52RxeUcswHdVs4Hln9Q==", - "requires": { - "@babel/runtime": "^7.16.0", - "@wordpress/hooks": "^3.13.0", - "gettext-parser": "^1.3.1", - "lodash": "^4.17.21", - "memize": "^1.1.0", - "sprintf-js": "^1.1.1", - "tannin": "^1.2.0" - } - }, "@wordpress/icons": { "version": "9.4.0", "resolved": "https://registry.npmjs.org/@wordpress/icons/-/icons-9.4.0.tgz", @@ -64022,14 +63978,6 @@ "@wordpress/primitives": "^3.11.0" } }, - "@wordpress/is-shallow-equal": { - "version": "4.13.0", - "resolved": "https://registry.npmjs.org/@wordpress/is-shallow-equal/-/is-shallow-equal-4.13.0.tgz", - "integrity": "sha512-oUoMbEZwnbd4nfEo6uxkvrNCc/LnqC9MIY6kK3iWtMhcykQNpbK3XY/i/NvJb+QpRf7U6XhXyw4//HcQv39iOA==", - "requires": { - "@babel/runtime": "^7.16.0" - } - }, "@wordpress/primitives": { "version": "3.11.0", "resolved": "https://registry.npmjs.org/@wordpress/primitives/-/primitives-3.11.0.tgz", @@ -64284,9 +64232,9 @@ "integrity": "sha512-4648iMotdeNMe3vLKWTx5C/X1+4hey00GrxAClTiAufGMR3slCjE8nQhnWtFfyqYZi0bSpuF+kYd6ofsKrtcQg==" }, "@wordpress/wordcount": { - "version": "3.12.0", - "resolved": "https://registry.npmjs.org/@wordpress/wordcount/-/wordcount-3.12.0.tgz", - "integrity": "sha512-noYFwkpzq7uCG85mYFSZueKF+eMXx9vGc6pgY6NX5tKiSsVrcea/SWWuwJcAA3XOtXcDxElf0kzYm7vPOGo1bg==", + "version": "3.13.0", + "resolved": "https://registry.npmjs.org/@wordpress/wordcount/-/wordcount-3.13.0.tgz", + "integrity": "sha512-P0HJZ70BIqAXW5kUccHfSAD6xH/geTOwp5RhZdtyUAqnlj9UR3FPY71XG7EEc1CkCD82+0Bc+iw0wm+oV6PKIQ==", "requires": { "@babel/runtime": "^7.16.0" } @@ -80687,9 +80635,9 @@ "dev": true }, "mini-css-extract-plugin": { - "version": "1.3.6", - "resolved": "https://registry.npmjs.org/mini-css-extract-plugin/-/mini-css-extract-plugin-1.3.6.tgz", - "integrity": "sha512-t86rLnySRQgN2+58gAIARTEtnClLNZoC99shNrvQ960V/wB9n50AUKJyqly76/s4fT0zwaLFIDFZAW7aK25pvg==", + "version": "1.6.2", + "resolved": "https://registry.npmjs.org/mini-css-extract-plugin/-/mini-css-extract-plugin-1.6.2.tgz", + "integrity": "sha512-WhDvO3SjGm40oV5y26GjMJYjd2UMqrLAGKy5YS2/3QKJy2F7jgynuHTir/tgUUOiNQu5saXHdc8reo7YuhhT4Q==", "dev": true, "requires": { "loader-utils": "^2.0.0", diff --git a/package.json b/package.json index b15dd3065c1..a4468377bfb 100644 --- a/package.json +++ b/package.json @@ -2,7 +2,7 @@ "name": "@woocommerce/block-library", "title": "WooCommerce Blocks", "author": "Automattic", - "version": "8.2.0-dev", + "version": "8.3.0-dev", "description": "WooCommerce blocks for the Gutenberg editor.", "homepage": "https://github.com/woocommerce/woocommerce-gutenberg-products-block/", "keywords": [ @@ -84,8 +84,8 @@ "@actions/core": "1.9.0", "@actions/github": "5.0.3", "@automattic/color-studio": "2.5.0", - "@babel/cli": "7.18.6", - "@babel/core": "7.18.6", + "@babel/cli": "7.18.9", + "@babel/core": "7.18.9", "@babel/plugin-proposal-class-properties": "7.18.6", "@babel/plugin-syntax-jsx": "7.18.6", "@babel/polyfill": "7.12.1", @@ -105,7 +105,7 @@ "@types/classnames": "2.3.0", "@types/dinero.js": "1.9.0", "@types/gtag.js": "0.0.10", - "@types/jest": "27.4.1", + "@types/jest": "27.5.2", "@types/jest-environment-puppeteer": "5.0.2", "@types/jquery": "3.5.14", "@types/lodash": "4.14.182", @@ -113,17 +113,17 @@ "@types/react": "17.0.47", "@types/react-dom": "17.0.17", "@types/wordpress__block-editor": "6.0.6", - "@types/wordpress__blocks": "11.0.3", + "@types/wordpress__blocks": "11.0.5", "@types/wordpress__compose": "4.0.1", "@types/wordpress__data": "4.6.11", "@types/wordpress__data-controls": "2.2.0", "@typescript-eslint/eslint-plugin": "5.30.5", - "@typescript-eslint/parser": "5.30.5", + "@typescript-eslint/parser": "5.31.0", "@woocommerce/api": "0.2.0", "@woocommerce/e2e-utils": "0.2.0", "@woocommerce/eslint-plugin": "2.0.0", "@woocommerce/woocommerce-rest-api": "1.0.1", - "@wordpress/api-fetch": "6.9.0", + "@wordpress/api-fetch": "6.11.0", "@wordpress/babel-preset-default": "6.14.0", "@wordpress/base-styles": "4.0.4", "@wordpress/block-editor": "8.2.0", @@ -138,8 +138,8 @@ "@wordpress/element": "4.0.4", "@wordpress/env": "4.9.0", "@wordpress/html-entities": "3.12.0", - "@wordpress/i18n": "4.12.0", - "@wordpress/is-shallow-equal": "4.12.0", + "@wordpress/i18n": "4.14.0", + "@wordpress/is-shallow-equal": "4.13.0", "@wordpress/prettier-config": "1.4.0", "@wordpress/scripts": "22.3.0", "autoprefixer": "10.4.7", @@ -182,7 +182,7 @@ "lodash": "4.17.21", "markdown-it": "13.0.1", "merge-config": "2.0.0", - "mini-css-extract-plugin": "1.3.6", + "mini-css-extract-plugin": "1.6.2", "patch-package": "6.4.7", "postcss": "8.4.14", "postcss-loader": "4.2.0", @@ -220,7 +220,7 @@ "@wordpress/primitives": "3.0.4", "@wordpress/server-side-render": "3.10.0", "@wordpress/url": "3.13.0", - "@wordpress/wordcount": "3.12.0", + "@wordpress/wordcount": "3.13.0", "classnames": "2.3.1", "compare-versions": "4.1.3", "config": "3.3.7", diff --git a/packages/checkout/README.md b/packages/checkout/README.md index d88518a2dce..bac61f7aa3f 100644 --- a/packages/checkout/README.md +++ b/packages/checkout/README.md @@ -59,6 +59,7 @@ This package contains the following directories. Navigate to a directory for mor [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./packages/checkout/README.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./packages/checkout/README.md) + diff --git a/packages/checkout/blocks-registry/README.md b/packages/checkout/blocks-registry/README.md index bf0f89cfc90..6dad7920e7b 100644 --- a/packages/checkout/blocks-registry/README.md +++ b/packages/checkout/blocks-registry/README.md @@ -209,6 +209,7 @@ const isValid = hasInnerBlocks( 'woocommerce/checkout-totals-block' ); // true [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./packages/checkout/blocks-registry/README.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./packages/checkout/blocks-registry/README.md) + diff --git a/packages/checkout/components/README.md b/packages/checkout/components/README.md index 1b22a69e050..305ebeb1946 100644 --- a/packages/checkout/components/README.md +++ b/packages/checkout/components/README.md @@ -26,6 +26,7 @@ These components are here so they can be consumed by extensions. [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./packages/checkout/components/README.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./packages/checkout/components/README.md) + diff --git a/packages/checkout/components/order-shipping-packages/index.js b/packages/checkout/components/order-shipping-packages/index.js index d07a6e95884..220e15e1127 100644 --- a/packages/checkout/components/order-shipping-packages/index.js +++ b/packages/checkout/components/order-shipping-packages/index.js @@ -23,9 +23,10 @@ const Slot = ( { cart, components, context, + shippingRates, } ) => { const { fills } = useSlot( slotName ); - const hasMultiplePackages = fills.length > 1; + const hasMultiplePackages = fills.length > 1 || shippingRates?.length > 1; return ( + diff --git a/packages/checkout/slot/README.md b/packages/checkout/slot/README.md index 3b74fb8fe12..4b332264894 100644 --- a/packages/checkout/slot/README.md +++ b/packages/checkout/slot/README.md @@ -189,6 +189,7 @@ Slot Fills are implemented throughout the Cart and Checkout Blocks, as well as s [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./packages/checkout/slot/README.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./packages/checkout/slot/README.md) + diff --git a/packages/checkout/utils/README.md b/packages/checkout/utils/README.md index 0d60ffbfe79..a6bb6be5776 100644 --- a/packages/checkout/utils/README.md +++ b/packages/checkout/utils/README.md @@ -78,6 +78,7 @@ What value must contain. If this is not found within `value`, and error will be [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./packages/checkout/utils/README.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./packages/checkout/utils/README.md) + diff --git a/readme.txt b/readme.txt index a8438b3fc39..c834b932a30 100644 --- a/readme.txt +++ b/readme.txt @@ -4,7 +4,7 @@ Tags: gutenberg, woocommerce, woo commerce, products, blocks, woocommerce blocks Requires at least: 6.0 Tested up to: 6.0 Requires PHP: 7.0 -Stable tag: 8.2.0-dev +Stable tag: 8.3.0-dev License: GPLv3 License URI: https://www.gnu.org/licenses/gpl-3.0.html @@ -86,6 +86,35 @@ Release and roadmap notes available on the [WooCommerce Developers Blog](https:/ == Changelog == += 8.2.1 - 2022-08-03 = + +#### Bug Fixes + +- Fixed an issue where shoppers could not switch between different saved payment methods. ([6825](https://github.com/woocommerce/woocommerce-blocks/pull/6825)) + += 8.2.0 - 2022-08-02 = + +#### Enhancements + +- Add update_customer_from_request action to Checkout flow. ([6792](https://github.com/woocommerce/woocommerce-blocks/pull/6792)) +- Update: New block icon for the Mini Cart block. ([6784](https://github.com/woocommerce/woocommerce-blocks/pull/6784)) +- Introduce `productNameFormat` filter for cart items in Cart and Checkout blocks. ([4993](https://github.com/woocommerce/woocommerce-blocks/pull/4993)) + +#### Bug Fixes + +- Fix proceed to checkout button not working for custom links. ([6804](https://github.com/woocommerce/woocommerce-blocks/pull/6804)) +- Mini Cart block: Remove the compatibility notice. ([6803](https://github.com/woocommerce/woocommerce-blocks/pull/6803)) +- Fix: Render the product attribute archive page using the `archive-product` template. ([6776](https://github.com/woocommerce/woocommerce-blocks/pull/6776)) +- Ensure using the "Use shipping as billing" checkbox in the Checkout Block correctly syncs the addresses when making the order. ([6773](https://github.com/woocommerce/woocommerce-blocks/pull/6773)) +- Ensure shipping package names are shown correctly in the Checkout Block when a cart contains multiple packages. ([6753](https://github.com/woocommerce/woocommerce-blocks/pull/6753)) +- Select the correct inner button for the "Featured Item" button to update its URL. ([6741](https://github.com/woocommerce/woocommerce-blocks/pull/6741)) +- Fix the spacing between separate shipping packages in the Checkout Block. ([6740](https://github.com/woocommerce/woocommerce-blocks/pull/6740)) +- Fix missing translations in the inspector (editor mode). ([6737](https://github.com/woocommerce/woocommerce-blocks/pull/6737)) +- Fix: Navigate through Mini Cart contents with keyboard. ([6731](https://github.com/woocommerce/woocommerce-blocks/pull/6731)) +- Fix: Ensure add to cart notices are displayed on pages containing the Mini Cart block. ([6728](https://github.com/woocommerce/woocommerce-blocks/pull/6728)) +- Fix Cart an d Checkout blocks compatiblity issue with wordpress.com in which blocks wouldn't load in the editor. ([6718](https://github.com/woocommerce/woocommerce-blocks/pull/6718)) +- Fixes an issue where search lists would not preserve the case of the original item. ([6551](https://github.com/woocommerce/woocommerce-blocks/pull/6551)) + = 8.1.0 - 2022-07-18 = #### Enhancements diff --git a/renovate.json b/renovate.json deleted file mode 100644 index c9759d4946d..00000000000 --- a/renovate.json +++ /dev/null @@ -1,37 +0,0 @@ -{ - "extends": [ "config:base" ], - "lockFileMaintenance": { "enabled": true }, - "ignoreDeps": [ "husky" ], - "prConcurrentLimit": 5, - "schedule": [ "before 3am on wednesday" ], - "composer": { - "enabled": false - }, - "labels": [ "type: dependencies", "skip-changelog" ], - "packageRules": [ - { - "packageNames": [ - "automattic/jetpack-autoloader", - "composer/installers" - ], - "rangeStrategy": "bump" - }, - { - "matchUpdateTypes": [ "patch", "pin", "digest" ], - "depTypeList": [ "dev" ], - "automerge": true - }, - { - "matchUpdateTypes": [ "major", "minor" ], - "depTypeList": [ "dev" ], - "automerge": false - }, - { - "matchUpdateTypes": [ "major", "minor", "patch", "pin", "digest" ], - "depTypeList": [ "devDependencies" ], - "automerge": true, - "prPriority": 1 - } - ], - "rebaseWhen": "conflicted" -} diff --git a/src/BlockTemplatesController.php b/src/BlockTemplatesController.php index 38a10c96b49..adc8af65ce4 100644 --- a/src/BlockTemplatesController.php +++ b/src/BlockTemplatesController.php @@ -300,6 +300,7 @@ public function get_block_templates_from_woocommerce( $slugs, $already_found_tem foreach ( $template_files as $template_file ) { // Skip the template if it's blockified, and we should only use classic ones. // Until the blockified Product Grid Block is implemented, we need to always skip the blockified templates. + // phpcs:ignore Squiz.PHP.CommentedOutCode if ( // $this->package->is_experimental_build() && // ! BlockTemplateUtils::should_use_blockified_product_grid_templates() && strpos( $template_file, 'blockified' ) !== false ) { @@ -425,6 +426,11 @@ public function render_block_template() { $this->block_template_is_available( 'taxonomy-product_tag' ) ) { add_filter( 'woocommerce_has_block_template', '__return_true', 10, 0 ); + } elseif ( taxonomy_is_product_attribute( get_query_var( 'taxonomy' ) ) && + ! BlockTemplateUtils::theme_has_template( 'archive-product' ) && + $this->block_template_is_available( 'archive-product' ) + ) { + add_filter( 'woocommerce_has_block_template', '__return_true', 10, 0 ); } elseif ( ( is_post_type_archive( 'product' ) || is_page( wc_get_page_id( 'shop' ) ) ) && ! BlockTemplateUtils::theme_has_template( 'archive-product' ) && diff --git a/src/BlockTypes/AbstractInnerBlock.php b/src/BlockTypes/AbstractInnerBlock.php new file mode 100644 index 00000000000..3b992d5f77b --- /dev/null +++ b/src/BlockTypes/AbstractInnerBlock.php @@ -0,0 +1,57 @@ + $this->get_block_type_render_callback(), + 'editor_style' => $this->get_block_type_editor_style(), + 'style' => $this->get_block_type_style(), + ]; + + if ( isset( $this->api_version ) && '2' === $this->api_version ) { + $block_settings['api_version'] = 2; + } + + $metadata_path = $this->asset_api->get_block_metadata_path( $this->block_name ); + // Prefer to register with metadata if the path is set in the block's class. + register_block_type_from_metadata( + $metadata_path, + $block_settings + ); + } + + /** + * For lazy loaded inner blocks, we don't want to enqueue the script but rather leave it for webpack to do that. + * + * @see $this->register_block_type() + * @param string $key Data to get, or default to everything. + * @return array|string|null + */ + protected function get_block_type_script( $key = null ) { + + if ( $this->is_lazy_loaded ) { + return null; + } + + return parent::get_block_type_script( $key ); + } + +} diff --git a/src/BlockTypes/AbstractProductGrid.php b/src/BlockTypes/AbstractProductGrid.php index cab1aa3df31..ed9d79ea587 100644 --- a/src/BlockTypes/AbstractProductGrid.php +++ b/src/BlockTypes/AbstractProductGrid.php @@ -81,6 +81,15 @@ protected function render( $attributes = array(), $content = '' ) { return ''; } + /** + * Override product description to prevent infinite loop. + * + * @see https://github.com/woocommerce/woocommerce-blocks/pull/6849 + */ + foreach ( $products as $product ) { + $product->set_description( '' ); + } + /** * Product List Render event. * diff --git a/src/BlockTypes/Cart.php b/src/BlockTypes/Cart.php index 15aad499b34..dc0c831b2ed 100644 --- a/src/BlockTypes/Cart.php +++ b/src/BlockTypes/Cart.php @@ -246,4 +246,35 @@ protected function register_block_type_assets() { $this->register_chunk_translations( array_merge( $chunks, $vendor_chunks ) ); } + + /** + * Get list of Cart block & its inner-block types. + * + * @return array; + */ + public static function get_cart_block_types() { + $block_types = []; + + if ( Package::feature()->is_feature_plugin_build() ) { + $block_types[] = 'Cart'; + $block_types[] = 'CartOrderSummaryTaxesBlock'; + $block_types[] = 'CartOrderSummarySubtotalBlock'; + $block_types[] = 'FilledCartBlock'; + $block_types[] = 'EmptyCartBlock'; + $block_types[] = 'CartTotalsBlock'; + $block_types[] = 'CartItemsBlock'; + $block_types[] = 'CartLineItemsBlock'; + $block_types[] = 'CartOrderSummaryBlock'; + $block_types[] = 'CartExpressPaymentBlock'; + $block_types[] = 'ProceedToCheckoutBlock'; + $block_types[] = 'CartAcceptedPaymentMethodsBlock'; + $block_types[] = 'CartOrderSummaryCouponFormBlock'; + $block_types[] = 'CartOrderSummaryDiscountBlock'; + $block_types[] = 'CartOrderSummaryFeeBlock'; + $block_types[] = 'CartOrderSummaryHeadingBlock'; + $block_types[] = 'CartOrderSummaryShippingBlock'; + } + + return $block_types; + } } diff --git a/src/BlockTypes/CartAcceptedPaymentMethodsBlock.php b/src/BlockTypes/CartAcceptedPaymentMethodsBlock.php new file mode 100644 index 00000000000..e92e38b678f --- /dev/null +++ b/src/BlockTypes/CartAcceptedPaymentMethodsBlock.php @@ -0,0 +1,14 @@ +register_chunk_translations( array_merge( $chunks, $vendor_chunks, $shared_chunks ) ); } + + /** + * Get list of Checkout block & its inner-block types. + * + * @return array; + */ + public static function get_checkout_block_types() { + $block_types = []; + + if ( Package::feature()->is_feature_plugin_build() ) { + $block_types[] = 'Checkout'; + $block_types[] = 'CheckoutActionsBlock'; + $block_types[] = 'CheckoutBillingAddressBlock'; + $block_types[] = 'CheckoutContactInformationBlock'; + $block_types[] = 'CheckoutExpressPaymentBlock'; + $block_types[] = 'CheckoutFieldsBlock'; + $block_types[] = 'CheckoutOrderNoteBlock'; + $block_types[] = 'CheckoutOrderSummaryBlock'; + $block_types[] = 'CheckoutOrderSummaryCartItemsBlock'; + $block_types[] = 'CheckoutOrderSummaryCouponFormBlock'; + $block_types[] = 'CheckoutOrderSummaryDiscountBlock'; + $block_types[] = 'CheckoutOrderSummaryFeeBlock'; + $block_types[] = 'CheckoutOrderSummaryShippingBlock'; + $block_types[] = 'CheckoutOrderSummarySubtotalBlock'; + $block_types[] = 'CheckoutOrderSummaryTaxesBlock'; + $block_types[] = 'CheckoutPaymentBlock'; + $block_types[] = 'CheckoutShippingAddressBlock'; + $block_types[] = 'CheckoutShippingMethodsBlock'; + $block_types[] = 'CheckoutTermsBlock'; + $block_types[] = 'CheckoutTotalsBlock'; + } + + return $block_types; + } } diff --git a/src/BlockTypes/CheckoutActionsBlock.php b/src/BlockTypes/CheckoutActionsBlock.php new file mode 100644 index 00000000000..67e132b8720 --- /dev/null +++ b/src/BlockTypes/CheckoutActionsBlock.php @@ -0,0 +1,14 @@ +get_cart_controller(); + $cart = $cart_controller->get_cart_instance(); + $cart_contents_total = $cart->get_subtotal(); + $typography_styles = isset( StyleAttributesUtils::get_font_weight_class_and_style( $attributes )['style'] ) ? StyleAttributesUtils::get_font_weight_class_and_style( $attributes )['style'] : null; + + return '' . esc_html( wp_strip_all_tags( wc_price( $cart_contents_total ) ) ) . ' + ' . $this->get_include_tax_label_markup(); + } + /** * Returns the markup for render the tax label. * @@ -360,8 +381,7 @@ protected function get_markup( $attributes ) { '; - $button_html = '' . esc_html( wp_strip_all_tags( wc_price( $cart_contents_total ) ) ) . ' - ' . $this->get_include_tax_label_markup() . ' + $button_html = $this->get_cart_price_markup( $attributes ) . ' ' . $icon . ' ' . $cart_contents_count . ' diff --git a/src/BlockTypes/ProceedToCheckoutBlock.php b/src/BlockTypes/ProceedToCheckoutBlock.php new file mode 100644 index 00000000000..e2a883eeca3 --- /dev/null +++ b/src/BlockTypes/ProceedToCheckoutBlock.php @@ -0,0 +1,26 @@ +asset_data_registry->register_page_id( isset( $attributes['checkoutPageId'] ) ? $attributes['checkoutPageId'] : 0 ); + } +} diff --git a/src/BlockTypesController.php b/src/BlockTypesController.php index d2653ad229b..79c0fe272a4 100644 --- a/src/BlockTypesController.php +++ b/src/BlockTypesController.php @@ -6,6 +6,8 @@ use Automattic\WooCommerce\Blocks\Assets\AssetDataRegistry; use Automattic\WooCommerce\Blocks\Assets\Api as AssetApi; use Automattic\WooCommerce\Blocks\Integrations\IntegrationRegistry; +use Automattic\WooCommerce\Blocks\BlockTypes\Cart; +use Automattic\WooCommerce\Blocks\BlockTypes\Checkout; /** * BlockTypesController class. @@ -279,10 +281,7 @@ protected function get_block_types() { 'MiniCartContents', ]; - if ( Package::feature()->is_feature_plugin_build() ) { - $block_types[] = 'Checkout'; - $block_types[] = 'Cart'; - } + $block_types = array_merge( $block_types, Cart::get_cart_block_types(), Checkout::get_checkout_block_types() ); if ( Package::feature()->is_experimental_build() ) { $block_types[] = 'SingleProduct'; diff --git a/src/Domain/Bootstrap.php b/src/Domain/Bootstrap.php index 7dd7f3b8074..186c18c52cc 100644 --- a/src/Domain/Bootstrap.php +++ b/src/Domain/Bootstrap.php @@ -22,6 +22,7 @@ use Automattic\WooCommerce\Blocks\Payments\Integrations\PayPal; use Automattic\WooCommerce\Blocks\Payments\PaymentMethodRegistry; use Automattic\WooCommerce\Blocks\Registry\Container; +use Automattic\WooCommerce\Blocks\Templates\ProductAttributeTemplate; use Automattic\WooCommerce\StoreApi\StoreApi; use Automattic\WooCommerce\StoreApi\RoutesController; use Automattic\WooCommerce\StoreApi\SchemaController; @@ -116,6 +117,7 @@ function() { $this->container->get( BlockTypesController::class ); $this->container->get( BlockTemplatesController::class ); $this->container->get( ProductSearchResultsTemplate::class ); + $this->container->get( ProductAttributeTemplate::class ); $this->container->get( ClassicTemplatesCompatibility::class ); if ( $this->package->feature()->is_feature_plugin_build() ) { $this->container->get( PaymentsApi::class ); @@ -249,6 +251,12 @@ function () { return new ProductSearchResultsTemplate(); } ); + $this->container->register( + ProductAttributeTemplate::class, + function () { + return new ProductAttributeTemplate(); + } + ); $this->container->register( ClassicTemplatesCompatibility::class, function ( Container $container ) { diff --git a/src/Package.php b/src/Package.php index 2c539ce6c6f..23e2a0481c4 100644 --- a/src/Package.php +++ b/src/Package.php @@ -106,7 +106,7 @@ public static function container( $reset = false ) { NewPackage::class, function ( $container ) { // leave for automated version bumping. - $version = '8.2.0-dev'; + $version = '8.3.0-dev'; return new NewPackage( $version, dirname( __DIR__ ), diff --git a/src/StoreApi/README.md b/src/StoreApi/README.md index b4760294b11..5fa712497a9 100644 --- a/src/StoreApi/README.md +++ b/src/StoreApi/README.md @@ -161,6 +161,7 @@ If the data is sensitive (for example, a core setting that should be private), o [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./src/StoreApi/README.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./src/StoreApi/README.md) + diff --git a/src/StoreApi/Routes/V1/Checkout.php b/src/StoreApi/Routes/V1/Checkout.php index 2fb34161cf4..c7dac9c0236 100644 --- a/src/StoreApi/Routes/V1/Checkout.php +++ b/src/StoreApi/Routes/V1/Checkout.php @@ -411,6 +411,14 @@ private function update_customer_from_request( \WP_REST_Request $request ) { } } + /** + * Fires when the Checkout Block/Store API updates a customer from the API request data. + * + * @param \WC_Customer $customer Customer object. + * @param \WP_REST_Request $request Full details about the request. + */ + do_action( 'woocommerce_store_api_checkout_update_customer_from_request', $customer, $request ); + $customer->save(); } diff --git a/src/StoreApi/docs/cart-coupons.md b/src/StoreApi/docs/cart-coupons.md index 4605d50865a..a8b1f8843b9 100644 --- a/src/StoreApi/docs/cart-coupons.md +++ b/src/StoreApi/docs/cart-coupons.md @@ -168,6 +168,7 @@ curl --request DELETE https://example-store.com/wp-json/wc/store/v1/cart/coupons [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./src/StoreApi/docs/cart-coupons.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./src/StoreApi/docs/cart-coupons.md) + diff --git a/src/StoreApi/docs/cart-items.md b/src/StoreApi/docs/cart-items.md index 3d54e4700c8..9d484d6972b 100644 --- a/src/StoreApi/docs/cart-items.md +++ b/src/StoreApi/docs/cart-items.md @@ -364,6 +364,7 @@ curl --request DELETE https://example-store.com/wp-json/wc/store/v1/cart/items [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./src/StoreApi/docs/cart-items.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./src/StoreApi/docs/cart-items.md) + diff --git a/src/StoreApi/docs/cart.md b/src/StoreApi/docs/cart.md index 9c077bab825..dc0eca05382 100644 --- a/src/StoreApi/docs/cart.md +++ b/src/StoreApi/docs/cart.md @@ -475,6 +475,7 @@ Returns the full [Cart Response](#cart-response) on success, or an [Error Respon [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./src/StoreApi/docs/cart.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./src/StoreApi/docs/cart.md) + diff --git a/src/StoreApi/docs/checkout.md b/src/StoreApi/docs/checkout.md index 578a314639f..db6bf78bb29 100644 --- a/src/StoreApi/docs/checkout.md +++ b/src/StoreApi/docs/checkout.md @@ -141,6 +141,7 @@ curl --header "Nonce: 12345" --request POST https://example-store.com/wp-json/wc [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./src/StoreApi/docs/checkout.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./src/StoreApi/docs/checkout.md) + diff --git a/src/StoreApi/docs/guiding-principles.md b/src/StoreApi/docs/guiding-principles.md index ec301ac0469..a523b67e5b3 100644 --- a/src/StoreApi/docs/guiding-principles.md +++ b/src/StoreApi/docs/guiding-principles.md @@ -133,10 +133,11 @@ The version will not increase for bug fixes unless the scope of the bug causes a --- +--- [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./src/StoreApi/docs/guiding-principles.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./src/StoreApi/docs/guiding-principles.md) + diff --git a/src/StoreApi/docs/nonce-tokens.md b/src/StoreApi/docs/nonce-tokens.md index 50fb0a0c89e..8ef6c96e017 100644 --- a/src/StoreApi/docs/nonce-tokens.md +++ b/src/StoreApi/docs/nonce-tokens.md @@ -53,6 +53,7 @@ NOTE: This should only be done on development sites where security is not import [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./src/StoreApi/docs/nonce-tokens.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./src/StoreApi/docs/nonce-tokens.md) + diff --git a/src/StoreApi/docs/product-attribute-terms.md b/src/StoreApi/docs/product-attribute-terms.md index 87edd29841e..efb4c05552e 100644 --- a/src/StoreApi/docs/product-attribute-terms.md +++ b/src/StoreApi/docs/product-attribute-terms.md @@ -40,6 +40,7 @@ curl "https://example-store.com/wp-json/wc/store/v1/products/attributes/1/terms" [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./src/StoreApi/docs/product-attribute-terms.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./src/StoreApi/docs/product-attribute-terms.md) + diff --git a/src/StoreApi/docs/product-attributes.md b/src/StoreApi/docs/product-attributes.md index dadc83b274b..04e3c36d939 100644 --- a/src/StoreApi/docs/product-attributes.md +++ b/src/StoreApi/docs/product-attributes.md @@ -75,6 +75,7 @@ curl "https://example-store.com/wp-json/wc/store/v1/products/attributes/1" [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./src/StoreApi/docs/product-attributes.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./src/StoreApi/docs/product-attributes.md) + diff --git a/src/StoreApi/docs/product-collection-data.md b/src/StoreApi/docs/product-collection-data.md index f59e5947899..1f1c93e25a0 100644 --- a/src/StoreApi/docs/product-collection-data.md +++ b/src/StoreApi/docs/product-collection-data.md @@ -63,6 +63,7 @@ curl "https://example-store.com/wp-json/wc/store/v1/products/collection-data?cal [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./src/StoreApi/docs/product-collection-data.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./src/StoreApi/docs/product-collection-data.md) + diff --git a/src/StoreApi/docs/products.md b/src/StoreApi/docs/products.md index d91fff43fa3..6e5eeeee29d 100644 --- a/src/StoreApi/docs/products.md +++ b/src/StoreApi/docs/products.md @@ -197,6 +197,7 @@ curl "https://example-store.com/wp-json/wc/store/v1/products/34" [We're hiring!](https://woocommerce.com/careers/) Come work with us! -🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-gutenberg-products-block/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./src/StoreApi/docs/products.md) +🐞 Found a mistake, or have a suggestion? [Leave feedback about this document here.](https://github.com/woocommerce/woocommerce-blocks/issues/new?assignees=&labels=type%3A+documentation&template=--doc-feedback.md&title=Feedback%20on%20./src/StoreApi/docs/products.md) + diff --git a/src/Templates/ProductAttributeTemplate.php b/src/Templates/ProductAttributeTemplate.php new file mode 100644 index 00000000000..62dc2defb95 --- /dev/null +++ b/src/Templates/ProductAttributeTemplate.php @@ -0,0 +1,39 @@ +init(); + } + + /** + * Initialization method. + */ + protected function init() { + add_filter( 'taxonomy_template_hierarchy', array( $this, 'update_taxonomy_template_hierarchy' ), 10, 3 ); + } + + /** + * Render the Archive Product Template for product attributes. + * + * @param array $templates Templates that match the product attributes taxonomy. + */ + public function update_taxonomy_template_hierarchy( $templates ) { + if ( taxonomy_is_product_attribute( get_query_var( 'taxonomy' ) ) && wc_current_theme_is_fse_theme() ) { + array_unshift( $templates, self::SLUG ); + } + + return $templates; + } +} diff --git a/src/Utils/BlocksWpQuery.php b/src/Utils/BlocksWpQuery.php index 4fe397ea35f..fbf0ba0a58d 100644 --- a/src/Utils/BlocksWpQuery.php +++ b/src/Utils/BlocksWpQuery.php @@ -24,25 +24,6 @@ class BlocksWpQuery extends WP_Query { public function __construct( $query = '' ) { if ( ! empty( $query ) ) { $this->init(); - - // Remove current product from query to avoid infinite loops and out of memory issues. - // That might happen if the store is using Gutenberg for product descriptions. - // See https://github.com/woocommerce/woocommerce-blocks/issues/6416. - global $post; - if ( $post && array_key_exists( 'post__in', $query ) && is_array( $query['post__in'] ) ) { - $global_post_id = $post->ID; - $filtered_post__in = array_filter( - $query['post__in'], - static function ( $post_id ) use ( $global_post_id ) { - if ( $global_post_id === $post_id ) { - return false; - } - return true; - } - ); - $query['post__in'] = $filtered_post__in; - } - $this->query = wp_parse_args( $query ); $this->query_vars = $this->query; $this->parse_query_vars(); diff --git a/src/Utils/StyleAttributesUtils.php b/src/Utils/StyleAttributesUtils.php index 52533191b26..e8786c78f42 100644 --- a/src/Utils/StyleAttributesUtils.php +++ b/src/Utils/StyleAttributesUtils.php @@ -37,6 +37,27 @@ public static function get_font_size_class_and_style( $attributes ) { return null; } + /** + * Get class and style for font-weight from attributes. + * + * @param array $attributes Block attributes. + * + * @return (array | null) + */ + public static function get_font_weight_class_and_style( $attributes ) { + + $custom_font_weight = $attributes['style']['typography']['fontWeight'] ?? ''; + + if ( '' !== $custom_font_weight ) { + return array( + 'class' => null, + 'style' => sprintf( 'font-weight: %s;', $custom_font_weight ), + ); + } + return null; + } + + /** * Get class and style for font-family from attributes. * @@ -340,6 +361,7 @@ public static function get_classes_and_styles_by_attributes( $attributes, $prope 'text_color' => self::get_text_color_class_and_style( $attributes ), 'font_size' => self::get_font_size_class_and_style( $attributes ), 'font_family' => self::get_font_family_class_and_style( $attributes ), + 'font_weight' => self::get_font_weight_class_and_style( $attributes ), 'link_color' => self::get_link_color_class_and_style( $attributes ), 'background_color' => self::get_background_color_class_and_style( $attributes ), 'border_color' => self::get_border_color_class_and_style( $attributes ), diff --git a/tests/e2e/specs/backend/mini-cart.test.js b/tests/e2e/specs/backend/mini-cart.test.js index 73bbe372912..24e910e8a50 100644 --- a/tests/e2e/specs/backend/mini-cart.test.js +++ b/tests/e2e/specs/backend/mini-cart.test.js @@ -19,7 +19,6 @@ import { goToSiteEditor, useTheme, waitForCanvas, - addBlockToFSEArea, } from '../../utils.js'; const block = { @@ -30,8 +29,6 @@ const block = { insertButton: "//button//span[text()='Mini Cart']", insertButtonDisabled: "//button[@aria-disabled]//span[text()='Mini Cart']", - compatibilityNoticeTitle: - "//h1[contains(text(), 'Compatibility notice')]", }, }; @@ -40,14 +37,6 @@ if ( process.env.WOOCOMMERCE_BLOCKS_PHASE < 3 ) { test.only( `skipping ${ block.name } tests`, () => {} ); } -const removeDismissedCompatibilityNoticesFromLocalStorage = async () => { - await page.evaluate( () => { - window.localStorage.removeItem( - 'wc-blocks_dismissed_compatibility_notices' - ); - } ); -}; - const addBlockToWidgetsArea = async () => { await closeModalIfExists(); await openWidgetsEditorBlockInserter(); @@ -58,10 +47,6 @@ const addBlockToWidgetsArea = async () => { describe( `${ block.name } Block`, () => { describe( 'in widget editor', () => { - beforeAll( async () => { - await removeDismissedCompatibilityNoticesFromLocalStorage(); - } ); - beforeEach( async () => { await openWidgetEditor(); } ); @@ -73,28 +58,6 @@ describe( `${ block.name } Block`, () => { ); } ); - it( 'the compatibility notice appears', async () => { - await addBlockToWidgetsArea(); - const compatibilityNoticeTitle = await page.$x( - block.selectors.compatibilityNoticeTitle - ); - expect( compatibilityNoticeTitle.length ).toBe( 1 ); - } ); - - it( "after the compatibility notice is dismissed, it doesn't appear again", async () => { - await page.evaluate( () => { - window.localStorage.setItem( - 'wc-blocks_dismissed_compatibility_notices', - '["mini-cart"]' - ); - } ); - await addBlockToWidgetsArea(); - const compatibilityNoticeTitle = await page.$x( - block.selectors.compatibilityNoticeTitle - ); - expect( compatibilityNoticeTitle.length ).toBe( 0 ); - } ); - it( 'can only be inserted once', async () => { await addBlockToWidgetsArea(); const miniCartButton = await page.$x( @@ -109,11 +72,7 @@ describe( `${ block.name } Block`, () => { useTheme( 'emptytheme' ); beforeEach( async () => { - // TODO: Update to always use site-editor.php once WordPress 6.0 is released and fix is verified. - await goToSiteEditor( - process.env.GUTENBERG_EDITOR_CONTEXT || 'core' - ); - await removeDismissedCompatibilityNoticesFromLocalStorage(); + await goToSiteEditor(); await waitForCanvas(); } ); @@ -122,28 +81,6 @@ describe( `${ block.name } Block`, () => { await expect( canvas() ).toMatchElement( block.class ); } ); - it( 'the compatibility notice appears', async () => { - await addBlockToFSEArea( block.name ); - const compatibilityNoticeTitle = await page.$x( - block.selectors.compatibilityNoticeTitle - ); - expect( compatibilityNoticeTitle.length ).toBe( 1 ); - } ); - - it( "after the compatibility notice is dismissed, it doesn't appear again", async () => { - await page.evaluate( () => { - window.localStorage.setItem( - 'wc-blocks_dismissed_compatibility_notices', - '["mini-cart"]' - ); - } ); - await addBlockToFSEArea( block.name ); - const compatibilityNoticeTitle = await page.$x( - block.selectors.compatibilityNoticeTitle - ); - expect( compatibilityNoticeTitle.length ).toBe( 0 ); - } ); - it( 'can only be inserted once', async () => { await insertBlock( block.name ); await searchForFSEBlock( block.name ); diff --git a/tests/e2e/specs/shopper/filter-products-by-attribute.test.ts b/tests/e2e/specs/shopper/filter-products-by-attribute.test.ts index 0359b790ee6..2154af8a43c 100644 --- a/tests/e2e/specs/shopper/filter-products-by-attribute.test.ts +++ b/tests/e2e/specs/shopper/filter-products-by-attribute.test.ts @@ -87,6 +87,8 @@ describe( `${ block.name } Block`, () => { it( 'should show only products that match the filter', async () => { const isRefreshed = jest.fn( () => void 0 ); page.on( 'load', isRefreshed ); + + await page.waitForSelector( selectors.frontend.filter ); await page.click( selectors.frontend.filter ); await waitForAllProductsBlockLoaded(); const products = await page.$$( selectors.frontend.productsList ); @@ -119,7 +121,6 @@ describe( `${ block.name } Block`, () => { ); await canvasEl.click( selectors.editor.doneButton ); await saveTemplate(); - await goToShopPage(); } ); afterAll( async () => { @@ -127,6 +128,10 @@ describe( `${ block.name } Block`, () => { await deleteAllTemplates( 'wp_template_part' ); } ); + beforeEach( async () => { + await goToShopPage(); + } ); + it( 'should render', async () => { const products = await page.$$( selectors.frontend.classicProductsList @@ -145,6 +150,8 @@ describe( `${ block.name } Block`, () => { expect( isRefreshed ).not.toBeCalled(); + await page.waitForSelector( selectors.frontend.filter ); + await Promise.all( [ page.waitForNavigation(), page.click( selectors.frontend.filter ), diff --git a/tests/e2e/specs/shopper/filter-products-by-price.test.ts b/tests/e2e/specs/shopper/filter-products-by-price.test.ts index 9d81d783fdf..87062c4e5f7 100644 --- a/tests/e2e/specs/shopper/filter-products-by-price.test.ts +++ b/tests/e2e/specs/shopper/filter-products-by-price.test.ts @@ -52,10 +52,10 @@ const goToShopPage = () => const setMaxPrice = async () => { await page.waitForSelector( selectors.frontend.priceMaxAmount ); await page.focus( selectors.frontend.priceMaxAmount ); - await page.$eval( - selectors.frontend.priceMaxAmount, - ( el ) => ( ( el as HTMLInputElement ).value = '' ) - ); + await page.keyboard.down( 'Shift' ); + await page.keyboard.press( 'Home' ); + await page.keyboard.up( 'Shift' ); + await page.keyboard.press( 'Backspace' ); await page.keyboard.type( '1.99' ); await page.keyboard.press( 'Tab' ); }; @@ -71,6 +71,7 @@ describe( `${ block.name } Block`, () => { await insertBlock( block.name ); await insertBlock( 'All Products' ); + await insertBlock( 'Active Product Filters' ); await publishPost(); const link = await page.evaluate( () => @@ -90,12 +91,18 @@ describe( `${ block.name } Block`, () => { const isRefreshed = jest.fn( () => void 0 ); page.on( 'load', isRefreshed ); await setMaxPrice(); + await expect( page ).toMatchElement( + '.wc-block-active-filters__title', + { + text: 'Active filters', + } + ); await waitForAllProductsBlockLoaded(); - await page.waitForSelector( selectors.frontend.productsList ); const products = await page.$$( selectors.frontend.productsList ); expect( isRefreshed ).not.toBeCalled(); + expect( products ).toHaveLength( 1 ); await expect( page ).toMatch( block.foundProduct ); diff --git a/tests/e2e/utils.js b/tests/e2e/utils.js index 0bf42c14dc5..3a4f127c19f 100644 --- a/tests/e2e/utils.js +++ b/tests/e2e/utils.js @@ -64,7 +64,7 @@ const SELECTORS = { savePrompt: '.entities-saved-states__text-prompt', }, allProductsBlock: { - productsList: '.wc-block-grid__products > li > div:not(.is-loading)', + productsList: '.wc-block-grid__products:not(.is-loading-products)', }, }; @@ -157,46 +157,29 @@ export const isBlockInsertedInWidgetsArea = async ( blockName ) => { /** * Visits site editor dependening on used WordPress version and how Gutenberg is installed. * - * 1. `themes.php?page=gutenberg-edit-site` this is a legacy editor access used for WP <=5.8. - * 2. `site-editor.php` is the new way of accessing the editor in WP >=5.9+. - * - * @param {'core' | 'gutenberg'} [editorContext='core'] Whether to go to the Gutenberg URL or the Core one. * @param {Object} params Query parameters to add to the URL. * @param {string} [params.postId] ID of the template if we want to access template editor. * @param {'wp_template' | 'wp_template_part'} [params.postType='wp_template'] Type of template. */ -export async function goToSiteEditor( editorContext = 'core', params ) { - // There is a bug in Gutenberg/WPCore now that makes it impossible to rely on site-editor.php on setups - // with locally installed Gutenberg. Details in https://github.com/WordPress/gutenberg/issues/39639. - // TODO: Update to always use site-editor.php once WordPress 6.0 is released and fix is verified. - // Remove usage of goToSiteEditor and GUTENBERG_EDITOR_CONTEXT from from here and from workflows. - let editorPath; - const queryParams = { ...params }; - - if ( editorContext === 'gutenberg' ) { - editorPath = 'themes.php'; - queryParams.page = 'gutenberg-edit-site'; - } else { - editorPath = 'site-editor.php'; - } - - return await visitAdminPage( editorPath, addQueryArgs( '', queryParams ) ); +export async function goToSiteEditor( params = {} ) { + return await visitAdminPage( + 'site-editor.php', + addQueryArgs( '', params ) + ); } /** * Visits the Site Editor template edit view. * * @param {Object} params - * @param {string} params.postId ID of the template if we want to access template editor. - * @param {'core' | 'gutenberg'} [params.editorContext='core'] Whether to go to the Gutenberg URL or the Core one. + * @param {string} [params.postId] ID of the template if we want to access template editor. * @param {'wp_template' | 'wp_template_part'} [params.postType='wp_template'] Type of template. */ export async function goToTemplateEditor( { postId, postType = 'wp_template', - editorContext = GUTENBERG_EDITOR_CONTEXT, } = {} ) { - await goToSiteEditor( editorContext, { + await goToSiteEditor( { postType, postId, } ); @@ -209,16 +192,14 @@ export async function goToTemplateEditor( { * Visits the Site Editor templates list view. * * @param {Object} params - * @param {'core' | 'gutenberg'} [params.editorContext='core'] Whether to go to the Gutenberg URL or the Core one. * @param {'wp_template' | 'wp_template_part'} [params.postType='wp_template'] Type of template. * @param {'list' | 'actions'} [params.waitFor='false'] Wait for list or for actions to be present - tempalte actions can take a moment to load, we can wait for them to be present if needed. */ export async function goToTemplatesList( { postType = 'wp_template', - editorContext = GUTENBERG_EDITOR_CONTEXT, waitFor = 'list', } = {} ) { - await goToSiteEditor( editorContext, { postType } ); + await goToSiteEditor( { postType } ); if ( waitFor === 'actions' ) { await page.waitForSelector( @@ -456,5 +437,4 @@ export const openBlockEditorSettings = async ( { isFSEEditor = false } ) => { */ export const waitForAllProductsBlockLoaded = async () => { await page.waitForSelector( SELECTORS.allProductsBlock.productsList ); - await page.waitForTimeout( 5000 ); }; diff --git a/woocommerce-gutenberg-products-block.php b/woocommerce-gutenberg-products-block.php index bcbea62ea4e..d45b7efb20a 100644 --- a/woocommerce-gutenberg-products-block.php +++ b/woocommerce-gutenberg-products-block.php @@ -3,7 +3,7 @@ * Plugin Name: WooCommerce Blocks * Plugin URI: https://github.com/woocommerce/woocommerce-gutenberg-products-block * Description: WooCommerce blocks for the Gutenberg editor. - * Version: 8.2.0-dev + * Version: 8.3.0-dev * Author: Automattic * Author URI: https://woocommerce.com * Text Domain: woo-gutenberg-products-block