Giter Club home page Giter Club logo

cache-firestore's Introduction

Cache FireStore with Proxy;

Install:

npm install cache-firestore valtio

Usage:

import {cacheFirestore} from 'cache-firestore';

let unsub;
unsub = cacheFirestore({
    query,
    proxy,
    unsub,
}, dependencies);

API:

{
    query: Firestore Query,
    store: Object or Proxy,
    proxy: Object or Proxy,
    listKey = 'list',
    idKey = 'id',
    idKeyOnData = false: `true` if `idKey` is on doc.data(),
    loadingKey = 'loading',
    errorKey = 'error',
    unsub: unsubscribe function,
    autoUnsub = true: `false` if you want to unsubscribe manually,
    devMode = false: `true` if you want to log the changes,
},
dependencies = [] | null | undefined: array of dependencies to trigger the query,

Example:

import {collection, query, where} from 'firebase/firestore';
import {cacheFirestore} from 'cache-firestore';
import {proxy} from 'valtio';
import {subscribeKey} from 'valtio/utils';

const projectListProxy = proxy({list: [], loading: false, error: null});

let unsub;
subscribeKey(stateProxy, 'user', (user) => {
    unsub = cacheFirestore({
        query: query(
            collection(db, 'projects'),
            where('uid', '==', uid),
        ),
        proxy: projectListProxy,
        unsub: unsub, //pass for autoUnsub
    }, [user?.uid]);
});

// use `unsub?.()` somewhere to unsubscribe manually
// `projectListProxy` will be updated automatically.

License:

MIT

Author:

ClassFunc Softwares JSC

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.