2024-06-20 14:10:42 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This file is part of Twig.
|
|
|
|
*
|
|
|
|
* (c) Fabien Potencier
|
|
|
|
*
|
|
|
|
* For the full copyright and license information, please view the LICENSE
|
|
|
|
* file that was distributed with this source code.
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace Twig;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Exposes a template to userland.
|
|
|
|
*
|
|
|
|
* @author Fabien Potencier <fabien@symfony.com>
|
|
|
|
*/
|
|
|
|
final class TemplateWrapper
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* This method is for internal use only and should never be called
|
|
|
|
* directly (use Twig\Environment::load() instead).
|
|
|
|
*
|
|
|
|
* @internal
|
|
|
|
*/
|
2025-01-13 09:56:01 +00:00
|
|
|
public function __construct(
|
|
|
|
private Environment $env,
|
|
|
|
private Template $template,
|
|
|
|
) {
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return iterable<scalar|\Stringable|null>
|
|
|
|
*/
|
|
|
|
public function stream(array $context = []): iterable
|
|
|
|
{
|
|
|
|
yield from $this->template->yield($context);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return iterable<scalar|\Stringable|null>
|
|
|
|
*/
|
|
|
|
public function streamBlock(string $name, array $context = []): iterable
|
2024-06-20 14:10:42 +00:00
|
|
|
{
|
2025-01-13 09:56:01 +00:00
|
|
|
yield from $this->template->yieldBlock($name, $context);
|
2024-06-20 14:10:42 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function render(array $context = []): string
|
|
|
|
{
|
|
|
|
return $this->template->render($context);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function display(array $context = [])
|
|
|
|
{
|
|
|
|
// using func_get_args() allows to not expose the blocks argument
|
|
|
|
// as it should only be used by internal code
|
|
|
|
$this->template->display($context, \func_get_args()[1] ?? []);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function hasBlock(string $name, array $context = []): bool
|
|
|
|
{
|
|
|
|
return $this->template->hasBlock($name, $context);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return string[] An array of defined template block names
|
|
|
|
*/
|
|
|
|
public function getBlockNames(array $context = []): array
|
|
|
|
{
|
|
|
|
return $this->template->getBlockNames($context);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function renderBlock(string $name, array $context = []): string
|
|
|
|
{
|
2025-01-13 09:56:01 +00:00
|
|
|
return $this->template->renderBlock($name, $context + $this->env->getGlobals());
|
2024-06-20 14:10:42 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function displayBlock(string $name, array $context = [])
|
|
|
|
{
|
2025-01-13 09:56:01 +00:00
|
|
|
$context += $this->env->getGlobals();
|
2024-06-20 14:10:42 +00:00
|
|
|
foreach ($this->template->yieldBlock($name, $context) as $data) {
|
|
|
|
echo $data;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getSourceContext(): Source
|
|
|
|
{
|
|
|
|
return $this->template->getSourceContext();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getTemplateName(): string
|
|
|
|
{
|
|
|
|
return $this->template->getTemplateName();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @internal
|
|
|
|
*
|
|
|
|
* @return Template
|
|
|
|
*/
|
|
|
|
public function unwrap()
|
|
|
|
{
|
|
|
|
return $this->template;
|
|
|
|
}
|
|
|
|
}
|