sensiolabs / minify-bundle
Assets Minifier (CSS, JS) for Symfony & Minify integration in Asset Mapper
Installs: 2 421
Dependents: 0
Suggesters: 0
Security: 0
Stars: 37
Watchers: 4
Forks: 7
Open Issues: 1
Type:symfony-bundle
Requires
- php: >=8.2
- psr/log: ^2|^3
- symfony/filesystem: ^6.4|^7.0
- symfony/http-client-contracts: ^3.5
- symfony/process: ^6.4|^7.0
Requires (Dev)
- phpstan/phpstan: ^1.12
- phpunit/phpunit: ^10.5
- symfony/asset-mapper: ^6.4|^7.0
- symfony/console: ^6.4|^7.0
- symfony/framework-bundle: ^6.4|^7.0
- symfony/http-client: ^6.4|^7.0
- symfony/http-kernel: ^6.4|^7.0
README
composer require sensiolabs/minify-bundle
Minify integration
SensioLabs Minify Bundle integrates Minify into Symfony Asset Mapper.
Asset Minifier
✅ Minify CSS
and JS
files, remove whitespace, comments, and more..
🌍 Reduces the size of your assets by up to 70%
(see metrics below).
🚀 Improves the loading time of your website, and the user experience
.
Asset Mapper
🎯 Automatically minify
assets during the build process.
📦 Stores minified assets in the Symfony cache
.
🌿 Download the Minify binary automatically
from Github.
Minification
JavaScript
Even gzip compression is more efficient on minified assets (see metrics below).
See transfer comparison (gzip)
CSS
See transfer comparison (gzip)
Installation
Make sure Composer is installed globally, as explained in the installation chapter of the Composer documentation.
With Symfony Flex
Open a command console, enter your project directory and execute:
composer require sensiolabs/minify-bundle
Without Symfony Flex
How to install without Symfony Flex
Step 1: Download the Bundle
Open a command console, enter your project directory and execute the following command to download the latest stable version of this bundle:
composer require sensiolabs/minify-bundle
Step 2: Enable the Bundle
Then, enable the bundle by adding it to the list of registered bundles
in the config/bundles.php
file of your project:
// config/bundles.php return [ // ... Sensiolabs\MinifyBundle\SensiolabsMinifyBundle::class => ['all' => true], ];
Depending on your deployment process, you might want to enable the bundle only in the desired environment(s).
Usage
If you use AssetMapper, run the following command to minify all the assets:
php bin/console asset-map:compile
This command is usually run when serving assets in production and the SensioLabs Minify Bundle will hook into it to minify all assets while copying them.
Command Line
You can also minify assets manually with the command line. First, make sure that the binary file used to minify assets is properly installed in your computer:
php bin/console minify:install
Then, run the following command to minify assets:
# this outputs the result in the console php bin/console minify:asset css/main.css # this will write the output into the 'main.min.css' file # (the given output file is created / overwritten if needed) php bin/console minify:asset css/main.css css/main.min.css
Configuration
AssetMapper
# config/packages/sensiolabs_minify.yaml sensiolabs_minify: asset_mapper: # you can minify only CSS files, only JS files or both types: css: true # (default: true) js: true # (default: true) # a list of assets to exclude from minification (default: []) # the values of the list can be any shell wildcard patterns ignore_paths: - 'admin/*' - '*.min.js' # whether to exclude the assets stored in vendor/ from minification; # these assets are usually pre-minified, so it's common to exclude them ignore_vendor: true # (default: true)
Minify Binary
Local binary
The minification is performed by a binary file that can be installed on your computer/server or downloaded automatically by the bundle. This is the default configuration used by the bundle:
# config/packages/sensiolabs_minify.yaml sensiolabs_minify: # ... minify: # this disables the usage of local binaries local_binary: false # if TRUE, the bundle will download the binary from GitHub download_binary: '%kernel.debug%' # the local path where the downloaded binary is stored download_directory: '%kernel.project_dir%/var/minify'
You can customize this configuration to use a local binary:
# config/packages/sensiolabs_minify.yaml sensiolabs_minify: # ... minify: # set it to 'auto' to let the bundle try to find the location of the binary local_binary: 'auto' # you can also define the path to the binary explicitly, but this won't work # if you run the application in multiple servers with different binary locations local_binary: "/usr/local/bin/minify"
Credits
Authors
- MinifyBundle: Simon André & SensioLabs
- Minify binary: Timo Dewolf
Acknowledgments
This bundle is inspired by the following projects:
- SassBundle from @SymfonyCasts
- BiomejsBundle from @Kocal
- TypeScriptBundle from @SensioLabs
Contributors
Special thanks to the Symfony community for their contributions and feedback.
License
The SensioLabs Minify Bundle is released under the MIT license.