helix/admin/menu-customization.php

145 lines
4.2 KiB
PHP
Raw Normal View History

<?php
/**
2025-08-10 00:09:35 +05:30
* Customizes the WordPress admin menu for Helix.
* This removes unwanted menu items and keeps only the ones you want
2025-08-10 00:09:35 +05:30
*
* @package Helix
*/
2025-08-10 00:09:35 +05:30
add_action(
'current_screen',
function ( $current_screen ) {
if ( ! $current_screen || 'toplevel_page_helix' !== $current_screen->id ) {
return;
}
2025-08-10 00:09:35 +05:30
// 1) Remove default WordPress admin menus when viewing Helix.
remove_menu_page( 'index.php' ); // Dashboard.
remove_menu_page( 'edit.php' ); // Posts.
remove_menu_page( 'upload.php' ); // Media.
remove_menu_page( 'edit.php?post_type=page' ); // Pages.
remove_menu_page( 'edit-comments.php' ); // Comments.
remove_menu_page( 'themes.php' ); // Appearance.
remove_menu_page( 'plugins.php' ); // Plugins.
remove_menu_page( 'users.php' ); // Users.
remove_menu_page( 'tools.php' ); // Tools.
remove_menu_page( 'options-general.php' ); // Settings.
// Remove all admin menu separators.
remove_all_admin_menu_separators();
2025-08-10 00:22:24 +05:30
// 2) Add custom Helix menu items.
2025-08-10 00:09:35 +05:30
add_menu_page(
'Helix Posts',
'Posts',
'edit_posts',
'helix-posts',
'helix_posts_callback',
'dashicons-admin-post',
3
);
add_menu_page(
'Helix Users',
'Users',
'list_users',
'helix-users',
'helix_users_callback',
'dashicons-admin-users',
4
);
},
10
);
/**
* Remove all admin menu separators.
*/
function remove_all_admin_menu_separators() {
2025-08-10 00:09:35 +05:30
global $menu;
if ( is_array( $menu ) ) {
foreach ( $menu as $key => $item ) {
// Check if menu item is a separator.
if ( false !== strpos( $item[4], 'wp-menu-separator' ) ) {
unset( $menu[ $key ] );
}
}
}
}
/**
2025-08-10 00:09:35 +05:30
* Add WordPress Admin menu item conditionally.
*/
2025-08-10 00:09:35 +05:30
add_action(
'admin_menu',
function () {
2025-08-10 00:22:24 +05:30
global $pagenow;
// Check if we're going to the Helix page by looking at the sanitized request.
$page_requested = filter_input( INPUT_GET, 'page', FILTER_SANITIZE_URL );
$is_helix_request = ( 'admin.php' === $pagenow && 'helix' === $page_requested );
2025-08-10 00:09:35 +05:30
$use_default_admin = get_option( 'helix_use_default_admin', false );
2025-08-10 00:22:24 +05:30
// Always show the WordPress Admin link when navigating to Helix, or when not in default admin mode.
if ( $is_helix_request || ! $use_default_admin ) {
// If this is a Helix request, ensure we're in Helix mode.
if ( $is_helix_request ) {
update_option( 'helix_use_default_admin', false );
}
// Add a menu item to go back to default WordPress admin.
add_menu_page(
'WordPress Admin', // Page title.
'WordPress Admin', // Menu title.
'read', // Capability.
'wordpress-admin', // Menu slug.
'wordpress_admin_callback', // Callback function.
'dashicons-wordpress', // Icon.
2 // Position (after main Helix menu).
);
}
2025-08-10 00:09:35 +05:30
},
1000
);
2025-08-10 00:09:35 +05:30
/**
* Add custom Helix menu items (only when on Helix page).
*/
/* previous current_screen callbacks combined into the single handler above */
/**
* Callback functions for custom menu items.
*/
function wordpress_admin_callback() {
2025-08-10 00:09:35 +05:30
// Set the option to use default WordPress admin.
update_option( 'helix_use_default_admin', true );
// Show a clean message and let the user navigate naturally.
?>
<div style="text-align: center; padding: 50px; font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;">
<h2> Switched to WordPress Admin</h2>
<p>You can now navigate to any WordPress admin page normally.</p>
<p><a href="<?php echo esc_url( admin_url( 'index.php' ) ); ?>" class="button button-primary">Go to Dashboard</a></p>
<p><a href="<?php echo esc_url( admin_url( 'edit.php' ) ); ?>" class="button">Posts</a>
<a href="<?php echo esc_url( admin_url( 'users.php' ) ); ?>" class="button">Users</a>
<a href="<?php echo esc_url( admin_url( 'options-general.php' ) ); ?>" class="button">Settings</a>
</p>
</div>
<?php
}
2025-08-10 00:09:35 +05:30
/**
* Callback function for Posts menu item.
*/
function helix_posts_callback() {
2025-08-10 00:09:35 +05:30
echo '<div id="helix-posts-root"></div>';
}
2025-08-10 00:09:35 +05:30
/**
* Callback function for Users menu item.
*/
function helix_users_callback() {
2025-08-10 00:09:35 +05:30
echo '<div id="helix-users-root"></div>';
}