diff --git a/libs/Template.php b/libs/Template.php index 3bb7c59..de22fdd 100644 --- a/libs/Template.php +++ b/libs/Template.php @@ -21,17 +21,13 @@ class Template public function render($name, array $data = array()) { - $this->engine->addData([ 'index' => utf8_encode($data['params']['base_page'] . $data['params']['index']->value), 'base_url' => $data['params']['base_url'], 'base_page' => $data['params']['base_page'], 'page' => $data['page'], 'params' => $data['params'], - //'homepage' => $data['params']['homepage'], - //'project_title' => utf8_encode($data['params']['title']), 'tree' => $data['params']['tree'], - //'entry_page' => $data['page']['entry_page'], ]); return $this->engine->render($name, $data); @@ -40,10 +36,8 @@ class Template protected function registerFunctions() { $this->engine->registerFunction('get_navigation', function($tree, $path, $current_url, $base_page, $mode) { - $nav = '
'; - return $nav; + $nav = $this->buildNavigation($tree, $path, $current_url, $base_page, $mode); + return $this->renderNavigation($nav); }); $this->engine->registerFunction('get_breadcrumb_title', function($page, $base_page) { @@ -64,42 +58,68 @@ class Template }); } + private function renderNavigation($entries) + { + $nav = ""; + foreach ($entries as $entry) { + + if (array_key_exists('children', $entry)) { + if (array_key_exists('href', $entry)) { + $link = '' . $entry['title'] . ''; + } else { + $link = '' . $entry['title'] . ''; + } + + $link .= $this->renderNavigation($entry['children']); + } else { + $link = '' . $entry['title'] . ''; + } + + $nav .= "