@webiny/app 5.44.1-beta.0 → 5.45.0-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (427) hide show
  1. package/App.d.ts +5 -13
  2. package/App.js +70 -87
  3. package/App.js.map +1 -1
  4. package/AppContainer.d.ts +23 -0
  5. package/AppContainer.js +9 -0
  6. package/AppContainer.js.map +1 -0
  7. package/README.md +7 -15
  8. package/apollo-client/InMemoryCache.d.ts +3 -2
  9. package/apollo-client/InMemoryCache.js +16 -47
  10. package/apollo-client/InMemoryCache.js.map +1 -1
  11. package/apollo-client/IntrospectionFragmentMatcher.d.ts +2 -2
  12. package/apollo-client/IntrospectionFragmentMatcher.js +33 -50
  13. package/apollo-client/IntrospectionFragmentMatcher.js.map +1 -1
  14. package/components/Image.d.ts +1 -2
  15. package/components/Image.js +11 -19
  16. package/components/Image.js.map +1 -1
  17. package/components/index.d.ts +1 -2
  18. package/components/index.js +1 -19
  19. package/components/index.js.map +1 -1
  20. package/config/RouterConfig/Route.d.ts +29 -0
  21. package/config/RouterConfig/Route.js +33 -0
  22. package/config/RouterConfig/Route.js.map +1 -0
  23. package/config/RouterConfig.d.ts +31 -0
  24. package/config/RouterConfig.js +18 -0
  25. package/config/RouterConfig.js.map +1 -0
  26. package/config.js +9 -15
  27. package/config.js.map +1 -1
  28. package/contexts/Ui/index.js +28 -52
  29. package/contexts/Ui/index.js.map +1 -1
  30. package/core/DebounceRender.js +13 -24
  31. package/core/DebounceRender.js.map +1 -1
  32. package/core/Plugin.d.ts +1 -1
  33. package/core/Plugin.js +11 -19
  34. package/core/Plugin.js.map +1 -1
  35. package/core/Plugins.d.ts +1 -1
  36. package/core/Plugins.js +20 -25
  37. package/core/Plugins.js.map +1 -1
  38. package/core/Provider.d.ts +1 -1
  39. package/core/Provider.js +9 -13
  40. package/core/Provider.js.map +1 -1
  41. package/core/Routes.d.ts +2 -1
  42. package/core/Routes.js +13 -23
  43. package/core/Routes.js.map +1 -1
  44. package/core/createProvider.d.ts +2 -2
  45. package/core/createProvider.js +1 -7
  46. package/core/createProvider.js.map +1 -1
  47. package/core/createProviderPlugin.d.ts +1 -1
  48. package/core/createProviderPlugin.js +4 -10
  49. package/core/createProviderPlugin.js.map +1 -1
  50. package/errors/AuthenticationErrorEvent.d.ts +9 -0
  51. package/errors/AuthenticationErrorEvent.js +10 -0
  52. package/errors/AuthenticationErrorEvent.js.map +1 -0
  53. package/errors/NetworkErrorEvent.d.ts +15 -0
  54. package/errors/NetworkErrorEvent.js +10 -0
  55. package/errors/NetworkErrorEvent.js.map +1 -0
  56. package/errors/abstractions.d.ts +12 -0
  57. package/errors/abstractions.js +5 -0
  58. package/errors/abstractions.js.map +1 -0
  59. package/errors/index.d.ts +6 -0
  60. package/errors/index.js +6 -0
  61. package/errors/index.js.map +1 -0
  62. package/exports/admin/envConfig.d.ts +1 -0
  63. package/exports/admin/envConfig.js +3 -0
  64. package/exports/admin/envConfig.js.map +1 -0
  65. package/exports/admin/graphqlClient.d.ts +1 -0
  66. package/exports/admin/graphqlClient.js +3 -0
  67. package/exports/admin/graphqlClient.js.map +1 -0
  68. package/exports/admin/localStorage.d.ts +2 -0
  69. package/exports/admin/localStorage.js +4 -0
  70. package/exports/admin/localStorage.js.map +1 -0
  71. package/exports/admin/router.d.ts +4 -0
  72. package/exports/admin/router.js +6 -0
  73. package/exports/admin/router.js.map +1 -0
  74. package/exports/admin/security.d.ts +1 -0
  75. package/exports/admin/security.js +3 -0
  76. package/exports/admin/security.js.map +1 -0
  77. package/exports/admin.d.ts +6 -0
  78. package/exports/admin.js +8 -0
  79. package/exports/admin.js.map +1 -0
  80. package/features/envConfig/EnvConfig.d.ts +6 -0
  81. package/features/envConfig/EnvConfig.js +14 -0
  82. package/features/envConfig/EnvConfig.js.map +1 -0
  83. package/features/envConfig/abstractions.d.ts +27 -0
  84. package/features/envConfig/abstractions.js +4 -0
  85. package/features/envConfig/abstractions.js.map +1 -0
  86. package/features/envConfig/feature.d.ts +17 -0
  87. package/features/envConfig/feature.js +14 -0
  88. package/features/envConfig/feature.js.map +1 -0
  89. package/features/envConfig/index.d.ts +1 -0
  90. package/features/envConfig/index.js +3 -0
  91. package/features/envConfig/index.js.map +1 -0
  92. package/features/eventPublisher/EventPublisher.d.ts +8 -0
  93. package/features/eventPublisher/EventPublisher.js +27 -0
  94. package/features/eventPublisher/EventPublisher.js.map +1 -0
  95. package/features/eventPublisher/abstractions.d.ts +18 -0
  96. package/features/eventPublisher/abstractions.js +14 -0
  97. package/features/eventPublisher/abstractions.js.map +1 -0
  98. package/features/eventPublisher/feature.d.ts +1 -0
  99. package/features/eventPublisher/feature.js +11 -0
  100. package/features/eventPublisher/feature.js.map +1 -0
  101. package/features/eventPublisher/index.d.ts +3 -0
  102. package/features/eventPublisher/index.js +4 -0
  103. package/features/eventPublisher/index.js.map +1 -0
  104. package/features/graphqlClient/AuthenticationErrorPublishing.d.ts +13 -0
  105. package/features/graphqlClient/AuthenticationErrorPublishing.js +35 -0
  106. package/features/graphqlClient/AuthenticationErrorPublishing.js.map +1 -0
  107. package/features/graphqlClient/BatchingGraphQLClient.d.ts +18 -0
  108. package/features/graphqlClient/BatchingGraphQLClient.js +164 -0
  109. package/features/graphqlClient/BatchingGraphQLClient.js.map +1 -0
  110. package/features/graphqlClient/FetchGraphQLClient.d.ts +10 -0
  111. package/features/graphqlClient/FetchGraphQLClient.js +62 -0
  112. package/features/graphqlClient/FetchGraphQLClient.js.map +1 -0
  113. package/features/graphqlClient/NetworkErrorPublishing.d.ts +14 -0
  114. package/features/graphqlClient/NetworkErrorPublishing.js +55 -0
  115. package/features/graphqlClient/NetworkErrorPublishing.js.map +1 -0
  116. package/features/graphqlClient/RequestValue.d.ts +20 -0
  117. package/features/graphqlClient/RequestValue.js +42 -0
  118. package/features/graphqlClient/RequestValue.js.map +1 -0
  119. package/features/graphqlClient/RetryGraphQLClient.d.ts +18 -0
  120. package/features/graphqlClient/RetryGraphQLClient.js +54 -0
  121. package/features/graphqlClient/RetryGraphQLClient.js.map +1 -0
  122. package/features/graphqlClient/__tests__/GraphQLClient.test.d.ts +1 -0
  123. package/features/graphqlClient/__tests__/GraphQLClient.test.js +350 -0
  124. package/features/graphqlClient/__tests__/GraphQLClient.test.js.map +1 -0
  125. package/features/graphqlClient/abstractions.d.ts +17 -0
  126. package/features/graphqlClient/abstractions.js +4 -0
  127. package/features/graphqlClient/abstractions.js.map +1 -0
  128. package/features/graphqlClient/feature.d.ts +6 -0
  129. package/features/graphqlClient/feature.js +31 -0
  130. package/features/graphqlClient/feature.js.map +1 -0
  131. package/features/graphqlClient/index.d.ts +1 -0
  132. package/features/graphqlClient/index.js +3 -0
  133. package/features/graphqlClient/index.js.map +1 -0
  134. package/features/graphqlClient/types.d.ts +5 -0
  135. package/features/graphqlClient/types.js +3 -0
  136. package/features/graphqlClient/types.js.map +1 -0
  137. package/features/localStorage/BrowserLocalStorageGateway.d.ts +9 -0
  138. package/features/localStorage/BrowserLocalStorageGateway.js +68 -0
  139. package/features/localStorage/BrowserLocalStorageGateway.js.map +1 -0
  140. package/features/localStorage/LocalStorage.d.ts +12 -0
  141. package/features/localStorage/LocalStorage.js +31 -0
  142. package/features/localStorage/LocalStorage.js.map +1 -0
  143. package/features/localStorage/LocalStorageRepository.d.ts +20 -0
  144. package/features/localStorage/LocalStorageRepository.js +95 -0
  145. package/features/localStorage/LocalStorageRepository.js.map +1 -0
  146. package/features/localStorage/abstractions.d.ts +48 -0
  147. package/features/localStorage/abstractions.js +19 -0
  148. package/features/localStorage/abstractions.js.map +1 -0
  149. package/features/localStorage/feature.d.ts +12 -0
  150. package/features/localStorage/feature.js +34 -0
  151. package/features/localStorage/feature.js.map +1 -0
  152. package/features/localStorage/index.d.ts +1 -0
  153. package/features/localStorage/index.js +3 -0
  154. package/features/localStorage/index.js.map +1 -0
  155. package/features/router/HistoryRouterGateway.d.ts +18 -0
  156. package/features/router/HistoryRouterGateway.js +82 -0
  157. package/features/router/HistoryRouterGateway.js.map +1 -0
  158. package/features/router/HistoryRouterGateway.test.d.ts +1 -0
  159. package/features/router/HistoryRouterGateway.test.js +204 -0
  160. package/features/router/HistoryRouterGateway.test.js.map +1 -0
  161. package/features/router/Route.d.ts +19 -0
  162. package/features/router/Route.js +59 -0
  163. package/features/router/Route.js.map +1 -0
  164. package/features/router/RouteUrl.d.ts +85 -0
  165. package/features/router/RouteUrl.js +232 -0
  166. package/features/router/RouteUrl.js.map +1 -0
  167. package/features/router/Router.d.ts +45 -0
  168. package/features/router/Router.js +129 -0
  169. package/features/router/Router.js.map +1 -0
  170. package/features/router/RouterPresenter.d.ts +17 -0
  171. package/features/router/RouterPresenter.js +45 -0
  172. package/features/router/RouterPresenter.js.map +1 -0
  173. package/features/router/RouterRepository.d.ts +21 -0
  174. package/features/router/RouterRepository.js +71 -0
  175. package/features/router/RouterRepository.js.map +1 -0
  176. package/features/router/RouterRepository.test.d.ts +1 -0
  177. package/features/router/RouterRepository.test.js +154 -0
  178. package/features/router/RouterRepository.test.js.map +1 -0
  179. package/features/router/abstractions.d.ts +68 -0
  180. package/features/router/abstractions.js +15 -0
  181. package/features/router/abstractions.js.map +1 -0
  182. package/features/router/feature.d.ts +4 -0
  183. package/features/router/feature.js +18 -0
  184. package/features/router/feature.js.map +1 -0
  185. package/features/router/index.d.ts +1 -0
  186. package/features/router/index.js +3 -0
  187. package/features/router/index.js.map +1 -0
  188. package/helpers/InterfaceGenerator/date.d.ts +15 -0
  189. package/helpers/InterfaceGenerator/date.js +3 -0
  190. package/helpers/InterfaceGenerator/date.js.map +1 -0
  191. package/helpers/InterfaceGenerator/id.d.ts +23 -0
  192. package/helpers/InterfaceGenerator/id.js +3 -0
  193. package/helpers/InterfaceGenerator/id.js.map +1 -0
  194. package/helpers/InterfaceGenerator/identity.d.ts +10 -0
  195. package/helpers/InterfaceGenerator/identity.js +3 -0
  196. package/helpers/InterfaceGenerator/identity.js.map +1 -0
  197. package/helpers/InterfaceGenerator/index.d.ts +5 -0
  198. package/helpers/InterfaceGenerator/index.js +3 -0
  199. package/helpers/InterfaceGenerator/index.js.map +1 -0
  200. package/helpers/InterfaceGenerator/numeric.d.ts +12 -0
  201. package/helpers/InterfaceGenerator/numeric.js +3 -0
  202. package/helpers/InterfaceGenerator/numeric.js.map +1 -0
  203. package/helpers/InterfaceGenerator/truthful.d.ts +7 -0
  204. package/helpers/InterfaceGenerator/truthful.js +3 -0
  205. package/helpers/InterfaceGenerator/truthful.js.map +1 -0
  206. package/hooks/useAutocomplete/index.d.ts +1 -1
  207. package/hooks/useAutocomplete/index.js +1 -12
  208. package/hooks/useAutocomplete/index.js.map +1 -1
  209. package/hooks/useAutocomplete/useAutocomplete.d.ts +1 -1
  210. package/hooks/useAutocomplete/useAutocomplete.js +6 -16
  211. package/hooks/useAutocomplete/useAutocomplete.js.map +1 -1
  212. package/hooks/useDataList/functions/getData.js +2 -11
  213. package/hooks/useDataList/functions/getData.js.map +1 -1
  214. package/hooks/useDataList/functions/getError.js +2 -11
  215. package/hooks/useDataList/functions/getError.js.map +1 -1
  216. package/hooks/useDataList/functions/getMeta.js +2 -11
  217. package/hooks/useDataList/functions/getMeta.js.map +1 -1
  218. package/hooks/useDataList/functions/index.d.ts +3 -3
  219. package/hooks/useDataList/functions/index.js +3 -27
  220. package/hooks/useDataList/functions/index.js.map +1 -1
  221. package/hooks/useDataList/functions/searchDataByKey.js +4 -10
  222. package/hooks/useDataList/functions/searchDataByKey.js.map +1 -1
  223. package/hooks/useDataList/index.d.ts +1 -1
  224. package/hooks/useDataList/index.js +1 -12
  225. package/hooks/useDataList/index.js.map +1 -1
  226. package/hooks/useDataList/useDataList.d.ts +2 -3
  227. package/hooks/useDataList/useDataList.js +74 -94
  228. package/hooks/useDataList/useDataList.js.map +1 -1
  229. package/hooks/useDataList/utils/index.d.ts +1 -2
  230. package/hooks/useDataList/utils/index.js +1 -20
  231. package/hooks/useDataList/utils/index.js.map +1 -1
  232. package/hooks/useDataList/utils/prepareLoadListParams.js +10 -16
  233. package/hooks/useDataList/utils/prepareLoadListParams.js.map +1 -1
  234. package/hooks/useHandler.js +7 -12
  235. package/hooks/useHandler.js.map +1 -1
  236. package/hooks/useHandlers.js +11 -17
  237. package/hooks/useHandlers.js.map +1 -1
  238. package/hooks/useRegisterLegacyPlugin.d.ts +1 -1
  239. package/hooks/useRegisterLegacyPlugin.js +5 -11
  240. package/hooks/useRegisterLegacyPlugin.js.map +1 -1
  241. package/hooks/useUi.d.ts +1 -1
  242. package/hooks/useUi.js +4 -10
  243. package/hooks/useUi.js.map +1 -1
  244. package/i18n/i18n.js +5 -13
  245. package/i18n/i18n.js.map +1 -1
  246. package/i18n/index.d.ts +1 -1
  247. package/i18n/index.js +1 -13
  248. package/i18n/index.js.map +1 -1
  249. package/index.d.ts +23 -15
  250. package/index.js +25 -177
  251. package/index.js.map +1 -1
  252. package/package.json +25 -22
  253. package/plugins/AddQuerySelectionPlugin.d.ts +2 -2
  254. package/plugins/AddQuerySelectionPlugin.js +61 -107
  255. package/plugins/AddQuerySelectionPlugin.js.map +1 -1
  256. package/plugins/ApolloCacheObjectIdPlugin.js +12 -31
  257. package/plugins/ApolloCacheObjectIdPlugin.js.map +1 -1
  258. package/plugins/ApolloDynamicLink.d.ts +3 -2
  259. package/plugins/ApolloDynamicLink.js +19 -46
  260. package/plugins/ApolloDynamicLink.js.map +1 -1
  261. package/plugins/ApolloLinkPlugin.d.ts +1 -1
  262. package/plugins/ApolloLinkPlugin.js +18 -37
  263. package/plugins/ApolloLinkPlugin.js.map +1 -1
  264. package/plugins/ConsoleLinkPlugin.d.ts +1 -1
  265. package/plugins/ConsoleLinkPlugin.js +20 -41
  266. package/plugins/ConsoleLinkPlugin.js.map +1 -1
  267. package/plugins/NetworkErrorLinkPlugin/ErrorOverlay.d.ts +8 -13
  268. package/plugins/NetworkErrorLinkPlugin/ErrorOverlay.js +35 -58
  269. package/plugins/NetworkErrorLinkPlugin/ErrorOverlay.js.map +1 -1
  270. package/plugins/NetworkErrorLinkPlugin/GqlErrorOverlay.d.ts +14 -0
  271. package/plugins/NetworkErrorLinkPlugin/GqlErrorOverlay.js +31 -0
  272. package/plugins/NetworkErrorLinkPlugin/GqlErrorOverlay.js.map +1 -0
  273. package/plugins/NetworkErrorLinkPlugin/LocalAwsLambdaTimeoutMessage.d.ts +2 -0
  274. package/plugins/NetworkErrorLinkPlugin/LocalAwsLambdaTimeoutMessage.js +31 -0
  275. package/plugins/NetworkErrorLinkPlugin/LocalAwsLambdaTimeoutMessage.js.map +1 -0
  276. package/plugins/NetworkErrorLinkPlugin/StyledComponents.d.ts +4 -5
  277. package/plugins/NetworkErrorLinkPlugin/StyledComponents.js +68 -12
  278. package/plugins/NetworkErrorLinkPlugin/StyledComponents.js.map +1 -1
  279. package/plugins/NetworkErrorLinkPlugin/Typography.d.ts +8 -0
  280. package/plugins/NetworkErrorLinkPlugin/Typography.js +18 -0
  281. package/plugins/NetworkErrorLinkPlugin/Typography.js.map +1 -0
  282. package/plugins/NetworkErrorLinkPlugin/createErrorOverlay.d.ts +3 -3
  283. package/plugins/NetworkErrorLinkPlugin/createErrorOverlay.js +10 -25
  284. package/plugins/NetworkErrorLinkPlugin/createErrorOverlay.js.map +1 -1
  285. package/plugins/NetworkErrorLinkPlugin.d.ts +4 -1
  286. package/plugins/NetworkErrorLinkPlugin.js +60 -37
  287. package/plugins/NetworkErrorLinkPlugin.js.map +1 -1
  288. package/plugins/OmitTypenameLinkPlugin.d.ts +1 -1
  289. package/plugins/OmitTypenameLinkPlugin.js +11 -30
  290. package/plugins/OmitTypenameLinkPlugin.js.map +1 -1
  291. package/plugins/TenantHeaderLinkPlugin.d.ts +3 -3
  292. package/plugins/TenantHeaderLinkPlugin.js +29 -48
  293. package/plugins/TenantHeaderLinkPlugin.js.map +1 -1
  294. package/plugins/components/Image.d.ts +6 -0
  295. package/plugins/components/Image.js +19 -0
  296. package/plugins/components/Image.js.map +1 -0
  297. package/plugins/image.d.ts +1 -1
  298. package/plugins/image.js +46 -53
  299. package/plugins/image.js.map +1 -1
  300. package/plugins/index.d.ts +4 -4
  301. package/plugins/index.js +31 -53
  302. package/plugins/index.js.map +1 -1
  303. package/presentation/localStorage/index.d.ts +3 -0
  304. package/presentation/localStorage/index.js +5 -0
  305. package/presentation/localStorage/index.js.map +1 -0
  306. package/presentation/localStorage/useLocalStorage.d.ts +6 -0
  307. package/presentation/localStorage/useLocalStorage.js +21 -0
  308. package/presentation/localStorage/useLocalStorage.js.map +1 -0
  309. package/presentation/localStorage/useLocalStorageValue.d.ts +1 -0
  310. package/presentation/localStorage/useLocalStorageValue.js +20 -0
  311. package/presentation/localStorage/useLocalStorageValue.js.map +1 -0
  312. package/presentation/localStorage/useLocalStorageValues.d.ts +5 -0
  313. package/presentation/localStorage/useLocalStorageValues.js +39 -0
  314. package/presentation/localStorage/useLocalStorageValues.js.map +1 -0
  315. package/presentation/router/RouteElementRegistry.d.ts +14 -0
  316. package/presentation/router/RouteElementRegistry.js +32 -0
  317. package/presentation/router/RouteElementRegistry.js.map +1 -0
  318. package/presentation/router/abstractions.d.ts +13 -0
  319. package/presentation/router/abstractions.js +4 -0
  320. package/presentation/router/abstractions.js.map +1 -0
  321. package/presentation/router/components/RouteContent.d.ts +2 -0
  322. package/presentation/router/components/RouteContent.js +17 -0
  323. package/presentation/router/components/RouteContent.js.map +1 -0
  324. package/presentation/router/components/RouteLink.d.ts +50 -0
  325. package/presentation/router/components/RouteLink.js +22 -0
  326. package/presentation/router/components/RouteLink.js.map +1 -0
  327. package/presentation/router/components/SimpleLink.d.ts +44 -0
  328. package/presentation/router/components/SimpleLink.js +30 -0
  329. package/presentation/router/components/SimpleLink.js.map +1 -0
  330. package/presentation/router/hooks/useRoute.d.ts +6 -0
  331. package/presentation/router/hooks/useRoute.js +30 -0
  332. package/presentation/router/hooks/useRoute.js.map +1 -0
  333. package/presentation/router/hooks/useRouter.d.ts +7 -0
  334. package/presentation/router/hooks/useRouter.js +26 -0
  335. package/presentation/router/hooks/useRouter.js.map +1 -0
  336. package/presentation/router/index.d.ts +4 -0
  337. package/presentation/router/index.js +5 -0
  338. package/presentation/router/index.js.map +1 -0
  339. package/presentation/router/types.d.ts +5 -0
  340. package/presentation/router/types.js +3 -0
  341. package/presentation/router/types.js.map +1 -0
  342. package/react-butterfiles/Files.js +208 -235
  343. package/react-butterfiles/Files.js.map +1 -1
  344. package/react-butterfiles/file.todo +1 -0
  345. package/react-butterfiles/index.d.ts +1 -1
  346. package/react-butterfiles/index.js +2 -8
  347. package/react-butterfiles/index.js.map +1 -1
  348. package/react-butterfiles/utils/generateId.js +1 -7
  349. package/react-butterfiles/utils/generateId.js.map +1 -1
  350. package/react-butterfiles/utils/readFileContent.js +4 -10
  351. package/react-butterfiles/utils/readFileContent.js.map +1 -1
  352. package/renderApp.d.ts +1 -1
  353. package/renderApp.js +4 -11
  354. package/renderApp.js.map +1 -1
  355. package/router.d.ts +5 -0
  356. package/router.js +8 -0
  357. package/router.js.map +1 -0
  358. package/shared/di/DiContainerProvider.d.ts +8 -0
  359. package/shared/di/DiContainerProvider.js +17 -0
  360. package/shared/di/DiContainerProvider.js.map +1 -0
  361. package/shared/di/createFeature.d.ts +11 -0
  362. package/shared/di/createFeature.js +11 -0
  363. package/shared/di/createFeature.js.map +1 -0
  364. package/shared/di/useFeature.d.ts +2 -0
  365. package/shared/di/useFeature.js +18 -0
  366. package/shared/di/useFeature.js.map +1 -0
  367. package/types.d.ts +9 -6
  368. package/types.js +1 -12
  369. package/types.js.map +1 -1
  370. package/utils/createGenericContext.js +13 -22
  371. package/utils/createGenericContext.js.map +1 -1
  372. package/utils/createHashing.js +9 -15
  373. package/utils/createHashing.js.map +1 -1
  374. package/utils/index.d.ts +2 -10
  375. package/utils/index.js +2 -115
  376. package/utils/index.js.map +1 -1
  377. package/utils/legacyPluginToReactComponent.d.ts +1 -1
  378. package/utils/legacyPluginToReactComponent.js +5 -11
  379. package/utils/legacyPluginToReactComponent.js.map +1 -1
  380. package/components/Routes.d.ts +0 -2
  381. package/components/Routes.js +0 -46
  382. package/components/Routes.js.map +0 -1
  383. package/components/View.d.ts +0 -8
  384. package/components/View.js +0 -31
  385. package/components/View.js.map +0 -1
  386. package/core/AddRoute.d.ts +0 -21
  387. package/core/AddRoute.js +0 -21
  388. package/core/AddRoute.js.map +0 -1
  389. package/hooks/useDataList/utils/redirectToRouteWithQueryParams.d.ts +0 -14
  390. package/hooks/useDataList/utils/redirectToRouteWithQueryParams.js +0 -30
  391. package/hooks/useDataList/utils/redirectToRouteWithQueryParams.js.map +0 -1
  392. package/hooks/useDataList/utils/types.d.ts +0 -40
  393. package/hooks/useDataList/utils/types.js +0 -7
  394. package/hooks/useDataList/utils/types.js.map +0 -1
  395. package/plugins/LocaleHeaderLinkPlugin.d.ts +0 -10
  396. package/plugins/LocaleHeaderLinkPlugin.js +0 -49
  397. package/plugins/LocaleHeaderLinkPlugin.js.map +0 -1
  398. package/plugins/RoutePlugin.d.ts +0 -12
  399. package/plugins/RoutePlugin.js +0 -35
  400. package/plugins/RoutePlugin.js.map +0 -1
  401. package/plugins/ViewPlugin.d.ts +0 -14
  402. package/plugins/ViewPlugin.js +0 -40
  403. package/plugins/ViewPlugin.js.map +0 -1
  404. package/utils/getApiUrl.d.ts +0 -1
  405. package/utils/getApiUrl.js +0 -12
  406. package/utils/getApiUrl.js.map +0 -1
  407. package/utils/getGqlApiUrl.d.ts +0 -1
  408. package/utils/getGqlApiUrl.js +0 -12
  409. package/utils/getGqlApiUrl.js.map +0 -1
  410. package/utils/getHeadlessCmsGqlApiUrl.d.ts +0 -5
  411. package/utils/getHeadlessCmsGqlApiUrl.js +0 -18
  412. package/utils/getHeadlessCmsGqlApiUrl.js.map +0 -1
  413. package/utils/getLocaleCode.d.ts +0 -6
  414. package/utils/getLocaleCode.js +0 -43
  415. package/utils/getLocaleCode.js.map +0 -1
  416. package/utils/getPrerenderId.d.ts +0 -6
  417. package/utils/getPrerenderId.js +0 -11
  418. package/utils/getPrerenderId.js.map +0 -1
  419. package/utils/getTenantId.d.ts +0 -6
  420. package/utils/getTenantId.js +0 -51
  421. package/utils/getTenantId.js.map +0 -1
  422. package/utils/isLocalhost.d.ts +0 -1
  423. package/utils/isLocalhost.js +0 -15
  424. package/utils/isLocalhost.js.map +0 -1
  425. package/utils/isPrerendering.d.ts +0 -1
  426. package/utils/isPrerendering.js +0 -11
  427. package/utils/isPrerendering.js.map +0 -1
@@ -0,0 +1,350 @@
1
+ import { describe, it, expect, vi, beforeEach } from "vitest";
2
+ import { Container } from "@webiny/di";
3
+ import { GraphQLClient } from "../abstractions.js";
4
+ import { FetchGraphQLClient } from "../FetchGraphQLClient.js";
5
+ import { BatchingGraphQLClient } from "../BatchingGraphQLClient.js";
6
+ import { RetryGraphQLClient } from "../RetryGraphQLClient.js";
7
+ import { EnvConfig } from "../../envConfig/index.js";
8
+ describe("GraphQLClient Feature", () => {
9
+ let container;
10
+ let mockEnvConfig;
11
+ beforeEach(() => {
12
+ container = new Container();
13
+ mockEnvConfig = {
14
+ get: vi.fn(key => {
15
+ if (key === "graphqlApiUrl") {
16
+ return "https://api.example.com/graphql";
17
+ }
18
+ return undefined;
19
+ })
20
+ };
21
+ container.registerInstance(EnvConfig, mockEnvConfig);
22
+ });
23
+ describe("FetchGraphQLClient", () => {
24
+ beforeEach(() => {
25
+ container.register(FetchGraphQLClient).inSingletonScope();
26
+ });
27
+ it("should execute a query successfully", async () => {
28
+ const mockResponse = {
29
+ data: {
30
+ user: {
31
+ id: "1",
32
+ name: "John"
33
+ }
34
+ }
35
+ };
36
+ global.fetch = vi.fn().mockResolvedValue({
37
+ status: 200,
38
+ json: async () => mockResponse
39
+ });
40
+ const client = container.resolve(GraphQLClient);
41
+ const result = await client.execute({
42
+ query: "query GetUser { user { id name } }"
43
+ });
44
+ expect(result).toEqual(mockResponse.data);
45
+ expect(global.fetch).toHaveBeenCalledWith("https://api.example.com/graphql", expect.objectContaining({
46
+ method: "POST",
47
+ headers: {
48
+ "Content-Type": "application/json"
49
+ }
50
+ }));
51
+ });
52
+ it("should execute a mutation successfully", async () => {
53
+ const mockResponse = {
54
+ data: {
55
+ createUser: {
56
+ id: "2",
57
+ name: "Jane"
58
+ }
59
+ }
60
+ };
61
+ global.fetch = vi.fn().mockResolvedValue({
62
+ status: 200,
63
+ json: async () => mockResponse
64
+ });
65
+ const client = container.resolve(GraphQLClient);
66
+ const result = await client.execute({
67
+ query: "mutation CreateUser($name: String!) { createUser(name: $name) { id name } }",
68
+ variables: {
69
+ name: "Jane"
70
+ }
71
+ });
72
+ expect(result).toEqual(mockResponse.data);
73
+ });
74
+ it("should include custom headers", async () => {
75
+ const mockResponse = {
76
+ data: {
77
+ user: {
78
+ id: "1"
79
+ }
80
+ }
81
+ };
82
+ global.fetch = vi.fn().mockResolvedValue({
83
+ status: 200,
84
+ json: async () => mockResponse
85
+ });
86
+ const client = container.resolve(GraphQLClient);
87
+ await client.execute({
88
+ query: "query GetUser { user { id } }",
89
+ headers: {
90
+ "x-tenant": "root",
91
+ Authorization: "Bearer token"
92
+ }
93
+ });
94
+ expect(global.fetch).toHaveBeenCalledWith("https://api.example.com/graphql", expect.objectContaining({
95
+ headers: {
96
+ "Content-Type": "application/json",
97
+ "x-tenant": "root",
98
+ Authorization: "Bearer token"
99
+ }
100
+ }));
101
+ });
102
+ it("should throw on network error", async () => {
103
+ global.fetch = vi.fn().mockRejectedValue(new Error("Network failure"));
104
+ const client = container.resolve(GraphQLClient);
105
+ await expect(client.execute({
106
+ query: "query { user { id } }"
107
+ })).rejects.toThrow("Network error: Network failure");
108
+ });
109
+ it("should throw on GraphQL errors", async () => {
110
+ const mockResponse = {
111
+ errors: [{
112
+ message: "User not found"
113
+ }],
114
+ data: null
115
+ };
116
+ global.fetch = vi.fn().mockResolvedValue({
117
+ status: 200,
118
+ json: async () => mockResponse
119
+ });
120
+ const client = container.resolve(GraphQLClient);
121
+ await expect(client.execute({
122
+ query: "query { user { id } }"
123
+ })).rejects.toThrow("GraphQL errors");
124
+ });
125
+ it("should throw on invalid JSON response", async () => {
126
+ global.fetch = vi.fn().mockResolvedValue({
127
+ json: async () => {
128
+ throw new Error("Invalid JSON");
129
+ }
130
+ });
131
+ const client = container.resolve(GraphQLClient);
132
+ await expect(client.execute({
133
+ query: "query { user { id } }"
134
+ })).rejects.toThrow("Failed to parse GraphQL response as JSON");
135
+ });
136
+ });
137
+ describe("BatchingGraphQLClient", () => {
138
+ beforeEach(() => {
139
+ container.register(FetchGraphQLClient).inSingletonScope();
140
+ container.registerDecorator(BatchingGraphQLClient);
141
+ });
142
+ it("should batch multiple requests within the batch window", async () => {
143
+ const mockResponse = [{
144
+ data: {
145
+ user: {
146
+ id: "1",
147
+ name: "John"
148
+ }
149
+ }
150
+ }, {
151
+ data: {
152
+ post: {
153
+ id: "2",
154
+ title: "Hello"
155
+ }
156
+ }
157
+ }];
158
+ global.fetch = vi.fn().mockResolvedValue({
159
+ json: async () => mockResponse
160
+ });
161
+ const client = container.resolve(GraphQLClient);
162
+ const [result1, result2] = await Promise.all([client.execute({
163
+ query: "query GetUser { user { id name } }"
164
+ }), client.execute({
165
+ query: "query GetPost { post { id title } }"
166
+ })]);
167
+ expect(result1).toEqual(mockResponse[0].data);
168
+ expect(result2).toEqual(mockResponse[1].data);
169
+ expect(global.fetch).toHaveBeenCalledTimes(1);
170
+ const callBody = JSON.parse(global.fetch.mock.calls[0][1].body);
171
+ expect(callBody).toHaveLength(2);
172
+ });
173
+ it("should execute single request without batching", async () => {
174
+ const mockResponse = {
175
+ data: {
176
+ user: {
177
+ id: "1",
178
+ name: "John"
179
+ }
180
+ }
181
+ };
182
+ global.fetch = vi.fn().mockResolvedValue({
183
+ status: 200,
184
+ json: async () => mockResponse
185
+ });
186
+ const client = container.resolve(GraphQLClient);
187
+ const result = await client.execute({
188
+ query: "query GetUser { user { id name } }"
189
+ });
190
+ expect(result).toEqual(mockResponse.data);
191
+
192
+ // Should use decoratee directly for single request
193
+ const callBody = JSON.parse(global.fetch.mock.calls[0][1].body);
194
+ expect(callBody).toHaveProperty("query");
195
+ expect(callBody).not.toBeInstanceOf(Array);
196
+ });
197
+ it("should handle mixed queries and mutations in batch", async () => {
198
+ const mockResponse = [{
199
+ data: {
200
+ user: {
201
+ id: "1"
202
+ }
203
+ }
204
+ }, {
205
+ data: {
206
+ createPost: {
207
+ id: "2"
208
+ }
209
+ }
210
+ }];
211
+ global.fetch = vi.fn().mockResolvedValue({
212
+ status: 200,
213
+ json: async () => mockResponse
214
+ });
215
+ const client = container.resolve(GraphQLClient);
216
+ await Promise.all([client.execute({
217
+ query: "query { user { id } }"
218
+ }), client.execute({
219
+ query: "mutation { createPost { id } }"
220
+ })]);
221
+ expect(global.fetch).toHaveBeenCalledTimes(1);
222
+ const callBody = JSON.parse(global.fetch.mock.calls[0][1].body);
223
+ expect(callBody[0]).toHaveProperty("query");
224
+ expect(callBody[1]).toHaveProperty("query");
225
+ });
226
+ it("should reject all requests if batch fails", async () => {
227
+ global.fetch = vi.fn().mockRejectedValue(new Error("Network error"));
228
+ const client = container.resolve(GraphQLClient);
229
+ const promises = [client.execute({
230
+ query: "query { user { id } }"
231
+ }), client.execute({
232
+ query: "query { post { id } }"
233
+ })];
234
+ await expect(Promise.all(promises)).rejects.toThrow("Network error");
235
+ });
236
+ it("should handle GraphQL errors in batched operations", async () => {
237
+ const mockResponse = [{
238
+ data: {
239
+ user: {
240
+ id: "1"
241
+ }
242
+ }
243
+ }, {
244
+ errors: [{
245
+ message: "Post not found"
246
+ }],
247
+ data: null
248
+ }];
249
+ global.fetch = vi.fn().mockResolvedValue({
250
+ json: async () => mockResponse
251
+ });
252
+ const client = container.resolve(GraphQLClient);
253
+ const promises = [client.execute({
254
+ query: "query { user { id } }"
255
+ }), client.execute({
256
+ query: "query { post { id } }"
257
+ })];
258
+ await expect(Promise.all(promises)).rejects.toThrow("GraphQL errors in operation 1");
259
+ });
260
+ });
261
+ describe("RetryGraphQLClient", () => {
262
+ beforeEach(() => {
263
+ container.register(FetchGraphQLClient).inSingletonScope();
264
+ container.registerDecorator(RetryGraphQLClient);
265
+ });
266
+ it("should retry on network errors", async () => {
267
+ const mockResponse = {
268
+ data: {
269
+ user: {
270
+ id: "1"
271
+ }
272
+ }
273
+ };
274
+ global.fetch = vi.fn().mockRejectedValueOnce(new Error("Network timeout")).mockRejectedValueOnce(new Error("Network timeout")).mockResolvedValueOnce({
275
+ status: 200,
276
+ json: async () => mockResponse
277
+ });
278
+ const client = container.resolve(GraphQLClient);
279
+ const result = await client.execute({
280
+ query: "query { user { id } }"
281
+ });
282
+ expect(result).toEqual(mockResponse.data);
283
+ expect(global.fetch).toHaveBeenCalledTimes(3);
284
+ });
285
+ it("should not retry on GraphQL errors", async () => {
286
+ const mockResponse = {
287
+ errors: [{
288
+ message: "Unauthorized"
289
+ }],
290
+ data: null
291
+ };
292
+ global.fetch = vi.fn().mockResolvedValue({
293
+ status: 200,
294
+ json: async () => mockResponse
295
+ });
296
+ const client = container.resolve(GraphQLClient);
297
+ await expect(client.execute({
298
+ query: "query { user { id } }"
299
+ })).rejects.toThrow("GraphQL errors");
300
+ expect(global.fetch).toHaveBeenCalledTimes(1);
301
+ });
302
+ it("should give up after max retries", async () => {
303
+ global.fetch = vi.fn().mockRejectedValue(new Error("Network error"));
304
+ const client = container.resolve(GraphQLClient);
305
+ await expect(client.execute({
306
+ query: "query { user { id } }"
307
+ })).rejects.toThrow("Network error");
308
+
309
+ // Should try 4 times: initial + 3 retries
310
+ expect(global.fetch).toHaveBeenCalledTimes(4);
311
+ });
312
+ });
313
+ describe("Combined decorators (Retry + Batching)", () => {
314
+ beforeEach(() => {
315
+ container.register(FetchGraphQLClient).inSingletonScope();
316
+ container.registerDecorator(BatchingGraphQLClient);
317
+ container.registerDecorator(RetryGraphQLClient);
318
+ });
319
+ it("should retry batched requests on failure", async () => {
320
+ const mockResponse = [{
321
+ data: {
322
+ user: {
323
+ id: "1"
324
+ }
325
+ }
326
+ }, {
327
+ data: {
328
+ post: {
329
+ id: "2"
330
+ }
331
+ }
332
+ }];
333
+ global.fetch = vi.fn().mockRejectedValueOnce(new Error("Network error")).mockResolvedValueOnce({
334
+ status: 200,
335
+ json: async () => mockResponse
336
+ });
337
+ const client = container.resolve(GraphQLClient);
338
+ const [result1, result2] = await Promise.all([client.execute({
339
+ query: "query { user { id } }"
340
+ }), client.execute({
341
+ query: "query { post { id } }"
342
+ })]);
343
+ expect(result1).toEqual(mockResponse[0].data);
344
+ expect(result2).toEqual(mockResponse[1].data);
345
+ expect(global.fetch).toHaveBeenCalledTimes(2);
346
+ });
347
+ });
348
+ });
349
+
350
+ //# sourceMappingURL=GraphQLClient.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["describe","it","expect","vi","beforeEach","Container","GraphQLClient","FetchGraphQLClient","BatchingGraphQLClient","RetryGraphQLClient","EnvConfig","container","mockEnvConfig","get","fn","key","undefined","registerInstance","register","inSingletonScope","mockResponse","data","user","id","name","global","fetch","mockResolvedValue","status","json","client","resolve","result","execute","query","toEqual","toHaveBeenCalledWith","objectContaining","method","headers","createUser","variables","Authorization","mockRejectedValue","Error","rejects","toThrow","errors","message","registerDecorator","post","title","result1","result2","Promise","all","toHaveBeenCalledTimes","callBody","JSON","parse","mock","calls","body","toHaveLength","toHaveProperty","not","toBeInstanceOf","Array","createPost","promises","mockRejectedValueOnce","mockResolvedValueOnce"],"sources":["GraphQLClient.test.ts"],"sourcesContent":["import { describe, it, expect, vi, beforeEach } from \"vitest\";\nimport { Container } from \"@webiny/di\";\nimport { GraphQLClient } from \"../abstractions.js\";\nimport { FetchGraphQLClient } from \"../FetchGraphQLClient.js\";\nimport { BatchingGraphQLClient } from \"../BatchingGraphQLClient.js\";\nimport { RetryGraphQLClient } from \"../RetryGraphQLClient.js\";\nimport { EnvConfig } from \"~/features/envConfig/index.js\";\n\ndescribe(\"GraphQLClient Feature\", () => {\n let container: Container;\n let mockEnvConfig: EnvConfig.Interface;\n\n beforeEach(() => {\n container = new Container();\n\n mockEnvConfig = {\n get: vi.fn((key: string) => {\n if (key === \"graphqlApiUrl\") {\n return \"https://api.example.com/graphql\";\n }\n return undefined;\n })\n } as any;\n\n container.registerInstance(EnvConfig, mockEnvConfig);\n });\n\n describe(\"FetchGraphQLClient\", () => {\n beforeEach(() => {\n container.register(FetchGraphQLClient).inSingletonScope();\n });\n\n it(\"should execute a query successfully\", async () => {\n const mockResponse = {\n data: { user: { id: \"1\", name: \"John\" } }\n };\n\n global.fetch = vi.fn().mockResolvedValue({\n status: 200,\n json: async () => mockResponse\n });\n\n const client = container.resolve(GraphQLClient);\n const result = await client.execute({\n query: \"query GetUser { user { id name } }\"\n });\n\n expect(result).toEqual(mockResponse.data);\n expect(global.fetch).toHaveBeenCalledWith(\n \"https://api.example.com/graphql\",\n expect.objectContaining({\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" }\n })\n );\n });\n\n it(\"should execute a mutation successfully\", async () => {\n const mockResponse = {\n data: { createUser: { id: \"2\", name: \"Jane\" } }\n };\n\n global.fetch = vi.fn().mockResolvedValue({\n status: 200,\n json: async () => mockResponse\n });\n\n const client = container.resolve(GraphQLClient);\n const result = await client.execute({\n query: \"mutation CreateUser($name: String!) { createUser(name: $name) { id name } }\",\n variables: { name: \"Jane\" }\n });\n\n expect(result).toEqual(mockResponse.data);\n });\n\n it(\"should include custom headers\", async () => {\n const mockResponse = { data: { user: { id: \"1\" } } };\n\n global.fetch = vi.fn().mockResolvedValue({\n status: 200,\n json: async () => mockResponse\n });\n\n const client = container.resolve(GraphQLClient);\n await client.execute({\n query: \"query GetUser { user { id } }\",\n headers: { \"x-tenant\": \"root\", Authorization: \"Bearer token\" }\n });\n\n expect(global.fetch).toHaveBeenCalledWith(\n \"https://api.example.com/graphql\",\n expect.objectContaining({\n headers: {\n \"Content-Type\": \"application/json\",\n \"x-tenant\": \"root\",\n Authorization: \"Bearer token\"\n }\n })\n );\n });\n\n it(\"should throw on network error\", async () => {\n global.fetch = vi.fn().mockRejectedValue(new Error(\"Network failure\"));\n\n const client = container.resolve(GraphQLClient);\n\n await expect(client.execute({ query: \"query { user { id } }\" })).rejects.toThrow(\n \"Network error: Network failure\"\n );\n });\n\n it(\"should throw on GraphQL errors\", async () => {\n const mockResponse = {\n errors: [{ message: \"User not found\" }],\n data: null\n };\n\n global.fetch = vi.fn().mockResolvedValue({\n status: 200,\n json: async () => mockResponse\n });\n\n const client = container.resolve(GraphQLClient);\n\n await expect(client.execute({ query: \"query { user { id } }\" })).rejects.toThrow(\n \"GraphQL errors\"\n );\n });\n\n it(\"should throw on invalid JSON response\", async () => {\n global.fetch = vi.fn().mockResolvedValue({\n json: async () => {\n throw new Error(\"Invalid JSON\");\n }\n });\n\n const client = container.resolve(GraphQLClient);\n\n await expect(client.execute({ query: \"query { user { id } }\" })).rejects.toThrow(\n \"Failed to parse GraphQL response as JSON\"\n );\n });\n });\n\n describe(\"BatchingGraphQLClient\", () => {\n beforeEach(() => {\n container.register(FetchGraphQLClient).inSingletonScope();\n container.registerDecorator(BatchingGraphQLClient);\n });\n\n it(\"should batch multiple requests within the batch window\", async () => {\n const mockResponse = [\n { data: { user: { id: \"1\", name: \"John\" } } },\n { data: { post: { id: \"2\", title: \"Hello\" } } }\n ];\n\n global.fetch = vi.fn().mockResolvedValue({\n json: async () => mockResponse\n });\n\n const client = container.resolve(GraphQLClient);\n\n const [result1, result2] = await Promise.all([\n client.execute({ query: \"query GetUser { user { id name } }\" }),\n client.execute({ query: \"query GetPost { post { id title } }\" })\n ]);\n\n expect(result1).toEqual(mockResponse[0].data);\n expect(result2).toEqual(mockResponse[1].data);\n expect(global.fetch).toHaveBeenCalledTimes(1);\n\n const callBody = JSON.parse((global.fetch as any).mock.calls[0][1].body);\n expect(callBody).toHaveLength(2);\n });\n\n it(\"should execute single request without batching\", async () => {\n const mockResponse = {\n data: { user: { id: \"1\", name: \"John\" } }\n };\n\n global.fetch = vi.fn().mockResolvedValue({\n status: 200,\n json: async () => mockResponse\n });\n\n const client = container.resolve(GraphQLClient);\n const result = await client.execute({\n query: \"query GetUser { user { id name } }\"\n });\n\n expect(result).toEqual(mockResponse.data);\n\n // Should use decoratee directly for single request\n const callBody = JSON.parse((global.fetch as any).mock.calls[0][1].body);\n expect(callBody).toHaveProperty(\"query\");\n expect(callBody).not.toBeInstanceOf(Array);\n });\n\n it(\"should handle mixed queries and mutations in batch\", async () => {\n const mockResponse = [\n { data: { user: { id: \"1\" } } },\n { data: { createPost: { id: \"2\" } } }\n ];\n\n global.fetch = vi.fn().mockResolvedValue({\n status: 200,\n json: async () => mockResponse\n });\n\n const client = container.resolve(GraphQLClient);\n\n await Promise.all([\n client.execute({ query: \"query { user { id } }\" }),\n client.execute({ query: \"mutation { createPost { id } }\" })\n ]);\n\n expect(global.fetch).toHaveBeenCalledTimes(1);\n const callBody = JSON.parse((global.fetch as any).mock.calls[0][1].body);\n expect(callBody[0]).toHaveProperty(\"query\");\n expect(callBody[1]).toHaveProperty(\"query\");\n });\n\n it(\"should reject all requests if batch fails\", async () => {\n global.fetch = vi.fn().mockRejectedValue(new Error(\"Network error\"));\n\n const client = container.resolve(GraphQLClient);\n\n const promises = [\n client.execute({ query: \"query { user { id } }\" }),\n client.execute({ query: \"query { post { id } }\" })\n ];\n\n await expect(Promise.all(promises)).rejects.toThrow(\"Network error\");\n });\n\n it(\"should handle GraphQL errors in batched operations\", async () => {\n const mockResponse = [\n { data: { user: { id: \"1\" } } },\n { errors: [{ message: \"Post not found\" }], data: null }\n ];\n\n global.fetch = vi.fn().mockResolvedValue({\n json: async () => mockResponse\n });\n\n const client = container.resolve(GraphQLClient);\n\n const promises = [\n client.execute({ query: \"query { user { id } }\" }),\n client.execute({ query: \"query { post { id } }\" })\n ];\n\n await expect(Promise.all(promises)).rejects.toThrow(\"GraphQL errors in operation 1\");\n });\n });\n\n describe(\"RetryGraphQLClient\", () => {\n beforeEach(() => {\n container.register(FetchGraphQLClient).inSingletonScope();\n container.registerDecorator(RetryGraphQLClient);\n });\n\n it(\"should retry on network errors\", async () => {\n const mockResponse = { data: { user: { id: \"1\" } } };\n\n global.fetch = vi\n .fn()\n .mockRejectedValueOnce(new Error(\"Network timeout\"))\n .mockRejectedValueOnce(new Error(\"Network timeout\"))\n .mockResolvedValueOnce({\n status: 200,\n json: async () => mockResponse\n });\n\n const client = container.resolve(GraphQLClient);\n const result = await client.execute({ query: \"query { user { id } }\" });\n\n expect(result).toEqual(mockResponse.data);\n expect(global.fetch).toHaveBeenCalledTimes(3);\n });\n\n it(\"should not retry on GraphQL errors\", async () => {\n const mockResponse = {\n errors: [{ message: \"Unauthorized\" }],\n data: null\n };\n\n global.fetch = vi.fn().mockResolvedValue({\n status: 200,\n json: async () => mockResponse\n });\n\n const client = container.resolve(GraphQLClient);\n\n await expect(client.execute({ query: \"query { user { id } }\" })).rejects.toThrow(\n \"GraphQL errors\"\n );\n\n expect(global.fetch).toHaveBeenCalledTimes(1);\n });\n\n it(\"should give up after max retries\", async () => {\n global.fetch = vi.fn().mockRejectedValue(new Error(\"Network error\"));\n\n const client = container.resolve(GraphQLClient);\n\n await expect(client.execute({ query: \"query { user { id } }\" })).rejects.toThrow(\n \"Network error\"\n );\n\n // Should try 4 times: initial + 3 retries\n expect(global.fetch).toHaveBeenCalledTimes(4);\n });\n });\n\n describe(\"Combined decorators (Retry + Batching)\", () => {\n beforeEach(() => {\n container.register(FetchGraphQLClient).inSingletonScope();\n container.registerDecorator(BatchingGraphQLClient);\n container.registerDecorator(RetryGraphQLClient);\n });\n\n it(\"should retry batched requests on failure\", async () => {\n const mockResponse = [{ data: { user: { id: \"1\" } } }, { data: { post: { id: \"2\" } } }];\n\n global.fetch = vi\n .fn()\n .mockRejectedValueOnce(new Error(\"Network error\"))\n .mockResolvedValueOnce({\n status: 200,\n json: async () => mockResponse\n });\n\n const client = container.resolve(GraphQLClient);\n\n const [result1, result2] = await Promise.all([\n client.execute({ query: \"query { user { id } }\" }),\n client.execute({ query: \"query { post { id } }\" })\n ]);\n\n expect(result1).toEqual(mockResponse[0].data);\n expect(result2).toEqual(mockResponse[1].data);\n expect(global.fetch).toHaveBeenCalledTimes(2);\n });\n });\n});\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,17 @@
1
+ import type { DocumentNode } from "graphql";
2
+ type IHeaders = Record<string, string | number | undefined>;
3
+ type GraphQLRequest<TVariables = any> = {
4
+ query: DocumentNode | string;
5
+ variables?: TVariables;
6
+ headers?: IHeaders;
7
+ };
8
+ export interface IGraphQLClient {
9
+ execute<TResult = any, TVariables = any>(params: GraphQLRequest<TVariables>): Promise<TResult>;
10
+ }
11
+ export declare const GraphQLClient: import("@webiny/di").Abstraction<IGraphQLClient>;
12
+ export declare namespace GraphQLClient {
13
+ type Headers = IHeaders;
14
+ type Interface = IGraphQLClient;
15
+ type Request<TVariables = any> = GraphQLRequest<TVariables>;
16
+ }
17
+ export {};
@@ -0,0 +1,4 @@
1
+ import { createAbstraction } from "@webiny/feature/admin";
2
+ export const GraphQLClient = createAbstraction("GraphQLClient");
3
+
4
+ //# sourceMappingURL=abstractions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["createAbstraction","GraphQLClient"],"sources":["abstractions.ts"],"sourcesContent":["import { createAbstraction } from \"@webiny/feature/admin\";\nimport type { DocumentNode } from \"graphql\";\n\ntype IHeaders = Record<string, string | number | undefined>;\n\ntype GraphQLRequest<TVariables = any> = {\n query: DocumentNode | string;\n variables?: TVariables;\n headers?: IHeaders;\n};\n\nexport interface IGraphQLClient {\n execute<TResult = any, TVariables = any>(params: GraphQLRequest<TVariables>): Promise<TResult>;\n}\nexport const GraphQLClient = createAbstraction<IGraphQLClient>(\"GraphQLClient\");\n\nexport namespace GraphQLClient {\n export type Headers = IHeaders;\n export type Interface = IGraphQLClient;\n export type Request<TVariables = any> = GraphQLRequest<TVariables>;\n}\n"],"mappings":"AAAA,SAASA,iBAAiB,QAAQ,uBAAuB;AAczD,OAAO,MAAMC,aAAa,GAAGD,iBAAiB,CAAiB,eAAe,CAAC","ignoreList":[]}
@@ -0,0 +1,6 @@
1
+ export declare const GraphQLClientFeature: import("~/shared/di/createFeature.js").FeatureDefinition<{
2
+ client: import("./abstractions.js").IGraphQLClient;
3
+ }, [options: {
4
+ batching: boolean;
5
+ retry: boolean;
6
+ }]>;
@@ -0,0 +1,31 @@
1
+ import { GraphQLClient } from "./abstractions.js";
2
+ import { BatchingGraphQLClient } from "./BatchingGraphQLClient.js";
3
+ import { FetchGraphQLClient } from "./FetchGraphQLClient.js";
4
+ import { createFeature } from "../../shared/di/createFeature.js";
5
+ import { RetryGraphQLClient } from "./RetryGraphQLClient.js";
6
+ import { NetworkErrorPublishing } from "./NetworkErrorPublishing.js";
7
+ import { AuthenticationErrorPublishing } from "./AuthenticationErrorPublishing.js";
8
+ export const GraphQLClientFeature = createFeature({
9
+ name: "GraphQLClient",
10
+ register(container, options) {
11
+ // Base implementation
12
+ container.register(FetchGraphQLClient).inSingletonScope();
13
+
14
+ // Optional decorators (order matters: retry wraps batching)
15
+ if (options.batching) {
16
+ container.registerDecorator(BatchingGraphQLClient);
17
+ }
18
+ if (options.retry) {
19
+ container.registerDecorator(RetryGraphQLClient);
20
+ }
21
+ container.registerDecorator(NetworkErrorPublishing);
22
+ container.registerDecorator(AuthenticationErrorPublishing);
23
+ },
24
+ resolve(container) {
25
+ return {
26
+ client: container.resolve(GraphQLClient)
27
+ };
28
+ }
29
+ });
30
+
31
+ //# sourceMappingURL=feature.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["GraphQLClient","BatchingGraphQLClient","FetchGraphQLClient","createFeature","RetryGraphQLClient","NetworkErrorPublishing","AuthenticationErrorPublishing","GraphQLClientFeature","name","register","container","options","inSingletonScope","batching","registerDecorator","retry","resolve","client"],"sources":["feature.ts"],"sourcesContent":["import { GraphQLClient } from \"./abstractions.js\";\nimport { BatchingGraphQLClient } from \"./BatchingGraphQLClient.js\";\nimport { FetchGraphQLClient } from \"./FetchGraphQLClient.js\";\nimport { createFeature } from \"~/shared/di/createFeature.js\";\nimport { RetryGraphQLClient } from \"./RetryGraphQLClient.js\";\nimport { NetworkErrorPublishing } from \"./NetworkErrorPublishing.js\";\nimport { AuthenticationErrorPublishing } from \"./AuthenticationErrorPublishing.js\";\n\nexport const GraphQLClientFeature = createFeature({\n name: \"GraphQLClient\",\n register(\n container,\n options: {\n batching: boolean;\n retry: boolean;\n }\n ) {\n // Base implementation\n container.register(FetchGraphQLClient).inSingletonScope();\n\n // Optional decorators (order matters: retry wraps batching)\n if (options.batching) {\n container.registerDecorator(BatchingGraphQLClient);\n }\n\n if (options.retry) {\n container.registerDecorator(RetryGraphQLClient);\n }\n\n container.registerDecorator(NetworkErrorPublishing);\n container.registerDecorator(AuthenticationErrorPublishing);\n },\n resolve(container) {\n return {\n client: container.resolve(GraphQLClient)\n };\n }\n});\n"],"mappings":"AAAA,SAASA,aAAa;AACtB,SAASC,qBAAqB;AAC9B,SAASC,kBAAkB;AAC3B,SAASC,aAAa;AACtB,SAASC,kBAAkB;AAC3B,SAASC,sBAAsB;AAC/B,SAASC,6BAA6B;AAEtC,OAAO,MAAMC,oBAAoB,GAAGJ,aAAa,CAAC;EAC9CK,IAAI,EAAE,eAAe;EACrBC,QAAQA,CACJC,SAAS,EACTC,OAGC,EACH;IACE;IACAD,SAAS,CAACD,QAAQ,CAACP,kBAAkB,CAAC,CAACU,gBAAgB,CAAC,CAAC;;IAEzD;IACA,IAAID,OAAO,CAACE,QAAQ,EAAE;MAClBH,SAAS,CAACI,iBAAiB,CAACb,qBAAqB,CAAC;IACtD;IAEA,IAAIU,OAAO,CAACI,KAAK,EAAE;MACfL,SAAS,CAACI,iBAAiB,CAACV,kBAAkB,CAAC;IACnD;IAEAM,SAAS,CAACI,iBAAiB,CAACT,sBAAsB,CAAC;IACnDK,SAAS,CAACI,iBAAiB,CAACR,6BAA6B,CAAC;EAC9D,CAAC;EACDU,OAAOA,CAACN,SAAS,EAAE;IACf,OAAO;MACHO,MAAM,EAAEP,SAAS,CAACM,OAAO,CAAChB,aAAa;IAC3C,CAAC;EACL;AACJ,CAAC,CAAC","ignoreList":[]}
@@ -0,0 +1 @@
1
+ export { GraphQLClient } from "./abstractions.js";
@@ -0,0 +1,3 @@
1
+ export { GraphQLClient } from "./abstractions.js";
2
+
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["GraphQLClient"],"sources":["index.ts"],"sourcesContent":["export { GraphQLClient } from \"./abstractions.js\";\n"],"mappings":"AAAA,SAASA,aAAa","ignoreList":[]}
@@ -0,0 +1,5 @@
1
+ export interface BatchingOptions {
2
+ enabled?: boolean;
3
+ batchWindowMs?: number;
4
+ maxBatchSize?: number;
5
+ }
@@ -0,0 +1,3 @@
1
+ export {};
2
+
3
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":[],"sources":["types.ts"],"sourcesContent":["export interface BatchingOptions {\n enabled?: boolean;\n batchWindowMs?: number;\n maxBatchSize?: number;\n}\n"],"mappings":"","ignoreList":[]}
@@ -0,0 +1,9 @@
1
+ import { ILocalStorageGateway } from "./abstractions.js";
2
+ export declare class BrowserLocalStorageGateway implements ILocalStorageGateway {
3
+ get<T = string>(key: string): T | null;
4
+ set<T = string>(key: string, value: T): void;
5
+ remove(key: string): void;
6
+ clear(): void;
7
+ getAll(): Record<string, unknown>;
8
+ subscribe(listener: (event: StorageEvent | CustomEvent) => void): () => void;
9
+ }
@@ -0,0 +1,68 @@
1
+ export class BrowserLocalStorageGateway {
2
+ get(key) {
3
+ const value = window.localStorage.getItem(key);
4
+ try {
5
+ return value ? JSON.parse(value) : null;
6
+ } catch {
7
+ return value;
8
+ }
9
+ }
10
+ set(key, value) {
11
+ const serialized = typeof value === "string" ? value : JSON.stringify(value);
12
+ window.localStorage.setItem(key, serialized);
13
+
14
+ // Dispatch local event so same-tab listeners are notified.
15
+ window.dispatchEvent(new CustomEvent("localstorage:changed", {
16
+ detail: {
17
+ key,
18
+ value,
19
+ action: "set"
20
+ }
21
+ }));
22
+ }
23
+ remove(key) {
24
+ window.localStorage.removeItem(key);
25
+ window.dispatchEvent(new CustomEvent("localstorage:changed", {
26
+ detail: {
27
+ key,
28
+ action: "remove"
29
+ }
30
+ }));
31
+ }
32
+ clear() {
33
+ window.localStorage.clear();
34
+ window.dispatchEvent(new CustomEvent("localstorage:changed", {
35
+ detail: {
36
+ action: "clear"
37
+ }
38
+ }));
39
+ }
40
+ getAll() {
41
+ const result = {};
42
+ for (let i = 0; i < window.localStorage.length; i++) {
43
+ const key = window.localStorage.key(i);
44
+ const val = this.get(key);
45
+ if (val !== null) {
46
+ result[key] = val;
47
+ }
48
+ }
49
+ return result;
50
+ }
51
+
52
+ // Subscribe to changes (cross-tab + same-tab)
53
+ subscribe(listener) {
54
+ const handler = ev => {
55
+ if (ev instanceof StorageEvent || ev instanceof CustomEvent) {
56
+ listener(ev);
57
+ }
58
+ };
59
+ window.addEventListener("storage", handler);
60
+ window.addEventListener("localstorage:changed", handler);
61
+ return () => {
62
+ window.removeEventListener("storage", handler);
63
+ window.removeEventListener("localstorage:changed", handler);
64
+ };
65
+ }
66
+ }
67
+
68
+ //# sourceMappingURL=BrowserLocalStorageGateway.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["BrowserLocalStorageGateway","get","key","value","window","localStorage","getItem","JSON","parse","set","serialized","stringify","setItem","dispatchEvent","CustomEvent","detail","action","remove","removeItem","clear","getAll","result","i","length","val","subscribe","listener","handler","ev","StorageEvent","addEventListener","removeEventListener"],"sources":["BrowserLocalStorageGateway.ts"],"sourcesContent":["import { ILocalStorageGateway } from \"./abstractions.js\";\n\nexport class BrowserLocalStorageGateway implements ILocalStorageGateway {\n get<T = string>(key: string): T | null {\n const value = window.localStorage.getItem(key);\n try {\n return value ? (JSON.parse(value) as T) : null;\n } catch {\n return value as unknown as T;\n }\n }\n\n set<T = string>(key: string, value: T): void {\n const serialized = typeof value === \"string\" ? value : JSON.stringify(value);\n window.localStorage.setItem(key, serialized);\n\n // Dispatch local event so same-tab listeners are notified.\n window.dispatchEvent(\n new CustomEvent(\"localstorage:changed\", {\n detail: { key, value, action: \"set\" }\n })\n );\n }\n\n remove(key: string): void {\n window.localStorage.removeItem(key);\n window.dispatchEvent(\n new CustomEvent(\"localstorage:changed\", {\n detail: { key, action: \"remove\" }\n })\n );\n }\n\n clear(): void {\n window.localStorage.clear();\n window.dispatchEvent(\n new CustomEvent(\"localstorage:changed\", {\n detail: { action: \"clear\" }\n })\n );\n }\n\n getAll(): Record<string, unknown> {\n const result: Record<string, unknown> = {};\n for (let i = 0; i < window.localStorage.length; i++) {\n const key = window.localStorage.key(i)!;\n const val = this.get(key);\n if (val !== null) {\n result[key] = val;\n }\n }\n return result;\n }\n\n // Subscribe to changes (cross-tab + same-tab)\n subscribe(listener: (event: StorageEvent | CustomEvent) => void): () => void {\n const handler = (ev: Event) => {\n if (ev instanceof StorageEvent || ev instanceof CustomEvent) {\n listener(ev);\n }\n };\n window.addEventListener(\"storage\", handler);\n window.addEventListener(\"localstorage:changed\", handler as any);\n\n return () => {\n window.removeEventListener(\"storage\", handler);\n window.removeEventListener(\"localstorage:changed\", handler as any);\n };\n }\n}\n"],"mappings":"AAEA,OAAO,MAAMA,0BAA0B,CAAiC;EACpEC,GAAGA,CAAaC,GAAW,EAAY;IACnC,MAAMC,KAAK,GAAGC,MAAM,CAACC,YAAY,CAACC,OAAO,CAACJ,GAAG,CAAC;IAC9C,IAAI;MACA,OAAOC,KAAK,GAAII,IAAI,CAACC,KAAK,CAACL,KAAK,CAAC,GAAS,IAAI;IAClD,CAAC,CAAC,MAAM;MACJ,OAAOA,KAAK;IAChB;EACJ;EAEAM,GAAGA,CAAaP,GAAW,EAAEC,KAAQ,EAAQ;IACzC,MAAMO,UAAU,GAAG,OAAOP,KAAK,KAAK,QAAQ,GAAGA,KAAK,GAAGI,IAAI,CAACI,SAAS,CAACR,KAAK,CAAC;IAC5EC,MAAM,CAACC,YAAY,CAACO,OAAO,CAACV,GAAG,EAAEQ,UAAU,CAAC;;IAE5C;IACAN,MAAM,CAACS,aAAa,CAChB,IAAIC,WAAW,CAAC,sBAAsB,EAAE;MACpCC,MAAM,EAAE;QAAEb,GAAG;QAAEC,KAAK;QAAEa,MAAM,EAAE;MAAM;IACxC,CAAC,CACL,CAAC;EACL;EAEAC,MAAMA,CAACf,GAAW,EAAQ;IACtBE,MAAM,CAACC,YAAY,CAACa,UAAU,CAAChB,GAAG,CAAC;IACnCE,MAAM,CAACS,aAAa,CAChB,IAAIC,WAAW,CAAC,sBAAsB,EAAE;MACpCC,MAAM,EAAE;QAAEb,GAAG;QAAEc,MAAM,EAAE;MAAS;IACpC,CAAC,CACL,CAAC;EACL;EAEAG,KAAKA,CAAA,EAAS;IACVf,MAAM,CAACC,YAAY,CAACc,KAAK,CAAC,CAAC;IAC3Bf,MAAM,CAACS,aAAa,CAChB,IAAIC,WAAW,CAAC,sBAAsB,EAAE;MACpCC,MAAM,EAAE;QAAEC,MAAM,EAAE;MAAQ;IAC9B,CAAC,CACL,CAAC;EACL;EAEAI,MAAMA,CAAA,EAA4B;IAC9B,MAAMC,MAA+B,GAAG,CAAC,CAAC;IAC1C,KAAK,IAAIC,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGlB,MAAM,CAACC,YAAY,CAACkB,MAAM,EAAED,CAAC,EAAE,EAAE;MACjD,MAAMpB,GAAG,GAAGE,MAAM,CAACC,YAAY,CAACH,GAAG,CAACoB,CAAC,CAAE;MACvC,MAAME,GAAG,GAAG,IAAI,CAACvB,GAAG,CAACC,GAAG,CAAC;MACzB,IAAIsB,GAAG,KAAK,IAAI,EAAE;QACdH,MAAM,CAACnB,GAAG,CAAC,GAAGsB,GAAG;MACrB;IACJ;IACA,OAAOH,MAAM;EACjB;;EAEA;EACAI,SAASA,CAACC,QAAqD,EAAc;IACzE,MAAMC,OAAO,GAAIC,EAAS,IAAK;MAC3B,IAAIA,EAAE,YAAYC,YAAY,IAAID,EAAE,YAAYd,WAAW,EAAE;QACzDY,QAAQ,CAACE,EAAE,CAAC;MAChB;IACJ,CAAC;IACDxB,MAAM,CAAC0B,gBAAgB,CAAC,SAAS,EAAEH,OAAO,CAAC;IAC3CvB,MAAM,CAAC0B,gBAAgB,CAAC,sBAAsB,EAAEH,OAAc,CAAC;IAE/D,OAAO,MAAM;MACTvB,MAAM,CAAC2B,mBAAmB,CAAC,SAAS,EAAEJ,OAAO,CAAC;MAC9CvB,MAAM,CAAC2B,mBAAmB,CAAC,sBAAsB,EAAEJ,OAAc,CAAC;IACtE,CAAC;EACL;AACJ","ignoreList":[]}
@@ -0,0 +1,12 @@
1
+ import { LocalStorage as LocalStorageAbstraction, LocalStorageRepository } from "./abstractions.js";
2
+ declare class LocalStorageImpl implements LocalStorageAbstraction.Interface {
3
+ private readonly repo;
4
+ constructor(repo: LocalStorageRepository.Interface);
5
+ get<T = string>(key: string): T | undefined;
6
+ set<T = string>(key: string, value: T): void;
7
+ remove(key: string): void;
8
+ clear(): void;
9
+ keys(): string[];
10
+ }
11
+ export declare const LocalStorage: import("@webiny/di").Implementation<typeof LocalStorageImpl>;
12
+ export {};
@@ -0,0 +1,31 @@
1
+ import { makeAutoObservable } from "mobx";
2
+ import { LocalStorage as LocalStorageAbstraction, LocalStorageRepository } from "./abstractions.js";
3
+ import { createImplementation } from "@webiny/di";
4
+ class LocalStorageImpl {
5
+ constructor(repo) {
6
+ this.repo = repo;
7
+ makeAutoObservable(this);
8
+ }
9
+ get(key) {
10
+ return this.repo.get(key);
11
+ }
12
+ set(key, value) {
13
+ this.repo.set(key, value);
14
+ }
15
+ remove(key) {
16
+ this.repo.remove(key);
17
+ }
18
+ clear() {
19
+ this.repo.clear();
20
+ }
21
+ keys() {
22
+ return this.repo.keys();
23
+ }
24
+ }
25
+ export const LocalStorage = createImplementation({
26
+ abstraction: LocalStorageAbstraction,
27
+ implementation: LocalStorageImpl,
28
+ dependencies: [LocalStorageRepository]
29
+ });
30
+
31
+ //# sourceMappingURL=LocalStorage.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["makeAutoObservable","LocalStorage","LocalStorageAbstraction","LocalStorageRepository","createImplementation","LocalStorageImpl","constructor","repo","get","key","set","value","remove","clear","keys","abstraction","implementation","dependencies"],"sources":["LocalStorage.ts"],"sourcesContent":["import { makeAutoObservable } from \"mobx\";\nimport { LocalStorage as LocalStorageAbstraction, LocalStorageRepository } from \"./abstractions.js\";\nimport { createImplementation } from \"@webiny/di\";\n\nclass LocalStorageImpl implements LocalStorageAbstraction.Interface {\n constructor(private readonly repo: LocalStorageRepository.Interface) {\n makeAutoObservable(this);\n }\n\n get<T = string>(key: string) {\n return this.repo.get<T>(key);\n }\n set<T = string>(key: string, value: T) {\n this.repo.set(key, value);\n }\n remove(key: string) {\n this.repo.remove(key);\n }\n clear() {\n this.repo.clear();\n }\n keys() {\n return this.repo.keys();\n }\n}\n\nexport const LocalStorage = createImplementation({\n abstraction: LocalStorageAbstraction,\n implementation: LocalStorageImpl,\n dependencies: [LocalStorageRepository]\n});\n"],"mappings":"AAAA,SAASA,kBAAkB,QAAQ,MAAM;AACzC,SAASC,YAAY,IAAIC,uBAAuB,EAAEC,sBAAsB;AACxE,SAASC,oBAAoB,QAAQ,YAAY;AAEjD,MAAMC,gBAAgB,CAA8C;EAChEC,WAAWA,CAAkBC,IAAsC,EAAE;IAAA,KAAxCA,IAAsC,GAAtCA,IAAsC;IAC/DP,kBAAkB,CAAC,IAAI,CAAC;EAC5B;EAEAQ,GAAGA,CAAaC,GAAW,EAAE;IACzB,OAAO,IAAI,CAACF,IAAI,CAACC,GAAG,CAAIC,GAAG,CAAC;EAChC;EACAC,GAAGA,CAAaD,GAAW,EAAEE,KAAQ,EAAE;IACnC,IAAI,CAACJ,IAAI,CAACG,GAAG,CAACD,GAAG,EAAEE,KAAK,CAAC;EAC7B;EACAC,MAAMA,CAACH,GAAW,EAAE;IAChB,IAAI,CAACF,IAAI,CAACK,MAAM,CAACH,GAAG,CAAC;EACzB;EACAI,KAAKA,CAAA,EAAG;IACJ,IAAI,CAACN,IAAI,CAACM,KAAK,CAAC,CAAC;EACrB;EACAC,IAAIA,CAAA,EAAG;IACH,OAAO,IAAI,CAACP,IAAI,CAACO,IAAI,CAAC,CAAC;EAC3B;AACJ;AAEA,OAAO,MAAMb,YAAY,GAAGG,oBAAoB,CAAC;EAC7CW,WAAW,EAAEb,uBAAuB;EACpCc,cAAc,EAAEX,gBAAgB;EAChCY,YAAY,EAAE,CAACd,sBAAsB;AACzC,CAAC,CAAC","ignoreList":[]}