Switch from ExyteGrid to lazygrid

This commit is contained in:
Aiden Vigue 2021-05-23 23:38:57 -04:00
parent 352d47f387
commit 58b45cd2be
4 changed files with 82 additions and 82 deletions

View File

@ -109,7 +109,7 @@ struct ContinueWatchingView: View {
if(resumeItems.count != 0) { if(resumeItems.count != 0) {
VStack(alignment: .leading) { VStack(alignment: .leading) {
ScrollView(.horizontal, showsIndicators: false) { ScrollView(.horizontal, showsIndicators: false) {
HStack() { LazyHStack() {
if(isLoading == false) { if(isLoading == false) {
Spacer().frame(width:16) Spacer().frame(width:16)
ForEach(resumeItems, id: \.Id) { item in ForEach(resumeItems, id: \.Id) { item in

View File

@ -84,7 +84,7 @@ struct LatestMediaView: View {
var body: some View { var body: some View {
ScrollView(.horizontal, showsIndicators: false) { ScrollView(.horizontal, showsIndicators: false) {
HStack() { LazyHStack() {
Spacer().frame(width:18) Spacer().frame(width:18)
ForEach(resumeItems, id: \.Id) { item in ForEach(resumeItems, id: \.Id) { item in
NavigationLink(destination: ItemView(item: item)) { NavigationLink(destination: ItemView(item: item)) {

View File

@ -33,8 +33,6 @@ struct LibraryView: View {
@State private var url: String = ""; @State private var url: String = "";
@State private var closeSearch: Bool = false; @State private var closeSearch: Bool = false;
var gridItems: [GridItem] = [GridItem(.adaptive(minimum: 150, maximum: 400))]
init(prefill: String?, names: [String: String], libraries: [String]) { init(prefill: String?, names: [String: String], libraries: [String]) {
_prefill_id = State(wrappedValue: prefill ?? "") _prefill_id = State(wrappedValue: prefill ?? "")
_library_names = State(wrappedValue: names) _library_names = State(wrappedValue: names)
@ -166,17 +164,18 @@ struct LibraryView: View {
_tracks.wrappedValue = [] _tracks.wrappedValue = []
for _ in (0..<trkCnt) for _ in (0..<trkCnt)
{ {
_tracks.wrappedValue.append(GridTrack.fr(1)) _tracks.wrappedValue.append(GridItem.init(.flexible()))
} }
} }
@State private var tracks: [GridTrack] = [] @State private var tracks: [GridItem] = []
var body: some View { var body: some View {
if(prefill_id != "") { if(prefill_id != "") {
LoadingView(isShowing: $isLoading) { LoadingView(isShowing: $isLoading) {
GeometryReader { geometry in GeometryReader { geometry in
Grid(tracks: _tracks.wrappedValue, spacing: GridSpacing(horizontal: 0, vertical: 20)) { ScrollView(.vertical) {
LazyVGrid(columns: tracks) {
ForEach(items, id: \.Id) { item in ForEach(items, id: \.Id) { item in
NavigationLink(destination: ItemView(item: item )) { NavigationLink(destination: ItemView(item: item )) {
VStack(alignment: .leading) { VStack(alignment: .leading) {
@ -184,7 +183,7 @@ struct LibraryView: View {
WebImage(url: URL(string: "\(globalData.server?.baseURI ?? "")/Items/\(item.Id)/Images/\(item.ImageType)?maxWidth=150&quality=90&tag=\(item.Image)")) WebImage(url: URL(string: "\(globalData.server?.baseURI ?? "")/Items/\(item.Id)/Images/\(item.ImageType)?maxWidth=150&quality=90&tag=\(item.Image)"))
.resizable() .resizable()
.placeholder { .placeholder {
Image(uiImage: UIImage(blurHash: (item.BlurHash == "" ? "W$H.4}D%bdo#a#xbtpxVW?W?jXWsXVt7Rjf5axWqxbWXnhada{s-" : item.BlurHash), size: CGSize(width: 32, height: 32))!) Image(uiImage: UIImage(blurHash: (item.BlurHash == "" ? "W$H.4}D%bdo#a#xbtpxVW?W?jXWsXVt7Rjf5axWqxbWXnhada{s-" : item.BlurHash), size: CGSize(width: 6, height: 6))!)
.resizable() .resizable()
.frame(width: 100, height: 150) .frame(width: 100, height: 150)
.cornerRadius(10) .cornerRadius(10)
@ -196,7 +195,7 @@ struct LibraryView: View {
WebImage(url: URL(string: "\(globalData.server?.baseURI ?? "")/Items/\(item.Id)/Images/\(item.ImageType)?maxWidth=150&quality=90&tag=\(item.Image)")) WebImage(url: URL(string: "\(globalData.server?.baseURI ?? "")/Items/\(item.Id)/Images/\(item.ImageType)?maxWidth=150&quality=90&tag=\(item.Image)"))
.resizable() .resizable()
.placeholder { .placeholder {
Image(uiImage: UIImage(blurHash: (item.BlurHash == "" ? "W$H.4}D%bdo#a#xbtpxVW?W?jXWsXVt7Rjf5axWqxbWXnhada{s-" : item.BlurHash), size: CGSize(width: 32, height: 32))!) Image(uiImage: UIImage(blurHash: (item.BlurHash == "" ? "W$H.4}D%bdo#a#xbtpxVW?W?jXWsXVt7Rjf5axWqxbWXnhada{s-" : item.BlurHash), size: CGSize(width: 6, height: 6))!)
.resizable() .resizable()
.frame(width: 100, height: 150) .frame(width: 100, height: 150)
.cornerRadius(10) .cornerRadius(10)
@ -247,10 +246,11 @@ struct LibraryView: View {
} }
} }
Spacer() Spacer()
}.gridSpan(column: _tracks.wrappedValue.count)
} }
Spacer().frame(height: 2).gridSpan(column: _tracks.wrappedValue.count) }
}.gridContentMode(.scroll) Spacer().frame(height: 2)
}
}
.onChange(of: isPortrait) { _ in .onChange(of: isPortrait) { _ in
recalcTracks() recalcTracks()
} }

View File

@ -72,7 +72,7 @@ struct NextUpView: View {
if(resumeItems.count != 0) { if(resumeItems.count != 0) {
Text("Next Up").font(.title2).fontWeight(.bold).padding(EdgeInsets(top: 0, leading: 16, bottom: 0, trailing: 16)) Text("Next Up").font(.title2).fontWeight(.bold).padding(EdgeInsets(top: 0, leading: 16, bottom: 0, trailing: 16))
ScrollView(.horizontal, showsIndicators: false) { ScrollView(.horizontal, showsIndicators: false) {
HStack() { LazyHStack() {
if(isLoading == false) { if(isLoading == false) {
Spacer().frame(width:18) Spacer().frame(width:18)
ForEach(resumeItems, id: \.Id) { item in ForEach(resumeItems, id: \.Id) { item in
@ -108,8 +108,8 @@ struct NextUpView: View {
} }
Spacer().frame(width:18) Spacer().frame(width:18)
} }
} }.frame(height: 200)
}.padding(EdgeInsets(top: -2, leading: 0, bottom: 0, trailing: 0)) }.padding(EdgeInsets(top: -2, leading: 0, bottom: 0, trailing: 0)).frame(height: 200)
} }
}.onAppear(perform: onAppear).padding(EdgeInsets(top: 0, leading: 0, bottom: 0, trailing: 0)) }.onAppear(perform: onAppear).padding(EdgeInsets(top: 0, leading: 0, bottom: 0, trailing: 0))
} }