Vai al contenuto principale

Panoramica

Il boilerplate minimale di Next.js fornisce un punto di partenza pronto all’uso per integrare Dodo Payments con la tua applicazione Next.js. Questo template include sessioni di checkout, gestione dei webhook, portale clienti e componenti UI moderni per aiutarti ad iniziare ad accettare pagamenti rapidamente.
Questo boilerplate utilizza Next.js 16 App Router con TypeScript, Tailwind CSS 4 e l’adattatore @dodopayments/nextjs.

Caratteristiche

  • Impostazione Rapida - Inizia in meno di 5 minuti
  • Integrazione dei Pagamenti - Flusso di checkout preconfigurato utilizzando @dodopayments/nextjs
  • UI Moderna - Pagina di pricing pulita e a tema scuro con Tailwind CSS
  • Gestore Webhook - Endpoint webhook pronto all’uso per eventi di pagamento
  • Portale Clienti - Gestione degli abbonamenti con un clic
  • TypeScript - Completamente tipizzato con tipi minimi e mirati
  • Checkout Precompilato - Dimostra come passare i dati del cliente per migliorare l’esperienza utente

Requisiti

Prima di iniziare, assicurati di avere:
  • Node.js 20.9+ (richiesto per Next.js 16)
  • Account Dodo Payments (per accedere alle chiavi API e Webhook dal dashboard)

Avvio Rapido

1

Clona il Repository

git clone https://github.com/dodopayments/dodo-nextjs-minimal-boilerplate.git
cd dodo-nextjs-minimal-boilerplate
2

Installa le Dipendenze

npm install
3

Ottieni le Credenziali API

Registrati su Dodo Payments e ottieni le tue credenziali dal dashboard:
Assicurati di essere in Modalità Test mentre sviluppi!
4

Configura le Variabili d'Ambiente

Crea un file .env nella directory principale:
cp .env.example .env
Aggiorna i valori con le tue credenziali Dodo Payments:
DODO_PAYMENTS_API_KEY=your_api_key_here
DODO_PAYMENTS_WEBHOOK_KEY=your_webhook_signing_key_here
DODO_PAYMENTS_RETURN_URL=http://localhost:3000
DODO_PAYMENTS_ENVIRONMENT=test_mode
Non impegnare mai il tuo file .env nel controllo di versione. È già incluso in .gitignore.
5

Aggiungi i Tuoi Prodotti

Aggiorna src/lib/products.ts con i tuoi ID prodotto reali da Dodo Payments:
export const products: Product[] = [
  {
    product_id: "pdt_001", // Replace with your product ID
    name: "Basic Plan",
    description: "Get access to basic features and support",
    price: 9999, // in cents
    features: [
      "Access to basic features",
      "Email support",
      "1 Team member",
      "Basic analytics",
    ],
  },
  // ... add more products
];
6

Esegui il Server di Sviluppo

npm run dev
Apri http://localhost:3000 per vedere la tua pagina di pricing!

Struttura del Progetto

src/
├── app/
│   ├── api/
│   │   ├── checkout/          # Checkout session handler
│   │   ├── customer-portal/   # Customer portal redirect
│   │   └── webhook/           # Webhook event handler
│   ├── components/
│   │   ├── Footer.tsx         # Reusable footer
│   │   ├── Header.tsx         # Navigation header
│   │   └── ProductCard.tsx    # Product pricing card
│   ├── globals.css            # Global styles
│   ├── layout.tsx             # Root layout
│   └── page.tsx               # Pricing page (home)
└── lib/
    └── products.ts            # Product definitions

Personalizzazione

Aggiorna le Informazioni sul Prodotto

Modifica src/lib/products.ts per modificare:
  • ID prodotto (dal tuo dashboard Dodo)
  • Prezzi
  • Caratteristiche
  • Descrizioni

Pre-compila i Dati del Cliente

In src/app/components/ProductCard.tsx, sostituisci i valori hardcoded con i tuoi dati utente reali:
customer: {
  name: "John Doe",
  email: "[email protected]",
},

Aggiorna il Portale Clienti

In src/app/components/Header.tsx, sostituisci l’ID cliente hardcoded:
const CUSTOMER_ID = "cus_001"; // Replace with actual customer ID
Puoi completare un acquisto di prova per ottenere l’ID cliente per il testing.

Eventi Webhook

Il boilerplate dimostra la gestione di due eventi webhook in src/app/api/webhook/route.ts:
  • onSubscriptionActive - Attivato quando un abbonamento diventa attivo
  • onPaymentSucceeded - Attivato quando un pagamento ha successo
Aggiungi la tua logica aziendale all’interno di questi gestori:
onSubscriptionActive: async (payload) => {
  // Grant access to your product
  // Update user database
  // Send welcome email
},
Aggiungi ulteriori eventi webhook se necessario. Per lo sviluppo locale, puoi utilizzare strumenti come ngrok per creare un tunnel sicuro al tuo server locale e usarlo come URL del tuo webhook.

Distribuzione

Compila per la Produzione

npm run build
npm start

Distribuisci su Vercel

[ Distribuisci con Vercel ](https://vercel.com/new/clone?repository-url=https://github.com/dodopayments/dodo-nextjs-minimal-boilerplate) Non dimenticare di aggiungere le tue variabili d’ambiente nel dashboard di Vercel!

Aggiorna l’URL del Webhook

Dopo la distribuzione, aggiorna il tuo URL del webhook nel Dashboard Dodo Payments:
https://example.com/api/webhook

Risoluzione dei Problemi

Elimina node_modules e reinstalla le dipendenze:
rm -rf node_modules package-lock.json
npm install
Cause comuni:
  • ID prodotto non valido - verifica che esista nel tuo dashboard Dodo
  • Chiave API errata o impostazione dell’ambiente in .env
  • Controlla la console del browser e il terminale per errori
Per il testing locale, utilizza ngrok per esporre il tuo server:
ngrok http 3000
Aggiorna l’URL del webhook nel tuo dashboard Dodo all’URL di ngrok. Ricorda di aggiornare il tuo file .env con la chiave di verifica del webhook corretta.

Scopri di Più

Supporto

Hai bisogno di aiuto con il boilerplate?