客户端按时间戳过滤订单文本消息

时间:2018-06-20 14:56:41

标签: ios swift firebase google-cloud-firestore

当前它显示的是在左侧发送的文本消息,然后是在右侧接收的文本消息。但是,我希望接收和发送的文本消息都按时间戳一次进行排序(当前,它先按时间戳,然后显示已发送的消息,然后下一步,它将按时间戳对接收到的消息进行排序,然后显示接收到的消息。)

override func viewDidLoad() {
    super.viewDidLoad()
    loadPosts()
    loadPostsReceivedMessage()
    }
func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell{
 let cell = collectionView.dequeueReusableCell(withReuseIdentifier: cellIdentifier, for: indexPath) as! ChatCollectionViewCell    
     let senderIDNumber = Auth.auth().currentUser?.uid

//Setup the messageReceived and messageSent
        if chats[indexPath.row].senderID == senderIDNumber {
        if let chatsText = chats[indexPath.row].message{
            let size = CGSize(width: 250, height: 1000)
            let options = NSStringDrawingOptions.usesFontLeading.union(.usesLineFragmentOrigin)
            let estimatedFrame = NSString(string: chatsText).boundingRect(with: size, options: options, attributes: [NSAttributedStringKey.font : UIFont.systemFont(ofSize: 18)], context: nil)
            cell.messageSend.frame = CGRect(x:8,y:0,width:estimatedFrame.width + 16, height:estimatedFrame.height + 20)
            cell.textBubbleView.frame = CGRect(x:0,y:0,width:estimatedFrame.width + 16 + 8, height:estimatedFrame.height + 20)
         //showOutgoingMessage(text: chats[indexPath.row].message)
    }
            cell.messageSend.text = chats[indexPath.row].message
        }
    else {
            cell.messageReceived.text = chats[indexPath.row].message
            let chatsText = chats[indexPath.row].message
            let size = CGSize(width: 250, height: 1000)
            let options = NSStringDrawingOptions.usesFontLeading.union(.usesLineFragmentOrigin)
            let estimatedFrame = NSString(string: chatsText!).boundingRect(with: size, options: options, attributes: [NSAttributedStringKey.font : UIFont.systemFont(ofSize: 18)], context: nil)
            cell.messageReceived.frame = CGRect(x:view.frame.width - estimatedFrame.width - 30,y:0,width:estimatedFrame.width + 16, height:estimatedFrame.height + 20)
            cell.textBubbleView.frame = CGRect(x:view.frame.width - estimatedFrame.width - 30,y:0,width:estimatedFrame.width + 16 + 4, height:estimatedFrame.height + 20)
    }
    return cell
}

func collectionView(_ collectionView: UICollectionView,
layout collectionViewLayout: UICollectionViewLayout,
sizeForItemAt indexPath: IndexPath) -> CGSize {
if let chatsText = chats[indexPath.row].message {
    let size = CGSize(width: 250, height: 1000)
        let options = NSStringDrawingOptions.usesFontLeading.union(.usesLineFragmentOrigin)
        let estimatedFrame = NSString(string: chatsText).boundingRect(with: size, options: options, attributes: [NSAttributedStringKey.font : UIFont.systemFont(ofSize: 18)], context: nil)
        return CGSize(width: view.frame.width, height: estimatedFrame.height + 20)
    }

    return CGSize(width: view.frame.width, height: 200)
}

//Get Message sent
  func loadPosts() {
    let senderIDNumber = Auth.auth().currentUser?.uid
    let chatsRef = db.collection("chats").order(by: "timestamp", descending: false)
    chatsRef.whereField("senderID", isEqualTo: senderIDNumber!).whereField("receiverID", isEqualTo: receiverIDNumber)
        .addSnapshotListener { querySnapshot, error in
            guard let documents = querySnapshot?.documents else {
                print("Error fetching documents: \(error!)")
                return
            }
            for document in documents {
                let messageText = document.data()["message"] as? String
                let senderIDNumber = document.data()["senderID"] as? String
                let receiverIDNumber = document.data()["receiverID"] as? String
                let timestamp = document.data()["timestamp"] as? String
                guard let sender = document.data()["sender"] as? String else {return}
               // let conversationsCounter = document.data()["conversationsCounter"] as? Int
                guard let profileUrl = document.data()["profileUrl"] as? String else { return}
                let chat = Chat(messageTextString: messageText!, senderIDNumber: senderIDNumber!, receiverIDNumber: receiverIDNumber!, timeStampString: timestamp!, profileImageUrl: profileUrl, senderString: sender)
self.chats.append(chat)
print(self.chats)
self.collectionView.reloadData()
}
}
}


//Get message received
func loadPostsReceivedMessage() {
   /* let uid = Auth.auth().currentUser?.uid
    let ref = Database.database().reference()
    ref.child("users").child(uid!).observeSingleEvent(of: .value, with: { (snapshot) in
        if let dic = snapshot.value as? [String: AnyObject]{
            let currentUser = dic["username"] as? String
            let senderIDNumber = Auth.auth().currentUser?.uid
        } */
            let chatsRef = db.collection("chats").order(by: "timestamp", descending: false)
            print("thecurrentreceiver"+senderString)
            print("thecurrentsender"+receiverIDNumber)
    chatsRef.whereField("receiverID", isEqualTo: senderString).whereField("sender", isEqualTo: receiverIDNumber)
                .addSnapshotListener { querySnapshot, error in
                    guard let documents = querySnapshot?.documents else {
                        print("Error fetching documents: \(error!)")
                        return
                    }
                    for document in documents {
                        let messageText = document.data()["message"] as? String
                        let senderIDNumber = document.data()["senderID"] as? String
                        let receiverIDNumber = document.data()["receiverID"] as? String
                        let timestamp = document.data()["timestamp"] as? String
                        // let conversationsCounter = document.data()["conversationsCounter"] as? Int
                        guard let profileUrl = document.data()["profileUrl"] as? String else { return}
                        guard let sender = document.data()["sender"] as? String else {return}
                        let chat = Chat(messageTextString: messageText!, senderIDNumber: senderIDNumber!, receiverIDNumber: receiverIDNumber!, timeStampString: timestamp!,profileImageUrl: profileUrl, senderString: sender)
                        print("whatisthemessage"+messageText!)
                        self.chats.append(chat)
                        print(self.chats)
                        self.collectionView.reloadData()
                    }
            }
}

1 个答案:

答案 0 :(得分:0)

我认为您已经为这一麻烦做好了准备。为什么不使用这种结构:

  -chats
   --chatID
      ---senderID
      ---receiverID

这样,每条传入的消息都是以发件人ID命名的文档。然后,当您要按loadPosts()快照的形式按时间顺序排列时,唯一要做的就是根据发件人的身份将其右移或左移。