From d817875755b37493e381a7d652014ed4a4677d6b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ste=CC=81phane=20Goetz?= Date: Thu, 23 Apr 2015 20:42:44 +0200 Subject: [PATCH] Simplify template --- libs/Template.php | 72 ++++++++++++++++++++++++++++++----------------- 1 file changed, 46 insertions(+), 26 deletions(-) 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 .= "
  • $link
  • "; + } + + return ""; + } + private function buildNavigation($tree, $path, $current_url, $base_page, $mode) { - $nav = ''; + $nav = []; foreach ($tree->value as $node) { $url = $node->getUri(); if ($node instanceof \Todaymade\Daux\Tree\Content) { if ($node->value === 'index') { continue; } - $nav .= '' . $node->getTitle() . ''; + + $nav[] = [ + 'title' => $node->getTitle(), + 'href' => $base_page . $link, + 'class' => ($current_url === $link)? 'active' : '' + ]; } if ($node instanceof \Todaymade\Daux\Tree\Directory) { - $nav .= ' $node->getTitle(), + 'class' => (strpos($current_url, $link) === 0)? 'open' : '', + ]; + if ($mode === \TodayMade\Daux\Daux::STATIC_MODE) { $link .= "/index.html"; } + if ($node->getIndexPage()) { - $nav .= '' . - $node->getTitle() . ''; - } else { - $nav .= '' . $node->getTitle() . ''; + $folder['href'] = $base_page . $link; } - $nav .= ''; + $folder['children'] = $this->buildNavigation($node, $new_path, $current_url, $base_page, $mode); + + $nav[] = $folder; } } return $nav;