Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/prescottprue/react-redux-firebase
Redux bindings for Firebase. Includes React Hooks and Higher Order Components.
https://github.com/prescottprue/react-redux-firebase
firebase react react-bindings redux redux-bindings redux-firebase redux-observable redux-thunk
Last synced: 5 days ago
JSON representation
Redux bindings for Firebase. Includes React Hooks and Higher Order Components.
- Host: GitHub
- URL: https://github.com/prescottprue/react-redux-firebase
- Owner: prescottprue
- License: mit
- Created: 2016-10-14T00:47:53.000Z (about 8 years ago)
- Default Branch: main
- Last Pushed: 2024-11-18T21:44:41.000Z (about 2 months ago)
- Last Synced: 2025-01-02T03:12:30.731Z (10 days ago)
- Topics: firebase, react, react-bindings, redux, redux-bindings, redux-firebase, redux-observable, redux-thunk
- Language: JavaScript
- Homepage: https://react-redux-firebase.com
- Size: 23.9 MB
- Stars: 2,551
- Watchers: 40
- Forks: 554
- Open Issues: 135
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: .github/CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- License: LICENSE.md
- Code of conduct: CODE_OF_CONDUCT.md
- Roadmap: docs/roadmap.md
Awesome Lists containing this project
- Flutter-Guide - React Redux Firebase
- Android-Guide - React Redux Firebase
- awesome-firebase - React Redux Firebase - Firebase를 위한 Redux 바인딩 라이브러리입니다. React와 함께 사용하기위한 Higher Order Component (HOC)를 제공합니다. (웹)
README
# react-redux-firebase
[![NPM version][npm-image]][npm-url]
[![NPM downloads][npm-downloads-image]][npm-url]
[![Quality][quality-image]][quality-url]
[![Code Coverage][coverage-image]][coverage-url]
[![Code Style][code-style-image]][code-style-url]
[![License][license-image]][license-url]
[![Build Status][build-status-image]][build-status-url][![Gitter][gitter-image]][gitter-url]
> Redux bindings for Firebase. Includes Higher Order Component (HOC) for use with React.
## Usage Note
If you are starting a new project and/or are not required to have your Firebase data loaded into redux, you might want to give [reactfire](https://github.com/FirebaseExtended/reactfire) a try before trying react-redux-firebase. I wrote up [a quick medium article](http://bit.ly/3d2XPsS) explaining a bit about how, why, and showing how to start a new project with these tools.
## [Simple Example](https://codesandbox.io/s/zrr0n5m2zp)
[![Edit Simple Example](https://codesandbox.io/static/img/play-codesandbox.svg)](https://codesandbox.io/s/zrr0n5m2zp)
The [Material Example](https://github.com/prescottprue/react-redux-firebase/tree/master/examples/complete/material) is deployed to [demo.react-redux-firebase.com](https://demo.react-redux-firebase.com).
## Features
- Out of the box support for authentication (with auto loading user profile from database/firestore)
- Full Firebase Platform Support Including Real Time Database, Firestore, and Storage
- Automatic binding/unbinding of listeners through React Hooks (`useFirebaseConnect`, `useFirestoreConnect`) or Higher Order Components (`firebaseConnect` and `firestoreConnect`)
- [Population capability](http://react-redux-firebase.com/docs/populate) (similar to mongoose's `populate` or SQL's `JOIN`)
- Support small data ( using `value` ) or large datasets ( using `child_added`, `child_removed`, `child_changed` )
- Multiple queries types supported including `orderByChild`, `orderByKey`, `orderByValue`, `orderByPriority`, `limitToLast`, `limitToFirst`, `startAt`, `endAt`, `equalTo`
- Tons of examples of integrations including [`redux-thunk`](https://github.com/gaearon/redux-thunk) and [`redux-observable`](https://redux-observable.js.org/)
- Server Side Rendering Support
- [`react-native` support](http://react-redux-firebase.com/docs/integrations/react-native.html) using [native modules](http://react-redux-firebase.com/docs/integrations/react-native.html#native-modules) or [web sdk](http://react-redux-firebase.com/docs/integrations/react-native.html#jsweb)## Installation
```bash
npm install --save react-redux-firebase
```This assumes you are using [npm](https://www.npmjs.com/) as your package manager.
If you're not, you can access the library on [unpkg](https://unpkg.com/redux-firestore@latest/dist/redux-firestore.min.js), download it, or point your package manager to it. Theres more on this in the [Builds section below](#builds).
### Older Versions
Interested in support for versions of [`react-redux`](https://github.com/reduxjs/react-redux) before v6 or the [new react context API](https://reactjs.org/docs/context.html)? Checkout [the `v2.*.*` versions](https://github.com/prescottprue/react-redux-firebase/tree/v2) (installed through `npm i --save react-redux-firebase^@2.5.0`).
## Use
Include `firebaseReducer` (reducer) while creating your redux store then pass dispatch and your firebase instance to `ReactReduxFirebaseProvider` (context provider):
```javascript
import React from 'react'
import { render } from 'react-dom'
import { Provider } from 'react-redux'
import firebase from 'firebase/app'
import 'firebase/database'
import 'firebase/auth'
// import 'firebase/firestore' // <- needed if using firestore
// import 'firebase/functions' // <- needed if using httpsCallable
import { createStore, combineReducers, compose } from 'redux'
import {
ReactReduxFirebaseProvider,
firebaseReducer
} from 'react-redux-firebase'
// import { createFirestoreInstance, firestoreReducer } from 'redux-firestore' // <- needed if using firestoreconst fbConfig = {}
// react-redux-firebase config
const rrfConfig = {
userProfile: 'users'
// useFirestoreForProfile: true // Firestore for Profile instead of Realtime DB
}// Initialize firebase instance
firebase.initializeApp(fbConfig)// Initialize other services on firebase instance
// firebase.firestore() // <- needed if using firestore
// firebase.functions() // <- needed if using httpsCallable// Add firebase to reducers
const rootReducer = combineReducers({
firebase: firebaseReducer
// firestore: firestoreReducer // <- needed if using firestore
})// Create store with reducers and initial state
const initialState = {}
const store = createStore(rootReducer, initialState)const rrfProps = {
firebase,
config: rrfConfig,
dispatch: store.dispatch
// createFirestoreInstance // <- needed if using firestore
}// Setup react-redux so that connect HOC can be used
function App() {
return (
)
}render(, document.getElementById('root'))
```The Firebase instance can then be grabbed from context within your components (`withFirebase` and `firebaseConnect` Higher Order Components provided to help):
**Add Data**
```jsx
import React from 'react'
import { useFirebase } from 'react-redux-firebase'export default function Todos() {
const firebase = useFirebase()function addSampleTodo() {
const sampleTodo = { text: 'Sample', done: false }
return firebase.push('todos', sampleTodo)
}return (
New Sample Todo
Add
)
}
```**Load Data (listeners automatically managed on mount/unmount)**
```jsx
import React from 'react'
import PropTypes from 'prop-types'
import { useSelector } from 'react-redux'
import { useFirebaseConnect, isLoaded, isEmpty } from 'react-redux-firebase'export default function Todos() {
useFirebaseConnect([
'todos' // { path: '/todos' } // object notation
])const todos = useSelector((state) => state.firebase.ordered.todos)
if (!isLoaded(todos)) {
returnLoading...
}if (isEmpty(todos)) {
returnTodos List Is Empty
}return (
{Object.keys(todos).map((key, id) => (
))}
)
}
```**Queries Based On Route Params**
It is common to make a detail page that loads a single item instead of a whole list of items. A query for a specific `Todos` can be created using
```jsx
import React from 'react'
import PropTypes from 'prop-types'
import { get } from 'lodash'
import { useSelector } from 'react-redux'
import { useFirebaseConnect, useFirebase } from 'react-redux-firebase'
import { useParams } from 'react-router-dom'export default function Todo() {
const { todoId } = useParams() // matches todos/:todoId in route
const firebase = useFirebase()useFirebaseConnect([
{ path: `todos/${todoId}` } // create todo listener
// `todos/${todoId}` // equivalent string notation
])const todo = useSelector(
({ firebase: { data } }) => data.todos && data.todos[todoId]
)function updateTodo() {
return firebase.update(`todos/${params.todoId}`, { done: !todo.isDone })
}return (
{todo.label}
)
}
```**Load Data On Click**
```jsx
import React from 'react'
import { useSelector } from 'react-redux'
import { useFirebase, isLoaded, isEmpty } from 'react-redux-firebase'function TodosList() {
const todos = useSelector((state) => state.firebase.ordered.todos)if (!isLoaded(todos)) {
returnLoading...
}if (isEmpty(todos)) {
returnTodos List Is Empty
}return (
{Object.keys(todos).map((key, id) => (
))}
)
}
export default function Todos() {
const firebase = useFirebase()
return (
Todos
firebase.watchEvent('value', 'todos')}>
Load Todos
)
}
```
## Firestore
If you plan to use Firestore, you should checkout [`redux-firestore`][redux-firestore]. It integrates nicely with `react-redux-firebase` and it allows you to run Real Time Database and Firestore along side each other.
`react-redux-firebase` provides the `firestoreConnect` HOC (similar to `firebaseConnect`) for easy setting/unsetting of listeners.
Currently `react-redux-firebase` still handles auth when using [`redux-firestore`][redux-firestore] - The future plan is to also have auth standalone auth library that will allow the developer to choose which pieces they do/do not want.
## [Docs](http://react-redux-firebase.com)
See full documentation at [react-redux-firebase.com](http://react-redux-firebase.com)
- [Getting Started](http://react-redux-firebase.com/docs/getting_started)
- [Auth](http://react-redux-firebase.com/docs/auth)
- [Queries](http://react-redux-firebase.com/docs/queries)
- [Firestore](http://react-redux-firebase.com/docs/firestore)
- [Populate](http://react-redux-firebase.com/docs/populate)
- [API Reference](http://react-redux-firebase.com/docs/api)
## [Examples](examples)
### [Examples Folder](examples)
Examples folder is broken into two categories [snippets](examples/snippets) and [complete](examples/complete). `/complete` contains full applications that can be run as is, where as `/snippets` contains small amounts of code to highlight specific functionality (dev tools and deps not included).
#### [State Based Query Snippet](examples/snippets/stateBasedQuery)
Snippet showing querying based on data in redux state. One of the more common examples is querying based on the current users auth UID.
#### [Decorators Snippet](examples/snippets/decorators)
Snippet showing how to use decorators to simplify connect functions (redux's `connect` and react-redux-firebase's `firebaseConnect`)
#### [Simple App Example](examples/complete/simple)
A simple example that was created using [create-react-app](https://github.com/facebookincubator/create-react-app)'s. Shows a list of todo items and allows you to add to them.
#### [Material App Example](examples/complete/material)
An example that user Material UI built on top of the output of [create-react-app](https://github.com/facebookincubator/create-react-app)'s eject command. Shows a list of todo items and allows you to add to them. This is what is deployed to [redux-firebasev3.firebaseapp.com](https://redux-firebasev3.firebaseapp.com/).
## Discussion
Join us on the [redux-firebase gitter](https://gitter.im/redux-firebase/Lobby).
## Integrations
View docs for recipes on integrations with:
- [redux-firestore](http://react-redux-firebase.com/docs/firestore.html)
- [redux-thunk](http://react-redux-firebase.com/docs/integrations/thunks.html)
- [reselect](http://react-redux-firebase.com/docs/integrations/integrations/reselect.html)
- [redux-observable](http://react-redux-firebase.com/docs/integrations/redux-observable.html)
- [redux-saga](http://react-redux-firebase.com/docs/integrations/redux-saga.html)
- [redux-form](http://react-redux-firebase.com/docs/integrations/redux-form.html)
- [redux-auth-wrapper](http://react-redux-firebase.com/docs/recipes/routing.html#advanced)
- [redux-persist](http://react-redux-firebase.com/docs/integrations/redux-persist.html)
- [react-native](http://react-redux-firebase.com/docs/integrations/react-native.html)
- [react-native-firebase](http://react-redux-firebase.com/docs/integrations/react-native.html#native-modules)
## Starting A Project
### Generator
[generator-react-firebase](https://github.com/prescottprue/generator-react-firebase) is a yeoman generator uses react-redux-firebase when opting to include redux.
### CRA Template
[cra-template-rrf](https://github.com/prescottprue/cra-template-rrf) is a create-react-app template with react-redux-firebase included
### Complete Examples
The [examples folder](/examples) contains full applications that can be copied/adapted and used as a new project.
## FAQ
Please visit the [FAQ section of the docs](http://docs.react-redux-firebase.com/history/v2.0.0/docs/FAQ.html)
## Builds
Most commonly people consume Redux Firestore as a [CommonJS module](http://webpack.github.io/docs/commonjs.html). This module is what you get when you import redux in a Webpack, Browserify, or a Node environment.
If you don't use a module bundler, it's also fine. The redux-firestore npm package includes precompiled production and development [UMD builds](https://github.com/umdjs/umd) in the [dist folder](https://unpkg.com/redux-firestore@latest/dist/). They can be used directly without a bundler and are thus compatible with many popular JavaScript module loaders and environments. For example, you can drop a UMD build as a `` tag on the page. The UMD builds make Redux Firestore available as a `window.ReactReduxFirebase` global variable.
It can be imported like so:
```html
<script src="../node_modules/react-redux-firebase/dist/react-redux-firebase.min.js">
console.log('react redux firebase:', window.ReactReduxFirebase)
```
Note: In an effort to keep things simple, the wording from this explanation was modeled after [the installation section of the Redux Docs](https://redux.js.org/#installation).
## Contributors
This project exists thanks to all the people who contribute.
[npm-image]: https://img.shields.io/npm/v/react-redux-firebase.svg?style=flat-square
[npm-url]: https://npmjs.org/package/react-redux-firebase
[npm-downloads-image]: https://img.shields.io/npm/dm/react-redux-firebase.svg?style=flat-square
[quality-image]: http://npm.packagequality.com/shield/react-redux-firebase.svg?style=flat-square
[quality-url]: https://packagequality.com/#?package=react-redux-firebase
[backers]: https://opencollective.com/react-redux-firebase/backers/badge.svg?style=flat-square&color=blue
[become-a-backer]: https://opencollective.com/react-redux-firebase#backer
[build-status-image]: https://img.shields.io/github/workflow/status/prescottprue/react-redux-firebase/NPM%20Package%20Publish?style=flat-square
[build-status-url]: https://github.com/prescottprue/react-redux-firebase/actions
[climate-image]: https://img.shields.io/codeclimate/github/prescottprue/react-redux-firebase.svg?style=flat-square
[climate-url]: https://codeclimate.com/github/prescottprue/react-redux-firebase
[coverage-image]: https://img.shields.io/codecov/c/github/prescottprue/react-redux-firebase.svg?style=flat-square
[coverage-url]: https://codecov.io/gh/prescottprue/react-redux-firebase
[license-image]: https://img.shields.io/npm/l/react-redux-firebase.svg?style=flat-square
[license-url]: https://github.com/prescottprue/react-redux-firebase/blob/master/LICENSE
[code-style-image]: https://img.shields.io/badge/code%20style-standard-brightgreen.svg?style=flat-square
[code-style-url]: http://standardjs.com/
[gitter-image]: https://img.shields.io/gitter/room/redux-firebase/gitter.svg?style=flat-square
[gitter-url]: https://gitter.im/redux-firebase/Lobby
[redux-firestore]: https://github.com/prescottprue/redux-firestore