WebJarVer
This package is intended to be used in projects having a Java backend that use Maven for build and WebJars to handle Javascript libraries. WebJars pack Javascript libraries in paths which include the version number of the library like this:
It's also necessary to have the version number in the pom dependency:
org.webjars angularjs 1.3.14
This setup allows to run a Grunt server with Livereload and a proxy during development, but requires to keep the version numbers in at least two diferent files.
To avoid problems with unsynchronized version numbers, I choose to let Maven handle it. Version numbers are written as properties in the pom and Maven resource filtering takes care of replacing their references in HTML files that reference the libraries.
Dependencies in pom.xml are written like this:
1.3.14 org.webjars angularjs ${angularjs.version}
The Javascript library can be referenced as such:
It also necessary to include a filtering configuration in pom.xml. This example assumes that webapp static resources are at src/main/resources/public following one of Spring Boot's conventions:
src/main/resources false src/main/resources/public true **/*.html
Installation
Install like any other npm package:
npm install webjarver
Usage
In Gruntfile. js, the middleware property of livereload middleware function should load pom.xml and insert WebJarVer in the middleware array.
Here is an example:
grunt;
Roadmap
- Convert into a Grunt task to reload version numbers when watch detects a pom.xml change.
- Add a task to integrate into Grunt build.
Change Log
- 1.0.0 - initial release. Connect middleware to be used with LiveReload.