vb.org Archive

vb.org Archive (https://vborg.vbsupport.ru/index.php)
-   vBulletin 3 Articles (https://vborg.vbsupport.ru/forumdisplay.php?f=187)
-   -   [How-To] Add entries to AdminCP Navigation Menu (https://vborg.vbsupport.ru/showthread.php?t=82698)

Andreas 06-07-2005 10:00 PM

[How-To] Add entries to AdminCP Navigation Menu
 
The AdminCP Navigation is now controlled through XML files.
To add custom entries, you must create a new file cpnav_yourhack.xml and place it in directory includes/xml.

This XML-File constist of 6 important tags:
  • <navgroups>
    This indicates that this is a XML File containing navgroups.
    It has one parameter product that should be set to your product identifier or vbulletin if it does not belong to any product.
  • <navgroup>
    This is the container for one Settings-Group, like Styles & Templates, vBulletin Options, etc.
    It has three parameters: phrase/text, permissions and hr.
    If you are using phrases, phrase must contain the variable name, if you are using hardcoded text then text must contain the label.
    Parameter permissions (optional) can be used to check an administrator permission, like canadminoptions.
    Parameter hr (optional) can be used to put a spacer below this navgroup.
  • <navoption>
    This is one Menu-Entry.
  • <phrase> or <text>
    This must contain the varname or hardcoded text for the menuetry.
  • <link>
    Tag link must contain the URL.
    You can use {$vbulletin->config[Misc][modcpdir]} to point to the ModCP directory here, no matter how it is actually called

Example
HTML Code:

<?xml version="1.0" encoding="ISO-8859-1"?>
<navgroups product="vbulletin">
        <navgroup phrase="demohack_settings" hr="true">
                <navoption>
                        <phrase>demohack_foo</phrase>
                        <link>demohack.php?do=foo</link>
                </navoption>
                <navoption>
                        <phrase>demohack_modcp</phrase>
                        <link>../{$vbulletin->config[Misc][modcpdir]}/foobar.php</link>
                </navoption>
        </navgroup>
        <navgroup text="Demohack Settings">
                <navoption>
                        <text>Demohack Foo</text>
                        <link>demohack.php?do=foo</link>
                </navoption>
                <navoption>
                        <text>Demohack ModCP</text>
                        <link>../{$vbulletin->config[Misc][modcpdir]}/foobar.php</link>
                </navoption>
        </navgroup>
</navgroups>

Update for Beta 3
With Beta 3 a new parameter displayorder has been introduced. This parameter is valid for Tags navgroup and navoption.
This way it is possible to control in which order the Navgroups and Links will be displayed, and you can also add custom Links to existing Navgroups.
To do so, your navgroup must have them same displayorder and Phrase Varname as the existing group:

HTML Code:

<?xml version="1.0" encoding="ISO-8859-1"?>
<navgroups product="vbulletin">
        <navgroup phrase="forums_and_moderators" displayorder="60">
                <navoption displayorder="1">
                        <text>Top-Link Forums &amp; Moderators</text>
                        <link>demohack.php?do=foo</link>
                </navoption>
        </navgroup>
</navgroups>

Then Top-Link Forums & Moderators will be the first link in Navgroup Forums & Moderators (Displayorder: 60).

To find out the Displayorder for existing groups, take a look at cpnav_vbulletin.xml.

This How-To is (C) 2005 by KirbyDE and you are not allowed to redistribute it in any way without my explicit consent.

Creative Suite 06-13-2005 08:51 PM

Thanks..

rjordan 06-13-2005 09:20 PM

So, in doing this, does this take care of the issues with no hooks being included in the AdminCP navigation menu? I know that it does not take care of not having hooks in the individual modules, just refering to the main selection menu.

feldon23 06-15-2005 03:10 AM

Quote:

Originally Posted by rjordan
So, in doing this, does this take care of the issues with no hooks being included in the AdminCP navigation menu? I know that it does not take care of not having hooks in the individual modules, just refering to the main selection menu.

Site administrators upload the XML file prepared by the hack author and presto, new items appear in the AdminCP.

The bummer here is that hack authors can't specify which existing group to add a menu item under (for instance, adding a new PM-related funtion or feature under the existing PM AdminCP tree) nor can hack authors specify a group that their hack should appear above or below. A hack author might want to add "Clans" right below Usergroups or Promotions.

I'm guessing that new menus created with this XML technique appear way at the bottom?

Of course to add all the functionality I am talking about, the admincp XML file would need to be cached in a "merged" state.

stlmike 06-22-2005 06:13 AM

Thanks KirbyDE in how to do this...

Chris M 06-22-2005 11:12 AM

Quote:

Originally Posted by feldon23
Site administrators upload the XML file prepared by the hack author and presto, new items appear in the AdminCP.

The bummer here is that hack authors can't specify which existing group to add a menu item under (for instance, adding a new PM-related funtion or feature under the existing PM AdminCP tree) nor can hack authors specify a group that their hack should appear above or below. A hack author might want to add "Clans" right below Usergroups or Promotions.

I'm guessing that new menus created with this XML technique appear way at the bottom?

Of course to add all the functionality I am talking about, the admincp XML file would need to be cached in a "merged" state.

They seem to appear at either the top or bottom, quite randomly...

It is bizzarre to be sure...

I hope the Devs listen to the requests and create some kind of display order feature for the CP Nav ;)

Satan

Andreas 06-22-2005 11:16 AM

Quote:

Originally Posted by hellsatan
They seem to appear at either the top or bottom, quite randomly...

They appear in the sort-order that is provided by the OS when you list cpnav_*.xml Files.

Chris M 06-22-2005 11:18 AM

Aha - Glad someone knows ;)

Satan

Dream 06-27-2005 07:12 PM

so kirby what changed in vb 3.5 beta 3? are you going to update this

Andreas 06-27-2005 07:24 PM

Updated :)


All times are GMT. The time now is 09:41 PM.

Powered by vBulletin® Version 3.8.12 by vBS
Copyright ©2000 - 2024, vBulletin Solutions Inc.

X vBulletin 3.8.12 by vBS Debug Information
  • Page Generation 0.01309 seconds
  • Memory Usage 1,752KB
  • Queries Executed 10 (?)
More Information
Template Usage:
  • (1)ad_footer_end
  • (1)ad_footer_start
  • (1)ad_header_end
  • (1)ad_header_logo
  • (1)ad_navbar_below
  • (2)bbcode_html_printable
  • (3)bbcode_quote_printable
  • (1)footer
  • (1)gobutton
  • (1)header
  • (1)headinclude
  • (6)option
  • (1)pagenav
  • (1)pagenav_curpage
  • (2)pagenav_pagelink
  • (1)post_thanks_navbar_search
  • (1)printthread
  • (10)printthreadbit
  • (1)spacer_close
  • (1)spacer_open 

Phrase Groups Available:
  • global
  • postbit
  • showthread
Included Files:
  • ./printthread.php
  • ./global.php
  • ./includes/init.php
  • ./includes/class_core.php
  • ./includes/config.php
  • ./includes/functions.php
  • ./includes/class_hook.php
  • ./includes/modsystem_functions.php
  • ./includes/class_bbcode_alt.php
  • ./includes/class_bbcode.php
  • ./includes/functions_bigthree.php 

Hooks Called:
  • init_startup
  • init_startup_session_setup_start
  • init_startup_session_setup_complete
  • cache_permissions
  • fetch_threadinfo_query
  • fetch_threadinfo
  • fetch_foruminfo
  • style_fetch
  • cache_templates
  • global_start
  • parse_templates
  • global_setup_complete
  • printthread_start
  • pagenav_page
  • pagenav_complete
  • bbcode_fetch_tags
  • bbcode_create
  • bbcode_parse_start
  • bbcode_parse_complete_precache
  • bbcode_parse_complete
  • printthread_post
  • printthread_complete