76 lines
		
	
	
	
		
			1.9 KiB
		
	
	
	
		
			Swift
		
	
	
	
	
	
			
		
		
	
	
			76 lines
		
	
	
	
		
			1.9 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) 2022 Jellyfin & Jellyfin Contributors
 | |
| //
 | |
| 
 | |
| import JellyfinAPI
 | |
| import SwiftUI
 | |
| 
 | |
| struct CinematicResumeCardView: View {
 | |
| 
 | |
| 	@EnvironmentObject
 | |
| 	var homeRouter: HomeCoordinator.Router
 | |
| 	@ObservedObject
 | |
| 	var viewModel: HomeViewModel
 | |
| 	let item: BaseItemDto
 | |
| 
 | |
| 	var body: some View {
 | |
| 		VStack(alignment: .leading) {
 | |
| 			Button {
 | |
| 				homeRouter.route(to: \.modalItem, item)
 | |
| 			} label: {
 | |
| 				ZStack(alignment: .bottom) {
 | |
| 
 | |
| 					if item.itemType == .episode {
 | |
| 						ImageView(sources: [
 | |
| 							item.getSeriesThumbImage(maxWidth: 350),
 | |
| 							item.getSeriesBackdropImage(maxWidth: 350),
 | |
| 						])
 | |
| 						.frame(width: 350, height: 210)
 | |
| 					} else {
 | |
| 						ImageView([
 | |
| 							.init(url: item.getThumbImage(maxWidth: 350)),
 | |
| 							.init(url: item.getBackdropImage(maxWidth: 350), blurHash: item.getBackdropImageBlurHash()),
 | |
| 						])
 | |
| 						.frame(width: 350, height: 210)
 | |
| 					}
 | |
| 
 | |
| 					LinearGradient(colors: [.clear, .black],
 | |
| 					               startPoint: .top,
 | |
| 					               endPoint: .bottom)
 | |
| 						.frame(height: 105)
 | |
| 						.ignoresSafeArea()
 | |
| 
 | |
| 					VStack(alignment: .leading, spacing: 0) {
 | |
| 						Text(item.getItemProgressString() ?? "")
 | |
| 							.font(.subheadline)
 | |
| 							.padding(.vertical, 5)
 | |
| 							.padding(.leading, 10)
 | |
| 							.foregroundColor(.white)
 | |
| 
 | |
| 						HStack {
 | |
| 							Color(UIColor.systemPurple)
 | |
| 								.frame(width: 350 * (item.userData?.playedPercentage ?? 0) / 100, height: 7)
 | |
| 
 | |
| 							Spacer(minLength: 0)
 | |
| 						}
 | |
| 					}
 | |
| 				}
 | |
| 				.frame(width: 350, height: 210)
 | |
| 			}
 | |
| 			.buttonStyle(CardButtonStyle())
 | |
| 			.padding(.top)
 | |
| 			.contextMenu {
 | |
| 				Button(role: .destructive) {
 | |
| 					viewModel.removeItemFromResume(item)
 | |
| 				} label: {
 | |
| 					L10n.removeFromResume.text
 | |
| 				}
 | |
| 			}
 | |
| 		}
 | |
| 		.padding(.vertical)
 | |
| 	}
 | |
| }
 |