synapse-storage 3.0.19 → 4.0.1

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 (351) hide show
  1. package/README.md +28 -168
  2. package/dist/_utils/chunk.util.d.ts +8 -0
  3. package/dist/_utils/chunk.util.d.ts.map +1 -0
  4. package/dist/_utils/chunk.util.js +21 -0
  5. package/dist/_utils/chunk.util.js.map +1 -0
  6. package/dist/_utils/deepMerge.util.d.ts +2 -0
  7. package/dist/_utils/deepMerge.util.d.ts.map +1 -0
  8. package/dist/_utils/deepMerge.util.js +19 -0
  9. package/dist/_utils/deepMerge.util.js.map +1 -0
  10. package/dist/_utils/error-handling.util.d.ts +50 -0
  11. package/dist/_utils/error-handling.util.d.ts.map +1 -0
  12. package/dist/_utils/error-handling.util.js +67 -0
  13. package/dist/_utils/error-handling.util.js.map +1 -0
  14. package/dist/_utils/flatMap.util.d.ts +10 -0
  15. package/dist/_utils/flatMap.util.d.ts.map +1 -0
  16. package/dist/_utils/flatMap.util.js +23 -0
  17. package/dist/_utils/flatMap.util.js.map +1 -0
  18. package/dist/_utils/index.d.ts +6 -0
  19. package/dist/_utils/index.d.ts.map +1 -0
  20. package/dist/_utils/index.js +13 -0
  21. package/dist/_utils/index.js.map +1 -0
  22. package/dist/_utils/logger-console.util.d.ts +9 -0
  23. package/dist/_utils/logger-console.util.d.ts.map +1 -0
  24. package/dist/_utils/logger-console.util.js +14 -0
  25. package/dist/_utils/logger-console.util.js.map +1 -0
  26. package/dist/api/api.module.d.ts +46 -0
  27. package/dist/api/api.module.d.ts.map +1 -0
  28. package/dist/api/api.module.js +121 -0
  29. package/dist/api/api.module.js.map +1 -0
  30. package/dist/api/components/endpoint.d.ts +57 -0
  31. package/dist/api/components/endpoint.d.ts.map +1 -0
  32. package/dist/api/components/endpoint.js +385 -0
  33. package/dist/api/components/endpoint.js.map +1 -0
  34. package/dist/api/components/query-storage.d.ts +100 -0
  35. package/dist/api/components/query-storage.d.ts.map +1 -0
  36. package/dist/api/components/query-storage.js +293 -0
  37. package/dist/api/components/query-storage.js.map +1 -0
  38. package/dist/api/example.d.ts +83 -0
  39. package/dist/api/example.d.ts.map +1 -0
  40. package/dist/api/example.js +90 -0
  41. package/dist/api/example.js.map +1 -0
  42. package/dist/api/index.d.ts +4 -0
  43. package/dist/api/index.d.ts.map +1 -0
  44. package/dist/api/index.js +11 -0
  45. package/dist/api/index.js.map +1 -0
  46. package/dist/api/types/api.interface.d.ts +126 -0
  47. package/dist/api/types/api.interface.d.ts.map +1 -0
  48. package/dist/api/types/api.interface.js +15 -0
  49. package/dist/api/types/api.interface.js.map +1 -0
  50. package/dist/api/types/endpoint.interface.d.ts +118 -0
  51. package/dist/api/types/endpoint.interface.d.ts.map +1 -0
  52. package/dist/api/types/endpoint.interface.js +6 -0
  53. package/dist/api/types/endpoint.interface.js.map +1 -0
  54. package/dist/api/types/query.interface.d.ts +85 -0
  55. package/dist/api/types/query.interface.d.ts.map +1 -0
  56. package/dist/api/types/query.interface.js +6 -0
  57. package/dist/api/types/query.interface.js.map +1 -0
  58. package/dist/api/utils/api-helpers.d.ts +22 -0
  59. package/dist/api/utils/api-helpers.d.ts.map +1 -0
  60. package/dist/api/utils/api-helpers.js +44 -0
  61. package/dist/api/utils/api-helpers.js.map +1 -0
  62. package/dist/api/utils/create-header-context.d.ts +10 -0
  63. package/dist/api/utils/create-header-context.d.ts.map +1 -0
  64. package/dist/api/utils/create-header-context.js +40 -0
  65. package/dist/api/utils/create-header-context.js.map +1 -0
  66. package/dist/api/utils/endpoint-headers.d.ts +23 -0
  67. package/dist/api/utils/endpoint-headers.d.ts.map +1 -0
  68. package/dist/api/utils/endpoint-headers.js +61 -0
  69. package/dist/api/utils/endpoint-headers.js.map +1 -0
  70. package/dist/api/utils/fetch-base-query.d.ts +9 -0
  71. package/dist/api/utils/fetch-base-query.d.ts.map +1 -0
  72. package/dist/api/utils/fetch-base-query.js +242 -0
  73. package/dist/api/utils/fetch-base-query.js.map +1 -0
  74. package/dist/api/utils/file-utils.d.ts +43 -0
  75. package/dist/api/utils/file-utils.d.ts.map +1 -0
  76. package/dist/api/utils/file-utils.js +102 -0
  77. package/dist/api/utils/file-utils.js.map +1 -0
  78. package/dist/api/utils/get-cacheable-headers.d.ts +8 -0
  79. package/dist/api/utils/get-cacheable-headers.d.ts.map +1 -0
  80. package/dist/api/utils/get-cacheable-headers.js +23 -0
  81. package/dist/api/utils/get-cacheable-headers.js.map +1 -0
  82. package/dist/core/index.d.ts +3 -0
  83. package/dist/core/index.d.ts.map +1 -0
  84. package/dist/core/index.js +7 -0
  85. package/dist/core/index.js.map +1 -0
  86. package/dist/core/selector/index.d.ts +3 -0
  87. package/dist/core/selector/index.d.ts.map +1 -0
  88. package/dist/core/selector/index.js +5 -0
  89. package/dist/core/selector/index.js.map +1 -0
  90. package/dist/{selector.interface-CA5y-kD_.d.ts → core/selector/selector.interface.d.ts} +41 -8
  91. package/dist/core/selector/selector.interface.d.ts.map +1 -0
  92. package/dist/core/selector/selector.interface.js +7 -0
  93. package/dist/core/selector/selector.interface.js.map +1 -0
  94. package/dist/core/selector/selector.module.d.ts +36 -0
  95. package/dist/core/selector/selector.module.d.ts.map +1 -0
  96. package/dist/core/selector/selector.module.js +412 -0
  97. package/dist/core/selector/selector.module.js.map +1 -0
  98. package/dist/core/storage/adapters/async-base-storage.service.d.ts +49 -0
  99. package/dist/core/storage/adapters/async-base-storage.service.d.ts.map +1 -0
  100. package/dist/core/storage/adapters/async-base-storage.service.js +505 -0
  101. package/dist/core/storage/adapters/async-base-storage.service.js.map +1 -0
  102. package/dist/core/storage/adapters/indexed-DB.service.d.ts +89 -0
  103. package/dist/core/storage/adapters/indexed-DB.service.d.ts.map +1 -0
  104. package/dist/core/storage/adapters/indexed-DB.service.js +596 -0
  105. package/dist/core/storage/adapters/indexed-DB.service.js.map +1 -0
  106. package/dist/core/storage/adapters/local-storage.service.d.ts +23 -0
  107. package/dist/core/storage/adapters/local-storage.service.d.ts.map +1 -0
  108. package/dist/core/storage/adapters/local-storage.service.js +111 -0
  109. package/dist/core/storage/adapters/local-storage.service.js.map +1 -0
  110. package/dist/core/storage/adapters/memory-storage.service.d.ts +24 -0
  111. package/dist/core/storage/adapters/memory-storage.service.d.ts.map +1 -0
  112. package/dist/core/storage/adapters/memory-storage.service.js +110 -0
  113. package/dist/core/storage/adapters/memory-storage.service.js.map +1 -0
  114. package/dist/core/storage/adapters/path.utils.d.ts +5 -0
  115. package/dist/core/storage/adapters/path.utils.d.ts.map +1 -0
  116. package/dist/core/storage/adapters/path.utils.js +42 -0
  117. package/dist/core/storage/adapters/path.utils.js.map +1 -0
  118. package/dist/core/storage/adapters/storage-core.d.ts +61 -0
  119. package/dist/core/storage/adapters/storage-core.d.ts.map +1 -0
  120. package/dist/core/storage/adapters/storage-core.js +221 -0
  121. package/dist/core/storage/adapters/storage-core.js.map +1 -0
  122. package/dist/core/storage/adapters/sync-base-storage.service.d.ts +56 -0
  123. package/dist/core/storage/adapters/sync-base-storage.service.d.ts.map +1 -0
  124. package/dist/core/storage/adapters/sync-base-storage.service.js +481 -0
  125. package/dist/core/storage/adapters/sync-base-storage.service.js.map +1 -0
  126. package/dist/core/storage/index.d.ts +16 -0
  127. package/dist/core/storage/index.d.ts.map +1 -0
  128. package/dist/core/storage/index.js +38 -0
  129. package/dist/core/storage/index.js.map +1 -0
  130. package/dist/core/storage/middlewares/broadcast.middleware.d.ts +9 -0
  131. package/dist/core/storage/middlewares/broadcast.middleware.d.ts.map +1 -0
  132. package/dist/core/storage/middlewares/broadcast.middleware.js +197 -0
  133. package/dist/core/storage/middlewares/broadcast.middleware.js.map +1 -0
  134. package/dist/core/storage/middlewares/index.d.ts +9 -0
  135. package/dist/core/storage/middlewares/index.d.ts.map +1 -0
  136. package/dist/core/storage/middlewares/index.js +17 -0
  137. package/dist/core/storage/middlewares/index.js.map +1 -0
  138. package/dist/core/storage/middlewares/storage-batching.middleware.d.ts +7 -0
  139. package/dist/core/storage/middlewares/storage-batching.middleware.d.ts.map +1 -0
  140. package/dist/core/storage/middlewares/storage-batching.middleware.js +108 -0
  141. package/dist/core/storage/middlewares/storage-batching.middleware.js.map +1 -0
  142. package/dist/core/storage/middlewares/storage-shallow-compare.middleware.d.ts +7 -0
  143. package/dist/core/storage/middlewares/storage-shallow-compare.middleware.d.ts.map +1 -0
  144. package/dist/core/storage/middlewares/storage-shallow-compare.middleware.js +43 -0
  145. package/dist/core/storage/middlewares/storage-shallow-compare.middleware.js.map +1 -0
  146. package/dist/core/storage/middlewares/sync-broadcast.middleware.d.ts +9 -0
  147. package/dist/core/storage/middlewares/sync-broadcast.middleware.d.ts.map +1 -0
  148. package/dist/core/storage/middlewares/sync-broadcast.middleware.js +177 -0
  149. package/dist/core/storage/middlewares/sync-broadcast.middleware.js.map +1 -0
  150. package/dist/core/storage/middlewares/sync-storage-batching.middleware.d.ts +6 -0
  151. package/dist/core/storage/middlewares/sync-storage-batching.middleware.d.ts.map +1 -0
  152. package/dist/core/storage/middlewares/sync-storage-batching.middleware.js +56 -0
  153. package/dist/core/storage/middlewares/sync-storage-batching.middleware.js.map +1 -0
  154. package/dist/core/storage/middlewares/sync-storage-shallow-compare.middleware.d.ts +7 -0
  155. package/dist/core/storage/middlewares/sync-storage-shallow-compare.middleware.d.ts.map +1 -0
  156. package/dist/core/storage/middlewares/sync-storage-shallow-compare.middleware.js +39 -0
  157. package/dist/core/storage/middlewares/sync-storage-shallow-compare.middleware.js.map +1 -0
  158. package/dist/core/storage/modules/plugin/plugin.interface.d.ts +101 -0
  159. package/dist/core/storage/modules/plugin/plugin.interface.d.ts.map +1 -0
  160. package/dist/core/storage/modules/plugin/plugin.interface.js +8 -0
  161. package/dist/core/storage/modules/plugin/plugin.interface.js.map +1 -0
  162. package/dist/core/storage/modules/plugin/plugin.service.d.ts +49 -0
  163. package/dist/core/storage/modules/plugin/plugin.service.d.ts.map +1 -0
  164. package/dist/core/storage/modules/plugin/plugin.service.js +406 -0
  165. package/dist/core/storage/modules/plugin/plugin.service.js.map +1 -0
  166. package/dist/core/storage/modules/singleton/mixin.util.d.ts +6 -0
  167. package/dist/core/storage/modules/singleton/mixin.util.d.ts.map +1 -0
  168. package/dist/core/storage/modules/singleton/mixin.util.js +30 -0
  169. package/dist/core/storage/modules/singleton/mixin.util.js.map +1 -0
  170. package/dist/core/storage/modules/singleton/models.d.ts +143 -0
  171. package/dist/core/storage/modules/singleton/models.d.ts.map +1 -0
  172. package/dist/core/storage/modules/singleton/models.js +60 -0
  173. package/dist/core/storage/modules/singleton/models.js.map +1 -0
  174. package/dist/core/storage/modules/singleton/singleton.util.d.ts +36 -0
  175. package/dist/core/storage/modules/singleton/singleton.util.d.ts.map +1 -0
  176. package/dist/core/storage/modules/singleton/singleton.util.js +216 -0
  177. package/dist/core/storage/modules/singleton/singleton.util.js.map +1 -0
  178. package/dist/core/storage/storage.interface.d.ts +168 -0
  179. package/dist/core/storage/storage.interface.d.ts.map +1 -0
  180. package/dist/core/storage/storage.interface.js +23 -0
  181. package/dist/core/storage/storage.interface.js.map +1 -0
  182. package/dist/core/storage/utils/broadcast.util.d.ts +49 -0
  183. package/dist/core/storage/utils/broadcast.util.d.ts.map +1 -0
  184. package/dist/core/storage/utils/broadcast.util.js +141 -0
  185. package/dist/core/storage/utils/broadcast.util.js.map +1 -0
  186. package/dist/core/storage/utils/cache.util.d.ts +33 -0
  187. package/dist/core/storage/utils/cache.util.d.ts.map +1 -0
  188. package/dist/core/storage/utils/cache.util.js +54 -0
  189. package/dist/core/storage/utils/cache.util.js.map +1 -0
  190. package/dist/core/storage/utils/middleware-module.d.ts +94 -0
  191. package/dist/core/storage/utils/middleware-module.d.ts.map +1 -0
  192. package/dist/core/storage/utils/middleware-module.js +258 -0
  193. package/dist/core/storage/utils/middleware-module.js.map +1 -0
  194. package/dist/core/storage/utils/path-selector.util.d.ts +15 -0
  195. package/dist/core/storage/utils/path-selector.util.d.ts.map +1 -0
  196. package/dist/core/storage/utils/path-selector.util.js +58 -0
  197. package/dist/core/storage/utils/path-selector.util.js.map +1 -0
  198. package/dist/core/storage/utils/state-diff.util.d.ts +14 -0
  199. package/dist/core/storage/utils/state-diff.util.d.ts.map +1 -0
  200. package/dist/core/storage/utils/state-diff.util.js +88 -0
  201. package/dist/core/storage/utils/state-diff.util.js.map +1 -0
  202. package/dist/core/storage/utils/storage-factory.util.d.ts +21 -0
  203. package/dist/core/storage/utils/storage-factory.util.d.ts.map +1 -0
  204. package/dist/core/storage/utils/storage-factory.util.js +40 -0
  205. package/dist/core/storage/utils/storage-factory.util.js.map +1 -0
  206. package/dist/core/storage/utils/storage-key.d.ts +11 -0
  207. package/dist/core/storage/utils/storage-key.d.ts.map +1 -0
  208. package/dist/core/storage/utils/storage-key.js +24 -0
  209. package/dist/core/storage/utils/storage-key.js.map +1 -0
  210. package/dist/core/storage/utils/storage.utils.d.ts +17 -0
  211. package/dist/core/storage/utils/storage.utils.d.ts.map +1 -0
  212. package/dist/core/storage/utils/storage.utils.js +57 -0
  213. package/dist/core/storage/utils/storage.utils.js.map +1 -0
  214. package/dist/index.d.ts +10 -12
  215. package/dist/index.d.ts.map +1 -0
  216. package/dist/index.js +17 -1
  217. package/dist/index.js.map +1 -0
  218. package/dist/react/hooks/index.d.ts +5 -0
  219. package/dist/react/hooks/index.d.ts.map +1 -0
  220. package/dist/react/hooks/index.js +11 -0
  221. package/dist/react/hooks/index.js.map +1 -0
  222. package/dist/react/hooks/useCreateStorage.d.ts +39 -0
  223. package/dist/react/hooks/useCreateStorage.d.ts.map +1 -0
  224. package/dist/react/hooks/useCreateStorage.js +137 -0
  225. package/dist/react/hooks/useCreateStorage.js.map +1 -0
  226. package/dist/react/hooks/useSelector.d.ts +21 -0
  227. package/dist/react/hooks/useSelector.d.ts.map +1 -0
  228. package/dist/react/hooks/useSelector.js +56 -0
  229. package/dist/react/hooks/useSelector.js.map +1 -0
  230. package/dist/react/hooks/useStorage.d.ts +39 -0
  231. package/dist/react/hooks/useStorage.d.ts.map +1 -0
  232. package/dist/react/hooks/useStorage.js +78 -0
  233. package/dist/react/hooks/useStorage.js.map +1 -0
  234. package/dist/react/hooks/useStorageSubscribe.d.ts +16 -0
  235. package/dist/react/hooks/useStorageSubscribe.d.ts.map +1 -0
  236. package/dist/react/hooks/useStorageSubscribe.js +55 -0
  237. package/dist/react/hooks/useStorageSubscribe.js.map +1 -0
  238. package/dist/react/index.d.ts +3 -0
  239. package/dist/react/index.d.ts.map +1 -0
  240. package/dist/react/index.js +7 -0
  241. package/dist/react/index.js.map +1 -0
  242. package/dist/react/utils/awaitSynapse.d.ts +34 -0
  243. package/dist/react/utils/awaitSynapse.d.ts.map +1 -0
  244. package/dist/react/utils/awaitSynapse.js +87 -0
  245. package/dist/react/utils/awaitSynapse.js.map +1 -0
  246. package/dist/react/utils/createSynapseCtx.d.ts +33 -0
  247. package/dist/react/utils/createSynapseCtx.d.ts.map +1 -0
  248. package/dist/react/utils/createSynapseCtx.js +139 -0
  249. package/dist/react/utils/createSynapseCtx.js.map +1 -0
  250. package/dist/react/utils/index.d.ts +3 -0
  251. package/dist/react/utils/index.d.ts.map +1 -0
  252. package/dist/react/utils/index.js +9 -0
  253. package/dist/react/utils/index.js.map +1 -0
  254. package/dist/reactive/dispatcher/dispatcher.module.d.ts +216 -0
  255. package/dist/reactive/dispatcher/dispatcher.module.d.ts.map +1 -0
  256. package/dist/reactive/dispatcher/dispatcher.module.js +384 -0
  257. package/dist/reactive/dispatcher/dispatcher.module.js.map +1 -0
  258. package/dist/reactive/dispatcher/index.d.ts +4 -0
  259. package/dist/reactive/dispatcher/index.d.ts.map +1 -0
  260. package/dist/reactive/dispatcher/index.js +9 -0
  261. package/dist/reactive/dispatcher/index.js.map +1 -0
  262. package/dist/reactive/dispatcher/middlewares/index.d.ts +2 -0
  263. package/dist/reactive/dispatcher/middlewares/index.d.ts.map +1 -0
  264. package/dist/reactive/dispatcher/middlewares/index.js +5 -0
  265. package/dist/reactive/dispatcher/middlewares/index.js.map +1 -0
  266. package/dist/reactive/dispatcher/middlewares/logger.middleware.d.ts +37 -0
  267. package/dist/reactive/dispatcher/middlewares/logger.middleware.d.ts.map +1 -0
  268. package/dist/reactive/dispatcher/middlewares/logger.middleware.js +188 -0
  269. package/dist/reactive/dispatcher/middlewares/logger.middleware.js.map +1 -0
  270. package/dist/reactive/dispatcher/standalone.d.ts +112 -0
  271. package/dist/reactive/dispatcher/standalone.d.ts.map +1 -0
  272. package/dist/reactive/dispatcher/standalone.js +142 -0
  273. package/dist/reactive/dispatcher/standalone.js.map +1 -0
  274. package/dist/reactive/effects/effects.module.d.ts +225 -0
  275. package/dist/reactive/effects/effects.module.d.ts.map +1 -0
  276. package/dist/reactive/effects/effects.module.js +356 -0
  277. package/dist/reactive/effects/effects.module.js.map +1 -0
  278. package/dist/reactive/effects/index.d.ts +4 -0
  279. package/dist/reactive/effects/index.d.ts.map +1 -0
  280. package/dist/reactive/effects/index.js +11 -0
  281. package/dist/reactive/effects/index.js.map +1 -0
  282. package/dist/reactive/effects/utils/chunkRequestConsistent.d.ts +12 -0
  283. package/dist/reactive/effects/utils/chunkRequestConsistent.d.ts.map +1 -0
  284. package/dist/reactive/effects/utils/chunkRequestConsistent.js +25 -0
  285. package/dist/reactive/effects/utils/chunkRequestConsistent.js.map +1 -0
  286. package/dist/reactive/effects/utils/chunkRequestParallel.d.ts +12 -0
  287. package/dist/reactive/effects/utils/chunkRequestParallel.d.ts.map +1 -0
  288. package/dist/reactive/effects/utils/chunkRequestParallel.js +22 -0
  289. package/dist/reactive/effects/utils/chunkRequestParallel.js.map +1 -0
  290. package/dist/reactive/effects/utils/fromRequest.d.ts +40 -0
  291. package/dist/reactive/effects/utils/fromRequest.d.ts.map +1 -0
  292. package/dist/reactive/effects/utils/fromRequest.js +64 -0
  293. package/dist/reactive/effects/utils/fromRequest.js.map +1 -0
  294. package/dist/reactive/effects/utils/index.d.ts +5 -0
  295. package/dist/reactive/effects/utils/index.d.ts.map +1 -0
  296. package/dist/reactive/effects/utils/index.js +11 -0
  297. package/dist/reactive/effects/utils/index.js.map +1 -0
  298. package/dist/reactive/effects/utils/toObservable.d.ts +23 -0
  299. package/dist/reactive/effects/utils/toObservable.d.ts.map +1 -0
  300. package/dist/reactive/effects/utils/toObservable.js +39 -0
  301. package/dist/reactive/effects/utils/toObservable.js.map +1 -0
  302. package/dist/reactive/index.d.ts +3 -0
  303. package/dist/reactive/index.d.ts.map +1 -0
  304. package/dist/reactive/index.js +7 -0
  305. package/dist/reactive/index.js.map +1 -0
  306. package/dist/utils/createEventBus.d.ts +87 -0
  307. package/dist/utils/createEventBus.d.ts.map +1 -0
  308. package/dist/utils/createEventBus.js +215 -0
  309. package/dist/utils/createEventBus.js.map +1 -0
  310. package/dist/utils/createSynapse/createSynapse.d.ts +9 -0
  311. package/dist/utils/createSynapse/createSynapse.d.ts.map +1 -0
  312. package/dist/utils/createSynapse/createSynapse.js +103 -0
  313. package/dist/utils/createSynapse/createSynapse.js.map +1 -0
  314. package/dist/utils/createSynapse/index.d.ts +3 -0
  315. package/dist/utils/createSynapse/index.d.ts.map +1 -0
  316. package/dist/utils/createSynapse/index.js +6 -0
  317. package/dist/utils/createSynapse/index.js.map +1 -0
  318. package/dist/utils/createSynapse/types.d.ts +93 -0
  319. package/dist/utils/createSynapse/types.d.ts.map +1 -0
  320. package/dist/utils/createSynapse/types.js +6 -0
  321. package/dist/utils/createSynapse/types.js.map +1 -0
  322. package/dist/utils/createSynapse/validate.d.ts +2 -0
  323. package/dist/utils/createSynapse/validate.d.ts.map +1 -0
  324. package/dist/utils/createSynapse/validate.js +76 -0
  325. package/dist/utils/createSynapse/validate.js.map +1 -0
  326. package/dist/utils/createSynapse/waitForDependencies.d.ts +3 -0
  327. package/dist/utils/createSynapse/waitForDependencies.d.ts.map +1 -0
  328. package/dist/utils/createSynapse/waitForDependencies.js +40 -0
  329. package/dist/utils/createSynapse/waitForDependencies.js.map +1 -0
  330. package/dist/utils/createSynapseAwaiter.d.ts +46 -0
  331. package/dist/utils/createSynapseAwaiter.d.ts.map +1 -0
  332. package/dist/utils/createSynapseAwaiter.js +102 -0
  333. package/dist/utils/createSynapseAwaiter.js.map +1 -0
  334. package/dist/utils/index.d.ts +4 -0
  335. package/dist/utils/index.d.ts.map +1 -0
  336. package/dist/utils/index.js +12 -0
  337. package/dist/utils/index.js.map +1 -0
  338. package/package.json +17 -21
  339. package/dist/api.d.ts +0 -365
  340. package/dist/api.js +0 -1
  341. package/dist/core.d.ts +0 -106
  342. package/dist/core.js +0 -1
  343. package/dist/createSynapse-vkfKjRob.d.ts +0 -97
  344. package/dist/dispatcher.module-BOsMHbD5.d.ts +0 -360
  345. package/dist/react.d.ts +0 -119
  346. package/dist/react.js +0 -1
  347. package/dist/reactive.d.ts +0 -35
  348. package/dist/reactive.js +0 -1
  349. package/dist/storage.interface-BA_ktyDz.d.ts +0 -591
  350. package/dist/utils.d.ts +0 -139
  351. package/dist/utils.js +0 -1
@@ -0,0 +1,17 @@
1
+ export interface StorageUtils {
2
+ pathUtils: {
3
+ join(...parts: string[]): string;
4
+ getParent(path: string): string;
5
+ isSubPath(parent: string, child: string): boolean;
6
+ getSegments(path: string): string[];
7
+ };
8
+ dataUtils: {
9
+ flatten(obj: any, prefix?: string): Record<string, any>;
10
+ unflatten(flat: Record<string, any>): any;
11
+ clone<T>(data: T): T;
12
+ merge(target: any, source: any): any;
13
+ };
14
+ }
15
+ export declare const pathUtils: StorageUtils['pathUtils'];
16
+ export declare const dataUtils: StorageUtils['dataUtils'];
17
+ //# sourceMappingURL=storage.utils.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"storage.utils.d.ts","sourceRoot":"","sources":["../../../../src/core/storage/utils/storage.utils.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,YAAY;IAE3B,SAAS,EAAE;QACT,IAAI,CAAC,GAAG,KAAK,EAAE,MAAM,EAAE,GAAG,MAAM,CAAA;QAChC,SAAS,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAAA;QAC/B,SAAS,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAA;QACjD,WAAW,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,EAAE,CAAA;KACpC,CAAA;IAGD,SAAS,EAAE;QACT,OAAO,CAAC,GAAG,EAAE,GAAG,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;QACvD,SAAS,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,GAAG,CAAA;QACzC,KAAK,CAAC,CAAC,EAAE,IAAI,EAAE,CAAC,GAAG,CAAC,CAAA;QACpB,KAAK,CAAC,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,GAAG,GAAG,CAAA;KACrC,CAAA;CACF;AAED,eAAO,MAAM,SAAS,EAAE,YAAY,CAAC,WAAW,CAQ/C,CAAA;AAED,eAAO,MAAM,SAAS,EAAE,YAAY,CAAC,WAAW,CAuD/C,CAAA"}
@@ -0,0 +1,57 @@
1
+ const pathUtils = {
2
+ join: (...parts)=>parts.filter(Boolean).join('.'),
3
+ getParent: (path)=>{
4
+ const segments = path.split('.');
5
+ return segments.slice(0, -1).join('.');
6
+ },
7
+ isSubPath: (parent, child)=>child.startsWith(`${parent}.`),
8
+ getSegments: (path)=>path.split('.')
9
+ };
10
+ const dataUtils = {
11
+ flatten: (obj, prefix = '')=>Object.keys(obj).reduce((acc, key)=>{
12
+ const prefixKey = prefix ? `${prefix}.${key}` : key;
13
+ if (typeof obj[key] === 'object' && obj[key] !== null) {
14
+ if (Array.isArray(obj[key])) {
15
+ acc[prefixKey] = obj[key];
16
+ } else {
17
+ Object.assign(acc, dataUtils.flatten(obj[key], prefixKey));
18
+ }
19
+ } else {
20
+ acc[prefixKey] = obj[key];
21
+ }
22
+ return acc;
23
+ }, {}),
24
+ unflatten: (flat)=>{
25
+ const result = {};
26
+ for(const key in flat){
27
+ const segments = pathUtils.getSegments(key);
28
+ let current = result;
29
+ for(let i = 0; i < segments.length - 1; i++){
30
+ const segment = segments[i];
31
+ current[segment] = current[segment] || {};
32
+ current = current[segment];
33
+ }
34
+ current[segments[segments.length - 1]] = flat[key];
35
+ }
36
+ return result;
37
+ },
38
+ clone: (data)=>JSON.parse(JSON.stringify(data)),
39
+ merge: (target, source)=>{
40
+ const merged = dataUtils.clone(target);
41
+ for(const key in source){
42
+ if (typeof source[key] === 'object' && source[key] !== null) {
43
+ if (typeof merged[key] !== 'object') {
44
+ merged[key] = {};
45
+ }
46
+ merged[key] = dataUtils.merge(merged[key], source[key]);
47
+ } else {
48
+ merged[key] = source[key];
49
+ }
50
+ }
51
+ return merged;
52
+ }
53
+ };
54
+
55
+ export { dataUtils, pathUtils };
56
+
57
+ //# sourceMappingURL=storage.utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"core/storage/utils/storage.utils.js","sources":["../../../../src/core/storage/utils/storage.utils.ts"],"sourcesContent":["export interface StorageUtils {\n // Утилиты для работы с путями\n pathUtils: {\n join(...parts: string[]): string\n getParent(path: string): string\n isSubPath(parent: string, child: string): boolean\n getSegments(path: string): string[]\n }\n\n // Утилиты для работы с данными\n dataUtils: {\n flatten(obj: any, prefix?: string): Record<string, any>\n unflatten(flat: Record<string, any>): any\n clone<T>(data: T): T\n merge(target: any, source: any): any\n }\n}\n\nexport const pathUtils: StorageUtils['pathUtils'] = {\n join: (...parts: string[]): string => parts.filter(Boolean).join('.'),\n getParent: (path: string): string => {\n const segments = path.split('.')\n return segments.slice(0, -1).join('.')\n },\n isSubPath: (parent: string, child: string): boolean => child.startsWith(`${parent}.`),\n getSegments: (path: string): string[] => path.split('.'),\n}\n\nexport const dataUtils: StorageUtils['dataUtils'] = {\n flatten: (obj: any, prefix = ''): Record<string, any> =>\n Object.keys(obj).reduce(\n (acc, key) => {\n const prefixKey = prefix ? `${prefix}.${key}` : key\n\n if (typeof obj[key] === 'object' && obj[key] !== null) {\n if (Array.isArray(obj[key])) {\n acc[prefixKey] = obj[key]\n } else {\n Object.assign(acc, dataUtils.flatten(obj[key], prefixKey))\n }\n } else {\n acc[prefixKey] = obj[key]\n }\n\n return acc\n },\n {} as Record<string, any>,\n ),\n unflatten: (flat: Record<string, any>): any => {\n const result = {}\n\n for (const key in flat) {\n const segments = pathUtils.getSegments(key)\n let current: Record<string, any> = result\n\n for (let i = 0; i < segments.length - 1; i++) {\n const segment = segments[i]\n current[segment] = current[segment] || {}\n current = current[segment]\n }\n\n current[segments[segments.length - 1]] = flat[key]\n }\n\n return result\n },\n clone: <T>(data: T): T => JSON.parse(JSON.stringify(data)),\n merge: (target: any, source: any): any => {\n const merged = dataUtils.clone(target)\n\n for (const key in source) {\n if (typeof source[key] === 'object' && source[key] !== null) {\n if (typeof merged[key] !== 'object') {\n merged[key] = {}\n }\n merged[key] = dataUtils.merge(merged[key], source[key])\n } else {\n merged[key] = source[key]\n }\n }\n\n return merged\n },\n}\n"],"names":["pathUtils","parts","Boolean","path","segments","parent","child","dataUtils","obj","prefix","Object","acc","key","prefixKey","Array","flat","result","current","i","segment","data","JSON","target","source","merged"],"mappings":"AAkBO,MAAMA,SAASA,GAA8B;IAClD,MAAM,CAAC,GAAGC,QAA4BA,MAAM,MAAM,CAACC,SAAS,IAAI,CAAC;IACjE,WAAW,CAACC;QACV,MAAMC,WAAWD,KAAK,KAAK,CAAC;QAC5B,OAAOC,SAAS,KAAK,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC;IACpC;IACA,WAAW,CAACC,QAAgBC,QAA2BA,MAAM,UAAU,CAAC,GAAGD,OAAO,CAAC,CAAC;IACpF,aAAa,CAACF,OAA2BA,KAAK,KAAK,CAAC;AACtD,EAAC;AAEM,MAAMI,SAASA,GAA8B;IAClD,SAAS,CAACC,KAAUC,SAAS,EAAE,GAC7BC,OAAO,IAAI,CAACF,KAAK,MAAM,CACrB,CAACG,KAAKC;YACJ,MAAMC,YAAYJ,SAAS,GAAGA,OAAO,CAAC,EAAEG,KAAK,GAAGA;YAEhD,IAAI,OAAOJ,GAAG,CAACI,IAAI,KAAK,YAAYJ,GAAG,CAACI,IAAI,KAAK,MAAM;gBACrD,IAAIE,MAAM,OAAO,CAACN,GAAG,CAACI,IAAI,GAAG;oBAC3BD,GAAG,CAACE,UAAU,GAAGL,GAAG,CAACI,IAAI;gBAC3B,OAAO;oBACLF,OAAO,MAAM,CAACC,KAAKJ,SAASA,CAAC,OAAO,CAACC,GAAG,CAACI,IAAI,EAAEC;gBACjD;YACF,OAAO;gBACLF,GAAG,CAACE,UAAU,GAAGL,GAAG,CAACI,IAAI;YAC3B;YAEA,OAAOD;QACT,GACA,CAAC;IAEL,WAAW,CAACI;QACV,MAAMC,SAAS,CAAC;QAEhB,IAAK,MAAMJ,OAAOG,KAAM;YACtB,MAAMX,WAAWJ,SAASA,CAAC,WAAW,CAACY;YACvC,IAAIK,UAA+BD;YAEnC,IAAK,IAAIE,IAAI,GAAGA,IAAId,SAAS,MAAM,GAAG,GAAGc,IAAK;gBAC5C,MAAMC,UAAUf,QAAQ,CAACc,EAAE;gBAC3BD,OAAO,CAACE,QAAQ,GAAGF,OAAO,CAACE,QAAQ,IAAI,CAAC;gBACxCF,UAAUA,OAAO,CAACE,QAAQ;YAC5B;YAEAF,OAAO,CAACb,QAAQ,CAACA,SAAS,MAAM,GAAG,EAAE,CAAC,GAAGW,IAAI,CAACH,IAAI;QACpD;QAEA,OAAOI;IACT;IACA,OAAO,CAAII,OAAeC,KAAK,KAAK,CAACA,KAAK,SAAS,CAACD;IACpD,OAAO,CAACE,QAAaC;QACnB,MAAMC,SAASjB,SAASA,CAAC,KAAK,CAACe;QAE/B,IAAK,MAAMV,OAAOW,OAAQ;YACxB,IAAI,OAAOA,MAAM,CAACX,IAAI,KAAK,YAAYW,MAAM,CAACX,IAAI,KAAK,MAAM;gBAC3D,IAAI,OAAOY,MAAM,CAACZ,IAAI,KAAK,UAAU;oBACnCY,MAAM,CAACZ,IAAI,GAAG,CAAC;gBACjB;gBACAY,MAAM,CAACZ,IAAI,GAAGL,SAASA,CAAC,KAAK,CAACiB,MAAM,CAACZ,IAAI,EAAEW,MAAM,CAACX,IAAI;YACxD,OAAO;gBACLY,MAAM,CAACZ,IAAI,GAAGW,MAAM,CAACX,IAAI;YAC3B;QACF;QAEA,OAAOY;IACT;AACF,EAAC"}
package/dist/index.d.ts CHANGED
@@ -1,12 +1,10 @@
1
- export { ApiClient, ResponseFormat, apiLogger, createUniqueId, headersToObject } from './api.js';
2
- export { I as ISelectorModule, S as SelectorAPI } from './selector.interface-CA5y-kD_.js';
3
- export { LocalStorage, MemoryStorage, SelectorModule, StorageFactory, StoragePluginModule, broadcastMiddleware } from './core.js';
4
- export { B as BatchingMiddlewareOptions, C as ConfigMergeStrategy, o as ConfigureMiddlewares, D as DefaultMiddlewares, G as GetDefaultMiddleware, m as IEventEmitter, n as ILogger, d as IPlugin, f as IPluginExecutor, g as IPluginManager, j as IStorage, e as IStoragePlugin, I as IndexedDBStorage, t as IndexedDBStorageConfig, L as LocalStorageConfig, s as MemoryStorageConfig, M as Middleware, a as MiddlewareAPI, N as NextFunction, P as PluginContext, S as ShallowCompareMiddlewareOptions, b as StorageAction, p as StorageConfig, l as StorageEvent, k as StorageEvents, i as StorageInitStatus, c as StorageKeyType, q as StorageSingletonConfig, h as StorageStatus, r as StorageType, U as UniversalStorageConfig } from './storage.interface-BA_ktyDz.js';
5
- export { UseSynapseStorageOptions, UseSynapseStorageReturn, awaitSynapse, createSynapseCtx, useCreateStorage, useSelector, useStorageSubscribe } from './react.js';
6
- export { A as Action, b as ActionDefinition, e as ActionsResult, c as ActionsSetupWithUtils, C as CreateDispatcherType, f as DispatchActions, D as DispatchFunction, j as Dispatcher, o as DispatcherActions, i as DispatcherMiddleware, h as DispatcherMiddlewareAPI, n as Effect, m as EffectBase, w as EffectsModule, a as EnhancedMiddleware, E as EnhancedMiddlewareAPI, l as ExternalStates, d as ExtractResultType, T as TypedAction, V as ValidateConfig, p as ValidateMapRequestUtils, g as WatcherActions, W as WatcherFunction, z as combineEffects, k as createDispatcher, y as createEffect, x as createEffectBase, q as ofType, r as ofTypes, s as ofTypesWaitAll, t as selectorMap, u as selectorObject, v as validateMap } from './dispatcher.module-BOsMHbD5.js';
7
- export { loggerDispatcherMiddleware } from './reactive.js';
8
- export { EventBusConfig, EventBusEvent, EventBusState, createEventBus, createSynapseAwaiter } from './utils.js';
9
- export { A as AnySynapseStore, S as SynapseStoreBasic, a as SynapseStoreWithDispatcher, b as SynapseStoreWithEffects, c as createSynapse } from './createSynapse-vkfKjRob.js';
10
- import 'react/jsx-runtime';
11
- import 'react';
12
- import 'rxjs';
1
+ /**
2
+ * Synapse - Библиотека управления состоянием и API-клиент
3
+ * @author Vlad Firsov
4
+ */
5
+ export * from './api';
6
+ export * from './core';
7
+ export * from './react';
8
+ export * from './reactive';
9
+ export * from './utils';
10
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,cAAc,OAAO,CAAA;AACrB,cAAc,QAAQ,CAAA;AACtB,cAAc,SAAS,CAAA;AACvB,cAAc,YAAY,CAAA;AAC1B,cAAc,SAAS,CAAA"}
package/dist/index.js CHANGED
@@ -1 +1,17 @@
1
- var Te={debug:(s,...e)=>{process.env.NODE_ENV},log:(s,...e)=>{process.env.NODE_ENV},info:(s,...e)=>{},warn:(s,...e)=>{},error:(s,...e)=>{}};function be(s){return`${s?`${s}|`:""}${Math.random().toString(36).substring(2,9)+Date.now().toString(36)}`}function we(s){let e={};return s.forEach((t,n)=>{e[n.toLowerCase()]=t}),e}function G(s={},e={}){return{...s,...e,getFromStorage:s.getFromStorage||(t=>{try{let n=localStorage.getItem(t);return n?JSON.parse(n):void 0}catch{return}}),getCookie:s.getCookie||(t=>{try{let n=document.cookie.match(new RegExp(`(?:^|; )${t.replace(/([\.$?*|{}\(\)\[\]\\\/\+^])/g,"\\$1")}=([^;]*)`));return n?decodeURIComponent(n[1]):void 0}catch{return}})}}async function Ee(s,e){let t=new Headers,n=e||G({},{});if(s)try{t=await Promise.resolve(s(t,n))}catch{}return t}function Re(s,e){return async(t,n)=>{let r=new Headers(t);if(s)try{r=await Promise.resolve(s(r,n))}catch{}if(e)try{r=await Promise.resolve(e(r,n))}catch{}return r}}var H=(o=>(o.Json="json",o.Blob="blob",o.ArrayBuffer="arrayBuffer",o.Text="text",o.FormData="formData",o.Raw="raw",o))(H||{});function ve(s){let e=s.toLowerCase().split(";")[0].trim();if(e.includes("application/json"))return"json";if(e.includes("text/"))return"text";if(e.includes("multipart/form-data"))return"formData";if(e.includes("application/octet-stream")||e.includes("application/pdf")||e.includes("image/")||e.includes("audio/")||e.includes("video/"))return"blob"}function ie(s){let e=s.get("content-type")||"",t=s.get("content-disposition")||"",n=e.includes("application/octet-stream")||e.includes("application/pdf")||e.includes("image/")||e.includes("audio/")||e.includes("video/"),r=t.includes("attachment")||t.includes("filename=");return n||r}function Ge(s){let e=s.get("content-disposition");if(!e)return;let t=e.match(/filename[^;=\n]*=((['"]).*?\2|[^;\n]*)/);if(t&&t[1])return t[1].replace(/['"]/g,"").trim()}function xe(s){let e=s.get("content-type")||"",t=s.get("content-disposition")||"",n=s.get("content-length");return ie(s)?{filename:Ge(s),contentType:e,contentDisposition:t,size:n?parseInt(n,10):void 0}:void 0}async function He(s,e){let t=e,n=s.headers.get("content-type")||"";!t&&n&&(ie(s.headers)?t="blob":t=ve(n)),t||(t="json");try{let r;switch((t==="blob"||t==="arrayBuffer")&&(r=xe(s.headers)),t){case"json":try{let o=await s.json();return s.ok?{data:o,fileMetadata:r}:{error:o,fileMetadata:r}}catch{let i=await s.text();return s.ok?{data:i,fileMetadata:r}:{error:i,fileMetadata:r}}case"text":{let o=await s.text();return s.ok?{data:o,fileMetadata:r}:{error:o,fileMetadata:r}}case"blob":{let o=await s.blob();return s.ok?{data:o,fileMetadata:r}:{error:o,fileMetadata:r}}case"arrayBuffer":{let o=await s.arrayBuffer();return s.ok?{data:o,fileMetadata:r}:{error:o,fileMetadata:r}}case"formData":{let o=await s.formData();return s.ok?{data:o,fileMetadata:r}:{error:o,fileMetadata:r}}case"raw":return s.ok?{data:s,fileMetadata:r}:{error:s,fileMetadata:r};default:let a=await s.blob();return s.ok?{data:a,fileMetadata:r}:{error:a,fileMetadata:r}}}catch(r){return s.ok?{data:void 0}:{error:r}}}function Ce(s){let{baseUrl:e,timeout:t=3e4,fetchFn:n=fetch,credentials:r="same-origin"}=s;return async(a,o={},i)=>{let{path:c,method:d,body:l,query:u,responseFormat:g}=a,{signal:p,timeout:f=t,responseFormat:y}=o,b=y||g,h=new URL(c.startsWith("http")?c:`${e}${c}`);u&&Object.entries(u).forEach(([m,w])=>{w!=null&&(Array.isArray(w)?w.forEach(x=>h.searchParams.append(m,String(x))):h.searchParams.append(m,String(w)))});let S;if(l!==void 0)if(l instanceof FormData||l instanceof Blob)S=l;else if(typeof l=="object"&&l!==null)try{S=JSON.stringify(l),i.has("Content-Type")||i.set("Content-Type","application/json")}catch{S=String(l)}else S=String(l);let v,E=new Promise((m,w)=>{f&&(v=window.setTimeout(()=>{w(new Error(`\u041F\u0440\u0435\u0432\u044B\u0448\u0435\u043D\u043E \u0432\u0440\u0435\u043C\u044F \u043E\u0436\u0438\u0434\u0430\u043D\u0438\u044F \u0437\u0430\u043F\u0440\u043E\u0441\u0430 (${f}\u043C\u0441)`))},f))});try{let m=n(h.toString(),{method:d,headers:i,body:S,signal:p,credentials:r}),w=await Promise.race([m,E]),{data:x,error:ae,fileMetadata:ze}=await He(w,b);return{data:x,error:ae,ok:w.ok,status:w.status,statusText:w.statusText,headers:w.headers,fileDownloadResult:ze}}catch(m){let w=m;return{error:w,ok:!1,status:0,statusText:w.message,headers:new Headers}}finally{v&&window.clearTimeout(v)}}}function Pe(s,e=[]){let t={};return!s||e.length===0||e.forEach(n=>{s.has(n)&&(t[n]=s.get(n)||"")}),t}var W=class{constructor(e,t,n,r,a,o){this.name=e;this.queryStorage=t;this.configCurrentEndpoint=n;this.cacheableHeaderKeys=r;this.globalCacheConfig=a;this.baseQueryConfig=o;this.prepareHeaders=Re(o.prepareHeaders,n.prepareHeaders),this.queryFunction=Ce({baseUrl:o.baseUrl,fetchFn:o.fetchFn,timeout:o.timeout,credentials:o.credentials}),this.cacheableHeaders=[...r||[],...n.includeCacheableHeaderKeys||[]].filter(i=>!n.excludeCacheableHeaderKeys?.includes(i)),this.meta.name=e,this.meta.tags=n.tags??this.meta.tags,this.meta.invalidatesTags=n.invalidatesTags??this.meta.invalidatesTags,this.meta.cache=this.queryStorage.createCacheConfig(this.configCurrentEndpoint)??this.meta.cache}endpointSubscribers=new Set;fetchCounts=0;meta={cache:!1,invalidatesTags:[],name:"",tags:[]};queryFunction;cacheableHeaders;prepareHeaders;request(e,t){this.fetchCounts++;let n=be(this.name),r=new AbortController,a=new Set,o={status:"idle",requestParams:e,headers:{},error:void 0,data:void 0,fromCache:!1},i=G({requestParams:e},t?.context||{}),c=l=>{Object.assign(o,l),a.forEach(u=>{u({...o})})},d=new Promise(async(l,u)=>{try{let g=await Ee(this.prepareHeaders,i),p=Pe(g,t?.cacheableHeaderKeys?t.cacheableHeaderKeys:this.cacheableHeaders),f=this.queryStorage.shouldCache(this.configCurrentEndpoint,t),[y,b]=this.queryStorage.createCacheKey(this.name,{...e,...p}),h;if(f&&(h=await this.queryStorage.getCachedResult(y)),h)c({fromCache:!0,status:"success",data:h.data,error:void 0,headers:h.headers,requestParams:e}),l({...h,fromCache:!0});else{c({fromCache:!1,status:"loading"});let S=this.configCurrentEndpoint.request(e,t?.context),v={...t,signal:r.signal},E=await this.queryFunction(S,v,g);if(E.ok){let{headers:m,...w}=E;if(this.configCurrentEndpoint.invalidatesTags?.length&&await this.queryStorage.invalidateCacheByTags(this.configCurrentEndpoint.invalidatesTags),f){let x=this.queryStorage.createCacheConfig(this.configCurrentEndpoint);await this.queryStorage.setCachedResult(y,{...w,headers:we(m)},x,b??{},this.configCurrentEndpoint.tags??[])}c({fromCache:!1,status:"success",data:E.data,error:void 0,headers:E.headers,requestParams:e}),this.endpointSubscribers.forEach(x=>{let ae={status:"success",fetchCounts:this.fetchCounts,meta:this.meta,cacheableHeaders:this.cacheableHeaders,error:void 0};x(ae)}),l({...E,fromCache:!1})}else c({fromCache:!1,status:"error",data:void 0,error:E.error,headers:E.headers,requestParams:e}),this.endpointSubscribers.forEach(m=>{let w={status:"error",fetchCounts:this.fetchCounts,meta:this.meta,cacheableHeaders:this.cacheableHeaders,error:E.error};m(w)}),u(E.error)}}catch(g){c({fromCache:!1,status:"error",data:void 0,error:g,headers:void 0,requestParams:e}),u(g)}});return{id:n,subscribe(l,u={}){let{autoUnsubscribe:g=!0}=u;a.add(l),l(o);let p=()=>a.delete(l);return g&&d.finally(()=>{p()}),p},wait:()=>d,waitWithCallbacks(l={}){let{idle:u,loading:g,success:p,error:f}=l;return this.subscribe(y=>{switch(y.status){case"idle":u?.(y);break;case"loading":g?.(y);break;case"success":p?.(y.data,y);break;case"error":f?.(y.error,y);break}},{autoUnsubscribe:!0}),d},abort:()=>{r&&!r.signal.aborted&&r.abort()},then:(l,u)=>d.then(l,u),catch:l=>d.catch(l),finally:l=>d.finally(l)}}subscribe(e){this.endpointSubscribers.add(e);let t={status:"idle",fetchCounts:this.fetchCounts,meta:this.meta,cacheableHeaders:this.cacheableHeaders,error:void 0};return e(t),()=>this.endpointSubscribers.delete(e)}reset(){return this.fetchCounts=0,Promise.resolve()}destroy(){this.endpointSubscribers.clear()}};var T=class{constructor(e,t=!1){this.value=e;this.isRawKey=t}toString(){return this.value}toJSON(){return this.value}valueOf(){return this.value}isUnparseable(){return this.isRawKey}};var D=class{static createMetadata(e=0,t=[]){let n=Date.now(),r=e>0?n+e:1/0;return{createdAt:n,updatedAt:n,expiresAt:r,tags:t,createdAtDateTime:this.formatDateTime(n),updatedAtDateTime:this.formatDateTime(n),expiresAtDateTime:r===1/0?"never":this.formatDateTime(r)}}static formatDateTime(e){return new Date(e).toISOString()}static isExpired(e){return Date.now()>e.expiresAt}static updateMetadata(e){return{...e,updatedAt:Date.now()}}static createKey(...e){return new T(e.join("_"))}static createApiKey(e,t){if(!t)return[new T(e,!0),t];let n=Object.entries(t).sort(([r],[a])=>r.localeCompare(a)).map(([r,a])=>`${r}=${a}`).join("&");return[new T(`${e}_${n}`,!0),t]}static hasAnyTag(e,t=[]){return!e.tags||!t.length?!1:t.some(n=>e.tags?.includes(n))}};var Q=class{constructor(e,t){this.storageExternal=e;this.globalCacheConfig=t}storage=null;cleanupInterval=null;defaultCacheOptions={ttl:5*60*1e3,cleanup:{enabled:!0,interval:10*60*1e3},invalidateOnError:!0};async initialize(){return await this.createStorage(),this.startCleanupInterval(),this}async createStorage(){try{let e=this.storageExternal;await e.initialize(),this.storage=e}catch(e){throw e}}startCleanupInterval(){this.cleanupInterval&&(clearInterval(this.cleanupInterval),this.cleanupInterval=null);let e=typeof this.globalCacheConfig=="object"?this.globalCacheConfig.cleanup:this.defaultCacheOptions.cleanup;e?.enabled&&e.interval&&(this.cleanupInterval=setInterval(()=>{this.cleanup().catch(t=>{})},e.interval))}getStorage(){return this.storage}createCacheKey(e,t){return D.createApiKey(e,t)}async getCachedResult(e){if(!this.storage)throw new Error("\u0425\u0440\u0430\u043D\u0438\u043B\u0438\u0449\u0435 \u043D\u0435 \u0438\u043D\u0438\u0446\u0438\u0430\u043B\u0438\u0437\u0438\u0440\u043E\u0432\u0430\u043D\u043E");let t=await this.storage.get(e);if(!t)return;if(D.isExpired(t.metadata)){await this.storage.delete(e);return}let n={...t,metadata:D.updateMetadata(t.metadata)};return await this.storage.set(e,n),t.data}async setCachedResult(e,t,n,r,a){if(!this.storage)throw new Error("\u0425\u0440\u0430\u043D\u0438\u043B\u0438\u0449\u0435 \u043D\u0435 \u0438\u043D\u0438\u0446\u0438\u0430\u043B\u0438\u0437\u0438\u0440\u043E\u0432\u0430\u043D\u043E");let o=D.createMetadata(n.ttl,a),i={data:t,metadata:o,params:r};await this.storage.set(e,i)}shouldCache(e,t){return!(this.globalCacheConfig===!1||e?.cache===!1||typeof e?.cache=="object"&&e?.cache.ttl===0||t?.disableCache===!0||this.globalCacheConfig===void 0&&e?.cache===void 0)}createCacheConfig(e){let t=this.defaultCacheOptions;if(typeof this.globalCacheConfig=="object"&&(t=this.globalCacheConfig),typeof e?.cache=="object"){let n=e.cache;t={...t,...n}}return t}async invalidateCacheByTags(e){if(!this.storage)throw new Error("\u0425\u0440\u0430\u043D\u0438\u043B\u0438\u0449\u0435 \u043D\u0435 \u0438\u043D\u0438\u0446\u0438\u0430\u043B\u0438\u0437\u0438\u0440\u043E\u0432\u0430\u043D\u043E");let t=await this.storage.keys();for(let n of t){let r=await this.storage.get(n);r&&D.hasAnyTag(r.metadata,e)&&await this.storage.delete(n)}}async invalidateCache(e){if(!this.storage)throw new Error("\u0425\u0440\u0430\u043D\u0438\u043B\u0438\u0449\u0435 \u043D\u0435 \u0438\u043D\u0438\u0446\u0438\u0430\u043B\u0438\u0437\u0438\u0440\u043E\u0432\u0430\u043D\u043E");await this.storage.delete(e)}async cleanup(){if(!this.storage)throw new Error("\u0425\u0440\u0430\u043D\u0438\u043B\u0438\u0449\u0435 \u043D\u0435 \u0438\u043D\u0438\u0446\u0438\u0430\u043B\u0438\u0437\u0438\u0440\u043E\u0432\u0430\u043D\u043E");let e=await this.storage.keys();for(let t of e){let n=await this.storage.get(t);n&&D.isExpired(n.metadata)&&await this.storage.delete(t)}}async destroy(){this.cleanupInterval&&(window.clearInterval(this.cleanupInterval),this.cleanupInterval=null),this.storage&&(await this.storage.destroy(),this.storage=null)}};var Ae=class{queryStorage;cacheableHeaderKeys;globalCacheConfig;baseQueryConfig;storageExternal;createEndpoints;endpoints={};constructor(e){this.cacheableHeaderKeys=e.cacheableHeaderKeys,this.globalCacheConfig=e.cache,this.baseQueryConfig=e.baseQuery,this.storageExternal=e.storage,this.createEndpoints=e.endpoints}async init(){return this.queryStorage=await new Q(this.storageExternal,this.globalCacheConfig).initialize(),await this.initializeEndpoints(),this}async initializeEndpoints(){let e=n=>n,t=await this.createEndpoints(e)||{};for(let[n,r]of Object.entries(t)){let a=n;this.endpoints[a]=new W(n,this.queryStorage,r,this.cacheableHeaderKeys,this.globalCacheConfig,this.baseQueryConfig)}}getEndpoints(){return this.endpoints}async request(e,t,n){let a=this.getEndpoints()[e];if(!a)throw new Error(`\u042D\u043D\u0434\u043F\u043E\u0438\u043D\u0442 ${String(e)} \u043D\u0435 \u043D\u0430\u0439\u0434\u0435\u043D`);try{return await a.request(t,n).wait()}catch(o){throw Te.error(`\u041E\u0448\u0438\u0431\u043A\u0430 \u0437\u0430\u043F\u0440\u043E\u0441\u0430 \u043A ${String(e)}`,{error:o,params:t}),o}}async destroy(){await Promise.all(Object.values(this.endpoints).map(async e=>(e.destroy(),Promise.resolve()))),this.endpoints={},await this.queryStorage.destroy()}};var R=!1,q=new Map;function Ie(s){let e=0;if(s.length===0)return e.toString(36);for(let t=0;t<s.length;t++){let n=s.charCodeAt(t);e=(e<<5)-e+n,e=e&e}return Math.abs(e).toString(36).substring(0,6)}function I(s,e){if(s===e)return!0;if(s==null||e==null)return!1;if(typeof s!="object"&&typeof s!="function"&&typeof e!="object"&&typeof e!="function")return s===e;if(typeof s!=typeof e)return!1;if(s instanceof Date&&e instanceof Date)return s.getTime()===e.getTime();if(Array.isArray(s)&&Array.isArray(e)){if(s.length!==e.length)return!1;for(let t=0;t<s.length;t++)if(!I(s[t],e[t]))return!1;return!0}if(typeof s=="object"&&typeof e=="object"){let t=Object.keys(s),n=Object.keys(e);return t.length!==n.length?!1:t.every(r=>Object.prototype.hasOwnProperty.call(e,r)?I(s[r],e[r]):!1)}return!1}function De(s,e=I){let t,n,r=!1;return function(o){if(!r||t!==o){let i=s(o);(!r||!e(i,n))&&(n=i),t=o,r=!0}return n}}var Y=class{constructor(e,t,n=I,r){this.name=e;this.equals=n;this.logger=r;this.id=e,this.memoizedGetState=this.createMemoizedGetState(t)}id;subscribers=new Set;lastValue;memoizedGetState;createMemoizedGetState(e){let t=null,n=!1;return async()=>{if(n&&t)return t;n=!0;try{return t=e(),await t}finally{n=!1}}}async notify(){try{let e=await this.memoizedGetState();if(this.lastValue===void 0||!this.equals(e,this.lastValue)){this.lastValue=e;let t=Array.from(this.subscribers).map(async n=>{try{await n.notify(e)}catch(r){this.logger?.error(`[${this.id}] \u041E\u0448\u0438\u0431\u043A\u0430 \u0432 \u0443\u0432\u0435\u0434\u043E\u043C\u043B\u0435\u043D\u0438\u0438 \u043F\u043E\u0434\u043F\u0438\u0441\u0447\u0438\u043A\u0430`,{error:r})}});await Promise.all(t)}}catch(e){throw this.logger?.error(`[${this.id}] \u041E\u0448\u0438\u0431\u043A\u0430 \u0432 notify()`,{error:e}),e}}subscribe(e){return this.subscribers.add(e),this.lastValue!==void 0?Promise.resolve().then(()=>{try{e.notify(this.lastValue)}catch(t){this.logger?.error(`[${this.id}] \u041E\u0448\u0438\u0431\u043A\u0430 \u0432 \u043F\u0435\u0440\u0432\u043E\u043D\u0430\u0447\u0430\u043B\u044C\u043D\u043E\u043C \u0443\u0432\u0435\u0434\u043E\u043C\u043B\u0435\u043D\u0438\u0438`,{error:t})}}):this.notify().catch(t=>{this.logger?.error(`[${this.id}] \u041E\u0448\u0438\u0431\u043A\u0430 \u0432 \u043F\u0435\u0440\u0432\u043E\u043D\u0430\u0447\u0430\u043B\u044C\u043D\u043E\u043C \u0443\u0432\u0435\u0434\u043E\u043C\u043B\u0435\u043D\u0438\u0438`,{error:t})}),()=>{this.subscribers.delete(e)}}cleanup(){this.subscribers.clear(),this.lastValue=void 0}getId(){return this.id}},J=class{constructor(e,t){this.source=e;this.logger=t;this.storageName=e.name,this.source.getState().then(n=>{this.cachedState=n})}storageName;subscriptions=new Map;cachedState;localSelectorCache=new Map;batchUpdateInProgress=!1;pendingUpdates=new Set;generateName(e,t,n){let r=e?"simple":"combined",a="";if(e){let o=t.toString();a=Ie(o)}else{let o=t.map(c=>c.getId()).join("_"),i=n.toString();a=Ie(o+i)}return`${this.storageName}_${r}_${a}`}processPendingUpdates(){this.pendingUpdates.size===0||this.batchUpdateInProgress||(this.batchUpdateInProgress=!0,setTimeout(async()=>{try{let e=Array.from(this.pendingUpdates);this.pendingUpdates.clear(),this.cachedState=await this.source.getState();let t=e.map(async n=>{let r=this.subscriptions.get(n);if(r)try{return await r.notify()}catch(a){this.logger?.error(`\u041E\u0448\u0438\u0431\u043A\u0430 \u0443\u0432\u0435\u0434\u043E\u043C\u043B\u0435\u043D\u0438\u044F \u043F\u043E\u0434\u043F\u0438\u0441\u0447\u0438\u043A\u0430 ${n}`,{error:a})}return Promise.resolve()});await Promise.all(t)}catch(e){this.logger?.error("\u041E\u0448\u0438\u0431\u043A\u0430 \u043E\u0431\u0440\u0430\u0431\u043E\u0442\u043A\u0438 \u043E\u0436\u0438\u0434\u0430\u044E\u0449\u0438\u0445 \u043E\u0431\u043D\u043E\u0432\u043B\u0435\u043D\u0438\u0439",{error:e})}finally{this.batchUpdateInProgress=!1,this.pendingUpdates.size>0&&this.processPendingUpdates()}},0))}createSelector(e,t,n){let r=!Array.isArray(e),a=r?t||{}:n||{},o=a.name||this.generateName(r,e,r?void 0:t);if(this.localSelectorCache.has(o))return this.localSelectorCache.get(o).api;if(q.has(o)){let l=q.get(o);return l.refCount++,l.api}let i,c,d=[];if(r){let l=De(e,a.equals||I),u=this.createSimpleSelector(l,{...a,name:o,equals:a.equals||I});i=u.api,d=u.unsubscribeFunctions}else{c=e;let l=this.createCombinedSelector(c,t,{...a,name:o,equals:a.equals||I});i=l.api,d=l.unsubscribeFunctions}return this.localSelectorCache.set(o,{api:i,dependencies:c,unsubscribeFunctions:d}),q.set(o,{api:i,refCount:1,unsubscribeFunctions:d}),i}createSimpleSelector(e,t){let n=async()=>{if(this.cachedState)return e(this.cachedState);let c=await this.source.getState();return this.cachedState=c,e(c)},r=new Y(t.name,n,t.equals||I,this.logger),a=r.getId();this.subscriptions.set(a,r);let i=[this.source.subscribeToAll(async c=>{c?.type==="storage:update"&&(this.pendingUpdates.add(a),this.processPendingUpdates())})];return{api:{select:()=>n(),subscribe:c=>r.subscribe(c),getId:()=>a},unsubscribeFunctions:i}}createCombinedSelector(e,t,n){let r=De(u=>t(...u),n.equals||I),a=async()=>{let u=await Promise.all(e.map(g=>g.select()));return r(u)},o=new Y(n.name,a,n.equals||I,this.logger),i=o.getId();this.subscriptions.set(i,o);let c=null,d=()=>{c!==null&&clearTimeout(c),c=setTimeout(()=>{c=null,o.notify().catch(u=>this.logger?.error(`[${i}] \u041E\u0448\u0438\u0431\u043A\u0430 \u0432 \u043E\u0431\u044A\u0435\u0434\u0438\u043D\u0435\u043D\u043D\u043E\u043C \u0443\u0432\u0435\u0434\u043E\u043C\u043B\u0435\u043D\u0438\u0438:`,{error:u}))},10)},l=e.map(u=>u.subscribe({notify:()=>{d()}}));return{api:{select:()=>a(),subscribe:u=>o.subscribe(u),getId:()=>i},unsubscribeFunctions:l}}destroy(){this.subscriptions.forEach(t=>t.cleanup()),this.subscriptions.clear(),this.cachedState=void 0,this.pendingUpdates.clear(),this.localSelectorCache.forEach(t=>{t.unsubscribeFunctions.forEach(n=>n())});let e=new Set;this.localSelectorCache.forEach((t,n)=>{e.add(n)}),this.localSelectorCache.clear(),e.forEach(t=>{let n=q.get(t);n&&(n.refCount--,n.refCount<=0&&(n.unsubscribeFunctions.forEach(r=>r()),q.delete(t)))})}};var Oe=class{constructor(e,t,n="default"){this.parentExecutor=e;this.logger=t;this.storageName=n}plugins=new Map;createContext(e){return{storageName:this.storageName,timestamp:Date.now(),metadata:e}}async add(e){if(this.plugins.has(e.name)){this.logger?.warn(`\u041F\u043B\u0430\u0433\u0438\u043D ${e.name} \u0443\u0436\u0435 \u0431\u044B\u043B \u0437\u0430\u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0438\u0440\u043E\u0432\u0430\u043D`);return}try{await e.initialize?.(),this.plugins.set(e.name,e),this.logger?.info("\u041F\u043B\u0430\u0433\u0438\u043D \u0434\u043E\u0431\u0430\u0432\u043B\u0435\u043D",{name:e.name})}catch(t){throw t}}async remove(e){let t=this.plugins.get(e);t&&(await t.destroy?.(),this.plugins.delete(e),this.logger?.info("\u041F\u043B\u0430\u0433\u0438\u043D \u0443\u0434\u0430\u043B\u0435\u043D",{name:e}))}get(e){return this.plugins.get(e)}getAll(){return Array.from(this.plugins.values())}async initialize(){for(let e of this.plugins.values())await e.initialize?.()}async destroy(){await Promise.all(Array.from(this.plugins.values()).map(e=>e.destroy?.()??Promise.resolve())),this.plugins.clear()}async executeBeforeSet(e,t){let n=e,r=this.createContext(t);this.parentExecutor&&(n=await this.parentExecutor.executeBeforeSet(n,r));for(let a of this.plugins.values())if(a.onBeforeSet)try{n=await a.onBeforeSet(n,r)}catch(o){throw this.logger?.error(`\u041E\u0448\u0438\u0431\u043A\u0430 \u0432 \u043F\u043B\u0430\u0433\u0438\u043D\u0435 ${a.name} onBeforeSet`,{error:o}),o}return n}async executeAfterSet(e,t,n){let r=t,a=this.createContext(n);this.parentExecutor&&(r=await this.parentExecutor.executeAfterSet(e,r,a));for(let o of this.plugins.values())if(o.onAfterSet)try{r=await o.onAfterSet(e,r,a)}catch(i){throw this.logger?.error(`\u041E\u0448\u0438\u0431\u043A\u0430 \u0432 \u043F\u043B\u0430\u0433\u0438\u043D\u0435 ${o.name} onAfterSet`,{key:e,error:i}),i}return r}async executeBeforeGet(e,t){let n=e,r=this.createContext(t);this.parentExecutor&&(n=await this.parentExecutor.executeBeforeGet(n,r));for(let a of this.plugins.values())if(a.onBeforeGet)try{n=await a.onBeforeGet(n,r)}catch(o){throw this.logger?.error(`\u041E\u0448\u0438\u0431\u043A\u0430 \u0432 \u043F\u043B\u0430\u0433\u0438\u043D\u0435 ${a.name} onBeforeGet`,{key:e,error:o}),o}return n}async executeAfterGet(e,t,n){let r=t,a=this.createContext(n);this.parentExecutor&&(r=await this.parentExecutor.executeAfterGet(e,r,a));for(let o of this.plugins.values())if(o.onAfterGet)try{r=await o.onAfterGet(e,r,a)}catch(i){throw this.logger?.error(`\u041E\u0448\u0438\u0431\u043A\u0430 \u0432 \u043F\u043B\u0430\u0433\u0438\u043D\u0435 ${o.name} onAfterGet`,{key:e,error:i}),i}return r}async executeBeforeDelete(e,t){let n=!0,r=this.createContext(t);this.parentExecutor&&(n=await this.parentExecutor.executeBeforeDelete(e,r));for(let a of this.plugins.values())if(a.onBeforeDelete)try{n=await a.onBeforeDelete(e,r)&&n}catch(o){throw this.logger?.error(`\u041E\u0448\u0438\u0431\u043A\u0430 \u0432 \u043F\u043B\u0430\u0433\u0438\u043D\u0435 ${a.name} onBeforeDelete`,{key:e,error:o}),o}return n}async executeAfterDelete(e,t){let n=this.createContext(t);this.parentExecutor&&await this.parentExecutor.executeAfterDelete(e,n);for(let r of this.plugins.values())if(r.onAfterDelete)try{await r.onAfterDelete(e,n)}catch(a){throw this.logger?.error(`\u041E\u0448\u0438\u0431\u043A\u0430 \u0432 \u043F\u043B\u0430\u0433\u0438\u043D\u0435 ${r.name} onAfterDelete`,{key:e,error:a}),a}}async executeOnClear(e){let t=this.createContext(e);this.parentExecutor&&await this.parentExecutor.executeOnClear(t);for(let n of this.plugins.values())if(n.onClear)try{await n.onClear(t)}catch(r){throw this.logger?.error(`\u041E\u0448\u0438\u0431\u043A\u0430 \u0432 \u043F\u043B\u0430\u0433\u0438\u043D\u0435 ${n.name} onClear`,{error:r}),r}}};var ce=(a=>(a.STRICT="strict",a.FIRST_WINS="first_wins",a.DEEP_MERGE="deep_merge",a.OVERRIDE="override",a.WARN_AND_USE_FIRST="warn_and_use_first",a))(ce||{});var le=(r=>(r.IDLE="idle",r.LOADING="loading",r.READY="ready",r.ERROR="error",r))(le||{}),de=(o=>(o.STORAGE_UPDATE="storage:update",o.STORAGE_DELETE="storage:delete",o.STORAGE_PATCH="storage:patch",o.STORAGE_SELECT="storage:select",o.STORAGE_CLEAR="storage:clear",o.STORAGE_DESTROY="storage:destroy",o))(de||{});var X=class{channel;tabId;messageHandlers;syncHandler;debug;syncTimeoutMs=1e3;pendingSyncRequests;constructor(e,t={}){this.channel=new BroadcastChannel(e),this.tabId=crypto.randomUUID(),this.messageHandlers=new Set,this.debug=t.debug??!1,this.pendingSyncRequests=new Map,this.channel.onmessage=this.handleMessage.bind(this),this.channel.onmessageerror=this.handleError.bind(this)}log(...e){this.debug}error(...e){}async handleMessage(e){let t=e.data;if(t.senderId!==this.tabId){if(t.type==="SYNC_REQUEST"){if(this.syncHandler)try{let n=await this.syncHandler();this.postMessage("SYNC_RESPONSE",n,t.senderId)}catch(n){this.error("Error handling sync request:",n)}return}if(t.type==="SYNC_RESPONSE"){let n=this.pendingSyncRequests.get(this.tabId);n&&(clearTimeout(n.timeout),this.pendingSyncRequests.delete(this.tabId),n.resolve(t.payload));return}for(let n of this.messageHandlers)try{await n(t)}catch(r){this.error("Error in message handler:",r)}}}handleError(e){this.error("Channel error:",e)}postMessage(e,t,n){let r={type:e,payload:t,senderId:this.tabId,timestamp:Date.now()};this.channel.postMessage(r)}subscribe(e){return this.messageHandlers.add(e),()=>this.messageHandlers.delete(e)}setSyncHandler(e){this.syncHandler=e}broadcast(e,t){this.postMessage(e,t)}async requestSync(){return new Promise((e,t)=>{let n=setTimeout(()=>{this.pendingSyncRequests.delete(this.tabId),e(null)},this.syncTimeoutMs);this.pendingSyncRequests.set(this.tabId,{resolve:e,reject:t,timeout:n}),this.postMessage("SYNC_REQUEST",{type:"sync"})})}close(){for(let[,e]of this.pendingSyncRequests)clearTimeout(e.timeout),e.reject(new Error("Channel closed"));this.pendingSyncRequests.clear(),this.messageHandlers.clear(),this.syncHandler=void 0,this.channel.close()}};async function We(s,e,t){switch(e){case"set":t?.key!==void 0&&t?.value!==void 0&&(await s.storage.doSet(t.key,t.value),s.storage.notifySubscribers(t.key,t.value));break;case"update":Array.isArray(t?.value)&&(await s.storage.doUpdate(t.value),t.value.forEach(({key:n,value:r})=>{s.storage.notifySubscribers(n,r)}));break;case"delete":t?.key!==void 0&&(await s.storage.doDelete(t.key),s.storage.notifySubscribers(t.key,void 0));break;case"clear":await s.storage.doClear(),s.storage.notifySubscribers("*",{type:"storage:update",value:{},source:"broadcast"});break}s.storage.notifySubscribers("*",{type:"storage:update",key:t?.key,value:t?.value,source:"broadcast"})}async function Qe(s,e,t){switch(e){case"set":if(t?.key!==void 0){let n=await s.storage.doGet(t.key);s.storage.notifySubscribers(t.key,n)}break;case"update":if(Array.isArray(t?.value)){for(let{key:n}of t.value){let r=await s.storage.doGet(n);s.storage.notifySubscribers(n,r)}s.storage.notifySubscribers("*",{type:"storage:update",key:t.value.map(({key:n})=>n),value:t.value,source:"broadcast"})}break;case"delete":t?.key!==void 0&&s.storage.notifySubscribers(t.key,void 0);break;case"clear":s.storage.notifySubscribers("*",{type:"storage:update",value:{},source:"broadcast"});break}e!=="update"&&s.storage.notifySubscribers("*",{type:"storage:update",key:t?.key,value:e==="delete"?void 0:t?.value,source:"broadcast"})}var Me=s=>{let{storageName:e,storageType:t}=s,n=`${t}-${e}`,r=new X(n,{debug:!0});return{name:"broadcast",setup:a=>(t==="memory"&&(r.setSyncHandler(async()=>{let o=await a.getState();return{type:"update",key:"*",value:Object.entries(o).map(([d,l])=>({key:d,value:l})),metadata:{batchUpdate:!0,timestamp:Date.now()}}}),r.requestSync().then(async o=>{if(o?.type==="update"&&Array.isArray(o.value))try{if(!o.value.every(c=>c&&typeof c=="object"&&"key"in c&&"value"in c))return;await a.storage.doUpdate(o.value),o.value.forEach(({key:c,value:d})=>{a.storage.notifySubscribers(c,d)}),a.storage.notifySubscribers("*",{type:"storage:update",value:o.value,source:"broadcast"})}catch{}})),r.subscribe(async o=>{let{type:i,payload:c}=o;t==="memory"?await We(a,i,c):await Qe(a,i,c)})),reducer:a=>o=>async i=>{let c=await o(i);return["set","delete","clear","update"].includes(i.type)&&r.broadcast(i.type,i),c},cleanup:()=>{r.close()}}};var $=class{static instances=new Map;static configs=new Map;static logger;static setLogger(e){this.logger=e}static getOrCreate(e,t,n){let r=this.configs.get(e),a=this.instances.get(e);if(a&&r){let i=this.mergeConfigurations(r,t);return{instance:a,isNewInstance:!1,appliedConfig:i.finalConfig,conflicts:i.conflicts}}let o=n(t);return this.instances.set(e,o),this.configs.set(e,{...t}),this.logger?.debug(`Created new singleton instance: ${e}`),{instance:o,isNewInstance:!0,appliedConfig:t,conflicts:[]}}static exists(e){return this.instances.has(e)}static getConfig(e){return this.configs.get(e)}static remove(e){let t=this.instances.get(e);return t?(typeof t.destroy=="function"&&t.destroy(),this.instances.delete(e),this.configs.delete(e),this.logger?.debug(`Removed singleton instance: ${e}`),!0):!1}static clear(){for(let[e,t]of this.instances)typeof t.destroy=="function"&&t.destroy();this.instances.clear(),this.configs.clear(),this.logger?.debug("Cleared all singleton instances")}static getStats(){return{instanceCount:this.instances.size,instances:Array.from(this.instances.keys())}}static mergeConfigurations(e,t){let n=t.singleton?.mergeStrategy||"first_wins",r=t.singleton?.warnOnConflict??!0;switch(n){case"strict":return this.strictMerge(e,t);case"first_wins":return this.firstWinsMerge(e,t,r);case"deep_merge":return this.deepMerge(e,t);case"override":return this.overrideMerge(e,t);case"warn_and_use_first":return this.warnAndUseFirst(e,t);default:return this.firstWinsMerge(e,t,r)}}static strictMerge(e,t){let n=this.findConflicts(e,t);if(n.length>0)throw new Error(`Strict singleton validation failed for "${e.name}". Conflicts: ${n.join(", ")}`);return{finalConfig:e,conflicts:[]}}static firstWinsMerge(e,t,n){let r=this.findConflicts(e,t);return n&&r.length>0&&(this.logger?.warn(`Singleton config conflicts for "${e.name}":`,r),this.logger?.warn("Using existing configuration")),{finalConfig:e,conflicts:r}}static deepMerge(e,t){let n=this.findConflicts(e,t),r={...e,initialState:this.deepMergeObjects(e.initialState||{},t.initialState||{})};return this.logger?.debug(`Deep merged singleton config for "${e.name}"`),{finalConfig:r,conflicts:n}}static overrideMerge(e,t){let n=this.findConflicts(e,t),r={...t,name:e.name};return this.logger?.warn(`Overriding singleton config for "${e.name}"`),{finalConfig:r,conflicts:n}}static warnAndUseFirst(e,t){let n=this.findConflicts(e,t);return n.length>0&&(this.logger?.warn(`Configuration conflicts detected for singleton "${e.name}":`),this.logger?.warn("Existing config:",e),this.logger?.warn("Incoming config:",t),this.logger?.warn("Using existing configuration")),{finalConfig:e,conflicts:n}}static findConflicts(e,t){let n=[];if(e.initialState&&t.initialState){let r=this.findObjectConflicts(e.initialState,t.initialState,"initialState");n.push(...r)}else e.initialState!==t.initialState&&n.push("initialState: one is undefined");return!!e.middlewares!=!!t.middlewares&&n.push("middlewares: configuration differs"),n}static findObjectConflicts(e,t,n){let r=[],a=new Set([...Object.keys(e||{}),...Object.keys(t||{})]);for(let o of a){let i=`${n}.${o}`,c=e?.[o],d=t?.[o];c!==d&&(c===void 0||d===void 0?r.push(`${i}: missing in one config`):typeof c!=typeof d?r.push(`${i}: type mismatch (${typeof c} vs ${typeof d})`):typeof c=="object"&&c!==null&&d!==null?r.push(...this.findObjectConflicts(c,d,i)):r.push(`${i}: value mismatch (${c} vs ${d})`))}return r}static deepMergeObjects(e,t){let n={...e};for(let r in t)t[r]!==null&&typeof t[r]=="object"&&!Array.isArray(t[r])?n[r]=this.deepMergeObjects(e[r]||{},t[r]):n[r]=t[r];return n}},K=class{static generate(e,t){return e.singleton?.key?e.singleton.key:`${t}_${e.name}`}};var M=class{static handleSingletonCreation(e,t,n,r){if(!e.singleton?.enabled)return n(e);r&&$.setLogger(r);let a=K.generate(e,t),o=$.getOrCreate(a,e,n);return o.isNewInstance?r?.debug(`Created new singleton storage: ${a}`):(r?.debug(`Reusing existing singleton storage: ${a}`),o.conflicts&&o.conflicts.length>0&&r?.debug(`Configuration conflicts detected: ${o.conflicts.join(", ")}`)),o.instance}};var Fe=(s={})=>{let e=s.batchSize??10,t=s.batchDelay??10,n=new Map,r=new Map,a=g=>g.type==="set"||g.type==="update",o=g=>`${g.type}_${g.key?.toString()||"default"}`,i=g=>{let p=new Map;for(let f of g){let y=`${f.type}_${f.key?.toString()||"default"}`;p.set(y,f)}return Array.from(p.values())},c=g=>{let p=r.get(g);p&&(globalThis.clearTimeout(p),r.delete(g))},d=(g,p)=>{let f=globalThis.setTimeout(p,t);r.set(g,f)},l=async(g,p,f)=>{let y=n.get(g);if(!(!y||y.length===0)){n.delete(g),c(g);try{let b=y.map(S=>S.action),h=i(b);for(let S of h)try{let v=await f(S);y.filter(m=>m.action.type===S.type&&m.action.key?.toString()===S.key?.toString()).forEach(m=>m.resolve(v))}catch(v){y.filter(m=>m.action.type===S.type&&m.action.key?.toString()===S.key?.toString()).forEach(m=>m.reject(v))}}catch(b){y.forEach(h=>h.reject(b))}}},u=async(g,p,f)=>new Promise((y,b)=>{let h=o(g),S=n.get(h);S||(S=[],n.set(h,S)),S.push({action:g,resolve:y,reject:b,timestamp:Date.now()}),c(h),S.length>=e?setImmediate(()=>l(h,p,f)):d(h,()=>l(h,p,f))});return{name:"batching",setup:()=>{},cleanup:async()=>{r.forEach(g=>globalThis.clearTimeout(g)),r.clear(),n.clear()},reducer:g=>p=>async f=>a(f)?u(f,g,p):p(f)}};var $e=(s={})=>{let{comparator:e=(r,a)=>{if(r===a)return!0;if(typeof r!="object"||typeof a!="object"||r===null||a===null)return r===a;let o=Object.keys(r),i=Object.keys(a);return o.length!==i.length?!1:o.every(c=>Object.prototype.hasOwnProperty.call(a,c)&&r[c]===a[c])},segments:t=[]}=s,n=new Map;return{name:"shallow-compare",setup:r=>{},reducer:r=>a=>async o=>{if(o.type!=="set"||t.length&&!t.includes(o.metadata?.segment??"default"))return a(o);let i=o.key,c=n.get(i),d=o.value;if(c!==void 0&&e(c,d))return{...c,t:{valueNotChanged:!0,originalValue:c}};let l=await a(o);return n.set(i,d),l}}};var Z=class{middlewares=[];api;initialized=!1;dispatchFn;constructor(e){this.api={dispatch:async t=>this.dispatch(t),getState:()=>e.getState(),storage:{doGet:e.doGet.bind(e),doSet:e.doSet.bind(e),doUpdate:e.doUpdate.bind(e),doDelete:e.doDelete.bind(e),doClear:e.doClear.bind(e),doKeys:e.doKeys.bind(e),notifySubscribers:e.notifySubscribers.bind(e)}}}async baseOperation(e){let{processed:t,...n}=e.metadata||{},r={...e,metadata:n};switch(r.type){case"get":return this.api.storage.doGet(r.key);case"set":return await this.api.storage.doSet(r.key,r.value),this.api.storage.doGet(r.key);case"update":return Array.isArray(r.value)?(await this.api.storage.doUpdate(r.value),this.api.storage.doGet("")):r.value;case"delete":return this.api.storage.doDelete(r.key);case"clear":return this.api.storage.doClear();case"init":{let a=await this.api.storage.doGet("");return Object.keys(a||{}).length>0?a:r.value?(await this.api.storage.doSet("",r.value),this.api.storage.doGet("")):a}case"keys":return this.api.storage.doKeys();default:throw new Error(`Unknown action type: ${r.type}`)}}initializeMiddlewares(){if(this.initialized)return;let e=this.baseOperation.bind(this);for(let t of[...this.middlewares].reverse()){let n=e;e=async r=>{if(r.metadata?.processed)return n(r);let a={...r,metadata:{...r.metadata,processed:!0,timestamp:r.metadata?.timestamp||Date.now()}};return t.reducer(this.api)(n)(a)}}this.dispatchFn=e,this.initialized=!0}use(e){e.setup&&e.setup(this.api),this.middlewares.push(e),this.initialized=!1}async dispatch(e){this.initialized||this.initializeMiddlewares();try{return this.dispatchFn(e)}catch(t){throw t}}};function P(s){return s instanceof T&&s.isUnparseable()?[s.toString()]:s.toString().replace(/\[/g,".").replace(/\]/g,"").split(".").filter(Boolean)}function A(s,e){return P(e).reduce((n,r)=>n===void 0?void 0:n[r],s)}function O(s,e,t){if(e==="")return t;let n=P(e);if(e instanceof T&&e.isUnparseable())return s[e.toString()]=t,s;let r=n.pop(),a=n.reduce((o,i)=>{let c=n[n.indexOf(i)+1],d=!Number.isNaN(Number(c));return i in o||(o[i]=d?[]:{}),o[i]},s);return a[r]=t,s}var F=class s{constructor(e,t,n,r){this.config=e;this.pluginExecutor=t;this.eventEmitter=n;this.logger=r;this.name=e.name,this.middlewareModule=new Z({getState:this.getState.bind(this),doGet:this.doGet.bind(this),doSet:this.doSet.bind(this),doUpdate:this.doUpdate.bind(this),doDelete:this.doDelete.bind(this),doClear:this.doClear.bind(this),doKeys:this.doKeys.bind(this),notifySubscribers:this.notifySubscribers.bind(this),pluginExecutor:this.pluginExecutor,eventEmitter:this.eventEmitter,logger:this.logger}),this.initializeMiddlewares()}static GLOBAL_SUBSCRIPTION_KEY="*";static STORAGE_TYPE;name;e={status:"idle"};statusSubscribers=new Set;selectorPathCache=new WeakMap;middlewareModule;initializedMiddlewares=null;subscribers=new Map;get initStatus(){return{...this.e}}async waitForReady(){if(this.e.status==="ready")return this;if(this.e.status==="error")throw this.e.error||new Error("Storage initialization failed");return new Promise((e,t)=>{let n=this.onStatusChange(r=>{r.status==="ready"?(n(),e(this)):r.status==="error"&&(n(),t(r.error||new Error("Storage initialization failed")))})})}onStatusChange(e){return this.statusSubscribers.add(e),e(this.initStatus),()=>{this.statusSubscribers.delete(e)}}updateInitStatus(e){let t=this.e.status;this.e={...this.e,...e},t!==this.e.status&&this.logger?.debug(`Storage "${this.name}" status changed: ${t} -> ${this.e.status}`);let n=this.initStatus;this.statusSubscribers.forEach(r=>{try{r(n)}catch(a){this.logger?.error("Error in status change callback",{error:a})}})}async initialize(){if(this.e.status==="ready")return this;if(this.e.status==="loading")return this.waitForReady();this.updateInitStatus({status:"loading",error:void 0});try{let e=await this.doInitialize();return this.updateInitStatus({status:"ready",error:void 0}),e}catch(e){throw this.updateInitStatus({status:"error",error:e instanceof Error?e:new Error(String(e))}),e}}ensureReady(){if(this.e.status!=="ready")throw new Error(`Storage "${this.name}" is not ready. Current status: ${this.e.status}`)}initializeMiddlewares(){this.config.middlewares&&!this.initializedMiddlewares&&(this.initializedMiddlewares=this.config.middlewares(()=>this.getDefaultMiddleware()),this.initializedMiddlewares.forEach(e=>this.middlewareModule.use(e)))}getDefaultMiddleware(){return{batching:(e={})=>Fe(e),shallowCompare:(e={})=>$e(e)}}async initializeWithMiddlewares(){try{let e=await this.getState();!(Object.keys(e).length>0)&&this.config.initialState&&await this.middlewareModule.dispatch({type:"init",value:this.config.initialState})}catch(e){throw this.logger?.error("\u041E\u0448\u0438\u0431\u043A\u0430 \u0438\u043D\u0438\u0446\u0438\u0430\u043B\u0438\u0437\u0430\u0446\u0438\u0438 \u0445\u0440\u0430\u043D\u0438\u043B\u0438\u0449\u0430",{error:e}),e}}async get(e){this.ensureReady();try{let t={operation:"get",timestamp:Date.now(),key:e},n=await this.middlewareModule.dispatch({type:"get",key:e,metadata:t}),r=await this.pluginExecutor?.executeAfterGet(e,n,t)??n;return await this.emitEvent({type:"storage:select",payload:{key:e,value:r}}),r}catch(t){throw this.logger?.error("Error getting value",{key:e,error:t}),t}}async set(e,t){this.ensureReady();try{let n={operation:"set",timestamp:Date.now(),key:e},r=await this.pluginExecutor?.executeBeforeSet(t,n)??t,a=await this.middlewareModule.dispatch({type:"set",key:e,value:r,metadata:n}),o=a?.t?.valueNotChanged===!0,i;if(o&&a?.t?.originalValue!==void 0?i=a.t.originalValue:i=await this.pluginExecutor?.executeAfterSet(e,a,n)??a,!o){let d=[e.toString()];this.notifySubscribers(e,i),this.notifySubscribers(s.GLOBAL_SUBSCRIPTION_KEY,{type:"storage:update",key:e,value:i,changedPaths:d}),await this.emitEvent({type:"storage:update",payload:{key:e,value:i,changedPaths:d}})}}catch(n){throw this.logger?.error("Error setting value",{key:e,error:n}),n}}async update(e){this.ensureReady();try{let t={operation:"update",timestamp:Date.now()},n=await this.getState(),r=structuredClone(n);e(r);let a=this.findChangedPaths(n,r);if(a.size===0){this.logger?.debug&&this.logger.debug("No changes detected in update");return}this.logger?.debug&&this.logger.debug("Changed paths:",{paths:Array.from(a)});let o=new Set;for(let g of a){let p=g.split(".")[0];o.add(p)}let i=await Promise.all(Array.from(o).map(async g=>{let p={...t,key:g},f=await this.pluginExecutor?.executeBeforeSet(r[g],p)??r[g];return{key:g,value:f}})),c=await this.middlewareModule.dispatch({type:"update",value:i,metadata:{...t,batchUpdate:!0,changedPaths:Array.from(a)}}),d={};Array.isArray(c)?c.forEach(g=>{g&&typeof g=="object"&&"key"in g&&"value"in g&&(d[g.key]=g.value)}):c&&typeof c=="object"&&(d={...c});let l=Object.keys(d).filter(g=>!this.isEqual(n[g],d[g]));if(l.length===0){this.logger?.debug&&this.logger.debug("No actual changes after middleware processing");return}let u={};l.forEach(g=>{u[g]=d[g]}),this.logger?.debug&&this.logger.debug("Notifying subscribers about changes:",{keys:l}),this.notifySubscribers(s.GLOBAL_SUBSCRIPTION_KEY,{type:"storage:update",key:l,value:u,changedPaths:Array.from(a)});for(let g of a)try{let p=g.split(".")[0];if(p in u){let f;if(g===p)f=u[p];else{let y=g.substring(p.length+1);f=A(u[p],y)}f!==void 0&&this.notifySubscribers(g,f)}}catch(p){this.logger?.error("Error notifying path subscribers",{path:g,error:p})}await this.emitEvent({type:"storage:update",payload:{state:u,key:l,changedPaths:Array.from(a)}})}catch(t){throw this.logger?.error("Error updating state",{error:t}),t}}async delete(e){this.ensureReady();try{let t={operation:"delete",timestamp:Date.now(),key:e};if(await this.pluginExecutor?.executeBeforeDelete(e,t)===!1)return;let r=await this.middlewareModule.dispatch({type:"delete",key:e,metadata:t});if(r===!1)return;await this.pluginExecutor?.executeAfterDelete(e,t);let o=[e.toString()];this.notifySubscribers(e,void 0),this.notifySubscribers(s.GLOBAL_SUBSCRIPTION_KEY,{type:"storage:update",key:e,value:void 0,result:r,changedPaths:o}),await this.emitEvent({type:"storage:update",payload:{key:e,value:void 0,result:r,changedPaths:o}})}catch(t){throw this.logger?.error("Error deleting value",{key:e,error:t}),t}}async clear(){this.ensureReady();try{this.pluginExecutor?.executeOnClear(),await this.middlewareModule.dispatch({type:"clear"})}catch(e){throw this.logger?.error("Error clearing storage",{error:e}),e}}async keys(){this.ensureReady();try{return await this.middlewareModule.dispatch({type:"keys"})}catch(e){throw this.logger?.error("Error getting keys",{error:e}),e}}async has(e){this.ensureReady();try{return await this.doHas(e)}catch(t){throw this.logger?.error("Error checking value existence",{key:e,error:t}),t}}async getState(){try{return await this.doGet("")||{}}catch(e){throw this.logger?.error("Error getting state",{error:e}),e}}subscribeToAll(e){return this.subscribers.has(s.GLOBAL_SUBSCRIPTION_KEY)||this.subscribers.set(s.GLOBAL_SUBSCRIPTION_KEY,new Set),this.subscribers.get(s.GLOBAL_SUBSCRIPTION_KEY).add(e),()=>{let t=this.subscribers.get(s.GLOBAL_SUBSCRIPTION_KEY);t&&(t.delete(e),t.size===0&&this.subscribers.delete(s.GLOBAL_SUBSCRIPTION_KEY))}}subscribe(e,t){return typeof e=="string"?this.subscribeByKey(e,t):this.subscribeBySelector(e,t)}async destroy(){try{if(await this.clear(),await this.doDestroy(),this.initializedMiddlewares&&(await Promise.all(this.initializedMiddlewares.map(async e=>{"cleanup"in e&&await e.cleanup?.()})),this.initializedMiddlewares=null),this.statusSubscribers.clear(),this.config.singleton?.enabled){let e=this.constructor.STORAGE_TYPE,t=K.generate(this.config,e);$.remove(t)}this.updateInitStatus({status:"idle"}),await this.emitEvent({type:"storage:destroy"})}catch(e){throw this.logger?.error("Error destroying storage",{error:e}),e}}subscribeByKey(e,t){this.subscribers.has(e)||this.subscribers.set(e,new Set);let n=!1;return this.subscribers.get(e).add(t),this.get(e).then(r=>{try{n||(n=!0,t(r))}catch(a){this.logger?.error("Error in initial callback",{key:e,error:a})}}),()=>{let r=this.subscribers.get(e);r&&(r.delete(t),r.size===0&&this.subscribers.delete(e))}}createDummyState(){let e={get:(t,n)=>(t[n]=t[n]||new Proxy({},e),t[n])};return new Proxy({},e)}isEqual(e,t){if(e===t)return!0;if(e==null||t==null)return e===t;let n=typeof e;if(n!==typeof t)return!1;if(n!=="object")return e===t;if(e instanceof Date&&t instanceof Date)return e.getTime()===t.getTime();if(Array.isArray(e)&&Array.isArray(t)){if(e.length!==t.length)return!1;for(let i=0;i<e.length;i++)if(!this.isEqual(e[i],t[i]))return!1;return!0}let a=Object.keys(e),o=Object.keys(t);return a.length!==o.length?!1:a.every(i=>Object.prototype.hasOwnProperty.call(t,i)&&this.isEqual(e[i],t[i]))}extractPath(e,t){if(this.selectorPathCache.has(e))return this.selectorPathCache.get(e);let n=[],r=(a="")=>({get:(o,i)=>{if(typeof i=="symbol")return Reflect.get(o,i);let c=a?`${a}.${i}`:i;return n.push(c),new Proxy({},r(c))},has:(o,i)=>!0,ownKeys:()=>[],getOwnPropertyDescriptor:()=>({configurable:!0,enumerable:!0}),apply:(o,i,c)=>new Proxy(()=>{},r(a))});try{e(new Proxy(t,r()))}catch{}return n.length===0?"":(n.sort((a,o)=>o.length-a.length),this.selectorPathCache.set(e,n[0]),n[0])}notifySubscribers(e,t){let n=e.toString(),r=this.subscribers.get(n);r?.size&&new Set(r).forEach(o=>{try{o(t)}catch(i){this.logger?.error("\u041E\u0448\u0438\u0431\u043A\u0430 \u0432 \u043F\u043E\u0434\u043F\u0438\u0441\u0447\u0438\u043A\u0435 \u043D\u0430 \u043A\u043E\u043B\u0431\u044D\u043A",{key:n,error:i})}})}findChangedPaths(e,t,n="",r=new Set,a=new WeakMap){if(e===t)return r;if(typeof e!="object"||typeof t!="object"||e===null||t===null)return e!==t&&r.add(n||""),r;if(a.has(e))return r;a.set(e,!0);let o=new Set([...Object.keys(e||{}),...Object.keys(t||{})]);for(let i of o){let c=e[i],d=t[i];if(c===d)continue;let l=n?`${n}.${i}`:i;c&&d&&typeof c=="object"&&typeof d=="object"&&!Array.isArray(c)&&!Array.isArray(d)?this.findChangedPaths(c,d,l,r,a):Array.isArray(c)&&Array.isArray(d)?this.isEqual(c,d)||r.add(l):this.isEqual(c,d)||r.add(l)}return r}subscribeBySelector(e,t){let n=this.createDummyState(),r=this.extractPath(e,n);this.logger?.debug&&this.logger.debug("Subscribing to path:",{path:r});let a=async o=>{try{if(o==null){let d=await this.getState(),l=e(d);t(l);return}if(typeof o!="object"||o===null){t(o);return}let i=await this.getState(),c=e(i);t(c)}catch(i){this.logger?.error("Error in selector callback",{path:r,error:i}),t(o)}};return r?this.subscribeByKey(r,a):this.subscribeToAll(()=>{this.getState().then(o=>{t(e(o))})})}async emitEvent(e){try{await this.eventEmitter?.emit({...e,metadata:{...e.metadata||{},timestamp:Date.now(),storageName:this.name}})}catch(t){this.logger?.error("Error emitting event",{event:e,error:t})}}};var ue=class s{constructor(e,t,n){this.dbName=e;this.logger=n;this.dbVersion=t}static instances=new Map;db=null;initPromise=null;storeNames=new Set;dbVersion;static getInstance(e,t=1,n){s.instances.has(e)||s.instances.set(e,new s(e,t,n));let r=s.instances.get(e);return t>r.dbVersion&&(r.dbVersion=t),r}async initialize(){return this.db?this.db:(this.initPromise||(this.initPromise=this.openDatabase()),this.initPromise)}async ensureStoreExists(e){if(await this.initialize(),this.db.objectStoreNames.contains(e))return this.storeNames.add(e),this.db;this.logger?.debug(`Store "${e}" not found, upgrading database`,{dbName:this.dbName,currentStores:Array.from(this.db.objectStoreNames)}),this.db.close(),this.db=null,this.dbVersion++,this.initPromise=this.openDatabase([e]);let t=await this.initPromise;return this.storeNames.add(e),t}async openDatabase(e=[]){return new Promise((t,n)=>{this.logger?.debug(`Opening database "${this.dbName}" with version ${this.dbVersion}`);let r=indexedDB.open(this.dbName,this.dbVersion);r.onerror=()=>{this.logger?.error(`Failed to open database "${this.dbName}"`,{error:r.error}),n(r.error)},r.onsuccess=()=>{this.db=r.result;for(let a=0;a<this.db.objectStoreNames.length;a++)this.storeNames.add(this.db.objectStoreNames[a]);this.logger?.debug(`Database "${this.dbName}" opened successfully`,{version:this.db.version,stores:Array.from(this.db.objectStoreNames)}),t(this.db)},r.onupgradeneeded=a=>{let o=a.target.result;this.logger?.debug(`Upgrading database "${this.dbName}" to version ${this.dbVersion}`);for(let i of e)o.objectStoreNames.contains(i)||(this.logger?.debug(`Creating store "${i}"`),o.createObjectStore(i))}})}closeDatabase(){this.db&&(this.db.close(),this.db=null,this.initPromise=null)}async deleteDatabase(){return this.closeDatabase(),new Promise((e,t)=>{let n=indexedDB.deleteDatabase(this.dbName);n.onsuccess=()=>{this.logger?.debug(`Database "${this.dbName}" deleted successfully`),s.instances.delete(this.dbName),this.storeNames.clear(),e()},n.onerror=()=>{this.logger?.error(`Failed to delete database "${this.dbName}"`,{error:n.error}),t(n.error)}})}async ensureStoresExist(e){await this.initialize();let t=e.filter(n=>!this.db.objectStoreNames.contains(n));return t.length===0?this.db:(this.logger?.debug(`\u0421\u043E\u0437\u0434\u0430\u043D\u0438\u0435 \u043D\u0435\u0434\u043E\u0441\u0442\u0430\u044E\u0449\u0438\u0445 \u0445\u0440\u0430\u043D\u0438\u043B\u0438\u0449: ${t.join(", ")}`,{dbName:this.dbName,currentStores:Array.from(this.db.objectStoreNames)}),this.db.close(),this.db=null,this.dbVersion++,this.initPromise=this.openDatabase(t),this.initPromise)}getCurrentVersion(){return this.dbVersion}},ge=class{constructor(e,t=1,n){this.dbName=e;this.logger=n;this.version=t}db=null;version;getCurrentVersion(){return this.version}openDatabase(e,t=[]){return new Promise((n,r)=>{this.logger?.debug(`\u041E\u0442\u043A\u0440\u044B\u0442\u0438\u0435 \u0431\u0430\u0437\u044B \u0434\u0430\u043D\u043D\u044B\u0445 "${this.dbName}" \u0441 \u0432\u0435\u0440\u0441\u0438\u0435\u0439 ${e}`);let a=indexedDB.open(this.dbName,e);a.onerror=()=>{this.logger?.error(`\u041E\u0448\u0438\u0431\u043A\u0430 \u043F\u0440\u0438 \u043E\u0442\u043A\u0440\u044B\u0442\u0438\u0438 \u0431\u0430\u0437\u044B \u0434\u0430\u043D\u043D\u044B\u0445 "${this.dbName}"`,{error:a.error}),r(a.error)},a.onsuccess=()=>{this.db=a.result,this.version=this.db.version,this.logger?.debug(`\u0411\u0430\u0437\u0430 \u0434\u0430\u043D\u043D\u044B\u0445 "${this.dbName}" \u0443\u0441\u043F\u0435\u0448\u043D\u043E \u043E\u0442\u043A\u0440\u044B\u0442\u0430`,{version:this.db.version,stores:Array.from(this.db.objectStoreNames)}),n(this.db)},a.onupgradeneeded=o=>{let i=o.target.result;this.logger?.debug(`\u041E\u0431\u043D\u043E\u0432\u043B\u0435\u043D\u0438\u0435 \u0431\u0430\u0437\u044B \u0434\u0430\u043D\u043D\u044B\u0445 "${this.dbName}" \u0434\u043E \u0432\u0435\u0440\u0441\u0438\u0438 ${e}`);for(let c of t)i.objectStoreNames.contains(c)||(this.logger?.debug(`\u0421\u043E\u0437\u0434\u0430\u043D\u0438\u0435 \u0445\u0440\u0430\u043D\u0438\u043B\u0438\u0449\u0430 "${c}"`),i.createObjectStore(c))}})}async ensureStoresExist(e){this.db||(this.db=await this.openDatabase(this.version));let t=e.filter(n=>!this.db.objectStoreNames.contains(n));return t.length===0?this.db:(this.logger?.debug(`\u041D\u0435\u043E\u0431\u0445\u043E\u0434\u0438\u043C\u043E \u0441\u043E\u0437\u0434\u0430\u0442\u044C \u043E\u0442\u0441\u0443\u0442\u0441\u0442\u0432\u0443\u044E\u0449\u0438\u0435 \u0445\u0440\u0430\u043D\u0438\u043B\u0438\u0449\u0430: ${t.join(", ")}`,{dbName:this.dbName,currentVersion:this.version}),this.db.close(),this.db=null,this.version++,this.db=await this.openDatabase(this.version,t),this.db)}close(){this.db&&(this.db.close(),this.db=null)}},k=class s extends F{static STORAGE_TYPE="memory";DB_NAME;STORE_NAME;DB_VERSION;dbManager;constructor(e,t,n,r){super(e,t,n,r);let a=e.options;this.DB_NAME=a.dbName||"app_storage",this.STORE_NAME=e.name,this.DB_VERSION=a.dbVersion||1,this.dbManager=ue.getInstance(this.DB_NAME,this.DB_VERSION,r)}getStorageType(){return"memory"}static create(e,t,n,r){return M.handleSingletonCreation(e,this.STORAGE_TYPE,a=>new s(a,t,n,r),r)}async doInitialize(){try{if(this.logger?.debug(`Initializing IndexedDB storage "${this.STORE_NAME}"`),await this.dbManager.ensureStoreExists(this.STORE_NAME),!(await this.dbManager.initialize()).objectStoreNames.contains(this.STORE_NAME))throw new Error(`Store "${this.STORE_NAME}" not found after initialization`);return this.initializeMiddlewares(),await this.initializeWithMiddlewares(),this.logger?.debug(`IndexedDB storage "${this.STORE_NAME}" initialized successfully`),this}catch(e){throw this.logger?.error(`\u041E\u0448\u0438\u0431\u043A\u0430 \u0438\u043D\u0438\u0446\u0438\u0430\u043B\u0438\u0437\u0430\u0446\u0438\u0438 IndexedDB "${this.name}"`,{error:e}),e}}static async getCurrentDBVersion(e){return new Promise(t=>{try{let n=indexedDB.open(e);n.onsuccess=()=>{let r=n.result.version;n.result.close(),t(r)},n.onerror=()=>{t(0)}}catch{t(0)}})}static async createStorages(e,t,n){let a=await this.getCurrentDBVersion(e)||1,o=new ge(e,a,n),i=Object.values(t).map(d=>d.name);await o.ensureStoresExist(i);let c={};for(let[d,l]of Object.entries(t)){let u=new s({...l,options:{dbName:e,dbVersion:o.getCurrentVersion()}},l.pluginExecutor,l.eventEmitter,n);c[d]=await u.initialize()}return c}async getTransaction(e="readonly"){try{let t=await this.dbManager.ensureStoreExists(this.STORE_NAME);if(!t.objectStoreNames.contains(this.STORE_NAME)){this.logger?.warn(`Object store "${this.STORE_NAME}" not found, attempting to repair`),t.close(),this.dbManager.closeDatabase();let n=await this.dbManager.ensureStoreExists(this.STORE_NAME);if(!n.objectStoreNames.contains(this.STORE_NAME))throw new Error(`Object store "${this.STORE_NAME}" still doesn't exist after repair attempt`);return n.transaction(this.STORE_NAME,e)}return t.transaction(this.STORE_NAME,e)}catch(t){throw this.logger?.error(`Failed to create transaction for store "${this.STORE_NAME}"`,{error:t}),t}}async getObjectStore(e="readonly"){return(await this.getTransaction(e)).objectStore(this.STORE_NAME)}async doGet(e){let t=await this.getObjectStore();if(e==="")return new Promise((r,a)=>{let o=t.getAll();o.onerror=()=>a(o.error),o.onsuccess=()=>{let i=o.result,c=t.getAllKeys();c.onsuccess=()=>{let d=c.result.reduce((l,u,g)=>(u!=="root"&&(l[u]=i[g]),l),{});r(d)},c.onerror=()=>a(c.error)}});if(e instanceof T&&e.isUnparseable())return new Promise((r,a)=>{let o=t.get(e.valueOf());o.onerror=()=>a(o.error),o.onsuccess=()=>r(o.result)});let n=P(e);if(n.length>1){let r=n[0];return new Promise((a,o)=>{let i=t.get(r);i.onerror=()=>o(i.error),i.onsuccess=()=>{let c=i.result;if(!c){a(void 0);return}let d=A(c,n.slice(1).join("."));a(d)}})}return new Promise((r,a)=>{let o=t.get(n[0]);o.onerror=()=>a(o.error),o.onsuccess=()=>r(o.result)})}async doSet(e,t){if(e===""){let a=await this.getObjectStore("readwrite");return new Promise((o,i)=>{let c=a.transaction;c.oncomplete=()=>{o()},c.onerror=()=>{i(c.error)};let d=a.clear();d.onsuccess=()=>{let l=Object.entries(t);for(let[u,g]of l)a.put(g,u)},d.onerror=()=>{i(d.error)}})}let n=await this.getObjectStore("readwrite");if(e instanceof T&&e.isUnparseable()){await this.putValueInStore(n,e.valueOf(),t);return}let r=P(e);if(r.length>1){let a=r[0];return new Promise((o,i)=>{let c=n.get(a);c.onerror=()=>i(c.error),c.onsuccess=()=>{let d=c.result||{},l=O(d,r.slice(1).join("."),t),u=n.put(l,a);u.onerror=()=>i(u.error),u.onsuccess=()=>o()}})}await this.putValueInStore(n,r[0],t)}async putValueInStore(e,t,n){return new Promise((r,a)=>{let o=e.put(n,t.valueOf());o.onerror=()=>a(o.error),o.onsuccess=()=>r()})}async doUpdate(e){let t=new Map,n=[];for(let{key:r,value:a}of e){if(r instanceof T&&r.isUnparseable()){n.push({key:r.valueOf(),value:a});continue}let o=P(r),i=o[0],c=o.slice(1);t.has(i)||t.set(i,[]),t.get(i).push({path:c,value:a})}try{for(let{key:r,value:a}of n){let o=await this.getObjectStore("readwrite");await this.putValueInStore(o,r,a)}for(let[r,a]of t){let i={...await this.doGet(r)||{}};for(let{path:d,value:l}of a)d.length===0?i=l:i=O(i,d.join("."),l);let c=await this.getObjectStore("readwrite");await this.putValueInStore(c,r,i)}}catch(r){throw this.logger?.error("Error during update:",{error:r}),r}}async doDelete(e){let t=await this.getObjectStore("readwrite");if(e instanceof T&&e.isUnparseable())return new Promise((a,o)=>{let i=t.delete(e.valueOf());i.onerror=()=>o(i.error),i.onsuccess=()=>a(!0)});let n=P(e);if(n.length===1)return new Promise((a,o)=>{let i=t.delete(n[0]);i.onerror=()=>o(i.error),i.onsuccess=()=>a(!0)});let r=n[0];return new Promise((a,o)=>{let i=t.get(r);i.onerror=()=>o(i.error),i.onsuccess=()=>{let c=i.result;if(!c){a(!1);return}let d=A(c,n.slice(0,-1).join(".")),l=n[n.length-1];if(!d||!(l in d)){a(!1);return}if(Array.isArray(d)){let g=parseInt(l,10);isNaN(g)?delete d[l]:d.splice(g,1)}else delete d[l];let u=t.put(c,r);u.onerror=()=>o(u.error),u.onsuccess=()=>a(!0)}})}async doClear(){let e=await this.getObjectStore("readwrite");return new Promise((t,n)=>{let r=e.clear();r.onsuccess=()=>t(),r.onerror=()=>n(r.error)})}async doKeys(){let t=(await this.getObjectStore()).getAllKeys();return new Promise((n,r)=>{t.onsuccess=()=>{n(t.result)},t.onerror=()=>r(t.error)})}async doHas(e){return await this.doGet(e)!==void 0}async doDestroy(){try{await this.doClear()}catch(e){throw this.logger?.error(`Error destroying store "${this.STORE_NAME}"`,{error:e}),e}}};var U=class s extends F{static STORAGE_TYPE="localStorage";constructor(e,t,n,r){super(e,t,n,r)}static create(e,t,n,r){return M.handleSingletonCreation(e,this.STORAGE_TYPE,a=>new s(a,t,n,r),r)}async doInitialize(){try{return this.logger?.debug(`Initializing LocalStorage "${this.name}"`),this.initializeMiddlewares(),await this.initializeWithMiddlewares(),this.logger?.debug(`LocalStorage "${this.name}" initialized successfully`),this}catch(e){throw this.logger?.error("Error initializing LocalStorage",{error:e}),e}}async doGet(e){let t=localStorage.getItem(this.name);if(!t)return;let n=JSON.parse(t);return e instanceof T&&e.isUnparseable()?n[e.valueOf()]:A(n,e)}async doSet(e,t){let n=localStorage.getItem(this.name),r=n?JSON.parse(n):{};if(e instanceof T&&e.isUnparseable()){r[e.valueOf()]=t,localStorage.setItem(this.name,JSON.stringify(r));return}let a=O({...r},e,t);localStorage.setItem(this.name,JSON.stringify(a))}async doDelete(e){let t=localStorage.getItem(this.name);if(!t)return!1;let n=JSON.parse(t);if(e instanceof T&&e.isUnparseable()){let c=e.valueOf();return c in n?(delete n[c],localStorage.setItem(this.name,JSON.stringify(n)),!0):!1}let r=P(e),a=r.slice(0,-1).join("."),o=r[r.length-1],i=a?A(n,a):n;return!i||!(o in i)?!1:(delete i[o],localStorage.setItem(this.name,JSON.stringify(n)),!0)}async doUpdate(e){let t=localStorage.getItem(this.name),n=t?JSON.parse(t):{};for(let{key:r,value:a}of e)r instanceof T&&r.isUnparseable()?n[r.valueOf()]=a:O(n,r,a);localStorage.setItem(this.name,JSON.stringify(n))}async doClear(){localStorage.removeItem(this.name)}async doKeys(){let e=localStorage.getItem(this.name);if(!e)return[];let t=JSON.parse(e);return this.getAllKeys(t)}async doHas(e){return await this.doGet(e)!==void 0}getAllKeys(e){return Object.keys(e)}async doDestroy(){await this.doClear()}};var B=class s extends F{static STORAGE_TYPE="memory";storage=new Map;constructor(e,t,n,r){super(e,t,n,r)}static create(e,t,n,r){return M.handleSingletonCreation(e,this.STORAGE_TYPE,a=>new s(a,t,n,r),r)}async doInitialize(){try{return this.logger?.debug(`Initializing MemoryStorage "${this.name}"`),this.initializeMiddlewares(),await this.initializeWithMiddlewares(),this.logger?.debug(`MemoryStorage "${this.name}" initialized successfully`),this}catch(e){throw this.logger?.error("Error initializing MemoryStorage",{error:e}),e}}async doGet(e){let t=this.storage.get(this.name);if(t)return e instanceof T&&e.isUnparseable()?t[e.valueOf()]:A(t,e)}async doSet(e,t){let n=this.storage.get(this.name)||{};if(e instanceof T&&e.isUnparseable()){n[e.valueOf()]=t,this.storage.set(this.name,n);return}let r=O({...n},e,t);this.storage.set(this.name,r)}async doDelete(e){let t=this.storage.get(this.name);if(!t)return!1;if(e instanceof T&&e.isUnparseable()){let i=e.valueOf();return i in t?(delete t[i],this.storage.set(this.name,t),!0):!1}let n=P(e),r=n.slice(0,-1).join("."),a=n[n.length-1],o=r?A(t,r):t;return!o||!(a in o)?!1:(delete o[a],this.storage.set(this.name,t),!0)}async doUpdate(e){let n={...this.storage.get(this.name)||{}};for(let{key:r,value:a}of e)r instanceof T&&r.isUnparseable()?n[r.valueOf()]=a:O(n,r,a);this.storage.set(this.name,n)}async doClear(){this.storage.delete(this.name)}async doKeys(){let e=this.storage.get(this.name);return e?this.getAllKeys(e):[]}async doHas(e){return await this.doGet(e)!==void 0}async doDestroy(){this.storage.delete(this.name)}getAllKeys(e){return Object.keys(e)}};var L=class{static createMemory(e,t,n,r){return B.create(e,t,n,r)}static createLocal(e,t,n,r){return U.create(e,t,n,r)}static createIndexedDB(e,t,n,r){return k.create(e,t,n,r)}static create(e,t,n,r){switch(e.type){case"memory":return this.createMemory(e,t,n,r);case"localStorage":return this.createLocal(e,t,n,r);case"indexedDB":return this.createIndexedDB(e,t,n,r);default:throw new Error(`Unsupported storage type: ${e.type}`)}}};import{useCallback as Be,useEffect as pe,useMemo as Ye,useRef as Je,useState as Xe}from"react";function jn(s,e={},t,n,r){let{autoInitialize:a=!0,destroyOnUnmount:o=!0}=e,i=Je(null),[c,d]=Xe({status:"idle"}),l=Ye(()=>{if(!i.current)try{i.current=L.create(s,t,n,r)}catch(b){return d({status:"error",error:b}),null}return i.current},[s,t,n,r]),u=Be(async()=>{if(l)try{d({status:"loading"}),await l.initialize(),d({status:"ready"})}catch(b){d({status:"error",error:b})}},[l]),g=Be(async()=>{if(l)try{await l.destroy(),d({status:"idle"})}catch(b){d({status:"error",error:b})}},[l]);pe(()=>l?l.onStatusChange(h=>{d(h)}):void 0,[l]),pe(()=>{a&&l&&c.status==="idle"&&u()},[a,l,c.status,u]),pe(()=>()=>{o&&l&&l.destroy().catch(console.error)},[o,l]);let p=c.status==="ready",f=c.status==="loading",y=c.status==="error";return{storage:l,status:c,initialize:u,destroy:g,isReady:p,isLoading:f,hasError:y}}import{useEffect as Ze,useRef as Ke,useState as Ne}from"react";var j=new Map;function zn(s,e){let[t,n]=Ne(e?.initialValue),[r,a]=Ne(!!e?.withLoading),o=Ke(e?.initialValue),i=Ke(e?.equals||((l,u)=>l===u)),c=s.getId(),d=l=>{(o.current===void 0||!i.current(l,o.current))&&(o.current=l,n(l))};return Ze(()=>{j.has(c)||j.set(c,{lastValue:void 0,listeners:new Set,unsubscribe:null});let l=j.get(c);return l.listeners.add(d),l.lastValue!==void 0?(d(l.lastValue),e?.withLoading&&a(!1)):(e?.withLoading&&a(!0),s.select().then(u=>{l.lastValue=u,l.listeners.forEach(g=>g(u)),e?.withLoading&&a(!1)}).catch(u=>{e?.withLoading&&a(!1)})),l.unsubscribe||(l.unsubscribe=s.subscribe({notify:u=>{l.lastValue=u,l.listeners.forEach(g=>{try{g(u)}catch{}})}})),()=>{let u=j.get(c);u&&(u.listeners.delete(d),u.listeners.size===0&&(u.unsubscribe&&u.unsubscribe(),j.delete(c)))}},[s,c]),e?.withLoading?{data:t,isLoading:r}:t}import{useEffect as et,useState as tt}from"react";var Wn=(s,e)=>{let[t,n]=tt(void 0);return et(()=>{let r=!0;(async()=>{try{let i=await s.getState(),c=e(i);r&&n(c)}catch{}})();let o;try{o=s.subscribe(e,i=>{r&&n(i)})}catch{o=()=>{}}return()=>{r=!1,o()}},[s,e]),t};import{useEffect as vt,useState as Se}from"react";import{Observable as rt,Subject as qe}from"rxjs";var fe=class{constructor(e){this.options=e;this.storage=e.storage,this.middlewareAPI={getState:()=>this.storage.getState(),dispatch:async t=>(this.actions$.next(t),t.payload),storage:this.storage,actions$:this.actions,actions:this.dispatch,watchers:this.watchers,findActionByType:t=>this.findActionByType(t),findWatcherByType:t=>this.findWatcherByType(t)},e.middlewares&&e.middlewares.length>0&&this.use(...e.middlewares)}actions$=new qe;actions=this.actions$.asObservable();dispatch={};watchers={};storage;middlewareFunctions=[];middlewareAPI;use(...e){for(let t=0;t<e.length;t++)try{let n=e[t](this.middlewareAPI);this.middlewareFunctions.push(n)}catch{}return this}getActions(){return this.dispatch}getTypedDispatch(){return this.dispatch}getTypedWatchers(){return this.watchers}findActionByType(e){return Object.values(this.dispatch).find(t=>t.actionType.split(`[${this.storage.name}]`)[1]===e)}findWatcherByType(e){return Object.values(this.watchers).find(t=>t.actionType===e)}createAction(e,t){let n=`[${this.storage.name}]${e.type}`,r=null,a=null,o=async i=>{let c=[i];if(t?.memoize&&r&&a&&t.memoize(c,r,a))return a;let d={type:n,meta:e.meta},l;if(this.middlewareFunctions.length>0){let u=async g=>t?.worker?this.executeInWorker(t.worker,n,c,e.action):Promise.resolve(e.action(i));for(let g=this.middlewareFunctions.length-1;g>=0;g--){let p=this.middlewareFunctions[g],f=u;u=async y=>p(async h=>f(h))(y)}l=await u(d)}else t?.worker?l=await this.executeInWorker(t.worker,n,c,e.action):l=await e.action(i);return d.payload=l,r=[...c],a=l,this.actions$.next(d),l};return o.r="dispatch",Object.defineProperty(o,"actionType",{value:n,writable:!1,enumerable:!0}),e.meta&&Object.defineProperty(o,"meta",{value:e.meta,writable:!1,enumerable:!0}),o}createWatcher(e){let t=`[${this.storage.name}]${e.type}`,n=new qe,r,a=async()=>{let c=await this.storage.getState();return e.selector(c)},o=this.storage.subscribe(e.selector,c=>{if(!e.shouldTrigger||e.shouldTrigger(r,c)){let d={type:t,payload:c,meta:e.meta};this.actions$.next(d),n.next(d),r=c}}),i=()=>{let c=n.asObservable();return e.notifyAfterSubscribe?new rt(d=>{let l=!1;a().then(g=>{if(!e.shouldTrigger||e.shouldTrigger(void 0,g)){let p={type:t,payload:g,meta:{...e.meta,isInitial:!0}};d.next(p),r=g,l=!0}}).catch(g=>{d.error(g)});let u=c.subscribe({next:g=>{l&&g.payload===r||d.next(g)},error:g=>d.error(g),complete:()=>d.complete()});return()=>{u.unsubscribe()}}):c};return i.r="watchers",Object.defineProperty(i,"actionType",{value:t,writable:!1,enumerable:!0}),e.meta&&Object.defineProperty(i,"meta",{value:e.meta,writable:!1,enumerable:!0}),Object.defineProperty(i,"unsubscribe",{value:o,writable:!1,enumerable:!0}),i}async executeInWorker(e,t,n,r){return new Promise((a,o)=>{let i=`${t}_${Date.now()}_${Math.random()}`,c=d=>{d.data.requestId===i&&(e.removeEventListener("message",c),d.data.error?o(new Error(d.data.error)):a(d.data.result))};e.addEventListener("message",c),e.postMessage({type:t,args:n,requestId:i}),setTimeout(()=>{e.removeEventListener("message",c),o(new Error(`Worker execution timeout for action: ${t}`))},3e4)})}};function ke(s,e){let t=new fe(s),n=e(s.storage,{createAction:(r,a)=>t.createAction(r,a),createWatcher:r=>t.createWatcher(r)});for(let[r,a]of Object.entries(n))if(typeof a=="function"){let o=a.r;t[o][r]=a}return t}function ee(s,e=1){if(e<=0)throw new Error("Size must be greater than 0");if(!s||!s.length)return[];let t=[],n=s.length,r=0;for(;r<n;)t.push(s.slice(r,r+e)),r+=e;return t}var N=globalThis.console,C={log:(...s)=>N.log(...s),warn:(...s)=>N.warn(...s),error:(...s)=>N.error(...s),group:(...s)=>N.group(...s),groupEnd:()=>N.groupEnd(),groupCollapsed:(...s)=>N.groupCollapsed(...s)};function Ue(s,e){let t={};return[...new Set([...Object.keys(s),...Object.keys(e)])].forEach(r=>{if(r in s&&r in e)if(typeof s[r]=="object"&&s[r]!==null&&typeof e[r]=="object"&&e[r]!==null&&!Array.isArray(s[r])&&!Array.isArray(e[r])){let a=Ue(s[r],e[r]);Object.keys(a).length>0&&(t[r]=a)}else JSON.stringify(s[r])!==JSON.stringify(e[r])&&(t[r]={PREV:s[r],NEXT:e[r]});else r in s?t[r]={PREV:s[r],NEXT:void 0}:t[r]={PREV:void 0,NEXT:e[r]}}),t}var gs=(s={})=>{let e={action:"\u0414\u0435\u0439\u0441\u0442\u0432\u0438\u0435",prevState:"\u041F\u0440\u0435\u0434\u044B\u0434\u0443\u0449\u0435\u0435 \u0441\u043E\u0441\u0442\u043E\u044F\u043D\u0438\u0435",nextState:"\u0421\u043B\u0435\u0434\u0443\u044E\u0449\u0435\u0435 \u0441\u043E\u0441\u0442\u043E\u044F\u043D\u0438\u0435",duration:"\u0414\u043B\u0438\u0442\u0435\u043B\u044C\u043D\u043E\u0441\u0442\u044C",error:"\u041E\u0448\u0438\u0431\u043A\u0430 \u0432 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0438",diff:"\u0418\u0437\u043C\u0435\u043D\u0435\u043D\u0438\u044F",changesCount:"\u041A\u043E\u043B\u0438\u0447\u0435\u0441\u0442\u0432\u043E \u0438\u0437\u043C\u0435\u043D\u0435\u043D\u0438\u0439",showFullState:"\u041F\u043E\u043B\u043D\u043E\u0435 \u0441\u043E\u0441\u0442\u043E\u044F\u043D\u0438\u0435"},t={collapsed:!1,duration:!0,diff:!1,showFullState:!0,translations:e,colors:{title:"#3498db",prevState:"#9E9E9E",fullState:"#008a15",action:"#03A9F4",nextState:"#4CAF50",error:"#F20404",diff:"#9C27B0"}},n={...t,...s,translations:{...e,...s.translations||{}},colors:{...t.colors,...s.colors||{}}},{collapsed:r,duration:a,colors:o,translations:i}=n;return c=>d=>async l=>{let u=Date.now(),g=await c.getState();try{let p=await d(l),f=await c.getState(),b=Date.now()-u,h=`${l.type}`;if((r?C.groupCollapsed:C.group)(`%c ${h}`,`color: ${o.title}; font-weight: bold`),C.log(`%c ${i.action}:`,`color: ${o.action}; font-weight: bold`,l),n.diff){let v=Ue(g,f),E=Object.keys(v).length;C.log(`%c ${i.diff} (${i.changesCount}: ${E}):`,`color: ${o.diff}; font-weight: bold`,v)}return n.showFullState&&(C.groupCollapsed(`%c ${i.showFullState}`,`color: ${o.fullState}; font-weight: bold`),C.log(`%c ${i.prevState}:`,`color: ${o.prevState}; font-weight: bold`,g),C.log(`%c ${i.nextState}:`,`color: ${o.nextState}; font-weight: bold`,f),C.groupEnd()),a&&C.log(`%c ${i.duration}: %c ${b}ms`,"font-weight: bold","color: #4CAF50"),C.groupEnd(),p}catch(p){throw C.error(`%c ${i.error}:`,`color: ${o.error}; font-weight: bold`,l.type,p),p}}};import{combineLatest as dt,merge as ut,Observable as gt,of as V,pipe as pt,Subject as ft}from"rxjs";import{catchError as yt,filter as _,map as te,share as ht,switchMap as St,take as mt}from"rxjs/operators";import{of as Le}from"rxjs";import{concatAll as nt,delay as st,mergeMap as ot,toArray as at}from"rxjs/operators";var je=(s,e,t,n=0)=>{let r=ee(e,t).map(a=>Le(a).pipe(st(n),ot(s)));return Le(...r).pipe(nt(),at())};import{forkJoin as it,timer as ct}from"rxjs";import{mergeMap as lt}from"rxjs/operators";var Ve=(s,e,t,n=0)=>it(ee(e,t).map((r,a)=>ct(a*n).pipe(lt(()=>s(r)))));function qs(s){let{actionType:e}=s;return e?t=>t.pipe(_(n=>n!==void 0&&n.type===e)):_(()=>!1)}function ks(s){let e=s.map(t=>t.actionType).filter(Boolean);return e.length===0?_(()=>!1):t=>t.pipe(_(n=>n!==void 0&&e.includes(n.type)))}function Us(s){return e=>{let t=s.map(r=>r.actionType).filter(Boolean);if(t.length===0)return V([]);let n=t.map((r,a)=>e.pipe(_(o=>o.type===r),mt(1),te(o=>({index:a,action:o}))));return dt(n).pipe(te(r=>(r.sort((a,o)=>a.index-o.index),r.map(a=>a.action))))}}function Ls(s,...e){return s.pipe(te(t=>e.map(n=>n(t))))}function js(s,e){return s.pipe(te(t=>{let n={};for(let[r,a]of Object.entries(e))n[r]=a(t);return n}))}function Vs({validator:s,apiCall:e}){return pt(St(t=>{let n=()=>e(t,{chunkRequest:Ve,chunkRequestConsistent:je});if(!s)return n();let r=s(t),{conditions:a,skipAction:o}=r;return a.every(Boolean)?n():Array.isArray(o)?V(...o?.filter(Boolean).map(c=>typeof c=="function"?c():c)):V(typeof o=="function"?o():o)}))}var re=class{constructor(e,t={},n,r={},a={}){this.storage=e;this.externalStates=t;this.dispatchers=n;this.services=r;this.config=a;this.subscribeToDispatchers(),this.state$=new gt(o=>{this.storage.getState().then(c=>o.next(c));let i=this.storage.subscribeToAll(()=>{this.storage.getState().then(c=>o.next(c))});return()=>i()}).pipe(ht())}effects=[];subscriptions=[];running=!1;action$=new ft;state$;subscribeToDispatchers(){for(let[e,t]of Object.entries(this.dispatchers)){let n=t.actions.subscribe(r=>{this.action$.next(r)});this.subscriptions.push(n)}}add(e){return this.effects.push(e),this.running&&this.subscribeToEffect(e),this}addEffects(e){return e.forEach(t=>this.add(t)),this}async start(){return this.running?this:(await this.storage.waitForReady(),this.effects.forEach(e=>this.subscribeToEffect(e)),this.running=!0,this)}stop(){return this.subscriptions.forEach(e=>e.unsubscribe()),this.subscriptions=[],this.running=!1,this}subscribeToEffect(e){try{let n=e(this.action$.asObservable(),this.state$,this.externalStates,this.dispatchers,this.services,this.config).pipe(yt(r=>V(null))).subscribe(r=>{if(r!=null&&typeof r=="function")try{r()}catch{}});this.subscriptions.push(n)}catch{}}};function _s(s){return s}function zs(s){return s}function Gs(...s){return(e,t,n,r,a,o)=>{let i=s.map(c=>{try{return c(e,t,n,r,a,o)}catch{return V(null)}});return ut(...i)}}function Tt(s){if(!s.storage&&!s.createStorageFn)throw new Error('Synapse config must have either "storage" or "createStorageFn"');if(s.storage&&s.createStorageFn)throw new Error('Synapse config cannot have both "storage" and "createStorageFn". Choose one.');if(s.effects&&!s.createDispatcherFn)throw new Error('Effects require dispatcher. Add "createDispatcherFn" to config.');if(s.createEffectConfig&&!s.createDispatcherFn)throw new Error('Effect config requires dispatcher. Add "createDispatcherFn" to config.');if(s.dependencies){if(!Array.isArray(s.dependencies))throw new Error("Dependencies must be an array");s.dependencies.forEach((e,t)=>{if(!e||typeof e!="object")throw new Error(`Dependency at index ${t} must be an object`);if(!e.storage||typeof e.storage.waitForReady!="function")throw new Error(`Dependency at index ${t} must have a storage with waitForReady method`)})}if(s.createStorageFn&&typeof s.createStorageFn!="function")throw new Error('"createStorageFn" must be a function');if(s.createDispatcherFn&&typeof s.createDispatcherFn!="function")throw new Error('"createDispatcherFn" must be a function');if(s.createSelectorsFn&&typeof s.createSelectorsFn!="function")throw new Error('"createSelectorsFn" must be a function');if(s.createEffectConfig&&typeof s.createEffectConfig!="function")throw new Error('"createEffectConfig" must be a function');if(s.effects){if(!Array.isArray(s.effects))throw new Error("Effects must be an array");s.effects.forEach((e,t)=>{if(typeof e!="function")throw new Error(`Effect at index ${t} must be a function`)})}if(s.externalSelectors&&typeof s.externalSelectors!="object")throw new Error("External selectors must be an object")}async function bt(s=[]){s.length!==0&&await Promise.all(s.map(async(e,t)=>{try{await e.storage.waitForReady()}catch(n){throw new Error(`Dependency ${t} initialization failed: ${n}`)}}))}async function ye(s){try{Tt(s)}catch(i){throw i}await bt(s.dependencies);let e=s.createStorageFn?await s.createStorageFn():s.storage;await e.waitForReady();let t=[],n={storage:e,selectors:{},destroy:async()=>{for(let i of t)await i()}};t.push(()=>e.destroy());let r,a,o;if(s.createSelectorsFn)try{a=new J(e);let i=s.externalSelectors||{};n.selectors=s.createSelectorsFn(a,i),typeof a.destroy=="function"&&t.push(()=>a.destroy())}catch{}if(s.createDispatcherFn&&(r=s.createDispatcherFn(e),n.dispatcher=r,r&&"dispatch"in r&&(n.actions=r.dispatch,typeof r.destroy=="function"&&t.push(()=>r.destroy()))),s.createEffectConfig&&r)try{let{dispatchers:i,api:c,config:d,externalStates:l}=s.createEffectConfig(r),u=l||{};o=new re(e,u,i,c,d),Array.isArray(s.effects)&&s.effects.forEach(g=>{o&&o.add(g)}),await o.start(),n.state$=o.state$,t.push(()=>{o&&o.stop()})}catch{}return n}function wt(s,e){return e==="*"?!0:e.includes("*")?new RegExp("^"+e.replace(/\*/g,".*")+"$").test(s):s===e}async function Et(s,e){let t=await s.getState(),n=Object.entries(t.events||{});if(n.length>e){let a=n.sort((o,i)=>i[1].timestamp-o[1].timestamp).slice(0,e);await s.set("events",Object.fromEntries(a))}}var Rt=(s={})=>ye({createStorageFn:async()=>new B({name:s.name||"eventBus",initialState:{events:{},subscriptions:{}}}).initialize(),createDispatcherFn:e=>ke({storage:e},(t,{createAction:n})=>({publish:n({type:"PUBLISH_EVENT",meta:{description:"\u041F\u0443\u0431\u043B\u0438\u043A\u0430\u0446\u0438\u044F \u0441\u043E\u0431\u044B\u0442\u0438\u044F \u0432 EventBus"},action:async({event:r,data:a,metadata:o={}})=>{let i=`${r}_${Date.now()}_${Math.random()}`;return await t.set(`events.${i}`,{id:i,event:r,data:a,metadata:{ttl:o.ttl||null,priority:o.priority||"normal",...o},timestamp:Date.now()}),s.autoCleanup&&await Et(t,s.maxEvents||1e3),{eventId:i,event:r,data:a}}}),subscribe:n({type:"SUBSCRIBE_TO_EVENT",meta:{description:"\u041F\u043E\u0434\u043F\u0438\u0441\u043A\u0430 \u043D\u0430 \u0441\u043E\u0431\u044B\u0442\u0438\u044F \u0432 EventBus"},action:async({eventPattern:r,handler:a,options:o={}})=>{let i=`sub_${Date.now()}_${Math.random()}`,c=t.subscribe(d=>d.events,d=>{Object.values(d||{}).forEach(l=>{if(wt(l.event,r)){if(o.priority&&l.metadata.priority!==o.priority)return;try{a(l.data,l)}catch{}}})});return await t.set(`subscriptions.${i}`,{id:i,pattern:r,options:o,createdAt:Date.now()}),{subscriptionId:i,unsubscribe:c}}}),getEventHistory:n({type:"GET_EVENT_HISTORY",meta:{description:"\u041F\u043E\u043B\u0443\u0447\u0435\u043D\u0438\u0435 \u0438\u0441\u0442\u043E\u0440\u0438\u0438 \u0441\u043E\u0431\u044B\u0442\u0438\u0439"},action:async({eventType:r,limit:a=100})=>{let o=await t.getState();return Object.values(o.events||{}).filter(i=>i.event===r).sort((i,c)=>c.timestamp-i.timestamp).slice(0,a)}}),clearEvents:n({type:"CLEAR_EVENTS",meta:{description:"\u041E\u0447\u0438\u0441\u0442\u043A\u0430 \u0441\u043E\u0431\u044B\u0442\u0438\u0439"},action:async({olderThan:r}={})=>{if(r){let a=Date.now()-r;await t.update(o=>{Object.keys(o.events||{}).forEach(i=>{o.events[i].timestamp<a&&delete o.events[i]})})}else await t.set("events",{})}}),getActiveSubscriptions:n({type:"GET_SUBSCRIPTIONS",meta:{description:"\u041F\u043E\u043B\u0443\u0447\u0435\u043D\u0438\u0435 \u0430\u043A\u0442\u0438\u0432\u043D\u044B\u0445 \u043F\u043E\u0434\u043F\u0438\u0441\u043E\u043A"},action:async()=>{let r=await t.getState();return Object.values(r.subscriptions||{})}})}))});function he(s){let e="pending",t,n=null,r=new Set,a=new Set,o=(async()=>{try{let i=await(s instanceof Promise?s:Promise.resolve(s));return await i.storage.waitForReady(),t=i,e="ready",r.forEach(c=>{try{c(t)}catch{}}),i}catch(i){let c=i instanceof Error?i:new Error(String(i));throw n=c,e="error",a.forEach(d=>{try{d(c)}catch{}}),c}})();return{waitForReady:()=>o,isReady:()=>e==="ready",getStoreIfReady:()=>t,onReady:i=>{if(e==="ready"&&t)try{i(t)}catch{}else r.add(i);return()=>{r.delete(i)}},onError:i=>{if(e==="error"&&n)try{i(n)}catch{}else a.add(i);return()=>{a.delete(i)}},getStatus:()=>e,getError:()=>n,destroy:()=>{r.clear(),a.clear(),t=void 0,n=null,e="pending"}}}import{Fragment as _e,jsx as ne,jsxs as Ct}from"react/jsx-runtime";function xt(s,e){let{loadingComponent:t=ne("div",{children:"\u0418\u043D\u0438\u0446\u0438\u0430\u043B\u0438\u0437\u0430\u0446\u0438\u044F..."}),errorComponent:n=i=>Ct("div",{children:["\u041E\u0448\u0438\u0431\u043A\u0430 \u0438\u043D\u0438\u0446\u0438\u0430\u043B\u0438\u0437\u0430\u0446\u0438\u0438: ",i.message]})}=e||{},r=he(s);function a(){let[i,c]=Se(()=>r.getStatus()),[d,l]=Se(()=>r.getStoreIfReady()),[u,g]=Se(()=>r.getError());return vt(()=>{let p=r.getStatus(),f=r.getStoreIfReady(),y=r.getError();c(p),l(f),g(y);let b=r.onReady(S=>{c("ready"),l(S),g(null)}),h=r.onError(S=>{c("error"),l(void 0),g(S)});return()=>{b(),h()}},[]),{isReady:i==="ready",isError:i==="error",isPending:i==="pending",store:d,error:u}}function o(i){function c(l){let{isReady:u,isError:g,error:p}=a();return g&&p?ne(_e,{children:n(p)}):u?ne(i,{...l}):ne(_e,{children:t})}let d=i.displayName||i.name||"Component";return c.displayName=`AwaitSynapse(${d})`,c}return{withSynapseReady:o,useSynapseReady:a,waitForReady:r.waitForReady,isReady:r.isReady,getStoreIfReady:r.getStoreIfReady,onReady:r.onReady,onError:r.onError,getStatus:r.getStatus,getError:r.getError,destroy:r.destroy}}import{createContext as Pt,useContext as se,useEffect as At,useState as me}from"react";import{Fragment as Ot,jsx as z}from"react/jsx-runtime";var oe="\u0425\u0443\u043A \u043D\u0435\u043E\u0431\u0445\u043E\u0434\u0438\u043C\u043E \u0438\u0441\u043F\u043E\u043B\u044C\u0437\u043E\u0432\u0430\u0442\u044C \u0432\u043D\u0443\u0442\u0440\u0438 \u043A\u043E\u043C\u043F\u043E\u043D\u0435\u043D\u0442\u0430 contextSynapse",It="\u041E\u0448\u0438\u0431\u043A\u0430 \u043F\u0440\u0438 \u0438\u043D\u0438\u0446\u0438\u0430\u043B\u0438\u0437\u0430\u0446\u0438\u0438 \u043A\u043E\u043D\u0442\u0435\u043A\u0441\u0442\u0430:";function Dt(s,e){let{loadingComponent:t=z("div",{children:"\u0418\u043D\u0438\u0446\u0438\u0430\u043B\u0438\u0437\u0430\u0446\u0438\u044F \u043A\u043E\u043D\u0442\u0435\u043A\u0441\u0442\u0430..."})}=e||{},n=(async()=>{try{let u=await(s instanceof Promise?s:Promise.resolve(s));return await u.storage.waitForReady(),u}catch(u){throw u}})(),r=Pt(null),a=()=>{let u=se(r);if(!u)throw new Error(`useSynapseStorage: ${oe}`);return u.storage},o=()=>{let u=se(r);if(!u)throw new Error(`useSynapseSelectors: ${oe}`);return u.selectors},i=()=>{let u=se(r);if(!u)throw new Error(`useSynapseActions: ${oe}`);if("actions"in u)return u.actions;throw new Error("useSynapseActions: actions \u043D\u0435\u0434\u043E\u0441\u0442\u0443\u043F\u043D\u044B \u0434\u043B\u044F \u044D\u0442\u043E\u0433\u043E \u0442\u0438\u043F\u0430 \u0445\u0440\u0430\u043D\u0438\u043B\u0438\u0449\u0430. \u0423\u0431\u0435\u0434\u0438\u0442\u0435\u0441\u044C, \u0447\u0442\u043E \u043F\u0435\u0440\u0435\u0434\u0430\u043D\u0430 \u0444\u0443\u043D\u043A\u0446\u0438\u044F createDispatcherFn \u043F\u0440\u0438 \u0441\u043E\u0437\u0434\u0430\u043D\u0438\u0438 \u0445\u0440\u0430\u043D\u0438\u043B\u0438\u0449\u0430.")},c=()=>{let u=se(r);if(!u)throw new Error(`useSynapseState$: ${oe}`);if("state$"in u)return u.state$;throw new Error("useSynapseState$: state$ \u043D\u0435\u0434\u043E\u0441\u0442\u0443\u043F\u0435\u043D \u0434\u043B\u044F \u044D\u0442\u043E\u0433\u043E \u0442\u0438\u043F\u0430 \u0445\u0440\u0430\u043D\u0438\u043B\u0438\u0449\u0430. \u0423\u0431\u0435\u0434\u0438\u0442\u0435\u0441\u044C, \u0447\u0442\u043E \u043F\u0435\u0440\u0435\u0434\u0430\u043D\u044B \u0444\u0443\u043D\u043A\u0446\u0438\u0438 createDispatcherFn \u0438 createEffectConfig \u043F\u0440\u0438 \u0441\u043E\u0437\u0434\u0430\u043D\u0438\u0438 \u0445\u0440\u0430\u043D\u0438\u043B\u0438\u0449\u0430.")};function d(u){function g(f){let[y,b]=me(null),[h,S]=me(!1),[v,E]=me(null);return At(()=>{let m=!0;return(async()=>{try{let x=await n;m&&(b(x),S(!0))}catch(x){m&&E(x instanceof Error?x:new Error(String(x)))}})(),()=>{m=!1}},[]),v?z("div",{children:`${It}: ${v.message}`}):!h||!y?z(Ot,{children:t}):z(r.Provider,{value:y,children:z(u,{...f})})}let p=u.displayName||u.name||"Component";return g.displayName=`SynapseContext(${p})`,g}return{contextSynapse:d,useSynapseStorage:a,useSynapseSelectors:o,useSynapseActions:i,useSynapseState$:c,cleanupSynapse:async()=>{try{return(await n)?.destroy()||Promise.resolve()}catch{}}}}export{Ae as ApiClient,ce as ConfigMergeStrategy,fe as Dispatcher,re as EffectsModule,k as IndexedDBStorage,U as LocalStorage,B as MemoryStorage,H as ResponseFormat,J as SelectorModule,de as StorageEvents,L as StorageFactory,Oe as StoragePluginModule,le as StorageStatus,Te as apiLogger,xt as awaitSynapse,Me as broadcastMiddleware,Gs as combineEffects,ke as createDispatcher,zs as createEffect,_s as createEffectBase,Rt as createEventBus,ye as createSynapse,he as createSynapseAwaiter,Dt as createSynapseCtx,be as createUniqueId,we as headersToObject,gs as loggerDispatcherMiddleware,qs as ofType,ks as ofTypes,Us as ofTypesWaitAll,Ls as selectorMap,js as selectorObject,jn as useCreateStorage,zn as useSelector,Wn as useStorageSubscribe,Vs as validateMap};
1
+ export * from "./api/index.js";
2
+ export * from "./core/index.js";
3
+ export * from "./react/index.js";
4
+ export * from "./reactive/index.js";
5
+ export * from "./utils/index.js";
6
+ /**
7
+ * Synapse - Библиотека управления состоянием и API-клиент
8
+ * @author Vlad Firsov
9
+ */ // Основные модули
10
+
11
+
12
+
13
+
14
+
15
+
16
+
17
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../src/index.ts"],"sourcesContent":["/**\n * Synapse - Библиотека управления состоянием и API-клиент\n * @author Vlad Firsov\n */\n\n// Основные модули\nexport * from './api'\nexport * from './core'\nexport * from './react'\nexport * from './reactive'\nexport * from './utils'\n"],"names":[],"mappings":";;;;;AAAA;;;CAGC,GAED,kBAAkB;AACG;AACC;AACC;AACG;AACH"}
@@ -0,0 +1,5 @@
1
+ export * from './useCreateStorage';
2
+ export * from './useSelector';
3
+ export * from './useStorage';
4
+ export * from './useStorageSubscribe';
5
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/react/hooks/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAA;AAClC,cAAc,eAAe,CAAA;AAC7B,cAAc,cAAc,CAAA;AAC5B,cAAc,uBAAuB,CAAA"}
@@ -0,0 +1,11 @@
1
+ export * from "./useCreateStorage.js";
2
+ export * from "./useSelector.js";
3
+ export * from "./useStorage.js";
4
+ export * from "./useStorageSubscribe.js";
5
+
6
+
7
+
8
+
9
+
10
+
11
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"react/hooks/index.js","sources":["../../../src/react/hooks/index.ts"],"sourcesContent":["export * from './useCreateStorage'\nexport * from './useSelector'\nexport * from './useStorage'\nexport * from './useStorageSubscribe'\n"],"names":[],"mappings":";;;;AAAkC;AACL;AACD;AACS"}
@@ -0,0 +1,39 @@
1
+ import { IAsyncPluginExecutor, IAsyncStorage, IEventEmitter, ILogger, IStorage, ISyncPluginExecutor, ISyncStorage, StorageInitStatus, UniversalStorageConfig } from '../../core';
2
+ export interface UseSynapseStorageOptions {
3
+ /**
4
+ * Автоматически инициализировать при монтировании
5
+ */
6
+ autoInitialize?: boolean;
7
+ /**
8
+ * Уничтожать storage при размонтировании
9
+ */
10
+ destroyOnUnmount?: boolean;
11
+ }
12
+ export type UseSynapseStorageReturn<S> = {
13
+ storage: S;
14
+ status: StorageInitStatus;
15
+ initialize: () => Promise<void>;
16
+ destroy: () => Promise<void>;
17
+ isReady: true;
18
+ isLoading: false;
19
+ hasError: false;
20
+ } | {
21
+ storage: null;
22
+ status: StorageInitStatus;
23
+ initialize: () => Promise<void>;
24
+ destroy: () => Promise<void>;
25
+ isReady: false;
26
+ isLoading: boolean;
27
+ hasError: boolean;
28
+ };
29
+ export declare function useCreateStorage<T extends Record<string, any>>(config: UniversalStorageConfig<T> & {
30
+ type: 'memory';
31
+ }, options?: UseSynapseStorageOptions, pluginExecutor?: ISyncPluginExecutor, eventEmitter?: IEventEmitter, logger?: ILogger): UseSynapseStorageReturn<ISyncStorage<T>>;
32
+ export declare function useCreateStorage<T extends Record<string, any>>(config: UniversalStorageConfig<T> & {
33
+ type: 'localStorage';
34
+ }, options?: UseSynapseStorageOptions, pluginExecutor?: ISyncPluginExecutor, eventEmitter?: IEventEmitter, logger?: ILogger): UseSynapseStorageReturn<ISyncStorage<T>>;
35
+ export declare function useCreateStorage<T extends Record<string, any>>(config: UniversalStorageConfig<T> & {
36
+ type: 'indexedDB';
37
+ }, options?: UseSynapseStorageOptions, pluginExecutor?: IAsyncPluginExecutor, eventEmitter?: IEventEmitter, logger?: ILogger): UseSynapseStorageReturn<IAsyncStorage<T>>;
38
+ export declare function useCreateStorage<T extends Record<string, any>>(config: UniversalStorageConfig<T>, options?: UseSynapseStorageOptions, pluginExecutor?: ISyncPluginExecutor | IAsyncPluginExecutor, eventEmitter?: IEventEmitter, logger?: ILogger): UseSynapseStorageReturn<IStorage<T>>;
39
+ //# sourceMappingURL=useCreateStorage.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useCreateStorage.d.ts","sourceRoot":"","sources":["../../../src/react/hooks/useCreateStorage.ts"],"names":[],"mappings":"AAGA,OAAO,EACL,oBAAoB,EACpB,aAAa,EACb,aAAa,EACb,OAAO,EACP,QAAQ,EACR,mBAAmB,EACnB,YAAY,EAEZ,iBAAiB,EAEjB,sBAAsB,EACvB,MAAM,YAAY,CAAA;AAEnB,MAAM,WAAW,wBAAwB;IACvC;;OAEG;IACH,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB;;OAEG;IACH,gBAAgB,CAAC,EAAE,OAAO,CAAA;CAC3B;AAED,MAAM,MAAM,uBAAuB,CAAC,CAAC,IACjC;IACE,OAAO,EAAE,CAAC,CAAA;IACV,MAAM,EAAE,iBAAiB,CAAA;IACzB,UAAU,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAA;IAC/B,OAAO,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAA;IAC5B,OAAO,EAAE,IAAI,CAAA;IACb,SAAS,EAAE,KAAK,CAAA;IAChB,QAAQ,EAAE,KAAK,CAAA;CAChB,GACD;IACE,OAAO,EAAE,IAAI,CAAA;IACb,MAAM,EAAE,iBAAiB,CAAA;IACzB,UAAU,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAA;IAC/B,OAAO,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAA;IAC5B,OAAO,EAAE,KAAK,CAAA;IACd,SAAS,EAAE,OAAO,CAAA;IAClB,QAAQ,EAAE,OAAO,CAAA;CAClB,CAAA;AAIL,wBAAgB,gBAAgB,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EAC5D,MAAM,EAAE,sBAAsB,CAAC,CAAC,CAAC,GAAG;IAAE,IAAI,EAAE,QAAQ,CAAA;CAAE,EACtD,OAAO,CAAC,EAAE,wBAAwB,EAClC,cAAc,CAAC,EAAE,mBAAmB,EACpC,YAAY,CAAC,EAAE,aAAa,EAC5B,MAAM,CAAC,EAAE,OAAO,GACf,uBAAuB,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAA;AAE3C,wBAAgB,gBAAgB,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EAC5D,MAAM,EAAE,sBAAsB,CAAC,CAAC,CAAC,GAAG;IAAE,IAAI,EAAE,cAAc,CAAA;CAAE,EAC5D,OAAO,CAAC,EAAE,wBAAwB,EAClC,cAAc,CAAC,EAAE,mBAAmB,EACpC,YAAY,CAAC,EAAE,aAAa,EAC5B,MAAM,CAAC,EAAE,OAAO,GACf,uBAAuB,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAA;AAE3C,wBAAgB,gBAAgB,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EAC5D,MAAM,EAAE,sBAAsB,CAAC,CAAC,CAAC,GAAG;IAAE,IAAI,EAAE,WAAW,CAAA;CAAE,EACzD,OAAO,CAAC,EAAE,wBAAwB,EAClC,cAAc,CAAC,EAAE,oBAAoB,EACrC,YAAY,CAAC,EAAE,aAAa,EAC5B,MAAM,CAAC,EAAE,OAAO,GACf,uBAAuB,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAA;AAE5C,wBAAgB,gBAAgB,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EAC5D,MAAM,EAAE,sBAAsB,CAAC,CAAC,CAAC,EACjC,OAAO,CAAC,EAAE,wBAAwB,EAClC,cAAc,CAAC,EAAE,mBAAmB,GAAG,oBAAoB,EAC3D,YAAY,CAAC,EAAE,aAAa,EAC5B,MAAM,CAAC,EAAE,OAAO,GACf,uBAAuB,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAA"}
@@ -0,0 +1,137 @@
1
+ import { useCallback, useEffect, useRef, useState } from "react";
2
+ import { handleCleanupError } from "../../_utils/error-handling.util.js";
3
+ import { StorageFactory, StorageStatus } from "../../core/index.js";
4
+
5
+
6
+
7
+
8
+
9
+
10
+
11
+ // ─── Реализация ─────────────────────────────────────────────────────────────
12
+ function useCreateStorage(config, options = {}, pluginExecutor, eventEmitter, logger) {
13
+ const destroyDefault = config.type === 'indexedDB' ? false : true;
14
+ const { autoInitialize = true, destroyOnUnmount = destroyDefault } = options;
15
+ const [status, setStatus] = useState({
16
+ status: StorageStatus.IDLE
17
+ });
18
+ const [storage] = useState(()=>{
19
+ try {
20
+ return StorageFactory.create(config, pluginExecutor, eventEmitter, logger);
21
+ } catch (error) {
22
+ setStatus({
23
+ status: StorageStatus.ERROR,
24
+ error: error
25
+ });
26
+ return null;
27
+ }
28
+ });
29
+ const destroyOnUnmountRef = useRef(destroyOnUnmount);
30
+ destroyOnUnmountRef.current = destroyOnUnmount;
31
+ const initialize = useCallback(async ()=>{
32
+ if (!storage) return;
33
+ try {
34
+ setStatus({
35
+ status: StorageStatus.LOADING
36
+ });
37
+ await storage.initialize();
38
+ setStatus({
39
+ status: StorageStatus.READY
40
+ });
41
+ } catch (error) {
42
+ setStatus({
43
+ status: StorageStatus.ERROR,
44
+ error: error
45
+ });
46
+ }
47
+ }, [
48
+ storage
49
+ ]);
50
+ const destroy = useCallback(async ()=>{
51
+ if (!storage) return;
52
+ try {
53
+ await storage.destroy();
54
+ setStatus({
55
+ status: StorageStatus.IDLE
56
+ });
57
+ } catch (error) {
58
+ setStatus({
59
+ status: StorageStatus.ERROR,
60
+ error: error
61
+ });
62
+ }
63
+ }, [
64
+ storage
65
+ ]);
66
+ useEffect(()=>{
67
+ if (!storage) return;
68
+ const unsubscribe = storage.onStatusChange((newStatus)=>{
69
+ setStatus(newStatus);
70
+ });
71
+ return unsubscribe;
72
+ }, [
73
+ storage
74
+ ]);
75
+ // Автоматическая инициализация
76
+ useEffect(()=>{
77
+ let cancelled = false;
78
+ if (autoInitialize && storage && status.status === StorageStatus.IDLE) {
79
+ setStatus({
80
+ status: StorageStatus.LOADING
81
+ });
82
+ storage.initialize().then(()=>{
83
+ if (!cancelled) setStatus({
84
+ status: StorageStatus.READY
85
+ });
86
+ }).catch((error)=>{
87
+ if (!cancelled) setStatus({
88
+ status: StorageStatus.ERROR,
89
+ error: error
90
+ });
91
+ });
92
+ }
93
+ return ()=>{
94
+ cancelled = true;
95
+ };
96
+ }, [
97
+ autoInitialize,
98
+ storage,
99
+ status.status
100
+ ]);
101
+ useEffect(()=>{
102
+ return ()=>{
103
+ if (destroyOnUnmountRef.current && storage) {
104
+ storage.destroy().catch((err)=>handleCleanupError('useCreateStorage: error during unmount destroy', err));
105
+ }
106
+ };
107
+ }, [
108
+ storage
109
+ ]);
110
+ const isReady = status.status === StorageStatus.READY;
111
+ const isLoading = status.status === StorageStatus.LOADING;
112
+ const hasError = status.status === StorageStatus.ERROR;
113
+ if (isReady && storage) {
114
+ return {
115
+ storage,
116
+ status,
117
+ initialize,
118
+ destroy,
119
+ isReady: true,
120
+ isLoading: false,
121
+ hasError: false
122
+ };
123
+ }
124
+ return {
125
+ storage: null,
126
+ status,
127
+ initialize,
128
+ destroy,
129
+ isReady: false,
130
+ isLoading,
131
+ hasError
132
+ };
133
+ }
134
+
135
+ export { useCreateStorage };
136
+
137
+ //# sourceMappingURL=useCreateStorage.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"react/hooks/useCreateStorage.js","sources":["../../../src/react/hooks/useCreateStorage.ts"],"sourcesContent":["import { useCallback, useEffect, useRef, useState } from 'react'\n\nimport { handleCleanupError } from '../../_utils/error-handling.util'\nimport {\n IAsyncPluginExecutor,\n IAsyncStorage,\n IEventEmitter,\n ILogger,\n IStorage,\n ISyncPluginExecutor,\n ISyncStorage,\n StorageFactory,\n StorageInitStatus,\n StorageStatus,\n UniversalStorageConfig,\n} from '../../core'\n\nexport interface UseSynapseStorageOptions {\n /**\n * Автоматически инициализировать при монтировании\n */\n autoInitialize?: boolean\n /**\n * Уничтожать storage при размонтировании\n */\n destroyOnUnmount?: boolean\n}\n\nexport type UseSynapseStorageReturn<S> =\n | {\n storage: S\n status: StorageInitStatus\n initialize: () => Promise<void>\n destroy: () => Promise<void>\n isReady: true\n isLoading: false\n hasError: false\n }\n | {\n storage: null\n status: StorageInitStatus\n initialize: () => Promise<void>\n destroy: () => Promise<void>\n isReady: false\n isLoading: boolean\n hasError: boolean\n }\n\n// ─── Перегрузки ─────────────────────────────────────────────────────────────\n\nexport function useCreateStorage<T extends Record<string, any>>(\n config: UniversalStorageConfig<T> & { type: 'memory' },\n options?: UseSynapseStorageOptions,\n pluginExecutor?: ISyncPluginExecutor,\n eventEmitter?: IEventEmitter,\n logger?: ILogger,\n): UseSynapseStorageReturn<ISyncStorage<T>>\n\nexport function useCreateStorage<T extends Record<string, any>>(\n config: UniversalStorageConfig<T> & { type: 'localStorage' },\n options?: UseSynapseStorageOptions,\n pluginExecutor?: ISyncPluginExecutor,\n eventEmitter?: IEventEmitter,\n logger?: ILogger,\n): UseSynapseStorageReturn<ISyncStorage<T>>\n\nexport function useCreateStorage<T extends Record<string, any>>(\n config: UniversalStorageConfig<T> & { type: 'indexedDB' },\n options?: UseSynapseStorageOptions,\n pluginExecutor?: IAsyncPluginExecutor,\n eventEmitter?: IEventEmitter,\n logger?: ILogger,\n): UseSynapseStorageReturn<IAsyncStorage<T>>\n\nexport function useCreateStorage<T extends Record<string, any>>(\n config: UniversalStorageConfig<T>,\n options?: UseSynapseStorageOptions,\n pluginExecutor?: ISyncPluginExecutor | IAsyncPluginExecutor,\n eventEmitter?: IEventEmitter,\n logger?: ILogger,\n): UseSynapseStorageReturn<IStorage<T>>\n\n// ─── Реализация ─────────────────────────────────────────────────────────────\n\nexport function useCreateStorage<T extends Record<string, any>>(\n config: UniversalStorageConfig<T>,\n options: UseSynapseStorageOptions = {},\n pluginExecutor?: ISyncPluginExecutor | IAsyncPluginExecutor,\n eventEmitter?: IEventEmitter,\n logger?: ILogger,\n): UseSynapseStorageReturn<IStorage<T>> {\n const destroyDefault = config.type === 'indexedDB' ? false : true\n const { autoInitialize = true, destroyOnUnmount = destroyDefault } = options\n\n const [status, setStatus] = useState<StorageInitStatus>({\n status: StorageStatus.IDLE,\n })\n\n const [storage] = useState<IStorage<T> | null>(() => {\n try {\n return StorageFactory.create<T>(config, pluginExecutor, eventEmitter, logger)\n } catch (error) {\n setStatus({\n status: StorageStatus.ERROR,\n error: error as Error,\n })\n return null\n }\n })\n\n const destroyOnUnmountRef = useRef(destroyOnUnmount)\n destroyOnUnmountRef.current = destroyOnUnmount\n\n const initialize = useCallback(async () => {\n if (!storage) return\n\n try {\n setStatus({ status: StorageStatus.LOADING })\n await storage.initialize()\n setStatus({ status: StorageStatus.READY })\n } catch (error) {\n setStatus({\n status: StorageStatus.ERROR,\n error: error as Error,\n })\n }\n }, [storage])\n\n const destroy = useCallback(async () => {\n if (!storage) return\n\n try {\n await storage.destroy()\n setStatus({ status: StorageStatus.IDLE })\n } catch (error) {\n setStatus({\n status: StorageStatus.ERROR,\n error: error as Error,\n })\n }\n }, [storage])\n\n useEffect(() => {\n if (!storage) return\n\n const unsubscribe = storage.onStatusChange((newStatus) => {\n setStatus(newStatus)\n })\n\n return unsubscribe\n }, [storage])\n\n // Автоматическая инициализация\n useEffect(() => {\n let cancelled = false\n\n if (autoInitialize && storage && status.status === StorageStatus.IDLE) {\n setStatus({ status: StorageStatus.LOADING })\n storage\n .initialize()\n .then(() => {\n if (!cancelled) setStatus({ status: StorageStatus.READY })\n })\n .catch((error) => {\n if (!cancelled) setStatus({ status: StorageStatus.ERROR, error: error as Error })\n })\n }\n\n return () => {\n cancelled = true\n }\n }, [autoInitialize, storage, status.status])\n\n useEffect(() => {\n return () => {\n if (destroyOnUnmountRef.current && storage) {\n storage.destroy().catch((err) => handleCleanupError('useCreateStorage: error during unmount destroy', err))\n }\n }\n }, [storage])\n\n const isReady = status.status === StorageStatus.READY\n const isLoading = status.status === StorageStatus.LOADING\n const hasError = status.status === StorageStatus.ERROR\n\n if (isReady && storage) {\n return {\n storage,\n status,\n initialize,\n destroy,\n isReady: true as const,\n isLoading: false as const,\n hasError: false as const,\n }\n }\n\n return {\n storage: null,\n status,\n initialize,\n destroy,\n isReady: false as const,\n isLoading,\n hasError,\n }\n}\n"],"names":["useCallback","useEffect","useRef","useState","handleCleanupError","StorageFactory","StorageStatus","useCreateStorage","config","options","pluginExecutor","eventEmitter","logger","destroyDefault","autoInitialize","destroyOnUnmount","status","setStatus","storage","error","destroyOnUnmountRef","initialize","destroy","unsubscribe","newStatus","cancelled","err","isReady","isLoading","hasError"],"mappings":";;;;;;;AAAgE;AAEK;AAalD;AAmEnB,+EAA+E;AAExE,SAASO,gBAAgBA,CAC9BC,MAAiC,EACjCC,UAAoC,CAAC,CAAC,EACtCC,cAA2D,EAC3DC,YAA4B,EAC5BC,MAAgB;IAEhB,MAAMC,iBAAiBL,OAAO,IAAI,KAAK,cAAc,QAAQ;IAC7D,MAAM,EAAEM,iBAAiB,IAAI,EAAEC,mBAAmBF,cAAc,EAAE,GAAGJ;IAErE,MAAM,CAACO,QAAQC,UAAU,GAAGd,QAAQA,CAAoB;QACtD,QAAQG,kBAAkB;IAC5B;IAEA,MAAM,CAACY,QAAQ,GAAGf,QAAQA,CAAqB;QAC7C,IAAI;YACF,OAAOE,qBAAqB,CAAIG,QAAQE,gBAAgBC,cAAcC;QACxE,EAAE,OAAOO,OAAO;YACdF,UAAU;gBACR,QAAQX,mBAAmB;gBAC3B,OAAOa;YACT;YACA,OAAO;QACT;IACF;IAEA,MAAMC,sBAAsBlB,MAAMA,CAACa;IACnCK,oBAAoB,OAAO,GAAGL;IAE9B,MAAMM,aAAarB,WAAWA,CAAC;QAC7B,IAAI,CAACkB,SAAS;QAEd,IAAI;YACFD,UAAU;gBAAE,QAAQX,qBAAqB;YAAC;YAC1C,MAAMY,QAAQ,UAAU;YACxBD,UAAU;gBAAE,QAAQX,mBAAmB;YAAC;QAC1C,EAAE,OAAOa,OAAO;YACdF,UAAU;gBACR,QAAQX,mBAAmB;gBAC3B,OAAOa;YACT;QACF;IACF,GAAG;QAACD;KAAQ;IAEZ,MAAMI,UAAUtB,WAAWA,CAAC;QAC1B,IAAI,CAACkB,SAAS;QAEd,IAAI;YACF,MAAMA,QAAQ,OAAO;YACrBD,UAAU;gBAAE,QAAQX,kBAAkB;YAAC;QACzC,EAAE,OAAOa,OAAO;YACdF,UAAU;gBACR,QAAQX,mBAAmB;gBAC3B,OAAOa;YACT;QACF;IACF,GAAG;QAACD;KAAQ;IAEZjB,SAASA,CAAC;QACR,IAAI,CAACiB,SAAS;QAEd,MAAMK,cAAcL,QAAQ,cAAc,CAAC,CAACM;YAC1CP,UAAUO;QACZ;QAEA,OAAOD;IACT,GAAG;QAACL;KAAQ;IAEZ,+BAA+B;IAC/BjB,SAASA,CAAC;QACR,IAAIwB,YAAY;QAEhB,IAAIX,kBAAkBI,WAAWF,OAAO,MAAM,KAAKV,kBAAkB,EAAE;YACrEW,UAAU;gBAAE,QAAQX,qBAAqB;YAAC;YAC1CY,QACG,UAAU,GACV,IAAI,CAAC;gBACJ,IAAI,CAACO,WAAWR,UAAU;oBAAE,QAAQX,mBAAmB;gBAAC;YAC1D,GACC,KAAK,CAAC,CAACa;gBACN,IAAI,CAACM,WAAWR,UAAU;oBAAE,QAAQX,mBAAmB;oBAAE,OAAOa;gBAAe;YACjF;QACJ;QAEA,OAAO;YACLM,YAAY;QACd;IACF,GAAG;QAACX;QAAgBI;QAASF,OAAO,MAAM;KAAC;IAE3Cf,SAASA,CAAC;QACR,OAAO;YACL,IAAImB,oBAAoB,OAAO,IAAIF,SAAS;gBAC1CA,QAAQ,OAAO,GAAG,KAAK,CAAC,CAACQ,MAAQtB,kBAAkBA,CAAC,kDAAkDsB;YACxG;QACF;IACF,GAAG;QAACR;KAAQ;IAEZ,MAAMS,UAAUX,OAAO,MAAM,KAAKV,mBAAmB;IACrD,MAAMsB,YAAYZ,OAAO,MAAM,KAAKV,qBAAqB;IACzD,MAAMuB,WAAWb,OAAO,MAAM,KAAKV,mBAAmB;IAEtD,IAAIqB,WAAWT,SAAS;QACtB,OAAO;YACLA;YACAF;YACAK;YACAC;YACA,SAAS;YACT,WAAW;YACX,UAAU;QACZ;IACF;IAEA,OAAO;QACL,SAAS;QACTN;QACAK;QACAC;QACA,SAAS;QACTM;QACAC;IACF;AACF"}
@@ -0,0 +1,21 @@
1
+ import type { SelectorAPI } from '../../core';
2
+ interface UseSelectorOptions<T> {
3
+ /** Функция сравнения для предотвращения лишних ререндеров */
4
+ equals?: (a: T, b: T) => boolean;
5
+ /** Включать ли статус загрузки в возвращаемый результат */
6
+ withLoading?: boolean;
7
+ }
8
+ /**
9
+ * Хук для использования селекторов в компонентах React.
10
+ * Использует useSyncExternalStore для корректной работы в Concurrent Mode.
11
+ * Подписывается напрямую через selector.subscribe() — без глобального реестра.
12
+ */
13
+ export declare function useSelector<T>(selector: SelectorAPI<T>): T;
14
+ export declare function useSelector<T>(selector: SelectorAPI<T>, options: UseSelectorOptions<T> & {
15
+ withLoading: true;
16
+ }): {
17
+ data: T;
18
+ isLoading: boolean;
19
+ };
20
+ export {};
21
+ //# sourceMappingURL=useSelector.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useSelector.d.ts","sourceRoot":"","sources":["../../../src/react/hooks/useSelector.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,YAAY,CAAA;AAE7C,UAAU,kBAAkB,CAAC,CAAC;IAC5B,6DAA6D;IAC7D,MAAM,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,KAAK,OAAO,CAAA;IAChC,2DAA2D;IAC3D,WAAW,CAAC,EAAE,OAAO,CAAA;CACtB;AAED;;;;GAIG;AACH,wBAAgB,WAAW,CAAC,CAAC,EAAE,QAAQ,EAAE,WAAW,CAAC,CAAC,CAAC,GAAG,CAAC,CAAA;AAC3D,wBAAgB,WAAW,CAAC,CAAC,EAAE,QAAQ,EAAE,WAAW,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,kBAAkB,CAAC,CAAC,CAAC,GAAG;IAAE,WAAW,EAAE,IAAI,CAAA;CAAE,GAAG;IAAE,IAAI,EAAE,CAAC,CAAC;IAAC,SAAS,EAAE,OAAO,CAAA;CAAE,CAAA"}