@esfaenza/preferences 12.2.6 → 12.2.10

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.
@@ -2,66 +2,46 @@
2
2
  import { Injectable } from "@angular/core";
3
3
  // Classi
4
4
  import { BasePreferencesPersistor } from "../base/BasePreferencesPersistor";
5
- /**
6
- * Implementazione di default per la classe **BasePreferencesPersistor**
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
- * Costruttore
11
- *
12
- * @ignore
13
- */
14
- constructor() { super(); }
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
- * Recupera, per una sessione, il valore assegnato ad una chiave
27
- *
28
- * @param {string} sessionId ID della sessione
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
- * Per una sessione recupera tutte le coppie Chiave - Valore salvate
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(sessionId))
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
- * Ripulisce le preference salvate relative ad una sessione
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(sessionId))
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
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTG9jYWxTdG9yYWdlUGVyc2lzdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJlZmVyZW5jZXMvc3JjL2xpYi9wZXJzaXN0b3IvaW1wbGVtZW50YXRpb24vTG9jYWxTdG9yYWdlUGVyc2lzdG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLFVBQVU7QUFDVixPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTNDLFNBQVM7QUFDVCxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUU1RTs7R0FFRztBQUVILE1BQU0sT0FBTyxxQkFBc0IsU0FBUSx3QkFBd0I7SUFFL0Q7Ozs7T0FJRztJQUNILGdCQUFnQixLQUFLLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFFMUI7Ozs7OztPQU1HO0lBQ0ksT0FBTyxDQUFJLFNBQWlCLEVBQUUsR0FBVyxFQUFFLElBQU87UUFDckQsWUFBWSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLFNBQVMsRUFBRSxHQUFHLENBQUMsRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7SUFDNUUsQ0FBQztJQUVEOzs7Ozs7O09BT0c7SUFDSSxPQUFPLENBQUksU0FBaUIsRUFBRSxHQUFXO1FBQzVDLE9BQVUsSUFBSSxDQUFDLEtBQUssQ0FBQyxZQUFZLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsU0FBUyxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUM1RSxDQUFDO0lBRUQ7Ozs7OztPQU1HO0lBQ0ksVUFBVSxDQUFDLFNBQWlCO1FBQy9CLElBQUksR0FBRyxHQUFpQyxFQUFFLENBQUM7UUFDM0MsS0FBSyxJQUFJLENBQUMsSUFBSSxZQUFZLEVBQUU7WUFDeEIsSUFBSSxDQUFDLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQyxVQUFVLENBQUMsU0FBUyxDQUFDO2dCQUMxQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsWUFBWSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1NBQ3ZFO1FBRUQsT0FBTyxHQUFHLENBQUM7SUFDZixDQUFDO0lBRUQ7Ozs7T0FJRztJQUNJLEtBQUssQ0FBQyxTQUFpQjtRQUMxQixLQUFLLElBQUksQ0FBQyxJQUFJLFlBQVksRUFBRTtZQUN4QixJQUFJLENBQUMsQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDLFVBQVUsQ0FBQyxTQUFTLENBQUM7Z0JBQzFDLFlBQVksQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLENBQUM7U0FDbEM7SUFDTCxDQUFDOzs7WUE1REosVUFBVSIsInNvdXJjZXNDb250ZW50IjpbIi8vIEFuZ3VsYXJcclxuaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcblxyXG4vLyBDbGFzc2lcclxuaW1wb3J0IHsgQmFzZVByZWZlcmVuY2VzUGVyc2lzdG9yIH0gZnJvbSBcIi4uL2Jhc2UvQmFzZVByZWZlcmVuY2VzUGVyc2lzdG9yXCI7XHJcblxyXG4vKipcclxuICogSW1wbGVtZW50YXppb25lIGRpIGRlZmF1bHQgcGVyIGxhIGNsYXNzZSAqKkJhc2VQcmVmZXJlbmNlc1BlcnNpc3RvcioqXHJcbiAqL1xyXG5ASW5qZWN0YWJsZSgpXHJcbmV4cG9ydCBjbGFzcyBMb2NhbFN0b3JhZ2VQZXJzaXN0b3IgZXh0ZW5kcyBCYXNlUHJlZmVyZW5jZXNQZXJzaXN0b3Ige1xyXG5cclxuICAgIC8qKlxyXG4gICAgICogQ29zdHJ1dHRvcmVcclxuICAgICAqIFxyXG4gICAgICogQGlnbm9yZVxyXG4gICAgICovXHJcbiAgICBjb25zdHJ1Y3RvcigpIHsgc3VwZXIoKTsgfVxyXG5cclxuICAgIC8qKlxyXG4gICAgICogU2FsdmEsIHBlciB1bmEgc2Vzc2lvbmUsIHVuYSBjaGlhdmUgY29uIHVuIHZhbG9yZVxyXG4gICAgICogXHJcbiAgICAgKiBAcGFyYW0ge3N0cmluZ30gc2Vzc2lvbklkIElEIGRlbGxhIHNlc3Npb25lXHJcbiAgICAgKiBAcGFyYW0ge3N0cmluZ30ga2V5IENoaWF2ZSBkYSBzdG9yaWNpenphcmVcclxuICAgICAqIFxyXG4gICAgICovXHJcbiAgICBwdWJsaWMgcGVyc2lzdDxUPihzZXNzaW9uSWQ6IHN0cmluZywga2V5OiBzdHJpbmcsIGl0ZW06IFQpIHtcclxuICAgICAgICBsb2NhbFN0b3JhZ2Uuc2V0SXRlbSh0aGlzLmdldEtleShzZXNzaW9uSWQsIGtleSksIEpTT04uc3RyaW5naWZ5KGl0ZW0pKTtcclxuICAgIH1cclxuXHJcbiAgICAvKipcclxuICAgICAqIFJlY3VwZXJhLCBwZXIgdW5hIHNlc3Npb25lLCBpbCB2YWxvcmUgYXNzZWduYXRvIGFkIHVuYSBjaGlhdmVcclxuICAgICAqIFxyXG4gICAgICogQHBhcmFtIHtzdHJpbmd9IHNlc3Npb25JZCBJRCBkZWxsYSBzZXNzaW9uZVxyXG4gICAgICogQHBhcmFtIHtzdHJpbmd9IGtleSBDaGlhdmUgZGEgcmVjdXBlcmFyZVxyXG4gICAgICogXHJcbiAgICAgKiBAcmV0dXJucyB7VH0gVmFsb3JlIHNhbHZhdG8gcGVyIGxhIGNoaWF2ZSAqKmtleSoqXHJcbiAgICAgKi9cclxuICAgIHB1YmxpYyByZWNvdmVyPFQ+KHNlc3Npb25JZDogc3RyaW5nLCBrZXk6IHN0cmluZyk6IFQge1xyXG4gICAgICAgIHJldHVybiA8VD5KU09OLnBhcnNlKGxvY2FsU3RvcmFnZS5nZXRJdGVtKHRoaXMuZ2V0S2V5KHNlc3Npb25JZCwga2V5KSkpO1xyXG4gICAgfVxyXG5cclxuICAgIC8qKlxyXG4gICAgICogUGVyIHVuYSBzZXNzaW9uZSByZWN1cGVyYSB0dXR0ZSBsZSBjb3BwaWUgQ2hpYXZlIC0gVmFsb3JlIHNhbHZhdGVcclxuICAgICAqIFxyXG4gICAgICogQHBhcmFtIHtzdHJpbmd9IHNlc3Npb25JZCBJRCBkZWxsYSBzZXNzaW9uZVxyXG4gICAgICogXHJcbiAgICAgKiBAcmV0dXJucyB7eyBbaW5kZXg6IHN0cmluZ106IHN0cmluZyB9fSBEaXppb25hcmlvIGNvbiB0dXR0ZSBsZSBwcmVmZXJlbmNlIHNhbHZhdGUgcGVyIGxhIHNlc3Npb25lICoqc2Vzc2lvbklkKipcclxuICAgICAqL1xyXG4gICAgcHVibGljIHJlY292ZXJBbGwoc2Vzc2lvbklkOiBzdHJpbmcpOiB7IFtpbmRleDogc3RyaW5nXTogc3RyaW5nOyB9IHtcclxuICAgICAgICB2YXIgcmV0OiB7IFtpbmRleDogc3RyaW5nXTogc3RyaW5nOyB9ID0ge307XHJcbiAgICAgICAgZm9yICh2YXIgayBpbiBsb2NhbFN0b3JhZ2UpIHtcclxuICAgICAgICAgICAgaWYgKGsuaW5jbHVkZXMoXCLCp1wiKSAmJiBrLnN0YXJ0c1dpdGgoc2Vzc2lvbklkKSlcclxuICAgICAgICAgICAgICAgIHJldFtrLm1hdGNoKC/CpyguKinCpy8pWzFdXSA9IEpTT04ucGFyc2UobG9jYWxTdG9yYWdlLmdldEl0ZW0oaykpO1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgcmV0dXJuIHJldDtcclxuICAgIH1cclxuXHJcbiAgICAvKipcclxuICAgICAqIFJpcHVsaXNjZSBsZSBwcmVmZXJlbmNlIHNhbHZhdGUgcmVsYXRpdmUgYWQgdW5hIHNlc3Npb25lXHJcbiAgICAgKiBcclxuICAgICAqIEBwYXJhbSB7c3RyaW5nfSBzZXNzaW9uSWQgSUQgZGVsbGEgc2Vzc2lvbmVcclxuICAgICAqL1xyXG4gICAgcHVibGljIGNsZWFyKHNlc3Npb25JZDogc3RyaW5nKSB7XHJcbiAgICAgICAgZm9yICh2YXIgayBpbiBsb2NhbFN0b3JhZ2UpIHtcclxuICAgICAgICAgICAgaWYgKGsuaW5jbHVkZXMoXCLCp1wiKSAmJiBrLnN0YXJ0c1dpdGgoc2Vzc2lvbklkKSlcclxuICAgICAgICAgICAgICAgIGxvY2FsU3RvcmFnZS5yZW1vdmVJdGVtKGspO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxufSJdfQ==
44
+ LocalStoragePersistor.ctorParameters = () => [
45
+ { type: BaseSessionRetriever }
46
+ ];
47
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTG9jYWxTdG9yYWdlUGVyc2lzdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJlZmVyZW5jZXMvc3JjL2xpYi9wZXJzaXN0b3IvaW1wbGVtZW50YXRpb24vTG9jYWxTdG9yYWdlUGVyc2lzdG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLFVBQVU7QUFDVixPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTNDLFNBQVM7QUFDVCxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUM1RSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUUvRSxPQUFPO0FBQ1AsT0FBTyxFQUFjLEVBQUUsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUN0QyxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFdkMsNEVBQTRFO0FBRTVFLE1BQU0sT0FBTyxxQkFBc0IsU0FBUSx3QkFBd0I7SUFFL0QsMEJBQTBCO0lBQzFCLFlBQVksT0FBNkIsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBRTlELCtCQUErQjtJQUN4QixPQUFPLENBQUksR0FBVyxFQUFFLElBQU87UUFDbEMsWUFBWSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztRQUM3RCxPQUFPLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztJQUNsQyxDQUFDO0lBRUQsK0JBQStCO0lBQ3hCLE9BQU8sQ0FBSSxHQUFXO1FBQ3pCLElBQUksR0FBRyxHQUFNLElBQUksQ0FBQyxLQUFLLENBQUMsWUFBWSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNoRSxPQUFPLEVBQUUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztJQUNqQyxDQUFDO0lBRUQsK0JBQStCO0lBQ3hCLFVBQVU7UUFDYixJQUFJLEdBQUcsR0FBaUMsRUFBRSxDQUFDO1FBQzNDLEtBQUssSUFBSSxDQUFDLElBQUksWUFBWSxFQUFFO1lBQ3hCLElBQUksQ0FBQyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsYUFBYSxFQUFFLENBQUM7Z0JBQzdELEdBQUcsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxZQUFZLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7U0FDdkU7UUFFRCxPQUFPLEVBQUUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztJQUNqQyxDQUFDO0lBRUQsK0JBQStCO0lBQ3hCLEtBQUs7UUFDUixLQUFLLElBQUksQ0FBQyxJQUFJLFlBQVksRUFBRTtZQUN4QixJQUFJLENBQUMsQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLGFBQWEsRUFBRSxDQUFDO2dCQUM3RCxZQUFZLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDO1NBQ2xDO1FBQ0QsT0FBTyxFQUFFLENBQUMsSUFBSSxDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUM7SUFDbEMsQ0FBQzs7O1lBcENKLFVBQVU7OztZQVBGLG9CQUFvQiIsInNvdXJjZXNDb250ZW50IjpbIi8vIEFuZ3VsYXJcclxuaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcblxyXG4vLyBDbGFzc2lcclxuaW1wb3J0IHsgQmFzZVByZWZlcmVuY2VzUGVyc2lzdG9yIH0gZnJvbSBcIi4uL2Jhc2UvQmFzZVByZWZlcmVuY2VzUGVyc2lzdG9yXCI7XHJcbmltcG9ydCB7IEJhc2VTZXNzaW9uUmV0cmlldmVyIH0gZnJvbSBcIi4uLy4uL3Nlc3Npb24vYmFzZS9CYXNlU2Vzc2lvblJldHJpZXZlclwiO1xyXG5cclxuLy8gUlhKU1xyXG5pbXBvcnQgeyBPYnNlcnZhYmxlLCBvZiB9IGZyb20gXCJyeGpzXCI7XHJcbmltcG9ydCB7IGZpcnN0IH0gZnJvbSBcInJ4anMvb3BlcmF0b3JzXCI7XHJcblxyXG4vKiogSW1wbGVtZW50YXppb25lIGRpIGRlZmF1bHQgcGVyIGxhIGNsYXNzZSAqKkJhc2VQcmVmZXJlbmNlc1BlcnNpc3RvcioqICovXHJcbkBJbmplY3RhYmxlKClcclxuZXhwb3J0IGNsYXNzIExvY2FsU3RvcmFnZVBlcnNpc3RvciBleHRlbmRzIEJhc2VQcmVmZXJlbmNlc1BlcnNpc3RvciB7XHJcblxyXG4gICAgLyoqIEBpZ25vcmUgQ29zdHJ1dHRvcmUgKi9cclxuICAgIGNvbnN0cnVjdG9yKHNlc3Npb246IEJhc2VTZXNzaW9uUmV0cmlldmVyKSB7IHN1cGVyKHNlc3Npb24pOyB9XHJcblxyXG4gICAgLyoqIEBpZ25vcmUgVmVkaSBjbGFzc2UgYmFzZSAqL1xyXG4gICAgcHVibGljIHBlcnNpc3Q8VD4oa2V5OiBzdHJpbmcsIGl0ZW06IFQpOiBPYnNlcnZhYmxlPGJvb2xlYW4+IHtcclxuICAgICAgICBsb2NhbFN0b3JhZ2Uuc2V0SXRlbSh0aGlzLmdldEtleShrZXkpLCBKU09OLnN0cmluZ2lmeShpdGVtKSk7XHJcbiAgICAgICAgcmV0dXJuIG9mKHRydWUpLnBpcGUoZmlyc3QoKSk7XHJcbiAgICB9XHJcblxyXG4gICAgLyoqIEBpZ25vcmUgVmVkaSBjbGFzc2UgYmFzZSAqL1xyXG4gICAgcHVibGljIHJlY292ZXI8VD4oa2V5OiBzdHJpbmcpOiBPYnNlcnZhYmxlPFQ+IHtcclxuICAgICAgICB2YXIgcmV0ID0gPFQ+SlNPTi5wYXJzZShsb2NhbFN0b3JhZ2UuZ2V0SXRlbSh0aGlzLmdldEtleShrZXkpKSk7XHJcbiAgICAgICAgcmV0dXJuIG9mKHJldCkucGlwZShmaXJzdCgpKTtcclxuICAgIH1cclxuXHJcbiAgICAvKiogQGlnbm9yZSBWZWRpIGNsYXNzZSBiYXNlICovXHJcbiAgICBwdWJsaWMgcmVjb3ZlckFsbCgpOiBPYnNlcnZhYmxlPHsgW2luZGV4OiBzdHJpbmddOiBhbnk7IH0+IHtcclxuICAgICAgICB2YXIgcmV0OiB7IFtpbmRleDogc3RyaW5nXTogc3RyaW5nOyB9ID0ge307XHJcbiAgICAgICAgZm9yICh2YXIgayBpbiBsb2NhbFN0b3JhZ2UpIHtcclxuICAgICAgICAgICAgaWYgKGsuaW5jbHVkZXMoXCLCp1wiKSAmJiBrLnN0YXJ0c1dpdGgodGhpcy5zZXNzaW9uLmdldFNlc3Npb25LZXkoKSkpXHJcbiAgICAgICAgICAgICAgICByZXRbay5tYXRjaCgvwqcoLiopwqcvKVsxXV0gPSBKU09OLnBhcnNlKGxvY2FsU3RvcmFnZS5nZXRJdGVtKGspKTtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIHJldHVybiBvZihyZXQpLnBpcGUoZmlyc3QoKSk7XHJcbiAgICB9XHJcblxyXG4gICAgLyoqIEBpZ25vcmUgVmVkaSBjbGFzc2UgYmFzZSAqL1xyXG4gICAgcHVibGljIGNsZWFyKCk6IE9ic2VydmFibGU8Ym9vbGVhbj4ge1xyXG4gICAgICAgIGZvciAodmFyIGsgaW4gbG9jYWxTdG9yYWdlKSB7XHJcbiAgICAgICAgICAgIGlmIChrLmluY2x1ZGVzKFwiwqdcIikgJiYgay5zdGFydHNXaXRoKHRoaXMuc2Vzc2lvbi5nZXRTZXNzaW9uS2V5KCkpKVxyXG4gICAgICAgICAgICAgICAgbG9jYWxTdG9yYWdlLnJlbW92ZUl0ZW0oayk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHJldHVybiBvZih0cnVlKS5waXBlKGZpcnN0KCkpO1xyXG4gICAgfVxyXG59Il19
@@ -1,8 +1,9 @@
1
1
  // Angular
2
2
  import { Inject, Injectable, Optional } from '@angular/core';
3
+ import { of } from 'rxjs';
4
+ import { concatMap, 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(sessionRetriever, persistor, PREF_FULL_RETRIEVE_AT_START) {
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(this.sessionId);
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(this.sessionId, key, item);
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,23 @@ 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(this.sessionId);
70
- this.FirstRetrieve = false;
62
+ return this.persistor.recoverAll().pipe(concatMap(res => {
63
+ this.LocalPreferences = res;
64
+ this.FirstRetrieve = false;
65
+ return this.internalRetrieve(key, cacheBust);
66
+ }));
71
67
  }
68
+ return this.internalRetrieve(key, cacheBust);
69
+ }
70
+ /** @ignore Vedi **retrieve** */
71
+ internalRetrieve(key, cacheBust = false) {
72
72
  if (this.LocalPreferences[key] && !cacheBust)
73
- return this.LocalPreferences[key];
73
+ return of(this.LocalPreferences[key]);
74
74
  else {
75
- var obj = this.persistor.recover(this.sessionId, key);
75
+ var obj = this.persistor.recover(key);
76
76
  if (!obj)
77
- return null;
78
- this.LocalPreferences[key] = obj;
77
+ return of(null);
78
+ obj.pipe(tap(item => { this.LocalPreferences[key] = item; }));
79
79
  return obj;
80
80
  }
81
81
  }
@@ -84,8 +84,7 @@ PreferencesService.decorators = [
84
84
  { type: Injectable }
85
85
  ];
86
86
  PreferencesService.ctorParameters = () => [
87
- { type: BaseSessionRetriever },
88
87
  { type: BasePreferencesPersistor },
89
88
  { type: Boolean, decorators: [{ type: Optional }, { type: Inject, args: [PREF_FULL_RETRIEVE_AT_START,] }] }
90
89
  ];
91
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJlZmVyZW5jZXMuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3ByZWZlcmVuY2VzL3NyYy9saWIvcHJlZmVyZW5jZXMuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxVQUFVO0FBQ1YsT0FBTyxFQUFFLE1BQU0sRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTdELFVBQVU7QUFDVixPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSwyQ0FBMkMsQ0FBQztBQUNyRixPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUMzRSxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFFdkQ7O0dBRUc7QUFFSCxNQUFNLE9BQU8sa0JBQWtCO0lBcUI3Qjs7OztPQUlHO0lBQ0gsWUFBb0IsZ0JBQXNDLEVBQVUsU0FBbUMsRUFBMkQsMkJBQW9DO1FBQWxMLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBc0I7UUFBVSxjQUFTLEdBQVQsU0FBUyxDQUEwQjtRQUEyRCxnQ0FBMkIsR0FBM0IsMkJBQTJCLENBQVM7UUF4QnRNOzs7V0FHRztRQUNLLGtCQUFhLEdBQVksSUFBSSxDQUFDO1FBRXRDOztXQUVHO1FBQ0sscUJBQWdCLEdBQTZCLEVBQUUsQ0FBQztJQWVrSixDQUFDO0lBYjNNOztPQUVHO0lBQ0gsSUFBWSxTQUFTO1FBQ25CLCtJQUErSTtRQUMvSSxPQUFPLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxhQUFhLEVBQUUsQ0FBQztJQUMvQyxDQUFDO0lBU0Q7O09BRUc7SUFDSCxLQUFLO1FBQ0gsSUFBSSxDQUFDLGdCQUFnQixHQUFHLEVBQUUsQ0FBQztRQUMzQixJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDdkMsQ0FBQztJQUVEOzs7OztPQUtHO0lBQ0gsS0FBSyxDQUFJLEdBQVcsRUFBRSxJQUFPO1FBQzNCLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxHQUFHLENBQUMsR0FBRyxJQUFJLENBQUM7UUFDbEMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxHQUFHLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDcEQsQ0FBQztJQUVEOzs7Ozs7Ozs7T0FTRztJQUNILFFBQVEsQ0FBSSxHQUFXLEVBQUUsWUFBcUIsS0FBSztRQUNqRCw4RkFBOEY7UUFDOUYsNkZBQTZGO1FBQzdGLElBQUksSUFBSSxDQUFDLGFBQWEsRUFBRTtZQUN0QixJQUFJLElBQUksQ0FBQywyQkFBMkI7Z0JBQ2xDLElBQUksQ0FBQyxnQkFBZ0IsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7WUFDcEUsSUFBSSxDQUFDLGFBQWEsR0FBRyxLQUFLLENBQUM7U0FDNUI7UUFFRCxJQUFJLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLFNBQVM7WUFDMUMsT0FBVSxJQUFJLENBQUMsZ0JBQWdCLENBQUMsR0FBRyxDQUFDLENBQUM7YUFDbEM7WUFDSCxJQUFJLEdBQUcsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBSSxJQUFJLENBQUMsU0FBUyxFQUFFLEdBQUcsQ0FBQyxDQUFDO1lBQ3pELElBQUksQ0FBQyxHQUFHO2dCQUNOLE9BQU8sSUFBSSxDQUFDO1lBQ2QsSUFBSSxDQUFDLGdCQUFnQixDQUFDLEdBQUcsQ0FBQyxHQUFHLEdBQUcsQ0FBQztZQUNqQyxPQUFPLEdBQUcsQ0FBQztTQUNaO0lBQ0gsQ0FBQzs7O1lBNUVGLFVBQVU7OztZQU5GLG9CQUFvQjtZQURwQix3QkFBd0I7MENBa0MyRSxRQUFRLFlBQUksTUFBTSxTQUFDLDJCQUEyQiIsInNvdXJjZXNDb250ZW50IjpbIi8vIEFuZ3VsYXJcbmltcG9ydCB7IEluamVjdCwgSW5qZWN0YWJsZSwgT3B0aW9uYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuLy8gTW9kZWxsaVxuaW1wb3J0IHsgQmFzZVByZWZlcmVuY2VzUGVyc2lzdG9yIH0gZnJvbSAnLi9wZXJzaXN0b3IvYmFzZS9CYXNlUHJlZmVyZW5jZXNQZXJzaXN0b3InO1xuaW1wb3J0IHsgQmFzZVNlc3Npb25SZXRyaWV2ZXIgfSBmcm9tICcuL3Nlc3Npb24vYmFzZS9CYXNlU2Vzc2lvblJldHJpZXZlcic7XG5pbXBvcnQgeyBQUkVGX0ZVTExfUkVUUklFVkVfQVRfU1RBUlQgfSBmcm9tICcuL3Rva2Vucyc7XG5cbi8qKlxuICogU2VydmljZSBjaGUgc2kgb2NjdXBhIGRpIHNhbHZhcmUgZSByZWN1cGVyYXJlIGxlIHByZWZlcmVuemUgdXRlbnRlIHJpc3BldHRvIGFsbGUgY2hpYXZpIHNhbHZhdGVcbiAqL1xuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIFByZWZlcmVuY2VzU2VydmljZSB7XG5cbiAgLyoqXG4gICAqIEluZGljYSBzZSDDqCBsYSBwcmltYSB2b2x0YSBjaGUgdmllbmUgZWZmZXR0dWF0YSB1bidvcGVyYXppb25lIGRpIHJldHJpZXZlLiBBcHBlbmEgZWZmZXR0dWF0YSBxdWVzdGEgdmFyaWFiaWxlIHZpZW5lIGltcG9zdGF0YSBhICoqZmFsc2UqKiBlIChpbiBxdWFudG8gc2luZ2xldG9uLFxuICAgKiBzZSBjb25maWd1cmF0byBiZW5lKSBtYWkgcGnDuSBtb2RpZmljYXRhXG4gICAqL1xuICBwcml2YXRlIEZpcnN0UmV0cmlldmU6IGJvb2xlYW4gPSB0cnVlO1xuXG4gIC8qKlxuICAgKiBTdG9yZSBpbiBtZW1vcmlhIGRlbGxlIHByZWZlcmVuemUgbG9jYWxpIGNoZSBzYXLDoCBwZXJzaXN0aXRvIHBlciBtZXp6byBkZWxsYSBjbGFzc2UgY2hlIGZhIGxlIHZlY2kgZGVsICoqQmFzZVByZWZlcmVuY2VzUGVyc2lzdG9yKipcbiAgICovXG4gIHByaXZhdGUgTG9jYWxQcmVmZXJlbmNlczogeyBbaW5kZXg6IHN0cmluZ106IGFueSB9ID0ge307XG5cbiAgLyoqXG4gICAqIEdldHRlciBwZXIgb3R0ZW5lcmUgbCdJRCBzZXNzaW9uZSBkYWxsYSBjbGFzc2UgY2hlIGZhIGxlIHZlY2kgZGVsICoqQmFzZVNlc3Npb25SZXRyaWV2ZXIqKiBcbiAgICovXG4gIHByaXZhdGUgZ2V0IHNlc3Npb25JZCgpIHtcbiAgICAvLyBOb24gbGEgY2FjaG8gcGVyY2jDqSBzZSBtaSBjYW1iaWEgbGEgc2Vzc2lvbmUgc290dG8gbWkgcmlzY2hpYSBkaSByaW1hbmVyZSBpbCBwcmVmZXJlbmNlIHNlcnZpY2UgY2hlIHB1bnRhIGFsbGEgc2Vzc2lvbmUgdmVjY2hpYSBlZCDDqCBsYSBmaW5lXG4gICAgcmV0dXJuIHRoaXMuc2Vzc2lvblJldHJpZXZlci5nZXRTZXNzaW9uS2V5KCk7XG4gIH1cblxuICAvKipcbiAgICogQ29zdHJ1dHRvcmVcbiAgICogXG4gICAqIEBpZ25vcmVcbiAgICovXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgc2Vzc2lvblJldHJpZXZlcjogQmFzZVNlc3Npb25SZXRyaWV2ZXIsIHByaXZhdGUgcGVyc2lzdG9yOiBCYXNlUHJlZmVyZW5jZXNQZXJzaXN0b3IsIEBPcHRpb25hbCgpIEBJbmplY3QoUFJFRl9GVUxMX1JFVFJJRVZFX0FUX1NUQVJUKSBwcml2YXRlIFBSRUZfRlVMTF9SRVRSSUVWRV9BVF9TVEFSVDogYm9vbGVhbikgeyB9XG5cbiAgLyoqXG4gICAqIFJpcHVsaXNjZSBsZSBpbXBvc3RhemlvbmkgbG9jYWxpIGUgbGUgaW1wb3N0YXppb25pIHNhbHZhdGUgZGFsIHBlcnNpc3RvclxuICAgKi9cbiAgY2xlYXIoKSB7XG4gICAgdGhpcy5Mb2NhbFByZWZlcmVuY2VzID0ge307XG4gICAgdGhpcy5wZXJzaXN0b3IuY2xlYXIodGhpcy5zZXNzaW9uSWQpO1xuICB9XG5cbiAgLyoqXG4gICAqIFNhbHZhIHVuIG9nZ2V0dG8gc2lhIG5lbGxhIGNhY2hlIGxvY2FsZSBjaGUgbmVsIHBlcnNpc3RvclxuICAgKiBcbiAgICogQHBhcmFtIHtzdHJpbmd9IGtleSBDaGlhdmUgZGkgcGVyc2lzdGVuemFcbiAgICogQHBhcmFtIHtUfSBpdGVtIE9nZ2V0dG8gZGEgc2FsdmFyZVxuICAgKi9cbiAgc3RvcmU8VD4oa2V5OiBzdHJpbmcsIGl0ZW06IFQpIHtcbiAgICB0aGlzLkxvY2FsUHJlZmVyZW5jZXNba2V5XSA9IGl0ZW07XG4gICAgdGhpcy5wZXJzaXN0b3IucGVyc2lzdCh0aGlzLnNlc3Npb25JZCwga2V5LCBpdGVtKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBSZWN1cGVyYSB1biBvZ2dldHRvIGluIGJhc2UgYSB1bmEgY2hpYXZlLiBQZXJtZXR0ZSBkaSBhY2NlZGVyZSBhbGxhIGNvcGlhIGxvY2FsZSBvIGFsbGEgY29waWEgcGVyc2lzdGl0YSBlZCBpbiBjYXNvIGZvc3NlIGlsIHByaW1vIGNhcmljYW1lbnRvIGUgbCdpbXBvc3RhemlvbmUgXG4gICAqICoqcmV0cmlldmVBbGxBdFN0YXJ0KiogZGVsbGEgY2xhc3NlIGRpIGNvbmZpZ3VyYXppb25lIGZvc3NlICoqdHJ1ZSoqIHNpIG9jY3VwYSBhbmNoZSBkZWxsYSBwcmltYSB2YWxvcml6emF6aW9uZSBkZWxsYSBjYWNoZSBsb2NhbGVcbiAgICogXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBrZXkgQ2hpYXZlIGRlbCB2YWxvcmUgZGEgcmVjdXBlcmFyZVxuICAgKiBAcGFyYW0ge2Jvb2xlYW59IGNhY2hlQnVzdCBJbmRpY2Egc2UgaWdub3JhcmUgaWwgdmFsb3JlIGRlbGxhIGNhY2hlIGxvY2FsZSBlIHJlY3VwZXJhcmUgbCdvZ2dldHRvIGRhbGxvIHN0b3JlIHBlcnNpc3RpdG8sIFxuICAgKiBpbiBjYXNvIGZvc3NlIHN0YXRvIG1vZGlmaWNhdG8gZnVvcmkgc2lzdGVtYSBvIGRhIHVuIGFsdHJvIHNpc3RlbWFcbiAgICogXG4gICAqIEByZXR1cm5zIHtUfSBPZ2dldHRvIHJpY2hpZXN0b1xuICAgKi9cbiAgcmV0cmlldmU8VD4oa2V5OiBzdHJpbmcsIGNhY2hlQnVzdDogYm9vbGVhbiA9IGZhbHNlKTogVCB7XG4gICAgLy8gU2Ugw6ggaWwgcHJpbW8gcmV0cmlldmUgZSBzb25vIGNvbmZpZ3VyYXRvIHBlciByZWN1cGVyYXJlIHR1dHRhIGxhIGNvbmZpZ3VyYXppb25lIGFsbCdpbml6aW9cbiAgICAvLyBlc2VndW8sIGFsdHJpbWVudGkgcHJlbmRvIGwnb2dnZXR0byBzZSBsbyB0cm92byBlIHNlIG5vbiBsbyB0cm92byBsbyBjYXJpY28gcHJpbWEgaW4gY2FjaGVcbiAgICBpZiAodGhpcy5GaXJzdFJldHJpZXZlKSB7XG4gICAgICBpZiAodGhpcy5QUkVGX0ZVTExfUkVUUklFVkVfQVRfU1RBUlQpXG4gICAgICAgIHRoaXMuTG9jYWxQcmVmZXJlbmNlcyA9IHRoaXMucGVyc2lzdG9yLnJlY292ZXJBbGwodGhpcy5zZXNzaW9uSWQpO1xuICAgICAgdGhpcy5GaXJzdFJldHJpZXZlID0gZmFsc2U7XG4gICAgfVxuXG4gICAgaWYgKHRoaXMuTG9jYWxQcmVmZXJlbmNlc1trZXldICYmICFjYWNoZUJ1c3QpXG4gICAgICByZXR1cm4gPFQ+dGhpcy5Mb2NhbFByZWZlcmVuY2VzW2tleV07XG4gICAgZWxzZSB7XG4gICAgICB2YXIgb2JqID0gdGhpcy5wZXJzaXN0b3IucmVjb3ZlcjxUPih0aGlzLnNlc3Npb25JZCwga2V5KTtcbiAgICAgIGlmICghb2JqKVxuICAgICAgICByZXR1cm4gbnVsbDtcbiAgICAgIHRoaXMuTG9jYWxQcmVmZXJlbmNlc1trZXldID0gb2JqO1xuICAgICAgcmV0dXJuIG9iajtcbiAgICB9XG4gIH1cbn0iXX0=
90
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJlZmVyZW5jZXMuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3ByZWZlcmVuY2VzL3NyYy9saWIvcHJlZmVyZW5jZXMuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxVQUFVO0FBQ1YsT0FBTyxFQUFFLE1BQU0sRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzdELE9BQU8sRUFBYyxFQUFFLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDdEMsT0FBTyxFQUFFLFNBQVMsRUFBRSxHQUFHLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUVoRCxVQUFVO0FBQ1YsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDckYsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sVUFBVSxDQUFDO0FBRXZEOztHQUVHO0FBRUgsTUFBTSxPQUFPLGtCQUFrQjtJQWE3Qjs7OztPQUlHO0lBQ0gsWUFBb0IsU0FBbUMsRUFBMkQsMkJBQW9DO1FBQWxJLGNBQVMsR0FBVCxTQUFTLENBQTBCO1FBQTJELGdDQUEyQixHQUEzQiwyQkFBMkIsQ0FBUztRQWhCdEo7OztXQUdHO1FBQ0ssa0JBQWEsR0FBWSxJQUFJLENBQUM7UUFFdEM7O1dBRUc7UUFDSyxxQkFBZ0IsR0FBNkIsRUFBRSxDQUFDO0lBT2tHLENBQUM7SUFFM0o7O09BRUc7SUFDSCxLQUFLO1FBQ0gsSUFBSSxDQUFDLGdCQUFnQixHQUFHLEVBQUUsQ0FBQztRQUMzQixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDaEMsQ0FBQztJQUVEOzs7OztPQUtHO0lBQ0gsS0FBSyxDQUFJLEdBQVcsRUFBRSxJQUFPO1FBQzNCLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxHQUFHLENBQUMsR0FBRyxJQUFJLENBQUM7UUFDbEMsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDM0MsQ0FBQztJQUVEOzs7Ozs7Ozs7T0FTRztJQUNILFFBQVEsQ0FBSSxHQUFXLEVBQUUsWUFBcUIsS0FBSztRQUNqRCw4RkFBOEY7UUFDOUYsNkZBQTZGO1FBQzdGLElBQUksSUFBSSxDQUFDLGFBQWEsRUFBRTtZQUN0QixJQUFJLElBQUksQ0FBQywyQkFBMkI7Z0JBQ2xDLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQyxVQUFVLEVBQUUsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxFQUFFO29CQUN0RCxJQUFJLENBQUMsZ0JBQWdCLEdBQUcsR0FBRyxDQUFDO29CQUM1QixJQUFJLENBQUMsYUFBYSxHQUFHLEtBQUssQ0FBQztvQkFDM0IsT0FBTyxJQUFJLENBQUMsZ0JBQWdCLENBQUksR0FBRyxFQUFFLFNBQVMsQ0FBQyxDQUFDO2dCQUNsRCxDQUFDLENBQUMsQ0FBQyxDQUFDO1NBQ1A7UUFFRCxPQUFPLElBQUksQ0FBQyxnQkFBZ0IsQ0FBSSxHQUFHLEVBQUUsU0FBUyxDQUFDLENBQUM7SUFDbEQsQ0FBQztJQUVELGdDQUFnQztJQUN4QixnQkFBZ0IsQ0FBSSxHQUFXLEVBQUUsWUFBcUIsS0FBSztRQUNqRSxJQUFJLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLFNBQVM7WUFDMUMsT0FBTyxFQUFFLENBQUksSUFBSSxDQUFDLGdCQUFnQixDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7YUFDdEM7WUFDSCxJQUFJLEdBQUcsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBSSxHQUFHLENBQUMsQ0FBQztZQUN6QyxJQUFJLENBQUMsR0FBRztnQkFDTixPQUFPLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUNsQixHQUFHLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRSxHQUFHLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxHQUFHLENBQUMsR0FBRyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFBO1lBQzdELE9BQU8sR0FBRyxDQUFDO1NBQ1o7SUFDSCxDQUFDOzs7WUE1RUYsVUFBVTs7O1lBTkYsd0JBQXdCOzBDQXlCMkIsUUFBUSxZQUFJLE1BQU0sU0FBQywyQkFBMkIiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBBbmd1bGFyXHJcbmltcG9ydCB7IEluamVjdCwgSW5qZWN0YWJsZSwgT3B0aW9uYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgT2JzZXJ2YWJsZSwgb2YgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgY29uY2F0TWFwLCB0YXAgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XHJcblxyXG4vLyBNb2RlbGxpXHJcbmltcG9ydCB7IEJhc2VQcmVmZXJlbmNlc1BlcnNpc3RvciB9IGZyb20gJy4vcGVyc2lzdG9yL2Jhc2UvQmFzZVByZWZlcmVuY2VzUGVyc2lzdG9yJztcclxuaW1wb3J0IHsgUFJFRl9GVUxMX1JFVFJJRVZFX0FUX1NUQVJUIH0gZnJvbSAnLi90b2tlbnMnO1xyXG5cclxuLyoqXHJcbiAqIFNlcnZpY2UgY2hlIHNpIG9jY3VwYSBkaSBzYWx2YXJlIGUgcmVjdXBlcmFyZSBsZSBwcmVmZXJlbnplIHV0ZW50ZSByaXNwZXR0byBhbGxlIGNoaWF2aSBzYWx2YXRlXHJcbiAqL1xyXG5ASW5qZWN0YWJsZSgpXHJcbmV4cG9ydCBjbGFzcyBQcmVmZXJlbmNlc1NlcnZpY2Uge1xyXG5cclxuICAvKipcclxuICAgKiBJbmRpY2Egc2Ugw6ggbGEgcHJpbWEgdm9sdGEgY2hlIHZpZW5lIGVmZmV0dHVhdGEgdW4nb3BlcmF6aW9uZSBkaSByZXRyaWV2ZS4gQXBwZW5hIGVmZmV0dHVhdGEgcXVlc3RhIHZhcmlhYmlsZSB2aWVuZSBpbXBvc3RhdGEgYSAqKmZhbHNlKiogZSAoaW4gcXVhbnRvIHNpbmdsZXRvbixcclxuICAgKiBzZSBjb25maWd1cmF0byBiZW5lKSBtYWkgcGnDuSBtb2RpZmljYXRhXHJcbiAgICovXHJcbiAgcHJpdmF0ZSBGaXJzdFJldHJpZXZlOiBib29sZWFuID0gdHJ1ZTtcclxuXHJcbiAgLyoqXHJcbiAgICogU3RvcmUgaW4gbWVtb3JpYSBkZWxsZSBwcmVmZXJlbnplIGxvY2FsaSBjaGUgc2Fyw6AgcGVyc2lzdGl0byBwZXIgbWV6em8gZGVsbGEgY2xhc3NlIGNoZSBmYSBsZSB2ZWNpIGRlbCAqKkJhc2VQcmVmZXJlbmNlc1BlcnNpc3RvcioqXHJcbiAgICovXHJcbiAgcHJpdmF0ZSBMb2NhbFByZWZlcmVuY2VzOiB7IFtpbmRleDogc3RyaW5nXTogYW55IH0gPSB7fTtcclxuXHJcbiAgLyoqXHJcbiAgICogQ29zdHJ1dHRvcmVcclxuICAgKiBcclxuICAgKiBAaWdub3JlXHJcbiAgICovXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBwZXJzaXN0b3I6IEJhc2VQcmVmZXJlbmNlc1BlcnNpc3RvciwgQE9wdGlvbmFsKCkgQEluamVjdChQUkVGX0ZVTExfUkVUUklFVkVfQVRfU1RBUlQpIHByaXZhdGUgUFJFRl9GVUxMX1JFVFJJRVZFX0FUX1NUQVJUOiBib29sZWFuKSB7IH1cclxuXHJcbiAgLyoqXHJcbiAgICogUmlwdWxpc2NlIGxlIGltcG9zdGF6aW9uaSBsb2NhbGkgZSBsZSBpbXBvc3Rhemlvbmkgc2FsdmF0ZSBkYWwgcGVyc2lzdG9yXHJcbiAgICovXHJcbiAgY2xlYXIoKTogT2JzZXJ2YWJsZTxib29sZWFuPiB7XHJcbiAgICB0aGlzLkxvY2FsUHJlZmVyZW5jZXMgPSB7fTtcclxuICAgIHJldHVybiB0aGlzLnBlcnNpc3Rvci5jbGVhcigpO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogU2FsdmEgdW4gb2dnZXR0byBzaWEgbmVsbGEgY2FjaGUgbG9jYWxlIGNoZSBuZWwgcGVyc2lzdG9yXHJcbiAgICogXHJcbiAgICogQHBhcmFtIHtzdHJpbmd9IGtleSBDaGlhdmUgZGkgcGVyc2lzdGVuemFcclxuICAgKiBAcGFyYW0ge1R9IGl0ZW0gT2dnZXR0byBkYSBzYWx2YXJlXHJcbiAgICovXHJcbiAgc3RvcmU8VD4oa2V5OiBzdHJpbmcsIGl0ZW06IFQpOiBPYnNlcnZhYmxlPGJvb2xlYW4+IHtcclxuICAgIHRoaXMuTG9jYWxQcmVmZXJlbmNlc1trZXldID0gaXRlbTtcclxuICAgIHJldHVybiB0aGlzLnBlcnNpc3Rvci5wZXJzaXN0KGtleSwgaXRlbSk7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBSZWN1cGVyYSB1biBvZ2dldHRvIGluIGJhc2UgYSB1bmEgY2hpYXZlLiBQZXJtZXR0ZSBkaSBhY2NlZGVyZSBhbGxhIGNvcGlhIGxvY2FsZSBvIGFsbGEgY29waWEgcGVyc2lzdGl0YSBlZCBpbiBjYXNvIGZvc3NlIGlsIHByaW1vIGNhcmljYW1lbnRvIGUgbCdpbXBvc3RhemlvbmUgXHJcbiAgICogKipyZXRyaWV2ZUFsbEF0U3RhcnQqKiBkZWxsYSBjbGFzc2UgZGkgY29uZmlndXJhemlvbmUgZm9zc2UgKip0cnVlKiogc2kgb2NjdXBhIGFuY2hlIGRlbGxhIHByaW1hIHZhbG9yaXp6YXppb25lIGRlbGxhIGNhY2hlIGxvY2FsZVxyXG4gICAqIFxyXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBrZXkgQ2hpYXZlIGRlbCB2YWxvcmUgZGEgcmVjdXBlcmFyZVxyXG4gICAqIEBwYXJhbSB7Ym9vbGVhbn0gY2FjaGVCdXN0IEluZGljYSBzZSBpZ25vcmFyZSBpbCB2YWxvcmUgZGVsbGEgY2FjaGUgbG9jYWxlIGUgcmVjdXBlcmFyZSBsJ29nZ2V0dG8gZGFsbG8gc3RvcmUgcGVyc2lzdGl0bywgXHJcbiAgICogaW4gY2FzbyBmb3NzZSBzdGF0byBtb2RpZmljYXRvIGZ1b3JpIHNpc3RlbWEgbyBkYSB1biBhbHRybyBzaXN0ZW1hXHJcbiAgICogXHJcbiAgICogQHJldHVybnMge1R9IE9nZ2V0dG8gcmljaGllc3RvXHJcbiAgICovXHJcbiAgcmV0cmlldmU8VD4oa2V5OiBzdHJpbmcsIGNhY2hlQnVzdDogYm9vbGVhbiA9IGZhbHNlKTogT2JzZXJ2YWJsZTxUPiB7XHJcbiAgICAvLyBTZSDDqCBpbCBwcmltbyByZXRyaWV2ZSBlIHNvbm8gY29uZmlndXJhdG8gcGVyIHJlY3VwZXJhcmUgdHV0dGEgbGEgY29uZmlndXJhemlvbmUgYWxsJ2luaXppb1xyXG4gICAgLy8gZXNlZ3VvLCBhbHRyaW1lbnRpIHByZW5kbyBsJ29nZ2V0dG8gc2UgbG8gdHJvdm8gZSBzZSBub24gbG8gdHJvdm8gbG8gY2FyaWNvIHByaW1hIGluIGNhY2hlXHJcbiAgICBpZiAodGhpcy5GaXJzdFJldHJpZXZlKSB7XHJcbiAgICAgIGlmICh0aGlzLlBSRUZfRlVMTF9SRVRSSUVWRV9BVF9TVEFSVClcclxuICAgICAgICByZXR1cm4gdGhpcy5wZXJzaXN0b3IucmVjb3ZlckFsbCgpLnBpcGUoY29uY2F0TWFwKHJlcyA9PiB7XHJcbiAgICAgICAgICB0aGlzLkxvY2FsUHJlZmVyZW5jZXMgPSByZXM7XHJcbiAgICAgICAgICB0aGlzLkZpcnN0UmV0cmlldmUgPSBmYWxzZTtcclxuICAgICAgICAgIHJldHVybiB0aGlzLmludGVybmFsUmV0cmlldmU8VD4oa2V5LCBjYWNoZUJ1c3QpO1xyXG4gICAgICAgIH0pKTtcclxuICAgIH1cclxuXHJcbiAgICByZXR1cm4gdGhpcy5pbnRlcm5hbFJldHJpZXZlPFQ+KGtleSwgY2FjaGVCdXN0KTtcclxuICB9XHJcblxyXG4gIC8qKiBAaWdub3JlIFZlZGkgKipyZXRyaWV2ZSoqICovXHJcbiAgcHJpdmF0ZSBpbnRlcm5hbFJldHJpZXZlPFQ+KGtleTogc3RyaW5nLCBjYWNoZUJ1c3Q6IGJvb2xlYW4gPSBmYWxzZSk6IE9ic2VydmFibGU8VD4ge1xyXG4gICAgaWYgKHRoaXMuTG9jYWxQcmVmZXJlbmNlc1trZXldICYmICFjYWNoZUJ1c3QpXHJcbiAgICAgIHJldHVybiBvZig8VD50aGlzLkxvY2FsUHJlZmVyZW5jZXNba2V5XSk7XHJcbiAgICBlbHNlIHtcclxuICAgICAgdmFyIG9iaiA9IHRoaXMucGVyc2lzdG9yLnJlY292ZXI8VD4oa2V5KTtcclxuICAgICAgaWYgKCFvYmopXHJcbiAgICAgICAgcmV0dXJuIG9mKG51bGwpO1xyXG4gICAgICBvYmoucGlwZSh0YXAoaXRlbSA9PiB7IHRoaXMuTG9jYWxQcmVmZXJlbmNlc1trZXldID0gaXRlbTsgfSkpXHJcbiAgICAgIHJldHVybiBvYmo7XHJcbiAgICB9XHJcbiAgfVxyXG59Il19
@@ -1,38 +1,38 @@
1
1
  import { InjectionToken, Injectable, Optional, Inject, NgModule } from '@angular/core';
2
+ import { forkJoin, of } from 'rxjs';
3
+ import { map, concatMap, 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(sessionId, dictionary) {
18
+ persistAll(dictionary) {
19
+ let observables = [];
14
20
  for (let key in dictionary)
15
- this.persist(sessionId, key, dictionary[key]);
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(sessionId, key) {
26
- return sessionId + "§" + key + "§";
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(sessionRetriever, persistor, PREF_FULL_RETRIEVE_AT_START) {
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(this.sessionId);
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(this.sessionId, key, item);
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,23 @@ 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(this.sessionId);
107
- this.FirstRetrieve = false;
98
+ return this.persistor.recoverAll().pipe(concatMap(res => {
99
+ this.LocalPreferences = res;
100
+ this.FirstRetrieve = false;
101
+ return this.internalRetrieve(key, cacheBust);
102
+ }));
108
103
  }
104
+ return this.internalRetrieve(key, cacheBust);
105
+ }
106
+ /** @ignore Vedi **retrieve** */
107
+ internalRetrieve(key, cacheBust = false) {
109
108
  if (this.LocalPreferences[key] && !cacheBust)
110
- return this.LocalPreferences[key];
109
+ return of(this.LocalPreferences[key]);
111
110
  else {
112
- var obj = this.persistor.recover(this.sessionId, key);
111
+ var obj = this.persistor.recover(key);
113
112
  if (!obj)
114
- return null;
115
- this.LocalPreferences[key] = obj;
113
+ return of(null);
114
+ obj.pipe(tap(item => { this.LocalPreferences[key] = item; }));
116
115
  return obj;
117
116
  }
118
117
  }
@@ -121,7 +120,6 @@ PreferencesService.decorators = [
121
120
  { type: Injectable }
122
121
  ];
123
122
  PreferencesService.ctorParameters = () => [
124
- { type: BaseSessionRetriever },
125
123
  { type: BasePreferencesPersistor },
126
124
  { type: Boolean, decorators: [{ type: Optional }, { type: Inject, args: [PREF_FULL_RETRIEVE_AT_START,] }] }
127
125
  ];
@@ -132,69 +130,51 @@ PreferencesService.ctorParameters = () => [
132
130
  class PreferencesModuleConfig {
133
131
  }
134
132
 
135
- // Angular
136
133
  /**
137
- * Implementazione di default per la classe **BasePreferencesPersistor**
134
+ * Classe astratta che si occupa di recuperare l'Id sessione univoco per applicazione ed utente collegato
138
135
  */
136
+ class BaseSessionRetriever {
137
+ }
138
+
139
+ // Angular
140
+ /** Implementazione di default per la classe **BasePreferencesPersistor** */
139
141
  class LocalStoragePersistor extends BasePreferencesPersistor {
140
- /**
141
- * Costruttore
142
- *
143
- * @ignore
144
- */
145
- constructor() { super(); }
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));
142
+ /** @ignore Costruttore */
143
+ constructor(session) { super(session); }
144
+ /** @ignore Vedi classe base */
145
+ persist(key, item) {
146
+ localStorage.setItem(this.getKey(key), JSON.stringify(item));
147
+ return of(true).pipe(first());
155
148
  }
156
- /**
157
- * Recupera, per una sessione, il valore assegnato ad una chiave
158
- *
159
- * @param {string} sessionId ID della sessione
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)));
149
+ /** @ignore Vedi classe base */
150
+ recover(key) {
151
+ var ret = JSON.parse(localStorage.getItem(this.getKey(key)));
152
+ return of(ret).pipe(first());
166
153
  }
167
- /**
168
- * Per una sessione recupera tutte le coppie Chiave - Valore salvate
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) {
154
+ /** @ignore Vedi classe base */
155
+ recoverAll() {
175
156
  var ret = {};
176
157
  for (var k in localStorage) {
177
- if (k.includes("§") && k.startsWith(sessionId))
158
+ if (k.includes("§") && k.startsWith(this.session.getSessionKey()))
178
159
  ret[k.match(/§(.*)§/)[1]] = JSON.parse(localStorage.getItem(k));
179
160
  }
180
- return ret;
161
+ return of(ret).pipe(first());
181
162
  }
182
- /**
183
- * Ripulisce le preference salvate relative ad una sessione
184
- *
185
- * @param {string} sessionId ID della sessione
186
- */
187
- clear(sessionId) {
163
+ /** @ignore Vedi classe base */
164
+ clear() {
188
165
  for (var k in localStorage) {
189
- if (k.includes("§") && k.startsWith(sessionId))
166
+ if (k.includes("§") && k.startsWith(this.session.getSessionKey()))
190
167
  localStorage.removeItem(k);
191
168
  }
169
+ return of(true).pipe(first());
192
170
  }
193
171
  }
194
172
  LocalStoragePersistor.decorators = [
195
173
  { type: Injectable }
196
174
  ];
197
- LocalStoragePersistor.ctorParameters = () => [];
175
+ LocalStoragePersistor.ctorParameters = () => [
176
+ { type: BaseSessionRetriever }
177
+ ];
198
178
 
199
179
  /**
200
180
  * 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]: any }>} Dizionario con tutte le preference salvate per la sessione\r\n */\r\n public abstract recoverAll(): Observable<{ [index: string]: any }>;\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 { concatMap, 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 return this.persistor.recoverAll().pipe(concatMap(res => {\r\n this.LocalPreferences = res;\r\n this.FirstRetrieve = false;\r\n return this.internalRetrieve<T>(key, cacheBust);\r\n }));\r\n }\r\n\r\n return this.internalRetrieve<T>(key, cacheBust);\r\n }\r\n\r\n /** @ignore Vedi **retrieve** */\r\n private internalRetrieve<T>(key: string, cacheBust: boolean = false): Observable<T> {\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]: any; }> {\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>(sessionId: string, key: string, item: T): any;
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>(sessionId: string, key?: string): 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
- * @param {string} sessionId ID della sessione
26
- *
27
- * @returns {{ [index: string]: string }} Dizionario con tutte le preference salvate per la sessione **sessionId**
28
- */
29
- abstract recoverAll(sessionId: string): {
30
- [index: string]: string;
31
- };
32
- /**
33
- * Ripulisce le preference salvate relative ad una sessione
34
- *
35
- * @param {string} sessionId ID della sessione
27
+ * @returns {Observable<{ [index: string]: any }>} Dizionario con tutte le preference salvate per la sessione
36
28
  */
37
- abstract clear(sessionId: string): any;
29
+ abstract recoverAll(): Observable<{
30
+ [index: 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(sessionId: string, dictionary: {
39
+ persistAll(dictionary: {
45
40
  [key: string]: string;
46
- }): void;
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(sessionId: string, key: string): string;
49
+ protected getKey(key: string): string;
56
50
  }