Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/YerkoPalma/choo-offline
:wrench: offline first support for choo apps
https://github.com/YerkoPalma/choo-offline
choo offline
Last synced: 4 months ago
JSON representation
:wrench: offline first support for choo apps
- Host: GitHub
- URL: https://github.com/YerkoPalma/choo-offline
- Owner: YerkoPalma
- License: mit
- Created: 2016-08-26T14:44:40.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2019-05-12T11:00:52.000Z (almost 6 years ago)
- Last Synced: 2024-04-14T05:32:03.031Z (10 months ago)
- Topics: choo, offline
- Language: JavaScript
- Homepage: https://www.npmjs.com/package/choo-offline
- Size: 57.6 KB
- Stars: 13
- Watchers: 2
- Forks: 1
- Open Issues: 25
-
Metadata Files:
- Readme: readme.md
- License: license
Awesome Lists containing this project
README
# choo-offline [data:image/s3,"s3://crabby-images/c6e35/c6e35d07006e9b861f27e03d9bda5b7884eb8e93" alt="Build Status"](https://travis-ci.org/YerkoPalma/choo-offline) [data:image/s3,"s3://crabby-images/2dc60/2dc60f52e435836097a37b13643944311631574f" alt="js-standard-style"](https://github.com/feross/standard)
> offline first support for choo apps
## Installation
```bash
npm install --save choo-offline
```## Usage
```javascript
const choo = require('choo')
const offline = require('choo-offline')const app = choo()
offline(offline => {
app.use(offline)const tree = app.start()
document.body.appendChild(tree)
})
```## API
### `offline([opts], fn())`
Function that wraps the choo `start` and `use` methods, only needed for this plugin, other plugins can be registered before.
It can take two parameters.#### `opts`
Type: `Object`
Optional configuration object for the plugin, can take the following options:
- `serviceWorker` (String): A string with the relative path to a service worker file, if not provided, it will not install a service worker. Defaults: `''`.
- `dbConfig` (Object): An object with [localforage config](https://github.com/localForage/localForage#configuration).#### `fn`
Type: `Function`
Required function that get as the only argument, the offline plugin object. The object use the following hooks:
- `onStateChange`: To update the app state locally with localforage.
- `onAction`: To check if the app is offline and, if it is, use a backup action. Use the backup function when you have actions that depend on network availability,
just define a `_backup` option in your `send()` data, the `_backup` option must be a string calling an effect or reducer from your model. For example
```javascript
send('xhrEffect', { foo: bar, _backup: 'nonXhrBackup' })
```
The above statement will call `xhrEffect` normally, but when offline, it will call the `nonXhrBackup` effect|reducer, passing the same data, excluding the _backup strings.
- `wrapInitialState`: To get the initial local state.## License
MIT
Crafted with <3 by [YerkoPalma](https://github.com/YerkoPalma) .
***
> This package was initially generated with [yeoman](http://yeoman.io) and the [p generator](https://github.com/johnotander/generator-p.git).