https://github.com/amanvarshney01/bookipedia
  
  
     
    https://github.com/amanvarshney01/bookipedia
  
        Last synced: 4 months ago 
        JSON representation
    
- Host: GitHub
- URL: https://github.com/amanvarshney01/bookipedia
- Owner: AmanVarshney01
- License: mit
- Created: 2025-01-18T06:58:51.000Z (9 months ago)
- Default Branch: master
- Last Pushed: 2025-01-20T16:23:20.000Z (9 months ago)
- Last Synced: 2025-06-20T21:23:19.640Z (4 months ago)
- Language: TypeScript
- Size: 79.1 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
- 
            Metadata Files:
            - Readme: README.md
- License: LICENSE
 
Awesome Lists containing this project
README
          # T-Rex Stack 🦖
A fully type-safe full-stack TypeScript template featuring tRPC, React Router v7, Express, Prisma and MongoDB.
## 🚀 Tech Stack
### Frontend
- 📝 TypeScript
- ⚛️ React 19
- 🛣️ React Router v7
- 🎨 TailwindCSS
- 🎯 shadcn/ui components
- 🔄 TanStack Query
- 🔒 better-auth for authentication
- 📡 tRPC client
- 🎯 Type-safe forms with react-hook-form & zod
### Backend
- 📝 TypeScript
- 📡 Express.js
- 🗄️ MongoDB (with Docker Compose)
- 🔗 Prisma ORM
- 🔒 better-auth
- 📨 tRPC server
- 📐 Zod for runtime type validation
## ✨ Type Safety Features
- End-to-end type safety with TypeScript and tRPC
- Type-safe database queries with Prisma
- Type-safe API routes and validators
- Type-safe forms and validations
- Automated type generation for API endpoints
## 🛠️ Prerequisites
- Node.js 18+
- Docker and Docker Compose
- pnpm (recommended) or npm
## 🏃♂️ Getting Started
1. Clone the repository:
```bash
git clone https://github.com/amanvarshney01/t-rex-stack.git
cd t-rex-stack
```
2. Install dependencies:
```bash
# Install server dependencies
cd server
pnpm install
# Install client dependencies
cd ../client
pnpm install
```
3. Set up MongoDB:
```bash
# Start MongoDB container
cd server
docker-compose up -d
```
4. Set up your environment variables:
```bash
# Server
cd server
cp .env.example .env
# Client
cd ../client
cp .env.example .env
```
5. Initialize the database:
```bash
cd server
pnpm db:push
```
6. Start the development servers:
```bash
# Terminal 1 - Start the backend
cd server
pnpm dev
# Terminal 2 - Start the frontend
cd client
pnpm dev
```
## 📝 Scripts
### Server
```bash
pnpm dev        # Start development server
pnpm build      # Build for production
pnpm db:push    # Push schema changes to database
pnpm db:studio  # Open Prisma Studio
```
### Client
```bash
pnpm dev        # Start development server
pnpm build      # Build for production
pnpm start      # Start production server
pnpm typecheck  # Type check the application
```