From 4c98eef1201c42100597d0093988db60b03b0e32 Mon Sep 17 00:00:00 2001 From: Shav Kinderlehrer Date: Sat, 13 Jan 2024 02:20:20 -0500 Subject: Start implementing ItemPersonView --- Jel/Views/Item/Person/ItemPeopleView.swift | 6 +-- Jel/Views/Item/Person/ItemPersonDetailView.swift | 47 ++++++++++++++++++++++++ 2 files changed, 48 insertions(+), 5 deletions(-) create mode 100644 Jel/Views/Item/Person/ItemPersonDetailView.swift (limited to 'Jel/Views/Item/Person') diff --git a/Jel/Views/Item/Person/ItemPeopleView.swift b/Jel/Views/Item/Person/ItemPeopleView.swift index f007796..1a60ca2 100644 --- a/Jel/Views/Item/Person/ItemPeopleView.swift +++ b/Jel/Views/Item/Person/ItemPeopleView.swift @@ -7,7 +7,6 @@ import SwiftUI import JellyfinKit -import NukeUI struct ItemPeopleView: View { @@ -24,10 +23,7 @@ struct ItemPeopleView: View { HStack(alignment: .top) { ForEach(item.people ?? [], id: \.iterId) {person in NavigationLink { - VStack { - ItemPersonIconView(person: person) - Text("Subview") - } + ItemPersonDetailView(person: person) .navigationTitle(person.name ?? "Unnamed") } label: { ItemPersonIconView(person: person) diff --git a/Jel/Views/Item/Person/ItemPersonDetailView.swift b/Jel/Views/Item/Person/ItemPersonDetailView.swift new file mode 100644 index 0000000..5e0bddf --- /dev/null +++ b/Jel/Views/Item/Person/ItemPersonDetailView.swift @@ -0,0 +1,47 @@ +// +// ItemPersonDetailView.swift +// Jel +// +// Created by zerocool on 1/13/24. +// + +import SwiftUI +import JellyfinKit + +struct ItemPersonDetailView: View { + @StateObject var authState: AuthStateController = AuthStateController.shared + @EnvironmentObject var jellyfinClient: JellyfinClientController + + var person: BaseItemPerson + + @State var personItem: BaseItemDto? + @State var loading: Bool = true + + var body: some View { + VStack { + if loading { + ProgressView() + .progressViewStyle(.circular) + } + + if let personItem = personItem { + ItemView(item: personItem) + } + } + .onAppear { + Task { + let request = Paths.getItem(userID: authState.userId ?? "", itemID: person.id ?? "") + + do { + let res = try await jellyfinClient.send(request) + personItem = res.value + loading = false + } catch {} + } + } + } +} + +//#Preview { +// ItemPersonDetailView() +//} -- cgit v1.2.3