MediaViewer: Add loading state for quicklook

This commit is contained in:
Thomas Ricouard 2023-10-29 08:27:26 +01:00
parent cd0e9c10ac
commit bbce55e703

View File

@ -15,6 +15,7 @@ public struct MediaUIView: View, @unchecked Sendable {
@State private var altTextDisplayed: String? @State private var altTextDisplayed: String?
@State private var isAltAlertDisplayed: Bool = false @State private var isAltAlertDisplayed: Bool = false
@State private var quickLookURL: URL? @State private var quickLookURL: URL?
@State private var isLoadingQuickLook = false
@State private var isSavingPhoto: Bool = false @State private var isSavingPhoto: Bool = false
@State private var didSavePhoto: Bool = false @State private var didSavePhoto: Bool = false
@ -84,13 +85,19 @@ public struct MediaUIView: View, @unchecked Sendable {
if let url = attachments.first(where: { $0.id == scrollToId})?.url { if let url = attachments.first(where: { $0.id == scrollToId})?.url {
Button { Button {
Task { Task {
isLoadingQuickLook = true
quickLookURL = await localPathFor(url: url) quickLookURL = await localPathFor(url: url)
isLoadingQuickLook = false
} }
} label: { } label: {
if isLoadingQuickLook {
ProgressView()
} else {
Image(systemName: "info.circle") Image(systemName: "info.circle")
} }
} }
} }
}
ToolbarItem(placement: .topBarTrailing) { ToolbarItem(placement: .topBarTrailing) {
if let alt = attachments.first(where: { $0.id == scrollToId})?.description { if let alt = attachments.first(where: { $0.id == scrollToId})?.description {
Button { Button {