mirror of https://github.com/lukechilds/damus.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
191 lines
6.0 KiB
191 lines
6.0 KiB
//
|
|
// EventActionBar.swift
|
|
// damus
|
|
//
|
|
// Created by William Casarin on 2022-04-16.
|
|
//
|
|
|
|
import SwiftUI
|
|
import UIKit
|
|
|
|
enum ActionBarSheet: Identifiable {
|
|
case reply
|
|
|
|
var id: String {
|
|
switch self {
|
|
case .reply: return "reply"
|
|
}
|
|
}
|
|
}
|
|
|
|
struct EventActionBar: View {
|
|
let damus_state: DamusState
|
|
let event: NostrEvent
|
|
let generator = UIImpactFeedbackGenerator(style: .medium)
|
|
@State var sheet: ActionBarSheet? = nil
|
|
@State var confirm_boost: Bool = false
|
|
@State var show_share_sheet: Bool = false
|
|
@StateObject var bar: ActionBarModel
|
|
|
|
var body: some View {
|
|
HStack {
|
|
/*
|
|
EventActionButton(img: "square.and.arrow.up") {
|
|
print("share")
|
|
}
|
|
|
|
Spacer()
|
|
|
|
*/
|
|
if damus_state.keypair.privkey != nil {
|
|
EventActionButton(img: "bubble.left", col: nil) {
|
|
notify(.reply, event)
|
|
}
|
|
.frame(minWidth: 0, maxWidth: .infinity, alignment: .leading)
|
|
}
|
|
|
|
HStack(alignment: .bottom) {
|
|
Text("\(bar.boosts > 0 ? "\(bar.boosts)" : "")")
|
|
.font(.footnote.weight(.medium))
|
|
.foregroundColor(bar.boosted ? Color.green : Color.gray)
|
|
|
|
EventActionButton(img: "arrow.2.squarepath", col: bar.boosted ? Color.green : nil) {
|
|
if bar.boosted {
|
|
notify(.delete, bar.our_boost)
|
|
} else {
|
|
self.confirm_boost = true
|
|
}
|
|
}
|
|
}
|
|
.frame(minWidth: 0, maxWidth: .infinity, alignment: .leading)
|
|
|
|
HStack(alignment: .bottom) {
|
|
Text("\(bar.likes > 0 ? "\(bar.likes)" : "")")
|
|
.font(.footnote.weight(.medium))
|
|
.foregroundColor(bar.liked ? Color.orange : Color.gray)
|
|
|
|
LikeButton(liked: bar.liked) {
|
|
if bar.liked {
|
|
notify(.delete, bar.our_like)
|
|
} else {
|
|
send_like()
|
|
}
|
|
}
|
|
}
|
|
.frame(minWidth: 0, maxWidth: .infinity, alignment: .leading)
|
|
|
|
EventActionButton(img: "square.and.arrow.up", col: Color.gray) {
|
|
show_share_sheet = true
|
|
}
|
|
.frame(minWidth: 0, maxWidth: .infinity, alignment: .leading)
|
|
|
|
/*
|
|
HStack(alignment: .bottom) {
|
|
Text("\(bar.tips > 0 ? "\(bar.tips)" : "")")
|
|
.font(.footnote)
|
|
.foregroundColor(bar.tipped ? Color.orange : Color.gray)
|
|
|
|
EventActionButton(img: bar.tipped ? "bitcoinsign.circle.fill" : "bitcoinsign.circle", col: bar.tipped ? Color.orange : nil) {
|
|
if bar.tipped {
|
|
//notify(.delete, bar.our_tip)
|
|
} else {
|
|
//notify(.boost, event)
|
|
}
|
|
}
|
|
}
|
|
*/
|
|
}
|
|
.sheet(isPresented: $show_share_sheet) {
|
|
if let note_id = bech32_note_id(event.id) {
|
|
if let url = URL(string: "https://damus.io/" + note_id) {
|
|
ShareSheet(activityItems: [url])
|
|
}
|
|
}
|
|
}
|
|
.alert(NSLocalizedString("Boost", comment: "Title of alert for confirming to boost a post."), isPresented: $confirm_boost) {
|
|
Button("Cancel") {
|
|
confirm_boost = false
|
|
}
|
|
Button(NSLocalizedString("Boost", comment: "Button to confirm boosting a post.")) {
|
|
send_boost()
|
|
}
|
|
} message: {
|
|
Text("Are you sure you want to boost this post?", comment: "Alert message to ask if user wants to boost a post.")
|
|
}
|
|
.onReceive(handle_notify(.liked)) { n in
|
|
let liked = n.object as! Counted
|
|
if liked.id != event.id {
|
|
return
|
|
}
|
|
self.bar.likes = liked.total
|
|
if liked.event.pubkey == damus_state.keypair.pubkey {
|
|
self.bar.our_like = liked.event
|
|
}
|
|
}
|
|
}
|
|
|
|
func send_boost() {
|
|
guard let privkey = self.damus_state.keypair.privkey else {
|
|
return
|
|
}
|
|
|
|
let boost = make_boost_event(pubkey: damus_state.keypair.pubkey, privkey: privkey, boosted: self.event)
|
|
|
|
self.bar.our_boost = boost
|
|
|
|
damus_state.pool.send(.event(boost))
|
|
}
|
|
|
|
func send_like() {
|
|
guard let privkey = damus_state.keypair.privkey else {
|
|
return
|
|
}
|
|
|
|
let like_ev = make_like_event(pubkey: damus_state.pubkey, privkey: privkey, liked: event)
|
|
|
|
self.bar.our_like = like_ev
|
|
|
|
generator.impactOccurred()
|
|
|
|
damus_state.pool.send(.event(like_ev))
|
|
}
|
|
}
|
|
|
|
|
|
func EventActionButton(img: String, col: Color?, action: @escaping () -> ()) -> some View {
|
|
Button(action: action) {
|
|
Label(" ", systemImage: img)
|
|
.font(.footnote.weight(.medium))
|
|
.foregroundColor(col == nil ? Color.gray : col!)
|
|
}
|
|
}
|
|
|
|
struct LikeButton: View {
|
|
let liked: Bool
|
|
let action: () -> ()
|
|
|
|
@Environment(\.colorScheme) var colorScheme
|
|
|
|
var body: some View {
|
|
Button(action: action) {
|
|
if liked {
|
|
Text("🤙", comment: "Button with emoji to like an event.")
|
|
} else {
|
|
Image("shaka")
|
|
.renderingMode(.template)
|
|
.foregroundColor(.gray)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
struct EventActionBar_Previews: PreviewProvider {
|
|
static var previews: some View {
|
|
let pk = "pubkey"
|
|
let ds = test_damus_state()
|
|
let bar = ActionBarModel(likes: 0, boosts: 0, tips: 0, our_like: nil, our_boost: nil, our_tip: nil)
|
|
let ev = NostrEvent(content: "hi", pubkey: pk)
|
|
EventActionBar(damus_state: ds, event: ev, bar: bar)
|
|
}
|
|
}
|
|
|