-
Notifications
You must be signed in to change notification settings - Fork 9
Expand file tree
/
Copy pathcompileBundle.js
More file actions
79 lines (71 loc) · 2.82 KB
/
Copy pathcompileBundle.js
File metadata and controls
79 lines (71 loc) · 2.82 KB
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
const Bluebird = require('bluebird')
const sassRender = Bluebird.promisify(require('node-sass').render)
const path = require('path')
const chalk = require('chalk')
const url = require('url')
const postcss = require('postcss')
const autoprefixer = require('autoprefixer')
const postcssUrl = require('postcss-url')
const CONFIG = require('./config')
const PATHS = CONFIG.paths
const SASS_STYLE = require('./sass_style')
const {fileChecksumSync} = require('./checksum')
const supportedBrowsers = require('./supportedBrowsers')
const cache = require('./cache')
const {relativeSassPath} = require('./utils')
function revedUrl (originalUrl, md5) {
let parsedUrl = url.parse(originalUrl)
const {dir, name, ext} = path.posix.parse(parsedUrl.pathname)
parsedUrl.pathname = `/dist${dir}/${name}-${md5}${ext}`
return url.format(parsedUrl)
}
function warn () {
console.error(chalk.yellow('brandable_css warning', ...arguments))
}
module.exports = async function compileBundle ({bundleName, variant}) {
const sassFile = path.join(PATHS.sass_dir, bundleName)
let includePaths = [PATHS.sass_dir, path.join(PATHS.sass_dir, 'variants', variant)]
let urlsFoundInCss = new Set()
function putMD5sInUrls (originalParsedUrl) {
const originalUrl = originalParsedUrl.url
const parsedUrl = url.parse(originalUrl)
if (!parsedUrl.pathname || parsedUrl.protocol === 'data:') {
return originalUrl
}
if (parsedUrl.host || parsedUrl.href.indexOf('//') === 0 || !parsedUrl.path) {
warn(bundleName, variant, 'has an external url() to:', originalUrl, 'that\'s not a problem but normally our css only links to files in our repo')
return originalUrl
}
const pathToFile = path.join(PATHS.public_dir, parsedUrl.pathname)
const relativePath = relativeSassPath(pathToFile)
let md5 = cache.file_checksums.data[relativePath]
if (!md5) {
md5 = fileChecksumSync(pathToFile)
if (!md5) {
warn(bundleName, variant, 'contains a url() to:', originalUrl, 'which doesn\'t exist on disk')
return originalUrl
}
cache.file_checksums.update(relativePath, md5)
}
urlsFoundInCss.add(pathToFile)
return revedUrl(originalUrl, md5)
}
const startTime = new Date()
const nodeSassResult = await sassRender({
file: sassFile,
includePaths: includePaths,
outputStyle: SASS_STYLE,
sourceComments: SASS_STYLE !== 'compressed',
sourceMap: false
})
const postcssResult = await postcss([
autoprefixer({browsers: supportedBrowsers}),
postcssUrl({url: putMD5sInUrls})
]).process(nodeSassResult.css, {from: sassFile})
postcssResult.warnings().forEach(warn)
console.warn(chalk.green('compiled', bundleName, variant, 'in'), new Date() - startTime, 'ms')
return {
css: postcssResult.css,
includedFiles: nodeSassResult.stats.includedFiles.concat([...urlsFoundInCss])
}
}