https://github.com/IjzerenHein/firestorter
Use Google Firestore in React with zero effort, using MobX ๐ค
https://github.com/IjzerenHein/firestorter
firestore-collection firestore-mobx firestore-models firestore-react firestoreter mox-firestore react-firestore
Last synced: 3 months ago
JSON representation
Use Google Firestore in React with zero effort, using MobX ๐ค
- Host: GitHub
- URL: https://github.com/IjzerenHein/firestorter
- Owner: IjzerenHein
- License: mit
- Created: 2017-11-02T14:49:27.000Z (over 7 years ago)
- Default Branch: main
- Last Pushed: 2023-12-30T15:42:50.000Z (about 1 year ago)
- Last Synced: 2024-11-12T16:11:55.278Z (3 months ago)
- Topics: firestore-collection, firestore-mobx, firestore-models, firestore-react, firestoreter, mox-firestore, react-firestore
- Language: TypeScript
- Homepage: http://firestorter.com
- Size: 10.2 MB
- Stars: 378
- Watchers: 15
- Forks: 50
- Open Issues: 23
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Funding: .github/FUNDING.yml
- License: LICENSE.txt
Awesome Lists containing this project
- awesome-firebase - Firestorter - ์ฌ์ด๋ ์ดํํธ ์์ด MobX๋ฅผ ์ด์ฉํ์ฌ React์์ Firestore๋ฅผ ์ฌ์ฉํ ์ ์๋ ๋ผ์ด๋ธ๋ฌ๋ฆฝ๋๋ค. (react-native์๋ ์ฌ์ฉ๊ฐ๋ฅ) (์น)
README
Firestorter
![]()
data:image/s3,"s3://crabby-images/a6bae/a6baeeb0e65e104ad1d4acea8c2d2aa532c532bd" alt="Build Status"
[data:image/s3,"s3://crabby-images/34eff/34eff7dc26d1b3572265eafa38cb4d33ffd5d10f" alt="codecov"](https://codecov.io/gh/IjzerenHein/firestorter)
[data:image/s3,"s3://crabby-images/cd905/cd905e0a2ca7bdcc1e24610cd29a025951ccf9ef" alt="MIT licensed"](https://raw.githubusercontent.com/IjzerenHein/firestorter/main/LICENSE.txt)
[data:image/s3,"s3://crabby-images/66d2a/66d2aa6f1e0afe66f640aa4ac2de0141d66555dc" alt="code style: prettier"](https://github.com/prettier/prettier)
[data:image/s3,"s3://crabby-images/7eb98/7eb98a78c003d631a14f0387ac79599d67d7dcaf" alt="Release Notes"](https://release-notes.com/@IjzerenHein/Firestorter)
[data:image/s3,"s3://crabby-images/446f0/446f07f8b36dc0a7e40fc4ecb3279fb45f0a126b" alt="Donate"](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=C7KAZKHW6MXYL)> Use Google Firestore in React with zero effort, using MobX ๐ค
* ๐ถ Simple, easy to use API, get up & running in minutes
* ๐ Fast, only fetches and re-renders data when needed
* ๐ค No clutter, no complex stores/providers/actions/reducers, just goThe latest version is compatible with the **Firebase v9 API**.
```sh
yarn add firestorter
```**1. Initialize**
```js
import { initializeApp } from 'firebase/app';
import { getFirestore } from 'firebase/firestore';
import { initFirestorter } from 'firestorter';
import makeWebContext from 'firestorter/web';// Initialize firebase app
const app = initializeApp({ ... });
const firestore = getFirestore(app);// Initialize `firestorter`
initFirestorter(makeWebContext({ firestore }));
```
> See here on how to use with [react-native](https://ijzerenhein.github.io/firestorter/#/./guides/Installation.md?id=usage-with-react-native), [compat mode](https://ijzerenhein.github.io/firestorter/#/./guides/Installation.md?id=usage-with-compat-mode) and [older firebase SDKs](https://ijzerenhein.github.io/firestorter/#/./guides/Installation.md?id=usage-with-older-javascript-sdks-lt-v8).**2. Create a `Collection` or `Document`**
```js
import { Collection, Document } from 'firestorter';const todos = new Collection('todos');
const user = new Document('users/8273872***');
```**3. Wrap your Components with mobx's `observer` pattern**
```jsx
import * as React from 'react';
import { observer } from 'mobx-react';const Todos = observer(() => {
return;
{todos.docs.map((doc) => (
))}
});const TodoItem = observer(({doc}) => {
const { finished, text } = doc.data;
return;
});
```**That's it.** Your Components will now render your firestore data
and re-render when data in the back-end changes.## How it works
Firestorter makes integrating Firestore real-time data into React easy as pie. It does this by providing a simple API for accessing Collection and Document data, whilst taking away the burden of managing snapshot listeners, data-caching and efficiently updating your React components.
It does this by intelligently tracking whether a Collection or Document should be listening for real-time updates (`onSnapshot` events) or not. Whenever a Component renders a Collection or Document, firestorter enables real-time updates on that resource. And whenever a Component stops using the resource _(e.g., component was unmounted)_, it stops listening for snapshot updates. This behavior really shines when multiple components are rendering collection/document data and it becomes more difficult to determine whether snapshot updates should be enabled or not.
## Features
- [Add, update & delete documents](https://ijzerenhein.github.io/firestorter/#/./guides/AddUpdateDelete.md)
- [Super efficient Component re-rendering](https://ijzerenhein.github.io/firestorter/#/./guides/FetchingData.md?id=automatic-fetching)
- [Declaratively link document/collection paths to document data](https://ijzerenhein.github.io/firestorter/#/./guides/SourcesPathsAndReferences.md?id=reactive-path-functions)
- [Geo query support](https://ijzerenhein.github.io/firestorter/#/./guides/GeoQueries.md)
- [Easily create aggregate collections from multiple queries](https://ijzerenhein.github.io/firestorter/#/./guides/AggregateCollections.md)
- [Runtime schema validation](https://ijzerenhein.github.io/firestorter/#/./guides/SchemaValidation.md) & [Type Generics](https://ijzerenhein.github.io/firestorter/#/./guides/Generics.md)
- [Manual fetching mode for use with Unit-tests/Async-functions](https://ijzerenhein.github.io/firestorter/#/./guides/FetchModes.md)
- [React-native support](https://ijzerenhein.github.io/firestorter/#/./guides/Installation.md?id=usage-with-react-native)
- [TypeScript- & Flow typings](https://ijzerenhein.github.io/firestorter/#/./guides/Generics.md)
- Works with Vue.jsWant to learn more, head over to [firestorter.com](http://firestorter.com) ๐ค