@christianriedl/utils 1.0.3 → 1.0.7
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/README.md +3 -0
- package/dist/utils/src/index.d.ts +4 -3
- package/dist/utils/src/index.js +4 -3
- package/dist/utils/src/index.js.map +1 -1
- package/dist/utils/src/reactiveStorage.d.ts +18 -0
- package/dist/utils/src/reactiveStorage.js +49 -0
- package/dist/utils/src/reactiveStorage.js.map +1 -0
- package/package.json +8 -1
package/README.md
ADDED
|
@@ -1,3 +1,4 @@
|
|
|
1
|
-
export
|
|
2
|
-
export
|
|
3
|
-
export
|
|
1
|
+
export * from './helper';
|
|
2
|
+
export * from './localStorage';
|
|
3
|
+
export * from './registerServiceWorker';
|
|
4
|
+
export * from './reactiveStorage';
|
package/dist/utils/src/index.js
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
export
|
|
2
|
-
export
|
|
3
|
-
export
|
|
1
|
+
export * from './helper';
|
|
2
|
+
export * from './localStorage';
|
|
3
|
+
export * from './registerServiceWorker';
|
|
4
|
+
export * from './reactiveStorage';
|
|
4
5
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/index.ts"],"names":[],"mappings":"AAAA,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,UAAU,CAAC;AACzB,cAAc,gBAAgB,CAAC;AAC/B,cAAc,yBAAyB,CAAC;AACxC,cAAc,mBAAmB,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { ILocalStorage } from './iLocalStorage';
|
|
2
|
+
declare type Dictionary<T> = {
|
|
3
|
+
[key: string]: T;
|
|
4
|
+
};
|
|
5
|
+
export declare class ReactiveStorageItem {
|
|
6
|
+
storage: ILocalStorage;
|
|
7
|
+
name: string;
|
|
8
|
+
value: import("vue").Ref<string | number | boolean>;
|
|
9
|
+
constructor(localStorage: ILocalStorage, name: string, val: string | number | boolean);
|
|
10
|
+
}
|
|
11
|
+
export declare class ReactiveStorage {
|
|
12
|
+
storage: ILocalStorage;
|
|
13
|
+
items: Dictionary<ReactiveStorageItem>;
|
|
14
|
+
constructor(localStorage: ILocalStorage);
|
|
15
|
+
setItem(name: string, val: string | number | boolean): void;
|
|
16
|
+
getItem(name: string): string | number | boolean | undefined;
|
|
17
|
+
}
|
|
18
|
+
export {};
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { ref, watchEffect } from 'vue';
|
|
2
|
+
export class ReactiveStorageItem {
|
|
3
|
+
storage;
|
|
4
|
+
name;
|
|
5
|
+
value = ref(null);
|
|
6
|
+
constructor(localStorage, name, val) {
|
|
7
|
+
this.storage = localStorage;
|
|
8
|
+
this.name = name;
|
|
9
|
+
const existingValue = localStorage.getItem(name);
|
|
10
|
+
if (existingValue == null) {
|
|
11
|
+
this.value.value = val;
|
|
12
|
+
localStorage.setItem(name, val);
|
|
13
|
+
}
|
|
14
|
+
else {
|
|
15
|
+
if (typeof val === 'string')
|
|
16
|
+
this.value.value = localStorage.getItemString(name);
|
|
17
|
+
if (typeof val === 'number')
|
|
18
|
+
this.value.value = localStorage.getItemNumber(name);
|
|
19
|
+
if (typeof val === 'boolean')
|
|
20
|
+
this.value.value = localStorage.getItemBoolean(name);
|
|
21
|
+
}
|
|
22
|
+
watchEffect(() => {
|
|
23
|
+
this.storage.setItem(this.name, this.value.value);
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
export class ReactiveStorage {
|
|
28
|
+
storage;
|
|
29
|
+
items = {};
|
|
30
|
+
constructor(localStorage) {
|
|
31
|
+
this.storage = localStorage;
|
|
32
|
+
}
|
|
33
|
+
setItem(name, val) {
|
|
34
|
+
let item = this.items[name];
|
|
35
|
+
if (item) {
|
|
36
|
+
item.value.value = val;
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
item = new ReactiveStorageItem(this.storage, name, val);
|
|
40
|
+
this.items[name] = item;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
getItem(name) {
|
|
44
|
+
let item = this.items[name];
|
|
45
|
+
if (item)
|
|
46
|
+
return item.value.value;
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
//# sourceMappingURL=reactiveStorage.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reactiveStorage.js","sourceRoot":"","sources":["../../../src/reactiveStorage.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,GAAG,EAAE,WAAW,EAAE,MAAM,KAAK,CAAC;AAIvC,MAAM,OAAO,mBAAmB;IAC5B,OAAO,CAAgB;IACvB,IAAI,CAAS;IACb,KAAK,GAAG,GAAG,CAA4B,IAAI,CAAC,CAAC;IAE7C,YAAY,YAA2B,EAAE,IAAY,EAAE,GAA8B;QACjF,IAAI,CAAC,OAAO,GAAG,YAAY,CAAC;QAC5B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,MAAM,aAAa,GAAG,YAAY,CAAC,OAAO,CAAE,IAAI,CAAC,CAAC;QAClD,IAAI,aAAa,IAAI,IAAI,EAAE;YACvB,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,CAAC;YACvB,YAAY,CAAC,OAAO,CAAE,IAAI,EAAE,GAAG,CAAC,CAAC;SACpC;aACI;YACD,IAAI,OAAO,GAAG,KAAK,QAAQ;gBACvB,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,YAAY,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;YACxD,IAAI,OAAO,GAAG,KAAK,QAAQ;gBACvB,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,YAAY,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;YACxD,IAAI,OAAO,GAAG,KAAK,SAAS;gBACxB,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,YAAY,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;SAC5D;QACD,WAAW,CAAE,GAAG,EAAE;YACd,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QACtD,CAAC,CAAC,CAAC;IACP,CAAC;CACJ;AAED,MAAM,OAAO,eAAe;IACxB,OAAO,CAAgB;IACvB,KAAK,GAAoC,EAAE,CAAC;IAE5C,YAAY,YAA2B;QACnC,IAAI,CAAC,OAAO,GAAG,YAAY,CAAC;IAChC,CAAC;IAED,OAAO,CAAE,IAAY,EAAE,GAA8B;QACjD,IAAI,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAC5B,IAAI,IAAI,EAAE;YACN,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,CAAC;SAC1B;aACI;YACD,IAAI,GAAG,IAAI,mBAAmB,CAAE,IAAI,CAAC,OAAO,EAAE,IAAI,EAAE,GAAG,CAAC,CAAC;YACzD,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;SAC3B;IACL,CAAC;IACD,OAAO,CAAE,IAAY;QACjB,IAAI,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAC5B,IAAI,IAAI;YACJ,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC;IAChC,CAAC;CACJ"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@christianriedl/utils",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.7",
|
|
4
4
|
"description": "",
|
|
5
5
|
|
|
6
6
|
"main": "dist/utils/src/index.js",
|
|
@@ -16,7 +16,14 @@
|
|
|
16
16
|
},
|
|
17
17
|
"author": "Christian Riedl",
|
|
18
18
|
"license": "ISC",
|
|
19
|
+
"dependencies": {
|
|
20
|
+
"vue": "^3.2.13"
|
|
21
|
+
},
|
|
22
|
+
"peerDependencies": {
|
|
23
|
+
"vue": "^3.2.13"
|
|
24
|
+
},
|
|
19
25
|
"devDependencies": {
|
|
26
|
+
"@vue/cli-plugin-typescript": "~5.0.0-rc.2",
|
|
20
27
|
"typescript": "^4.5.4",
|
|
21
28
|
"@types/node": "^17.0.8"
|
|
22
29
|
}
|