bp_core_create_subnav_link( array|string $args = '', string $component = 'members' )
Add a subnav link to the BuddyPress navigation.
Description
Parameters
- $args
-
(Optional) Array describing the new subnav item.
- 'name'
(string) Display name for the subnav item. - 'slug'
(string) Unique URL slug for the subnav item. - 'parent_slug'
(string) Slug of the top-level nav item under which the new subnav item should be added. - 'parent_url'
(string) URL of the parent nav item. - 'item_css_id'
(bool|string) Optional. 'id' attribute for the nav item. Default: the value of $slug. - 'user_has_access'
(bool) Optional. True if the logged-in user has access to the subnav item, otherwise false. Can be set dynamically when registering the subnav; eg, use bp_is_my_profile() to restrict access to profile owners only. Default: true. - 'site_admin_only'
(bool) Optional. Whether the nav item should be visible only to site admins (those with the 'bp_moderate' cap). Default: false. - 'position'
(int) Optional. Numerical index specifying where the item should appear in the subnav array. Default: 90. - 'screen_function'
(callable) The callback function that will run when the nav item is clicked. - 'link'
(string) Optional. The URL that the subnav item should point to. Defaults to a value generated from the $parent_url + $slug. - 'show_in_admin_bar'
(bool) Optional. Whether the nav item should be added into the group's "Edit" Admin Bar menu for group admins. Default: false.
Default value: ''
- 'name'
- $component
-
(Optional) The component the navigation is attached to. Defaults to 'members'.
Default value: 'members'
Return
(false|array) Returns false on failure, new BP_Core_Nav_Item instance on success.
Source
File: bp-core/bp-core-buddybar.php
485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 | function bp_core_create_subnav_link( $args = '' , $component = 'members' ) { $bp = buddypress(); $r = wp_parse_args( $args , array ( 'name' => false, // Display name for the nav item. 'slug' => false, // URL slug for the nav item. 'parent_slug' => false, // URL slug of the parent nav item. 'parent_url' => false, // URL of the parent item. 'item_css_id' => false, // The CSS ID to apply to the HTML of the nav item. 'user_has_access' => true, // Can the logged in user see this nav item? 'no_access_url' => '' , 'site_admin_only' => false, // Can only site admins see this nav item? 'position' => 90, // Index of where this nav item should be positioned. 'screen_function' => false, // The name of the function to run when clicked. 'link' => '' , // The link for the subnav item; optional, not usually required. 'show_in_admin_bar' => false, // Show the Manage link in the current group's "Edit" Admin Bar menu. ) ); // If we don't have the required info we need, don't create this subnav item. if ( empty ( $r [ 'name' ] ) || empty ( $r [ 'slug' ] ) || empty ( $r [ 'parent_slug' ] ) || empty ( $r [ 'parent_url' ] ) || empty ( $r [ 'screen_function' ] ) ) return false; // Link was not forced, so create one. if ( empty ( $r [ 'link' ] ) ) { $r [ 'link' ] = trailingslashit( $r [ 'parent_url' ] . $r [ 'slug' ] ); $parent_nav = $bp ->{ $component }->nav->get_primary( array ( 'slug' => $r [ 'parent_slug' ] ), false ); // If this sub item is the default for its parent, skip the slug. if ( $parent_nav ) { $parent_nav_item = reset( $parent_nav ); if ( ! empty ( $parent_nav_item ->default_subnav_slug ) && $r [ 'slug' ] === $parent_nav_item ->default_subnav_slug ) { $r [ 'link' ] = trailingslashit( $r [ 'parent_url' ] ); } } } // If this is for site admins only and the user is not one, don't create the subnav item. if ( ! empty ( $r [ 'site_admin_only' ] ) && ! bp_current_user_can( 'bp_moderate' ) ) { return false; } if ( empty ( $r [ 'item_css_id' ] ) ) { $r [ 'item_css_id' ] = $r [ 'slug' ]; } $subnav_item = array ( 'name' => $r [ 'name' ], 'link' => $r [ 'link' ], 'slug' => $r [ 'slug' ], 'parent_slug' => $r [ 'parent_slug' ], 'css_id' => $r [ 'item_css_id' ], 'position' => $r [ 'position' ], 'user_has_access' => $r [ 'user_has_access' ], 'no_access_url' => $r [ 'no_access_url' ], 'screen_function' => & $r [ 'screen_function' ], 'show_in_admin_bar' => (bool) $r [ 'show_in_admin_bar' ], ); buddypress()->{ $component }->nav->add_nav( $subnav_item ); return $subnav_item ; } |
Changelog
Version | Description |
---|---|
BuddyPress 2.4.0 | Introduced. |
Questions?
We're always happy to help with code or other questions you might have! Search our developer docs, contact support, or connect with our sales team.