]> git.mxchange.org Git - friendica.git/blobdiff - include/nav.php
Merge remote-tracking branch 'upstream/develop' into 1509-new-feed-import
[friendica.git] / include / nav.php
index 602385c32c448d622c1e0573ba48f4350cba0790..935d08f524536b6272951cf643842415f071e4b5 100644 (file)
@@ -17,6 +17,35 @@ function nav(&$a) {
 
        $a->page['nav'] .= '<div id="panel" style="display: none;"></div>' ;
 
+       $nav_info = nav_info($a);
+
+       /**
+        * Build the page
+        */
+
+       $tpl = get_markup_template('nav.tpl');
+
+       $a->page['nav'] .= replace_macros($tpl, array(
+               '$baseurl' => $a->get_baseurl(),
+               '$langselector' => lang_selector(),
+               '$sitelocation' => $nav_info['sitelocation'],
+               '$nav' => $nav_info['nav'],
+               '$banner' =>  $nav_info['banner'],
+               '$emptynotifications' => t('Nothing new here'),
+               '$userinfo' => $nav_info['userinfo'],
+               '$sel' =>       $a->nav_sel,
+               '$apps' => $a->apps,
+               '$clear_notifs' => t('Clear notifications')
+       ));
+
+       call_hooks('page_header', $a->page['nav']);
+}
+
+
+function nav_info(&$a) {
+
+       $ssl_state = ((local_user()) ? true : false);
+
        /**
         *
         * Our network is distributed, and as you visit friends some of the 
@@ -26,22 +55,41 @@ function nav(&$a) {
         */
 
        $myident = ((is_array($a->user) && isset($a->user['nickname'])) ? $a->user['nickname'] . '@' : '');
-               
-       $sitelocation = $myident . substr($a->get_baseurl(),strpos($a->get_baseurl(),'//') + 2 );
+
+       $sitelocation = $myident . substr($a->get_baseurl($ssl_state),strpos($a->get_baseurl($ssl_state),'//') + 2 );
 
 
-       // nav links: array of array('href', 'text', 'extra css classes')
+       // nav links: array of array('href', 'text', 'extra css classes', 'title')
        $nav = Array();
 
        /**
         * Display login or logout
         */
 
+       $nav['usermenu']=array();
+       $userinfo = null;
+
        if(local_user()) {
-               $nav['logout'] = Array('logout',t('Logout'), "");
+               $nav['logout'] = Array('logout',t('Logout'), "", t('End this session'));
+
+               // user menu
+               $nav['usermenu'][] = Array('profile/' . $a->user['nickname'], t('Status'), "", t('Your posts and conversations'));
+               $nav['usermenu'][] = Array('profile/' . $a->user['nickname']. '?tab=profile', t('Profile'), "", t('Your profile page'));
+               $nav['usermenu'][] = Array('photos/' . $a->user['nickname'], t('Photos'), "", t('Your photos'));
+               $nav['usermenu'][] = Array('videos/' . $a->user['nickname'], t('Videos'), "", t('Your videos'));
+               $nav['usermenu'][] = Array('events/', t('Events'), "", t('Your events'));
+               $nav['usermenu'][] = Array('notes/', t('Personal notes'), "", t('Your personal notes'));
+
+               // user info
+               $r = q("SELECT micro FROM contact WHERE uid=%d AND self=1", intval($a->user['uid']));
+               $userinfo = array(
+                       'icon' => (count($r) ? $a->get_cached_avatar_image($r[0]['micro']) : $a->get_baseurl($ssl_state)."/images/person-48.jpg"),
+                       'name' => $a->user['username'],
+               );
+
        }
        else {
-               $nav['login'] = Array('login',t('Login'), ($a->module == 'login'?'nav-selected':''));
+               $nav['login'] = Array('login',t('Login'), ($a->module == 'login'?'selected':''), t('Sign in'));
        }
 
 
@@ -49,36 +97,50 @@ function nav(&$a) {
         * "Home" should also take you home from an authenticated remote profile connection
         */
 
-       $homelink = ((x($_SESSION,'visitor_home')) ? $_SESSION['visitor_home'] : '');
+       $homelink = get_my_url();
+       if(! $homelink)
+               $homelink = ((x($_SESSION,'visitor_home')) ? $_SESSION['visitor_home'] : '');
 
-       if(($a->module != 'home') && (! (local_user()))) 
-               $nav['home'] = array($homelink, t('Home'), "");
+       if(($a->module != 'home') && (! (local_user())))
+               $nav['home'] = array($homelink, t('Home'), "", t('Home Page'));
 
 
        if(($a->config['register_policy'] == REGISTER_OPEN) && (! local_user()) && (! remote_user()))
-               $nav['register'] = array('register',t('Register'), "");
+               $nav['register'] = array('register',t('Register'), "", t('Create an account'));
 
-       $help_url = $a->get_baseurl() . '/help';
+       $help_url = $a->get_baseurl($ssl_state) . '/help';
 
-       if(! get_config('system','hide-help'))
-               $nav['help'] = array($help_url, t('Help'), "");
+       if(! get_config('system','hide_help'))
+               $nav['help'] = array($help_url, t('Help'), "", t('Help and documentation'));
 
+       if(count($a->apps)>0)
+               $nav['apps'] = array('apps', t('Apps'), "", t('Addon applications, utilities, games'));
 
-       if(strlen($a->apps)) {
-               $nav['apps'] = array('apps', t('Apps'), "");
-       }
+       $nav['search'] = array('search', t('Search'), "", t('Search site content'));
+
+       $nav['searchoption'] = array(
+                                       t("Full Text"),
+                                       t("Tags"),
+                                       t("Contacts"));
 
-       $nav['search'] = array('search', t('Search'), "");
+       if (get_config('system','poco_local_search'))
+               $nav['searchoption'][] = t("Forums");
 
        $gdirpath = 'directory';
 
        if(strlen(get_config('system','singleuser'))) {
-               $gdir = dirname(get_config('system','directory_submit_url'));
+               $gdir = get_config('system','directory');
                if(strlen($gdir))
                        $gdirpath = $gdir;
        }
+       elseif(get_config('system','community_page_style') == CP_USERS_ON_SERVER)
+               $nav['community'] = array('community', t('Community'), "", t('Conversations on this site'));
+       elseif(get_config('system','community_page_style') == CP_GLOBAL_COMMUNITY)
+               $nav['community'] = array('community', t('Community'), "", t('Conversations on the network'));
+
+       $nav['directory'] = array($gdirpath, t('Directory'), "", t('People directory'));
 
-       $nav['directory'] = array($gdirpath, t('Directory'), ""); 
+       $nav['about'] = Array('friendica', t('Information'), "", t('Information about this friendica instance'));
 
        /**
         *
@@ -88,30 +150,52 @@ function nav(&$a) {
 
        if(local_user()) {
 
-               $nav['network'] = array('network', t('Network'), "");
+               $nav['network'] = array('network', t('Network'), "", t('Conversations from your friends'));
+               $nav['net_reset'] = array('network/0?f=&order=comment&nets=all', t('Network Reset'), "", t('Load Network page with no filters'));
 
-               $nav['home'] = array('profile/' . $a->user['nickname'], t('Home'), "");
+               $nav['home'] = array('profile/' . $a->user['nickname'], t('Home'), "", t('Your posts and conversations'));
 
+               if(in_array($_SESSION['page_flags'], array(PAGE_NORMAL, PAGE_SOAPBOX, PAGE_FREELOVE, PAGE_PRVGROUP))) {
+                       /* only show friend requests for normal pages. Other page types have automatic friendship. */
+                       if(in_array($_SESSION['page_flags'], array(PAGE_NORMAL, PAGE_SOAPBOX, PAGE_PRVGROUP)))
+                               $nav['introductions'] = array('notifications/intros',   t('Introductions'), "", t('Friend Requests'));
 
-               /* 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'), "");
+                       if(in_array($_SESSION['page_flags'], array(PAGE_NORMAL, PAGE_SOAPBOX, PAGE_FREELOVE))) {
+                               $nav['notifications'] = array('notifications',  t('Notifications'), "", t('Notifications'));
+                               $nav['notifications']['all']=array('notifications/system', t('See all notifications'), "", "");
+                               $nav['notifications']['mark'] = array('', t('Mark all system notifications seen'), '','');
+                       }
                }
 
-               $nav['messages'] = array('message', t('Messages'), "");
-               
+               $nav['messages'] = array('message', t('Messages'), "", t('Private mail'));
+               $nav['messages']['inbox'] = array('message', t('Inbox'), "", t('Inbox'));
+               $nav['messages']['outbox']= array('message/sent', t('Outbox'), "", t('Outbox'));
+               $nav['messages']['new'] = array('message/new', t('New Message'), "", t('New Message'));
+
                if(is_array($a->identities) && count($a->identities) > 1) {
-                       $nav['manage'] = array('manage', t('Manage'), "");
+                       $nav['manage'] = array('manage', t('Manage'), "", t('Manage other pages'));
                }
 
-               $nav['settings'] = array('settings', t('Settings'),"");
-               $nav['profiles'] = array('profiles', t('Profiles'),"");
-               $nav['contacts'] = array('contacts', t('Contacts'),"");
+               $nav['delegations'] = Array('delegate', t('Delegations'), "", t('Delegate Page Management'));
 
-               
+               $nav['settings'] = array('settings', t('Settings'),"", t('Account settings'));
+
+               if(feature_enabled(local_user(),'multi_profiles'))
+                       $nav['profiles'] = array('profiles', t('Profiles'),"", t('Manage/Edit Profiles'));
+
+               $nav['contacts'] = array('contacts', t('Contacts'),"", t('Manage/edit friends and contacts'));
        }
 
+       /**
+        * Admin page
+        */
+        if (is_site_admin()){
+                $nav['admin'] = array('admin/', t('Admin'), "", t('Site setup and configuration'));
+        }
+
+
+        $nav['navigation'] = array('navigation/', t('Navigation'), "", t('Site map'));
+
 
        /**
         *
@@ -122,18 +206,39 @@ function nav(&$a) {
        $banner = get_config('system','banner');
 
        if($banner === false) 
-               $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>';
+               $banner .= '<a href="http://friendica.com"><img id="logo-img" src="images/friendica-32.png" alt="logo" /></a><span id="logo-text"><a href="http://friendica.com">Friendica</a></span>';
 
+       call_hooks('nav_info', $nav);
 
-       $tpl = file_get_contents('view/nav.tpl');
 
-       $a->page['nav'] .= replace_macros($tpl, array(
-               '$langselector' => lang_selector(),
-               '$sitelocation' => $sitelocation,
-               '$nav' => $nav,
-               '$banner' =>  $banner,
-       ));
+       return array(
+               'sitelocation' => $sitelocation,
+               'nav' => $nav,
+               'banner' => $banner,
+               'userinfo' => $userinfo,
+       );
+}
 
-       call_hooks('page_header', $a->page['nav']);
 
+/*
+ * Set a menu item in navbar as selected
+ * 
+ */
+function nav_set_selected($item){
+       $a = get_app();
+    $a->nav_sel = array(
+               'community'     => null,
+               'network'               => null,
+               'home'                  => null,
+               'profiles'              => null,
+               'introductions' => null,
+               'notifications' => null,
+               'messages'              => null,
+               'directory'         => null,
+               'settings'              => null,
+               'contacts'              => null,
+               'manage'        => null,
+               'register'      => null,
+       );
+       $a->nav_sel[$item] = 'selected';
 }