Skip to content

Latest commit

 

History

History
72 lines (48 loc) · 1.94 KB

README.md

File metadata and controls

72 lines (48 loc) · 1.94 KB

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

[email protected]

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;
  // ... 
});