1
0
mirror of https://github.com/yattee/yattee.git synced 2025-01-07 10:00:33 +05:30
yattee/Apple TV/VideoCellView.swift

82 lines
3.0 KiB
Swift
Raw Normal View History

2021-06-24 03:49:58 +05:30
import URLImage
import URLImageStore
import SwiftUI
struct VideoCellView: View {
var video: Video
2021-06-28 16:13:07 +05:30
2021-06-24 03:49:58 +05:30
var body: some View {
NavigationLink(destination: PlayerView(id: video.id)) {
VStack(alignment: .leading) {
ZStack(alignment: .trailing) {
2021-07-08 04:09:18 +05:30
if let thumbnail = video.thumbnailURL(quality: "high") {
2021-06-24 03:49:58 +05:30
// to replace with AsyncImage when it is fixed with lazy views
URLImage(thumbnail) { image in
image
.resizable()
.aspectRatio(contentMode: .fill)
.frame(width: 550, height: 310)
}
.mask(RoundedRectangle(cornerRadius: 12))
} else {
Image(systemName: "exclamationmark.square")
.frame(width: 550, height: 310)
}
2021-07-12 02:22:49 +05:30
VStack(alignment: .trailing) {
Text(video.author)
2021-06-24 03:49:58 +05:30
.padding(8)
.background(.thickMaterial)
.mask(RoundedRectangle(cornerRadius: 12))
2021-07-12 02:22:49 +05:30
.offset(x: -5, y: 5)
.truncationMode(.middle)
Spacer()
if let time = video.playTime {
Text(time)
.fontWeight(.bold)
.padding(8)
.background(.thickMaterial)
.mask(RoundedRectangle(cornerRadius: 12))
.offset(x: -5, y: -5)
}
2021-06-24 03:49:58 +05:30
}
}
.frame(width: 550, height: 310)
VStack(alignment: .leading) {
Text(video.title)
.bold()
.lineLimit(2)
.multilineTextAlignment(.leading)
.padding(.horizontal)
.padding(.bottom, 2)
.frame(minHeight: 80, alignment: .top)
.truncationMode(.middle)
2021-06-26 15:09:35 +05:30
if !video.published.isEmpty || video.views != 0 {
HStack(spacing: 8) {
if !video.published.isEmpty {
Image(systemName: "calendar")
Text(video.published)
}
2021-06-24 03:49:58 +05:30
2021-06-26 15:09:35 +05:30
if video.views != 0 {
Image(systemName: "eye")
Text(video.viewsCount)
}
2021-06-24 03:49:58 +05:30
}
2021-06-26 15:09:35 +05:30
.padding([.horizontal, .bottom])
.foregroundColor(.secondary)
2021-06-24 03:49:58 +05:30
}
}
}
.frame(width: 550, alignment: .leading)
}
.buttonStyle(.plain)
.padding(.vertical)
}
}