Hikari is a powerful, feature-rich Next.js SaaS starter designed to accelerate your development process. This guide will walk you through setting up Hikari, including its Supabase backend and Stripe integration.
Key Features
- Next.js 14.2.3: Leveraging the latest features of Next.js for optimal performance.
- Supabase 1.172.2: Robust backend solution for database management and authentication.
- Stripe.js 2.4.0: Seamless payment processing with easy setup.
- TypeScript: Enhanced code quality and developer productivity.
- TailwindCSS: Rapid UI development with utility-first CSS.
- UI Components: Rich set of pre-built components using shadcn/ui and magicui.
- Documentation Framework: Integrated Fumadocs for easy documentation creation.
- Landing Page Components: Complete set of customizable landing page elements.
- Dashboard and User Management: Pre-built dashboard and user management pages.
Quick Start Guide
1. Clone the Repository
2. Install Dependencies
Ensure you have pnpm installed and run:
3. Set Up Local Development Environment with Supabase
Prerequisites
- Install Docker
- Set up environment files:
- Copy
.env.local.example
to.env.local
- Copy
.env.example
to.env
- Copy
Start Local Supabase Instance
-
Start Supabase:
-
Configure environment variables:
- Copy the
service_role_key
from the terminal output. - Set
SUPABASE_SERVICE_ROLE_KEY
in your.env.local
file with this value.
- Copy the
-
Get Supabase URLs:
Copy the following values to your
.env.local
file:API URL
asNEXT_PUBLIC_SUPABASE_URL
anon key
asNEXT_PUBLIC_SUPABASE_ANON_KEY
service_role key
asSUPABASE_SERVICE_ROLE_KEY
-
Link local Supabase instance:
Follow the prompts to link to your Supabase project.
4. Set Up Stripe Integration
Create a Stripe Account
If you don't already have a Stripe account, create one now.
Enable Test Mode
Make sure you have the "Test Mode" toggle switched on in your Stripe dashboard for development purposes.
Configure Stripe API Keys
- Go to the API Keys section on the Developers tab in your Stripe dashboard.
- Copy the
Publishable key
andSecret key
. - Paste them into your
.env.local
file:
Set Up Stripe CLI
- Download and install the Stripe CLI.
- Log in to your Stripe account via the CLI:
Configure Webhook
- Forward events to your local webhook endpoint:
- Copy the webhook signing secret that's printed in the console.
- Add it to your
.env.local
file:
Create Products and Pricing
Hikari uses a fixtures file to bootstrap test product and pricing data in your Stripe account. Here's an example of a comprehensive Stripe fixtures file:
To use this:
- Save the above JSON in
utils/stripe/fixtures/stripe-fixtures.json
. - Ensure the Stripe CLI is listening to your local environment:
- Run the Stripe fixtures command to create the products in your Stripe account:
5. Set Up GitHub OAuth (Optional)
-
Create a GitHub OAuth app following this guide.
-
Add the following to your
.env
file:
6. Final Environment Setup
Your .env.local
file should now look similar to this:
7. Run the Development Server
-
Start the Next.js development server:
-
Open http://localhost:3000 in your browser to see your Hikari application.
Key Components
Supabase Integration
Hikari uses Supabase for database management and authentication. The setup process includes:
- Local Supabase instance setup
- Environment variable configuration
- Database schema management
Stripe Integration
The Stripe integration in Hikari includes:
- Webhook handling for various Stripe events
- Product and pricing management using fixtures
- Subscription handling
UI Components
Hikari comes with a rich set of UI components, including:
- Complete landing page elements
- Dashboard components
- User management interfaces
Customization
While Hikari provides a solid starting point, it's designed to be customizable:
- Modify the
stripe-fixtures.json
file to adjust product and pricing information - Customize UI components to match your brand
- Extend the provided API routes and add new ones as needed
Important Notes
- Stripe Checkout in Hikari supports pricing that bills a predefined amount at a specific interval. More complex plans (e.g., different pricing tiers or seats) are not yet supported.
- Always ensure your Stripe webhook is correctly configured and that you've redeployed with all necessary environment variables.
- The webhook listener must be running concurrently with your development server for the Stripe integration to function correctly.
Licensing
Hikari is open-source and available under the MIT License, allowing for both personal and commercial use with proper attribution.
Conclusion
Hikari provides a comprehensive starting point for your Next.js SaaS projects, combining powerful features with ease of use. By leveraging Hikari, you can focus on building your unique product features rather than setting up infrastructure and common SaaS components.
Remember, Hikari is an evolving project. Check the official repository for the latest updates, features, and community contributions.
Happy building with Hikari!
Written by
Antoine Ross
At
Sat Aug 03 2024