Skip to content

This opensource project is the local data request proxy. Written by TypeScript, is used to implement offline browsing of the app. The data proxy will be responsible for data request, creation, destruction and expiration detection. We only need to define the data model and leave the rest to the proxy!

License

Notifications You must be signed in to change notification settings

bobbylkchao/bison-local-data-offline-proxy

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

34 Commits
 
 
 
 
 
 
 
 

Repository files navigation

bison-local-data-offline-proxy

This opensource project is the local data request proxy.

Written by TypeScript, is used to implement offline browsing of the app.

The data proxy will be responsible for data request, creation, destruction and expiration detection.

We only need to define the data model and leave the rest to the proxy! Even without network!

>>> Currently based on Expo <<<

Author

Bobby Chao

bobbylkchao@gmail.com

https://www.linkedin.com/in/bobbylkchao/

Integration diagram

ScreenShot

How it works?

ScreenShot

Install Steps

  1. git clone https://github.com/bobbylkchao/bison-local-data-offline-proxy.git
  2. cd bison-local-data-offline-proxy/src
  3. npm i
  4. Configure the data model in model.config.js
  5. In your code, use import { proxyGetFullData, proxyGetIncrementalData, proxyGetMoreData, proxyCheckDataExpired } from "proxy"

Core methods introduction

proxyGetFullData(): Get full data

proxyGetIncrementalData()(): Get incremental data

proxyGetMoreData(): Get more data

proxyCheckDataExpired(): Check data expired status

How to use core methods?

Please read interface interfaces.ts, there are code comments on the interface.

Usage Example

const checkLocalDataExpiredStatus = await proxyCheckDataExpired('weatherandrating');
let paramByPass;
if(checkLocalDataExpiredStatus){
  // Local data has expired
  paramByPass = true;
}else{
  // Local data has not expired
  paramByPass = false;
}

proxyGetFullData({
  tableName: 'weatherandrating',
  bypass: paramByPass,
}, (r:any) => {
  const response = r.message;
  const exchangeRate = response.message.exchange;
  const weather = response.message.weather;
  // ... 
});

About

This opensource project is the local data request proxy. Written by TypeScript, is used to implement offline browsing of the app. The data proxy will be responsible for data request, creation, destruction and expiration detection. We only need to define the data model and leave the rest to the proxy!

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published