|
@ -35,6 +35,11 @@ enum ThreadState { |
|
|
case chatroom |
|
|
case chatroom |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
enum FilterState : Int { |
|
|
|
|
|
case posts_and_replies = 1 |
|
|
|
|
|
case posts = 0 |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
struct ContentView: View { |
|
|
struct ContentView: View { |
|
|
let keypair: Keypair |
|
|
let keypair: Keypair |
|
|
|
|
|
|
|
@ -59,6 +64,7 @@ struct ContentView: View { |
|
|
@State var profile_open: Bool = false |
|
|
@State var profile_open: Bool = false |
|
|
@State var thread_open: Bool = false |
|
|
@State var thread_open: Bool = false |
|
|
@State var search_open: Bool = false |
|
|
@State var search_open: Bool = false |
|
|
|
|
|
@State var filter_state : FilterState = .posts_and_replies |
|
|
@StateObject var home: HomeModel = HomeModel() |
|
|
@StateObject var home: HomeModel = HomeModel() |
|
|
|
|
|
|
|
|
// connect retry timer |
|
|
// connect retry timer |
|
@ -88,9 +94,11 @@ struct ContentView: View { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
var PostingTimelineView: some View { |
|
|
var PostingTimelineView: some View { |
|
|
|
|
|
VStack{ |
|
|
|
|
|
FiltersView |
|
|
ZStack { |
|
|
ZStack { |
|
|
if let damus = self.damus_state { |
|
|
if let damus = self.damus_state { |
|
|
TimelineView(events: $home.events, loading: $home.loading, damus: damus, show_friend_icon: false) |
|
|
TimelineView(events: $home.events, loading: $home.loading, damus: damus, show_friend_icon: false, filter: filter_event) |
|
|
} |
|
|
} |
|
|
if privkey != nil { |
|
|
if privkey != nil { |
|
|
PostButtonContainer { |
|
|
PostButtonContainer { |
|
@ -99,6 +107,25 @@ struct ContentView: View { |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
var FiltersView: some View { |
|
|
|
|
|
VStack{ |
|
|
|
|
|
Picker("Filter State", selection: $filter_state) { |
|
|
|
|
|
Text("Posts").tag(FilterState.posts) |
|
|
|
|
|
Text("Posts & Replies").tag(FilterState.posts_and_replies) |
|
|
|
|
|
} |
|
|
|
|
|
.pickerStyle(.segmented) |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
func filter_event(_ ev: NostrEvent) -> Bool { |
|
|
|
|
|
if self.filter_state == .posts { |
|
|
|
|
|
return !ev.is_reply(nil) |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
return true |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
func MainContent(damus: DamusState) -> some View { |
|
|
func MainContent(damus: DamusState) -> some View { |
|
|
VStack { |
|
|
VStack { |
|
@ -119,7 +146,7 @@ struct ContentView: View { |
|
|
PostingTimelineView |
|
|
PostingTimelineView |
|
|
|
|
|
|
|
|
case .notifications: |
|
|
case .notifications: |
|
|
TimelineView(events: $home.notifications, loading: $home.loading, damus: damus, show_friend_icon: true) |
|
|
TimelineView(events: $home.notifications, loading: $home.loading, damus: damus, show_friend_icon: true, filter: { _ in true }) |
|
|
.navigationTitle("Notifications") |
|
|
.navigationTitle("Notifications") |
|
|
|
|
|
|
|
|
case .dms: |
|
|
case .dms: |
|
|