59 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Swift
		
	
	
	
	
	
			
		
		
	
	
			59 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Swift
		
	
	
	
	
	
| //
 | |
| // Swiftfin is subject to the terms of the Mozilla Public
 | |
| // License, v2.0. If a copy of the MPL was not distributed with this
 | |
| // file, you can obtain one at https://mozilla.org/MPL/2.0/.
 | |
| //
 | |
| // Copyright (c) 2023 Jellyfin & Jellyfin Contributors
 | |
| //
 | |
| 
 | |
| import SwiftUI
 | |
| 
 | |
| // TODO: See if `descriptionTopPadding` is really necessary to fix the navigation bar padding, or just add all the time
 | |
| 
 | |
| struct SplitFormWindowView: View {
 | |
| 
 | |
|     private var descriptionTopPadding: Bool = false
 | |
| 
 | |
|     private var contentView: () -> any View
 | |
|     private var descriptionView: () -> any View
 | |
| 
 | |
|     var body: some View {
 | |
|         HStack {
 | |
| 
 | |
|             descriptionView()
 | |
|                 .eraseToAnyView()
 | |
|                 .frame(maxWidth: .infinity)
 | |
| 
 | |
|             Form {
 | |
|                 contentView()
 | |
|                     .eraseToAnyView()
 | |
|             }
 | |
|             .if(descriptionTopPadding) { view in
 | |
|                 view.padding(.top)
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| }
 | |
| 
 | |
| extension SplitFormWindowView {
 | |
| 
 | |
|     init() {
 | |
|         self.init(
 | |
|             contentView: { EmptyView() },
 | |
|             descriptionView: { Color.clear }
 | |
|         )
 | |
|     }
 | |
| 
 | |
|     func contentView(@ViewBuilder _ content: @escaping () -> any View) -> Self {
 | |
|         copy(modifying: \.contentView, with: content)
 | |
|     }
 | |
| 
 | |
|     func descriptionView(@ViewBuilder _ content: @escaping () -> any View) -> Self {
 | |
|         copy(modifying: \.descriptionView, with: content)
 | |
|     }
 | |
| 
 | |
|     func withDescriptionTopPadding() -> Self {
 | |
|         copy(modifying: \.descriptionTopPadding, with: true)
 | |
|     }
 | |
| }
 |