* ios: block members (WIP) * CIBlocked, blocking api * show item as blocked * show blocked and merge multiple deleted items * update block icons * split sent and received deleted to two categories * merge chat feature items, refactor CIMergedRange * merge feature items, two profile images and names on merged items * ensure range is withing chat items range * merge group events * fix/refactor * make group member changes observable * exclude some group events from merging * fix states not updating and other fixes * load list of members when tapping profile * refactor * fix incorrect merging of sent/received marked deleted * fix incorrect expand/hide on single moderated items without content * load members list when opening member via item * comments * fix member counting in case of name collision
81 lines
2.7 KiB
Swift
81 lines
2.7 KiB
Swift
//
|
|
// MarkedDeletedItemView.swift
|
|
// SimpleX (iOS)
|
|
//
|
|
// Created by JRoberts on 30.11.2022.
|
|
// Copyright © 2022 SimpleX Chat. All rights reserved.
|
|
//
|
|
|
|
import SwiftUI
|
|
import SimpleXChat
|
|
|
|
struct MarkedDeletedItemView: View {
|
|
@EnvironmentObject var m: ChatModel
|
|
@Environment(\.colorScheme) var colorScheme
|
|
@ObservedObject var chat: Chat
|
|
var chatItem: ChatItem
|
|
@Binding var revealed: Bool
|
|
|
|
var body: some View {
|
|
(Text(mergedMarkedDeletedText).italic() + Text(" ") + chatItem.timestampText)
|
|
.font(.caption)
|
|
.foregroundColor(.secondary)
|
|
.padding(.horizontal, 12)
|
|
.padding(.vertical, 6)
|
|
.background(chatItemFrameColor(chatItem, colorScheme))
|
|
.cornerRadius(18)
|
|
.textSelection(.disabled)
|
|
}
|
|
|
|
var mergedMarkedDeletedText: LocalizedStringKey {
|
|
if !revealed,
|
|
let ciCategory = chatItem.mergeCategory,
|
|
var i = m.getChatItemIndex(chatItem) {
|
|
var moderated = 0
|
|
var blocked = 0
|
|
var deleted = 0
|
|
var moderatedBy: Set<String> = []
|
|
while i < m.reversedChatItems.count,
|
|
let ci = .some(m.reversedChatItems[i]),
|
|
ci.mergeCategory == ciCategory,
|
|
let itemDeleted = ci.meta.itemDeleted {
|
|
switch itemDeleted {
|
|
case let .moderated(_, byGroupMember):
|
|
moderated += 1
|
|
moderatedBy.insert(byGroupMember.displayName)
|
|
case .blocked: blocked += 1
|
|
case .deleted: deleted += 1
|
|
}
|
|
i += 1
|
|
}
|
|
let total = moderated + blocked + deleted
|
|
return total <= 1
|
|
? markedDeletedText
|
|
: total == moderated
|
|
? "\(total) messages moderated by \(moderatedBy.joined(separator: ", "))"
|
|
: total == blocked
|
|
? "\(total) messages blocked"
|
|
: "\(total) messages marked deleted"
|
|
} else {
|
|
return markedDeletedText
|
|
}
|
|
}
|
|
|
|
var markedDeletedText: LocalizedStringKey {
|
|
switch chatItem.meta.itemDeleted {
|
|
case let .moderated(_, byGroupMember): "moderated by \(byGroupMember.displayName)"
|
|
case .blocked: "blocked"
|
|
default: "marked deleted"
|
|
}
|
|
}
|
|
}
|
|
|
|
struct MarkedDeletedItemView_Previews: PreviewProvider {
|
|
static var previews: some View {
|
|
Group {
|
|
MarkedDeletedItemView(chat: Chat.sampleData, chatItem: ChatItem.getSample(1, .directSnd, .now, "hello", .sndSent(sndProgress: .complete), itemDeleted: .deleted(deletedTs: .now)), revealed: Binding.constant(true))
|
|
}
|
|
.previewLayout(.fixed(width: 360, height: 200))
|
|
}
|
|
}
|