Skip to content

Commit

Permalink
[vite] Allow package authors to specify packages to include in vite (#…
Browse files Browse the repository at this point in the history
  • Loading branch information
brijeshb42 authored Jul 10, 2024
1 parent 86ee5ee commit b7cda5f
Showing 1 changed file with 56 additions and 7 deletions.
63 changes: 56 additions & 7 deletions packages/pigment-css-vite-plugin/src/index.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import * as path from 'node:path';
import type { Plugin } from 'vite';
import type { Plugin, UserConfig } from 'vite';
import {
preprocessor as basePreprocessor,
generateTokenCss,
Expand All @@ -17,6 +17,14 @@ export interface PigmentOptions extends Omit<VitePluginOptions, 'themeArgs'> {
theme?: Theme;
}

type PigmentMeta = {
'pigment-css'?: {
vite?: {
include: string[];
};
};
};

const VIRTUAL_CSS_FILE = `\0zero-runtime-styles.css`;
const VIRTUAL_THEME_FILE = `\0zero-runtime-theme.js`;

Expand All @@ -37,6 +45,8 @@ function isZeroRuntimeProcessableFile(fileName: string, transformLibraries: stri
);
}

const MATERIAL_WRAPPER_LIB = '@mui/material-pigment-css';

export function pigment(options: PigmentOptions) {
const {
theme,
Expand All @@ -47,13 +57,13 @@ export function pigment(options: PigmentOptions) {
css,
...rest
} = options ?? {};
const finalTransformLibraries = transformLibraries
.concat([process.env.RUNTIME_PACKAGE_NAME as string, '@mui/material-pigment-css'])
.map((lib) => lib.split('/').join(path.sep));
const defaultLibs = [process.env.RUNTIME_PACKAGE_NAME as string, MATERIAL_WRAPPER_LIB];
const allLibs = transformLibraries.concat(defaultLibs);
const finalTransformLibraries = allLibs.map((lib) => lib.split('/').join(path.sep));

function injectMUITokensPlugin(): Plugin {
return {
name: 'vite-mui-theme-injection-plugin',
name: 'pigment-css-theme-injection-plugin',
enforce: 'pre',
resolveId(source) {
if (finalTransformLibraries.some((lib) => source.includes(`${lib}/styles.css`))) {
Expand All @@ -78,7 +88,7 @@ export function pigment(options: PigmentOptions) {

function intermediateBabelPlugin(): Plugin {
return {
name: 'vite-mui-zero-intermediate-plugin',
name: 'pigment-css-sx-plugin',
enforce: 'post',
async transform(code, id) {
const [filename] = id.split('?');
Expand All @@ -104,6 +114,40 @@ export function pigment(options: PigmentOptions) {
};
}

function updateConfigPlugin(): Plugin {
return {
name: 'pigment-css-config-plugin',
config() {
const includes: Array<string> = [];
allLibs.forEach((lib) => {
try {
// eslint-disable-next-line import/no-dynamic-require, global-require
const pkg = require(`${lib}/package.json`) as PigmentMeta;
const pkgIncludes = pkg['pigment-css']?.vite?.include ?? [];
if (pkgIncludes.length > 0) {
includes.push(...pkgIncludes);
}
} catch (ex) {
if (lib !== MATERIAL_WRAPPER_LIB) {
console.warn(
`${process.env.PACKAGE_NAME}: You have specified "${lib}" in "transformLibraries" but it is not installed.`,
);
}
}
});
const optimizeDeps: UserConfig['optimizeDeps'] = {
exclude: allLibs,
};
if (includes.length) {
optimizeDeps.include = includes;
}
return {
optimizeDeps,
};
},
};
}

const withRtl = (selector: string, cssText: string) => {
return basePreprocessor(selector, cssText, css);
};
Expand All @@ -128,7 +172,12 @@ export function pigment(options: PigmentOptions) {
...rest,
});

return [injectMUITokensPlugin(), transformSx ? intermediateBabelPlugin() : null, zeroPlugin];
return [
updateConfigPlugin(),
injectMUITokensPlugin(),
transformSx ? intermediateBabelPlugin() : null,
zeroPlugin,
];
}

export { extendTheme };

0 comments on commit b7cda5f

Please sign in to comment.