11 KiB
TTUI - Требование к приложению
Описание приложения
Терминальный интерфейс для telegram
Функциональные требования
Интерфейс
┌─ TTUI ───────────────────────────────────────────────────────────────────────┐ │ 1:All │ 2:Personal │ 3:Work │ 4:Bots │ ├──────────────────────┬───────────────────────────────────────────────────────┤ │ 🔍 Search... │ 👤 Mom (online) │ ├──────────────────────┼───────────────────────────────────────────────────────┤ │ 📌 Saved Messages │ Today, Dec 21│ │ ▌ Mom (2)│ │ │ Boss │ Mom ────────────────────────────────────────── 14:20 │ │ Rust Community │ Привет! Ты покормил кота? │ │ Durov │ │ │ News Channel │ You ─────────────────────────────────────── 14:22 ✓✓ │ │ Spam Bot │ Да, конечно. Купил ему корм. │ │ Wife │ Скоро буду дома. │ │ Team Lead │ │ │ DevOps Chat (9)│ Mom ────────────────────────────────────────── 14:23 │ │ Server Alerts │ Отлично, захвати хлеба. │ │ Gym Bro │ │ │ Design Team │ You ─────────────────────────────────────── 14:25 ✓ │ │ Project X │ Ок. │ │ HR │ │ │ Mom's Friend │ │ │ Taxi Bot │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ├──────────────────────┼───────────────────────────────────────────────────────┤ │ [User: Online] │ > message │ └──────────────────────┴───────────────────────────────────────────────────────┘ commands
Список желаемого
- футер - список папок в телеграме
- список с чатами - лички и группы, сверху инпут для поиска чата
- основной контент - открытый чат с сообщениями из чата, если никакой чат не открыт, то контент пустой, ничего не показываем. Снизу - инпут для ввода сообщения в чат, который открыт
- снизу списка чата статус онлайн или нет сам пользователь приложения
- при открытии чата должна загружаться история чата, а так же подгружаться новые сообщения от собеседника.
- выделяем сообщения собеседника его никнеймом, группируем его сообщения и разделяем наши сообщения и сообщения собеседника, как на интерфейсе сверху
- отображаем наше сообщение символом
✓, если телеграм подтвердил, что сообщение отправлено, и выделяем✓✓если собеседник прочитал его - при навигации в чате выделяем строку курсивом, при выборе чата (то есть его открытии) ставим в начало символ ▌
(2)— счетчик непрочитанных (можно красить в красный/зеленый).muted— статус чата (серый цвет).@— пинг/меншн.- с видео/картинками/голосовые пока ничего не делаем, ренденим заглушку (с упоминанием что это картинка или видео и тд)
Дополнительно реализованные возможности
- Markdown форматирование: жирный, курсив, подчёркивание, зачёркивание, код, спойлеры, ссылки, упоминания
- Редактирование сообщений: ↑ при пустом инпуте → выбор → Enter → редактирование
- Удаление сообщений: d/в/Delete в режиме выбора → подтверждение → удаление
- Reply на сообщения: r/к в режиме выбора → превью → отправка ответа
- Forward сообщений: f/а в режиме выбора → выбор чата → пересылка
- Typing indicator: отображение "печатает..." когда собеседник набирает текст
- Закреплённые сообщения: отображение pinned message вверху чата с переходом
- Поиск по сообщениям: Ctrl+F для поиска внутри чата, n/N для навигации
- Черновики: автосохранение текста при переключении между чатами
- Профиль: i для просмотра информации о пользователе/группе
- Копирование: y/н для копирования сообщения в системный буфер
- Реакции: e/у для добавления реакций, emoji picker с навигацией стрелками
- Конфигурация: ~/.config/tele-tui/config.toml для настройки цветов и timezone
- Credentials: приоритетная загрузка из ~/.config/tele-tui/credentials или .env
- Блочный курсор: Vim-style курсор █ с навигацией ←/→/Home/End
- Динамический инпут: автоматическое расширение до 10 строк
- Онлайн-статус: зелёная точка ● для онлайн пользователей
- Индикаторы: 📌 закреплённые чаты, 🔇 замьюченные, @ упоминания
- Состояние сети: индикатор в футере (⚠ Нет сети, ⏳ Подключение...)
- Graceful shutdown: корректное закрытие при Ctrl+C
Управление
- ctrl+c или command+c - выход из программы
- "h j k l" - влево, вниз, вверх, вправо (навигация в левом столбце) vim-style управление
- стрелки - управление, так же как и "h j k l"
- "command + 1", "command + 2" и так далее - переключение между папками, которые созданы в телеграме
- из интерфейса "message" - это инпут для ввода сообщения в открытый чат
- ctrl + s - фокус в инпут поиска чата
- Esc - закрытие открытого чата
- command + стрелка вверх (или ctrl + k) - выделяем самый верхний чат (без открытия)
- поддержка русской раскладки: "р о л д" соответствует "h j k l"
- Ctrl+R - обновить список чатов
Реализованные команды
Навигация
↑/↓ или k/j (р/о): Navigate | Enter: Open/Send | Esc: Close/Cancel | 1-9: Folders
Ctrl+S: Search Chats | Ctrl+R: Refresh | Ctrl+F: Search in Chat | Ctrl+C: Quit
Работа с сообщениями
↑ (пустой инпут): Select message | Enter: Edit | r/к: Reply | f/а: Forward
d/в/Delete: Delete | y/н: Copy | e/у: React | i: Profile
Emoji Picker (реакции)
←/→/↑/↓: Navigate | Enter: Toggle reaction | Esc: Close
Технологии
Пишем на rust-е
- ratatui 0.29 - для tui интерфейса
- tdlib-rs 1.1 - для подключения апи телеграма (обёртка над TDLib)
- tokio 1.x - async runtime
- crossterm 0.28 - кроссплатформенный терминал
- serde + serde_json 1.0 - сериализация/десериализация
- toml 0.8 - парсинг конфигурации
- dirs 5.0 - XDG директории (config, data)
- clipboard 0.5 - работа с системным буфером обмена
- chrono 0.4 - форматирование даты/времени
- dotenvy 0.15 - загрузка .env файлов
Нефункциональные требования
Производительность
- программа должна выдавать 60 фпс
- интерфейс не должен мерцать
- минимальное разрешение - 600 символов, максимального нет, не ограничиваем