-
Notifications
You must be signed in to change notification settings - Fork 7
Expand file tree
/
Copy pathMessageReactionSummaryView.swift
More file actions
83 lines (77 loc) · 2.81 KB
/
MessageReactionSummaryView.swift
File metadata and controls
83 lines (77 loc) · 2.81 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
import AblyChat
import SwiftUI
struct MessageReactionSummaryView: View {
let summary: MessageReactionSummary
let currentClientID: String
let onPickReaction: () -> Void
let onAddReaction: (String) -> Void
let onDeleteReaction: (String) -> Void
@State private var selectedEmoji: String?
@State private var showReactionMenu = false
@State private var showAllReactionsSheet = false
private let maxReactionsCount = 5
var reactions: [String: MessageReactionSummary.ClientIdList] {
summary.distinct
}
var body: some View {
HStack {
let reactions = reactions
if !reactions.isEmpty {
Button(action: onPickReaction) {
Image(systemName: "plus")
.font(.system(size: 14, weight: .bold))
.frame(width: 24, height: 24)
.background(Circle().fill(Color.gray.opacity(0.2)))
}
.buttonStyle(.plain)
}
ForEach(reactions.keys.sorted().prefix(maxReactionsCount), id: \.self) { emoji in
if let item = reactions[emoji] {
Text("\(emoji) \(item.total)")
.frame(minWidth: 40, minHeight: 24)
.font(.system(size: 12, weight: .regular))
.background(Color.gray.opacity(0.2))
.cornerRadius(12)
.padding(left: -2)
.onTapGesture {
selectedEmoji = emoji
showReactionMenu = true
}
}
}
if !reactions.isEmpty {
Button("•••") {
showAllReactionsSheet = true
}
.padding(left: 2)
.lineLimit(1)
.buttonStyle(.plain)
}
Spacer()
}
.confirmationDialog(
"Reaction Options",
isPresented: $showReactionMenu,
titleVisibility: .visible,
) {
Button("Show who reacted") {
showAllReactionsSheet = true
}
if let emoji = selectedEmoji {
if reactions[emoji]?.clientIds.contains(currentClientID) ?? false {
Button("Remove my \(emoji)", role: .destructive) {
onDeleteReaction(emoji)
}
} else {
Button("React with \(emoji)") {
onAddReaction(emoji)
}
}
}
Button("Cancel", role: .cancel) {}
}
.sheet(isPresented: $showAllReactionsSheet) {
MessageReactionsSheet(uniqueOrDistinct: reactions)
}
}
}