> ## Documentation Index
> Fetch the complete documentation index at: https://cometchat-013b37f0.mintlify.site/llms.txt
> Use this file to discover all available pages before exploring further.

# Transient Messages

Transient messages are messages that are sent in real-time only and are not saved or tracked anywhere. The receiver of the message will only receive the message if he is online and these messages cannot be retrieved later.

## Send a Transient Message

You can use the `sendTransientMessage()` method to send a transient message to a user or in a group. The receiver will receive this information in the `onTransientMessageReceived()` method of the `MessageListener` class. In order to send the transient message, you need to use the `TransientMessage` class.

<Tabs>
  <Tab title="Dart">
    ```dart theme={null}
    String receiverId = "cometchat-uid-2";
    Map<String,String> data= {};
    data["LIVE_REACTION"] =  "heart";
                        
    TransientMessage transientMessage = TransientMessage( receiverId:receiverId , receiverType:  CometChatReceiverType.user , data: data, );

    CometChat.sendTransientMessage(transientMessage, onSuccess: (){
     				debugPrint("Transient Message Sent");
      			}, onError: (CometChatException e){
    			debugPrint("Transient message sending failed with exception: ${e.message}");
    });
    ```
  </Tab>
</Tabs>

## Real-time Transient Messages

*In other words, as a recipient, how do I know when someone sends a transient message?*

You will receive the transient message in the `onTransientMessageReceived()` method of the registered `MessageListener` class.

<Tabs>
  <Tab title="Dart">
    ```dart theme={null}
    class Class_Name  with MessageListener {

    //CometChat.addMessageListener("listenerId", this);
    @override
    void onTransientMessageReceived(TransientMessage message) {
      // TODO: implement onTransientMessageReceived
    }


    }
    ```
  </Tab>
</Tabs>

The `TransientMessage` class consists of the below parameters:

| Parameter        | Information                                                                                               |
| ---------------- | --------------------------------------------------------------------------------------------------------- |
| **sender**       | An object of the User class holding all the information. related to the sender of the transient message.  |
| **receiverId**   | Unique Id of the receiver. This can be the Id of the group or the user the transient message is sent to.  |
| **receiverType** | The type of the receiver - `CometChatReceiverType.user` (user) or `CometChatReceiverType.``group `(group) |
| **data**         | A Map to provide data.                                                                                    |
