2022-04-08 18:17:10 +01:00
|
|
|
//
|
|
|
|
// LinkPreview.swift
|
|
|
|
// SimpleX
|
|
|
|
//
|
|
|
|
// Created by Ian Davies on 04/04/2022.
|
|
|
|
// Copyright © 2022 SimpleX Chat. All rights reserved.
|
|
|
|
//
|
|
|
|
|
|
|
|
import SwiftUI
|
|
|
|
import LinkPresentation
|
2022-05-31 07:55:13 +01:00
|
|
|
import SimpleXChat
|
2022-04-08 18:17:10 +01:00
|
|
|
|
|
|
|
struct ComposeLinkView: View {
|
2024-07-03 22:42:13 +01:00
|
|
|
@EnvironmentObject var theme: AppTheme
|
2022-05-30 08:59:04 +01:00
|
|
|
let linkPreview: LinkPreview?
|
2022-04-08 18:17:10 +01:00
|
|
|
var cancelPreview: (() -> Void)? = nil
|
2023-05-03 15:57:10 +03:00
|
|
|
let cancelEnabled: Bool
|
2022-04-08 18:17:10 +01:00
|
|
|
|
|
|
|
var body: some View {
|
2022-05-30 08:59:04 +01:00
|
|
|
HStack(alignment: .center, spacing: 8) {
|
2025-05-11 15:42:09 +01:00
|
|
|
if let linkPreview {
|
2022-05-30 08:59:04 +01:00
|
|
|
linkPreviewView(linkPreview)
|
|
|
|
} else {
|
|
|
|
ProgressView()
|
|
|
|
.padding(.leading, 12)
|
|
|
|
.frame(maxWidth: .infinity, minHeight: 60, maxHeight: 60, alignment: .leading)
|
|
|
|
}
|
2023-05-03 15:57:10 +03:00
|
|
|
if let cancelPreview = cancelPreview, cancelEnabled {
|
2022-05-30 08:59:04 +01:00
|
|
|
Button { cancelPreview() } label: {
|
|
|
|
Image(systemName: "multiply")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
.padding(.vertical, 1)
|
|
|
|
.padding(.trailing, 12)
|
2024-07-03 22:42:13 +01:00
|
|
|
.background(theme.appColors.sentMessage)
|
2024-07-15 13:14:14 +01:00
|
|
|
.frame(minHeight: 54)
|
2022-05-30 08:59:04 +01:00
|
|
|
.frame(maxWidth: .infinity)
|
|
|
|
}
|
|
|
|
|
|
|
|
private func linkPreviewView(_ linkPreview: LinkPreview) -> some View {
|
2022-04-08 18:17:10 +01:00
|
|
|
HStack(alignment: .center, spacing: 8) {
|
2024-09-04 14:49:01 +01:00
|
|
|
if let uiImage = imageFromBase64(linkPreview.image) {
|
2022-04-08 18:17:10 +01:00
|
|
|
Image(uiImage: uiImage)
|
|
|
|
.resizable()
|
|
|
|
.aspectRatio(contentMode: .fit)
|
|
|
|
.frame(maxWidth: 80, maxHeight: 60)
|
|
|
|
}
|
|
|
|
VStack(alignment: .center, spacing: 4) {
|
|
|
|
Text(linkPreview.title)
|
|
|
|
.lineLimit(1)
|
|
|
|
Text(linkPreview.uri.absoluteString)
|
|
|
|
.font(.caption)
|
|
|
|
.lineLimit(1)
|
2024-07-03 22:42:13 +01:00
|
|
|
.foregroundColor(theme.colors.secondary)
|
2022-04-08 18:17:10 +01:00
|
|
|
}
|
|
|
|
.padding(.vertical, 5)
|
2024-08-14 21:29:13 +03:00
|
|
|
.frame(maxWidth: .infinity, minHeight: 60)
|
2022-04-08 18:17:10 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
struct SmallLinkPreview_Previews: PreviewProvider {
|
|
|
|
static var previews: some View {
|
|
|
|
let preview = LinkPreview(
|
|
|
|
uri: URL(string: "http://DuckDuckGo.com")!,
|
|
|
|
title: "Privacy, simplified.",
|
|
|
|
description: "",
|
|
|
|
image: "
|
|
|
|
)
|
2022-05-30 08:59:04 +01:00
|
|
|
Group {
|
2023-05-03 15:57:10 +03:00
|
|
|
ComposeLinkView(linkPreview: preview, cancelPreview: {}, cancelEnabled: true)
|
2022-05-30 08:59:04 +01:00
|
|
|
.previewLayout(.fixed(width: 360, height: 200))
|
2023-05-03 15:57:10 +03:00
|
|
|
ComposeLinkView(linkPreview: nil, cancelPreview: {}, cancelEnabled: true)
|
2022-05-30 08:59:04 +01:00
|
|
|
.previewLayout(.fixed(width: 360, height: 200))
|
|
|
|
}
|
2022-04-08 18:17:10 +01:00
|
|
|
}
|
|
|
|
}
|