nav_order |
---|
3 |
{: .no_toc }
{: .no_toc .text-delta }
- TOC {:toc}
Webpack is a module bundler. Its main purpose is to bundle JavaScript files for usage in a browser, yet it is also capable of transforming, bundling, or packaging just about any resource or asset.
There are 2 different Loaders available which are using generated json
-files from Webpack:
WebpackManifestLoader
EncoreEntrypointsLoader
The webpack-manifest-plugin creates a manifest.json
-file in your root output directory with a mapping of all source file names to their corresponding output file, for example:
manifest.json
{
"script.js": "/public/path/script.23dafsf2138d.js",
"style.css": "style.23dafsf2138d.css",
"sub-folder/style.css": ""
}
To load this file in your application you can do following:
<?php
use Inpsyde\Assets\Loader\WebpackManifestLoader;
$loader = new WebpackManifestLoader();
/** @var \Inpsyde\Assets\Asset[] $assets */
$assets = $loader->load('manifest.json');
If the Asset URL needs to be changed, you can use following:
<?php
use Inpsyde\Assets\Loader\WebpackManifestLoader;
$loader = new WebpackManifestLoader();
$loader->withDirectoryUrl('www.example.com/path/to/assets/');
/** @var \Inpsyde\Assets\Asset[] $assets */
$assets = $loader->load('manifest.json');
Symfony Webpack Encore provides a custom implementation of the assets-webpack-plugin which groups asset chunks into a single array for a given handle.
The EncoreEntrypointsLoader
can load those configurations and automatically configure your dependencies for splitted chunks.
entrypoints.json
{
"entrypoints": {
"theme": {
"css": [
"./theme.css",
"./theme1.css",
"./theme2.css",
]
}
}
}
And loading this file:
<?php
use Inpsyde\Assets\Loader\EncoreEntrypointsLoader;
$loader = new EncoreEntrypointsLoader();
/** @var \Inpsyde\Assets\Asset[] $assets */
$assets = $loader->load('entrypoints.json');
$second = $assets[1]; // theme1.css
$second->dependencies(); // handle from $asset[0]
$third = $assets[2]; // theme2.css
$third->dependencies(); // handles from $asset[1] and $asset[2]
To create multiple Assets you can use following:
<?php
use Inpsyde\Assets\Loader\ArrayLoader;
use Inpsyde\Assets\Asset;
use Inpsyde\Assets\Script;
use Inpsyde\Assets\Style;
$config = [
[
'handle' => 'foo',
'url' => 'www.example.com/assets/style.css',
'location' => Asset::FRONTEND,
'type' => Style::class
],
[
'handle' => 'bar',
'url' => 'www.example.com/assets/bar.js',
'location' => Asset::FRONTEND,
'type' => Script::class
],
];
$loader = new ArrayLoader();
/** @var Asset[] $assets */
$assets = $loader->load($config);
If you want to avoid having large array configuration in your code, you can move everything to an external PHP-file which returns the array:
config/assets.php
<?php
use Inpsyde\Assets\Asset;
use Inpsyde\Assets\Script;
use Inpsyde\Assets\Style;
return [
[
'handle' => 'foo',
'url' => 'www.example.com/assets/style.css',
'location' => Asset::FRONTEND,
'type' => Style::class
],
[
'handle' => 'bar',
'url' => 'www.example.com/assets/bar.js',
'location' => Asset::FRONTEND,
'type' => Script::class
],
];
And in your application:
<?php
use Inpsyde\Assets\Loader\PhpFileLoader;
use Inpsyde\Assets\Asset;
$loader = new PhpFileLoader();
/** @var Asset[] $assets */
$assets = $loader->load('config/assets.php');
In webpack it is possible to configure file name versioning which will produce something like: script.{hash}.js
. To support versioning via file name you can simply disable the auto discovering of file versioning like this:
<?php
use Inpsyde\Assets\Loader\WebpackManifestLoader;
$loader = new WebpackManifestLoader();
$loader->disableAutodiscoverVersion();
/** @var \Inpsyde\Assets\Asset[] $assets */
$assets = $loader->load('manifest.json');