From c38f6a6e1a83305cbd4c56c32e10bc94be4c388a Mon Sep 17 00:00:00 2001 From: dankito Date: Mon, 14 Sep 2020 22:47:19 +0200 Subject: [PATCH] Implemented wrapping UIKitTextField in a scroll view if text doesn't fit into available space --- .../ui/UIKit/LabelledUIKitTextField.swift | 42 +++++++++++++++---- .../ui/views/CollapsibleText.swift | 2 +- 2 files changed, 36 insertions(+), 8 deletions(-) diff --git a/ui/BankingiOSApp/BankingiOSApp/ui/UIKit/LabelledUIKitTextField.swift b/ui/BankingiOSApp/BankingiOSApp/ui/UIKit/LabelledUIKitTextField.swift index c3ba94bc..82a1b047 100644 --- a/ui/BankingiOSApp/BankingiOSApp/ui/UIKit/LabelledUIKitTextField.swift +++ b/ui/BankingiOSApp/BankingiOSApp/ui/UIKit/LabelledUIKitTextField.swift @@ -36,9 +36,12 @@ struct LabelledUIKitTextField: View { var textChanged: ((String) -> Void)? = nil + + @State private var textFitsIntoAvailableSpace: Bool = true + var body: some View { - HStack { + HStack(alignment: .center) { Text(label) .onTapGesture { DispatchQueue.main.async { @@ -48,14 +51,39 @@ struct LabelledUIKitTextField: View { Spacer() - 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) + if textFitsIntoAvailableSpace { + textField + } + else { + ScrollView(.horizontal) { + 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 + ) + } } diff --git a/ui/BankingiOSApp/BankingiOSApp/ui/views/CollapsibleText.swift b/ui/BankingiOSApp/BankingiOSApp/ui/views/CollapsibleText.swift index 5fd21686..a3e699fa 100644 --- a/ui/BankingiOSApp/BankingiOSApp/ui/views/CollapsibleText.swift +++ b/ui/BankingiOSApp/BankingiOSApp/ui/views/CollapsibleText.swift @@ -54,7 +54,7 @@ struct CollapsibleText: View { .frame(height: .greatestFiniteMagnitude) }) .hidden() // Hide the background - ) + ) if isTruncated { Button(action: { self.isExpanded.toggle() }) {