| [ Index ] |
PHP Cross Reference of WordPress Trunk (Updated Daily) |
[Summary view] [Print] [Text view]
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
title
Description
Body
title
Description
Body
title
Description
Body
title
Body
| Generated : Sat Jun 13 09:38:55 2026 | Cross-referenced by PHPXref |