Learn Lingo is a web application designed to help users learn new languages through interactive lessons and activities. This project leverages the power of Next.js, React, and TypeScript to provide a seamless learning experience.
Follow these steps to set up the project locally:
-
Clone the repository:
git clone https://github.com/valik3201/learn-lingo.git cd learn-lingo
-
Install dependencies:
Ensure you have Node.js installed. Then, run:
npm install
-
Set up environment variables:
Rename the
.env.local.example
file to.env.local
and update the environment variables as needed. -
Run the development server:
npm run dev
Open http://localhost:3000 with your browser to see the result.
Once the development server is running, you can start exploring the application. The main features include:
- Interactive language lessons
- Progress tracking
- User authentication (sign up, log in, log out)
- Next.js Framework: Server-side rendering, static site generation, and API routes.
- React: Component-based architecture for building reusable UI components.
- TypeScript: Static typing for enhanced code quality and developer productivity.
- Tailwind CSS: Utility-first CSS framework for rapid UI development.
- Firebase: Backend services for authentication, database, and storage.
Learn Lingo uses Zustand for efficient and straightforward state management. Zustand provides a minimalistic API to create global state stores, making it easier to manage the state across the application.
- Auth Store (
useAuthStore.ts
): Manages the authentication state, including user information and authentication status. - Favorites Store (
useFavoritesStore.ts
): Handles the state related to users’ favorite teachers or lessons. - Teachers Store (
useTeachersStore.ts
): Manages the list of available teachers, including filtering and sorting.
Zustand is chosen for its simplicity and flexibility. It allows us to create easily maintainable state logic without the boilerplate often associated with other state management solutions. It also supports asynchronous actions and provides a clean API for interacting with the global state.
The application uses environment variables for configuration. These should be defined in the .env.local
file:
NEXT_PUBLIC_FIREBASE_API_KEY
NEXT_PUBLIC_FIREBASE_AUTH_DOMAIN
NEXT_PUBLIC_FIREBASE_PROJECT_ID
NEXT_PUBLIC_FIREBASE_STORAGE_BUCKET
NEXT_PUBLIC_FIREBASE_MESSAGING_SENDER_ID
NEXT_PUBLIC_FIREBASE_APP_ID
npm run dev
: Run the development server.npm run build
: Build the application for production.npm start
: Start the production server.npm run lint
: Run ESLint to lint the codebase.
Contributions are welcome! Please follow these steps to contribute:
- Fork the repository.
- Create a new branch (
git checkout -b feature/your-feature
). - Make your changes.
- Commit your changes (
git commit -m 'Add some feature'
). - Push to the branch (
git push origin feature/your-feature
). - Open a pull request.
For questions, suggestions, or issues, please contact valik3201@gmail.com
.