From 885615d1dd029138700c36bb8b23d211cf713811 Mon Sep 17 00:00:00 2001 From: Shav Kinderlehrer Date: Sat, 23 Dec 2023 00:53:44 -0500 Subject: Refactor LibraryIconView --- Jel/Views/Library/LibraryDetailView.swift | 43 +++++++++++++++++++++++++++++++ 1 file changed, 43 insertions(+) create mode 100644 Jel/Views/Library/LibraryDetailView.swift (limited to 'Jel/Views/Library/LibraryDetailView.swift') diff --git a/Jel/Views/Library/LibraryDetailView.swift b/Jel/Views/Library/LibraryDetailView.swift new file mode 100644 index 0000000..3d5a04b --- /dev/null +++ b/Jel/Views/Library/LibraryDetailView.swift @@ -0,0 +1,43 @@ +// +// LibraryDetailView.swift +// Jel +// +// Created by zerocool on 12/22/23. +// + +import SwiftUI +import JellyfinKit + +struct LibraryDetailView: View { + @EnvironmentObject var jellyfinClient: JellyfinClientController + @StateObject var authState: AuthStateController = AuthStateController.shared + + @State var library: BaseItemDto + @State var items: [BaseItemDto]? = [] + + var body: some View { + ScrollView { + ForEach(items ?? []) {item in + LibraryIconView(library: item, imageType: "Primary", width: 120) + .padding() + } + } + .navigationTitle(library.name ?? "Unknown") + .onAppear { + Task { + let params = Paths.GetItemsParameters(userID: authState.userId, parentID: library.id) + let request = Paths.getItems(parameters: params) + + do { + let res = try await jellyfinClient.send(request) + items = res.value.items + } catch { + } + } + } + } +} + +#Preview { + LibraryDetailView(library: BaseItemDto()) +} -- cgit v1.2.3