diff --git a/Sources/Orbit/Components/InputField.swift b/Sources/Orbit/Components/InputField.swift index 03bde156830..08d8b5b01e5 100644 --- a/Sources/Orbit/Components/InputField.swift +++ b/Sources/Orbit/Components/InputField.swift @@ -71,7 +71,6 @@ public struct InputField: private let isSecure: Bool private let passwordStrength: PasswordStrengthIndicator.PasswordStrength? private let message: Message? - @Binding private var messageHeight: CGFloat // Builder properties (keyboard related) var autocapitalizationType: UITextAutocapitalizationType = .none @@ -82,7 +81,7 @@ public struct InputField: var shouldDeleteBackwardAction: (String) -> Bool = { _ in true } public var body: some View { - FieldWrapper(message: message, messageHeight: $messageHeight) { + FieldWrapper(message: message) { InputContent(state: state, message: message, isFocused: isFocused) { textField } label: { @@ -206,7 +205,6 @@ public struct InputField: /// /// - Parameters: /// - message: Optional message below the text field. - /// - messageHeight: Binding to the current height of the optional message. public init( value: Binding, state: InputState = .default, @@ -214,7 +212,6 @@ public struct InputField: isSecure: Bool = false, passwordStrength: PasswordStrengthIndicator.PasswordStrength? = nil, message: Message? = nil, - messageHeight: Binding = .constant(0), @ViewBuilder label: () -> Label, @ViewBuilder prompt: () -> Prompt = { EmptyView() }, @ViewBuilder prefix: () -> Prefix = { EmptyView() }, @@ -226,7 +223,6 @@ public struct InputField: self.isSecure = isSecure self.passwordStrength = passwordStrength self.message = message - self._messageHeight = messageHeight self.label = label() self.prompt = prompt() self.prefix = prefix() @@ -241,7 +237,6 @@ public extension InputField where Label == Text, Prompt == Text, Prefix == Icon, /// /// - Parameters: /// - message: Optional message below the text field. - /// - messageHeight: Binding to the current height of the optional message. @_disfavoredOverload init( _ label: some StringProtocol = String(""), @@ -253,8 +248,7 @@ public extension InputField where Label == Text, Prompt == Text, Prefix == Icon, labelStyle: InputLabelStyle = .default, isSecure: Bool = false, passwordStrength: PasswordStrengthIndicator.PasswordStrength? = nil, - message: Message? = nil, - messageHeight: Binding = .constant(0) + message: Message? = nil ) { self.init( value: value, @@ -262,8 +256,7 @@ public extension InputField where Label == Text, Prompt == Text, Prefix == Icon, labelStyle: labelStyle, isSecure: isSecure, passwordStrength: passwordStrength, - message: message, - messageHeight: messageHeight + message: message ) { Text(label) } prompt: { @@ -279,7 +272,6 @@ public extension InputField where Label == Text, Prompt == Text, Prefix == Icon, /// /// - Parameters: /// - message: Optional message below the text field. - /// - messageHeight: Binding to the current height of the optional message. @_semantics("swiftui.init_with_localization") init( _ label: LocalizedStringKey = "", @@ -292,7 +284,6 @@ public extension InputField where Label == Text, Prompt == Text, Prefix == Icon, isSecure: Bool = false, passwordStrength: PasswordStrengthIndicator.PasswordStrength? = nil, message: Message? = nil, - messageHeight: Binding = .constant(0), tableName: String? = nil, bundle: Bundle? = nil, labelComment: StaticString? = nil @@ -303,8 +294,7 @@ public extension InputField where Label == Text, Prompt == Text, Prefix == Icon, labelStyle: labelStyle, isSecure: isSecure, passwordStrength: passwordStrength, - message: message, - messageHeight: messageHeight + message: message ) { Text(label, tableName: tableName, bundle: bundle) } prompt: { diff --git a/Sources/Orbit/Components/Select.swift b/Sources/Orbit/Components/Select.swift index 510d17c4e34..a0b4f215847 100644 --- a/Sources/Orbit/Components/Select.swift +++ b/Sources/Orbit/Components/Select.swift @@ -42,8 +42,6 @@ public struct Select = .constant(0), action: @escaping () -> Void, @ViewBuilder label: () -> Label = { EmptyView() }, @ViewBuilder value: () -> Value = { EmptyView() }, @@ -154,7 +151,6 @@ public struct Select = .constant(0), action: @escaping () -> Void ) { self.init( state: state, labelStyle: labelStyle, - message: message, - messageHeight: messageHeight + message: message ) { action() } label: { @@ -213,7 +207,6 @@ public extension Select where Prefix == Icon, Suffix == Icon, Label == Text, Val state: InputState = .default, labelStyle: InputLabelStyle = .default, message: Message? = nil, - messageHeight: Binding = .constant(0), tableName: String? = nil, bundle: Bundle? = nil, labelComment: StaticString? = nil, @@ -222,8 +215,7 @@ public extension Select where Prefix == Icon, Suffix == Icon, Label == Text, Val self.init( state: state, labelStyle: labelStyle, - message: message, - messageHeight: messageHeight + message: message ) { action() } label: { diff --git a/Sources/Orbit/Components/Textarea.swift b/Sources/Orbit/Components/Textarea.swift index d808794b341..3546686fee9 100644 --- a/Sources/Orbit/Components/Textarea.swift +++ b/Sources/Orbit/Components/Textarea.swift @@ -35,7 +35,6 @@ public struct Textarea: View, TextFieldBuildable { private let state: InputState private let message: Message? - @Binding private var messageHeight: CGFloat @ViewBuilder private let label: Label @ViewBuilder private let prompt: Prompt @@ -48,7 +47,7 @@ public struct Textarea: View, TextFieldBuildable { var shouldDeleteBackwardAction: (String) -> Bool = { _ in true } public var body: some View { - FieldWrapper(message: message, messageHeight: $messageHeight) { + FieldWrapper(message: message) { InputContent(state: state, message: message, isFocused: isFocused) { textView .alignmentGuide(.firstTextBaseline) { dimension in @@ -109,19 +108,16 @@ public struct Textarea: View, TextFieldBuildable { /// /// - Parameters: /// - message: Optional message below the text field. - /// - messageHeight: Binding to the current height of the optional message. public init( value: Binding, state: InputState = .default, message: Message? = nil, - messageHeight: Binding = .constant(0), @ViewBuilder label: () -> Label, @ViewBuilder prompt: () -> Prompt = { EmptyView() } ) { self._value = value self.state = state self.message = message - self._messageHeight = messageHeight self.label = label() self.prompt = prompt() } @@ -134,21 +130,18 @@ public extension Textarea where Label == Text, Prompt == Text { /// /// - Parameters: /// - message: Optional message below the text field. - /// - messageHeight: Binding to the current height of the optional message. @_disfavoredOverload init( _ label: some StringProtocol = String(""), value: Binding, prompt: some StringProtocol = String(""), state: InputState = .default, - message: Message? = nil, - messageHeight: Binding = .constant(0) + message: Message? = nil ) { self.init( value: value, state: state, - message: message, - messageHeight: messageHeight + message: message ) { Text(label) } prompt: { @@ -160,7 +153,6 @@ public extension Textarea where Label == Text, Prompt == Text { /// /// - Parameters: /// - message: Optional message below the text field. - /// - messageHeight: Binding to the current height of the optional message. @_semantics("swiftui.init_with_localization") init( _ label: LocalizedStringKey = "", @@ -168,7 +160,6 @@ public extension Textarea where Label == Text, Prompt == Text { prompt: LocalizedStringKey = "", state: InputState = .default, message: Message? = nil, - messageHeight: Binding = .constant(0), tableName: String? = nil, bundle: Bundle? = nil, labelComment: StaticString? = nil @@ -176,8 +167,7 @@ public extension Textarea where Label == Text, Prompt == Text { self.init( value: value, state: state, - message: message, - messageHeight: messageHeight + message: message ) { Text(label, tableName: tableName, bundle: bundle) } prompt: { diff --git a/Sources/Orbit/Support/Forms/FieldWrapper.swift b/Sources/Orbit/Support/Forms/FieldWrapper.swift index 16802fa2613..f231f7c006f 100644 --- a/Sources/Orbit/Support/Forms/FieldWrapper.swift +++ b/Sources/Orbit/Support/Forms/FieldWrapper.swift @@ -1,14 +1,12 @@ import SwiftUI -/// Orbit support component that orovides label and message around input field. +/// Orbit support component that provides label and message around the form field. public struct FieldWrapper: View { - @Binding private var messageHeight: CGFloat - private let message: Message? - @ViewBuilder private let content: Content @ViewBuilder private let label: Label @ViewBuilder private let footer: Footer + @ViewBuilder private let content: Content public var body: some View { VStack(alignment: .leading, spacing: 0) { @@ -18,13 +16,11 @@ public struct FieldWrapper: View { content - ContentHeightReader(height: $messageHeight) { - VStack(alignment: .leading, spacing: 0) { - footer + VStack(alignment: .leading, spacing: 0) { + footer - FieldMessage(message) - .padding(.top, .xxSmall) - } + FieldMessage(message) + .padding(.top, .xxSmall) } } } @@ -32,13 +28,11 @@ public struct FieldWrapper: View { /// Creates Orbit ``FieldWrapper`` around form field content with a custom label and an additional message content. public init( message: Message? = nil, - messageHeight: Binding = .constant(0), @ViewBuilder content: () -> Content, @ViewBuilder label: () -> Label, @ViewBuilder footer: () -> Footer = { EmptyView() } ) { self.message = message - self._messageHeight = messageHeight self.content = content() self.label = label() self.footer = footer() @@ -53,13 +47,11 @@ public extension FieldWrapper where Label == Text { init( _ label: some StringProtocol = String(""), message: Message? = nil, - messageHeight: Binding = .constant(0), @ViewBuilder content: () -> Content, @ViewBuilder footer: () -> Footer = { EmptyView() } ) { self.init( message: message, - messageHeight: messageHeight, content: content, label: { Text(label) @@ -73,13 +65,11 @@ public extension FieldWrapper where Label == Text { init( _ label: LocalizedStringKey = "", message: Message? = nil, - messageHeight: Binding = .constant(0), @ViewBuilder content: () -> Content, @ViewBuilder footer: () -> Footer = { EmptyView() } ) { self.init( message: message, - messageHeight: messageHeight, content: content, label: { Text(label) @@ -114,32 +104,29 @@ struct FieldWrapperPreviews: PreviewProvider { contentPlaceholder } - StateWrapper((true, true, CGFloat(0), false)) { state in + StateWrapper((true, true, false)) { state in VStack(alignment: .leading, spacing: .large) { FieldWrapper( state.0.wrappedValue ? "Form Field Label" : "", - message: state.1.wrappedValue ? .error("Error message") : .none, - messageHeight: state.2 + message: state.1.wrappedValue ? .error("Error message") : .none ) { contentPlaceholder } - Text("Message height: \(state.2.wrappedValue)") - HStack(spacing: .medium) { Button("Toggle label") { state.0.wrappedValue.toggle() - state.3.wrappedValue.toggle() + state.2.wrappedValue.toggle() } Button("Toggle message") { state.1.wrappedValue.toggle() - state.3.wrappedValue.toggle() + state.2.wrappedValue.toggle() } } Spacer() } - .animation(.easeOut(duration: 1), value: state.3.wrappedValue) + .animation(.easeOut(duration: 1), value: state.2.wrappedValue) } .previewDisplayName("Live preview") }