wpseek.com
A WordPress-centric search engine for devs and theme authors



wp_taxonomies_wp_admin_enqueue_scripts › WordPress Function

Sincen/a
Deprecatedn/a
wp_taxonomies_wp_admin_enqueue_scripts ( $hook_suffix )
Parameters:
  • (string) $hook_suffix The current admin page.
    Required: Yes
Defined at:
Codex:

Enqueue scripts and styles for the taxonomies-wp-admin page.

Hooked to admin_enqueue_scripts.


Source

function wp_taxonomies_wp_admin_enqueue_scripts( $hook_suffix ) {
	// Check all possible ways this page can be accessed:
	// 1. Menu page via admin.php?page=taxonomies-wp-admin (plugin)
	// 2. Direct file via taxonomies.php (Core) - screen ID will be 'taxonomies'
	$current_screen = get_current_screen();
	$is_our_page = (
		( isset( $_GET['page'] ) && 'taxonomies-wp-admin' === $_GET['page'] ) || // phpcs:ignore WordPress.Security.NonceVerification.Recommended
		( $current_screen && 'taxonomies' === $current_screen->id )
	);

	if ( ! $is_our_page ) {
		return;
	}

	// Load build constants
	$build_constants = require __DIR__ . '/../../constants.php';

	// Fire init action for extensions to register routes and menu items
	do_action( 'taxonomies-wp-admin_init' );

	// Preload REST API data
	wp_taxonomies_wp_admin_preload_data();

	// Get all registered routes
	$routes = wp_get_taxonomies_wp_admin_routes();

	// Get boot module asset file for dependencies
	$asset_file = ABSPATH . WPINC . '/js/dist/script-modules/boot/index.min.asset.php';
	if ( file_exists( $asset_file ) ) {
		$asset = require $asset_file;

		// This script serves two purposes:
		// 1. It ensures all the globals that are made available to the modules are loaded.
		// 2. It initializes the boot module as an inline script.
		wp_register_script( 'taxonomies-wp-admin-prerequisites', '', $asset['dependencies'], $asset['version'], true );

		// Add inline script to initialize the app using initSinglePage (no menuItems)
		wp_add_inline_script(
			'taxonomies-wp-admin-prerequisites',
			sprintf(
				'import("@wordpress/boot").then(mod => mod.initSinglePage({mountId: "%s", routes: %s}));',
				'taxonomies-wp-admin-app',
				wp_json_encode( $routes, JSON_HEX_TAG | JSON_UNESCAPED_SLASHES )
			)
		);

		// Register prerequisites style by filtering script dependencies to find registered styles
		$style_dependencies = array_filter(
			$asset['dependencies'],
			function ( $handle ) {
				return wp_style_is( $handle, 'registered' );
			}
		);
		wp_register_style( 'taxonomies-wp-admin-prerequisites', false, $style_dependencies, $asset['version'] );

		// Build dependencies for taxonomies-wp-admin module
		$boot_dependencies = array(
			array(
				'import' => 'static',
				'id'     => '@wordpress/boot',
			),
		);

		// Add all registered routes as dependencies
		foreach ( $routes as $route ) {
			if ( isset( $route['route_module'] ) ) {
				$boot_dependencies[] = array(
					'import' => 'static',
					'id'     => $route['route_module'],
				);
			}
			if ( isset( $route['content_module'] ) ) {
				$boot_dependencies[] = array(
					'import' => 'dynamic',
					'id'     => $route['content_module'],
				);
			}
		}

		// Dummy script module to ensure dependencies are loaded
		wp_register_script_module(
			'taxonomies-wp-admin',
			$build_constants['build_url'] . 'pages/taxonomies/loader.js',
			$boot_dependencies
		);

		// Enqueue the boot scripts and styles
		wp_enqueue_script( 'taxonomies-wp-admin-prerequisites' );
		wp_enqueue_script_module( 'taxonomies-wp-admin' );
		wp_enqueue_style( 'taxonomies-wp-admin-prerequisites' );
	}
}