1
1
mirror of https://github.com/primer/css.git synced 2024-12-25 15:14:59 +03:00
css/postcss.config.cjs

50 lines
1.5 KiB
JavaScript
Raw Normal View History

2021-10-02 02:22:30 +03:00
const autoprefixer = require('autoprefixer')
const sass = require('@csstools/postcss-sass')
2021-10-02 02:22:30 +03:00
const scss = require('postcss-scss')
const scssImport = require('postcss-import')
const { join } = require('path')
const path = require('path')
const fs = require('fs')
2021-10-02 02:22:30 +03:00
module.exports = {
map: {
sourcesContent: false,
annotation: true
},
customSyntax: scss,
2021-10-02 02:22:30 +03:00
parser: scss,
plugins: [
scssImport,
sass({
includePaths: [join(__dirname, 'node_modules')],
outputStyle: process.env.CSS_MINIFY === '0' ? 'expanded' : 'compressed'
}),
autoprefixer,
require('postcss-custom-properties-fallback')({
importFrom: [
() => {
const primitiveFallbacks = [
'color-fallbacks.json',
'base/size/size.json',
'base/typography/typography.json',
'functional/size/border.json',
'functional/size/breakpoints.json',
'functional/size/size-coarse.json',
'functional/size/size-fine.json',
'functional/size/size.json',
'functional/size/viewport.json',
'functional/typography/typography.json',
]
let customProperties = {}
for (const filePath of primitiveFallbacks) {
const fileData = fs.readFileSync(path.join(__dirname, './node_modules/@primer/primitives/tokens-next-private/fallbacks/', filePath), 'utf8')
customProperties = {...customProperties, ...JSON.parse(fileData)}
}
return { customProperties: customProperties };
}
]
}),
2021-10-02 02:22:30 +03:00
]
}