odan / plates-asset-cache
Caching and compression for Plates template assets (JavaScript and CSS).
Installs: 2 441
Dependents: 0
Suggesters: 1
Security: 0
Stars: 5
Watchers: 1
Forks: 1
Open Issues: 3
Requires
- php: ^7.3 || ^8.0
- mrclay/jsmin-php: ^2
- symfony/cache: ^5
- tubalmartin/cssmin: ^4
Requires (Dev)
This package is auto-updated.
Last update: 2021-10-21 17:09:04 UTC
README
Caching and compression for Plates template assets (JavaScript and CSS).
Installation
composer require odan/plates-asset-cache
Requirements
- PHP 7.3+ or 8.0+
Configuration
use League\Plates\Engine; use Odan\PlatesAsset\AssetEngine; use Odan\PlatesAsset\PlatesAssetExtension; use Symfony\Component\Cache\Adapter\FilesystemAdapter; $engine = new Engine('/path/with/html/templates'); $options = [ // Public assets cache directory 'path' => '/var/www/example.com/htdocs/public/assets/cache', // Public cache directory permissions (octal) // You need to prefix mode with a zero (0) // Use -1 to disable chmod 'path_chmod' => 0750, // The public url base path 'url_base_path' => 'assets/cache/', // Internal cache settings // // The main cache directory // Use '' (empty string) to disable the internal cache 'cache_path' => '/var/www/example.com/htdocs/temp', // Used as the subdirectory of the cache_path directory, // where cache items will be stored 'cache_name' => 'assets-cache', // The lifetime (in seconds) for cache items // With a value 0 causing items to be stored indefinitely 'cache_lifetime' => 0, // Enable JavaScript and CSS compression // 1 = on, 0 = off 'minify' => 1 ]; // Register asset extension $engine->loadExtension(new PlatesAssetExtension(new AssetEngine($engine, $options)));
Usage
The page template
Template file: index.php
<?php /** @var League\Plates\Template\Template $this */ ?> <!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8"> <base href="<?= $baseUrl; ?>" /> <title>Demo</title> <?= $this->assets(['default.css', 'print.css'], ['inline' => true]); ?> </head> <body> <!-- content --> <!-- JavaScript assets --> <?= $this->assets(['mylib.js', 'page.js']); ?> </body> </html>
Render a template
$engine = new League\Plates\Engine('/path/to/templates'); echo $engine->render('index', ['baseUrl' => '']);
The result
<!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8"> <base href="" /> <title>Demo</title> <style></style> <style>@media print{.noprint{display:none}.navbar{visibility:hidden;display:none}.container{width:99%}.table{table-layout:fixed;width:99%;max-width:99%}}</style></head> <body> <!-- content --> <!-- JavaScript assets --> <script src="assets/file.3dd5380c0b893eea8a14e30ce5bfa4cb9aab011b.js"></script></body> </html>
Parameters
- Parameter: $assets
Name | Type | Default | Required | Description |
---|---|---|---|---|
files | array | [] | yes | All assets (files) to be delivered to the browser. Plates Folders (myalias::myfile.js ) are also supported. |
- Parameter: $options
Name | Type | Default | Required | Description |
---|---|---|---|---|
inline | bool | false | no | Defines whether the browser downloads the assets inline or via URL. |
minify | bool | true | no | Specifies whether JS/CSS compression is enabled or disabled. |
name | string | file | no | Defines the output file name within the URL. |
Slim 4 integration
For this example we use the PHP-DI package.
Add the container definition:
<?php use League\Plates\Engine; use Odan\PlatesAsset\PlatesAssetExtension; use Psr\Container\ContainerInterface; use Slim\App; // ... return [ // ... Engine::class => function (ContainerInterface $container) { $settings = $container->get('settings'); $viewPath = $settings['plates']['path']; $engine = new Engine($viewPath); // The public url base path $baseUrl = $container->get(App::class)->getBasePath(); $engine->addData(['baseUrl' => $baseUrl]); $options['url_base_path'] = $basePath; $engine->loadExtension(new PlatesAssetExtension(new AssetEngine($engine, $options))); return $engine; }, ];
Render the template and write content to the response stream:
$response->withHeader('Content-Type', 'text/html; charset=utf-8'); $response->getBody()->write($this->engine->render($name, $viewData)); return $response;
License
The MIT License (MIT). Please see License File for more information.