1
0
mirror of https://github.com/yattee/yattee.git synced 2024-12-15 06:40:32 +05:30
yattee/Shared/Player/ChapterView.swift

76 lines
2.2 KiB
Swift
Raw Normal View History

2022-09-01 22:21:59 +05:30
import CachedAsyncImage
2022-08-21 02:35:40 +05:30
import Foundation
import SDWebImageSwiftUI
import SwiftUI
struct ChapterView: View {
var chapter: Chapter
@EnvironmentObject<PlayerModel> private var player
var body: some View {
Button {
player.backend.seek(to: chapter.start, seekType: .userInteracted)
2022-08-21 02:35:40 +05:30
} label: {
HStack(spacing: 12) {
if !chapter.image.isNil {
smallImage(chapter)
}
VStack(alignment: .leading, spacing: 4) {
Text(chapter.title)
.font(.headline)
Text(chapter.start.formattedAsPlaybackTime(allowZero: true) ?? "")
.font(.system(.subheadline).monospacedDigit())
.foregroundColor(.secondary)
}
}
.frame(maxWidth: .infinity, alignment: .leading)
.contentShape(Rectangle())
}
.buttonStyle(.plain)
}
@ViewBuilder func smallImage(_ chapter: Chapter) -> some View {
2022-09-02 04:49:30 +05:30
Group {
if #available(iOS 15, macOS 12, *) {
CachedAsyncImage(url: chapter.image) { image in
image
.resizable()
} placeholder: {
Rectangle().foregroundColor(Color("PlaceholderColor"))
}
} else {
WebImage(url: chapter.image)
2022-09-01 00:54:46 +05:30
.resizable()
2022-09-02 04:49:30 +05:30
.placeholder {
ProgressView()
}
.indicator(.activity)
2022-08-21 02:35:40 +05:30
}
2022-09-01 00:54:46 +05:30
}
2022-09-02 04:49:30 +05:30
#if os(tvOS)
.frame(width: thumbnailWidth, height: 140)
.mask(RoundedRectangle(cornerRadius: 12))
#else
.frame(width: thumbnailWidth, height: 60)
.mask(RoundedRectangle(cornerRadius: 6))
#endif
2022-08-21 02:35:40 +05:30
}
private var thumbnailWidth: Double {
#if os(tvOS)
250
#else
100
#endif
}
}
struct ChapterView_Preview: PreviewProvider {
static var previews: some View {
ChapterView(chapter: .init(title: "Chapter", start: 30))
.injectFixtureEnvironmentObjects()
}
}