Product Collection: allow custom collections hiding each of the filters (#49713)
* Allow hiding all of the filter controls in PC block * Add new test * Add changelog * Update documentation with information about hideControls values
This commit is contained in:
parent
5fdc8fa520
commit
d85acc7e09
|
@ -81,8 +81,23 @@ const ProductCollectionInspectorControls = (
|
||||||
isArchiveTemplate && shouldShowFilter( CoreFilterNames.INHERIT );
|
isArchiveTemplate && shouldShowFilter( CoreFilterNames.INHERIT );
|
||||||
const showOrderControl =
|
const showOrderControl =
|
||||||
showQueryControls && shouldShowFilter( CoreFilterNames.ORDER );
|
showQueryControls && shouldShowFilter( CoreFilterNames.ORDER );
|
||||||
const showFeaturedControl = shouldShowFilter( CoreFilterNames.FEATURED );
|
|
||||||
const showOnSaleControl = shouldShowFilter( CoreFilterNames.ON_SALE );
|
const showOnSaleControl = shouldShowFilter( CoreFilterNames.ON_SALE );
|
||||||
|
const showStockStatusControl = shouldShowFilter(
|
||||||
|
CoreFilterNames.STOCK_STATUS
|
||||||
|
);
|
||||||
|
const showHandPickedProductsControl = shouldShowFilter(
|
||||||
|
CoreFilterNames.HAND_PICKED
|
||||||
|
);
|
||||||
|
const showKeywordControl = shouldShowFilter( CoreFilterNames.KEYWORD );
|
||||||
|
const showAttributesControl = shouldShowFilter(
|
||||||
|
CoreFilterNames.ATTRIBUTES
|
||||||
|
);
|
||||||
|
const showTaxonomyControls = shouldShowFilter( CoreFilterNames.TAXONOMY );
|
||||||
|
const showFeaturedControl = shouldShowFilter( CoreFilterNames.FEATURED );
|
||||||
|
const showCreatedControl = shouldShowFilter( CoreFilterNames.CREATED );
|
||||||
|
const showPriceRangeControl = shouldShowFilter(
|
||||||
|
CoreFilterNames.PRICE_RANGE
|
||||||
|
);
|
||||||
|
|
||||||
const setQueryAttributeBind = useMemo(
|
const setQueryAttributeBind = useMemo(
|
||||||
() => setQueryAttribute.bind( null, props ),
|
() => setQueryAttribute.bind( null, props ),
|
||||||
|
@ -134,16 +149,30 @@ const ProductCollectionInspectorControls = (
|
||||||
{ showOnSaleControl && (
|
{ showOnSaleControl && (
|
||||||
<OnSaleControl { ...queryControlProps } />
|
<OnSaleControl { ...queryControlProps } />
|
||||||
) }
|
) }
|
||||||
|
{ showStockStatusControl && (
|
||||||
<StockStatusControl { ...queryControlProps } />
|
<StockStatusControl { ...queryControlProps } />
|
||||||
|
) }
|
||||||
|
{ showHandPickedProductsControl && (
|
||||||
<HandPickedProductsControl { ...queryControlProps } />
|
<HandPickedProductsControl { ...queryControlProps } />
|
||||||
|
) }
|
||||||
|
{ showKeywordControl && (
|
||||||
<KeywordControl { ...queryControlProps } />
|
<KeywordControl { ...queryControlProps } />
|
||||||
|
) }
|
||||||
|
{ showAttributesControl && (
|
||||||
<AttributesControl { ...queryControlProps } />
|
<AttributesControl { ...queryControlProps } />
|
||||||
|
) }
|
||||||
|
{ showTaxonomyControls && (
|
||||||
<TaxonomyControls { ...queryControlProps } />
|
<TaxonomyControls { ...queryControlProps } />
|
||||||
|
) }
|
||||||
{ showFeaturedControl && (
|
{ showFeaturedControl && (
|
||||||
<FeaturedProductsControl { ...queryControlProps } />
|
<FeaturedProductsControl { ...queryControlProps } />
|
||||||
) }
|
) }
|
||||||
|
{ showCreatedControl && (
|
||||||
<CreatedControl { ...queryControlProps } />
|
<CreatedControl { ...queryControlProps } />
|
||||||
|
) }
|
||||||
|
{ showPriceRangeControl && (
|
||||||
<PriceRangeControl { ...queryControlProps } />
|
<PriceRangeControl { ...queryControlProps } />
|
||||||
|
) }
|
||||||
</ToolsPanel>
|
</ToolsPanel>
|
||||||
) : null }
|
) : null }
|
||||||
<ProductCollectionFeedbackPrompt />
|
<ProductCollectionFeedbackPrompt />
|
||||||
|
|
|
@ -66,7 +66,17 @@ Attributes are the properties that define the behavior of the collection. All th
|
||||||
- `type` (type `string`): The type of layout. Accepted values are `grid` and `stack`.
|
- `type` (type `string`): The type of layout. Accepted values are `grid` and `stack`.
|
||||||
- `columns` (type `number`): The number of columns to display.
|
- `columns` (type `number`): The number of columns to display.
|
||||||
- `shrinkColumns` (type `boolean`): Whether the layout should be responsive.
|
- `shrinkColumns` (type `boolean`): Whether the layout should be responsive.
|
||||||
- `hideControls` (type `array`): The controls to hide.
|
- `hideControls` (type `array`): The controls to hide. Possible values:
|
||||||
|
- `order` - "Order by" setting
|
||||||
|
- `attributes` - "Product Attributes" filter
|
||||||
|
- `created` - "Created" filter
|
||||||
|
- `featured` - "Featured" filter
|
||||||
|
- `hand-picked` - "Hand-picked Products" filter
|
||||||
|
- `keyword` - "Keyword" filter
|
||||||
|
- `on-sale` - "On Sale" filter
|
||||||
|
- `stock-status` - "Stock Status" filter
|
||||||
|
- `taxonomy` - "Product Categories", "Product Tags" and custom taxonomies filters
|
||||||
|
- `price-range` - "Price Range" filter
|
||||||
|
|
||||||
#### Preview Attribute
|
#### Preview Attribute
|
||||||
|
|
||||||
|
@ -127,6 +137,7 @@ __experimentalRegisterProductCollection({
|
||||||
columns: 3,
|
columns: 3,
|
||||||
shrinkColumns: true,
|
shrinkColumns: true,
|
||||||
},
|
},
|
||||||
|
hideControls: [ "created", "stock-status" ]
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
```
|
```
|
||||||
|
|
|
@ -11,6 +11,7 @@ __experimentalRegisterProductCollection( {
|
||||||
query: {
|
query: {
|
||||||
perPage: 5,
|
perPage: 5,
|
||||||
},
|
},
|
||||||
|
hideControls: [ 'keyword', 'on-sale' ],
|
||||||
},
|
},
|
||||||
} );
|
} );
|
||||||
|
|
||||||
|
|
|
@ -1468,6 +1468,30 @@ test.describe( 'Testing registerProductCollection', () => {
|
||||||
.locator( 'visible=true' );
|
.locator( 'visible=true' );
|
||||||
await expect( products ).toHaveCount( 5 );
|
await expect( products ).toHaveCount( 5 );
|
||||||
} );
|
} );
|
||||||
|
|
||||||
|
test( 'hideControls allows to hide filters', async ( {
|
||||||
|
pageObject,
|
||||||
|
page,
|
||||||
|
} ) => {
|
||||||
|
await pageObject.goToProductCatalogAndInsertCollection(
|
||||||
|
'myCustomCollection'
|
||||||
|
);
|
||||||
|
|
||||||
|
const sidebarSettings = await pageObject.locateSidebarSettings();
|
||||||
|
const onsaleControl = sidebarSettings.getByLabel(
|
||||||
|
SELECTORS.onSaleControlLabel
|
||||||
|
);
|
||||||
|
await expect( onsaleControl ).toBeHidden();
|
||||||
|
|
||||||
|
await page
|
||||||
|
.getByRole( 'button', { name: 'Filters options' } )
|
||||||
|
.click();
|
||||||
|
const keywordControl = page.getByRole( 'menuitemcheckbox', {
|
||||||
|
name: 'Keyword',
|
||||||
|
} );
|
||||||
|
|
||||||
|
await expect( keywordControl ).toBeHidden();
|
||||||
|
} );
|
||||||
} );
|
} );
|
||||||
|
|
||||||
test.describe( 'My Custom Collection with Preview', () => {
|
test.describe( 'My Custom Collection with Preview', () => {
|
||||||
|
|
|
@ -0,0 +1,4 @@
|
||||||
|
Significance: patch
|
||||||
|
Type: fix
|
||||||
|
|
||||||
|
Product Collection: allow custom collections to hide all of the filter controls, not only some of them
|
Loading…
Reference in New Issue