From 0afef6b17e622d1fabd0f499ac206e8924278dfb Mon Sep 17 00:00:00 2001 From: Fabio Comuni Date: Thu, 14 Apr 2011 09:22:38 +0200 Subject: arrays and simple conditional blocks in template, template for nav, load templates from themes --- include/nav.php | 61 ++++++++++++++++++++++++++++----------------------------- 1 file changed, 30 insertions(+), 31 deletions(-) (limited to 'include/nav.php') diff --git a/include/nav.php b/include/nav.php index fa4b0a5cc..2ead5c07e 100644 --- a/include/nav.php +++ b/include/nav.php @@ -16,7 +16,6 @@ function nav(&$a) { */ $a->page['nav'] .= '' ; - $a->page['nav'] .= lang_selector(); /** * @@ -28,24 +27,23 @@ function nav(&$a) { $myident = ((is_array($a->user) && isset($a->user['nickname'])) ? $a->user['nickname'] . '@' : ''); - $a->page['nav'] .= '
' . $myident . substr($a->get_baseurl(),strpos($a->get_baseurl(),'//') + 2 ) . '
'; + $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 @@ -54,23 +52,23 @@ function nav(&$a) { $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'), ""); $help_url = $a->get_baseurl() . '/help'; if(! get_config('system','hide-help')) - $a->page['nav'] .= '' . t('Help') . "\r\n"; + $nav['help'] = array($help_url, t('Help'), ""); + if(strlen($a->apps)) { - $a->page['nav'] .= '' . t('Apps') . "\r\n"; + $nav['apps'] = array('apps', t('Apps'), ""); } - $a->page['nav'] .= '' . t('Search') . "\r\n"; + $nav['search'] = array('search', t('Search'), ""); $gdirpath = 'directory'; @@ -80,7 +78,7 @@ function nav(&$a) { $gdirpath = $gdir; } - $a->page['nav'] .= '' . t('Directory') . "\r\n"; + $nav['directory'] = array($gdirpath, t('Directory'), ""); /** * @@ -90,36 +88,30 @@ function nav(&$a) { if(local_user()) { - $a->page['nav'] .= '' . t('Network') - . '' . "\r\n"; + $nav['network'] = array('network', t('Network'), ""); + + $nav['home'] = array('profile/' . $a->user['nickname'], t('Home'), ""); - $a->page['nav'] .= '' - . t('Home') . '' . "\r\n"; /* only show friend requests for normal pages. Other page types have automatic friendship. */ if($_SESSION['page_flags'] == PAGE_NORMAL) { - $a->page['nav'] .= '' . t('Notifications') - . '' . "\r\n"; + $nav['notifications'] = array('notifications', t('Notifications'), ""); } - $a->page['nav'] .= '' . t('Messages') - . '' . "\r\n"; + $nav['messages'] = array('message', t('Messages'), ""); if(is_array($a->identities) && count($a->identities) > 1) { - $a->page['nav'] .= '' . t('Manage') . '' . "\r\n"; + $nav['manage'] = array('manage', t('Manage'), ""); } - $a->page['nav'] .= '' . t('Settings') . "\r\n"; - - $a->page['nav'] .= '' . t('Profiles') . "\r\n"; - - $a->page['nav'] .= '' . t('Contacts') . "\r\n"; + $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"; /** * @@ -133,7 +125,14 @@ function nav(&$a) { $banner .= 'logoFriendika'; - $a->page['nav'] .= ''; + $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']); -- cgit v1.2.3