Macros and components for integration of Encore into Nette project.
composer require vavo/nette-encore
yarn add @symfony/webpack-encore --dev
1 . Register extension.
extensions:
encoreLoader: vavo\EncoreLoader\DI\EncoreLoaderExtension
2 . Define encore properties in config.
encoreLoader:
outDir: "%wwwDir%/build/"
defaultEntry: index
3 . Add trait into Presenter.
<?php
declare(strict_types=1);
namespace App\Presenters;
use vavo\EncoreLoader\EncoreLoaderTrait;
use Nette;
class BasePresenter extends Nette\Application\UI\Presenter
{
use EncoreLoaderTrait;
...
4 . Add control into @layout.latte. You can specify what file should be included.
{control encore-css}
{control encore-css, [filename]}
...
{control encore-js, index}
5 . Use latte macro anywhere you need.
<img src="{asset "build/images/logo.svg"}" />
6 . Use relative path to your image in css
background-image: url('../images/background.jpg')