Integrate the Assetic asset management framework into your TYPO3 CMS installation.
composer require cundd/assetic
- Include the static TypoScript files
- Configure the assets you want to be loaded
plugin.CunddAssetic {
stylesheets {
custom_identifier_for_the_asset = fileadmin/stylesheets/style.css
}
}
plugin.CunddAssetic {
stylesheets {
identifier_for_asset_1 = fileadmin/stylesheets/reset.css
identifier_for_asset_2 = fileadmin/stylesheets/style.css
}
}
If your web server and web user are configured to be able to use the sass
command line tool, from within your TYPO3 installation, you could use the following:
plugin.CunddAssetic {
stylesheets {
custom_identifier_for_the_asset = fileadmin/bootstrap/lib/bootstrap.scss
}
}
Analog you can use other CSS preprocessors. The Assetic Github Page provides a (incomplete) list of all filters provided with the installed Assetic version.
To make sure that the assets are compiled each time the frontend page is refreshed, you can enable the development mode:
plugin.CunddAssetic {
development = 1
}
By default Cundd Assetic is configured not to compile files if NO backend user is logged in. To allow file compilation without a logged in backend user you can change the allow_compile_without_login
configuration, in TypoScript or the Constant editor.
plugin.CunddAssetic {
allow_compile_without_login = 1
}
Some filters allow futher customization. The Sass filter e.g. provides the method addImportPath
which enables you to add another path to look for imported scss files. Cundd Assetic provides an interface to invoke such functions through TypoScript.
plugin.CunddAssetic.stylesheets.custom_identifier_for_the_asset {
### Add functions that will be called on the filter
functions {
addImportPath = fileadmin/local/sass/
}
}
If you want to invoke a method multiple times you can just add a numeric prefix to the function name:
plugin.CunddAssetic.stylesheets.custom_identifier_for_the_asset {
functions {
# Add a numeric prefix to allow the function to called multiple times
0-addImportPath = fileadmin/local/sass/
1-addImportPath = fileadmin/core/sass/
}
}
In some cases you may have to specify the path to a CSS preprocessor to match your system's configuration. This can be done through the filter_binaries
directive in TypoScript:
plugin.CunddAssetic {
filter_binaries {
# Change the path to the filter binaries. I.e. if node.js is installed
# into /usr/local/bin/
assetic_filter_lessfilter = /usr/local/bin/node
# The binary for filter class \Assetic\Filter\Sass\ScssFilter
assetic_filter_sass_scssfilter = /usr/local/bin/sass
}
}
Assetic provides three different CLI commands.
Compiles the assets and exit.
vendor/bin/typo3 assetic:run
Watches for file changes in fileadmin/ and re-compiles the assets if needed.
vendor/bin/typo3 assetic:watch
Starts a LiveReload compatible server that watches for file changes in fileadmin/ and re-compiles the assets if needed. The TypoScript constant module.tx_assetic.settings.livereload.add_javascript
should be set to 1.
vendor/bin/typo3 assetic:livereload
Cundd Assetic provides a JavaScript that observes the CSS and JavaScript assets on the page for changes and automatically reloads them. For more information and usage visit /Resources/Public/JavaScript.