Official React Native SDK for Stream Video

Quick Links
What is Stream?
Stream allows developers to rapidly deploy scalable feeds, chat messaging and video with an industry leading 99.999% uptime SLA guarantee.
With Stream's video components, you can use their SDK to build in-app video calling, audio rooms, audio calls, or live streaming. The best place to get started is with their tutorials:
Stream provides UI components and state handling that make it easy to build video calling for your app. All calls run on Stream's network of edge servers around the world, ensuring optimal latency and reliability.
👩💻 Free for Makers 👨💻
Stream is free for most side and hobby projects. To qualify, your project/company needs to have < 5 team members and < $10k in monthly revenue. Makers get $100 in monthly credit for video for free.
💡 Supported Features 💡
Here are some of the features we support:
- Developer experience: Great SDKs, docs, tutorials and support so you can build quickly
- Edge network: Servers around the world ensure optimal latency and reliability
- Chat: Stored chat, reactions, threads, typing indicators, URL previews etc
- Security & Privacy: Based in USA and EU, Soc2 certified, GDPR compliant
- Dynascale: Automatically switch resolutions, fps, bitrate, codecs and paginate video on large calls
- Screen sharing (To be implemented)
- Picture-in-picture support (To be implemented)
- Active speaker
- Custom events
- Geofencing
- Notifications and ringing calls
- Opus DTX & Red for reliable audio
- Webhooks & SQS
- Backstage mode
- Flexible permissions system
- Joining calls by ID, link or invite
- Enabling and disabling audio and video when in calls
- Flipping, Enabling and disabling camera in calls
- Enabling and disabling speakerphone in calls
- Push notification providers support
- Call recording (To be implemented)
- Broadcasting to HLS
Repo Overview 😎
This repo contains projects and samples developed by the team and Stream community.
Projects are broken up into directories containing the source code for each project.
Projects/Packages 🚀
The React Native SDK is a part of the Stream Video JS monorepo.
The monorepo consists of multiple folders, the most important of which are packages
and sample-apps
.
-
The packages
folder contains the packages each of which is a separate npm package. The React Native SDK is one of the packages alongside:
-
The sample-apps
folder contains the sample apps that are built using the packages from the packages
folder.
React Native's most relevant sample app is the dogfooding
app which is a complete app that implements most of the features of the SDK.
-
The docs-content
repo contains the documentation and guides.
Requirements 🛠
Before running this project please ensure you have set up your development environment for React Native.
The Stream Video React Native SDK supports apps created with the React Native CLI.
Contributing 🤝
- How can I submit a sample app?
- Apps submissions are always welcomed 🥳 Open a pr with a proper description and we'll review it as soon as possible
- Spot a bug 🕷 ?
- We welcome code changes that improve the apps or fix a problem. Please make sure to follow all best practices and add tests if applicable before submitting a Pull Request on Github.
Roadmap
Stream's video roadmap and changelog are available here.
0.1, 0.2 and 0.3 milestone
0.4 Milestones
Milestones