[ 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,image_output_formats,jpeg_interlaced,png_interlaced,gif_interlaced,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      // Fire init action for extensions to register routes and menu items
 138      do_action( 'options-connectors-wp-admin_init' );
 139  
 140      // Preload REST API data
 141      wp_options_connectors_wp_admin_preload_data();
 142  
 143      // Get all registered routes
 144      $routes = wp_get_options_connectors_wp_admin_routes();
 145  
 146      // Get boot module asset file for dependencies
 147      $asset_file = ABSPATH . WPINC . '/js/dist/script-modules/boot/index.min.asset.php';
 148      if ( file_exists( $asset_file ) ) {
 149          $asset = require $asset_file;
 150  
 151          // This script serves two purposes:
 152          // 1. It ensures all the globals that are made available to the modules are loaded.
 153          // 2. It initializes the boot module as an inline script.
 154          wp_register_script( 'options-connectors-wp-admin-prerequisites', '', $asset['dependencies'], $asset['version'], true );
 155  
 156          /*
 157           * Add inline script to initialize the app using initSinglePage (no menuItems).
 158           * The dynamic import is deferred until DOMContentLoaded so that all classic
 159           * script dependencies of @wordpress/boot (wp-private-apis, wp-components,
 160           * wp-theme, etc.) have finished parsing and executing before the boot module
 161           * evaluates. Otherwise, a modulepreloaded @wordpress/boot can win the race
 162           * against the classic-script-printing pass on fast CDN-fronted hosts in
 163           * Chrome, evaluating before wp.theme.privateApis is defined and throwing
 164           * "Cannot unlock an undefined object". See <https://core.trac.wordpress.org/ticket/65103>.
 165           */
 166          $init_js_function = <<<'JS'
 167          ( mountId, routes ) => {
 168              const run = async () => {
 169                  const mod = await import( "@wordpress/boot" );
 170                  mod.initSinglePage( { mountId, routes } );
 171              };
 172              if ( document.readyState === "loading" ) {
 173                  document.addEventListener( "DOMContentLoaded", run );
 174              } else {
 175                  run();
 176              }
 177          }
 178          JS;
 179          wp_add_inline_script(
 180              'options-connectors-wp-admin-prerequisites',
 181              sprintf(
 182                  '( %s )( %s, %s );',
 183                  $init_js_function,
 184                  wp_json_encode( 'options-connectors-wp-admin-app', JSON_HEX_TAG | JSON_UNESCAPED_SLASHES ),
 185                  wp_json_encode( $routes, JSON_HEX_TAG | JSON_UNESCAPED_SLASHES )
 186              )
 187          );
 188  
 189          // Register prerequisites style by filtering script dependencies to find registered styles
 190          $style_dependencies = array_filter(
 191              $asset['dependencies'],
 192              function ( $handle ) {
 193                  return wp_style_is( $handle, 'registered' );
 194              }
 195          );
 196          wp_register_style( 'options-connectors-wp-admin-prerequisites', false, $style_dependencies, $asset['version'] );
 197  
 198          // Build dependencies for options-connectors-wp-admin module
 199          $boot_dependencies = array(
 200              array(
 201                  'import' => 'static',
 202                  'id'     => '@wordpress/boot',
 203              ),
 204          );
 205  
 206          // Add all registered routes as dependencies
 207          foreach ( $routes as $route ) {
 208              if ( isset( $route['route_module'] ) ) {
 209                  $boot_dependencies[] = array(
 210                      'import' => 'static',
 211                      'id'     => $route['route_module'],
 212                  );
 213              }
 214              if ( isset( $route['content_module'] ) ) {
 215                  $boot_dependencies[] = array(
 216                      'import' => 'dynamic',
 217                      'id'     => $route['content_module'],
 218                  );
 219              }
 220          }
 221  
 222          // Dummy script module to ensure dependencies are loaded
 223          wp_register_script_module(
 224              'options-connectors-wp-admin',
 225              $build_constants['build_url'] . 'pages/options-connectors/loader.js',
 226              $boot_dependencies
 227          );
 228  
 229          // Enqueue the boot scripts and styles
 230          wp_enqueue_script( 'options-connectors-wp-admin-prerequisites' );
 231          wp_enqueue_script_module( 'options-connectors-wp-admin' );
 232          wp_enqueue_style( 'options-connectors-wp-admin-prerequisites' );
 233      }
 234  }
 235  
 236  /**
 237   * Render the options-connectors-wp-admin page.
 238   * Call this function from add_menu_page or add_submenu_page.
 239   * This renders within the normal WordPress admin interface.
 240   */
 241  function wp_options_connectors_wp_admin_render_page() {
 242      ?>
 243      <style>
 244          /* Critical styles to prevent layout shifts - inlined for immediate application */
 245  
 246          /* Background colors */
 247          #wpwrap {
 248              background: var(--wpds-color-fg-content-neutral, #1e1e1e);
 249              overflow-y: auto;
 250          }
 251          body {
 252              background: #fff;
 253          }
 254  
 255          /* Reset wp-admin padding */
 256          #wpcontent {
 257              padding-inline-start: 0;
 258          }
 259          #wpbody-content {
 260              padding-bottom: 0;
 261          }
 262  
 263          /* Hide legacy admin elements */
 264          #wpbody-content > div:not(.boot-layout-container):not(#screen-meta) {
 265              display: none;
 266          }
 267          #wpfooter {
 268              display: none;
 269          }
 270  
 271          /* Accessibility regions */
 272          .a11y-speak-region {
 273              inset-inline-start: -1px;
 274              top: -1px;
 275          }
 276  
 277          /* Admin menu indicators */
 278          ul#adminmenu a.wp-has-current-submenu::after,
 279          ul#adminmenu > li.current > a.current::after {
 280              border-inline-end-color: #fff;
 281          }
 282  
 283          /* Media frame fix */
 284          .media-frame select.attachment-filters:last-of-type {
 285              width: auto;
 286              max-width: 100%;
 287          }
 288  
 289          /* Responsive overflow fix for #wpwrap */
 290          @media (min-width: 782px) {
 291              #wpwrap {
 292                  overflow-y: initial;
 293              }
 294          }
 295      </style>
 296      <div id="options-connectors-wp-admin-app" class="boot-layout-container"></div>
 297      <?php
 298  }
 299  
 300  // Hook the enqueue function to admin_enqueue_scripts
 301  add_action( 'admin_enqueue_scripts', 'wp_options_connectors_wp_admin_enqueue_scripts' );
 302  


Generated : Sat Jun 13 09:38:55 2026 Cross-referenced by PHPXref