Compare commits
No commits in common. "2f68345c569aa1eba31589c3ec98a2852e87dc62" and "359b51627228b1b84f4102c0c69da771bc4d2285" have entirely different histories.
2f68345c56
...
359b516272
@ -235,9 +235,6 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"Если не нашли ответ, напишите нам своё предложение или проблему." : {
|
|
||||||
"comment" : "FAQ: contact developers footer"
|
|
||||||
},
|
|
||||||
"Заглушка: Push-уведомления" : {
|
"Заглушка: Push-уведомления" : {
|
||||||
|
|
||||||
},
|
},
|
||||||
@ -336,7 +333,6 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"Идеи" : {
|
"Идеи" : {
|
||||||
"extractionState" : "stale",
|
|
||||||
"localizations" : {
|
"localizations" : {
|
||||||
"en" : {
|
"en" : {
|
||||||
"stringUnit" : {
|
"stringUnit" : {
|
||||||
@ -400,12 +396,6 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"Кликер в разработке" : {
|
|
||||||
"comment" : "Concept tab placeholder title"
|
|
||||||
},
|
|
||||||
"Концепт" : {
|
|
||||||
"comment" : "Tab bar: concept clicker"
|
|
||||||
},
|
|
||||||
"Корзина" : {
|
"Корзина" : {
|
||||||
"comment" : "Cart",
|
"comment" : "Cart",
|
||||||
"localizations" : {
|
"localizations" : {
|
||||||
@ -1134,9 +1124,6 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"Связаться с разработчиками" : {
|
|
||||||
"comment" : "FAQ: contact developers link"
|
|
||||||
},
|
|
||||||
"Сервер не отвечает. Попробуйте позже." : {
|
"Сервер не отвечает. Попробуйте позже." : {
|
||||||
"localizations" : {
|
"localizations" : {
|
||||||
"en" : {
|
"en" : {
|
||||||
@ -1178,9 +1165,6 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"Скоро появится мини-игра, где можно заработать очки для кастомизации профиля. Следите за обновлениями!" : {
|
|
||||||
"comment" : "Concept tab placeholder description"
|
|
||||||
},
|
|
||||||
"Слишком много запросов." : {
|
"Слишком много запросов." : {
|
||||||
"localizations" : {
|
"localizations" : {
|
||||||
"en" : {
|
"en" : {
|
||||||
|
|||||||
@ -6,9 +6,6 @@
|
|||||||
//
|
//
|
||||||
|
|
||||||
import SwiftUI
|
import SwiftUI
|
||||||
#if canImport(UIKit)
|
|
||||||
import UIKit
|
|
||||||
#endif
|
|
||||||
|
|
||||||
struct ChatsTab: View {
|
struct ChatsTab: View {
|
||||||
var currentUserId: String?
|
var currentUserId: String?
|
||||||
@ -128,9 +125,7 @@ struct ChatsTab: View {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
.listStyle(.plain)
|
.listStyle(.plain)
|
||||||
.modifier(ScrollDismissesKeyboardModifier())
|
|
||||||
.simultaneousGesture(searchBarGesture)
|
.simultaneousGesture(searchBarGesture)
|
||||||
.simultaneousGesture(tapToDismissKeyboardGesture)
|
|
||||||
// .safeAreaInset(edge: .top) {
|
// .safeAreaInset(edge: .top) {
|
||||||
// VStack(spacing: 0) {
|
// VStack(spacing: 0) {
|
||||||
// searchBar
|
// searchBar
|
||||||
@ -198,12 +193,6 @@ struct ChatsTab: View {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private var tapToDismissKeyboardGesture: some Gesture {
|
|
||||||
TapGesture().onEnded {
|
|
||||||
dismissKeyboard()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private var isSearching: Bool {
|
private var isSearching: Bool {
|
||||||
!searchText.trimmingCharacters(in: .whitespacesAndNewlines).isEmpty
|
!searchText.trimmingCharacters(in: .whitespacesAndNewlines).isEmpty
|
||||||
}
|
}
|
||||||
@ -297,24 +286,6 @@ struct ChatsTab: View {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private extension ChatsTab {
|
|
||||||
func dismissKeyboard() {
|
|
||||||
#if canImport(UIKit)
|
|
||||||
UIApplication.shared.sendAction(#selector(UIResponder.resignFirstResponder), to: nil, from: nil, for: nil)
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private struct ScrollDismissesKeyboardModifier: ViewModifier {
|
|
||||||
func body(content: Content) -> some View {
|
|
||||||
if #available(iOS 16.0, *) {
|
|
||||||
content.scrollDismissesKeyboard(.interactively)
|
|
||||||
} else {
|
|
||||||
content
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private struct ChatRowView: View {
|
private struct ChatRowView: View {
|
||||||
let chat: PrivateChatListItem
|
let chat: PrivateChatListItem
|
||||||
let currentUserId: String?
|
let currentUserId: String?
|
||||||
|
|||||||
@ -1,33 +0,0 @@
|
|||||||
import SwiftUI
|
|
||||||
|
|
||||||
struct ConceptTab: View {
|
|
||||||
var body: some View {
|
|
||||||
ScrollView {
|
|
||||||
VStack(spacing: 24) {
|
|
||||||
Image(systemName: "gamecontroller.fill")
|
|
||||||
.resizable()
|
|
||||||
.scaledToFit()
|
|
||||||
.frame(width: 96, height: 96)
|
|
||||||
.foregroundColor(.accentColor)
|
|
||||||
|
|
||||||
Text(NSLocalizedString("Кликер в разработке", comment: "Concept tab placeholder title"))
|
|
||||||
.font(.title2)
|
|
||||||
.fontWeight(.semibold)
|
|
||||||
|
|
||||||
Text(NSLocalizedString("Скоро появится мини-игра, где можно заработать очки для кастомизации профиля. Следите за обновлениями!", comment: "Concept tab placeholder description"))
|
|
||||||
.font(.body)
|
|
||||||
.multilineTextAlignment(.center)
|
|
||||||
.foregroundColor(.secondary)
|
|
||||||
.padding(.horizontal)
|
|
||||||
}
|
|
||||||
.padding(.vertical, 48)
|
|
||||||
.frame(maxWidth: .infinity)
|
|
||||||
}
|
|
||||||
.background(Color(UIColor.systemGroupedBackground))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#Preview {
|
|
||||||
ConceptTab()
|
|
||||||
.environmentObject(ThemeManager())
|
|
||||||
}
|
|
||||||
@ -12,7 +12,7 @@ struct CustomTabBar: View {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Tab 2: Search
|
// Tab 2: Search
|
||||||
TabBarButton(systemName: "gamecontroller.fill", text: NSLocalizedString("Концепт", comment: "Tab bar: concept clicker"), isSelected: selectedTab == 1) {
|
TabBarButton(systemName: "lightbulb", text: NSLocalizedString("Идеи", comment: ""), isSelected: selectedTab == 1) {
|
||||||
selectedTab = 1
|
selectedTab = 1
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -3,7 +3,7 @@ import SwiftUI
|
|||||||
import UIKit
|
import UIKit
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
struct FeedbackView: View {
|
struct FeedbackTab: View {
|
||||||
@State private var suggestion: String = ""
|
@State private var suggestion: String = ""
|
||||||
@State private var submittedSuggestion: String? = nil
|
@State private var submittedSuggestion: String? = nil
|
||||||
@State private var isSubmitting: Bool = false
|
@State private var isSubmitting: Bool = false
|
||||||
@ -122,7 +122,7 @@ struct FeedbackView: View {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private extension FeedbackView {
|
private extension FeedbackTab {
|
||||||
func dismissKeyboardIfNeeded() {
|
func dismissKeyboardIfNeeded() {
|
||||||
guard isSuggestionFocused else { return }
|
guard isSuggestionFocused else { return }
|
||||||
isSuggestionFocused = false
|
isSuggestionFocused = false
|
||||||
@ -133,9 +133,9 @@ private extension FeedbackView {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
struct FeedbackView_Previews: PreviewProvider {
|
struct FeedbackTab_Previews: PreviewProvider {
|
||||||
static var previews: some View {
|
static var previews: some View {
|
||||||
FeedbackView()
|
FeedbackTab()
|
||||||
.environmentObject(ThemeManager())
|
.environmentObject(ThemeManager())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -18,7 +18,7 @@ struct MainView: View {
|
|||||||
private var tabTitle: String {
|
private var tabTitle: String {
|
||||||
switch selectedTab {
|
switch selectedTab {
|
||||||
case 0: return "Home"
|
case 0: return "Home"
|
||||||
case 1: return "Concept"
|
case 1: return "Ideas"
|
||||||
case 2: return "Chats"
|
case 2: return "Chats"
|
||||||
case 3: return "Profile"
|
case 3: return "Profile"
|
||||||
default: return "Home"
|
default: return "Home"
|
||||||
@ -47,7 +47,7 @@ struct MainView: View {
|
|||||||
NewHomeTab()
|
NewHomeTab()
|
||||||
.opacity(selectedTab == 0 ? 1 : 0)
|
.opacity(selectedTab == 0 ? 1 : 0)
|
||||||
|
|
||||||
ConceptTab()
|
FeedbackTab()
|
||||||
.opacity(selectedTab == 1 ? 1 : 0)
|
.opacity(selectedTab == 1 ? 1 : 0)
|
||||||
|
|
||||||
ChatsTab(
|
ChatsTab(
|
||||||
|
|||||||
@ -23,29 +23,15 @@ struct FAQView: View {
|
|||||||
]
|
]
|
||||||
|
|
||||||
var body: some View {
|
var body: some View {
|
||||||
List {
|
List(faqItems) { item in
|
||||||
ForEach(faqItems) { item in
|
VStack(alignment: .leading, spacing: 6) {
|
||||||
VStack(alignment: .leading, spacing: 6) {
|
Text(item.question)
|
||||||
Text(item.question)
|
.font(.headline)
|
||||||
.font(.headline)
|
Text(item.answer)
|
||||||
Text(item.answer)
|
.font(.subheadline)
|
||||||
.font(.subheadline)
|
.foregroundColor(.secondary)
|
||||||
.foregroundColor(.secondary)
|
|
||||||
}
|
|
||||||
.padding(.vertical, 6)
|
|
||||||
}
|
|
||||||
|
|
||||||
Section {
|
|
||||||
NavigationLink(destination: FeedbackView()) {
|
|
||||||
Text(NSLocalizedString("Связаться с разработчиками", comment: "FAQ: contact developers link"))
|
|
||||||
.font(.callout)
|
|
||||||
.fontWeight(.semibold)
|
|
||||||
.foregroundColor(.accentColor)
|
|
||||||
}
|
|
||||||
} footer: {
|
|
||||||
Text(NSLocalizedString("Если не нашли ответ, напишите нам своё предложение или проблему.", comment: "FAQ: contact developers footer"))
|
|
||||||
.font(.footnote)
|
|
||||||
}
|
}
|
||||||
|
.padding(.vertical, 6)
|
||||||
}
|
}
|
||||||
.listStyle(.insetGrouped)
|
.listStyle(.insetGrouped)
|
||||||
.navigationTitle(NSLocalizedString("Частые вопросы", comment: "FAQ navigation title"))
|
.navigationTitle(NSLocalizedString("Частые вопросы", comment: "FAQ navigation title"))
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user