83 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Swift
		
	
	
	
	
	
			
		
		
	
	
			83 lines
		
	
	
		
			3.3 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 2021 Aiden Vigue & Jellyfin Contributors
 | |
|   */
 | |
| 
 | |
| import SwiftUI
 | |
| 
 | |
| struct PortraitImageHStackView<TopBarView: View, ItemType: PortraitImageStackable>: View {
 | |
| 
 | |
|     let items: [ItemType]
 | |
|     let maxWidth: CGFloat
 | |
|     let horizontalAlignment: HorizontalAlignment
 | |
|     let textAlignment: TextAlignment
 | |
|     let topBarView: () -> TopBarView
 | |
|     let selectedAction: (ItemType) -> Void
 | |
| 
 | |
|     init(items: [ItemType],
 | |
|          maxWidth: CGFloat = 110,
 | |
|          horizontalAlignment: HorizontalAlignment = .leading,
 | |
|          textAlignment: TextAlignment = .leading,
 | |
|          topBarView: @escaping () -> TopBarView,
 | |
|          selectedAction: @escaping (ItemType) -> Void) {
 | |
|         self.items = items
 | |
|         self.maxWidth = maxWidth
 | |
|         self.horizontalAlignment = horizontalAlignment
 | |
|         self.textAlignment = textAlignment
 | |
|         self.topBarView = topBarView
 | |
|         self.selectedAction = selectedAction
 | |
|     }
 | |
| 
 | |
|     var body: some View {
 | |
|         VStack(alignment: .leading, spacing: 0) {
 | |
|             topBarView()
 | |
| 
 | |
|             ScrollView(.horizontal, showsIndicators: false) {
 | |
|                 HStack(alignment: .top, spacing: 15) {
 | |
|                     ForEach(items, id: \.self.portraitImageID) { item in
 | |
|                         Button {
 | |
|                             selectedAction(item)
 | |
|                         } label: {
 | |
|                             VStack(alignment: horizontalAlignment) {
 | |
|                                 ImageView(src: item.imageURLContsructor(maxWidth: Int(maxWidth)),
 | |
|                                           bh: item.blurHash,
 | |
|                                           failureInitials: item.failureInitials)
 | |
|                                     .frame(width: maxWidth, height: maxWidth * 1.5)
 | |
|                                     .cornerRadius(10)
 | |
|                                     .shadow(radius: 4, y: 2)
 | |
| 
 | |
|                                 if item.showTitle {
 | |
|                                     Text(item.title)
 | |
|                                         .font(.footnote)
 | |
|                                         .fontWeight(.regular)
 | |
|                                         .foregroundColor(.primary)
 | |
|                                         .multilineTextAlignment(textAlignment)
 | |
|                                         .fixedSize(horizontal: false, vertical: true)
 | |
|                                         .lineLimit(2)
 | |
|                                 }
 | |
| 
 | |
|                                 if let description = item.subtitle {
 | |
|                                     Text(description)
 | |
|                                         .font(.caption)
 | |
|                                         .fontWeight(.medium)
 | |
|                                         .foregroundColor(.secondary)
 | |
|                                         .multilineTextAlignment(textAlignment)
 | |
|                                         .fixedSize(horizontal: false, vertical: true)
 | |
|                                         .lineLimit(2)
 | |
|                                 }
 | |
|                             }
 | |
|                             .frame(width: maxWidth)
 | |
|                         }
 | |
|                         .padding(.bottom)
 | |
|                     }
 | |
|                 }
 | |
|                 .padding(.horizontal)
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| }
 |