X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;ds=sidebyside;f=include%2Fnav.php;h=b290a8da23ddeb0e7b24f58fccdc68a0b1003ae4;hb=d284f8017cefb79571fe51c4ae3f85b9b4e517c9;hp=2e59ad2ac465be0eb8d108265d2cb8f8f82bf2ac;hpb=8f83c4ab6408dd3fa789304ce918205e688be4a8;p=friendica.git diff --git a/include/nav.php b/include/nav.php index 2e59ad2ac4..b290a8da23 100644 --- a/include/nav.php +++ b/include/nav.php @@ -1,42 +1,185 @@ page['nav'] .= '' . t('Logout') . "\r\n"; -} +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', 'title') + $nav = Array(); + + /** + * Display login or logout + */ + + $nav['usermenu']=array(); + $userinfo = null; + + if(local_user()) { + $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('events/', t('Events'), "", t('Your events')); + $nav['usermenu'][] = Array('notes/', t('Personal notes'), "", t('Your personal photos')); + + // user info + $r = q("SELECT micro FROM contact WHERE uid=%d AND self=1", intval($a->user['uid'])); + $userinfo = array( + 'icon' => (count($r) ? $r[0]['micro']: $a->get_baseurl()."/images/default-profile-mm.jpg"), + 'name' => $a->user['username'], + ); + + } + else { + $nav['login'] = Array('login',t('Login'), ($a->module == 'login'?'selected':''), t('Sign in')); + } + + + /** + * "Home" should also take you home from an authenticated remote profile connection + */ - $a->page['nav'] .= " \r\n\r\n"; + /** + * Admin page + */ + if (is_site_admin()){ + $nav['admin'] = array('admin/', t('Admin'), "", t('Site setup and configuration')); + } + + + /** + * + * Provide a banner/logo/whatever + * + */ + + $banner = get_config('system','banner'); + + if($banner === false) + $banner .= 'Friendika'; + + + $tpl = get_markup_template('nav.tpl'); + + $a->page['nav'] .= replace_macros($tpl, array( + '$langselector' => lang_selector(), + '$sitelocation' => $sitelocation, + '$nav' => $nav, + '$banner' => $banner, + '$emptynotifications' => t('Nothing new here'), + '$userinfo' => $userinfo, + '$sel' => $a->nav_sel, + '$apps' => $a->apps, + )); + + 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, + 'notifications' => null, + 'messages' => null, + 'directyory' => null, + 'settings' => null, + 'contacts' => null, + ); + $a->nav_sel[$item] = 'selected'; +}