X-Git-Url: https://git.rapsys.eu/packbundle/blobdiff_plain/55a896d78af2f339ce675640248c2a6a05f7cb7f..a6ed75729b0e17fb79e3a1afcba518f6856fd5b3:/Extension/PackExtension.php diff --git a/Extension/PackExtension.php b/Extension/PackExtension.php index 697f469..aa11688 100644 --- a/Extension/PackExtension.php +++ b/Extension/PackExtension.php @@ -11,89 +11,61 @@ namespace Rapsys\PackBundle\Extension; -use Symfony\Component\Asset\PackageInterface; -use Symfony\Component\DependencyInjection\ContainerInterface; -use Symfony\Component\HttpKernel\Config\FileLocator; -use Twig\Extension\AbstractExtension; - use Rapsys\PackBundle\Parser\TokenParser; use Rapsys\PackBundle\RapsysPackBundle; use Rapsys\PackBundle\Util\IntlUtil; use Rapsys\PackBundle\Util\SluggerUtil; +use Symfony\Component\Asset\PackageInterface; +use Symfony\Component\HttpKernel\Config\FileLocator; + +use Twig\Extension\AbstractExtension; + /** * {@inheritdoc} */ class PackExtension extends AbstractExtension { /** - * The config array - */ - protected array $config; - - /** - * The output array - */ - protected array $output; - - /** - * The filter array - */ - protected array $filters; - - /** - * @link https://twig.symfony.com/doc/2.x/advanced.html - * * {@inheritdoc} + * + * @link https://twig.symfony.com/doc/2.x/advanced.html */ - public function __construct(protected ContainerInterface $container, protected IntlUtil $intl, protected FileLocator $locator, protected PackageInterface $package, protected SluggerUtil $slugger) { - //Retrieve bundle config - if ($parameters = $container->getParameter(self::getAlias())) { - //Set config, output and filters arrays - foreach(['config', 'output', 'filters'] as $k) { - $this->$k = $parameters[$k]; - } - } + public function __construct(protected IntlUtil $intl, protected FileLocator $locator, protected PackageInterface $package, protected SluggerUtil $slugger, protected array $parameters) { } /** - * Returns a list of filters to add to the existing list. + * Returns a filter array to add to the existing list. * * @return \Twig\TwigFilter[] */ public function getTokenParsers(): array { return [ - new TokenParser($this->locator, $this->package, $this->config, 'stylesheet', $this->output['css'], $this->filters['css']), - new TokenParser($this->locator, $this->package, $this->config, 'javascript', $this->output['js'], $this->filters['js']), - new TokenParser($this->locator, $this->package, $this->config, 'image', $this->output['img'], $this->filters['img']) + new TokenParser($this->locator, $this->package, $this->parameters['token'], 'stylesheet', $this->parameters['output']['css'], $this->parameters['filters']['css']), + new TokenParser($this->locator, $this->package, $this->parameters['token'], 'javascript', $this->parameters['output']['js'], $this->parameters['filters']['js']), + new TokenParser($this->locator, $this->package, $this->parameters['token'], 'image', $this->parameters['output']['img'], $this->parameters['filters']['img']) ]; } /** - * Returns a list of filters to add to the existing list. + * Returns a filter array to add to the existing list. * * @return \Twig\TwigFilter[] */ public function getFilters(): array { return [ - new \Twig\TwigFilter('lcfirst', 'lcfirst'), - new \Twig\TwigFilter('ucfirst', 'ucfirst'), + new \Twig\TwigFilter('base64_decode', 'base64_decode'), + new \Twig\TwigFilter('base64_encode', 'base64_encode'), + new \Twig\TwigFilter('download', 'file_get_contents', [false, null]), new \Twig\TwigFilter('hash', [$this->slugger, 'hash']), - new \Twig\TwigFilter('unshort', [$this->slugger, 'unshort']), - new \Twig\TwigFilter('short', [$this->slugger, 'short']), - new \Twig\TwigFilter('slug', [$this->slugger, 'slug']), + new \Twig\TwigFilter('intlcurrency', [$this->intl, 'currency']), new \Twig\TwigFilter('intldate', [$this->intl, 'date'], ['needs_environment' => true]), new \Twig\TwigFilter('intlnumber', [$this->intl, 'number']), - new \Twig\TwigFilter('intlcurrency', [$this->intl, 'currency']), - new \Twig\TwigFilter('download', 'file_get_contents', [false, null]), - new \Twig\TwigFilter('base64_encode', 'base64_encode'), - new \Twig\TwigFilter('base64_decode', 'base64_decode') + new \Twig\TwigFilter('intlsize', [$this->intl, 'size']), + new \Twig\TwigFilter('lcfirst', 'lcfirst'), + new \Twig\TwigFilter('short', [$this->slugger, 'short']), + new \Twig\TwigFilter('slug', [$this->slugger, 'slug']), + new \Twig\TwigFilter('ucfirst', 'ucfirst'), + new \Twig\TwigFilter('unshort', [$this->slugger, 'unshort']) ]; } - - /** - * {@inheritdoc} - */ - public function getAlias(): string { - return RapsysPackBundle::getAlias(); - } }