Developers

Headless API

API reference

@nlxai/chat-core

Interfaces

Type Aliases

Context

Ƭ Context: Record<string, any>

Context for usage later in the intent.

Defined in

index.ts:13


SlotsRecord

Ƭ SlotsRecord: Record<string, any>

Values to fill an intent's attached slots.

SlotRecord Keys are the attached slot's name

SlotRecord Values are usually a discrete value matching the slots's type. for custom slots, this can optionally be the value's ID.

A SlotsRecord is equivalent to an array of SlotValue objects.

Defined in

index.ts:42


SlotsRecordOrArray

Ƭ SlotsRecordOrArray: SlotsRecord | SlotValue[]

Values to fill an intent's attached slots.

Supports either a SlotsRecord or an array of SlotValue objects

Defined in

index.ts:49


UserResponsePayload

Ƭ UserResponsePayload: { type: "text" ; text: string ; context?: Context } | { type: "choice" ; choiceId: string ; context?: Context } | { type: "structured" ; context?: Context } & StructuredRequest

The payload of the user response

Defined in

index.ts:224


Response

Ƭ Response: BotResponse | UserResponse | FailureMessage

A response from the bot or the user.

Defined in

index.ts:293


Time

Ƭ Time: number

The time value in milliseconds since midnight, January 1, 1970 UTC.

Defined in

index.ts:298


Subscriber

Ƭ Subscriber: (response: Response[], newResponse?: Response) => void

The callback function for listening to all responses.

Type declaration

▸ (response, newResponse?): void

Parameters
NameType
responseResponse[]
newResponse?Response
Returns

void

Defined in

index.ts:552

Functions

shouldReinitialize

shouldReinitialize(config1, config2): boolean

Helper method to decide when a new Config requires creating a new ConversationHandler or whether the old Config's ConversationHandler can be used.

The order of configs doesn't matter.

Parameters

NameType
config1Config
config2Config

Returns

boolean

true if createConversation should be called again

Defined in

index.ts:563


createConversation

createConversation(config): ConversationHandler

Call this to create a conversation handler.

Parameters

NameType
configConfig

Returns

ConversationHandler

The ConversationHandler is a bundle of functions to interact with the conversation.

Defined in

index.ts:575


getCurrentExpirationTimestamp

getCurrentExpirationTimestamp(responses): null | number

Get current expiration timestamp from the current list of reponses

Parameters

NameTypeDescription
responsesResponse[]the current list of user and bot responses (first argument in the subscribe callback)

Returns

null | number

an expiration timestamp in Unix Epoch (new Date().getTime()), or null if this is not known (typically occurs if the bot has not responded yet)

Defined in

index.ts:950


promisify

promisify<T>(fn, convo, timeout?): (payload: T) => Promise<Response | null>

This package is intentionally designed with a subscription-based API as opposed to a promise-based one where each message corresponds to a single bot response, available asynchronously.

If you need a promise-based wrapper, you can use the promisify helper available in the package:

Type parameters

NameDescription
Tthe type of the function's params, e.g. for sendText it's text: string, context?: Context

Parameters

NameTypeDefault valueDescription
fn(payload: T) => voidundefinedthe function to wrap (e.g. convo.sendText, convo.sendChoice, etc.)
convoConversationHandlerundefinedthe ConversationHandler (from createConversation)
timeoutnumber10000the timeout in milliseconds

Returns

fn

A promise-wrapped version of the function. The function, when called, returns a promise that resolves to the Conversation's next response.

▸ (payload): Promise<Response | null>

Parameters
NameType
payloadT
Returns

Promise<Response | null>

Example

1import { createConversation, promisify } from "@nlxai/chat-core"; 2 3const convo = createConversation(config); 4 5const sendTextWrapped = promisify(convo.sendText, convo); 6 7sendTextWrapped("Hello").then((response) => { 8 console.log(response); 9});

Defined in

index.ts:987

Interfaces

Interface: BotMessage

A message from the bot, as well as any choices the user can make.

Properties

messageId

Optional messageId: string

A unique identifier for the message.

Defined in

index.ts:154


nodeId

Optional nodeId: string

The node id that this message is associated with. This is must be sent with a choice when the user is changing a previously sent choice.

Defined in

index.ts:159


text

text: string

The body of the message. Show this to the user.

Defined in

index.ts:163


choices

choices: Choice[]

A selection of choices to show to the user. They may choose one of them.

Defined in

index.ts:167


metadata

Optional metadata: BotMessageMetadata

Metadata

Defined in

index.ts:171


selectedChoiceId

Optional selectedChoiceId: string

After a choice has been made by the user, this will be updated locally to the selected choice id. This field is set locally and does not come from the bot.

Defined in

index.ts:176

Interface: BotMessageMetadata

Metadata for the individual bot message as well as whether the client should poll for more bot responses.

Properties

intentId

Optional intentId: string

The message node's intent

Defined in

index.ts:144

Interface: BotResponse

A message from the bot

See also:

Properties

type

type: "bot"

The type of the response is "bot" for bot and "user" for user, and "failure" for failure.

Defined in

index.ts:63


receivedAt

receivedAt: number

When the response was received

Defined in

index.ts:67


payload

payload: BotResponsePayload

The payload of the response

Defined in

index.ts:71

Interface: BotResponseMetadata

Global state about the current conversation as well as whether the client should poll for more bot responses.

Properties

intentId

Optional intentId: string

The conversation's intent

Defined in

index.ts:117


escalation

Optional escalation: boolean

Whether the current conversation has been marked as incomprehension.

Defined in

index.ts:121


frustration

Optional frustration: boolean

Whether the current conversation has been marked frustrated

Defined in

index.ts:125


incomprehension

Optional incomprehension: boolean

Whether the current conversation has been marked as incomprehension.

Defined in

index.ts:129


hasPendingDataRequest

Optional hasPendingDataRequest: boolean

Whether the client should poll for more bot responses.

Defined in

index.ts:133

Interface: BotResponsePayload

The payload of the bot response

Properties

expirationTimestamp

Optional expirationTimestamp: number

If there isn't some interaction by this time, the conversation will expire.

Defined in

index.ts:81


conversationId

Optional conversationId: string

The active conversation ID. If not set, a new conversation will be started.

Defined in

index.ts:85


messages

messages: BotMessage[]

Any messages from the bot.

Defined in

index.ts:89


metadata

Optional metadata: BotResponseMetadata

Global state about the current conversation as well as whether the client should poll for more bot responses.

Defined in

index.ts:94


payload

Optional payload: string

If configured, the node's payload.

Defined in

index.ts:98


modalities

Optional modalities: Record<string, any>

If configured, the node's modalities and their payloads.

Defined in

index.ts:102


context

Optional context: Context

If the node is set to send context, the whole context associated with the conversation.

Defined in

index.ts:106

Interface: Choice

A choices to show to the user.

Properties

choiceId

choiceId: string

choiceId is used by sendChoice to let the user choose this choice.

Defined in

index.ts:186


choiceText

choiceText: string

The text of the choice

Defined in

index.ts:190


choicePayload

Optional choicePayload: any

An optional, schemaless payload for the choice.

Defined in

index.ts:194

Interface: ChoiceRequestMetadata

Helps link the choice to the specific message in the conversation.

Properties

responseIndex

Optional responseIndex: number

The index of the Response associated with this choice. Setting this ensures that local state's selectedChoiceId on the corresponding BotResponse is set. It is not sent to the bot.

Defined in

index.ts:432


messageIndex

Optional messageIndex: number

The index of the BotMessage associated with this choice. Setting this ensures that local state's selectedChoiceId on the corresponding BotResponse is set. It is not sent to the bot.

Defined in

index.ts:438


nodeId

Optional nodeId: string

Required if you want to change a choice that's already been sent. The nodeId can be found in the corresponding BotMessage.

Defined in

index.ts:443


intentId

Optional intentId: string

Intent ID, used for sending to the NLU to allow it to double-check

Defined in

index.ts:447

Interface: Config

The configuration to create a conversation.

Properties

botUrl

botUrl: string

Fetch this from the bot's Deployment page.

Defined in

index.ts:314


headers

headers: Record<string, string> & { nlx-api-key: string }

Headers to forward to the NLX API.

Defined in

index.ts:318


conversationId

Optional conversationId: string

Set conversationId to continue an existing conversation. If not set, a new conversation will be started.

Defined in

index.ts:328


userId

Optional userId: string

Setting the userID allows it to be searchable in bot history, as well as usable via {System.userId} in the intent.

Defined in

index.ts:332


responses

Optional responses: Response[]

When responses is set, initialize the chatHandler with historical messages.

Defined in

index.ts:336


failureMessage

Optional failureMessage: string

When set, this overrides the default failure message ("We encountered an issue. Please try again soon.").

Defined in

index.ts:340


languageCode

languageCode: string

The language code to use for the bot. In the browser this can be fetched with navigator.language. If you don't have translations, hard-code this to the language code you support.

Defined in

index.ts:345


experimental

Optional experimental: Object

Experimental settings

Type declaration
NameTypeDescription
channelType?stringSimulate alternative channel types
completeBotUrl?booleanPrevent the languageCode parameter to be appended to the bot URL - used in special deployment environments such as the sandbox chat inside Dialog Studio
Defined in

index.ts:354

Interface: ConversationHandler

A bundle of functions to interact with a conversation, created by createConversation.

Properties

sendText

sendText: (text: string, context?: Context) => void

Send user's message

Type declaration

▸ (text, context?): void

Parameters
NameTypeDescription
textstringthe user's message
context?ContextContext for usage later in the intent.
Returns

void

Defined in

index.ts:459


sendSlots

sendSlots: (slots: SlotsRecordOrArray, context?: Context) => void

Send slots to the bot.

Type declaration

▸ (slots, context?): void

Parameters
NameTypeDescription
slotsSlotsRecordOrArrayThe slots to populate
context?ContextContext for usage later in the intent.
Returns

void

Defined in

index.ts:465


sendChoice

sendChoice: (choiceId: string, context?: Context, metadata?: ChoiceRequestMetadata) => void

Respond to a choice from the bot.

Type declaration

▸ (choiceId, context?, metadata?): void

Parameters
NameTypeDescription
choiceIdstring-
context?ContextContext for usage later in the intent.
metadata?ChoiceRequestMetadatalinks the choice to the specific message and node in the conversation.
Returns

void

Defined in

index.ts:472


sendWelcomeIntent

sendWelcomeIntent: (context?: Context) => void

Trigger the welcome intent. This should be done when the user starts interacting with the chat.

Type declaration

▸ (context?): void

Parameters
NameTypeDescription
context?ContextContext for usage later in the intent.
Returns

void

Defined in

index.ts:482


sendIntent

sendIntent: (intentId: string, context?: Context) => void

Trigger a specific intent.

Type declaration

▸ (intentId, context?): void

Parameters
NameTypeDescription
intentIdstringthe intent to trigger. The id is the name under the Bot's Intents.
context?ContextContext for usage later in the intent.
Returns

void

Defined in

index.ts:489


sendStructured

sendStructured: (request: StructuredRequest, context?: Context) => void

Send a combination of choice, slots, and intent in one request.

Type declaration

▸ (request, context?): void

Parameters
NameTypeDescription
requestStructuredRequest
context?ContextContext for usage later in the intent.
Returns

void

Defined in

index.ts:496


subscribe

subscribe: (subscriber: Subscriber) => () => void

Subscribe a callback to the conversation. On subscribe, the subscriber will receive all of the Responses that the conversation has already received.

Type declaration

▸ (subscriber): () => void

Parameters
NameTypeDescription
subscriberSubscriberThe callback to subscribe
Returns

fn

▸ (): void

Returns

void

Defined in

index.ts:501


unsubscribe

unsubscribe: (subscriber: Subscriber) => void

Unsubscribe a callback from the conversation.

Type declaration

▸ (subscriber): void

Parameters
NameTypeDescription
subscriberSubscriberThe callback to unsubscribe
Returns

void

Defined in

index.ts:506


unsubscribeAll

unsubscribeAll: () => void

Unsubscribe all callback from the conversation.

Type declaration

▸ (): void

Returns

void

Defined in

index.ts:510


currentConversationId

currentConversationId: () => undefined | string

Get the current conversation ID if it's set, or undefined if there is no conversation.

Type declaration

▸ (): undefined | string

Returns

undefined | string

Defined in

index.ts:514


reset

reset: (options?: { clearResponses?: boolean }) => void

Forces a new conversation. If clearResponses is set to true, will also clear historical responses passed to subscribers. Retains all existing subscribers.

Type declaration

▸ (options?): void

Parameters
NameTypeDescription
options?Object-
options.clearResponses?booleanIf set to true, will clear historical responses passed to subscribers.
Returns

void

Defined in

index.ts:519


destroy

destroy: () => void

Removes all subscribers and, if using websockets, closes the connection.

Type declaration

▸ (): void

Returns

void

Defined in

index.ts:528

Interface: FailureMessage

A failure message is received when the NLX api is unreachable, or sends an unparsable response.

Properties

type

type: "failure"

The type of the response is "bot" for bot and "user" for user.

Defined in

index.ts:274


payload

payload: Object

The payload only includes an error message.

Type declaration
NameTypeDescription
textstringThe error message is either the default, or the failureMessage set in the Config.
Defined in

index.ts:278


receivedAt

receivedAt: number

When the failure occurred.

Defined in

index.ts:287

Interface: SlotValue

Values to fill an intent's attached slots.

An array of SlotValue objects is equivalent to a SlotsRecord.

Properties

slotId

slotId: string

The attached slot's name

Defined in

index.ts:24


value

value: any

Usually this will be a discrete value matching the slots's type. for custom slots, this can optionally be the value's ID.

Defined in

index.ts:29

Interface: StructuredRequest

The body of sendStructured Includes a combination of choice, slots, and intent in one request.

Properties

choiceId

Optional choiceId: string

The choiceId is in the BotResponse's .payload.messages[].choices[].choiceId fields

Defined in

index.ts:390


nodeId

Optional nodeId: string

Required if you want to change a choice that's already been sent. The nodeId can be found in the corresponding BotMessage.

Defined in

index.ts:395


intentId

Optional intentId: string

The intent to trigger. The intentId is the name under the Bot's Intents.

Defined in

index.ts:399


slots

Optional slots: SlotsRecordOrArray

The slots to populate

Defined in

index.ts:403

Interface: UserResponse

A message from the user

See also:

Properties

type

type: "user"

The type of the response is "bot" for bot and "user" for user, and "failure" for failure.

Defined in

index.ts:210


receivedAt

receivedAt: number

When the response was received

Defined in

index.ts:214


payload

payload: UserResponsePayload

The payload of the response

Defined in

index.ts:218