wp_get_themes

Получает данные всех тем (шаблонов) из папки “themes”. Данные отдаются в виде массива объектов: каждый объект набор данных темы.

Скорость работы функции напрямую зависит от того, сколько у вас тем в папке “themes”. Поэтому в целях производительности ограничитесь функцией wp_get_theme(), если это возможно.

Если нужно просто получить названия всех тем (названия директорий тем), можно воспользоваться функцией search_theme_directories().

Аналогичная функция для получения данных плагинов: get_plugins()

Хуков нет.

Возвращает

Массив объектов WP_Theme.

Использование

wp_get_themes( $args );

Параметры $args

$args(массив)

Массив аргументов по которым будет получен результат. Может принимать следующие аргументы:

  • errors – Может быть:

    • “true” – чтобы вернуть темы с ошибками.
    • “false” – чтобы вернуть темы без ошибок.
    • “null” – чтобы вернуть все темы.

    по умолчанию false

  • allowed (мультисайты) – Может быть:

    • “true” – чтобы вернуть только доступные для сайта темы.
    • “false” – чтобы вернуть недоступные для сайта темы.
    • “site” – чтобы вернуть темы доступные для сайтов сети.
    • “network” – чтобы вернуть темы доступные для самой сети.
    • “null” – вернет все темы.

    по умолчанию null

  • blog_id (мультисайты) – ID блога темы для которого доступны. По умолчанию 0 (означает – текущий блог).

По умолчанию: array( ‘errors’ => false , ‘allowed’ => null, ‘blog_id’ => 0 )

Примеры

#1 Получим данные всех существующих тем (шаблонов)

<?php
function wp_get_themes( $args = array() ) {
	global $wp_theme_directories;

	$defaults = array( 'errors' => false, 'allowed' => null, 'blog_id' => 0 );
	$args = wp_parse_args( $args, $defaults );

	$theme_directories = search_theme_directories();

	if ( count( $wp_theme_directories ) > 1 ) {
		// Make sure the current theme wins out, in case search_theme_directories() picks the wrong
		// one in the case of a conflict. (Normally, last registered theme root wins.)
		$current_theme = get_stylesheet();
		if ( isset( $theme_directories[ $current_theme ] ) ) {
			$root_of_current_theme = get_raw_theme_root( $current_theme );
			if ( ! in_array( $root_of_current_theme, $wp_theme_directories ) )
				$root_of_current_theme = WP_CONTENT_DIR . $root_of_current_theme;
			$theme_directories[ $current_theme ]['theme_root'] = $root_of_current_theme;
		}
	}

	if ( empty( $theme_directories ) )
		return array();

	if ( is_multisite() && null !== $args['allowed'] ) {
		$allowed = $args['allowed'];
		if ( 'network' === $allowed )
			$theme_directories = array_intersect_key( $theme_directories, WP_Theme::get_allowed_on_network() );
		elseif ( 'site' === $allowed )
			$theme_directories = array_intersect_key( $theme_directories, WP_Theme::get_allowed_on_site( $args['blog_id'] ) );
		elseif ( $allowed )
			$theme_directories = array_intersect_key( $theme_directories, WP_Theme::get_allowed( $args['blog_id'] ) );
		else
			$theme_directories = array_diff_key( $theme_directories, WP_Theme::get_allowed( $args['blog_id'] ) );
	}

	$themes = array();
	static $_themes = array();

	foreach ( $theme_directories as $theme => $theme_root ) {
		if ( isset( $_themes[ $theme_root['theme_root'] . '/' . $theme ] ) )
			$themes[ $theme ] = $_themes[ $theme_root['theme_root'] . '/' . $theme ];
		else
			$themes[ $theme ] = $_themes[ $theme_root['theme_root'] . '/' . $theme ] = new WP_Theme( $theme, $theme_root['theme_root'] );
	}

	if ( null !== $args['errors'] ) {
		foreach ( $themes as $theme => $wp_theme ) {
			if ( $wp_theme->errors() != $args['errors'] )
				unset( $themes[ $theme ] );
		}
	}

	return $themes;
}