This repository was archived by the owner on Mar 3, 2026. It is now read-only.
Commit 47653e3
committed
Asset module fix jooby-project#192
The asset module is library to concatenate, minify or compress JavaScript and CSS assets. It also adds the ability to write these assets in other languages and process/compile them to another language. Finally, it help you to write high quality code by validate JavaScript and CSS too.
A variety of processors are available (jshint, csslint, jscs, uglify, closure-compiler, etc..), but also you might want to write your owns.
```xml
<dependency>
<groupId>org.jooby</groupId>
<artifactId>jooby-assets</artifactId>
<version>{{version}}</version>
</dependency>
```
The first thing you need to do is to define your assets. Definition is done in your ```.conf``` file or in a special file: ```assets.conf```.
**assets.conf**
```properties
assets {
fileset {
home: [assets/home.js, assets/home.css]
}
}
```
**App.java**
```java
{
use(new Assets());
}
```
The assets module will publish 4 request local variables for ```home``` fileset: ```_css``` and ```_js``` each of these variables is a list of string with the corresponding files. There are two more variables: ```_styles``` and ```_scripts``` :
```html
<html>
<head>
{{{home_styles}}}
<body>
...
{{{home_scripts}}
</body>
</head>
</html>
```
The variables: ```_styles``` and ```_scripts``` produces one ore more ```link``` and ```script``` tags. The example above, shows you how to render these variables in the template engine of your choice (handlebars, here).
Now, let's see how to configure the Maven plugin to process our assets at build-time:
**pom.xml**
```html
<plugin>
<groupId>org.jooby</groupId>
<artifactId>jooby-maven-plugin</artifactId>
<executions>
<execution>
<goals>
<goal>assets</goal>
</goals>
</execution>
</executions>
</plugin>
```
The plugin will process all your assets and include them to the final ```.jar```, ```.zip``` or ```.war```.
Cool, isn't?
The ```assets.fileset``` defines all your assets. In ```dev``` assets are rendered/processed at runtime. In ```prod``` at built-time.
Assets are rendered at runtime using ```*_styles``` or ```*_scripts ``` variables. So you define your assets in one single place: ```assets.conf```.
Also, at build-time, the asset compiler concatenates all the files from a fileset and generate a fingerprint. The fingerprint is a SHA-1 hash of the content of the fileset. Thanks to the fingerprint an asset can be cached it for ever! Defaults cache max age is: ```365 days```.
That isn't all! the ```*_styles``` and ```*_scripts``` are updated with the fingerprint version of assets, so you don't have to do or change anything in your views! It just works!!!
A fileset is a group of assets within a name. The fileset name is expanded into 4 request local variables, for example:
```properties
assets {
fileset {
home: [assets/home.js, assets/home.css]
pageA: [assets/pageA.js, assets/pageA.css]
}
}
```
Produces 4 variables for ```home```:
* home_css: a list of all the ```css``` files
* home_styles: a string, with all the ```css``` files rendered as ```link``` tags
* home_js: a list of all the ```js``` files
* home_scripts: a string, with all the ```js``` files rendered as ```script``` tags
Another 4 variables will be available for the ```pageA``` fileset!
Extension or re-use of filesets is possible via the: ```<``` operator:
```properties
assets {
fileset {
base: [js/lib/jquery.js, css/normalize.css]
home < base: [js/home.js]
pageA < base: [js/pageA.js]
}
}
```
An [AssetProcessor]({{defdocs}}/assets/AssetProcessor.html) usually checks or modify an asset content in one way or another. They are defined in the ```assets.conf``` files using the ```pipeline``` construction:
```properties
assets {
fileset {
home: [js/home.js, css/home.css]
}
pipeline {
dev: [jshint, jscs, csslint, sass]
dist: [uglify, sass, clean-css]
}
}
```
Example above, defines a **pipeline** for development (dev) and one generic for prod (dist).
In ```dev``` the code will be checked it against js-hint, jscs and csslint! But also, we want to use sass for css!!
The generic ```dist``` will be used it for any other environment and here we just want to optimize our javascript code with uglify, compile sass to css and then optimize the css using clean-css!!1 parent 78a98ca commit 47653e3
File tree
299 files changed
+304592
-46
lines changed- coverage-report
- src/test
- java/org/jooby/assets
- resources/org/jooby/assets
- css
- js
- jooby-assets-clean-css
- src
- main
- java/org/jooby/assets
- resources
- lib
- test
- java/org/jooby/assets
- resources
- jooby-assets-closure-compiler
- src
- main/java/org/jooby/assets
- test
- java/org/jooby/assets
- resources
- jooby-assets-csslint
- src
- main
- java/org/jooby/assets
- resources
- lib
- test/java/org/jooby/assets
- jooby-assets-j2v8
- src/main/java/org/jooby/assets
- jooby-assets-jscs
- src
- main
- java/org/jooby/assets
- resources
- lib
- test/java/org/jooby/assets
- jooby-assets-jshint
- src
- main
- java/org/jooby/assets
- resources
- lib
- test/java/org/jooby/assets
- jooby-assets-less4j
- src
- main
- java/org/jooby/assets
- resources
- lib
- test
- java/org/jooby/assets
- resources
- css
- jooby-assets-less
- src
- main
- java/org/jooby/assets
- resources
- lib
- test
- java/org/jooby/assets
- resources
- css
- jooby-assets-ng-annotate
- src
- main
- java/org/jooby/assets
- resources
- lib
- test/java/org/jooby/assets
- jooby-assets-requirejs
- src
- main
- java/org/jooby/assets
- resources
- lib
- test
- java/org/jooby/assets
- resources
- scripts
- jooby-assets-sass
- src
- main
- java/org/jooby/assets
- resources
- ruby
- gems/sass-3.4.18
- lib
- sass
- cache_stores
- exec
- importers
- logger
- plugin
- script
- tree
- value
- scss
- selector
- source
- tree
- visitors
- util
- specifications
- test
- java/org/jooby/assets
- resources
- assets/css
- relative
- jooby-assets-uglify
- src
- main
- java/org/jooby/assets
- resources
- lib
- test/java/org/jooby/assets
- jooby-assets-yui-compressor
- src
- main/java/org/jooby/assets
- test/java/org/jooby/assets
- jooby-assets
- src
- main/java/org/jooby/assets
- test
- java/org/jooby/assets
- resources
- assets
- lib
- jooby-dist/src/main/resources/assemblies
- jooby-maven-plugin
- src/main/java/org/jooby
- jooby/src
- main
- java/org/jooby
- handlers
- internal
- resources/org/jooby
- test/java/org/jooby
- md
- doc
- assets-clean-css
- assets-closure-compiler
- assets-csslint
- assets-jscs
- assets-less4j
- assets-less
- assets-ng-annotate
- assets-requirejs
- assets-sass
- assets-uglify
- assets-yui-compressor
- assets
Some content is hidden
Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.
299 files changed
+304592
-46
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
62 | 62 | | |
63 | 63 | | |
64 | 64 | | |
| 65 | + | |
65 | 66 | | |
66 | 67 | | |
67 | 68 | | |
| |||
102 | 103 | | |
103 | 104 | | |
104 | 105 | | |
| 106 | + | |
105 | 107 | | |
106 | 108 | | |
107 | 109 | | |
| |||
116 | 118 | | |
117 | 119 | | |
118 | 120 | | |
| 121 | + | |
| 122 | + | |
| 123 | + | |
119 | 124 | | |
120 | 125 | | |
121 | 126 | | |
| |||
364 | 369 | | |
365 | 370 | | |
366 | 371 | | |
| 372 | + | |
| 373 | + | |
| 374 | + | |
| 375 | + | |
| 376 | + | |
| 377 | + | |
367 | 378 | | |
368 | 379 | | |
369 | 380 | | |
| |||
Lines changed: 32 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
Lines changed: 39 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
Lines changed: 3 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
Lines changed: 4 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
Lines changed: 2 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
Lines changed: 82 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
0 commit comments