diff options
author | Shav Kinderlehrer <[email protected]> | 2024-01-09 12:32:06 -0500 |
---|---|---|
committer | Shav Kinderlehrer <[email protected]> | 2024-01-09 12:32:06 -0500 |
commit | 6edc39791a577a500c92f32361cf1e7d2590ec37 (patch) | |
tree | 776de4bae461836f8cba5ff673fc4ccfabd6df55 /Jel/Views/Library/Item/Person | |
parent | 4ec0f962b2a175ae5f1e3e55a720f9534618a4ad (diff) | |
download | jel-6edc39791a577a500c92f32361cf1e7d2590ec37.tar.gz jel-6edc39791a577a500c92f32361cf1e7d2590ec37.zip |
Implement ItemPeopleView
Diffstat (limited to 'Jel/Views/Library/Item/Person')
-rw-r--r-- | Jel/Views/Library/Item/Person/ItemPeopleView.swift | 37 | ||||
-rw-r--r-- | Jel/Views/Library/Item/Person/ItemPersonIconView.swift | 70 |
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() +//} |