@esfaenza/preferences 12.2.7 → 12.2.8
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.
- package/bundles/esfaenza-preferences.umd.js +52 -86
- package/bundles/esfaenza-preferences.umd.js.map +1 -1
- package/esfaenza-preferences.metadata.json +1 -1
- package/esm2015/lib/persistor/base/BasePreferencesPersistor.js +13 -7
- package/esm2015/lib/persistor/implementation/LocalStoragePersistor.js +27 -47
- package/esm2015/lib/preferences.service.js +11 -19
- package/fesm2015/esfaenza-preferences.js +47 -74
- package/fesm2015/esfaenza-preferences.js.map +1 -1
- package/lib/persistor/base/BasePreferencesPersistor.d.ts +16 -22
- package/lib/persistor/implementation/LocalStoragePersistor.d.ts +14 -41
- package/lib/preferences.service.d.ts +5 -10
- package/package.json +1 -1
|
@@ -2,66 +2,46 @@
|
|
|
2
2
|
import { Injectable } from "@angular/core";
|
|
3
3
|
// Classi
|
|
4
4
|
import { BasePreferencesPersistor } from "../base/BasePreferencesPersistor";
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
5
|
+
import { BaseSessionRetriever } from "../../session/base/BaseSessionRetriever";
|
|
6
|
+
// RXJS
|
|
7
|
+
import { of } from "rxjs";
|
|
8
|
+
import { first } from "rxjs/operators";
|
|
9
|
+
/** Implementazione di default per la classe **BasePreferencesPersistor** */
|
|
8
10
|
export class LocalStoragePersistor extends BasePreferencesPersistor {
|
|
9
|
-
/**
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
/**
|
|
16
|
-
* Salva, per una sessione, una chiave con un valore
|
|
17
|
-
*
|
|
18
|
-
* @param {string} sessionId ID della sessione
|
|
19
|
-
* @param {string} key Chiave da storicizzare
|
|
20
|
-
*
|
|
21
|
-
*/
|
|
22
|
-
persist(sessionId, key, item) {
|
|
23
|
-
localStorage.setItem(this.getKey(sessionId, key), JSON.stringify(item));
|
|
11
|
+
/** @ignore Costruttore */
|
|
12
|
+
constructor(session) { super(session); }
|
|
13
|
+
/** @ignore Vedi classe base */
|
|
14
|
+
persist(key, item) {
|
|
15
|
+
localStorage.setItem(this.getKey(key), JSON.stringify(item));
|
|
16
|
+
return of(true).pipe(first());
|
|
24
17
|
}
|
|
25
|
-
/**
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
* @param {string} key Chiave da recuperare
|
|
30
|
-
*
|
|
31
|
-
* @returns {T} Valore salvato per la chiave **key**
|
|
32
|
-
*/
|
|
33
|
-
recover(sessionId, key) {
|
|
34
|
-
return JSON.parse(localStorage.getItem(this.getKey(sessionId, key)));
|
|
18
|
+
/** @ignore Vedi classe base */
|
|
19
|
+
recover(key) {
|
|
20
|
+
var ret = JSON.parse(localStorage.getItem(this.getKey(key)));
|
|
21
|
+
return of(ret).pipe(first());
|
|
35
22
|
}
|
|
36
|
-
/**
|
|
37
|
-
|
|
38
|
-
*
|
|
39
|
-
* @param {string} sessionId ID della sessione
|
|
40
|
-
*
|
|
41
|
-
* @returns {{ [index: string]: string }} Dizionario con tutte le preference salvate per la sessione **sessionId**
|
|
42
|
-
*/
|
|
43
|
-
recoverAll(sessionId) {
|
|
23
|
+
/** @ignore Vedi classe base */
|
|
24
|
+
recoverAll() {
|
|
44
25
|
var ret = {};
|
|
45
26
|
for (var k in localStorage) {
|
|
46
|
-
if (k.includes("§") && k.startsWith(
|
|
27
|
+
if (k.includes("§") && k.startsWith(this.session.getSessionKey()))
|
|
47
28
|
ret[k.match(/§(.*)§/)[1]] = JSON.parse(localStorage.getItem(k));
|
|
48
29
|
}
|
|
49
|
-
return ret;
|
|
30
|
+
return of(ret).pipe(first());
|
|
50
31
|
}
|
|
51
|
-
/**
|
|
52
|
-
|
|
53
|
-
*
|
|
54
|
-
* @param {string} sessionId ID della sessione
|
|
55
|
-
*/
|
|
56
|
-
clear(sessionId) {
|
|
32
|
+
/** @ignore Vedi classe base */
|
|
33
|
+
clear() {
|
|
57
34
|
for (var k in localStorage) {
|
|
58
|
-
if (k.includes("§") && k.startsWith(
|
|
35
|
+
if (k.includes("§") && k.startsWith(this.session.getSessionKey()))
|
|
59
36
|
localStorage.removeItem(k);
|
|
60
37
|
}
|
|
38
|
+
return of(true).pipe(first());
|
|
61
39
|
}
|
|
62
40
|
}
|
|
63
41
|
LocalStoragePersistor.decorators = [
|
|
64
42
|
{ type: Injectable }
|
|
65
43
|
];
|
|
66
|
-
LocalStoragePersistor.ctorParameters = () => [
|
|
67
|
-
|
|
44
|
+
LocalStoragePersistor.ctorParameters = () => [
|
|
45
|
+
{ type: BaseSessionRetriever }
|
|
46
|
+
];
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTG9jYWxTdG9yYWdlUGVyc2lzdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJlZmVyZW5jZXMvc3JjL2xpYi9wZXJzaXN0b3IvaW1wbGVtZW50YXRpb24vTG9jYWxTdG9yYWdlUGVyc2lzdG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLFVBQVU7QUFDVixPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTNDLFNBQVM7QUFDVCxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUM1RSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUUvRSxPQUFPO0FBQ1AsT0FBTyxFQUFjLEVBQUUsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUN0QyxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFdkMsNEVBQTRFO0FBRTVFLE1BQU0sT0FBTyxxQkFBc0IsU0FBUSx3QkFBd0I7SUFFL0QsMEJBQTBCO0lBQzFCLFlBQVksT0FBNkIsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBRTlELCtCQUErQjtJQUN4QixPQUFPLENBQUksR0FBVyxFQUFFLElBQU87UUFDbEMsWUFBWSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztRQUM3RCxPQUFPLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztJQUNsQyxDQUFDO0lBRUQsK0JBQStCO0lBQ3hCLE9BQU8sQ0FBSSxHQUFXO1FBQ3pCLElBQUksR0FBRyxHQUFNLElBQUksQ0FBQyxLQUFLLENBQUMsWUFBWSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNoRSxPQUFPLEVBQUUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztJQUNqQyxDQUFDO0lBRUQsK0JBQStCO0lBQ3hCLFVBQVU7UUFDYixJQUFJLEdBQUcsR0FBaUMsRUFBRSxDQUFDO1FBQzNDLEtBQUssSUFBSSxDQUFDLElBQUksWUFBWSxFQUFFO1lBQ3hCLElBQUksQ0FBQyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsYUFBYSxFQUFFLENBQUM7Z0JBQzdELEdBQUcsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxZQUFZLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7U0FDdkU7UUFFRCxPQUFPLEVBQUUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztJQUNqQyxDQUFDO0lBRUQsK0JBQStCO0lBQ3hCLEtBQUs7UUFDUixLQUFLLElBQUksQ0FBQyxJQUFJLFlBQVksRUFBRTtZQUN4QixJQUFJLENBQUMsQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLGFBQWEsRUFBRSxDQUFDO2dCQUM3RCxZQUFZLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDO1NBQ2xDO1FBQ0QsT0FBTyxFQUFFLENBQUMsSUFBSSxDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUM7SUFDbEMsQ0FBQzs7O1lBcENKLFVBQVU7OztZQVBGLG9CQUFvQiIsInNvdXJjZXNDb250ZW50IjpbIi8vIEFuZ3VsYXJcclxuaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcblxyXG4vLyBDbGFzc2lcclxuaW1wb3J0IHsgQmFzZVByZWZlcmVuY2VzUGVyc2lzdG9yIH0gZnJvbSBcIi4uL2Jhc2UvQmFzZVByZWZlcmVuY2VzUGVyc2lzdG9yXCI7XHJcbmltcG9ydCB7IEJhc2VTZXNzaW9uUmV0cmlldmVyIH0gZnJvbSBcIi4uLy4uL3Nlc3Npb24vYmFzZS9CYXNlU2Vzc2lvblJldHJpZXZlclwiO1xyXG5cclxuLy8gUlhKU1xyXG5pbXBvcnQgeyBPYnNlcnZhYmxlLCBvZiB9IGZyb20gXCJyeGpzXCI7XHJcbmltcG9ydCB7IGZpcnN0IH0gZnJvbSBcInJ4anMvb3BlcmF0b3JzXCI7XHJcblxyXG4vKiogSW1wbGVtZW50YXppb25lIGRpIGRlZmF1bHQgcGVyIGxhIGNsYXNzZSAqKkJhc2VQcmVmZXJlbmNlc1BlcnNpc3RvcioqICovXHJcbkBJbmplY3RhYmxlKClcclxuZXhwb3J0IGNsYXNzIExvY2FsU3RvcmFnZVBlcnNpc3RvciBleHRlbmRzIEJhc2VQcmVmZXJlbmNlc1BlcnNpc3RvciB7XHJcblxyXG4gICAgLyoqIEBpZ25vcmUgQ29zdHJ1dHRvcmUgKi9cclxuICAgIGNvbnN0cnVjdG9yKHNlc3Npb246IEJhc2VTZXNzaW9uUmV0cmlldmVyKSB7IHN1cGVyKHNlc3Npb24pOyB9XHJcblxyXG4gICAgLyoqIEBpZ25vcmUgVmVkaSBjbGFzc2UgYmFzZSAqL1xyXG4gICAgcHVibGljIHBlcnNpc3Q8VD4oa2V5OiBzdHJpbmcsIGl0ZW06IFQpOiBPYnNlcnZhYmxlPGJvb2xlYW4+IHtcclxuICAgICAgICBsb2NhbFN0b3JhZ2Uuc2V0SXRlbSh0aGlzLmdldEtleShrZXkpLCBKU09OLnN0cmluZ2lmeShpdGVtKSk7XHJcbiAgICAgICAgcmV0dXJuIG9mKHRydWUpLnBpcGUoZmlyc3QoKSk7XHJcbiAgICB9XHJcblxyXG4gICAgLyoqIEBpZ25vcmUgVmVkaSBjbGFzc2UgYmFzZSAqL1xyXG4gICAgcHVibGljIHJlY292ZXI8VD4oa2V5OiBzdHJpbmcpOiBPYnNlcnZhYmxlPFQ+IHtcclxuICAgICAgICB2YXIgcmV0ID0gPFQ+SlNPTi5wYXJzZShsb2NhbFN0b3JhZ2UuZ2V0SXRlbSh0aGlzLmdldEtleShrZXkpKSk7XHJcbiAgICAgICAgcmV0dXJuIG9mKHJldCkucGlwZShmaXJzdCgpKTtcclxuICAgIH1cclxuXHJcbiAgICAvKiogQGlnbm9yZSBWZWRpIGNsYXNzZSBiYXNlICovXHJcbiAgICBwdWJsaWMgcmVjb3ZlckFsbCgpOiBPYnNlcnZhYmxlPHsgW2luZGV4OiBzdHJpbmddOiBzdHJpbmc7IH0+IHtcclxuICAgICAgICB2YXIgcmV0OiB7IFtpbmRleDogc3RyaW5nXTogc3RyaW5nOyB9ID0ge307XHJcbiAgICAgICAgZm9yICh2YXIgayBpbiBsb2NhbFN0b3JhZ2UpIHtcclxuICAgICAgICAgICAgaWYgKGsuaW5jbHVkZXMoXCLCp1wiKSAmJiBrLnN0YXJ0c1dpdGgodGhpcy5zZXNzaW9uLmdldFNlc3Npb25LZXkoKSkpXHJcbiAgICAgICAgICAgICAgICByZXRbay5tYXRjaCgvwqcoLiopwqcvKVsxXV0gPSBKU09OLnBhcnNlKGxvY2FsU3RvcmFnZS5nZXRJdGVtKGspKTtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIHJldHVybiBvZihyZXQpLnBpcGUoZmlyc3QoKSk7XHJcbiAgICB9XHJcblxyXG4gICAgLyoqIEBpZ25vcmUgVmVkaSBjbGFzc2UgYmFzZSAqL1xyXG4gICAgcHVibGljIGNsZWFyKCk6IE9ic2VydmFibGU8Ym9vbGVhbj4ge1xyXG4gICAgICAgIGZvciAodmFyIGsgaW4gbG9jYWxTdG9yYWdlKSB7XHJcbiAgICAgICAgICAgIGlmIChrLmluY2x1ZGVzKFwiwqdcIikgJiYgay5zdGFydHNXaXRoKHRoaXMuc2Vzc2lvbi5nZXRTZXNzaW9uS2V5KCkpKVxyXG4gICAgICAgICAgICAgICAgbG9jYWxTdG9yYWdlLnJlbW92ZUl0ZW0oayk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHJldHVybiBvZih0cnVlKS5waXBlKGZpcnN0KCkpO1xyXG4gICAgfVxyXG59Il19
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
// Angular
|
|
2
2
|
import { Inject, Injectable, Optional } from '@angular/core';
|
|
3
|
+
import { of } from 'rxjs';
|
|
4
|
+
import { tap } from 'rxjs/operators';
|
|
3
5
|
// Modelli
|
|
4
6
|
import { BasePreferencesPersistor } from './persistor/base/BasePreferencesPersistor';
|
|
5
|
-
import { BaseSessionRetriever } from './session/base/BaseSessionRetriever';
|
|
6
7
|
import { PREF_FULL_RETRIEVE_AT_START } from './tokens';
|
|
7
8
|
/**
|
|
8
9
|
* Service che si occupa di salvare e recuperare le preferenze utente rispetto alle chiavi salvate
|
|
@@ -13,8 +14,7 @@ export class PreferencesService {
|
|
|
13
14
|
*
|
|
14
15
|
* @ignore
|
|
15
16
|
*/
|
|
16
|
-
constructor(
|
|
17
|
-
this.sessionRetriever = sessionRetriever;
|
|
17
|
+
constructor(persistor, PREF_FULL_RETRIEVE_AT_START) {
|
|
18
18
|
this.persistor = persistor;
|
|
19
19
|
this.PREF_FULL_RETRIEVE_AT_START = PREF_FULL_RETRIEVE_AT_START;
|
|
20
20
|
/**
|
|
@@ -27,19 +27,12 @@ export class PreferencesService {
|
|
|
27
27
|
*/
|
|
28
28
|
this.LocalPreferences = {};
|
|
29
29
|
}
|
|
30
|
-
/**
|
|
31
|
-
* Getter per ottenere l'ID sessione dalla classe che fa le veci del **BaseSessionRetriever**
|
|
32
|
-
*/
|
|
33
|
-
get sessionId() {
|
|
34
|
-
// Non la cacho perché se mi cambia la sessione sotto mi rischia di rimanere il preference service che punta alla sessione vecchia ed è la fine
|
|
35
|
-
return this.sessionRetriever.getSessionKey();
|
|
36
|
-
}
|
|
37
30
|
/**
|
|
38
31
|
* Ripulisce le impostazioni locali e le impostazioni salvate dal persistor
|
|
39
32
|
*/
|
|
40
33
|
clear() {
|
|
41
34
|
this.LocalPreferences = {};
|
|
42
|
-
this.persistor.clear(
|
|
35
|
+
return this.persistor.clear();
|
|
43
36
|
}
|
|
44
37
|
/**
|
|
45
38
|
* Salva un oggetto sia nella cache locale che nel persistor
|
|
@@ -49,7 +42,7 @@ export class PreferencesService {
|
|
|
49
42
|
*/
|
|
50
43
|
store(key, item) {
|
|
51
44
|
this.LocalPreferences[key] = item;
|
|
52
|
-
this.persistor.persist(
|
|
45
|
+
return this.persistor.persist(key, item);
|
|
53
46
|
}
|
|
54
47
|
/**
|
|
55
48
|
* Recupera un oggetto in base a una chiave. Permette di accedere alla copia locale o alla copia persistita ed in caso fosse il primo caricamento e l'impostazione
|
|
@@ -66,16 +59,16 @@ export class PreferencesService {
|
|
|
66
59
|
// eseguo, altrimenti prendo l'oggetto se lo trovo e se non lo trovo lo carico prima in cache
|
|
67
60
|
if (this.FirstRetrieve) {
|
|
68
61
|
if (this.PREF_FULL_RETRIEVE_AT_START)
|
|
69
|
-
this.LocalPreferences = this.persistor.recoverAll(
|
|
62
|
+
this.LocalPreferences = this.persistor.recoverAll();
|
|
70
63
|
this.FirstRetrieve = false;
|
|
71
64
|
}
|
|
72
65
|
if (this.LocalPreferences[key] && !cacheBust)
|
|
73
|
-
return this.LocalPreferences[key];
|
|
66
|
+
return of(this.LocalPreferences[key]);
|
|
74
67
|
else {
|
|
75
|
-
var obj = this.persistor.recover(
|
|
68
|
+
var obj = this.persistor.recover(key);
|
|
76
69
|
if (!obj)
|
|
77
|
-
return null;
|
|
78
|
-
this.LocalPreferences[key] =
|
|
70
|
+
return of(null);
|
|
71
|
+
obj.pipe(tap(item => { this.LocalPreferences[key] = item; }));
|
|
79
72
|
return obj;
|
|
80
73
|
}
|
|
81
74
|
}
|
|
@@ -84,8 +77,7 @@ PreferencesService.decorators = [
|
|
|
84
77
|
{ type: Injectable }
|
|
85
78
|
];
|
|
86
79
|
PreferencesService.ctorParameters = () => [
|
|
87
|
-
{ type: BaseSessionRetriever },
|
|
88
80
|
{ type: BasePreferencesPersistor },
|
|
89
81
|
{ type: Boolean, decorators: [{ type: Optional }, { type: Inject, args: [PREF_FULL_RETRIEVE_AT_START,] }] }
|
|
90
82
|
];
|
|
91
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
83
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJlZmVyZW5jZXMuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3ByZWZlcmVuY2VzL3NyYy9saWIvcHJlZmVyZW5jZXMuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxVQUFVO0FBQ1YsT0FBTyxFQUFFLE1BQU0sRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzdELE9BQU8sRUFBYyxFQUFFLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDdEMsT0FBTyxFQUFFLEdBQUcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRXJDLFVBQVU7QUFDVixPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSwyQ0FBMkMsQ0FBQztBQUNyRixPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFFdkQ7O0dBRUc7QUFFSCxNQUFNLE9BQU8sa0JBQWtCO0lBYTdCOzs7O09BSUc7SUFDSCxZQUFvQixTQUFtQyxFQUEyRCwyQkFBb0M7UUFBbEksY0FBUyxHQUFULFNBQVMsQ0FBMEI7UUFBMkQsZ0NBQTJCLEdBQTNCLDJCQUEyQixDQUFTO1FBaEJ0Sjs7O1dBR0c7UUFDSyxrQkFBYSxHQUFZLElBQUksQ0FBQztRQUV0Qzs7V0FFRztRQUNLLHFCQUFnQixHQUE2QixFQUFFLENBQUM7SUFPa0csQ0FBQztJQUUzSjs7T0FFRztJQUNILEtBQUs7UUFDSCxJQUFJLENBQUMsZ0JBQWdCLEdBQUcsRUFBRSxDQUFDO1FBQzNCLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUNoQyxDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSCxLQUFLLENBQUksR0FBVyxFQUFFLElBQU87UUFDM0IsSUFBSSxDQUFDLGdCQUFnQixDQUFDLEdBQUcsQ0FBQyxHQUFHLElBQUksQ0FBQztRQUNsQyxPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLEdBQUcsRUFBRSxJQUFJLENBQUMsQ0FBQztJQUMzQyxDQUFDO0lBRUQ7Ozs7Ozs7OztPQVNHO0lBQ0gsUUFBUSxDQUFJLEdBQVcsRUFBRSxZQUFxQixLQUFLO1FBQ2pELDhGQUE4RjtRQUM5Riw2RkFBNkY7UUFDN0YsSUFBSSxJQUFJLENBQUMsYUFBYSxFQUFFO1lBQ3RCLElBQUksSUFBSSxDQUFDLDJCQUEyQjtnQkFDbEMsSUFBSSxDQUFDLGdCQUFnQixHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsVUFBVSxFQUFFLENBQUM7WUFDdEQsSUFBSSxDQUFDLGFBQWEsR0FBRyxLQUFLLENBQUM7U0FDNUI7UUFFRCxJQUFJLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLFNBQVM7WUFDMUMsT0FBTyxFQUFFLENBQUksSUFBSSxDQUFDLGdCQUFnQixDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7YUFDdEM7WUFDSCxJQUFJLEdBQUcsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBSSxHQUFHLENBQUMsQ0FBQztZQUN6QyxJQUFJLENBQUMsR0FBRztnQkFDTixPQUFPLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUNsQixHQUFHLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRSxHQUFHLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxHQUFHLENBQUMsR0FBRyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFBO1lBQzdELE9BQU8sR0FBRyxDQUFDO1NBQ1o7SUFDSCxDQUFDOzs7WUFwRUYsVUFBVTs7O1lBTkYsd0JBQXdCOzBDQXlCMkIsUUFBUSxZQUFJLE1BQU0sU0FBQywyQkFBMkIiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBBbmd1bGFyXHJcbmltcG9ydCB7IEluamVjdCwgSW5qZWN0YWJsZSwgT3B0aW9uYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgT2JzZXJ2YWJsZSwgb2YgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgdGFwIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xyXG5cclxuLy8gTW9kZWxsaVxyXG5pbXBvcnQgeyBCYXNlUHJlZmVyZW5jZXNQZXJzaXN0b3IgfSBmcm9tICcuL3BlcnNpc3Rvci9iYXNlL0Jhc2VQcmVmZXJlbmNlc1BlcnNpc3Rvcic7XHJcbmltcG9ydCB7IFBSRUZfRlVMTF9SRVRSSUVWRV9BVF9TVEFSVCB9IGZyb20gJy4vdG9rZW5zJztcclxuXHJcbi8qKlxyXG4gKiBTZXJ2aWNlIGNoZSBzaSBvY2N1cGEgZGkgc2FsdmFyZSBlIHJlY3VwZXJhcmUgbGUgcHJlZmVyZW56ZSB1dGVudGUgcmlzcGV0dG8gYWxsZSBjaGlhdmkgc2FsdmF0ZVxyXG4gKi9cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgUHJlZmVyZW5jZXNTZXJ2aWNlIHtcclxuXHJcbiAgLyoqXHJcbiAgICogSW5kaWNhIHNlIMOoIGxhIHByaW1hIHZvbHRhIGNoZSB2aWVuZSBlZmZldHR1YXRhIHVuJ29wZXJhemlvbmUgZGkgcmV0cmlldmUuIEFwcGVuYSBlZmZldHR1YXRhIHF1ZXN0YSB2YXJpYWJpbGUgdmllbmUgaW1wb3N0YXRhIGEgKipmYWxzZSoqIGUgKGluIHF1YW50byBzaW5nbGV0b24sXHJcbiAgICogc2UgY29uZmlndXJhdG8gYmVuZSkgbWFpIHBpw7kgbW9kaWZpY2F0YVxyXG4gICAqL1xyXG4gIHByaXZhdGUgRmlyc3RSZXRyaWV2ZTogYm9vbGVhbiA9IHRydWU7XHJcblxyXG4gIC8qKlxyXG4gICAqIFN0b3JlIGluIG1lbW9yaWEgZGVsbGUgcHJlZmVyZW56ZSBsb2NhbGkgY2hlIHNhcsOgIHBlcnNpc3RpdG8gcGVyIG1lenpvIGRlbGxhIGNsYXNzZSBjaGUgZmEgbGUgdmVjaSBkZWwgKipCYXNlUHJlZmVyZW5jZXNQZXJzaXN0b3IqKlxyXG4gICAqL1xyXG4gIHByaXZhdGUgTG9jYWxQcmVmZXJlbmNlczogeyBbaW5kZXg6IHN0cmluZ106IGFueSB9ID0ge307XHJcblxyXG4gIC8qKlxyXG4gICAqIENvc3RydXR0b3JlXHJcbiAgICogXHJcbiAgICogQGlnbm9yZVxyXG4gICAqL1xyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcGVyc2lzdG9yOiBCYXNlUHJlZmVyZW5jZXNQZXJzaXN0b3IsIEBPcHRpb25hbCgpIEBJbmplY3QoUFJFRl9GVUxMX1JFVFJJRVZFX0FUX1NUQVJUKSBwcml2YXRlIFBSRUZfRlVMTF9SRVRSSUVWRV9BVF9TVEFSVDogYm9vbGVhbikgeyB9XHJcblxyXG4gIC8qKlxyXG4gICAqIFJpcHVsaXNjZSBsZSBpbXBvc3RhemlvbmkgbG9jYWxpIGUgbGUgaW1wb3N0YXppb25pIHNhbHZhdGUgZGFsIHBlcnNpc3RvclxyXG4gICAqL1xyXG4gIGNsZWFyKCk6IE9ic2VydmFibGU8Ym9vbGVhbj4ge1xyXG4gICAgdGhpcy5Mb2NhbFByZWZlcmVuY2VzID0ge307XHJcbiAgICByZXR1cm4gdGhpcy5wZXJzaXN0b3IuY2xlYXIoKTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIFNhbHZhIHVuIG9nZ2V0dG8gc2lhIG5lbGxhIGNhY2hlIGxvY2FsZSBjaGUgbmVsIHBlcnNpc3RvclxyXG4gICAqIFxyXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBrZXkgQ2hpYXZlIGRpIHBlcnNpc3RlbnphXHJcbiAgICogQHBhcmFtIHtUfSBpdGVtIE9nZ2V0dG8gZGEgc2FsdmFyZVxyXG4gICAqL1xyXG4gIHN0b3JlPFQ+KGtleTogc3RyaW5nLCBpdGVtOiBUKTogT2JzZXJ2YWJsZTxib29sZWFuPiB7XHJcbiAgICB0aGlzLkxvY2FsUHJlZmVyZW5jZXNba2V5XSA9IGl0ZW07XHJcbiAgICByZXR1cm4gdGhpcy5wZXJzaXN0b3IucGVyc2lzdChrZXksIGl0ZW0pO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogUmVjdXBlcmEgdW4gb2dnZXR0byBpbiBiYXNlIGEgdW5hIGNoaWF2ZS4gUGVybWV0dGUgZGkgYWNjZWRlcmUgYWxsYSBjb3BpYSBsb2NhbGUgbyBhbGxhIGNvcGlhIHBlcnNpc3RpdGEgZWQgaW4gY2FzbyBmb3NzZSBpbCBwcmltbyBjYXJpY2FtZW50byBlIGwnaW1wb3N0YXppb25lIFxyXG4gICAqICoqcmV0cmlldmVBbGxBdFN0YXJ0KiogZGVsbGEgY2xhc3NlIGRpIGNvbmZpZ3VyYXppb25lIGZvc3NlICoqdHJ1ZSoqIHNpIG9jY3VwYSBhbmNoZSBkZWxsYSBwcmltYSB2YWxvcml6emF6aW9uZSBkZWxsYSBjYWNoZSBsb2NhbGVcclxuICAgKiBcclxuICAgKiBAcGFyYW0ge3N0cmluZ30ga2V5IENoaWF2ZSBkZWwgdmFsb3JlIGRhIHJlY3VwZXJhcmVcclxuICAgKiBAcGFyYW0ge2Jvb2xlYW59IGNhY2hlQnVzdCBJbmRpY2Egc2UgaWdub3JhcmUgaWwgdmFsb3JlIGRlbGxhIGNhY2hlIGxvY2FsZSBlIHJlY3VwZXJhcmUgbCdvZ2dldHRvIGRhbGxvIHN0b3JlIHBlcnNpc3RpdG8sIFxyXG4gICAqIGluIGNhc28gZm9zc2Ugc3RhdG8gbW9kaWZpY2F0byBmdW9yaSBzaXN0ZW1hIG8gZGEgdW4gYWx0cm8gc2lzdGVtYVxyXG4gICAqIFxyXG4gICAqIEByZXR1cm5zIHtUfSBPZ2dldHRvIHJpY2hpZXN0b1xyXG4gICAqL1xyXG4gIHJldHJpZXZlPFQ+KGtleTogc3RyaW5nLCBjYWNoZUJ1c3Q6IGJvb2xlYW4gPSBmYWxzZSk6IE9ic2VydmFibGU8VD4ge1xyXG4gICAgLy8gU2Ugw6ggaWwgcHJpbW8gcmV0cmlldmUgZSBzb25vIGNvbmZpZ3VyYXRvIHBlciByZWN1cGVyYXJlIHR1dHRhIGxhIGNvbmZpZ3VyYXppb25lIGFsbCdpbml6aW9cclxuICAgIC8vIGVzZWd1bywgYWx0cmltZW50aSBwcmVuZG8gbCdvZ2dldHRvIHNlIGxvIHRyb3ZvIGUgc2Ugbm9uIGxvIHRyb3ZvIGxvIGNhcmljbyBwcmltYSBpbiBjYWNoZVxyXG4gICAgaWYgKHRoaXMuRmlyc3RSZXRyaWV2ZSkge1xyXG4gICAgICBpZiAodGhpcy5QUkVGX0ZVTExfUkVUUklFVkVfQVRfU1RBUlQpXHJcbiAgICAgICAgdGhpcy5Mb2NhbFByZWZlcmVuY2VzID0gdGhpcy5wZXJzaXN0b3IucmVjb3ZlckFsbCgpO1xyXG4gICAgICB0aGlzLkZpcnN0UmV0cmlldmUgPSBmYWxzZTtcclxuICAgIH1cclxuXHJcbiAgICBpZiAodGhpcy5Mb2NhbFByZWZlcmVuY2VzW2tleV0gJiYgIWNhY2hlQnVzdClcclxuICAgICAgcmV0dXJuIG9mKDxUPnRoaXMuTG9jYWxQcmVmZXJlbmNlc1trZXldKTtcclxuICAgIGVsc2Uge1xyXG4gICAgICB2YXIgb2JqID0gdGhpcy5wZXJzaXN0b3IucmVjb3ZlcjxUPihrZXkpO1xyXG4gICAgICBpZiAoIW9iailcclxuICAgICAgICByZXR1cm4gb2YobnVsbCk7XHJcbiAgICAgIG9iai5waXBlKHRhcChpdGVtID0+IHsgdGhpcy5Mb2NhbFByZWZlcmVuY2VzW2tleV0gPSBpdGVtOyB9KSlcclxuICAgICAgcmV0dXJuIG9iajtcclxuICAgIH1cclxuICB9XHJcbn0iXX0=
|
|
@@ -1,38 +1,38 @@
|
|
|
1
1
|
import { InjectionToken, Injectable, Optional, Inject, NgModule } from '@angular/core';
|
|
2
|
+
import { forkJoin, of } from 'rxjs';
|
|
3
|
+
import { map, tap, first } from 'rxjs/operators';
|
|
2
4
|
|
|
3
5
|
/**
|
|
4
6
|
* Classe astratta che rappresenta lo stato di persistenza fra la libreria e uno storage
|
|
5
7
|
*/
|
|
6
8
|
class BasePreferencesPersistor {
|
|
9
|
+
/** @ignore Costruttore */
|
|
10
|
+
constructor(session) {
|
|
11
|
+
this.session = session;
|
|
12
|
+
}
|
|
7
13
|
/**
|
|
8
14
|
* Effettua il **persist** massivo di una lista di Chiave - Valore
|
|
9
15
|
*
|
|
10
|
-
* @param {string} sessionId ID della sessione
|
|
11
16
|
* @param {{ [key: string]: string }} dictionary Dizionario (lista di Chiave - Valore) da persistere
|
|
12
17
|
*/
|
|
13
|
-
persistAll(
|
|
18
|
+
persistAll(dictionary) {
|
|
19
|
+
let observables = [];
|
|
14
20
|
for (let key in dictionary)
|
|
15
|
-
this.persist(
|
|
21
|
+
observables.push(this.persist(key, dictionary[key]));
|
|
22
|
+
return forkJoin(observables).pipe(map(res => res.reduce((acc, val) => acc && val, true)));
|
|
16
23
|
}
|
|
17
24
|
/**
|
|
18
25
|
* Ottiene la chiave "Reale" da utilizzare per la persistenza di una chiave generica
|
|
19
26
|
*
|
|
20
|
-
* @param {string} sessionId ID della sessione
|
|
21
27
|
* @param {string} key Chiave da storicizzare
|
|
22
28
|
*
|
|
23
29
|
* @returns {string} Unione fra l'identificativo della sessione e la chiave specificata
|
|
24
30
|
*/
|
|
25
|
-
getKey(
|
|
26
|
-
return
|
|
31
|
+
getKey(key) {
|
|
32
|
+
return this.session.getSessionKey() + "§" + key + "§";
|
|
27
33
|
}
|
|
28
34
|
}
|
|
29
35
|
|
|
30
|
-
/**
|
|
31
|
-
* Classe astratta che si occupa di recuperare l'Id sessione univoco per applicazione ed utente collegato
|
|
32
|
-
*/
|
|
33
|
-
class BaseSessionRetriever {
|
|
34
|
-
}
|
|
35
|
-
|
|
36
36
|
/**
|
|
37
37
|
* Indica se recuperare autonomamente tutte le configurazioni salvate al bootstrap della libreria o se aspettare le richieste specifiche.
|
|
38
38
|
*
|
|
@@ -50,8 +50,7 @@ class PreferencesService {
|
|
|
50
50
|
*
|
|
51
51
|
* @ignore
|
|
52
52
|
*/
|
|
53
|
-
constructor(
|
|
54
|
-
this.sessionRetriever = sessionRetriever;
|
|
53
|
+
constructor(persistor, PREF_FULL_RETRIEVE_AT_START) {
|
|
55
54
|
this.persistor = persistor;
|
|
56
55
|
this.PREF_FULL_RETRIEVE_AT_START = PREF_FULL_RETRIEVE_AT_START;
|
|
57
56
|
/**
|
|
@@ -64,19 +63,12 @@ class PreferencesService {
|
|
|
64
63
|
*/
|
|
65
64
|
this.LocalPreferences = {};
|
|
66
65
|
}
|
|
67
|
-
/**
|
|
68
|
-
* Getter per ottenere l'ID sessione dalla classe che fa le veci del **BaseSessionRetriever**
|
|
69
|
-
*/
|
|
70
|
-
get sessionId() {
|
|
71
|
-
// Non la cacho perché se mi cambia la sessione sotto mi rischia di rimanere il preference service che punta alla sessione vecchia ed è la fine
|
|
72
|
-
return this.sessionRetriever.getSessionKey();
|
|
73
|
-
}
|
|
74
66
|
/**
|
|
75
67
|
* Ripulisce le impostazioni locali e le impostazioni salvate dal persistor
|
|
76
68
|
*/
|
|
77
69
|
clear() {
|
|
78
70
|
this.LocalPreferences = {};
|
|
79
|
-
this.persistor.clear(
|
|
71
|
+
return this.persistor.clear();
|
|
80
72
|
}
|
|
81
73
|
/**
|
|
82
74
|
* Salva un oggetto sia nella cache locale che nel persistor
|
|
@@ -86,7 +78,7 @@ class PreferencesService {
|
|
|
86
78
|
*/
|
|
87
79
|
store(key, item) {
|
|
88
80
|
this.LocalPreferences[key] = item;
|
|
89
|
-
this.persistor.persist(
|
|
81
|
+
return this.persistor.persist(key, item);
|
|
90
82
|
}
|
|
91
83
|
/**
|
|
92
84
|
* Recupera un oggetto in base a una chiave. Permette di accedere alla copia locale o alla copia persistita ed in caso fosse il primo caricamento e l'impostazione
|
|
@@ -103,16 +95,16 @@ class PreferencesService {
|
|
|
103
95
|
// eseguo, altrimenti prendo l'oggetto se lo trovo e se non lo trovo lo carico prima in cache
|
|
104
96
|
if (this.FirstRetrieve) {
|
|
105
97
|
if (this.PREF_FULL_RETRIEVE_AT_START)
|
|
106
|
-
this.LocalPreferences = this.persistor.recoverAll(
|
|
98
|
+
this.LocalPreferences = this.persistor.recoverAll();
|
|
107
99
|
this.FirstRetrieve = false;
|
|
108
100
|
}
|
|
109
101
|
if (this.LocalPreferences[key] && !cacheBust)
|
|
110
|
-
return this.LocalPreferences[key];
|
|
102
|
+
return of(this.LocalPreferences[key]);
|
|
111
103
|
else {
|
|
112
|
-
var obj = this.persistor.recover(
|
|
104
|
+
var obj = this.persistor.recover(key);
|
|
113
105
|
if (!obj)
|
|
114
|
-
return null;
|
|
115
|
-
this.LocalPreferences[key] =
|
|
106
|
+
return of(null);
|
|
107
|
+
obj.pipe(tap(item => { this.LocalPreferences[key] = item; }));
|
|
116
108
|
return obj;
|
|
117
109
|
}
|
|
118
110
|
}
|
|
@@ -121,7 +113,6 @@ PreferencesService.decorators = [
|
|
|
121
113
|
{ type: Injectable }
|
|
122
114
|
];
|
|
123
115
|
PreferencesService.ctorParameters = () => [
|
|
124
|
-
{ type: BaseSessionRetriever },
|
|
125
116
|
{ type: BasePreferencesPersistor },
|
|
126
117
|
{ type: Boolean, decorators: [{ type: Optional }, { type: Inject, args: [PREF_FULL_RETRIEVE_AT_START,] }] }
|
|
127
118
|
];
|
|
@@ -132,69 +123,51 @@ PreferencesService.ctorParameters = () => [
|
|
|
132
123
|
class PreferencesModuleConfig {
|
|
133
124
|
}
|
|
134
125
|
|
|
135
|
-
// Angular
|
|
136
126
|
/**
|
|
137
|
-
*
|
|
127
|
+
* Classe astratta che si occupa di recuperare l'Id sessione univoco per applicazione ed utente collegato
|
|
138
128
|
*/
|
|
129
|
+
class BaseSessionRetriever {
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
// Angular
|
|
133
|
+
/** Implementazione di default per la classe **BasePreferencesPersistor** */
|
|
139
134
|
class LocalStoragePersistor extends BasePreferencesPersistor {
|
|
140
|
-
/**
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
/**
|
|
147
|
-
* Salva, per una sessione, una chiave con un valore
|
|
148
|
-
*
|
|
149
|
-
* @param {string} sessionId ID della sessione
|
|
150
|
-
* @param {string} key Chiave da storicizzare
|
|
151
|
-
*
|
|
152
|
-
*/
|
|
153
|
-
persist(sessionId, key, item) {
|
|
154
|
-
localStorage.setItem(this.getKey(sessionId, key), JSON.stringify(item));
|
|
135
|
+
/** @ignore Costruttore */
|
|
136
|
+
constructor(session) { super(session); }
|
|
137
|
+
/** @ignore Vedi classe base */
|
|
138
|
+
persist(key, item) {
|
|
139
|
+
localStorage.setItem(this.getKey(key), JSON.stringify(item));
|
|
140
|
+
return of(true).pipe(first());
|
|
155
141
|
}
|
|
156
|
-
/**
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
* @param {string} key Chiave da recuperare
|
|
161
|
-
*
|
|
162
|
-
* @returns {T} Valore salvato per la chiave **key**
|
|
163
|
-
*/
|
|
164
|
-
recover(sessionId, key) {
|
|
165
|
-
return JSON.parse(localStorage.getItem(this.getKey(sessionId, key)));
|
|
142
|
+
/** @ignore Vedi classe base */
|
|
143
|
+
recover(key) {
|
|
144
|
+
var ret = JSON.parse(localStorage.getItem(this.getKey(key)));
|
|
145
|
+
return of(ret).pipe(first());
|
|
166
146
|
}
|
|
167
|
-
/**
|
|
168
|
-
|
|
169
|
-
*
|
|
170
|
-
* @param {string} sessionId ID della sessione
|
|
171
|
-
*
|
|
172
|
-
* @returns {{ [index: string]: string }} Dizionario con tutte le preference salvate per la sessione **sessionId**
|
|
173
|
-
*/
|
|
174
|
-
recoverAll(sessionId) {
|
|
147
|
+
/** @ignore Vedi classe base */
|
|
148
|
+
recoverAll() {
|
|
175
149
|
var ret = {};
|
|
176
150
|
for (var k in localStorage) {
|
|
177
|
-
if (k.includes("§") && k.startsWith(
|
|
151
|
+
if (k.includes("§") && k.startsWith(this.session.getSessionKey()))
|
|
178
152
|
ret[k.match(/§(.*)§/)[1]] = JSON.parse(localStorage.getItem(k));
|
|
179
153
|
}
|
|
180
|
-
return ret;
|
|
154
|
+
return of(ret).pipe(first());
|
|
181
155
|
}
|
|
182
|
-
/**
|
|
183
|
-
|
|
184
|
-
*
|
|
185
|
-
* @param {string} sessionId ID della sessione
|
|
186
|
-
*/
|
|
187
|
-
clear(sessionId) {
|
|
156
|
+
/** @ignore Vedi classe base */
|
|
157
|
+
clear() {
|
|
188
158
|
for (var k in localStorage) {
|
|
189
|
-
if (k.includes("§") && k.startsWith(
|
|
159
|
+
if (k.includes("§") && k.startsWith(this.session.getSessionKey()))
|
|
190
160
|
localStorage.removeItem(k);
|
|
191
161
|
}
|
|
162
|
+
return of(true).pipe(first());
|
|
192
163
|
}
|
|
193
164
|
}
|
|
194
165
|
LocalStoragePersistor.decorators = [
|
|
195
166
|
{ type: Injectable }
|
|
196
167
|
];
|
|
197
|
-
LocalStoragePersistor.ctorParameters = () => [
|
|
168
|
+
LocalStoragePersistor.ctorParameters = () => [
|
|
169
|
+
{ type: BaseSessionRetriever }
|
|
170
|
+
];
|
|
198
171
|
|
|
199
172
|
/**
|
|
200
173
|
* Implementazione di default per la classe **BaseSessionRetriever**
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"esfaenza-preferences.js","sources":["../../../projects/preferences/src/lib/persistor/base/BasePreferencesPersistor.ts","../../../projects/preferences/src/lib/session/base/BaseSessionRetriever.ts","../../../projects/preferences/src/lib/tokens.ts","../../../projects/preferences/src/lib/preferences.service.ts","../../../projects/preferences/src/lib/models/PreferencesModuleConfig.ts","../../../projects/preferences/src/lib/persistor/implementation/LocalStoragePersistor.ts","../../../projects/preferences/src/lib/session/implementation/DefaultSessionRetriever.ts","../../../projects/preferences/src/lib/preferences.module.ts","../../../projects/preferences/src/esfaenza-preferences.ts"],"sourcesContent":["/**\r\n * Classe astratta che rappresenta lo stato di persistenza fra la libreria e uno storage\r\n */\r\nexport abstract class BasePreferencesPersistor {\r\n\r\n /**\r\n * Salva, per una sessione, una chiave con un valore\r\n * \r\n * @param {string} sessionId ID della sessione\r\n * @param {string} key Chiave da storicizzare\r\n * \r\n */\r\n public abstract persist<T>(sessionId: string, key: string, item: T);\r\n\r\n /**\r\n * Recupera, per una sessione, il valore assegnato ad una chiave\r\n * \r\n * @param {string} sessionId ID della sessione\r\n * @param {string} key Chiave da recuperare\r\n * \r\n * @returns {T} Valore salvato per la chiave **key**\r\n */\r\n public abstract recover<T>(sessionId: string, key?: string): T;\r\n\r\n /**\r\n * Per una sessione recupera tutte le coppie Chiave - Valore salvate\r\n * \r\n * @param {string} sessionId ID della sessione\r\n * \r\n * @returns {{ [index: string]: string }} Dizionario con tutte le preference salvate per la sessione **sessionId**\r\n */\r\n public abstract recoverAll(sessionId: string): { [index: string]: string };\r\n\r\n /**\r\n * Ripulisce le preference salvate relative ad una sessione\r\n * \r\n * @param {string} sessionId ID della sessione\r\n */\r\n public abstract clear(sessionId: string);\r\n\r\n /**\r\n * Effettua il **persist** massivo di una lista di Chiave - Valore\r\n * \r\n * @param {string} sessionId ID della sessione\r\n * @param {{ [key: string]: string }} dictionary Dizionario (lista di Chiave - Valore) da persistere\r\n */\r\n public persistAll(sessionId: string, dictionary: { [key: string]: string }) {\r\n for (let key in dictionary)\r\n this.persist(sessionId, key, dictionary[key]);\r\n }\r\n\r\n /**\r\n * Ottiene la chiave \"Reale\" da utilizzare per la persistenza di una chiave generica\r\n * \r\n * @param {string} sessionId ID della sessione\r\n * @param {string} key Chiave da storicizzare\r\n * \r\n * @returns {string} Unione fra l'identificativo della sessione e la chiave specificata\r\n */\r\n protected getKey(sessionId: string, key: string): string {\r\n return sessionId + \"§\" + key + \"§\";\r\n }\r\n}","/**\r\n * Classe astratta che si occupa di recuperare l'Id sessione univoco per applicazione ed utente collegato\r\n */\r\nexport abstract class BaseSessionRetriever {\r\n\r\n /**\r\n * Ottiene un ID sessione\r\n * \r\n * @returns {string} ID sessione\r\n */\r\n public abstract getSessionKey(): string;\r\n}","import { InjectionToken } from '@angular/core';\r\n\r\n/**\r\n * Indica se recuperare autonomamente tutte le configurazioni salvate al bootstrap della libreria o se aspettare le richieste specifiche.\r\n * \r\n * Utile se non vengono salvate tante cose, potrebbe creare un momento di irresponsività se le info da recuperare sono molte\r\n */\r\nexport const PREF_FULL_RETRIEVE_AT_START: InjectionToken<boolean> = new InjectionToken<boolean>('PREF_FULL_RETRIEVE_AT_START');","// Angular\nimport { Inject, Injectable, Optional } from '@angular/core';\n\n// Modelli\nimport { BasePreferencesPersistor } from './persistor/base/BasePreferencesPersistor';\nimport { BaseSessionRetriever } from './session/base/BaseSessionRetriever';\nimport { PREF_FULL_RETRIEVE_AT_START } from './tokens';\n\n/**\n * Service che si occupa di salvare e recuperare le preferenze utente rispetto alle chiavi salvate\n */\n@Injectable()\nexport class PreferencesService {\n\n /**\n * Indica se è la prima volta che viene effettuata un'operazione di retrieve. Appena effettuata questa variabile viene impostata a **false** e (in quanto singleton,\n * se configurato bene) mai più modificata\n */\n private FirstRetrieve: boolean = true;\n\n /**\n * Store in memoria delle preferenze locali che sarà persistito per mezzo della classe che fa le veci del **BasePreferencesPersistor**\n */\n private LocalPreferences: { [index: string]: any } = {};\n\n /**\n * Getter per ottenere l'ID sessione dalla classe che fa le veci del **BaseSessionRetriever** \n */\n private get sessionId() {\n // Non la cacho perché se mi cambia la sessione sotto mi rischia di rimanere il preference service che punta alla sessione vecchia ed è la fine\n return this.sessionRetriever.getSessionKey();\n }\n\n /**\n * Costruttore\n * \n * @ignore\n */\n constructor(private sessionRetriever: BaseSessionRetriever, private persistor: BasePreferencesPersistor, @Optional() @Inject(PREF_FULL_RETRIEVE_AT_START) private PREF_FULL_RETRIEVE_AT_START: boolean) { }\n\n /**\n * Ripulisce le impostazioni locali e le impostazioni salvate dal persistor\n */\n clear() {\n this.LocalPreferences = {};\n this.persistor.clear(this.sessionId);\n }\n\n /**\n * Salva un oggetto sia nella cache locale che nel persistor\n * \n * @param {string} key Chiave di persistenza\n * @param {T} item Oggetto da salvare\n */\n store<T>(key: string, item: T) {\n this.LocalPreferences[key] = item;\n this.persistor.persist(this.sessionId, key, item);\n }\n\n /**\n * Recupera un oggetto in base a una chiave. Permette di accedere alla copia locale o alla copia persistita ed in caso fosse il primo caricamento e l'impostazione \n * **retrieveAllAtStart** della classe di configurazione fosse **true** si occupa anche della prima valorizzazione della cache locale\n * \n * @param {string} key Chiave del valore da recuperare\n * @param {boolean} cacheBust Indica se ignorare il valore della cache locale e recuperare l'oggetto dallo store persistito, \n * in caso fosse stato modificato fuori sistema o da un altro sistema\n * \n * @returns {T} Oggetto richiesto\n */\n retrieve<T>(key: string, cacheBust: boolean = false): T {\n // Se è il primo retrieve e sono configurato per recuperare tutta la configurazione all'inizio\n // eseguo, altrimenti prendo l'oggetto se lo trovo e se non lo trovo lo carico prima in cache\n if (this.FirstRetrieve) {\n if (this.PREF_FULL_RETRIEVE_AT_START)\n this.LocalPreferences = this.persistor.recoverAll(this.sessionId);\n this.FirstRetrieve = false;\n }\n\n if (this.LocalPreferences[key] && !cacheBust)\n return <T>this.LocalPreferences[key];\n else {\n var obj = this.persistor.recover<T>(this.sessionId, key);\n if (!obj)\n return null;\n this.LocalPreferences[key] = obj;\n return obj;\n }\n }\n}","import { Type } from \"@angular/core\";\r\nimport { BasePreferencesPersistor } from \"../persistor/base/BasePreferencesPersistor\";\r\nimport { BaseSessionRetriever } from \"../session/base/BaseSessionRetriever\";\r\n\r\n/**\r\n * Classe di Configurazione per la libreria\r\n */\r\nexport class PreferencesModuleConfig{\r\n\r\n /**\r\n * Indica se recuperare autonomamente tutte le configurazioni salvate al bootstrap della libreria o se aspettare le richieste specifiche.\r\n * \r\n * Utile se non vengono salvate tante cose, potrebbe creare un momento di irresponsività se le info da recuperare sono molte\r\n */\r\n retrieveAllAtStart?: boolean;\r\n\r\n /**\r\n * Classe che si deve occupare dello store \"Definitivo\" delle preferenze. Di default viene proposto uno store lato localStorage ma si può facilmente \r\n * fornire uno storage che porta le informazioni lato Database\r\n */\r\n preferencePersistor?: Type<BasePreferencesPersistor>;\r\n\r\n /**\r\n * Classe che si deve occupare per generare un ID univoco di sessione in base al quale verranno salvate le preferenze\r\n */\r\n sessionRetriever?: Type<BaseSessionRetriever>;\r\n}","// Angular\r\nimport { Injectable } from \"@angular/core\";\r\n\r\n// Classi\r\nimport { BasePreferencesPersistor } from \"../base/BasePreferencesPersistor\";\r\n\r\n/**\r\n * Implementazione di default per la classe **BasePreferencesPersistor**\r\n */\r\n@Injectable()\r\nexport class LocalStoragePersistor extends BasePreferencesPersistor {\r\n\r\n /**\r\n * Costruttore\r\n * \r\n * @ignore\r\n */\r\n constructor() { super(); }\r\n\r\n /**\r\n * Salva, per una sessione, una chiave con un valore\r\n * \r\n * @param {string} sessionId ID della sessione\r\n * @param {string} key Chiave da storicizzare\r\n * \r\n */\r\n public persist<T>(sessionId: string, key: string, item: T) {\r\n localStorage.setItem(this.getKey(sessionId, key), JSON.stringify(item));\r\n }\r\n\r\n /**\r\n * Recupera, per una sessione, il valore assegnato ad una chiave\r\n * \r\n * @param {string} sessionId ID della sessione\r\n * @param {string} key Chiave da recuperare\r\n * \r\n * @returns {T} Valore salvato per la chiave **key**\r\n */\r\n public recover<T>(sessionId: string, key: string): T {\r\n return <T>JSON.parse(localStorage.getItem(this.getKey(sessionId, key)));\r\n }\r\n\r\n /**\r\n * Per una sessione recupera tutte le coppie Chiave - Valore salvate\r\n * \r\n * @param {string} sessionId ID della sessione\r\n * \r\n * @returns {{ [index: string]: string }} Dizionario con tutte le preference salvate per la sessione **sessionId**\r\n */\r\n public recoverAll(sessionId: string): { [index: string]: string; } {\r\n var ret: { [index: string]: string; } = {};\r\n for (var k in localStorage) {\r\n if (k.includes(\"§\") && k.startsWith(sessionId))\r\n ret[k.match(/§(.*)§/)[1]] = JSON.parse(localStorage.getItem(k));\r\n }\r\n\r\n return ret;\r\n }\r\n\r\n /**\r\n * Ripulisce le preference salvate relative ad una sessione\r\n * \r\n * @param {string} sessionId ID della sessione\r\n */\r\n public clear(sessionId: string) {\r\n for (var k in localStorage) {\r\n if (k.includes(\"§\") && k.startsWith(sessionId))\r\n localStorage.removeItem(k);\r\n }\r\n }\r\n}","import { Injectable } from \"@angular/core\";\r\nimport { BaseSessionRetriever } from \"../base/BaseSessionRetriever\";\r\n\r\n/**\r\n * Implementazione di default per la classe **BaseSessionRetriever**\r\n */\r\n@Injectable()\r\nexport class DefaultSessionRetriever extends BaseSessionRetriever {\r\n\r\n /**\r\n * Costruttore\r\n * \r\n * @ignore\r\n */\r\n constructor() { super(); }\r\n\r\n /**\r\n * Ottiene un ID sessione\r\n * \r\n * @returns {string} ID sessione\r\n */\r\n getSessionKey(): string {\r\n return \"DUMMY_SESSION\";\r\n }\r\n}","// Angular\nimport { ModuleWithProviders } from '@angular/core';\nimport { NgModule } from '@angular/core';\n\n// Modelli\nimport { PreferencesModuleConfig } from './models/PreferencesModuleConfig';\nimport { BasePreferencesPersistor } from './persistor/base/BasePreferencesPersistor';\nimport { LocalStoragePersistor } from './persistor/implementation/LocalStoragePersistor';\nimport { BaseSessionRetriever } from './session/base/BaseSessionRetriever';\nimport { DefaultSessionRetriever } from './session/implementation/DefaultSessionRetriever';\nimport { PreferencesService } from './preferences.service';\nimport { PREF_FULL_RETRIEVE_AT_START } from './tokens';\n\n@NgModule()\nexport class PreferencesModule {\n static forRoot(config?: PreferencesModuleConfig): ModuleWithProviders<PreferencesModule> {\n return {\n ngModule: PreferencesModule,\n providers: [\n PreferencesService,\n { provide: BasePreferencesPersistor, useClass: config?.preferencePersistor || LocalStoragePersistor },\n { provide: BaseSessionRetriever, useClass: config?.sessionRetriever || DefaultSessionRetriever },\n { provide: PREF_FULL_RETRIEVE_AT_START, useValue: config?.retrieveAllAtStart || true }\n ]\n };\n }\n}","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n\nexport {LocalStoragePersistor as ɵa} from './lib/persistor/implementation/LocalStoragePersistor';\nexport {DefaultSessionRetriever as ɵb} from './lib/session/implementation/DefaultSessionRetriever';"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"esfaenza-preferences.js","sources":["../../../projects/preferences/src/lib/persistor/base/BasePreferencesPersistor.ts","../../../projects/preferences/src/lib/tokens.ts","../../../projects/preferences/src/lib/preferences.service.ts","../../../projects/preferences/src/lib/models/PreferencesModuleConfig.ts","../../../projects/preferences/src/lib/session/base/BaseSessionRetriever.ts","../../../projects/preferences/src/lib/persistor/implementation/LocalStoragePersistor.ts","../../../projects/preferences/src/lib/session/implementation/DefaultSessionRetriever.ts","../../../projects/preferences/src/lib/preferences.module.ts","../../../projects/preferences/src/esfaenza-preferences.ts"],"sourcesContent":["import { Observable, forkJoin } from \"rxjs\";\r\nimport { map } from \"rxjs/operators\";\r\nimport { BaseSessionRetriever } from \"../../session/base/BaseSessionRetriever\";\r\n\r\n/**\r\n * Classe astratta che rappresenta lo stato di persistenza fra la libreria e uno storage\r\n */\r\nexport abstract class BasePreferencesPersistor {\r\n\r\n /** @ignore Costruttore */\r\n constructor(protected session: BaseSessionRetriever) {}\r\n\r\n /**\r\n * Salva, per una sessione, una chiave con un valore\r\n * \r\n * @param {string} key Chiave da storicizzare\r\n */\r\n public abstract persist<T>(key: string, item: T): Observable<boolean>;\r\n\r\n /**\r\n * Recupera, per una sessione, il valore assegnato ad una chiave\r\n * \r\n * @param {string} key Chiave da recuperare\r\n * \r\n * @returns {Observable<T>} Valore salvato per la chiave **key**\r\n */\r\n public abstract recover<T>(key?: string): Observable<T>;\r\n\r\n /**\r\n * Per una sessione recupera tutte le coppie Chiave - Valore salvate\r\n * \r\n * @returns {Observable<{ [index: string]: string }>} Dizionario con tutte le preference salvate per la sessione\r\n */\r\n public abstract recoverAll(): Observable<{ [index: string]: string }>;\r\n\r\n /** Ripulisce le preference salvate relative ad una sessione */\r\n public abstract clear(): Observable<boolean>;\r\n\r\n /**\r\n * Effettua il **persist** massivo di una lista di Chiave - Valore\r\n * \r\n * @param {{ [key: string]: string }} dictionary Dizionario (lista di Chiave - Valore) da persistere\r\n */\r\n public persistAll(dictionary: { [key: string]: string }): Observable<boolean> {\r\n let observables: Observable<boolean>[] = [];\r\n for (let key in dictionary)\r\n observables.push(this.persist(key, dictionary[key]));\r\n\r\n return forkJoin(observables).pipe(map(res => res.reduce((acc, val) => acc && val, true)));\r\n }\r\n\r\n /**\r\n * Ottiene la chiave \"Reale\" da utilizzare per la persistenza di una chiave generica\r\n * \r\n * @param {string} key Chiave da storicizzare\r\n * \r\n * @returns {string} Unione fra l'identificativo della sessione e la chiave specificata\r\n */\r\n protected getKey(key: string): string {\r\n return this.session.getSessionKey() + \"§\" + key + \"§\";\r\n }\r\n}","import { InjectionToken } from '@angular/core';\r\n\r\n/**\r\n * Indica se recuperare autonomamente tutte le configurazioni salvate al bootstrap della libreria o se aspettare le richieste specifiche.\r\n * \r\n * Utile se non vengono salvate tante cose, potrebbe creare un momento di irresponsività se le info da recuperare sono molte\r\n */\r\nexport const PREF_FULL_RETRIEVE_AT_START: InjectionToken<boolean> = new InjectionToken<boolean>('PREF_FULL_RETRIEVE_AT_START');","// Angular\r\nimport { Inject, Injectable, Optional } from '@angular/core';\r\nimport { Observable, of } from 'rxjs';\r\nimport { tap } from 'rxjs/operators';\r\n\r\n// Modelli\r\nimport { BasePreferencesPersistor } from './persistor/base/BasePreferencesPersistor';\r\nimport { PREF_FULL_RETRIEVE_AT_START } from './tokens';\r\n\r\n/**\r\n * Service che si occupa di salvare e recuperare le preferenze utente rispetto alle chiavi salvate\r\n */\r\n@Injectable()\r\nexport class PreferencesService {\r\n\r\n /**\r\n * Indica se è la prima volta che viene effettuata un'operazione di retrieve. Appena effettuata questa variabile viene impostata a **false** e (in quanto singleton,\r\n * se configurato bene) mai più modificata\r\n */\r\n private FirstRetrieve: boolean = true;\r\n\r\n /**\r\n * Store in memoria delle preferenze locali che sarà persistito per mezzo della classe che fa le veci del **BasePreferencesPersistor**\r\n */\r\n private LocalPreferences: { [index: string]: any } = {};\r\n\r\n /**\r\n * Costruttore\r\n * \r\n * @ignore\r\n */\r\n constructor(private persistor: BasePreferencesPersistor, @Optional() @Inject(PREF_FULL_RETRIEVE_AT_START) private PREF_FULL_RETRIEVE_AT_START: boolean) { }\r\n\r\n /**\r\n * Ripulisce le impostazioni locali e le impostazioni salvate dal persistor\r\n */\r\n clear(): Observable<boolean> {\r\n this.LocalPreferences = {};\r\n return this.persistor.clear();\r\n }\r\n\r\n /**\r\n * Salva un oggetto sia nella cache locale che nel persistor\r\n * \r\n * @param {string} key Chiave di persistenza\r\n * @param {T} item Oggetto da salvare\r\n */\r\n store<T>(key: string, item: T): Observable<boolean> {\r\n this.LocalPreferences[key] = item;\r\n return this.persistor.persist(key, item);\r\n }\r\n\r\n /**\r\n * Recupera un oggetto in base a una chiave. Permette di accedere alla copia locale o alla copia persistita ed in caso fosse il primo caricamento e l'impostazione \r\n * **retrieveAllAtStart** della classe di configurazione fosse **true** si occupa anche della prima valorizzazione della cache locale\r\n * \r\n * @param {string} key Chiave del valore da recuperare\r\n * @param {boolean} cacheBust Indica se ignorare il valore della cache locale e recuperare l'oggetto dallo store persistito, \r\n * in caso fosse stato modificato fuori sistema o da un altro sistema\r\n * \r\n * @returns {T} Oggetto richiesto\r\n */\r\n retrieve<T>(key: string, cacheBust: boolean = false): Observable<T> {\r\n // Se è il primo retrieve e sono configurato per recuperare tutta la configurazione all'inizio\r\n // eseguo, altrimenti prendo l'oggetto se lo trovo e se non lo trovo lo carico prima in cache\r\n if (this.FirstRetrieve) {\r\n if (this.PREF_FULL_RETRIEVE_AT_START)\r\n this.LocalPreferences = this.persistor.recoverAll();\r\n this.FirstRetrieve = false;\r\n }\r\n\r\n if (this.LocalPreferences[key] && !cacheBust)\r\n return of(<T>this.LocalPreferences[key]);\r\n else {\r\n var obj = this.persistor.recover<T>(key);\r\n if (!obj)\r\n return of(null);\r\n obj.pipe(tap(item => { this.LocalPreferences[key] = item; }))\r\n return obj;\r\n }\r\n }\r\n}","import { Type } from \"@angular/core\";\r\nimport { BasePreferencesPersistor } from \"../persistor/base/BasePreferencesPersistor\";\r\nimport { BaseSessionRetriever } from \"../session/base/BaseSessionRetriever\";\r\n\r\n/**\r\n * Classe di Configurazione per la libreria\r\n */\r\nexport class PreferencesModuleConfig{\r\n\r\n /**\r\n * Indica se recuperare autonomamente tutte le configurazioni salvate al bootstrap della libreria o se aspettare le richieste specifiche.\r\n * \r\n * Utile se non vengono salvate tante cose, potrebbe creare un momento di irresponsività se le info da recuperare sono molte\r\n */\r\n retrieveAllAtStart?: boolean;\r\n\r\n /**\r\n * Classe che si deve occupare dello store \"Definitivo\" delle preferenze. Di default viene proposto uno store lato localStorage ma si può facilmente \r\n * fornire uno storage che porta le informazioni lato Database\r\n */\r\n preferencePersistor?: Type<BasePreferencesPersistor>;\r\n\r\n /**\r\n * Classe che si deve occupare per generare un ID univoco di sessione in base al quale verranno salvate le preferenze\r\n */\r\n sessionRetriever?: Type<BaseSessionRetriever>;\r\n}","/**\r\n * Classe astratta che si occupa di recuperare l'Id sessione univoco per applicazione ed utente collegato\r\n */\r\nexport abstract class BaseSessionRetriever {\r\n\r\n /**\r\n * Ottiene un ID sessione\r\n * \r\n * @returns {string} ID sessione\r\n */\r\n public abstract getSessionKey(): string;\r\n}","// Angular\r\nimport { Injectable } from \"@angular/core\";\r\n\r\n// Classi\r\nimport { BasePreferencesPersistor } from \"../base/BasePreferencesPersistor\";\r\nimport { BaseSessionRetriever } from \"../../session/base/BaseSessionRetriever\";\r\n\r\n// RXJS\r\nimport { Observable, of } from \"rxjs\";\r\nimport { first } from \"rxjs/operators\";\r\n\r\n/** Implementazione di default per la classe **BasePreferencesPersistor** */\r\n@Injectable()\r\nexport class LocalStoragePersistor extends BasePreferencesPersistor {\r\n\r\n /** @ignore Costruttore */\r\n constructor(session: BaseSessionRetriever) { super(session); }\r\n\r\n /** @ignore Vedi classe base */\r\n public persist<T>(key: string, item: T): Observable<boolean> {\r\n localStorage.setItem(this.getKey(key), JSON.stringify(item));\r\n return of(true).pipe(first());\r\n }\r\n\r\n /** @ignore Vedi classe base */\r\n public recover<T>(key: string): Observable<T> {\r\n var ret = <T>JSON.parse(localStorage.getItem(this.getKey(key)));\r\n return of(ret).pipe(first());\r\n }\r\n\r\n /** @ignore Vedi classe base */\r\n public recoverAll(): Observable<{ [index: string]: string; }> {\r\n var ret: { [index: string]: string; } = {};\r\n for (var k in localStorage) {\r\n if (k.includes(\"§\") && k.startsWith(this.session.getSessionKey()))\r\n ret[k.match(/§(.*)§/)[1]] = JSON.parse(localStorage.getItem(k));\r\n }\r\n\r\n return of(ret).pipe(first());\r\n }\r\n\r\n /** @ignore Vedi classe base */\r\n public clear(): Observable<boolean> {\r\n for (var k in localStorage) {\r\n if (k.includes(\"§\") && k.startsWith(this.session.getSessionKey()))\r\n localStorage.removeItem(k);\r\n }\r\n return of(true).pipe(first());\r\n }\r\n}","import { Injectable } from \"@angular/core\";\r\nimport { BaseSessionRetriever } from \"../base/BaseSessionRetriever\";\r\n\r\n/**\r\n * Implementazione di default per la classe **BaseSessionRetriever**\r\n */\r\n@Injectable()\r\nexport class DefaultSessionRetriever extends BaseSessionRetriever {\r\n\r\n /**\r\n * Costruttore\r\n * \r\n * @ignore\r\n */\r\n constructor() { super(); }\r\n\r\n /**\r\n * Ottiene un ID sessione\r\n * \r\n * @returns {string} ID sessione\r\n */\r\n getSessionKey(): string {\r\n return \"DUMMY_SESSION\";\r\n }\r\n}","// Angular\nimport { ModuleWithProviders } from '@angular/core';\nimport { NgModule } from '@angular/core';\n\n// Modelli\nimport { PreferencesModuleConfig } from './models/PreferencesModuleConfig';\nimport { BasePreferencesPersistor } from './persistor/base/BasePreferencesPersistor';\nimport { LocalStoragePersistor } from './persistor/implementation/LocalStoragePersistor';\nimport { BaseSessionRetriever } from './session/base/BaseSessionRetriever';\nimport { DefaultSessionRetriever } from './session/implementation/DefaultSessionRetriever';\nimport { PreferencesService } from './preferences.service';\nimport { PREF_FULL_RETRIEVE_AT_START } from './tokens';\n\n@NgModule()\nexport class PreferencesModule {\n static forRoot(config?: PreferencesModuleConfig): ModuleWithProviders<PreferencesModule> {\n return {\n ngModule: PreferencesModule,\n providers: [\n PreferencesService,\n { provide: BasePreferencesPersistor, useClass: config?.preferencePersistor || LocalStoragePersistor },\n { provide: BaseSessionRetriever, useClass: config?.sessionRetriever || DefaultSessionRetriever },\n { provide: PREF_FULL_RETRIEVE_AT_START, useValue: config?.retrieveAllAtStart || true }\n ]\n };\n }\n}","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n\nexport {LocalStoragePersistor as ɵa} from './lib/persistor/implementation/LocalStoragePersistor';\nexport {DefaultSessionRetriever as ɵb} from './lib/session/implementation/DefaultSessionRetriever';"],"names":[],"mappings":"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"}
|
|
@@ -1,56 +1,50 @@
|
|
|
1
|
+
import { Observable } from "rxjs";
|
|
2
|
+
import { BaseSessionRetriever } from "../../session/base/BaseSessionRetriever";
|
|
1
3
|
/**
|
|
2
4
|
* Classe astratta che rappresenta lo stato di persistenza fra la libreria e uno storage
|
|
3
5
|
*/
|
|
4
6
|
export declare abstract class BasePreferencesPersistor {
|
|
7
|
+
protected session: BaseSessionRetriever;
|
|
8
|
+
/** @ignore Costruttore */
|
|
9
|
+
constructor(session: BaseSessionRetriever);
|
|
5
10
|
/**
|
|
6
11
|
* Salva, per una sessione, una chiave con un valore
|
|
7
12
|
*
|
|
8
|
-
* @param {string} sessionId ID della sessione
|
|
9
13
|
* @param {string} key Chiave da storicizzare
|
|
10
|
-
*
|
|
11
14
|
*/
|
|
12
|
-
abstract persist<T>(
|
|
15
|
+
abstract persist<T>(key: string, item: T): Observable<boolean>;
|
|
13
16
|
/**
|
|
14
17
|
* Recupera, per una sessione, il valore assegnato ad una chiave
|
|
15
18
|
*
|
|
16
|
-
* @param {string} sessionId ID della sessione
|
|
17
19
|
* @param {string} key Chiave da recuperare
|
|
18
20
|
*
|
|
19
|
-
* @returns {T} Valore salvato per la chiave **key**
|
|
21
|
+
* @returns {Observable<T>} Valore salvato per la chiave **key**
|
|
20
22
|
*/
|
|
21
|
-
abstract recover<T>(
|
|
23
|
+
abstract recover<T>(key?: string): Observable<T>;
|
|
22
24
|
/**
|
|
23
25
|
* Per una sessione recupera tutte le coppie Chiave - Valore salvate
|
|
24
26
|
*
|
|
25
|
-
* @
|
|
26
|
-
*
|
|
27
|
-
* @returns {{ [index: string]: string }} Dizionario con tutte le preference salvate per la sessione **sessionId**
|
|
27
|
+
* @returns {Observable<{ [index: string]: string }>} Dizionario con tutte le preference salvate per la sessione
|
|
28
28
|
*/
|
|
29
|
-
abstract recoverAll(
|
|
29
|
+
abstract recoverAll(): Observable<{
|
|
30
30
|
[index: string]: string;
|
|
31
|
-
}
|
|
32
|
-
/**
|
|
33
|
-
|
|
34
|
-
*
|
|
35
|
-
* @param {string} sessionId ID della sessione
|
|
36
|
-
*/
|
|
37
|
-
abstract clear(sessionId: string): any;
|
|
31
|
+
}>;
|
|
32
|
+
/** Ripulisce le preference salvate relative ad una sessione */
|
|
33
|
+
abstract clear(): Observable<boolean>;
|
|
38
34
|
/**
|
|
39
35
|
* Effettua il **persist** massivo di una lista di Chiave - Valore
|
|
40
36
|
*
|
|
41
|
-
* @param {string} sessionId ID della sessione
|
|
42
37
|
* @param {{ [key: string]: string }} dictionary Dizionario (lista di Chiave - Valore) da persistere
|
|
43
38
|
*/
|
|
44
|
-
persistAll(
|
|
39
|
+
persistAll(dictionary: {
|
|
45
40
|
[key: string]: string;
|
|
46
|
-
}):
|
|
41
|
+
}): Observable<boolean>;
|
|
47
42
|
/**
|
|
48
43
|
* Ottiene la chiave "Reale" da utilizzare per la persistenza di una chiave generica
|
|
49
44
|
*
|
|
50
|
-
* @param {string} sessionId ID della sessione
|
|
51
45
|
* @param {string} key Chiave da storicizzare
|
|
52
46
|
*
|
|
53
47
|
* @returns {string} Unione fra l'identificativo della sessione e la chiave specificata
|
|
54
48
|
*/
|
|
55
|
-
protected getKey(
|
|
49
|
+
protected getKey(key: string): string;
|
|
56
50
|
}
|