A parser for Vite manifest files.
Table of contents
composer require idleberg/vite-manifest
To get you going, first instantiate the class exposed by this library.
new Manifest(string $manifestPath, string $baseUri, string $algorithm = "sha256");
Type: string
Specifies the path to the manifest.
Type: string
Specifies the base URI for the assets in the manifest.
Type: "sha256"
|"sha384"
|"sha512"
| ":manifest:"
Default: "sha256"
Specifies the algorithm used for hashing the assets. This will be used can be used for subsource integrity when printing script or style tags. You can use ":manifest:"
in conjunction with vite-plugin-manifest-sri, a plug-in that calculates the hashes at build-time and adds them to the manifest.
Example
use Idleberg\ViteManifest\Manifest;
$baseUrl = "https://idleberg.github.io";
$manifest = "path/to/manifest.json";
$vm = new Manifest($manifest, $baseUrl);
Usage: getManifest()
Returns the contents of the manifest file as a PHP array.
Usage: getEntrypoint(string $entrypoint, bool $hash = true)
Example
$entrypoint = $vm->getEntrypoint("index.ts");
if ($entrypoint) {
["url" => $url, "hash" => $hash] = $entrypoint;
echo "<script type='module' src='$url' crossorigin integrity='$hash'></script>" . PHP_EOL;
}
Usage: getEntrypoints()
Returns all entrypoints from the manifest.
Usage: getImports(string $entrypoint, bool $hash = true)
Returns imports for a file listed in the manifest.
Example
foreach ($vm->getImports("index.ts", false) as $import) {
["url" => $url] = $import;
echo "<link rel='modulepreload' href='$url' />" . PHP_EOL;
}
Usage: getStyles(string $entrypoint, bool $hash = true)
Returns stylesheets for a file listed in the manifest.
Example
foreach ($vm->getStyles("index.ts") as $style) {
["url" => $url, "hash" => $hash] = $style;
echo "<link rel='stylesheet' href='$url' crossorigin integrity='$hash' />" . PHP_EOL;
}
This work is licensed under The MIT License.