ember-sprite
Version:
An ember addon which generates sprite sheets
107 lines (85 loc) • 2.74 kB
JavaScript
/* eslint-env node */
;
const Funnel = require('broccoli-funnel');
const brocMergeTrees = require('broccoli-merge-trees');
const concat = require('broccoli-concat');
const brocSprite = require('broccoli-sprite');
const util = require('util');
module.exports = {
name: 'ember-sprite',
treeFor: treeFor,
postprocessTree: postprocessTree,
_processSprite: _processSprite,
};
function treeFor( /*inTree*/ ) {}
function getAppCSSOutputPath(options) {
let appCssOutputPath = options.outputPaths.app.css.app;
if(appCssOutputPath[0] === '/' ){
appCssOutputPath = appCssOutputPath.substr(1);
}
return appCssOutputPath;
}
function postprocessTree(type, workingTree) {
if (type === 'all' && this.app.options.sprite) {
let self = this;
// retrieves the app CSS output path
const appCssOutputPath = getAppCSSOutputPath(this.app.options);
// for backwards compatibility to previous implementation that
// passed plain object into sprite,
// we push that object into an array we can iterate through to
// process the sprite(s)
if (Object.prototype.toString.call(this.app.options.sprite) ===
'[object Object]') {
let tmp = this.app.options.sprite;
this.app.options.sprite = [];
this.app.options.sprite.push(tmp);
}
// process each of the sprites that was passed in
this.app.options.sprite.forEach(function eachSprite(sprite) {
workingTree = self._processSprite(sprite, workingTree, appCssOutputPath);
});
}
return workingTree;
}
function _processSprite(sprite, workingTree, appCssOutputPath) {
let spriteTree = new Funnel(workingTree, {
srcDir: '/',
destDir: '/',
include: [
...sprite.src
],
});
if (!!sprite.debug) {
console.log('spriteTree', util.inspect(workingTree, false, 6, true));
}
spriteTree = brocSprite(spriteTree, sprite);
workingTree = brocMergeTrees([
workingTree,
spriteTree
]);
//sprites.css is appended to app.css,
//so that two separate styles sheets do not need to get linked from index.html
let spriteCssFile = sprite.stylesheetPath;
let treeConcatCss = concat(workingTree, {
inputFiles: [
appCssOutputPath,
spriteCssFile
],
outputFile: "/" + appCssOutputPath
});
workingTree = brocMergeTrees([
workingTree,
treeConcatCss
], {
overwrite: true,
});
if (sprite.removeSrcFiles) {
workingTree = new Funnel(workingTree, {
exclude: [
spriteCssFile,
...sprite.src
]
});
}
return workingTree;
}