react-state-bucket 1.2.16 → 1.2.18

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.
@@ -1,3 +1,6 @@
1
+ "use client";
2
+ 'use strict';
3
+
1
4
  function setCookie(key, value, days = 7) {
2
5
  const expires = new Date(Date.now() + days * 864e5).toUTCString();
3
6
  document.cookie =
@@ -13,4 +16,8 @@ function getCookie(key) {
13
16
  }
14
17
  }
15
18
  return null;
16
- }export{getCookie,setCookie};//# sourceMappingURL=Cookie.mjs.map
19
+ }
20
+
21
+ exports.getCookie = getCookie;
22
+ exports.setCookie = setCookie;
23
+ //# sourceMappingURL=Cookie.cjs.map
package/Cookie.cjs.map ADDED
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Cookie.cjs","sources":["../src/Cookie.ts"],"sourcesContent":["\"use client\"\r\nexport function setCookie(\r\n key: string,\r\n value: string,\r\n days = 7\r\n) {\r\n const expires = new Date(Date.now() + days * 864e5).toUTCString();\r\n document.cookie =\r\n `${encodeURIComponent(key)}=${encodeURIComponent(value)}; ` +\r\n `expires=${expires}; path=/; SameSite=Lax`;\r\n}\r\n\r\nexport function getCookie(key: string): string | null {\r\n const name = encodeURIComponent(key) + \"=\";\r\n const parts = document.cookie.split(\"; \");\r\n\r\n for (const part of parts) {\r\n if (part.startsWith(name)) {\r\n return decodeURIComponent(part.slice(name.length));\r\n }\r\n }\r\n\r\n return null;\r\n}"],"names":[],"mappings":";;;AACM;AAKH;AACA;;;AAGH;AAEM;;;AAIH;AACG;;;;AAKH;AACH;;;"}
package/Cookie.js CHANGED
@@ -1,4 +1,5 @@
1
- 'use strict';Object.defineProperty(exports,'__esModule',{value:true});function setCookie(key, value, days = 7) {
1
+ "use client";
2
+ function setCookie(key, value, days = 7) {
2
3
  const expires = new Date(Date.now() + days * 864e5).toUTCString();
3
4
  document.cookie =
4
5
  `${encodeURIComponent(key)}=${encodeURIComponent(value)}; ` +
@@ -13,4 +14,7 @@ function getCookie(key) {
13
14
  }
14
15
  }
15
16
  return null;
16
- }exports.getCookie=getCookie;exports.setCookie=setCookie;//# sourceMappingURL=Cookie.js.map
17
+ }
18
+
19
+ export { getCookie, setCookie };
20
+ //# sourceMappingURL=Cookie.js.map
package/Cookie.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"Cookie.js","sources":["../src/Cookie.ts"],"sourcesContent":["export function setCookie(\n key: string,\n value: string,\n days = 7\n) {\n const expires = new Date(Date.now() + days * 864e5).toUTCString();\n document.cookie =\n `${encodeURIComponent(key)}=${encodeURIComponent(value)}; ` +\n `expires=${expires}; path=/; SameSite=Lax`;\n}\n\nexport function getCookie(key: string): string | null {\n const name = encodeURIComponent(key) + \"=\";\n const parts = document.cookie.split(\"; \");\n\n for (const part of parts) {\n if (part.startsWith(name)) {\n return decodeURIComponent(part.slice(name.length));\n }\n }\n\n return null;\n}"],"names":[],"mappings":"sEAAM,SAAU,SAAS,CACtB,GAAW,EACX,KAAa,EACb,IAAI,GAAG,CAAC,EAAA;AAER,IAAA,MAAM,OAAO,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,GAAG,KAAK,CAAC,CAAC,WAAW,EAAE;AACjE,IAAA,QAAQ,CAAC,MAAM;QACZ,CAAA,EAAG,kBAAkB,CAAC,GAAG,CAAC,IAAI,kBAAkB,CAAC,KAAK,CAAC,CAAA,EAAA,CAAI;YAC3D,CAAA,QAAA,EAAW,OAAO,wBAAwB;AAChD;AAEM,SAAU,SAAS,CAAC,GAAW,EAAA;IAClC,MAAM,IAAI,GAAG,kBAAkB,CAAC,GAAG,CAAC,GAAG,GAAG;IAC1C,MAAM,KAAK,GAAG,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC;AAEzC,IAAA,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE;AACvB,QAAA,IAAI,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE;YACxB,OAAO,kBAAkB,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACrD;IACH;AAEA,IAAA,OAAO,IAAI;AACd"}
1
+ {"version":3,"file":"Cookie.js","sources":["../src/Cookie.ts"],"sourcesContent":["\"use client\"\r\nexport function setCookie(\r\n key: string,\r\n value: string,\r\n days = 7\r\n) {\r\n const expires = new Date(Date.now() + days * 864e5).toUTCString();\r\n document.cookie =\r\n `${encodeURIComponent(key)}=${encodeURIComponent(value)}; ` +\r\n `expires=${expires}; path=/; SameSite=Lax`;\r\n}\r\n\r\nexport function getCookie(key: string): string | null {\r\n const name = encodeURIComponent(key) + \"=\";\r\n const parts = document.cookie.split(\"; \");\r\n\r\n for (const part of parts) {\r\n if (part.startsWith(name)) {\r\n return decodeURIComponent(part.slice(name.length));\r\n }\r\n }\r\n\r\n return null;\r\n}"],"names":[],"mappings":";AACM;AAKH;AACA;;;AAGH;AAEM;;;AAIH;AACG;;;;AAKH;AACH;;"}
@@ -1,4 +1,8 @@
1
- import {getCookie}from'./Cookie.mjs';const Initial = (initial, data_key, option) => {
1
+ 'use strict';
2
+
3
+ var Cookie = require('./Cookie.cjs');
4
+
5
+ const Initial = (initial, data_key, option) => {
2
6
  let state = {};
3
7
  let data = "";
4
8
  if (typeof window !== 'undefined') {
@@ -11,7 +15,7 @@ import {getCookie}from'./Cookie.mjs';const Initial = (initial, data_key, option)
11
15
  data = decodeURIComponent(url.searchParams.get(data_key) || "");
12
16
  }
13
17
  else if (option.store === 'cookie') {
14
- data = getCookie(data_key);
18
+ data = Cookie.getCookie(data_key);
15
19
  }
16
20
  }
17
21
  if (data) {
@@ -34,4 +38,7 @@ import {getCookie}from'./Cookie.mjs';const Initial = (initial, data_key, option)
34
38
  }
35
39
  }
36
40
  return state;
37
- };export{Initial as default};//# sourceMappingURL=Initial.mjs.map
41
+ };
42
+
43
+ module.exports = Initial;
44
+ //# sourceMappingURL=Initial.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Initial.cjs","sources":["../src/Initial.ts"],"sourcesContent":["import { BucketOptions, InitialBucketData } from \".\";\r\nimport { getCookie } from \"./Cookie\";\r\n\r\nconst Initial = (initial: InitialBucketData, data_key: string, option: BucketOptions) => {\r\n let state = {} as Record<string, any>;\r\n let data: any = \"\"\r\n\r\n if (typeof window !== 'undefined') {\r\n if (option.store === 'session' || option.store === 'local') {\r\n let storage = option.store === \"session\" ? sessionStorage : localStorage\r\n data = storage.getItem(data_key)\r\n } else if (option.store === 'url') {\r\n let url = new URL(window.location.href)\r\n data = decodeURIComponent(url.searchParams.get(data_key) || \"\")\r\n } else if (option.store === 'cookie') {\r\n data = getCookie(data_key)\r\n }\r\n }\r\n\r\n if (data) {\r\n try {\r\n data = JSON.parse(data)\r\n } catch (error) {\r\n data = {}\r\n }\r\n } else {\r\n data = {}\r\n }\r\n\r\n for (let key in initial) {\r\n try {\r\n state[key] = initial[key].parse(data[key])\r\n } catch (error) {\r\n state[key] = data[key]\r\n }\r\n }\r\n\r\n return state;\r\n}\r\n\r\nexport default Initial;"],"names":["getCookie"],"mappings":";;;;AAGA,MAAM,OAAO,GAAG,CAAC,OAA0B,EAAE,QAAgB,EAAE,MAAqB,KAAI;IACrF,IAAI,KAAK,GAAG,EAAyB;IACrC,IAAI,IAAI,GAAQ,EAAE;AAElB,IAAA,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE;AAChC,QAAA,IAAI,MAAM,CAAC,KAAK,KAAK,SAAS,IAAI,MAAM,CAAC,KAAK,KAAK,OAAO,EAAE;AACzD,YAAA,IAAI,OAAO,GAAG,MAAM,CAAC,KAAK,KAAK,SAAS,GAAG,cAAc,GAAG,YAAY;AACxE,YAAA,IAAI,GAAG,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC;QACnC;AAAO,aAAA,IAAI,MAAM,CAAC,KAAK,KAAK,KAAK,EAAE;YAChC,IAAI,GAAG,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC;AACvC,YAAA,IAAI,GAAG,kBAAkB,CAAC,GAAG,CAAC,YAAY,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QAClE;AAAO,aAAA,IAAI,MAAM,CAAC,KAAK,KAAK,QAAQ,EAAE;AACnC,YAAA,IAAI,GAAGA,gBAAS,CAAC,QAAQ,CAAC;QAC7B;IACH;IAEA,IAAI,IAAI,EAAE;AACP,QAAA,IAAI;AACD,YAAA,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;QAC1B;QAAE,OAAO,KAAK,EAAE;YACb,IAAI,GAAG,EAAE;QACZ;IACH;SAAO;QACJ,IAAI,GAAG,EAAE;IACZ;AAEA,IAAA,KAAK,IAAI,GAAG,IAAI,OAAO,EAAE;AACtB,QAAA,IAAI;AACD,YAAA,KAAK,CAAC,GAAG,CAAC,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC7C;QAAE,OAAO,KAAK,EAAE;YACb,KAAK,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC;QACzB;IACH;AAEA,IAAA,OAAO,KAAK;AACf;;;;"}
package/Initial.js CHANGED
@@ -1,4 +1,6 @@
1
- 'use strict';Object.defineProperty(exports,'__esModule',{value:true});var Cookie=require('./Cookie.js');const Initial = (initial, data_key, option) => {
1
+ import { getCookie } from './Cookie.js';
2
+
3
+ const Initial = (initial, data_key, option) => {
2
4
  let state = {};
3
5
  let data = "";
4
6
  if (typeof window !== 'undefined') {
@@ -11,7 +13,7 @@
11
13
  data = decodeURIComponent(url.searchParams.get(data_key) || "");
12
14
  }
13
15
  else if (option.store === 'cookie') {
14
- data = Cookie.getCookie(data_key);
16
+ data = getCookie(data_key);
15
17
  }
16
18
  }
17
19
  if (data) {
@@ -34,4 +36,7 @@
34
36
  }
35
37
  }
36
38
  return state;
37
- };exports.default=Initial;//# sourceMappingURL=Initial.js.map
39
+ };
40
+
41
+ export { Initial as default };
42
+ //# sourceMappingURL=Initial.js.map
package/Initial.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"Initial.js","sources":["../src/Initial.ts"],"sourcesContent":["import { BucketOptions, InitialBucketData } from \".\";\nimport { getCookie } from \"./Cookie\";\n\nconst Initial = (initial: InitialBucketData, data_key: string, option: BucketOptions) => {\n let state = {} as Record<string, any>;\n let data: any = \"\"\n\n if (typeof window !== 'undefined') {\n if (option.store === 'session' || option.store === 'local') {\n let storage = option.store === \"session\" ? sessionStorage : localStorage\n data = storage.getItem(data_key)\n } else if (option.store === 'url') {\n let url = new URL(window.location.href)\n data = decodeURIComponent(url.searchParams.get(data_key) || \"\")\n } else if (option.store === 'cookie') {\n data = getCookie(data_key)\n }\n }\n\n if (data) {\n try {\n data = JSON.parse(data)\n } catch (error) {\n data = {}\n }\n } else {\n data = {}\n }\n\n for (let key in initial) {\n try {\n state[key] = initial[key].parse(data[key])\n } catch (error) {\n state[key] = data[key]\n }\n }\n\n return state;\n}\n\nexport default Initial;"],"names":["getCookie"],"mappings":"wGAGA,MAAM,OAAO,GAAG,CAAC,OAA0B,EAAE,QAAgB,EAAE,MAAqB,KAAI;IACrF,IAAI,KAAK,GAAG,EAAyB;IACrC,IAAI,IAAI,GAAQ,EAAE;AAElB,IAAA,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE;AAChC,QAAA,IAAI,MAAM,CAAC,KAAK,KAAK,SAAS,IAAI,MAAM,CAAC,KAAK,KAAK,OAAO,EAAE;AACzD,YAAA,IAAI,OAAO,GAAG,MAAM,CAAC,KAAK,KAAK,SAAS,GAAG,cAAc,GAAG,YAAY;AACxE,YAAA,IAAI,GAAG,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC;QACnC;AAAO,aAAA,IAAI,MAAM,CAAC,KAAK,KAAK,KAAK,EAAE;YAChC,IAAI,GAAG,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC;AACvC,YAAA,IAAI,GAAG,kBAAkB,CAAC,GAAG,CAAC,YAAY,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QAClE;AAAO,aAAA,IAAI,MAAM,CAAC,KAAK,KAAK,QAAQ,EAAE;AACnC,YAAA,IAAI,GAAGA,gBAAS,CAAC,QAAQ,CAAC;QAC7B;IACH;IAEA,IAAI,IAAI,EAAE;AACP,QAAA,IAAI;AACD,YAAA,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;QAC1B;QAAE,OAAO,KAAK,EAAE;YACb,IAAI,GAAG,EAAE;QACZ;IACH;SAAO;QACJ,IAAI,GAAG,EAAE;IACZ;AAEA,IAAA,KAAK,IAAI,GAAG,IAAI,OAAO,EAAE;AACtB,QAAA,IAAI;AACD,YAAA,KAAK,CAAC,GAAG,CAAC,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC7C;QAAE,OAAO,KAAK,EAAE;YACb,KAAK,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC;QACzB;IACH;AAEA,IAAA,OAAO,KAAK;AACf"}
1
+ {"version":3,"file":"Initial.js","sources":["../src/Initial.ts"],"sourcesContent":["import { BucketOptions, InitialBucketData } from \".\";\r\nimport { getCookie } from \"./Cookie\";\r\n\r\nconst Initial = (initial: InitialBucketData, data_key: string, option: BucketOptions) => {\r\n let state = {} as Record<string, any>;\r\n let data: any = \"\"\r\n\r\n if (typeof window !== 'undefined') {\r\n if (option.store === 'session' || option.store === 'local') {\r\n let storage = option.store === \"session\" ? sessionStorage : localStorage\r\n data = storage.getItem(data_key)\r\n } else if (option.store === 'url') {\r\n let url = new URL(window.location.href)\r\n data = decodeURIComponent(url.searchParams.get(data_key) || \"\")\r\n } else if (option.store === 'cookie') {\r\n data = getCookie(data_key)\r\n }\r\n }\r\n\r\n if (data) {\r\n try {\r\n data = JSON.parse(data)\r\n } catch (error) {\r\n data = {}\r\n }\r\n } else {\r\n data = {}\r\n }\r\n\r\n for (let key in initial) {\r\n try {\r\n state[key] = initial[key].parse(data[key])\r\n } catch (error) {\r\n state[key] = data[key]\r\n }\r\n }\r\n\r\n return state;\r\n}\r\n\r\nexport default Initial;"],"names":[],"mappings":";;AAGA,MAAM,OAAO,GAAG,CAAC,OAA0B,EAAE,QAAgB,EAAE,MAAqB,KAAI;IACrF,IAAI,KAAK,GAAG,EAAyB;IACrC,IAAI,IAAI,GAAQ,EAAE;AAElB,IAAA,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE;AAChC,QAAA,IAAI,MAAM,CAAC,KAAK,KAAK,SAAS,IAAI,MAAM,CAAC,KAAK,KAAK,OAAO,EAAE;AACzD,YAAA,IAAI,OAAO,GAAG,MAAM,CAAC,KAAK,KAAK,SAAS,GAAG,cAAc,GAAG,YAAY;AACxE,YAAA,IAAI,GAAG,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC;QACnC;AAAO,aAAA,IAAI,MAAM,CAAC,KAAK,KAAK,KAAK,EAAE;YAChC,IAAI,GAAG,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC;AACvC,YAAA,IAAI,GAAG,kBAAkB,CAAC,GAAG,CAAC,YAAY,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QAClE;AAAO,aAAA,IAAI,MAAM,CAAC,KAAK,KAAK,QAAQ,EAAE;AACnC,YAAA,IAAI,GAAG,SAAS,CAAC,QAAQ,CAAC;QAC7B;IACH;IAEA,IAAI,IAAI,EAAE;AACP,QAAA,IAAI;AACD,YAAA,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;QAC1B;QAAE,OAAO,KAAK,EAAE;YACb,IAAI,GAAG,EAAE;QACZ;IACH;SAAO;QACJ,IAAI,GAAG,EAAE;IACZ;AAEA,IAAA,KAAK,IAAI,GAAG,IAAI,OAAO,EAAE;AACtB,QAAA,IAAI;AACD,YAAA,KAAK,CAAC,GAAG,CAAC,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC7C;QAAE,OAAO,KAAK,EAAE;YACb,KAAK,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC;QACzB;IACH;AAEA,IAAA,OAAO,KAAK;AACf;;;;"}
package/index.cjs ADDED
@@ -0,0 +1,198 @@
1
+ "use client";
2
+ 'use strict';
3
+
4
+ var react = require('react');
5
+ var xanv = require('xanv');
6
+ var youid = require('youid');
7
+ var Cookie = require('./Cookie.cjs');
8
+ var Initial = require('./Initial.cjs');
9
+
10
+ const createBucket = (initial, option) => {
11
+ option = Object.assign({ store: "memory" }, option);
12
+ if (!(option === null || option === void 0 ? void 0 : option.data_key)) {
13
+ let data_key = '';
14
+ for (let key in initial) {
15
+ const field = initial[key];
16
+ data_key += key + ':' + JSON.stringify(field.meta) + ';';
17
+ }
18
+ option.data_key = youid(data_key);
19
+ }
20
+ const hooks = new Map();
21
+ const state = Initial(initial, (option === null || option === void 0 ? void 0 : option.data_key) || '', option || {});
22
+ const changes = {};
23
+ const errors = {};
24
+ const useHook = () => {
25
+ try {
26
+ const id = "rsb_" + react.useId();
27
+ const [, setState] = react.useState(0);
28
+ react.useEffect(() => {
29
+ hooks.set(id, () => setState(Math.random()));
30
+ return () => {
31
+ hooks.delete(id);
32
+ };
33
+ }, []);
34
+ }
35
+ catch (error) {
36
+ }
37
+ };
38
+ const get = (key, defaultValue, dispatch = true) => {
39
+ if (!(key in initial)) {
40
+ throw new Error(`Property ${String(key)} is not defined in the bucket.`);
41
+ }
42
+ if (dispatch) {
43
+ useHook();
44
+ }
45
+ let value = state[key];
46
+ if (value === undefined && defaultValue !== undefined) {
47
+ value = defaultValue;
48
+ }
49
+ return value;
50
+ };
51
+ const set = (key, value, dispatch = true) => {
52
+ if (!(key in initial)) {
53
+ throw new Error(`Property ${String(key)} is not defined in the bucket.`);
54
+ }
55
+ state[key] = value;
56
+ if (dispatch) {
57
+ hooks.forEach((hook) => hook());
58
+ }
59
+ changes[key] = true;
60
+ if ((option === null || option === void 0 ? void 0 : option.onChange) && changes[key]) {
61
+ option.onChange(key, value);
62
+ }
63
+ if (typeof window !== 'undefined') {
64
+ value = JSON.stringify(value);
65
+ if (option.store === 'session' || option.store === 'local') {
66
+ let storage = option.store === "session" ? sessionStorage : localStorage;
67
+ storage.setItem(option.data_key, JSON.stringify(state));
68
+ }
69
+ else if (option.store === 'url') {
70
+ let url = new URL(window.location.href);
71
+ url.searchParams.set(option.data_key, encodeURIComponent(JSON.stringify(state)));
72
+ window.history.replaceState({}, '', url.toString());
73
+ }
74
+ else if (option.store === 'cookie') {
75
+ Cookie.setCookie(option.data_key, JSON.stringify(state));
76
+ }
77
+ }
78
+ };
79
+ const sets = (data, dispatch = true) => {
80
+ for (let k in data) {
81
+ let v = data[k];
82
+ set(k, v, false);
83
+ }
84
+ if (dispatch) {
85
+ hooks.forEach((hook) => hook());
86
+ }
87
+ };
88
+ const _delete = (key) => {
89
+ set(key, undefined);
90
+ };
91
+ const clear = () => {
92
+ const initVal = Initial(initial, (option === null || option === void 0 ? void 0 : option.data_key) || '', option || {});
93
+ for (let key in initial) {
94
+ state[key] = initVal[key];
95
+ delete changes[key];
96
+ }
97
+ hooks.forEach((hook) => hook());
98
+ };
99
+ const getChanges = (dispatch = true) => {
100
+ if (dispatch) {
101
+ useHook();
102
+ }
103
+ const changedData = {};
104
+ for (let k in changes) {
105
+ if (changes[k]) {
106
+ changedData[k] = state[k];
107
+ }
108
+ }
109
+ return changedData;
110
+ };
111
+ const isChanged = (k, dispatch = true) => {
112
+ if (dispatch) {
113
+ useHook();
114
+ }
115
+ return !!changes[k];
116
+ };
117
+ const isValid = (key, dispatch = true) => {
118
+ if (dispatch) {
119
+ useHook();
120
+ }
121
+ try {
122
+ initial[key].parse(state[key]);
123
+ }
124
+ catch (error) {
125
+ errors[key] = error.message;
126
+ }
127
+ hooks.forEach((hook) => hook());
128
+ return !(key in errors);
129
+ };
130
+ const validate = () => {
131
+ for (let k in initial) {
132
+ try {
133
+ initial[k].parse(state[k]);
134
+ }
135
+ catch (error) {
136
+ errors[k] = error.message;
137
+ }
138
+ }
139
+ hooks.forEach((hook) => hook());
140
+ return Object.keys(errors).length === 0;
141
+ };
142
+ const getError = (key, dispatch = true) => {
143
+ if (dispatch) {
144
+ useHook();
145
+ }
146
+ if (key in errors) {
147
+ return errors[key];
148
+ }
149
+ return '';
150
+ };
151
+ const getErrors = (dispatch = true) => {
152
+ if (dispatch) {
153
+ useHook();
154
+ }
155
+ return errors;
156
+ };
157
+ const setError = (key, message) => {
158
+ errors[key] = message;
159
+ hooks.forEach((hook) => hook());
160
+ };
161
+ const clearErrors = () => {
162
+ for (let k in errors) {
163
+ delete errors[k];
164
+ }
165
+ hooks.forEach((hook) => hook());
166
+ };
167
+ const clearError = (key) => {
168
+ delete errors[key];
169
+ hooks.forEach((hook) => hook());
170
+ };
171
+ return {
172
+ state: (dispatch = true) => {
173
+ if (dispatch) {
174
+ useHook();
175
+ }
176
+ return state;
177
+ },
178
+ get,
179
+ set,
180
+ sets,
181
+ delete: _delete,
182
+ clear,
183
+ validate,
184
+ isValid,
185
+ getChanges,
186
+ isChanged,
187
+ getErrors,
188
+ getError,
189
+ setError,
190
+ clearErrors,
191
+ clearError
192
+ };
193
+ };
194
+ const xv = xanv.xv;
195
+
196
+ exports.createBucket = createBucket;
197
+ exports.xv = xv;
198
+ //# sourceMappingURL=index.cjs.map
package/index.cjs.map ADDED
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","sources":["../src/index.ts"],"sourcesContent":["\"use client\"\r\nimport { useEffect, useId, useState } from \"react\"\r\nimport { Infer, xv as XV, XVAny, XVArray, XVBoolean, XVDate, XVEnum, XVFile, XVFunction, XVMap, XVNumber, XVObject, XVPromise, XVRecord, XVSet, XVString, XVTuple, XVType, XVUnion } from \"xanv\"\r\nimport youid from \"youid\";\r\nimport { setCookie } from \"./Cookie\";\r\nimport Initial from \"./Initial\";\r\n\r\nexport type StoreType = \"memory\" | \"session\" | \"local\" | \"url\" | \"cookie\"\r\nexport type BucketOptions = {\r\n store?: StoreType;\r\n data_key?: string;\r\n onChange?: (key: string, value: any) => void\r\n}\r\n\r\nexport type InitialBucketData = {\r\n [key: string]: XVAny\r\n | XVArray<any>\r\n | XVBoolean\r\n | XVDate\r\n | XVEnum<any>\r\n | XVFile\r\n | XVFunction<any, any>\r\n | XVMap\r\n | XVNumber\r\n | XVObject<any>\r\n | XVPromise<any>\r\n | XVRecord<any, any>\r\n | XVSet\r\n | XVString\r\n | XVTuple\r\n | XVType<any>\r\n | XVUnion\r\n}\r\n\r\n\r\nexport const createBucket = <T extends InitialBucketData>(initial: T, option?: BucketOptions) => {\r\n option = {\r\n store: \"memory\",\r\n ...option,\r\n }\r\n\r\n if (!option?.data_key) {\r\n let data_key = ''\r\n for (let key in initial) {\r\n const field = initial[key]\r\n data_key += key + ':' + JSON.stringify(field.meta) + ';'\r\n }\r\n option.data_key = youid(data_key)\r\n }\r\n\r\n const hooks = new Map<string, Function>()\r\n const state: Record<keyof T, any> = Initial(initial, option?.data_key || '', option || {}) as Record<keyof T, any>;\r\n const changes: Record<keyof T, boolean> = {} as any\r\n const errors: Record<keyof T, string> = {} as any\r\n\r\n const useHook = () => {\r\n try {\r\n const id = \"rsb_\" + useId()\r\n const [, setState] = useState(0)\r\n useEffect(() => {\r\n hooks.set(id, () => setState(Math.random()))\r\n return () => {\r\n hooks.delete(id)\r\n }\r\n }, [])\r\n } catch (error) {\r\n\r\n }\r\n }\r\n\r\n\r\n\r\n const get = (key: keyof T, defaultValue?: any, dispatch = true) => {\r\n if (!(key in initial)) {\r\n throw new Error(`Property ${String(key)} is not defined in the bucket.`)\r\n }\r\n if (dispatch) {\r\n useHook()\r\n }\r\n let value = state[key];\r\n if (value === undefined && defaultValue !== undefined) {\r\n value = defaultValue\r\n }\r\n return value;\r\n }\r\n\r\n const set = (key: keyof T, value: any, dispatch = true) => {\r\n if (!(key in initial)) {\r\n throw new Error(`Property ${String(key)} is not defined in the bucket.`)\r\n }\r\n state[key] = value;\r\n if (dispatch) {\r\n hooks.forEach((hook) => hook());\r\n }\r\n changes[key] = true\r\n if (option?.onChange && changes[key]) {\r\n option.onChange(key as string, value)\r\n }\r\n\r\n if (typeof window !== 'undefined') {\r\n value = JSON.stringify(value) as any\r\n if (option.store === 'session' || option.store === 'local') {\r\n let storage = option.store === \"session\" ? sessionStorage : localStorage\r\n storage.setItem(option.data_key!, JSON.stringify(state))\r\n } else if (option.store === 'url') {\r\n let url = new URL(window.location.href)\r\n url.searchParams.set(option.data_key!, encodeURIComponent(JSON.stringify(state)))\r\n window.history.replaceState({}, '', url.toString())\r\n } else if (option.store === 'cookie') {\r\n setCookie(option.data_key!, JSON.stringify(state))\r\n }\r\n }\r\n }\r\n\r\n const sets = (data: Partial<Infer<T>>, dispatch = true) => {\r\n for (let k in data) {\r\n let v = data[k]\r\n set(k, v, false)\r\n }\r\n\r\n if (dispatch) {\r\n hooks.forEach((hook) => hook());\r\n }\r\n }\r\n\r\n const _delete = (key: keyof T) => {\r\n set(key, undefined)\r\n }\r\n\r\n const clear = () => {\r\n const initVal = Initial(initial, option?.data_key || '', option || {}) as Record<keyof T, any>;\r\n for (let key in initial) {\r\n state[key] = initVal[key];\r\n delete changes[key]\r\n }\r\n hooks.forEach((hook) => hook());\r\n }\r\n\r\n const getChanges = (dispatch = true) => {\r\n if (dispatch) {\r\n useHook()\r\n }\r\n const changedData: Partial<Record<keyof T, any>> = {}\r\n for (let k in changes) {\r\n if (changes[k]) {\r\n changedData[k] = state[k]\r\n }\r\n }\r\n return changedData\r\n }\r\n\r\n const isChanged = (k: keyof T, dispatch = true) => {\r\n if (dispatch) {\r\n useHook()\r\n }\r\n return !!changes[k]\r\n }\r\n\r\n const isValid = (key: keyof T, dispatch = true) => {\r\n if (dispatch) {\r\n useHook()\r\n }\r\n try {\r\n initial[key].parse(state[key])\r\n } catch (error: any) {\r\n errors[key] = (error as any).message\r\n }\r\n hooks.forEach((hook) => hook());\r\n return !(key in errors)\r\n }\r\n\r\n const validate = () => {\r\n for (let k in initial) {\r\n try {\r\n initial[k].parse(state[k])\r\n } catch (error: any) {\r\n errors[k] = (error as any).message\r\n }\r\n }\r\n hooks.forEach((hook) => hook());\r\n return Object.keys(errors).length === 0\r\n }\r\n\r\n const getError = (key: keyof T, dispatch = true) => {\r\n if (dispatch) {\r\n useHook()\r\n }\r\n if (key in errors) {\r\n return errors[key]\r\n }\r\n return ''\r\n }\r\n\r\n const getErrors = (dispatch = true) => {\r\n if (dispatch) {\r\n useHook()\r\n }\r\n return errors\r\n }\r\n\r\n const setError = (key: keyof T, message: string) => {\r\n errors[key] = message\r\n hooks.forEach((hook) => hook());\r\n }\r\n\r\n const clearErrors = () => {\r\n for (let k in errors) {\r\n delete errors[k]\r\n }\r\n hooks.forEach((hook) => hook());\r\n }\r\n\r\n const clearError = (key: keyof T) => {\r\n delete errors[key]\r\n hooks.forEach((hook) => hook());\r\n }\r\n\r\n return {\r\n state: (dispatch = true) => {\r\n if (dispatch) {\r\n useHook()\r\n }\r\n return state\r\n },\r\n get,\r\n set,\r\n sets,\r\n delete: _delete,\r\n clear,\r\n validate,\r\n isValid,\r\n getChanges,\r\n isChanged,\r\n getErrors,\r\n getError,\r\n setError,\r\n clearErrors,\r\n clearError\r\n }\r\n\r\n}\r\n\r\nexport const xv = XV"],"names":[],"mappings":";;;;;;;;;;AAoCE;;;AAOE;AACE;AACA;;AAEF;;AAGF;;;;;AAME;AACE;;;AAGE;AACA;AACE;AACF;;;;;AAKN;;AAKE;;;;AAIE;;AAEF;;;;AAIA;AACF;;AAGE;;;AAGA;;;;AAIA;AACA;AACE;;AAGF;AACE;AACA;AACE;AACA;;AACK;;AAEL;AACA;;AACK;AACL;;;AAGN;;AAGE;AACE;AACA;;;;;AAMJ;AAEA;AACE;AACF;;;AAIE;;AAEE;;;AAGJ;AAEA;;AAEI;;;AAGF;AACE;;;;AAIF;AACF;;;AAII;;AAEF;AACF;;;AAII;;AAEF;;;;AAGE;;;AAGF;AACF;;AAGE;AACE;;;;AAGE;;;;;AAKN;;;AAII;;AAEF;AACE;;AAEF;AACF;AAEA;;AAEI;;AAEF;AACF;AAEA;AACE;;AAEF;;AAGE;AACE;;;AAGJ;AAEA;AACE;;AAEF;;AAGE;;AAEI;;AAEF;;;;;AAKF;;;;;;;;;;;;AAaJ;AAEO;;;"}
package/index.d.ts CHANGED
@@ -1,5 +1,4 @@
1
- import * as xanv from 'xanv';
2
- import { XVInstanceType, Infer } from 'xanv';
1
+ import { XVAny, XVArray, XVBoolean, XVDate, XVEnum, XVFile, XVFunction, XVMap, XVNumber, XVObject, XVPromise, XVRecord, XVSet, XVString, XVTuple, XVType, XVUnion, Infer } from 'xanv';
3
2
 
4
3
  type StoreType = "memory" | "session" | "local" | "url" | "cookie";
5
4
  type BucketOptions = {
@@ -8,41 +7,42 @@ type BucketOptions = {
8
7
  onChange?: (key: string, value: any) => void;
9
8
  };
10
9
  type InitialBucketData = {
11
- [key: string]: XVInstanceType;
10
+ [key: string]: XVAny | XVArray<any> | XVBoolean | XVDate | XVEnum<any> | XVFile | XVFunction<any, any> | XVMap | XVNumber | XVObject<any> | XVPromise<any> | XVRecord<any, any> | XVSet | XVString | XVTuple | XVType<any> | XVUnion;
12
11
  };
13
- declare const createBucket: <T extends InitialBucketData>(initial: T, option?: BucketOptions) => () => {
14
- state: Record<keyof T, any>;
15
- get: (key: keyof T, defaultValue?: any) => Record<keyof T, any>[keyof T];
12
+ declare const createBucket: <T extends InitialBucketData>(initial: T, option?: BucketOptions) => {
13
+ state: (dispatch?: boolean) => Record<keyof T, any>;
14
+ get: (key: keyof T, defaultValue?: any, dispatch?: boolean) => Record<keyof T, any>[keyof T];
16
15
  set: (key: keyof T, value: any, dispatch?: boolean) => void;
17
16
  sets: (data: Partial<Infer<T>>, dispatch?: boolean) => void;
18
17
  delete: (key: keyof T) => void;
19
18
  clear: () => void;
20
19
  validate: () => boolean;
21
- isValid: (key: keyof T) => boolean;
22
- getChanges: () => Partial<Record<keyof T, any>>;
23
- isChanged: (k: keyof T) => boolean;
24
- getErrors: () => Record<keyof T, string>;
25
- getError: (key: keyof T) => Record<keyof T, string>[keyof T] | "";
20
+ isValid: (key: keyof T, dispatch?: boolean) => boolean;
21
+ getChanges: (dispatch?: boolean) => Partial<Record<keyof T, any>>;
22
+ isChanged: (k: keyof T, dispatch?: boolean) => boolean;
23
+ getErrors: (dispatch?: boolean) => Record<keyof T, string>;
24
+ getError: (key: keyof T, dispatch?: boolean) => Record<keyof T, string>[keyof T] | "";
26
25
  setError: (key: keyof T, message: string) => void;
27
26
  clearErrors: () => void;
28
27
  clearError: (key: keyof T) => void;
29
28
  };
30
29
  declare const xv: {
31
- any: () => xanv.XVAny<any>;
32
- array: (type: XVInstanceType, length?: number) => xanv.XVArray<any[]>;
33
- boolean: () => xanv.XVBoolean;
34
- date: () => xanv.XVDate<Date>;
35
- enum: (values: xanv.XVEnumValues) => xanv.XVEnum<string | number>;
36
- file: () => xanv.XVFile<File | Blob>;
37
- map: (key: XVInstanceType, value: XVInstanceType) => xanv.XVMap<any, any>;
38
- number: (length?: number) => xanv.XVNumber<number>;
39
- object: (arg?: xanv.XVObjectType) => xanv.XVObject<Record<any, any>>;
40
- record: (key: XVInstanceType, value: XVInstanceType) => xanv.XVRecord<string, any>;
41
- set: (type: XVInstanceType) => xanv.XVSet<unknown>;
42
- string: (length?: number) => xanv.XVString<string>;
43
- tuple: (type: XVInstanceType[]) => xanv.XVTuple<any[]>;
44
- union: (type: XVInstanceType[]) => xanv.XVUnion<any>;
45
- json: () => xanv.XVJson;
30
+ any: () => XVAny<any>;
31
+ array: <T extends XVType<any>>(type: T) => XVArray<T>;
32
+ boolean: () => XVBoolean;
33
+ date: () => XVDate;
34
+ enum: <const T extends string | number>(input: readonly T[] | Record<string, T>) => XVEnum<T>;
35
+ file: () => XVFile;
36
+ number: (length?: number) => XVNumber<number>;
37
+ object: <T extends Record<string, XVType<any>>>(shape: T) => XVObject<T>;
38
+ record: <K extends XVType<any>, V extends XVType<any>>(key: K, value: V) => XVRecord<K, V>;
39
+ map: <K extends XVType<any>, V extends XVType<any>>(key: K, value: V) => XVMap<K, V>;
40
+ set: <T extends XVType<any>>(type: T) => XVSet<T>;
41
+ string: (length?: number) => XVString;
42
+ tuple: <T extends XVType<any>[]>(type: T) => XVTuple<T>;
43
+ union: <T extends XVType<any>[]>(types: T) => XVUnion<T>;
44
+ function: <const A extends XVType<any>[], R extends XVType<any>>(args: A, ret: R) => XVFunction<A, R>;
45
+ promise: <T extends XVType<any>>(type: T) => XVPromise<T>;
46
46
  };
47
47
 
48
48
  export { createBucket, xv };