summaryrefslogtreecommitdiff
path: root/Jel/Views/Library/Item/ItemHeaderView.swift
blob: 3b5769a4331f10beb3a436694984eb021c0765b9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
//
//  ItemHeaderView.swift
//  Jel
//
//  Created by zerocool on 12/23/23.
//

import SwiftUI
import JellyfinKit

struct ItemHeaderView: View {
  var item: BaseItemDto
  
  let overlayGradient = LinearGradient(gradient: Gradient(stops: [
    .init(color: .clear, location: 0),
    .init(color: .black, location: 0.5),
    //    .init(color: .black, location: 0.7),
    //    .init(color: .clear, location: 1)
  ]), startPoint: .bottom, endPoint: .top)
  
  var body: some View {
    ZStack(alignment: .bottom) {
      StickyHeaderView(minHeight: 300) {
        ItemIconView(item: item, imageType: "Backdrop", contentMode: .fill)
          .setCornerRadius(0)
          .mask(overlayGradient)
          .background {
            ItemIconView(item: item, imageType: "Backdrop", contentMode: .fill)
              .setCornerRadius(0)
              .blur(radius: 50)
          }
      }
      
      HStack {
        ItemIconView(item: item, imageType: "Logo", width: 200, height: 100, placeHolder: AnyView(Text(item.name ?? "Unknown").font(.title).bold().truncationMode(.middle)))
          .setCornerRadius(0)
          .shadow(radius: 10)
          .frame(alignment: .leading)
        Spacer()
        ItemInfoView(item: item)
          .foregroundStyle(.white)
      }
      .padding([.leading, .trailing])
    }
    .scrollTransition {content, phase in
      content
        .scaleEffect(phase.isIdentity ? 1 : 2)
        .opacity(phase.isIdentity ? 1 : 0.1)
        .blur(radius: phase.isIdentity ? 0 : 50)
    }
  }
}

//  #Preview {
//    ItemHeaderView(item: BaseItemDto())
//  }