@po-ui/ng-storage 5.22.3 → 6.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (39) hide show
  1. package/README.md +16 -16
  2. package/{esm2015/lib/drivers/lokijs/po-loki-driver.js → esm2020/lib/drivers/lokijs/po-loki-driver.mjs} +209 -209
  3. package/{esm2015/lib/index.js → esm2020/lib/index.mjs} +3 -3
  4. package/esm2020/lib/po-storage.module.mjs +33 -0
  5. package/esm2020/lib/services/po-storage-config.interface.mjs +11 -0
  6. package/esm2020/lib/services/po-storage.service.mjs +520 -0
  7. package/esm2020/po-ui-ng-storage.mjs +5 -0
  8. package/{esm2015/public-api.js → esm2020/public-api.mjs} +2 -2
  9. package/fesm2015/{po-ui-ng-storage.js → po-ui-ng-storage.mjs} +786 -774
  10. package/fesm2015/po-ui-ng-storage.mjs.map +1 -0
  11. package/fesm2020/po-ui-ng-storage.mjs +764 -0
  12. package/fesm2020/po-ui-ng-storage.mjs.map +1 -0
  13. package/lib/drivers/lokijs/po-loki-driver.d.ts +30 -30
  14. package/lib/index.d.ts +3 -3
  15. package/lib/po-storage.module.d.ts +14 -10
  16. package/lib/services/po-storage-config.interface.d.ts +27 -27
  17. package/lib/services/po-storage.service.d.ts +381 -378
  18. package/package.json +28 -13
  19. package/po-ui-ng-storage-6.2.0.tgz +0 -0
  20. package/po-ui-ng-storage.d.ts +5 -5
  21. package/public-api.d.ts +1 -1
  22. package/schematics/README.md +91 -91
  23. package/schematics/collection.json +10 -10
  24. package/schematics/ng-add/index.d.ts +7 -7
  25. package/schematics/ng-add/index.js +28 -28
  26. package/schematics/ng-add/index.js.map +1 -1
  27. package/schematics/ng-add/index.spec.d.ts +1 -1
  28. package/schematics/ng-add/index.spec.js +50 -50
  29. package/schematics/ng-add/index.spec.js.map +1 -1
  30. package/schematics/ng-add/schema.json +6 -6
  31. package/bundles/po-ui-ng-storage.umd.js +0 -1279
  32. package/bundles/po-ui-ng-storage.umd.js.map +0 -1
  33. package/esm2015/lib/po-storage.module.js +0 -29
  34. package/esm2015/lib/services/po-storage-config.interface.js +0 -11
  35. package/esm2015/lib/services/po-storage.service.js +0 -546
  36. package/esm2015/po-ui-ng-storage.js +0 -6
  37. package/fesm2015/po-ui-ng-storage.js.map +0 -1
  38. package/po-ui-ng-storage-5.22.3.tgz +0 -0
  39. package/po-ui-ng-storage.metadata.json +0 -1
@@ -0,0 +1,520 @@
1
+ import { Inject, Injectable, InjectionToken } from '@angular/core';
2
+ import * as LocalForage from 'localforage';
3
+ import 'localforage';
4
+ import IdleQueue from 'custom-idle-queue';
5
+ import { PoLokiDriver } from '../drivers/lokijs/po-loki-driver';
6
+ import * as i0 from "@angular/core";
7
+ export const PO_STORAGE_CONFIG_TOKEN = new InjectionToken('PO_STORAGE_CONFIG_TOKEN');
8
+ /**
9
+ * @description
10
+ *
11
+ * O PO Storage é uma biblioteca que fornece um serviço para armazenamento de dados no dispositivo local, sendo semelhante
12
+ * ao funcionamento do [IonicStorage](https://ionicframework.com/docs/storage/).
13
+ * É possível utilizar os drivers [Websql](https://dev.w3.org/html5/webdatabase/), [Indexeddb](https://www.w3.org/TR/IndexedDB/),
14
+ * [LocalStorage](https://html.spec.whatwg.org/multipage/webstorage.html) e também [LokiJS](https://github.com/techfort/LokiJS/wiki).
15
+ *
16
+ * Para um melhor ganho de performance ao buscar e salvar dados, recomendamos a utilização do `LokiJS`, um *database*
17
+ * orientado a documento semelhante ao MongoDB, que além de permitir a persistência dos dados no dispositivo possibilita
18
+ * também o armazenamento dos dados em memória. Outra vantagem, é o aumento do limite de armazenamento para
19
+ * aproximadamente `300mb`.
20
+ *
21
+ * A estrutura utilizada para armazenar os dados é a de chave/valor, onde uma chave funciona como um identificador exclusivo.
22
+ *
23
+ * #### Instalando o PO Storage
24
+ *
25
+ * Para instalar o `po-storage` em sua aplicação execute o seguinte comando:
26
+ *
27
+ * ```shell
28
+ * ng add @po-ui/ng-storage
29
+ * ```
30
+ * Será instalado o pacote `@po-ui/ng-storage` e também já importará `PoStorageModule` no módulo principal da sua aplicação, conforme abaixo:
31
+ *
32
+ * ```typescript
33
+ * import { PoStorageModule } from '@po-ui/ng-storage';
34
+ *
35
+ * @NgModule({
36
+ * declarations: [...],
37
+ * imports: [
38
+ * // Importação do módulo PoStorageModule
39
+ * PoStorageModule.forRoot(),
40
+ * ],
41
+ * bootstrap: [IonicApp],
42
+ * providers: [...]
43
+ * })
44
+ * export class AppModule {}
45
+ * ```
46
+ *
47
+ * Com a declaração do módulo, é criada uma base de dados no armazenamento local e o serviço `PoStorageService` estará
48
+ * pronto para ser utilizada na sua aplicação.
49
+ *
50
+ * #### Configurando as opções de armazenamento
51
+ *
52
+ * Na importação do módulo, o método `PoStorageModule.forRoot()` pode receber como parâmetro um objeto do tipo
53
+ * [`PoStorageConfig`](documentation/po-storage#po-storage-config),
54
+ * que serve para configurar as opções personalizadas do armazenamento, como por exemplo: o tipo de armazenamento
55
+ * preferêncial.
56
+ *
57
+ * Caso não seja passada nenhuma configuração a ordem padrão será: ['websql', 'indexeddb', 'localstorage', 'lokijs'].
58
+ *
59
+ * Abaixo segue um exemplo de configuração onde o storage preferencial passa a ser o `lokijs`:
60
+ *
61
+ * ```typescript
62
+ * import { PoStorageModule } from '@po-ui/ng-storage';
63
+ *
64
+ * @NgModule({
65
+ * declarations: [...],
66
+ * imports: [
67
+ * // Importação do módulo PoStorageModule com a configuração personalizada
68
+ * PoStorageModule.forRoot({
69
+ * name: 'mystorage',
70
+ * storeName: '_mystore',
71
+ * driverOrder: ['lokijs', 'websql', 'indexeddb', 'localstorage']
72
+ * }),
73
+ * ],
74
+ * bootstrap: [IonicApp],
75
+ * providers: [...]
76
+ * })
77
+ * export class AppModule {}
78
+ * ```
79
+ */
80
+ export class PoStorageService {
81
+ constructor(config) {
82
+ this.driver = null;
83
+ this.idleQueue = new IdleQueue();
84
+ this.lokijsDriver = new PoLokiDriver();
85
+ this.setStoragePromise(config);
86
+ }
87
+ /**
88
+ * Retorna a configuração padrão para o armazenamento. Caso nenhuma configuração seja inserida,
89
+ * essa configuração será utilizada.
90
+ *
91
+ * @returns {PoStorageConfig} Objeto com a configuração padrão do armazenamento.
92
+ */
93
+ static getDefaultConfig() {
94
+ return {
95
+ name: '_postorage',
96
+ storeName: '_pokv',
97
+ driverOrder: ['websql', 'indexeddb', 'localstorage', 'lokijs']
98
+ };
99
+ }
100
+ /**
101
+ * Cria uma instância do `PoStorageService` com a configuração de armazenamento passada como parâmetro.
102
+ *
103
+ * @param {PoStorageConfig} storageConfig Configuração para o armazenamento.
104
+ * @returns {PoStorageService} Instância do `PoStorageService`.
105
+ */
106
+ static providePoStorage(storageConfig) {
107
+ return new PoStorageService(PoStorageService.getConfig(storageConfig));
108
+ }
109
+ static getConfig(storageConfig) {
110
+ return storageConfig || PoStorageService.getDefaultConfig();
111
+ }
112
+ /**
113
+ * Busca uma lista armazenada pela chave e concatena com a lista passada por parâmetro.
114
+ *
115
+ * Por exemplo:
116
+ *
117
+ * ``` typescript
118
+ * const clients = [ { name: 'Marie', age: 23 }, { name: 'Pether', age: 39 }];
119
+ *
120
+ * this.poStorageService.set('clientKey', clients).then(() => {});
121
+ *
122
+ * ...
123
+ *
124
+ * const newClients = [ { name: 'Lisa', age: 36 }, { name: 'Bruce', age: 18 } ];
125
+ *
126
+ * this.poStorageService.appendArrayToArray('clientKey', newClients).then(() => {
127
+ * // A lista agora será:
128
+ * // [ { name: 'Marie', age: 23 }, { name: 'Pether', age: 39 }, { name: 'Lisa', age: 36 }, { name: 'Bruce', age: 18 }];
129
+ * });
130
+ * ```
131
+ *
132
+ * @param {string} key Chave da lista armazenada.
133
+ * @param {Array} value Lista que será concatenada.
134
+ *
135
+ * @returns {Promise<any>} Promessa que é resolvida após as duas listas serem concatenadas e armazenadas localmente.
136
+ */
137
+ async appendArrayToArray(key, value) {
138
+ const data = await this.getArrayOfStorage(key);
139
+ const newData = [...data, ...value];
140
+ return this.set(key, newData);
141
+ }
142
+ /**
143
+ * Acrescenta um item em uma lista armazenada pela chave.
144
+ *
145
+ * @param {string} key Chave da lista armazenada.
146
+ * @param {Array} value Item que será acrescentado na lista.
147
+ *
148
+ * @returns {Promise<any>} Promessa que é resolvida após o item ser acrescentado na lista armazenada.
149
+ */
150
+ async appendItemToArray(key, value) {
151
+ const data = await this.getArrayOfStorage(key);
152
+ data.push(value);
153
+ return this.set(key, data);
154
+ }
155
+ /**
156
+ * Remove todos os itens da base de dados local configurada na declaração do módulo `PoStorageModule`.
157
+ *
158
+ * > Utilize este método com cautela, para evitar a perda indesejada de dados.
159
+ *
160
+ * @returns {Promise<void>} Promessa que é resolvida após todos os itens da base de dados local serem removidos.
161
+ */
162
+ clear() {
163
+ return this.storagePromise.then(store => store.clear());
164
+ }
165
+ /**
166
+ * Verifica se existe um valor dentro de uma determinada chave.
167
+ *
168
+ * @param {string} key Chave que será verificada.
169
+ *
170
+ * @returns {Promise<boolean>} Promessa que é resolvida quando a verificação da existência do valor na chave é concluída.
171
+ */
172
+ exists(key) {
173
+ return this.get(key).then(data => Promise.resolve(data !== null));
174
+ }
175
+ /**
176
+ * Itera sobre todas as chaves armazenadas.
177
+ *
178
+ * @param {any} iteratorCallback Função de `callback` que é chamada a cada iteração, com os seguintes parâmetros:
179
+ * valor, chave e número da iteração.
180
+ *
181
+ * Exemplo de utilização:
182
+ *
183
+ * ``` typescript
184
+ * this.poStorageService.forEach((value: any, key: string, iterationNumber: number) => {
185
+ * // Iteração sobre cada chave armazenada.
186
+ * });
187
+ * ```
188
+ *
189
+ * @returns {Promise<void>} Promessa que é resolvida após a iteração sobre todas as chaves armazenadas.
190
+ */
191
+ forEach(iteratorCallback) {
192
+ return this.storagePromise.then(store => store.iterate(iteratorCallback));
193
+ }
194
+ /**
195
+ * Retorna o valor armazenado em uma determinada chave.
196
+ *
197
+ * @param {string} key Chave que identifica o item.
198
+ * @param {boolean} lock Define se irá travar a leitura e a escrita da base de dados para não ser acessada de forma paralela.
199
+ * Caso outra leitura/escrita já tenha sido iniciada, este método irá esperar o outro terminar para então começar.
200
+ *
201
+ * Padrão: `false`.
202
+ *
203
+ * > Esta definição só será válida se o outro acesso paralelo a este método também estiver com o parâmetro *lock* ativado.
204
+ * @returns {Promise<any>} Promessa que é resolvida após o item ser buscado.
205
+ */
206
+ async get(key, lock = false) {
207
+ if (lock) {
208
+ await this.requestIdlePromise();
209
+ return await this.idleQueue.wrapCall(async () => {
210
+ await this.getImmutableItem(key);
211
+ });
212
+ }
213
+ return await this.getImmutableItem(key);
214
+ }
215
+ /**
216
+ * Retorna o nome do *driver* que está sendo usado para armazenar os dados, por exemplo: localStorage.
217
+ *
218
+ * @returns {string | null} Nome do *driver*.
219
+ */
220
+ getDriver() {
221
+ return this.driver;
222
+ }
223
+ /**
224
+ * Retorna o primeiro item de uma lista para uma determinada chave.
225
+ *
226
+ * @param {string} key Chave da lista.
227
+ * @returns {Promise<any>} Promessa que é resolvida após o primeiro item ser encontrado.
228
+ */
229
+ getFirstItem(key) {
230
+ return this.get(key).then((data) => Promise.resolve(data ? data[0] : null));
231
+ }
232
+ /**
233
+ * Remove o primeiro item de uma lista a partir da chave.
234
+ *
235
+ * @param {string} key Chave da lista que será removido o primeiro item.
236
+ * @returns {Promise<any>} Promessa que é resolvida após o primeiro item da lista ser removido.
237
+ */
238
+ getItemAndRemove(key) {
239
+ return this.get(key).then((data) => {
240
+ if (data === null) {
241
+ return null;
242
+ }
243
+ const item = data.shift();
244
+ return this.set(key, data).then(() => Promise.resolve(item));
245
+ });
246
+ }
247
+ /**
248
+ * Busca o primeiro objeto encontrado dentro de uma lista pelo do valor de um campo.
249
+ *
250
+ * Por exemplo:
251
+ *
252
+ * ``` typescript
253
+ * const clients = [ { name: 'Marie', age: 23 }, { name: 'Pether', age: 39 }];
254
+ *
255
+ * this.poStorageService.set('clientKey', clients).then(() => {});
256
+ *
257
+ * ...
258
+ *
259
+ * this.poStorageService.getItemByField('clientKey', 'name', 'Marie').then(client => {
260
+ * // Resultado do console.log: { name: 'Marie', age: 23 }
261
+ * console.log(client);
262
+ * });
263
+ * ```
264
+ *
265
+ * @param {string} key Chave da lista.
266
+ * @param {string} fieldName O campo a ser filtrado.
267
+ * @param {any} fieldValue O valor do campo.
268
+ * @returns {Promise<any>} Promessa que é resolvida com o item que foi encontrado.
269
+ */
270
+ getItemByField(key, fieldName, fieldValue) {
271
+ return this.get(key).then((storageRecords) => {
272
+ let storageRecordsFiltered = storageRecords.find(storageRecord => storageRecord[fieldName] === fieldValue);
273
+ storageRecordsFiltered = storageRecordsFiltered || null;
274
+ return Promise.resolve(storageRecordsFiltered);
275
+ });
276
+ }
277
+ /**
278
+ * Lista com todas as chaves armazenadas.
279
+ *
280
+ * @returns {Promise<Array<string>>} Promessa que é resolvida com todas as chaves armazenadas.
281
+ */
282
+ keys() {
283
+ return this.storagePromise.then(store => store.keys());
284
+ }
285
+ /**
286
+ * Quantidade de chaves armazenadas.
287
+ *
288
+ * @returns {Promise<number>} Promessa que é resolvida com o número de chaves armazenadas.
289
+ */
290
+ length() {
291
+ return this.storagePromise.then(store => store.length());
292
+ }
293
+ /**
294
+ * Utilizado para gerenciar o bloqueio e desbloqueio de recursos no `PoStorageService`.
295
+ * Aguardando a liberação da utilização dos recursos que participam deste comportamento e posteriormente envolve o recurso
296
+ * passado como parâmetro em um comportamento de bloqueio e desbloqueio.
297
+ *
298
+ * Este método se comporta igual a utilização em conjunta dos métodos: `PoStorageService.requestIdlePromise()`,
299
+ * `PoStorageService.lock()` e `PoStorageService.unlook()`.
300
+ *
301
+ * Veja mais no método: [`PoStorage.requestIdlePromise()`](documentation/po-storage#request-idle-promise).
302
+ *
303
+ * @param {Function} limitedResource Função que será envolvida no comportamento de bloqueio e desbloqueio.
304
+ */
305
+ async limitedCallWrap(limitedResource) {
306
+ await this.requestIdlePromise();
307
+ return this.idleQueue.wrapCall(limitedResource);
308
+ }
309
+ /**
310
+ * Incrementa um valor na fila de bloqueio do `PoStorageService`. Utilizado juntamente com o método `unlock` para poder
311
+ * controlar a execução de uma determinada tarefa com o `PoStorage.requestIdlePromise()`.
312
+ *
313
+ * Veja mais no método: [`PoStorage.requestIdlePromise()`](documentation/po-storage#request-idle-promise).
314
+ */
315
+ lock() {
316
+ this.idleQueue.lock();
317
+ }
318
+ /**
319
+ * Determina se o processo de inicialização do *driver* assíncrono foi concluído.
320
+ *
321
+ * @returns {Promise<LocalForage>} Promessa que é resolvida quando o processo de inicialização do *driver* assíncrono
322
+ * for concluído.
323
+ */
324
+ ready() {
325
+ return this.storagePromise;
326
+ }
327
+ /**
328
+ * Remove um valor associado a uma chave.
329
+ *
330
+ * @param {key} key Chave do valor que será removido.
331
+ * @returns {Promise<any>} Promessa que é resolvida após o valor ser removido.
332
+ */
333
+ remove(key) {
334
+ return this.storagePromise.then(store => store.removeItem(key));
335
+ }
336
+ /**
337
+ * Remove uma propriedade de um objeto armazenado.
338
+ *
339
+ * @param {string} key Chave do objeto armazenado.
340
+ * @param {string} property Propriedade que será removida.
341
+ *
342
+ * @returns {Promise<any>} Promessa que é resolvida após a propriedade ser removida.
343
+ */
344
+ async removeIndexFromObject(key, property) {
345
+ const data = await this.getObjectOfStorage(key);
346
+ delete data[property];
347
+ return this.set(key, data);
348
+ }
349
+ /**
350
+ * Remove um objeto de uma lista armazenada pelo valor de uma propriedade.
351
+ *
352
+ * Por exemplo:
353
+ *
354
+ * ``` typescript
355
+ * const clients = [ { name: 'Marie', age: 23 }, { name: 'Pether', age: 39 }];
356
+ *
357
+ * this.poStorageService.set('clientKey', clients).then(() => {});
358
+ *
359
+ * ...
360
+ *
361
+ * this.poStorageService.removeItemFromArray('clientKey', 'name', 'Marie').then(() => {
362
+ * // O objeto { name: 'Marie', age: 23 } foi removido da lista que está na chave 'clientKey'
363
+ * });
364
+ * ```
365
+ *
366
+ * @param {string} key Chave da lista que contém o item que será removido.
367
+ * @param {string} field O campo a ser filtrado no item.
368
+ * @param {string} value O valor do filtro.
369
+ * @returns {Promise<any>} Promessa que é resolvida quando o objeto for removido da lista.
370
+ */
371
+ async removeItemFromArray(key, field, value) {
372
+ let data = await this.getArrayOfStorage(key);
373
+ data = data.filter(item => item[field] !== value);
374
+ return this.set(key, data);
375
+ }
376
+ /**
377
+ * <a id="request-idle-promise"></a>
378
+ * Método que verifica se o acesso a base de dados configurada está liberado.
379
+ *
380
+ * Utilizado em conjunto com os métodos `lock()` e `unlock()` entre tarefas que não podem ser executadas de forma
381
+ * paralela, para não causar inconsistências nos dados.
382
+ *
383
+ * Exemplo de utilização:
384
+ *
385
+ * ```
386
+ * // Aguarda a liberação para continuar
387
+ * await this.poStorage.requestIdlePromise();
388
+ *
389
+ * this.poStorage.lock();
390
+ *
391
+ * // Executa uma tarefa que irá ler e/ou escrever na base de dados configurada.
392
+ *
393
+ * this.poStorage.unlock();
394
+ * ```
395
+ *
396
+ * > É importante sempre utilizá-lo antes de executar os métodos `lock()` e `unlock()` para garantir que a tarefa só
397
+ * será executada caso o acesso esteja livre.
398
+ *
399
+ * @returns {Promise<any>} Promessa que é resolvida quando o acesso a base de dados configurada estiver liberado.
400
+ */
401
+ requestIdlePromise() {
402
+ return this.idleQueue.requestIdlePromise();
403
+ }
404
+ /**
405
+ * Grava um valor em uma determinada chave.
406
+ *
407
+ * @param {string} key Chave para o valor que será gravado.
408
+ * @param {any} value Valor que será gravado.
409
+ * @param {boolean} lock Define se irá travar a leitura e a escrita da base de dados para não ser acessada de forma paralela.
410
+ * Caso outra leitura/escrita já tenha sido iniciada, este método irá esperar o outro terminar para então começar.
411
+ *
412
+ * Padrão: `false`.
413
+ *
414
+ * > Esta definição só será válida se o outro acesso paralelo a este método também estiver com o parâmetro *lock* ativado.
415
+ * @returns {Promise<any>} Promessa que é resolvida após o valor ter sido gravado.
416
+ */
417
+ async set(key, value, lock = false) {
418
+ const store = await this.storagePromise;
419
+ const newValue = typeof value === 'object' ? JSON.parse(JSON.stringify(value)) : value;
420
+ if (lock) {
421
+ await this.requestIdlePromise();
422
+ return this.idleQueue.wrapCall(() => store.setItem(key, newValue));
423
+ }
424
+ return store.setItem(key, newValue);
425
+ }
426
+ /**
427
+ * Atribui um valor a uma propriedade de um objeto armazenado pela chave.
428
+ *
429
+ * Por exemplo:
430
+ *
431
+ * ``` typescript
432
+ * const clients = [ { name: 'Marie', age: 23 }, { name: 'Pether', age: 39 }];
433
+ *
434
+ * this.poStorageService.set('clientKey', clients).then(() => {});
435
+ *
436
+ * ...
437
+ *
438
+ * this.poStorageService.setIndexToObject('clientKey', 'name', 'Clare').then(() => {
439
+ * // O objeto { name: 'Marie', age: 23 } passa a ser { name: 'Clare', age: 23 }
440
+ * });
441
+ * ```
442
+ *
443
+ * @param {string} key Chave do objeto.
444
+ * @param {string} property Nome da propriedade do objeto.
445
+ * @param {any} value Valor que será gravado na propriedade do objeto.
446
+ */
447
+ async setIndexToObject(key, property, value) {
448
+ const data = await this.getObjectOfStorage(key);
449
+ data[property] = value;
450
+ return this.set(key, data);
451
+ }
452
+ /**
453
+ * Decrementa um valor na fila de bloqueio. Utilizado juntamente com o método `lock` para poder
454
+ * controlar a execução de uma determinada tarefa com o `PoStorage.requestIdlePromise()`.
455
+ *
456
+ * Veja mais no método: [`PoStorage.requestIdlePromise()`](documentation/po-storage#request-idle-promise).
457
+ */
458
+ unlock() {
459
+ this.idleQueue.unlock();
460
+ }
461
+ async getArrayOfStorage(key) {
462
+ const data = await this.get(key);
463
+ return data || [];
464
+ }
465
+ async getImmutableItem(key) {
466
+ const store = await this.storagePromise;
467
+ const items = await store.getItem(key);
468
+ return items ? JSON.parse(JSON.stringify(items)) : null;
469
+ }
470
+ async defineLocalForageDriver(localForageInstance, driverOrder) {
471
+ await localForageInstance.defineDriver(this.lokijsDriver.getDriver());
472
+ await this.setDriver(localForageInstance, driverOrder);
473
+ return localForageInstance;
474
+ }
475
+ getDriverOrder(driverOrder) {
476
+ return driverOrder.map(driver => {
477
+ switch (driver) {
478
+ case 'indexeddb':
479
+ return LocalForage.INDEXEDDB;
480
+ case 'websql':
481
+ return LocalForage.WEBSQL;
482
+ case 'localstorage':
483
+ return LocalForage.LOCALSTORAGE;
484
+ default:
485
+ return driver;
486
+ }
487
+ });
488
+ }
489
+ async getObjectOfStorage(key) {
490
+ const data = await this.get(key);
491
+ return data || {};
492
+ }
493
+ async setDriver(localForageInstance, driverOrder) {
494
+ await localForageInstance.setDriver(this.getDriverOrder(driverOrder));
495
+ this.driver = localForageInstance.driver();
496
+ }
497
+ setStoragePromise(config) {
498
+ this.storagePromise = this.getStorageInstance(config);
499
+ }
500
+ async getStorageInstance(config) {
501
+ const defaultConfig = PoStorageService.getDefaultConfig();
502
+ const actualConfig = Object.assign(defaultConfig, config || {});
503
+ const localForageInstance = LocalForage.createInstance(actualConfig);
504
+ try {
505
+ return await this.defineLocalForageDriver(localForageInstance, actualConfig.driverOrder);
506
+ }
507
+ catch {
508
+ throw new Error(`Cannot use this drivers: ${actualConfig.driverOrder.join(', ')}.`);
509
+ }
510
+ }
511
+ }
512
+ PoStorageService.ɵfac = function PoStorageService_Factory(t) { return new (t || PoStorageService)(i0.ɵɵinject(PO_STORAGE_CONFIG_TOKEN)); };
513
+ PoStorageService.ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: PoStorageService, factory: PoStorageService.ɵfac });
514
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PoStorageService, [{
515
+ type: Injectable
516
+ }], function () { return [{ type: undefined, decorators: [{
517
+ type: Inject,
518
+ args: [PO_STORAGE_CONFIG_TOKEN]
519
+ }] }]; }, null); })();
520
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"po-storage.service.js","sourceRoot":"","sources":["../../../../../projects/storage/src/lib/services/po-storage.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, InjectionToken } from '@angular/core';\n\nimport * as LocalForage from 'localforage';\nimport 'localforage';\n\nimport IdleQueue from 'custom-idle-queue';\n\nimport { PoLokiDriver } from '../drivers/lokijs/po-loki-driver';\nimport { PoStorageConfig } from './po-storage-config.interface';\n\nexport const PO_STORAGE_CONFIG_TOKEN = new InjectionToken('PO_STORAGE_CONFIG_TOKEN');\n\n/**\n * @description\n *\n * O PO Storage é uma biblioteca que fornece um serviço para armazenamento de dados no dispositivo local, sendo semelhante\n * ao funcionamento do [IonicStorage](https://ionicframework.com/docs/storage/).\n * É possível utilizar os drivers [Websql](https://dev.w3.org/html5/webdatabase/), [Indexeddb](https://www.w3.org/TR/IndexedDB/),\n * [LocalStorage](https://html.spec.whatwg.org/multipage/webstorage.html) e também [LokiJS](https://github.com/techfort/LokiJS/wiki).\n *\n * Para um melhor ganho de performance ao buscar e salvar dados, recomendamos a utilização do `LokiJS`, um *database*\n * orientado a documento semelhante ao MongoDB, que além de permitir a persistência dos dados no dispositivo possibilita\n * também o armazenamento dos dados em memória. Outra vantagem, é o aumento do limite de armazenamento para\n * aproximadamente `300mb`.\n *\n * A estrutura utilizada para armazenar os dados é a de chave/valor, onde uma chave funciona como um identificador exclusivo.\n *\n * #### Instalando o PO Storage\n *\n * Para instalar o `po-storage` em sua aplicação execute o seguinte comando:\n *\n * ```shell\n * ng add @po-ui/ng-storage\n * ```\n * Será instalado o pacote `@po-ui/ng-storage` e também já importará `PoStorageModule` no módulo principal da sua aplicação, conforme abaixo:\n *\n * ```typescript\n * import { PoStorageModule } from '@po-ui/ng-storage';\n *\n * @NgModule({\n *  declarations: [...],\n *  imports: [\n *    // Importação do módulo PoStorageModule\n *    PoStorageModule.forRoot(),\n *  ],\n *  bootstrap: [IonicApp],\n *  providers: [...]\n * })\n * export class AppModule {}\n * ```\n *\n * Com a declaração do módulo, é criada uma base de dados no armazenamento local e o serviço `PoStorageService` estará\n * pronto para ser utilizada na sua aplicação.\n *\n * #### Configurando as opções de armazenamento\n *\n * Na importação do módulo, o método `PoStorageModule.forRoot()` pode receber como parâmetro um objeto do tipo\n * [`PoStorageConfig`](documentation/po-storage#po-storage-config),\n * que serve para configurar as opções personalizadas do armazenamento, como por exemplo: o tipo de armazenamento\n * preferêncial.\n *\n * Caso não seja passada nenhuma configuração a ordem padrão será: ['websql', 'indexeddb', 'localstorage', 'lokijs'].\n *\n * Abaixo segue um exemplo de configuração onde o storage preferencial passa a ser o `lokijs`:\n *\n * ```typescript\n * import { PoStorageModule } from '@po-ui/ng-storage';\n *\n * @NgModule({\n *  declarations: [...],\n *  imports: [\n *    // Importação do módulo PoStorageModule com a configuração personalizada\n *    PoStorageModule.forRoot({\n *      name: 'mystorage',\n *      storeName: '_mystore',\n *      driverOrder: ['lokijs', 'websql', 'indexeddb', 'localstorage']\n *    }),\n *  ],\n *  bootstrap: [IonicApp],\n *  providers: [...]\n * })\n * export class AppModule {}\n * ```\n */\n@Injectable()\nexport class PoStorageService {\n  private driver: string = null;\n  private idleQueue = new IdleQueue();\n  private storagePromise: Promise<LocalForage>;\n  private lokijsDriver: PoLokiDriver;\n\n  constructor(@Inject(PO_STORAGE_CONFIG_TOKEN) config?: PoStorageConfig) {\n    this.lokijsDriver = new PoLokiDriver();\n    this.setStoragePromise(config);\n  }\n\n  /**\n   * Retorna a configuração padrão para o armazenamento. Caso nenhuma configuração seja inserida,\n   * essa configuração será utilizada.\n   *\n   * @returns {PoStorageConfig} Objeto com a configuração padrão do armazenamento.\n   */\n  static getDefaultConfig(): PoStorageConfig {\n    return {\n      name: '_postorage',\n      storeName: '_pokv',\n      driverOrder: ['websql', 'indexeddb', 'localstorage', 'lokijs']\n    };\n  }\n\n  /**\n   * Cria uma instância do `PoStorageService` com a configuração de armazenamento passada como parâmetro.\n   *\n   * @param {PoStorageConfig} storageConfig Configuração para o armazenamento.\n   * @returns {PoStorageService} Instância do `PoStorageService`.\n   */\n  static providePoStorage(storageConfig?: PoStorageConfig): PoStorageService {\n    return new PoStorageService(PoStorageService.getConfig(storageConfig));\n  }\n\n  private static getConfig(storageConfig?: PoStorageConfig) {\n    return storageConfig || PoStorageService.getDefaultConfig();\n  }\n\n  /**\n   * Busca uma lista armazenada pela chave e concatena com a lista passada por parâmetro.\n   *\n   * Por exemplo:\n   *\n   * ``` typescript\n   * const clients = [ { name: 'Marie', age: 23 }, { name: 'Pether', age: 39 }];\n   *\n   * this.poStorageService.set('clientKey', clients).then(() => {});\n   *\n   * ...\n   *\n   * const newClients = [ { name: 'Lisa', age: 36 }, { name: 'Bruce', age: 18 } ];\n   *\n   * this.poStorageService.appendArrayToArray('clientKey', newClients).then(() => {\n   *   // A lista agora será:\n   *   // [ { name: 'Marie', age: 23 }, { name: 'Pether', age: 39 }, { name: 'Lisa', age: 36 }, { name: 'Bruce', age: 18 }];\n   * });\n   * ```\n   *\n   * @param {string} key Chave da lista armazenada.\n   * @param {Array} value Lista que será concatenada.\n   *\n   * @returns {Promise<any>} Promessa que é resolvida após as duas listas serem concatenadas e armazenadas localmente.\n   */\n  async appendArrayToArray(key: string, value: Array<any>): Promise<any> {\n    const data = await this.getArrayOfStorage(key);\n\n    const newData = [...data, ...value];\n    return this.set(key, newData);\n  }\n\n  /**\n   * Acrescenta um item em uma lista armazenada pela chave.\n   *\n   * @param {string} key Chave da lista armazenada.\n   * @param {Array} value Item que será acrescentado na lista.\n   *\n   * @returns {Promise<any>} Promessa que é resolvida após o item ser acrescentado na lista armazenada.\n   */\n  async appendItemToArray(key: string, value: any): Promise<any> {\n    const data = await this.getArrayOfStorage(key);\n\n    data.push(value);\n    return this.set(key, data);\n  }\n\n  /**\n   * Remove todos os itens da base de dados local configurada na declaração do módulo `PoStorageModule`.\n   *\n   * > Utilize este método com cautela, para evitar a perda indesejada de dados.\n   *\n   * @returns {Promise<void>} Promessa que é resolvida após todos os itens da base de dados local serem removidos.\n   */\n  clear(): Promise<void> {\n    return this.storagePromise.then(store => store.clear());\n  }\n\n  /**\n   * Verifica se existe um valor dentro de uma determinada chave.\n   *\n   * @param {string} key Chave que será verificada.\n   *\n   * @returns {Promise<boolean>} Promessa que é resolvida quando a verificação da existência do valor na chave é concluída.\n   */\n  exists(key: string): Promise<boolean> {\n    return this.get(key).then(data => Promise.resolve(data !== null));\n  }\n\n  /**\n   * Itera sobre todas as chaves armazenadas.\n   *\n   * @param {any} iteratorCallback Função de `callback` que é chamada a cada iteração, com os seguintes parâmetros:\n   * valor, chave e número da iteração.\n   *\n   * Exemplo de utilização:\n   *\n   * ``` typescript\n   * this.poStorageService.forEach((value: any, key: string, iterationNumber: number) => {\n   *   // Iteração sobre cada chave armazenada.\n   * });\n   * ```\n   *\n   * @returns {Promise<void>} Promessa que é resolvida após a iteração sobre todas as chaves armazenadas.\n   */\n  forEach(iteratorCallback: (value: any, key: string, iterationNumber: number) => any): Promise<void> {\n    return this.storagePromise.then(store => store.iterate(iteratorCallback));\n  }\n\n  /**\n   * Retorna o valor armazenado em uma determinada chave.\n   *\n   * @param {string} key Chave que identifica o item.\n   * @param {boolean} lock Define se irá travar a leitura e a escrita da base de dados para não ser acessada de forma paralela.\n   * Caso outra leitura/escrita já tenha sido iniciada, este método irá esperar o outro terminar para então começar.\n   *\n   * Padrão: `false`.\n   *\n   * > Esta definição só será válida se o outro acesso paralelo a este método também estiver com o parâmetro *lock* ativado.\n   * @returns {Promise<any>} Promessa que é resolvida após o item ser buscado.\n   */\n  async get(key: string, lock: boolean = false): Promise<any> {\n    if (lock) {\n      await this.requestIdlePromise();\n      return await this.idleQueue.wrapCall(async () => {\n        await this.getImmutableItem(key);\n      });\n    }\n    return await this.getImmutableItem(key);\n  }\n\n  /**\n   * Retorna o nome do *driver* que está sendo usado para armazenar os dados, por exemplo: localStorage.\n   *\n   * @returns {string | null} Nome do *driver*.\n   */\n  getDriver(): string {\n    return this.driver;\n  }\n\n  /**\n   * Retorna o primeiro item de uma lista para uma determinada chave.\n   *\n   * @param {string} key Chave da lista.\n   * @returns {Promise<any>} Promessa que é resolvida após o primeiro item ser encontrado.\n   */\n  getFirstItem(key: string): Promise<any> {\n    return this.get(key).then((data: Array<any>) => Promise.resolve(data ? data[0] : null));\n  }\n\n  /**\n   * Remove o primeiro item de uma lista a partir da chave.\n   *\n   * @param {string} key Chave da lista que será removido o primeiro item.\n   * @returns {Promise<any>} Promessa que é resolvida após o primeiro item da lista ser removido.\n   */\n  getItemAndRemove(key: string): Promise<any> {\n    return this.get(key).then((data: Array<any>) => {\n      if (data === null) {\n        return null;\n      }\n\n      const item = data.shift();\n      return this.set(key, data).then(() => Promise.resolve(item));\n    });\n  }\n\n  /**\n   * Busca o primeiro objeto encontrado dentro de uma lista pelo do valor de um campo.\n   *\n   * Por exemplo:\n   *\n   * ``` typescript\n   * const clients = [ { name: 'Marie', age: 23 }, { name: 'Pether', age: 39 }];\n   *\n   * this.poStorageService.set('clientKey', clients).then(() => {});\n   *\n   * ...\n   *\n   * this.poStorageService.getItemByField('clientKey', 'name', 'Marie').then(client => {\n   *   // Resultado do console.log: { name: 'Marie', age: 23 }\n   *   console.log(client);\n   * });\n   * ```\n   *\n   * @param {string} key Chave da lista.\n   * @param {string} fieldName O campo a ser filtrado.\n   * @param {any} fieldValue O valor do campo.\n   * @returns {Promise<any>} Promessa que é resolvida com o item que foi encontrado.\n   */\n  getItemByField(key: string, fieldName: string, fieldValue: any): Promise<any> {\n    return this.get(key).then((storageRecords: Array<any>) => {\n      let storageRecordsFiltered = storageRecords.find(storageRecord => storageRecord[fieldName] === fieldValue);\n      storageRecordsFiltered = storageRecordsFiltered || null;\n\n      return Promise.resolve(storageRecordsFiltered);\n    });\n  }\n\n  /**\n   * Lista com todas as chaves armazenadas.\n   *\n   * @returns {Promise<Array<string>>} Promessa que é resolvida com todas as chaves armazenadas.\n   */\n  keys(): Promise<Array<string>> {\n    return this.storagePromise.then(store => store.keys());\n  }\n\n  /**\n   * Quantidade de chaves armazenadas.\n   *\n   * @returns {Promise<number>} Promessa que é resolvida com o número de chaves armazenadas.\n   */\n  length(): Promise<number> {\n    return this.storagePromise.then(store => store.length());\n  }\n\n  /**\n   * Utilizado para gerenciar o bloqueio e desbloqueio de recursos no `PoStorageService`.\n   * Aguardando a liberação da utilização dos recursos que participam deste comportamento e posteriormente envolve o recurso\n   * passado como parâmetro em um comportamento de bloqueio e desbloqueio.\n   *\n   * Este método se comporta igual a utilização em conjunta dos métodos: `PoStorageService.requestIdlePromise()`,\n   * `PoStorageService.lock()` e `PoStorageService.unlook()`.\n   *\n   * Veja mais no método: [`PoStorage.requestIdlePromise()`](documentation/po-storage#request-idle-promise).\n   *\n   * @param {Function} limitedResource Função que será envolvida no comportamento de bloqueio e desbloqueio.\n   */\n  async limitedCallWrap(limitedResource: Function): Promise<any> {\n    await this.requestIdlePromise();\n    return this.idleQueue.wrapCall(limitedResource);\n  }\n\n  /**\n   * Incrementa um valor na fila de bloqueio do `PoStorageService`. Utilizado juntamente com o método `unlock` para poder\n   * controlar a execução de uma determinada tarefa com o `PoStorage.requestIdlePromise()`.\n   *\n   * Veja mais no método: [`PoStorage.requestIdlePromise()`](documentation/po-storage#request-idle-promise).\n   */\n  lock() {\n    this.idleQueue.lock();\n  }\n\n  /**\n   * Determina se o processo de inicialização do *driver* assíncrono foi concluído.\n   *\n   * @returns {Promise<LocalForage>} Promessa que é resolvida quando o processo de inicialização do *driver* assíncrono\n   * for concluído.\n   */\n  ready(): Promise<LocalForage> {\n    return this.storagePromise;\n  }\n\n  /**\n   * Remove um valor associado a uma chave.\n   *\n   * @param {key} key Chave do valor que será removido.\n   * @returns {Promise<any>} Promessa que é resolvida após o valor ser removido.\n   */\n  remove(key: string): Promise<any> {\n    return this.storagePromise.then(store => store.removeItem(key));\n  }\n\n  /**\n   * Remove uma propriedade de um objeto armazenado.\n   *\n   * @param {string} key Chave do objeto armazenado.\n   * @param {string} property Propriedade que será removida.\n   *\n   * @returns {Promise<any>} Promessa que é resolvida após a propriedade ser removida.\n   */\n  async removeIndexFromObject(key: string, property: string): Promise<any> {\n    const data = await this.getObjectOfStorage(key);\n\n    delete data[property];\n    return this.set(key, data);\n  }\n\n  /**\n   * Remove um objeto de uma lista armazenada pelo valor de uma propriedade.\n   *\n   * Por exemplo:\n   *\n   * ``` typescript\n   * const clients = [ { name: 'Marie', age: 23 }, { name: 'Pether', age: 39 }];\n   *\n   * this.poStorageService.set('clientKey', clients).then(() => {});\n   *\n   * ...\n   *\n   * this.poStorageService.removeItemFromArray('clientKey', 'name', 'Marie').then(() => {\n   *   // O objeto { name: 'Marie', age: 23 } foi removido da lista que está na chave 'clientKey'\n   * });\n   * ```\n   *\n   * @param {string} key Chave da lista que contém o item que será removido.\n   * @param {string} field O campo a ser filtrado no item.\n   * @param {string} value O valor do filtro.\n   * @returns {Promise<any>} Promessa que é resolvida quando o objeto for removido da lista.\n   */\n  async removeItemFromArray(key: string, field: string, value: any): Promise<any> {\n    let data = await this.getArrayOfStorage(key);\n\n    data = data.filter(item => item[field] !== value);\n    return this.set(key, data);\n  }\n\n  /**\n   * <a id=\"request-idle-promise\"></a>\n   * Método que verifica se o acesso a base de dados configurada está liberado.\n   *\n   * Utilizado em conjunto com os métodos `lock()` e `unlock()` entre tarefas que não podem ser executadas de forma\n   * paralela, para não causar inconsistências nos dados.\n   *\n   * Exemplo de utilização:\n   *\n   * ```\n   * // Aguarda a liberação para continuar\n   * await this.poStorage.requestIdlePromise();\n   *\n   * this.poStorage.lock();\n   *\n   * // Executa uma tarefa que irá ler e/ou escrever na base de dados configurada.\n   *\n   * this.poStorage.unlock();\n   * ```\n   *\n   * > É importante sempre utilizá-lo antes de executar os métodos `lock()` e `unlock()` para garantir que a tarefa só\n   * será executada caso o acesso esteja livre.\n   *\n   * @returns {Promise<any>} Promessa que é resolvida quando o acesso a base de dados configurada estiver liberado.\n   */\n  requestIdlePromise(): Promise<any> {\n    return this.idleQueue.requestIdlePromise();\n  }\n\n  /**\n   * Grava um valor em uma determinada chave.\n   *\n   * @param {string} key Chave para o valor que será gravado.\n   * @param {any} value Valor que será gravado.\n   * @param {boolean} lock Define se irá travar a leitura e a escrita da base de dados para não ser acessada de forma paralela.\n   * Caso outra leitura/escrita já tenha sido iniciada, este método irá esperar o outro terminar para então começar.\n   *\n   * Padrão: `false`.\n   *\n   * > Esta definição só será válida se o outro acesso paralelo a este método também estiver com o parâmetro *lock* ativado.\n   * @returns {Promise<any>} Promessa que é resolvida após o valor ter sido gravado.\n   */\n  async set(key: string, value: any, lock: boolean = false): Promise<any> {\n    const store = await this.storagePromise;\n    const newValue = typeof value === 'object' ? JSON.parse(JSON.stringify(value)) : value;\n\n    if (lock) {\n      await this.requestIdlePromise();\n      return this.idleQueue.wrapCall(() => store.setItem(key, newValue));\n    }\n\n    return store.setItem(key, newValue);\n  }\n\n  /**\n   * Atribui um valor a uma propriedade de um objeto armazenado pela chave.\n   *\n   * Por exemplo:\n   *\n   * ``` typescript\n   * const clients = [ { name: 'Marie', age: 23 }, { name: 'Pether', age: 39 }];\n   *\n   * this.poStorageService.set('clientKey', clients).then(() => {});\n   *\n   * ...\n   *\n   * this.poStorageService.setIndexToObject('clientKey', 'name', 'Clare').then(() => {\n   *   // O objeto { name: 'Marie', age: 23 } passa a ser { name: 'Clare', age: 23 }\n   * });\n   * ```\n   *\n   * @param {string} key Chave do objeto.\n   * @param {string} property Nome da propriedade do objeto.\n   * @param {any} value Valor que será gravado na propriedade do objeto.\n   */\n  async setIndexToObject(key: string, property: string, value: any): Promise<any> {\n    const data = await this.getObjectOfStorage(key);\n\n    data[property] = value;\n    return this.set(key, data);\n  }\n\n  /**\n   * Decrementa um valor na fila de bloqueio. Utilizado juntamente com o método `lock` para poder\n   * controlar a execução de uma determinada tarefa com o `PoStorage.requestIdlePromise()`.\n   *\n   * Veja mais no método: [`PoStorage.requestIdlePromise()`](documentation/po-storage#request-idle-promise).\n   */\n  unlock() {\n    this.idleQueue.unlock();\n  }\n\n  private async getArrayOfStorage(key: string) {\n    const data = await this.get(key);\n    return data || [];\n  }\n\n  private async getImmutableItem(key: string) {\n    const store = await this.storagePromise;\n    const items = await store.getItem(key);\n    return items ? JSON.parse(JSON.stringify(items)) : null;\n  }\n\n  private async defineLocalForageDriver(localForageInstance: any, driverOrder) {\n    await localForageInstance.defineDriver(this.lokijsDriver.getDriver());\n    await this.setDriver(localForageInstance, driverOrder);\n    return localForageInstance;\n  }\n\n  private getDriverOrder(driverOrder: Array<string>): Array<string> {\n    return driverOrder.map(driver => {\n      switch (driver) {\n        case 'indexeddb':\n          return LocalForage.INDEXEDDB;\n        case 'websql':\n          return LocalForage.WEBSQL;\n        case 'localstorage':\n          return LocalForage.LOCALSTORAGE;\n        default:\n          return driver;\n      }\n    });\n  }\n\n  private async getObjectOfStorage(key: string) {\n    const data = await this.get(key);\n    return data || {};\n  }\n\n  private async setDriver(localForageInstance: LocalForage, driverOrder) {\n    await localForageInstance.setDriver(this.getDriverOrder(driverOrder));\n    this.driver = localForageInstance.driver();\n  }\n\n  private setStoragePromise(config: PoStorageConfig) {\n    this.storagePromise = this.getStorageInstance(config);\n  }\n\n  private async getStorageInstance(config: PoStorageConfig) {\n    const defaultConfig = PoStorageService.getDefaultConfig();\n    const actualConfig = Object.assign(defaultConfig, config || {});\n\n    const localForageInstance = LocalForage.createInstance(actualConfig);\n\n    try {\n      return await this.defineLocalForageDriver(localForageInstance, actualConfig.driverOrder);\n    } catch {\n      throw new Error(`Cannot use this drivers: ${actualConfig.driverOrder.join(', ')}.`);\n    }\n  }\n}\n"]}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './public-api';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG8tdWktbmctc3RvcmFnZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL3N0b3JhZ2Uvc3JjL3BvLXVpLW5nLXN0b3JhZ2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
@@ -1,2 +1,2 @@
1
- export * from './lib/index';
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL3N0b3JhZ2Uvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxhQUFhLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2xpYi9pbmRleCc7XHJcbiJdfQ==
1
+ export * from './lib/index';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL3N0b3JhZ2Uvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxhQUFhLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2xpYi9pbmRleCc7XG4iXX0=