BaseItemDto ItemType usage

This commit is contained in:
jhays 2022-05-26 09:26:10 -05:00
parent 0d6b9acb79
commit bc8f5e95d9
3 changed files with 67 additions and 61 deletions

View File

@ -236,6 +236,7 @@ public extension BaseItemDto {
case boxset = "BoxSet" case boxset = "BoxSet"
case collectionFolder = "CollectionFolder" case collectionFolder = "CollectionFolder"
case folder = "Folder" case folder = "Folder"
case liveTV = "LiveTV"
case unknown case unknown
@ -247,6 +248,21 @@ public extension BaseItemDto {
return true return true
} }
} }
public init?(rawValue: String) {
let lowerCase = rawValue.lowercased()
switch lowerCase {
case "movie": self = .movie
case "season": self = .season
case "episode": self = .episode
case "series": self = .series
case "boxset": self = .boxset
case "collectionfolder": self = .collectionFolder
case "folder": self = .folder
case "livetv": self = .liveTV
default: self = .unknown
}
}
} }
var itemType: ItemType { var itemType: ItemType {
@ -258,7 +274,7 @@ public extension BaseItemDto {
func portraitHeaderViewURL(maxWidth: Int) -> URL { func portraitHeaderViewURL(maxWidth: Int) -> URL {
switch itemType { switch itemType {
case .movie, .season, .series, .boxset, .collectionFolder, .folder: case .movie, .season, .series, .boxset, .collectionFolder, .folder, .liveTV:
return getPrimaryImage(maxWidth: maxWidth) return getPrimaryImage(maxWidth: maxWidth)
case .episode: case .episode:
return getSeriesPrimaryImage(maxWidth: maxWidth) return getSeriesPrimaryImage(maxWidth: maxWidth)

View File

@ -8,7 +8,9 @@
import Defaults import Defaults
import Foundation import Foundation
import Stinsen
import SwiftUI import SwiftUI
import JellyfinAPI
struct LibraryListView: View { struct LibraryListView: View {
@EnvironmentObject @EnvironmentObject
@ -21,7 +23,13 @@ struct LibraryListView: View {
@Default(.Experimental.liveTVAlphaEnabled) @Default(.Experimental.liveTVAlphaEnabled)
var liveTVAlphaEnabled var liveTVAlphaEnabled
let supportedCollectionTypes = ["movies", "tvshows", "boxsets", "livetv", "other"] var supportedCollectionTypes: [BaseItemDto.ItemType] {
if liveTVAlphaEnabled {
return [.movie, .season, .series, .liveTV, .boxset, .unknown]
} else {
return [.movie, .season, .series, .boxset, .unknown]
}
}
var body: some View { var body: some View {
ScrollView { ScrollView {
@ -30,38 +38,18 @@ struct LibraryListView: View {
ForEach(viewModel.libraries.filter { [self] library in ForEach(viewModel.libraries.filter { [self] library in
let collectionType = library.collectionType ?? "other" let collectionType = library.collectionType ?? "other"
return self.supportedCollectionTypes.contains(collectionType) let itemType = BaseItemDto.ItemType(rawValue: collectionType) ?? .unknown
return self.supportedCollectionTypes.contains(itemType)
}, id: \.id) { library in }, id: \.id) { library in
if library.collectionType == "livetv" {
if liveTVAlphaEnabled {
Button { Button {
let itemType = BaseItemDto.ItemType(rawValue: library.collectionType ?? "other") ?? .unknown
if itemType == .liveTV {
self.mainCoordinator.root(\.liveTV) self.mainCoordinator.root(\.liveTV)
}
label: {
ZStack {
HStack {
Spacer()
VStack {
Text(library.name ?? "")
.foregroundColor(.white)
.font(.title2)
.fontWeight(.semibold)
}
Spacer()
}.padding(32)
}
.frame(minWidth: 100, maxWidth: .infinity)
.frame(height: 100)
}
.cornerRadius(10)
.shadow(radius: 5)
.padding(.bottom, 5)
}
} else { } else {
Button {
self.libraryListRouter.route(to: \.library, self.libraryListRouter.route(to: \.library,
(viewModel: LibraryViewModel(parentID: library.id), title: library.name ?? "")) (viewModel: LibraryViewModel(parentID: library.id), title: library.name ?? ""))
} }
}
label: { label: {
ZStack { ZStack {
HStack { HStack {
@ -82,7 +70,6 @@ struct LibraryListView: View {
.shadow(radius: 5) .shadow(radius: 5)
.padding(.bottom, 5) .padding(.bottom, 5)
} }
}
} else { } else {
ProgressView() ProgressView()
} }

View File

@ -10,6 +10,7 @@ import Defaults
import Foundation import Foundation
import Stinsen import Stinsen
import SwiftUI import SwiftUI
import JellyfinAPI
struct LibraryListView: View { struct LibraryListView: View {
@EnvironmentObject @EnvironmentObject
@ -20,11 +21,11 @@ struct LibraryListView: View {
@Default(.Experimental.liveTVAlphaEnabled) @Default(.Experimental.liveTVAlphaEnabled)
var liveTVAlphaEnabled var liveTVAlphaEnabled
var supportedCollectionTypes: [String] { var supportedCollectionTypes: [BaseItemDto.ItemType] {
if liveTVAlphaEnabled { if liveTVAlphaEnabled {
return ["movies", "tvshows", "livetv", "boxsets", "other"] return [.movie, .season, .series, .liveTV, .boxset, .unknown]
} else { } else {
return ["movies", "tvshows", "boxsets", "other"] return [.movie, .season, .series, .boxset, .unknown]
} }
} }
@ -56,10 +57,12 @@ struct LibraryListView: View {
if !viewModel.isLoading { if !viewModel.isLoading {
ForEach(viewModel.libraries.filter { [self] library in ForEach(viewModel.libraries.filter { [self] library in
let collectionType = library.collectionType ?? "other" let collectionType = library.collectionType ?? "other"
return self.supportedCollectionTypes.contains(collectionType) let itemType = BaseItemDto.ItemType(rawValue: collectionType) ?? .unknown
return self.supportedCollectionTypes.contains(itemType)
}, id: \.id) { library in }, id: \.id) { library in
Button { Button {
if library.collectionType == "livetv" { let itemType = BaseItemDto.ItemType(rawValue: library.collectionType ?? "other") ?? .unknown
if itemType == .liveTV {
libraryListRouter.route(to: \.liveTV) libraryListRouter.route(to: \.liveTV)
} else { } else {
libraryListRouter.route(to: \.library, libraryListRouter.route(to: \.library,