Implemented wrapping UIKitTextField in a scroll view if text doesn't fit into available space
This commit is contained in:
parent
50c6a72dff
commit
c38f6a6e1a
|
@ -37,8 +37,11 @@ struct LabelledUIKitTextField: View {
|
||||||
var textChanged: ((String) -> Void)? = nil
|
var textChanged: ((String) -> Void)? = nil
|
||||||
|
|
||||||
|
|
||||||
|
@State private var textFitsIntoAvailableSpace: Bool = true
|
||||||
|
|
||||||
|
|
||||||
var body: some View {
|
var body: some View {
|
||||||
HStack {
|
HStack(alignment: .center) {
|
||||||
Text(label)
|
Text(label)
|
||||||
.onTapGesture {
|
.onTapGesture {
|
||||||
DispatchQueue.main.async {
|
DispatchQueue.main.async {
|
||||||
|
@ -48,15 +51,40 @@ struct LabelledUIKitTextField: View {
|
||||||
|
|
||||||
Spacer()
|
Spacer()
|
||||||
|
|
||||||
UIKitTextField(placeholder, text: $text,
|
if textFitsIntoAvailableSpace {
|
||||||
keyboardType: keyboardType, autocapitalizationType: autocapitalizationType, addDoneButton: addDoneButton,
|
textField
|
||||||
isPasswordField: isPasswordField,
|
}
|
||||||
focusOnStart: focusOnStart, focusNextTextFieldOnReturnKeyPress: focusNextTextFieldOnReturnKeyPress, focusTextField: focusTextFieldBinding,
|
else {
|
||||||
isFocusedChanged: isFocusedChanged, textAlignment: .right, isUserInputEnabled: isUserInputEnabled,
|
ScrollView(.horizontal) {
|
||||||
actionOnReturnKeyPress: actionOnReturnKeyPress, textChanged: textChanged)
|
textField
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private var textField: some View {
|
||||||
|
UIKitTextField(placeholder, text: $text,
|
||||||
|
keyboardType: keyboardType, autocapitalizationType: autocapitalizationType, addDoneButton: addDoneButton,
|
||||||
|
isPasswordField: isPasswordField,
|
||||||
|
focusOnStart: focusOnStart, focusNextTextFieldOnReturnKeyPress: focusNextTextFieldOnReturnKeyPress, focusTextField: focusTextFieldBinding,
|
||||||
|
isFocusedChanged: isFocusedChanged, textAlignment: .right, isUserInputEnabled: isUserInputEnabled,
|
||||||
|
actionOnReturnKeyPress: actionOnReturnKeyPress, textChanged: textChanged)
|
||||||
|
|
||||||
|
.background(
|
||||||
|
|
||||||
|
// Render the limited text and measure its size
|
||||||
|
Text(text).lineLimit(1)
|
||||||
|
.background(GeometryReader { availableSpace in
|
||||||
|
Color.clear.onAppear {
|
||||||
|
let textsFrame = availableSpace.frame(in: .global)
|
||||||
|
self.textFitsIntoAvailableSpace = textsFrame.maxX <= UIScreen.main.bounds.width
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.hidden() // Hide the background
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -54,7 +54,7 @@ struct CollapsibleText: View {
|
||||||
.frame(height: .greatestFiniteMagnitude)
|
.frame(height: .greatestFiniteMagnitude)
|
||||||
})
|
})
|
||||||
.hidden() // Hide the background
|
.hidden() // Hide the background
|
||||||
)
|
)
|
||||||
|
|
||||||
if isTruncated {
|
if isTruncated {
|
||||||
Button(action: { self.isExpanded.toggle() }) {
|
Button(action: { self.isExpanded.toggle() }) {
|
||||||
|
|
Loading…
Reference in New Issue