Add ViewHelper in view for injecting some basic classes in views

This commit is contained in:
Tim 2023-08-15 12:10:04 +02:00
parent de5ff3a2b9
commit 45797ba20a
12 changed files with 61 additions and 22 deletions

View File

@ -13,9 +13,9 @@ use Ardent\Undercurrent\View\ViewInterface;
class HelloWorldController
{
#[Route('/')]
public function index(): ResponseInterface
public function index(): ViewInterface
{
return new GenericResponse('Index, <a href="/hello">Hello</a>');
return new BaseView('/index.php');
}
#[Route('/error')]
@ -30,10 +30,10 @@ class HelloWorldController
return new GenericResponse('Hello World!');
}
#[Route('/view')]
public function view(): ViewInterface
#[Route('/view/{name}')]
public function view(string $name): ViewInterface
{
return new BaseView('/Template/home.php', ['message' => 'Hello World!']);
return new BaseView('/home.php', ['name' => $name]);
}
#[Route('/routes/{word}')]

View File

@ -1,10 +1,10 @@
<?php /** @var $this \Ardent\Undercurrent\View\BaseView */ ?>
<html>
<html lang="en">
<head>
<title>TOSTI MAN KOMT JE HALEN</title>
<title>Base view title</title>
</head>
<body>
<?= $this->data['slot'] ?>
Base, slot: <?= $this->data['slot'] ?>
</body>
</html>

View File

@ -1,4 +1,4 @@
<?php /** @var $this \Ardent\Undercurrent\View\BaseView */ ?>
<?php $this->extends = '/Template/base.php' ?>
<?php $this->extends = '/base.php' ?>
<?= $this->data['message'] ?>
Hello <?= $this->data['name'] ?>!

4
app/Template/index.php Normal file
View File

@ -0,0 +1,4 @@
<?php /** @var $this \Ardent\Undercurrent\View\BaseView */ ?>
<?php $this->extends = '/base.php' ?>
Hello <a href="<?= $this->helper->getRoute(\App\Controller\HelloWorldController::class, 'hello') ?>">index</a>!

View File

@ -6,6 +6,7 @@ class AppConfig
{
public function __construct(
private readonly string $rootPath,
private readonly string $templatePath,
)
{
}
@ -14,4 +15,9 @@ class AppConfig
{
return $this->rootPath;
}
public function getTemplatePath(): string
{
return $this->getRootPath() . $this->templatePath;
}
}

View File

@ -11,6 +11,7 @@ class Route
public function __construct(
public string $path,
public ?MethodEnum $method = null,
public ?string $name = null,
)
{
}

View File

@ -5,6 +5,7 @@ namespace Ardent\Undercurrent\Http;
use Ardent\Undercurrent\AppConfig;
use Ardent\Undercurrent\Container\ContainerInterface;
use Ardent\Undercurrent\Logger\LoggerInterface;
use Ardent\Undercurrent\View\ViewHelper;
use Ardent\Undercurrent\View\ViewInterface;
class GenericRouter implements RouterInterface
@ -38,7 +39,10 @@ class GenericRouter implements RouterInterface
);
if ($response instanceof ViewInterface) {
return new GenericResponse($response->render($this->container->get(AppConfig::class)));
return new GenericResponse($response->render(
$this->container->get(AppConfig::class),
$this->container->get(ViewHelper::class)
));
}
return $response;
@ -47,7 +51,7 @@ class GenericRouter implements RouterInterface
throw new RouteNotFoundException($request);
}
public function toUri(string $controller, string $method): string
public function toUri(string $controller, string $method, array $params): string
{
foreach ($this->config->getRoutes() as $route) {
if ($route->getController() === $controller && $route->getMethod() === $method) {

View File

@ -7,4 +7,6 @@ use Ardent\Undercurrent\View\ViewInterface;
interface RouterInterface
{
public function dispatch(RequestInterface $request): ResponseInterface;
public function toUri(string $controller, string $method, array $params): string;
}

View File

@ -14,6 +14,7 @@ use Ardent\Undercurrent\Http\RouterInterface;
use Ardent\Undercurrent\Http\StatusEnum;
use Ardent\Undercurrent\Logger\LogContainer;
use Ardent\Undercurrent\Logger\LoggerInterface;
use Ardent\Undercurrent\View\ViewHelper;
use Ardent\Undercurrent\View\ViewInterface;
class BaseKernel
@ -26,7 +27,7 @@ class BaseKernel
public function run(): void
{
$appConfig = new AppConfig($this->rootDirectory);
$appConfig = new AppConfig($this->rootDirectory, '/Template');
$container = (new GenericContainer());
$container
@ -36,6 +37,7 @@ class BaseKernel
->add(GenericContainer::class, fn($container) => $container)
->add(AppConfig::class, fn() => $appConfig)
->add(GenericRouter::class)
->add(ViewHelper::class)
->add(LogContainer::class);
$this->dependencies($container);

View File

@ -3,28 +3,29 @@
namespace Ardent\Undercurrent\View;
use Ardent\Undercurrent\AppConfig;
use Ardent\Undercurrent\Http\GenericResponse;
use Ardent\Undercurrent\Http\ResponseInterface;
class BaseView implements ViewInterface
{
private ViewHelper $helper;
public function __construct(
private readonly string $path,
private readonly array $data = [],
private ?string $extends = null,
private readonly string $path,
private readonly array $data = [],
private ?string $extends = null,
)
{
}
public function render(AppConfig $config): string
public function render(AppConfig $config, ViewHelper $helper): string
{
$path = $config->getRootPath() . $this->path;
$this->helper = $helper;
$path = $config->getTemplatePath() . $this->path;
ob_start();
include $path;
$output = ob_get_clean();
if ($this->extends) {
return (new BaseView($this->extends, $this->data + ['slot' => $output]))->render($config);
return (new BaseView($this->extends, $this->data + ['slot' => $output]))->render($config, $helper);
}
return $output;

19
src/View/ViewHelper.php Normal file
View File

@ -0,0 +1,19 @@
<?php
namespace Ardent\Undercurrent\View;
use Ardent\Undercurrent\Http\RouterInterface;
class ViewHelper
{
public function __construct(
private readonly RouterInterface $router,
)
{
}
public function getRoute(string $class, string $method, array $params = []): string
{
return $this->router->toUri($class, $method, $params);
}
}

View File

@ -7,5 +7,5 @@ use Ardent\Undercurrent\Http\ResponseInterface;
interface ViewInterface
{
public function render(AppConfig $config): string;
public function render(AppConfig $config, ViewHelper $helper): string;
}