Session
The Session 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.
The Session component can be used by itself or with the Chatbox,
Inbox or Popup components as its descendants. If you use a Chatbox, Inbox or Popup then it must be a descendant of Session. It, however, does not need to be a direct descendant.
The session encapsulates a connection to the TalkJS realtime infrastructure, and this connection will live as long as the session component is mounted. If you want to listen for events or show desktop notifications for new messages, we recommend putting the session at the top of your component hierarchy, so that it is active even when no chat UI is being shown.
| Name | Type | Description | 
|---|---|---|
| string | Your app's unique TalkJS ID. Get it from the Settings page of the dashboard. | |
| Talk.User|() => Talk.User | Required unless userIdis provided.A Talk.Userobject or a function returning aTalk.Userobject that identifies the currently active user. | |
| string | Required unless syncUseris provided.The idof the currently active user. | |
| boolean | Determines whether desktop notifications will be sent to the device the user is currently using. | |
| React | A React mutable ref object that holds the current TalkJS session object. See an example of how to use sessionRefin your application. | |
| string | A token to authenticate the session with. Pass tokenif you use standard (non-refreshable) authentication. | |
| () => Promise<string> | A callback that fetches a new token from your backend and returns 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. | 
You can pass all events (methods with names starting with on) accepted by Talk.Session to the Session component as props with the same name.
You can pass the Unreads.onChange event to the session as the onUnreadsChange prop.
See below for an example.
This section gives some examples that demonstrate how to use the Session component.
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.
Create a session for an existing user with the userId prop:
Create or update user data with the syncUser prop. This prop expects a callback that uses the regular TalkJS JavaScript SDK to create a Talk.User object:
To reference a session outside the Session component, assign the underlying Talk.Session object to a ref:
The ref will be set once the Talk.Session object has initialized, and it will be set back to undefined once it has been destroyed.
Make sure you always check the isAlive property to ensure that the object is not destroyed, because React is prone to trigger race conditions here (especially when React.StrictMode is enabled or when using a development setup with hot reloading, both of which cause a lot of destroying).
Respond to events (in this case, new messages and changes in the number of unread message) by printing details to the console: