Yeoman generator that scaffolds out a Salesforce web app.
- Automagically deploy the
dist
folder to Force.com - CSS Autoprefixing
- Built-in preview server with LiveReload
- Automagically compile ES6 (with Babel) & Sass
- Automagically lint your scripts
- Automagically wire up your Bower components with grunt-wiredep.
- Awesome Image Optimization (via OptiPNG, pngquant, jpegtran and gifsicle)
- Mocha Unit Testing with PhantomJS
- Bootstrap for Sass (Optional)
- Leaner Modernizr builds (Optional)
For more information on what generator-webapp-sfdc
can do for you, take a look at the Grunt tasks used in our package.json
.
- Install:
npm install -g generator-webapp-sfdc
- Run:
yo webapp-sfdc
- Run
grunt
for building andgrunt serve
for preview* - Run
grunt deploy
for building and uploadingdist
as astatic resource
in Force.com
(HTML/CSS/JS/Images/etc)
Third-party dependencies are managed with grunt-wiredep. Add new dependencies using Bower and then run the Grunt task to load them:
$ bower install --save jquery
$ grunt wiredep
This works if the package author has followed the Bower spec. If the files are not automatically added to your source code, check with the package's repo for support and/or file an issue with them to have it updated.
To manually add dependencies, bower install --save depName
to get the files, then add a script
or style
tag to your index.html
or another appropriate place.
The components are installed in the root of the project at /bower_components
. To reference them from index.html, use src="bower_components"
or src="/bower_components"
. Treat the bower_components
directory as if it was a sibling to index.html
.
Testing Note: a project checked into source control and later checked out needs to have bower install
run from the test
folder as well as from the project root.
Note: grunt server
was used for previewing in earlier versions of the project, and has since been deprecated in favor of grunt serve
.
We have recipes for integrating other popular technologies like Compass.
-
--skip-install
Skips the automatic execution of
bower
andnpm
after scaffolding has finished. -
--test-framework=<framework>
Either
mocha
orjasmine
. Defaults tomocha
. -
--no-babel
Turn off Babel support.
See the contributing docs.
Note: We are regularly asked whether we can add or take away features. If a change is good enough to have a positive impact on all users, we are happy to consider it.
If not, generator-webapp
is fork-friendly and you can always maintain a custom version which you npm install && npm link
to continue using via yo webapp
or a name of your choosing.