summaryrefslogtreecommitdiff
path: root/Jel/Views/Item/Person
diff options
context:
space:
mode:
authorShav Kinderlehrer <[email protected]>2024-01-13 02:20:20 -0500
committerShav Kinderlehrer <[email protected]>2024-01-13 02:20:20 -0500
commit4c98eef1201c42100597d0093988db60b03b0e32 (patch)
tree137c8d612bbbfa2d79f60276801f94b1f0eb568a /Jel/Views/Item/Person
parent6b8d3372d21149ed0efb4d43bf0cab44bd24f9a4 (diff)
downloadjel-4c98eef1201c42100597d0093988db60b03b0e32.tar.gz
jel-4c98eef1201c42100597d0093988db60b03b0e32.zip
Start implementing ItemPersonView
Diffstat (limited to 'Jel/Views/Item/Person')
-rw-r--r--Jel/Views/Item/Person/ItemPeopleView.swift6
-rw-r--r--Jel/Views/Item/Person/ItemPersonDetailView.swift47
2 files changed, 48 insertions, 5 deletions
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()
+//}