74 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Swift
		
	
	
	
			
		
		
	
	
			74 lines
		
	
	
		
			2.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 2021 Aiden Vigue & Jellyfin Contributors
 | |
|  */
 | |
| 
 | |
| import Foundation
 | |
| import SwiftUI
 | |
| 
 | |
| struct HomeView: View {
 | |
|     @EnvironmentObject var homeRouter: HomeCoordinator.Router
 | |
|     @StateObject var viewModel = HomeViewModel()
 | |
| 
 | |
|     @ViewBuilder
 | |
|     var innerBody: some View {
 | |
|         if viewModel.isLoading {
 | |
|             ProgressView()
 | |
|         } else {
 | |
|             ScrollView {
 | |
|                 VStack(alignment: .leading) {
 | |
|                     if !viewModel.resumeItems.isEmpty {
 | |
|                         ContinueWatchingView(items: viewModel.resumeItems)
 | |
|                     }
 | |
|                     if !viewModel.nextUpItems.isEmpty {
 | |
|                         NextUpView(items: viewModel.nextUpItems)
 | |
|                     }
 | |
|                     if !viewModel.librariesShowRecentlyAddedIDs.isEmpty {
 | |
|                         ForEach(viewModel.librariesShowRecentlyAddedIDs, id: \.self) { libraryID in
 | |
|                             let library = viewModel.libraries.first(where: { $0.id == libraryID })
 | |
|                             HStack {
 | |
|                                 Text("Latest \(library?.name ?? "")")
 | |
|                                     .font(.title2)
 | |
|                                     .fontWeight(.bold)
 | |
|                                 Spacer()
 | |
|                                 Button {
 | |
|                                     homeRouter
 | |
|                                         .route(to: \.library, (viewModel: .init(parentID: libraryID,
 | |
|                                                                                 filters: viewModel.recentFilterSet),
 | |
|                                                                title: library?.name ?? ""))
 | |
|                                 } label: {
 | |
|                                     HStack {
 | |
|                                         Text("See All").font(.subheadline).fontWeight(.bold)
 | |
|                                         Image(systemName: "chevron.right").font(Font.subheadline.bold())
 | |
|                                     }
 | |
|                                 }
 | |
|                             }.padding(.leading, 16)
 | |
|                                 .padding(.trailing, 16)
 | |
|                             LatestMediaView(viewModel: .init(libraryID: libraryID))
 | |
|                         }
 | |
|                     }
 | |
|                 }
 | |
|                 .padding(.bottom, UIDevice.current.userInterfaceIdiom == .phone ? 20 : 30)
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     var body: some View {
 | |
|         innerBody
 | |
|             .navigationTitle(NSLocalizedString("Home", comment: ""))
 | |
|             .toolbar {
 | |
|                 ToolbarItemGroup(placement: .navigationBarTrailing) {
 | |
|                     Button {
 | |
|                         homeRouter.route(to: \.settings)
 | |
|                     } label: {
 | |
|                         Image(systemName: "gear")
 | |
|                     }
 | |
|                 }
 | |
|             }
 | |
|     }
 | |
| }
 |