Skip to content
This repository has been archived by the owner on Feb 23, 2024. It is now read-only.

Product Collection - shrink columns to fit #11320

Merged
merged 5 commits into from
Oct 23, 2023

Conversation

kmanijak
Copy link
Contributor

What

Add an option to "Shrink columns to fit" in Product Collection so the blocks is responsive.

Fixes #10827

Why

Product Collection has the option to set a number of columns but it's a fixed number which looks weird on smaller screens. That number of columns collapses to a single one on mobile devices ( check #9971).

This option allows to set a MAX number of columns but as the screen gets narrower, the number of columns decreases.

The minimal width of a product was chosen arbitrarily to 150px and is a subject to change (I'm open to suggestion in this area).

Testing Instructions

Please consider any edge cases this change may have, and also other areas of the product this may impact.

  1. Go to Editor
  2. Add Product Collection block
  3. "Shrink columns to fit" is disabled by default. Enable it
  4. Label of columns control should change from "Columns" to "Max Columns"
  5. Play with the "Max Columns" control and make sure it's respected in the Editor
  6. Narrow down the screen width and make sure the number of columns decreases as the screen gets narrower
  7. Save the Editor with couple of different "Max Columns" settings and go to frontend
  8. Narrow down the screen width and make sure the number of columns decreases as the screen gets narrower
  9. Verify frontend on major browsers
  • Do not include in the Testing Notes
  • Should be tested by the development team exclusively

Screenshots or screencast

Before After
https://github.com/woocommerce/woocommerce-blocks/assets/20098064/ae3e12e0-b894-46b8-9027-614da9a5fb51 https://github.com/woocommerce/woocommerce-blocks/assets/20098064/ecc7e75c-c787-486c-a000-8f951c52416e

WooCommerce Visibility

Required:

  • WooCommerce Core
  • Feature plugin
  • Experimental
  • N/A

Checklist

Required:

  • This PR has either a [type] label or a [skip-changelog] label.
  • This PR is assigned to a milestone.

Conditional:

  • This PR has a changelog description (if [skip-changelog] label is not present).
  • This PR adds/removes a feature flag & I've updated this doc.
  • This PR adds/removes an experimental interfaces, and I've updated this doc.
  • This PR has been accessibility tested.
  • This PR has had any necessary documentation added/updated.

Changelog

Product Collection: add "Shrink columns to fit" option so the columns are responsive and adjust to the screen width.

@kmanijak kmanijak added type: enhancement The issue is a request for an enhancement. block: product collection Issues related to the Product Collection block labels Oct 18, 2023
@woocommercebot woocommercebot requested review from a team and roykho and removed request for a team October 18, 2023 15:03
@github-actions
Copy link
Contributor

github-actions bot commented Oct 18, 2023

The release ZIP for this PR is accessible via:

https://wcblocks.wpcomstaging.com/wp-content/uploads/woocommerce-gutenberg-products-block-11320.zip

Script Dependencies Report

There is no changed script dependency between this branch and trunk.

This comment was automatically generated by the ./github/compare-assets action.

TypeScript Errors Report

  • Files with errors: 523
  • Total errors: 2341

🎉 🎉 This PR does not introduce new TS errors.

comments-aggregator

@github-actions
Copy link
Contributor

github-actions bot commented Oct 18, 2023

Size Change: +1.68 kB (0%)

Total Size: 1.54 MB

Filename Size Change
build/active-filters-frontend.js 6.56 kB -138 B (-2%)
build/active-filters-wrapper-frontend.js 6.88 kB -160 B (-2%)
build/active-filters.js 6.04 kB -124 B (-2%)
build/all-products-frontend.js 9.86 kB -22 B (0%)
build/all-products-rtl.css 4.53 kB -5 B (0%)
build/all-products.css 4.53 kB -1 B (0%)
build/all-products.js 39.8 kB +43 B (0%)
build/all-reviews.js 7.84 kB -3 B (0%)
build/attribute-filter-frontend.js 19.8 kB -107 B (-1%)
build/attribute-filter-wrapper-frontend.js 21 kB -119 B (-1%)
build/attribute-filter.js 11.2 kB -102 B (-1%)
build/blocks-components.js 7.48 kB +154 B (+2%)
build/cart-blocks/cart-cross-sells-products-frontend.js 5.55 kB -122 B (-2%)
build/cart-blocks/cart-order-summary-frontend.js 21 kB -89 B (0%)
build/cart-blocks/order-summary-coupon-form-frontend.js 21.3 kB -90 B (0%)
build/cart-blocks/order-summary-discount-frontend.js 21.4 kB -94 B (0%)
build/cart-blocks/order-summary-shipping-frontend.js 21 kB -92 B (0%)
build/cart-blocks/proceed-to-checkout-frontend.js 7.62 kB +36 B (0%)
build/cart-frontend.js 28.9 kB -40 B (0%)
build/cart-rtl.css 9.62 kB +18 B (0%)
build/cart.css 9.61 kB +15 B (0%)
build/cart.js 40 kB +778 B (+2%)
build/checkout-blocks/actions-frontend.js 8.11 kB +6 B (0%)
build/checkout-blocks/express-payment-frontend.js 5.85 kB -38 B (-1%)
build/checkout-blocks/order-summary-cart-items-frontend.js 6.47 kB -131 B (-2%)
build/checkout-blocks/order-summary-coupon-form-frontend.js 21.3 kB -117 B (-1%)
build/checkout-blocks/order-summary-discount-frontend.js 21.4 kB -121 B (-1%)
build/checkout-blocks/order-summary-frontend.js 21 kB -114 B (-1%)
build/checkout-blocks/order-summary-shipping-frontend.js 21 kB -114 B (-1%)
build/checkout-blocks/payment-frontend.js 15.4 kB -109 B (-1%)
build/checkout-blocks/pickup-options-frontend.js 12 kB -133 B (-1%)
build/checkout-blocks/shipping-address-frontend.js 10.2 kB +14 B (0%)
build/checkout-blocks/shipping-methods-frontend.js 19.8 kB -131 B (-1%)
build/checkout-frontend.js 30.5 kB -3 B (0%)
build/checkout-rtl.css 9.31 kB +4 B (0%)
build/checkout.css 9.3 kB +4 B (0%)
build/checkout.js 43.4 kB +801 B (+2%)
build/classic-shortcode.js 4.63 kB +233 B (+5%) 🔍
build/collection-price-filter.js 3.43 kB -119 B (-3%)
build/filter-wrapper-frontend.js 14.5 kB -1 B (0%)
build/legacy-template.js 7.73 kB +11 B (0%)
build/mini-cart-component-frontend.js 30.7 kB +16 B (0%)
build/mini-cart-contents-rtl.css 3.21 kB -11 B (0%)
build/mini-cart-contents.css 3.2 kB -9 B (0%)
build/mini-cart-contents.js 15.9 kB +1 B (0%)
build/mini-cart-rtl.css 2.44 kB -10 B (0%)
build/mini-cart.css 2.44 kB -8 B (0%)
build/packages-style-rtl.css 4.21 kB -1 B (0%)
build/packages-style.css 4.21 kB -1 B (0%)
build/price-filter-frontend.js 7.86 kB -111 B (-1%)
build/price-filter-wrapper-frontend.js 8.08 kB -142 B (-2%)
build/price-filter.js 7.42 kB -108 B (-1%)
build/product-add-to-cart-rtl.css 1.37 kB -4 B (0%)
build/product-add-to-cart.css 1.38 kB -3 B (0%)
build/product-button-interactivity-frontend.js 8.48 kB -3 B (0%)
build/product-collection.js 13.7 kB +131 B (+1%)
build/product-gallery-large-image-frontend.js 585 B +169 B (+41%) 🚨
build/product-gallery-rtl.css 1.15 kB +74 B (+7%) 🔍
build/product-gallery.css 1.15 kB +74 B (+7%) 🔍
build/product-gallery.js 9.4 kB +54 B (+1%)
build/product-image-frontend.js 2.89 kB -1 B (0%)
build/product-image.js 2.53 kB -152 B (-6%)
build/product-query.js 11.5 kB +10 B (0%)
build/product-sale-badge-frontend.js 2.01 kB -4 B (0%)
build/product-sale-badge.js 1.52 kB -171 B (-10%) 👏
build/product-template-rtl.css 536 B +113 B (+27%) 🚨
build/product-template.css 535 B +113 B (+27%) 🚨
build/product-template.js 2.8 kB +41 B (+1%)
build/rating-filter-frontend.js 18.7 kB -105 B (-1%)
build/rating-filter-wrapper-frontend.js 19.7 kB -137 B (-1%)
build/rating-filter.js 5.79 kB -121 B (-2%)
build/reviews-by-category.js 11.4 kB -1 B (0%)
build/reviews-by-product.js 12.7 kB -2 B (0%)
build/reviews-frontend.js 6.52 kB -2 B (0%)
build/single-product.js 11 kB -1 B (0%)
build/stock-filter-frontend.js 18.9 kB -113 B (-1%)
build/stock-filter-wrapper-frontend.js 19.9 kB -128 B (-1%)
build/stock-filter.js 6.42 kB -104 B (-2%)
build/wc-blocks-editor-style-rtl.css 7.18 kB +98 B (+1%)
build/wc-blocks-editor-style.css 7.17 kB +93 B (+1%)
build/wc-blocks-vendors.js 61.7 kB +2.47 kB (+4%)
ℹ️ View Unchanged
Filename Size
build/3810-frontend.js 18.3 kB
build/4124-frontend.js 23.9 kB
build/8280-frontend.js 8.48 kB
build/active-filters-rtl.css 1.68 kB
build/active-filters-wrapper-rtl.css 1.53 kB
build/active-filters-wrapper.css 1.53 kB
build/active-filters.css 1.68 kB
build/add-to-cart-form-rtl.css 375 B
build/add-to-cart-form.css 373 B
build/all-reviews-rtl.css 1.79 kB
build/all-reviews.css 1.79 kB
build/attribute-filter-rtl.css 4.03 kB
build/attribute-filter-wrapper-rtl.css 1.65 kB
build/attribute-filter-wrapper.css 1.65 kB
build/attribute-filter.css 4.01 kB
build/base-components-stock-filter-wrapper~attribute-filter-wrapper~rating-filter-wrapper-style.scss-rtl.css 2.97 kB
build/base-components-stock-filter-wrapper~attribute-filter-wrapper~rating-filter-wrapper-style.scss.css 2.97 kB
build/blocks-checkout.js 33.9 kB
build/breadcrumbs-rtl.css 234 B
build/breadcrumbs.css 234 B
build/breadcrumbs.js 2.03 kB
build/cart-blocks/cart-accepted-payment-methods-frontend.js 1.4 kB
build/cart-blocks/cart-accepted-payment-methods-style.js 153 B
build/cart-blocks/cart-cross-sells-frontend.js 268 B
build/cart-blocks/cart-cross-sells-products-style.js 153 B
build/cart-blocks/cart-cross-sells-style.js 269 B
build/cart-blocks/cart-express-payment-frontend.js 5.36 kB
build/cart-blocks/cart-express-payment-style.js 155 B
build/cart-blocks/cart-items-frontend.js 273 B
build/cart-blocks/cart-items-style.js 240 B
build/cart-blocks/cart-line-items-frontend.js 9.23 kB
build/cart-blocks/cart-line-items-style.js 153 B
build/cart-blocks/cart-order-summary-style.js 341 B
build/cart-blocks/cart-totals-frontend.js 290 B
build/cart-blocks/cart-totals-style.js 253 B
build/cart-blocks/empty-cart-frontend.js 367 B
build/cart-blocks/empty-cart-style.js 365 B
build/cart-blocks/filled-cart-frontend.js 605 B
build/cart-blocks/filled-cart-style.js 333 B
build/cart-blocks/order-summary-coupon-form-style.js 155 B
build/cart-blocks/order-summary-discount-style.js 155 B
build/cart-blocks/order-summary-fee-frontend.js 288 B
build/cart-blocks/order-summary-fee-style.js 153 B
build/cart-blocks/order-summary-heading-frontend.js 346 B
build/cart-blocks/order-summary-heading-style.js 351 B
build/cart-blocks/order-summary-shipping-style.js 154 B
build/cart-blocks/order-summary-subtotal-frontend.js 291 B
build/cart-blocks/order-summary-subtotal-style.js 154 B
build/cart-blocks/order-summary-taxes-frontend.js 456 B
build/cart-blocks/order-summary-taxes-style.js 202 B
build/cart-blocks/proceed-to-checkout-style.js 1.08 kB
build/catalog-sorting-rtl.css 259 B
build/catalog-sorting.css 259 B
build/catalog-sorting.js 1.69 kB
build/checkout-blocks/actions-style.js 1.01 kB
build/checkout-blocks/billing-address-frontend.js 10.2 kB
build/checkout-blocks/billing-address-style.js 626 B
build/checkout-blocks/contact-information-frontend.js 2.08 kB
build/checkout-blocks/contact-information-style.js 651 B
build/checkout-blocks/fields-frontend.js 297 B
build/checkout-blocks/fields-style.js 271 B
build/checkout-blocks/order-note-frontend.js 1.14 kB
build/checkout-blocks/order-summary-cart-items-style.js 153 B
build/checkout-blocks/order-summary-coupon-form-style.js 155 B
build/checkout-blocks/order-summary-discount-style.js 154 B
build/checkout-blocks/order-summary-fee-frontend.js 291 B
build/checkout-blocks/order-summary-fee-style.js 155 B
build/checkout-blocks/order-summary-shipping-style.js 154 B
build/checkout-blocks/order-summary-style.js 342 B
build/checkout-blocks/order-summary-subtotal-frontend.js 289 B
build/checkout-blocks/order-summary-subtotal-style.js 155 B
build/checkout-blocks/order-summary-taxes-frontend.js 456 B
build/checkout-blocks/order-summary-taxes-style.js 201 B
build/checkout-blocks/payment-style.js 504 B
build/checkout-blocks/pickup-options-style.js 476 B
build/checkout-blocks/shipping-address-style.js 515 B
build/checkout-blocks/shipping-method-frontend.js 2.34 kB
build/checkout-blocks/shipping-method-style.js 1.43 kB
build/checkout-blocks/shipping-methods-style.js 450 B
build/checkout-blocks/terms-frontend.js 1.55 kB
build/checkout-blocks/terms-style.js 1.02 kB
build/checkout-blocks/totals-frontend.js 334 B
build/checkout-blocks/totals-style.js 301 B
build/classic-shortcode-rtl.css 242 B
build/classic-shortcode.css 241 B
build/collection-filters.js 1.63 kB
build/collection-price-filter-frontend.js 577 B
build/collection-price-filter-rtl.css 1.28 kB
build/collection-price-filter.css 1.28 kB
build/customer-account-rtl.css 410 B
build/customer-account.css 409 B
build/customer-account.js 3.17 kB
build/featured-category-rtl.css 974 B
build/featured-category.css 973 B
build/featured-category.js 13.6 kB
build/featured-product-rtl.css 1.02 kB
build/featured-product.css 1.02 kB
build/featured-product.js 13.7 kB
build/filter-wrapper-rtl.css 378 B
build/filter-wrapper.css 378 B
build/filter-wrapper.js 2.37 kB
build/handpicked-products.js 7.22 kB
build/legacy-template-rtl.css 240 B
build/legacy-template.css 240 B
build/mini-cart-contents-block/cart-button-frontend.js 1.86 kB
build/mini-cart-contents-block/cart-button-style.js 1.23 kB
build/mini-cart-contents-block/checkout-button-frontend.js 1.95 kB
build/mini-cart-contents-block/checkout-button-style.js 1.43 kB
build/mini-cart-contents-block/empty-cart-frontend.js 374 B
build/mini-cart-contents-block/empty-cart-style.js 378 B
build/mini-cart-contents-block/filled-cart-frontend.js 284 B
build/mini-cart-contents-block/filled-cart-style.js 288 B
build/mini-cart-contents-block/footer-frontend.js 3.87 kB
build/mini-cart-contents-block/footer-style.js 1.95 kB
build/mini-cart-contents-block/items-frontend.js 247 B
build/mini-cart-contents-block/items-style.js 251 B
build/mini-cart-contents-block/products-table-frontend.js 8.58 kB
build/mini-cart-contents-block/shopping-button-frontend.js 501 B
build/mini-cart-contents-block/shopping-button-style.js 361 B
build/mini-cart-contents-block/title-frontend.js 2.04 kB
build/mini-cart-contents-block/title-items-counter-frontend.js 1.74 kB
build/mini-cart-contents-block/title-items-counter-style.js 1.2 kB
build/mini-cart-contents-block/title-label-frontend.js 1.68 kB
build/mini-cart-contents-block/title-label-style.js 1.14 kB
build/mini-cart-contents-block/title-style.js 1.38 kB
build/mini-cart-frontend.js 2.35 kB
build/mini-cart.js 6 kB
build/order-confirmation-additional-information-rtl.css 367 B
build/order-confirmation-additional-information.css 367 B
build/order-confirmation-additional-information.js 1.57 kB
build/order-confirmation-billing-address-rtl.css 398 B
build/order-confirmation-billing-address.css 397 B
build/order-confirmation-billing-address.js 1.55 kB
build/order-confirmation-billing-wrapper.js 1.5 kB
build/order-confirmation-downloads-rtl.css 477 B
build/order-confirmation-downloads-wrapper.js 1.57 kB
build/order-confirmation-downloads.css 478 B
build/order-confirmation-downloads.js 1.9 kB
build/order-confirmation-shipping-address-rtl.css 399 B
build/order-confirmation-shipping-address.css 398 B
build/order-confirmation-shipping-address.js 1.55 kB
build/order-confirmation-shipping-wrapper.js 1.5 kB
build/order-confirmation-status-rtl.css 280 B
build/order-confirmation-status.css 280 B
build/order-confirmation-status.js 1.54 kB
build/order-confirmation-summary-rtl.css 460 B
build/order-confirmation-summary.css 460 B
build/order-confirmation-summary.js 1.75 kB
build/order-confirmation-totals-rtl.css 594 B
build/order-confirmation-totals-wrapper.js 1.79 kB
build/order-confirmation-totals.css 593 B
build/order-confirmation-totals.js 2.16 kB
build/page-content-wrapper.js 1.85 kB
build/price-filter-rtl.css 2.68 kB
build/price-filter-wrapper-rtl.css 2.53 kB
build/price-filter-wrapper.css 2.53 kB
build/price-filter.css 2.67 kB
build/price-format.js 913 B
build/product-add-to-cart-frontend.js 8.11 kB
build/product-add-to-cart.js 8.35 kB
build/product-average-rating-frontend.js 1.88 kB
build/product-average-rating.js 1.4 kB
build/product-best-sellers.js 7.04 kB
build/product-button-frontend.js 4.93 kB
build/product-button-rtl.css 1.14 kB
build/product-button.css 1.14 kB
build/product-button.js 4.64 kB
build/product-categories-rtl.css 654 B
build/product-categories.css 654 B
build/product-categories.js 2.58 kB
build/product-category.js 7.97 kB
build/product-details-rtl.css 397 B
build/product-details.css 394 B
build/product-gallery-frontend.js 392 B
build/product-gallery-large-image-next-previous.js 4.15 kB
build/product-gallery-large-image.js 2.36 kB
build/product-gallery-pager.js 3.38 kB
build/product-gallery-thumbnails.js 3.8 kB
build/product-image-gallery-rtl.css 307 B
build/product-image-gallery.css 306 B
build/product-image-rtl.css 996 B
build/product-image.css 994 B
build/product-new.js 7.3 kB
build/product-on-sale.js 7.29 kB
build/product-price-frontend.js 2.81 kB
build/product-price-rtl.css 644 B
build/product-price.css 643 B
build/product-price.js 2.33 kB
build/product-query-rtl.css 350 B
build/product-query.css 349 B
build/product-rating-counter-frontend.js 2.19 kB
build/product-rating-counter.js 1.71 kB
build/product-rating-frontend.js 2.53 kB
build/product-rating-rtl.css 247 B
build/product-rating-stars-frontend.js 2.43 kB
build/product-rating-stars-rtl.css 899 B
build/product-rating-stars.css 900 B
build/product-rating-stars.js 1.95 kB
build/product-rating.css 246 B
build/product-rating.js 2.05 kB
build/product-results-count-rtl.css 230 B
build/product-results-count.css 230 B
build/product-results-count.js 1.65 kB
build/product-reviews-rtl.css 458 B
build/product-reviews.css 458 B
build/product-sale-badge-rtl.css 437 B
build/product-sale-badge.css 437 B
build/product-search-rtl.css 419 B
build/product-search.css 417 B
build/product-search.js 2.6 kB
build/product-sku-frontend.js 2.02 kB
build/product-sku-rtl.css 240 B
build/product-sku.css 239 B
build/product-sku.js 1.53 kB
build/product-stock-indicator-frontend.js 2.19 kB
build/product-stock-indicator-rtl.css 232 B
build/product-stock-indicator.css 232 B
build/product-stock-indicator.js 1.71 kB
build/product-summary-frontend.js 2.35 kB
build/product-summary-rtl.css 549 B
build/product-summary.css 549 B
build/product-summary.js 1.87 kB
build/product-tag.js 7.5 kB
build/product-title-frontend.js 2.31 kB
build/product-title-rtl.css 693 B
build/product-title.css 694 B
build/product-title.js 2.04 kB
build/product-top-rated.js 7.57 kB
build/products-by-attribute.js 8.02 kB
build/rating-filter-rtl.css 4.08 kB
build/rating-filter-wrapper-rtl.css 1.73 kB
build/rating-filter-wrapper.css 1.73 kB
build/rating-filter.css 4.07 kB
build/reviews-by-category-rtl.css 1.79 kB
build/reviews-by-category.css 1.79 kB
build/reviews-by-product-rtl.css 1.79 kB
build/reviews-by-product.css 1.79 kB
build/single-product-rtl.css 378 B
build/single-product.css 378 B
build/stock-filter-rtl.css 3.88 kB
build/stock-filter-wrapper-rtl.css 1.49 kB
build/stock-filter-wrapper.css 1.49 kB
build/stock-filter.css 3.87 kB
build/store-notices.js 1.67 kB
build/wc-blocks-classic-template-revert-button-style-rtl.css 240 B
build/wc-blocks-classic-template-revert-button-style.css 239 B
build/wc-blocks-classic-template-revert-button.js 1.18 kB
build/wc-blocks-data.js 19.6 kB
build/wc-blocks-google-analytics.js 1.16 kB
build/wc-blocks-middleware.js 735 B
build/wc-blocks-registry.js 2.74 kB
build/wc-blocks-rtl.css 2.47 kB
build/wc-blocks-shared-context.js 850 B
build/wc-blocks-shared-hocs.js 1.4 kB
build/wc-blocks.css 2.48 kB
build/wc-blocks.js 2.61 kB
build/wc-interactivity.js 10.7 kB
build/wc-payment-method-bacs.js 406 B
build/wc-payment-method-cheque.js 401 B
build/wc-payment-method-cod.js 508 B
build/wc-payment-method-paypal.js 437 B
build/wc-settings.js 2.4 kB
build/wc-shipping-method-pickup-location.js 29.3 kB

compressed-size-action

@roykho
Copy link
Member

roykho commented Oct 18, 2023

So I was able to trigger a console warning:

  1. Add the product collections block to the page.
  2. Update/save the page.
  3. Refresh the page.
  4. Click on Stack Layout.
  5. Click on back on Grid Layout.
  6. Click on Shrink columns to fit toggle.
  7. See console warning.

Warning: A component is changing an uncontrolled input to be controlled. This is likely caused by the value changing from undefined to a defined value, which should not happen. Decide between using a controlled or uncontrolled input element for the lifetime of the component. More info: https://reactjs.org/link/controlled-components

@kmanijak
Copy link
Contributor Author

So I was able to trigger a console warning:

@roykho, nice catch! I can't reproduce it sthough. Am I doing something wrong? See video below:

warning.mov

I repeated the steps also in the post and also in the scenario in which I add Product Collection on trunk and switch to this branch. In didn't get warning in neither of these cases 🤔

@roykho
Copy link
Member

roykho commented Oct 19, 2023

Interesting indeed. Please see video:

file.mov

Just to note that I tested this with WP 6.3.2 and WP 6.4-RC.1 and with GB disabled.

@kmanijak
Copy link
Contributor Author

Interesting indeed. Please see video:
Just to note that I tested this with WP 6.3.2 and WP 6.4-RC.1 and with GB disabled.

Thanks for the video, I'll be checking it further!

@kmanijak kmanijak changed the title Add/10827 product collection shrink columns to fit Product Collection - shrink columns to fit Oct 20, 2023
checked={ !! shrinkColumns }
label={ toggleLabel }
help={ toggleHelp }
onChange={ onToggleChange }
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I would suggest a more descriptive naming for the "onChange" callbacks because if we ever want to add more "toggle" controls, onToggleChange would not describe which settings it is referring to without looking into the details. Perhaps onShrinkColToggleChange?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Addressed in 99b6415 👍

@kmanijak
Copy link
Contributor Author

For reference: the console warning issue (#11320 (comment)) was resolved in 624fdfc

@kmanijak kmanijak requested a review from roykho October 23, 2023 07:56
Copy link
Member

@roykho roykho left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM Thanks for working on this.

@github-actions github-actions bot added this to the 11.4.0 milestone Oct 23, 2023
@kmanijak kmanijak merged commit e470bdb into trunk Oct 23, 2023
36 checks passed
@kmanijak kmanijak deleted the add/10827-product-collection-shrink-columns-to-fit branch October 23, 2023 12:28
@@ -61,7 +61,11 @@ protected function render( $attributes, $content, $block ) {
$classnames = '';
if ( isset( $block->context['displayLayout'] ) && isset( $block->context['query'] ) ) {
if ( isset( $block->context['displayLayout']['type'] ) && 'flex' === $block->context['displayLayout']['type'] ) {
$classnames = "is-flex-container columns-{$block->context['displayLayout']['columns']}";
if ( $block->context['displayLayout']['shrinkColumns'] ) {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hi @kmanijak - I didn't catch this earlier but this can potentially be undefined and will cause a PHP warning. So perhaps use ! empty()check?

Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
block: product collection Issues related to the Product Collection block type: enhancement The issue is a request for an enhancement.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Product Collection: Implement Responsive Columns Setting for Block
2 participants