# Текущий контекст проекта ## Статус: Фаза 3 — улучшение UX ### Что сделано #### TDLib интеграция - Подключена библиотека `tdlib-rs` v1.1 с автоматической загрузкой TDLib - Реализована авторизация через телефон + код + 2FA пароль - Сессия сохраняется автоматически в папке `tdlib_data/` - Отключены логи TDLib через FFI вызов `td_execute` до создания клиента - Updates обрабатываются в отдельном потоке через `mpsc` канал (неблокирующе) #### Функциональность - Загрузка списка чатов (до 50 штук) - **Фильтрация чатов**: показываются только чаты из ChatList::Main (без архива) - Отображение названия чата, счётчика непрочитанных и **@username** - **Иконка 📌** для закреплённых чатов - Загрузка истории сообщений при открытии чата (множественные попытки) - **Группировка сообщений по дате** (разделители "Сегодня", "Вчера", дата) - **Группировка сообщений по отправителю** (заголовок с именем) - **Отображение времени сообщений** в формате [HH:MM] - **Галочки прочтения** (✓ отправлено, ✓✓ прочитано) - **Отправка текстовых сообщений** - **Новые сообщения в реальном времени** при открытом чате - **Поиск по чатам** (Ctrl+S): фильтрация по названию и @username #### Управление - `↑/↓` стрелки — навигация по списку чатов - `Enter` — открыть чат / отправить сообщение - `Esc` — закрыть открытый чат / отменить поиск - `Ctrl+S` — поиск по чатам (фильтрация по названию и username) - `Ctrl+R` — обновить список чатов - `Ctrl+C` — выход - `Cmd+↑/Cmd+↓` — скролл сообщений в открытом чате (с подгрузкой старых) - `1-9` — переключение папок (в списке чатов) - Ввод текста в поле сообщения ### Структура проекта ``` src/ ├── main.rs # Точка входа, event loop, TDLib инициализация ├── app/ │ ├── mod.rs # App структура и состояние │ └── state.rs # AppScreen enum ├── ui/ │ ├── mod.rs # Роутинг UI по экранам │ ├── loading.rs # Экран загрузки │ ├── auth.rs # Экран авторизации │ ├── main_screen.rs # Главный экран │ ├── chat_list.rs # Список чатов (с pin и username) │ ├── messages.rs # Область сообщений (группировка по дате/отправителю) │ └── footer.rs # Подвал с командами ├── input/ │ ├── mod.rs # Роутинг ввода │ ├── auth.rs # Обработка ввода на экране авторизации │ └── main_input.rs # Обработка ввода на главном экране ├── utils.rs # Утилиты (disable_tdlib_logs, format_timestamp, format_date, get_day) └── tdlib/ ├── mod.rs # Модуль экспорта └── client.rs # TdClient: авторизация, чаты, сообщения, кеш usernames ``` ### Ключевые решения 1. **Неблокирующий receive**: TDLib updates приходят в отдельном потоке и передаются в main loop через `mpsc::channel`. Это позволяет UI оставаться отзывчивым. 2. **FFI для логов**: Используем прямой вызов `td_execute` для отключения логов синхронно, до создания клиента, чтобы избежать вывода в терминал. 3. **Синхронизация чатов**: Чаты загружаются асинхронно через updates. Main loop периодически синхронизирует `app.chats` с `td_client.chats`. 4. **Кеширование usernames**: При получении `Update::User` сохраняем username в HashMap. При получении приватного чата связываем chat_id с user_id. 5. **Группировка сообщений**: Сообщения группируются по дате (разделители) и по отправителю (заголовки). Время отображается рядом с каждым сообщением. 6. **Новые сообщения**: `current_chat_id` отслеживает открытый чат. При получении `NewMessage` для этого чата сообщение добавляется сразу. ### Зависимости (Cargo.toml) ```toml ratatui = "0.29" crossterm = "0.28" tdlib-rs = { version = "1.1", features = ["download-tdlib"] } tokio = { version = "1", features = ["full"] } serde = { version = "1.0", features = ["derive"] } serde_json = "1.0" dotenvy = "0.15" ``` ### Переменные окружения (.env) ``` API_ID=your_api_id API_HASH=your_api_hash ``` ## Что НЕ сделано / TODO - [ ] Папки телеграма (сейчас только "All") - [ ] Отображение онлайн-статуса пользователя - [ ] Markdown форматирование в сообщениях - [ ] Отметка сообщений как прочитанные - [ ] Медиа-сообщения (фото, видео, голосовые) ## Известные проблемы 1. При первом запуске нужно пройти авторизацию 2. Время отображается с фиксированным смещением +3 (MSK)