W3cubDocs

/WordPress

WP_REST_Themes_Controller::get_items( WP_REST_Request $request ): WP_REST_Response|WP_Error

Retrieves a collection of themes.

Parameters

$requestWP_REST_Requestrequired
Full details about the request.

Return

WP_REST_Response|WP_Error Response object on success, or WP_Error object on failure.

Source

public function get_items( $request ) {
	$themes = array();

	$active_themes = wp_get_themes();
	$current_theme = wp_get_theme();
	$status        = $request['status'];

	foreach ( $active_themes as $theme ) {
		$theme_status = ( $this->is_same_theme( $theme, $current_theme ) ) ? 'active' : 'inactive';
		if ( is_array( $status ) && ! in_array( $theme_status, $status, true ) ) {
			continue;
		}

		$prepared = $this->prepare_item_for_response( $theme, $request );
		$themes[] = $this->prepare_response_for_collection( $prepared );
	}

	$response = rest_ensure_response( $themes );

	$response->header( 'X-WP-Total', count( $themes ) );
	$response->header( 'X-WP-TotalPages', 1 );

	return $response;
}

Changelog

Version Description
5.0.0 Introduced.

© 2003–2024 WordPress Foundation
Licensed under the GNU GPLv2+ License.
https://developer.wordpress.org/reference/classes/wp_rest_themes_controller/get_items