All assets for this project are compiled using Grunt and managed via Yarn. Developers modifying Javascript or SCSS/CSS assets should use the files located in workbench/resources
.
Files in modules/contentbox-admin/includes/
will be overwritten on compilation. Please use Gruntfile.js
to configure your asset distributions.
To setup your development environment, install NodeJS and run in the root of the project: box recipe workbench/setup.boxr
to install all dependencies. If not you will have to run these manually.
cd workbench
## Install Grunt-cli globally
npm install -g yarn grunt-cli
## Install assets
yarn install
To start Grunt compilation, run grunt
from the workbench directory. Directories and relevant files, along with the Gruntfile.js
, itself, will be watched for changes, which will recompile relevant assets.
The directory workbench/resources/scss
contains all of the SCSS theme files. Global variables used may be set in _globals.scss
.
All needed CSS from libraries are added via the cssmin
task.
Vendor CSS files are added into workbench/resources/vendor/css
.
The build process will produce a modules/contentbox-admin/includes/css/contentbox.min.css
according to the theme, vendor CSS.
ContentBox Libraries
All JS files in the workbench/resources/js
are the core ContentBox JavaScript libraries. They will all be minified and sent to a contentbox-pre.js
library.
Global Libraries
Two global libraries are created in ContentBox:
contentbox-pre.js
: Loaded in the<head>
sectioncontentbox-post.js
: Loaded after the<body>
section
Tip: Please look in the
Gruntfile.js
for determination of the libraries loading pre and post.
JavaScript libraries not managed by Yarn will be placed under the workbench/resources/vendor/js
folder and optimized by our build process into their appropriate global libraries.
To load an asset at Runtime, please use the prc.jsAppendList, prc.jsFullAppendList
and prc.cssAppendList, prc.cssFullAppendList
variables in your handlers.
Note: No extensions are required for each list.
The Full
lists are absolute or http locations, while the normal append lists are are relative to the module's css/js folder: /includes/js|css
:
// relative
prc.cssAppendList = "../plugins/morris/css/morris";
prc.jsAppendList = "../plugins/morris/js/raphael-min,../plugins/morris/js/morris.min";
// full
prc.jsFullList = "https://cdnjs.cloudflare.com/ajax/libs/mocha/2.4.5/mocha.min"
prc.cssFullList = "https://cdnjs.cloudflare.com/ajax/libs/mocha/2.4.5/mocha"
Plugins
Plugins which are used only for specific handler/actions, should be deployed as plugins. See the Grunt copy:plugins
task array for examples.
Warning: The following module directories are cleared on initial Grunt Startup and should not be used for development:
modules/contentbox-admin/includes/css
modules/contentbox-admin/includes/js
modules/contentbox-admin/includes/plugins
modules/contentbox-admin/includes/fonts