Now this repository has been migrated to react-router v7 by releasing the new library nest-react-router, nestjs-remix will be maintained synchronously for a period of time and will be completely deprecated in the future, you can continue to use nestjs-remix, but please note that there are some minor changes.
before | after |
---|---|
handleByRemix | handleByReactRouter |
remixArgs | reactRouterArgs |
remixParams | reactRouterParams |
before | after |
---|---|
RemixArgs | ReactRouterArgs |
import { Loader, Action, useServer } from "nest-react-router";
@Injectable()
export class IndexBackend {
constructor(private readonly appService: AppService) {}
@Loader()
loader(@Req() req: Request, @Query("name") name?: string) {
return this.appService.getHello();
}
@Action()
action(@Body() body: LoginDto) {
return {};
}
@Action.Patch()
patch() {
return "[patch]: returned by server side";
}
@Action.Delete()
delete() {
return "[delete]: returned by server side";
}
}
export const useIndexServer = useServer(IndexBackend);
import {
type IndexBackend,
useIndexServer,
} from './server/index.server';
import {
useActionData,
useLoaderData,
} from 'nest-react-router/client';
export const loader: LoaderFunction = (args) => {
return useIndexServer(args);
};
export const action: ActionFunction = (args) => {
return useIndexServer(args);
};
export default function Index() {
const data = useLoaderData<IndexBackend>();
const actionData = useActionData<IndexBackend>();
return <div>{data.message}</div>
}
For more detailed usage, please refer to Example
git clone https://github.com/JinYuSha0/nest-remix.git
yarn install
yarn start:dev
# If you want to try to get data from microservice
yarn start:dev:microservice
yarn add nest-react-router
import { Module } from "@nestjs/common";
import { resolve } from "path";
import { resolveReactRouterServices } from "nest-react-router";
@Module({
imports: [],
controllers: [AppController],
providers: [
AppService,
...resolveReactRouterServices(resolve("dist/routes/server")),
],
})
export class AppModule {}
Please note that the path is the path after build, not the source code path
import { startNestReactRouter } from "nest-react-router";
async function bootstrap() {
const app = await NestFactory.create<NestApplication>(AppModule);
// ...
await startNestReactRouter(app);
await app.listen(3000);
}
bootstrap();
"scripts": {
"build": "concurrently \"npm run build:nest\" \"npm run build:react-router\" -n \"NEST,REACT-ROUTER\"",
"start": "nest start",
"start:dev": "cross-env NODE_ENV=development concurrently \"npm run start:dev:nest\" -n \"NEST\"",
"start:prod": "cross-env NODE_ENV=production node dist/main",
"build:nest": "rimraf dist && nest build -p tsconfig.nest.json",
"build:react-router": "rimraf build && react-router build",
"start:dev:nest": "rimraf dist && nest start --watch -p tsconfig.nest.json"
}
[vite] Error when evaluating SSR module /src/routes/server/xxx.server.ts: failed to import "nest-react-router"
Modify vite.config.mts
ssr: {
noExternal: process.env.NODE_ENV === 'development'
? ['nest-react-router', /* ... */] // add this
: [/* ... */],
},
useloaderdata must be used within a data router
Modify vite.config.mts
ssr: {
noExternal: process.env.NODE_ENV === 'development'
? ['nest-react-router', /* ... */] // add this
: [/* ... */],
},