slim / twig-view
Slim Framework 4 view helper built on top of the Twig 3 templating component
Installs: 5 590 051
Dependents: 258
Suggesters: 10
Security: 0
Stars: 360
Watchers: 24
Forks: 87
Open Issues: 7
Requires
- php: ^7.4 || ^8.0
- psr/http-message: ^1.1 || ^2.0
- slim/slim: ^4.12
- symfony/polyfill-php81: ^1.29
- twig/twig: ^3.11
Requires (Dev)
- phpspec/prophecy-phpunit: ^2.0
- phpstan/phpstan: ^1.10.59
- phpunit/phpunit: ^9.6 || ^10
- psr/http-factory: ^1.0
- squizlabs/php_codesniffer: ^3.9
- 3.x-dev
- 3.4.1
- 3.4.0
- 3.3.0
- 3.2.0
- 3.1.0
- 3.0.0
- 3.0.0-beta
- 3.0.0-alpha
- 2.x-dev
- 2.5.1
- 2.5.0
- 2.4.0
- 2.3.0
- 2.2.0
- 2.1.1
- 2.1.0
- 2.0
- 1.2.0
- 1.1.1
- 1.1.0
- 1.0
- dev-dependabot/composer/phpspec/prophecy-phpunit-tw-2.3
- dev-dependabot/composer/phpstan/phpstan-tw-2.0.3
- dev-dependabot/composer/squizlabs/php_codesniffer-tw-3.11
- dev-dependabot/composer/symfony/polyfill-php81-tw-1.31
This package is auto-updated.
Last update: 2024-12-31 06:29:38 UTC
README
This is a Slim Framework view helper built on top of the Twig templating component. You can use this component to create and render templates in your Slim Framework application.
Install
Via Composer
composer require slim/twig-view
Requires Slim Framework 4, Twig 3 and PHP 7.4 or newer.
Usage
With DI Container
use DI\Container; use Slim\Factory\AppFactory; use Slim\Views\Twig; use Slim\Views\TwigMiddleware; require __DIR__ . '/../vendor/autoload.php'; // Create Container $container = new Container(); // Set view in Container $container->set(Twig::class, function() { return Twig::create(__DIR__ . '/../templates', ['cache' => 'path/to/cache']); }); // Create App from container $app = AppFactory::createFromContainer($container); // Add Twig-View Middleware $app->add(TwigMiddleware::create($app, $container->get(Twig::class))); // Add other middleware $app->addRoutingMiddleware(); $app->addErrorMiddleware(true, true, true); // Render from template file templates/profile.html.twig $app->get('/hello/{name}', function ($request, $response, $args) { $viewData = [ 'name' => $args['name'], ]; $twig = $this->get(Twig::class); return $twig->render($response, 'profile.html.twig', $viewData); })->setName('profile'); // Render from string $app->get('/hi/{name}', function ($request, $response, $args) { $viewData = [ 'name' => $args['name'], ]; $twig = $this->get(Twig::class); $str = $twig->fetchFromString('<p>Hi, my name is {{ name }}.</p>', $viewData); $response->getBody()->write($str); return $response; }); // Run app $app->run();
Without DI container
use Slim\Factory\AppFactory; use Slim\Views\Twig; use Slim\Views\TwigMiddleware; require __DIR__ . '/../vendor/autoload.php'; // Create App $app = AppFactory::create(); // Create Twig $twig = Twig::create('path/to/templates', ['cache' => 'path/to/cache']); // Add Twig-View Middleware $app->add(TwigMiddleware::create($app, $twig)); // Define named route $app->get('/hello/{name}', function ($request, $response, $args) { $view = Twig::fromRequest($request); return $view->render($response, 'profile.html.twig', [ 'name' => $args['name'] ]); })->setName('profile'); // Render from string $app->get('/hi/{name}', function ($request, $response, $args) { $view = Twig::fromRequest($request); $str = $view->fetchFromString( '<p>Hi, my name is {{ name }}.</p>', [ 'name' => $args['name'] ] ); $response->getBody()->write($str); return $response; }); // Run app $app->run();
Custom template functions
TwigExtension
provides these functions to your Twig templates:
url_for()
- returns the URL for a given route. e.g.: /hello/worldfull_url_for()
- returns the URL for a given route. e.g.: https://www.example.com/hello/worldis_current_url()
- returns true is the provided route name and parameters are valid for the current path.current_url()
- returns the current path, with or without the query string.get_uri()
- returns theUriInterface
object from the incomingServerRequestInterface
objectbase_path()
- returns the base path.
You can use url_for
to generate complete URLs to any Slim application named route and use is_current_url
to determine if you need to mark a link as active as shown in this example Twig template:
<h1>User List</h1> <ul> <li><a href="{{ url_for('profile', { 'name': 'josh' }) }}" {% if is_current_url('profile', { 'name': 'josh' }) %}class="active"{% endif %}>Josh</a></li> <li><a href="{{ url_for('profile', { 'name': 'andrew' }) }}">Andrew</a></li> </ul>
Tests
To execute the test suite, you'll need to clone the repository and install the dependencies.
$ git clone https://github.com/slimphp/Twig-View
$ composer install
$ composer test
Contributing
Please see CONTRIBUTING for details.
Security
If you discover any security related issues, please email security@slimframework.com instead of using the issue tracker.
Credits
License
The MIT License (MIT). Please see License File for more information.