Skip to content

hugsmidjan/hxmgulp

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

HxmGulp

Default gulp tasks for Hugsmiðjan's projects.

Install:

npm install --save-dev gulp
npm install --save-dev github:hugsmidjan/hxmgulp#semver:^2

Usage:

In your project's skin folder create a gulpfile.js containing this command:

var gulp = require('gulp');
require('hxmgulp')(gulp, options);

then isolate all your HTML-demo, JavaScript and LESS/SCSS and image/icon source files inside the _src/ subfolder, and start gulp.

gulp

That's it!

Skin Options (and their defaults):

The options support the following properties (and defaults):

  • src: '_src' - path to the root source folder.

  • dist: '.' - path to the root distribution folder where the compiled/minified CSS and JS files are saved.

  • Feature flags:

    • $minimal: false - Setting this to true turns off all features by default.
    • do_css: true - Render Stylus/LESS.
    • do_scripts: true - Minify, ES6 transpile and Browserify JavaScripts.
    • do_images: true - Minify/Compress images.
    • do_iconfont: true - Convert SVGs to an icon-font.
    • do_htmltests: true - Render nunjucks templates to static files.
    • do_htmltestsscripts: true - ES6 transpile and Browserify JavaScripts inside the htmltests folder.
  • modules: ['/'] - Array of (sub)folder names (Strings) or { src, dist, [feature-flags] } objects.

    • 'foo/' processes files within the folder options.src + '/foo/' and saves the output into options.dist + '/foo/'.
    • { src:'foo/', dist:'../bar/baz/'} would however, save the output files into options.dist + '/../bar/baz/'.
    • Any feature flags (see above) override the default flags for this module only.
  • cssProc: 'styl' - type of CSS preporcessor being used. Currently valid options are 'styl', 'scss' and 'less'

  • js_suffixSource: '-source' - file-name suffix for unminified JavaScript files.

  • js_suffixMin: undefined - file-name suffix for minified JavaScript files.

  • svg_keepIds: false - Should the SVG minifier keep id="" attributes intact. – this can also be controlled on a per-file level with a ---ids.svg suffix.

  • task: undefined - optional function which then gets run once for each item in the modules array. Example:

tasks: function (moduleInfo, gulp) {
    // moduleInfo.name === the current module (i.e. (sub)folder)
    // moduleInfo.paths === paths config for the current module
    // moduleInfo.basePathCfg === A good default options object for gulp.task()
    // moduleInfo.module === Normalized version of the current module
    gulp.task('mytask', function(){ ... });
    return { build:['mytask'], watch:null };
  }
  • browserifyOpts: undefined - object with options for browserify

  • browserify: undefined - optional function to run (and configure) browserify. Example:

    browserify: function (filename, moduleInfo, browserify) {
        // moduleInfo.name === the current module (i.e. (sub)folder)
        // moduleInfo.paths === paths config for the current module
        // moduleInfo.basePathCfg === A good default options object for gulp.task()
        // moduleInfo.module === Normalized version of the current module
        var b = browserify();
        b.require([{ file:'foobar.js', expose:'foobar' }]);
        b.external(['react']);
        return b;
      }

  • cssBrowserSupport: ... - Array of Strings with custom browser-support config for Autoprefixer.

  • copyrightYear: (new Date()).getFullYear() - Starting year for the copyright clauses at the top of minified files.

  • copyrightInfo: 'Hugsmiðjan ehf. (www.hugsmidjan.is)' - text that appears after "Copyright 20XX-20YY ..." in the copyright clause.


Features

All operations are performed within the "sources-folder" defined by options.src.

All rendering/compilation/minification results are saved under options.dist - with path- and file-names preseerved from their "source" counterpart.

options.modules contains a list of folders (and subfolders, and sub-subfolders) that each should be searched for files and watched for file-changes. All modules behave the same.

(Turtles all the way down...)

CSS files

Any .styl file placed directly inside the source folder gets rendered to a (lightly) minified CSS file with the same name inside the dist folder.

.styl files within the _styl/ folder are watched for changes and trigger rerendering of SCSS files both within this "module" and all "submodules"

(NOTE: if options.cssProc is set to 'less' or 'scss' then replace all the above instances of "styl" with "less" or "scss" respectively.)

CSS data URIs

any CSS url() that ends with #datauri is automatically resolved and base64 encoded as an inline data URI in the rendered CSS file. Example:

.box { background-image: url(i/stripes.png#datauri); }

becomes:

.box { background-image: url(...); }

JavaScripts

Any .js file placed directly inside the source folder gets rendered to a minified JavaScript file with the same name inside the dist folder. (An unminified version is also saved with the suffix -source.js.)

.js files within the _js/ folder are watched for changes and trigger rerendering of JavaScript files both within this "module" and all "submodules".

All naked references to console.[log|error|warn|etc...]() are converted to undefined during minification, to avoid accidental console.logging in production code. Logging on production is still available as opt-in, either through indirection ((i.e. var konsole = console; konsole.log('Hi');), or via window-property access (i.e. window.console.log('Hi');).

All scripts are run through the babel-preset-es2015 so using that subset es6 features is allowed.

Additionally: Any JavaScript file with the suffix -common.js is passed through browserify. The -common suffix is then stripped off.

HTML test pages

The _tests/ folder contains static .htm page templates using [nunjucks][1] syntax. Any subfolder structure is retained during rendering.

*.htm partials inside _tests/incl/ are also watched and trigger rerendering of the page templates in the base _tests/ folder.

Any files inside _tests/media/ are copied over (and lightly minified).

All JavaScripts are copied over (unless they're in a folder called _js) and browserified if their filename end with -common.js.

NOTE: there's a special case for page-templates with filenames with double-extensions. Those files become rooted in the options.dist folder itself, and have their ".htm" extension chopped off. Example:

_src/_tests/homepage.htm
_src/_tests/section/page.htm     <-- note subfolder

_src/_tests/foobar.jsp.htm       <-- note double extension
_src/_tests/subfoo/baz.json.htm  <-- note subfolder

...get rendered as:

./_tests/homepage.html      <-- HTML demo/tests folder
./_tests/section/page.html  <-- note subfolder

./foobar.jsp                <-- options.dist root folder
./subfoo/baz.json           <-- subfolder preserved

Icon fonts

Any SVG icons placed in iconfont automatically converted into a web-font (eot, ttf, woff, svg) with human-friendly filename-based JSON object saved in in {options.dist}/i/icons.json for quick import in Stylus using json('../../dist/i/icons.json').

For projects using LESS (or SCSS) the variables are also written to the file _less/_iconVars.less (or _scss/_iconVars.scss).

NOTE: SVG files inside the folder iconfont/_raw/ are ignored as alternative designs and raw-materials for properly normalized icons.

Images

Files placed inside i/ are automatically copied to the corresponding dist folder. JPG, GIF, SVG and PNG files are passed through a lossless minimizer to remove comments, color-profiles, thumbnails and other unwanted meta-data.

PNG and JPEG images can be forced through a lossy compression via a ---q{N} file-name suffix. The suffix is stripped from the filename before saving in the dist folder.

In SVG files all ID attributes are stripped away unless a svg_keepIds: true option is passed, or if an individual SVG file has a ---ids file-name suffix - which then gets stripped away before saving.

Examples:

  • src/i/photo---q60.jpg (100% quality original) ---> dist/i/photo.png (recompressed to approx. 60% quality)
  • src/i/image---q50.png (24bit file) ---> dist/i/image.png (png8 with at least 50% quality)
  • src/i/image---q50-70.png (24bit file) ---> dist/i/image.png (png8 with between 50% and 70% quality)
  • src/i/image---q50--d0.png (24bit file) ---> dist/i/image.png (png8 with at least 50% quality - no dithering)
  • src/i/image---ids.svg (keep ID attributes) ---> dist/i/image.svg (with ID attributes intact)

NOTE: Any images placed in the folder i/_raw/ are ignored as raw-materials.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Packages

No packages published