summaryrefslogtreecommitdiff
path: root/Jel/Views
diff options
context:
space:
mode:
authorShav Kinderlehrer <[email protected]>2023-12-23 00:53:44 -0500
committerShav Kinderlehrer <[email protected]>2023-12-23 00:53:44 -0500
commit885615d1dd029138700c36bb8b23d211cf713811 (patch)
treed358d87926a8b5b73db87e9b87f3c46dfb35a435 /Jel/Views
parent73c40b5aa0142ed89082214f790df539174e4dac (diff)
downloadjel-885615d1dd029138700c36bb8b23d211cf713811.tar.gz
jel-885615d1dd029138700c36bb8b23d211cf713811.zip
Refactor LibraryIconView
Diffstat (limited to 'Jel/Views')
-rw-r--r--Jel/Views/Dashboard/DashboardLibraryView.swift (renamed from Jel/Views/Dashboard/Library/LibraryView.swift)12
-rw-r--r--Jel/Views/Dashboard/DashboardView.swift10
-rw-r--r--Jel/Views/Library/LibraryDetailView.swift43
-rw-r--r--Jel/Views/Library/LibraryIconView.swift (renamed from Jel/Views/Dashboard/Library/LibraryIconView.swift)11
4 files changed, 63 insertions, 13 deletions
diff --git a/Jel/Views/Dashboard/Library/LibraryView.swift b/Jel/Views/Dashboard/DashboardLibraryView.swift
index 63bfd64..98c92c0 100644
--- a/Jel/Views/Dashboard/Library/LibraryView.swift
+++ b/Jel/Views/Dashboard/DashboardLibraryView.swift
@@ -1,5 +1,5 @@
//
-// LibraryView.swift
+// DashboardLibraryView.swift
// Jel
//
// Created by zerocool on 12/15/23.
@@ -8,7 +8,7 @@
import SwiftUI
import JellyfinKit
-struct LibraryView: View {
+struct DashboardLibraryView: View {
@EnvironmentObject var jellyfinClient: JellyfinClientController
@StateObject var authState: AuthStateController = AuthStateController.shared
@@ -19,7 +19,12 @@ struct LibraryView: View {
HStack {
ForEach(libraries) {library in
if library.collectionType == "movies" || library.collectionType == "tvshows" {
- LibraryIconView(library: library)
+ NavigationLink {
+ LibraryDetailView(library: library)
+ } label: {
+ LibraryIconView(library: library, height: 200)
+ .padding()
+ }
}
}
}
@@ -32,7 +37,6 @@ struct LibraryView: View {
libraries = results
}
} catch {
- print(error)
}
}
}
diff --git a/Jel/Views/Dashboard/DashboardView.swift b/Jel/Views/Dashboard/DashboardView.swift
index 2658180..50d3538 100644
--- a/Jel/Views/Dashboard/DashboardView.swift
+++ b/Jel/Views/Dashboard/DashboardView.swift
@@ -14,10 +14,10 @@ struct DashboardView: View {
var body: some View {
NavigationStack {
VStack {
- LibraryView()
+ DashboardLibraryView()
}
.toolbar {
- ToolbarItem {
+ ToolbarItem(placement: .topBarTrailing) {
Button {
showingSettingsSheet.toggle()
} label: {
@@ -32,6 +32,6 @@ struct DashboardView: View {
}
}
-#Preview {
- DashboardView()
-}
+//#Preview {
+// DashboardView()
+//}
diff --git a/Jel/Views/Library/LibraryDetailView.swift b/Jel/Views/Library/LibraryDetailView.swift
new file mode 100644
index 0000000..3d5a04b
--- /dev/null
+++ b/Jel/Views/Library/LibraryDetailView.swift
@@ -0,0 +1,43 @@
+//
+// LibraryDetailView.swift
+// Jel
+//
+// Created by zerocool on 12/22/23.
+//
+
+import SwiftUI
+import JellyfinKit
+
+struct LibraryDetailView: View {
+ @EnvironmentObject var jellyfinClient: JellyfinClientController
+ @StateObject var authState: AuthStateController = AuthStateController.shared
+
+ @State var library: BaseItemDto
+ @State var items: [BaseItemDto]? = []
+
+ var body: some View {
+ ScrollView {
+ ForEach(items ?? []) {item in
+ LibraryIconView(library: item, imageType: "Primary", width: 120)
+ .padding()
+ }
+ }
+ .navigationTitle(library.name ?? "Unknown")
+ .onAppear {
+ Task {
+ let params = Paths.GetItemsParameters(userID: authState.userId, parentID: library.id)
+ let request = Paths.getItems(parameters: params)
+
+ do {
+ let res = try await jellyfinClient.send(request)
+ items = res.value.items
+ } catch {
+ }
+ }
+ }
+ }
+}
+
+#Preview {
+ LibraryDetailView(library: BaseItemDto())
+}
diff --git a/Jel/Views/Dashboard/Library/LibraryIconView.swift b/Jel/Views/Library/LibraryIconView.swift
index 0131ff7..e5f42b0 100644
--- a/Jel/Views/Dashboard/Library/LibraryIconView.swift
+++ b/Jel/Views/Library/LibraryIconView.swift
@@ -7,23 +7,26 @@
import SwiftUI
import JellyfinKit
-import BlurHashKit
struct LibraryIconView: View {
@EnvironmentObject var jellyfinClient: JellyfinClientController
@State var library: BaseItemDto
+
@State var loadingImage: Bool = true
+ @State var imageType: String = "Primary"
+ var width: CGFloat?
+ var height: CGFloat?
@State var loadedImageBinaryData: Data?
var body: some View {
VStack {
AsyncImageView(imageId: library.id ?? "",
- blurhash: library.imageBlurHashes?.primary?[library.imageTags?["Primary"] ?? ""] ?? "",
- imageType: "Primary")
+ blurhash: library.imageBlurHashes?.primary?[library.imageTags?[imageType] ?? ""] ?? "",
+ imageType: imageType)
.aspectRatio(contentMode: .fill)
- .frame(width: 255, height: 150)
+ .frame(width: width, height: height)
.clipShape(RoundedRectangle(cornerRadius: 5))