import { fileURLToPath, pathToFileURL } from 'node:url' import { requireModule, tryResolveModule } from '@nuxt/kit' import type { Nuxt, NuxtOptions } from '@nuxt/schema' import type { InlineConfig as ViteConfig } from 'vite' import { interopDefault } from 'mlly' import type { Plugin } from 'postcss' function sortPlugins ({ plugins, order }: NuxtOptions['postcss']): string[] { const names = Object.keys(plugins) return typeof order === 'function' ? order(names) : (order || names) } export async function resolveCSSOptions (nuxt: Nuxt): Promise { const css: ViteConfig['css'] & { postcss: NonNullable['postcss'], string>> } = { postcss: { plugins: [], }, } css.postcss.plugins = [] const postcssOptions = nuxt.options.postcss const cwd = fileURLToPath(new URL('.', import.meta.url)) for (const pluginName of sortPlugins(postcssOptions)) { const pluginOptions = postcssOptions.plugins[pluginName] if (!pluginOptions) { continue } const path = await tryResolveModule(pluginName, nuxt.options.modulesDir) let pluginFn: (opts: Record) => Plugin // TODO: use jiti v2 if (path) { pluginFn = await import(pathToFileURL(path).href).then(interopDefault) } else { console.warn(`[nuxt] could not import postcss plugin \`${pluginName}\` with ESM. Please report this as a bug.`) // fall back to cjs pluginFn = requireModule(pluginName, { paths: [cwd] }) } if (typeof pluginFn === 'function') { css.postcss.plugins.push(pluginFn(pluginOptions)) } } return css }