A responsive quiz application built with Next.js 14, utilizing React Query, Redux Toolkit, TypeScript, and Chakra UI. This app allows users to select quiz categories and answer questions, providing instant feedback on their answers, with support for light/dark mode.
- Dynamic Quiz Categories: Select from various categories to take quizzes relevant to your interests.
- Instant Feedback: Get immediate feedback on whether your answers are correct or incorrect.
- Progress Tracking: Track your progress throughout the quiz.
- Light/Dark Mode: Toggle between light and dark themes for a personalized experience.
- Responsive Design: Optimized for both desktop and mobile views.
- Next.js 14: Framework for building the application with server-side rendering and static site generation.
- React Query: For managing server state and fetching data efficiently.
- Redux Toolkit: State management for application-wide data.
- TypeScript: Provides type safety and enhances development experience.
- Chakra UI: For building accessible and responsive UI components.
Follow these steps to set up the project locally:
-
Clone the repository:
git clone https://github.com/azarahmadov/NextJs-Quiz-app.git cd NextJs-Quiz-app
-
Install dependencies:
npm install
-
Set up the environment:
NEXT_PUBLIC_BASE_URL=http://localhost:3000
-
Run the development server:
npm run dev
-
Open your browser and go to http://localhost:3000 to see the application in action.
- Choose a quiz category from the main page.
- Answer the multiple-choice questions presented.
- Receive feedback on your answers.
- Track your progress with the provided progress bar.
- Toggle between light and dark mode using the UI switch.
data:image/s3,"s3://crabby-images/24e70/24e70beb085bfc22c94f88b6dc535bc3f1b3cf9e" alt="Screenshot 2024-10-31 at 01 12 29"
data:image/s3,"s3://crabby-images/1805f/1805f33445e7a078ecd7612aa3a7cdfd3f2e8128" alt="Screenshot 2024-10-31 at 01 12 48"
data:image/s3,"s3://crabby-images/8aa63/8aa63af6b0cfb908637e993b3a504b0cb0cabb8b" alt="Screenshot 2024-10-31 at 01 13 01"