This is an app for the Elefant CMS that pre-compiles and compresses Javascript and CSS using the Assetic library.
It also supports compiling the following formats
- SASS -> CSS (.sass files)
- LESS -> CSS (.less files)
- CoffeeScript -> Javascript (.cs or .coffee files)
- Handlebars -> Compiled templates
- Drop this app into your
apps/
folder. - Open the file
apps/assetic/conf/config.php
and set the paths to your compressors/compilers of choice (SASS, CoffeeScript, Handlebars, etc).
By default, it will use JSMinPlus for JavaScript compression and CSSMin for CSS compression. Other options include UglifyJS2/UglifyCSS, and YUI Compressor.
To use Assetic on a single script:
<script src="{# assetic/js/my_script.js #}"></script>
This will output something like:
<script src="/cache/assetic/js_my_script.js?v=12"></script>
Similarly, you can do the same with CSS files:
<link rel="stylesheet" link="{# assetic/css/style.css #}" />
Will produce:
<link rel="styelsheet" link="/cache/assetic/css_style.css?v=12" />
To use Assetic on several scripts or stylesheets at a time:
<head>
{# assetic/myscripts?js[]=js/jquery.js&js[]=js/jquery.verify_values.js #}
</head>
This will produce:
<script src="/cache/assetic/myscripts.js?v=12"></script>
Note: Change
myscripts
to the name to use to save the cache file as. Otherwise,all.js
will be used.
File lists can also be written over multiple lines, like this:
<head>
{# assetic/myscripts
?js[]=js/jquery.js
&js[]=js/jquery.verify_values.js #}
</head>
To regenerate the scripts, log into Elefant and go to Tools > Assetic
and
click Recompile Assets
. This will change the modification time on all templates,
so that they are regenerated the next time they are run in the browser.
The ?v=
number will also regenerate so that browsers will automatically
use the latest version at all times.
For development, you can also change the tags to use Elefant's {! !}
tags instead,
which will load the Assetic compilation process anew on each request:
<script src="{! assetic/js/my_script.js !}"></script>
It is smart enough to not regenerate the cache if the original files haven't changed, to reduce page load times during development.
The {# #}
template tag will render the scripts the first time the layout is loaded
and hard-code the resulting HTML into the template for subsequent requests, so the
handler is only called the first time. This makes this plugin very fast for
serving your optimized CSS and Javascript, since after the first load, the
compiled scripts are called directly, bypassing the plugin entirely for subsequent
requests.
You can achieve additional optimization by enabling GZIP output in your web server configuration.
To precompile your Handlebars templates for faster execution on the client-side, which also includes only the much smaller Handlebars runtime without the compiler, follow these steps:
1. Save your Handlebars templates with a .handlebars
file extension in your app's views folder.
For example:
<!-- apps/myapp/views/hello.handlebars -->
<p>Hello {{name}}</p>
2. Include the following tag in your layout template to precompile them:
{! assetic/handlebars !}
3. After the above include has compiled the templates, you can include them via:
<script src="/cache/assetic/handlebars.compiled.js"></script>
This also includes the Handlebars runtime, minus the compiler, for you.
4. To call a template, simply refer to it like this:
<script>
$('#my-div').html (Handlebars.templates.my_template (data));
</script>
Alternately, you can run the Handlebars compiler from the command line like this:
$ cd /path/to/your/website
$ ./elefant assetic/handlebars
This replaces step 2 from the above, but note that you'll need to call it again
whenever you modify a template, or run it with the --auto
option to watch for
template changes and automatically recompile them:
$ cd /path/to/your/website
$ ./elefant assetic/handlebars --auto