[ Index ]

PHP Cross Reference of WordPress Trunk (Updated Daily)

Search

title

Body

[close]

/wp-includes/build/pages/options-connectors/ -> page-wp-admin.php (source)

   1  <?php
   2  /**
   3   * Page: options-connectors (wp-admin integrated)
   4   * Auto-generated by build process.
   5   * Do not edit this file manually.
   6   *
   7   * This version integrates with the standard WordPress admin interface,
   8   * keeping the wp-admin sidebar and scripts/styles intact.
   9   *
  10   * @package wp
  11   */
  12  
  13  // Global storage for options-connectors routes and menu items
  14  global $wp_options_connectors_wp_admin_routes, $wp_options_connectors_wp_admin_menu_items;
  15  $wp_options_connectors_wp_admin_routes     = array();
  16  $wp_options_connectors_wp_admin_menu_items = array();
  17  
  18  /**
  19   * Register a route for the options-connectors-wp-admin page.
  20   *
  21   * @param string      $path           Route path (e.g., '/types/$type/edit/$id').
  22   * @param string|null $content_module Script module ID for content (stage/inspector).
  23   * @param string|null $route_module   Script module ID for route lifecycle hooks.
  24   */
  25  function wp_register_options_connectors_wp_admin_route( $path, $content_module = null, $route_module = null ) {
  26      global $wp_options_connectors_wp_admin_routes;
  27  
  28      $route = array( 'path' => $path );
  29      if ( ! empty( $content_module ) ) {
  30          $route['content_module'] = $content_module;
  31      }
  32      if ( ! empty( $route_module ) ) {
  33          $route['route_module'] = $route_module;
  34      }
  35  
  36      $wp_options_connectors_wp_admin_routes[] = $route;
  37  }
  38  
  39  /**
  40   * Register a menu item for the options-connectors-wp-admin page.
  41   * Note: Menu items are registered but not displayed in single-page mode.
  42   *
  43   * @param string $id        Menu item ID.
  44   * @param string $label     Display label.
  45   * @param string $to        Route path to navigate to.
  46   * @param string $parent_id Optional. Parent menu item ID.
  47   */
  48  function wp_register_options_connectors_wp_admin_menu_item( $id, $label, $to, $parent_id = '' ) {
  49      global $wp_options_connectors_wp_admin_menu_items;
  50  
  51      $menu_item = array(
  52          'id'    => $id,
  53          'label' => $label,
  54          'to'    => $to,
  55      );
  56  
  57      if ( ! empty( $parent_id ) ) {
  58          $menu_item['parent'] = $parent_id;
  59      }
  60  
  61      $wp_options_connectors_wp_admin_menu_items[] = $menu_item;
  62  }
  63  
  64  /**
  65   * Get all registered routes for the options-connectors-wp-admin page.
  66   *
  67   * @return array Array of route objects.
  68   */
  69  function wp_get_options_connectors_wp_admin_routes() {
  70      global $wp_options_connectors_wp_admin_routes;
  71      return $wp_options_connectors_wp_admin_routes ?? array();
  72  }
  73  
  74  /**
  75   * Get all registered menu items for the options-connectors-wp-admin page.
  76   *
  77   * @return array Array of menu item objects.
  78   */
  79  function wp_get_options_connectors_wp_admin_menu_items() {
  80      global $wp_options_connectors_wp_admin_menu_items;
  81      return $wp_options_connectors_wp_admin_menu_items ?? array();
  82  }
  83  
  84  /**
  85   * Preload REST API data for the options-connectors-wp-admin page.
  86   * Automatically called during page rendering.
  87   */
  88  function wp_options_connectors_wp_admin_preload_data() {
  89      // Define paths to preload - same for all pages
  90      // Please also change packages/core-data/src/entities.js when changing this.
  91      $preload_paths = array(
  92          '/?_fields=description,gmt_offset,home,image_sizes,image_size_threshold,name,site_icon,site_icon_url,site_logo,timezone_string,url,page_for_posts,page_on_front,show_on_front',
  93          array( '/wp/v2/settings', 'OPTIONS' ),
  94      );
  95  
  96      // Use rest_preload_api_request to gather the preloaded data
  97      $preload_data = array_reduce(
  98          $preload_paths,
  99          'rest_preload_api_request',
 100          array()
 101      );
 102  
 103      // Register the preloading middleware with wp-api-fetch
 104      wp_add_inline_script(
 105          'wp-api-fetch',
 106          sprintf(
 107              'wp.apiFetch.use( wp.apiFetch.createPreloadingMiddleware( %s ) );',
 108              wp_json_encode( $preload_data )
 109          ),
 110          'after'
 111      );
 112  }
 113  
 114  /**
 115   * Enqueue scripts and styles for the options-connectors-wp-admin page.
 116   * Hooked to admin_enqueue_scripts.
 117   *
 118   * @param string $hook_suffix The current admin page.
 119   */
 120  function wp_options_connectors_wp_admin_enqueue_scripts( $hook_suffix ) {
 121      // Check all possible ways this page can be accessed:
 122      // 1. Menu page via admin.php?page=options-connectors-wp-admin (plugin)
 123      // 2. Direct file via options-connectors.php (Core) - screen ID will be 'options-connectors'
 124      $current_screen = get_current_screen();
 125      $is_our_page = (
 126          ( isset( $_GET['page'] ) && 'options-connectors-wp-admin' === $_GET['page'] ) || // phpcs:ignore WordPress.Security.NonceVerification.Recommended
 127          ( $current_screen && 'options-connectors' === $current_screen->id )
 128      );
 129  
 130      if ( ! $is_our_page ) {
 131          return;
 132      }
 133  
 134      // Load build constants
 135      $build_constants = require  __DIR__ . '/../../constants.php';
 136  
 137      /**
 138       * Fires when the options-connectors admin page is initialized so extensions can register routes and menu items.
 139       */
 140      do_action( 'options-connectors-wp-admin_init' );
 141  
 142      // Preload REST API data
 143      wp_options_connectors_wp_admin_preload_data();
 144  
 145      // Get all registered routes
 146      $routes = wp_get_options_connectors_wp_admin_routes();
 147  
 148      // Get boot module asset file for dependencies
 149      $asset_file = ABSPATH . WPINC . '/js/dist/script-modules/boot/index.min.asset.php';
 150      if ( file_exists( $asset_file ) ) {
 151          $asset = require $asset_file;
 152  
 153          // This script serves two purposes:
 154          // 1. It ensures all the globals that are made available to the modules are loaded.
 155          // 2. It initializes the boot module as an inline script.
 156          wp_register_script( 'options-connectors-wp-admin-prerequisites', '', $asset['dependencies'], $asset['version'], true );
 157  
 158          /*
 159           * Add inline script to initialize the app using initSinglePage (no menuItems).
 160           * The dynamic import is deferred until DOMContentLoaded so that all classic
 161           * script dependencies of @wordpress/boot (wp-private-apis, wp-components,
 162           * wp-theme, etc.) have finished parsing and executing before the boot module
 163           * evaluates. Otherwise, a modulepreloaded @wordpress/boot can win the race
 164           * against the classic-script-printing pass on fast CDN-fronted hosts in
 165           * Chrome, evaluating before wp.theme.privateApis is defined and throwing
 166           * "Cannot unlock an undefined object". See <https://core.trac.wordpress.org/ticket/65103>.
 167           */
 168          $init_js_function = <<<'JS'
 169          ( mountId, routes ) => {
 170              const run = async () => {
 171                  const mod = await import( "@wordpress/boot" );
 172                  mod.initSinglePage( { mountId, routes } );
 173              };
 174              if ( document.readyState === "loading" ) {
 175                  document.addEventListener( "DOMContentLoaded", run );
 176              } else {
 177                  run();
 178              }
 179          }
 180          JS;
 181          wp_add_inline_script(
 182              'options-connectors-wp-admin-prerequisites',
 183              sprintf(
 184                  '( %s )( %s, %s );',
 185                  $init_js_function,
 186                  wp_json_encode( 'options-connectors-wp-admin-app', JSON_HEX_TAG | JSON_UNESCAPED_SLASHES ),
 187                  wp_json_encode( $routes, JSON_HEX_TAG | JSON_UNESCAPED_SLASHES )
 188              )
 189          );
 190  
 191          // Register prerequisites style by filtering script dependencies to find registered styles
 192          $style_dependencies = array_filter(
 193              $asset['dependencies'],
 194              function ( $handle ) {
 195                  return wp_style_is( $handle, 'registered' );
 196              }
 197          );
 198          wp_register_style( 'options-connectors-wp-admin-prerequisites', false, $style_dependencies, $asset['version'] );
 199  
 200          // Build dependencies for options-connectors-wp-admin module
 201          $boot_dependencies = array(
 202              array(
 203                  'import' => 'static',
 204                  'id'     => '@wordpress/boot',
 205              ),
 206          );
 207  
 208          // Add all registered routes as dependencies
 209          foreach ( $routes as $route ) {
 210              if ( isset( $route['route_module'] ) ) {
 211                  $boot_dependencies[] = array(
 212                      'import' => 'static',
 213                      'id'     => $route['route_module'],
 214                  );
 215              }
 216              if ( isset( $route['content_module'] ) ) {
 217                  $boot_dependencies[] = array(
 218                      'import' => 'dynamic',
 219                      'id'     => $route['content_module'],
 220                  );
 221              }
 222          }
 223  
 224          /**
 225           * Filters the boot script-module dependencies for the
 226           * options-connectors-wp-admin page.
 227           *
 228           * Surfaces extending this page can append entries to the boot
 229           * dependency list. Each entry is an array with 'import' (string
 230           * 'static' or 'dynamic') and 'id' (script-module handle) keys.
 231           *
 232           * @param array $boot_dependencies Boot dependencies for the page.
 233           */
 234          $boot_dependencies = apply_filters(
 235              'options-connectors-wp-admin_boot_dependencies',
 236              $boot_dependencies
 237          );
 238  
 239          // Dummy script module to ensure dependencies are loaded
 240          wp_register_script_module(
 241              'options-connectors-wp-admin',
 242              $build_constants['build_url'] . 'pages/options-connectors/loader.js',
 243              $boot_dependencies
 244          );
 245  
 246          // Enqueue the boot scripts and styles
 247          wp_enqueue_script( 'options-connectors-wp-admin-prerequisites' );
 248          wp_enqueue_script_module( 'options-connectors-wp-admin' );
 249          wp_enqueue_style( 'options-connectors-wp-admin-prerequisites' );
 250      }
 251  }
 252  
 253  /**
 254   * Render the options-connectors-wp-admin page.
 255   * Call this function from add_menu_page or add_submenu_page.
 256   * This renders within the normal WordPress admin interface.
 257   */
 258  function wp_options_connectors_wp_admin_render_page() {
 259      ?>
 260      <style>
 261          /* Critical styles to prevent layout shifts - inlined for immediate application */
 262  
 263          #wpwrap {
 264              overflow-y: auto;
 265          }
 266          body {
 267              background: #fff;
 268          }
 269  
 270          /* Reset wp-admin padding */
 271          #wpcontent {
 272              padding-inline-start: 0;
 273          }
 274          #wpbody-content {
 275              padding-bottom: 0;
 276          }
 277  
 278          /* Hide legacy admin elements */
 279          #wpbody-content > div:not(.boot-layout-container):not(#screen-meta) {
 280              display: none;
 281          }
 282          #wpfooter {
 283              display: none;
 284          }
 285  
 286          /* Accessibility regions */
 287          .a11y-speak-region {
 288              inset-inline-start: -1px;
 289              top: -1px;
 290          }
 291  
 292          /* Admin menu indicators */
 293          ul#adminmenu a.wp-has-current-submenu::after,
 294          ul#adminmenu > li.current > a.current::after {
 295              border-inline-end-color: #fff;
 296          }
 297  
 298          /* Media frame fix */
 299          .media-frame select.attachment-filters:last-of-type {
 300              width: auto;
 301              max-width: 100%;
 302          }
 303  
 304          /* Responsive overflow fix for #wpwrap */
 305          @media (min-width: 782px) {
 306              #wpwrap {
 307                  overflow-y: initial;
 308              }
 309          }
 310      </style>
 311      <div id="options-connectors-wp-admin-app" class="boot-layout-container"></div>
 312      <?php
 313  }
 314  
 315  // Hook the enqueue function to admin_enqueue_scripts
 316  add_action( 'admin_enqueue_scripts', 'wp_options_connectors_wp_admin_enqueue_scripts' );
 317  


Generated : Fri Jul 3 08:20:12 2026 Cross-referenced by PHPXref