From e4c14242e9f3cf6238ca297d5cc369d92c4f661c Mon Sep 17 00:00:00 2001 From: =?utf8?q?Rapha=C3=ABl=20Gertz?= Date: Tue, 26 Nov 2019 15:12:03 +0100 Subject: [PATCH] Switch from Packages to PackageInterface Switch from \Twig_Extension to AbstractExtension Declare protected members Hardcode parameters name in copy process Cleanup --- Twig/PackExtension.php | 37 ++++++++++++++++++++++--------------- 1 file changed, 22 insertions(+), 15 deletions(-) diff --git a/Twig/PackExtension.php b/Twig/PackExtension.php index 23cceb6..91a7a89 100644 --- a/Twig/PackExtension.php +++ b/Twig/PackExtension.php @@ -4,9 +4,10 @@ namespace Rapsys\PackBundle\Twig; use Symfony\Component\HttpKernel\Config\FileLocator; use Symfony\Component\DependencyInjection\ContainerInterface; -use Symfony\Component\Asset\Packages; +use Symfony\Component\Asset\PackageInterface; +use Twig\Extension\AbstractExtension; -class PackExtension extends \Twig_Extension { +class PackExtension extends AbstractExtension { //The config private $config; @@ -16,28 +17,34 @@ class PackExtension extends \Twig_Extension { //The filter private $filters; - public function __construct(FileLocator $fileLocator, ContainerInterface $containerInterface, Packages $assetsPackages) { + //The file locator + protected $locator; + + //The assets package + protected $package; + + public function __construct(FileLocator $locator, ContainerInterface $container, PackageInterface $package) { //Set file locator - $this->fileLocator = $fileLocator; - //Set container interface - $this->containerInterface = $containerInterface; + $this->locator = $locator; + //Set assets packages - $this->assetsPackages = $assetsPackages; + $this->package = $package; //Retrieve bundle config - if ($parameters = $containerInterface->getParameter($this->getAlias())) { - foreach($parameters as $k => $v) { - $this->$k = $v; + if ($parameters = $container->getParameter($this->getAlias())) { + //Set config, output and filters arrays + foreach(['config', 'output', 'filters'] as $k) { + $this->$k = $parameters[$k]; } } } public function getTokenParsers() { - return array( - new PackTokenParser($this->fileLocator, $this->assetsPackages, $this->config, 'stylesheet', $this->output['css'], $this->filters['css']), - new PackTokenParser($this->fileLocator, $this->assetsPackages, $this->config, 'javascript', $this->output['js'], $this->filters['js']), - new PackTokenParser($this->fileLocator, $this->assetsPackages, $this->config, 'image', $this->output['img'], $this->filters['img']) - ); + return [ + new PackTokenParser($this->locator, $this->package, $this->config, 'stylesheet', $this->output['css'], $this->filters['css']), + new PackTokenParser($this->locator, $this->package, $this->config, 'javascript', $this->output['js'], $this->filters['js']), + new PackTokenParser($this->locator, $this->package, $this->config, 'image', $this->output['img'], $this->filters['img']) + ]; } /** -- 2.41.1