const cssvariables = require("postcss-css-variables"); const flexbugsFixes = require("postcss-flexbugs-fixes"); const compileVariables = require("./scripts/postcss/css-compile-variables"); const urlVariables = require("./scripts/postcss/css-url-to-variables"); const urlProcessor = require("./scripts/postcss/css-url-processor"); const fs = require("fs"); const path = require("path"); const manifest = require("./package.json"); const version = manifest.version; const compiledVariables = new Map(); import {buildColorizedSVG as replacer} from "./scripts/postcss/svg-builder.mjs"; import {derive} from "./src/platform/web/theming/shared/color.mjs"; const commonOptions = { logLevel: "warn", publicDir: false, server: { hmr: false }, resolve: { alias: { // these should only be imported by the base-x package in any runtime code // and works in the browser with a Uint8Array shim, // rather than including a ton of polyfill code "safe-buffer": "./scripts/package-overrides/safe-buffer/index.js", "buffer": "./scripts/package-overrides/buffer/index.js", } }, build: { emptyOutDir: true, assetsInlineLimit: 0, polyfillModulePreload: false, }, assetsInclude: ['**/config.json'], define: { DEFINE_VERSION: JSON.stringify(version), DEFINE_GLOBAL_HASH: JSON.stringify(null), }, css: { postcss: { plugins: [ compileVariables({derive, compiledVariables}), urlVariables({compiledVariables}), urlProcessor({replacer}), // cssvariables({ // preserve: (declaration) => { // return declaration.value.indexOf("var(--ios-") == 0; // } // }), // the grid option creates some source fragment that causes the vite warning reporter to crash because // it wants to log a warning on a line that does not exist in the source fragment. // autoprefixer({overrideBrowserslist: ["IE 11"], grid: "no-autoplace"}), flexbugsFixes() ] } } }; module.exports = { commonOptions, compiledVariables };