Session
This component represents a user's active TalkJS session. It handles authenticating your app with TalkJS. You need to ensure that your users can only have a TalkJS session when they have a valid session in your app.
A Session component can be used standalone or with Chatbox as its descendant.
If you need to use a Chatbox then it MUST be a descendant of Session.
It, however, does not need to be a direct descendant.
| Name | Type | Description | 
|---|---|---|
| string | Your app's unique TalkJS ID. Get it from the Settings page of your dashboard. | |
| User | A Userobject that identifies the currently active user. The user is uniquely identified by theirid. | |
| boolean | This determines whether push notifications will be sent to the device the user is currently using. If not passed or explicitly set to undefined, the SDK will not automatically register or unregister the current device. You'll have to callsetPushRegistrationorunsetPushRegistrationaccordingly. | |
| string | A token to authenticate the session with. Pass tokenif you use standard (non-refreshable) authentication. | |
| TokenFetcherHandler | Triggered when TalkJS needs a new authentication token. The handler should fetch a new token from your server and return it. Pass tokenFetcherif you use authentication with refreshable tokens. | |
| string | The HMAC-SHA256 hash of the current user id, signed with your TalkJS secret key. Pass signatureif you use legacy signature-based authentication. | |
| MessageHandler | Triggered when a message is sent in a conversation the current user is in. | |
| UnreadsChangeHandler | Triggered when the list of unread conversations changes. | 
Verifies whether the appId is valid.
Returns a Promise of a boolean that never rejects.
Promise<boolean>
Unregisters all the push registration device tokens for the currently active user.
void
Registers the given device token with the TalkJS backend to receive push notifications from the given platform.
| Name | Type | Description | 
|---|---|---|
| token Required | DeviceToken | Object detailing the push notification platform and device id to be registered | 
void
Unregisters the given device token from the TalkJS backend.
| Name | Type | Description | 
|---|---|---|
| token Required | DeviceToken | Object detailing the push notification platform and device id to be unregistered | 
void
You'll need to replace <APP_ID> with your TalkJS App ID. You can find your App ID in the Settings tab of the TalkJS dashboard.
Triggered when the current token is about to expire. Should fetch a new token from your backend and return it.
Triggered when a message is sent in a conversation the current user is in.
A message event is fired every time a message
is sent or received by the current user (even if no TalkJS UI is visible).
Note: MessageHandler does not get triggered for conversations where the current user is a guest. It only applies to users who were added as
participants.
| Name | Type | Description | 
|---|---|---|
| message | Message | An object representing a TalkJS message. | 
Triggered when the list of unread conversations changes.
A "change" event is fired right after the Session loads as well as every time the amount of unread conversations changed. The handler is called with an array of objects with limited information about each conversation.
| Field | Type | Description | 
|---|---|---|
| conversation | ConversationData | The ConversationDataof the unread conversation. | 
| lastMessage | Message | Contains the last Messagefor this conversation. | 
| unreadMessageCount | number | The number of unread messages in this conversation | 
Contains details regarding the device's push registration ID and the platform the ID is to be used for.
| Name | Type | Description | 
|---|---|---|
| provider Required | fcm|apns | The platform to be used to send push notifications. | 
| pushRegistrationId Required | string | The push registration device id for the given device. |