nlx-chat-sdk v0.3.0
Chat SDK for NLX bots
This is our official JavaScript SDK to communicate with NLX conversational bots.
Getting started
import createConversation from "nlx-chat-sdk";
// Create some configuration
const testConfig = {
botUrl: "" // obtain from NLX deployments page
};
// Start the conversation
const convo = createConversation(testConfig);
// Subscribe to changes in the list of messages
convo.subscribe(messages => {
console.log(messages);
});
// Send a message from the user's end
convo.sendText("hello");
API reference
The package exports a single function called createConversation
, which is called with the bot configuration and returns a conversation handler object. This object has the following methods:
sendText: (text: string) => void
Send a simple text to your bot.
sendChoice: (choiceId: string) => void
Your bot may send a list of choices to choose from, each with a choiceText
and a choiceId
field. You can use choiceText
as button labels, and include the choiceId
in this method when sending responses.
sendSlots: (slots: Array<{ slotId: string; value: unknown }>) => void
Send slot values directly through custom widgets such as interactive maps.
subscribe: (subscriber: (messages: Message[], additional: { payload?: string }) => void) => void
Subscribe to the current state of messages whenever there is a change.
unsubscribe: (subscriber: (messages: Message[], additional: { payload?: string }) => void) => void
Remove a subscription.
unsubscribeAll: () => void
Remove all subscriptions.
reset: () => void
Reset the conversation. This makes sure that information previously collected by your bot will not affect the logic of the conversation any longer.
Usage with React
We provide a React example in TypeScript to illustrate how the project works in a modern web application framework. This implementation uses our useChat
hook which you can use to build your own chat widget:
import { useChat } from "nlx-chat-sdk/react-utils";
const ChatWidget = () => {
const chat = useChat({
botUrl: ""
});
return (
<div>
{chat.messages.map(/* render messages in the current conversation */)}
</div>
);
};
See full example.
The API of the hook is similar to the vanilla API. It leaves out subscribe and unsubscribe methods as they are used internally in effect hooks, making sure things are properly cleaned up. Instead, messages are readily available in the chat.messages
field, and we added state hooks for taking care of the value of the chat input field. You are free to not use these and manage things on your own.
Usage with *
Do you work with Vue? React without hooks? Custom elements? Elm? Let us know what framework you are looking to build web-based chat applications with so we can look into making utilities for those.
TypeScript
This SDK is written in TypeScript so you can use our type definitions in your project.
Widget
This package also exports a themeable widget build in React. Docs here.
Contributing
Issues and feature requests are always welcome.
License
MIT.
5 years ago
5 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago