X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;ds=sidebyside;f=include%2Fnav.php;h=2ead5c07e9465db1167faf36b6ad2aa0557593a2;hb=b3a5fccc9d4af4dc66ae8f0404817690a333c433;hp=2c9d76bb35f9f2de647fe8ab74f294bacd54ac15;hpb=0f47ac282c30c61dbc13e42c4f53b2fc14d65593;p=friendica.git
diff --git a/include/nav.php b/include/nav.php
index 2c9d76bb35..2ead5c07e9 100644
--- a/include/nav.php
+++ b/include/nav.php
@@ -1,58 +1,139 @@
page['nav'] .= '
' ;
+function nav(&$a) {
-if(local_user()) {
- $a->page['nav'] .= '' . t('Logout') . "\r\n";
-}
-else {
- $a->page['nav'] .= '' . t('Login') . "\r\n";
-}
+ /**
+ *
+ * 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();
- $a->page['nav'] .= "\r\n";
+ /**
+ * Display login or logout
+ */
+
+ if(local_user()) {
+ $nav['logout'] = Array('logout',t('Logout'), "");
+ }
+ else {
+ $nav['login'] = Array('login',t('Login'), ($a->module == 'login'?'nav-selected':''));
+ }
+
+
+ /**
+ * "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('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
+ *
+ */
- $a->page['nav'] .= '' . t('Settings') . "\r\n";
+ if(local_user()) {
- $a->page['nav'] .= '' . t('Profiles') . "\r\n";
+ $nav['network'] = array('network', t('Network'), "");
- $a->page['nav'] .= '' . t('Contacts') . "\r\n";
+ $nav['home'] = array('profile/' . $a->user['nickname'], t('Home'), "");
+ /* 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 = 'mistpark';
+ if($banner === false)
+ $banner .= 'Friendika';
+
- $a->page['nav'] .= '' . $banner . '';
+ $tpl = load_view_file('view/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']);
+
+}