mirror of
https://github.com/simplex-chat/simplex-chat.git
synced 2026-04-27 06:25:48 +00:00
f5eea018d9
* ios: wallpapers (#4304) * ios: wallpapers * theme selection * applied theme colors and preset wallpaper * more places with background * one more * accent color * defaults * rename * background * no change to cell color * unneeded * changes * no global tint * defaults * removed unneeded class * for merging * ios: wallpapers types (#4325) * types and api * divided types per target * creating directory for wallpapers * creating wallpaper dir at launch * ios: wallpapers appearance (#4335) * appearance * changes * refactor * scale * lambda to function --------- Co-authored-by: Evgeny Poberezkin <2769109+epoberezkin@users.noreply.github.com> * ios: wallpapers user/chat overrides (#4345) * ios: wallpapers user/chat overrides * chat overrides * color picker updates colors correctly * fix state update * labels * background for light theme * small optimization * removed commented code * ios: enhancements to wallpapers (#4361) * ios: enhancements to wallpapers * colors for background * ios: wallpapers import/export (#4362) * ios: wallpapers import/export * comment * ios: wallpapers theme updates (#4365) * ios: wallpapers theme updates * group member background * colors * profile picture colors * unneeded * optimizations, images, state fixes * fixes * no editing of title color * rename Menus and alerts, refactor * tint applying fix * fixes * migration of accent and themes * fix updating system theme * migration changes * limiting color range * ios: wallpapers rename enum (#4384) * ios: wallpapers rename enum2 (#4385) * ios: wallpapers rename enum2 * change * colors were commented * fix build and look --------- Co-authored-by: Stanislav Dmitrenko <7953703+avently@users.noreply.github.com>
149 lines
6.2 KiB
Swift
149 lines
6.2 KiB
Swift
//
|
|
// CIImageView.swift
|
|
// SimpleX
|
|
//
|
|
// Created by JRoberts on 12/04/2022.
|
|
// Copyright © 2022 SimpleX Chat. All rights reserved.
|
|
//
|
|
|
|
import SwiftUI
|
|
import SimpleXChat
|
|
|
|
struct CIImageView: View {
|
|
@EnvironmentObject var m: ChatModel
|
|
let chatItem: ChatItem
|
|
var preview: UIImage?
|
|
let maxWidth: CGFloat
|
|
var imgWidth: CGFloat?
|
|
@State private var showFullScreenImage = false
|
|
|
|
var body: some View {
|
|
let file = chatItem.file
|
|
VStack(alignment: .center, spacing: 6) {
|
|
if let uiImage = getLoadedImage(file) {
|
|
imageView(uiImage)
|
|
.fullScreenCover(isPresented: $showFullScreenImage) {
|
|
FullScreenMediaView(chatItem: chatItem, image: uiImage, showView: $showFullScreenImage)
|
|
}
|
|
.onTapGesture { showFullScreenImage = true }
|
|
.onChange(of: m.activeCallViewIsCollapsed) { _ in
|
|
showFullScreenImage = false
|
|
}
|
|
} else if let preview {
|
|
imageView(preview)
|
|
.onTapGesture {
|
|
if let file = file {
|
|
switch file.fileStatus {
|
|
case .rcvInvitation, .rcvAborted:
|
|
Task {
|
|
if let user = m.currentUser {
|
|
await receiveFile(user: user, fileId: file.fileId)
|
|
}
|
|
}
|
|
case .rcvAccepted:
|
|
switch file.fileProtocol {
|
|
case .xftp:
|
|
AlertManager.shared.showAlertMsg(
|
|
title: "Waiting for image",
|
|
message: "Image will be received when your contact completes uploading it."
|
|
)
|
|
case .smp:
|
|
AlertManager.shared.showAlertMsg(
|
|
title: "Waiting for image",
|
|
message: "Image will be received when your contact is online, please wait or check later!"
|
|
)
|
|
case .local: ()
|
|
}
|
|
case .rcvTransfer: () // ?
|
|
case .rcvComplete: () // ?
|
|
case .rcvCancelled: () // TODO
|
|
case let .rcvError(rcvFileError):
|
|
AlertManager.shared.showAlert(Alert(
|
|
title: Text("File error"),
|
|
message: Text(rcvFileError.errorInfo)
|
|
))
|
|
case let .rcvWarning(rcvFileError):
|
|
AlertManager.shared.showAlert(Alert(
|
|
title: Text("Temporary file error"),
|
|
message: Text(rcvFileError.errorInfo)
|
|
))
|
|
case let .sndError(sndFileError):
|
|
AlertManager.shared.showAlert(Alert(
|
|
title: Text("File error"),
|
|
message: Text(sndFileError.errorInfo)
|
|
))
|
|
case let .sndWarning(sndFileError):
|
|
AlertManager.shared.showAlert(Alert(
|
|
title: Text("Temporary file error"),
|
|
message: Text(sndFileError.errorInfo)
|
|
))
|
|
default: ()
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
private func imageView(_ img: UIImage) -> some View {
|
|
let w = img.size.width <= img.size.height ? maxWidth * 0.75 : maxWidth
|
|
return ZStack(alignment: .topTrailing) {
|
|
if img.imageData == nil {
|
|
Image(uiImage: img)
|
|
.resizable()
|
|
.scaledToFit()
|
|
.frame(width: w)
|
|
} else {
|
|
SwiftyGif(image: img)
|
|
.frame(width: w, height: w * img.size.height / img.size.width)
|
|
.scaledToFit()
|
|
}
|
|
loadingIndicator()
|
|
}
|
|
}
|
|
|
|
@ViewBuilder private func loadingIndicator() -> some View {
|
|
if let file = chatItem.file {
|
|
switch file.fileStatus {
|
|
case .sndStored:
|
|
switch file.fileProtocol {
|
|
case .xftp: progressView()
|
|
case .smp: EmptyView()
|
|
case .local: EmptyView()
|
|
}
|
|
case .sndTransfer: progressView()
|
|
case .sndComplete: fileIcon("checkmark", 10, 13)
|
|
case .sndCancelled: fileIcon("xmark", 10, 13)
|
|
case .sndError: fileIcon("xmark", 10, 13)
|
|
case .sndWarning: fileIcon("exclamationmark.triangle.fill", 10, 13)
|
|
case .rcvInvitation: fileIcon("arrow.down", 10, 13)
|
|
case .rcvAccepted: fileIcon("ellipsis", 14, 11)
|
|
case .rcvTransfer: progressView()
|
|
case .rcvAborted: fileIcon("exclamationmark.arrow.circlepath", 14, 11)
|
|
case .rcvComplete: EmptyView()
|
|
case .rcvCancelled: fileIcon("xmark", 10, 13)
|
|
case .rcvError: fileIcon("xmark", 10, 13)
|
|
case .rcvWarning: fileIcon("exclamationmark.triangle.fill", 10, 13)
|
|
case .invalid: fileIcon("questionmark", 10, 13)
|
|
}
|
|
}
|
|
}
|
|
|
|
private func fileIcon(_ icon: String, _ size: CGFloat, _ padding: CGFloat) -> some View {
|
|
Image(systemName: icon)
|
|
.resizable()
|
|
.aspectRatio(contentMode: .fit)
|
|
.frame(width: size, height: size)
|
|
.foregroundColor(.white)
|
|
.padding(padding)
|
|
}
|
|
|
|
private func progressView() -> some View {
|
|
ProgressView()
|
|
.progressViewStyle(.circular)
|
|
.frame(width: 20, height: 20)
|
|
.tint(.white)
|
|
.padding(8)
|
|
}
|
|
}
|