• Stars
    star
    133
  • Rank 272,600 (Top 6 %)
  • Language
    JavaScript
  • License
    Other
  • Created over 10 years ago
  • Updated about 5 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Offline usage for Ember Data, based on localstorage adapter, but now uses Mozilla's localforage as data source

Ember Data Localforage Adapter

Store your ember application data in Mozilla's localForage. Compatible with Ember Data 3.0.

"localForage is a JavaScript library that improves the offline experience of your web app by using asynchronous storage (via IndexedDB or WebSQL where available) with a simple, localStorage-like API."

It is supported by all major browsers, including mobile.

Build Status npm version Bower version Ember Observer Score

Usage

Install the addon using ember cli

ember install ember-localforage-adapter

Initialize the adapter.

//app/adapters/application.js
import LFAdapter from 'ember-localforage-adapter/adapters/localforage';

export default LFAdapter;

For a more thorough introduction how to use this adapter, please read Models and application data on the MDN website of Mozilla.

Localforage Namespace

All of your application data lives on a single localforage key, it defaults to DS.LFAdapter but if you supply a namespace option it will store it there:

//app/adapters/user.js
import LFAdapter from 'ember-localforage-adapter/adapters/localforage';

export default LFAdapter.extend({
  namespace: 'users'
});

Cache

In order to reduce the number of getItem calls to localforage, you can specify a caching mechanism.

import LFAdapter from 'ember-localforage-adapter/adapters/localforage';

export default LFAdapter.extend({
  caching: 'model|all|none'
});

While all will reduce the number of calls to getItem (for reading) to only one, you will fetch all your data in memory. The default behaviour therefore is model. This means: if you query one model, it will fetch all the items of that model from localforage.

Embedded records

Since version 0.7.0 this library is also compatible with Ember Data's embedded records. Include the embedded attributes in your serializer like below and benefit from the often superior approach of doing complex object graphs when you don't really have full control over how and when data gets loaded. See the specific PR for more information.

// serializers/customer.js
export default LFSerializer.extend(
  DS.EmbeddedRecordsMixin, {
    attrs: {
      addresses: { embedded: 'always' },
      hour: { embedded: 'always' }
    }
  }
);

Semantic versioning

This library follows the rules of semantic versioning. If you see any unexpected API changes, please create an issue to resolve this. Since Ember Data released its first stable version, this library will follows the major and minor version numbers that Ember Data is using. So version 1.13.* will be matched by 1.13.0 of the Localforage adapter. If we build in new features in this adapter, they can only be released together with an update of Ember Data. Of course patches will always be released as soon as possible.

Support

The adapter is available in the current versions of all major browsers: Chrome, Firefox, IE, and Safari (including Safari Mobile). localStorage is used for browsers with no IndexedDB or WebSQL support. See Mozilla's localForage for an updated detailed compatibility info.

  • Android Browser 2.1
  • Blackberry 7
  • Chrome 23 (Chrome 4.0+ with localStorage)
  • Chrome for Android 32
  • Firefox 10 (Firefox 3.5+ with localStorage)
  • Firefox for Android 25
  • Firefox OS 1.0
  • IE 10 (IE 8+ with localStorage)
  • IE Mobile 10
  • Opera 15 (Opera 10.5+ with localStorage)
  • Opera Mobile 11
  • Phonegap/Apache Cordova 1.2.0
  • Safari 3.1 (includes Mobile Safari)

Localforage Adapter License & Copyright

Copyright (c) 2012 Genkgo BV MIT Style license. http://opensource.org/licenses/MIT

Original LocalStorage Adapter Copyright (c) 2012 Ryan Florence MIT Style license. http://opensource.org/licenses/MIT

More Repositories

1

mail

Library to send e-mails over different transports and protocols (like SMTP and IMAP) using immutable messages and streams. Also includes SMTP server.
PHP
401
star
2

camt

PHP Parser for CAMT messages
PHP
81
star
3

xsl

XSL 2.0 Transpiler in PHP
PHP
50
star
4

push

Send push messages to Android and Apple using one interface
PHP
12
star
5

migrations

Framework independent migration library for your PHP project
PHP
7
star
6

gworkerd

CLI Worker written in Rust Lang + UI written in Ember
Rust
5
star
7

ap-npm

Private Authenticated NPM Repository
JavaScript
5
star
8

php-ext-fs-notify

PHP Extension for cross-platform filesystem notifications
Rust
4
star
9

api

Genkgo API
PHP
4
star
10

uncompass

Compass mixin removal script
Shell
4
star
11

APNS-iOS-server-token-creator

Simple bash script that automates the steps taken to create, test and prepare the signed server certificate for the Apple Push Notification Service.
Shell
3
star
12

babel-plugin-dynamic-import-amd

Babel plugin to transpile import() to require, for AMD module loaders
JavaScript
2
star
13

favicon

Favicon generator in PHP
PHP
2
star
14

omnipay-abn-internetkassa-ideal-only

Ogone gateway for omnipay
PHP
2
star
15

cache

PHP Cache library using mechanisms as originally proposed by Anthony Ferrara.
PHP
1
star
16

dtk-cli

Genkgo Design Toolkit CLI
JavaScript
1
star
17

routed-enhancement

Progressively enhance webpages by using a router based on CSS selectors, page size, scroll bar position and events
JavaScript
1
star
18

omnipay-ideallite

Omnipay implementation for easy / basic / lite iDeal payments
PHP
1
star
19

broccoli-sass-simultaneous

Simultaneous sass compiler for Broccoli, using broccoli-sass-source-maps
JavaScript
1
star
20

php-asn1

PHP
1
star