beastbytes / view-latte
Yii Framework Latte Template Renderer
Installs: 24
Dependents: 2
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
pkg:composer/beastbytes/view-latte
Requires
- php: ^8.1
- beastbytes/latte-use-extension: dev-master
- latte/latte: dev-master
- psr/container: ^2.0
- yiisoft/router: ^4.0
- yiisoft/view: 10 - 12
Requires (Dev)
- httpsoft/http-message: ^1.0
- phpunit/phpunit: ^10.0
- vimeo/psalm: ^5.0
- yiisoft/aliases: ^3.0
- yiisoft/cache-file: ^3.0
- yiisoft/dummy-provider: ^1.0
- yiisoft/psr-dummy-provider: ^1.0
- yiisoft/router-fastroute: 4.0
- yiisoft/test-support: ^3.0
- yiisoft/translator: ^3.0
Suggests
- beastbytes/forn-latte: Integrates the Yii Framework Form package simplifing form creation
- beastbytes/yii-dataview-latte: Integrates the Yii Framework DataView package with view-latte Latte Template Renderer
- beastbytes/yii-tracy: Integrates the Tracy Debugging tool with Yii
This package is auto-updated.
Last update: 2025-10-15 16:52:44 UTC
README
This package is an extension of the Yii View Rendering Library. This extension
provides a ViewRender that allows use of the Latte view template engine.
Latte has some advantages over Twig as a templating engine:
- The major advantage of Latte is that it is PHP (Twig is Python), this makes writing Latte templates simpler and debugging them (if you need to) a lot simpler.
- Use PHP expressions in templates
- Better defence against XSS (Cross Site Scripting)
- Excellent plugin for PhpStorm that enables type hints, code completion, etc.
Requirements
- PHP 8.1 or higher.
Installation
Install the package using Composer:
Either:
composer require beastbytes/view-latte
or add the following to the require section of your composer.json
"beastbytes/view-latte": "*"
Configuration
In order to register Latte as the renderer in WebView, the beastbytes/view-latte package must override
the yiisoft\view package configuration. To do this, add beastbytes/view-latte to the vendor-override-layer
option in config-plugin-options; this is either in the extra section of your root composer.json
or in your external configuration file.
composer.json
"extra": { "config-plugin-options": { "vendor-override-layer": [ "beastbytes/view-latte" ] }, "config-plugin": { // ... } }
External Configuration File
'config-plugin-options' => [ // other config-plugin-options 'vendor-override-layer' => [ 'beastbytes/view-latte', // other vendor overrides ] ],
Note: if beastbytes/view-latte is the only vendor override,
it can be specified as a string in both of the configuration formats.
Params
The beastbytes/view-latte package supports the addition of user defined filters, functions, and extensions to Latte.
Each filter and function is defined in its own class; extensions are packages.
To add them to Latte specify them in the filterProviders, functionProviders, and extensions keys
of beastbytes/view-latte in the params array.
'beastbytes/view-latte' => [ 'filterProviders' => [ new MyLatteFilter() ], 'functionProviders' => [ new MyLatteFunction() ], 'extensions' => [ new myLatteExtension() ] ],
See User Defined Filters and Functions for details on how to define filters and functions.
See Creating an Extension for details on how to create an extension.
Templates
As you would expect, all the variables defined when calling the view renderer's render() method in an action are
available in the template, as are injected variables.
The Latte extension provides access to everything defined in the application container in all view templates and layouts.
Basic Layout & View Templates
Note: A major difference between Latte and PHP templates is the definition of $this.
- $thisin Latte templates is the Latte template being rendered
- $viewis the WebView instance
{varType string $content} {varType Yiisoft\View\WebView $view} {do $assetManager->register('App\Asset\AppAsset')} {do $view->addCssFiles($assetManager->getCssFiles())} {do $view->addCssStrings($assetManager->getCssStrings())} {do $view->addJsFiles($assetManager->getJsFiles())} {do $view->addJsStrings($assetManager->getJsStrings())} {do $view->addJsVars($assetManager->getJsVars())} {$view->beginPage()|noescape} <!DOCTYPE html> <html lang=""> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1"> <title>{$view->getTitle()}</title> {$view->head()|noescape} </head> <body> {$view->beginBody()|noescape} {include 'header.latte'} <main role="main" class="container py-4"> {$content|noescape} </main> {include 'footer.latte'} {$view->endBody()|noescape} </body> </html> {$view->endPage(true)|noescape}
And a view template will be:
{varType App\ApplicationParameters $applicationParameters} {varType Yiisoft\View\WebView $view} {do $view->setTitle($applicationParameters->getName())} <h1 class="title">Hello!</h1> <p class="subtitle">Let's start something great with <strong>Yii3 & Latte</strong>!</p> <p class="subtitle is-italic"> <a href="https://github.com/yiisoft/docs/tree/master/guide/en" target="_blank" rel="noopener"> Don't forget to check the Yii guide </a> <a href="https://latte.nette.org/en/guide" target="_blank" rel="noopener"> and the Latte documentation. </a> </p>
View-Latte Extensions
The view-latte package contains the following extensions:
CacheExtension
NOTE: CacheExtension is not implemented yet
The CacheExtension allows caching of view fragments and dynamic content within cached fragments.
The extension provides the cache and dynamic tags.
It is enabled if the DI container contains a Yiisoft\Cache\CacheInterface implementation.
NOTE: Templates using caching must have the variable $cache,
a concrete instance of  Yiisoft\Cache\CacheInterface, defined
{varType Yiisoft\Cache\CacheInterface $cache}
{cache} Tag
The cache tag allows a template or part of a template to be cached. The tag has three parameters:
- ttl (int) – The TTL of the cached content in seconds. Default is 60.
- dependency (Yiisoft\Cache\Dependency\Dependency|null) – The dependency of the cached content.
Default is null.
- beta (float) – The value for calculating the range that's used for "Probably early expiration".
Default is 1.0.
Examples
Basic Usage
{cache} content to be cached {/cache}
Set TTL
{cache 3600} content to be cached {/cache}
Set a Dependency
{cache 3600, new Yiisoft\Cache\Dependency\TagDependency('fragment-1')} content to be cached {/cache} ... {if $theAnswerToTheUltimateQuestionOfLife !== 42} {do Yiisoft\Cache\Dependency\TagDependency::invalidate('fragment-1')} {/if}
{dynamic} Tag
The dynamic tag defines dynamic content within a cache tag. The tag has three parameters:
- contentGenerator (callable) – a callable that generates the dynamic content;
it has the signature function (array $parameters = []): string;
- parameters (array) – parameters as key=>value pairs passed to contentGenerator
{dynamic function (array $parameters = []): string {return $generatedContent}, ['a' => 1, 'b' => 2]}
There is no limit to the number of dynamic tags within a cache tag.
UrlExtension
The UrlExtension allows generation of URL using routes.
The extension provides the n:action, n:href, and n:src n:attributes and link tag to generate URLs.
It is enabled if the DI container contains a Yiisoft\Router\UrlGeneratorInterface implementation.
n:attributes
The n:action, n:href, and n:src n:attributes are used to generate URLs as attributes in HTML tags;
their parameters are the same as `Yiisoft\Router\UrlGeneratorInterface::generate().
n:action Attribute
The n:action attribute is used to generate the action URL in <form/> tags.
<form n:action="route/name, arguments, queryParameters"> // Form controls </form>
Tip The form-latte extension integrates the Yii Framework Form package with view-latte.
n:href Attribute
The n:href attribute is used to generate links in <a/> tags;
<a n:href="route/name, arguments, queryParameters">Content</a>
n:src Attribute
The n:src attribute is used to generate URLs to the media source in media tags, e.g. <img/>;
<img n:src="route/name, arguments, queryParameters"/>
{link} Tag
The {link} tag is used to print a URL;
its parameters are the same as `Yiisoft\Router\UrlGeneratorInterface::generate().
{link route/name, arguments, queryParameters}
UseExtension
The UseExtension emulates PHP's use operator and allows writing cleaner templates.
The extension provides provides the use tag.
It is always enabled.
By default, Latte templates require the use of Fully Qualified CLass Names (FQCN); this can lead to cluttered templates.
The use tag emulates PHP's use operator and allows templates to define the FQCN and optionally an alias,
and refer to the used class by the alias or base class name.
Using Namespaced Classes in Latte
The FQCN must be defined in a use tag before the base class name or alias is referenced in the template.
The best way to ensure this is to place use tags at the start of the template.
The extension replaces the alias or base class name defined in the use tag with the FQCN in class instantation (new)
statements and class constants during compilation; it does not import or alias the class.
Differences from PHP
- There is no asclause when defining an alias
- Group usedefinitions are not supported.
{use} Tag
{use Framework\Module\NamespacedClass} <p>The value is {(new NamespacedClass)->getValue()}</p> <p>The constant is {NamespacedClass::CONSTANT}</p>
{use} Tag with Alias
{use Framework\Module\Aliased\NamespacedClass AliasedClass} <p>The value is {(new AliasedClass)->getValue()}</p> <p>The constant is {AliasedClass::CONSTANT}</p>
Multiple {use} Tags
{use Framework\Module\Aliased\NamespacedClass AliasedClass} {use Framework\Module\NamespacedClass} {varType int $arg} {varType string $testString} <p>The value is {(new NamespacedClass($arg))->getValue()}</p> <p>The constant is {NamespacedClass::CONSTANT}</p> <p>{$testString|replace: AliasedClass::CONSTANT}</p>
YiiLatteExtension
The YiiLatteExtension allows access to any package in the DI container.
The extension provides the get function which takes the id of the required package as a parameter.
It is always enabled.
get() Function
{do $package = get('PackageId')}
Other Extensions
TranslatorExtension
Latte's Translation Extension is enabled if
the DI container contains a Yiisoft\Translator\TranslatorInterface implementation,
allowing use of Latte's Translation tags
and filter in templates.
RawPhpExtension
Latte's RawPhpExtension is not enabled by default. To enable it, add it to the extensions section
of the beastbytes/view-latte in your configuration parameters:
return [ 'beastbytes/view-latte' => [ 'extensions' => [ new \Latte\Essential\RawPhpExtension(), // Other extensions ], // Other view-latte configuration ], ]
User Defined Filters and Functions
The view-latte package supports the addition of user-defined filters and functions to the Latte Engine;
see Configuration -> Params for details on how to specify them. This section details how to define them.
Each filter and/or function is defined in its own class. Filters must implement the FilterProviderinterface
and functions the FunctionProviderinterface; both must implement the __invoke() method to provide their
functionality.
Example Filter
<?php declare(strict_types=1); namespace App\Latte\Providers; use BeastBytes\View\Latte\Provider\FilterProvider; class MyLatteFilter implements FilterProvider { public function getName(): string { return 'myLatteFilter'; // the name registered with Latte and used to invoke the filter in templates } public function __invoke(string $string): string { return strrev($string); } }
Example Function
<?php declare(strict_types=1); namespace App\Latte\Providers; use BeastBytes\View\Latte\Provider\FunctionProvider; class MyLatteFunction implements FunctionProvider { public function getName(): string { return 'myLatteFunction'; // the name registered with Latte and used to call the function in templates } public function __invoke(int $number): int { return $number * 2; } }
Example Template
{var int $x = 2} {var string $strig = 'ABCDE'} <p>{$strig|myLatteFilter}</p> <!-- will output EDCBA --> <p>{=myLatteFunction($x)}</p> <!-- will output 4 -->
License
The BeastBytes View Latte Renderer is free software. It is released under the terms of the BSD License.
Please see LICENSE for more information.