Socket
Socket
Sign inDemoInstall

@ionic/storage-angular

Package Overview
Dependencies
Maintainers
24
Versions
12
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@ionic/storage-angular - npm Package Compare versions

Comparing version 3.0.0-alpha.5 to 3.0.2

94

bundles/ionic-storage-angular.umd.js

@@ -298,96 +298,2 @@ (function (global, factory) {

}
/**
* 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 { }
* ```
*/
var IonicStorageModule = /** @class */ (function () {

@@ -394,0 +300,0 @@ function IonicStorageModule() {

96

esm2015/index.js

@@ -54,96 +54,2 @@ var IonicStorageModule_1;

}
/**
* 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 { }
* ```
*/
let IonicStorageModule = IonicStorageModule_1 = class IonicStorageModule {

@@ -168,2 +74,2 @@ static forRoot(storageConfig = null) {

export { IonicStorageModule };
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AaW9uaWMvc3RvcmFnZS1hbmd1bGFyLyIsInNvdXJjZXMiOlsiaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFvQyxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFM0YsT0FBTyxFQUNMLE9BQU8sRUFFUixNQUFNLGdCQUFnQixDQUFDO0FBQ3hCLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBRW5ELE1BQU0sa0JBQWtCLEdBQUcsSUFBSSxjQUFjLENBQzNDLHNCQUFzQixDQUN2QixDQUFDO0FBRUYsT0FBTyxFQUFpQixrQkFBa0IsRUFBRSxPQUFPLEVBQUUsQ0FBQztBQUV0RCxNQUFNLFdBQVksU0FBUSxPQUFPO0lBQy9CO1FBQ0UsS0FBSyxFQUFFLENBQUM7SUFDVixDQUFDO0lBQ0ssTUFBTTs7WUFDVixPQUFPLElBQUksQ0FBQztRQUNkLENBQUM7S0FBQTtJQUNLLFlBQVk7O1FBQ2xCLENBQUM7S0FBQTtJQUNELElBQUksTUFBTTtRQUNSLE9BQU8sTUFBTSxDQUFDO0lBQ2hCLENBQUM7SUFDSyxHQUFHLENBQUMsR0FBVzs4REFBSSxPQUFPLElBQUksQ0FBQyxDQUFDLENBQUM7S0FBQTtJQUNqQyxHQUFHLENBQUMsR0FBVyxFQUFFLEtBQVU7OERBQUksQ0FBQztLQUFBO0lBQ2hDLE1BQU0sQ0FBQyxHQUFXOzhEQUFrQixDQUFDO0tBQUE7SUFDckMsS0FBSzs4REFBb0IsQ0FBQztLQUFBO0lBQzFCLE1BQU07OERBQXNCLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQztLQUFBO0lBQ3ZDLElBQUk7OERBQUssT0FBTyxFQUFFLENBQUEsQ0FBQyxDQUFDO0tBQUE7SUFDcEIsT0FBTyxDQUFDLGdCQUEyRTs4REFBbUIsQ0FBQztLQUFBO0lBQzdHLGdCQUFnQixDQUFDLEdBQVcsSUFBSSxDQUFDO0NBQ2xDO0FBRUQsTUFBTSxVQUFVLGNBQWMsQ0FDNUIsYUFBNEI7SUFFNUIsSUFBSSxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLEVBQUU7UUFDckMsMERBQTBEO1FBQzFELE9BQU8sSUFBSSxXQUFXLEVBQUUsQ0FBQztLQUMxQjtJQUVELE9BQU8sSUFBSSxPQUFPLENBQUMsYUFBYSxDQUFDLENBQUM7QUFDcEMsQ0FBQztBQUdEOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0E2Rkc7QUFFSCxJQUFhLGtCQUFrQiwwQkFBL0IsTUFBYSxrQkFBa0I7SUFDN0IsTUFBTSxDQUFDLE9BQU8sQ0FBQyxnQkFBK0IsSUFBSTtRQUNoRCxPQUFPO1lBQ0wsUUFBUSxFQUFFLG9CQUFrQjtZQUM1QixTQUFTLEVBQUU7Z0JBQ1QsRUFBRSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsUUFBUSxFQUFFLGFBQWEsRUFBRTtnQkFDeEQ7b0JBQ0UsT0FBTyxFQUFFLE9BQU87b0JBQ2hCLFVBQVUsRUFBRSxjQUFjO29CQUMxQixJQUFJLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQztpQkFDM0I7YUFDRjtTQUNGLENBQUM7SUFDSixDQUFDO0NBQ0YsQ0FBQTtBQWRZLGtCQUFrQjtJQUQ5QixRQUFRLEVBQUU7R0FDRSxrQkFBa0IsQ0FjOUI7U0FkWSxrQkFBa0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSwgTW9kdWxlV2l0aFByb3ZpZGVycywgUExBVEZPUk1fSUQsIEluamVjdGlvblRva2VuIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7XG4gIFN0b3JhZ2UsXG4gIFN0b3JhZ2VDb25maWdcbn0gZnJvbSAnQGlvbmljL3N0b3JhZ2UnO1xuaW1wb3J0IHsgaXNQbGF0Zm9ybVNlcnZlciB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5cbmNvbnN0IFN0b3JhZ2VDb25maWdUb2tlbiA9IG5ldyBJbmplY3Rpb25Ub2tlbjxhbnk+KFxuICAnU1RPUkFHRV9DT05GSUdfVE9LRU4nXG4pO1xuXG5leHBvcnQgeyBTdG9yYWdlQ29uZmlnLCBTdG9yYWdlQ29uZmlnVG9rZW4sIFN0b3JhZ2UgfTtcblxuY2xhc3MgTm9vcFN0b3JhZ2UgZXh0ZW5kcyBTdG9yYWdlIHtcbiAgY29uc3RydWN0b3IoKSB7XG4gICAgc3VwZXIoKTtcbiAgfVxuICBhc3luYyBjcmVhdGUoKSB7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cbiAgYXN5bmMgZGVmaW5lRHJpdmVyKCkge1xuICB9XG4gIGdldCBkcml2ZXIoKTogc3RyaW5nIHwgbnVsbCB7XG4gICAgcmV0dXJuICdub29wJztcbiAgfVxuICBhc3luYyBnZXQoa2V5OiBzdHJpbmcpIHsgcmV0dXJuIG51bGw7IH1cbiAgYXN5bmMgc2V0KGtleTogc3RyaW5nLCB2YWx1ZTogYW55KSB7IH1cbiAgYXN5bmMgcmVtb3ZlKGtleTogc3RyaW5nKTogUHJvbWlzZTxhbnk+IHsgfVxuICBhc3luYyBjbGVhcigpOiBQcm9taXNlPHZvaWQ+IHsgfVxuICBhc3luYyBsZW5ndGgoKTogUHJvbWlzZTxudW1iZXI+IHsgcmV0dXJuIDA7IH1cbiAgYXN5bmMga2V5cygpIHsgcmV0dXJuIFtdIH1cbiAgYXN5bmMgZm9yRWFjaChpdGVyYXRvckNhbGxiYWNrOiAodmFsdWU6IGFueSwga2V5OiBzdHJpbmcsIGl0ZXJhdGlvbk51bWJlcjogTnVtYmVyKSA9PiBhbnkpOiBQcm9taXNlPHZvaWQ+IHsgfVxuICBzZXRFbmNyeXB0aW9uS2V5KGtleTogc3RyaW5nKSB7IH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHByb3ZpZGVTdG9yYWdlKFxuICBzdG9yYWdlQ29uZmlnOiBTdG9yYWdlQ29uZmlnXG4pOiBTdG9yYWdlIHtcbiAgaWYgKGlzUGxhdGZvcm1TZXJ2ZXIodGhpcy5wbGF0Zm9ybUlkKSkge1xuICAgIC8vIFdoZW4gcnVubmluZyBpbiBhIHNlcnZlciBjb250ZXh0IHJldHVybiB0aGUgTm9vcFN0b3JhZ2VcbiAgICByZXR1cm4gbmV3IE5vb3BTdG9yYWdlKCk7XG4gIH1cblxuICByZXR1cm4gbmV3IFN0b3JhZ2Uoc3RvcmFnZUNvbmZpZyk7XG59XG5cblxuLyoqXG4gKiBTdG9yYWdlIGlzIGFuIGVhc3kgd2F5IHRvIHN0b3JlIGtleS92YWx1ZSBwYWlycyBhbmQgSlNPTiBvYmplY3RzLlxuICogU3RvcmFnZSB1c2VzIGEgdmFyaWV0eSBvZiBzdG9yYWdlIGVuZ2luZXMgdW5kZXJuZWF0aCwgcGlja2luZyB0aGUgYmVzdCBvbmUgYXZhaWxhYmxlXG4gKiBkZXBlbmRpbmcgb24gdGhlIHBsYXRmb3JtLlxuICpcbiAqIFdoZW4gcnVubmluZyBpbiBhIG5hdGl2ZSBhcHAgY29udGV4dCwgU3RvcmFnZSB3aWxsIHByaW9yaXRpemUgdXNpbmcgU1FMaXRlLCBhcyBpdCdzIG9uZSBvZlxuICogdGhlIG1vc3Qgc3RhYmxlIGFuZCB3aWRlbHkgdXNlZCBmaWxlLWJhc2VkIGRhdGFiYXNlcywgYW5kIGF2b2lkcyBzb21lIG9mIHRoZVxuICogcGl0ZmFsbHMgb2YgdGhpbmdzIGxpa2UgbG9jYWxzdG9yYWdlIGFuZCBJbmRleGVkREIsIHN1Y2ggYXMgdGhlIE9TIGRlY2lkaW5nIHRvIGNsZWFyIG91dCBzdWNoXG4gKiBkYXRhIGluIGxvdyBkaXNrLXNwYWNlIHNpdHVhdGlvbnMuXG4gKlxuICogV2hlbiBydW5uaW5nIGluIHRoZSB3ZWIgb3IgYXMgYSBQcm9ncmVzc2l2ZSBXZWIgQXBwLCBTdG9yYWdlIHdpbGwgYXR0ZW1wdCB0byB1c2VcbiAqIEluZGV4ZWREQiwgV2ViU1FMLCBhbmQgbG9jYWxzdG9yYWdlLCBpbiB0aGF0IG9yZGVyLlxuICpcbiAqIEB1c2FnZVxuICogRmlyc3QsIGlmIHlvdSdkIGxpa2UgdG8gdXNlIFNRTGl0ZSwgaW5zdGFsbCB0aGUgY29yZG92YS1zcWxpdGUtc3RvcmFnZSBwbHVnaW46XG4gKiBgYGBiYXNoXG4gKiBpb25pYyBjb3Jkb3ZhIHBsdWdpbiBhZGQgY29yZG92YS1zcWxpdGUtc3RvcmFnZVxuICogYGBgXG4gKlxuICogTmV4dCwgaW5zdGFsbCB0aGUgcGFja2FnZSAoY29tZXMgYnkgZGVmYXVsdCBmb3IgSW9uaWMgYXBwcyA+IElvbmljIFYxKTpcbiAqIGBgYGJhc2hcbiAqIG5wbSBpbnN0YWxsIC0tc2F2ZSBAaW9uaWMvc3RvcmFnZVxuICogYGBgXG4gKlxuICogTmV4dCwgYWRkIGl0IHRvIHRoZSBpbXBvcnRzIGxpc3QgaW4geW91ciBgTmdNb2R1bGVgIGRlY2xhcmF0aW9uIChmb3IgZXhhbXBsZSwgaW4gYHNyYy9hcHAvYXBwLm1vZHVsZS50c2ApOlxuICpcbiAqIGBgYHR5cGVzY3JpcHRcbiAqIGltcG9ydCB7IElvbmljU3RvcmFnZU1vZHVsZSB9IGZyb20gJ0Bpb25pYy9zdG9yYWdlJztcbiAqXG4gKiBATmdNb2R1bGUoe1xuICogICBkZWNsYXJhdGlvbnM6IFtcbiAqICAgICAvLyAuLi5cbiAqICAgXSxcbiAqICAgaW1wb3J0czogW1xuICogICAgIEJyb3dzZXJNb2R1bGUsXG4gKiAgICAgSW9uaWNNb2R1bGUuZm9yUm9vdChNeUFwcCksXG4gKiAgICAgSW9uaWNTdG9yYWdlTW9kdWxlLmZvclJvb3QoKVxuICogICBdLFxuICogICBib290c3RyYXA6IFtJb25pY0FwcF0sXG4gKiAgIGVudHJ5Q29tcG9uZW50czogW1xuICogICAgIC8vIC4uLlxuICogICBdLFxuICogICBwcm92aWRlcnM6IFtcbiAqICAgICAvLyAuLi5cbiAqICAgXVxuICogfSlcbiAqIGV4cG9ydCBjbGFzcyBBcHBNb2R1bGUge31cbiAqYGBgXG4gKlxuICogRmluYWxseSwgaW5qZWN0IGl0IGludG8gYW55IG9mIHlvdXIgY29tcG9uZW50cyBvciBwYWdlczpcbiAqIGBgYHR5cGVzY3JpcHRcbiAqIGltcG9ydCB7IFN0b3JhZ2UgfSBmcm9tICdAaW9uaWMvc3RvcmFnZSc7XG5cbiAqIGV4cG9ydCBjbGFzcyBNeUFwcCB7XG4gKiAgIGNvbnN0cnVjdG9yKHByaXZhdGUgc3RvcmFnZTogU3RvcmFnZSkgeyB9XG4gKlxuICogICAuLi5cbiAqXG4gKiAgIC8vIHNldCBhIGtleS92YWx1ZVxuICogICBzdG9yYWdlLnNldCgnbmFtZScsICdNYXgnKTtcbiAqXG4gKiAgIC8vIE9yIHRvIGdldCBhIGtleS92YWx1ZSBwYWlyXG4gKiAgIHN0b3JhZ2UuZ2V0KCdhZ2UnKS50aGVuKCh2YWwpID0+IHtcbiAqICAgICBjb25zb2xlLmxvZygnWW91ciBhZ2UgaXMnLCB2YWwpO1xuICogICB9KTtcbiAqIH1cbiAqIGBgYFxuICpcbiAqXG4gKiAjIyMgQ29uZmlndXJpbmcgU3RvcmFnZVxuICpcbiAqIFRoZSBTdG9yYWdlIGVuZ2luZSBjYW4gYmUgY29uZmlndXJlZCBib3RoIHdpdGggc3BlY2lmaWMgc3RvcmFnZSBlbmdpbmUgcHJpb3JpdGllcywgb3IgY3VzdG9tIGNvbmZpZ3VyYXRpb25cbiAqIG9wdGlvbnMgdG8gcGFzcyB0byBsb2NhbEZvcmFnZS4gU2VlIHRoZSBsb2NhbEZvcmFnZSBjb25maWcgZG9jcyBmb3IgcG9zc2libGUgb3B0aW9uczogaHR0cHM6Ly9naXRodWIuY29tL2xvY2FsRm9yYWdlL2xvY2FsRm9yYWdlI2NvbmZpZ3VyYXRpb25cbiAqXG4gKiBOb3RlOiBBbnkgY3VzdG9tIGNvbmZpZ3VyYXRpb25zIHdpbGwgYmUgbWVyZ2VkIHdpdGggdGhlIGRlZmF1bHQgY29uZmlndXJhdGlvblxuICpcbiAqIGBgYHR5cGVzY3JpcHRcbiAqIGltcG9ydCB7IElvbmljU3RvcmFnZU1vZHVsZSB9IGZyb20gJ0Bpb25pYy9zdG9yYWdlJztcbiAqXG4gKiBATmdNb2R1bGUoe1xuICogICBkZWNsYXJhdGlvbnM6IFsuLi5dLFxuICogICBpbXBvcnRzOiBbXG4gKiAgICAgSW9uaWNTdG9yYWdlTW9kdWxlLmZvclJvb3Qoe1xuICogICAgICAgbmFtZTogJ19fbXlkYicsXG4gICAgICAgICBkcml2ZXJPcmRlcjogWydpbmRleGVkZGInLCAnc3FsaXRlJywgJ3dlYnNxbCddXG4gKiAgICAgfSlcbiAqICAgXSxcbiAqICAgYm9vdHN0cmFwOiBbLi4uXSxcbiAqICAgZW50cnlDb21wb25lbnRzOiBbLi4uXSxcbiAqICAgIHByb3ZpZGVyczogWy4uLl1cbiAqIH0pXG4gKiBleHBvcnQgY2xhc3MgQXBwTW9kdWxlIHsgfVxuICogYGBgXG4gKi9cbkBOZ01vZHVsZSgpXG5leHBvcnQgY2xhc3MgSW9uaWNTdG9yYWdlTW9kdWxlIHtcbiAgc3RhdGljIGZvclJvb3Qoc3RvcmFnZUNvbmZpZzogU3RvcmFnZUNvbmZpZyA9IG51bGwpOiBNb2R1bGVXaXRoUHJvdmlkZXJzPElvbmljU3RvcmFnZU1vZHVsZT4ge1xuICAgIHJldHVybiB7XG4gICAgICBuZ01vZHVsZTogSW9uaWNTdG9yYWdlTW9kdWxlLFxuICAgICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIHsgcHJvdmlkZTogU3RvcmFnZUNvbmZpZ1Rva2VuLCB1c2VWYWx1ZTogc3RvcmFnZUNvbmZpZyB9LFxuICAgICAgICB7XG4gICAgICAgICAgcHJvdmlkZTogU3RvcmFnZSxcbiAgICAgICAgICB1c2VGYWN0b3J5OiBwcm92aWRlU3RvcmFnZSxcbiAgICAgICAgICBkZXBzOiBbU3RvcmFnZUNvbmZpZ1Rva2VuXVxuICAgICAgICB9XG4gICAgICBdXG4gICAgfTtcbiAgfVxufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AaW9uaWMvc3RvcmFnZS1hbmd1bGFyLyIsInNvdXJjZXMiOlsiaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFvQyxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFM0YsT0FBTyxFQUNMLE9BQU8sRUFFUixNQUFNLGdCQUFnQixDQUFDO0FBQ3hCLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBRW5ELE1BQU0sa0JBQWtCLEdBQUcsSUFBSSxjQUFjLENBQzNDLHNCQUFzQixDQUN2QixDQUFDO0FBRUYsT0FBTyxFQUFpQixrQkFBa0IsRUFBRSxPQUFPLEVBQUUsQ0FBQztBQUV0RCxNQUFNLFdBQVksU0FBUSxPQUFPO0lBQy9CO1FBQ0UsS0FBSyxFQUFFLENBQUM7SUFDVixDQUFDO0lBQ0ssTUFBTTs7WUFDVixPQUFPLElBQUksQ0FBQztRQUNkLENBQUM7S0FBQTtJQUNLLFlBQVk7O1FBQ2xCLENBQUM7S0FBQTtJQUNELElBQUksTUFBTTtRQUNSLE9BQU8sTUFBTSxDQUFDO0lBQ2hCLENBQUM7SUFDSyxHQUFHLENBQUMsR0FBVzs4REFBSSxPQUFPLElBQUksQ0FBQyxDQUFDLENBQUM7S0FBQTtJQUNqQyxHQUFHLENBQUMsR0FBVyxFQUFFLEtBQVU7OERBQUksQ0FBQztLQUFBO0lBQ2hDLE1BQU0sQ0FBQyxHQUFXOzhEQUFrQixDQUFDO0tBQUE7SUFDckMsS0FBSzs4REFBb0IsQ0FBQztLQUFBO0lBQzFCLE1BQU07OERBQXNCLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQztLQUFBO0lBQ3ZDLElBQUk7OERBQUssT0FBTyxFQUFFLENBQUEsQ0FBQyxDQUFDO0tBQUE7SUFDcEIsT0FBTyxDQUFDLGdCQUEyRTs4REFBbUIsQ0FBQztLQUFBO0lBQzdHLGdCQUFnQixDQUFDLEdBQVcsSUFBSSxDQUFDO0NBQ2xDO0FBRUQsTUFBTSxVQUFVLGNBQWMsQ0FDNUIsYUFBNEI7SUFFNUIsSUFBSSxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLEVBQUU7UUFDckMsMERBQTBEO1FBQzFELE9BQU8sSUFBSSxXQUFXLEVBQUUsQ0FBQztLQUMxQjtJQUVELE9BQU8sSUFBSSxPQUFPLENBQUMsYUFBYSxDQUFDLENBQUM7QUFDcEMsQ0FBQztBQUdELElBQWEsa0JBQWtCLDBCQUEvQixNQUFhLGtCQUFrQjtJQUM3QixNQUFNLENBQUMsT0FBTyxDQUFDLGdCQUErQixJQUFJO1FBQ2hELE9BQU87WUFDTCxRQUFRLEVBQUUsb0JBQWtCO1lBQzVCLFNBQVMsRUFBRTtnQkFDVCxFQUFFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxRQUFRLEVBQUUsYUFBYSxFQUFFO2dCQUN4RDtvQkFDRSxPQUFPLEVBQUUsT0FBTztvQkFDaEIsVUFBVSxFQUFFLGNBQWM7b0JBQzFCLElBQUksRUFBRSxDQUFDLGtCQUFrQixDQUFDO2lCQUMzQjthQUNGO1NBQ0YsQ0FBQztJQUNKLENBQUM7Q0FDRixDQUFBO0FBZFksa0JBQWtCO0lBRDlCLFFBQVEsRUFBRTtHQUNFLGtCQUFrQixDQWM5QjtTQWRZLGtCQUFrQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlLCBNb2R1bGVXaXRoUHJvdmlkZXJzLCBQTEFURk9STV9JRCwgSW5qZWN0aW9uVG9rZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHtcbiAgU3RvcmFnZSxcbiAgU3RvcmFnZUNvbmZpZ1xufSBmcm9tICdAaW9uaWMvc3RvcmFnZSc7XG5pbXBvcnQgeyBpc1BsYXRmb3JtU2VydmVyIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcblxuY29uc3QgU3RvcmFnZUNvbmZpZ1Rva2VuID0gbmV3IEluamVjdGlvblRva2VuPGFueT4oXG4gICdTVE9SQUdFX0NPTkZJR19UT0tFTidcbik7XG5cbmV4cG9ydCB7IFN0b3JhZ2VDb25maWcsIFN0b3JhZ2VDb25maWdUb2tlbiwgU3RvcmFnZSB9O1xuXG5jbGFzcyBOb29wU3RvcmFnZSBleHRlbmRzIFN0b3JhZ2Uge1xuICBjb25zdHJ1Y3RvcigpIHtcbiAgICBzdXBlcigpO1xuICB9XG4gIGFzeW5jIGNyZWF0ZSgpIHtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuICBhc3luYyBkZWZpbmVEcml2ZXIoKSB7XG4gIH1cbiAgZ2V0IGRyaXZlcigpOiBzdHJpbmcgfCBudWxsIHtcbiAgICByZXR1cm4gJ25vb3AnO1xuICB9XG4gIGFzeW5jIGdldChrZXk6IHN0cmluZykgeyByZXR1cm4gbnVsbDsgfVxuICBhc3luYyBzZXQoa2V5OiBzdHJpbmcsIHZhbHVlOiBhbnkpIHsgfVxuICBhc3luYyByZW1vdmUoa2V5OiBzdHJpbmcpOiBQcm9taXNlPGFueT4geyB9XG4gIGFzeW5jIGNsZWFyKCk6IFByb21pc2U8dm9pZD4geyB9XG4gIGFzeW5jIGxlbmd0aCgpOiBQcm9taXNlPG51bWJlcj4geyByZXR1cm4gMDsgfVxuICBhc3luYyBrZXlzKCkgeyByZXR1cm4gW10gfVxuICBhc3luYyBmb3JFYWNoKGl0ZXJhdG9yQ2FsbGJhY2s6ICh2YWx1ZTogYW55LCBrZXk6IHN0cmluZywgaXRlcmF0aW9uTnVtYmVyOiBOdW1iZXIpID0+IGFueSk6IFByb21pc2U8dm9pZD4geyB9XG4gIHNldEVuY3J5cHRpb25LZXkoa2V5OiBzdHJpbmcpIHsgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gcHJvdmlkZVN0b3JhZ2UoXG4gIHN0b3JhZ2VDb25maWc6IFN0b3JhZ2VDb25maWdcbik6IFN0b3JhZ2Uge1xuICBpZiAoaXNQbGF0Zm9ybVNlcnZlcih0aGlzLnBsYXRmb3JtSWQpKSB7XG4gICAgLy8gV2hlbiBydW5uaW5nIGluIGEgc2VydmVyIGNvbnRleHQgcmV0dXJuIHRoZSBOb29wU3RvcmFnZVxuICAgIHJldHVybiBuZXcgTm9vcFN0b3JhZ2UoKTtcbiAgfVxuXG4gIHJldHVybiBuZXcgU3RvcmFnZShzdG9yYWdlQ29uZmlnKTtcbn1cblxuQE5nTW9kdWxlKClcbmV4cG9ydCBjbGFzcyBJb25pY1N0b3JhZ2VNb2R1bGUge1xuICBzdGF0aWMgZm9yUm9vdChzdG9yYWdlQ29uZmlnOiBTdG9yYWdlQ29uZmlnID0gbnVsbCk6IE1vZHVsZVdpdGhQcm92aWRlcnM8SW9uaWNTdG9yYWdlTW9kdWxlPiB7XG4gICAgcmV0dXJuIHtcbiAgICAgIG5nTW9kdWxlOiBJb25pY1N0b3JhZ2VNb2R1bGUsXG4gICAgICBwcm92aWRlcnM6IFtcbiAgICAgICAgeyBwcm92aWRlOiBTdG9yYWdlQ29uZmlnVG9rZW4sIHVzZVZhbHVlOiBzdG9yYWdlQ29uZmlnIH0sXG4gICAgICAgIHtcbiAgICAgICAgICBwcm92aWRlOiBTdG9yYWdlLFxuICAgICAgICAgIHVzZUZhY3Rvcnk6IHByb3ZpZGVTdG9yYWdlLFxuICAgICAgICAgIGRlcHM6IFtTdG9yYWdlQ29uZmlnVG9rZW5dXG4gICAgICAgIH1cbiAgICAgIF1cbiAgICB9O1xuICB9XG59XG4iXX0=

@@ -78,96 +78,2 @@ import { __awaiter, __decorate, __extends, __generator } from "tslib";

}
/**
* 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 { }
* ```
*/
var IonicStorageModule = /** @class */ (function () {

@@ -198,2 +104,2 @@ function IonicStorageModule() {

export { IonicStorageModule };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"ng://@ionic/storage-angular/","sources":["index.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,QAAQ,EAAoC,cAAc,EAAE,MAAM,eAAe,CAAC;AAE3F,OAAO,EACL,OAAO,EAER,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAEnD,IAAM,kBAAkB,GAAG,IAAI,cAAc,CAC3C,sBAAsB,CACvB,CAAC;AAEF,OAAO,EAAiB,kBAAkB,EAAE,OAAO,EAAE,CAAC;AAEtD;IAA0B,+BAAO;IAC/B;eACE,iBAAO;IACT,CAAC;IACK,4BAAM,GAAZ;;;gBACE,sBAAO,IAAI,EAAC;;;KACb;IACK,kCAAY,GAAlB;;;;;;KACC;IACD,sBAAI,+BAAM;aAAV;YACE,OAAO,MAAM,CAAC;QAChB,CAAC;;;OAAA;IACK,yBAAG,GAAT,UAAU,GAAW;;YAAI,sBAAO,IAAI,EAAC;;KAAE;IACjC,yBAAG,GAAT,UAAU,GAAW,EAAE,KAAU;;;;KAAK;IAChC,4BAAM,GAAZ,UAAa,GAAW;;;;KAAmB;IACrC,2BAAK,GAAX;;;;KAAgC;IAC1B,4BAAM,GAAZ;;YAAkC,sBAAO,CAAC,EAAC;;KAAE;IACvC,0BAAI,GAAV;;YAAe,sBAAO,EAAE,EAAA;;KAAE;IACpB,6BAAO,GAAb,UAAc,gBAA2E;;;;KAAoB;IAC7G,sCAAgB,GAAhB,UAAiB,GAAW,IAAI,CAAC;IACnC,kBAAC;AAAD,CAAC,AApBD,CAA0B,OAAO,GAoBhC;AAED,MAAM,UAAU,cAAc,CAC5B,aAA4B;IAE5B,IAAI,gBAAgB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE;QACrC,0DAA0D;QAC1D,OAAO,IAAI,WAAW,EAAE,CAAC;KAC1B;IAED,OAAO,IAAI,OAAO,CAAC,aAAa,CAAC,CAAC;AACpC,CAAC;AAGD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6FG;AAEH;IAAA;IAcA,CAAC;2BAdY,kBAAkB;IACtB,0BAAO,GAAd,UAAe,aAAmC;QAAnC,8BAAA,EAAA,oBAAmC;QAChD,OAAO;YACL,QAAQ,EAAE,oBAAkB;YAC5B,SAAS,EAAE;gBACT,EAAE,OAAO,EAAE,kBAAkB,EAAE,QAAQ,EAAE,aAAa,EAAE;gBACxD;oBACE,OAAO,EAAE,OAAO;oBAChB,UAAU,EAAE,cAAc;oBAC1B,IAAI,EAAE,CAAC,kBAAkB,CAAC;iBAC3B;aACF;SACF,CAAC;IACJ,CAAC;;IAbU,kBAAkB;QAD9B,QAAQ,EAAE;OACE,kBAAkB,CAc9B;IAAD,yBAAC;CAAA,AAdD,IAcC;SAdY,kBAAkB","sourcesContent":["import { NgModule, ModuleWithProviders, PLATFORM_ID, InjectionToken } from '@angular/core';\n\nimport {\n  Storage,\n  StorageConfig\n} from '@ionic/storage';\nimport { isPlatformServer } from '@angular/common';\n\nconst StorageConfigToken = new InjectionToken<any>(\n  'STORAGE_CONFIG_TOKEN'\n);\n\nexport { StorageConfig, StorageConfigToken, Storage };\n\nclass NoopStorage extends Storage {\n  constructor() {\n    super();\n  }\n  async create() {\n    return this;\n  }\n  async defineDriver() {\n  }\n  get driver(): string | null {\n    return 'noop';\n  }\n  async get(key: string) { return null; }\n  async set(key: string, value: any) { }\n  async remove(key: string): Promise<any> { }\n  async clear(): Promise<void> { }\n  async length(): Promise<number> { return 0; }\n  async keys() { return [] }\n  async forEach(iteratorCallback: (value: any, key: string, iterationNumber: Number) => any): Promise<void> { }\n  setEncryptionKey(key: string) { }\n}\n\nexport function provideStorage(\n  storageConfig: StorageConfig\n): Storage {\n  if (isPlatformServer(this.platformId)) {\n    // When running in a server context return the NoopStorage\n    return new NoopStorage();\n  }\n\n  return new Storage(storageConfig);\n}\n\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 */\n@NgModule()\nexport class IonicStorageModule {\n  static forRoot(storageConfig: StorageConfig = null): ModuleWithProviders<IonicStorageModule> {\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"]}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AaW9uaWMvc3RvcmFnZS1hbmd1bGFyLyIsInNvdXJjZXMiOlsiaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQW9DLGNBQWMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUzRixPQUFPLEVBQ0wsT0FBTyxFQUVSLE1BQU0sZ0JBQWdCLENBQUM7QUFDeEIsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFbkQsSUFBTSxrQkFBa0IsR0FBRyxJQUFJLGNBQWMsQ0FDM0Msc0JBQXNCLENBQ3ZCLENBQUM7QUFFRixPQUFPLEVBQWlCLGtCQUFrQixFQUFFLE9BQU8sRUFBRSxDQUFDO0FBRXREO0lBQTBCLCtCQUFPO0lBQy9CO2VBQ0UsaUJBQU87SUFDVCxDQUFDO0lBQ0ssNEJBQU0sR0FBWjs7O2dCQUNFLHNCQUFPLElBQUksRUFBQzs7O0tBQ2I7SUFDSyxrQ0FBWSxHQUFsQjs7Ozs7O0tBQ0M7SUFDRCxzQkFBSSwrQkFBTTthQUFWO1lBQ0UsT0FBTyxNQUFNLENBQUM7UUFDaEIsQ0FBQzs7O09BQUE7SUFDSyx5QkFBRyxHQUFULFVBQVUsR0FBVzs7WUFBSSxzQkFBTyxJQUFJLEVBQUM7O0tBQUU7SUFDakMseUJBQUcsR0FBVCxVQUFVLEdBQVcsRUFBRSxLQUFVOzs7O0tBQUs7SUFDaEMsNEJBQU0sR0FBWixVQUFhLEdBQVc7Ozs7S0FBbUI7SUFDckMsMkJBQUssR0FBWDs7OztLQUFnQztJQUMxQiw0QkFBTSxHQUFaOztZQUFrQyxzQkFBTyxDQUFDLEVBQUM7O0tBQUU7SUFDdkMsMEJBQUksR0FBVjs7WUFBZSxzQkFBTyxFQUFFLEVBQUE7O0tBQUU7SUFDcEIsNkJBQU8sR0FBYixVQUFjLGdCQUEyRTs7OztLQUFvQjtJQUM3RyxzQ0FBZ0IsR0FBaEIsVUFBaUIsR0FBVyxJQUFJLENBQUM7SUFDbkMsa0JBQUM7QUFBRCxDQUFDLEFBcEJELENBQTBCLE9BQU8sR0FvQmhDO0FBRUQsTUFBTSxVQUFVLGNBQWMsQ0FDNUIsYUFBNEI7SUFFNUIsSUFBSSxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLEVBQUU7UUFDckMsMERBQTBEO1FBQzFELE9BQU8sSUFBSSxXQUFXLEVBQUUsQ0FBQztLQUMxQjtJQUVELE9BQU8sSUFBSSxPQUFPLENBQUMsYUFBYSxDQUFDLENBQUM7QUFDcEMsQ0FBQztBQUdEO0lBQUE7SUFjQSxDQUFDOzJCQWRZLGtCQUFrQjtJQUN0QiwwQkFBTyxHQUFkLFVBQWUsYUFBbUM7UUFBbkMsOEJBQUEsRUFBQSxvQkFBbUM7UUFDaEQsT0FBTztZQUNMLFFBQVEsRUFBRSxvQkFBa0I7WUFDNUIsU0FBUyxFQUFFO2dCQUNULEVBQUUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLFFBQVEsRUFBRSxhQUFhLEVBQUU7Z0JBQ3hEO29CQUNFLE9BQU8sRUFBRSxPQUFPO29CQUNoQixVQUFVLEVBQUUsY0FBYztvQkFDMUIsSUFBSSxFQUFFLENBQUMsa0JBQWtCLENBQUM7aUJBQzNCO2FBQ0Y7U0FDRixDQUFDO0lBQ0osQ0FBQzs7SUFiVSxrQkFBa0I7UUFEOUIsUUFBUSxFQUFFO09BQ0Usa0JBQWtCLENBYzlCO0lBQUQseUJBQUM7Q0FBQSxBQWRELElBY0M7U0FkWSxrQkFBa0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSwgTW9kdWxlV2l0aFByb3ZpZGVycywgUExBVEZPUk1fSUQsIEluamVjdGlvblRva2VuIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7XG4gIFN0b3JhZ2UsXG4gIFN0b3JhZ2VDb25maWdcbn0gZnJvbSAnQGlvbmljL3N0b3JhZ2UnO1xuaW1wb3J0IHsgaXNQbGF0Zm9ybVNlcnZlciB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5cbmNvbnN0IFN0b3JhZ2VDb25maWdUb2tlbiA9IG5ldyBJbmplY3Rpb25Ub2tlbjxhbnk+KFxuICAnU1RPUkFHRV9DT05GSUdfVE9LRU4nXG4pO1xuXG5leHBvcnQgeyBTdG9yYWdlQ29uZmlnLCBTdG9yYWdlQ29uZmlnVG9rZW4sIFN0b3JhZ2UgfTtcblxuY2xhc3MgTm9vcFN0b3JhZ2UgZXh0ZW5kcyBTdG9yYWdlIHtcbiAgY29uc3RydWN0b3IoKSB7XG4gICAgc3VwZXIoKTtcbiAgfVxuICBhc3luYyBjcmVhdGUoKSB7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cbiAgYXN5bmMgZGVmaW5lRHJpdmVyKCkge1xuICB9XG4gIGdldCBkcml2ZXIoKTogc3RyaW5nIHwgbnVsbCB7XG4gICAgcmV0dXJuICdub29wJztcbiAgfVxuICBhc3luYyBnZXQoa2V5OiBzdHJpbmcpIHsgcmV0dXJuIG51bGw7IH1cbiAgYXN5bmMgc2V0KGtleTogc3RyaW5nLCB2YWx1ZTogYW55KSB7IH1cbiAgYXN5bmMgcmVtb3ZlKGtleTogc3RyaW5nKTogUHJvbWlzZTxhbnk+IHsgfVxuICBhc3luYyBjbGVhcigpOiBQcm9taXNlPHZvaWQ+IHsgfVxuICBhc3luYyBsZW5ndGgoKTogUHJvbWlzZTxudW1iZXI+IHsgcmV0dXJuIDA7IH1cbiAgYXN5bmMga2V5cygpIHsgcmV0dXJuIFtdIH1cbiAgYXN5bmMgZm9yRWFjaChpdGVyYXRvckNhbGxiYWNrOiAodmFsdWU6IGFueSwga2V5OiBzdHJpbmcsIGl0ZXJhdGlvbk51bWJlcjogTnVtYmVyKSA9PiBhbnkpOiBQcm9taXNlPHZvaWQ+IHsgfVxuICBzZXRFbmNyeXB0aW9uS2V5KGtleTogc3RyaW5nKSB7IH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHByb3ZpZGVTdG9yYWdlKFxuICBzdG9yYWdlQ29uZmlnOiBTdG9yYWdlQ29uZmlnXG4pOiBTdG9yYWdlIHtcbiAgaWYgKGlzUGxhdGZvcm1TZXJ2ZXIodGhpcy5wbGF0Zm9ybUlkKSkge1xuICAgIC8vIFdoZW4gcnVubmluZyBpbiBhIHNlcnZlciBjb250ZXh0IHJldHVybiB0aGUgTm9vcFN0b3JhZ2VcbiAgICByZXR1cm4gbmV3IE5vb3BTdG9yYWdlKCk7XG4gIH1cblxuICByZXR1cm4gbmV3IFN0b3JhZ2Uoc3RvcmFnZUNvbmZpZyk7XG59XG5cbkBOZ01vZHVsZSgpXG5leHBvcnQgY2xhc3MgSW9uaWNTdG9yYWdlTW9kdWxlIHtcbiAgc3RhdGljIGZvclJvb3Qoc3RvcmFnZUNvbmZpZzogU3RvcmFnZUNvbmZpZyA9IG51bGwpOiBNb2R1bGVXaXRoUHJvdmlkZXJzPElvbmljU3RvcmFnZU1vZHVsZT4ge1xuICAgIHJldHVybiB7XG4gICAgICBuZ01vZHVsZTogSW9uaWNTdG9yYWdlTW9kdWxlLFxuICAgICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIHsgcHJvdmlkZTogU3RvcmFnZUNvbmZpZ1Rva2VuLCB1c2VWYWx1ZTogc3RvcmFnZUNvbmZpZyB9LFxuICAgICAgICB7XG4gICAgICAgICAgcHJvdmlkZTogU3RvcmFnZSxcbiAgICAgICAgICB1c2VGYWN0b3J5OiBwcm92aWRlU3RvcmFnZSxcbiAgICAgICAgICBkZXBzOiBbU3RvcmFnZUNvbmZpZ1Rva2VuXVxuICAgICAgICB9XG4gICAgICBdXG4gICAgfTtcbiAgfVxufVxuIl19

@@ -55,96 +55,2 @@ import { __awaiter, __decorate } from 'tslib';

}
/**
* 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 { }
* ```
*/
let IonicStorageModule = IonicStorageModule_1 = class IonicStorageModule {

@@ -151,0 +57,0 @@ static forRoot(storageConfig = null) {

@@ -79,96 +79,2 @@ import { __extends, __awaiter, __generator, __decorate } from 'tslib';

}
/**
* 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 { }
* ```
*/
var IonicStorageModule = /** @class */ (function () {

@@ -175,0 +81,0 @@ function IonicStorageModule() {

@@ -6,98 +6,4 @@ import { ModuleWithProviders, InjectionToken } from '@angular/core';

export declare function provideStorage(storageConfig: StorageConfig): Storage;
/**
* 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 declare class IonicStorageModule {
static forRoot(storageConfig?: StorageConfig): ModuleWithProviders<IonicStorageModule>;
}

2

ionic-storage-angular.metadata.json

@@ -1,1 +0,1 @@

{"__symbolic":"module","version":4,"metadata":{"StorageConfigToken":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":8,"character":31},"arguments":["STORAGE_CONFIG_TOKEN"]},"provideStorage":{"__symbolic":"function"},"IonicStorageModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":142,"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","module":"@ionic/storage","name":"Storage","line":150,"character":19},"useFactory":{"__symbolic":"reference","name":"provideStorage"},"deps":[{"__symbolic":"reference","name":"StorageConfigToken"}]}]}}}}},"origins":{"StorageConfigToken":"./index","StorageConfig":"@ionic/storage","Storage":"@ionic/storage","provideStorage":"./index","IonicStorageModule":"./index"},"importAs":"@ionic/storage-angular"}
{"__symbolic":"module","version":4,"metadata":{"StorageConfigToken":{"__symbolic":"new","expression":{"__symbolic":"reference","module":"@angular/core","name":"InjectionToken","line":8,"character":31},"arguments":["STORAGE_CONFIG_TOKEN"]},"provideStorage":{"__symbolic":"function"},"IonicStorageModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":47,"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","module":"@ionic/storage","name":"Storage","line":55,"character":19},"useFactory":{"__symbolic":"reference","name":"provideStorage"},"deps":[{"__symbolic":"reference","name":"StorageConfigToken"}]}]}}}}},"origins":{"StorageConfigToken":"./index","StorageConfig":"@ionic/storage","Storage":"@ionic/storage","provideStorage":"./index","IonicStorageModule":"./index"},"importAs":"@ionic/storage-angular"}
{
"name": "@ionic/storage-angular",
"version": "3.0.0-alpha.5",
"version": "3.0.2",
"description": "Ionic Storage utility",

@@ -22,4 +22,3 @@ "repository": {

"dependencies": {
"localforage": "1.7.1",
"localforage-cordovasqlitedriver": "1.7.0",
"@ionic/storage": "3.0.0-alpha.2",
"tslib": "^1.10.0"

@@ -62,3 +61,3 @@ },

},
"gitHead": "d711a0c40addba50180df24a063226f1bdaf0aa9",
"gitHead": "0b550acdc2d21c95c68e0655b28698ec60fa283a",
"main": "bundles/ionic-storage-angular.umd.js",

@@ -65,0 +64,0 @@ "module": "fesm5/ionic-storage-angular.js",

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

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc