chatkitty-js
ChatKitty helps you build real-time chat without any back-end.
data:image/s3,"s3://crabby-images/6faa9/6faa9794a4f2b18f7245f7ed120acd7f42dbacc6" alt="Realtime Chat Demo"
The example above was created with ChatKitty. Check it out at demo.chatkitty.com.
data:image/s3,"s3://crabby-images/efc2c/efc2c677c6db4ac6b95f677e688408819cdefa22" alt="NPM Package"
data:image/s3,"s3://crabby-images/28ac2/28ac2095174d3a457b48ca71d40af7e87d21f1e0" alt="Build Status"
Features
-
Private chat - Provide secure and encrypted direct messaging to your users.
-
Group chat - Your users can request to join or be invited to group chats.
-
Message threads - Keep conversations organized with message threads.
-
Push notifications - Make sure your users always see their messages.
-
File attachments - Attach images, videos, or any other type of files.
-
Typing indicators - Let your users know when others are typing.
-
Reactions - Users can react to messages with emojis and GIFs.
-
Presence indicators - Let your users know who's online.
-
Delivery and read receipts - See when messages get delivered and read.
-
Link preview generation - Messages with links get rich media previews.
ChatKitty is the first complete chat platform; bringing together everything that's
required to build real-time chat into Web and mobile apps. Getting started with ChatKitty
is easy and you get:
Reliability
Your user chat sessions remain stable even in the presence of proxies, load balancers and personal
firewalls. ChatKitty provides auto reconnection support and offline notifications so your users stay
in the loop.
Low Latency
With response times below 100ms, ChatKitty makes sure your users have a smooth and immersive chat
experience.
Cross-platform support
You can use ChatKitty across every major browser and device platform. ChatKitty also works great
with multi-platform frameworks like React-Native and Ionic.
Simple and convenient API
Sample code:
let kitty = ChatKitty.getInstance(CHATKITTY_API_KEY);
useEffect(() => {
let result = kitty.startChatSession({
channel: channel,
onReceivedMessage: (message) => {
showMessage(message);
},
});
return result.session.end;
}, []);
We've spent a lot of time thinking of the right abstractions and implementing our API to be straightforward
and easy to use - making you more productive.
Installation
Install with NPM
npm install chatkitty
Install with Yarn
yarn add chatkitty
How to use
Getting an API key
You'll need a free ChatKitty account before you can
begin building chat with ChatKitty. After creating your account, create a ChatKitty application using the dashboard
and copy its API key from your application's setting page.
Initialize the SDK with your API key
With your API key you can initialize a new instance of the ChatKitty JS client:
let kitty = ChatKitty.getInstance(CHATKITTY_API_KEY);
Starting a user session
To make calls to ChatKitty as a user, a user session must be started.
You can start a user session using the unique username of a user and optional authentication
parameters to secure the user session.
await kitty.startSession({
username: email,
});
Starting a chat session
Before a user can begin sending and receiving real-time messages and use in-app chat features like
typing indicators, delivery and read receipts, emoji and like reactions, etc, you'll need to start a chat session.
kitty.startChatSession({
channel: channel,
onReceivedMessage: (message) => {
},
});
API Documentation
Please see the documentation for this SDK at the ChatKitty Website.
The source code of the website can be found here. Contributions are welcome!
A complete SDK reference document is hosted at https://chatkitty.github.io/chatkitty-js/
Questions? Need Help? Found a bug?
If you've got questions about setup, usage, special feature implementation in your chat app, or just want to chat with a
ChatKitty dev, please feel free to start a thread in our Discussions tab!
Found a bug with ChatKitty? Go ahead and submit an issue.
And, of course, feel free to submit pull requests with bug fixes or changes.
Contributing
We welcome code changes that improve this library or fix a problem, please make sure to follow all best practices
and add tests if applicable before submitting a Pull Request. We are very happy to merge your code.
License
Distributed under the MIT License. See LICENSE
for more information.
Acknowledgements