UNPKG

@tanstack/router-plugin

Version:

Modern and scalable routing for React applications

93 lines (82 loc) 2.72 kB
import { getConfig } from '@tanstack/router-generator' import { unpluginRouterGeneratorFactory } from './router-generator-plugin' import { unpluginRouterCodeSplitterFactory } from './router-code-splitter-plugin' import { unpluginRouterHmrFactory } from './router-hmr-plugin' import type { Config } from './config' import type { RspackCompiler, UnpluginFactory, UnpluginOptions, WebpackCompiler, } from 'unplugin' const INLINE_CSS_DEFAULT_DEFINES = { 'process.env.TSS_INLINE_CSS_ENABLED': JSON.stringify('false'), 'import.meta.env.TSS_INLINE_CSS_ENABLED': JSON.stringify('false'), } type EsbuildOptionsWithDefine = Parameters< NonNullable<NonNullable<UnpluginOptions['esbuild']>['config']> >[0] function applyWebpackInlineCssDefaultDefinePlugin(compiler: WebpackCompiler) { new compiler.webpack.DefinePlugin(INLINE_CSS_DEFAULT_DEFINES).apply(compiler) } function applyRspackInlineCssDefaultDefinePlugin(compiler: RspackCompiler) { new compiler.webpack.DefinePlugin(INLINE_CSS_DEFAULT_DEFINES).apply(compiler) } export const unpluginRouterComposedFactory: UnpluginFactory< Partial<Config | (() => Config)> | undefined > = (options = {}, meta) => { const ROOT: string = process.cwd() const userConfig = getConfig( (typeof options === 'function' ? options() : options) as Partial<Config>, ROOT, ) const getPlugin = ( pluginFactory: UnpluginFactory<Partial<Config | (() => Config)>>, ) => { const plugin = pluginFactory(options, meta) if (!Array.isArray(plugin)) { return [plugin] } return plugin } const routerGenerator = getPlugin(unpluginRouterGeneratorFactory) const routerCodeSplitter = getPlugin(unpluginRouterCodeSplitterFactory) const result = [ { name: 'tanstack:router-inline-css-defaults', vite: { config() { return { define: { ...INLINE_CSS_DEFAULT_DEFINES, }, } }, }, webpack(compiler: WebpackCompiler) { applyWebpackInlineCssDefaultDefinePlugin(compiler) }, rspack(compiler: RspackCompiler) { applyRspackInlineCssDefaultDefinePlugin(compiler) }, esbuild: { config(options: EsbuildOptionsWithDefine) { options.define = { ...INLINE_CSS_DEFAULT_DEFINES, ...options.define, } }, }, }, ...routerGenerator, ] if (userConfig.autoCodeSplitting) { result.push(...routerCodeSplitter) } const isProduction = process.env.NODE_ENV === 'production' if (!isProduction && !userConfig.autoCodeSplitting) { const routerHmr = getPlugin(unpluginRouterHmrFactory) result.push(...routerHmr) } return result }