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/ItemPersonDetailView.swift | 47 ++++++++++++++++++++++++ 1 file changed, 47 insertions(+) create mode 100644 Jel/Views/Item/Person/ItemPersonDetailView.swift (limited to 'Jel/Views/Item/Person/ItemPersonDetailView.swift') 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