rsnext/packages/next/build/webpack/loaders/next-flight-client-entry-loader.ts
Tobias Koppers 9c41634104
fix next-app-loader on windows (#39657)
## Bug

- [x] Related issues linked using `fixes #number`
- [ ] Integration tests added
- [ ] Errors have helpful link attached, see `contributing.md`


Co-authored-by: JJ Kasper <22380829+ijjk@users.noreply.github.com>
Co-authored-by: Jiachi Liu <4800338+huozhi@users.noreply.github.com>
2022-08-17 17:14:03 +00:00

41 lines
1.1 KiB
TypeScript

export type ClientComponentImports = string[]
export type CssImports = Record<string, string[]>
export type NextFlightClientEntryLoaderOptions = {
modules: ClientComponentImports
/** This is transmitted as a string to `getOptions` */
server: boolean | 'true' | 'false'
}
export default async function transformSource(this: any): Promise<string> {
let { modules, server }: NextFlightClientEntryLoaderOptions =
this.getOptions()
const isServer = server === 'true'
if (!Array.isArray(modules)) {
modules = modules ? [modules] : []
}
const requests = modules as string[]
const code =
requests
// Filter out css files on the server
.filter((request) => (isServer ? !request.endsWith('.css') : true))
.map((request) =>
request.endsWith('.css')
? `(() => import(/* webpackMode: "lazy" */ ${JSON.stringify(
request
)}))`
: `import(/* webpackMode: "eager" */ ${JSON.stringify(request)})`
)
.join(';\n') +
`
export const __next_rsc__ = {
server: false,
__webpack_require__
};
export default function RSC() {};
`
return code
}