@envive-ai/react-hooks 0.2.6-alpha-arthur-3 → 0.2.6-alpha-arthur-6

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 (236) hide show
  1. package/dist/{AmplitudeOperations-CQs4sVHN.cjs → AmplitudeOperations-BU9A9Jdd.cjs} +2 -2
  2. package/dist/{AmplitudeOperations-BjC8DOqm.js → AmplitudeOperations-Cu59kGhS.js} +2 -2
  3. package/dist/{NewOrgConfig-CRakarmw.js → NewOrgConfig-9wAXPrL1.js} +2 -2
  4. package/dist/{NewOrgConfig-D48KabOj.cjs → NewOrgConfig-B8M-0VB5.cjs} +2 -2
  5. package/dist/{TrackComponentVisibleEvent-_Fb-JXkV.cjs → TrackComponentVisibleEvent-7iexpwkM.cjs} +4 -4
  6. package/dist/{TrackComponentVisibleEvent-C9RvfdS9.js → TrackComponentVisibleEvent-s4aYQ1Po.js} +4 -4
  7. package/dist/{amplitudeContext-wW37Ziq-.js → amplitudeContext-BDnZgp_c.js} +8 -8
  8. package/dist/{amplitudeContext-D5HSmIWg.cjs → amplitudeContext-BINPUhrB.cjs} +9 -9
  9. package/dist/{amplitudeTrackEventAtom-f22P2U0u.cjs → amplitudeTrackEventAtom-D2dmLwju.cjs} +1 -1
  10. package/dist/{amplitudeTrackEventAtom-D66l5oFp.js → amplitudeTrackEventAtom-T5Hfgv1d.js} +1 -1
  11. package/dist/app-C6fvSwK7.js +110 -0
  12. package/dist/app-DLIfJpA6.cjs +150 -0
  13. package/dist/application/models/graphql/index.d.ts +1 -1
  14. package/dist/application/models/guards/api/index.d.ts +2 -2
  15. package/dist/application/models/guards/utils.d.ts +1 -1
  16. package/dist/application/models/index.cjs +2 -2
  17. package/dist/application/models/index.d.cts +1 -1
  18. package/dist/application/models/index.d.ts +4 -4
  19. package/dist/application/models/index.js +2 -2
  20. package/dist/application/utils/index.cjs +3 -3
  21. package/dist/application/utils/index.d.cts +2 -2
  22. package/dist/application/utils/index.d.ts +4 -4
  23. package/dist/application/utils/index.js +3 -3
  24. package/dist/{atomStore-CZKe3itM.cjs → atomStore-8ppNkJ_n.cjs} +1 -1
  25. package/dist/{atomStore-BuopbV9k.js → atomStore-BLYJ2ZoQ.js} +1 -1
  26. package/dist/atoms/app/index.cjs +4 -16
  27. package/dist/atoms/app/index.d.cts +7 -7
  28. package/dist/atoms/app/index.d.ts +6 -6
  29. package/dist/atoms/app/index.js +4 -16
  30. package/dist/atoms/atomStore/index.cjs +1 -1
  31. package/dist/atoms/atomStore/index.js +1 -1
  32. package/dist/atoms/chat/index.cjs +8 -18
  33. package/dist/atoms/chat/index.d.cts +31 -31
  34. package/dist/atoms/chat/index.d.ts +33 -33
  35. package/dist/atoms/chat/index.js +8 -18
  36. package/dist/atoms/globalSearch/index.cjs +1 -1
  37. package/dist/atoms/globalSearch/index.d.cts +5 -5
  38. package/dist/atoms/globalSearch/index.d.ts +6 -6
  39. package/dist/atoms/globalSearch/index.js +1 -1
  40. package/dist/atoms/org/index.cjs +12 -10
  41. package/dist/atoms/org/index.d.cts +15 -15
  42. package/dist/atoms/org/index.d.ts +17 -17
  43. package/dist/atoms/org/index.js +4 -2
  44. package/dist/atoms/search/index.cjs +8 -6
  45. package/dist/atoms/search/index.d.cts +15 -15
  46. package/dist/atoms/search/index.d.ts +15 -15
  47. package/dist/atoms/search/index.js +8 -6
  48. package/dist/atoms/search/utils.cjs +1 -1
  49. package/dist/atoms/search/utils.d.cts +1 -1
  50. package/dist/atoms/search/utils.js +1 -1
  51. package/dist/{cdnContext-BJT_Wn9Z.js → cdnContext-QjEi8uUT.js} +2 -2
  52. package/dist/{cdnContext-BoPraJxf.cjs → cdnContext-c_ktbXSd.cjs} +2 -2
  53. package/dist/{chat-ZaY3KY-R.js → chat-B_uOuZIL.js} +5 -5
  54. package/dist/{chat-rhEjVfrd.cjs → chat-C37wHZ_K.cjs} +5 -5
  55. package/dist/{chatState-BbI93m6r.js → chatState-8MDLF_t4.js} +2 -2
  56. package/dist/{chatState-DlJpHAsW.cjs → chatState-DVZZ2tvl.cjs} +2 -2
  57. package/dist/config/index.d.ts +4 -4
  58. package/dist/config/locators/components/chat/index.d.ts +1 -1
  59. package/dist/config/locators/components/common/index.d.ts +1 -1
  60. package/dist/config/locators/components/index.d.ts +1 -1
  61. package/dist/config/locators/index.d.ts +4 -4
  62. package/dist/contexts/amplitudeContext/index.cjs +9 -19
  63. package/dist/contexts/amplitudeContext/index.js +9 -19
  64. package/dist/contexts/cdnContext/index.cjs +3 -3
  65. package/dist/contexts/cdnContext/index.js +3 -3
  66. package/dist/contexts/enviveConfigContext/index.cjs +4 -4
  67. package/dist/contexts/enviveConfigContext/index.d.cts +1 -1
  68. package/dist/contexts/enviveConfigContext/index.js +4 -4
  69. package/dist/contexts/enviveCssContext/index.cjs +12 -12
  70. package/dist/contexts/enviveCssContext/index.js +12 -12
  71. package/dist/contexts/featureFlagContext/index.cjs +4 -4
  72. package/dist/contexts/featureFlagContext/index.d.cts +1 -1
  73. package/dist/contexts/featureFlagContext/index.js +4 -4
  74. package/dist/contexts/featureFlagServiceContext/index.cjs +3 -3
  75. package/dist/contexts/featureFlagServiceContext/index.d.ts +1 -1
  76. package/dist/contexts/featureFlagServiceContext/index.js +3 -3
  77. package/dist/contexts/graphqlContext/index.cjs +6 -6
  78. package/dist/contexts/graphqlContext/index.d.cts +1 -1
  79. package/dist/contexts/graphqlContext/index.d.ts +2 -2
  80. package/dist/contexts/graphqlContext/index.js +6 -6
  81. package/dist/contexts/localStorageContext/index.cjs +2 -2
  82. package/dist/contexts/localStorageContext/index.d.cts +1 -1
  83. package/dist/contexts/localStorageContext/index.js +2 -2
  84. package/dist/contexts/newOrgConfigContext/index.cjs +11 -11
  85. package/dist/contexts/newOrgConfigContext/index.js +11 -11
  86. package/dist/contexts/searchContext/index.cjs +12 -19
  87. package/dist/contexts/searchContext/index.js +12 -19
  88. package/dist/contexts/sessionStorageContext/index.cjs +1 -1
  89. package/dist/contexts/sessionStorageContext/index.js +1 -1
  90. package/dist/contexts/shopifyUrlContext/index.cjs +1 -1
  91. package/dist/contexts/shopifyUrlContext/index.js +1 -1
  92. package/dist/contexts/systemSettingsContext/index.cjs +3 -3
  93. package/dist/contexts/systemSettingsContext/index.d.cts +2 -2
  94. package/dist/contexts/systemSettingsContext/index.d.ts +4 -4
  95. package/dist/contexts/systemSettingsContext/index.js +3 -3
  96. package/dist/contexts/userIdentityContext/index.cjs +14 -11
  97. package/dist/contexts/userIdentityContext/index.d.ts +1 -1
  98. package/dist/contexts/userIdentityContext/index.js +12 -9
  99. package/dist/{dist-VxRI6eQv.cjs → dist-B7BErEyV.cjs} +1 -1
  100. package/dist/{dist-C38adNK1.js → dist-CtkINi1R.js} +1 -1
  101. package/dist/{enviveConfig-CUJgI97-.js → enviveConfig-Bv94rcOj.js} +2 -2
  102. package/dist/{enviveConfig-CHXb9xwk.cjs → enviveConfig-CA2mgxjq.cjs} +2 -2
  103. package/dist/{enviveConfigContext-C91Air9z.js → enviveConfigContext-DDqnpREh.js} +2 -2
  104. package/dist/{enviveConfigContext-zZAJwv87.cjs → enviveConfigContext-wHEs5vdF.cjs} +2 -2
  105. package/dist/exceptions/index.d.cts +1 -1
  106. package/dist/{featureFlagServiceContext-x-hAAKdL.d.ts → featureFlagServiceContext-C6nTNI_i.d.ts} +1 -1
  107. package/dist/{featureFlagServiceContext-DHtkQAtq.cjs → featureFlagServiceContext-C9RuEQda.cjs} +2 -2
  108. package/dist/{featureFlagServiceContext-Cvp7NlpC.js → featureFlagServiceContext-CqQvJq3j.js} +2 -2
  109. package/dist/{globalSearch-nmrfGLOn.js → globalSearch-B_v9qfCT.js} +1 -1
  110. package/dist/{globalSearch-Cpc8egsM.cjs → globalSearch-OiF96VLG.cjs} +1 -1
  111. package/dist/graphqlConfig-9tU9_Lzt.js +14 -0
  112. package/dist/graphqlConfig-BxnjdY1c.cjs +39 -0
  113. package/dist/{graphqlContext-C3T_K97L.js → graphqlContext--SHxTN8f.js} +3 -3
  114. package/dist/{graphqlContext-DqWvz7Op.cjs → graphqlContext-DHhncOYt.cjs} +3 -3
  115. package/dist/hooks/AmplitudeOperations/index.cjs +10 -20
  116. package/dist/hooks/AmplitudeOperations/index.js +10 -20
  117. package/dist/hooks/AppDetails/index.cjs +10 -18
  118. package/dist/hooks/AppDetails/index.d.cts +1 -1
  119. package/dist/hooks/AppDetails/index.js +10 -18
  120. package/dist/hooks/BlockBackButton/index.d.cts +1 -1
  121. package/dist/hooks/BlockBackButton/index.d.ts +1 -1
  122. package/dist/hooks/CdnOperations/index.cjs +3 -3
  123. package/dist/hooks/CdnOperations/index.js +3 -3
  124. package/dist/hooks/ChatToggle/index.cjs +14 -22
  125. package/dist/hooks/ChatToggle/index.js +14 -22
  126. package/dist/hooks/ChatToggleAnalytics/index.cjs +12 -22
  127. package/dist/hooks/ChatToggleAnalytics/index.d.cts +1 -1
  128. package/dist/hooks/ChatToggleAnalytics/index.js +12 -22
  129. package/dist/hooks/Debounce/index.d.cts +1 -1
  130. package/dist/hooks/ElementObserver/index.d.ts +1 -1
  131. package/dist/hooks/GraphQLConfig/index.cjs +7 -7
  132. package/dist/hooks/GraphQLConfig/index.js +7 -7
  133. package/dist/hooks/IdentifyUser/index.cjs +14 -11
  134. package/dist/hooks/IdentifyUser/index.js +13 -10
  135. package/dist/hooks/ImageResolver/index.cjs +2 -2
  136. package/dist/hooks/ImageResolver/index.js +2 -2
  137. package/dist/hooks/Intersection/index.cjs +1 -1
  138. package/dist/hooks/Intersection/index.d.ts +1 -1
  139. package/dist/hooks/Intersection/index.js +1 -1
  140. package/dist/hooks/IsSmallScreen/index.d.ts +1 -1
  141. package/dist/hooks/LocalStorageOperations/index.cjs +2 -2
  142. package/dist/hooks/LocalStorageOperations/index.d.cts +1 -1
  143. package/dist/hooks/LocalStorageOperations/index.js +2 -2
  144. package/dist/hooks/MessageFilter/index.cjs +1 -1
  145. package/dist/hooks/MessageFilter/index.d.cts +1 -1
  146. package/dist/hooks/MessageFilter/index.js +1 -1
  147. package/dist/hooks/NewOrgConfig/index.cjs +12 -12
  148. package/dist/hooks/NewOrgConfig/index.d.ts +2 -2
  149. package/dist/hooks/NewOrgConfig/index.js +12 -12
  150. package/dist/hooks/Search/index.cjs +22 -29
  151. package/dist/hooks/Search/index.js +21 -28
  152. package/dist/hooks/SearchOperations/index.cjs +13 -20
  153. package/dist/hooks/SearchOperations/index.js +13 -20
  154. package/dist/hooks/SessionStorageOperations/index.cjs +1 -1
  155. package/dist/hooks/SessionStorageOperations/index.js +1 -1
  156. package/dist/hooks/ShopifyUrlOperations/index.cjs +1 -1
  157. package/dist/hooks/ShopifyUrlOperations/index.d.cts +2 -2
  158. package/dist/hooks/ShopifyUrlOperations/index.d.ts +2 -2
  159. package/dist/hooks/ShopifyUrlOperations/index.js +1 -1
  160. package/dist/hooks/SystemSettingsContext/index.cjs +3 -3
  161. package/dist/hooks/SystemSettingsContext/index.d.cts +4 -4
  162. package/dist/hooks/SystemSettingsContext/index.d.ts +4 -4
  163. package/dist/hooks/SystemSettingsContext/index.js +3 -3
  164. package/dist/hooks/TrackComponentVisibleEvent/index.cjs +11 -21
  165. package/dist/hooks/TrackComponentVisibleEvent/index.js +11 -21
  166. package/dist/hooks/UpdateAnalyticsProps/index.cjs +10 -20
  167. package/dist/hooks/UpdateAnalyticsProps/index.d.cts +1 -1
  168. package/dist/hooks/UpdateAnalyticsProps/index.js +10 -20
  169. package/dist/hooks/utils.cjs +1 -1
  170. package/dist/hooks/utils.d.ts +1 -1
  171. package/dist/hooks/utils.js +1 -1
  172. package/dist/index-CMZcE7pk.d.cts +1 -1
  173. package/dist/{index-BiDHHLjr.d.ts → index-ChRMX2kc.d.ts} +2 -2
  174. package/dist/index-ChiZg0yw.d.cts +1 -1
  175. package/dist/{index-dc4j0jws.d.ts → index-CkaLTFlB.d.ts} +1 -1
  176. package/dist/{index-DywcCZdp.d.ts → index-Cl35ht05.d.ts} +1 -1
  177. package/dist/{index-B95cXAA4.d.ts → index-DIq5F_-r.d.ts} +1 -1
  178. package/dist/{index-DZU7c0jP.d.ts → index-DijHU7yp.d.ts} +1 -1
  179. package/dist/{index-CAXM2KiM.d.ts → index-PktRD1En.d.ts} +1 -1
  180. package/dist/index-npqPeJ1g.d.cts +1 -1
  181. package/dist/{index--OKiRCTl.d.ts → index-smzckpKv.d.ts} +1 -1
  182. package/dist/interceptors/index.cjs +1 -1
  183. package/dist/interceptors/index.d.ts +1 -1
  184. package/dist/interceptors/index.js +1 -1
  185. package/dist/{localStorageContext-BFwvuEcf.js → localStorageContext-ByBkX01A.js} +2 -2
  186. package/dist/{localStorageContext-CWc5xJ6U.cjs → localStorageContext-DZeQYK5o.cjs} +2 -2
  187. package/dist/{models-Cw0QcbQv.js → models-DmsMlaHT.js} +2 -2
  188. package/dist/{models-Dl0_Ujgj.cjs → models-wh2gh_Qz.cjs} +2 -2
  189. package/dist/{newOrgConfigAtom-C8h3w_Ji.js → newOrgConfigAtom--tewb_G0.js} +1 -1
  190. package/dist/{newOrgConfigAtom-CDttTiuu.cjs → newOrgConfigAtom-DkSi45_Q.cjs} +1 -1
  191. package/dist/{newOrgConfigContext-D1sgTmVU.cjs → newOrgConfigContext-Bu0aUAaQ.cjs} +5 -5
  192. package/dist/{newOrgConfigContext-B_rJMpwN.js → newOrgConfigContext-DveWXpnn.js} +5 -5
  193. package/dist/{nodeSelector-NqW-FBED.d.ts → nodeSelector-DU-o1I1d.d.ts} +1 -1
  194. package/dist/org-DU3Wck0R.cjs +43 -0
  195. package/dist/org-DptftvB6.js +12 -0
  196. package/dist/orgAnalyticsConfig-9TyGN3XE.js +14 -0
  197. package/dist/orgAnalyticsConfig-C-MmVJI_.cjs +39 -0
  198. package/dist/{search-OWKKaQQj.js → search-Bg9CM7Pr.js} +5 -5
  199. package/dist/{search-CWkDtqQV.cjs → search-dzjbiWgZ.cjs} +5 -5
  200. package/dist/{searchContext-3VsAb17A.cjs → searchContext-DVDxVP6F.cjs} +5 -5
  201. package/dist/{searchContext-Bhhp_q_P.js → searchContext-XLoz5-mf.js} +5 -5
  202. package/dist/{searchServiceAdapter-B0h7psvh.js → searchServiceAdapter-BSPZOg1r.js} +1 -1
  203. package/dist/{searchServiceAdapter-BclWy4fE.cjs → searchServiceAdapter-DrjFCiw8.cjs} +1 -1
  204. package/dist/{sessionStorageContext-kQJRbkHL.js → sessionStorageContext-2YcmPz4e.js} +1 -1
  205. package/dist/{sessionStorageContext-L3f_btsR.cjs → sessionStorageContext-BKniJ7Gn.cjs} +1 -1
  206. package/dist/{shopifyUrlContext-CB9LQU_i.js → shopifyUrlContext-CsQGH9zr.js} +1 -1
  207. package/dist/{shopifyUrlContext-BsYGfLvw.cjs → shopifyUrlContext-D24p48M1.cjs} +1 -1
  208. package/dist/{systemSettingsContext-Cac6mmfA.js → systemSettingsContext-DY64VEFC.js} +2 -2
  209. package/dist/{systemSettingsContext-B5plhu8S.cjs → systemSettingsContext-DgzDCZ3p.cjs} +2 -2
  210. package/dist/types/index.d.ts +1 -1
  211. package/dist/{useAppDetails-BAJjqvyF.cjs → useAppDetails-C-V1pUwN.cjs} +4 -4
  212. package/dist/{useAppDetails-B-lZpIPK.js → useAppDetails-eHiX9MCB.js} +4 -4
  213. package/dist/{useGraphQLConfig-CeYY5maa.js → useGraphQLConfig-DxmjxBCL.js} +2 -2
  214. package/dist/{useGraphQLConfig-Cm_lEb1T.cjs → useGraphQLConfig-h1xSOrvO.cjs} +2 -2
  215. package/dist/{useIntersection-bCSteycU.js → useIntersection-UEO0Cezc.js} +1 -1
  216. package/dist/{useIntersection-DuwPFRY9.cjs → useIntersection-rV0Q8mBH.cjs} +1 -1
  217. package/dist/userIdentityContext-5pH_mMyM.cjs +436 -0
  218. package/dist/userIdentityContext-DjUEecq5.js +418 -0
  219. package/dist/{utils-CqVRbvfN.cjs → utils-BBICrPjW.cjs} +1 -1
  220. package/dist/{utils-DjhLO2vO.d.ts → utils-BLe5oreh.d.ts} +1 -1
  221. package/dist/{utils-DMwh3QbT.js → utils-CxDOv-yL.js} +3 -3
  222. package/dist/{utils-BZT_oZ3n.js → utils-D_kATUj6.js} +1 -1
  223. package/dist/{utils-D3MjNkd3.cjs → utils-DucG4gQ7.cjs} +3 -3
  224. package/dist/{utils-qtHPLFby.cjs → utils-hYTjy7hJ.cjs} +1 -1
  225. package/dist/{utils-DQhbbAnt.js → utils-w4-xONRA.js} +1 -1
  226. package/package.json +1 -1
  227. package/src/atoms/app/index.ts +1 -2
  228. package/src/contexts/userIdentityContext/userIdentityContext.tsx +7 -0
  229. package/dist/app-CGw4C9Bn.js +0 -515
  230. package/dist/app-Di_sBmzj.cjs +0 -570
  231. package/dist/org-BNs_maoW.cjs +0 -111
  232. package/dist/org-CScQqL4k.js +0 -32
  233. /package/dist/{enviveConfigContext-CZPfJkcS.cjs → enviveConfigContext-BNixYqrz.cjs} +0 -0
  234. /package/dist/{enviveConfigContext-Hc1JBLu-.js → enviveConfigContext-ghO3oO9J.js} +0 -0
  235. /package/dist/{featureFlagServiceContext-Csgo-MUv.cjs → featureFlagServiceContext-lsgEUS_a.cjs} +0 -0
  236. /package/dist/{featureFlagServiceContext-CISyb90N.js → featureFlagServiceContext-x0YyrABt.js} +0 -0
@@ -1,570 +0,0 @@
1
- const require_chunk = require('./chunk-CUT6urMc.cjs');
2
- const require_exceptions = require('./exceptions-BjDgLzGi.cjs');
3
- const require_dist = require('./dist-VxRI6eQv.cjs');
4
- const require_models = require('./models-Dl0_Ujgj.cjs');
5
- const require_logger = require('./logger-BqHq67zN.cjs');
6
- const require_utils = require('./utils-D3MjNkd3.cjs');
7
- const require_atomStore = require('./atomStore-CZKe3itM.cjs');
8
- const require_enviveConfig = require('./enviveConfig-CHXb9xwk.cjs');
9
- const require_org = require('./org-BNs_maoW.cjs');
10
- const require_localStorageContext = require('./localStorageContext-CWc5xJ6U.cjs');
11
- let __spiffy_ai_commerce_api_client = require("@spiffy-ai/commerce-api-client");
12
- __spiffy_ai_commerce_api_client = require_chunk.__toESM(__spiffy_ai_commerce_api_client);
13
- let react = require("react");
14
- react = require_chunk.__toESM(react);
15
- let uuid = require("uuid");
16
- uuid = require_chunk.__toESM(uuid);
17
- let jotai = require("jotai");
18
- jotai = require_chunk.__toESM(jotai);
19
- let jotai_utils = require("jotai/utils");
20
- jotai_utils = require_chunk.__toESM(jotai_utils);
21
- let ua_parser_js = require("ua-parser-js");
22
- ua_parser_js = require_chunk.__toESM(ua_parser_js);
23
- let react_jsx_runtime = require("react/jsx-runtime");
24
- react_jsx_runtime = require_chunk.__toESM(react_jsx_runtime);
25
-
26
- //#region src/application/commerce-api.ts
27
- async function errorResponseBody(error) {
28
- try {
29
- return await error.response.json();
30
- } catch {
31
- return {};
32
- }
33
- }
34
- async function throwSessionRestartRequiredIf(errorMsg, error) {
35
- if (!(error instanceof __spiffy_ai_commerce_api_client.ResponseError)) {
36
- require_logger.logger_default.logInfo(errorMsg, error);
37
- throw error;
38
- }
39
- const errorResponse = await errorResponseBody(error);
40
- if (errorResponse?.message?.toLowerCase() === "unsupported product" || errorResponse?.app_code?.toUpperCase() === "PRODUCT_NOT_FOUND") throw new require_exceptions.UnsupportedProductException();
41
- else if (errorResponse?.app_code?.toUpperCase() === "RESTART_SESSION" || errorResponse?.sub_code?.toUpperCase() === "NOT_FOUND") {
42
- require_logger.logger_default.logInfo("Session does not exist. Re-start session", error, error.response, errorResponse);
43
- throw new require_exceptions.SessionRestartRequired();
44
- }
45
- require_logger.logger_default.logInfo(errorMsg, error);
46
- throw error;
47
- }
48
- var CommerceApiClient = class CommerceApiClient {
49
- static {
50
- this.getInstance = () => {
51
- if (!CommerceApiClient.instance) CommerceApiClient.instance = new CommerceApiClient();
52
- return CommerceApiClient.instance;
53
- };
54
- }
55
- constructor(basePath) {
56
- this.suggestionsAbortController = new AbortController();
57
- this.responsesAbortController = new AbortController();
58
- const baseUrl = require_atomStore.getAtomStore().get(require_enviveConfig.baseUrlAtom);
59
- const config = new __spiffy_ai_commerce_api_client.Configuration({
60
- basePath: basePath || baseUrl,
61
- headers: {
62
- "Content-Type": "application/json",
63
- Accept: "application/json"
64
- }
65
- });
66
- this.defaultApi = new __spiffy_ai_commerce_api_client.DefaultApi(config);
67
- this.inferenceApi = new __spiffy_ai_commerce_api_client.InferenceApi(config);
68
- this.customerServiceApi = new __spiffy_ai_commerce_api_client.CustomerServiceApi(config);
69
- }
70
- static {
71
- this.resolveUrl = async (url) => {
72
- const atomStore = require_atomStore.getAtomStore();
73
- const orgShortName = atomStore.get(require_enviveConfig.orgShortNameAtom);
74
- const orgId = atomStore.get(require_org.orgIdAtom);
75
- const userId = atomStore.get(userIdAtom);
76
- const chatId = atomStore.get(chatIdAtom);
77
- const source = atomStore.get(require_enviveConfig.contextSourceAtom);
78
- const env = atomStore.get(require_enviveConfig.envAtom);
79
- const featureFlagService = atomStore.get(require_org.featureFlagServiceAtom);
80
- const context = {
81
- user_id: userId ?? "",
82
- org_id: orgId ?? "",
83
- org_short_name: orgShortName ?? "",
84
- chat_id: chatId ?? "",
85
- source: source ?? __spiffy_ai_commerce_api_client.ContextSourceEnum.App,
86
- env: env ?? __spiffy_ai_commerce_api_client.ContextEnvEnum.Dev
87
- };
88
- const featureGates = featureFlagService?.featureFlagService?.getFeatureFlags() || {};
89
- const urlResolvingRequest = {
90
- url,
91
- context,
92
- feature_gates: featureGates
93
- };
94
- return await (await CommerceApiClient.getInstance().inferenceApi.v1UrlResolvingPostRaw({ UrlResolvingRequest: urlResolvingRequest })).raw.json();
95
- };
96
- }
97
- static {
98
- this.reportSession = async (reportRequest) => {
99
- await CommerceApiClient.getInstance().defaultApi.v1ChatsReportSessionIdPost({ ReportSessionRequest: reportRequest });
100
- };
101
- }
102
- static {
103
- this.getNextResponses = async (payload) => {
104
- try {
105
- return (await CommerceApiClient.getInstance().inferenceApi.v1NextResponsesPost({ NextMessageRequest: require_utils.messageRequestToCommerceMessageRequest(payload) })).map((resp) => require_models.validateResponse(resp)).map((resp) => require_utils.messageFromResponse(resp)).filter((m) => m != null);
106
- } catch (err) {
107
- require_logger.logger_default.logInfo("Failed to get next responses", err, {
108
- payloadContext: payload?.context,
109
- userEvents: payload?.userEvents
110
- });
111
- await throwSessionRestartRequiredIf("Failed to get next responses", err);
112
- return [];
113
- }
114
- };
115
- }
116
- static {
117
- this.getNextResponseStreaming = (payload) => {
118
- async function* generate(inferenceApi, abortController) {
119
- try {
120
- const response = await inferenceApi.v1NextResponsesPostRaw({ NextMessageRequest: require_utils.messageRequestToCommerceMessageRequest(payload) }, { signal: abortController.signal });
121
- if (!response.raw.body) {
122
- require_logger.logger_default.logError("[spiffy-ai] No body in the streamed response", void 0, { response: response.raw });
123
- return;
124
- }
125
- const reader = response.raw.body.getReader();
126
- const decoder = new TextDecoder("utf-8");
127
- let partial = "";
128
- const safeParse = (line) => {
129
- try {
130
- return JSON.parse(line);
131
- } catch (err) {
132
- require_logger.logger_default.logError("[spiffy-ai] Error parsing streamed line", err, {
133
- line,
134
- partial
135
- });
136
- partial = line;
137
- return partial;
138
- }
139
- };
140
- const processChunk = (chunk) => {
141
- return `${partial}${chunk}`.split("\n").map((line) => line.replace(/^data: /, "").trim()).filter((line) => line !== "" && line !== "[DONE]").map(safeParse).filter((v) => v);
142
- };
143
- while (true) {
144
- const { done, value } = await reader.read();
145
- if (done) break;
146
- const chunk = decoder.decode(value);
147
- const parsedLines = processChunk(chunk);
148
- for (const parsedLine of parsedLines) {
149
- const validatedResponse = require_models.validateResponse(parsedLine);
150
- if (validatedResponse) yield validatedResponse;
151
- }
152
- }
153
- } catch (error) {
154
- require_logger.logger_default.logError("[spiffy-ai] Failed to get next streaming responses", error, {
155
- payloadContext: payload?.context,
156
- userEvents: payload?.userEvents
157
- });
158
- await throwSessionRestartRequiredIf("Failed to get next streaming responses", error);
159
- }
160
- }
161
- CommerceApiClient.getInstance().responsesAbortController.abort();
162
- CommerceApiClient.getInstance().responsesAbortController = new AbortController();
163
- return generate(CommerceApiClient.getInstance().inferenceApi, CommerceApiClient.getInstance().responsesAbortController);
164
- };
165
- }
166
- static {
167
- this.getNextSuggestions = async (payload) => {
168
- try {
169
- CommerceApiClient.getInstance().suggestionsAbortController.abort();
170
- CommerceApiClient.getInstance().suggestionsAbortController = new AbortController();
171
- return (await CommerceApiClient.getInstance().inferenceApi.v1NextSuggestionsPost({ NextMessageRequest: require_utils.messageRequestToCommerceMessageRequest(payload) }, { signal: CommerceApiClient.getInstance().suggestionsAbortController.signal })).map((resp) => require_models.validateSuggestion(resp)).filter((suggestion) => suggestion != null);
172
- } catch (error) {
173
- require_logger.logger_default.logInfo("Failed to get suggestions", error, {
174
- payloadContext: payload?.context,
175
- userEvents: payload?.userEvents
176
- });
177
- await throwSessionRestartRequiredIf("Failed to get suggestions", error);
178
- return [];
179
- }
180
- };
181
- }
182
- static {
183
- this.getResponses = async (orgId, chatId, userId) => {
184
- let data = {
185
- responses: [],
186
- suggestions: [],
187
- user_events: []
188
- };
189
- const request = {
190
- org_id: orgId,
191
- chat_id: chatId,
192
- user_id: userId
193
- };
194
- try {
195
- data = await CommerceApiClient.getInstance().defaultApi.v1GetSessionMessages(request);
196
- } catch (error) {
197
- await throwSessionRestartRequiredIf("Failed to get chat responses", error);
198
- }
199
- const responses = data?.responses?.map((turn) => turn.map((response) => require_models.validateResponse(response)).filter((response) => response != null));
200
- const suggestions = data?.suggestions.map((suggestion) => require_models.validateSuggestion(suggestion)).filter((suggestion) => suggestion != null);
201
- const userEvents = data?.user_events.map((event) => require_models.validateUserEvent(event)).filter((event) => event != null);
202
- const formSubmittedUserEventsFormIds = userEvents.filter((event) => event.category === __spiffy_ai_commerce_api_client.UserEventCategory.FormSubmitted).map((event) => event.attributes.formResponseId);
203
- const assistantMessages = responses.map((turn) => turn.filter((response) => !(response.category === __spiffy_ai_commerce_api_client.ResponseCategory.Form && formSubmittedUserEventsFormIds.includes(response.id))).map((response) => require_utils.messageFromResponse(response)).filter((message) => message != null)).filter((turn) => turn.length > 0);
204
- const userMessages = userEvents.map((event) => {
205
- if ([__spiffy_ai_commerce_api_client.UserEventCategory.QueryTyped, __spiffy_ai_commerce_api_client.UserEventCategory.Search].includes(event.category)) return [require_utils.messageFromQueryEvent(event)];
206
- if (event.category === __spiffy_ai_commerce_api_client.UserEventCategory.SuggestionClicked) return [require_utils.messageFromSuggestionEvent(event, suggestions)];
207
- if (event.category === __spiffy_ai_commerce_api_client.UserEventCategory.FormSubmitted) {
208
- const formResponse = responses.flat().find((response) => response.id === event.attributes.formResponseId && event.attributes.formType !== __spiffy_ai_commerce_api_client.FormType.Escalation);
209
- if (formResponse && formResponse.category === __spiffy_ai_commerce_api_client.ResponseCategory.Form) return [require_utils.messageFromFormSubmittedEvent(event, formResponse.attributes)];
210
- }
211
- return [];
212
- }).filter((message) => message.length > 0);
213
- const sortedMessages = [...assistantMessages, ...userMessages].sort((a, b) => new Date(a[0].createdAt).getTime() - new Date(b[0].createdAt).getTime());
214
- return {
215
- responses,
216
- userEvents,
217
- suggestions,
218
- messages: sortedMessages
219
- };
220
- };
221
- }
222
- static {
223
- this.isSupportedEvent = async (payload) => {
224
- try {
225
- const httpResponseText = await (await CommerceApiClient.getInstance().inferenceApi.v1SupportedEventPostRaw({ SupportedEventRequest: require_utils.coreSupportedEventRequestToApiRequest(payload) })).raw.text();
226
- const httpResponseJson = JSON.parse(httpResponseText);
227
- return {
228
- ...httpResponseJson,
229
- numberOfReviews: httpResponseJson.num_of_reviews,
230
- merchant_tags: httpResponseJson.merchant_tags || []
231
- };
232
- } catch (err) {
233
- require_logger.logger_default.logError("Failed to get response for v1SupportedEventPost", { err });
234
- return {
235
- supported: false,
236
- ready: false,
237
- category: void 0,
238
- collections: [],
239
- numberOfReviews: void 0,
240
- top_category: void 0,
241
- merchant_tags: []
242
- };
243
- }
244
- };
245
- }
246
- static {
247
- this.identifyUser = async (spiffyUserId, merchantUserId, uaDetails) => {
248
- try {
249
- await CommerceApiClient.getInstance().defaultApi.v1AnalyticsIdentifyPost({ AnalyticsIdentifyRequest: {
250
- user_id: spiffyUserId,
251
- os_name: uaDetails.os,
252
- os_version: uaDetails.osVersion,
253
- platform: uaDetails.os,
254
- device_id: uaDetails.deviceModel,
255
- device_brand: uaDetails.deviceBrand,
256
- device_manufacturer: uaDetails.deviceManufacturer,
257
- device_model: uaDetails.deviceModel,
258
- user_properties: {
259
- cdp_user_id: merchantUserId,
260
- browser: uaDetails.browser,
261
- browser_version: uaDetails.browserVersion,
262
- user_agent: uaDetails.userAgent
263
- }
264
- } });
265
- } catch (err) {
266
- require_logger.logger_default.logError("Failed to identify user", err);
267
- }
268
- };
269
- }
270
- static {
271
- this.mapContextSourceToV1OrgConfigGetSource = (source) => {
272
- if (source === void 0) return void 0;
273
- switch (source) {
274
- case __spiffy_ai_commerce_api_client.ContextSourceEnum.Fork: return __spiffy_ai_commerce_api_client.V1OrgConfigGetSourceEnum.Fork;
275
- case __spiffy_ai_commerce_api_client.ContextSourceEnum.Playground: return __spiffy_ai_commerce_api_client.V1OrgConfigGetSourceEnum.Playground;
276
- case __spiffy_ai_commerce_api_client.ContextSourceEnum.App: return __spiffy_ai_commerce_api_client.V1OrgConfigGetSourceEnum.App;
277
- case __spiffy_ai_commerce_api_client.ContextSourceEnum.Test: return __spiffy_ai_commerce_api_client.V1OrgConfigGetSourceEnum.Test;
278
- case __spiffy_ai_commerce_api_client.ContextSourceEnum.Eval: return __spiffy_ai_commerce_api_client.V1OrgConfigGetSourceEnum.Test;
279
- default: return source;
280
- }
281
- };
282
- }
283
- static {
284
- this.getOrgConfig = async (user_id) => {
285
- try {
286
- const atomStore = require_atomStore.getAtomStore();
287
- const reactAppName = atomStore.get(require_enviveConfig.reactAppNameAtom);
288
- const contextSource = atomStore.get(require_enviveConfig.contextSourceAtom);
289
- const featureFlagService = atomStore.get(require_org.featureFlagServiceAtom);
290
- const request = {
291
- namespace: reactAppName,
292
- user_id,
293
- source: this.mapContextSourceToV1OrgConfigGetSource(contextSource),
294
- include_experiments: Object.values(require_dist.ProductExperiment),
295
- include_feature_gates: Object.entries(featureFlagService?.featureFlagService?.getFeatureFlags() || {}).filter(([, isEnabled]) => isEnabled).map(([featureGateName]) => featureGateName)
296
- };
297
- const response = await CommerceApiClient.getInstance().defaultApi.v1OrgConfigGet(request);
298
- return require_models.validateOrgConfigResults(response);
299
- } catch (err) {
300
- require_logger.logger_default.logError(`Failed to get org config`, err, { err });
301
- return;
302
- }
303
- };
304
- }
305
- static {
306
- this.addNoteToLatestConversation = async (spiffyUserId, email, customerServiceProvider) => {
307
- require_logger.logger_default.logInfo(`addNoteToLatestConversation - user_id=${spiffyUserId} email=${email} customer_service_provider=${customerServiceProvider}`);
308
- try {
309
- await CommerceApiClient.getInstance().customerServiceApi.v1CustserviceAddNoteToLatestConversationPost({ AddNoteToLatestConversationRequest: {
310
- spiffy_user_id: spiffyUserId,
311
- email,
312
- customer_service_provider: customerServiceProvider
313
- } });
314
- } catch (err) {
315
- require_logger.logger_default.logError("Failed to add note to latest conversation", { err });
316
- }
317
- };
318
- }
319
- static {
320
- this.getCustomerServiceApi = () => CommerceApiClient.getInstance().customerServiceApi;
321
- }
322
- };
323
- var commerce_api_default = CommerceApiClient;
324
-
325
- //#endregion
326
- //#region src/contexts/userIdentityContext/userIdentityContext.tsx
327
- const getUserAgentDetails = () => {
328
- const result = new ua_parser_js.default().getResult();
329
- return {
330
- os: result?.os?.name,
331
- osVersion: result?.os?.version,
332
- deviceBrand: result?.device?.vendor,
333
- deviceManufacturer: result?.device?.vendor,
334
- deviceModel: result?.device?.model,
335
- browser: result?.browser?.name,
336
- browserVersion: result?.browser?.version,
337
- userAgent: result?.ua
338
- };
339
- };
340
- const UserIdentityContext = (0, react.createContext)(void 0);
341
- const UserIdentityProvider = ({ children }) => {
342
- const { getItem, setItem, isAvailable: localStorageIsReady } = require_localStorageContext.useLocalStorage();
343
- const [isReady, setIsReady] = (0, react.useState)(false);
344
- (0, react.useEffect)(() => {
345
- setIsReady(localStorageIsReady);
346
- }, [localStorageIsReady]);
347
- const USER_ID_OVERRIDE_KEY = "v1-spiffy-user-id-override";
348
- const USER_ID_DEFAULT_KEY = "v1-spiffy-user-id-default";
349
- const getUserIdOverrideFromLocalStorage = (0, react.useCallback)(() => getItem(USER_ID_OVERRIDE_KEY) ?? void 0, [getItem]);
350
- const getUserIdDefaultFromLocalStorage = (0, react.useCallback)(() => getItem(USER_ID_DEFAULT_KEY) ?? void 0, [getItem]);
351
- const setUserIdDefaultInLocalStorage = (0, react.useCallback)((userId) => {
352
- require_logger.logger_default.logInfo(`setUserIdDefaultInLocalStorage - Setting user_id=${userId}`);
353
- setItem(USER_ID_DEFAULT_KEY, userId);
354
- return userId;
355
- }, [setItem, USER_ID_DEFAULT_KEY]);
356
- const setUserIdOverrideInLocalStorage = (0, react.useCallback)((userId) => {
357
- require_logger.logger_default.logInfo(`setUserIdOverrideInLocalStorage - Setting user_id=${userId}`);
358
- setItem(USER_ID_OVERRIDE_KEY, userId);
359
- return userId;
360
- }, [setItem, USER_ID_OVERRIDE_KEY]);
361
- const clearUserIdOverrideInLocalStorage = (0, react.useCallback)(() => {
362
- require_logger.logger_default.logInfo(`clearUserIdOverrideInLocalStorage - Clearing user_id`);
363
- setItem(USER_ID_OVERRIDE_KEY, "");
364
- }, [setItem, USER_ID_OVERRIDE_KEY]);
365
- const getUserIdOrDefault = (0, react.useCallback)(() => {
366
- const userIdOverride = getUserIdOverrideFromLocalStorage();
367
- if (userIdOverride) return userIdOverride;
368
- const defaultUserId = getUserIdDefaultFromLocalStorage();
369
- if (defaultUserId) return defaultUserId;
370
- return setUserIdDefaultInLocalStorage(`spiffy-user-id-${(0, uuid.v4)()}`);
371
- }, [
372
- getUserIdOverrideFromLocalStorage,
373
- getUserIdDefaultFromLocalStorage,
374
- setUserIdDefaultInLocalStorage
375
- ]);
376
- const identifyUser = (0, react.useCallback)(async () => {
377
- if (!isReady) {
378
- require_logger.logger_default.logWarn("[UserIdentityContext] Context not ready, skipping identifyUser", void 0);
379
- return;
380
- }
381
- try {
382
- const cdpUserId = "UNKNOWN_CDP_USER_ID";
383
- const userId = getUserIdOrDefault();
384
- const userAgentDetails = getUserAgentDetails();
385
- await commerce_api_default.identifyUser(userId, cdpUserId, userAgentDetails);
386
- } catch (error) {
387
- require_logger.logger_default.logError("[spiffy-ai] Error identifying user", error);
388
- }
389
- }, [isReady, getUserIdOrDefault]);
390
- const value = (0, react.useMemo)(() => ({
391
- identifyUser,
392
- getUserIdOrDefault,
393
- getUserIdOverrideFromLocalStorage,
394
- getUserIdDefaultFromLocalStorage,
395
- setUserIdDefaultInLocalStorage,
396
- setUserIdOverrideInLocalStorage,
397
- clearUserIdOverrideInLocalStorage,
398
- isReady
399
- }), [
400
- identifyUser,
401
- getUserIdOrDefault,
402
- getUserIdOverrideFromLocalStorage,
403
- getUserIdDefaultFromLocalStorage,
404
- setUserIdDefaultInLocalStorage,
405
- setUserIdOverrideInLocalStorage,
406
- clearUserIdOverrideInLocalStorage,
407
- isReady
408
- ]);
409
- return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(UserIdentityContext.Provider, {
410
- value,
411
- children
412
- });
413
- };
414
- const useUserIdentity = () => {
415
- const context = (0, react.useContext)(UserIdentityContext);
416
- if (!context) throw new Error("useUserIdentity must be used within a UserIdentityProvider");
417
- return context;
418
- };
419
-
420
- //#endregion
421
- //#region src/atoms/app/variant.ts
422
- const internalStorageUrlResolverAtom = (0, jotai_utils.atomWithStorage)("spiffy-url-resolver", void 0, require_atomStore.sessionStorageUtil, { getOnInit: true });
423
- const urlResolverAtom = (0, jotai.atom)((get) => {
424
- const maybeUrlResolver = get(internalStorageUrlResolverAtom);
425
- if (maybeUrlResolver == null) return {};
426
- return JSON.parse(maybeUrlResolver);
427
- }, (get, set, value) => {
428
- const newCache = {
429
- ...get(urlResolverAtom),
430
- [value.url]: value.response
431
- };
432
- set(internalStorageUrlResolverAtom, JSON.stringify(newCache));
433
- });
434
- const internalStorageSupportedEventAtom = (0, jotai_utils.atomWithStorage)("spiffy-supported-event", void 0, require_atomStore.sessionStorageUtil, { getOnInit: true });
435
- const internalSupportedEventAtom = (0, jotai.atom)(void 0);
436
- const supportedEventAtom = (0, jotai.atom)((get) => {
437
- const maybeSupportedEvent = get(internalStorageSupportedEventAtom);
438
- if (maybeSupportedEvent == null) return;
439
- return JSON.parse(maybeSupportedEvent);
440
- }, (_, set, value) => {
441
- if (value == null) {
442
- set(internalStorageSupportedEventAtom, void 0);
443
- set(internalSupportedEventAtom, void 0);
444
- return;
445
- }
446
- set(internalSupportedEventAtom, value);
447
- set(internalStorageSupportedEventAtom, JSON.stringify(value));
448
- });
449
- const internalVariantIdAtom = (0, jotai.atom)();
450
- const internalProductIdAtom = (0, jotai.atom)();
451
- const internalParentProductIdAtom = (0, jotai.atom)();
452
- const internalProductUrlAtom = (0, jotai.atom)();
453
- const internalPlpIdAtom = (0, jotai.atom)();
454
- const internalUrlAtom = (0, jotai.atom)();
455
- const internalPageVisitCategoryAtom = (0, jotai.atom)();
456
- const internalVariantAtom = (0, jotai.atom)("pdp");
457
- const variantIdAtom = (0, jotai.atom)((get) => get(internalVariantIdAtom));
458
- const productIdAtom = (0, jotai.atom)((get) => get(internalProductIdAtom));
459
- const parentProductIdAtom = (0, jotai.atom)((get) => get(internalParentProductIdAtom));
460
- const productUrlAtom = (0, jotai.atom)((get) => get(internalProductUrlAtom));
461
- const plpIdAtom = (0, jotai.atom)((get) => get(internalPlpIdAtom));
462
- const urlAtom = (0, jotai.atom)((get) => get(internalUrlAtom));
463
- const pageVisitCategoryAtom = (0, jotai.atom)((get) => get(internalPageVisitCategoryAtom));
464
- const variantAtom = (0, jotai.atom)((get) => get(internalVariantAtom));
465
- const hasParsedVariantInfoAtom = (0, jotai.atom)(false);
466
- const variantInfoAtom = (0, jotai.atom)((get) => {
467
- const variant = get(variantAtom);
468
- if (variant === require_dist.VariantTypeEnum.Pdp) return {
469
- variantId: get(variantIdAtom),
470
- variant,
471
- productId: get(productIdAtom),
472
- parentProductId: get(parentProductIdAtom),
473
- url: get(urlAtom)
474
- };
475
- if (variant === require_dist.VariantTypeEnum.Plp) return {
476
- variantId: get(variantIdAtom),
477
- variant,
478
- plpId: get(plpIdAtom),
479
- url: get(urlAtom)
480
- };
481
- if (variant === require_dist.VariantTypeEnum.PageVisit) return {
482
- variantId: get(variantIdAtom),
483
- variant,
484
- url: get(urlAtom),
485
- pageVisitCategory: get(pageVisitCategoryAtom)
486
- };
487
- throw new Error("Invalid variantInfo details");
488
- }, (_, set, newVariant) => {
489
- set(internalVariantAtom, newVariant.variant);
490
- set(internalVariantIdAtom, newVariant.variantId);
491
- if (newVariant.variant === require_dist.VariantTypeEnum.Pdp) {
492
- set(internalProductIdAtom, newVariant.productId);
493
- set(internalParentProductIdAtom, newVariant.parentProductId);
494
- set(internalUrlAtom, newVariant.url);
495
- }
496
- if (newVariant.variant === require_dist.VariantTypeEnum.Plp) {
497
- set(internalPlpIdAtom, newVariant.plpId);
498
- set(internalUrlAtom, newVariant.url);
499
- }
500
- if (newVariant.variant === require_dist.VariantTypeEnum.PageVisit) {
501
- set(internalUrlAtom, newVariant.url);
502
- set(internalPageVisitCategoryAtom, newVariant.pageVisitCategory);
503
- }
504
- });
505
-
506
- //#endregion
507
- //#region src/atoms/app/index.ts
508
- const internalUserIdAtom = (0, jotai.atom)(void 0);
509
- const userIdAtom = (0, jotai.atom)((get) => {
510
- const maybeUserId = get(internalUserIdAtom);
511
- if (maybeUserId) return maybeUserId;
512
- const { getUserIdOrDefault } = useUserIdentity();
513
- return getUserIdOrDefault();
514
- }, (_, set, value) => {
515
- set(internalUserIdAtom, value);
516
- });
517
- const userIdentityAtom = (0, jotai.atom)(void 0);
518
- const appSourceAtom = (0, jotai.atom)((get) => get(require_enviveConfig.contextSourceAtom) ?? __spiffy_ai_commerce_api_client.ContextSourceEnum.App);
519
- const chatIdAtom = (0, jotai_utils.atomWithStorage)("v1-spiffy-chat-session-id", (0, uuid.v4)(), void 0, { getOnInit: true });
520
-
521
- //#endregion
522
- Object.defineProperty(exports, 'UserIdentityProvider', {
523
- enumerable: true,
524
- get: function () {
525
- return UserIdentityProvider;
526
- }
527
- });
528
- Object.defineProperty(exports, 'appSourceAtom', {
529
- enumerable: true,
530
- get: function () {
531
- return appSourceAtom;
532
- }
533
- });
534
- Object.defineProperty(exports, 'chatIdAtom', {
535
- enumerable: true,
536
- get: function () {
537
- return chatIdAtom;
538
- }
539
- });
540
- Object.defineProperty(exports, 'hasParsedVariantInfoAtom', {
541
- enumerable: true,
542
- get: function () {
543
- return hasParsedVariantInfoAtom;
544
- }
545
- });
546
- Object.defineProperty(exports, 'useUserIdentity', {
547
- enumerable: true,
548
- get: function () {
549
- return useUserIdentity;
550
- }
551
- });
552
- Object.defineProperty(exports, 'userIdAtom', {
553
- enumerable: true,
554
- get: function () {
555
- return userIdAtom;
556
- }
557
- });
558
- Object.defineProperty(exports, 'userIdentityAtom', {
559
- enumerable: true,
560
- get: function () {
561
- return userIdentityAtom;
562
- }
563
- });
564
- Object.defineProperty(exports, 'variantInfoAtom', {
565
- enumerable: true,
566
- get: function () {
567
- return variantInfoAtom;
568
- }
569
- });
570
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"app-Di_sBmzj.cjs","names":["ResponseError","UnsupportedProductException","SessionRestartRequired","getAtomStore","baseUrlAtom","config: Configuration","Configuration","DefaultApi","InferenceApi","CustomerServiceApi","orgShortNameAtom","orgIdAtom","contextSourceAtom","envAtom","featureFlagServiceAtom","context: Context","ContextSourceEnum","ContextEnvEnum","messageRequestToCommerceMessageRequest","validateResponse","messageFromResponse","err: unknown","error: unknown","validateSuggestion","data: V1GetSessionMessages200Response","responses: ApiResponse[][]","suggestions: Suggestion[]","userEvents: UserEvent[]","validateUserEvent","UserEventCategory","assistantMessages: Message[][]","ResponseCategory","userMessages: Message[][]","messageFromQueryEvent","messageFromSuggestionEvent","FormType","messageFromFormSubmittedEvent","coreSupportedEventRequestToApiRequest","V1OrgConfigGetSourceEnum","reactAppNameAtom","request: V1OrgConfigGetRequest","ProductExperiment","validateOrgConfigResults","UAParser","UserIdentityProvider: React.FC<{ children: React.ReactNode }>","useLocalStorage","CommerceApiClient","sessionStorageUtil","VariantTypeEnum","contextSourceAtom","ContextSourceEnum"],"sources":["../src/application/commerce-api.ts","../src/contexts/userIdentityContext/userIdentityContext.tsx","../src/atoms/app/variant.ts","../src/atoms/app/index.ts"],"sourcesContent":["import {\n  Context,\n  ContextEnvEnum,\n  Configuration,\n  CustomerServiceApi,\n  DefaultApi,\n  InferenceApi,\n  ReportSessionRequest,\n  ResponseError,\n  UserEventCategory,\n  V1GetSessionMessages200Response,\n  V1OrgConfigGetRequest,\n  ContextSourceEnum,\n  V1OrgConfigGetSourceEnum,\n  CustomerServiceProvider,\n  ResponseCategory,\n  FormType,\n} from \"@spiffy-ai/commerce-api-client\";\nimport {\n  SupportedEvent,\n  ProductExperiment,\n  ClientDetails,\n  UserEvent,\n  NextMessageRequest,\n  SupportedEventRequest,\n  OrgConfig,\n} from \"@envive-ai/types\";\nimport { ApiResponse, Message, Suggestion } from \"src/types\";\nimport { userIdAtom, chatIdAtom } from \"src/atoms/app\";\nimport { getAtomStore } from \"src/atoms/atomStore\";\nimport {\n  baseUrlAtom,\n  orgShortNameAtom,\n  contextSourceAtom,\n  envAtom,\n  reactAppNameAtom,\n} from \"src/atoms/envive/enviveConfig\";\nimport { orgIdAtom, featureFlagServiceAtom } from \"src/atoms/org\";\nimport {\n  UnsupportedProductException,\n  SessionRestartRequired,\n} from \"src/exceptions\";\nimport Logger from \"./logging/logger\";\nimport {\n  validateResponse,\n  validateSuggestion,\n  validateUserEvent,\n  validateOrgConfigResults,\n} from \"./models\";\nimport {\n  messageRequestToCommerceMessageRequest,\n  messageFromResponse,\n  messageFromQueryEvent,\n  messageFromSuggestionEvent,\n  messageFromFormSubmittedEvent,\n  coreSupportedEventRequestToApiRequest,\n} from \"./utils\";\n\nasync function errorResponseBody(error: ResponseError) {\n  try {\n    return await error.response.json();\n  } catch {\n    return {};\n  }\n}\n\nasync function throwSessionRestartRequiredIf(errorMsg: string, error: unknown) {\n  if (!(error instanceof ResponseError)) {\n    Logger.logInfo(errorMsg, error);\n    throw error;\n  }\n\n  const errorResponse = await errorResponseBody(error);\n  if (\n    errorResponse?.message?.toLowerCase() === \"unsupported product\" || // for backward compatibility. newer versions of the API return sub_code instead of message\n    errorResponse?.app_code?.toUpperCase() === \"PRODUCT_NOT_FOUND\"\n  ) {\n    throw new UnsupportedProductException();\n  } else if (\n    errorResponse?.app_code?.toUpperCase() === \"RESTART_SESSION\" ||\n    errorResponse?.sub_code?.toUpperCase() === \"NOT_FOUND\" // for backward compatibility. new API responses will contain \"app_code\"\n  ) {\n    Logger.logInfo(\n      \"Session does not exist. Re-start session\",\n      error,\n      error.response,\n      errorResponse\n    );\n    throw new SessionRestartRequired();\n  }\n\n  Logger.logInfo(errorMsg, error);\n  throw error;\n}\n\nclass CommerceApiClient {\n  private readonly defaultApi: DefaultApi;\n\n  private readonly customerServiceApi: CustomerServiceApi;\n\n  private readonly inferenceApi: InferenceApi;\n\n  private static instance: CommerceApiClient | undefined;\n\n  private suggestionsAbortController = new AbortController();\n\n  private responsesAbortController = new AbortController();\n\n  private static getInstance = (): CommerceApiClient => {\n    if (!CommerceApiClient.instance) {\n      CommerceApiClient.instance = new CommerceApiClient();\n    }\n\n    return CommerceApiClient.instance;\n  };\n\n  private constructor(basePath?: string) {\n    const atomStore = getAtomStore();\n    const baseUrl = atomStore.get(baseUrlAtom);\n    const path = basePath || baseUrl;\n    // API Key is now handled at the EnviveConfigProvider level\n    const config: Configuration = new Configuration({\n      basePath: path,\n      headers: {\n        \"Content-Type\": \"application/json\",\n        Accept: \"application/json\",\n      },\n    });\n    this.defaultApi = new DefaultApi(config);\n    this.inferenceApi = new InferenceApi(config);\n    this.customerServiceApi = new CustomerServiceApi(config);\n  }\n\n  static resolveUrl = async (url: string) => {\n    const atomStore = getAtomStore();\n    const orgShortName = atomStore.get(orgShortNameAtom);\n    const orgId = atomStore.get(orgIdAtom);\n    const userId = atomStore.get(userIdAtom);\n    const chatId = atomStore.get(chatIdAtom);\n    const source = atomStore.get(contextSourceAtom);\n    const env = atomStore.get(envAtom);\n\n    const featureFlagService = atomStore.get(featureFlagServiceAtom);\n\n    const context: Context = {\n      user_id: userId ?? \"\",\n      org_id: orgId ?? \"\",\n      org_short_name: orgShortName ?? \"\",\n      chat_id: chatId ?? \"\",\n      source: source ?? ContextSourceEnum.App,\n      env: (env as ContextEnvEnum) ?? ContextEnvEnum.Dev, // Cast env to ContextEnvEnum\n    };\n\n    const featureGates =\n      featureFlagService?.featureFlagService?.getFeatureFlags() || {};\n    const urlResolvingRequest = {\n      url,\n      context,\n      feature_gates: featureGates,\n    };\n\n    const rawResponse =\n      await CommerceApiClient.getInstance().inferenceApi.v1UrlResolvingPostRaw({\n        UrlResolvingRequest: urlResolvingRequest,\n      });\n\n    const responseBody = await rawResponse.raw.json();\n\n    return responseBody;\n  };\n\n  static reportSession = async (\n    reportRequest: ReportSessionRequest\n  ): Promise<void> => {\n    await CommerceApiClient.getInstance().defaultApi.v1ChatsReportSessionIdPost(\n      {\n        ReportSessionRequest: reportRequest,\n      }\n    );\n  };\n\n  static getNextResponses = async (\n    payload: NextMessageRequest\n  ): Promise<Message[]> => {\n    try {\n      const response =\n        await CommerceApiClient.getInstance().inferenceApi.v1NextResponsesPost({\n          NextMessageRequest: messageRequestToCommerceMessageRequest(payload),\n        });\n      const messages = response\n        .map((resp) => validateResponse(resp))\n        .map((resp) => messageFromResponse(resp));\n\n      return messages.filter((m): m is Message => m != null);\n    } catch (err: unknown) {\n      Logger.logInfo(\"Failed to get next responses\", err, {\n        payloadContext: payload?.context,\n        userEvents: payload?.userEvents,\n      });\n      await throwSessionRestartRequiredIf(\"Failed to get next responses\", err);\n      return [];\n    }\n  };\n\n  static getNextResponseStreaming = (\n    payload: NextMessageRequest\n  ): AsyncGenerator<ApiResponse, void, unknown> => {\n    async function* generate(\n      inferenceApi: InferenceApi,\n      abortController: AbortController\n    ) {\n      // make sure streaming is enabled\n      try {\n        const response = await inferenceApi.v1NextResponsesPostRaw(\n          {\n            NextMessageRequest: messageRequestToCommerceMessageRequest(payload),\n          },\n          { signal: abortController.signal }\n        );\n\n        // Read the response as a stream of data\n        if (!response.raw.body) {\n          Logger.logError(\n            \"[spiffy-ai] No body in the streamed response\",\n            undefined,\n            {\n              response: response.raw,\n            }\n          );\n          return;\n        }\n\n        const reader = response.raw.body.getReader();\n        const decoder = new TextDecoder(\"utf-8\");\n\n        let partial = \"\";\n        // TODO this function is recreated every time new data comes from the stream - define it outside of the generator\n        const safeParse = (line: string): unknown => {\n          try {\n            return JSON.parse(line); // Parse the JSON string\n          } catch (err) {\n            Logger.logError(\"[spiffy-ai] Error parsing streamed line\", err, {\n              line,\n              partial,\n            });\n            // swallow the error and set the partial to our current chunk\n            partial = line;\n            return partial;\n          }\n        };\n\n        // TODO this function is recreated every time new data comes from the stream - define it outside of the generator\n        const processChunk = (chunk: string): unknown[] => {\n          // merge the partial with the incoming chunk\n          const lines = `${partial}${chunk}`.split(\"\\n\");\n\n          const parsedLines = lines\n            .map((line) => line.replace(/^data: /, \"\").trim()) // Remove the \"data: \" prefix\n            .filter((line) => line !== \"\" && line !== \"[DONE]\") // Remove empty lines and \"[DONE]\"\n            .map(safeParse)\n            .filter((v) => v); // and filter out the undefined values\n          return parsedLines;\n        };\n\n        while (true) {\n          // eslint-disable-next-line no-await-in-loop\n          const { done, value } = await reader.read();\n\n          if (done) {\n            break;\n          }\n\n          // Massage and parse the chunk of data\n          const chunk = decoder.decode(value);\n          const parsedLines = processChunk(chunk);\n\n          for (const parsedLine of parsedLines) {\n            const validatedResponse = validateResponse(parsedLine);\n\n            if (validatedResponse) {\n              yield validatedResponse;\n            }\n          }\n        }\n      } catch (error: unknown) {\n        Logger.logError(\n          \"[spiffy-ai] Failed to get next streaming responses\",\n          error,\n          {\n            payloadContext: payload?.context,\n            userEvents: payload?.userEvents,\n          }\n        );\n        await throwSessionRestartRequiredIf(\n          \"Failed to get next streaming responses\",\n          error\n        );\n      }\n    }\n\n    CommerceApiClient.getInstance().responsesAbortController.abort();\n    CommerceApiClient.getInstance().responsesAbortController =\n      new AbortController();\n\n    return generate(\n      CommerceApiClient.getInstance().inferenceApi,\n      CommerceApiClient.getInstance().responsesAbortController\n    );\n  };\n\n  static getNextSuggestions = async (\n    payload: NextMessageRequest\n  ): Promise<Suggestion[]> => {\n    try {\n      CommerceApiClient.getInstance().suggestionsAbortController.abort();\n      CommerceApiClient.getInstance().suggestionsAbortController =\n        new AbortController();\n\n      const response =\n        await CommerceApiClient.getInstance().inferenceApi.v1NextSuggestionsPost(\n          {\n            NextMessageRequest: messageRequestToCommerceMessageRequest(payload),\n          },\n          {\n            signal:\n              CommerceApiClient.getInstance().suggestionsAbortController.signal,\n          }\n        );\n\n      const suggestions = response\n        .map((resp) => validateSuggestion(resp))\n        .filter((suggestion): suggestion is Suggestion => suggestion != null);\n\n      return suggestions;\n    } catch (error: unknown) {\n      Logger.logInfo(\"Failed to get suggestions\", error, {\n        payloadContext: payload?.context,\n        userEvents: payload?.userEvents,\n      });\n\n      await throwSessionRestartRequiredIf(\"Failed to get suggestions\", error);\n      return [];\n    }\n  };\n\n  /**\n   * Fetches the existing chat data for a given session and transforms them to reconstruct the chat history.\n   *\n   * @param orgId The organization Id\n   * @param chatId The existing chat Id\n   * @param userId The user Id\n   *\n   * @returns A list of messages that were exchanged in the chat, throws an error if the chat session has expired.\n   */\n  static getResponses = async (\n    orgId: string,\n    chatId: string,\n    userId: string\n  ): Promise<{\n    responses: ApiResponse[][];\n    userEvents: UserEvent[];\n    suggestions: Suggestion[];\n    messages: Message[][];\n  }> => {\n    let data: V1GetSessionMessages200Response = {\n      responses: [],\n      suggestions: [],\n      user_events: [],\n    };\n    const request = {\n      org_id: orgId,\n      chat_id: chatId,\n      user_id: userId,\n    };\n    try {\n      data =\n        await CommerceApiClient.getInstance().defaultApi.v1GetSessionMessages(\n          request\n        );\n    } catch (error: unknown) {\n      await throwSessionRestartRequiredIf(\n        \"Failed to get chat responses\",\n        error\n      );\n    }\n\n    const responses: ApiResponse[][] = data?.responses?.map((turn) =>\n      turn\n        .map((response) => validateResponse(response))\n        .filter((response): response is ApiResponse => response != null)\n    );\n\n    const suggestions: Suggestion[] = data?.suggestions\n      .map((suggestion) => validateSuggestion(suggestion))\n      .filter((suggestion): suggestion is Suggestion => suggestion != null);\n\n    const userEvents: UserEvent[] = data?.user_events\n      .map((event) => validateUserEvent(event))\n      .filter((event): event is UserEvent => event != null);\n\n    // if a form has already been submitted, don't show it in the chat history\n    const formSubmittedUserEventsFormIds = userEvents\n      .filter((event) => event.category === UserEventCategory.FormSubmitted)\n      .map((event) => event.attributes.formResponseId);\n\n    const assistantMessages: Message[][] = responses\n      .map((turn) =>\n        turn\n          .filter(\n            (response) =>\n              !(\n                response.category === ResponseCategory.Form &&\n                formSubmittedUserEventsFormIds.includes(response.id)\n              )\n          )\n          .map((response) => messageFromResponse(response))\n          .filter((message): message is Message => message != null)\n      )\n      .filter((turn) => turn.length > 0);\n\n    const userMessages: Message[][] = userEvents\n      .map((event) => {\n        if (\n          [UserEventCategory.QueryTyped, UserEventCategory.Search].includes(\n            event.category\n          )\n        ) {\n          return [messageFromQueryEvent(event)];\n        }\n\n        if (event.category === UserEventCategory.SuggestionClicked) {\n          return [messageFromSuggestionEvent(event, suggestions)];\n        }\n\n        if (event.category === UserEventCategory.FormSubmitted) {\n          const formResponse = responses\n            .flat()\n            .find(\n              (response) =>\n                response.id === event.attributes.formResponseId &&\n                event.attributes.formType !== FormType.Escalation\n            );\n\n          if (formResponse && formResponse.category === ResponseCategory.Form) {\n            return [\n              messageFromFormSubmittedEvent(event, formResponse.attributes),\n            ];\n          }\n        }\n\n        return [];\n      })\n      .filter((message): message is Message[] => message.length > 0);\n\n    // Sort the messages chronologically to reconstruct the chat history\n    const sortedMessages = [...assistantMessages, ...userMessages].sort(\n      (a, b) =>\n        new Date(a[0].createdAt).getTime() - new Date(b[0].createdAt).getTime()\n    );\n\n    return { responses, userEvents, suggestions, messages: sortedMessages };\n  };\n\n  /**\n   *\n   * @param payload\n   * @returns\n   */\n  static isSupportedEvent = async (\n    payload: SupportedEventRequest\n  ): Promise<SupportedEvent> => {\n    try {\n      const rawResponse =\n        await CommerceApiClient.getInstance().inferenceApi.v1SupportedEventPostRaw(\n          {\n            SupportedEventRequest:\n              coreSupportedEventRequestToApiRequest(payload),\n          }\n        );\n\n      // Get the actual HTTP response JSON\n      const httpResponseText = await rawResponse.raw.text();\n      const httpResponseJson = JSON.parse(httpResponseText);\n\n      return {\n        ...httpResponseJson,\n        numberOfReviews: httpResponseJson.num_of_reviews,\n        merchant_tags: httpResponseJson.merchant_tags || [],\n      };\n    } catch (err) {\n      Logger.logError(\"Failed to get response for v1SupportedEventPost\", {\n        err,\n      });\n      return {\n        supported: false,\n        ready: false,\n        category: undefined,\n        collections: [],\n        numberOfReviews: undefined,\n        top_category: undefined,\n        merchant_tags: [],\n      };\n    }\n  };\n\n  static identifyUser = async (\n    spiffyUserId: string,\n    merchantUserId: string,\n    uaDetails: ClientDetails\n  ): Promise<void> => {\n    try {\n      await CommerceApiClient.getInstance().defaultApi.v1AnalyticsIdentifyPost({\n        AnalyticsIdentifyRequest: {\n          user_id: spiffyUserId,\n          os_name: uaDetails.os,\n          os_version: uaDetails.osVersion,\n          platform: uaDetails.os,\n          device_id: uaDetails.deviceModel,\n          device_brand: uaDetails.deviceBrand,\n          device_manufacturer: uaDetails.deviceManufacturer,\n          device_model: uaDetails.deviceModel,\n          user_properties: {\n            cdp_user_id: merchantUserId,\n            browser: uaDetails.browser,\n            browser_version: uaDetails.browserVersion,\n            user_agent: uaDetails.userAgent,\n          },\n        },\n      });\n    } catch (err) {\n      Logger.logError(\"Failed to identify user\", err);\n    }\n  };\n\n  private static mapContextSourceToV1OrgConfigGetSource = (\n    source: ContextSourceEnum | undefined\n  ): V1OrgConfigGetSourceEnum | undefined => {\n    if (source === undefined) return undefined;\n    switch (source) {\n      case ContextSourceEnum.Fork:\n        return V1OrgConfigGetSourceEnum.Fork;\n      case ContextSourceEnum.Playground:\n        return V1OrgConfigGetSourceEnum.Playground;\n      case ContextSourceEnum.App:\n        return V1OrgConfigGetSourceEnum.App;\n      case ContextSourceEnum.Test:\n        return V1OrgConfigGetSourceEnum.Test;\n      case ContextSourceEnum.Eval:\n        return V1OrgConfigGetSourceEnum.Test;\n      default: {\n        // This ensures that if new values are added to ContextSourceEnum, we catch it\n        const exhaustiveCheck: never = source;\n        return exhaustiveCheck;\n      }\n    }\n  };\n\n  static getOrgConfig = async (\n    user_id: string\n  ): Promise<OrgConfig | undefined> => {\n    try {\n      const atomStore = getAtomStore();\n      const reactAppName = atomStore.get(reactAppNameAtom);\n      const contextSource = atomStore.get(contextSourceAtom);\n      const featureFlagService = atomStore.get(featureFlagServiceAtom); // Get featureFlagService\n      const request: V1OrgConfigGetRequest = {\n        namespace: reactAppName,\n        user_id,\n        source: this.mapContextSourceToV1OrgConfigGetSource(contextSource),\n        include_experiments: Object.values(ProductExperiment),\n        include_feature_gates: Object.entries(\n          featureFlagService?.featureFlagService?.getFeatureFlags() || {}\n        )\n          .filter(([, isEnabled]) => isEnabled)\n          .map(([featureGateName]) => featureGateName), // Use featureFlagService\n      };\n      const response =\n        await CommerceApiClient.getInstance().defaultApi.v1OrgConfigGet(\n          request\n        );\n\n      return validateOrgConfigResults(response);\n    } catch (err) {\n      Logger.logError(`Failed to get org config`, err, { err });\n      return undefined;\n    }\n  };\n\n  static addNoteToLatestConversation = async (\n    spiffyUserId: string,\n    email: string,\n    customerServiceProvider: CustomerServiceProvider\n  ) => {\n    Logger.logInfo(\n      `addNoteToLatestConversation - user_id=${spiffyUserId} email=${email} customer_service_provider=${customerServiceProvider}`\n    );\n    try {\n      await CommerceApiClient.getInstance().customerServiceApi.v1CustserviceAddNoteToLatestConversationPost(\n        {\n          AddNoteToLatestConversationRequest: {\n            spiffy_user_id: spiffyUserId,\n            email,\n            customer_service_provider: customerServiceProvider,\n          },\n        }\n      );\n    } catch (err) {\n      Logger.logError(\"Failed to add note to latest conversation\", { err });\n    }\n  };\n\n  static getCustomerServiceApi = () =>\n    CommerceApiClient.getInstance().customerServiceApi;\n}\n\nexport default CommerceApiClient;\n","import React, { createContext, useCallback, useContext, useMemo, useState, useEffect } from 'react';\nimport UAParser from 'ua-parser-js';\nimport { ClientDetails, UserIdentityContextType } from '@envive-ai/types';\nimport Logger from '../../application/logging/logger';\nimport CommerceApiClient from '../../application/commerce-api';\nimport { useLocalStorage } from '../localStorageContext';\nimport { v4 as uuid } from 'uuid';\n\n// Helper function from the original service\nconst getUserAgentDetails = (): ClientDetails => {\n  const uaParser = new UAParser();\n  const result = uaParser.getResult();\n\n  return {\n    os: result?.os?.name,\n    osVersion: result?.os?.version,\n    deviceBrand: result?.device?.vendor,\n    deviceManufacturer: result?.device?.vendor,\n    deviceModel: result?.device?.model,\n    browser: result?.browser?.name,\n    browserVersion: result?.browser?.version,\n    userAgent: result?.ua,\n  };\n};\n\nconst UserIdentityContext = createContext<UserIdentityContextType | undefined>(undefined);\n\nexport const UserIdentityProvider: React.FC<{ children: React.ReactNode }> = ({ children }) => {\n  const { getItem, setItem, isAvailable: localStorageIsReady } = useLocalStorage();\n\n  const [isReady, setIsReady] = useState(false);\n\n  useEffect(() => {\n    // Assuming CommerceApiClient and other dependencies are ready if localStorage is.\n    // In a more complex scenario, you might have more checks here.\n    setIsReady(localStorageIsReady);\n  }, [localStorageIsReady]);\n\n  const USER_ID_OVERRIDE_KEY = 'v1-spiffy-user-id-override';\n  const USER_ID_DEFAULT_KEY = 'v1-spiffy-user-id-default';\n\n  const getUserIdOverrideFromLocalStorage = useCallback(\n    (): string | undefined => getItem(USER_ID_OVERRIDE_KEY) ?? undefined,\n    [getItem],\n  );\n\n  const getUserIdDefaultFromLocalStorage = useCallback(\n    (): string | undefined => getItem(USER_ID_DEFAULT_KEY) ?? undefined,\n    [getItem],\n  );\n\n  const setUserIdDefaultInLocalStorage = useCallback(\n    (userId: string): string => {\n      Logger.logInfo(`setUserIdDefaultInLocalStorage - Setting user_id=${userId}`);\n      setItem(USER_ID_DEFAULT_KEY, userId);\n      // window.dispatchEvent is handled by useLocalStorage now\n      return userId;\n    },\n    [setItem, USER_ID_DEFAULT_KEY],\n  );\n\n  const setUserIdOverrideInLocalStorage = useCallback(\n    (userId: string): string => {\n      Logger.logInfo(`setUserIdOverrideInLocalStorage - Setting user_id=${userId}`);\n      setItem(USER_ID_OVERRIDE_KEY, userId);\n      // window.dispatchEvent is handled by useLocalStorage now\n      return userId;\n    },\n    [setItem, USER_ID_OVERRIDE_KEY],\n  );\n\n  const clearUserIdOverrideInLocalStorage = useCallback(() => {\n    Logger.logInfo(`clearUserIdOverrideInLocalStorage - Clearing user_id`);\n    // LocalStorageService.getLocalStorage()?.removeItem(USER_ID_OVERRIDE_KEY);\n    // window.dispatchEvent is handled by useLocalStorage now\n    setItem(USER_ID_OVERRIDE_KEY, ''); // Set to empty string to clear\n  }, [setItem, USER_ID_OVERRIDE_KEY]);\n\n  const getUserIdOrDefault = useCallback((): string => {\n    const userIdOverride = getUserIdOverrideFromLocalStorage();\n    if (userIdOverride) {\n      return userIdOverride;\n    }\n\n    const defaultUserId = getUserIdDefaultFromLocalStorage();\n    if (defaultUserId) {\n      return defaultUserId;\n    }\n\n    return setUserIdDefaultInLocalStorage(`spiffy-user-id-${uuid()}`);\n  }, [\n    getUserIdOverrideFromLocalStorage,\n    getUserIdDefaultFromLocalStorage,\n    setUserIdDefaultInLocalStorage,\n  ]);\n\n  const identifyUser = useCallback(async (): Promise<void> => {\n    if (!isReady) {\n      Logger.logWarn('[UserIdentityContext] Context not ready, skipping identifyUser', undefined);\n      return;\n    }\n\n    try {\n      // Temporarily commented out until WindowDataLayerService is resolved\n      // const cdpUserId = WindowDataLayerService.getGoogleAnalyticsClientId();\n      const cdpUserId = 'UNKNOWN_CDP_USER_ID'; // Placeholder\n      const userId = getUserIdOrDefault();\n      const userAgentDetails = getUserAgentDetails();\n\n      if (!cdpUserId) {\n        Logger.logWarn('[spiffy-ai] No GA Client ID found, skipping identifyUser', undefined);\n        return;\n      }\n\n      await CommerceApiClient.identifyUser(userId, cdpUserId, userAgentDetails);\n    } catch (error) {\n      Logger.logError('[spiffy-ai] Error identifying user', error);\n    }\n  }, [isReady, getUserIdOrDefault]);\n\n  const value = useMemo(\n    () => ({\n      identifyUser,\n      getUserIdOrDefault,\n      getUserIdOverrideFromLocalStorage,\n      getUserIdDefaultFromLocalStorage,\n      setUserIdDefaultInLocalStorage,\n      setUserIdOverrideInLocalStorage,\n      clearUserIdOverrideInLocalStorage,\n      isReady,\n    }),\n    [\n      identifyUser,\n      getUserIdOrDefault,\n      getUserIdOverrideFromLocalStorage,\n      getUserIdDefaultFromLocalStorage,\n      setUserIdDefaultInLocalStorage,\n      setUserIdOverrideInLocalStorage,\n      clearUserIdOverrideInLocalStorage,\n      isReady,\n    ],\n  );\n\n  return <UserIdentityContext.Provider value={value}>{children}</UserIdentityContext.Provider>;\n};\n\nexport const useUserIdentity = () => {\n  const context = useContext(UserIdentityContext);\n  if (!context) {\n    throw new Error('useUserIdentity must be used within a UserIdentityProvider');\n  }\n  return context;\n};\n","import { atomWithStorage } from 'jotai/utils';\nimport { atom } from 'jotai';\nimport { SupportedEventResponse, PageVisitCategory } from '@spiffy-ai/commerce-api-client';\nimport {\n  PageVisitVariantInfo,\n  PDPVariantInfo,\n  PLPVariantInfo,\n  VariantInfo,\n  VariantTypeEnum,\n} from '@envive-ai/types';\nimport { sessionStorageUtil } from 'src/atoms/atomStore';\n\nexport interface SupportedEvent\n  extends Pick<\n    SupportedEventResponse,\n    'supported' | 'ready' | 'category' | 'collections' | 'top_category'\n  > {\n  numberOfReviews: number | undefined;\n  merchant_tags?: string[];\n}\n\ninterface PDPAttributes {\n  product_id?: string;\n}\n\ninterface PLPAttributes {\n  attributes?: {\n    id?: string;\n  };\n}\n\nexport interface UrlResolvingPDPConfig {\n  pdp_attributes: PDPAttributes;\n  number_of_reviews?: number;\n  collections?: string[];\n  merchant_tags?: string[];\n}\n\nexport interface UrlResolvingPLPConfig {\n  plp_attributes: PLPAttributes;\n  top_category?: string;\n}\n\ninterface UrlResolvingGenericConfig {\n  details?: string;\n}\n\nexport type PageVariantCheckConfig = {\n  check_type: string;\n  feature_gate?: string;\n  extractor?: {\n    type: string;\n    map?: Record<string, string[]>;\n    value?: string;\n  };\n  product_id_extractor?: string;\n  product_ids?: string[];\n  plp_id_extractor?: string;\n  plp_ids?: string[];\n  collections?: string[];\n  query_param?: string;\n  category?: string;\n  top_category?: string[];\n  review_minimum?: number;\n  merchant_tags?: string[];\n};\n\nexport type BackendWidgetMountingConfig = {\n  mounting_config_id: string;\n  widget_config_id?: string;\n  mounting_point_widgets?: Array<{\n    checks: PageVariantCheckConfig[];\n    widget_config_id: string;\n  }>;\n};\n\nexport type BackendPageVariantConfig = {\n  variant_id: string;\n  variant_type: string;\n  variant_checks: PageVariantCheckConfig[];\n  widget_mounting: BackendWidgetMountingConfig[];\n  plp_id_extractor?: string;\n  product_id_extractor?: string;\n  parent_product_id_extractor?: string;\n};\n\nexport interface UrlResolverResponse {\n  variant_type: string;\n  specific_details: UrlResolvingPDPConfig | UrlResolvingPLPConfig | UrlResolvingGenericConfig;\n  ready: boolean;\n  user_event?: {\n    event_id?: string;\n    attributes?: PDPAttributes | PLPAttributes;\n    category?: string;\n    created_at?: string;\n  };\n  page_variant?: BackendPageVariantConfig;\n}\n\n// Use a map for per-URL cache\nexport type UrlResolverCache = Record<string, UrlResolverResponse | undefined>;\n\nconst internalStorageUrlResolverAtom = atomWithStorage<string | undefined>(\n  'spiffy-url-resolver',\n  undefined,\n  sessionStorageUtil,\n  {\n    getOnInit: true,\n  },\n);\n\nexport const urlResolverAtom = atom(\n  (get): UrlResolverCache => {\n    const maybeUrlResolver = get(internalStorageUrlResolverAtom);\n    if (maybeUrlResolver == null) {\n      return {};\n    }\n    return JSON.parse(maybeUrlResolver);\n  },\n  (get, set, value: { url: string; response: UrlResolverResponse | undefined }) => {\n    // Get current cache from storage\n    const currentCache = get(urlResolverAtom);\n    const newCache = { ...currentCache, [value.url]: value.response };\n\n    set(internalStorageUrlResolverAtom, JSON.stringify(newCache));\n  },\n);\n\nconst internalStorageSupportedEventAtom = atomWithStorage<string | undefined>(\n  'spiffy-supported-event',\n  undefined,\n  sessionStorageUtil,\n  {\n    getOnInit: true,\n  },\n);\nconst internalSupportedEventAtom = atom<SupportedEvent | undefined>(undefined);\n\nexport const supportedEventAtom = atom(\n  (get): SupportedEvent | undefined => {\n    const maybeSupportedEvent = get(internalStorageSupportedEventAtom);\n    if (maybeSupportedEvent == null) {\n      return undefined;\n    }\n\n    // TODO this is an unvalidated parse. It may be better to implement a custom storage util\n    // and perform the object validation on \"get\" there.\n    return JSON.parse(maybeSupportedEvent);\n  },\n  (_, set, value: SupportedEvent | undefined) => {\n    if (value == null) {\n      set(internalStorageSupportedEventAtom, undefined);\n      set(internalSupportedEventAtom, undefined);\n      return;\n    }\n\n    set(internalSupportedEventAtom, value);\n    set(internalStorageSupportedEventAtom, JSON.stringify(value));\n  },\n);\n\nconst internalVariantIdAtom = atom<string>();\nconst internalProductIdAtom = atom<string>();\nconst internalParentProductIdAtom = atom<string>();\nconst internalProductUrlAtom = atom<string>();\nconst internalPlpIdAtom = atom<string>();\nconst internalUrlAtom = atom<string>();\nconst internalPageVisitCategoryAtom = atom<PageVisitCategory>();\nconst internalVariantAtom = atom<'pdp' | 'plp' | 'search' | 'page_visit'>('pdp');\n\nexport const variantIdAtom = atom((get) => get(internalVariantIdAtom));\nexport const productIdAtom = atom((get) => get(internalProductIdAtom));\nexport const parentProductIdAtom = atom((get) => get(internalParentProductIdAtom));\nexport const productUrlAtom = atom((get) => get(internalProductUrlAtom));\nexport const plpIdAtom = atom((get) => get(internalPlpIdAtom));\nexport const urlAtom = atom((get) => get(internalUrlAtom));\nexport const pageVisitCategoryAtom = atom((get) => get(internalPageVisitCategoryAtom));\nexport const variantAtom = atom((get) => get(internalVariantAtom));\nexport const hasParsedVariantInfoAtom = atom(false);\n\nexport const variantInfoAtom = atom(\n  (get): VariantInfo => {\n    const variant = get(variantAtom);\n    if (variant === VariantTypeEnum.Pdp) {\n      return {\n        variantId: get(variantIdAtom),\n        variant,\n        productId: get(productIdAtom),\n        parentProductId: get(parentProductIdAtom),\n        url: get(urlAtom),\n      } as PDPVariantInfo;\n    }\n    if (variant === VariantTypeEnum.Plp) {\n      return {\n        variantId: get(variantIdAtom),\n        variant,\n        plpId: get(plpIdAtom),\n        url: get(urlAtom),\n      } as PLPVariantInfo;\n    }\n    if (variant === VariantTypeEnum.PageVisit) {\n      return {\n        variantId: get(variantIdAtom),\n        variant,\n        url: get(urlAtom),\n        pageVisitCategory: get(pageVisitCategoryAtom),\n      } as PageVisitVariantInfo;\n    }\n    throw new Error('Invalid variantInfo details');\n  },\n  (_, set, newVariant: VariantInfo) => {\n    set(internalVariantAtom, newVariant.variant);\n    set(internalVariantIdAtom, newVariant.variantId);\n    if (newVariant.variant === VariantTypeEnum.Pdp) {\n      set(internalProductIdAtom, newVariant.productId);\n      set(internalParentProductIdAtom, newVariant.parentProductId);\n      set(internalUrlAtom, newVariant.url);\n    }\n    if (newVariant.variant === VariantTypeEnum.Plp) {\n      set(internalPlpIdAtom, newVariant.plpId);\n      set(internalUrlAtom, newVariant.url);\n    }\n    if (newVariant.variant === VariantTypeEnum.PageVisit) {\n      set(internalUrlAtom, newVariant.url);\n      set(internalPageVisitCategoryAtom, newVariant.pageVisitCategory);\n    }\n  },\n);\n","import { ContextEnvEnum, ContextSourceEnum } from '@spiffy-ai/commerce-api-client';\nimport { atom } from 'jotai';\nimport { atomWithStorage } from 'jotai/utils';\nimport { VariantInfo, UserIdentityContextType } from '@envive-ai/types';\nimport { useUserIdentity } from 'src/contexts/userIdentityContext/userIdentityContext';\nimport { variantInfoAtom } from 'src/atoms/app/variant';\nimport { v4 as uuid } from 'uuid';\nimport { contextSourceAtom } from '../envive/enviveConfig';\n\nexport interface AppDetails {\n  orgId: string;\n  orgShortName: string;\n  chatId: string;\n  userId: string;\n  source: ContextSourceEnum;\n  env: ContextEnvEnum;\n  variantInfo: VariantInfo;\n}\n\nexport { variantInfoAtom } from './variant';\n\nconst internalUserIdAtom = atom<string | undefined>(undefined);\n\nexport const userIdAtom = atom(\n  (get) => {\n    const maybeUserId = get(internalUserIdAtom);\n\n    if (maybeUserId) {\n      return maybeUserId;\n    }\n\n    const { getUserIdOrDefault } = useUserIdentity();\n    return getUserIdOrDefault();\n  },\n  (_, set, value: string | undefined) => {\n    set(internalUserIdAtom, value);\n  },\n);\n\nexport const userIdentityAtom = atom<UserIdentityContextType | undefined>(undefined);\n\nexport const appSourceAtom = atom<ContextSourceEnum>(\n  (get): ContextSourceEnum => get(contextSourceAtom) ?? ContextSourceEnum.App,\n);\nexport const chatIdAtom = atomWithStorage<string>('v1-spiffy-chat-session-id', uuid(), undefined, {\n  getOnInit: true,\n});\n"],"mappings":"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"}