Simplify template
This commit is contained in:
parent
6edd4ce477
commit
d817875755
@ -21,17 +21,13 @@ class Template
|
|||||||
|
|
||||||
public function render($name, array $data = array())
|
public function render($name, array $data = array())
|
||||||
{
|
{
|
||||||
|
|
||||||
$this->engine->addData([
|
$this->engine->addData([
|
||||||
'index' => utf8_encode($data['params']['base_page'] . $data['params']['index']->value),
|
'index' => utf8_encode($data['params']['base_page'] . $data['params']['index']->value),
|
||||||
'base_url' => $data['params']['base_url'],
|
'base_url' => $data['params']['base_url'],
|
||||||
'base_page' => $data['params']['base_page'],
|
'base_page' => $data['params']['base_page'],
|
||||||
'page' => $data['page'],
|
'page' => $data['page'],
|
||||||
'params' => $data['params'],
|
'params' => $data['params'],
|
||||||
//'homepage' => $data['params']['homepage'],
|
|
||||||
//'project_title' => utf8_encode($data['params']['title']),
|
|
||||||
'tree' => $data['params']['tree'],
|
'tree' => $data['params']['tree'],
|
||||||
//'entry_page' => $data['page']['entry_page'],
|
|
||||||
]);
|
]);
|
||||||
|
|
||||||
return $this->engine->render($name, $data);
|
return $this->engine->render($name, $data);
|
||||||
@ -40,10 +36,8 @@ class Template
|
|||||||
protected function registerFunctions()
|
protected function registerFunctions()
|
||||||
{
|
{
|
||||||
$this->engine->registerFunction('get_navigation', function($tree, $path, $current_url, $base_page, $mode) {
|
$this->engine->registerFunction('get_navigation', function($tree, $path, $current_url, $base_page, $mode) {
|
||||||
$nav = '<ul class="nav nav-list">';
|
$nav = $this->buildNavigation($tree, $path, $current_url, $base_page, $mode);
|
||||||
$nav .= $this->buildNavigation($tree, $path, $current_url, $base_page, $mode);
|
return $this->renderNavigation($nav);
|
||||||
$nav .= '</ul>';
|
|
||||||
return $nav;
|
|
||||||
});
|
});
|
||||||
|
|
||||||
$this->engine->registerFunction('get_breadcrumb_title', function($page, $base_page) {
|
$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 = '<a href="' . $entry['href'] . '" class="folder">' . $entry['title'] . '</a>';
|
||||||
|
} else {
|
||||||
|
$link = '<a href="#" class="aj-nav folder">' . $entry['title'] . '</a>';
|
||||||
|
}
|
||||||
|
|
||||||
|
$link .= $this->renderNavigation($entry['children']);
|
||||||
|
} else {
|
||||||
|
$link = '<a href="' . $entry['href'] . '">' . $entry['title'] . '</a>';
|
||||||
|
}
|
||||||
|
|
||||||
|
$nav .= "<li class='$entry[class]'>$link</li>";
|
||||||
|
}
|
||||||
|
|
||||||
|
return "<ul class='nav nav-list'>$nav</ul>";
|
||||||
|
}
|
||||||
|
|
||||||
private function buildNavigation($tree, $path, $current_url, $base_page, $mode)
|
private function buildNavigation($tree, $path, $current_url, $base_page, $mode)
|
||||||
{
|
{
|
||||||
$nav = '';
|
$nav = [];
|
||||||
foreach ($tree->value as $node) {
|
foreach ($tree->value as $node) {
|
||||||
$url = $node->getUri();
|
$url = $node->getUri();
|
||||||
if ($node instanceof \Todaymade\Daux\Tree\Content) {
|
if ($node instanceof \Todaymade\Daux\Tree\Content) {
|
||||||
if ($node->value === 'index') {
|
if ($node->value === 'index') {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
$nav .= '<li';
|
|
||||||
$link = ($path === '') ? $url : $path . '/' . $url;
|
$link = ($path === '') ? $url : $path . '/' . $url;
|
||||||
if ($current_url === $link) {
|
|
||||||
$nav .= ' class="active"';
|
$nav[] = [
|
||||||
}
|
'title' => $node->getTitle(),
|
||||||
$nav .= '><a href="' . $base_page . $link . '">' . $node->getTitle() . '</a></li>';
|
'href' => $base_page . $link,
|
||||||
|
'class' => ($current_url === $link)? 'active' : ''
|
||||||
|
];
|
||||||
}
|
}
|
||||||
if ($node instanceof \Todaymade\Daux\Tree\Directory) {
|
if ($node instanceof \Todaymade\Daux\Tree\Directory) {
|
||||||
$nav .= '<li';
|
|
||||||
$link = ($path === '') ? $url : $path . '/' . $url;
|
$link = ($path === '') ? $url : $path . '/' . $url;
|
||||||
if (strpos($current_url, $link) === 0) {
|
|
||||||
$nav .= ' class="open"';
|
$folder = [
|
||||||
}
|
'title' => $node->getTitle(),
|
||||||
$nav .= ">";
|
'class' => (strpos($current_url, $link) === 0)? 'open' : '',
|
||||||
|
];
|
||||||
|
|
||||||
if ($mode === \TodayMade\Daux\Daux::STATIC_MODE) {
|
if ($mode === \TodayMade\Daux\Daux::STATIC_MODE) {
|
||||||
$link .= "/index.html";
|
$link .= "/index.html";
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($node->getIndexPage()) {
|
if ($node->getIndexPage()) {
|
||||||
$nav .= '<a href="' . $base_page . $link . '" class="folder">' .
|
$folder['href'] = $base_page . $link;
|
||||||
$node->getTitle() . '</a>';
|
|
||||||
} else {
|
|
||||||
$nav .= '<a href="#" class="aj-nav folder">' . $node->getTitle() . '</a>';
|
|
||||||
}
|
}
|
||||||
$nav .= '<ul class="nav nav-list">';
|
|
||||||
|
//Child pages
|
||||||
$new_path = ($path === '') ? $url : $path . '/' . $url;
|
$new_path = ($path === '') ? $url : $path . '/' . $url;
|
||||||
$nav .= $this->buildNavigation($node, $new_path, $current_url, $base_page, $mode);
|
$folder['children'] = $this->buildNavigation($node, $new_path, $current_url, $base_page, $mode);
|
||||||
$nav .= '</ul></li>';
|
|
||||||
|
$nav[] = $folder;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return $nav;
|
return $nav;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user