https://github.com/wo0zz1/unolingo
🌐 Unolingo 🎓 — это интерактивное мобильное приложение для изучения иностранных языков в игровой форме
https://github.com/wo0zz1/unolingo
nestjs-backend postgresql prisma-orm react react-native typescript unolingo
Last synced: 11 months ago
JSON representation
🌐 Unolingo 🎓 — это интерактивное мобильное приложение для изучения иностранных языков в игровой форме
- Host: GitHub
- URL: https://github.com/wo0zz1/unolingo
- Owner: Wo0zZ1
- License: mit
- Created: 2025-04-17T17:06:59.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2025-05-08T16:24:04.000Z (about 1 year ago)
- Last Synced: 2025-05-08T16:33:02.333Z (about 1 year ago)
- Topics: nestjs-backend, postgresql, prisma-orm, react, react-native, typescript, unolingo
- Homepage:
- Size: 472 KB
- Stars: 2
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: readme.md
- License: LICENSE
Awesome Lists containing this project
README
🌐 Unolingo 🎓
Изучайте языки легко и весело!
**Unolingo** — это интерактивное мобильное приложение для изучения иностранных языков в игровой форме. Проект разработан в рамках учебной практики в вузе и сочетает в себе современные технологии с удобным интерфейсом.
## 🔥 **Ключевые особенности**
- 🎮 **Геймификация обучения** — система уровней, достижений и наград.
- 📚 **Разнообразные упражнения** — словарные карточки, аудирование, грамматические тесты.
- 📊 **Таблица рейтинга** — соревнуйтесь с другими пользователями.
- 🌍 **Поддержка нескольких языков** — английский, испанский, французский и другие.
- 🔄 **Синхронизация между устройствами** — ваш прогресс сохраняется в облаке.
## 🛠 **Технологический стек**
### **Frontend**
- [React Native](https://reactnative.dev/) + [Expo](https://expo.dev/go) — кроссплатформенная разработка.
- [Axios](https://axios-http.com/ru/) — работа с API.
- [zustand](https://zustand-demo.pmnd.rs/) - state-менеджер
- [Async storage](https://www.npmjs.com/package/@react-native-async-storage/async-storage) — работа с локальным хранилищем.
- [TypeScript](https://www.typescriptlang.org/) — статическая типизация.
### **Backend**
- [NestJS](https://nestjs.com/) — масштабируемый backend на Node.js.
- [Bcrypt](https://www.npmjs.com/package/bcrypt) — хеширование паролей.
- [JWT](https://www.npmjs.com/package/@nestjs/jwt) — аутентификация.
### **База данных**
- [PostgreSQL](https://www.postgresql.org/) — реляционная СУБД для хранения данных.
- [PrismaORM](https://www.prisma.io/) — работа с БД.
## 🚀 **Установка и запуск**
### **1. Клонирование репозитория с подмодулями**
```bash
git clone --recurse-submodules https://github.com/Wo0zZ1/unolingo.git
cd unolingo
```
#### 💡 **`TIP`**: Если репозиторий был склонирован без подмодулей, выполните:
```bash
git submodule update --init --recursive
```
### **2. Настройка Backend**
```bash
cd backend
yarn
```
#### 💡 **`TIP`**: Если у вас не установлен [yarn](https://yarnpkg.com/), вы можете заменить команду на `npm install`
#### ⚠️ **`WARN`**: Не забудьте настроить переменные окружения `.env` на основе `.env.example`:
### **3. Запуск Backend**
```bash
docker compose build
docker compose up -d
```
#### 💡 **`TIP`**: Убедитесь, что у вас запущен [Docker Engine](https://docs.docker.com)
####
### **4. Настройка Frontend**
```bash
cd frontend
yarn
```
#### 💡 **`TIP`**: Убедитесь, что вы вернулись в корневую директорию перед выполнением команды `cd frontend`
#### 💡 **`TIP`**: Если у вас не установлен [yarn](https://yarnpkg.com/), вы можете заменить команду на `npm install`
#### ⚠️ **`WARN`**: Не забудьте настроить переменные окружения `.env` на основе `.env.example`
### **5. Запуск Frontend**
```bash
yarn start
```
#### 💡 **`TIP`**: Для работы на мобильным приложении установите [Expo Go](https://expo.dev/go)
## 📱 Демо:
### 1. Страница авторизации

### 2. Страница профиля

### 3. Страница статистики

### 4. Страница выбора уровня

### 5. Страница теории

### 6. Страницы прохожения уровня


### 7. Страница результатов прохождения уровня

## 📄 Лицензия
Copyright © 2025 [Wo0zZ1](https://github.com/Wo0zZ1)\
Этот проект использует [MIT](LICENSE) лицензию