]> git.mxchange.org Git - friendica.git/blobdiff - include/nav.php
Merge pull request #146 from tobiasd/master
[friendica.git] / include / nav.php
index 430841722b0b3b98e3a4060907fbadc2d4235d43..895c321e6ad39ac893d3dadd3585c1d34377a97f 100644 (file)
@@ -25,24 +25,25 @@ function nav(&$a) {
         *
         */
 
-       $a->page['nav'] .= '<div id="site-location">' . substr($a->get_baseurl(),strpos($a->get_baseurl(),'//') + 2 ) . '</div>';
+       $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', 'title')
+       $nav = Array();
 
        /**
         * Display login or logout
         */
 
        if(local_user()) {
-               $a->page['nav'] .= '<a id="nav-logout-link" class="nav-link" href="logout">' . t('Logout') . "</a>\r\n";
+               $nav['logout'] = Array('logout',t('Logout'), "", t('End this session'));
        }
        else {
-               $a->page['nav'] .= '<a id="nav-login-link" class="nav-login-link';
-               if ($a->module == 'login') { $a->page['nav'] .= ' nav-selected';  }
-
-               $a->page['nav'] .= '" href="login">' . t('Login') . "</a>\r\n";
+               $nav['login'] = Array('login',t('Login'), ($a->module == 'login'?'nav-selected':''), t('Sign in'));
        }
 
-       $a->page['nav'] .= "<span id=\"nav-link-wrapper\" >\r\n";
 
        /**
         * "Home" should also take you home from an authenticated remote profile connection
@@ -51,20 +52,33 @@ function nav(&$a) {
        $homelink = ((x($_SESSION,'visitor_home')) ? $_SESSION['visitor_home'] : '');
 
        if(($a->module != 'home') && (! (local_user()))) 
-               $a->page['nav'] .= '<a id="nav-home-link" class="nav-commlink" href="' . $homelink . '">' . t('Home') . "</a>\r\n";
+               $nav['home'] = array($homelink, t('Home'), "", t('Home Page'));
 
 
        if(($a->config['register_policy'] == REGISTER_OPEN) && (! local_user()) && (! remote_user()))
-               $a->page['nav'] .= '<a id="nav-register-link" class="nav-commlink" href="register" >' 
-                       . t('Register') . "</a>\r\n";
+               $nav['register'] = array('register',t('Register'), "", t('Create an account'));
 
-       if(strlen($a->apps)) {
-               $a->page['nav'] .= '<a id="nav-apps-link" class="nav-link" href="apps">' . t('Apps') . "</a>\r\n";
-       }
+       $help_url = $a->get_baseurl() . '/help';
+
+       if(! get_config('system','hide_help'))
+               $nav['help'] = array($help_url, t('Help'), "", t('Help and documentation'));
 
-       $a->page['nav'] .= '<a id="nav-search-link" class="nav-link" href="search">' . t('Search') . "</a>\r\n";
-       $a->page['nav'] .= '<a id="nav-directory-link" class="nav-link" href="directory">' . t('Directory') . "</a>\r\n";
+       if($a->apps)
+               $nav['apps'] = array('apps', t('Apps'), "", t('Addon applications, utilities, games'));
 
+       $nav['search'] = array('search', t('Search'), "", t('Search site content'));
+
+       $gdirpath = 'directory';
+
+       if(strlen(get_config('system','singleuser'))) {
+               $gdir = dirname(get_config('system','directory_submit_url'));
+               if(strlen($gdir))
+                       $gdirpath = $gdir;
+       }
+       elseif(! get_config('system','no_community_page'))
+               $nav['community'] = array('community', t('Community'), "", t('Conversations on this site'));
+
+       $nav['directory'] = array($gdirpath, t('Directory'), "", t('People directory')); 
 
        /**
         *
@@ -72,35 +86,37 @@ function nav(&$a) {
         *
         */
 
-       if(x($_SESSION,'uid')) {
+       if(local_user()) {
+
+               $nav['network'] = array('network', t('Network'), "", t('Conversations from your friends'));
 
-               $a->page['nav'] .= '<a id="nav-network-link" class="nav-commlink" href="network">' . t('Network') 
-                       . '</a><span id="net-update" class="nav-ajax-left"></span>' . "\r\n";
+               $nav['home'] = array('profile/' . $a->user['nickname'], t('Home'), "", t('Your posts and conversations'));
 
-               $a->page['nav'] .= '<a id="nav-home-link" class="nav-commlink" href="profile/' . $a->user['nickname'] . '">' 
-                       . t('Home') . '</a><span id="home-update" class="nav-ajax-left"></span>' . "\r\n";
 
                /* only show friend requests for normal pages. Other page types have automatic friendship. */
 
                if($_SESSION['page_flags'] == PAGE_NORMAL) {
-                       $a->page['nav'] .= '<a id="nav-notify-link" class="nav-commlink" href="notifications">' . t('Notifications') 
-                               . '</a><span id="notify-update" class="nav-ajax-left"></span>' . "\r\n";
+                       $nav['notifications'] = array('notifications',  t('Notifications'), "", t('Friend requests'));
                }
 
-               $a->page['nav'] .= '<a id="nav-messages-link" class="nav-commlink" href="message">' . t('Messages') 
-                       . '</a><span id="mail-update" class="nav-ajax-left"></span>' . "\r\n";
+               $nav['messages'] = array('message', t('Messages'), "", t('Private mail'));
                
+               if(is_array($a->identities) && count($a->identities) > 1) {
+                       $nav['manage'] = array('manage', t('Manage'), "", t('Manage other pages'));
+               }
 
-               $a->page['nav'] .= '<a id="nav-settings-link" class="nav-link" href="settings">' . t('Settings') . "</a>\r\n";
-
-               $a->page['nav'] .= '<a id="nav-profiles-link" class="nav-link" href="profiles">' . t('Profiles') . "</a>\r\n";
-
-               $a->page['nav'] .= '<a id="nav-contacts-link" class="nav-link" href="contacts">' . t('Contacts') . "</a>\r\n";
-
-               
+               $nav['settings'] = array('settings', t('Settings'),"", t('Account settings'));
+               $nav['profiles'] = array('profiles', t('Profiles'),"", t('Manage/edit profiles'));
+               $nav['contacts'] = array('contacts', t('Contacts'),"", t('Manage/edit friends and contacts'));
        }
 
-       $a->page['nav'] .= "</span>\r\n<span id=\"nav-end\"></span>\r\n";
+       /**
+        * Admin page
+        */
+        if (is_site_admin()){
+                $nav['admin'] = array('admin/', t('Admin'), "", t('Site setup and configuration'));
+        }
+
 
        /**
         *
@@ -111,10 +127,17 @@ function nav(&$a) {
        $banner = get_config('system','banner');
 
        if($banner === false) 
-               $banner .= '<a href="http://friendika.com"><img id="logo-img" src="images/ff-32.jpg" alt="logo" /></a><span id="logo-text"><a href="http://friendika.com">Friendika</a></span>';
+               $banner .= '<a href="http://project.friendika.com"><img id="logo-img" src="images/friendika-32.png" alt="logo" /></a><span id="logo-text"><a href="http://project.friendika.com">Friendika</a></span>';
+
 
+       $tpl = get_markup_template('nav.tpl');
 
-       $a->page['nav'] .= '<span id="banner">' . $banner . '</span>';
+       $a->page['nav'] .= replace_macros($tpl, array(
+               '$langselector' => lang_selector(),
+               '$sitelocation' => $sitelocation,
+               '$nav' => $nav,
+               '$banner' =>  $banner,
+       ));
 
        call_hooks('page_header', $a->page['nav']);