A modern web application for managing your Pokémon card collection with AI-powered card scanning and identification.
- 🤖 AI Card Scanning: Use Gemini Vision to automatically identify Pokémon cards from photos
- ✨ AI Card Generation: Create custom Pokémon cards using Google Imagen4
- 🎬 AI Video Generation: Bring your cards to life with animated videos using Google Veo 2.0
- 📸 Photo-to-Card: Transform your own photos into Pokemon cards using AI image generation
- 🔐 Secure Authentication: Firebase Authentication with email and Google login
- 📱 Responsive Design: Modern UI built with Next.js and Tailwind CSS
- 💾 Cloud Storage: Real-time data synchronization with Firestore
- ✏️ CRUD Operations: Create, read, update, and delete cards in your collection
- 🎯 Type Safety: Full TypeScript implementation for better development experience
graph TB
subgraph "Frontend"
A[Next.js 15] --> B[React 18]
B --> C[TypeScript]
C --> D[Tailwind CSS]
D --> E[Radix UI Components]
B --> F[React Hook Form]
F --> G[Zod Validation]
end
subgraph "Backend Services"
H[Firebase Auth] --> I[Google Authentication]
J[Firestore Database] --> K[Real-time Updates]
L[Gemini AI] --> M[Vision API]
M --> N[Card Recognition]
O[Google Veo 2.0] --> P[Video Generation]
P --> Q[Card Animation]
end
subgraph "Development Tools"
O[Genkit AI Framework] --> P[AI Flow Management]
Q[ESLint] --> R[Code Quality]
S[PostCSS] --> T[CSS Processing]
end
A --> H
A --> J
A --> L
A --> O
O --> L
src/
├── ai/
│ └── flows/
│ ├── scan-pokemon-card.ts # AI card scanning logic
│ ├── generate-pokemon-card.ts # AI card generation logic
│ ├── generate-pokemon-card-from-photo.ts # Photo-to-card logic
│ └── generate-card-video.ts # AI video generation logic
├── app/
│ ├── dashboard/
│ │ ├── collection/ # Card collection pages
│ │ └── scan/ # Card scanning page
│ └── page.tsx # Root page with auth routing
├── components/
│ ├── cards/
│ │ ├── CardForm.tsx # Reusable card form
│ │ ├── CardItem.tsx # Individual card display
│ │ └── CardScanner.tsx # AI scanning component
│ └── ui/ # Reusable UI components
├── hooks/
│ └── useAuth.tsx # Authentication hook
├── lib/
│ ├── firebase.ts # Firebase configuration
│ └── firestore.ts # Database operations
└── types/
└── index.ts # TypeScript type definitions
- Node.js 18+
- Firebase project with Firestore and Authentication enabled
- Google AI API key for Gemini Vision, Imagen4, and Veo 2.0
- OpenAI API key for DALL-E 3 and GPT-4o (for photo-based card generation)
- Clone the repository:
git clone <repository-url>
cd cardex- Install dependencies:
npm install- Set up environment variables:
# Create .env.local file with:
NEXT_PUBLIC_FIREBASE_API_KEY=your_firebase_api_key
NEXT_PUBLIC_FIREBASE_AUTH_DOMAIN=your_project.firebaseapp.com
NEXT_PUBLIC_FIREBASE_PROJECT_ID=your_project_id
NEXT_PUBLIC_FIREBASE_STORAGE_BUCKET=your_project.appspot.com
NEXT_PUBLIC_FIREBASE_MESSAGING_SENDER_ID=your_sender_id
NEXT_PUBLIC_FIREBASE_APP_ID=your_app_id
GOOGLE_GENAI_API_KEY=your_gemini_api_key
OPENAI_API_KEY=your_openai_api_key- Run the development server:
npm run dev- (Optional) Start the Genkit AI development server:
npm run genkit:dev- Navigate to the scan page
- Upload a photo of your Pokémon card
- Click "Scan Card" to identify the card using AI
- Review and edit the detected information
- Save the card to your collection
- Navigate to the generate page
- Fill out the card parameters:
- Pokemon name and type
- Card properties (Full Art, Holographic)
- Descriptions for the Pokemon and background
- Language and optional stats
- Click "Generate Pokemon Card" to create a custom card using AI
- Preview the generated card
- Save it to your collection if you like it
- Navigate to the "Photo Card" page
- Upload a reference photo that will inspire the card design
- Fill out the Pokemon details:
- Pokemon name and type
- Style description explaining how to adapt the photo
- Card properties and optional stats
- Click "Generate Pokemon Card from Photo" to create a card using your photo as reference
- Preview the generated card that combines your photo's style with Pokemon card design
- Save it to your collection
- Navigate to any card in your collection
- Click "Make Card Live" to generate an animated video
- The AI will create a 5-second video where:
- The Pokemon comes to life and moves within the card frame
- Sparkles, glowing effects, and type-specific elemental effects are added
- The background has subtle movement and atmospheric effects
- The card maintains a gentle holographic shimmer
- Video generation may take several minutes - the page will refresh automatically
- Once complete, you can:
- Play the video directly in the card view
- Download the video to your device
- Share the animated card with others
- View all your cards in a responsive grid layout
- Edit card details by clicking on any card
- Delete cards from your collection
- Cards are automatically sorted by last updated date
Firestore Collection: users/{userId}/pokemon_cards/{cardId}
├── name: string
├── set: string
├── rarity: string
├── imageUrl: string (Firebase Storage URL)
├── videoUrl?: string (Firebase Storage URL for animated video)
├── videoGenerationStatus?: 'generating' | 'completed' | 'failed'
├── videoPrompt?: string (AI prompt used for video generation)
├── userId: string
├── createdAt: timestamp
└── updatedAt: timestamp
Firebase Storage Structure:
/users/{userId}/cards/{sanitized_card_name}_{timestamp}.png
/users/{userId}/videos/{sanitized_card_name}_{timestamp}.mp4
The app uses multiple AI services through the Genkit framework:
- Gemini Vision API: Analyze uploaded card images and extract card information
- Imagen4: Generate custom Pokemon card artwork based on user parameters
- Google Veo 2.0: Create animated videos of Pokemon cards with magical effects and movements
- OpenAI DALL-E 3: Generate Pokemon cards based on reference photos with advanced image analysis
- GPT-4o: Analyze reference photos to extract visual elements for enhanced card generation
- Provide structured data for user review and confirmation
- Fork the repository
- Create a feature branch (
git checkout -b feature/amazing-feature) - Commit your changes (
git commit -m 'Add amazing feature') - Push to the branch (
git push origin feature/amazing-feature) - Open a Pull Request
npm run dev- Start development server with Turbopacknpm run build- Build for productionnpm run start- Start production servernpm run lint- Run ESLintnpm run typecheck- Run TypeScript type checkingnpm run genkit:dev- Start Genkit AI development servernpm run genkit:watch- Start Genkit with file watching
For support and questions, please open an issue in the repository.