Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/zeshuaro/firestore_cache
A Flutter plugin for fetching Firestore documents with read from cache first then server.
https://github.com/zeshuaro/firestore_cache
dart firebase-firestore flutter flutter-package flutter-plugin
Last synced: 4 months ago
JSON representation
A Flutter plugin for fetching Firestore documents with read from cache first then server.
- Host: GitHub
- URL: https://github.com/zeshuaro/firestore_cache
- Owner: zeshuaro
- License: mit
- Created: 2020-05-03T01:55:25.000Z (almost 5 years ago)
- Default Branch: main
- Last Pushed: 2024-10-20T15:26:26.000Z (4 months ago)
- Last Synced: 2024-10-20T17:31:12.635Z (4 months ago)
- Topics: dart, firebase-firestore, flutter, flutter-package, flutter-plugin
- Language: Dart
- Homepage: https://pub.dev/packages/firestore_cache
- Size: 1.35 MB
- Stars: 33
- Watchers: 3
- Forks: 12
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
# Firestore Cache
[data:image/s3,"s3://crabby-images/74e1b/74e1b0b4b9ff228d54a116b18c90a1a695db6343" alt="pub package"](https://pub.dartlang.org/packages/firestore_cache)
[data:image/s3,"s3://crabby-images/afad3/afad38562de2c63a29fd1cc72b0ef4afde270cbe" alt="docs"](https://pub.dev/documentation/firestore_cache/latest/)
[data:image/s3,"s3://crabby-images/0e52c/0e52c404f1bafca2cf5ce53f3d19e2c182e3b7aa" alt="MIT License"](https://github.com/zeshuaro/firestore_cache/blob/master/LICENSE)
[data:image/s3,"s3://crabby-images/b1245/b1245f71142f52c8d293e919643cba3667a838f9" alt="GitHub Actions"](https://github.com/zeshuaro/firestore_cache/actions/workflows/github-actions.yml)
[data:image/s3,"s3://crabby-images/8e802/8e802a127ec1c0487275025d624b80f85ee938e1" alt="codecov"](https://codecov.io/gh/zeshuaro/firestore_cache)
[data:image/s3,"s3://crabby-images/c715b/c715b88b2ea3ace44c0eb5506f5f64ebc0c8295c" alt="Codacy Badge"](https://app.codacy.com/gh/zeshuaro/firestore_cache/dashboard?utm_source=gh&utm_medium=referral&utm_content=&utm_campaign=Badge_grade)
[data:image/s3,"s3://crabby-images/07941/07941b9919ab42406ce00746a5dbf28fdf3e7992" alt="style: flutter_lints"](https://pub.dev/packages/flutter_lints)[data:image/s3,"s3://crabby-images/ef50f/ef50fdeeaad546304070eac8fb4d96b02422e29f" alt="Github-sponsors"](https://github.com/sponsors/zeshuaro)
[data:image/s3,"s3://crabby-images/df527/df527595e72f139e11165b1bd69d5c57309b9238" alt="BuyMeACoffee"](https://www.buymeacoffee.com/zeshuaro)
[data:image/s3,"s3://crabby-images/ebf76/ebf76a2612960092db331a59728a424d8f819fed" alt="Ko-Fi"](https://ko-fi.com/zeshuaro)
[data:image/s3,"s3://crabby-images/330f2/330f2689beeb67afcb3c2ae3ccba51ab842fe0d1" alt="LiberaPay"](https://liberapay.com/zeshuaro/)
[data:image/s3,"s3://crabby-images/355b4/355b4486103cc1a0f63d825cd503cf6b2d894e78" alt="Patreon"](https://patreon.com/zeshuaro)
[data:image/s3,"s3://crabby-images/e8097/e809741ad9b3c761cf89ed1e82108ec708f2cdd1" alt="PayPal"](https://paypal.me/JoshuaTang)A Flutter plugin for fetching Firestore documents with read from cache first then server.
This plugin is mainly designed for applications using the `DocumentReference.get()` and `Query.get()` methods in the `cloud_firestore` plugin, and is implemented with read from cache first then server.
## Getting Started
Add this to your package's `pubspec.yaml` file:
```yaml
dependencies:
firestore_cache: ^2.14.9
```### Usage
Before using the plugin, you will need to create a document on Firestore and create a timestamp field in that document. See the screenshot below for an example:
data:image/s3,"s3://crabby-images/9a5ed/9a5ed9342732498c5552772a4c60d5f2d974ef47" alt="Firestore Screenshot"
__⚠️ PLEASE NOTE__ This plugin does not compare the documents in the cache and the ones in the server to determine if it should fetch data from the server. Instead, it relies on the timestamp field in the document to make that decision. And so your application should implement the logic to update this field if you want to read new data from the server instead of reading it from the cache.
You should also create different timestamp fields for different collections or documents that you are fetching.
```dart
import 'package:cloud_firestore/cloud_firestore.dart';
import 'package:firestore_cache/firestore_cache.dart';// This should be the path of the document containing the timestampe field
// that you created
final cacheDocRef = Firestore.instance.doc('status/status');// This should be the timestamp field in that document
final cacheField = 'updatedAt';final query = Firestore.instance.collection('posts');
final snapshot = await FirestoreCache.getDocuments(
query: query,
cacheDocRef: cacheDocRef,
firestoreCacheField: cacheField,
);
```