forked from Wikia/design-system
-
Notifications
You must be signed in to change notification settings - Fork 0
/
ember-cli-build.js
105 lines (97 loc) · 2.67 KB
/
ember-cli-build.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
'use strict';
const EmberAddon = require('ember-cli/lib/broccoli/ember-addon');
const Funnel = require('broccoli-funnel');
const SvgStore = require('broccoli-svgstore');
module.exports = function(defaults) {
const inlineScriptsPath = 'vendor/inline-scripts';
var app = new EmberAddon(defaults, {
autoprefixer: {
cascade: false,
map: false,
remove: false
},
fingerprint: {
enabled: false
},
inlineContent: {
'tracking-queue-stub': `${inlineScriptsPath}/tracking-queue-stub.js`,
},
snippetPaths: ['tests/dummy/snippets'],
snippetSearchPaths: ['tests/dummy/app'],
snippetRegexes: {
begin: /<Demo[^}]+@name="(\S+)"/,
end: /<\/Demo>/,
},
includeFileExtensionInSnippetNames: false,
includeHighlightStyle: false,
includeHighlightJS: false,
outputPaths: {
app: {
css: {
'app': '/assets/design-system.css',
// This one is copied after build to /dist for use by other apps, see postBuildCopy below
'wds': '/assets/wds.css'
}
}
},
postBuildCopy: [
{
src: '/assets/wds.css',
dest: 'dist/css/styles.css',
enabled: EmberAddon.env() === 'production'
},
{
src: '/svg/*.svg',
dest: 'dist/svg/',
enabled: EmberAddon.env() === 'production'
}
],
sassOptions: {
includePaths: [
'style-guide/styles',
'node_modules/highlight.js/styles'
]
},
vendorFiles: { 'jquery.js': null }
});
var additionalTrees = [];
if (app.env === 'production') {
// We build separate SVG files just for the /dist
// Don't waste resources during development
additionalTrees.push(new Funnel('style-guide/assets', {
include: ['*.svg'],
destDir: 'svg'
}));
}
additionalTrees.push(SvgStore('style-guide/assets', {
outputFile: '/svg/sprite.svg',
svgstoreOpts: {
inline: true,
svgAttrs: {
style: 'position: absolute; width: 0; height: 0;',
width: '0',
height: '0',
version: '1.1',
xmlns: 'http://www.w3.org/2000/svg',
'xmlns:xlink': 'http://www.w3.org/1999/xlink'
}
}
}));
additionalTrees.push(new Funnel('i18n', {
include: ['**/*.json'],
destDir: 'assets/i18n'
}));
// Use `app.import` to add additional libraries to the generated
// output files.
//
// If you need to use different assets in different
// environments, specify an object as the first parameter. That
// object's keys should be the environment name and the values
// should be the asset to use in that environment.
//
// If the library that you are including contains AMD or ES6
// modules that you would like to import into your application
// please specify an object with the list of modules as keys
// along with the exports of each module as its value.
return app.toTree(additionalTrees);
};