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,125 @@
1
+ // src/platform/platform.ts
2
+ var _webStorage = (store) => ({
3
+ getItem: (k) => store.getItem(k),
4
+ setItem: (k, v) => store.setItem(k, v),
5
+ removeItem: (k) => store.removeItem(k),
6
+ clear: () => store.clear()
7
+ });
8
+ var _MemStorageImpl = class {
9
+ _m = /* @__PURE__ */ new Map();
10
+ getItem(k) {
11
+ return this._m.get(k) ?? null;
12
+ }
13
+ setItem(k, v) {
14
+ this._m.set(k, v);
15
+ }
16
+ removeItem(k) {
17
+ this._m.delete(k);
18
+ }
19
+ clear() {
20
+ this._m.clear();
21
+ }
22
+ };
23
+ function _detect() {
24
+ if (typeof navigator !== "undefined" && navigator.product === "ReactNative") return "react-native";
25
+ const _proc = globalThis["process"];
26
+ if (typeof window === "undefined" && _proc?.versions?.node) return "node";
27
+ if (typeof window !== "undefined") return "web";
28
+ return "unknown";
29
+ }
30
+ var JoopPlatform = class {
31
+ static _type = _detect();
32
+ static _adapter = {};
33
+ static _memStorage = null;
34
+ /**
35
+ * Call once at app startup to configure adapters for your platform.
36
+ *
37
+ * Web (default — no call needed):
38
+ * JoopPlatform.init();
39
+ *
40
+ * React Native with react-native-mmkv:
41
+ * import { MMKV } from 'react-native-mmkv';
42
+ * const mmkv = new MMKV();
43
+ * JoopPlatform.init({ adapter: { storage: mmkv } });
44
+ *
45
+ * React Native with custom compression (fflate):
46
+ * import { gzip, ungzip } from 'fflate';
47
+ * JoopPlatform.init({
48
+ * adapter: {
49
+ * compression: {
50
+ * compress: (d, fmt) => new Promise((res, rej) => gzip(d, (e, r) => e ? rej(e) : res(r))),
51
+ * decompress: (d, fmt) => new Promise((res, rej) => ungzip(d, (e, r) => e ? rej(e) : res(r))),
52
+ * },
53
+ * },
54
+ * });
55
+ */
56
+ static init(config = {}) {
57
+ if (config.platform) this._type = config.platform;
58
+ this._adapter = { ...this._adapter, ...config.adapter ?? {} };
59
+ }
60
+ /** Current detected or overridden platform type */
61
+ static get type() {
62
+ return this._type;
63
+ }
64
+ static is(type) {
65
+ return this._type === type;
66
+ }
67
+ static isMobile() {
68
+ return this._type === "react-native";
69
+ }
70
+ static isWeb() {
71
+ return this._type === "web";
72
+ }
73
+ static isNode() {
74
+ return this._type === "node";
75
+ }
76
+ /** Raw adapter config registered via init() */
77
+ static getAdapter() {
78
+ return this._adapter;
79
+ }
80
+ /**
81
+ * Returns the best available storage adapter:
82
+ * 1. Custom adapter registered via init()
83
+ * 2. localStorage (web)
84
+ * 3. In-memory fallback (Node / RN without adapter)
85
+ */
86
+ static getStorage() {
87
+ if (this._adapter.storage) return this._adapter.storage;
88
+ if (typeof localStorage !== "undefined") return _webStorage(localStorage);
89
+ if (!this._memStorage) this._memStorage = new _MemStorageImpl();
90
+ return this._memStorage;
91
+ }
92
+ /**
93
+ * Returns the best available session-scoped storage:
94
+ * 1. Custom adapter registered via init()
95
+ * 2. sessionStorage (web)
96
+ * 3. Shared in-memory fallback
97
+ */
98
+ static getSessionStorage() {
99
+ if (this._adapter.storage) return this._adapter.storage;
100
+ if (typeof sessionStorage !== "undefined") return _webStorage(sessionStorage);
101
+ if (!this._memStorage) this._memStorage = new _MemStorageImpl();
102
+ return this._memStorage;
103
+ }
104
+ /** What APIs are available in the current environment */
105
+ static capabilities() {
106
+ return {
107
+ compression: typeof CompressionStream !== "undefined" || !!this._adapter.compression,
108
+ workers: typeof Worker !== "undefined" || !!this._adapter.worker,
109
+ cryptoSubtle: !!(typeof globalThis !== "undefined" && globalThis.crypto?.subtle),
110
+ persistentStorage: typeof localStorage !== "undefined" || !!this._adapter.storage,
111
+ dom: typeof document !== "undefined",
112
+ serviceWorker: typeof navigator !== "undefined" && "serviceWorker" in navigator
113
+ };
114
+ }
115
+ /** Reset to auto-detected defaults — useful between tests */
116
+ static _reset() {
117
+ this._type = _detect();
118
+ this._adapter = {};
119
+ this._memStorage = null;
120
+ }
121
+ };
122
+
123
+ export { JoopPlatform };
124
+ //# sourceMappingURL=index.mjs.map
125
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/platform/platform.ts"],"names":[],"mappings":"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","file":"index.mjs","sourcesContent":["import type { JoopPlatformAdapterConfig, JoopStorageAdapter } from './adapters';\n\nexport type JoopPlatformType = 'web' | 'react-native' | 'node' | 'unknown';\n\nexport interface JoopCapabilities {\n compression: boolean;\n workers: boolean;\n cryptoSubtle: boolean;\n persistentStorage: boolean;\n dom: boolean;\n serviceWorker: boolean;\n}\n\nexport interface JoopPlatformConfig {\n adapter?: JoopPlatformAdapterConfig;\n /** Override auto-detection — useful in tests or SSR */\n platform?: JoopPlatformType;\n}\n\n// ---------------------------------------------------------------------------\n// Built-in storage adapters\n// ---------------------------------------------------------------------------\n\nconst _webStorage = (store: Storage): JoopStorageAdapter => ({\n getItem: (k) => store.getItem(k),\n setItem: (k, v) => store.setItem(k, v),\n removeItem: (k) => store.removeItem(k),\n clear: () => store.clear(),\n});\n\nclass _MemStorageImpl implements JoopStorageAdapter {\n private _m = new Map<string, string>();\n getItem(k: string) { return this._m.get(k) ?? null; }\n setItem(k: string, v: string) { this._m.set(k, v); }\n removeItem(k: string) { this._m.delete(k); }\n clear() { this._m.clear(); }\n}\n\n// ---------------------------------------------------------------------------\n// Platform detection\n// ---------------------------------------------------------------------------\n\nfunction _detect(): JoopPlatformType {\n // React Native sets navigator.product = 'ReactNative'\n if (typeof navigator !== 'undefined' && navigator.product === 'ReactNative') return 'react-native';\n // Node.js: no window, has globalThis.process.versions.node\n const _proc = (globalThis as Record<string, unknown>)['process'] as { versions?: { node?: string } } | undefined;\n if (typeof window === 'undefined' && _proc?.versions?.node) return 'node';\n // Browser\n if (typeof window !== 'undefined') return 'web';\n return 'unknown';\n}\n\n// ---------------------------------------------------------------------------\n// JoopPlatform\n// ---------------------------------------------------------------------------\n\nexport class JoopPlatform {\n private static _type: JoopPlatformType = _detect();\n private static _adapter: JoopPlatformAdapterConfig = {};\n private static _memStorage: JoopStorageAdapter | null = null;\n\n /**\n * Call once at app startup to configure adapters for your platform.\n *\n * Web (default — no call needed):\n * JoopPlatform.init();\n *\n * React Native with react-native-mmkv:\n * import { MMKV } from 'react-native-mmkv';\n * const mmkv = new MMKV();\n * JoopPlatform.init({ adapter: { storage: mmkv } });\n *\n * React Native with custom compression (fflate):\n * import { gzip, ungzip } from 'fflate';\n * JoopPlatform.init({\n * adapter: {\n * compression: {\n * compress: (d, fmt) => new Promise((res, rej) => gzip(d, (e, r) => e ? rej(e) : res(r))),\n * decompress: (d, fmt) => new Promise((res, rej) => ungzip(d, (e, r) => e ? rej(e) : res(r))),\n * },\n * },\n * });\n */\n static init(config: JoopPlatformConfig = {}): void {\n if (config.platform) this._type = config.platform;\n this._adapter = { ...this._adapter, ...(config.adapter ?? {}) };\n }\n\n /** Current detected or overridden platform type */\n static get type(): JoopPlatformType { return this._type; }\n\n static is(type: JoopPlatformType): boolean { return this._type === type; }\n static isMobile(): boolean { return this._type === 'react-native'; }\n static isWeb(): boolean { return this._type === 'web'; }\n static isNode(): boolean { return this._type === 'node'; }\n\n /** Raw adapter config registered via init() */\n static getAdapter(): JoopPlatformAdapterConfig { return this._adapter; }\n\n /**\n * Returns the best available storage adapter:\n * 1. Custom adapter registered via init()\n * 2. localStorage (web)\n * 3. In-memory fallback (Node / RN without adapter)\n */\n static getStorage(): JoopStorageAdapter {\n if (this._adapter.storage) return this._adapter.storage;\n if (typeof localStorage !== 'undefined') return _webStorage(localStorage);\n if (!this._memStorage) this._memStorage = new _MemStorageImpl();\n return this._memStorage;\n }\n\n /**\n * Returns the best available session-scoped storage:\n * 1. Custom adapter registered via init()\n * 2. sessionStorage (web)\n * 3. Shared in-memory fallback\n */\n static getSessionStorage(): JoopStorageAdapter {\n if (this._adapter.storage) return this._adapter.storage;\n if (typeof sessionStorage !== 'undefined') return _webStorage(sessionStorage);\n if (!this._memStorage) this._memStorage = new _MemStorageImpl();\n return this._memStorage;\n }\n\n /** What APIs are available in the current environment */\n static capabilities(): JoopCapabilities {\n return {\n compression: typeof CompressionStream !== 'undefined' || !!this._adapter.compression,\n workers: typeof Worker !== 'undefined' || !!this._adapter.worker,\n cryptoSubtle: !!(typeof globalThis !== 'undefined' && (globalThis as typeof globalThis & { crypto?: Crypto }).crypto?.subtle),\n persistentStorage: typeof localStorage !== 'undefined' || !!this._adapter.storage,\n dom: typeof document !== 'undefined',\n serviceWorker: typeof navigator !== 'undefined' && 'serviceWorker' in navigator,\n };\n }\n\n /** Reset to auto-detected defaults — useful between tests */\n static _reset(): void {\n this._type = _detect();\n this._adapter = {};\n this._memStorage = null;\n }\n}\n"]}
@@ -0,0 +1,31 @@
1
+ import { J as JoopObservable, a as JoopBehaviorSubject } from '../index-Dz0gOur2.mjs';
2
+ export { a as JoopNotificationOptions, b as JoopNotificationPermission, J as JoopNotificationService } from '../notification.service-Dm4fvfZf.mjs';
3
+
4
+ type JoopSwState = 'unregistered' | 'installing' | 'installed' | 'activating' | 'activated' | 'redundant';
5
+ declare class JoopServiceWorkerService {
6
+ private _reg;
7
+ private _state$;
8
+ private _updateHandlers;
9
+ private _controllerHandlers;
10
+ private _messageHandlers;
11
+ private _swMessageListener;
12
+ private _controllerListener;
13
+ isSupported(): boolean;
14
+ isControlled(): boolean;
15
+ getRegistration(): ServiceWorkerRegistration | null;
16
+ state$(): JoopObservable<JoopSwState>;
17
+ register(scriptUrl: string, options?: RegistrationOptions): Promise<ServiceWorkerRegistration>;
18
+ unregister(): Promise<boolean>;
19
+ update(): Promise<void>;
20
+ postMessage(data: unknown): Promise<void>;
21
+ onUpdateAvailable(handler: () => void): () => void;
22
+ onControllerChange(handler: () => void): () => void;
23
+ onMessage(handler: (data: unknown) => void): () => void;
24
+ isOnline(): boolean;
25
+ onlineState$(): JoopBehaviorSubject<boolean>;
26
+ private _trackState;
27
+ private _listenForUpdates;
28
+ destroy(): void;
29
+ }
30
+
31
+ export { JoopServiceWorkerService };
@@ -0,0 +1,31 @@
1
+ import { J as JoopObservable, a as JoopBehaviorSubject } from '../index-Dz0gOur2.js';
2
+ export { a as JoopNotificationOptions, b as JoopNotificationPermission, J as JoopNotificationService } from '../notification.service-tEMKatWJ.js';
3
+
4
+ type JoopSwState = 'unregistered' | 'installing' | 'installed' | 'activating' | 'activated' | 'redundant';
5
+ declare class JoopServiceWorkerService {
6
+ private _reg;
7
+ private _state$;
8
+ private _updateHandlers;
9
+ private _controllerHandlers;
10
+ private _messageHandlers;
11
+ private _swMessageListener;
12
+ private _controllerListener;
13
+ isSupported(): boolean;
14
+ isControlled(): boolean;
15
+ getRegistration(): ServiceWorkerRegistration | null;
16
+ state$(): JoopObservable<JoopSwState>;
17
+ register(scriptUrl: string, options?: RegistrationOptions): Promise<ServiceWorkerRegistration>;
18
+ unregister(): Promise<boolean>;
19
+ update(): Promise<void>;
20
+ postMessage(data: unknown): Promise<void>;
21
+ onUpdateAvailable(handler: () => void): () => void;
22
+ onControllerChange(handler: () => void): () => void;
23
+ onMessage(handler: (data: unknown) => void): () => void;
24
+ isOnline(): boolean;
25
+ onlineState$(): JoopBehaviorSubject<boolean>;
26
+ private _trackState;
27
+ private _listenForUpdates;
28
+ destroy(): void;
29
+ }
30
+
31
+ export { JoopServiceWorkerService };
@@ -0,0 +1,247 @@
1
+ 'use strict';
2
+
3
+ // src/events/index.ts
4
+ var JoopSubject = class {
5
+ _listeners = [];
6
+ subscribe(listener) {
7
+ this._listeners.push(listener);
8
+ return () => {
9
+ this._listeners = this._listeners.filter((l) => l !== listener);
10
+ };
11
+ }
12
+ next(value) {
13
+ for (const listener of this._listeners) {
14
+ listener(value);
15
+ }
16
+ }
17
+ asObservable() {
18
+ return new JoopObservable((listener) => this.subscribe(listener));
19
+ }
20
+ };
21
+ var JoopBehaviorSubject = class extends JoopSubject {
22
+ _value;
23
+ constructor(initialValue) {
24
+ super();
25
+ this._value = initialValue;
26
+ }
27
+ getValue() {
28
+ return this._value;
29
+ }
30
+ next(value) {
31
+ this._value = value;
32
+ super.next(value);
33
+ }
34
+ subscribe(listener) {
35
+ listener(this._value);
36
+ return super.subscribe(listener);
37
+ }
38
+ asObservable() {
39
+ return new JoopObservable((listener) => this.subscribe(listener));
40
+ }
41
+ };
42
+ var JoopObservable = class {
43
+ constructor(_subscribeFn) {
44
+ this._subscribeFn = _subscribeFn;
45
+ }
46
+ _subscribeFn;
47
+ subscribe(listener) {
48
+ return this._subscribeFn(listener);
49
+ }
50
+ /** Returns the current value without subscribing (only meaningful for BehaviorSubject-backed observables). */
51
+ getOnce() {
52
+ let result;
53
+ const unsub = this.subscribe((v) => {
54
+ result = v;
55
+ });
56
+ unsub();
57
+ return result;
58
+ }
59
+ };
60
+
61
+ // src/pwa/service-worker.service.ts
62
+ var JoopServiceWorkerService = class {
63
+ _reg = null;
64
+ _state$ = new JoopBehaviorSubject("unregistered");
65
+ _updateHandlers = [];
66
+ _controllerHandlers = [];
67
+ _messageHandlers = [];
68
+ _swMessageListener = null;
69
+ _controllerListener = null;
70
+ isSupported() {
71
+ return "serviceWorker" in navigator;
72
+ }
73
+ isControlled() {
74
+ return !!navigator.serviceWorker?.controller;
75
+ }
76
+ getRegistration() {
77
+ return this._reg;
78
+ }
79
+ state$() {
80
+ return this._state$.asObservable();
81
+ }
82
+ async register(scriptUrl, options) {
83
+ if (!this.isSupported()) throw new Error("ServiceWorker not supported");
84
+ this._reg = await navigator.serviceWorker.register(scriptUrl, options);
85
+ this._trackState(this._reg);
86
+ this._listenForUpdates(this._reg);
87
+ this._swMessageListener = (e) => {
88
+ this._messageHandlers.forEach((h) => h(e.data));
89
+ };
90
+ navigator.serviceWorker.addEventListener("message", this._swMessageListener);
91
+ this._controllerListener = () => {
92
+ this._controllerHandlers.forEach((h) => h());
93
+ };
94
+ navigator.serviceWorker.addEventListener("controllerchange", this._controllerListener);
95
+ return this._reg;
96
+ }
97
+ async unregister() {
98
+ if (!this._reg) return false;
99
+ const result = await this._reg.unregister();
100
+ if (result) {
101
+ this._reg = null;
102
+ this._state$.next("unregistered");
103
+ }
104
+ return result;
105
+ }
106
+ async update() {
107
+ if (!this._reg) throw new Error("No service worker registered");
108
+ await this._reg.update();
109
+ }
110
+ async postMessage(data) {
111
+ if (!this._reg?.active) throw new Error("No active service worker");
112
+ this._reg.active.postMessage(data);
113
+ }
114
+ onUpdateAvailable(handler) {
115
+ this._updateHandlers.push(handler);
116
+ return () => {
117
+ this._updateHandlers = this._updateHandlers.filter((h) => h !== handler);
118
+ };
119
+ }
120
+ onControllerChange(handler) {
121
+ this._controllerHandlers.push(handler);
122
+ return () => {
123
+ this._controllerHandlers = this._controllerHandlers.filter((h) => h !== handler);
124
+ };
125
+ }
126
+ onMessage(handler) {
127
+ this._messageHandlers.push(handler);
128
+ return () => {
129
+ this._messageHandlers = this._messageHandlers.filter((h) => h !== handler);
130
+ };
131
+ }
132
+ isOnline() {
133
+ return navigator.onLine;
134
+ }
135
+ onlineState$() {
136
+ const s$ = new JoopBehaviorSubject(navigator.onLine);
137
+ window.addEventListener("online", () => s$.next(true));
138
+ window.addEventListener("offline", () => s$.next(false));
139
+ return s$;
140
+ }
141
+ _trackState(reg) {
142
+ const sw = reg.installing ?? reg.waiting ?? reg.active;
143
+ if (sw) this._state$.next(sw.state);
144
+ const track = (worker) => {
145
+ if (!worker) return;
146
+ worker.addEventListener("statechange", () => this._state$.next(worker.state));
147
+ };
148
+ track(reg.installing);
149
+ track(reg.waiting);
150
+ track(reg.active);
151
+ reg.addEventListener("updatefound", () => track(reg.installing));
152
+ }
153
+ _listenForUpdates(reg) {
154
+ reg.addEventListener("updatefound", () => {
155
+ const newSw = reg.installing;
156
+ if (!newSw) return;
157
+ newSw.addEventListener("statechange", () => {
158
+ if (newSw.state === "installed" && navigator.serviceWorker.controller) {
159
+ this._updateHandlers.forEach((h) => h());
160
+ }
161
+ });
162
+ });
163
+ }
164
+ destroy() {
165
+ if (this._swMessageListener) navigator.serviceWorker?.removeEventListener("message", this._swMessageListener);
166
+ if (this._controllerListener) navigator.serviceWorker?.removeEventListener("controllerchange", this._controllerListener);
167
+ this._updateHandlers = [];
168
+ this._controllerHandlers = [];
169
+ this._messageHandlers = [];
170
+ }
171
+ };
172
+
173
+ // src/utilities/notification.service.ts
174
+ var JoopNotificationService = class {
175
+ _permission$ = new JoopBehaviorSubject(
176
+ typeof Notification !== "undefined" ? Notification.permission : "default"
177
+ );
178
+ _messageHandlers = [];
179
+ _swReg = null;
180
+ isSupported() {
181
+ return typeof Notification !== "undefined";
182
+ }
183
+ getPermission() {
184
+ return this._permission$.getValue();
185
+ }
186
+ permission$() {
187
+ return this._permission$.asObservable();
188
+ }
189
+ async requestPermission() {
190
+ if (!this.isSupported()) return "denied";
191
+ const result = await Notification.requestPermission();
192
+ this._permission$.next(result);
193
+ return result;
194
+ }
195
+ async show(title, options = {}) {
196
+ if (this._permission$.getValue() !== "granted") {
197
+ const p = await this.requestPermission();
198
+ if (p !== "granted") return null;
199
+ }
200
+ if (this._swReg) {
201
+ await this._swReg.showNotification(title, options);
202
+ return null;
203
+ }
204
+ return new Notification(title, options);
205
+ }
206
+ async setServiceWorker(reg) {
207
+ this._swReg = reg;
208
+ }
209
+ async subscribe(vapidPublicKey) {
210
+ if (!this._swReg) throw new Error("JoopNotification: ServiceWorkerRegistration required");
211
+ const key = _urlBase64ToUint8Array(vapidPublicKey);
212
+ return this._swReg.pushManager.subscribe({ userVisibleOnly: true, applicationServerKey: key });
213
+ }
214
+ async unsubscribe() {
215
+ if (!this._swReg) return false;
216
+ const sub = await this._swReg.pushManager.getSubscription();
217
+ if (!sub) return false;
218
+ return sub.unsubscribe();
219
+ }
220
+ async getSubscription() {
221
+ if (!this._swReg) return null;
222
+ return this._swReg.pushManager.getSubscription();
223
+ }
224
+ onMessage(handler) {
225
+ this._messageHandlers.push(handler);
226
+ navigator.serviceWorker?.addEventListener("message", handler);
227
+ return () => {
228
+ this._messageHandlers = this._messageHandlers.filter((h) => h !== handler);
229
+ navigator.serviceWorker?.removeEventListener("message", handler);
230
+ };
231
+ }
232
+ destroy() {
233
+ for (const h of this._messageHandlers) navigator.serviceWorker?.removeEventListener("message", h);
234
+ this._messageHandlers = [];
235
+ }
236
+ };
237
+ function _urlBase64ToUint8Array(base64String) {
238
+ const padding = "=".repeat((4 - base64String.length % 4) % 4);
239
+ const base64 = (base64String + padding).replace(/-/g, "+").replace(/_/g, "/");
240
+ const raw = atob(base64);
241
+ return new Uint8Array(Array.from(raw, (c) => c.charCodeAt(0)));
242
+ }
243
+
244
+ exports.JoopNotificationService = JoopNotificationService;
245
+ exports.JoopServiceWorkerService = JoopServiceWorkerService;
246
+ //# sourceMappingURL=index.js.map
247
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/events/index.ts","../../src/pwa/service-worker.service.ts","../../src/utilities/notification.service.ts"],"names":[],"mappings":"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","file":"index.js","sourcesContent":["export type Unsubscribe = () => void;\nexport type Listener<T> = (value: T) => void;\n\n/**\n * Lightweight pub/sub subject — emits to all current subscribers.\n * Replaces RxJS Subject without pulling in the full RxJS dependency.\n */\nexport class JoopSubject<T> {\n private _listeners: Listener<T>[] = [];\n\n subscribe(listener: Listener<T>): Unsubscribe {\n this._listeners.push(listener);\n return () => {\n this._listeners = this._listeners.filter(l => l !== listener);\n };\n }\n\n next(value: T): void {\n for (const listener of this._listeners) {\n listener(value);\n }\n }\n\n asObservable(): JoopObservable<T> {\n return new JoopObservable<T>(listener => this.subscribe(listener));\n }\n}\n\n/**\n * Stateful subject — replays the current value to any new subscriber immediately.\n * Replaces RxJS BehaviorSubject.\n */\nexport class JoopBehaviorSubject<T> extends JoopSubject<T> {\n private _value: T;\n\n constructor(initialValue: T) {\n super();\n this._value = initialValue;\n }\n\n getValue(): T {\n return this._value;\n }\n\n override next(value: T): void {\n this._value = value;\n super.next(value);\n }\n\n override subscribe(listener: Listener<T>): Unsubscribe {\n listener(this._value);\n return super.subscribe(listener);\n }\n\n override asObservable(): JoopObservable<T> {\n return new JoopObservable<T>(listener => this.subscribe(listener));\n }\n}\n\n/**\n * Read-only observable handle returned from asObservable().\n */\nexport class JoopObservable<T> {\n constructor(private _subscribeFn: (listener: Listener<T>) => Unsubscribe) {}\n\n subscribe(listener: Listener<T>): Unsubscribe {\n return this._subscribeFn(listener);\n }\n\n /** Returns the current value without subscribing (only meaningful for BehaviorSubject-backed observables). */\n getOnce(): T | undefined {\n let result: T | undefined;\n const unsub = this.subscribe(v => { result = v; });\n unsub();\n return result;\n }\n}\n","import { JoopBehaviorSubject } from '../events';\n\nexport type JoopSwState = 'unregistered' | 'installing' | 'installed' | 'activating' | 'activated' | 'redundant';\n\nexport class JoopServiceWorkerService {\n private _reg: ServiceWorkerRegistration | null = null;\n private _state$ = new JoopBehaviorSubject<JoopSwState>('unregistered');\n private _updateHandlers: Array<() => void> = [];\n private _controllerHandlers: Array<() => void> = [];\n private _messageHandlers: Array<(data: unknown) => void> = [];\n private _swMessageListener: ((e: MessageEvent) => void) | null = null;\n private _controllerListener: (() => void) | null = null;\n\n isSupported(): boolean { return 'serviceWorker' in navigator; }\n isControlled(): boolean { return !!navigator.serviceWorker?.controller; }\n getRegistration(): ServiceWorkerRegistration | null { return this._reg; }\n state$() { return this._state$.asObservable(); }\n\n async register(scriptUrl: string, options?: RegistrationOptions): Promise<ServiceWorkerRegistration> {\n if (!this.isSupported()) throw new Error('ServiceWorker not supported');\n this._reg = await navigator.serviceWorker.register(scriptUrl, options);\n this._trackState(this._reg);\n this._listenForUpdates(this._reg);\n\n this._swMessageListener = (e: MessageEvent) => { this._messageHandlers.forEach(h => h(e.data)); };\n navigator.serviceWorker.addEventListener('message', this._swMessageListener);\n\n this._controllerListener = () => { this._controllerHandlers.forEach(h => h()); };\n navigator.serviceWorker.addEventListener('controllerchange', this._controllerListener);\n\n return this._reg;\n }\n\n async unregister(): Promise<boolean> {\n if (!this._reg) return false;\n const result = await this._reg.unregister();\n if (result) { this._reg = null; this._state$.next('unregistered'); }\n return result;\n }\n\n async update(): Promise<void> {\n if (!this._reg) throw new Error('No service worker registered');\n await this._reg.update();\n }\n\n async postMessage(data: unknown): Promise<void> {\n if (!this._reg?.active) throw new Error('No active service worker');\n this._reg.active.postMessage(data);\n }\n\n onUpdateAvailable(handler: () => void): () => void {\n this._updateHandlers.push(handler);\n return () => { this._updateHandlers = this._updateHandlers.filter(h => h !== handler); };\n }\n\n onControllerChange(handler: () => void): () => void {\n this._controllerHandlers.push(handler);\n return () => { this._controllerHandlers = this._controllerHandlers.filter(h => h !== handler); };\n }\n\n onMessage(handler: (data: unknown) => void): () => void {\n this._messageHandlers.push(handler);\n return () => { this._messageHandlers = this._messageHandlers.filter(h => h !== handler); };\n }\n\n isOnline(): boolean { return navigator.onLine; }\n\n onlineState$(): JoopBehaviorSubject<boolean> {\n const s$ = new JoopBehaviorSubject<boolean>(navigator.onLine);\n window.addEventListener('online', () => s$.next(true));\n window.addEventListener('offline', () => s$.next(false));\n return s$;\n }\n\n private _trackState(reg: ServiceWorkerRegistration): void {\n const sw = reg.installing ?? reg.waiting ?? reg.active;\n if (sw) this._state$.next(sw.state as JoopSwState);\n const track = (worker: ServiceWorker | null) => {\n if (!worker) return;\n worker.addEventListener('statechange', () => this._state$.next(worker.state as JoopSwState));\n };\n track(reg.installing); track(reg.waiting); track(reg.active);\n reg.addEventListener('updatefound', () => track(reg.installing));\n }\n\n private _listenForUpdates(reg: ServiceWorkerRegistration): void {\n reg.addEventListener('updatefound', () => {\n const newSw = reg.installing;\n if (!newSw) return;\n newSw.addEventListener('statechange', () => {\n if (newSw.state === 'installed' && navigator.serviceWorker.controller) {\n this._updateHandlers.forEach(h => h());\n }\n });\n });\n }\n\n destroy(): void {\n if (this._swMessageListener) navigator.serviceWorker?.removeEventListener('message', this._swMessageListener);\n if (this._controllerListener) navigator.serviceWorker?.removeEventListener('controllerchange', this._controllerListener);\n this._updateHandlers = []; this._controllerHandlers = []; this._messageHandlers = [];\n }\n}\n","import { JoopBehaviorSubject } from '../events';\n\nexport type JoopNotificationPermission = 'default' | 'granted' | 'denied';\n\nexport interface JoopNotificationOptions extends NotificationOptions {\n tag?: string;\n requireInteraction?: boolean;\n}\n\nexport class JoopNotificationService {\n private _permission$ = new JoopBehaviorSubject<JoopNotificationPermission>(\n typeof Notification !== 'undefined' ? Notification.permission as JoopNotificationPermission : 'default',\n );\n private _messageHandlers: Array<(event: MessageEvent) => void> = [];\n private _swReg: ServiceWorkerRegistration | null = null;\n\n isSupported(): boolean { return typeof Notification !== 'undefined'; }\n\n getPermission(): JoopNotificationPermission { return this._permission$.getValue(); }\n permission$() { return this._permission$.asObservable(); }\n\n async requestPermission(): Promise<JoopNotificationPermission> {\n if (!this.isSupported()) return 'denied';\n const result = await Notification.requestPermission() as JoopNotificationPermission;\n this._permission$.next(result);\n return result;\n }\n\n async show(title: string, options: JoopNotificationOptions = {}): Promise<Notification | null> {\n if (this._permission$.getValue() !== 'granted') {\n const p = await this.requestPermission();\n if (p !== 'granted') return null;\n }\n if (this._swReg) {\n await this._swReg.showNotification(title, options);\n return null;\n }\n return new Notification(title, options);\n }\n\n async setServiceWorker(reg: ServiceWorkerRegistration): Promise<void> {\n this._swReg = reg;\n }\n\n async subscribe(vapidPublicKey: string): Promise<PushSubscription | null> {\n if (!this._swReg) throw new Error('JoopNotification: ServiceWorkerRegistration required');\n const key = _urlBase64ToUint8Array(vapidPublicKey);\n return this._swReg.pushManager.subscribe({ userVisibleOnly: true, applicationServerKey: key });\n }\n\n async unsubscribe(): Promise<boolean> {\n if (!this._swReg) return false;\n const sub = await this._swReg.pushManager.getSubscription();\n if (!sub) return false;\n return sub.unsubscribe();\n }\n\n async getSubscription(): Promise<PushSubscription | null> {\n if (!this._swReg) return null;\n return this._swReg.pushManager.getSubscription();\n }\n\n onMessage(handler: (event: MessageEvent) => void): () => void {\n this._messageHandlers.push(handler);\n navigator.serviceWorker?.addEventListener('message', handler);\n return () => {\n this._messageHandlers = this._messageHandlers.filter(h => h !== handler);\n navigator.serviceWorker?.removeEventListener('message', handler);\n };\n }\n\n destroy(): void {\n for (const h of this._messageHandlers) navigator.serviceWorker?.removeEventListener('message', h);\n this._messageHandlers = [];\n }\n}\n\nfunction _urlBase64ToUint8Array(base64String: string): Uint8Array<ArrayBuffer> {\n const padding = '='.repeat((4 - (base64String.length % 4)) % 4);\n const base64 = (base64String + padding).replace(/-/g, '+').replace(/_/g, '/');\n const raw = atob(base64);\n return new Uint8Array(Array.from(raw, c => c.charCodeAt(0)));\n}\n"]}