X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=include%2Fnav.php;h=d8f7621cc8ed30655f0bd3644986f33b5ebd3f4b;hb=a27b7fb28d151c00eef8319cdf876896d36df8b0;hp=dd2655e84a1f55f75325d28d68af781e865a9109;hpb=1131b2ea53c97b832beee8e6a676ff6ec4c0f1ff;p=friendica.git diff --git a/include/nav.php b/include/nav.php index dd2655e84a..d8f7621cc8 100644 --- a/include/nav.php +++ b/include/nav.php @@ -1,62 +1,139 @@ page,'nav')) +function nav(&$a) { + + /** + * + * Build page header and site navigation bars + * + */ + + if(!(x($a->page,'nav'))) $a->page['nav'] = ''; + /** + * Placeholder div for popup panel + */ + $a->page['nav'] .= '' ; + /** + * + * Our network is distributed, and as you visit friends some of the + * sites look exactly the same - it isn't always easy to know where you are. + * Display the current site location as a navigation aid. + * + */ + + $myident = ((is_array($a->user) && isset($a->user['nickname'])) ? $a->user['nickname'] . '@' : ''); + + $sitelocation = $myident . substr($a->get_baseurl(),strpos($a->get_baseurl(),'//') + 2 ); + + + // nav links: array of array('href', 'text', 'extra css classes') + $nav = Array(); + + /** + * Display login or logout + */ + if(local_user()) { - $a->page['nav'] .= '' . t('Logout') . "\r\n"; + $nav['logout'] = Array('logout',t('Logout'), ""); } else { - $a->page['nav'] .= '' . t('Login') . "\r\n"; + $nav['login'] = Array('login',t('Login'), ($a->module == 'login'?'nav-selected':'')); } - $a->page['nav'] .= "\r\n"; + + /** + * "Home" should also take you home from an authenticated remote profile connection + */ + + $homelink = ((x($_SESSION,'visitor_home')) ? $_SESSION['visitor_home'] : ''); if(($a->module != 'home') && (! (local_user()))) - $a->page['nav'] .= '' . t('Home') . "\r\n"; + $nav['home'] = array($homelink, t('Home'), ""); + + if(($a->config['register_policy'] == REGISTER_OPEN) && (! local_user()) && (! remote_user())) - $a->page['nav'] .= '' - . t('Register') . "\r\n"; + $nav['register'] = array('register',t('Register'), ""); - $a->page['nav'] .= '' . t('Search') . "\r\n"; - $a->page['nav'] .= '' . t('Directory') . "\r\n"; + $help_url = $a->get_baseurl() . '/help'; - if(x($_SESSION,'uid')) { + if(! get_config('system','hide-help')) + $nav['help'] = array($help_url, t('Help'), ""); - $a->page['nav'] .= '' . t('Network') - . '' . "\r\n"; - $a->page['nav'] .= '' - . t('Home') . '' . "\r\n"; + if(strlen($a->apps)) { + $nav['apps'] = array('apps', t('Apps'), ""); + } - // only show friend requests for normal pages. Other page types have automatic friendship. + $nav['search'] = array('search', t('Search'), ""); - if($_SESSION['page_flags'] == PAGE_NORMAL) { - $a->page['nav'] .= '' . t('Notifications') - . '' . "\r\n"; - } + $gdirpath = 'directory'; - $a->page['nav'] .= '' . t('Messages') - . '' . "\r\n"; - + if(strlen(get_config('system','singleuser'))) { + $gdir = dirname(get_config('system','directory_submit_url')); + if(strlen($gdir)) + $gdirpath = $gdir; + } + + $nav['directory'] = array($gdirpath, t('Directory'), ""); + + /** + * + * The following nav links are only show to logged in users + * + */ + + if(local_user()) { - $a->page['nav'] .= '' . t('Settings') . "\r\n"; + $nav['network'] = array('network', t('Network'), ""); - $a->page['nav'] .= '' . t('Profiles') . "\r\n"; + $nav['home'] = array('profile/' . $a->user['nickname'], t('Home'), ""); - $a->page['nav'] .= '' . t('Contacts') . "\r\n"; + /* only show friend requests for normal pages. Other page types have automatic friendship. */ + + if($_SESSION['page_flags'] == PAGE_NORMAL) { + $nav['notifications'] = array('notifications', t('Notifications'), ""); + } + + $nav['messages'] = array('message', t('Messages'), ""); + + if(is_array($a->identities) && count($a->identities) > 1) { + $nav['manage'] = array('manage', t('Manage'), ""); + } + + $nav['settings'] = array('settings', t('Settings'),""); + $nav['profiles'] = array('profiles', t('Profiles'),""); + $nav['contacts'] = array('contacts', t('Contacts'),""); } - $a->page['nav'] .= "\r\n\r\n"; + + /** + * + * Provide a banner/logo/whatever + * + */ $banner = get_config('system','banner'); if($banner === false) - $banner .= 'logoFriendika'; + $banner .= 'logoFriendika'; + + + $tpl = get_markup_template('nav.tpl'); + + $a->page['nav'] .= replace_macros($tpl, array( + '$langselector' => lang_selector(), + '$sitelocation' => $sitelocation, + '$nav' => $nav, + '$banner' => $banner, + )); + + call_hooks('page_header', $a->page['nav']); - $a->page['nav'] .= ''; +}