@ionic/storage
Advanced tools
Comparing version 2.2.0 to 2.3.0
(function (global, factory) { | ||
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('localforage'), require('localforage-cordovasqlitedriver')) : | ||
typeof define === 'function' && define.amd ? define('@ionic/storage', ['exports', '@angular/core', 'localforage', 'localforage-cordovasqlitedriver'], factory) : | ||
(factory((global.ionic = global.ionic || {}, global.ionic.storage = {}),global.ng.core,null,null)); | ||
}(this, (function (exports,core,LocalForage,CordovaSQLiteDriver) { 'use strict'; | ||
(global = global || self, factory((global.ionic = global.ionic || {}, global.ionic.storage = {}), global.ng.core, global.localforage, global.CordovaSQLiteDriver)); | ||
}(this, (function (exports, core, localforage, CordovaSQLiteDriver) { 'use strict'; | ||
/*! ***************************************************************************** | ||
Copyright (c) Microsoft Corporation. | ||
Permission to use, copy, modify, and/or distribute this software for any | ||
purpose with or without fee is hereby granted. | ||
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH | ||
REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY | ||
AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, | ||
INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM | ||
LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR | ||
OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR | ||
PERFORMANCE OF THIS SOFTWARE. | ||
***************************************************************************** */ | ||
/* global Reflect, Promise */ | ||
var extendStatics = function(d, b) { | ||
extendStatics = Object.setPrototypeOf || | ||
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || | ||
function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; | ||
return extendStatics(d, b); | ||
}; | ||
function __extends(d, b) { | ||
extendStatics(d, b); | ||
function __() { this.constructor = d; } | ||
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); | ||
} | ||
var __assign = function() { | ||
__assign = Object.assign || function __assign(t) { | ||
for (var s, i = 1, n = arguments.length; i < n; i++) { | ||
s = arguments[i]; | ||
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; | ||
} | ||
return t; | ||
}; | ||
return __assign.apply(this, arguments); | ||
}; | ||
function __rest(s, e) { | ||
var t = {}; | ||
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) | ||
t[p] = s[p]; | ||
if (s != null && typeof Object.getOwnPropertySymbols === "function") | ||
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) { | ||
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) | ||
t[p[i]] = s[p[i]]; | ||
} | ||
return t; | ||
} | ||
function __decorate(decorators, target, key, desc) { | ||
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; | ||
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); | ||
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; | ||
return c > 3 && r && Object.defineProperty(target, key, r), r; | ||
} | ||
function __param(paramIndex, decorator) { | ||
return function (target, key) { decorator(target, key, paramIndex); } | ||
} | ||
function __metadata(metadataKey, metadataValue) { | ||
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(metadataKey, metadataValue); | ||
} | ||
function __awaiter(thisArg, _arguments, P, generator) { | ||
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } | ||
return new (P || (P = Promise))(function (resolve, reject) { | ||
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } | ||
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } | ||
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } | ||
step((generator = generator.apply(thisArg, _arguments || [])).next()); | ||
}); | ||
} | ||
function __generator(thisArg, body) { | ||
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; | ||
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; | ||
function verb(n) { return function (v) { return step([n, v]); }; } | ||
function step(op) { | ||
if (f) throw new TypeError("Generator is already executing."); | ||
while (_) try { | ||
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; | ||
if (y = 0, t) op = [op[0] & 2, t.value]; | ||
switch (op[0]) { | ||
case 0: case 1: t = op; break; | ||
case 4: _.label++; return { value: op[1], done: false }; | ||
case 5: _.label++; y = op[1]; op = [0]; continue; | ||
case 7: op = _.ops.pop(); _.trys.pop(); continue; | ||
default: | ||
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } | ||
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } | ||
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } | ||
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } | ||
if (t[2]) _.ops.pop(); | ||
_.trys.pop(); continue; | ||
} | ||
op = body.call(thisArg, _); | ||
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } | ||
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; | ||
} | ||
} | ||
function __createBinding(o, m, k, k2) { | ||
if (k2 === undefined) k2 = k; | ||
o[k2] = m[k]; | ||
} | ||
function __exportStar(m, exports) { | ||
for (var p in m) if (p !== "default" && !exports.hasOwnProperty(p)) exports[p] = m[p]; | ||
} | ||
function __values(o) { | ||
var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0; | ||
if (m) return m.call(o); | ||
if (o && typeof o.length === "number") return { | ||
next: function () { | ||
if (o && i >= o.length) o = void 0; | ||
return { value: o && o[i++], done: !o }; | ||
} | ||
}; | ||
throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined."); | ||
} | ||
function __read(o, n) { | ||
var m = typeof Symbol === "function" && o[Symbol.iterator]; | ||
if (!m) return o; | ||
var i = m.call(o), r, ar = [], e; | ||
try { | ||
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); | ||
} | ||
catch (error) { e = { error: error }; } | ||
finally { | ||
try { | ||
if (r && !r.done && (m = i["return"])) m.call(i); | ||
} | ||
finally { if (e) throw e.error; } | ||
} | ||
return ar; | ||
} | ||
function __spread() { | ||
for (var ar = [], i = 0; i < arguments.length; i++) | ||
ar = ar.concat(__read(arguments[i])); | ||
return ar; | ||
} | ||
function __spreadArrays() { | ||
for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length; | ||
for (var r = Array(s), k = 0, i = 0; i < il; i++) | ||
for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) | ||
r[k] = a[j]; | ||
return r; | ||
}; | ||
function __await(v) { | ||
return this instanceof __await ? (this.v = v, this) : new __await(v); | ||
} | ||
function __asyncGenerator(thisArg, _arguments, generator) { | ||
if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); | ||
var g = generator.apply(thisArg, _arguments || []), i, q = []; | ||
return i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i; | ||
function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; } | ||
function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } } | ||
function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); } | ||
function fulfill(value) { resume("next", value); } | ||
function reject(value) { resume("throw", value); } | ||
function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); } | ||
} | ||
function __asyncDelegator(o) { | ||
var i, p; | ||
return i = {}, verb("next"), verb("throw", function (e) { throw e; }), verb("return"), i[Symbol.iterator] = function () { return this; }, i; | ||
function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === "return" } : f ? f(v) : v; } : f; } | ||
} | ||
function __asyncValues(o) { | ||
if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); | ||
var m = o[Symbol.asyncIterator], i; | ||
return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i); | ||
function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; } | ||
function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); } | ||
} | ||
function __makeTemplateObject(cooked, raw) { | ||
if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; } | ||
return cooked; | ||
}; | ||
function __importStar(mod) { | ||
if (mod && mod.__esModule) return mod; | ||
var result = {}; | ||
if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k]; | ||
result.default = mod; | ||
return result; | ||
} | ||
function __importDefault(mod) { | ||
return (mod && mod.__esModule) ? mod : { default: mod }; | ||
} | ||
function __classPrivateFieldGet(receiver, privateMap) { | ||
if (!privateMap.has(receiver)) { | ||
throw new TypeError("attempted to get private field on non-instance"); | ||
} | ||
return privateMap.get(receiver); | ||
} | ||
function __classPrivateFieldSet(receiver, privateMap, value) { | ||
if (!privateMap.has(receiver)) { | ||
throw new TypeError("attempted to set private field on non-instance"); | ||
} | ||
privateMap.set(receiver, value); | ||
return value; | ||
} | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes} checked by tsc | ||
*/ | ||
/** | ||
* Storage is an easy way to store key/value pairs and JSON objects. | ||
@@ -24,3 +239,3 @@ * Storage uses a variety of storage engines underneath, picking the best one available | ||
* | ||
* \@usage | ||
* @usage | ||
* First, if you'd like to use SQLite, install the cordova-sqlite-storage plugin: | ||
@@ -33,3 +248,3 @@ * ```bash | ||
* ```bash | ||
* npm install --save \@ionic/storage | ||
* npm install --save @ionic/storage | ||
* ``` | ||
@@ -40,5 +255,5 @@ * | ||
* ```typescript | ||
* import { IonicStorageModule } from '\@ionic/storage'; | ||
* import { IonicStorageModule } from '@ionic/storage'; | ||
* | ||
* \@NgModule({ | ||
* @NgModule({ | ||
* declarations: [ | ||
@@ -61,7 +276,8 @@ * // ... | ||
* export class AppModule {} | ||
* ``` | ||
*``` | ||
* | ||
* Finally, inject it into any of your components or pages: | ||
* ```typescript | ||
* import { Storage } from '\@ionic/storage'; | ||
* import { Storage } from '@ionic/storage'; | ||
* export class MyApp { | ||
@@ -91,5 +307,5 @@ * constructor(private storage: Storage) { } | ||
* ```typescript | ||
* import { IonicStorageModule } from '\@ionic/storage'; | ||
* import { IonicStorageModule } from '@ionic/storage'; | ||
* | ||
* \@NgModule({ | ||
* @NgModule({ | ||
* declarations: [...], | ||
@@ -99,3 +315,3 @@ * imports: [ | ||
* name: '__mydb', | ||
* driverOrder: ['indexeddb', 'sqlite', 'websql'] | ||
driverOrder: ['indexeddb', 'sqlite', 'websql'] | ||
* }) | ||
@@ -110,95 +326,3 @@ * ], | ||
*/ | ||
var /** | ||
* Storage is an easy way to store key/value pairs and JSON objects. | ||
* Storage uses a variety of storage engines underneath, picking the best one available | ||
* depending on the platform. | ||
* | ||
* When running in a native app context, Storage will prioritize using SQLite, as it's one of | ||
* the most stable and widely used file-based databases, and avoids some of the | ||
* pitfalls of things like localstorage and IndexedDB, such as the OS deciding to clear out such | ||
* data in low disk-space situations. | ||
* | ||
* When running in the web or as a Progressive Web App, Storage will attempt to use | ||
* IndexedDB, WebSQL, and localstorage, in that order. | ||
* | ||
* \@usage | ||
* First, if you'd like to use SQLite, install the cordova-sqlite-storage plugin: | ||
* ```bash | ||
* ionic cordova plugin add cordova-sqlite-storage | ||
* ``` | ||
* | ||
* Next, install the package (comes by default for Ionic apps > Ionic V1): | ||
* ```bash | ||
* npm install --save \@ionic/storage | ||
* ``` | ||
* | ||
* Next, add it to the imports list in your `NgModule` declaration (for example, in `src/app/app.module.ts`): | ||
* | ||
* ```typescript | ||
* import { IonicStorageModule } from '\@ionic/storage'; | ||
* | ||
* \@NgModule({ | ||
* declarations: [ | ||
* // ... | ||
* ], | ||
* imports: [ | ||
* BrowserModule, | ||
* IonicModule.forRoot(MyApp), | ||
* IonicStorageModule.forRoot() | ||
* ], | ||
* bootstrap: [IonicApp], | ||
* entryComponents: [ | ||
* // ... | ||
* ], | ||
* providers: [ | ||
* // ... | ||
* ] | ||
* }) | ||
* export class AppModule {} | ||
* ``` | ||
* | ||
* Finally, inject it into any of your components or pages: | ||
* ```typescript | ||
* import { Storage } from '\@ionic/storage'; | ||
* export class MyApp { | ||
* constructor(private storage: Storage) { } | ||
* | ||
* ... | ||
* | ||
* // set a key/value | ||
* storage.set('name', 'Max'); | ||
* | ||
* // Or to get a key/value pair | ||
* storage.get('age').then((val) => { | ||
* console.log('Your age is', val); | ||
* }); | ||
* } | ||
* ``` | ||
* | ||
* | ||
* ### Configuring Storage | ||
* | ||
* The Storage engine can be configured both with specific storage engine priorities, or custom configuration | ||
* options to pass to localForage. See the localForage config docs for possible options: https://github.com/localForage/localForage#configuration | ||
* | ||
* Note: Any custom configurations will be merged with the default configuration | ||
* | ||
* ```typescript | ||
* import { IonicStorageModule } from '\@ionic/storage'; | ||
* | ||
* \@NgModule({ | ||
* declarations: [...], | ||
* imports: [ | ||
* IonicStorageModule.forRoot({ | ||
* name: '__mydb', | ||
* driverOrder: ['indexeddb', 'sqlite', 'websql'] | ||
* }) | ||
* ], | ||
* bootstrap: [...], | ||
* entryComponents: [...], | ||
* providers: [...] | ||
* }) | ||
* export class AppModule { } | ||
* ``` | ||
*/ Storage = /** @class */ (function () { | ||
var Storage = /** @class */ (function () { | ||
/** | ||
@@ -215,8 +339,13 @@ * Create a new Storage instance using the order of drivers and any additional config | ||
this._dbPromise = new Promise(function (resolve, reject) { | ||
var /** @type {?} */ db; | ||
var /** @type {?} */ defaultConfig = getDefaultConfig(); | ||
var /** @type {?} */ actualConfig = Object.assign(defaultConfig, config || {}); | ||
LocalForage.defineDriver(CordovaSQLiteDriver) | ||
if (typeof process !== 'undefined') { | ||
var noopDriver = getNoopDriver(); | ||
resolve(noopDriver); | ||
return; | ||
} | ||
var db; | ||
var defaultConfig = getDefaultConfig(); | ||
var actualConfig = Object.assign(defaultConfig, config || {}); | ||
localforage.defineDriver(CordovaSQLiteDriver) | ||
.then(function () { | ||
db = LocalForage.createInstance(actualConfig); | ||
db = localforage.createInstance(actualConfig); | ||
}) | ||
@@ -238,6 +367,3 @@ .then(function () { | ||
*/ | ||
get: /** | ||
* Get the name of the driver being used. | ||
* @return {?} Name of the driver | ||
*/ function () { | ||
get: function () { | ||
return this._driver; | ||
@@ -252,38 +378,21 @@ }, | ||
*/ | ||
Storage.prototype.ready = function () { | ||
return this._dbPromise; | ||
}; | ||
/** @hidden */ | ||
Storage.prototype._getDriverOrder = function (driverOrder) { | ||
return driverOrder.map(function (driver) { | ||
switch (driver) { | ||
case 'sqlite': | ||
return CordovaSQLiteDriver._driver; | ||
case 'indexeddb': | ||
return localforage.INDEXEDDB; | ||
case 'websql': | ||
return localforage.WEBSQL; | ||
case 'localstorage': | ||
return localforage.LOCALSTORAGE; | ||
} | ||
}); | ||
}; | ||
/** | ||
* Reflect the readiness of the store. | ||
* @return {?} Returns a promise that resolves when the store is ready | ||
*/ | ||
Storage.prototype.ready = /** | ||
* Reflect the readiness of the store. | ||
* @return {?} Returns a promise that resolves when the store is ready | ||
*/ | ||
function () { | ||
return this._dbPromise; | ||
}; | ||
/** | ||
* @hidden | ||
* @param {?} driverOrder | ||
* @return {?} | ||
*/ | ||
Storage.prototype._getDriverOrder = /** | ||
* @hidden | ||
* @param {?} driverOrder | ||
* @return {?} | ||
*/ | ||
function (driverOrder) { | ||
return driverOrder.map(function (driver) { | ||
switch (driver) { | ||
case 'sqlite': | ||
return CordovaSQLiteDriver._driver; | ||
case 'indexeddb': | ||
return LocalForage.INDEXEDDB; | ||
case 'websql': | ||
return LocalForage.WEBSQL; | ||
case 'localstorage': | ||
return LocalForage.LOCALSTORAGE; | ||
} | ||
}); | ||
}; | ||
/** | ||
* Get the value associated with the given key. | ||
@@ -293,16 +402,6 @@ * @param key the key to identify this value | ||
*/ | ||
Storage.prototype.get = function (key) { | ||
return this._dbPromise.then(function (db) { return db.getItem(key); }); | ||
}; | ||
/** | ||
* Get the value associated with the given key. | ||
* @param {?} key the key to identify this value | ||
* @return {?} Returns a promise with the value of the given key | ||
*/ | ||
Storage.prototype.get = /** | ||
* Get the value associated with the given key. | ||
* @param {?} key the key to identify this value | ||
* @return {?} Returns a promise with the value of the given key | ||
*/ | ||
function (key) { | ||
return this._dbPromise.then(function (db) { return db.getItem(key); }); | ||
}; | ||
/** | ||
* Set the value for the given key. | ||
@@ -313,18 +412,6 @@ * @param key the key to identify this value | ||
*/ | ||
Storage.prototype.set = function (key, value) { | ||
return this._dbPromise.then(function (db) { return db.setItem(key, value); }); | ||
}; | ||
/** | ||
* Set the value for the given key. | ||
* @param {?} key the key to identify this value | ||
* @param {?} value the value for this key | ||
* @return {?} Returns a promise that resolves when the key and value are set | ||
*/ | ||
Storage.prototype.set = /** | ||
* Set the value for the given key. | ||
* @param {?} key the key to identify this value | ||
* @param {?} value the value for this key | ||
* @return {?} Returns a promise that resolves when the key and value are set | ||
*/ | ||
function (key, value) { | ||
return this._dbPromise.then(function (db) { return db.setItem(key, value); }); | ||
}; | ||
/** | ||
* Remove any value associated with this key. | ||
@@ -334,55 +421,25 @@ * @param key the key to identify this value | ||
*/ | ||
Storage.prototype.remove = function (key) { | ||
return this._dbPromise.then(function (db) { return db.removeItem(key); }); | ||
}; | ||
/** | ||
* Remove any value associated with this key. | ||
* @param {?} key the key to identify this value | ||
* @return {?} Returns a promise that resolves when the value is removed | ||
*/ | ||
Storage.prototype.remove = /** | ||
* Remove any value associated with this key. | ||
* @param {?} key the key to identify this value | ||
* @return {?} Returns a promise that resolves when the value is removed | ||
*/ | ||
function (key) { | ||
return this._dbPromise.then(function (db) { return db.removeItem(key); }); | ||
}; | ||
/** | ||
* Clear the entire key value store. WARNING: HOT! | ||
* @returns Returns a promise that resolves when the store is cleared | ||
*/ | ||
Storage.prototype.clear = function () { | ||
return this._dbPromise.then(function (db) { return db.clear(); }); | ||
}; | ||
/** | ||
* Clear the entire key value store. WARNING: HOT! | ||
* @return {?} Returns a promise that resolves when the store is cleared | ||
*/ | ||
Storage.prototype.clear = /** | ||
* Clear the entire key value store. WARNING: HOT! | ||
* @return {?} Returns a promise that resolves when the store is cleared | ||
*/ | ||
function () { | ||
return this._dbPromise.then(function (db) { return db.clear(); }); | ||
}; | ||
/** | ||
* @returns Returns a promise that resolves with the number of keys stored. | ||
*/ | ||
Storage.prototype.length = function () { | ||
return this._dbPromise.then(function (db) { return db.length(); }); | ||
}; | ||
/** | ||
* @return {?} Returns a promise that resolves with the number of keys stored. | ||
*/ | ||
Storage.prototype.length = /** | ||
* @return {?} Returns a promise that resolves with the number of keys stored. | ||
*/ | ||
function () { | ||
return this._dbPromise.then(function (db) { return db.length(); }); | ||
}; | ||
/** | ||
* @returns Returns a promise that resolves with the keys in the store. | ||
*/ | ||
Storage.prototype.keys = function () { | ||
return this._dbPromise.then(function (db) { return db.keys(); }); | ||
}; | ||
/** | ||
* @return {?} Returns a promise that resolves with the keys in the store. | ||
*/ | ||
Storage.prototype.keys = /** | ||
* @return {?} Returns a promise that resolves with the keys in the store. | ||
*/ | ||
function () { | ||
return this._dbPromise.then(function (db) { return db.keys(); }); | ||
}; | ||
/** | ||
* Iterate through each key,value pair. | ||
@@ -392,21 +449,8 @@ * @param iteratorCallback a callback of the form (value, key, iterationNumber) | ||
*/ | ||
/** | ||
* Iterate through each key,value pair. | ||
* @param {?} iteratorCallback a callback of the form (value, key, iterationNumber) | ||
* @return {?} Returns a promise that resolves when the iteration has finished. | ||
*/ | ||
Storage.prototype.forEach = /** | ||
* Iterate through each key,value pair. | ||
* @param {?} iteratorCallback a callback of the form (value, key, iterationNumber) | ||
* @return {?} Returns a promise that resolves when the iteration has finished. | ||
*/ | ||
function (iteratorCallback) { | ||
return this._dbPromise.then(function (db) { return db.iterate(iteratorCallback); }); | ||
}; | ||
Storage.prototype.forEach = function (iteratorCallback) { | ||
return this._dbPromise.then(function (db) { return db.iterate(iteratorCallback); }); | ||
}; | ||
return Storage; | ||
}()); | ||
/** | ||
* @hidden | ||
* @return {?} | ||
*/ | ||
/** @hidden */ | ||
function getDefaultConfig() { | ||
@@ -420,61 +464,52 @@ return { | ||
} | ||
/** | ||
* @hidden | ||
*/ | ||
var /** @type {?} */ StorageConfigToken = new core.InjectionToken('STORAGE_CONFIG_TOKEN'); | ||
/** | ||
* @hidden | ||
* @param {?} storageConfig | ||
* @return {?} | ||
*/ | ||
/** @hidden */ | ||
var StorageConfigToken = new core.InjectionToken('STORAGE_CONFIG_TOKEN'); | ||
/** @hidden */ | ||
function provideStorage(storageConfig) { | ||
var /** @type {?} */ config = !!storageConfig ? storageConfig : getDefaultConfig(); | ||
var config = !!storageConfig ? storageConfig : getDefaultConfig(); | ||
return new Storage(config); | ||
} | ||
function getNoopDriver() { | ||
// noop driver for ssr environment | ||
var noop = function () { }; | ||
var driver = { | ||
getItem: noop, | ||
setItem: noop, | ||
removeItem: noop, | ||
clear: noop, | ||
length: function () { return 0; }, | ||
keys: function () { return []; }, | ||
iterate: noop | ||
}; | ||
return driver; | ||
} | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes} checked by tsc | ||
*/ | ||
var IonicStorageModule = /** @class */ (function () { | ||
function IonicStorageModule() { | ||
} | ||
/** | ||
* @param {?=} storageConfig | ||
* @return {?} | ||
*/ | ||
IonicStorageModule.forRoot = /** | ||
* @param {?=} storageConfig | ||
* @return {?} | ||
*/ | ||
function (storageConfig) { | ||
if (storageConfig === void 0) { | ||
storageConfig = null; | ||
} | ||
return { | ||
ngModule: IonicStorageModule, | ||
providers: [ | ||
{ provide: StorageConfigToken, useValue: storageConfig }, | ||
{ | ||
provide: Storage, | ||
useFactory: provideStorage, | ||
deps: [StorageConfigToken] | ||
} | ||
] | ||
}; | ||
IonicStorageModule_1 = IonicStorageModule; | ||
IonicStorageModule.forRoot = function (storageConfig) { | ||
if (storageConfig === void 0) { storageConfig = null; } | ||
return { | ||
ngModule: IonicStorageModule_1, | ||
providers: [ | ||
{ provide: StorageConfigToken, useValue: storageConfig }, | ||
{ | ||
provide: Storage, | ||
useFactory: provideStorage, | ||
deps: [StorageConfigToken] | ||
} | ||
] | ||
}; | ||
IonicStorageModule.decorators = [ | ||
{ type: core.NgModule }, | ||
]; | ||
}; | ||
var IonicStorageModule_1; | ||
IonicStorageModule = IonicStorageModule_1 = __decorate([ | ||
core.NgModule() | ||
], IonicStorageModule); | ||
return IonicStorageModule; | ||
}()); | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes} checked by tsc | ||
*/ | ||
exports.IonicStorageModule = IonicStorageModule; | ||
exports.Storage = Storage; | ||
exports.StorageConfigToken = StorageConfigToken; | ||
exports.Storage = Storage; | ||
exports.IonicStorageModule = IonicStorageModule; | ||
exports.ɵa = provideStorage; | ||
@@ -485,3 +520,2 @@ | ||
}))); | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ionic-storage.umd.js.map","sources":["ng://@ionic/storage/storage.ts","ng://@ionic/storage/index.ts"],"sourcesContent":["import { InjectionToken } from '@angular/core';\n\nimport * as LocalForage from 'localforage';\n\nimport * as CordovaSQLiteDriver from 'localforage-cordovasqlitedriver';\n\n/**\n * Storage is an easy way to store key/value pairs and JSON objects.\n * Storage uses a variety of storage engines underneath, picking the best one available\n * depending on the platform.\n *\n * When running in a native app context, Storage will prioritize using SQLite, as it's one of\n * the most stable and widely used file-based databases, and avoids some of the\n * pitfalls of things like localstorage and IndexedDB, such as the OS deciding to clear out such\n * data in low disk-space situations.\n *\n * When running in the web or as a Progressive Web App, Storage will attempt to use\n * IndexedDB, WebSQL, and localstorage, in that order.\n *\n * @usage\n * First, if you'd like to use SQLite, install the cordova-sqlite-storage plugin:\n * ```bash\n * ionic cordova plugin add cordova-sqlite-storage\n * ```\n *\n * Next, install the package (comes by default for Ionic apps > Ionic V1):\n * ```bash\n * npm install --save @ionic/storage\n * ```\n *\n * Next, add it to the imports list in your `NgModule` declaration (for example, in `src/app/app.module.ts`):\n *\n * ```typescript\n * import { IonicStorageModule } from '@ionic/storage';\n *\n * @NgModule({\n *   declarations: [\n *     // ...\n *   ],\n *   imports: [\n *     BrowserModule,\n *     IonicModule.forRoot(MyApp),\n *     IonicStorageModule.forRoot()\n *   ],\n *   bootstrap: [IonicApp],\n *   entryComponents: [\n *     // ...\n *   ],\n *   providers: [\n *     // ...\n *   ]\n * })\n * export class AppModule {}\n *```\n *\n * Finally, inject it into any of your components or pages:\n * ```typescript\n * import { Storage } from '@ionic/storage';\n\n * export class MyApp {\n *   constructor(private storage: Storage) { }\n *\n *   ...\n *\n *   // set a key/value\n *   storage.set('name', 'Max');\n *\n *   // Or to get a key/value pair\n *   storage.get('age').then((val) => {\n *     console.log('Your age is', val);\n *   });\n * }\n * ```\n *\n *\n * ### Configuring Storage\n *\n * The Storage engine can be configured both with specific storage engine priorities, or custom configuration\n * options to pass to localForage. See the localForage config docs for possible options: https://github.com/localForage/localForage#configuration\n *\n * Note: Any custom configurations will be merged with the default configuration\n *\n * ```typescript\n * import { IonicStorageModule } from '@ionic/storage';\n *\n * @NgModule({\n *   declarations: [...],\n *   imports: [\n *     IonicStorageModule.forRoot({\n *       name: '__mydb',\n         driverOrder: ['indexeddb', 'sqlite', 'websql']\n *     })\n *   ],\n *   bootstrap: [...],\n *   entryComponents: [...],\n *    providers: [...]\n * })\n * export class AppModule { }\n * ```\n */\nexport class Storage {\n  private _dbPromise: Promise<LocalForage>;\n  private _driver: string = null;\n\n  /**\n   * Create a new Storage instance using the order of drivers and any additional config\n   * options to pass to LocalForage.\n   *\n   * Possible driver options are: ['sqlite', 'indexeddb', 'websql', 'localstorage'] and the\n   * default is that exact ordering.\n   */\n  constructor(config: StorageConfig) {\n    this._dbPromise = new Promise((resolve, reject) => {\n      let db: LocalForage;\n\n      const defaultConfig = getDefaultConfig();\n      const actualConfig = Object.assign(defaultConfig, config || {});\n\n      LocalForage.defineDriver(CordovaSQLiteDriver)\n        .then(() => {\n          db = LocalForage.createInstance(actualConfig);\n        })\n        .then(() =>\n          db.setDriver(this._getDriverOrder(actualConfig.driverOrder))\n        )\n        .then(() => {\n          this._driver = db.driver();\n          resolve(db);\n        })\n        .catch(reason => reject(reason));\n    });\n  }\n\n  /**\n   * Get the name of the driver being used.\n   * @returns Name of the driver\n   */\n  get driver(): string | null {\n    return this._driver;\n  }\n\n  /**\n   * Reflect the readiness of the store.\n   * @returns Returns a promise that resolves when the store is ready\n   */\n  ready(): Promise<LocalForage> {\n    return this._dbPromise;\n  }\n\n  /** @hidden */\n  private _getDriverOrder(driverOrder) {\n    return driverOrder.map(driver => {\n      switch (driver) {\n        case 'sqlite':\n          return CordovaSQLiteDriver._driver;\n        case 'indexeddb':\n          return LocalForage.INDEXEDDB;\n        case 'websql':\n          return LocalForage.WEBSQL;\n        case 'localstorage':\n          return LocalForage.LOCALSTORAGE;\n      }\n    });\n  }\n\n  /**\n   * Get the value associated with the given key.\n   * @param key the key to identify this value\n   * @returns Returns a promise with the value of the given key\n   */\n  get(key: string): Promise<any> {\n    return this._dbPromise.then(db => db.getItem(key));\n  }\n\n  /**\n   * Set the value for the given key.\n   * @param key the key to identify this value\n   * @param value the value for this key\n   * @returns Returns a promise that resolves when the key and value are set\n   */\n  set(key: string, value: any): Promise<any> {\n    return this._dbPromise.then(db => db.setItem(key, value));\n  }\n\n  /**\n   * Remove any value associated with this key.\n   * @param key the key to identify this value\n   * @returns Returns a promise that resolves when the value is removed\n   */\n  remove(key: string): Promise<any> {\n    return this._dbPromise.then(db => db.removeItem(key));\n  }\n\n  /**\n   * Clear the entire key value store. WARNING: HOT!\n   * @returns Returns a promise that resolves when the store is cleared\n   */\n  clear(): Promise<void> {\n    return this._dbPromise.then(db => db.clear());\n  }\n\n  /**\n   * @returns Returns a promise that resolves with the number of keys stored.\n   */\n  length(): Promise<number> {\n    return this._dbPromise.then(db => db.length());\n  }\n\n  /**\n   * @returns Returns a promise that resolves with the keys in the store.\n   */\n  keys(): Promise<string[]> {\n    return this._dbPromise.then(db => db.keys());\n  }\n\n  /**\n   * Iterate through each key,value pair.\n   * @param iteratorCallback a callback of the form (value, key, iterationNumber)\n   * @returns Returns a promise that resolves when the iteration has finished.\n   */\n  forEach(\n    iteratorCallback: (value: any, key: string, iterationNumber: Number) => any\n  ): Promise<void> {\n    return this._dbPromise.then(db => db.iterate(iteratorCallback));\n  }\n}\n\n/** @hidden */\nexport function getDefaultConfig() {\n  return {\n    name: '_ionicstorage',\n    storeName: '_ionickv',\n    dbKey: '_ionickey',\n    driverOrder: ['sqlite', 'indexeddb', 'websql', 'localstorage']\n  };\n}\n\n/** @hidden */\nexport interface StorageConfig {\n  name?: string;\n  version?: number;\n  size?: number;\n  storeName?: string;\n  description?: string;\n  driverOrder?: string[];\n  dbKey?: string;\n}\n\n/** @hidden */\nexport const StorageConfigToken = new InjectionToken<any>(\n  'STORAGE_CONFIG_TOKEN'\n);\n\n/** @hidden */\nexport function provideStorage(storageConfig: StorageConfig): Storage {\n  const config = !!storageConfig ? storageConfig : getDefaultConfig();\n  return new Storage(config);\n}\n","import { NgModule, ModuleWithProviders } from '@angular/core';\nimport {\n  getDefaultConfig,\n  provideStorage,\n  Storage,\n  StorageConfig,\n  StorageConfigToken\n} from './storage';\n\nexport { StorageConfig, StorageConfigToken, Storage };\n\n@NgModule()\nexport class IonicStorageModule {\n  static forRoot(storageConfig: StorageConfig = null): ModuleWithProviders {\n    return {\n      ngModule: IonicStorageModule,\n      providers: [\n        { provide: StorageConfigToken, useValue: storageConfig },\n        {\n          provide: Storage,\n          useFactory: provideStorage,\n          deps: [StorageConfigToken]\n        }\n      ]\n    };\n  }\n}\n"],"names":["LocalForage.defineDriver","LocalForage.createInstance","CordovaSQLiteDriver._driver","LocalForage.INDEXEDDB","LocalForage.WEBSQL","LocalForage.LOCALSTORAGE","InjectionToken","NgModule"],"mappings":"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"} | ||
//# sourceMappingURL=ionic-storage.umd.js.map |
@@ -1,2 +0,16 @@ | ||
!function(e,r){"object"==typeof exports&&"undefined"!=typeof module?r(exports,require("@angular/core"),require("localforage"),require("localforage-cordovasqlitedriver")):"function"==typeof define&&define.amd?define("@ionic/storage",["exports","@angular/core","localforage","localforage-cordovasqlitedriver"],r):r((e.ionic=e.ionic||{},e.ionic.storage={}),e.ng.core,null,null)}(this,function(e,t,c,s){"use strict";var n=function(){function e(i){var u=this;this._driver=null,this._dbPromise=new Promise(function(e,r){var t,n={name:"_ionicstorage",storeName:"_ionickv",dbKey:"_ionickey",driverOrder:["sqlite","indexeddb","websql","localstorage"]},o=Object.assign(n,i||{});c.defineDriver(s).then(function(){t=c.createInstance(o)}).then(function(){return t.setDriver(u._getDriverOrder(o.driverOrder))}).then(function(){u._driver=t.driver(),e(t)})["catch"](function(e){return r(e)})})}return Object.defineProperty(e.prototype,"driver",{get:function(){return this._driver},enumerable:!0,configurable:!0}),e.prototype.ready=function(){return this._dbPromise},e.prototype._getDriverOrder=function(e){return e.map(function(e){switch(e){case"sqlite":return s._driver;case"indexeddb":return c.INDEXEDDB;case"websql":return c.WEBSQL;case"localstorage":return c.LOCALSTORAGE}})},e.prototype.get=function(r){return this._dbPromise.then(function(e){return e.getItem(r)})},e.prototype.set=function(r,t){return this._dbPromise.then(function(e){return e.setItem(r,t)})},e.prototype.remove=function(r){return this._dbPromise.then(function(e){return e.removeItem(r)})},e.prototype.clear=function(){return this._dbPromise.then(function(e){return e.clear()})},e.prototype.length=function(){return this._dbPromise.then(function(e){return e.length()})},e.prototype.keys=function(){return this._dbPromise.then(function(e){return e.keys()})},e.prototype.forEach=function(r){return this._dbPromise.then(function(e){return e.iterate(r)})},e}();var o=new t.InjectionToken("STORAGE_CONFIG_TOKEN");function i(e){return new n(e||{name:"_ionicstorage",storeName:"_ionickv",dbKey:"_ionickey",driverOrder:["sqlite","indexeddb","websql","localstorage"]})}var r=function(){function r(){}return r.forRoot=function(e){return void 0===e&&(e=null),{ngModule:r,providers:[{provide:o,useValue:e},{provide:n,useFactory:i,deps:[o]}]}},r.decorators=[{type:t.NgModule}],r}();e.StorageConfigToken=o,e.Storage=n,e.IonicStorageModule=r,e.ɵa=i,Object.defineProperty(e,"__esModule",{value:!0})}); | ||
!function(e,r){"object"==typeof exports&&"undefined"!=typeof module?r(exports,require("@angular/core"),require("localforage"),require("localforage-cordovasqlitedriver")):"function"==typeof define&&define.amd?define("@ionic/storage",["exports","@angular/core","localforage","localforage-cordovasqlitedriver"],r):r(((e=e||self).ionic=e.ionic||{},e.ionic.storage={}),e.ng.core,e.localforage,e.CordovaSQLiteDriver)}(this,(function(e,r,t,n){"use strict"; | ||
/*! ***************************************************************************** | ||
Copyright (c) Microsoft Corporation. | ||
Permission to use, copy, modify, and/or distribute this software for any | ||
purpose with or without fee is hereby granted. | ||
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH | ||
REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY | ||
AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, | ||
INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM | ||
LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR | ||
OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR | ||
PERFORMANCE OF THIS SOFTWARE. | ||
***************************************************************************** */var o=function(){function e(e){var r=this;this._driver=null,this._dbPromise=new Promise((function(o,i){if("undefined"==typeof process){var c,u,s={name:"_ionicstorage",storeName:"_ionickv",dbKey:"_ionickey",driverOrder:["sqlite","indexeddb","websql","localstorage"]},a=Object.assign(s,e||{});t.defineDriver(n).then((function(){u=t.createInstance(a)})).then((function(){return u.setDriver(r._getDriverOrder(a.driverOrder))})).then((function(){r._driver=u.driver(),o(u)})).catch((function(e){return i(e)}))}else{var f={getItem:c=function(){},setItem:c,removeItem:c,clear:c,length:function(){return 0},keys:function(){return[]},iterate:c};o(f)}}))}return Object.defineProperty(e.prototype,"driver",{get:function(){return this._driver},enumerable:!0,configurable:!0}),e.prototype.ready=function(){return this._dbPromise},e.prototype._getDriverOrder=function(e){return e.map((function(e){switch(e){case"sqlite":return n._driver;case"indexeddb":return t.INDEXEDDB;case"websql":return t.WEBSQL;case"localstorage":return t.LOCALSTORAGE}}))},e.prototype.get=function(e){return this._dbPromise.then((function(r){return r.getItem(e)}))},e.prototype.set=function(e,r){return this._dbPromise.then((function(t){return t.setItem(e,r)}))},e.prototype.remove=function(e){return this._dbPromise.then((function(r){return r.removeItem(e)}))},e.prototype.clear=function(){return this._dbPromise.then((function(e){return e.clear()}))},e.prototype.length=function(){return this._dbPromise.then((function(e){return e.length()}))},e.prototype.keys=function(){return this._dbPromise.then((function(e){return e.keys()}))},e.prototype.forEach=function(e){return this._dbPromise.then((function(r){return r.iterate(e)}))},e}();var i=new r.InjectionToken("STORAGE_CONFIG_TOKEN");function c(e){return new o(e||{name:"_ionicstorage",storeName:"_ionickv",dbKey:"_ionickey",driverOrder:["sqlite","indexeddb","websql","localstorage"]})}var u=function(){function e(){}var t;return t=e,e.forRoot=function(e){return void 0===e&&(e=null),{ngModule:t,providers:[{provide:i,useValue:e},{provide:o,useFactory:c,deps:[i]}]}},e=t=function(e,r,t,n){var o,i=arguments.length,c=i<3?r:null===n?n=Object.getOwnPropertyDescriptor(r,t):n;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)c=Reflect.decorate(e,r,t,n);else for(var u=e.length-1;u>=0;u--)(o=e[u])&&(c=(i<3?o(c):i>3?o(r,t,c):o(r,t))||c);return i>3&&c&&Object.defineProperty(r,t,c),c}([r.NgModule()],e)}();e.IonicStorageModule=u,e.Storage=o,e.StorageConfigToken=i,e.ɵa=c,Object.defineProperty(e,"__esModule",{value:!0})})); | ||
//# sourceMappingURL=ionic-storage.umd.min.js.map |
@@ -1,16 +0,10 @@ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes} checked by tsc | ||
*/ | ||
var IonicStorageModule_1; | ||
import { __decorate } from "tslib"; | ||
import { NgModule } from '@angular/core'; | ||
import { provideStorage, Storage, StorageConfigToken } from './storage'; | ||
export { StorageConfigToken, Storage }; | ||
export class IonicStorageModule { | ||
/** | ||
* @param {?=} storageConfig | ||
* @return {?} | ||
*/ | ||
let IonicStorageModule = IonicStorageModule_1 = class IonicStorageModule { | ||
static forRoot(storageConfig = null) { | ||
return { | ||
ngModule: IonicStorageModule, | ||
ngModule: IonicStorageModule_1, | ||
providers: [ | ||
@@ -26,16 +20,7 @@ { provide: StorageConfigToken, useValue: storageConfig }, | ||
} | ||
} | ||
IonicStorageModule.decorators = [ | ||
{ type: NgModule }, | ||
]; | ||
function IonicStorageModule_tsickle_Closure_declarations() { | ||
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */ | ||
IonicStorageModule.decorators; | ||
/** | ||
* @nocollapse | ||
* @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>} | ||
*/ | ||
IonicStorageModule.ctorParameters; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AaW9uaWMvc3RvcmFnZS8iLCJzb3VyY2VzIjpbImluZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7QUFBQSxPQUFPLEVBQUUsUUFBUSxFQUF1QixNQUFNLGVBQWUsQ0FBQztBQUM5RCxPQUFPLEVBRUwsY0FBYyxFQUNkLE9BQU8sRUFFUCxrQkFBa0IsRUFDbkIsTUFBTSxXQUFXLENBQUM7QUFFbkIsT0FBTyxFQUFpQixrQkFBa0IsRUFBRSxPQUFPLEVBQUUsQ0FBQztBQUd0RCxNQUFNOzs7OztJQUNKLE1BQU0sQ0FBQyxPQUFPLENBQUMsZ0JBQStCLElBQUk7UUFDaEQsT0FBTztZQUNMLFFBQVEsRUFBRSxrQkFBa0I7WUFDNUIsU0FBUyxFQUFFO2dCQUNULEVBQUUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLFFBQVEsRUFBRSxhQUFhLEVBQUU7Z0JBQ3hEO29CQUNFLE9BQU8sRUFBRSxPQUFPO29CQUNoQixVQUFVLEVBQUUsY0FBYztvQkFDMUIsSUFBSSxFQUFFLENBQUMsa0JBQWtCLENBQUM7aUJBQzNCO2FBQ0Y7U0FDRixDQUFDO0tBQ0g7OztZQWRGLFFBQVEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSwgTW9kdWxlV2l0aFByb3ZpZGVycyB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtcbiAgZ2V0RGVmYXVsdENvbmZpZyxcbiAgcHJvdmlkZVN0b3JhZ2UsXG4gIFN0b3JhZ2UsXG4gIFN0b3JhZ2VDb25maWcsXG4gIFN0b3JhZ2VDb25maWdUb2tlblxufSBmcm9tICcuL3N0b3JhZ2UnO1xuXG5leHBvcnQgeyBTdG9yYWdlQ29uZmlnLCBTdG9yYWdlQ29uZmlnVG9rZW4sIFN0b3JhZ2UgfTtcblxuQE5nTW9kdWxlKClcbmV4cG9ydCBjbGFzcyBJb25pY1N0b3JhZ2VNb2R1bGUge1xuICBzdGF0aWMgZm9yUm9vdChzdG9yYWdlQ29uZmlnOiBTdG9yYWdlQ29uZmlnID0gbnVsbCk6IE1vZHVsZVdpdGhQcm92aWRlcnMge1xuICAgIHJldHVybiB7XG4gICAgICBuZ01vZHVsZTogSW9uaWNTdG9yYWdlTW9kdWxlLFxuICAgICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIHsgcHJvdmlkZTogU3RvcmFnZUNvbmZpZ1Rva2VuLCB1c2VWYWx1ZTogc3RvcmFnZUNvbmZpZyB9LFxuICAgICAgICB7XG4gICAgICAgICAgcHJvdmlkZTogU3RvcmFnZSxcbiAgICAgICAgICB1c2VGYWN0b3J5OiBwcm92aWRlU3RvcmFnZSxcbiAgICAgICAgICBkZXBzOiBbU3RvcmFnZUNvbmZpZ1Rva2VuXVxuICAgICAgICB9XG4gICAgICBdXG4gICAgfTtcbiAgfVxufVxuIl19 | ||
}; | ||
IonicStorageModule = IonicStorageModule_1 = __decorate([ | ||
NgModule() | ||
], IonicStorageModule); | ||
export { IonicStorageModule }; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AaW9uaWMvc3RvcmFnZS8iLCJzb3VyY2VzIjpbImluZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsT0FBTyxFQUFFLFFBQVEsRUFBdUIsTUFBTSxlQUFlLENBQUM7QUFDOUQsT0FBTyxFQUVMLGNBQWMsRUFDZCxPQUFPLEVBRVAsa0JBQWtCLEVBQ25CLE1BQU0sV0FBVyxDQUFDO0FBRW5CLE9BQU8sRUFBaUIsa0JBQWtCLEVBQUUsT0FBTyxFQUFFLENBQUM7QUFHdEQsSUFBYSxrQkFBa0IsMEJBQS9CLE1BQWEsa0JBQWtCO0lBQzdCLE1BQU0sQ0FBQyxPQUFPLENBQUMsZ0JBQStCLElBQUk7UUFDaEQsT0FBTztZQUNMLFFBQVEsRUFBRSxvQkFBa0I7WUFDNUIsU0FBUyxFQUFFO2dCQUNULEVBQUUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLFFBQVEsRUFBRSxhQUFhLEVBQUU7Z0JBQ3hEO29CQUNFLE9BQU8sRUFBRSxPQUFPO29CQUNoQixVQUFVLEVBQUUsY0FBYztvQkFDMUIsSUFBSSxFQUFFLENBQUMsa0JBQWtCLENBQUM7aUJBQzNCO2FBQ0Y7U0FDRixDQUFDO0lBQ0osQ0FBQztDQUNGLENBQUE7QUFkWSxrQkFBa0I7SUFEOUIsUUFBUSxFQUFFO0dBQ0Usa0JBQWtCLENBYzlCO1NBZFksa0JBQWtCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUsIE1vZHVsZVdpdGhQcm92aWRlcnMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7XG4gIGdldERlZmF1bHRDb25maWcsXG4gIHByb3ZpZGVTdG9yYWdlLFxuICBTdG9yYWdlLFxuICBTdG9yYWdlQ29uZmlnLFxuICBTdG9yYWdlQ29uZmlnVG9rZW5cbn0gZnJvbSAnLi9zdG9yYWdlJztcblxuZXhwb3J0IHsgU3RvcmFnZUNvbmZpZywgU3RvcmFnZUNvbmZpZ1Rva2VuLCBTdG9yYWdlIH07XG5cbkBOZ01vZHVsZSgpXG5leHBvcnQgY2xhc3MgSW9uaWNTdG9yYWdlTW9kdWxlIHtcbiAgc3RhdGljIGZvclJvb3Qoc3RvcmFnZUNvbmZpZzogU3RvcmFnZUNvbmZpZyA9IG51bGwpOiBNb2R1bGVXaXRoUHJvdmlkZXJzPElvbmljU3RvcmFnZU1vZHVsZT4ge1xuICAgIHJldHVybiB7XG4gICAgICBuZ01vZHVsZTogSW9uaWNTdG9yYWdlTW9kdWxlLFxuICAgICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIHsgcHJvdmlkZTogU3RvcmFnZUNvbmZpZ1Rva2VuLCB1c2VWYWx1ZTogc3RvcmFnZUNvbmZpZyB9LFxuICAgICAgICB7XG4gICAgICAgICAgcHJvdmlkZTogU3RvcmFnZSxcbiAgICAgICAgICB1c2VGYWN0b3J5OiBwcm92aWRlU3RvcmFnZSxcbiAgICAgICAgICBkZXBzOiBbU3RvcmFnZUNvbmZpZ1Rva2VuXVxuICAgICAgICB9XG4gICAgICBdXG4gICAgfTtcbiAgfVxufVxuIl19 |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes} checked by tsc | ||
*/ | ||
/** | ||
* Generated bundle index. Do not edit. | ||
*/ | ||
export { StorageConfigToken, Storage, IonicStorageModule } from './index'; | ||
export * from './index'; | ||
export { provideStorage as ɵa } from './storage'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW9uaWMtc3RvcmFnZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Bpb25pYy9zdG9yYWdlLyIsInNvdXJjZXMiOlsiaW9uaWMtc3RvcmFnZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBSUEsZ0VBQWMsU0FBUyxDQUFDO0FBRXhCLE9BQU8sRUFBQyxjQUFjLElBQUksRUFBRSxFQUFDLE1BQU0sV0FBVyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcblxuZXhwb3J0IHtwcm92aWRlU3RvcmFnZSBhcyDJtWF9IGZyb20gJy4vc3RvcmFnZSc7Il19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW9uaWMtc3RvcmFnZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Bpb25pYy9zdG9yYWdlLyIsInNvdXJjZXMiOlsiaW9uaWMtc3RvcmFnZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDO0FBRXhCLE9BQU8sRUFBQyxjQUFjLElBQUksRUFBRSxFQUFDLE1BQU0sV0FBVyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcblxuZXhwb3J0IHtwcm92aWRlU3RvcmFnZSBhcyDJtWF9IGZyb20gJy4vc3RvcmFnZSc7Il19 |
@@ -1,5 +0,1 @@ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes} checked by tsc | ||
*/ | ||
import { InjectionToken } from '@angular/core'; | ||
@@ -21,3 +17,3 @@ import * as LocalForage from 'localforage'; | ||
* | ||
* \@usage | ||
* @usage | ||
* First, if you'd like to use SQLite, install the cordova-sqlite-storage plugin: | ||
@@ -30,3 +26,3 @@ * ```bash | ||
* ```bash | ||
* npm install --save \@ionic/storage | ||
* npm install --save @ionic/storage | ||
* ``` | ||
@@ -37,5 +33,5 @@ * | ||
* ```typescript | ||
* import { IonicStorageModule } from '\@ionic/storage'; | ||
* import { IonicStorageModule } from '@ionic/storage'; | ||
* | ||
* \@NgModule({ | ||
* @NgModule({ | ||
* declarations: [ | ||
@@ -58,7 +54,8 @@ * // ... | ||
* export class AppModule {} | ||
* ``` | ||
*``` | ||
* | ||
* Finally, inject it into any of your components or pages: | ||
* ```typescript | ||
* import { Storage } from '\@ionic/storage'; | ||
* import { Storage } from '@ionic/storage'; | ||
* export class MyApp { | ||
@@ -88,5 +85,5 @@ * constructor(private storage: Storage) { } | ||
* ```typescript | ||
* import { IonicStorageModule } from '\@ionic/storage'; | ||
* import { IonicStorageModule } from '@ionic/storage'; | ||
* | ||
* \@NgModule({ | ||
* @NgModule({ | ||
* declarations: [...], | ||
@@ -96,3 +93,3 @@ * imports: [ | ||
* name: '__mydb', | ||
* driverOrder: ['indexeddb', 'sqlite', 'websql'] | ||
driverOrder: ['indexeddb', 'sqlite', 'websql'] | ||
* }) | ||
@@ -114,3 +111,2 @@ * ], | ||
* default is that exact ordering. | ||
* @param {?} config | ||
*/ | ||
@@ -120,5 +116,10 @@ constructor(config) { | ||
this._dbPromise = new Promise((resolve, reject) => { | ||
let /** @type {?} */ db; | ||
const /** @type {?} */ defaultConfig = getDefaultConfig(); | ||
const /** @type {?} */ actualConfig = Object.assign(defaultConfig, config || {}); | ||
if (typeof process !== 'undefined') { | ||
const noopDriver = getNoopDriver(); | ||
resolve(noopDriver); | ||
return; | ||
} | ||
let db; | ||
const defaultConfig = getDefaultConfig(); | ||
const actualConfig = Object.assign(defaultConfig, config || {}); | ||
LocalForage.defineDriver(CordovaSQLiteDriver) | ||
@@ -138,3 +139,3 @@ .then(() => { | ||
* Get the name of the driver being used. | ||
* @return {?} Name of the driver | ||
* @returns Name of the driver | ||
*/ | ||
@@ -146,3 +147,3 @@ get driver() { | ||
* Reflect the readiness of the store. | ||
* @return {?} Returns a promise that resolves when the store is ready | ||
* @returns Returns a promise that resolves when the store is ready | ||
*/ | ||
@@ -152,7 +153,3 @@ ready() { | ||
} | ||
/** | ||
* @hidden | ||
* @param {?} driverOrder | ||
* @return {?} | ||
*/ | ||
/** @hidden */ | ||
_getDriverOrder(driverOrder) { | ||
@@ -174,4 +171,4 @@ return driverOrder.map(driver => { | ||
* Get the value associated with the given key. | ||
* @param {?} key the key to identify this value | ||
* @return {?} Returns a promise with the value of the given key | ||
* @param key the key to identify this value | ||
* @returns Returns a promise with the value of the given key | ||
*/ | ||
@@ -183,5 +180,5 @@ get(key) { | ||
* Set the value for the given key. | ||
* @param {?} key the key to identify this value | ||
* @param {?} value the value for this key | ||
* @return {?} Returns a promise that resolves when the key and value are set | ||
* @param key the key to identify this value | ||
* @param value the value for this key | ||
* @returns Returns a promise that resolves when the key and value are set | ||
*/ | ||
@@ -193,4 +190,4 @@ set(key, value) { | ||
* Remove any value associated with this key. | ||
* @param {?} key the key to identify this value | ||
* @return {?} Returns a promise that resolves when the value is removed | ||
* @param key the key to identify this value | ||
* @returns Returns a promise that resolves when the value is removed | ||
*/ | ||
@@ -202,3 +199,3 @@ remove(key) { | ||
* Clear the entire key value store. WARNING: HOT! | ||
* @return {?} Returns a promise that resolves when the store is cleared | ||
* @returns Returns a promise that resolves when the store is cleared | ||
*/ | ||
@@ -209,3 +206,3 @@ clear() { | ||
/** | ||
* @return {?} Returns a promise that resolves with the number of keys stored. | ||
* @returns Returns a promise that resolves with the number of keys stored. | ||
*/ | ||
@@ -216,3 +213,3 @@ length() { | ||
/** | ||
* @return {?} Returns a promise that resolves with the keys in the store. | ||
* @returns Returns a promise that resolves with the keys in the store. | ||
*/ | ||
@@ -224,4 +221,4 @@ keys() { | ||
* Iterate through each key,value pair. | ||
* @param {?} iteratorCallback a callback of the form (value, key, iterationNumber) | ||
* @return {?} Returns a promise that resolves when the iteration has finished. | ||
* @param iteratorCallback a callback of the form (value, key, iterationNumber) | ||
* @returns Returns a promise that resolves when the iteration has finished. | ||
*/ | ||
@@ -232,12 +229,3 @@ forEach(iteratorCallback) { | ||
} | ||
function Storage_tsickle_Closure_declarations() { | ||
/** @type {?} */ | ||
Storage.prototype._dbPromise; | ||
/** @type {?} */ | ||
Storage.prototype._driver; | ||
} | ||
/** | ||
* @hidden | ||
* @return {?} | ||
*/ | ||
/** @hidden */ | ||
export function getDefaultConfig() { | ||
@@ -251,37 +239,23 @@ return { | ||
} | ||
/** | ||
* @hidden | ||
* @record | ||
*/ | ||
export function StorageConfig() { } | ||
function StorageConfig_tsickle_Closure_declarations() { | ||
/** @type {?|undefined} */ | ||
StorageConfig.prototype.name; | ||
/** @type {?|undefined} */ | ||
StorageConfig.prototype.version; | ||
/** @type {?|undefined} */ | ||
StorageConfig.prototype.size; | ||
/** @type {?|undefined} */ | ||
StorageConfig.prototype.storeName; | ||
/** @type {?|undefined} */ | ||
StorageConfig.prototype.description; | ||
/** @type {?|undefined} */ | ||
StorageConfig.prototype.driverOrder; | ||
/** @type {?|undefined} */ | ||
StorageConfig.prototype.dbKey; | ||
} | ||
/** | ||
* @hidden | ||
*/ | ||
export const /** @type {?} */ StorageConfigToken = new InjectionToken('STORAGE_CONFIG_TOKEN'); | ||
/** | ||
* @hidden | ||
* @param {?} storageConfig | ||
* @return {?} | ||
*/ | ||
/** @hidden */ | ||
export const StorageConfigToken = new InjectionToken('STORAGE_CONFIG_TOKEN'); | ||
/** @hidden */ | ||
export function provideStorage(storageConfig) { | ||
const /** @type {?} */ config = !!storageConfig ? storageConfig : getDefaultConfig(); | ||
const config = !!storageConfig ? storageConfig : getDefaultConfig(); | ||
return new Storage(config); | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"storage.js","sourceRoot":"ng://@ionic/storage/","sources":["storage.ts"],"names":[],"mappings":"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","sourcesContent":["import { InjectionToken } from '@angular/core';\n\nimport * as LocalForage from 'localforage';\n\nimport * as CordovaSQLiteDriver from 'localforage-cordovasqlitedriver';\n\n/**\n * Storage is an easy way to store key/value pairs and JSON objects.\n * Storage uses a variety of storage engines underneath, picking the best one available\n * depending on the platform.\n *\n * When running in a native app context, Storage will prioritize using SQLite, as it's one of\n * the most stable and widely used file-based databases, and avoids some of the\n * pitfalls of things like localstorage and IndexedDB, such as the OS deciding to clear out such\n * data in low disk-space situations.\n *\n * When running in the web or as a Progressive Web App, Storage will attempt to use\n * IndexedDB, WebSQL, and localstorage, in that order.\n *\n * @usage\n * First, if you'd like to use SQLite, install the cordova-sqlite-storage plugin:\n * ```bash\n * ionic cordova plugin add cordova-sqlite-storage\n * ```\n *\n * Next, install the package (comes by default for Ionic apps > Ionic V1):\n * ```bash\n * npm install --save @ionic/storage\n * ```\n *\n * Next, add it to the imports list in your `NgModule` declaration (for example, in `src/app/app.module.ts`):\n *\n * ```typescript\n * import { IonicStorageModule } from '@ionic/storage';\n *\n * @NgModule({\n *   declarations: [\n *     // ...\n *   ],\n *   imports: [\n *     BrowserModule,\n *     IonicModule.forRoot(MyApp),\n *     IonicStorageModule.forRoot()\n *   ],\n *   bootstrap: [IonicApp],\n *   entryComponents: [\n *     // ...\n *   ],\n *   providers: [\n *     // ...\n *   ]\n * })\n * export class AppModule {}\n *```\n *\n * Finally, inject it into any of your components or pages:\n * ```typescript\n * import { Storage } from '@ionic/storage';\n\n * export class MyApp {\n *   constructor(private storage: Storage) { }\n *\n *   ...\n *\n *   // set a key/value\n *   storage.set('name', 'Max');\n *\n *   // Or to get a key/value pair\n *   storage.get('age').then((val) => {\n *     console.log('Your age is', val);\n *   });\n * }\n * ```\n *\n *\n * ### Configuring Storage\n *\n * The Storage engine can be configured both with specific storage engine priorities, or custom configuration\n * options to pass to localForage. See the localForage config docs for possible options: https://github.com/localForage/localForage#configuration\n *\n * Note: Any custom configurations will be merged with the default configuration\n *\n * ```typescript\n * import { IonicStorageModule } from '@ionic/storage';\n *\n * @NgModule({\n *   declarations: [...],\n *   imports: [\n *     IonicStorageModule.forRoot({\n *       name: '__mydb',\n         driverOrder: ['indexeddb', 'sqlite', 'websql']\n *     })\n *   ],\n *   bootstrap: [...],\n *   entryComponents: [...],\n *    providers: [...]\n * })\n * export class AppModule { }\n * ```\n */\nexport class Storage {\n  private _dbPromise: Promise<LocalForage>;\n  private _driver: string = null;\n\n  /**\n   * Create a new Storage instance using the order of drivers and any additional config\n   * options to pass to LocalForage.\n   *\n   * Possible driver options are: ['sqlite', 'indexeddb', 'websql', 'localstorage'] and the\n   * default is that exact ordering.\n   */\n  constructor(config: StorageConfig) {\n    this._dbPromise = new Promise((resolve, reject) => {\n      let db: LocalForage;\n\n      const defaultConfig = getDefaultConfig();\n      const actualConfig = Object.assign(defaultConfig, config || {});\n\n      LocalForage.defineDriver(CordovaSQLiteDriver)\n        .then(() => {\n          db = LocalForage.createInstance(actualConfig);\n        })\n        .then(() =>\n          db.setDriver(this._getDriverOrder(actualConfig.driverOrder))\n        )\n        .then(() => {\n          this._driver = db.driver();\n          resolve(db);\n        })\n        .catch(reason => reject(reason));\n    });\n  }\n\n  /**\n   * Get the name of the driver being used.\n   * @returns Name of the driver\n   */\n  get driver(): string | null {\n    return this._driver;\n  }\n\n  /**\n   * Reflect the readiness of the store.\n   * @returns Returns a promise that resolves when the store is ready\n   */\n  ready(): Promise<LocalForage> {\n    return this._dbPromise;\n  }\n\n  /** @hidden */\n  private _getDriverOrder(driverOrder) {\n    return driverOrder.map(driver => {\n      switch (driver) {\n        case 'sqlite':\n          return CordovaSQLiteDriver._driver;\n        case 'indexeddb':\n          return LocalForage.INDEXEDDB;\n        case 'websql':\n          return LocalForage.WEBSQL;\n        case 'localstorage':\n          return LocalForage.LOCALSTORAGE;\n      }\n    });\n  }\n\n  /**\n   * Get the value associated with the given key.\n   * @param key the key to identify this value\n   * @returns Returns a promise with the value of the given key\n   */\n  get(key: string): Promise<any> {\n    return this._dbPromise.then(db => db.getItem(key));\n  }\n\n  /**\n   * Set the value for the given key.\n   * @param key the key to identify this value\n   * @param value the value for this key\n   * @returns Returns a promise that resolves when the key and value are set\n   */\n  set(key: string, value: any): Promise<any> {\n    return this._dbPromise.then(db => db.setItem(key, value));\n  }\n\n  /**\n   * Remove any value associated with this key.\n   * @param key the key to identify this value\n   * @returns Returns a promise that resolves when the value is removed\n   */\n  remove(key: string): Promise<any> {\n    return this._dbPromise.then(db => db.removeItem(key));\n  }\n\n  /**\n   * Clear the entire key value store. WARNING: HOT!\n   * @returns Returns a promise that resolves when the store is cleared\n   */\n  clear(): Promise<void> {\n    return this._dbPromise.then(db => db.clear());\n  }\n\n  /**\n   * @returns Returns a promise that resolves with the number of keys stored.\n   */\n  length(): Promise<number> {\n    return this._dbPromise.then(db => db.length());\n  }\n\n  /**\n   * @returns Returns a promise that resolves with the keys in the store.\n   */\n  keys(): Promise<string[]> {\n    return this._dbPromise.then(db => db.keys());\n  }\n\n  /**\n   * Iterate through each key,value pair.\n   * @param iteratorCallback a callback of the form (value, key, iterationNumber)\n   * @returns Returns a promise that resolves when the iteration has finished.\n   */\n  forEach(\n    iteratorCallback: (value: any, key: string, iterationNumber: Number) => any\n  ): Promise<void> {\n    return this._dbPromise.then(db => db.iterate(iteratorCallback));\n  }\n}\n\n/** @hidden */\nexport function getDefaultConfig() {\n  return {\n    name: '_ionicstorage',\n    storeName: '_ionickv',\n    dbKey: '_ionickey',\n    driverOrder: ['sqlite', 'indexeddb', 'websql', 'localstorage']\n  };\n}\n\n/** @hidden */\nexport interface StorageConfig {\n  name?: string;\n  version?: number;\n  size?: number;\n  storeName?: string;\n  description?: string;\n  driverOrder?: string[];\n  dbKey?: string;\n}\n\n/** @hidden */\nexport const StorageConfigToken = new InjectionToken<any>(\n  'STORAGE_CONFIG_TOKEN'\n);\n\n/** @hidden */\nexport function provideStorage(storageConfig: StorageConfig): Storage {\n  const config = !!storageConfig ? storageConfig : getDefaultConfig();\n  return new Storage(config);\n}\n"]} | ||
function getNoopDriver() { | ||
// noop driver for ssr environment | ||
const noop = () => { }; | ||
const driver = { | ||
getItem: noop, | ||
setItem: noop, | ||
removeItem: noop, | ||
clear: noop, | ||
length: () => 0, | ||
keys: () => [], | ||
iterate: noop | ||
}; | ||
return driver; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"storage.js","sourceRoot":"ng://@ionic/storage/","sources":["storage.ts"],"names":[],"mappings":"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","sourcesContent":["import { InjectionToken } from '@angular/core';\n\nimport * as LocalForage from 'localforage';\n\nimport * as CordovaSQLiteDriver from 'localforage-cordovasqlitedriver';\n\n/**\n * Storage is an easy way to store key/value pairs and JSON objects.\n * Storage uses a variety of storage engines underneath, picking the best one available\n * depending on the platform.\n *\n * When running in a native app context, Storage will prioritize using SQLite, as it's one of\n * the most stable and widely used file-based databases, and avoids some of the\n * pitfalls of things like localstorage and IndexedDB, such as the OS deciding to clear out such\n * data in low disk-space situations.\n *\n * When running in the web or as a Progressive Web App, Storage will attempt to use\n * IndexedDB, WebSQL, and localstorage, in that order.\n *\n * @usage\n * First, if you'd like to use SQLite, install the cordova-sqlite-storage plugin:\n * ```bash\n * ionic cordova plugin add cordova-sqlite-storage\n * ```\n *\n * Next, install the package (comes by default for Ionic apps > Ionic V1):\n * ```bash\n * npm install --save @ionic/storage\n * ```\n *\n * Next, add it to the imports list in your `NgModule` declaration (for example, in `src/app/app.module.ts`):\n *\n * ```typescript\n * import { IonicStorageModule } from '@ionic/storage';\n *\n * @NgModule({\n *   declarations: [\n *     // ...\n *   ],\n *   imports: [\n *     BrowserModule,\n *     IonicModule.forRoot(MyApp),\n *     IonicStorageModule.forRoot()\n *   ],\n *   bootstrap: [IonicApp],\n *   entryComponents: [\n *     // ...\n *   ],\n *   providers: [\n *     // ...\n *   ]\n * })\n * export class AppModule {}\n *```\n *\n * Finally, inject it into any of your components or pages:\n * ```typescript\n * import { Storage } from '@ionic/storage';\n\n * export class MyApp {\n *   constructor(private storage: Storage) { }\n *\n *   ...\n *\n *   // set a key/value\n *   storage.set('name', 'Max');\n *\n *   // Or to get a key/value pair\n *   storage.get('age').then((val) => {\n *     console.log('Your age is', val);\n *   });\n * }\n * ```\n *\n *\n * ### Configuring Storage\n *\n * The Storage engine can be configured both with specific storage engine priorities, or custom configuration\n * options to pass to localForage. See the localForage config docs for possible options: https://github.com/localForage/localForage#configuration\n *\n * Note: Any custom configurations will be merged with the default configuration\n *\n * ```typescript\n * import { IonicStorageModule } from '@ionic/storage';\n *\n * @NgModule({\n *   declarations: [...],\n *   imports: [\n *     IonicStorageModule.forRoot({\n *       name: '__mydb',\n         driverOrder: ['indexeddb', 'sqlite', 'websql']\n *     })\n *   ],\n *   bootstrap: [...],\n *   entryComponents: [...],\n *    providers: [...]\n * })\n * export class AppModule { }\n * ```\n */\nexport class Storage {\n  private _dbPromise: Promise<LocalForage>;\n  private _driver: string = null;\n\n  /**\n   * Create a new Storage instance using the order of drivers and any additional config\n   * options to pass to LocalForage.\n   *\n   * Possible driver options are: ['sqlite', 'indexeddb', 'websql', 'localstorage'] and the\n   * default is that exact ordering.\n   */\n  constructor(config: StorageConfig) {\n    this._dbPromise = new Promise((resolve, reject) => {\n      if (typeof process !== 'undefined') {\n        const noopDriver = getNoopDriver();\n        resolve(noopDriver);\n        return;\n      }\n\n      let db: LocalForage;\n\n      const defaultConfig = getDefaultConfig();\n      const actualConfig = Object.assign(defaultConfig, config || {});\n\n      LocalForage.defineDriver(CordovaSQLiteDriver)\n        .then(() => {\n          db = LocalForage.createInstance(actualConfig);\n        })\n        .then(() =>\n          db.setDriver(this._getDriverOrder(actualConfig.driverOrder))\n        )\n        .then(() => {\n          this._driver = db.driver();\n          resolve(db);\n        })\n        .catch(reason => reject(reason));\n    });\n  }\n\n  /**\n   * Get the name of the driver being used.\n   * @returns Name of the driver\n   */\n  get driver(): string | null {\n    return this._driver;\n  }\n\n  /**\n   * Reflect the readiness of the store.\n   * @returns Returns a promise that resolves when the store is ready\n   */\n  ready(): Promise<LocalForage> {\n    return this._dbPromise;\n  }\n\n  /** @hidden */\n  private _getDriverOrder(driverOrder) {\n    return driverOrder.map(driver => {\n      switch (driver) {\n        case 'sqlite':\n          return CordovaSQLiteDriver._driver;\n        case 'indexeddb':\n          return LocalForage.INDEXEDDB;\n        case 'websql':\n          return LocalForage.WEBSQL;\n        case 'localstorage':\n          return LocalForage.LOCALSTORAGE;\n      }\n    });\n  }\n\n  /**\n   * Get the value associated with the given key.\n   * @param key the key to identify this value\n   * @returns Returns a promise with the value of the given key\n   */\n  get(key: string): Promise<any> {\n    return this._dbPromise.then(db => db.getItem(key));\n  }\n\n  /**\n   * Set the value for the given key.\n   * @param key the key to identify this value\n   * @param value the value for this key\n   * @returns Returns a promise that resolves when the key and value are set\n   */\n  set(key: string, value: any): Promise<any> {\n    return this._dbPromise.then(db => db.setItem(key, value));\n  }\n\n  /**\n   * Remove any value associated with this key.\n   * @param key the key to identify this value\n   * @returns Returns a promise that resolves when the value is removed\n   */\n  remove(key: string): Promise<any> {\n    return this._dbPromise.then(db => db.removeItem(key));\n  }\n\n  /**\n   * Clear the entire key value store. WARNING: HOT!\n   * @returns Returns a promise that resolves when the store is cleared\n   */\n  clear(): Promise<void> {\n    return this._dbPromise.then(db => db.clear());\n  }\n\n  /**\n   * @returns Returns a promise that resolves with the number of keys stored.\n   */\n  length(): Promise<number> {\n    return this._dbPromise.then(db => db.length());\n  }\n\n  /**\n   * @returns Returns a promise that resolves with the keys in the store.\n   */\n  keys(): Promise<string[]> {\n    return this._dbPromise.then(db => db.keys());\n  }\n\n  /**\n   * Iterate through each key,value pair.\n   * @param iteratorCallback a callback of the form (value, key, iterationNumber)\n   * @returns Returns a promise that resolves when the iteration has finished.\n   */\n  forEach(\n    iteratorCallback: (value: any, key: string, iterationNumber: Number) => any\n  ): Promise<void> {\n    return this._dbPromise.then(db => db.iterate(iteratorCallback));\n  }\n}\n\n/** @hidden */\nexport function getDefaultConfig() {\n  return {\n    name: '_ionicstorage',\n    storeName: '_ionickv',\n    dbKey: '_ionickey',\n    driverOrder: ['sqlite', 'indexeddb', 'websql', 'localstorage']\n  };\n}\n\n/** @hidden */\nexport interface StorageConfig {\n  name?: string;\n  version?: number;\n  size?: number;\n  storeName?: string;\n  description?: string;\n  driverOrder?: string[];\n  dbKey?: string;\n}\n\n/** @hidden */\nexport const StorageConfigToken = new InjectionToken<any>(\n  'STORAGE_CONFIG_TOKEN'\n);\n\n/** @hidden */\nexport function provideStorage(storageConfig: StorageConfig): Storage {\n  const config = !!storageConfig ? storageConfig : getDefaultConfig();\n  return new Storage(config);\n}\n\nfunction getNoopDriver() {\n  // noop driver for ssr environment\n  const noop = () => {};\n  const driver: any = {\n    getItem: noop,\n    setItem: noop,\n    removeItem: noop,\n    clear: noop,\n    length: () => 0,\n    keys: () => [],\n    iterate: noop\n  };\n  return driver;\n}"]} |
@@ -1,5 +0,2 @@ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes} checked by tsc | ||
*/ | ||
import { __decorate } from "tslib"; | ||
import { NgModule } from '@angular/core'; | ||
@@ -11,14 +8,7 @@ import { provideStorage, Storage, StorageConfigToken } from './storage'; | ||
} | ||
/** | ||
* @param {?=} storageConfig | ||
* @return {?} | ||
*/ | ||
IonicStorageModule.forRoot = /** | ||
* @param {?=} storageConfig | ||
* @return {?} | ||
*/ | ||
function (storageConfig) { | ||
IonicStorageModule_1 = IonicStorageModule; | ||
IonicStorageModule.forRoot = function (storageConfig) { | ||
if (storageConfig === void 0) { storageConfig = null; } | ||
return { | ||
ngModule: IonicStorageModule, | ||
ngModule: IonicStorageModule_1, | ||
providers: [ | ||
@@ -34,18 +24,9 @@ { provide: StorageConfigToken, useValue: storageConfig }, | ||
}; | ||
IonicStorageModule.decorators = [ | ||
{ type: NgModule }, | ||
]; | ||
var IonicStorageModule_1; | ||
IonicStorageModule = IonicStorageModule_1 = __decorate([ | ||
NgModule() | ||
], IonicStorageModule); | ||
return IonicStorageModule; | ||
}()); | ||
export { IonicStorageModule }; | ||
function IonicStorageModule_tsickle_Closure_declarations() { | ||
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */ | ||
IonicStorageModule.decorators; | ||
/** | ||
* @nocollapse | ||
* @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>} | ||
*/ | ||
IonicStorageModule.ctorParameters; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AaW9uaWMvc3RvcmFnZS8iLCJzb3VyY2VzIjpbImluZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7QUFBQSxPQUFPLEVBQUUsUUFBUSxFQUF1QixNQUFNLGVBQWUsQ0FBQztBQUM5RCxPQUFPLEVBRUwsY0FBYyxFQUNkLE9BQU8sRUFFUCxrQkFBa0IsRUFDbkIsTUFBTSxXQUFXLENBQUM7QUFFbkIsT0FBTyxFQUFpQixrQkFBa0IsRUFBRSxPQUFPLEVBQUUsQ0FBQzs7Ozs7Ozs7SUFJN0MsMEJBQU87Ozs7SUFBZCxVQUFlLGFBQW1DO1FBQW5DLDhCQUFBLEVBQUEsb0JBQW1DO1FBQ2hELE9BQU87WUFDTCxRQUFRLEVBQUUsa0JBQWtCO1lBQzVCLFNBQVMsRUFBRTtnQkFDVCxFQUFFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxRQUFRLEVBQUUsYUFBYSxFQUFFO2dCQUN4RDtvQkFDRSxPQUFPLEVBQUUsT0FBTztvQkFDaEIsVUFBVSxFQUFFLGNBQWM7b0JBQzFCLElBQUksRUFBRSxDQUFDLGtCQUFrQixDQUFDO2lCQUMzQjthQUNGO1NBQ0YsQ0FBQztLQUNIOztnQkFkRixRQUFROzs2QkFYVDs7U0FZYSxrQkFBa0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSwgTW9kdWxlV2l0aFByb3ZpZGVycyB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtcbiAgZ2V0RGVmYXVsdENvbmZpZyxcbiAgcHJvdmlkZVN0b3JhZ2UsXG4gIFN0b3JhZ2UsXG4gIFN0b3JhZ2VDb25maWcsXG4gIFN0b3JhZ2VDb25maWdUb2tlblxufSBmcm9tICcuL3N0b3JhZ2UnO1xuXG5leHBvcnQgeyBTdG9yYWdlQ29uZmlnLCBTdG9yYWdlQ29uZmlnVG9rZW4sIFN0b3JhZ2UgfTtcblxuQE5nTW9kdWxlKClcbmV4cG9ydCBjbGFzcyBJb25pY1N0b3JhZ2VNb2R1bGUge1xuICBzdGF0aWMgZm9yUm9vdChzdG9yYWdlQ29uZmlnOiBTdG9yYWdlQ29uZmlnID0gbnVsbCk6IE1vZHVsZVdpdGhQcm92aWRlcnMge1xuICAgIHJldHVybiB7XG4gICAgICBuZ01vZHVsZTogSW9uaWNTdG9yYWdlTW9kdWxlLFxuICAgICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIHsgcHJvdmlkZTogU3RvcmFnZUNvbmZpZ1Rva2VuLCB1c2VWYWx1ZTogc3RvcmFnZUNvbmZpZyB9LFxuICAgICAgICB7XG4gICAgICAgICAgcHJvdmlkZTogU3RvcmFnZSxcbiAgICAgICAgICB1c2VGYWN0b3J5OiBwcm92aWRlU3RvcmFnZSxcbiAgICAgICAgICBkZXBzOiBbU3RvcmFnZUNvbmZpZ1Rva2VuXVxuICAgICAgICB9XG4gICAgICBdXG4gICAgfTtcbiAgfVxufVxuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AaW9uaWMvc3RvcmFnZS8iLCJzb3VyY2VzIjpbImluZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsUUFBUSxFQUF1QixNQUFNLGVBQWUsQ0FBQztBQUM5RCxPQUFPLEVBRUwsY0FBYyxFQUNkLE9BQU8sRUFFUCxrQkFBa0IsRUFDbkIsTUFBTSxXQUFXLENBQUM7QUFFbkIsT0FBTyxFQUFpQixrQkFBa0IsRUFBRSxPQUFPLEVBQUUsQ0FBQztBQUd0RDtJQUFBO0lBY0EsQ0FBQzsyQkFkWSxrQkFBa0I7SUFDdEIsMEJBQU8sR0FBZCxVQUFlLGFBQW1DO1FBQW5DLDhCQUFBLEVBQUEsb0JBQW1DO1FBQ2hELE9BQU87WUFDTCxRQUFRLEVBQUUsb0JBQWtCO1lBQzVCLFNBQVMsRUFBRTtnQkFDVCxFQUFFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxRQUFRLEVBQUUsYUFBYSxFQUFFO2dCQUN4RDtvQkFDRSxPQUFPLEVBQUUsT0FBTztvQkFDaEIsVUFBVSxFQUFFLGNBQWM7b0JBQzFCLElBQUksRUFBRSxDQUFDLGtCQUFrQixDQUFDO2lCQUMzQjthQUNGO1NBQ0YsQ0FBQztJQUNKLENBQUM7O0lBYlUsa0JBQWtCO1FBRDlCLFFBQVEsRUFBRTtPQUNFLGtCQUFrQixDQWM5QjtJQUFELHlCQUFDO0NBQUEsQUFkRCxJQWNDO1NBZFksa0JBQWtCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUsIE1vZHVsZVdpdGhQcm92aWRlcnMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7XG4gIGdldERlZmF1bHRDb25maWcsXG4gIHByb3ZpZGVTdG9yYWdlLFxuICBTdG9yYWdlLFxuICBTdG9yYWdlQ29uZmlnLFxuICBTdG9yYWdlQ29uZmlnVG9rZW5cbn0gZnJvbSAnLi9zdG9yYWdlJztcblxuZXhwb3J0IHsgU3RvcmFnZUNvbmZpZywgU3RvcmFnZUNvbmZpZ1Rva2VuLCBTdG9yYWdlIH07XG5cbkBOZ01vZHVsZSgpXG5leHBvcnQgY2xhc3MgSW9uaWNTdG9yYWdlTW9kdWxlIHtcbiAgc3RhdGljIGZvclJvb3Qoc3RvcmFnZUNvbmZpZzogU3RvcmFnZUNvbmZpZyA9IG51bGwpOiBNb2R1bGVXaXRoUHJvdmlkZXJzPElvbmljU3RvcmFnZU1vZHVsZT4ge1xuICAgIHJldHVybiB7XG4gICAgICBuZ01vZHVsZTogSW9uaWNTdG9yYWdlTW9kdWxlLFxuICAgICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIHsgcHJvdmlkZTogU3RvcmFnZUNvbmZpZ1Rva2VuLCB1c2VWYWx1ZTogc3RvcmFnZUNvbmZpZyB9LFxuICAgICAgICB7XG4gICAgICAgICAgcHJvdmlkZTogU3RvcmFnZSxcbiAgICAgICAgICB1c2VGYWN0b3J5OiBwcm92aWRlU3RvcmFnZSxcbiAgICAgICAgICBkZXBzOiBbU3RvcmFnZUNvbmZpZ1Rva2VuXVxuICAgICAgICB9XG4gICAgICBdXG4gICAgfTtcbiAgfVxufVxuIl19 |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes} checked by tsc | ||
*/ | ||
/** | ||
* Generated bundle index. Do not edit. | ||
*/ | ||
export { StorageConfigToken, Storage, IonicStorageModule } from './index'; | ||
export * from './index'; | ||
export { provideStorage as ɵa } from './storage'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW9uaWMtc3RvcmFnZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Bpb25pYy9zdG9yYWdlLyIsInNvdXJjZXMiOlsiaW9uaWMtc3RvcmFnZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBSUEsZ0VBQWMsU0FBUyxDQUFDO0FBRXhCLE9BQU8sRUFBQyxjQUFjLElBQUksRUFBRSxFQUFDLE1BQU0sV0FBVyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcblxuZXhwb3J0IHtwcm92aWRlU3RvcmFnZSBhcyDJtWF9IGZyb20gJy4vc3RvcmFnZSc7Il19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW9uaWMtc3RvcmFnZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Bpb25pYy9zdG9yYWdlLyIsInNvdXJjZXMiOlsiaW9uaWMtc3RvcmFnZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDO0FBRXhCLE9BQU8sRUFBQyxjQUFjLElBQUksRUFBRSxFQUFDLE1BQU0sV0FBVyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcblxuZXhwb3J0IHtwcm92aWRlU3RvcmFnZSBhcyDJtWF9IGZyb20gJy4vc3RvcmFnZSc7Il19 |
@@ -1,5 +0,1 @@ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes} checked by tsc | ||
*/ | ||
import { InjectionToken } from '@angular/core'; | ||
@@ -21,3 +17,3 @@ import * as LocalForage from 'localforage'; | ||
* | ||
* \@usage | ||
* @usage | ||
* First, if you'd like to use SQLite, install the cordova-sqlite-storage plugin: | ||
@@ -30,3 +26,3 @@ * ```bash | ||
* ```bash | ||
* npm install --save \@ionic/storage | ||
* npm install --save @ionic/storage | ||
* ``` | ||
@@ -37,5 +33,5 @@ * | ||
* ```typescript | ||
* import { IonicStorageModule } from '\@ionic/storage'; | ||
* import { IonicStorageModule } from '@ionic/storage'; | ||
* | ||
* \@NgModule({ | ||
* @NgModule({ | ||
* declarations: [ | ||
@@ -58,7 +54,8 @@ * // ... | ||
* export class AppModule {} | ||
* ``` | ||
*``` | ||
* | ||
* Finally, inject it into any of your components or pages: | ||
* ```typescript | ||
* import { Storage } from '\@ionic/storage'; | ||
* import { Storage } from '@ionic/storage'; | ||
* export class MyApp { | ||
@@ -88,5 +85,5 @@ * constructor(private storage: Storage) { } | ||
* ```typescript | ||
* import { IonicStorageModule } from '\@ionic/storage'; | ||
* import { IonicStorageModule } from '@ionic/storage'; | ||
* | ||
* \@NgModule({ | ||
* @NgModule({ | ||
* declarations: [...], | ||
@@ -96,3 +93,3 @@ * imports: [ | ||
* name: '__mydb', | ||
* driverOrder: ['indexeddb', 'sqlite', 'websql'] | ||
driverOrder: ['indexeddb', 'sqlite', 'websql'] | ||
* }) | ||
@@ -107,96 +104,3 @@ * ], | ||
*/ | ||
var /** | ||
* Storage is an easy way to store key/value pairs and JSON objects. | ||
* Storage uses a variety of storage engines underneath, picking the best one available | ||
* depending on the platform. | ||
* | ||
* When running in a native app context, Storage will prioritize using SQLite, as it's one of | ||
* the most stable and widely used file-based databases, and avoids some of the | ||
* pitfalls of things like localstorage and IndexedDB, such as the OS deciding to clear out such | ||
* data in low disk-space situations. | ||
* | ||
* When running in the web or as a Progressive Web App, Storage will attempt to use | ||
* IndexedDB, WebSQL, and localstorage, in that order. | ||
* | ||
* \@usage | ||
* First, if you'd like to use SQLite, install the cordova-sqlite-storage plugin: | ||
* ```bash | ||
* ionic cordova plugin add cordova-sqlite-storage | ||
* ``` | ||
* | ||
* Next, install the package (comes by default for Ionic apps > Ionic V1): | ||
* ```bash | ||
* npm install --save \@ionic/storage | ||
* ``` | ||
* | ||
* Next, add it to the imports list in your `NgModule` declaration (for example, in `src/app/app.module.ts`): | ||
* | ||
* ```typescript | ||
* import { IonicStorageModule } from '\@ionic/storage'; | ||
* | ||
* \@NgModule({ | ||
* declarations: [ | ||
* // ... | ||
* ], | ||
* imports: [ | ||
* BrowserModule, | ||
* IonicModule.forRoot(MyApp), | ||
* IonicStorageModule.forRoot() | ||
* ], | ||
* bootstrap: [IonicApp], | ||
* entryComponents: [ | ||
* // ... | ||
* ], | ||
* providers: [ | ||
* // ... | ||
* ] | ||
* }) | ||
* export class AppModule {} | ||
* ``` | ||
* | ||
* Finally, inject it into any of your components or pages: | ||
* ```typescript | ||
* import { Storage } from '\@ionic/storage'; | ||
* export class MyApp { | ||
* constructor(private storage: Storage) { } | ||
* | ||
* ... | ||
* | ||
* // set a key/value | ||
* storage.set('name', 'Max'); | ||
* | ||
* // Or to get a key/value pair | ||
* storage.get('age').then((val) => { | ||
* console.log('Your age is', val); | ||
* }); | ||
* } | ||
* ``` | ||
* | ||
* | ||
* ### Configuring Storage | ||
* | ||
* The Storage engine can be configured both with specific storage engine priorities, or custom configuration | ||
* options to pass to localForage. See the localForage config docs for possible options: https://github.com/localForage/localForage#configuration | ||
* | ||
* Note: Any custom configurations will be merged with the default configuration | ||
* | ||
* ```typescript | ||
* import { IonicStorageModule } from '\@ionic/storage'; | ||
* | ||
* \@NgModule({ | ||
* declarations: [...], | ||
* imports: [ | ||
* IonicStorageModule.forRoot({ | ||
* name: '__mydb', | ||
* driverOrder: ['indexeddb', 'sqlite', 'websql'] | ||
* }) | ||
* ], | ||
* bootstrap: [...], | ||
* entryComponents: [...], | ||
* providers: [...] | ||
* }) | ||
* export class AppModule { } | ||
* ``` | ||
*/ | ||
Storage = /** @class */ (function () { | ||
var Storage = /** @class */ (function () { | ||
/** | ||
@@ -213,5 +117,10 @@ * Create a new Storage instance using the order of drivers and any additional config | ||
this._dbPromise = new Promise(function (resolve, reject) { | ||
var /** @type {?} */ db; | ||
var /** @type {?} */ defaultConfig = getDefaultConfig(); | ||
var /** @type {?} */ actualConfig = Object.assign(defaultConfig, config || {}); | ||
if (typeof process !== 'undefined') { | ||
var noopDriver = getNoopDriver(); | ||
resolve(noopDriver); | ||
return; | ||
} | ||
var db; | ||
var defaultConfig = getDefaultConfig(); | ||
var actualConfig = Object.assign(defaultConfig, config || {}); | ||
LocalForage.defineDriver(CordovaSQLiteDriver) | ||
@@ -236,7 +145,3 @@ .then(function () { | ||
*/ | ||
get: /** | ||
* Get the name of the driver being used. | ||
* @return {?} Name of the driver | ||
*/ | ||
function () { | ||
get: function () { | ||
return this._driver; | ||
@@ -251,24 +156,7 @@ }, | ||
*/ | ||
/** | ||
* Reflect the readiness of the store. | ||
* @return {?} Returns a promise that resolves when the store is ready | ||
*/ | ||
Storage.prototype.ready = /** | ||
* Reflect the readiness of the store. | ||
* @return {?} Returns a promise that resolves when the store is ready | ||
*/ | ||
function () { | ||
Storage.prototype.ready = function () { | ||
return this._dbPromise; | ||
}; | ||
/** | ||
* @hidden | ||
* @param {?} driverOrder | ||
* @return {?} | ||
*/ | ||
Storage.prototype._getDriverOrder = /** | ||
* @hidden | ||
* @param {?} driverOrder | ||
* @return {?} | ||
*/ | ||
function (driverOrder) { | ||
/** @hidden */ | ||
Storage.prototype._getDriverOrder = function (driverOrder) { | ||
return driverOrder.map(function (driver) { | ||
@@ -292,13 +180,3 @@ switch (driver) { | ||
*/ | ||
/** | ||
* Get the value associated with the given key. | ||
* @param {?} key the key to identify this value | ||
* @return {?} Returns a promise with the value of the given key | ||
*/ | ||
Storage.prototype.get = /** | ||
* Get the value associated with the given key. | ||
* @param {?} key the key to identify this value | ||
* @return {?} Returns a promise with the value of the given key | ||
*/ | ||
function (key) { | ||
Storage.prototype.get = function (key) { | ||
return this._dbPromise.then(function (db) { return db.getItem(key); }); | ||
@@ -312,15 +190,3 @@ }; | ||
*/ | ||
/** | ||
* Set the value for the given key. | ||
* @param {?} key the key to identify this value | ||
* @param {?} value the value for this key | ||
* @return {?} Returns a promise that resolves when the key and value are set | ||
*/ | ||
Storage.prototype.set = /** | ||
* Set the value for the given key. | ||
* @param {?} key the key to identify this value | ||
* @param {?} value the value for this key | ||
* @return {?} Returns a promise that resolves when the key and value are set | ||
*/ | ||
function (key, value) { | ||
Storage.prototype.set = function (key, value) { | ||
return this._dbPromise.then(function (db) { return db.setItem(key, value); }); | ||
@@ -333,13 +199,3 @@ }; | ||
*/ | ||
/** | ||
* Remove any value associated with this key. | ||
* @param {?} key the key to identify this value | ||
* @return {?} Returns a promise that resolves when the value is removed | ||
*/ | ||
Storage.prototype.remove = /** | ||
* Remove any value associated with this key. | ||
* @param {?} key the key to identify this value | ||
* @return {?} Returns a promise that resolves when the value is removed | ||
*/ | ||
function (key) { | ||
Storage.prototype.remove = function (key) { | ||
return this._dbPromise.then(function (db) { return db.removeItem(key); }); | ||
@@ -351,11 +207,3 @@ }; | ||
*/ | ||
/** | ||
* Clear the entire key value store. WARNING: HOT! | ||
* @return {?} Returns a promise that resolves when the store is cleared | ||
*/ | ||
Storage.prototype.clear = /** | ||
* Clear the entire key value store. WARNING: HOT! | ||
* @return {?} Returns a promise that resolves when the store is cleared | ||
*/ | ||
function () { | ||
Storage.prototype.clear = function () { | ||
return this._dbPromise.then(function (db) { return db.clear(); }); | ||
@@ -366,9 +214,3 @@ }; | ||
*/ | ||
/** | ||
* @return {?} Returns a promise that resolves with the number of keys stored. | ||
*/ | ||
Storage.prototype.length = /** | ||
* @return {?} Returns a promise that resolves with the number of keys stored. | ||
*/ | ||
function () { | ||
Storage.prototype.length = function () { | ||
return this._dbPromise.then(function (db) { return db.length(); }); | ||
@@ -379,9 +221,3 @@ }; | ||
*/ | ||
/** | ||
* @return {?} Returns a promise that resolves with the keys in the store. | ||
*/ | ||
Storage.prototype.keys = /** | ||
* @return {?} Returns a promise that resolves with the keys in the store. | ||
*/ | ||
function () { | ||
Storage.prototype.keys = function () { | ||
return this._dbPromise.then(function (db) { return db.keys(); }); | ||
@@ -394,13 +230,3 @@ }; | ||
*/ | ||
/** | ||
* Iterate through each key,value pair. | ||
* @param {?} iteratorCallback a callback of the form (value, key, iterationNumber) | ||
* @return {?} Returns a promise that resolves when the iteration has finished. | ||
*/ | ||
Storage.prototype.forEach = /** | ||
* Iterate through each key,value pair. | ||
* @param {?} iteratorCallback a callback of the form (value, key, iterationNumber) | ||
* @return {?} Returns a promise that resolves when the iteration has finished. | ||
*/ | ||
function (iteratorCallback) { | ||
Storage.prototype.forEach = function (iteratorCallback) { | ||
return this._dbPromise.then(function (db) { return db.iterate(iteratorCallback); }); | ||
@@ -410,106 +236,4 @@ }; | ||
}()); | ||
/** | ||
* Storage is an easy way to store key/value pairs and JSON objects. | ||
* Storage uses a variety of storage engines underneath, picking the best one available | ||
* depending on the platform. | ||
* | ||
* When running in a native app context, Storage will prioritize using SQLite, as it's one of | ||
* the most stable and widely used file-based databases, and avoids some of the | ||
* pitfalls of things like localstorage and IndexedDB, such as the OS deciding to clear out such | ||
* data in low disk-space situations. | ||
* | ||
* When running in the web or as a Progressive Web App, Storage will attempt to use | ||
* IndexedDB, WebSQL, and localstorage, in that order. | ||
* | ||
* \@usage | ||
* First, if you'd like to use SQLite, install the cordova-sqlite-storage plugin: | ||
* ```bash | ||
* ionic cordova plugin add cordova-sqlite-storage | ||
* ``` | ||
* | ||
* Next, install the package (comes by default for Ionic apps > Ionic V1): | ||
* ```bash | ||
* npm install --save \@ionic/storage | ||
* ``` | ||
* | ||
* Next, add it to the imports list in your `NgModule` declaration (for example, in `src/app/app.module.ts`): | ||
* | ||
* ```typescript | ||
* import { IonicStorageModule } from '\@ionic/storage'; | ||
* | ||
* \@NgModule({ | ||
* declarations: [ | ||
* // ... | ||
* ], | ||
* imports: [ | ||
* BrowserModule, | ||
* IonicModule.forRoot(MyApp), | ||
* IonicStorageModule.forRoot() | ||
* ], | ||
* bootstrap: [IonicApp], | ||
* entryComponents: [ | ||
* // ... | ||
* ], | ||
* providers: [ | ||
* // ... | ||
* ] | ||
* }) | ||
* export class AppModule {} | ||
* ``` | ||
* | ||
* Finally, inject it into any of your components or pages: | ||
* ```typescript | ||
* import { Storage } from '\@ionic/storage'; | ||
* export class MyApp { | ||
* constructor(private storage: Storage) { } | ||
* | ||
* ... | ||
* | ||
* // set a key/value | ||
* storage.set('name', 'Max'); | ||
* | ||
* // Or to get a key/value pair | ||
* storage.get('age').then((val) => { | ||
* console.log('Your age is', val); | ||
* }); | ||
* } | ||
* ``` | ||
* | ||
* | ||
* ### Configuring Storage | ||
* | ||
* The Storage engine can be configured both with specific storage engine priorities, or custom configuration | ||
* options to pass to localForage. See the localForage config docs for possible options: https://github.com/localForage/localForage#configuration | ||
* | ||
* Note: Any custom configurations will be merged with the default configuration | ||
* | ||
* ```typescript | ||
* import { IonicStorageModule } from '\@ionic/storage'; | ||
* | ||
* \@NgModule({ | ||
* declarations: [...], | ||
* imports: [ | ||
* IonicStorageModule.forRoot({ | ||
* name: '__mydb', | ||
* driverOrder: ['indexeddb', 'sqlite', 'websql'] | ||
* }) | ||
* ], | ||
* bootstrap: [...], | ||
* entryComponents: [...], | ||
* providers: [...] | ||
* }) | ||
* export class AppModule { } | ||
* ``` | ||
*/ | ||
export { Storage }; | ||
function Storage_tsickle_Closure_declarations() { | ||
/** @type {?} */ | ||
Storage.prototype._dbPromise; | ||
/** @type {?} */ | ||
Storage.prototype._driver; | ||
} | ||
/** | ||
* @hidden | ||
* @return {?} | ||
*/ | ||
/** @hidden */ | ||
export function getDefaultConfig() { | ||
@@ -523,37 +247,23 @@ return { | ||
} | ||
/** | ||
* @hidden | ||
* @record | ||
*/ | ||
export function StorageConfig() { } | ||
function StorageConfig_tsickle_Closure_declarations() { | ||
/** @type {?|undefined} */ | ||
StorageConfig.prototype.name; | ||
/** @type {?|undefined} */ | ||
StorageConfig.prototype.version; | ||
/** @type {?|undefined} */ | ||
StorageConfig.prototype.size; | ||
/** @type {?|undefined} */ | ||
StorageConfig.prototype.storeName; | ||
/** @type {?|undefined} */ | ||
StorageConfig.prototype.description; | ||
/** @type {?|undefined} */ | ||
StorageConfig.prototype.driverOrder; | ||
/** @type {?|undefined} */ | ||
StorageConfig.prototype.dbKey; | ||
} | ||
/** | ||
* @hidden | ||
*/ | ||
export var /** @type {?} */ StorageConfigToken = new InjectionToken('STORAGE_CONFIG_TOKEN'); | ||
/** | ||
* @hidden | ||
* @param {?} storageConfig | ||
* @return {?} | ||
*/ | ||
/** @hidden */ | ||
export var StorageConfigToken = new InjectionToken('STORAGE_CONFIG_TOKEN'); | ||
/** @hidden */ | ||
export function provideStorage(storageConfig) { | ||
var /** @type {?} */ config = !!storageConfig ? storageConfig : getDefaultConfig(); | ||
var config = !!storageConfig ? storageConfig : getDefaultConfig(); | ||
return new Storage(config); | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"storage.js","sourceRoot":"ng://@ionic/storage/","sources":["storage.ts"],"names":[],"mappings":"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","sourcesContent":["import { InjectionToken } from '@angular/core';\n\nimport * as LocalForage from 'localforage';\n\nimport * as CordovaSQLiteDriver from 'localforage-cordovasqlitedriver';\n\n/**\n * Storage is an easy way to store key/value pairs and JSON objects.\n * Storage uses a variety of storage engines underneath, picking the best one available\n * depending on the platform.\n *\n * When running in a native app context, Storage will prioritize using SQLite, as it's one of\n * the most stable and widely used file-based databases, and avoids some of the\n * pitfalls of things like localstorage and IndexedDB, such as the OS deciding to clear out such\n * data in low disk-space situations.\n *\n * When running in the web or as a Progressive Web App, Storage will attempt to use\n * IndexedDB, WebSQL, and localstorage, in that order.\n *\n * @usage\n * First, if you'd like to use SQLite, install the cordova-sqlite-storage plugin:\n * ```bash\n * ionic cordova plugin add cordova-sqlite-storage\n * ```\n *\n * Next, install the package (comes by default for Ionic apps > Ionic V1):\n * ```bash\n * npm install --save @ionic/storage\n * ```\n *\n * Next, add it to the imports list in your `NgModule` declaration (for example, in `src/app/app.module.ts`):\n *\n * ```typescript\n * import { IonicStorageModule } from '@ionic/storage';\n *\n * @NgModule({\n *   declarations: [\n *     // ...\n *   ],\n *   imports: [\n *     BrowserModule,\n *     IonicModule.forRoot(MyApp),\n *     IonicStorageModule.forRoot()\n *   ],\n *   bootstrap: [IonicApp],\n *   entryComponents: [\n *     // ...\n *   ],\n *   providers: [\n *     // ...\n *   ]\n * })\n * export class AppModule {}\n *```\n *\n * Finally, inject it into any of your components or pages:\n * ```typescript\n * import { Storage } from '@ionic/storage';\n\n * export class MyApp {\n *   constructor(private storage: Storage) { }\n *\n *   ...\n *\n *   // set a key/value\n *   storage.set('name', 'Max');\n *\n *   // Or to get a key/value pair\n *   storage.get('age').then((val) => {\n *     console.log('Your age is', val);\n *   });\n * }\n * ```\n *\n *\n * ### Configuring Storage\n *\n * The Storage engine can be configured both with specific storage engine priorities, or custom configuration\n * options to pass to localForage. See the localForage config docs for possible options: https://github.com/localForage/localForage#configuration\n *\n * Note: Any custom configurations will be merged with the default configuration\n *\n * ```typescript\n * import { IonicStorageModule } from '@ionic/storage';\n *\n * @NgModule({\n *   declarations: [...],\n *   imports: [\n *     IonicStorageModule.forRoot({\n *       name: '__mydb',\n         driverOrder: ['indexeddb', 'sqlite', 'websql']\n *     })\n *   ],\n *   bootstrap: [...],\n *   entryComponents: [...],\n *    providers: [...]\n * })\n * export class AppModule { }\n * ```\n */\nexport class Storage {\n  private _dbPromise: Promise<LocalForage>;\n  private _driver: string = null;\n\n  /**\n   * Create a new Storage instance using the order of drivers and any additional config\n   * options to pass to LocalForage.\n   *\n   * Possible driver options are: ['sqlite', 'indexeddb', 'websql', 'localstorage'] and the\n   * default is that exact ordering.\n   */\n  constructor(config: StorageConfig) {\n    this._dbPromise = new Promise((resolve, reject) => {\n      let db: LocalForage;\n\n      const defaultConfig = getDefaultConfig();\n      const actualConfig = Object.assign(defaultConfig, config || {});\n\n      LocalForage.defineDriver(CordovaSQLiteDriver)\n        .then(() => {\n          db = LocalForage.createInstance(actualConfig);\n        })\n        .then(() =>\n          db.setDriver(this._getDriverOrder(actualConfig.driverOrder))\n        )\n        .then(() => {\n          this._driver = db.driver();\n          resolve(db);\n        })\n        .catch(reason => reject(reason));\n    });\n  }\n\n  /**\n   * Get the name of the driver being used.\n   * @returns Name of the driver\n   */\n  get driver(): string | null {\n    return this._driver;\n  }\n\n  /**\n   * Reflect the readiness of the store.\n   * @returns Returns a promise that resolves when the store is ready\n   */\n  ready(): Promise<LocalForage> {\n    return this._dbPromise;\n  }\n\n  /** @hidden */\n  private _getDriverOrder(driverOrder) {\n    return driverOrder.map(driver => {\n      switch (driver) {\n        case 'sqlite':\n          return CordovaSQLiteDriver._driver;\n        case 'indexeddb':\n          return LocalForage.INDEXEDDB;\n        case 'websql':\n          return LocalForage.WEBSQL;\n        case 'localstorage':\n          return LocalForage.LOCALSTORAGE;\n      }\n    });\n  }\n\n  /**\n   * Get the value associated with the given key.\n   * @param key the key to identify this value\n   * @returns Returns a promise with the value of the given key\n   */\n  get(key: string): Promise<any> {\n    return this._dbPromise.then(db => db.getItem(key));\n  }\n\n  /**\n   * Set the value for the given key.\n   * @param key the key to identify this value\n   * @param value the value for this key\n   * @returns Returns a promise that resolves when the key and value are set\n   */\n  set(key: string, value: any): Promise<any> {\n    return this._dbPromise.then(db => db.setItem(key, value));\n  }\n\n  /**\n   * Remove any value associated with this key.\n   * @param key the key to identify this value\n   * @returns Returns a promise that resolves when the value is removed\n   */\n  remove(key: string): Promise<any> {\n    return this._dbPromise.then(db => db.removeItem(key));\n  }\n\n  /**\n   * Clear the entire key value store. WARNING: HOT!\n   * @returns Returns a promise that resolves when the store is cleared\n   */\n  clear(): Promise<void> {\n    return this._dbPromise.then(db => db.clear());\n  }\n\n  /**\n   * @returns Returns a promise that resolves with the number of keys stored.\n   */\n  length(): Promise<number> {\n    return this._dbPromise.then(db => db.length());\n  }\n\n  /**\n   * @returns Returns a promise that resolves with the keys in the store.\n   */\n  keys(): Promise<string[]> {\n    return this._dbPromise.then(db => db.keys());\n  }\n\n  /**\n   * Iterate through each key,value pair.\n   * @param iteratorCallback a callback of the form (value, key, iterationNumber)\n   * @returns Returns a promise that resolves when the iteration has finished.\n   */\n  forEach(\n    iteratorCallback: (value: any, key: string, iterationNumber: Number) => any\n  ): Promise<void> {\n    return this._dbPromise.then(db => db.iterate(iteratorCallback));\n  }\n}\n\n/** @hidden */\nexport function getDefaultConfig() {\n  return {\n    name: '_ionicstorage',\n    storeName: '_ionickv',\n    dbKey: '_ionickey',\n    driverOrder: ['sqlite', 'indexeddb', 'websql', 'localstorage']\n  };\n}\n\n/** @hidden */\nexport interface StorageConfig {\n  name?: string;\n  version?: number;\n  size?: number;\n  storeName?: string;\n  description?: string;\n  driverOrder?: string[];\n  dbKey?: string;\n}\n\n/** @hidden */\nexport const StorageConfigToken = new InjectionToken<any>(\n  'STORAGE_CONFIG_TOKEN'\n);\n\n/** @hidden */\nexport function provideStorage(storageConfig: StorageConfig): Storage {\n  const config = !!storageConfig ? storageConfig : getDefaultConfig();\n  return new Storage(config);\n}\n"]} | ||
function getNoopDriver() { | ||
// noop driver for ssr environment | ||
var noop = function () { }; | ||
var driver = { | ||
getItem: noop, | ||
setItem: noop, | ||
removeItem: noop, | ||
clear: noop, | ||
length: function () { return 0; }, | ||
keys: function () { return []; }, | ||
iterate: noop | ||
}; | ||
return driver; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"storage.js","sourceRoot":"ng://@ionic/storage/","sources":["storage.ts"],"names":[],"mappings":"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","sourcesContent":["import { InjectionToken } from '@angular/core';\n\nimport * as LocalForage from 'localforage';\n\nimport * as CordovaSQLiteDriver from 'localforage-cordovasqlitedriver';\n\n/**\n * Storage is an easy way to store key/value pairs and JSON objects.\n * Storage uses a variety of storage engines underneath, picking the best one available\n * depending on the platform.\n *\n * When running in a native app context, Storage will prioritize using SQLite, as it's one of\n * the most stable and widely used file-based databases, and avoids some of the\n * pitfalls of things like localstorage and IndexedDB, such as the OS deciding to clear out such\n * data in low disk-space situations.\n *\n * When running in the web or as a Progressive Web App, Storage will attempt to use\n * IndexedDB, WebSQL, and localstorage, in that order.\n *\n * @usage\n * First, if you'd like to use SQLite, install the cordova-sqlite-storage plugin:\n * ```bash\n * ionic cordova plugin add cordova-sqlite-storage\n * ```\n *\n * Next, install the package (comes by default for Ionic apps > Ionic V1):\n * ```bash\n * npm install --save @ionic/storage\n * ```\n *\n * Next, add it to the imports list in your `NgModule` declaration (for example, in `src/app/app.module.ts`):\n *\n * ```typescript\n * import { IonicStorageModule } from '@ionic/storage';\n *\n * @NgModule({\n *   declarations: [\n *     // ...\n *   ],\n *   imports: [\n *     BrowserModule,\n *     IonicModule.forRoot(MyApp),\n *     IonicStorageModule.forRoot()\n *   ],\n *   bootstrap: [IonicApp],\n *   entryComponents: [\n *     // ...\n *   ],\n *   providers: [\n *     // ...\n *   ]\n * })\n * export class AppModule {}\n *```\n *\n * Finally, inject it into any of your components or pages:\n * ```typescript\n * import { Storage } from '@ionic/storage';\n\n * export class MyApp {\n *   constructor(private storage: Storage) { }\n *\n *   ...\n *\n *   // set a key/value\n *   storage.set('name', 'Max');\n *\n *   // Or to get a key/value pair\n *   storage.get('age').then((val) => {\n *     console.log('Your age is', val);\n *   });\n * }\n * ```\n *\n *\n * ### Configuring Storage\n *\n * The Storage engine can be configured both with specific storage engine priorities, or custom configuration\n * options to pass to localForage. See the localForage config docs for possible options: https://github.com/localForage/localForage#configuration\n *\n * Note: Any custom configurations will be merged with the default configuration\n *\n * ```typescript\n * import { IonicStorageModule } from '@ionic/storage';\n *\n * @NgModule({\n *   declarations: [...],\n *   imports: [\n *     IonicStorageModule.forRoot({\n *       name: '__mydb',\n         driverOrder: ['indexeddb', 'sqlite', 'websql']\n *     })\n *   ],\n *   bootstrap: [...],\n *   entryComponents: [...],\n *    providers: [...]\n * })\n * export class AppModule { }\n * ```\n */\nexport class Storage {\n  private _dbPromise: Promise<LocalForage>;\n  private _driver: string = null;\n\n  /**\n   * Create a new Storage instance using the order of drivers and any additional config\n   * options to pass to LocalForage.\n   *\n   * Possible driver options are: ['sqlite', 'indexeddb', 'websql', 'localstorage'] and the\n   * default is that exact ordering.\n   */\n  constructor(config: StorageConfig) {\n    this._dbPromise = new Promise((resolve, reject) => {\n      if (typeof process !== 'undefined') {\n        const noopDriver = getNoopDriver();\n        resolve(noopDriver);\n        return;\n      }\n\n      let db: LocalForage;\n\n      const defaultConfig = getDefaultConfig();\n      const actualConfig = Object.assign(defaultConfig, config || {});\n\n      LocalForage.defineDriver(CordovaSQLiteDriver)\n        .then(() => {\n          db = LocalForage.createInstance(actualConfig);\n        })\n        .then(() =>\n          db.setDriver(this._getDriverOrder(actualConfig.driverOrder))\n        )\n        .then(() => {\n          this._driver = db.driver();\n          resolve(db);\n        })\n        .catch(reason => reject(reason));\n    });\n  }\n\n  /**\n   * Get the name of the driver being used.\n   * @returns Name of the driver\n   */\n  get driver(): string | null {\n    return this._driver;\n  }\n\n  /**\n   * Reflect the readiness of the store.\n   * @returns Returns a promise that resolves when the store is ready\n   */\n  ready(): Promise<LocalForage> {\n    return this._dbPromise;\n  }\n\n  /** @hidden */\n  private _getDriverOrder(driverOrder) {\n    return driverOrder.map(driver => {\n      switch (driver) {\n        case 'sqlite':\n          return CordovaSQLiteDriver._driver;\n        case 'indexeddb':\n          return LocalForage.INDEXEDDB;\n        case 'websql':\n          return LocalForage.WEBSQL;\n        case 'localstorage':\n          return LocalForage.LOCALSTORAGE;\n      }\n    });\n  }\n\n  /**\n   * Get the value associated with the given key.\n   * @param key the key to identify this value\n   * @returns Returns a promise with the value of the given key\n   */\n  get(key: string): Promise<any> {\n    return this._dbPromise.then(db => db.getItem(key));\n  }\n\n  /**\n   * Set the value for the given key.\n   * @param key the key to identify this value\n   * @param value the value for this key\n   * @returns Returns a promise that resolves when the key and value are set\n   */\n  set(key: string, value: any): Promise<any> {\n    return this._dbPromise.then(db => db.setItem(key, value));\n  }\n\n  /**\n   * Remove any value associated with this key.\n   * @param key the key to identify this value\n   * @returns Returns a promise that resolves when the value is removed\n   */\n  remove(key: string): Promise<any> {\n    return this._dbPromise.then(db => db.removeItem(key));\n  }\n\n  /**\n   * Clear the entire key value store. WARNING: HOT!\n   * @returns Returns a promise that resolves when the store is cleared\n   */\n  clear(): Promise<void> {\n    return this._dbPromise.then(db => db.clear());\n  }\n\n  /**\n   * @returns Returns a promise that resolves with the number of keys stored.\n   */\n  length(): Promise<number> {\n    return this._dbPromise.then(db => db.length());\n  }\n\n  /**\n   * @returns Returns a promise that resolves with the keys in the store.\n   */\n  keys(): Promise<string[]> {\n    return this._dbPromise.then(db => db.keys());\n  }\n\n  /**\n   * Iterate through each key,value pair.\n   * @param iteratorCallback a callback of the form (value, key, iterationNumber)\n   * @returns Returns a promise that resolves when the iteration has finished.\n   */\n  forEach(\n    iteratorCallback: (value: any, key: string, iterationNumber: Number) => any\n  ): Promise<void> {\n    return this._dbPromise.then(db => db.iterate(iteratorCallback));\n  }\n}\n\n/** @hidden */\nexport function getDefaultConfig() {\n  return {\n    name: '_ionicstorage',\n    storeName: '_ionickv',\n    dbKey: '_ionickey',\n    driverOrder: ['sqlite', 'indexeddb', 'websql', 'localstorage']\n  };\n}\n\n/** @hidden */\nexport interface StorageConfig {\n  name?: string;\n  version?: number;\n  size?: number;\n  storeName?: string;\n  description?: string;\n  driverOrder?: string[];\n  dbKey?: string;\n}\n\n/** @hidden */\nexport const StorageConfigToken = new InjectionToken<any>(\n  'STORAGE_CONFIG_TOKEN'\n);\n\n/** @hidden */\nexport function provideStorage(storageConfig: StorageConfig): Storage {\n  const config = !!storageConfig ? storageConfig : getDefaultConfig();\n  return new Storage(config);\n}\n\nfunction getNoopDriver() {\n  // noop driver for ssr environment\n  const noop = () => {};\n  const driver: any = {\n    getItem: noop,\n    setItem: noop,\n    removeItem: noop,\n    clear: noop,\n    length: () => 0,\n    keys: () => [],\n    iterate: noop\n  };\n  return driver;\n}"]} |
@@ -0,3 +1,4 @@ | ||
import { __decorate } from 'tslib'; | ||
import { InjectionToken, NgModule } from '@angular/core'; | ||
import { defineDriver, createInstance, INDEXEDDB, WEBSQL, LOCALSTORAGE } from 'localforage'; | ||
import { defineDriver, createInstance, LOCALSTORAGE, WEBSQL, INDEXEDDB } from 'localforage'; | ||
import * as CordovaSQLiteDriver from 'localforage-cordovasqlitedriver'; | ||
@@ -7,6 +8,2 @@ import { _driver } from 'localforage-cordovasqlitedriver'; | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes} checked by tsc | ||
*/ | ||
/** | ||
* Storage is an easy way to store key/value pairs and JSON objects. | ||
@@ -24,3 +21,3 @@ * Storage uses a variety of storage engines underneath, picking the best one available | ||
* | ||
* \@usage | ||
* @usage | ||
* First, if you'd like to use SQLite, install the cordova-sqlite-storage plugin: | ||
@@ -33,3 +30,3 @@ * ```bash | ||
* ```bash | ||
* npm install --save \@ionic/storage | ||
* npm install --save @ionic/storage | ||
* ``` | ||
@@ -40,5 +37,5 @@ * | ||
* ```typescript | ||
* import { IonicStorageModule } from '\@ionic/storage'; | ||
* import { IonicStorageModule } from '@ionic/storage'; | ||
* | ||
* \@NgModule({ | ||
* @NgModule({ | ||
* declarations: [ | ||
@@ -61,7 +58,8 @@ * // ... | ||
* export class AppModule {} | ||
* ``` | ||
*``` | ||
* | ||
* Finally, inject it into any of your components or pages: | ||
* ```typescript | ||
* import { Storage } from '\@ionic/storage'; | ||
* import { Storage } from '@ionic/storage'; | ||
* export class MyApp { | ||
@@ -91,5 +89,5 @@ * constructor(private storage: Storage) { } | ||
* ```typescript | ||
* import { IonicStorageModule } from '\@ionic/storage'; | ||
* import { IonicStorageModule } from '@ionic/storage'; | ||
* | ||
* \@NgModule({ | ||
* @NgModule({ | ||
* declarations: [...], | ||
@@ -99,3 +97,3 @@ * imports: [ | ||
* name: '__mydb', | ||
* driverOrder: ['indexeddb', 'sqlite', 'websql'] | ||
driverOrder: ['indexeddb', 'sqlite', 'websql'] | ||
* }) | ||
@@ -117,3 +115,2 @@ * ], | ||
* default is that exact ordering. | ||
* @param {?} config | ||
*/ | ||
@@ -123,5 +120,10 @@ constructor(config) { | ||
this._dbPromise = new Promise((resolve, reject) => { | ||
let /** @type {?} */ db; | ||
const /** @type {?} */ defaultConfig = getDefaultConfig(); | ||
const /** @type {?} */ actualConfig = Object.assign(defaultConfig, config || {}); | ||
if (typeof process !== 'undefined') { | ||
const noopDriver = getNoopDriver(); | ||
resolve(noopDriver); | ||
return; | ||
} | ||
let db; | ||
const defaultConfig = getDefaultConfig(); | ||
const actualConfig = Object.assign(defaultConfig, config || {}); | ||
defineDriver(CordovaSQLiteDriver) | ||
@@ -141,3 +143,3 @@ .then(() => { | ||
* Get the name of the driver being used. | ||
* @return {?} Name of the driver | ||
* @returns Name of the driver | ||
*/ | ||
@@ -149,3 +151,3 @@ get driver() { | ||
* Reflect the readiness of the store. | ||
* @return {?} Returns a promise that resolves when the store is ready | ||
* @returns Returns a promise that resolves when the store is ready | ||
*/ | ||
@@ -155,7 +157,3 @@ ready() { | ||
} | ||
/** | ||
* @hidden | ||
* @param {?} driverOrder | ||
* @return {?} | ||
*/ | ||
/** @hidden */ | ||
_getDriverOrder(driverOrder) { | ||
@@ -177,4 +175,4 @@ return driverOrder.map(driver => { | ||
* Get the value associated with the given key. | ||
* @param {?} key the key to identify this value | ||
* @return {?} Returns a promise with the value of the given key | ||
* @param key the key to identify this value | ||
* @returns Returns a promise with the value of the given key | ||
*/ | ||
@@ -186,5 +184,5 @@ get(key) { | ||
* Set the value for the given key. | ||
* @param {?} key the key to identify this value | ||
* @param {?} value the value for this key | ||
* @return {?} Returns a promise that resolves when the key and value are set | ||
* @param key the key to identify this value | ||
* @param value the value for this key | ||
* @returns Returns a promise that resolves when the key and value are set | ||
*/ | ||
@@ -196,4 +194,4 @@ set(key, value) { | ||
* Remove any value associated with this key. | ||
* @param {?} key the key to identify this value | ||
* @return {?} Returns a promise that resolves when the value is removed | ||
* @param key the key to identify this value | ||
* @returns Returns a promise that resolves when the value is removed | ||
*/ | ||
@@ -205,3 +203,3 @@ remove(key) { | ||
* Clear the entire key value store. WARNING: HOT! | ||
* @return {?} Returns a promise that resolves when the store is cleared | ||
* @returns Returns a promise that resolves when the store is cleared | ||
*/ | ||
@@ -212,3 +210,3 @@ clear() { | ||
/** | ||
* @return {?} Returns a promise that resolves with the number of keys stored. | ||
* @returns Returns a promise that resolves with the number of keys stored. | ||
*/ | ||
@@ -219,3 +217,3 @@ length() { | ||
/** | ||
* @return {?} Returns a promise that resolves with the keys in the store. | ||
* @returns Returns a promise that resolves with the keys in the store. | ||
*/ | ||
@@ -227,4 +225,4 @@ keys() { | ||
* Iterate through each key,value pair. | ||
* @param {?} iteratorCallback a callback of the form (value, key, iterationNumber) | ||
* @return {?} Returns a promise that resolves when the iteration has finished. | ||
* @param iteratorCallback a callback of the form (value, key, iterationNumber) | ||
* @returns Returns a promise that resolves when the iteration has finished. | ||
*/ | ||
@@ -235,6 +233,3 @@ forEach(iteratorCallback) { | ||
} | ||
/** | ||
* @hidden | ||
* @return {?} | ||
*/ | ||
/** @hidden */ | ||
function getDefaultConfig() { | ||
@@ -248,28 +243,29 @@ return { | ||
} | ||
/** | ||
* @hidden | ||
*/ | ||
const /** @type {?} */ StorageConfigToken = new InjectionToken('STORAGE_CONFIG_TOKEN'); | ||
/** | ||
* @hidden | ||
* @param {?} storageConfig | ||
* @return {?} | ||
*/ | ||
/** @hidden */ | ||
const StorageConfigToken = new InjectionToken('STORAGE_CONFIG_TOKEN'); | ||
/** @hidden */ | ||
function provideStorage(storageConfig) { | ||
const /** @type {?} */ config = !!storageConfig ? storageConfig : getDefaultConfig(); | ||
const config = !!storageConfig ? storageConfig : getDefaultConfig(); | ||
return new Storage(config); | ||
} | ||
function getNoopDriver() { | ||
// noop driver for ssr environment | ||
const noop = () => { }; | ||
const driver = { | ||
getItem: noop, | ||
setItem: noop, | ||
removeItem: noop, | ||
clear: noop, | ||
length: () => 0, | ||
keys: () => [], | ||
iterate: noop | ||
}; | ||
return driver; | ||
} | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes} checked by tsc | ||
*/ | ||
class IonicStorageModule { | ||
/** | ||
* @param {?=} storageConfig | ||
* @return {?} | ||
*/ | ||
var IonicStorageModule_1; | ||
let IonicStorageModule = IonicStorageModule_1 = class IonicStorageModule { | ||
static forRoot(storageConfig = null) { | ||
return { | ||
ngModule: IonicStorageModule, | ||
ngModule: IonicStorageModule_1, | ||
providers: [ | ||
@@ -285,14 +281,12 @@ { provide: StorageConfigToken, useValue: storageConfig }, | ||
} | ||
} | ||
IonicStorageModule.decorators = [ | ||
{ type: NgModule }, | ||
]; | ||
}; | ||
IonicStorageModule = IonicStorageModule_1 = __decorate([ | ||
NgModule() | ||
], IonicStorageModule); | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes} checked by tsc | ||
* Generated bundle index. Do not edit. | ||
*/ | ||
export { StorageConfigToken, Storage, IonicStorageModule, provideStorage as ɵa }; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ionic-storage.js.map","sources":["ng://@ionic/storage/storage.ts","ng://@ionic/storage/index.ts"],"sourcesContent":["import { InjectionToken } from '@angular/core';\n\nimport * as LocalForage from 'localforage';\n\nimport * as CordovaSQLiteDriver from 'localforage-cordovasqlitedriver';\n\n/**\n * Storage is an easy way to store key/value pairs and JSON objects.\n * Storage uses a variety of storage engines underneath, picking the best one available\n * depending on the platform.\n *\n * When running in a native app context, Storage will prioritize using SQLite, as it's one of\n * the most stable and widely used file-based databases, and avoids some of the\n * pitfalls of things like localstorage and IndexedDB, such as the OS deciding to clear out such\n * data in low disk-space situations.\n *\n * When running in the web or as a Progressive Web App, Storage will attempt to use\n * IndexedDB, WebSQL, and localstorage, in that order.\n *\n * @usage\n * First, if you'd like to use SQLite, install the cordova-sqlite-storage plugin:\n * ```bash\n * ionic cordova plugin add cordova-sqlite-storage\n * ```\n *\n * Next, install the package (comes by default for Ionic apps > Ionic V1):\n * ```bash\n * npm install --save @ionic/storage\n * ```\n *\n * Next, add it to the imports list in your `NgModule` declaration (for example, in `src/app/app.module.ts`):\n *\n * ```typescript\n * import { IonicStorageModule } from '@ionic/storage';\n *\n * @NgModule({\n *   declarations: [\n *     // ...\n *   ],\n *   imports: [\n *     BrowserModule,\n *     IonicModule.forRoot(MyApp),\n *     IonicStorageModule.forRoot()\n *   ],\n *   bootstrap: [IonicApp],\n *   entryComponents: [\n *     // ...\n *   ],\n *   providers: [\n *     // ...\n *   ]\n * })\n * export class AppModule {}\n *```\n *\n * Finally, inject it into any of your components or pages:\n * ```typescript\n * import { Storage } from '@ionic/storage';\n\n * export class MyApp {\n *   constructor(private storage: Storage) { }\n *\n *   ...\n *\n *   // set a key/value\n *   storage.set('name', 'Max');\n *\n *   // Or to get a key/value pair\n *   storage.get('age').then((val) => {\n *     console.log('Your age is', val);\n *   });\n * }\n * ```\n *\n *\n * ### Configuring Storage\n *\n * The Storage engine can be configured both with specific storage engine priorities, or custom configuration\n * options to pass to localForage. See the localForage config docs for possible options: https://github.com/localForage/localForage#configuration\n *\n * Note: Any custom configurations will be merged with the default configuration\n *\n * ```typescript\n * import { IonicStorageModule } from '@ionic/storage';\n *\n * @NgModule({\n *   declarations: [...],\n *   imports: [\n *     IonicStorageModule.forRoot({\n *       name: '__mydb',\n         driverOrder: ['indexeddb', 'sqlite', 'websql']\n *     })\n *   ],\n *   bootstrap: [...],\n *   entryComponents: [...],\n *    providers: [...]\n * })\n * export class AppModule { }\n * ```\n */\nexport class Storage {\n  private _dbPromise: Promise<LocalForage>;\n  private _driver: string = null;\n\n  /**\n   * Create a new Storage instance using the order of drivers and any additional config\n   * options to pass to LocalForage.\n   *\n   * Possible driver options are: ['sqlite', 'indexeddb', 'websql', 'localstorage'] and the\n   * default is that exact ordering.\n   */\n  constructor(config: StorageConfig) {\n    this._dbPromise = new Promise((resolve, reject) => {\n      let db: LocalForage;\n\n      const defaultConfig = getDefaultConfig();\n      const actualConfig = Object.assign(defaultConfig, config || {});\n\n      LocalForage.defineDriver(CordovaSQLiteDriver)\n        .then(() => {\n          db = LocalForage.createInstance(actualConfig);\n        })\n        .then(() =>\n          db.setDriver(this._getDriverOrder(actualConfig.driverOrder))\n        )\n        .then(() => {\n          this._driver = db.driver();\n          resolve(db);\n        })\n        .catch(reason => reject(reason));\n    });\n  }\n\n  /**\n   * Get the name of the driver being used.\n   * @returns Name of the driver\n   */\n  get driver(): string | null {\n    return this._driver;\n  }\n\n  /**\n   * Reflect the readiness of the store.\n   * @returns Returns a promise that resolves when the store is ready\n   */\n  ready(): Promise<LocalForage> {\n    return this._dbPromise;\n  }\n\n  /** @hidden */\n  private _getDriverOrder(driverOrder) {\n    return driverOrder.map(driver => {\n      switch (driver) {\n        case 'sqlite':\n          return CordovaSQLiteDriver._driver;\n        case 'indexeddb':\n          return LocalForage.INDEXEDDB;\n        case 'websql':\n          return LocalForage.WEBSQL;\n        case 'localstorage':\n          return LocalForage.LOCALSTORAGE;\n      }\n    });\n  }\n\n  /**\n   * Get the value associated with the given key.\n   * @param key the key to identify this value\n   * @returns Returns a promise with the value of the given key\n   */\n  get(key: string): Promise<any> {\n    return this._dbPromise.then(db => db.getItem(key));\n  }\n\n  /**\n   * Set the value for the given key.\n   * @param key the key to identify this value\n   * @param value the value for this key\n   * @returns Returns a promise that resolves when the key and value are set\n   */\n  set(key: string, value: any): Promise<any> {\n    return this._dbPromise.then(db => db.setItem(key, value));\n  }\n\n  /**\n   * Remove any value associated with this key.\n   * @param key the key to identify this value\n   * @returns Returns a promise that resolves when the value is removed\n   */\n  remove(key: string): Promise<any> {\n    return this._dbPromise.then(db => db.removeItem(key));\n  }\n\n  /**\n   * Clear the entire key value store. WARNING: HOT!\n   * @returns Returns a promise that resolves when the store is cleared\n   */\n  clear(): Promise<void> {\n    return this._dbPromise.then(db => db.clear());\n  }\n\n  /**\n   * @returns Returns a promise that resolves with the number of keys stored.\n   */\n  length(): Promise<number> {\n    return this._dbPromise.then(db => db.length());\n  }\n\n  /**\n   * @returns Returns a promise that resolves with the keys in the store.\n   */\n  keys(): Promise<string[]> {\n    return this._dbPromise.then(db => db.keys());\n  }\n\n  /**\n   * Iterate through each key,value pair.\n   * @param iteratorCallback a callback of the form (value, key, iterationNumber)\n   * @returns Returns a promise that resolves when the iteration has finished.\n   */\n  forEach(\n    iteratorCallback: (value: any, key: string, iterationNumber: Number) => any\n  ): Promise<void> {\n    return this._dbPromise.then(db => db.iterate(iteratorCallback));\n  }\n}\n\n/** @hidden */\nexport function getDefaultConfig() {\n  return {\n    name: '_ionicstorage',\n    storeName: '_ionickv',\n    dbKey: '_ionickey',\n    driverOrder: ['sqlite', 'indexeddb', 'websql', 'localstorage']\n  };\n}\n\n/** @hidden */\nexport interface StorageConfig {\n  name?: string;\n  version?: number;\n  size?: number;\n  storeName?: string;\n  description?: string;\n  driverOrder?: string[];\n  dbKey?: string;\n}\n\n/** @hidden */\nexport const StorageConfigToken = new InjectionToken<any>(\n  'STORAGE_CONFIG_TOKEN'\n);\n\n/** @hidden */\nexport function provideStorage(storageConfig: StorageConfig): Storage {\n  const config = !!storageConfig ? storageConfig : getDefaultConfig();\n  return new Storage(config);\n}\n","import { NgModule, ModuleWithProviders } from '@angular/core';\nimport {\n  getDefaultConfig,\n  provideStorage,\n  Storage,\n  StorageConfig,\n  StorageConfigToken\n} from './storage';\n\nexport { StorageConfig, StorageConfigToken, Storage };\n\n@NgModule()\nexport class IonicStorageModule {\n  static forRoot(storageConfig: StorageConfig = null): ModuleWithProviders {\n    return {\n      ngModule: IonicStorageModule,\n      providers: [\n        { provide: StorageConfigToken, useValue: storageConfig },\n        {\n          provide: Storage,\n          useFactory: provideStorage,\n          deps: [StorageConfigToken]\n        }\n      ]\n    };\n  }\n}\n"],"names":["LocalForage.defineDriver","LocalForage.createInstance","CordovaSQLiteDriver._driver","LocalForage.INDEXEDDB","LocalForage.WEBSQL","LocalForage.LOCALSTORAGE"],"mappings":"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"} | ||
export { IonicStorageModule, Storage, StorageConfigToken, provideStorage as ɵa }; | ||
//# sourceMappingURL=ionic-storage.js.map |
@@ -0,3 +1,4 @@ | ||
import { __decorate } from 'tslib'; | ||
import { InjectionToken, NgModule } from '@angular/core'; | ||
import { defineDriver, createInstance, INDEXEDDB, WEBSQL, LOCALSTORAGE } from 'localforage'; | ||
import { defineDriver, createInstance, LOCALSTORAGE, WEBSQL, INDEXEDDB } from 'localforage'; | ||
import * as CordovaSQLiteDriver from 'localforage-cordovasqlitedriver'; | ||
@@ -7,6 +8,2 @@ import { _driver } from 'localforage-cordovasqlitedriver'; | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes} checked by tsc | ||
*/ | ||
/** | ||
* Storage is an easy way to store key/value pairs and JSON objects. | ||
@@ -24,3 +21,3 @@ * Storage uses a variety of storage engines underneath, picking the best one available | ||
* | ||
* \@usage | ||
* @usage | ||
* First, if you'd like to use SQLite, install the cordova-sqlite-storage plugin: | ||
@@ -33,3 +30,3 @@ * ```bash | ||
* ```bash | ||
* npm install --save \@ionic/storage | ||
* npm install --save @ionic/storage | ||
* ``` | ||
@@ -40,5 +37,5 @@ * | ||
* ```typescript | ||
* import { IonicStorageModule } from '\@ionic/storage'; | ||
* import { IonicStorageModule } from '@ionic/storage'; | ||
* | ||
* \@NgModule({ | ||
* @NgModule({ | ||
* declarations: [ | ||
@@ -61,7 +58,8 @@ * // ... | ||
* export class AppModule {} | ||
* ``` | ||
*``` | ||
* | ||
* Finally, inject it into any of your components or pages: | ||
* ```typescript | ||
* import { Storage } from '\@ionic/storage'; | ||
* import { Storage } from '@ionic/storage'; | ||
* export class MyApp { | ||
@@ -91,5 +89,5 @@ * constructor(private storage: Storage) { } | ||
* ```typescript | ||
* import { IonicStorageModule } from '\@ionic/storage'; | ||
* import { IonicStorageModule } from '@ionic/storage'; | ||
* | ||
* \@NgModule({ | ||
* @NgModule({ | ||
* declarations: [...], | ||
@@ -99,3 +97,3 @@ * imports: [ | ||
* name: '__mydb', | ||
* driverOrder: ['indexeddb', 'sqlite', 'websql'] | ||
driverOrder: ['indexeddb', 'sqlite', 'websql'] | ||
* }) | ||
@@ -110,96 +108,3 @@ * ], | ||
*/ | ||
var /** | ||
* Storage is an easy way to store key/value pairs and JSON objects. | ||
* Storage uses a variety of storage engines underneath, picking the best one available | ||
* depending on the platform. | ||
* | ||
* When running in a native app context, Storage will prioritize using SQLite, as it's one of | ||
* the most stable and widely used file-based databases, and avoids some of the | ||
* pitfalls of things like localstorage and IndexedDB, such as the OS deciding to clear out such | ||
* data in low disk-space situations. | ||
* | ||
* When running in the web or as a Progressive Web App, Storage will attempt to use | ||
* IndexedDB, WebSQL, and localstorage, in that order. | ||
* | ||
* \@usage | ||
* First, if you'd like to use SQLite, install the cordova-sqlite-storage plugin: | ||
* ```bash | ||
* ionic cordova plugin add cordova-sqlite-storage | ||
* ``` | ||
* | ||
* Next, install the package (comes by default for Ionic apps > Ionic V1): | ||
* ```bash | ||
* npm install --save \@ionic/storage | ||
* ``` | ||
* | ||
* Next, add it to the imports list in your `NgModule` declaration (for example, in `src/app/app.module.ts`): | ||
* | ||
* ```typescript | ||
* import { IonicStorageModule } from '\@ionic/storage'; | ||
* | ||
* \@NgModule({ | ||
* declarations: [ | ||
* // ... | ||
* ], | ||
* imports: [ | ||
* BrowserModule, | ||
* IonicModule.forRoot(MyApp), | ||
* IonicStorageModule.forRoot() | ||
* ], | ||
* bootstrap: [IonicApp], | ||
* entryComponents: [ | ||
* // ... | ||
* ], | ||
* providers: [ | ||
* // ... | ||
* ] | ||
* }) | ||
* export class AppModule {} | ||
* ``` | ||
* | ||
* Finally, inject it into any of your components or pages: | ||
* ```typescript | ||
* import { Storage } from '\@ionic/storage'; | ||
* export class MyApp { | ||
* constructor(private storage: Storage) { } | ||
* | ||
* ... | ||
* | ||
* // set a key/value | ||
* storage.set('name', 'Max'); | ||
* | ||
* // Or to get a key/value pair | ||
* storage.get('age').then((val) => { | ||
* console.log('Your age is', val); | ||
* }); | ||
* } | ||
* ``` | ||
* | ||
* | ||
* ### Configuring Storage | ||
* | ||
* The Storage engine can be configured both with specific storage engine priorities, or custom configuration | ||
* options to pass to localForage. See the localForage config docs for possible options: https://github.com/localForage/localForage#configuration | ||
* | ||
* Note: Any custom configurations will be merged with the default configuration | ||
* | ||
* ```typescript | ||
* import { IonicStorageModule } from '\@ionic/storage'; | ||
* | ||
* \@NgModule({ | ||
* declarations: [...], | ||
* imports: [ | ||
* IonicStorageModule.forRoot({ | ||
* name: '__mydb', | ||
* driverOrder: ['indexeddb', 'sqlite', 'websql'] | ||
* }) | ||
* ], | ||
* bootstrap: [...], | ||
* entryComponents: [...], | ||
* providers: [...] | ||
* }) | ||
* export class AppModule { } | ||
* ``` | ||
*/ | ||
Storage = /** @class */ (function () { | ||
var Storage = /** @class */ (function () { | ||
/** | ||
@@ -216,5 +121,10 @@ * Create a new Storage instance using the order of drivers and any additional config | ||
this._dbPromise = new Promise(function (resolve, reject) { | ||
var /** @type {?} */ db; | ||
var /** @type {?} */ defaultConfig = getDefaultConfig(); | ||
var /** @type {?} */ actualConfig = Object.assign(defaultConfig, config || {}); | ||
if (typeof process !== 'undefined') { | ||
var noopDriver = getNoopDriver(); | ||
resolve(noopDriver); | ||
return; | ||
} | ||
var db; | ||
var defaultConfig = getDefaultConfig(); | ||
var actualConfig = Object.assign(defaultConfig, config || {}); | ||
defineDriver(CordovaSQLiteDriver) | ||
@@ -239,7 +149,3 @@ .then(function () { | ||
*/ | ||
get: /** | ||
* Get the name of the driver being used. | ||
* @return {?} Name of the driver | ||
*/ | ||
function () { | ||
get: function () { | ||
return this._driver; | ||
@@ -254,24 +160,7 @@ }, | ||
*/ | ||
/** | ||
* Reflect the readiness of the store. | ||
* @return {?} Returns a promise that resolves when the store is ready | ||
*/ | ||
Storage.prototype.ready = /** | ||
* Reflect the readiness of the store. | ||
* @return {?} Returns a promise that resolves when the store is ready | ||
*/ | ||
function () { | ||
Storage.prototype.ready = function () { | ||
return this._dbPromise; | ||
}; | ||
/** | ||
* @hidden | ||
* @param {?} driverOrder | ||
* @return {?} | ||
*/ | ||
Storage.prototype._getDriverOrder = /** | ||
* @hidden | ||
* @param {?} driverOrder | ||
* @return {?} | ||
*/ | ||
function (driverOrder) { | ||
/** @hidden */ | ||
Storage.prototype._getDriverOrder = function (driverOrder) { | ||
return driverOrder.map(function (driver) { | ||
@@ -295,13 +184,3 @@ switch (driver) { | ||
*/ | ||
/** | ||
* Get the value associated with the given key. | ||
* @param {?} key the key to identify this value | ||
* @return {?} Returns a promise with the value of the given key | ||
*/ | ||
Storage.prototype.get = /** | ||
* Get the value associated with the given key. | ||
* @param {?} key the key to identify this value | ||
* @return {?} Returns a promise with the value of the given key | ||
*/ | ||
function (key) { | ||
Storage.prototype.get = function (key) { | ||
return this._dbPromise.then(function (db) { return db.getItem(key); }); | ||
@@ -315,15 +194,3 @@ }; | ||
*/ | ||
/** | ||
* Set the value for the given key. | ||
* @param {?} key the key to identify this value | ||
* @param {?} value the value for this key | ||
* @return {?} Returns a promise that resolves when the key and value are set | ||
*/ | ||
Storage.prototype.set = /** | ||
* Set the value for the given key. | ||
* @param {?} key the key to identify this value | ||
* @param {?} value the value for this key | ||
* @return {?} Returns a promise that resolves when the key and value are set | ||
*/ | ||
function (key, value) { | ||
Storage.prototype.set = function (key, value) { | ||
return this._dbPromise.then(function (db) { return db.setItem(key, value); }); | ||
@@ -336,13 +203,3 @@ }; | ||
*/ | ||
/** | ||
* Remove any value associated with this key. | ||
* @param {?} key the key to identify this value | ||
* @return {?} Returns a promise that resolves when the value is removed | ||
*/ | ||
Storage.prototype.remove = /** | ||
* Remove any value associated with this key. | ||
* @param {?} key the key to identify this value | ||
* @return {?} Returns a promise that resolves when the value is removed | ||
*/ | ||
function (key) { | ||
Storage.prototype.remove = function (key) { | ||
return this._dbPromise.then(function (db) { return db.removeItem(key); }); | ||
@@ -354,11 +211,3 @@ }; | ||
*/ | ||
/** | ||
* Clear the entire key value store. WARNING: HOT! | ||
* @return {?} Returns a promise that resolves when the store is cleared | ||
*/ | ||
Storage.prototype.clear = /** | ||
* Clear the entire key value store. WARNING: HOT! | ||
* @return {?} Returns a promise that resolves when the store is cleared | ||
*/ | ||
function () { | ||
Storage.prototype.clear = function () { | ||
return this._dbPromise.then(function (db) { return db.clear(); }); | ||
@@ -369,9 +218,3 @@ }; | ||
*/ | ||
/** | ||
* @return {?} Returns a promise that resolves with the number of keys stored. | ||
*/ | ||
Storage.prototype.length = /** | ||
* @return {?} Returns a promise that resolves with the number of keys stored. | ||
*/ | ||
function () { | ||
Storage.prototype.length = function () { | ||
return this._dbPromise.then(function (db) { return db.length(); }); | ||
@@ -382,9 +225,3 @@ }; | ||
*/ | ||
/** | ||
* @return {?} Returns a promise that resolves with the keys in the store. | ||
*/ | ||
Storage.prototype.keys = /** | ||
* @return {?} Returns a promise that resolves with the keys in the store. | ||
*/ | ||
function () { | ||
Storage.prototype.keys = function () { | ||
return this._dbPromise.then(function (db) { return db.keys(); }); | ||
@@ -397,13 +234,3 @@ }; | ||
*/ | ||
/** | ||
* Iterate through each key,value pair. | ||
* @param {?} iteratorCallback a callback of the form (value, key, iterationNumber) | ||
* @return {?} Returns a promise that resolves when the iteration has finished. | ||
*/ | ||
Storage.prototype.forEach = /** | ||
* Iterate through each key,value pair. | ||
* @param {?} iteratorCallback a callback of the form (value, key, iterationNumber) | ||
* @return {?} Returns a promise that resolves when the iteration has finished. | ||
*/ | ||
function (iteratorCallback) { | ||
Storage.prototype.forEach = function (iteratorCallback) { | ||
return this._dbPromise.then(function (db) { return db.iterate(iteratorCallback); }); | ||
@@ -413,6 +240,3 @@ }; | ||
}()); | ||
/** | ||
* @hidden | ||
* @return {?} | ||
*/ | ||
/** @hidden */ | ||
function getDefaultConfig() { | ||
@@ -426,35 +250,32 @@ return { | ||
} | ||
/** | ||
* @hidden | ||
*/ | ||
var /** @type {?} */ StorageConfigToken = new InjectionToken('STORAGE_CONFIG_TOKEN'); | ||
/** | ||
* @hidden | ||
* @param {?} storageConfig | ||
* @return {?} | ||
*/ | ||
/** @hidden */ | ||
var StorageConfigToken = new InjectionToken('STORAGE_CONFIG_TOKEN'); | ||
/** @hidden */ | ||
function provideStorage(storageConfig) { | ||
var /** @type {?} */ config = !!storageConfig ? storageConfig : getDefaultConfig(); | ||
var config = !!storageConfig ? storageConfig : getDefaultConfig(); | ||
return new Storage(config); | ||
} | ||
function getNoopDriver() { | ||
// noop driver for ssr environment | ||
var noop = function () { }; | ||
var driver = { | ||
getItem: noop, | ||
setItem: noop, | ||
removeItem: noop, | ||
clear: noop, | ||
length: function () { return 0; }, | ||
keys: function () { return []; }, | ||
iterate: noop | ||
}; | ||
return driver; | ||
} | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes} checked by tsc | ||
*/ | ||
var IonicStorageModule = /** @class */ (function () { | ||
function IonicStorageModule() { | ||
} | ||
/** | ||
* @param {?=} storageConfig | ||
* @return {?} | ||
*/ | ||
IonicStorageModule.forRoot = /** | ||
* @param {?=} storageConfig | ||
* @return {?} | ||
*/ | ||
function (storageConfig) { | ||
IonicStorageModule_1 = IonicStorageModule; | ||
IonicStorageModule.forRoot = function (storageConfig) { | ||
if (storageConfig === void 0) { storageConfig = null; } | ||
return { | ||
ngModule: IonicStorageModule, | ||
ngModule: IonicStorageModule_1, | ||
providers: [ | ||
@@ -470,5 +291,6 @@ { provide: StorageConfigToken, useValue: storageConfig }, | ||
}; | ||
IonicStorageModule.decorators = [ | ||
{ type: NgModule }, | ||
]; | ||
var IonicStorageModule_1; | ||
IonicStorageModule = IonicStorageModule_1 = __decorate([ | ||
NgModule() | ||
], IonicStorageModule); | ||
return IonicStorageModule; | ||
@@ -478,8 +300,6 @@ }()); | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes} checked by tsc | ||
* Generated bundle index. Do not edit. | ||
*/ | ||
export { StorageConfigToken, Storage, IonicStorageModule, provideStorage as ɵa }; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ionic-storage.js.map","sources":["ng://@ionic/storage/storage.ts","ng://@ionic/storage/index.ts"],"sourcesContent":["import { InjectionToken } from '@angular/core';\n\nimport * as LocalForage from 'localforage';\n\nimport * as CordovaSQLiteDriver from 'localforage-cordovasqlitedriver';\n\n/**\n * Storage is an easy way to store key/value pairs and JSON objects.\n * Storage uses a variety of storage engines underneath, picking the best one available\n * depending on the platform.\n *\n * When running in a native app context, Storage will prioritize using SQLite, as it's one of\n * the most stable and widely used file-based databases, and avoids some of the\n * pitfalls of things like localstorage and IndexedDB, such as the OS deciding to clear out such\n * data in low disk-space situations.\n *\n * When running in the web or as a Progressive Web App, Storage will attempt to use\n * IndexedDB, WebSQL, and localstorage, in that order.\n *\n * @usage\n * First, if you'd like to use SQLite, install the cordova-sqlite-storage plugin:\n * ```bash\n * ionic cordova plugin add cordova-sqlite-storage\n * ```\n *\n * Next, install the package (comes by default for Ionic apps > Ionic V1):\n * ```bash\n * npm install --save @ionic/storage\n * ```\n *\n * Next, add it to the imports list in your `NgModule` declaration (for example, in `src/app/app.module.ts`):\n *\n * ```typescript\n * import { IonicStorageModule } from '@ionic/storage';\n *\n * @NgModule({\n *   declarations: [\n *     // ...\n *   ],\n *   imports: [\n *     BrowserModule,\n *     IonicModule.forRoot(MyApp),\n *     IonicStorageModule.forRoot()\n *   ],\n *   bootstrap: [IonicApp],\n *   entryComponents: [\n *     // ...\n *   ],\n *   providers: [\n *     // ...\n *   ]\n * })\n * export class AppModule {}\n *```\n *\n * Finally, inject it into any of your components or pages:\n * ```typescript\n * import { Storage } from '@ionic/storage';\n\n * export class MyApp {\n *   constructor(private storage: Storage) { }\n *\n *   ...\n *\n *   // set a key/value\n *   storage.set('name', 'Max');\n *\n *   // Or to get a key/value pair\n *   storage.get('age').then((val) => {\n *     console.log('Your age is', val);\n *   });\n * }\n * ```\n *\n *\n * ### Configuring Storage\n *\n * The Storage engine can be configured both with specific storage engine priorities, or custom configuration\n * options to pass to localForage. See the localForage config docs for possible options: https://github.com/localForage/localForage#configuration\n *\n * Note: Any custom configurations will be merged with the default configuration\n *\n * ```typescript\n * import { IonicStorageModule } from '@ionic/storage';\n *\n * @NgModule({\n *   declarations: [...],\n *   imports: [\n *     IonicStorageModule.forRoot({\n *       name: '__mydb',\n         driverOrder: ['indexeddb', 'sqlite', 'websql']\n *     })\n *   ],\n *   bootstrap: [...],\n *   entryComponents: [...],\n *    providers: [...]\n * })\n * export class AppModule { }\n * ```\n */\nexport class Storage {\n  private _dbPromise: Promise<LocalForage>;\n  private _driver: string = null;\n\n  /**\n   * Create a new Storage instance using the order of drivers and any additional config\n   * options to pass to LocalForage.\n   *\n   * Possible driver options are: ['sqlite', 'indexeddb', 'websql', 'localstorage'] and the\n   * default is that exact ordering.\n   */\n  constructor(config: StorageConfig) {\n    this._dbPromise = new Promise((resolve, reject) => {\n      let db: LocalForage;\n\n      const defaultConfig = getDefaultConfig();\n      const actualConfig = Object.assign(defaultConfig, config || {});\n\n      LocalForage.defineDriver(CordovaSQLiteDriver)\n        .then(() => {\n          db = LocalForage.createInstance(actualConfig);\n        })\n        .then(() =>\n          db.setDriver(this._getDriverOrder(actualConfig.driverOrder))\n        )\n        .then(() => {\n          this._driver = db.driver();\n          resolve(db);\n        })\n        .catch(reason => reject(reason));\n    });\n  }\n\n  /**\n   * Get the name of the driver being used.\n   * @returns Name of the driver\n   */\n  get driver(): string | null {\n    return this._driver;\n  }\n\n  /**\n   * Reflect the readiness of the store.\n   * @returns Returns a promise that resolves when the store is ready\n   */\n  ready(): Promise<LocalForage> {\n    return this._dbPromise;\n  }\n\n  /** @hidden */\n  private _getDriverOrder(driverOrder) {\n    return driverOrder.map(driver => {\n      switch (driver) {\n        case 'sqlite':\n          return CordovaSQLiteDriver._driver;\n        case 'indexeddb':\n          return LocalForage.INDEXEDDB;\n        case 'websql':\n          return LocalForage.WEBSQL;\n        case 'localstorage':\n          return LocalForage.LOCALSTORAGE;\n      }\n    });\n  }\n\n  /**\n   * Get the value associated with the given key.\n   * @param key the key to identify this value\n   * @returns Returns a promise with the value of the given key\n   */\n  get(key: string): Promise<any> {\n    return this._dbPromise.then(db => db.getItem(key));\n  }\n\n  /**\n   * Set the value for the given key.\n   * @param key the key to identify this value\n   * @param value the value for this key\n   * @returns Returns a promise that resolves when the key and value are set\n   */\n  set(key: string, value: any): Promise<any> {\n    return this._dbPromise.then(db => db.setItem(key, value));\n  }\n\n  /**\n   * Remove any value associated with this key.\n   * @param key the key to identify this value\n   * @returns Returns a promise that resolves when the value is removed\n   */\n  remove(key: string): Promise<any> {\n    return this._dbPromise.then(db => db.removeItem(key));\n  }\n\n  /**\n   * Clear the entire key value store. WARNING: HOT!\n   * @returns Returns a promise that resolves when the store is cleared\n   */\n  clear(): Promise<void> {\n    return this._dbPromise.then(db => db.clear());\n  }\n\n  /**\n   * @returns Returns a promise that resolves with the number of keys stored.\n   */\n  length(): Promise<number> {\n    return this._dbPromise.then(db => db.length());\n  }\n\n  /**\n   * @returns Returns a promise that resolves with the keys in the store.\n   */\n  keys(): Promise<string[]> {\n    return this._dbPromise.then(db => db.keys());\n  }\n\n  /**\n   * Iterate through each key,value pair.\n   * @param iteratorCallback a callback of the form (value, key, iterationNumber)\n   * @returns Returns a promise that resolves when the iteration has finished.\n   */\n  forEach(\n    iteratorCallback: (value: any, key: string, iterationNumber: Number) => any\n  ): Promise<void> {\n    return this._dbPromise.then(db => db.iterate(iteratorCallback));\n  }\n}\n\n/** @hidden */\nexport function getDefaultConfig() {\n  return {\n    name: '_ionicstorage',\n    storeName: '_ionickv',\n    dbKey: '_ionickey',\n    driverOrder: ['sqlite', 'indexeddb', 'websql', 'localstorage']\n  };\n}\n\n/** @hidden */\nexport interface StorageConfig {\n  name?: string;\n  version?: number;\n  size?: number;\n  storeName?: string;\n  description?: string;\n  driverOrder?: string[];\n  dbKey?: string;\n}\n\n/** @hidden */\nexport const StorageConfigToken = new InjectionToken<any>(\n  'STORAGE_CONFIG_TOKEN'\n);\n\n/** @hidden */\nexport function provideStorage(storageConfig: StorageConfig): Storage {\n  const config = !!storageConfig ? storageConfig : getDefaultConfig();\n  return new Storage(config);\n}\n","import { NgModule, ModuleWithProviders } from '@angular/core';\nimport {\n  getDefaultConfig,\n  provideStorage,\n  Storage,\n  StorageConfig,\n  StorageConfigToken\n} from './storage';\n\nexport { StorageConfig, StorageConfigToken, Storage };\n\n@NgModule()\nexport class IonicStorageModule {\n  static forRoot(storageConfig: StorageConfig = null): ModuleWithProviders {\n    return {\n      ngModule: IonicStorageModule,\n      providers: [\n        { provide: StorageConfigToken, useValue: storageConfig },\n        {\n          provide: Storage,\n          useFactory: provideStorage,\n          deps: [StorageConfigToken]\n        }\n      ]\n    };\n  }\n}\n"],"names":["LocalForage.defineDriver","LocalForage.createInstance","CordovaSQLiteDriver._driver","LocalForage.INDEXEDDB","LocalForage.WEBSQL","LocalForage.LOCALSTORAGE"],"mappings":"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"} | ||
export { IonicStorageModule, Storage, StorageConfigToken, provideStorage as ɵa }; | ||
//# sourceMappingURL=ionic-storage.js.map |
@@ -5,3 +5,3 @@ import { ModuleWithProviders } from '@angular/core'; | ||
export declare class IonicStorageModule { | ||
static forRoot(storageConfig?: StorageConfig): ModuleWithProviders; | ||
static forRoot(storageConfig?: StorageConfig): ModuleWithProviders<IonicStorageModule>; | ||
} |
@@ -1,1 +0,1 @@ | ||
{"__symbolic":"module","version":4,"metadata":{"ɵa":{"__symbolic":"function"},"StorageConfig":{"__symbolic":"interface"},"StorageConfigToken":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":249,"character":38},"arguments":["STORAGE_CONFIG_TOKEN"]},"Storage":{"__symbolic":"class","members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"any"}]}],"ready":[{"__symbolic":"method"}],"_getDriverOrder":[{"__symbolic":"method"}],"get":[{"__symbolic":"method"}],"set":[{"__symbolic":"method"}],"remove":[{"__symbolic":"method"}],"clear":[{"__symbolic":"method"}],"length":[{"__symbolic":"method"}],"keys":[{"__symbolic":"method"}],"forEach":[{"__symbolic":"method"}]}},"IonicStorageModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":11,"character":1}}],"members":{},"statics":{"forRoot":{"__symbolic":"function","parameters":["storageConfig"],"defaults":[null],"value":{"ngModule":{"__symbolic":"reference","name":"IonicStorageModule"},"providers":[{"provide":{"__symbolic":"reference","name":"StorageConfigToken"},"useValue":{"__symbolic":"reference","name":"storageConfig"}},{"provide":{"__symbolic":"reference","name":"Storage"},"useFactory":{"__symbolic":"reference","name":"ɵa"},"deps":[{"__symbolic":"reference","name":"StorageConfigToken"}]}]}}}}},"origins":{"ɵa":"./storage","StorageConfig":"./storage","StorageConfigToken":"./storage","Storage":"./storage","IonicStorageModule":"./index"},"importAs":"@ionic/storage"} | ||
{"__symbolic":"module","version":4,"metadata":{"ɵa":{"__symbolic":"function"},"StorageConfig":{"__symbolic":"interface"},"StorageConfigToken":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":255,"character":38},"arguments":["STORAGE_CONFIG_TOKEN"]},"Storage":{"__symbolic":"class","members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","name":"any"}]}],"ready":[{"__symbolic":"method"}],"_getDriverOrder":[{"__symbolic":"method"}],"get":[{"__symbolic":"method"}],"set":[{"__symbolic":"method"}],"remove":[{"__symbolic":"method"}],"clear":[{"__symbolic":"method"}],"length":[{"__symbolic":"method"}],"keys":[{"__symbolic":"method"}],"forEach":[{"__symbolic":"method"}]}},"IonicStorageModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":11,"character":1}}],"members":{},"statics":{"forRoot":{"__symbolic":"function","parameters":["storageConfig"],"defaults":[null],"value":{"ngModule":{"__symbolic":"reference","name":"IonicStorageModule"},"providers":[{"provide":{"__symbolic":"reference","name":"StorageConfigToken"},"useValue":{"__symbolic":"reference","name":"storageConfig"}},{"provide":{"__symbolic":"reference","name":"Storage"},"useFactory":{"__symbolic":"reference","name":"ɵa"},"deps":[{"__symbolic":"reference","name":"StorageConfigToken"}]}]}}}}},"origins":{"ɵa":"./storage","StorageConfig":"./storage","StorageConfigToken":"./storage","Storage":"./storage","IonicStorageModule":"./index"},"importAs":"@ionic/storage"} |
{ | ||
"name": "@ionic/storage", | ||
"version": "2.2.0", | ||
"version": "2.3.0", | ||
"description": "Ionic Storage utility", | ||
@@ -24,25 +24,4 @@ "repository": { | ||
"localforage-cordovasqlitedriver": "1.7.0", | ||
"tslib": "^1.7.1" | ||
"tslib": "^1.10.0" | ||
}, | ||
"devDependencies": { | ||
"@angular/compiler": "^5.2.11", | ||
"@angular/compiler-cli": "^5.2.11", | ||
"@angular/core": "^5.2.11", | ||
"@types/node": "^6.0.41", | ||
"canonical-path": "0.0.2", | ||
"conventional-changelog-cli": "^2.0.1", | ||
"cpr": "^2.0.0", | ||
"dgeni": "0.4.9", | ||
"dgeni-packages": "0.26.2", | ||
"gulp": "^3.9.1", | ||
"ng-packagr": "^3.0.1", | ||
"np": "3.0.4", | ||
"rimraf": "^2.6.2", | ||
"rxjs": "5.5.2", | ||
"semver": "^5.3.0", | ||
"tslint": "^5.10.0", | ||
"tslint-ionic-rules": "*", | ||
"typescript": "^2.6.2", | ||
"zone.js": "^0.8.26" | ||
}, | ||
"peerDependencies": { | ||
@@ -49,0 +28,0 @@ "@angular/core": "*", |
@@ -1,2 +0,2 @@ | ||
[![Circle CI](https://circleci.com/gh/ionic-team/ionic-storage.svg?style=shield)](https://circleci.com/gh/ionic-team/ionic-storage) | ||
[![Build Status](https://img.shields.io/endpoint.svg?url=https%3A%2F%2Factions-badge.atrox.dev%2Fionic-team%2Fionic-storage%2Fbadge%3Fref%3Dmain&style=flat)](https://actions-badge.atrox.dev/ionic-team/ionic-storage/goto?ref=main) | ||
@@ -58,5 +58,2 @@ # Ionic Storage | ||
import { Component } from '@angular/core'; | ||
import { NavController } from 'ionic-angular'; | ||
import { Storage } from '@ionic/storage'; | ||
@@ -70,3 +67,3 @@ | ||
constructor(public navCtrl: NavController, public storage: Storage) { | ||
constructor(private storage: Storage) { | ||
} | ||
@@ -133,2 +130,4 @@ | ||
2. npm run build | ||
3. npm publish | ||
3. commit and push: `git push origin master --tags` | ||
4. cd dist | ||
5. npm publish |
@@ -112,3 +112,3 @@ /// <reference types="localforage" /> | ||
*/ | ||
readonly driver: string | null; | ||
get driver(): string | null; | ||
/** | ||
@@ -115,0 +115,0 @@ * Reflect the readiness of the store. |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
0
22
197750
1778
131
Updatedtslib@^1.10.0