라이브 방

- 채팅창 너비 축소
- 오른쪽 하단 옵션 버튼 baseline이 채팅창 baseline과 동일하게 설정
This commit is contained in:
Yu Sung
2024-10-24 01:46:10 +09:00
parent 97a3637a7b
commit c7314cc1d4
3 changed files with 116 additions and 53 deletions

View File

@@ -0,0 +1,61 @@
//
// ChatTextFieldView.swift
// SodaLive
//
// Created by klaus on 10/24/24.
//
import SwiftUI
import UIKit
struct ChatTextFieldView: UIViewRepresentable {
class Coordinator: NSObject, UITextFieldDelegate {
var parent: ChatTextFieldView
init(parent: ChatTextFieldView) {
self.parent = parent
}
func textFieldShouldReturn(_ textField: UITextField) -> Bool {
// "Send"
parent.onSend()
return true
}
@objc func textDidChange(_ textField: UITextField) {
parent.text = textField.text ?? ""
}
}
@Binding var text: String
var placeholder: String
var onSend: () -> Void
func makeUIView(context: Context) -> UITextField {
let textField = UITextField(frame: .zero)
textField.delegate = context.coordinator
textField.borderStyle = .roundedRect
textField.placeholder = placeholder
textField.autocorrectionType = .no
textField.autocapitalizationType = .none
textField.borderStyle = .none
textField.backgroundColor = UIColor(hex: "222222")
textField.textColor = UIColor(hex: "BBBBBB")
textField.tintColor = UIColor(hex: "3BB9F1")
textField.font = UIFont(name: Font.medium.rawValue, size: 13.3)
textField.returnKeyType = .send
textField.addTarget(context.coordinator, action: #selector(Coordinator.textDidChange(_:)), for: .editingChanged)
return textField
}
func updateUIView(_ uiView: UITextField, context: Context) {
uiView.text = text
}
func makeCoordinator() -> Coordinator {
return Coordinator(parent: self)
}
}
#Preview {
ChatTextFieldView(text: .constant(""), placeholder: "채팅을 입력하세요") {}
}