Official React Native SDK for Stream Video
- Register to get an API key for Stream Video
- React Native Video Tutorial
- Sample application
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.
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.
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
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.
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:- Our shared JS Call Engine (
client
). - React Bindings (
react-bindings
). - React SDK (
react-sdk
).
- Our shared JS Call Engine (
-
The
sample-apps
folder contains the sample apps that are built using the packages from thepackages
folder. React Native's most relevant sample app is thedogfooding
app which is a complete app that implements most of the features of the SDK. -
The
react-native-sdk/docusaurus
folder contains the documentation and guides.
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.
- 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.
Stream's video roadmap and changelog are available here.
- Push notification- Android
- Chat integration guide
- Simulcasting- Android
- Push notification- VoIP iOS
- Reconnection
- Simulcasting- iOS
- Pinning and spotlighting participants
- Components parity, alignment and refactor
- Write docs:
- UI Components
- Tutorials
- Video Rooms Tutorial
- Audio Rooms Tutorial
- Livestream Tutorial
- Core
- Camera & Microphone
- Advanced
- Chat Integration
- Internationalization
- Push Notification (validate)
- UI Cookbook
- Call Controls
- Permission requests (native)
- Runtime layout switching
- Video Layout (refactor)
- ParticipantView customizations
- Expo Support
- Regular Push Notification for Vanilla React Native
- Ringing and Regular Push Notification for Expo
- Landscape Support
- Livestream components
- Screen-share media track support
- PiP on Android
- Speaking while muted
- Demo app on play-store and app-store
- Transcriptions
- Speaker management
- PiP on iOS
- Video filters
- CPU usage improvement
- Audio filters and Noise Cancellation
- Analytics Integration
- Long press to focus
- Dynascale 2.0
- Test coverage