data:image/s3,"s3://crabby-images/35271/352711ac3bfe77bd8a5186c4aa9e196a3add8a61" alt="Project Banner"
Novel Hub is a modern and user-friendly web application designed for avid novel readers and aspiring authors. This platform to foster a community of web novel enthusiasts, providing a platform for readers to engage in discussions, reviews, and ratings while allowing authors to publish and manage their works.
- 📚 Browse Novels: Explore a wide range of novels.
- 📖 Read Chapters: Dive into your favorite stories chapter by chapter.
- ⭐ Write and Read Reviews: Share and explore opinions on novels.
- 🎯 Get Recommendations: Receive personalized novel suggestions.
- 🗣️ Forum: Post thoughts and interact with the community.
- ✍️ Become an Author: Apply for authorship directly via the profile page.
- 📊 Novel Analytics: View stats and engagement data for your novels.
- 📝 Upload Novels and Chapters: Publish your work and keep it updated.
- Secure login using Google or email/password.
- Protect user privacy with no data sharing.
- Users can request data deletion via support.
- Intelligent chatbot "Novik" to assist users with queries and navigation.
- Clear, concise, and friendly responses.
- Node.js (v16.0 or higher)
- npm (v8.0 or higher)
- MongoDB instance
- Google OAuth credentials (if using Google login)
- Cloudinary credentials (for image and video storage)
- Gemini API Key for AI chatbot
-
Clone the Repository:
git clone https://github.com/NK-Works/Novel-Hub.git cd novel-hub
-
Open both the Directories:
cd frontend (for frontend) cd backend (for backend)
-
Install Dependencies:
npm install
-
Set Environment Variables: Create a
.env
file in the backend root directory and add:PORT=3002 MONGO_URI=your_mongodb_connection_string jwt_secret=your_jwt_secret GOOGLE_CLIENT_ID=your_google_client_id GOOGLE_CLIENT_SECRET=your_google_client_secret CLOUDINARY_CLOUD_NAME=cloudinary_cloud_name CLOUDINARY_API_KEY=cloudinary_api_key CLOUDINARY_API_SECRET=cloudinary_api_secret GEMINI_API_KEY=gemini_api_key
Create a
.env
file in the frontend root directory and add:VITE_API_URL=http://localhost:3002/api VITE_API_GOOGLE_CLIENT_ID=your_google_client_id
-
Start the Application: Start the backend using:
npm start
Start the frontend using:
npm run dev
- Visit
http://localhost:5173
to access the frontned andhttp://localhost:3002
to access the backend locally. - Register or log in using Google or email/password.
- Home Page: Browse trending and new novels.
- Rankings Page: Discover top-rated novels.
- Search: Find novels by name or genre.
- Profile: Manage your account, apply for authorship, and view stats.
- Forum: Share thoughts and connect with the community.
/home
- Home page/login
- Login page/signup
- Sign-up page/rankings
- Rankings page/search
- Search for novels
/novels/:id
- View novel details/novels/:id/chapters
- View chapters of a novel/novels/:novelId/reviews/:reviewId
- View specific review/profile
- Access user profile/forum
- Engage with the community/novel-analytics/:novelId
- View analytics of authored novels
/*
- Displays a custom 404 page
Novik is an intelligent chatbot integrated into the application to assist users with:
- Navigating the platform
- Understanding features
- Answering common queries
Behavior:
- Provides clear, concise responses.
- Handles out-of-scope queries politely.
- Does not share user data or provide irrelevant suggestions.
Example Queries:
- "Show me novels"
- "Help with chapters"
- "How to write review"
- "Recommend novels"
We welcome contributions to enhance Novel Hub! To contribute:
- Fork the repository.
- Create a new branch for your feature/bugfix.
- Submit a pull request with detailed explanations.
Enjoy using Novel Hub and happy reading!