Skip to content

Commit

Permalink
[TASK] Use #[AsHelper] attribute in all helpers
Browse files Browse the repository at this point in the history
  • Loading branch information
eliashaeussler committed Dec 18, 2024
1 parent 3bc5168 commit 0c80cdd
Show file tree
Hide file tree
Showing 5 changed files with 22 additions and 29 deletions.
5 changes: 3 additions & 2 deletions Classes/Renderer/Helper/BlockHelper.php
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@

namespace Fr\Typo3Handlebars\Renderer\Helper;

use Fr\Typo3Handlebars\Attribute;
use Fr\Typo3Handlebars\Exception;
use Fr\Typo3Handlebars\Renderer;

Expand All @@ -33,13 +34,13 @@
* @license GPL-2.0-or-later
* @see https://github.com/shannonmoeller/handlebars-layouts#block-name
*/
class BlockHelper implements HelperInterface
final readonly class BlockHelper implements HelperInterface
{
/**
* @param array<string, mixed> $options
* @throws Exception\UnsupportedTypeException
*/
public function evaluate(string $name, array $options): string
#[Attribute\AsHelper('block')]
{
$data = $options['_this'];
$actions = $data['_layoutActions'] ?? [];
Expand Down
11 changes: 4 additions & 7 deletions Classes/Renderer/Helper/ContentHelper.php
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@

namespace Fr\Typo3Handlebars\Renderer\Helper;

use Fr\Typo3Handlebars\Attribute;
use Fr\Typo3Handlebars\Renderer;
use Psr\Log;

Expand All @@ -33,17 +34,13 @@
* @license GPL-2.0-or-later
* @see https://github.com/shannonmoeller/handlebars-layouts#content-name-modeappendprependreplace
*/
class ContentHelper implements HelperInterface
final readonly class ContentHelper implements HelperInterface
{
public function __construct(
protected readonly Log\LoggerInterface $logger,
private Log\LoggerInterface $logger,
) {}

/**
* @param array<string, mixed> $options
* @return string|bool
*/
public function evaluate(string $name, array $options)
#[Attribute\AsHelper('content')]
{
$data = $options['_this'];
$mode = $options['hash']['mode'] ?? Renderer\Component\Layout\HandlebarsLayoutAction::REPLACE;
Expand Down
7 changes: 4 additions & 3 deletions Classes/Renderer/Helper/ExtendHelper.php
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@

namespace Fr\Typo3Handlebars\Renderer\Helper;

use Fr\Typo3Handlebars\Attribute;
use Fr\Typo3Handlebars\Renderer;

/**
Expand All @@ -32,13 +33,13 @@
* @license GPL-2.0-or-later
* @see https://github.com/shannonmoeller/handlebars-layouts#extend-partial-context-keyvalue-
*/
class ExtendHelper implements HelperInterface
final readonly class ExtendHelper implements HelperInterface
{
public function __construct(
protected readonly Renderer\RendererInterface $renderer,
private Renderer\RendererInterface $renderer,
) {}

public function evaluate(string $name): string
#[Attribute\AsHelper('extend')]
{
// Get helper options
$arguments = \func_get_args();
Expand Down
14 changes: 6 additions & 8 deletions Classes/Renderer/Helper/RenderHelper.php
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@

namespace Fr\Typo3Handlebars\Renderer\Helper;

use Fr\Typo3Handlebars\Attribute;
use Fr\Typo3Handlebars\DataProcessing;
use Fr\Typo3Handlebars\Exception;
use Fr\Typo3Handlebars\Renderer;
Expand All @@ -37,18 +38,15 @@
* @license GPL-2.0-or-later
* @see https://github.com/frctl/fractal/blob/main/packages/handlebars/src/helpers/render.js
*/
class RenderHelper implements HelperInterface
final readonly class RenderHelper implements HelperInterface
{
public function __construct(
protected readonly Renderer\RendererInterface $renderer,
protected readonly Core\TypoScript\TypoScriptService $typoScriptService,
protected readonly Frontend\ContentObject\ContentObjectRenderer $contentObjectRenderer,
private Renderer\RendererInterface $renderer,
private Core\TypoScript\TypoScriptService $typoScriptService,
private Frontend\ContentObject\ContentObjectRenderer $contentObjectRenderer,
) {}

/**
* @throws Exception\InvalidConfigurationException
*/
public function evaluate(string $name): SafeString
#[Attribute\AsHelper('render')]
{
// Get helper options
$arguments = \func_get_args();
Expand Down
14 changes: 5 additions & 9 deletions Classes/Renderer/Helper/VarDumpHelper.php
Original file line number Diff line number Diff line change
Expand Up @@ -23,26 +23,22 @@

namespace Fr\Typo3Handlebars\Renderer\Helper;

use Fr\Typo3Handlebars\Attribute\AsHelper;
use TYPO3\CMS\Core\Utility\DebugUtility;
use Fr\Typo3Handlebars\Attribute;
use TYPO3\CMS\Core;

/**
* VarDumpHelper
*
* @author Elias Häußler <e.haeussler@familie-redlich.de>
* @license GPL-2.0-or-later
*/
class VarDumpHelper implements HelperInterface
final readonly class VarDumpHelper implements HelperInterface
{
/**
* @param array<string|int, mixed> $context
*/
#[AsHelper('varDump')]
public static function evaluate(array $context): string
#[Attribute\AsHelper('varDump')]
{
\ob_start();

DebugUtility::debug($context['_this']);
Core\Utility\DebugUtility::debug($context->renderingContext);

return (string)\ob_get_clean();
}
Expand Down

0 comments on commit 0c80cdd

Please sign in to comment.