joopjs 2.0.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.
Files changed (259) hide show
  1. package/CHANGELOG.md +678 -0
  2. package/README.md +583 -0
  3. package/dist/a11y.service-C-DQQfgO.d.mts +143 -0
  4. package/dist/a11y.service-CauEJrJe.d.ts +143 -0
  5. package/dist/adapters-B6slG6hQ.d.mts +84 -0
  6. package/dist/adapters-B6slG6hQ.d.ts +84 -0
  7. package/dist/aes.service-CkoupAww.d.mts +95 -0
  8. package/dist/aes.service-CkoupAww.d.ts +95 -0
  9. package/dist/ai/index.d.mts +99 -0
  10. package/dist/ai/index.d.ts +99 -0
  11. package/dist/ai/index.js +307 -0
  12. package/dist/ai/index.js.map +1 -0
  13. package/dist/ai/index.mjs +304 -0
  14. package/dist/ai/index.mjs.map +1 -0
  15. package/dist/analytics/index.d.mts +42 -0
  16. package/dist/analytics/index.d.ts +42 -0
  17. package/dist/analytics/index.js +139 -0
  18. package/dist/analytics/index.js.map +1 -0
  19. package/dist/analytics/index.mjs +136 -0
  20. package/dist/analytics/index.mjs.map +1 -0
  21. package/dist/angular/index.d.mts +148 -0
  22. package/dist/angular/index.d.ts +148 -0
  23. package/dist/angular/index.js +122 -0
  24. package/dist/angular/index.js.map +1 -0
  25. package/dist/angular/index.mjs +101 -0
  26. package/dist/angular/index.mjs.map +1 -0
  27. package/dist/api/index.d.mts +128 -0
  28. package/dist/api/index.d.ts +128 -0
  29. package/dist/api/index.js +1358 -0
  30. package/dist/api/index.js.map +1 -0
  31. package/dist/api/index.mjs +1332 -0
  32. package/dist/api/index.mjs.map +1 -0
  33. package/dist/auth/index.d.mts +105 -0
  34. package/dist/auth/index.d.ts +105 -0
  35. package/dist/auth/index.js +989 -0
  36. package/dist/auth/index.js.map +1 -0
  37. package/dist/auth/index.mjs +979 -0
  38. package/dist/auth/index.mjs.map +1 -0
  39. package/dist/auth.service-DNVB-L4U.d.mts +16 -0
  40. package/dist/auth.service-PjUUSUIt.d.ts +16 -0
  41. package/dist/banking/index.d.mts +1530 -0
  42. package/dist/banking/index.d.ts +1530 -0
  43. package/dist/banking/index.js +4739 -0
  44. package/dist/banking/index.js.map +1 -0
  45. package/dist/banking/index.mjs +4661 -0
  46. package/dist/banking/index.mjs.map +1 -0
  47. package/dist/cache/index.d.mts +40 -0
  48. package/dist/cache/index.d.ts +40 -0
  49. package/dist/cache/index.js +174 -0
  50. package/dist/cache/index.js.map +1 -0
  51. package/dist/cache/index.mjs +172 -0
  52. package/dist/cache/index.mjs.map +1 -0
  53. package/dist/client-profile.service-BuPeXVp5.d.mts +28 -0
  54. package/dist/client-profile.service-D5bRRYQp.d.ts +28 -0
  55. package/dist/config.models-Cqg04fAQ.d.mts +84 -0
  56. package/dist/config.models-Cqg04fAQ.d.ts +84 -0
  57. package/dist/config.service-CrCvI-JS.d.ts +31 -0
  58. package/dist/config.service-Cz4QQLlf.d.mts +31 -0
  59. package/dist/core/index.d.mts +4 -0
  60. package/dist/core/index.d.ts +4 -0
  61. package/dist/core/index.js +631 -0
  62. package/dist/core/index.js.map +1 -0
  63. package/dist/core/index.mjs +619 -0
  64. package/dist/core/index.mjs.map +1 -0
  65. package/dist/crypto-utils-DriNhLdx.d.mts +30 -0
  66. package/dist/crypto-utils-DriNhLdx.d.ts +30 -0
  67. package/dist/data-storage.service-DT6xaTxE.d.ts +51 -0
  68. package/dist/data-storage.service-LvhGRCmw.d.mts +51 -0
  69. package/dist/deeplink/index.d.mts +39 -0
  70. package/dist/deeplink/index.d.ts +39 -0
  71. package/dist/deeplink/index.js +268 -0
  72. package/dist/deeplink/index.js.map +1 -0
  73. package/dist/deeplink/index.mjs +265 -0
  74. package/dist/deeplink/index.mjs.map +1 -0
  75. package/dist/deeplink.service-Ctd5u243.d.mts +35 -0
  76. package/dist/deeplink.service-uUuTnY9_.d.ts +35 -0
  77. package/dist/dev/index.d.mts +20 -0
  78. package/dist/dev/index.d.ts +20 -0
  79. package/dist/dev/index.js +51 -0
  80. package/dist/dev/index.js.map +1 -0
  81. package/dist/dev/index.mjs +49 -0
  82. package/dist/dev/index.mjs.map +1 -0
  83. package/dist/device/index.d.mts +108 -0
  84. package/dist/device/index.d.ts +108 -0
  85. package/dist/device/index.js +960 -0
  86. package/dist/device/index.js.map +1 -0
  87. package/dist/device/index.mjs +951 -0
  88. package/dist/device/index.mjs.map +1 -0
  89. package/dist/differential-privacy-BcAv1G80.d.mts +210 -0
  90. package/dist/differential-privacy-C8mAUjZr.d.ts +210 -0
  91. package/dist/encryption/index.d.mts +75 -0
  92. package/dist/encryption/index.d.ts +75 -0
  93. package/dist/encryption/index.js +605 -0
  94. package/dist/encryption/index.js.map +1 -0
  95. package/dist/encryption/index.mjs +598 -0
  96. package/dist/encryption/index.mjs.map +1 -0
  97. package/dist/form-validator-3tkmzr_o.d.mts +72 -0
  98. package/dist/form-validator-3tkmzr_o.d.ts +72 -0
  99. package/dist/forms/index.d.mts +59 -0
  100. package/dist/forms/index.d.ts +59 -0
  101. package/dist/forms/index.js +446 -0
  102. package/dist/forms/index.js.map +1 -0
  103. package/dist/forms/index.mjs +442 -0
  104. package/dist/forms/index.mjs.map +1 -0
  105. package/dist/i18n/index.d.mts +37 -0
  106. package/dist/i18n/index.d.ts +37 -0
  107. package/dist/i18n/index.js +147 -0
  108. package/dist/i18n/index.js.map +1 -0
  109. package/dist/i18n/index.mjs +145 -0
  110. package/dist/i18n/index.mjs.map +1 -0
  111. package/dist/idempotency.service-_6LqhivP.d.mts +372 -0
  112. package/dist/idempotency.service-eOKoISRD.d.ts +372 -0
  113. package/dist/index-B_ksKpS1.d.mts +202 -0
  114. package/dist/index-CqDKWTUP.d.mts +28 -0
  115. package/dist/index-CqDKWTUP.d.ts +28 -0
  116. package/dist/index-DFqEoX_l.d.ts +202 -0
  117. package/dist/index-Dz0gOur2.d.mts +36 -0
  118. package/dist/index-Dz0gOur2.d.ts +36 -0
  119. package/dist/index.d.mts +1336 -0
  120. package/dist/index.d.ts +1336 -0
  121. package/dist/index.js +19464 -0
  122. package/dist/index.js.map +1 -0
  123. package/dist/index.mjs +19155 -0
  124. package/dist/index.mjs.map +1 -0
  125. package/dist/india/index.d.mts +75 -0
  126. package/dist/india/index.d.ts +75 -0
  127. package/dist/india/index.js +325 -0
  128. package/dist/india/index.js.map +1 -0
  129. package/dist/india/index.mjs +303 -0
  130. package/dist/india/index.mjs.map +1 -0
  131. package/dist/joop-Bx7Iwj5p.d.mts +155 -0
  132. package/dist/joop-CA3DMeOO.d.ts +155 -0
  133. package/dist/native-bridge/index.d.mts +27 -0
  134. package/dist/native-bridge/index.d.ts +27 -0
  135. package/dist/native-bridge/index.js +98 -0
  136. package/dist/native-bridge/index.js.map +1 -0
  137. package/dist/native-bridge/index.mjs +96 -0
  138. package/dist/native-bridge/index.mjs.map +1 -0
  139. package/dist/network/index.d.mts +85 -0
  140. package/dist/network/index.d.ts +85 -0
  141. package/dist/network/index.js +454 -0
  142. package/dist/network/index.js.map +1 -0
  143. package/dist/network/index.mjs +451 -0
  144. package/dist/network/index.mjs.map +1 -0
  145. package/dist/network-monitor-BIwPSXme.d.mts +179 -0
  146. package/dist/network-monitor-Bqp2hvZr.d.ts +179 -0
  147. package/dist/notification.service-Dm4fvfZf.d.mts +25 -0
  148. package/dist/notification.service-tEMKatWJ.d.ts +25 -0
  149. package/dist/observability/index.d.mts +179 -0
  150. package/dist/observability/index.d.ts +179 -0
  151. package/dist/observability/index.js +559 -0
  152. package/dist/observability/index.js.map +1 -0
  153. package/dist/observability/index.mjs +552 -0
  154. package/dist/observability/index.mjs.map +1 -0
  155. package/dist/oidc-client-DIJcClmB.d.mts +190 -0
  156. package/dist/oidc-client-DxhyE59t.d.ts +190 -0
  157. package/dist/platform/index.d.mts +73 -0
  158. package/dist/platform/index.d.ts +73 -0
  159. package/dist/platform/index.js +127 -0
  160. package/dist/platform/index.js.map +1 -0
  161. package/dist/platform/index.mjs +125 -0
  162. package/dist/platform/index.mjs.map +1 -0
  163. package/dist/pwa/index.d.mts +31 -0
  164. package/dist/pwa/index.d.ts +31 -0
  165. package/dist/pwa/index.js +247 -0
  166. package/dist/pwa/index.js.map +1 -0
  167. package/dist/pwa/index.mjs +244 -0
  168. package/dist/pwa/index.mjs.map +1 -0
  169. package/dist/react/index.d.mts +133 -0
  170. package/dist/react/index.d.ts +133 -0
  171. package/dist/react/index.js +632 -0
  172. package/dist/react/index.js.map +1 -0
  173. package/dist/react/index.mjs +630 -0
  174. package/dist/react/index.mjs.map +1 -0
  175. package/dist/router/index.d.mts +39 -0
  176. package/dist/router/index.d.ts +39 -0
  177. package/dist/router/index.js +168 -0
  178. package/dist/router/index.js.map +1 -0
  179. package/dist/router/index.mjs +166 -0
  180. package/dist/router/index.mjs.map +1 -0
  181. package/dist/security/index.d.mts +206 -0
  182. package/dist/security/index.d.ts +206 -0
  183. package/dist/security/index.js +1297 -0
  184. package/dist/security/index.js.map +1 -0
  185. package/dist/security/index.mjs +1285 -0
  186. package/dist/security/index.mjs.map +1 -0
  187. package/dist/session/index.d.mts +115 -0
  188. package/dist/session/index.d.ts +115 -0
  189. package/dist/session/index.js +297 -0
  190. package/dist/session/index.js.map +1 -0
  191. package/dist/session/index.mjs +292 -0
  192. package/dist/session/index.mjs.map +1 -0
  193. package/dist/state/index.d.mts +43 -0
  194. package/dist/state/index.d.ts +43 -0
  195. package/dist/state/index.js +156 -0
  196. package/dist/state/index.js.map +1 -0
  197. package/dist/state/index.mjs +152 -0
  198. package/dist/state/index.mjs.map +1 -0
  199. package/dist/statement-parser-BHQtXwCM.d.ts +260 -0
  200. package/dist/statement-parser-C2qNmb49.d.mts +260 -0
  201. package/dist/storage/index.d.mts +40 -0
  202. package/dist/storage/index.d.ts +40 -0
  203. package/dist/storage/index.js +256 -0
  204. package/dist/storage/index.js.map +1 -0
  205. package/dist/storage/index.mjs +252 -0
  206. package/dist/storage/index.mjs.map +1 -0
  207. package/dist/sync/index.d.mts +69 -0
  208. package/dist/sync/index.d.ts +69 -0
  209. package/dist/sync/index.js +330 -0
  210. package/dist/sync/index.js.map +1 -0
  211. package/dist/sync/index.mjs +323 -0
  212. package/dist/sync/index.mjs.map +1 -0
  213. package/dist/sync-engine-DCIMRG5s.d.ts +61 -0
  214. package/dist/sync-engine-DZqyKHkK.d.mts +61 -0
  215. package/dist/theme/index.d.mts +53 -0
  216. package/dist/theme/index.d.ts +53 -0
  217. package/dist/theme/index.js +169 -0
  218. package/dist/theme/index.js.map +1 -0
  219. package/dist/theme/index.mjs +167 -0
  220. package/dist/theme/index.mjs.map +1 -0
  221. package/dist/ui/index.d.mts +66 -0
  222. package/dist/ui/index.d.ts +66 -0
  223. package/dist/ui/index.js +811 -0
  224. package/dist/ui/index.js.map +1 -0
  225. package/dist/ui/index.mjs +803 -0
  226. package/dist/ui/index.mjs.map +1 -0
  227. package/dist/utilities/index.d.mts +199 -0
  228. package/dist/utilities/index.d.ts +199 -0
  229. package/dist/utilities/index.js +1991 -0
  230. package/dist/utilities/index.js.map +1 -0
  231. package/dist/utilities/index.mjs +1923 -0
  232. package/dist/utilities/index.mjs.map +1 -0
  233. package/dist/validation/index.d.mts +60 -0
  234. package/dist/validation/index.d.ts +60 -0
  235. package/dist/validation/index.js +460 -0
  236. package/dist/validation/index.js.map +1 -0
  237. package/dist/validation/index.mjs +455 -0
  238. package/dist/validation/index.mjs.map +1 -0
  239. package/dist/vue/index.d.mts +135 -0
  240. package/dist/vue/index.d.ts +135 -0
  241. package/dist/vue/index.js +621 -0
  242. package/dist/vue/index.js.map +1 -0
  243. package/dist/vue/index.mjs +619 -0
  244. package/dist/vue/index.mjs.map +1 -0
  245. package/dist/watermark.service-Detur5tq.d.ts +235 -0
  246. package/dist/watermark.service-QNegMeQZ.d.mts +235 -0
  247. package/dist/workers/index.d.mts +42 -0
  248. package/dist/workers/index.d.ts +42 -0
  249. package/dist/workers/index.js +359 -0
  250. package/dist/workers/index.js.map +1 -0
  251. package/dist/workers/index.mjs +356 -0
  252. package/dist/workers/index.mjs.map +1 -0
  253. package/dist/workflow/index.d.mts +99 -0
  254. package/dist/workflow/index.d.ts +99 -0
  255. package/dist/workflow/index.js +282 -0
  256. package/dist/workflow/index.js.map +1 -0
  257. package/dist/workflow/index.mjs +279 -0
  258. package/dist/workflow/index.mjs.map +1 -0
  259. package/package.json +226 -0
@@ -0,0 +1,619 @@
1
+ // src/events/index.ts
2
+ var JoopSubject = class {
3
+ _listeners = [];
4
+ subscribe(listener) {
5
+ this._listeners.push(listener);
6
+ return () => {
7
+ this._listeners = this._listeners.filter((l) => l !== listener);
8
+ };
9
+ }
10
+ next(value) {
11
+ for (const listener of this._listeners) {
12
+ listener(value);
13
+ }
14
+ }
15
+ asObservable() {
16
+ return new JoopObservable((listener) => this.subscribe(listener));
17
+ }
18
+ };
19
+ var JoopBehaviorSubject = class extends JoopSubject {
20
+ _value;
21
+ constructor(initialValue) {
22
+ super();
23
+ this._value = initialValue;
24
+ }
25
+ getValue() {
26
+ return this._value;
27
+ }
28
+ next(value) {
29
+ this._value = value;
30
+ super.next(value);
31
+ }
32
+ subscribe(listener) {
33
+ listener(this._value);
34
+ return super.subscribe(listener);
35
+ }
36
+ asObservable() {
37
+ return new JoopObservable((listener) => this.subscribe(listener));
38
+ }
39
+ };
40
+ var JoopObservable = class {
41
+ constructor(_subscribeFn) {
42
+ this._subscribeFn = _subscribeFn;
43
+ }
44
+ _subscribeFn;
45
+ subscribe(listener) {
46
+ return this._subscribeFn(listener);
47
+ }
48
+ /** Returns the current value without subscribing (only meaningful for BehaviorSubject-backed observables). */
49
+ getOnce() {
50
+ let result;
51
+ const unsub = this.subscribe((v) => {
52
+ result = v;
53
+ });
54
+ unsub();
55
+ return result;
56
+ }
57
+ };
58
+
59
+ // src/platform/platform.ts
60
+ var _webStorage = (store) => ({
61
+ getItem: (k) => store.getItem(k),
62
+ setItem: (k, v) => store.setItem(k, v),
63
+ removeItem: (k) => store.removeItem(k),
64
+ clear: () => store.clear()
65
+ });
66
+ var _MemStorageImpl = class {
67
+ _m = /* @__PURE__ */ new Map();
68
+ getItem(k) {
69
+ return this._m.get(k) ?? null;
70
+ }
71
+ setItem(k, v) {
72
+ this._m.set(k, v);
73
+ }
74
+ removeItem(k) {
75
+ this._m.delete(k);
76
+ }
77
+ clear() {
78
+ this._m.clear();
79
+ }
80
+ };
81
+ function _detect() {
82
+ if (typeof navigator !== "undefined" && navigator.product === "ReactNative") return "react-native";
83
+ const _proc = globalThis["process"];
84
+ if (typeof window === "undefined" && _proc?.versions?.node) return "node";
85
+ if (typeof window !== "undefined") return "web";
86
+ return "unknown";
87
+ }
88
+ var JoopPlatform = class {
89
+ static _type = _detect();
90
+ static _adapter = {};
91
+ static _memStorage = null;
92
+ /**
93
+ * Call once at app startup to configure adapters for your platform.
94
+ *
95
+ * Web (default — no call needed):
96
+ * JoopPlatform.init();
97
+ *
98
+ * React Native with react-native-mmkv:
99
+ * import { MMKV } from 'react-native-mmkv';
100
+ * const mmkv = new MMKV();
101
+ * JoopPlatform.init({ adapter: { storage: mmkv } });
102
+ *
103
+ * React Native with custom compression (fflate):
104
+ * import { gzip, ungzip } from 'fflate';
105
+ * JoopPlatform.init({
106
+ * adapter: {
107
+ * compression: {
108
+ * compress: (d, fmt) => new Promise((res, rej) => gzip(d, (e, r) => e ? rej(e) : res(r))),
109
+ * decompress: (d, fmt) => new Promise((res, rej) => ungzip(d, (e, r) => e ? rej(e) : res(r))),
110
+ * },
111
+ * },
112
+ * });
113
+ */
114
+ static init(config = {}) {
115
+ if (config.platform) this._type = config.platform;
116
+ this._adapter = { ...this._adapter, ...config.adapter ?? {} };
117
+ }
118
+ /** Current detected or overridden platform type */
119
+ static get type() {
120
+ return this._type;
121
+ }
122
+ static is(type) {
123
+ return this._type === type;
124
+ }
125
+ static isMobile() {
126
+ return this._type === "react-native";
127
+ }
128
+ static isWeb() {
129
+ return this._type === "web";
130
+ }
131
+ static isNode() {
132
+ return this._type === "node";
133
+ }
134
+ /** Raw adapter config registered via init() */
135
+ static getAdapter() {
136
+ return this._adapter;
137
+ }
138
+ /**
139
+ * Returns the best available storage adapter:
140
+ * 1. Custom adapter registered via init()
141
+ * 2. localStorage (web)
142
+ * 3. In-memory fallback (Node / RN without adapter)
143
+ */
144
+ static getStorage() {
145
+ if (this._adapter.storage) return this._adapter.storage;
146
+ if (typeof localStorage !== "undefined") return _webStorage(localStorage);
147
+ if (!this._memStorage) this._memStorage = new _MemStorageImpl();
148
+ return this._memStorage;
149
+ }
150
+ /**
151
+ * Returns the best available session-scoped storage:
152
+ * 1. Custom adapter registered via init()
153
+ * 2. sessionStorage (web)
154
+ * 3. Shared in-memory fallback
155
+ */
156
+ static getSessionStorage() {
157
+ if (this._adapter.storage) return this._adapter.storage;
158
+ if (typeof sessionStorage !== "undefined") return _webStorage(sessionStorage);
159
+ if (!this._memStorage) this._memStorage = new _MemStorageImpl();
160
+ return this._memStorage;
161
+ }
162
+ /** What APIs are available in the current environment */
163
+ static capabilities() {
164
+ return {
165
+ compression: typeof CompressionStream !== "undefined" || !!this._adapter.compression,
166
+ workers: typeof Worker !== "undefined" || !!this._adapter.worker,
167
+ cryptoSubtle: !!(typeof globalThis !== "undefined" && globalThis.crypto?.subtle),
168
+ persistentStorage: typeof localStorage !== "undefined" || !!this._adapter.storage,
169
+ dom: typeof document !== "undefined",
170
+ serviceWorker: typeof navigator !== "undefined" && "serviceWorker" in navigator
171
+ };
172
+ }
173
+ /** Reset to auto-detected defaults — useful between tests */
174
+ static _reset() {
175
+ this._type = _detect();
176
+ this._adapter = {};
177
+ this._memStorage = null;
178
+ }
179
+ };
180
+
181
+ // src/device/network-monitor.ts
182
+ var JoopNetworkMonitor = class {
183
+ _adapter;
184
+ _state$;
185
+ _cleanup = [];
186
+ constructor(config = {}) {
187
+ this._adapter = config.adapter ?? JoopPlatform.getAdapter().network ?? null;
188
+ this._state$ = new JoopBehaviorSubject(this._read());
189
+ this._init();
190
+ }
191
+ _init() {
192
+ if (this._adapter) {
193
+ this._state$.next(this._adapter.getState());
194
+ const unsub = this._adapter.onChange((s) => this._state$.next(s));
195
+ this._cleanup.push(unsub);
196
+ return;
197
+ }
198
+ if (typeof window === "undefined") return;
199
+ const refresh = () => this._state$.next(this._read());
200
+ window.addEventListener("online", refresh);
201
+ window.addEventListener("offline", refresh);
202
+ const conn = navigator.connection;
203
+ if (conn) {
204
+ conn.addEventListener("change", refresh);
205
+ this._cleanup.push(() => conn.removeEventListener("change", refresh));
206
+ }
207
+ this._cleanup.push(
208
+ () => window.removeEventListener("online", refresh),
209
+ () => window.removeEventListener("offline", refresh)
210
+ );
211
+ }
212
+ _read() {
213
+ if (this._adapter) return this._adapter.getState();
214
+ if (typeof navigator === "undefined") return { online: false, type: "unknown" };
215
+ const online = navigator.onLine;
216
+ if (!online) return { online: false, type: "offline" };
217
+ const conn = navigator.connection;
218
+ const type = conn ? _mapType(conn.type) : "unknown";
219
+ return {
220
+ online,
221
+ type,
222
+ effectiveType: conn?.effectiveType,
223
+ downlink: conn?.downlink,
224
+ rtt: conn?.rtt,
225
+ saveData: conn?.saveData,
226
+ metered: conn?.metered ?? type === "cellular"
227
+ };
228
+ }
229
+ getState() {
230
+ return this._state$.getValue();
231
+ }
232
+ state$() {
233
+ return this._state$.asObservable();
234
+ }
235
+ isOnline() {
236
+ return this.getState().online;
237
+ }
238
+ isMetered() {
239
+ return this.getState().metered ?? this.getState().type === "cellular";
240
+ }
241
+ /** Call fn when connectivity is regained. */
242
+ onOnline(fn) {
243
+ let prev = this.getState().online;
244
+ return this._state$.subscribe((s) => {
245
+ if (s.online && !prev) fn();
246
+ prev = s.online;
247
+ });
248
+ }
249
+ /** Call fn when connectivity is lost. */
250
+ onOffline(fn) {
251
+ let prev = this.getState().online;
252
+ return this._state$.subscribe((s) => {
253
+ if (!s.online && prev) fn();
254
+ prev = s.online;
255
+ });
256
+ }
257
+ /** Call fn when the connection type changes (e.g. wifi → cellular). */
258
+ onTypeChange(fn) {
259
+ let prev = this.getState().type;
260
+ return this._state$.subscribe((s) => {
261
+ if (s.type !== prev) {
262
+ fn(s.type);
263
+ prev = s.type;
264
+ }
265
+ });
266
+ }
267
+ destroy() {
268
+ for (const fn of this._cleanup) fn();
269
+ this._cleanup = [];
270
+ }
271
+ };
272
+ function _mapType(raw) {
273
+ if (!raw) return "unknown";
274
+ if (raw === "wifi" || raw === "wimax") return "wifi";
275
+ if (raw === "cellular" || raw === "2g" || raw === "3g" || raw === "4g" || raw === "5g") return "cellular";
276
+ if (raw === "ethernet") return "ethernet";
277
+ if (raw === "none" || raw === "offline") return "offline";
278
+ return "unknown";
279
+ }
280
+
281
+ // src/device/app-lifecycle.ts
282
+ var JoopAppLifecycle = class {
283
+ _state$ = new JoopBehaviorSubject("unknown");
284
+ _cleanup = [];
285
+ _adapter;
286
+ constructor(config = {}) {
287
+ this._adapter = config.adapter ?? JoopPlatform.getAdapter().lifecycle ?? null;
288
+ this._init();
289
+ }
290
+ _init() {
291
+ if (this._adapter) {
292
+ this._state$.next(this._adapter.getState());
293
+ const unsub = this._adapter.onChange((s) => this._state$.next(s));
294
+ this._cleanup.push(unsub);
295
+ return;
296
+ }
297
+ if (typeof document === "undefined") {
298
+ this._state$.next("unknown");
299
+ return;
300
+ }
301
+ this._state$.next(document.hidden ? "background" : "active");
302
+ const onVisibility = () => this._state$.next(document.hidden ? "background" : "active");
303
+ const onFocus = () => this._state$.next("active");
304
+ const onBlur = () => this._state$.next("background");
305
+ document.addEventListener("visibilitychange", onVisibility);
306
+ window.addEventListener("focus", onFocus);
307
+ window.addEventListener("blur", onBlur);
308
+ this._cleanup.push(
309
+ () => document.removeEventListener("visibilitychange", onVisibility),
310
+ () => window.removeEventListener("focus", onFocus),
311
+ () => window.removeEventListener("blur", onBlur)
312
+ );
313
+ }
314
+ getState() {
315
+ return this._state$.getValue();
316
+ }
317
+ state$() {
318
+ return this._state$.asObservable();
319
+ }
320
+ isActive() {
321
+ return this.getState() === "active";
322
+ }
323
+ /** Call fn each time the app comes to the foreground (background → active). */
324
+ onForeground(fn) {
325
+ let prev = this.getState();
326
+ return this._state$.subscribe((s) => {
327
+ if (s === "active" && prev !== "active") fn();
328
+ prev = s;
329
+ });
330
+ }
331
+ /** Call fn each time the app goes to the background (active → background). */
332
+ onBackground(fn) {
333
+ let prev = this.getState();
334
+ return this._state$.subscribe((s) => {
335
+ if (s === "background" && prev !== "background") fn();
336
+ prev = s;
337
+ });
338
+ }
339
+ destroy() {
340
+ for (const fn of this._cleanup) fn();
341
+ this._cleanup = [];
342
+ }
343
+ };
344
+
345
+ // src/device/key-vault.ts
346
+ var JoopKeyVault = class {
347
+ _prefix;
348
+ _encKey;
349
+ _adapter;
350
+ _cryptoKey = null;
351
+ constructor(config = {}) {
352
+ this._prefix = config.prefix ?? "joop_vault_";
353
+ this._encKey = config.encryptionKey;
354
+ this._adapter = config.adapter ?? JoopPlatform.getAdapter().keyVault ?? null;
355
+ }
356
+ /** Store a secret. On web: AES-GCM encrypted if `encryptionKey` was provided. */
357
+ async set(key, value) {
358
+ if (this._adapter) return this._adapter.set(key, value);
359
+ const stored = this._encKey ? await _encrypt(value, await this._key()) : btoa(unescape(encodeURIComponent(value)));
360
+ JoopPlatform.getStorage().setItem(this._prefix + key, stored);
361
+ }
362
+ /** Retrieve a secret, or null if not found. */
363
+ async get(key) {
364
+ if (this._adapter) return this._adapter.get(key);
365
+ const raw = JoopPlatform.getStorage().getItem(this._prefix + key);
366
+ if (!raw) return null;
367
+ try {
368
+ return this._encKey ? await _decrypt(raw, await this._key()) : decodeURIComponent(escape(atob(raw)));
369
+ } catch {
370
+ return null;
371
+ }
372
+ }
373
+ async remove(key) {
374
+ if (this._adapter) return this._adapter.remove(key);
375
+ JoopPlatform.getStorage().removeItem(this._prefix + key);
376
+ }
377
+ async clear() {
378
+ if (this._adapter) return this._adapter.clear();
379
+ JoopPlatform.getStorage().clear?.();
380
+ }
381
+ async has(key) {
382
+ return await this.get(key) !== null;
383
+ }
384
+ /** Rotate the encryption key: re-encrypts all known entries with a new key. */
385
+ async rotateKey(newEncryptionKey, keys) {
386
+ if (this._adapter) throw new Error("rotateKey not supported with native adapter");
387
+ const values = await Promise.all(keys.map((k) => this.get(k)));
388
+ this._encKey = newEncryptionKey;
389
+ this._cryptoKey = null;
390
+ for (let i = 0; i < keys.length; i++) {
391
+ if (values[i] !== null) await this.set(keys[i], values[i]);
392
+ }
393
+ }
394
+ async _key() {
395
+ if (!this._cryptoKey) this._cryptoKey = await _deriveKey(this._encKey);
396
+ return this._cryptoKey;
397
+ }
398
+ };
399
+ var _SALT = new Uint8Array([
400
+ 106,
401
+ 111,
402
+ 111,
403
+ 112,
404
+ 45,
405
+ 118,
406
+ 97,
407
+ 117,
408
+ 108,
409
+ 116,
410
+ 45,
411
+ 118,
412
+ 49,
413
+ 0,
414
+ 0,
415
+ 0
416
+ ]);
417
+ async function _deriveKey(password) {
418
+ const km = await crypto.subtle.importKey(
419
+ "raw",
420
+ new TextEncoder().encode(password),
421
+ { name: "PBKDF2" },
422
+ false,
423
+ ["deriveKey"]
424
+ );
425
+ return crypto.subtle.deriveKey(
426
+ { name: "PBKDF2", salt: _SALT, iterations: 1e5, hash: "SHA-256" },
427
+ km,
428
+ { name: "AES-GCM", length: 256 },
429
+ false,
430
+ ["encrypt", "decrypt"]
431
+ );
432
+ }
433
+ async function _encrypt(value, key) {
434
+ const iv = crypto.getRandomValues(new Uint8Array(12));
435
+ const encrypted = await crypto.subtle.encrypt(
436
+ { name: "AES-GCM", iv },
437
+ key,
438
+ new TextEncoder().encode(value)
439
+ );
440
+ const combined = new Uint8Array(12 + encrypted.byteLength);
441
+ combined.set(iv);
442
+ combined.set(new Uint8Array(encrypted), 12);
443
+ return btoa(String.fromCharCode(...combined));
444
+ }
445
+ async function _decrypt(encoded, key) {
446
+ const combined = Uint8Array.from(atob(encoded), (c) => c.charCodeAt(0));
447
+ const iv = combined.slice(0, 12);
448
+ const data = combined.slice(12);
449
+ const decrypted = await crypto.subtle.decrypt({ name: "AES-GCM", iv }, key, data);
450
+ return new TextDecoder().decode(decrypted);
451
+ }
452
+
453
+ // src/vue/index.ts
454
+ function createJoopVue(vue) {
455
+ const { ref, computed, onUnmounted, provide, inject } = vue;
456
+ const JoopKey = /* @__PURE__ */ Symbol("JoopInstance");
457
+ function provideJoop(instance) {
458
+ provide(JoopKey, instance);
459
+ }
460
+ function useJoop() {
461
+ const joop = inject(JoopKey, null);
462
+ if (!joop) throw new Error("[joopjs] useJoop() must be called inside a component where provideJoop() was called");
463
+ return joop;
464
+ }
465
+ function useJoopNetworkMonitor() {
466
+ const monitor = new JoopNetworkMonitor();
467
+ const state = ref(monitor.getState());
468
+ const unsub = monitor.state$().subscribe((s) => {
469
+ state.value = { ...s };
470
+ });
471
+ onUnmounted(() => {
472
+ unsub();
473
+ monitor.destroy();
474
+ });
475
+ return {
476
+ online: computed(() => state.value.online),
477
+ type: computed(() => state.value.type),
478
+ effectiveType: computed(() => state.value.effectiveType),
479
+ isMetered: computed(() => state.value.metered ?? state.value.type === "cellular"),
480
+ monitor
481
+ };
482
+ }
483
+ function useJoopAppLifecycle() {
484
+ const lc = new JoopAppLifecycle();
485
+ const state = ref(lc.getState());
486
+ const unsub = lc.state$().subscribe((s) => {
487
+ state.value = s;
488
+ });
489
+ onUnmounted(() => {
490
+ unsub();
491
+ lc.destroy();
492
+ });
493
+ return {
494
+ state: computed(() => state.value),
495
+ isActive: computed(() => state.value === "active")
496
+ };
497
+ }
498
+ function useJoopKeyVault(key, vaultConfig) {
499
+ const vault = new JoopKeyVault(vaultConfig);
500
+ const value = ref(null);
501
+ const loading = ref(true);
502
+ const refresh = async () => {
503
+ loading.value = true;
504
+ value.value = await vault.get(key);
505
+ loading.value = false;
506
+ };
507
+ refresh();
508
+ return {
509
+ value,
510
+ loading,
511
+ async set(v) {
512
+ await vault.set(key, v);
513
+ value.value = v;
514
+ },
515
+ async remove() {
516
+ await vault.remove(key);
517
+ value.value = null;
518
+ },
519
+ refresh
520
+ };
521
+ }
522
+ function useJoopAuth() {
523
+ const joop = useJoop();
524
+ const isLoggedIn = ref(joop.auth.isLoggedIn());
525
+ const unsub = joop.auth.isLoggedIn$().subscribe((v) => {
526
+ isLoggedIn.value = v;
527
+ });
528
+ onUnmounted(() => unsub());
529
+ return {
530
+ isLoggedIn,
531
+ login: () => joop.auth.setLoggedIn(true),
532
+ logout: () => joop.auth.logout()
533
+ };
534
+ }
535
+ function useJoopTheme() {
536
+ const joop = useJoop();
537
+ const active = ref(joop.theme.getActiveName());
538
+ const themes = computed(() => joop.theme.getMapped());
539
+ const unsub = joop.theme.active$().subscribe((name) => {
540
+ active.value = name;
541
+ });
542
+ onUnmounted(() => unsub());
543
+ return {
544
+ active,
545
+ themes,
546
+ setTheme: (nameOrId) => joop.theme.apply(nameOrId)
547
+ };
548
+ }
549
+ function useJoopI18n() {
550
+ const joop = useJoop();
551
+ const details = joop.i18n.getDetails();
552
+ const language = ref(details.code);
553
+ const direction = ref(details.direction);
554
+ const unsub = joop.i18n.language$().subscribe((lang) => {
555
+ language.value = lang;
556
+ direction.value = joop.i18n.getDirection();
557
+ });
558
+ onUnmounted(() => unsub());
559
+ return {
560
+ language,
561
+ direction,
562
+ t: (key, params) => joop.i18n.t(key, params),
563
+ setLanguage: (lang) => joop.i18n.setLanguage(lang)
564
+ };
565
+ }
566
+ function useJoopLoader() {
567
+ const joop = useJoop();
568
+ const isLoading = ref(joop.loader.isLoading());
569
+ const unsub = joop.loader.isLoading$().subscribe((v) => {
570
+ isLoading.value = v;
571
+ });
572
+ onUnmounted(() => unsub());
573
+ return {
574
+ isLoading,
575
+ show: () => joop.loader.show(),
576
+ hide: () => joop.loader.hide()
577
+ };
578
+ }
579
+ function useJoopConfig(key) {
580
+ const joop = useJoop();
581
+ return computed(() => joop.config.get(key));
582
+ }
583
+ function useJoopFeatureFlag(flagKey, context) {
584
+ const joop = useJoop();
585
+ return {
586
+ enabled: computed(() => joop.featureFlags.isEnabled(flagKey, context)),
587
+ variant: computed(() => joop.featureFlags.getVariant(flagKey, context))
588
+ };
589
+ }
590
+ function useJoopStore(selector) {
591
+ const joop = useJoop();
592
+ const store = joop.store;
593
+ const value = ref(selector(store.getState()));
594
+ const unsub = store.subscribe((s) => {
595
+ value.value = selector(s);
596
+ });
597
+ onUnmounted(() => unsub());
598
+ return value;
599
+ }
600
+ return {
601
+ JoopKey,
602
+ provideJoop,
603
+ useJoop,
604
+ useJoopNetworkMonitor,
605
+ useJoopAppLifecycle,
606
+ useJoopKeyVault,
607
+ useJoopAuth,
608
+ useJoopTheme,
609
+ useJoopI18n,
610
+ useJoopLoader,
611
+ useJoopConfig,
612
+ useJoopFeatureFlag,
613
+ useJoopStore
614
+ };
615
+ }
616
+
617
+ export { createJoopVue };
618
+ //# sourceMappingURL=index.mjs.map
619
+ //# sourceMappingURL=index.mjs.map