diff --git a/assets/js/blocks/product-collection/constants.ts b/assets/js/blocks/product-collection/constants.ts
index 96ecb190aa4..6a5759c3597 100644
--- a/assets/js/blocks/product-collection/constants.ts
+++ b/assets/js/blocks/product-collection/constants.ts
@@ -40,7 +40,6 @@ export const DEFAULT_QUERY: ProductCollectionQuery = {
postType: 'product',
order: 'asc',
orderBy: 'title',
- author: '',
search: '',
exclude: [],
inherit: null,
diff --git a/assets/js/blocks/product-collection/inspector-controls/author-control.tsx b/assets/js/blocks/product-collection/inspector-controls/author-control.tsx
deleted file mode 100644
index 8fedd27376c..00000000000
--- a/assets/js/blocks/product-collection/inspector-controls/author-control.tsx
+++ /dev/null
@@ -1,151 +0,0 @@
-/**
- * External dependencies
- */
-import { __ } from '@wordpress/i18n';
-import { useEntityRecords } from '@wordpress/core-data';
-import {
- FormTokenField,
- // @ts-expect-error Using experimental features
- // eslint-disable-next-line @wordpress/no-unsafe-wp-apis
- __experimentalToolsPanelItem as ToolsPanelItem,
-} from '@wordpress/components';
-
-/**
- * Internal dependencies
- */
-import { QueryControlProps } from '../types';
-
-interface Author {
- id: string;
- name: string;
-}
-
-interface AuthorsInfo {
- authors: Author[];
- mapById: Map< number, Author >;
- mapByName: Map< string, Author >;
- names: string[];
-}
-
-const AUTHORS_QUERY = {
- who: 'authors',
- per_page: -1,
- _fields: 'id,name',
- context: 'view',
-};
-
-export const getAuthorsInfo = ( authors: Author[] ): AuthorsInfo => {
- const mapById = new Map< number, Author >();
- const mapByName = new Map< string, Author >();
- const names: string[] = [];
-
- authors.forEach( ( author ) => {
- mapById.set( Number( author.id ), author );
- mapByName.set( author.name, author );
- names.push( author.name );
- } );
-
- return {
- authors,
- mapById,
- mapByName,
- names,
- };
-};
-
-const getIdByValue = (
- entitiesMappedByName: Map< string, Author >,
- authorValue: string | Author
-) => {
- const id =
- ( authorValue as Author )?.id ||
- entitiesMappedByName.get( authorValue as string )?.id;
- if ( id ) return id;
-};
-
-function AuthorControl( { query, setQueryAttribute }: QueryControlProps ) {
- const value = query.author;
- const { records: authorsList, error } = useEntityRecords< Author[] >(
- 'root',
- 'user',
- AUTHORS_QUERY
- );
-
- if ( error ) {
- return (
- true }
- >
-
-
- );
- }
-
- if ( ! authorsList ) return null;
-
- const authorsInfo = getAuthorsInfo( authorsList as Author[] );
-
- /**
- * We need to normalize the value because the block operates on a
- * comma(`,`) separated string value and `FormTokenFields` needs an
- * array.
- *
- * Returns only the existing authors ids. This prevents the component
- * from crashing in the editor, when non existing ids are provided.
- */
- const sanitizedValue = value
- ? ( value
- .split( ',' )
- .map( ( authorId ) => {
- const author = authorsInfo.mapById.get(
- Number( authorId )
- );
- return author
- ? {
- id: author.id,
- value: author.name,
- }
- : null;
- } )
- .filter( Boolean ) as { id: string; value: string }[] )
- : [];
-
- const onAuthorChange = ( newValue: string[] ) => {
- const ids = Array.from(
- newValue.reduce( ( accumulator: Set< string >, author: string ) => {
- // Verify that new values point to existing entities.
- const id = getIdByValue( authorsInfo.mapByName, author );
- if ( id ) accumulator.add( id );
- return accumulator;
- }, new Set() )
- );
- setQueryAttribute( { author: ids.join( ',' ) } );
- };
-
- return (
- !! value }
- label={ __( 'Authors', 'woo-gutenberg-products-block' ) }
- onDeselect={ () => setQueryAttribute( { author: '' } ) }
- >
-
-
- );
-}
-
-export default AuthorControl;
diff --git a/assets/js/blocks/product-collection/inspector-controls/index.tsx b/assets/js/blocks/product-collection/inspector-controls/index.tsx
index a68c6a178ee..8d8ffed8f85 100644
--- a/assets/js/blocks/product-collection/inspector-controls/index.tsx
+++ b/assets/js/blocks/product-collection/inspector-controls/index.tsx
@@ -38,7 +38,6 @@ import KeywordControl from './keyword-control';
import AttributesControl from './attributes-control';
import TaxonomyControls from './taxonomy-controls';
import HandPickedProductsControl from './hand-picked-products-control';
-import AuthorControl from './author-control';
import LayoutOptionsControl from './layout-options-control';
const ProductCollectionInspectorControls = (
@@ -99,7 +98,6 @@ const ProductCollectionInspectorControls = (
-
) : null }
diff --git a/assets/js/blocks/product-collection/types.ts b/assets/js/blocks/product-collection/types.ts
index 7d20d723fee..ad2f0d4a26a 100644
--- a/assets/js/blocks/product-collection/types.ts
+++ b/assets/js/blocks/product-collection/types.ts
@@ -29,7 +29,6 @@ export interface ProductCollectionDisplayLayout {
}
export interface ProductCollectionQuery {
- author: string;
exclude: string[];
inherit: boolean | null;
offset: number;
diff --git a/assets/js/blocks/product-template/edit.tsx b/assets/js/blocks/product-template/edit.tsx
index 7bcff3bdbb1..15572127262 100644
--- a/assets/js/blocks/product-template/edit.tsx
+++ b/assets/js/blocks/product-template/edit.tsx
@@ -77,7 +77,6 @@ const ProductTemplateEdit = ( {
offset = 0,
order,
orderBy,
- author,
search,
exclude,
inherit,
@@ -155,9 +154,6 @@ const ProductTemplateEdit = ( {
if ( perPage ) {
query.per_page = perPage;
}
- if ( author ) {
- query.author = author;
- }
if ( search ) {
query.search = search;
}
@@ -186,7 +182,6 @@ const ProductTemplateEdit = ( {
order,
orderBy,
clientId,
- author,
search,
postType,
exclude,
diff --git a/src/BlockTypes/ProductCollection.php b/src/BlockTypes/ProductCollection.php
index a486345f2be..eef32cfa7b5 100644
--- a/src/BlockTypes/ProductCollection.php
+++ b/src/BlockTypes/ProductCollection.php
@@ -207,7 +207,9 @@ public function update_rest_query_in_editor( $args, $request ): array {
$stock_status = $request->get_param( 'woocommerceStockStatus' );
$product_attributes = $request->get_param( 'woocommerceAttributes' );
$handpicked_products = $request->get_param( 'woocommerceHandPickedProducts' );
- $args['author'] = $request->get_param( 'author' ) ?? '';
+ // This argument is required for the tests to PHP Unit Tests to run correctly.
+ // Most likely this argument is being accessed in the test environment image.
+ $args['author'] = '';
return $this->get_final_query_args(
$args,
@@ -297,7 +299,6 @@ private function get_final_frontend_query( $query, $page = 1, $is_exclude_applie
'tax_query' => array(),
'paged' => $page,
's' => $query['search'],
- 'author' => $query['author'] ?? '',
);
$is_on_sale = $query['woocommerceOnSale'] ?? false;
diff --git a/tests/php/BlockTypes/ProductCollection.php b/tests/php/BlockTypes/ProductCollection.php
index 412c32d4213..5007f28960b 100644
--- a/tests/php/BlockTypes/ProductCollection.php
+++ b/tests/php/BlockTypes/ProductCollection.php
@@ -29,7 +29,6 @@ private function get_base_parsed_block() {
'postType' => 'product',
'order' => 'desc',
'orderBy' => 'date',
- 'author' => '',
'search' => '',
'exclude' => array(),
'sticky' => '',