summaryrefslogtreecommitdiff
path: root/Jel/Views/Library/Item/Person
diff options
context:
space:
mode:
Diffstat (limited to 'Jel/Views/Library/Item/Person')
-rw-r--r--Jel/Views/Library/Item/Person/ItemPeopleView.swift37
-rw-r--r--Jel/Views/Library/Item/Person/ItemPersonIconView.swift70
2 files changed, 107 insertions, 0 deletions
diff --git a/Jel/Views/Library/Item/Person/ItemPeopleView.swift b/Jel/Views/Library/Item/Person/ItemPeopleView.swift
new file mode 100644
index 0000000..6e2a974
--- /dev/null
+++ b/Jel/Views/Library/Item/Person/ItemPeopleView.swift
@@ -0,0 +1,37 @@
+//
+// ItemPeopleView.swift
+// Jel
+//
+// Created by zerocool on 1/8/24.
+//
+
+import SwiftUI
+import JellyfinKit
+import NukeUI
+
+struct ItemPeopleView: View {
+
+ var item: BaseItemDto
+
+ var body: some View {
+ VStack(alignment: .leading) {
+ Text("Cast and Crew")
+ .font(.title2)
+ .padding(.leading)
+
+ ScrollView(.horizontal) {
+ LazyHStack(alignment: .top) {
+ ForEach(item.people ?? [], id: \.iterId) {person in
+ ItemPersonIconView(person: person)
+ }
+ }
+ .padding(.horizontal)
+ }
+ .scrollIndicators(.hidden)
+ }
+ }
+}
+
+//#Preview {
+// ItemPeopleView()
+//}
diff --git a/Jel/Views/Library/Item/Person/ItemPersonIconView.swift b/Jel/Views/Library/Item/Person/ItemPersonIconView.swift
new file mode 100644
index 0000000..a6e5161
--- /dev/null
+++ b/Jel/Views/Library/Item/Person/ItemPersonIconView.swift
@@ -0,0 +1,70 @@
+//
+// ItemPersonIconView.swift
+// Jel
+//
+// Created by zerocool on 1/8/24.
+//
+
+import SwiftUI
+import JellyfinKit
+import NukeUI
+
+struct ItemPersonIconPlaceholderView: View {
+ var body: some View {
+ VStack {
+ Image(systemName: "person")
+ .resizable()
+ .padding()
+ .scaledToFit()
+ }
+ }
+}
+
+struct ItemPersonIconView: View {
+ @StateObject var authState: AuthStateController = AuthStateController.shared
+ @EnvironmentObject var jellyfinClient: JellyfinClientController
+
+ var person: BaseItemPerson
+
+ @State var personImageUrl: URL?
+ @State var loading: Bool = true
+
+ var body: some View {
+ VStack() {
+ LazyImage(url: personImageUrl) {state in
+ if let image = state.image {
+ image
+ .resizable()
+ .clipShape(RoundedRectangle(cornerRadius: 5))
+ } else {
+ ItemPersonIconPlaceholderView()
+ }
+ }
+ .aspectRatio(contentMode: .fit)
+ .frame(width: 100, height: 170)
+
+ VStack {
+ Text(person.name ?? "---")
+ .font(.callout)
+ Text(person.role ?? "---")
+ .font(.caption)
+ .foregroundStyle(.gray)
+ }
+ .frame(width: 100)
+ }
+ // .redacted(reason: loading ? .placeholder : [])
+ .onAppear {
+ Task {
+ let request = Paths.getItemImage(itemID: person.id ?? "", imageType: "Primary")
+
+ let serverUrl = jellyfinClient.getUrl()
+ personImageUrl = serverUrl?.appending(path: request.url?.absoluteString ?? "")
+ // loading = false
+ }
+ }
+ }
+}
+
+//#Preview {
+// ItemPersonView()
+//}