WP_REST_Menus_Controller::handle_auto_add( int $menu_id, WP_REST_Request $request ): bool

Updates the menu’s auto add from a REST request.


Parameters

$menu_id int Required
The menu id to update.
$request WP_REST_Request Required
Full details about the request.

Top ↑

Return

bool True if the auto add setting was successfully updated.


Top ↑

Source

File: wp-includes/rest-api/endpoints/class-wp-rest-menus-controller.php. View all references

protected function handle_auto_add( $menu_id, $request ) {
	if ( ! isset( $request['auto_add'] ) ) {
		return true;
	}

	$nav_menu_option = (array) get_option( 'nav_menu_options', array( 'auto_add' => array() ) );

	if ( ! isset( $nav_menu_option['auto_add'] ) ) {
		$nav_menu_option['auto_add'] = array();
	}

	$auto_add = $request['auto_add'];

	$i = array_search( $menu_id, $nav_menu_option['auto_add'], true );

	if ( $auto_add && false === $i ) {
		$nav_menu_option['auto_add'][] = $menu_id;
	} elseif ( ! $auto_add && false !== $i ) {
		array_splice( $nav_menu_option['auto_add'], $i, 1 );
	}

	$update = update_option( 'nav_menu_options', $nav_menu_option );

	/** This action is documented in wp-includes/nav-menu.php */
	do_action( 'wp_update_nav_menu', $menu_id );

	return $update;
}

Top ↑

Hooks



Top ↑

Changelog

Changelog
Version Description
5.9.0 Introduced.

Top ↑

User Contributed Notes

You must log in before being able to contribute a note or feedback.