This is a monorepo setup using pnpm workspaces with two Next.js applications that demonstrate remote components functionality.
- Runs on port 3000
- Contains a counter with sync provider
- Has a link to the remote component
- Runs on port 4000
- Serves remote components
- Has a counter component at
/remote-components/counter
- ✅ pnpm workspaces monorepo setup
- ✅ Two Next.js applications (web, components)
- ✅
remote-componentsdependency added to both apps - ✅
withRemoteComponentsconfiguration in bothnext.config.tsfiles - ✅ Web app runs on port 3000
- ✅ Components app runs on port 4000
- ✅ Remote components route at
/remote-components/counter - ✅ Counter with sync provider functionality using
remote-componentsshared modules - ✅ Counter state managed by a provider in the web app
- ✅ Confetti animation on counter increment only in the web app counter provider implementation
pnpm install# Run both apps simultaneously
pnpm dev
# Or run individually:
pnpm dev:web # Web app on port 3000
pnpm dev:components # Components app on port 4000pnpm build # Build both apps
pnpm build:web # Build web app only
pnpm build:components # Build components app onlyStart applications in production mode
# Run both apps simultaneously
pnpm start
# Or run individually:
pnpm start:web # Web app on port 3000
pnpm start:components # Components app on port 4000- Start both applications using
pnpm dev - Visit the web app at http://localhost:3000
- Use the counter controls to change the state
- Next.js 15 - React framework
- TypeScript - Type safety
- Tailwind CSS - Styling
- pnpm - Package manager and workspace manager
- remote-components - Remote component functionality