another.im-ios/Monal/another.im/Views/Conversation/ConversationTextInput.swift

105 lines
4.2 KiB
Swift
Raw Normal View History

2024-11-23 23:22:07 +00:00
import SwiftUI
import UIKit
struct ConversationTextInput: View {
@Environment(\.router) var router
2024-11-25 13:14:23 +00:00
@EnvironmentObject var chatWrapper: MonalChatWrapper
2024-11-23 23:22:07 +00:00
@State private var messageStr = ""
@FocusState private var isFocused: Bool
@Binding var autoScroll: Bool
var body: some View {
VStack(spacing: 0) {
Rectangle()
.foregroundColor(.Material.Shape.separator)
.frame(height: 0.5)
.padding(.bottom, 8)
2024-11-25 13:14:23 +00:00
if !chatWrapper.replyText.isEmpty {
VStack(spacing: 0) {
HStack(alignment: .top) {
Text(chatWrapper.replyText)
.font(.body3)
.foregroundColor(Color.Material.Text.main)
.multilineTextAlignment(.leading)
.lineLimit(3)
.padding(8)
Spacer()
Image(systemName: "xmark")
.font(.title2)
.foregroundColor(.Material.Elements.active)
.padding(.leading, 8)
.tappablePadding(.symmetric(8)) {
chatWrapper.replyText = ""
}
.padding(8)
}
.frame(maxWidth: .infinity)
.background(RoundedRectangle(cornerRadius: 4)
.foregroundColor(.Material.Background.light)
.shadow(radius: 0.5)
)
.padding(.bottom, 8)
.padding(.horizontal, 8)
}
.padding(.horizontal, 8)
}
2024-11-23 23:22:07 +00:00
HStack {
Image(systemName: "paperclip")
.font(.title2)
.foregroundColor(.Material.Elements.active)
.padding(.leading, 8)
.tappablePadding(.symmetric(8)) {
router.showScreen(.fullScreenCover) { _ in
2024-11-25 13:14:23 +00:00
Text("not yet implemented")
// AttachmentPickerScreen()
2024-11-23 23:22:07 +00:00
// .environmentObject(messages)
// .environmentObject(attachments)
}
}
TextField("", text: $messageStr, prompt: Text(L10n.Chat.textfieldPrompt).foregroundColor(.Material.Shape.separator), axis: .vertical)
.font(.body1)
.foregroundColor(Color.Material.Text.main)
.accentColor(.Material.Shape.black)
.focused($isFocused)
.padding(.horizontal, 8)
.padding(.vertical, 4)
.background(Color.Material.Shape.white)
.clipShape(RoundedRectangle(cornerRadius: 8))
.padding(.vertical, 4)
let img = messageStr.isEmpty ? "paperplane" : "paperplane.fill"
Image(systemName: img)
.font(.title2)
.foregroundColor(messageStr.isEmpty ? .Material.Elements.inactive : .Material.Elements.active)
.padding(.trailing, 8)
.tappablePadding(.symmetric(8)) {
if !messageStr.isEmpty {
2024-11-25 13:14:23 +00:00
chatWrapper.sendText(composedMessage)
messageStr = ""
autoScroll = true
if !chatWrapper.replyText.isEmpty {
chatWrapper.replyText = ""
}
2024-11-23 23:22:07 +00:00
}
}
}
}
.padding(.bottom, 8)
.background(Color.Material.Background.dark)
2024-11-25 13:14:23 +00:00
.onChange(of: chatWrapper.replyText) { new in
if !new.isEmpty {
isFocused = true
}
}
2024-11-23 23:22:07 +00:00
}
private var composedMessage: String {
var result = ""
2024-11-25 13:14:23 +00:00
if !chatWrapper.replyText.isEmpty {
result += chatWrapper.replyText.makeReply + "\n\n"
}
result += messageStr
2024-11-23 23:22:07 +00:00
return result
}
}