2022-04-19 12:29:03 +04:00
|
|
|
//
|
|
|
|
|
// ComposeImageView.swift
|
|
|
|
|
// SimpleX
|
|
|
|
|
//
|
|
|
|
|
// Created by JRoberts on 11/04/2022.
|
|
|
|
|
// Copyright © 2022 SimpleX Chat. All rights reserved.
|
|
|
|
|
//
|
|
|
|
|
|
|
|
|
|
import SwiftUI
|
2022-05-31 07:55:13 +01:00
|
|
|
import SimpleXChat
|
2022-04-19 12:29:03 +04:00
|
|
|
|
|
|
|
|
struct ComposeImageView: View {
|
|
|
|
|
@Environment(\.colorScheme) var colorScheme
|
2022-10-10 10:40:30 +01:00
|
|
|
let images: [String]
|
2022-04-25 12:44:24 +04:00
|
|
|
let cancelImage: (() -> Void)
|
|
|
|
|
let cancelEnabled: Bool
|
2022-04-19 12:29:03 +04:00
|
|
|
|
|
|
|
|
var body: some View {
|
|
|
|
|
HStack(alignment: .center, spacing: 8) {
|
2022-10-10 10:40:30 +01:00
|
|
|
let imgs: [UIImage] = images.compactMap { image in
|
|
|
|
|
if let data = Data(base64Encoded: dropImagePrefix(image)) {
|
|
|
|
|
return UIImage(data: data)
|
|
|
|
|
}
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
if imgs.count == 0 {
|
|
|
|
|
ProgressView()
|
|
|
|
|
.padding(.leading, 12)
|
|
|
|
|
.frame(maxWidth: .infinity, minHeight: 60, maxHeight: 60, alignment: .leading)
|
|
|
|
|
} else {
|
|
|
|
|
ScrollView(.horizontal) {
|
|
|
|
|
HStack {
|
|
|
|
|
ForEach(imgs, id: \.hash) { img in
|
|
|
|
|
Image(uiImage: img)
|
|
|
|
|
.resizable()
|
|
|
|
|
.scaledToFit()
|
|
|
|
|
.frame(maxWidth: 80, minHeight: 40, maxHeight: 60)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2022-04-19 12:29:03 +04:00
|
|
|
}
|
2022-04-25 12:44:24 +04:00
|
|
|
Spacer()
|
|
|
|
|
if cancelEnabled {
|
2022-04-19 12:29:03 +04:00
|
|
|
Button { cancelImage() } label: {
|
|
|
|
|
Image(systemName: "multiply")
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
.padding(.vertical, 1)
|
|
|
|
|
.padding(.trailing, 12)
|
|
|
|
|
.background(colorScheme == .light ? sentColorLight : sentColorDark)
|
|
|
|
|
.frame(maxWidth: .infinity)
|
|
|
|
|
.padding(.top, 8)
|
|
|
|
|
}
|
|
|
|
|
}
|
2022-04-25 12:44:24 +04:00
|
|
|
|
|
|
|
|
//struct ComposeImageView: View {
|
|
|
|
|
// @Environment(\.colorScheme) var colorScheme
|
|
|
|
|
// let image: String
|
|
|
|
|
// let cancelImage: (() -> Void)
|
|
|
|
|
//
|
|
|
|
|
// var body: some View {
|
|
|
|
|
// if let data = Data(base64Encoded: dropImagePrefix(image)),
|
|
|
|
|
// let uiImage = UIImage(data: data) {
|
|
|
|
|
// HStack(alignment: .center) {
|
|
|
|
|
// ZStack(alignment: .topTrailing) {
|
|
|
|
|
// Image(uiImage: uiImage)
|
|
|
|
|
// .resizable()
|
|
|
|
|
// .scaledToFit()
|
|
|
|
|
// .cornerRadius(20)
|
|
|
|
|
// .frame(maxHeight: 150)
|
|
|
|
|
// Button { cancelImage() } label: {
|
|
|
|
|
// Image(systemName: "multiply")
|
|
|
|
|
// .foregroundColor(.white)
|
|
|
|
|
// }
|
|
|
|
|
// .padding(8)
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
// .padding(.top, 8)
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
//}
|