Company
Date Published
May 24, 2023
Author
Stephen Kiss
Word count
4569
Language
English
Hacker News points
None

Summary

In this tutorial, we will build a real-time chat application using Ably's realtime messaging capabilities and OpenAI's text generation API. The app will allow users to send messages in real-time and receive responses from OpenAI. We will use Next.js as our frontend framework and Vercel for serverless deployment. To start, you need to have Node.js installed on your machine. You can download it from the official website: https://nodejs.org/en/download/. Once you have Node.js installed, create a new directory for your project and navigate into it using the terminal or command prompt. Then run the following commands to initialize a new Next.js app: ```bash npx create-next-app ably-chat-app cd ably-chat-app ``` This will create a new directory called "ably-chat-app" and install all necessary dependencies for Next.js. Next, we need to install Ably's JavaScript SDK and the OpenAI API client library: ```bash npm install ably @ably/react react-helmet next-compose-styles npm install openai ``` AblyReactEffect is a custom React Hook that encapsulates Ably pub/sub for React functional components in one place. It returns both the current Ably channel and the Ably SDK for the calling code to use to send messages. This hook encapsulates Ably pub/sub for React functional components in one place, so we don't need to worry about it elsewhere, and the code that uses it can just process the messages it receives. The useChannel Hook returns both the current Ably channel and the Ably SDK for the calling code to use to send messages. This hook encapsulates Ably pub/sub for React functional components in one place, so we don't need to worry about it elsewhere, and the code that uses it can just process the messages it receives. Making everything look beautiful with module CSS - AblyChatComponent.module.css You might have noticed when writing the chat component that Next.js has some compiler enforced conventions that dictate where you keep your CSS and how to import it. For this app, we will create a CSS file with the same name as the .jsx file, just with the extensions .module.css. We do this to keep management of the components easier, if in the future we want to delete this component it is nice and simple to also remove its CSS. Once created, it can be imported into the component: import styles from './AblyChatComponent.module.css'; When creating a CSS class on a JSX element, we use the following syntax on the element: className={styles.yourClassName} and the accompanying css would look like this: .yourClassName { styles: gohere; } This app is built with CSS Grid to create the app layout, you are of course welcome to use the CSS provided with this project or to write your own or use a framework. Hosting on Vercel We're using Vercel as our development server and build pipeline. The easiest way to deploy Next.js to production is to use the Vercel platform from the creators of Next.js. Vercel is an all-in-one platform with Global CDN supporting static & Jamstack deployment and Serverless Functions. -- The Next.js documentation In order to deploy your new chat app to Vercel you'll need to: Create a GitHub account (if you don't already have one). Push your app to a GitHub repository. Create a Vercel account. Create a new Vercel app and import your app from your GitHub repository. (This will require you to authorise Vercel to use your GitHub account) Add your ABLY_API_KEY and OPENAI_API_KEY as environment variables. Watch your app deploy. Visit the newly created URL in your browser! WebSockets in Vercel with AblyWhy AblyWhat are we going to build?How to prompt OpenAI?DependenciesLocal dev pre-requirementsBuilding the realtime chat appRealtime Pub/Sub messaging with AblyAuthentication with the Ably serviceWriting the Serverless function to connect query OpenAIThe realtime chat app architectureBuilding the componentsWriting the chat component logicUse a Vercel Lambda to query OpenAIUsing Ably correctly in React ComponentsMaking everything look beautiful with module CSS - AblyChatComponent.module.cssHosting on Vercel