pug / yii2
Yii2 Pug (ex Jade) extension
Fund package maintenance!
kylekatarnls
Open Collective
Tidelift
Installs: 9 317
Dependents: 2
Suggesters: 0
Security: 0
Stars: 7
Watchers: 2
Forks: 0
Open Issues: 0
Type:yii2-extension
Requires
- php: >=5.4.0
- pug-php/pug: ^2.7.6 || ^3.4.1
- yiisoft/yii2: ^2.0.13
Requires (Dev)
- phpunit/phpunit: ^8.5.15
- yidas/yii2-composer-bower-skip: ^2.0.13
- yiisoft/yii2-bootstrap: ^2.0.10
Replaces
- jacmoe/yii2-pug: 1.5.5
- rmrevin/yii2-pug: 0.0.1
This package is auto-updated.
Last update: 2024-12-29 05:21:56 UTC
README
This extension provides a view renderer for Pug templates for Yii framework 2.0 applications.
Support
Installation
The preferred way to install this extension is through composer.
Either run
composer require pug/yii2
or add
"pug/yii2": "^1.0",
to the require
section of your composer.json
file.
Configure
<?php return [ // ... 'components' => [ // ... 'view' => [ // ... 'renderers' => [ 'pug' => 'Pug\\Yii\\ViewRenderer', ], ], ], ];
You can also use other pug renderer like phug or tale-pug
<?php return [ // ... 'components' => [ // ... 'view' => [ // ... 'renderers' => [ 'pug' => [ 'class' => 'Pug\\Yii\\ViewRenderer', 'renderer' => 'Phug\\Renderer', ], ], ], ], ];
Phug and Pug-php (the default renderer) are automatically installed
when you install the last version of pug/yii2
, for other pug renderer,
replace the renderer class and include it.
For example, for Tale-pug, use composer require talesoft/tale-pug
then replace 'Tale\\Pug\\Renderer'
with 'Tale\\Pug\\Renderer'
in the config example above.
Cache path and View path
By default, this extension uses '@runtime/pug/cache'
to store compiled
templates, and looks in '@app/views'
to find the templates to compile.
You can change this, by specifying cachePath
and/or viewPath
in the
configuration, for example:
return [
// ...
'components' => [
// ...
'view' => [
// ...
'renderers' => [
'pug' => [
'class' => 'Pug\\Yii\\ViewRenderer',
'cachePath' => '@app/runtime/Pugcache',
'viewPath' => '@app/themes/dark/templates/views',
],
],
],
],
];
pug/yii
provide 2 global variables: app
(Yii::$app
) and view
(view
path given to ->render()
in your controller). It imply that:
- If you set app or view shared variables, they will be erased by those system values.
- If you pass app or view locals to the
->render()
method they will have the precedence on system values.
To avoid such name conflict, you can pack into on object and store in a shared variable with a name you chose:
return [ // ... 'components' => [ // ... 'view' => [ // ... 'renderers' => [ 'pug' => [ 'class' => 'Pug\\Yii\\ViewRenderer', // ... 'systemVariable' => '_yii', ], ], ], ], ];
With this config, app and view are no longer reserved names (can be used for your own locals or shared variables), only _yii is, and so you can get app and view like this:
h1=_yii.view.defaultExtension p=_yii.app.version
Or if you set the expressionLanguage
option to "php"
:
h1=$_yii->view->defaultExtension p=$_yii->app->getVersion()
Credits
This solution merge both project rmrevin/yii2-pug (original fork that support pug-php 2) and jacmoe/yii2-tale-pug (tale-pug and tale-jade Yii2 solution) and finally bring support for pug-php 3 and phug engines.