fix ideas

This commit is contained in:
cheykrym 2025-10-06 06:13:23 +03:00
parent c2647fa22e
commit 8eb1e17692
3 changed files with 532 additions and 321 deletions

View File

@ -395,7 +395,7 @@
ASSETCATALOG_COMPILER_GLOBAL_ACCENT_COLOR_NAME = AccentColor;
CODE_SIGN_ENTITLEMENTS = yobble/yobble.entitlements;
CODE_SIGN_STYLE = Automatic;
CURRENT_PROJECT_VERSION = 2;
CURRENT_PROJECT_VERSION = 3;
DEVELOPMENT_TEAM = V22H44W47J;
ENABLE_HARDENED_RUNTIME = YES;
ENABLE_PREVIEWS = YES;
@ -435,7 +435,7 @@
ASSETCATALOG_COMPILER_GLOBAL_ACCENT_COLOR_NAME = AccentColor;
CODE_SIGN_ENTITLEMENTS = yobble/yobble.entitlements;
CODE_SIGN_STYLE = Automatic;
CURRENT_PROJECT_VERSION = 2;
CURRENT_PROJECT_VERSION = 3;
DEVELOPMENT_TEAM = V22H44W47J;
ENABLE_HARDENED_RUNTIME = YES;
ENABLE_PREVIEWS = YES;

View File

@ -1,7 +1,9 @@
{
"sourceLanguage" : "ru",
"strings" : {
"%lld": {},
"(не работает) Отправить предложение" : {
},
"@%@" : {
"localizations" : {
"en" : {
@ -12,8 +14,25 @@
}
}
},
"Chat ID:": {},
"Companion ID:": {},
"%lld" : {
},
"🌍" : {
"localizations" : {
"en" : {
"stringUnit" : {
"state" : "translated",
"value" : "🌍"
}
}
}
},
"Chat ID:" : {
},
"Companion ID:" : {
},
"DEBUG UPDATE" : {
"localizations" : {
"en" : {
@ -61,7 +80,18 @@
}
}
},
"Push-уведомления": {},
"profile_down_text_1" : {
},
"profile_down_text_2" : {
},
"profile_down_text_3" : {
},
"Push-уведомления" : {
},
"Yobble" : {
"localizations" : {
"en" : {
@ -72,14 +102,21 @@
}
}
},
"profile_down_text_1": {},
"profile_down_text_2": {},
"profile_down_text_3": {},
"Активные сессии": {},
"Без звука (скоро)": {},
"Безопасность": {},
"Ваше предложение": {},
"Вложение": {},
"Активные сессии" : {
},
"Без звука (скоро)" : {
},
"Безопасность" : {
},
"Ваше предложение" : {
},
"Вложение" : {
},
"Войти" : {
"localizations" : {
"en" : {
@ -90,14 +127,24 @@
}
}
},
"Вы": {},
"Вы предложили: %@": {},
"Выйти из аккаунта": {},
"Вы" : {
},
"Вы предложили: %@" : {
},
"Выйти из аккаунта" : {
},
"Где найти сохранённые черновики?" : {
"comment" : "FAQ question: drafts"
},
"Данные": {},
"Двухфакторная аутентификация": {},
"Данные" : {
},
"Двухфакторная аутентификация" : {
},
"Добавить друзей" : {
"comment" : "Add friends",
"localizations" : {
@ -109,15 +156,33 @@
}
}
},
"Другое": {},
"Заглушка: Push-уведомления": {},
"Заглушка: Активные сессии": {},
"Заглушка: Двухфакторная аутентификация": {},
"Заглушка: Другие настройки": {},
"Заглушка: Обратная связь": {},
"Заглушка: Сменить пароль": {},
"Заглушка: Хранилище данных": {},
"Загружаем чаты…": {},
"Другое" : {
},
"Заглушка: Push-уведомления" : {
},
"Заглушка: Активные сессии" : {
},
"Заглушка: Двухфакторная аутентификация" : {
},
"Заглушка: Другие настройки" : {
},
"Заглушка: Обратная связь" : {
},
"Заглушка: Сменить пароль" : {
},
"Заглушка: Хранилище данных" : {
},
"Загружаем чаты…" : {
},
"Загрузка..." : {
"localizations" : {
"en" : {
@ -139,7 +204,9 @@
}
}
},
"Закрепить (скоро)": {},
"Закрепить (скоро)" : {
},
"Закрыть" : {
"comment" : "Закрыть",
"localizations" : {
@ -162,9 +229,15 @@
}
}
},
"Здесь не будут чаты": {},
"Идеи": {},
"Избранные сообщения": {},
"Здесь не будут чаты" : {
},
"Идеи" : {
},
"Избранные сообщения" : {
},
"Инвайт-код (необязательно)" : {
"comment" : "Инвайт-код",
"localizations" : {
@ -193,7 +266,9 @@
"Как связаться с поддержкой?" : {
"comment" : "FAQ question: support"
},
"Какая вкладка вам нужна?": {},
"Какая вкладка вам нужна?" : {
},
"Корзина" : {
"comment" : "Cart",
"localizations" : {
@ -216,8 +291,12 @@
}
}
},
"Лента": {},
"Лицо": {},
"Лента" : {
},
"Лицо" : {
},
"Логин" : {
"comment" : "Логин",
"localizations" : {
@ -240,7 +319,9 @@
}
}
},
"Логин уже занят.": {},
"Логин уже занят." : {
},
"Мини-приложения" : {
"comment" : "Applets",
"localizations" : {
@ -274,12 +355,18 @@
}
}
},
"Мой профиль": {},
"Мы планируем заменить вкладку. Поделитесь, что бы вы хотели видеть здесь чаще всего.": {},
"Мой профиль" : {
},
"Мы планируем заменить вкладку. Поделитесь, что бы вы хотели видеть здесь чаще всего." : {
},
"Напишите нам через форму обратной связи в разделе \"Поддержка\"." : {
"comment" : "FAQ answer: support"
},
"Например: закладки, друзья, активность...": {},
"Например: закладки, друзья, активность..." : {
},
"Настройки" : {
"comment" : "Settings",
"localizations" : {
@ -291,46 +378,99 @@
}
}
},
"Не удалось загрузить список чатов.": {},
"Не удалось загрузить чаты.": {},
"Не удалось обработать данные чатов.": {},
"Не удалось обработать ответ сервера.": {},
"Не удалось сериализовать данные запроса.": {},
"Неверный запрос (400).": {},
"Неверный код приглашения.": {},
"Не удалось загрузить список чатов." : {
},
"Не удалось загрузить чаты." : {
},
"Не удалось обработать данные чатов." : {
},
"Не удалось обработать ответ сервера." : {
},
"Не удалось сериализовать данные запроса." : {
},
"Неверный запрос (400)." : {
},
"Неверный код приглашения." : {
},
"Неверный логин" : {
"comment" : "Неверный логин"
},
"Неверный логин или пароль.": {},
"Неверный логин или пароль." : {
},
"Неверный пароль" : {
"comment" : "Неверный пароль"
},
"Неизвестная ошибка": {},
"Неизвестная ошибка.": {},
"Неизвестная ошибка. Попробуйте позже.": {},
"Неизвестный": {},
"Неизвестный пользователь": {},
"Некорректный ответ от сервера.": {},
"Неизвестная ошибка" : {
},
"Неизвестная ошибка." : {
},
"Неизвестная ошибка. Попробуйте позже." : {
},
"Неизвестный" : {
},
"Неизвестный пользователь" : {
},
"Некорректный ответ от сервера." : {
},
"Нет аккаунта? Регистрация" : {
"comment" : "Регистрация"
},
"Нет сообщений": {},
"О приложении": {},
"Обновить": {},
"Обратная связь": {},
"Описание": {},
"Отображаемое имя": {},
"Отправить предложение": {},
"Отправляем...": {},
"Ошибка авторизации": {},
"Ошибка при деавторизации.": {},
"Нет сообщений" : {
},
"О приложении" : {
},
"Обновить" : {
},
"Обратная связь" : {
},
"Описание" : {
},
"Отображаемое имя" : {
},
"Отправляем..." : {
},
"Ошибка авторизации" : {
},
"Ошибка при деавторизации." : {
},
"Ошибка регистрация" : {
"comment" : "Ошибка"
},
"Ошибка сервера (%@).": {},
"Ошибка сервера: %@": {},
"Ошибка сети: %@": {},
"Ошибка соединения с сервером.": {},
"Ошибка сервера (%@)." : {
},
"Ошибка сервера: %@" : {
},
"Ошибка сети: %@" : {
},
"Ошибка соединения с сервером." : {
},
"Пароли не совпадают" : {
"comment" : "Пароли не совпадают"
},
@ -343,12 +483,18 @@
"Перейдите в раздел \"Настройки > Сменить пароль\" и следуйте инструкциям." : {
"comment" : "FAQ answer: reset password"
},
"Повторить": {},
"Поддержка": {},
"Повторить" : {
},
"Поддержка" : {
},
"Подтверждение пароля" : {
"comment" : "Подтверждение пароля"
},
"Пока что у вас нет чатов": {},
"Пока что у вас нет чатов" : {
},
"Помощь" : {
"comment" : "Help Center",
"localizations" : {
@ -360,24 +506,54 @@
}
}
},
"Приглашение достигло лимита использования.": {},
"Приглашение истекло.": {},
"Приглашение не активно.": {},
"Приложение": {},
"Применить": {},
"Произошла ошибка.": {},
"Профиль": {},
"Публичная информация": {},
"Приглашение достигло лимита использования." : {
},
"Приглашение истекло." : {
},
"Приглашение не активно." : {
},
"Приложение" : {
},
"Применить" : {
},
"Произошла ошибка." : {
},
"Профиль" : {
},
"Публичная информация" : {
},
"Регистрация" : {
"comment" : "Регистрация"
},
"Регистрация временно недоступна.": {},
"Регистрация выполнена, но вход не удался.": {},
"Регистрация запрещена.": {},
"Регистрация и вход выполнены успешно.": {},
"Редактировать профиль": {},
"Сервер не отвечает. Попробуйте позже.": {},
"Сессия истекла. Войдите снова.": {},
"Регистрация временно недоступна." : {
},
"Регистрация выполнена, но вход не удался." : {
},
"Регистрация запрещена." : {
},
"Регистрация и вход выполнены успешно." : {
},
"Редактировать профиль" : {
},
"Сервер не отвечает. Попробуйте позже." : {
},
"Сессия истекла. Войдите снова." : {
},
"Скан" : {
"comment" : "Scan",
"localizations" : {
@ -389,13 +565,27 @@
}
}
},
"Слишком много запросов.": {},
"Сменить пароль": {},
"Сообщение": {},
"Спасибо!": {},
"Тёмная тема": {},
"Уведомления": {},
"Удалить чат (скоро)": {},
"Слишком много запросов." : {
},
"Сменить пароль" : {
},
"Сообщение" : {
},
"Спасибо!" : {
},
"Тёмная тема" : {
},
"Уведомления" : {
},
"Удалить чат (скоро)" : {
},
"Центр авторов" : {
"comment" : "Creator Center",
"localizations" : {
@ -410,8 +600,12 @@
"Частые вопросы" : {
"comment" : "FAQ navigation title"
},
"Чат": {},
"Чаты": {},
"Чат" : {
},
"Чаты" : {
},
"Черновики" : {
"comment" : "Drafts",
"localizations" : {
@ -426,17 +620,11 @@
"Черновики доступны в боковом меню в разделе Drafts." : {
"comment" : "FAQ answer: drafts"
},
"Экран чата в разработке": {},
"Язык": {},
"🌍": {
"localizations": {
"en": {
"stringUnit": {
"state": "translated",
"value": "🌍"
}
}
}
"Экран чата в разработке" : {
},
"Язык" : {
}
},
"version" : "1.0"

View File

@ -1,10 +1,14 @@
import SwiftUI
#if canImport(UIKit)
import UIKit
#endif
struct FeedbackTab: View {
@State private var suggestion: String = ""
@State private var submittedSuggestion: String? = nil
@State private var isSubmitting: Bool = false
@State private var showSubmissionMessage: Bool = false
@FocusState private var isSuggestionFocused: Bool
var body: some View {
ScrollView {
@ -45,6 +49,7 @@ struct FeedbackTab: View {
}
)
.disableAutocorrection(true)
.focused($isSuggestionFocused)
}
Button(action: submitSuggestion) {
@ -55,7 +60,7 @@ struct FeedbackTab: View {
}
Text(isSubmitting
? NSLocalizedString("Отправляем...", comment: "")
: NSLocalizedString("Отправить предложение", comment: ""))
: NSLocalizedString("(не работает) Отправить предложение", comment: ""))
.fontWeight(.semibold)
}
.frame(maxWidth: .infinity)
@ -88,6 +93,11 @@ struct FeedbackTab: View {
.padding(.horizontal, 20)
.padding(.vertical, 32)
}
.simultaneousGesture(
TapGesture().onEnded {
dismissKeyboardIfNeeded()
}
)
}
private var suggestionIsValid: Bool {
@ -98,6 +108,8 @@ struct FeedbackTab: View {
guard suggestionIsValid else { return }
let trimmed = suggestion.trimmingCharacters(in: .whitespacesAndNewlines)
dismissKeyboardIfNeeded()
isSubmitting = true
DispatchQueue.main.asyncAfter(deadline: .now() + 0.7) { // имитируем сетевой вызов
submittedSuggestion = trimmed
@ -110,6 +122,17 @@ struct FeedbackTab: View {
}
}
private extension FeedbackTab {
func dismissKeyboardIfNeeded() {
guard isSuggestionFocused else { return }
isSuggestionFocused = false
#if canImport(UIKit)
UIApplication.shared.sendAction(#selector(UIResponder.resignFirstResponder), to: nil, from: nil, for: nil)
#endif
}
}
struct FeedbackTab_Previews: PreviewProvider {
static var previews: some View {
FeedbackTab()