mirror of
				https://github.com/Wan-Video/Wan2.1.git
				synced 2025-11-04 06:15:17 +00:00 
			
		
		
		
	This commit adds a production-ready Progressive Web App for AI-powered video generation using Wan2.1 models. Features: - Next.js 15 frontend with App Router and PWA support - FastAPI backend with Replicate integration - 50+ prompt templates across 7 categories - Supabase authentication and database - Credit system with usage tracking - Text-to-Video and Image-to-Video generation - Complete documentation (setup, deployment, contributing) Project Structure: - apps/web: Next.js frontend with shadcn/ui components - apps/api: FastAPI backend with GPU processing via Replicate - packages/db: Database schema and migrations for Supabase Tech Stack: - Frontend: Next.js 15, shadcn/ui, Tailwind, Zustand, React Hook Form, Zod - Backend: FastAPI, Replicate, Supabase - Database: Supabase (Postgres) with RLS - Infrastructure: Turborepo monorepo, Vercel/Modal deployment Documentation: - README.md: Project overview and features - SETUP.md: Complete setup guide (5-minute quickstart) - DEPLOYMENT.md: Production deployment instructions - CONTRIBUTING.md: Contribution guidelines - PROJECT_SUMMARY.md: Comprehensive project documentation Ready for development and deployment. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
		
			
				
	
	
		
			55 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			55 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
/** @type {import('tailwindcss').Config} */
 | 
						|
module.exports = {
 | 
						|
  darkMode: ["class"],
 | 
						|
  content: [
 | 
						|
    "./src/pages/**/*.{js,ts,jsx,tsx,mdx}",
 | 
						|
    "./src/components/**/*.{js,ts,jsx,tsx,mdx}",
 | 
						|
    "./src/app/**/*.{js,ts,jsx,tsx,mdx}",
 | 
						|
  ],
 | 
						|
  theme: {
 | 
						|
    extend: {
 | 
						|
      colors: {
 | 
						|
        border: "hsl(var(--border))",
 | 
						|
        input: "hsl(var(--input))",
 | 
						|
        ring: "hsl(var(--ring))",
 | 
						|
        background: "hsl(var(--background))",
 | 
						|
        foreground: "hsl(var(--foreground))",
 | 
						|
        primary: {
 | 
						|
          DEFAULT: "hsl(var(--primary))",
 | 
						|
          foreground: "hsl(var(--primary-foreground))",
 | 
						|
        },
 | 
						|
        secondary: {
 | 
						|
          DEFAULT: "hsl(var(--secondary))",
 | 
						|
          foreground: "hsl(var(--secondary-foreground))",
 | 
						|
        },
 | 
						|
        destructive: {
 | 
						|
          DEFAULT: "hsl(var(--destructive))",
 | 
						|
          foreground: "hsl(var(--destructive-foreground))",
 | 
						|
        },
 | 
						|
        muted: {
 | 
						|
          DEFAULT: "hsl(var(--muted))",
 | 
						|
          foreground: "hsl(var(--muted-foreground))",
 | 
						|
        },
 | 
						|
        accent: {
 | 
						|
          DEFAULT: "hsl(var(--accent))",
 | 
						|
          foreground: "hsl(var(--accent-foreground))",
 | 
						|
        },
 | 
						|
        popover: {
 | 
						|
          DEFAULT: "hsl(var(--popover))",
 | 
						|
          foreground: "hsl(var(--popover-foreground))",
 | 
						|
        },
 | 
						|
        card: {
 | 
						|
          DEFAULT: "hsl(var(--card))",
 | 
						|
          foreground: "hsl(var(--card-foreground))",
 | 
						|
        },
 | 
						|
      },
 | 
						|
      borderRadius: {
 | 
						|
        lg: "var(--radius)",
 | 
						|
        md: "calc(var(--radius) - 2px)",
 | 
						|
        sm: "calc(var(--radius) - 4px)",
 | 
						|
      },
 | 
						|
    },
 | 
						|
  },
 | 
						|
  plugins: [require("tailwindcss-animate")],
 | 
						|
}
 |