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/ItemPersonIconView.swift | |
parent | 4ec0f962b2a175ae5f1e3e55a720f9534618a4ad (diff) | |
download | jel-6edc39791a577a500c92f32361cf1e7d2590ec37.tar.gz jel-6edc39791a577a500c92f32361cf1e7d2590ec37.zip |
Implement ItemPeopleView
Diffstat (limited to 'Jel/Views/Library/Item/Person/ItemPersonIconView.swift')
-rw-r--r-- | Jel/Views/Library/Item/Person/ItemPersonIconView.swift | 70 |
1 files changed, 70 insertions, 0 deletions
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() +//} |