have navlinks as a utility methods that themes can call, if they want to

This commit is contained in:
Shish 2020-02-01 23:23:23 +00:00
parent 321eafa408
commit 0bcbcb679e
9 changed files with 109 additions and 53 deletions

View file

@ -138,9 +138,6 @@ class BasePage
/** @var string */ /** @var string */
public $subheading = ""; public $subheading = "";
/** @var string */
public $quicknav = "";
/** @var string[] */ /** @var string[] */
public $html_headers = []; public $html_headers = [];
@ -312,49 +309,8 @@ class BasePage
# header('Expires: ' . gmdate('D, d M Y H:i:s', time() - 600) . ' GMT'); # header('Expires: ' . gmdate('D, d M Y H:i:s', time() - 600) . ' GMT');
#} #}
usort($this->blocks, "blockcmp"); usort($this->blocks, "blockcmp");
$pnbe = send_event(new PageNavBuildingEvent());
$nav_links = $pnbe->links;
$active_link = null;
// To save on event calls, we check if one of the top-level links has already been marked as active
foreach ($nav_links as $link) {
if ($link->active===true) {
$active_link = $link;
break;
}
}
$sub_links = null;
// If one is, we just query for sub-menu options under that one tab
if ($active_link!==null) {
$psnbe = send_event(new PageSubNavBuildingEvent($active_link->name));
$sub_links = $psnbe->links;
} else {
// Otherwise we query for the sub-items under each of the tabs
foreach ($nav_links as $link) {
$psnbe = send_event(new PageSubNavBuildingEvent($link->name));
// Now we check for a current link so we can identify the sub-links to show
foreach ($psnbe->links as $sub_link) {
if ($sub_link->active===true) {
$sub_links = $psnbe->links;
break;
}
}
// If the active link has been detected, we break out
if ($sub_links!==null) {
$link->active = true;
break;
}
}
}
$sub_links = $sub_links??[];
usort($nav_links, "sort_nav_links");
usort($sub_links, "sort_nav_links");
$this->add_auto_html_headers(); $this->add_auto_html_headers();
$this->render($nav_links, $sub_links); $this->render();
break; break;
case PageMode::DATA: case PageMode::DATA:
header("Content-Length: " . strlen($this->data)); header("Content-Length: " . strlen($this->data));
@ -504,10 +460,56 @@ class BasePage
$this->add_html_header("<script defer src='$data_href/$js_cache_file' type='text/javascript'></script>", 44); $this->add_html_header("<script defer src='$data_href/$js_cache_file' type='text/javascript'></script>", 44);
} }
protected function get_nav_links()
{
$pnbe = send_event(new PageNavBuildingEvent());
$nav_links = $pnbe->links;
$active_link = null;
// To save on event calls, we check if one of the top-level links has already been marked as active
foreach ($nav_links as $link) {
if ($link->active===true) {
$active_link = $link;
break;
}
}
$sub_links = null;
// If one is, we just query for sub-menu options under that one tab
if ($active_link!==null) {
$psnbe = send_event(new PageSubNavBuildingEvent($active_link->name));
$sub_links = $psnbe->links;
} else {
// Otherwise we query for the sub-items under each of the tabs
foreach ($nav_links as $link) {
$psnbe = send_event(new PageSubNavBuildingEvent($link->name));
// Now we check for a current link so we can identify the sub-links to show
foreach ($psnbe->links as $sub_link) {
if ($sub_link->active===true) {
$sub_links = $psnbe->links;
break;
}
}
// If the active link has been detected, we break out
if ($sub_links!==null) {
$link->active = true;
break;
}
}
}
$sub_links = $sub_links??[];
usort($nav_links, "sort_nav_links");
usort($sub_links, "sort_nav_links");
return [$nav_links, $sub_links];
}
/** /**
* turns the Page into HTML * turns the Page into HTML
*/ */
public function render(array $nav_links, array $sub_links) public function render()
{ {
$head_html = $this->head_html(); $head_html = $this->head_html();
$body_html = $this->body_html(); $body_html = $this->body_html();

View file

@ -0,0 +1,48 @@
<?php declare(strict_types=1);
require_once "core/basepage.php";
class BasePageTest extends \PHPUnit\Framework\TestCase
{
public function test_page()
{
$page = new BasePage();
$page->set_mode(PageMode::PAGE);
ob_start();
$page->display();
ob_end_clean();
$this->assertTrue(true); // doesn't crash
}
public function test_file()
{
$page = new BasePage();
$page->set_mode(PageMode::FILE);
$page->set_file("tests/pbx_screenshot.jpg");
ob_start();
$page->display();
ob_end_clean();
$this->assertTrue(true); // doesn't crash
}
public function test_data()
{
$page = new BasePage();
$page->set_mode(PageMode::DATA);
$page->set_data("hello world");
ob_start();
$page->display();
ob_end_clean();
$this->assertTrue(true); // doesn't crash
}
public function test_redirect()
{
$page = new BasePage();
$page->set_mode(PageMode::REDIRECT);
$page->set_redirect("/new/page");
ob_start();
$page->display();
ob_end_clean();
$this->assertTrue(true); // doesn't crash
}
}

View file

@ -51,10 +51,12 @@ class Page extends BasePage
$this->left_enabled = false; $this->left_enabled = false;
} }
public function render(array $nav_links, array $sub_links) public function render()
{ {
global $config; global $config;
list($nav_links, $sub_links) = $this->get_nav_links();
$left_block_html = ""; $left_block_html = "";
$user_block_html = ""; $user_block_html = "";
$main_block_html = ""; $main_block_html = "";

View file

@ -50,10 +50,12 @@ class Page extends BasePage
$this->left_enabled = false; $this->left_enabled = false;
} }
public function render(array $nav_links, array $sub_links) public function render()
{ {
global $config; global $config;
list($nav_links, $sub_links) = $this->get_nav_links();
$left_block_html = ""; $left_block_html = "";
$user_block_html = ""; $user_block_html = "";
$main_block_html = ""; $main_block_html = "";

View file

@ -8,7 +8,7 @@ class Page extends BasePage
$this->left_enabled = false; $this->left_enabled = false;
} }
public function render($nav_links, $subnav_links) public function render()
{ {
$left_block_html = ""; $left_block_html = "";
$main_block_html = ""; $main_block_html = "";

View file

@ -18,10 +18,11 @@ class Page extends BasePage
$this->left_enabled = false; $this->left_enabled = false;
} }
public function render(array $nav_links, array $sub_links) public function render()
{ {
global $config; global $config;
list($nav_links, $sub_links) = $this->get_nav_links();
$theme_name = $config->get_string(SetupConfig::THEME, 'lite'); $theme_name = $config->get_string(SetupConfig::THEME, 'lite');
$site_name = $config->get_string(SetupConfig::TITLE); $site_name = $config->get_string(SetupConfig::TITLE);
$data_href = get_base_href(); $data_href = get_base_href();

View file

@ -1,10 +1,11 @@
<?php declare(strict_types=1); <?php declare(strict_types=1);
class Page extends BasePage class Page extends BasePage
{ {
public function render($nav_links, $subnav_links) public function render()
{ {
global $config; global $config;
list($nav_links, $sub_links) = $this->get_nav_links();
$theme_name = $config->get_string(SetupConfig::THEME, 'material'); $theme_name = $config->get_string(SetupConfig::THEME, 'material');
$site_name = $config->get_string(SetupConfig::TITLE); $site_name = $config->get_string(SetupConfig::TITLE);
$data_href = get_base_href(); $data_href = get_base_href();

View file

@ -1,7 +1,7 @@
<?php declare(strict_types=1); <?php declare(strict_types=1);
class Page extends BasePage class Page extends BasePage
{ {
public function render($nav_links, $subnav_links) public function render()
{ {
global $config; global $config;

View file

@ -1,7 +1,7 @@
<?php declare(strict_types=1); <?php declare(strict_types=1);
class Page extends BasePage class Page extends BasePage
{ {
public function render($nav_links, $subnav_links) public function render()
{ {
global $config; global $config;