File manager - Edit - /home/watersyst/public_html/wp-includes/blocks/comment-content/pages.tar
Back
font-library/loader.js 0000644 00000000055 15211435750 0010763 0 ustar 00 // Empty module loader for page dependencies font-library/page-wp-admin.php 0000644 00000022035 15211435750 0012320 0 ustar 00 <?php /** * Page: font-library (wp-admin integrated) * Auto-generated by build process. * Do not edit this file manually. * * This version integrates with the standard WordPress admin interface, * keeping the wp-admin sidebar and scripts/styles intact. * * @package wp */ // Global storage for font-library routes and menu items global $wp_font_library_wp_admin_routes, $wp_font_library_wp_admin_menu_items; $wp_font_library_wp_admin_routes = array(); $wp_font_library_wp_admin_menu_items = array(); /** * Register a route for the font-library-wp-admin page. * * @param string $path Route path (e.g., '/types/$type/edit/$id'). * @param string|null $content_module Script module ID for content (stage/inspector). * @param string|null $route_module Script module ID for route lifecycle hooks. */ function wp_register_font_library_wp_admin_route( $path, $content_module = null, $route_module = null ) { global $wp_font_library_wp_admin_routes; $route = array( 'path' => $path ); if ( ! empty( $content_module ) ) { $route['content_module'] = $content_module; } if ( ! empty( $route_module ) ) { $route['route_module'] = $route_module; } $wp_font_library_wp_admin_routes[] = $route; } /** * Register a menu item for the font-library-wp-admin page. * Note: Menu items are registered but not displayed in single-page mode. * * @param string $id Menu item ID. * @param string $label Display label. * @param string $to Route path to navigate to. * @param string $parent_id Optional. Parent menu item ID. */ function wp_register_font_library_wp_admin_menu_item( $id, $label, $to, $parent_id = '' ) { global $wp_font_library_wp_admin_menu_items; $menu_item = array( 'id' => $id, 'label' => $label, 'to' => $to, ); if ( ! empty( $parent_id ) ) { $menu_item['parent'] = $parent_id; } $wp_font_library_wp_admin_menu_items[] = $menu_item; } /** * Get all registered routes for the font-library-wp-admin page. * * @return array Array of route objects. */ function wp_get_font_library_wp_admin_routes() { global $wp_font_library_wp_admin_routes; return $wp_font_library_wp_admin_routes ?? array(); } /** * Get all registered menu items for the font-library-wp-admin page. * * @return array Array of menu item objects. */ function wp_get_font_library_wp_admin_menu_items() { global $wp_font_library_wp_admin_menu_items; return $wp_font_library_wp_admin_menu_items ?? array(); } /** * Preload REST API data for the font-library-wp-admin page. * Automatically called during page rendering. */ function wp_font_library_wp_admin_preload_data() { // Define paths to preload - same for all pages // Please also change packages/core-data/src/entities.js when changing this. $preload_paths = array( '/?_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', array( '/wp/v2/settings', 'OPTIONS' ), ); // Use rest_preload_api_request to gather the preloaded data $preload_data = array_reduce( $preload_paths, 'rest_preload_api_request', array() ); // Register the preloading middleware with wp-api-fetch wp_add_inline_script( 'wp-api-fetch', sprintf( 'wp.apiFetch.use( wp.apiFetch.createPreloadingMiddleware( %s ) );', wp_json_encode( $preload_data ) ), 'after' ); } /** * Enqueue scripts and styles for the font-library-wp-admin page. * Hooked to admin_enqueue_scripts. * * @param string $hook_suffix The current admin page. */ function wp_font_library_wp_admin_enqueue_scripts( $hook_suffix ) { // Check all possible ways this page can be accessed: // 1. Menu page via admin.php?page=font-library-wp-admin (plugin) // 2. Direct file via font-library.php (Core) - screen ID will be 'font-library' $current_screen = get_current_screen(); $is_our_page = ( ( isset( $_GET['page'] ) && 'font-library-wp-admin' === $_GET['page'] ) || // phpcs:ignore WordPress.Security.NonceVerification.Recommended ( $current_screen && 'font-library' === $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( 'font-library-wp-admin_init' ); // Preload REST API data wp_font_library_wp_admin_preload_data(); // Get all registered routes $routes = wp_get_font_library_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( 'font-library-wp-admin-prerequisites', '', $asset['dependencies'], $asset['version'], true ); /* * Add inline script to initialize the app using initSinglePage (no menuItems). * The dynamic import is deferred until DOMContentLoaded so that all classic * script dependencies of @wordpress/boot (wp-private-apis, wp-components, * wp-theme, etc.) have finished parsing and executing before the boot module * evaluates. Otherwise, a modulepreloaded @wordpress/boot can win the race * against the classic-script-printing pass on fast CDN-fronted hosts in * Chrome, evaluating before wp.theme.privateApis is defined and throwing * "Cannot unlock an undefined object". See <https://core.trac.wordpress.org/ticket/65103>. */ $init_js_function = <<<'JS' ( mountId, routes ) => { const run = async () => { const mod = await import( "@wordpress/boot" ); mod.initSinglePage( { mountId, routes } ); }; if ( document.readyState === "loading" ) { document.addEventListener( "DOMContentLoaded", run ); } else { run(); } } JS; wp_add_inline_script( 'font-library-wp-admin-prerequisites', sprintf( '( %s )( %s, %s );', $init_js_function, wp_json_encode( 'font-library-wp-admin-app', JSON_HEX_TAG | JSON_UNESCAPED_SLASHES ), 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( 'font-library-wp-admin-prerequisites', false, $style_dependencies, $asset['version'] ); // Build dependencies for font-library-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( 'font-library-wp-admin', $build_constants['build_url'] . 'pages/font-library/loader.js', $boot_dependencies ); // Enqueue the boot scripts and styles wp_enqueue_script( 'font-library-wp-admin-prerequisites' ); wp_enqueue_script_module( 'font-library-wp-admin' ); wp_enqueue_style( 'font-library-wp-admin-prerequisites' ); } } /** * Render the font-library-wp-admin page. * Call this function from add_menu_page or add_submenu_page. * This renders within the normal WordPress admin interface. */ function wp_font_library_wp_admin_render_page() { ?> <style> /* Critical styles to prevent layout shifts - inlined for immediate application */ /* Background colors */ #wpwrap { background: var(--wpds-color-fg-content-neutral, #1e1e1e); overflow-y: auto; } body { background: #fff; } /* Reset wp-admin padding */ #wpcontent { padding-inline-start: 0; } #wpbody-content { padding-bottom: 0; } /* Hide legacy admin elements */ #wpbody-content > div:not(.boot-layout-container):not(#screen-meta) { display: none; } #wpfooter { display: none; } /* Accessibility regions */ .a11y-speak-region { inset-inline-start: -1px; top: -1px; } /* Admin menu indicators */ ul#adminmenu a.wp-has-current-submenu::after, ul#adminmenu > li.current > a.current::after { border-inline-end-color: #fff; } /* Media frame fix */ .media-frame select.attachment-filters:last-of-type { width: auto; max-width: 100%; } /* Responsive overflow fix for #wpwrap */ @media (min-width: 782px) { #wpwrap { overflow-y: initial; } } </style> <div id="font-library-wp-admin-app" class="boot-layout-container"></div> <?php } // Hook the enqueue function to admin_enqueue_scripts add_action( 'admin_enqueue_scripts', 'wp_font_library_wp_admin_enqueue_scripts' ); font-library/page.php 0000644 00000022137 15211435750 0010611 0 ustar 00 <?php /** * Page: font-library * Auto-generated by build process. * Do not edit this file manually. * * @package wp */ // Global storage for font-library routes and menu items global $wp_font_library_routes, $wp_font_library_menu_items; $wp_font_library_routes = array(); $wp_font_library_menu_items = array(); /** * Register a route for the font-library page. * * @param string $path Route path (e.g., '/types/$type/edit/$id'). * @param string|null $content_module Script module ID for content (stage/inspector). * @param string|null $route_module Script module ID for route lifecycle hooks. */ function wp_register_font_library_route( $path, $content_module = null, $route_module = null ) { global $wp_font_library_routes; $route = array( 'path' => $path ); if ( ! empty( $content_module ) ) { $route['content_module'] = $content_module; } if ( ! empty( $route_module ) ) { $route['route_module'] = $route_module; } $wp_font_library_routes[] = $route; } /** * Register a menu item for the font-library page. * * @param string $id Menu item ID. * @param string $label Display label. * @param string $to Route path to navigate to. * @param string $parent_id Optional. Parent menu item ID. * @param string $parent_type Optional. Parent type: 'drilldown' or 'dropdown'. */ function wp_register_font_library_menu_item( $id, $label, $to, $parent_id = '', $parent_type = '' ) { global $wp_font_library_menu_items; $menu_item = array( 'id' => $id, 'label' => $label, 'to' => $to, ); if ( ! empty( $parent_id ) ) { $menu_item['parent'] = $parent_id; } if ( ! empty( $parent_type ) && in_array( $parent_type, array( 'drilldown', 'dropdown' ), true ) ) { $menu_item['parent_type'] = $parent_type; } $wp_font_library_menu_items[] = $menu_item; } /** * Get all registered routes for the font-library page. * * @return array Array of route objects. */ function wp_get_font_library_routes() { global $wp_font_library_routes; return $wp_font_library_routes ?? array(); } /** * Get all registered menu items for the font-library page. * * @return array Array of menu item objects. */ function wp_get_font_library_menu_items() { global $wp_font_library_menu_items; return $wp_font_library_menu_items ?? array(); } /** * Preload REST API data for the font-library page. * Automatically called during page rendering. */ function wp_font_library_preload_data() { // Define paths to preload - same for all pages // Please also change packages/core-data/src/entities.js when changing this. $preload_paths = array( '/?_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', array( '/wp/v2/settings', 'OPTIONS' ), ); // Use rest_preload_api_request to gather the preloaded data $preload_data = array_reduce( $preload_paths, 'rest_preload_api_request', array() ); // Register the preloading middleware with wp-api-fetch wp_add_inline_script( 'wp-api-fetch', sprintf( 'wp.apiFetch.use( wp.apiFetch.createPreloadingMiddleware( %s ) );', wp_json_encode( $preload_data ) ), 'after' ); } /** * Render the font-library page. * Call this function from add_menu_page or add_submenu_page. */ function wp_font_library_render_page() { // Load build constants $build_constants = require __DIR__ . '/../../constants.php'; // Set current screen set_current_screen(); // Remove unwanted deprecated handler remove_action( 'admin_head', 'wp_admin_bar_header' ); // Remove unwanted scripts and styles that were enqueued during `admin_init` foreach ( wp_scripts()->queue as $script ) { wp_dequeue_script( $script ); } foreach ( wp_styles()->queue as $style ) { wp_dequeue_style( $style ); } // Fire init action for extensions to register routes and menu items do_action( 'font-library_init' ); // Enqueue command palette assets for boot-based pages if ( function_exists( 'wp_enqueue_command_palette_assets' ) ) { wp_enqueue_command_palette_assets(); } // Preload REST API data wp_font_library_preload_data(); // Get all registered routes and menu items $menu_items = wp_get_font_library_menu_items(); $routes = wp_get_font_library_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( 'font-library-prerequisites', '', $asset['dependencies'], $asset['version'], true ); // Add inline script to initialize the app $init_modules = []; wp_add_inline_script( 'font-library-prerequisites', sprintf( 'import("@wordpress/boot").then(mod => mod.init({mountId: "%s", menuItems: %s, routes: %s, initModules: %s, dashboardLink: "%s"}));', 'font-library-app', wp_json_encode( $menu_items, JSON_HEX_TAG | JSON_UNESCAPED_SLASHES ), wp_json_encode( $routes, JSON_HEX_TAG | JSON_UNESCAPED_SLASHES ), wp_json_encode( $init_modules, JSON_HEX_TAG | JSON_UNESCAPED_SLASHES ), esc_url( admin_url( '/' ) ) ) ); // 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( 'font-library-prerequisites', false, $style_dependencies, $asset['version'] ); // Build dependencies for font-library module $boot_dependencies = array( array( 'import' => 'static', 'id' => '@wordpress/boot', ), ); // Add init modules as static dependencies // No init modules configured // 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( 'font-library', $build_constants['build_url'] . 'pages/font-library/loader.js', $boot_dependencies ); // Enqueue the boot scripts and styles wp_enqueue_script( 'font-library-prerequisites' ); wp_enqueue_script_module( 'font-library' ); wp_enqueue_style( 'font-library-prerequisites' ); } // Output the HTML ?> <!DOCTYPE html> <html <?php language_attributes(); ?>> <head> <meta charset="<?php bloginfo( 'charset' ); ?>"> <meta name="viewport" content="width=device-width, initial-scale=1"> <title><?php echo esc_html( get_admin_page_title() ); ?></title> <style> html { background: #f1f1f1; color: #444; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif; font-size: 13px; line-height: 1.4em; } body { margin: 0; } #wpadminbar { display: none; } </style> <?php global $hook_suffix; // phpcs:ignore WordPress.WP.GlobalVariablesOverride.Prohibited $hook_suffix = 'font-library'; // BEGIN see wp-admin/admin-header.php print_admin_styles(); print_head_scripts(); /** * Fires in head section for a specific admin page. * * @since 2.1.0 */ do_action( "admin_head-{$hook_suffix}" ); // phpcs:ignore WordPress.NamingConventions.ValidHookName.UseUnderscores /** * Fires in head section for all admin pages. * * @since 2.1.0 */ do_action( 'admin_head' ); // END see wp-admin/admin-header.php ?> </head> <body class="font-library"> <div id="font-library-app" style="height: 100vh; box-sizing: border-box;"></div> <?php // BEGIN see wp-admin/admin-footer.php /** * Prints scripts or data before the default footer scripts. * * @since 1.2.0 */ do_action( 'admin_footer', '' ); // Print import map first so it's available for inline scripts wp_script_modules()->print_import_map(); print_footer_scripts(); wp_script_modules()->print_enqueued_script_modules(); wp_script_modules()->print_script_module_preloads(); wp_script_modules()->print_script_module_data(); /** * Prints scripts or data after the default footer scripts. * * @since 2.8.0 */ do_action( "admin_footer-{$hook_suffix}" ); // phpcs:ignore WordPress.NamingConventions.ValidHookName.UseUnderscores // END see wp-admin/admin-footer.php ?> </body> </html> <?php exit; } /** * Intercept admin_init to render the page early. * This bypasses the default WordPress admin template. */ function wp_font_library_intercept_render() { // phpcs:ignore WordPress.Security.NonceVerification.Recommended if ( isset( $_GET['page'] ) && 'font-library' === $_GET['page'] ) { wp_font_library_render_page(); exit; } } // Hook the interceptor to admin_init add_action( 'admin_init', 'wp_font_library_intercept_render' ); options-connectors/loader.js 0000644 00000000055 15211435750 0012221 0 ustar 00 // Empty module loader for page dependencies options-connectors/page-wp-admin.php 0000644 00000022475 15211435750 0013566 0 ustar 00 <?php /** * Page: options-connectors (wp-admin integrated) * Auto-generated by build process. * Do not edit this file manually. * * This version integrates with the standard WordPress admin interface, * keeping the wp-admin sidebar and scripts/styles intact. * * @package wp */ // Global storage for options-connectors routes and menu items global $wp_options_connectors_wp_admin_routes, $wp_options_connectors_wp_admin_menu_items; $wp_options_connectors_wp_admin_routes = array(); $wp_options_connectors_wp_admin_menu_items = array(); /** * Register a route for the options-connectors-wp-admin page. * * @param string $path Route path (e.g., '/types/$type/edit/$id'). * @param string|null $content_module Script module ID for content (stage/inspector). * @param string|null $route_module Script module ID for route lifecycle hooks. */ function wp_register_options_connectors_wp_admin_route( $path, $content_module = null, $route_module = null ) { global $wp_options_connectors_wp_admin_routes; $route = array( 'path' => $path ); if ( ! empty( $content_module ) ) { $route['content_module'] = $content_module; } if ( ! empty( $route_module ) ) { $route['route_module'] = $route_module; } $wp_options_connectors_wp_admin_routes[] = $route; } /** * Register a menu item for the options-connectors-wp-admin page. * Note: Menu items are registered but not displayed in single-page mode. * * @param string $id Menu item ID. * @param string $label Display label. * @param string $to Route path to navigate to. * @param string $parent_id Optional. Parent menu item ID. */ function wp_register_options_connectors_wp_admin_menu_item( $id, $label, $to, $parent_id = '' ) { global $wp_options_connectors_wp_admin_menu_items; $menu_item = array( 'id' => $id, 'label' => $label, 'to' => $to, ); if ( ! empty( $parent_id ) ) { $menu_item['parent'] = $parent_id; } $wp_options_connectors_wp_admin_menu_items[] = $menu_item; } /** * Get all registered routes for the options-connectors-wp-admin page. * * @return array Array of route objects. */ function wp_get_options_connectors_wp_admin_routes() { global $wp_options_connectors_wp_admin_routes; return $wp_options_connectors_wp_admin_routes ?? array(); } /** * Get all registered menu items for the options-connectors-wp-admin page. * * @return array Array of menu item objects. */ function wp_get_options_connectors_wp_admin_menu_items() { global $wp_options_connectors_wp_admin_menu_items; return $wp_options_connectors_wp_admin_menu_items ?? array(); } /** * Preload REST API data for the options-connectors-wp-admin page. * Automatically called during page rendering. */ function wp_options_connectors_wp_admin_preload_data() { // Define paths to preload - same for all pages // Please also change packages/core-data/src/entities.js when changing this. $preload_paths = array( '/?_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', array( '/wp/v2/settings', 'OPTIONS' ), ); // Use rest_preload_api_request to gather the preloaded data $preload_data = array_reduce( $preload_paths, 'rest_preload_api_request', array() ); // Register the preloading middleware with wp-api-fetch wp_add_inline_script( 'wp-api-fetch', sprintf( 'wp.apiFetch.use( wp.apiFetch.createPreloadingMiddleware( %s ) );', wp_json_encode( $preload_data ) ), 'after' ); } /** * Enqueue scripts and styles for the options-connectors-wp-admin page. * Hooked to admin_enqueue_scripts. * * @param string $hook_suffix The current admin page. */ function wp_options_connectors_wp_admin_enqueue_scripts( $hook_suffix ) { // Check all possible ways this page can be accessed: // 1. Menu page via admin.php?page=options-connectors-wp-admin (plugin) // 2. Direct file via options-connectors.php (Core) - screen ID will be 'options-connectors' $current_screen = get_current_screen(); $is_our_page = ( ( isset( $_GET['page'] ) && 'options-connectors-wp-admin' === $_GET['page'] ) || // phpcs:ignore WordPress.Security.NonceVerification.Recommended ( $current_screen && 'options-connectors' === $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( 'options-connectors-wp-admin_init' ); // Preload REST API data wp_options_connectors_wp_admin_preload_data(); // Get all registered routes $routes = wp_get_options_connectors_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( 'options-connectors-wp-admin-prerequisites', '', $asset['dependencies'], $asset['version'], true ); /* * Add inline script to initialize the app using initSinglePage (no menuItems). * The dynamic import is deferred until DOMContentLoaded so that all classic * script dependencies of @wordpress/boot (wp-private-apis, wp-components, * wp-theme, etc.) have finished parsing and executing before the boot module * evaluates. Otherwise, a modulepreloaded @wordpress/boot can win the race * against the classic-script-printing pass on fast CDN-fronted hosts in * Chrome, evaluating before wp.theme.privateApis is defined and throwing * "Cannot unlock an undefined object". See <https://core.trac.wordpress.org/ticket/65103>. */ $init_js_function = <<<'JS' ( mountId, routes ) => { const run = async () => { const mod = await import( "@wordpress/boot" ); mod.initSinglePage( { mountId, routes } ); }; if ( document.readyState === "loading" ) { document.addEventListener( "DOMContentLoaded", run ); } else { run(); } } JS; wp_add_inline_script( 'options-connectors-wp-admin-prerequisites', sprintf( '( %s )( %s, %s );', $init_js_function, wp_json_encode( 'options-connectors-wp-admin-app', JSON_HEX_TAG | JSON_UNESCAPED_SLASHES ), 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( 'options-connectors-wp-admin-prerequisites', false, $style_dependencies, $asset['version'] ); // Build dependencies for options-connectors-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( 'options-connectors-wp-admin', $build_constants['build_url'] . 'pages/options-connectors/loader.js', $boot_dependencies ); // Enqueue the boot scripts and styles wp_enqueue_script( 'options-connectors-wp-admin-prerequisites' ); wp_enqueue_script_module( 'options-connectors-wp-admin' ); wp_enqueue_style( 'options-connectors-wp-admin-prerequisites' ); } } /** * Render the options-connectors-wp-admin page. * Call this function from add_menu_page or add_submenu_page. * This renders within the normal WordPress admin interface. */ function wp_options_connectors_wp_admin_render_page() { ?> <style> /* Critical styles to prevent layout shifts - inlined for immediate application */ /* Background colors */ #wpwrap { background: var(--wpds-color-fg-content-neutral, #1e1e1e); overflow-y: auto; } body { background: #fff; } /* Reset wp-admin padding */ #wpcontent { padding-inline-start: 0; } #wpbody-content { padding-bottom: 0; } /* Hide legacy admin elements */ #wpbody-content > div:not(.boot-layout-container):not(#screen-meta) { display: none; } #wpfooter { display: none; } /* Accessibility regions */ .a11y-speak-region { inset-inline-start: -1px; top: -1px; } /* Admin menu indicators */ ul#adminmenu a.wp-has-current-submenu::after, ul#adminmenu > li.current > a.current::after { border-inline-end-color: #fff; } /* Media frame fix */ .media-frame select.attachment-filters:last-of-type { width: auto; max-width: 100%; } /* Responsive overflow fix for #wpwrap */ @media (min-width: 782px) { #wpwrap { overflow-y: initial; } } </style> <div id="options-connectors-wp-admin-app" class="boot-layout-container"></div> <?php } // Hook the enqueue function to admin_enqueue_scripts add_action( 'admin_enqueue_scripts', 'wp_options_connectors_wp_admin_enqueue_scripts' ); options-connectors/page.php 0000644 00000022571 15211435750 0012051 0 ustar 00 <?php /** * Page: options-connectors * Auto-generated by build process. * Do not edit this file manually. * * @package wp */ // Global storage for options-connectors routes and menu items global $wp_options_connectors_routes, $wp_options_connectors_menu_items; $wp_options_connectors_routes = array(); $wp_options_connectors_menu_items = array(); /** * Register a route for the options-connectors page. * * @param string $path Route path (e.g., '/types/$type/edit/$id'). * @param string|null $content_module Script module ID for content (stage/inspector). * @param string|null $route_module Script module ID for route lifecycle hooks. */ function wp_register_options_connectors_route( $path, $content_module = null, $route_module = null ) { global $wp_options_connectors_routes; $route = array( 'path' => $path ); if ( ! empty( $content_module ) ) { $route['content_module'] = $content_module; } if ( ! empty( $route_module ) ) { $route['route_module'] = $route_module; } $wp_options_connectors_routes[] = $route; } /** * Register a menu item for the options-connectors page. * * @param string $id Menu item ID. * @param string $label Display label. * @param string $to Route path to navigate to. * @param string $parent_id Optional. Parent menu item ID. * @param string $parent_type Optional. Parent type: 'drilldown' or 'dropdown'. */ function wp_register_options_connectors_menu_item( $id, $label, $to, $parent_id = '', $parent_type = '' ) { global $wp_options_connectors_menu_items; $menu_item = array( 'id' => $id, 'label' => $label, 'to' => $to, ); if ( ! empty( $parent_id ) ) { $menu_item['parent'] = $parent_id; } if ( ! empty( $parent_type ) && in_array( $parent_type, array( 'drilldown', 'dropdown' ), true ) ) { $menu_item['parent_type'] = $parent_type; } $wp_options_connectors_menu_items[] = $menu_item; } /** * Get all registered routes for the options-connectors page. * * @return array Array of route objects. */ function wp_get_options_connectors_routes() { global $wp_options_connectors_routes; return $wp_options_connectors_routes ?? array(); } /** * Get all registered menu items for the options-connectors page. * * @return array Array of menu item objects. */ function wp_get_options_connectors_menu_items() { global $wp_options_connectors_menu_items; return $wp_options_connectors_menu_items ?? array(); } /** * Preload REST API data for the options-connectors page. * Automatically called during page rendering. */ function wp_options_connectors_preload_data() { // Define paths to preload - same for all pages // Please also change packages/core-data/src/entities.js when changing this. $preload_paths = array( '/?_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', array( '/wp/v2/settings', 'OPTIONS' ), ); // Use rest_preload_api_request to gather the preloaded data $preload_data = array_reduce( $preload_paths, 'rest_preload_api_request', array() ); // Register the preloading middleware with wp-api-fetch wp_add_inline_script( 'wp-api-fetch', sprintf( 'wp.apiFetch.use( wp.apiFetch.createPreloadingMiddleware( %s ) );', wp_json_encode( $preload_data ) ), 'after' ); } /** * Render the options-connectors page. * Call this function from add_menu_page or add_submenu_page. */ function wp_options_connectors_render_page() { // Load build constants $build_constants = require __DIR__ . '/../../constants.php'; // Set current screen set_current_screen(); // Remove unwanted deprecated handler remove_action( 'admin_head', 'wp_admin_bar_header' ); // Remove unwanted scripts and styles that were enqueued during `admin_init` foreach ( wp_scripts()->queue as $script ) { wp_dequeue_script( $script ); } foreach ( wp_styles()->queue as $style ) { wp_dequeue_style( $style ); } // Fire init action for extensions to register routes and menu items do_action( 'options-connectors_init' ); // Enqueue command palette assets for boot-based pages if ( function_exists( 'wp_enqueue_command_palette_assets' ) ) { wp_enqueue_command_palette_assets(); } // Preload REST API data wp_options_connectors_preload_data(); // Get all registered routes and menu items $menu_items = wp_get_options_connectors_menu_items(); $routes = wp_get_options_connectors_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( 'options-connectors-prerequisites', '', $asset['dependencies'], $asset['version'], true ); // Add inline script to initialize the app $init_modules = []; wp_add_inline_script( 'options-connectors-prerequisites', sprintf( 'import("@wordpress/boot").then(mod => mod.init({mountId: "%s", menuItems: %s, routes: %s, initModules: %s, dashboardLink: "%s"}));', 'options-connectors-app', wp_json_encode( $menu_items, JSON_HEX_TAG | JSON_UNESCAPED_SLASHES ), wp_json_encode( $routes, JSON_HEX_TAG | JSON_UNESCAPED_SLASHES ), wp_json_encode( $init_modules, JSON_HEX_TAG | JSON_UNESCAPED_SLASHES ), esc_url( admin_url( '/' ) ) ) ); // 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( 'options-connectors-prerequisites', false, $style_dependencies, $asset['version'] ); // Build dependencies for options-connectors module $boot_dependencies = array( array( 'import' => 'static', 'id' => '@wordpress/boot', ), ); // Add init modules as static dependencies // No init modules configured // 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( 'options-connectors', $build_constants['build_url'] . 'pages/options-connectors/loader.js', $boot_dependencies ); // Enqueue the boot scripts and styles wp_enqueue_script( 'options-connectors-prerequisites' ); wp_enqueue_script_module( 'options-connectors' ); wp_enqueue_style( 'options-connectors-prerequisites' ); } // Output the HTML ?> <!DOCTYPE html> <html <?php language_attributes(); ?>> <head> <meta charset="<?php bloginfo( 'charset' ); ?>"> <meta name="viewport" content="width=device-width, initial-scale=1"> <title><?php echo esc_html( get_admin_page_title() ); ?></title> <style> html { background: #f1f1f1; color: #444; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif; font-size: 13px; line-height: 1.4em; } body { margin: 0; } #wpadminbar { display: none; } </style> <?php global $hook_suffix; // phpcs:ignore WordPress.WP.GlobalVariablesOverride.Prohibited $hook_suffix = 'options-connectors'; // BEGIN see wp-admin/admin-header.php print_admin_styles(); print_head_scripts(); /** * Fires in head section for a specific admin page. * * @since 2.1.0 */ do_action( "admin_head-{$hook_suffix}" ); // phpcs:ignore WordPress.NamingConventions.ValidHookName.UseUnderscores /** * Fires in head section for all admin pages. * * @since 2.1.0 */ do_action( 'admin_head' ); // END see wp-admin/admin-header.php ?> </head> <body class="options-connectors"> <div id="options-connectors-app" style="height: 100vh; box-sizing: border-box;"></div> <?php // BEGIN see wp-admin/admin-footer.php /** * Prints scripts or data before the default footer scripts. * * @since 1.2.0 */ do_action( 'admin_footer', '' ); // Print import map first so it's available for inline scripts wp_script_modules()->print_import_map(); print_footer_scripts(); wp_script_modules()->print_enqueued_script_modules(); wp_script_modules()->print_script_module_preloads(); wp_script_modules()->print_script_module_data(); /** * Prints scripts or data after the default footer scripts. * * @since 2.8.0 */ do_action( "admin_footer-{$hook_suffix}" ); // phpcs:ignore WordPress.NamingConventions.ValidHookName.UseUnderscores // END see wp-admin/admin-footer.php ?> </body> </html> <?php exit; } /** * Intercept admin_init to render the page early. * This bypasses the default WordPress admin template. */ function wp_options_connectors_intercept_render() { // phpcs:ignore WordPress.Security.NonceVerification.Recommended if ( isset( $_GET['page'] ) && 'options-connectors' === $_GET['page'] ) { wp_options_connectors_render_page(); exit; } } // Hook the interceptor to admin_init add_action( 'admin_init', 'wp_options_connectors_intercept_render' );
| ver. 1.4 |
Github
|
.
| PHP 8.3.31 | Generation time: 0.06 |
proxy
|
phpinfo
|
Settings