Fix Conversation.lastStatus nullability issue (#709) close #696

* Fix Conversation.lastStatus nullability issue

* Fix UI

---------

Co-authored-by: Thomas Ricouard <ricouard77@gmail.com>
This commit is contained in:
Peter-Josef Meisch 2023-02-08 06:27:44 +01:00 committed by GitHub
parent e953c243cc
commit 1c8fabbe59
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
6 changed files with 25 additions and 17 deletions

View file

@ -113,12 +113,14 @@ public struct ConversationDetailView: View {
private var inputTextView: some View { private var inputTextView: some View {
VStack { VStack {
HStack(alignment: .bottom, spacing: 8) { HStack(alignment: .bottom, spacing: 8) {
if viewModel.conversation.lastStatus != nil {
Button { Button {
routerPath.presentedSheet = .replyToStatusEditor(status: viewModel.conversation.lastStatus) routerPath.presentedSheet = .replyToStatusEditor(status: viewModel.conversation.lastStatus!)
} label: { } label: {
Image(systemName: "plus") Image(systemName: "plus")
} }
.padding(.bottom, 7) .padding(.bottom, 7)
}
TextField("conversations.new.message.placeholder", text: $viewModel.newMessageText, axis: .vertical) TextField("conversations.new.message.placeholder", text: $viewModel.newMessageText, axis: .vertical)
.focused($isMessageFieldFocused) .focused($isMessageFieldFocused)

View file

@ -17,7 +17,7 @@ class ConversationDetailViewModel: ObservableObject {
init(conversation: Conversation) { init(conversation: Conversation) {
self.conversation = conversation self.conversation = conversation
messages = [conversation.lastStatus] messages = conversation.lastStatus != nil ? [conversation.lastStatus!] : []
} }
func fetchMessages() async { func fetchMessages() async {
@ -64,7 +64,9 @@ class ConversationDetailViewModel: ObservableObject {
event.conversation.id == conversation.id event.conversation.id == conversation.id
{ {
conversation = event.conversation conversation = event.conversation
appendNewStatus(status: conversation.lastStatus) if conversation.lastStatus != nil {
appendNewStatus(status: conversation.lastStatus!)
}
} }
} }

View file

@ -61,7 +61,7 @@ struct ConversationMessageView: View {
.padding(.trailing, isOwnMessage ? 0 : 24) .padding(.trailing, isOwnMessage ? 0 : 24)
} }
if message.id == conversation.lastStatus.id { if message.id == String(conversation.lastStatus?.id ?? "") {
HStack { HStack {
if isOwnMessage { if isOwnMessage {
Spacer() Spacer()

View file

@ -31,10 +31,12 @@ struct ConversationsListRow: View {
.foregroundColor(theme.tintColor) .foregroundColor(theme.tintColor)
.frame(width: 10, height: 10) .frame(width: 10, height: 10)
} }
Text(conversation.lastStatus.createdAt.relativeFormatted) if conversation.lastStatus != nil {
Text(conversation.lastStatus!.createdAt.relativeFormatted)
.font(.scaledFootnote) .font(.scaledFootnote)
} }
EmojiTextApp(conversation.lastStatus.content, emojis: conversation.lastStatus.emojis) }
EmojiTextApp(conversation.lastStatus?.content ?? HTMLString(stringValue: ""), emojis: conversation.lastStatus?.emojis ?? [])
.multilineTextAlignment(.leading) .multilineTextAlignment(.leading)
.font(.scaledBody) .font(.scaledBody)
} }
@ -48,9 +50,11 @@ struct ConversationsListRow: View {
routerPath.navigate(to: .conversationDetail(conversation: conversation)) routerPath.navigate(to: .conversationDetail(conversation: conversation))
} }
.padding(.top, 4) .padding(.top, 4)
if conversation.lastStatus != nil {
actionsView actionsView
.padding(.bottom, 4) .padding(.bottom, 4)
} }
}
.contextMenu { .contextMenu {
contextMenu contextMenu
} }
@ -59,7 +63,7 @@ struct ConversationsListRow: View {
private var actionsView: some View { private var actionsView: some View {
HStack(spacing: 12) { HStack(spacing: 12) {
Button { Button {
routerPath.presentedSheet = .replyToStatusEditor(status: conversation.lastStatus) routerPath.presentedSheet = .replyToStatusEditor(status: conversation.lastStatus!)
} label: { } label: {
Image(systemName: "arrowshape.turn.up.left.fill") Image(systemName: "arrowshape.turn.up.left.fill")
} }

View file

@ -64,7 +64,7 @@ class ConversationsListViewModel: ObservableObject {
conversations.remove(at: index) conversations.remove(at: index)
} }
conversations.insert(event.conversation, at: 0) conversations.insert(event.conversation, at: 0)
conversations = conversations.sorted(by: { $0.lastStatus.createdAt.asDate > $1.lastStatus.createdAt.asDate }) conversations = conversations.sorted(by: { ($0.lastStatus?.createdAt.asDate ?? Date.now) > ($1.lastStatus?.createdAt.asDate ?? Date.now) })
} }
} }
} }

View file

@ -3,7 +3,7 @@ import Foundation
public struct Conversation: Identifiable, Decodable, Hashable, Equatable { public struct Conversation: Identifiable, Decodable, Hashable, Equatable {
public let id: String public let id: String
public let unread: Bool public let unread: Bool
public let lastStatus: Status public let lastStatus: Status?
public let accounts: [Account] public let accounts: [Account]
public static func placeholder() -> Conversation { public static func placeholder() -> Conversation {