BaseItemDto ItemType usage
This commit is contained in:
parent
0d6b9acb79
commit
bc8f5e95d9
|
@ -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)
|
||||||
|
|
|
@ -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()
|
||||||
}
|
}
|
||||||
|
|
|
@ -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,
|
||||||
|
|
Loading…
Reference in New Issue