Skip to content

A localStorage-like wrapper around React Native's AsyncStorage with cache expiration.

Notifications You must be signed in to change notification settings

FatalTouch/react-native-cache-store

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

9 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

React Native Cache Store npm version

A localStorage-like wrapper around React Native's AsyncStorage with cache expiration.

100% inspired by @pamelafox's lscache. Currently being used by my project, hackerweb-ios.

WARNING: The test coverage is not very high 😅

Installation

npm i --save react-native-cache-store

API Reference

  • set(key, value, [time]) - Stores the value. Expires after specified number of seconds.

    1. key (string)
    2. value (Object | string)
    3. time (number: optional)
  • get(key) - Retrieves specified value, if not expired.

    1. key (string)
  • remove(key) - Removes a value.

    1. key (string)
  • isExpired(key) - Checks if a value has expired.

    1. key (string)
  • flush() - Removes all items.

  • flushExpired() - Removes all expired items. This method runs every time this code is initalized.

Example Usage

import CacheStore from 'react-native-cache-store';

CacheStore.set('key', 'value', 10); // Expires in 10 seconds

CacheStore.get('key').then((value) => {
  // Do something with value
});

CacheStore.isExpired('key')
  .then(() => {/* true */ })
  .catch(() => {/* false */})

Contribute

Of course, contributions welcomed! 🙌

License

MIT.

About

A localStorage-like wrapper around React Native's AsyncStorage with cache expiration.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 100.0%