npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

manoshatzi-pubnub-react-chat-components

v0.7.6

Published

PubNub Chat Components is a development kit of React components that aims to help you to easily build Chat applications using PubNub infrastructure. It removes the complexicity of picking an adequate Chat engine, learning its APIs and dealing with its low

Downloads

8

Readme

PubNub Chat Components for React

PubNub Chat Components for React are the fastest way to add chat features like direct and group messaging, typing indicators, reactions, without going through the complexity of low-level architecture of realtime networks.

  • Reduced Implementation Time. Develop proof-of-concept and production ready apps faster using predefined components.
  • Fast and Simple Extensibility. Add rich features like typing indicators, read receipts, reactions etc. without writing complex code.
  • Flexible and Customizable Components. Customize component design and add custom components to extend functionality.
  • High Scalability. Let PubNub take care of scaling and reliability as you grow your app.
  • Easy Theming. Use the built-in light and dark themes or create custom ones for various use cases: group, support, and event chats.
  • Strong Typing. Utilize the power of TypeScript to develop your application.

PubNub Chat Components

Chat features

  • User and Channel Metadata: add additional information about the users, channels, and their memberships from PubNub Objects storage using custom hooks
  • Subscriptions: subscribe to user channels automatically
  • Messages: publish and display new and historical text messages
  • Presence: get currently active users, observe their state, and notify about changes
  • Typing Indicators: display notifications that users are typing
  • Message Reactions: publish and add emojis to messages

Requirements

Available components

Other documentation

Usage

Set up and use PubNub Chat Components for React to build your own chat application.

Set up PubNub account

  1. Sign in or create an account to create an app on the Admin Portal and get the keys to use in your application.

  2. When you create a new app, the first set of keys is generated automatically, but a single app can have as many keysets as you like. We recommend that you create separate keysets for production and test environments.

  3. Some of the functionalities you might want to enable on your keyset depending on the use-case include Presence, Files, Storage & Playback (including correct Retention Period) and Objects (be sure to select a geographical region corresponding to most users of your application and to enable User, Channel and Membership Events). The moderated-chat sample requires these features are set in order to work with the moderation dashboard.

Run Sample Apps

Start by exploring our Sample Apps that are built using chat components. Follow the steps below to run the apps locally in your own environment.

  1. Clone the repository.
git clone https://github.com/pubnub/react-chat-components.git
  1. Go to the samples folder.
cd react-chat-components/samples
  1. Install the dependencies.
npm install
  1. Follow steps from the PubNub Account section to create your own keys. Copy .env.example file as .env and paste your keys there.
cp .env.example .env
vi .env
  1. Pre-populate the User and Channel Object metadata (required only for the moderated-chat sample).
npm run setup
  1. Run the application.
npm start

Install and use components

  1. Install the components and all required dependencies using npm.
npm install --save pubnub pubnub-react @pubnub/react-chat-components
  1. Import PubNub, PubNub React Provider and the components.
import PubNub from "pubnub";
import { PubNubProvider } from "pubnub-react";
import {
  Chat,
  MessageList,
  MessageInput,
  ChannelList,
  MemberList,
} from "@pubnub/react-chat-components";
  1. Create your PubNub client and rest of the configuration for the Chat provider.
const pubnub = new PubNub({
  publishKey: "myPublishKey",
  subscribeKey: "mySubscribeKey",
  uuid: "myUniqueUUID",
});
const currentChannel = "myCurrentChannel";
const theme = "light";
  1. Feed the PubNub Provider with your newly created client as with other PubNub React applications.
const MyComponent = () => {
  return <PubNubProvider client={pubnub}></PubNubProvider>;
};
  1. Place the components within the Chat state provider in any order that your app requires. Components can be tweaked later on using option properties and CSS variables.
const MyComponent = () => {
  return (
    <PubNubProvider client={pubnub}>
      <Chat {...{ currentChannel, theme }}>
        <MessageList />
        <MessageInput />
      </Chat>
    </PubNubProvider>
  );
};