From 764778f56c1333cd2b1d5398a2d68a1a81469be2 Mon Sep 17 00:00:00 2001 From: Ndriqim Nagavci Date: Mon, 23 Sep 2024 10:16:35 +0200 Subject: [PATCH] Load remote images. --- .../PhotoPreview/PhotoPreviewItemView.swift | 25 ++++++++++++++++++- 1 file changed, 24 insertions(+), 1 deletion(-) diff --git a/Sources/UI/SwiftUI/Views/PhotoPreview/PhotoPreviewItemView.swift b/Sources/UI/SwiftUI/Views/PhotoPreview/PhotoPreviewItemView.swift index 2e80cff1..4fa792d0 100644 --- a/Sources/UI/SwiftUI/Views/PhotoPreview/PhotoPreviewItemView.swift +++ b/Sources/UI/SwiftUI/Views/PhotoPreview/PhotoPreviewItemView.swift @@ -16,6 +16,7 @@ struct PhotoPreviewItemView: View { typealias VoidHandler = () -> Swift.Void typealias DragHandler = (CGFloat) -> Swift.Void + @StateObject var imageLoader = PhotoPreviewImageLoader() @Binding var dragEnabled: Bool @Binding var currentIndex: Int @Binding var verticalOffset: CGFloat @@ -85,7 +86,29 @@ extension PhotoPreviewItemView { } .scaledToFit() #else - URLImageView(from: item.url, placeholder: item.placeholder) + Group { + switch imageLoader.state { + case .loading: + ProgressView() + .progressViewStyle(.circular) + .frame(width: 50, height: 50) + .task { + await imageLoader.loadImage(from: item.url) + } + case .loaded(let image): + Image(uiImage: image) + .resizable() + .scaledToFit() + case .failed: + if let placeholder = item.placeholder { + placeholder + .resizable() + .scaledToFit() + } else { + Color.clear + } + } + } #endif } }