mirror of
https://github.com/status-im/consul.git
synced 2025-01-25 05:00:32 +00:00
62a66a32d7
* Use postcss instead of ember-cli-sass This will make it possible to work with tailwindcss. * configure postcss to compile sass * add "sub-app" css into app/styles tree * pin node@14 via volta Only used by people that use volta * Install tailwind and autoprefixer * Create tailwind config * Use tailwind via postcss * Fix: tailwind changes current styling When adding tailwind to the bottom of app.scss we apparently change the way the application looks. We will import it first to make sure we don't change the current styling of the application right now. * Automatic import of HDS colors in tailwind * Install @hashicorp/design-system-components * install add-on * setup postcss scss pipeline to include tokens css * import add-on css * Install ember-auto-import v2 HDS depends on v2 of ember-auto-import so we need to upgrade. * Upgrade ember-cli-yadda v0.6.0 of ember-cli-yadda adds configuration for webpack. This configuration is incompatible with webpack v5 which ember-auto-import v2 is using. We need to upgrade ember-cli-yadda to the latest version that fixes this incompatability with auto-import v2 * Install ember-flight-icons HDS components are using the addon internally. * Document HDS usage in engineering docs * Upgrade ember-cli-api-double * fix new linting errors
46 lines
1.5 KiB
JavaScript
46 lines
1.5 KiB
JavaScript
/**
|
|
* A function that parses the `tokens.css`-file from `@hashicorp/design-system-tokens`
|
|
* and creates a map out of it that can be used to build up a color configuration
|
|
* in `tailwind.config.js`.
|
|
*
|
|
* @param {string} tokensPath - The path to `tokens.css` from `@hashicorp/design-system-tokens`
|
|
* @returns { { [string]: string } } An object that contains color names as keys and color values as values.
|
|
*/
|
|
function colorMapFromTokens(tokensPath) {
|
|
const css = require('css');
|
|
const path = require('path');
|
|
const fs = require('fs');
|
|
|
|
const hdsTokensPath = path.join(__dirname, tokensPath);
|
|
|
|
const tokensFile = fs.readFileSync(hdsTokensPath, {
|
|
encoding: 'utf8',
|
|
flag: 'r',
|
|
});
|
|
|
|
const ast = css.parse(tokensFile);
|
|
const rootVars = ast.stylesheet.rules.filter((r) => r.type !== 'comment')[0];
|
|
|
|
// filter out all colors and then create a map out of them
|
|
const vars = rootVars.declarations.filter((d) => d.type !== 'comment');
|
|
const colorPropertyNameCleanupRegex = /^--token-color-(palette-)?/;
|
|
const colors = vars.filter((d) => d.property.match(/^--token-color-/));
|
|
|
|
return colors.reduce((acc, d) => {
|
|
acc[d.property.replace(colorPropertyNameCleanupRegex, 'hds-')] = d.value;
|
|
return acc;
|
|
}, {});
|
|
}
|
|
|
|
/** @type {import('tailwindcss').Config} */
|
|
module.exports = {
|
|
content: ['./app/**/*.{html,js,hbs,mdx}', './docs/**/*.{html,js,hbs,mdx}'],
|
|
theme: {
|
|
colors: colorMapFromTokens(
|
|
'../../node_modules/@hashicorp/design-system-tokens/dist/products/css/tokens.css'
|
|
),
|
|
extend: {},
|
|
},
|
|
plugins: [],
|
|
};
|