Gromuse Template
A modern, feature-rich grocery ecommerce template.
View the Deployed Live Version of the App:
This is the Live version here
Overview
Gromuse is a complete grocery ecommerce solution designed to provide seamless shopping experiences for fresh produce and groceries. Built with cutting-edge technologies like Next.js 14, TypeScript, and Tailwind CSS, along with MongoDB, Prisma, and Shadcn UI, it offers a robust platform for managing online grocery stores with ease.
Key Features
-
Customer Features:
- Fresh produce browsing with quality tracking
- Category & department-based navigation
- Real-time stock availability
- Delivery slot booking system
- Shopping cart with real-time updates
- Secure checkout process
- Responsive and fast-loading design
-
Admin Dashboard:
- Inventory management with fresh produce tracking
- Sales and analytics monitoring
- Order processing and delivery scheduling
- Customer management
- Promotions and special offers
- Multi-role authentication (Admin and Staff)
-
Core Functionalities:
- Authentication (NextAuth.js)
- Payment processing (Stripe/Paystack)
- Email notifications (Resend)
- Real-time stock updates
- Dynamic category filtering
- Image optimization
Installation
Prerequisites
- Node.js 18.x or higher
- MongoDB database
- Stripe account
- Resend account
- A code editor of your choice (e.g., Visual Studio Code, Sublime Text)
Installation Steps
Clone Repository
git clone https://github.com/yourusername/gromuse-template.git
cd gromuse-template
Install Dependencies
npm install
#You can use pnpm
Seed data
# Seed data
npm run seed
4. Start Development Server
npm run dev
Configuration Guide
Environment Setup
Create a .env
file in the root directory with the following variables:
# App
NEXT_PUBLIC_APP_URL=http://localhost:3000
# Database
DATABASE_URL="your-mongodb-url"
# Authentication
NEXTAUTH_SECRET="your-secret"
NEXTAUTH_URL="http://localhost:3000"
# Stripe
STRIPE_SECRET_KEY="your-stripe-secret"
NEXT_PUBLIC_STRIPE_PUBLISHABLE_KEY="your-stripe-publishable"
STRIPE_WEBHOOK_SECRET="your-webhook-secret"
# Email (Resend)
RESEND_API_KEY="your-resend-key"
# GitHub (Auth)
GITHUB_CLIENT_ID="your-client-id"
GITHUB_SECRET="your-secret-id"
# Google (Auth)
GOOGLE_CLIENT_ID="your-client-id"
GOOGLE_CLIENT_SECRET="your-secret-id"
# Uploadthing (Image Upload)
Uploadthing-Token ="your token"
Access the Application
Open your web browser and navigate to http://localhost:3000 (or the port specified in your environment setup).
You should now see the login page of your Gromuse Grocery Store.
Default User Accounts
The seeding process creates two default user accounts for testing:
-
Admin
- Email: admin@admin.com
- Password: admin
-
Client
- Email: client@client.com
- Password: client
You can use these credentials to log in and explore different user roles within the application.
Production Deployment
Build Application
bash npm run build
Migrate Database
bash npx prisma migrate
Start Production Server
bash npm start
Deployment Platforms
The application can be deployed to:
- Vercel (Recommended)
- Railway
- AWS
- Digital Ocean
Support & Customization
Getting Help
For support and customization requests:
- WhatsApp Support: Contact Us
- GitHub Issues: Report bugs
Customization Services
We offer customization services to adapt Gromuse to your specific needs:
- Custom feature development
- UI/UX modifications
- Integration with existing systems
- Database migration
- Deployment assistance
Contact us through WhatsApp for customization inquiries.
Troubleshooting
Common Issues
-
Payment Processing Errors
# Verify Stripe webhook stripe listen --forward-to localhost:3000/api/payments/webhook
-
Database Connection Issues
# Test database connection npx prisma db pull
Need more help? Please Join Chat to talk with a real developer