gjendje 1.2.0 → 1.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -2,8 +2,8 @@
2
2
 
3
3
  # gjendje
4
4
 
5
- ![NPM Last Update](https://img.shields.io/npm/last-update/gjendje)
6
5
  ![NPM Version](https://img.shields.io/npm/v/gjendje)
6
+ ![NPM Last Update](https://img.shields.io/npm/last-update/gjendje)
7
7
  ![GitHub License](https://img.shields.io/github/license/charliebeckstrand/gjendje)
8
8
 
9
9
  gjendje is a storage-agnostic state management library for TypeScript and JavaScript. It gives you a single, unified API for reactive state — regardless of where that state lives.
@@ -24,7 +24,55 @@ function log(level, message) {
24
24
  }
25
25
  }
26
26
  function reportError(key, scope, error) {
27
- globalConfig.onError?.({ key, scope, error });
27
+ if (globalConfig.onError === void 0) return;
28
+ try {
29
+ globalConfig.onError({ key, scope, error });
30
+ } catch (err) {
31
+ console.error("[gjendje] onError callback threw:", err);
32
+ }
33
+ }
34
+
35
+ // src/listeners.ts
36
+ function safeCall(listener, value) {
37
+ try {
38
+ listener(value);
39
+ } catch (err) {
40
+ console.error("[gjendje] Listener threw:", err);
41
+ }
42
+ }
43
+ function safeCallChange(handler, next, prev) {
44
+ try {
45
+ handler(next, prev);
46
+ } catch (err) {
47
+ console.error("[gjendje] Change handler threw:", err);
48
+ }
49
+ }
50
+ function safeCallConfig(fn, arg) {
51
+ if (fn === void 0) return;
52
+ try {
53
+ fn(arg);
54
+ } catch (err) {
55
+ console.error("[gjendje] Config callback threw:", err);
56
+ }
57
+ }
58
+ function createListeners() {
59
+ const set = /* @__PURE__ */ new Set();
60
+ return {
61
+ notify(value) {
62
+ for (const listener of set) {
63
+ safeCall(listener, value);
64
+ }
65
+ },
66
+ subscribe(listener) {
67
+ set.add(listener);
68
+ return () => {
69
+ set.delete(listener);
70
+ };
71
+ },
72
+ clear() {
73
+ set.clear();
74
+ }
75
+ };
28
76
  }
29
77
 
30
78
  // src/registry.ts
@@ -46,7 +94,7 @@ function registerNew(rKey, key, scope, instance, config, existing) {
46
94
  );
47
95
  }
48
96
  registry.set(rKey, instance);
49
- config.onRegister?.({ key, scope });
97
+ safeCallConfig(config.onRegister, { key, scope });
50
98
  }
51
99
  function unregisterByKey(rKey) {
52
100
  registry.delete(rKey);
@@ -55,12 +103,17 @@ function getRegistry() {
55
103
  return registry;
56
104
  }
57
105
 
106
+ exports.PERSISTENT_SCOPES = PERSISTENT_SCOPES;
58
107
  exports.configure = configure;
108
+ exports.createListeners = createListeners;
59
109
  exports.getConfig = getConfig;
60
110
  exports.getRegistered = getRegistered;
61
111
  exports.getRegistry = getRegistry;
62
112
  exports.log = log;
63
113
  exports.registerNew = registerNew;
64
114
  exports.reportError = reportError;
115
+ exports.safeCall = safeCall;
116
+ exports.safeCallChange = safeCallChange;
117
+ exports.safeCallConfig = safeCallConfig;
65
118
  exports.scopedKey = scopedKey;
66
119
  exports.unregisterByKey = unregisterByKey;
@@ -22,7 +22,55 @@ function log(level, message) {
22
22
  }
23
23
  }
24
24
  function reportError(key, scope, error) {
25
- globalConfig.onError?.({ key, scope, error });
25
+ if (globalConfig.onError === void 0) return;
26
+ try {
27
+ globalConfig.onError({ key, scope, error });
28
+ } catch (err) {
29
+ console.error("[gjendje] onError callback threw:", err);
30
+ }
31
+ }
32
+
33
+ // src/listeners.ts
34
+ function safeCall(listener, value) {
35
+ try {
36
+ listener(value);
37
+ } catch (err) {
38
+ console.error("[gjendje] Listener threw:", err);
39
+ }
40
+ }
41
+ function safeCallChange(handler, next, prev) {
42
+ try {
43
+ handler(next, prev);
44
+ } catch (err) {
45
+ console.error("[gjendje] Change handler threw:", err);
46
+ }
47
+ }
48
+ function safeCallConfig(fn, arg) {
49
+ if (fn === void 0) return;
50
+ try {
51
+ fn(arg);
52
+ } catch (err) {
53
+ console.error("[gjendje] Config callback threw:", err);
54
+ }
55
+ }
56
+ function createListeners() {
57
+ const set = /* @__PURE__ */ new Set();
58
+ return {
59
+ notify(value) {
60
+ for (const listener of set) {
61
+ safeCall(listener, value);
62
+ }
63
+ },
64
+ subscribe(listener) {
65
+ set.add(listener);
66
+ return () => {
67
+ set.delete(listener);
68
+ };
69
+ },
70
+ clear() {
71
+ set.clear();
72
+ }
73
+ };
26
74
  }
27
75
 
28
76
  // src/registry.ts
@@ -44,7 +92,7 @@ function registerNew(rKey, key, scope, instance, config, existing) {
44
92
  );
45
93
  }
46
94
  registry.set(rKey, instance);
47
- config.onRegister?.({ key, scope });
95
+ safeCallConfig(config.onRegister, { key, scope });
48
96
  }
49
97
  function unregisterByKey(rKey) {
50
98
  registry.delete(rKey);
@@ -53,4 +101,4 @@ function getRegistry() {
53
101
  return registry;
54
102
  }
55
103
 
56
- export { configure, getConfig, getRegistered, getRegistry, log, registerNew, reportError, scopedKey, unregisterByKey };
104
+ export { PERSISTENT_SCOPES, configure, createListeners, getConfig, getRegistered, getRegistry, log, registerNew, reportError, safeCall, safeCallChange, safeCallConfig, scopedKey, unregisterByKey };