@envive-ai/react-hooks 0.2.6 → 0.2.7-arthur-2

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 (377) hide show
  1. package/dist/{NewOrgConfig-BfrGpiGk.js → NewOrgConfig-BVByiYPp.js} +2 -2
  2. package/dist/{NewOrgConfig-BxSuoP9C.cjs → NewOrgConfig-CInGtTV6.cjs} +2 -2
  3. package/dist/{SystemSettingsContext-Bkoiobdv.cjs → SystemSettingsContext-150LTxIk.cjs} +2 -2
  4. package/dist/{SystemSettingsContext-B8X_Dvw2.js → SystemSettingsContext-ei5B0dxO.js} +2 -2
  5. package/dist/{TrackComponentVisibleEvent-DMuX-byo.cjs → TrackComponentVisibleEvent-C7-nnBks.cjs} +2 -2
  6. package/dist/{TrackComponentVisibleEvent-DwfGqNTx.js → TrackComponentVisibleEvent-CuwSLbug.js} +2 -2
  7. package/dist/amplitudeContext-BBQ1ATA3.js +265 -0
  8. package/dist/amplitudeContext-BItT9HmT.js +1 -0
  9. package/dist/amplitudeContext-C-0-DDk3.cjs +287 -0
  10. package/dist/{amplitudeContext-B73xamNe.d.cts → amplitudeContext-CCVyp5RU.d.cts} +1 -1
  11. package/dist/amplitudeContext-DPtyVv3Q.cjs +0 -0
  12. package/dist/{amplitudeContext-CiO9T9c-.d.ts → amplitudeContext-DcRur97Z.d.ts} +1 -1
  13. package/dist/{api-bHEYmSiT.js → api-BWSsazAG.js} +3 -3
  14. package/dist/{api-BvygKEiX.cjs → api-DeW6rHj3.cjs} +3 -3
  15. package/dist/{app-Aqkm_SlS.js → app-C_Y-57U5.js} +3 -4
  16. package/dist/{app-BQw_-JGl.cjs → app-XEFPotoH.cjs} +3 -4
  17. package/dist/application/models/graphql/index.cjs +4 -3
  18. package/dist/application/models/graphql/index.d.cts +2 -2
  19. package/dist/application/models/graphql/index.d.ts +2 -2
  20. package/dist/application/models/graphql/index.js +3 -3
  21. package/dist/application/models/guards/api/index.cjs +3 -3
  22. package/dist/application/models/guards/api/index.d.cts +2 -1
  23. package/dist/application/models/guards/api/index.d.ts +2 -1
  24. package/dist/application/models/guards/api/index.js +3 -3
  25. package/dist/application/models/guards/utils.cjs +1 -1
  26. package/dist/application/models/guards/utils.d.cts +1 -1
  27. package/dist/application/models/guards/utils.d.ts +1 -1
  28. package/dist/application/models/guards/utils.js +1 -1
  29. package/dist/application/models/index.cjs +9 -9
  30. package/dist/application/models/index.d.cts +11 -10
  31. package/dist/application/models/index.d.ts +11 -10
  32. package/dist/application/models/index.js +8 -8
  33. package/dist/application/models/variantInfo/index.d.cts +1 -1
  34. package/dist/application/models/variantInfo/index.d.ts +1 -1
  35. package/dist/application/utils/index.cjs +17 -17
  36. package/dist/application/utils/index.d.cts +16 -15
  37. package/dist/application/utils/index.d.ts +16 -15
  38. package/dist/application/utils/index.js +17 -17
  39. package/dist/{atomStore-CmZbgQHc.cjs → atomStore-8ppNkJ_n.cjs} +1 -1
  40. package/dist/{atomStore-DEcDhiLp.js → atomStore-BLYJ2ZoQ.js} +1 -1
  41. package/dist/atoms/app/index.cjs +12 -12
  42. package/dist/atoms/app/index.d.cts +19 -18
  43. package/dist/atoms/app/index.d.ts +14 -13
  44. package/dist/atoms/app/index.js +12 -12
  45. package/dist/atoms/atomStore/index.cjs +1 -1
  46. package/dist/atoms/atomStore/index.js +1 -1
  47. package/dist/atoms/chat/index.cjs +18 -18
  48. package/dist/atoms/chat/index.d.cts +39 -38
  49. package/dist/atoms/chat/index.d.ts +13 -12
  50. package/dist/atoms/chat/index.js +18 -18
  51. package/dist/atoms/globalSearch/index.d.cts +5 -5
  52. package/dist/atoms/org/index.cjs +1 -1
  53. package/dist/atoms/org/index.d.cts +30 -29
  54. package/dist/atoms/org/index.d.ts +30 -29
  55. package/dist/atoms/org/index.js +1 -1
  56. package/dist/atoms/search/index.cjs +20 -20
  57. package/dist/atoms/search/index.d.cts +13 -12
  58. package/dist/atoms/search/index.d.ts +13 -12
  59. package/dist/atoms/search/index.js +20 -20
  60. package/dist/atoms/search/types.d.cts +4 -2
  61. package/dist/atoms/search/types.d.ts +4 -2
  62. package/dist/{cdnContext-Cd0Kvt6g.cjs → cdnContext-Bzqk0s2M.cjs} +2 -2
  63. package/dist/{cdnContext-D8pHA9gh.js → cdnContext-CTC-zBtx.js} +2 -2
  64. package/dist/{chat-U1IgKNij.js → chat-Bzay7QnI.js} +9 -9
  65. package/dist/{chat-DwNALtox.cjs → chat-Ckd1b_z_.cjs} +14 -8
  66. package/dist/{chat-EJbfGWRr.js → chat-ClvJ9xEj.js} +1 -1
  67. package/dist/{chat-CJ9D8n7g.cjs → chat-DCGriB7h.cjs} +1 -1
  68. package/dist/{chatElementDisplayLocation-DWmfNX_u.d.cts → chatElementDisplayLocation-B7vr33eG.d.cts} +1 -1
  69. package/dist/{chatElementDisplayLocation-DbmdwAff.d.ts → chatElementDisplayLocation-D4XF0UfI.d.ts} +1 -1
  70. package/dist/{chatSearch-DtE2cUQw.cjs → chatSearch-Bev4ZI8Z.cjs} +4 -4
  71. package/dist/{chatSearch-Bb2SMr9X.js → chatSearch-DNaGtQyx.js} +4 -4
  72. package/dist/{chatState-BXBN-12W.js → chatState-CcCvgmSM.js} +3 -3
  73. package/dist/{chatState-B3Dyrd9M.cjs → chatState-OkYPVghN.cjs} +3 -3
  74. package/dist/{commerce-api-DXbnMNT8.js → commerce-api-ml5fkEuk.js} +9 -8
  75. package/dist/{commerce-api-Dx02FCQ7.cjs → commerce-api-sQtLuwTh.cjs} +9 -8
  76. package/dist/{common-CuwWqIJ1.cjs → common-DQPvV_S_.cjs} +1 -1
  77. package/dist/{common-Df2bwzd2.js → common-c_4eX0qn.js} +1 -1
  78. package/dist/{components-QGCWJ26c.js → components-CDpaMUjK.js} +1 -1
  79. package/dist/{components-BCfFLf9X.cjs → components-DKwVHIjq.cjs} +1 -1
  80. package/dist/config/index.cjs +4 -4
  81. package/dist/config/index.d.cts +4 -4
  82. package/dist/config/index.d.ts +4 -4
  83. package/dist/config/index.js +4 -4
  84. package/dist/config/locators/components/chat/index.cjs +1 -1
  85. package/dist/config/locators/components/chat/index.d.cts +1 -1
  86. package/dist/config/locators/components/chat/index.d.ts +1 -1
  87. package/dist/config/locators/components/chat/index.js +1 -1
  88. package/dist/config/locators/components/common/index.cjs +1 -1
  89. package/dist/config/locators/components/common/index.d.cts +1 -1
  90. package/dist/config/locators/components/common/index.d.ts +1 -1
  91. package/dist/config/locators/components/common/index.js +1 -1
  92. package/dist/config/locators/components/index.cjs +1 -1
  93. package/dist/config/locators/components/index.d.cts +1 -1
  94. package/dist/config/locators/components/index.d.ts +1 -1
  95. package/dist/config/locators/components/index.js +1 -1
  96. package/dist/config/locators/index.cjs +4 -4
  97. package/dist/config/locators/index.d.cts +4 -4
  98. package/dist/config/locators/index.d.ts +4 -4
  99. package/dist/config/locators/index.js +4 -4
  100. package/dist/contexts/amplitudeContext/index.cjs +17 -16
  101. package/dist/contexts/amplitudeContext/index.d.cts +1 -1
  102. package/dist/contexts/amplitudeContext/index.d.ts +1 -1
  103. package/dist/contexts/amplitudeContext/index.js +17 -16
  104. package/dist/contexts/cdnContext/index.cjs +4 -4
  105. package/dist/contexts/cdnContext/index.js +4 -4
  106. package/dist/contexts/chatContext/index.cjs +25 -25
  107. package/dist/contexts/chatContext/index.d.cts +2 -2
  108. package/dist/contexts/chatContext/index.d.ts +2 -2
  109. package/dist/contexts/chatContext/index.js +25 -25
  110. package/dist/contexts/enviveConfigContext/index.cjs +4 -4
  111. package/dist/contexts/enviveConfigContext/index.d.cts +3 -3
  112. package/dist/contexts/enviveConfigContext/index.d.ts +3 -3
  113. package/dist/contexts/enviveConfigContext/index.js +4 -4
  114. package/dist/contexts/enviveCssContext/index.cjs +15 -15
  115. package/dist/contexts/enviveCssContext/index.js +15 -15
  116. package/dist/contexts/featureFlagContext/index.cjs +6 -6
  117. package/dist/contexts/featureFlagContext/index.d.cts +3 -3
  118. package/dist/contexts/featureFlagContext/index.d.ts +3 -3
  119. package/dist/contexts/featureFlagContext/index.js +6 -6
  120. package/dist/contexts/featureFlagServiceContext/index.cjs +3 -3
  121. package/dist/contexts/featureFlagServiceContext/index.d.cts +4 -4
  122. package/dist/contexts/featureFlagServiceContext/index.d.ts +4 -4
  123. package/dist/contexts/featureFlagServiceContext/index.js +3 -3
  124. package/dist/contexts/graphqlContext/index.cjs +11 -11
  125. package/dist/contexts/graphqlContext/index.d.cts +13 -12
  126. package/dist/contexts/graphqlContext/index.d.ts +13 -12
  127. package/dist/contexts/graphqlContext/index.js +11 -11
  128. package/dist/contexts/localStorageContext/index.cjs +2 -2
  129. package/dist/contexts/localStorageContext/index.js +2 -2
  130. package/dist/contexts/newOrgConfigContext/index.cjs +14 -14
  131. package/dist/contexts/newOrgConfigContext/index.d.cts +14 -13
  132. package/dist/contexts/newOrgConfigContext/index.d.ts +14 -13
  133. package/dist/contexts/newOrgConfigContext/index.js +14 -14
  134. package/dist/contexts/searchContext/index.cjs +18 -18
  135. package/dist/contexts/searchContext/index.d.cts +1 -1
  136. package/dist/contexts/searchContext/index.d.ts +1 -1
  137. package/dist/contexts/searchContext/index.js +18 -18
  138. package/dist/contexts/sessionStorageContext/index.cjs +2 -2
  139. package/dist/contexts/sessionStorageContext/index.js +2 -2
  140. package/dist/contexts/shopifyUrlContext/index.cjs +2 -2
  141. package/dist/contexts/shopifyUrlContext/index.d.cts +3 -3
  142. package/dist/contexts/shopifyUrlContext/index.d.ts +3 -3
  143. package/dist/contexts/shopifyUrlContext/index.js +2 -2
  144. package/dist/contexts/systemSettingsContext/index.cjs +4 -4
  145. package/dist/contexts/systemSettingsContext/index.d.cts +16 -15
  146. package/dist/contexts/systemSettingsContext/index.d.ts +16 -15
  147. package/dist/contexts/systemSettingsContext/index.js +4 -4
  148. package/dist/contexts/types.cjs +1 -1
  149. package/dist/contexts/types.d.cts +3 -3
  150. package/dist/contexts/types.d.ts +3 -3
  151. package/dist/contexts/types.js +1 -1
  152. package/dist/contexts/userIdentityContext/index.cjs +20 -20
  153. package/dist/contexts/userIdentityContext/index.d.cts +1 -1
  154. package/dist/contexts/userIdentityContext/index.d.ts +1 -1
  155. package/dist/contexts/userIdentityContext/index.js +20 -20
  156. package/dist/{enviveConfig-BlIkxiAF.js → enviveConfig-DV8F12B9.js} +3 -3
  157. package/dist/{enviveConfig-B42OJ8bK.cjs → enviveConfig-DZHdtLsQ.cjs} +3 -3
  158. package/dist/{enviveConfigContext-1_EivtCa.js → enviveConfigContext-BS7aNop5.js} +3 -3
  159. package/dist/{enviveConfigContext-Y1ahEAMe.cjs → enviveConfigContext-CTcHUIFP.cjs} +3 -3
  160. package/dist/{featureFlagServiceContext-D3Ge8GH5.cjs → featureFlagServiceContext-CJyYItqu.cjs} +3 -3
  161. package/dist/{featureFlagServiceContext-C5U0bshi.d.ts → featureFlagServiceContext-CpxlOkI9.d.ts} +2 -2
  162. package/dist/{featureFlagServiceContext-CAPrb4e_.js → featureFlagServiceContext-FBM6DdMJ.js} +3 -3
  163. package/dist/{featureFlagServiceContext-CiKWV306.d.cts → featureFlagServiceContext-p5UBwPM3.d.cts} +2 -2
  164. package/dist/{featureGates-D4Me_IZH.js → featureGates-KEwAL8p_.js} +1 -1
  165. package/dist/{featureGates-Bt_Y3kZ7.cjs → featureGates-qU_ulhpC.cjs} +1 -1
  166. package/dist/{frontendConfig-BiD1-j48.d.ts → frontendConfig-Cawh5iqv.d.ts} +6 -3
  167. package/dist/{frontendConfig-tVg0hsWZ.d.cts → frontendConfig-iZipB5FG.d.cts} +6 -3
  168. package/dist/graphql-CkxgqsXP.js +48 -0
  169. package/dist/graphql-i3dtpVTl.cjs +71 -0
  170. package/dist/{graphqlContext-Bf3E-V2T.d.cts → graphqlContext-BeyKU1Dr.d.cts} +2 -2
  171. package/dist/{graphqlContext-CpwAvnro.cjs → graphqlContext-CVbYIftg.cjs} +6 -6
  172. package/dist/{graphqlContext-CDeKzb46.d.ts → graphqlContext-DgkS-UX1.d.ts} +4 -4
  173. package/dist/{graphqlContext-dyWNSWNv.js → graphqlContext-DouNZbYo.js} +5 -5
  174. package/dist/hooks/AmplitudeOperations/index.cjs +18 -18
  175. package/dist/hooks/AmplitudeOperations/index.d.cts +1 -1
  176. package/dist/hooks/AmplitudeOperations/index.d.ts +1 -1
  177. package/dist/hooks/AmplitudeOperations/index.js +18 -18
  178. package/dist/hooks/AppDetails/index.cjs +15 -15
  179. package/dist/hooks/AppDetails/index.d.cts +12 -11
  180. package/dist/hooks/AppDetails/index.d.ts +12 -11
  181. package/dist/hooks/AppDetails/index.js +15 -15
  182. package/dist/hooks/CdnOperations/index.cjs +4 -4
  183. package/dist/hooks/CdnOperations/index.js +4 -4
  184. package/dist/hooks/ChatToggle/index.cjs +18 -18
  185. package/dist/hooks/ChatToggle/index.d.cts +1 -1
  186. package/dist/hooks/ChatToggle/index.d.ts +1 -1
  187. package/dist/hooks/ChatToggle/index.js +18 -18
  188. package/dist/hooks/ChatToggleAnalytics/index.cjs +19 -19
  189. package/dist/hooks/ChatToggleAnalytics/index.d.cts +1 -1
  190. package/dist/hooks/ChatToggleAnalytics/index.d.ts +1 -1
  191. package/dist/hooks/ChatToggleAnalytics/index.js +19 -19
  192. package/dist/hooks/CustomerSupportHandoff/index.cjs +1 -1
  193. package/dist/hooks/CustomerSupportHandoff/index.js +1 -1
  194. package/dist/hooks/Debounce/index.cjs +20 -2
  195. package/dist/hooks/Debounce/index.js +18 -2
  196. package/dist/hooks/ElementObserver/index.d.cts +1 -1
  197. package/dist/hooks/ElementObserver/index.d.ts +1 -1
  198. package/dist/hooks/GrabAndScroll/index.d.ts +2 -2
  199. package/dist/hooks/GraphQLConfig/index.cjs +12 -12
  200. package/dist/hooks/GraphQLConfig/index.d.cts +13 -12
  201. package/dist/hooks/GraphQLConfig/index.d.ts +13 -12
  202. package/dist/hooks/GraphQLConfig/index.js +12 -12
  203. package/dist/hooks/IdentifyUser/index.cjs +20 -20
  204. package/dist/hooks/IdentifyUser/index.js +20 -20
  205. package/dist/hooks/ImageResolver/index.cjs +10 -10
  206. package/dist/hooks/ImageResolver/index.js +10 -10
  207. package/dist/hooks/LocalStorageOperations/index.cjs +2 -2
  208. package/dist/hooks/LocalStorageOperations/index.js +2 -2
  209. package/dist/hooks/MessageFilter/index.cjs +8 -8
  210. package/dist/hooks/MessageFilter/index.d.cts +12 -11
  211. package/dist/hooks/MessageFilter/index.d.ts +12 -11
  212. package/dist/hooks/MessageFilter/index.js +8 -8
  213. package/dist/hooks/NewOrgConfig/index.cjs +15 -15
  214. package/dist/hooks/NewOrgConfig/index.d.cts +14 -13
  215. package/dist/hooks/NewOrgConfig/index.d.ts +14 -13
  216. package/dist/hooks/NewOrgConfig/index.js +15 -15
  217. package/dist/hooks/Search/index.cjs +323 -152
  218. package/dist/hooks/Search/index.d.cts +21 -17
  219. package/dist/hooks/Search/index.d.ts +21 -17
  220. package/dist/hooks/Search/index.js +323 -153
  221. package/dist/hooks/SearchOperations/index.cjs +18 -18
  222. package/dist/hooks/SearchOperations/index.d.cts +1 -1
  223. package/dist/hooks/SearchOperations/index.d.ts +1 -1
  224. package/dist/hooks/SearchOperations/index.js +18 -18
  225. package/dist/hooks/SessionStorageOperations/index.cjs +2 -2
  226. package/dist/hooks/SessionStorageOperations/index.js +2 -2
  227. package/dist/hooks/ShopifyUrlOperations/index.cjs +2 -2
  228. package/dist/hooks/ShopifyUrlOperations/index.d.cts +5 -5
  229. package/dist/hooks/ShopifyUrlOperations/index.d.ts +5 -5
  230. package/dist/hooks/ShopifyUrlOperations/index.js +2 -2
  231. package/dist/hooks/SystemSettingsContext/index.cjs +5 -5
  232. package/dist/hooks/SystemSettingsContext/index.d.cts +12 -11
  233. package/dist/hooks/SystemSettingsContext/index.d.ts +14 -13
  234. package/dist/hooks/SystemSettingsContext/index.js +5 -5
  235. package/dist/hooks/TrackComponentVisibleEvent/index.cjs +17 -17
  236. package/dist/hooks/TrackComponentVisibleEvent/index.d.cts +2 -2
  237. package/dist/hooks/TrackComponentVisibleEvent/index.d.ts +2 -2
  238. package/dist/hooks/TrackComponentVisibleEvent/index.js +17 -17
  239. package/dist/hooks/UpdateAnalyticsProps/index.cjs +16 -16
  240. package/dist/hooks/UpdateAnalyticsProps/index.js +16 -16
  241. package/dist/hooks/utils.d.cts +12 -11
  242. package/dist/hooks/utils.d.ts +12 -11
  243. package/dist/{index-B6xpW8RG.d.ts → index--9_c4tze.d.ts} +1 -1
  244. package/dist/index-BEpDGqnz.d.cts +41 -0
  245. package/dist/{index-D31m6bPU.d.ts → index-BKvFVPUX.d.ts} +1 -1
  246. package/dist/{index-VwfWqyR_.d.ts → index-BNHIIgYk.d.ts} +1 -1
  247. package/dist/index-BUDrAxnl.d.ts +673 -0
  248. package/dist/{index-DzbkQtaK.d.cts → index-CCboEuTO.d.cts} +1 -1
  249. package/dist/{index-wFHfdr6p.d.ts → index-CMJM-3zV.d.ts} +5 -5
  250. package/dist/{index-FQjyuD3D.d.cts → index-COXkY78t.d.cts} +1 -1
  251. package/dist/{index--uHjE7L8.d.ts → index-D7htGSQC.d.ts} +1 -1
  252. package/dist/index-DM_5fh8c.d.ts +101 -0
  253. package/dist/index-DU7uw0ba.d.cts +101 -0
  254. package/dist/{index-Da1s8h5C.d.cts → index-DZtnHhlr.d.cts} +1 -1
  255. package/dist/{index-Bq39XSmY.d.cts → index-DpJzjjpi.d.cts} +34 -34
  256. package/dist/{index-DSRs6N6J.d.ts → index-Dtw-hJdt.d.ts} +1 -1
  257. package/dist/index-Dy3TTIOm.d.cts +673 -0
  258. package/dist/index-ErVcwUnR.d.ts +41 -0
  259. package/dist/{index-Cyq5HiC0.d.cts → index-OkKEOL6H.d.cts} +1 -1
  260. package/dist/{index-9NE86em3.d.cts → index-hAqp0oYb.d.cts} +1 -1
  261. package/dist/interceptors/index.d.cts +13 -12
  262. package/dist/interceptors/index.d.ts +13 -12
  263. package/dist/interceptors/types.d.cts +12 -11
  264. package/dist/interceptors/types.d.ts +12 -11
  265. package/dist/{localStorageContext-DAOJ4be4.js → localStorageContext-CqcSvg2H.js} +2 -2
  266. package/dist/{localStorageContext-C5giszHn.cjs → localStorageContext-DiLfSsqL.cjs} +2 -2
  267. package/dist/{locators-C2fWd-74.js → locators-BMQGmGLq.js} +1 -1
  268. package/dist/{locators-Cx3q6Z_h.cjs → locators-DxYdak1F.cjs} +1 -1
  269. package/dist/{logger-0D_8Ip2L.cjs → logger-TBIl4uIH.cjs} +1 -1
  270. package/dist/{logger-Co0IA3k5.js → logger-W3lqg-4b.js} +1 -1
  271. package/dist/models-CWOgrLCm.js +1284 -0
  272. package/dist/models-DqdLOi2I.cjs +1519 -0
  273. package/dist/{newOrgConfigContext-BMvcqPzD.cjs → newOrgConfigContext-BIDz4ZuO.cjs} +4 -4
  274. package/dist/{newOrgConfigContext-DOdUxlOE.d.cts → newOrgConfigContext-CJI3tsVV.d.cts} +2 -2
  275. package/dist/{newOrgConfigContext-BVyJExeW.d.ts → newOrgConfigContext-CKn7B2rj.d.ts} +2 -2
  276. package/dist/{newOrgConfigContext-6mlrvr1w.js → newOrgConfigContext-u_9UPNcX.js} +4 -4
  277. package/dist/{nodeSelector-DYhDUi7v.d.ts → nodeSelector-B5NfnUHv.d.ts} +1 -1
  278. package/dist/{nodeSelector-B3bPtEjX.d.cts → nodeSelector-vKB44CDB.d.cts} +1 -1
  279. package/dist/{orgAnalyticsConfig-Bm23fw4s.cjs → orgAnalyticsConfig-CGEQtAFs.cjs} +1 -1
  280. package/dist/{orgAnalyticsConfig-CpBmga08.js → orgAnalyticsConfig-i4jozLBB.js} +1 -1
  281. package/dist/responseGenerics-D9bS-Dd6.d.ts +148 -0
  282. package/dist/{index-Cx9e-fRi.d.ts → responseGenerics-DWLV09cQ.d.cts} +4 -40
  283. package/dist/{search-y-ioX5Mz.d.cts → search-6RrxBXD6.d.cts} +1 -1
  284. package/dist/{search-D-UfTjB7.cjs → search-CTVX9gC6.cjs} +2 -2
  285. package/dist/{search-B1OtJe8Z.d.ts → search-DrJiCT7d.d.ts} +1 -1
  286. package/dist/{search-yawhMv22.js → search-NgNrXNS9.js} +2 -2
  287. package/dist/{search-filter-types-BxaNSLs_.d.cts → search-filter-types-BItKtezf.d.cts} +1 -1
  288. package/dist/{search-filter-types-OI9zH3E_.d.ts → search-filter-types-CGFhksO3.d.ts} +1 -1
  289. package/dist/{searchContext-CFuwIIW-.cjs → searchContext-CnDXkawZ.cjs} +6 -6
  290. package/dist/{searchContext-CiqOqTJL.js → searchContext-DtRmshTA.js} +6 -6
  291. package/dist/{sessionStorageContext-BmCW091C.cjs → sessionStorageContext-1Ks_d4Z0.cjs} +2 -2
  292. package/dist/{sessionStorageContext-CNxkqJi1.js → sessionStorageContext-CDcl7NVl.js} +2 -2
  293. package/dist/{shopifyUrlContext-aZMwCfbJ.cjs → shopifyUrlContext-CxjV3qvH.cjs} +2 -2
  294. package/dist/{shopifyUrlContext-BXbI0PIG.js → shopifyUrlContext-D2btP_lY.js} +2 -2
  295. package/dist/{spiffyWidgets-CvEJIuJx.d.ts → spiffyWidgets-CR6F7FRE.d.ts} +1 -1
  296. package/dist/{spiffyWidgets-BuS00VaQ.d.cts → spiffyWidgets-eNbU1gMc.d.cts} +1 -1
  297. package/dist/{systemSettingsContext-SozpUezn.cjs → systemSettingsContext-BejoGzzB.cjs} +2 -2
  298. package/dist/{systemSettingsContext-kz6yyiFF.js → systemSettingsContext-C4dtZ0uZ.js} +2 -2
  299. package/dist/{test-types-DRhqHXw-.d.ts → test-types-BEml_bm3.d.ts} +1 -1
  300. package/dist/{test-types-ThQiO_cc.d.cts → test-types-Dsu8RJZu.d.cts} +1 -1
  301. package/dist/types/index.d.cts +2 -2
  302. package/dist/types/index.d.ts +2 -2
  303. package/dist/{types-r0Z6CwyF.d.ts → types-4LQ7LUCk.d.ts} +2 -2
  304. package/dist/types-BegmH0S1.d.ts +60 -0
  305. package/dist/types-BuvXXGxE.cjs +1 -1
  306. package/dist/types-CtUb63bt.js +76 -0
  307. package/dist/{types-zQGBI-Yo.d.cts → types-DFsSqmWx.d.cts} +2 -2
  308. package/dist/types-DWorwfS-.d.cts +60 -0
  309. package/dist/types-DXnG1tV0.js +1 -1
  310. package/dist/types-UUvB6h05.cjs +106 -0
  311. package/dist/types.d.cts +3 -3
  312. package/dist/types.d.ts +3 -3
  313. package/dist/{unsupportedProductExceptions-B4f9aLjr.cjs → unsupportedProductExceptions-B0yx2bHK.cjs} +1 -1
  314. package/dist/{unsupportedProductExceptions-DlmraJm8.js → unsupportedProductExceptions-Cs66ngs3.js} +1 -1
  315. package/dist/{urlsParser-DhcEZLc_.cjs → urlsParser-COzMdJaX.cjs} +1 -1
  316. package/dist/{urlsParser-DLCzibqU.js → urlsParser-DxjoLj98.js} +1 -1
  317. package/dist/{useAmplitudeOperations-D0nvIYlt.cjs → useAmplitudeOperations-BJXD9v2u.cjs} +2 -2
  318. package/dist/{useAmplitudeOperations-Dhks3PgF.js → useAmplitudeOperations-Dym0Ker8.js} +2 -2
  319. package/dist/{useAppDetails-qyaQIbWE.js → useAppDetails-Dmh16bWE.js} +4 -4
  320. package/dist/{useAppDetails-B9sGmpJ3.cjs → useAppDetails-DsAZ1xQn.cjs} +4 -4
  321. package/dist/{useGraphQLConfig-CgKEfVYc.cjs → useGraphQLConfig-B3DlwmGg.cjs} +2 -2
  322. package/dist/{useGraphQLConfig-BccQUaeW.js → useGraphQLConfig-DSRaDTdT.js} +2 -2
  323. package/dist/{userIdentityContext-BKLedN4R.d.ts → userIdentityContext-C6kApbuk.d.ts} +1 -1
  324. package/dist/userIdentityContext-DF3atBFE.js +119 -0
  325. package/dist/userIdentityContext-DpQTduhF.cjs +136 -0
  326. package/dist/{userIdentityContext-D2oFVFzo.d.cts → userIdentityContext-kU1PIo8K.d.cts} +1 -1
  327. package/dist/{utils-DFPt3FSw.js → utils-B7KTAEmV.js} +4 -4
  328. package/dist/{utils-BhyZiDrE.d.ts → utils-BRkGP1eb.d.ts} +1 -1
  329. package/dist/{utils-B7PAzB_M.d.cts → utils-CBD4g2Nc.d.cts} +4 -4
  330. package/dist/{utils-C6imnLBo.cjs → utils-CDw74BCO.cjs} +1 -1
  331. package/dist/{utils-Cazq8Q3q.cjs → utils-CcC2jZRi.cjs} +4 -4
  332. package/dist/{utils-B3x_9JTY.d.cts → utils-DCrwX6FT.d.cts} +1 -1
  333. package/dist/{utils-C4ci_t0-.js → utils-DIvMgPe8.js} +1 -1
  334. package/dist/{utils-B1v0iXs3.d.ts → utils-QKFAbPT6.d.ts} +4 -4
  335. package/package.json +7 -2
  336. package/src/application/commerce-api.ts +2 -0
  337. package/src/application/models/graphql/index.ts +1 -0
  338. package/src/atoms/app/index.ts +1 -1
  339. package/src/atoms/search/productRetrievalAPI.ts +70 -0
  340. package/src/atoms/search/productRetrievalAdapter.ts +25 -0
  341. package/src/atoms/search/types.ts +13 -0
  342. package/src/contexts/amplitudeContext/__tests__/amplitudeContext.test.tsx +525 -0
  343. package/src/contexts/amplitudeContext/amplitudeContext.tsx +5 -2
  344. package/src/contexts/graphqlContext/__tests__/graphqlContext.test.tsx +790 -0
  345. package/src/contexts/localStorageContext/__tests__/localStorageContext.test.tsx +775 -0
  346. package/src/contexts/newOrgConfigContext/__tests__/newOrgConfigContext.test.tsx +495 -0
  347. package/src/contexts/searchContext/__tests__/searchContext.test.tsx +806 -0
  348. package/src/contexts/systemSettingsContext/__tests__/systemSettingsContext.test.tsx +506 -0
  349. package/src/contexts/types.ts +3 -0
  350. package/src/contexts/userIdentityContext/userIdentityContext.tsx +7 -5
  351. package/src/hooks/Search/useRecommendedProducts.ts +48 -0
  352. package/src/hooks/Search/useSearch.tsx +89 -182
  353. package/src/hooks/Search/useSearchInput.ts +263 -0
  354. package/src/types/FilterAttribute.ts +35 -0
  355. package/dist/amplitudeContext-DOqL2Vn8.js +0 -264
  356. package/dist/amplitudeContext-ZTQMvVTV.cjs +0 -286
  357. package/dist/graphql-OkhsP4ir.js +0 -36
  358. package/dist/graphql-l4dQrsA6.cjs +0 -53
  359. package/dist/index-Bmub8e38.d.cts +0 -98
  360. package/dist/index-CG3P8xE1.d.cts +0 -676
  361. package/dist/index-CiWEYzXl.d.cts +0 -184
  362. package/dist/index-D2VaMPA3.d.ts +0 -98
  363. package/dist/index-fUsw_Mea.d.ts +0 -676
  364. package/dist/models-CkJ-wg9Q.cjs +0 -1537
  365. package/dist/models-UHOY0ak5.js +0 -1296
  366. package/dist/types-BwNrLPSZ.cjs +0 -106
  367. package/dist/types-CKMMb_gX.d.cts +0 -51
  368. package/dist/types-D3uOF0Oy.js +0 -76
  369. package/dist/types-DZPuBnHe.d.ts +0 -51
  370. package/dist/useDebounce-BZDtUAQ8.cjs +0 -26
  371. package/dist/useDebounce-ueblXZI-.js +0 -19
  372. package/dist/userIdentityContext-Cb6lLv6t.cjs +0 -132
  373. package/dist/userIdentityContext-O_DHHPTN.js +0 -115
  374. /package/dist/{AmplitudeOperations-ChZWcSsc.js → AmplitudeOperations-C-ieCm9m.js} +0 -0
  375. /package/dist/{AmplitudeOperations-JggIc1zD.cjs → AmplitudeOperations-p7APchq9.cjs} +0 -0
  376. /package/dist/{index-RcVcRKH7.d.cts → index-A0HvA68Y.d.cts} +0 -0
  377. /package/dist/{index-mHc9_XC3.d.ts → index-DNVvRcKu.d.ts} +0 -0
@@ -1,47 +1,293 @@
1
1
  const require_chunk = require('../../chunk-CUT6urMc.cjs');
2
- require('../../types-BwNrLPSZ.cjs');
2
+ require('../../types-UUvB6h05.cjs');
3
3
  require('../../events-DYY4l817.cjs');
4
4
  const require_utils = require('../../utils-hYTjy7hJ.cjs');
5
- const require_logger = require('../../logger-0D_8Ip2L.cjs');
6
- const require_models = require('../../models-CkJ-wg9Q.cjs');
7
- require('../../featureGates-Bt_Y3kZ7.cjs');
8
- require('../../urlsParser-DhcEZLc_.cjs');
9
- require('../../graphql-l4dQrsA6.cjs');
10
- require('../../utils-C6imnLBo.cjs');
11
- require('../../api-BvygKEiX.cjs');
5
+ const require_models = require('../../models-DqdLOi2I.cjs');
6
+ const require_featureGates = require('../../featureGates-qU_ulhpC.cjs');
7
+ require('../../urlsParser-COzMdJaX.cjs');
8
+ require('../../graphql-i3dtpVTl.cjs');
9
+ require('../../utils-CDw74BCO.cjs');
10
+ require('../../api-DeW6rHj3.cjs');
11
+ require('../../logger-TBIl4uIH.cjs');
12
12
  require('../../utilityTypes-BGbL2WTP.cjs');
13
13
  require('../../variantInfo-DpLn4nHz.cjs');
14
- require('../../localStorageContext-C5giszHn.cjs');
15
- const require_enviveConfig = require('../../enviveConfig-B42OJ8bK.cjs');
16
- require('../../orgAnalyticsConfig-Bm23fw4s.cjs');
17
- require('../../atomStore-CmZbgQHc.cjs');
18
- require('../../app-BQw_-JGl.cjs');
19
- require('../../enviveConfigContext-Y1ahEAMe.cjs');
20
- require('../../featureFlagServiceContext-D3Ge8GH5.cjs');
21
- const require_amplitudeContext = require('../../amplitudeContext-ZTQMvVTV.cjs');
22
- require('../../chatState-B3Dyrd9M.cjs');
14
+ require('../../atomStore-8ppNkJ_n.cjs');
15
+ require('../../localStorageContext-DiLfSsqL.cjs');
16
+ const require_enviveConfig = require('../../enviveConfig-DZHdtLsQ.cjs');
17
+ require('../../orgAnalyticsConfig-CGEQtAFs.cjs');
18
+ require('../../app-XEFPotoH.cjs');
19
+ require('../../enviveConfigContext-CTcHUIFP.cjs');
20
+ const require_featureFlagServiceContext = require('../../featureFlagServiceContext-CJyYItqu.cjs');
21
+ const require_amplitudeContext = require('../../amplitudeContext-C-0-DDk3.cjs');
22
+ require('../../chatState-OkYPVghN.cjs');
23
23
  require('../../graphqlConfig-BnfE0ql5.cjs');
24
- require('../../chat-DwNALtox.cjs');
24
+ const require_chat = require('../../chat-Ckd1b_z_.cjs');
25
25
  const require_globalSearch = require('../../globalSearch-BOG3wmck.cjs');
26
26
  require('../../org-B_cWn2bt.cjs');
27
27
  require('../../newOrgConfigAtom-CPA6Gp6n.cjs');
28
28
  const require_utils$2 = require('../../utils-CvLmSsUj.cjs');
29
- require('../../chatSearch-DtE2cUQw.cjs');
29
+ require('../../chatSearch-Bev4ZI8Z.cjs');
30
30
  const require_types$1 = require('../../types-BuvXXGxE.cjs');
31
31
  require('../../searchServiceAdapter-BGlvoZFE.cjs');
32
- const require_search = require('../../search-D-UfTjB7.cjs');
33
- require('../../graphqlContext-CpwAvnro.cjs');
34
- require('../../useGraphQLConfig-CgKEfVYc.cjs');
35
- require('../../newOrgConfigContext-BMvcqPzD.cjs');
36
- const require_NewOrgConfig = require('../../NewOrgConfig-BxSuoP9C.cjs');
37
- const require_useDebounce = require('../../useDebounce-BZDtUAQ8.cjs');
32
+ const require_search = require('../../search-CTVX9gC6.cjs');
33
+ require('../../amplitudeContext-DPtyVv3Q.cjs');
34
+ require('../../graphqlContext-CVbYIftg.cjs');
35
+ require('../../useGraphQLConfig-B3DlwmGg.cjs');
36
+ require('../../newOrgConfigContext-BIDz4ZuO.cjs');
37
+ const require_NewOrgConfig = require('../../NewOrgConfig-CInGtTV6.cjs');
38
38
  require('../../useIntersection-DSDREfj6.cjs');
39
- const require_TrackComponentVisibleEvent = require('../../TrackComponentVisibleEvent-DMuX-byo.cjs');
39
+ const require_TrackComponentVisibleEvent = require('../../TrackComponentVisibleEvent-C7-nnBks.cjs');
40
40
  let react = require("react");
41
41
  react = require_chunk.__toESM(react);
42
42
  let jotai = require("jotai");
43
43
  jotai = require_chunk.__toESM(jotai);
44
+ let fuse_js = require("fuse.js");
45
+ fuse_js = require_chunk.__toESM(fuse_js);
44
46
 
47
+ //#region src/hooks/Search/useSearchInput.ts
48
+ const useSearchInput = ({ initialSearchText = "", searchOrigin, onSearchSubmit }) => {
49
+ const track = (0, jotai.useAtomValue)(require_chat.amplitudeTrackEventAtom);
50
+ const [searchText, setSearchText] = (0, react.useState)(initialSearchText);
51
+ const [hasText, setHasText] = (0, react.useState)(initialSearchText.trim().length > 0);
52
+ const [isFocused, setIsFocused] = (0, react.useState)(false);
53
+ const [focusedIndex, setFocusedIndex] = (0, react.useState)(-1);
54
+ const [focusedOptionId, setFocusedOptionId] = (0, react.useState)(void 0);
55
+ const globalAutocompleteResults = (0, jotai.useAtomValue)(require_globalSearch.autocompleteStateAtom).results;
56
+ const isAutocompleteEnabled = globalAutocompleteResults.length > 0;
57
+ const isSelectingAutocomplete = (0, react.useRef)(false);
58
+ const shouldShowAutocomplete = hasText && isFocused && isAutocompleteEnabled;
59
+ const autocompleteResultsLimit = 5;
60
+ const fuseOptions = (0, react.useMemo)(() => ({
61
+ includeScore: true,
62
+ includeMatches: true,
63
+ threshold: .3,
64
+ location: 0,
65
+ distance: 4,
66
+ minMatchCharLength: 1,
67
+ keys: [],
68
+ useExtendedSearch: false,
69
+ ignoreLocation: false
70
+ }), []);
71
+ const fuse = (0, react.useMemo)(() => {
72
+ if (!globalAutocompleteResults.length) return null;
73
+ return new fuse_js.default(globalAutocompleteResults, fuseOptions);
74
+ }, [globalAutocompleteResults, fuseOptions]);
75
+ const autocompleteResults = (0, react.useMemo)(() => {
76
+ if (!isAutocompleteEnabled || !fuse) return [];
77
+ if (!searchText.trim()) return [];
78
+ return fuse.search(searchText).slice(0, autocompleteResultsLimit).map((result) => result.item);
79
+ }, [
80
+ isAutocompleteEnabled,
81
+ fuse,
82
+ searchText,
83
+ autocompleteResultsLimit
84
+ ]);
85
+ const handleSearchInputChange = (0, react.useCallback)((newValue) => {
86
+ if (newValue !== searchText) setIsFocused(true);
87
+ if (newValue.length === 1) track?.({
88
+ eventName: require_amplitudeContext.SpiffyMetricsEventName.SearchInputStarted,
89
+ eventProps: { searchOrigin }
90
+ });
91
+ setSearchText(newValue);
92
+ setHasText(newValue.trim().length > 0);
93
+ setFocusedIndex(-1);
94
+ setFocusedOptionId(void 0);
95
+ }, [
96
+ searchOrigin,
97
+ searchText,
98
+ track
99
+ ]);
100
+ const handleSearchInputFocus = (0, react.useCallback)(() => {
101
+ setIsFocused(true);
102
+ }, []);
103
+ const handleSearchInputBlur = (0, react.useCallback)(() => {
104
+ setTimeout(() => {
105
+ if (!isSelectingAutocomplete.current) {
106
+ setIsFocused(false);
107
+ setFocusedIndex(-1);
108
+ setFocusedOptionId(void 0);
109
+ }
110
+ }, 150);
111
+ }, []);
112
+ const handleSubmitSearch = (0, react.useCallback)(() => {
113
+ setIsFocused(false);
114
+ if (searchText.trim() && onSearchSubmit) {
115
+ track?.({
116
+ eventName: require_amplitudeContext.SpiffyMetricsEventName.SearchQuerySubmitted,
117
+ eventProps: {
118
+ searchOrigin,
119
+ queryText: searchText.trim()
120
+ },
121
+ alsoSendToGoogleAnalytics: true
122
+ });
123
+ onSearchSubmit(searchText.trim());
124
+ }
125
+ }, [
126
+ searchText,
127
+ onSearchSubmit,
128
+ searchOrigin,
129
+ track
130
+ ]);
131
+ const handleAutocompleteSelect = (0, react.useCallback)((suggestion, rankPosition) => {
132
+ isSelectingAutocomplete.current = true;
133
+ setSearchText(suggestion);
134
+ setHasText(suggestion.trim().length > 0);
135
+ setIsFocused(false);
136
+ track?.({
137
+ eventName: require_amplitudeContext.SpiffyMetricsEventName.SearchInputStarted,
138
+ eventProps: { searchOrigin }
139
+ });
140
+ if (onSearchSubmit) onSearchSubmit(suggestion.trim());
141
+ setTimeout(() => {
142
+ isSelectingAutocomplete.current = false;
143
+ }, 100);
144
+ }, [
145
+ onSearchSubmit,
146
+ searchOrigin,
147
+ track
148
+ ]);
149
+ const handleKeyDown = (0, react.useCallback)((event) => {
150
+ if (event.key === "ArrowDown") {
151
+ event.preventDefault();
152
+ const newIndex = (focusedIndex + 1) % autocompleteResults.length;
153
+ setFocusedIndex(newIndex);
154
+ setFocusedOptionId(`option-${newIndex}`);
155
+ } else if (event.key === "ArrowUp") {
156
+ event.preventDefault();
157
+ const newIndex = (focusedIndex - 1 + autocompleteResults.length) % autocompleteResults.length;
158
+ setFocusedIndex(newIndex);
159
+ setFocusedOptionId(`option-${newIndex}`);
160
+ } else if (event.key === "Enter") if (focusedIndex === -1) {
161
+ event.preventDefault();
162
+ handleSubmitSearch();
163
+ } else {
164
+ event.preventDefault();
165
+ const suggestionText = autocompleteResults[focusedIndex];
166
+ handleAutocompleteSelect(suggestionText, focusedIndex);
167
+ }
168
+ else if (event.key === "Escape") {
169
+ event.preventDefault();
170
+ setFocusedIndex(-1);
171
+ setFocusedOptionId(void 0);
172
+ }
173
+ }, [
174
+ autocompleteResults,
175
+ focusedIndex,
176
+ handleAutocompleteSelect,
177
+ handleSubmitSearch
178
+ ]);
179
+ const setSearchTextUtility = (0, react.useCallback)((text) => {
180
+ setSearchText(text);
181
+ setHasText(text.trim().length > 0);
182
+ }, []);
183
+ const resetSearch = (0, react.useCallback)(() => {
184
+ setSearchText("");
185
+ setHasText(false);
186
+ setIsFocused(false);
187
+ setFocusedIndex(-1);
188
+ setFocusedOptionId(void 0);
189
+ }, []);
190
+ return {
191
+ searchText,
192
+ hasText,
193
+ isFocused,
194
+ focusedIndex,
195
+ focusedOptionId,
196
+ autocompleteResults,
197
+ shouldShowAutocomplete,
198
+ handleSearchInputChange,
199
+ handleSearchInputFocus,
200
+ handleSearchInputBlur,
201
+ handleKeyDown,
202
+ handleAutocompleteSelect,
203
+ handleSubmitSearch,
204
+ setSearchText: setSearchTextUtility,
205
+ resetSearch
206
+ };
207
+ };
208
+
209
+ //#endregion
210
+ //#region src/atoms/search/productRetrievalAdapter.ts
211
+ let productRetrievalFunction = null;
212
+ const getProductRetrievalFunction = () => {
213
+ if (!productRetrievalFunction) throw new Error("Product retrieval function not initialized. Make sure ProductRetrievalProvider is mounted.");
214
+ return productRetrievalFunction;
215
+ };
216
+
217
+ //#endregion
218
+ //#region src/atoms/search/productRetrievalAPI.ts
219
+ const productRetrievalAtom = (0, jotai.atom)({
220
+ data: null,
221
+ loading: false,
222
+ error: null,
223
+ lastProductIds: null
224
+ });
225
+ const performProductRetrievalAtom = (0, jotai.atom)(null, async (get, set, params) => {
226
+ if (get(productRetrievalAtom).loading) return;
227
+ set(productRetrievalAtom, {
228
+ data: null,
229
+ loading: true,
230
+ error: null,
231
+ lastProductIds: params.productIds
232
+ });
233
+ try {
234
+ const result = await getProductRetrievalFunction()(params);
235
+ set(productRetrievalAtom, {
236
+ data: result,
237
+ loading: false,
238
+ error: null,
239
+ lastProductIds: params.productIds
240
+ });
241
+ } catch (error) {
242
+ const errorMessage = error instanceof Error ? error.message : "An unknown error occurred";
243
+ set(productRetrievalAtom, {
244
+ data: null,
245
+ loading: false,
246
+ error: errorMessage,
247
+ lastProductIds: params.productIds
248
+ });
249
+ }
250
+ });
251
+ const retrievedProductsAtom = (0, jotai.atom)((get) => {
252
+ return get(productRetrievalAtom).data?.products || [];
253
+ });
254
+ const productRetrievalLoadingAtom = (0, jotai.atom)((get) => {
255
+ return get(productRetrievalAtom).loading;
256
+ });
257
+ const productRetrievalErrorAtom = (0, jotai.atom)((get) => {
258
+ return get(productRetrievalAtom).error;
259
+ });
260
+
261
+ //#endregion
262
+ //#region src/hooks/Search/useRecommendedProducts.ts
263
+ /**
264
+ * A hook to get recommended products.
265
+ * It checks the `IsRecommendedProductsEnabled` feature gate and triggers fetching if needed.
266
+ * If the gate is enabled, it returns the list of recommended products.
267
+ * If the gate is disabled, it returns an empty array.
268
+ *
269
+ * @returns The list of recommended products or an empty array.
270
+ */
271
+ const useRecommendedProducts = () => {
272
+ const { featureFlagService } = require_featureFlagServiceContext.useFeatureFlagService();
273
+ const isEnabled = featureFlagService?.isFeatureGateEnabled(require_featureGates.FeatureGates.IsRecommendedProductsEnabled);
274
+ const recommendedProducts = (0, jotai.useAtomValue)(retrievedProductsAtom);
275
+ const performProductRetrieval = (0, jotai.useSetAtom)(performProductRetrievalAtom);
276
+ const { lastProductIds } = (0, jotai.useAtomValue)(productRetrievalAtom);
277
+ const orgUIConfig = require_NewOrgConfig.useNewOrgConfig();
278
+ (0, react.useEffect)(() => {
279
+ const recommendedProductIds = orgUIConfig.frontendConfig?.uiConfigs?.searchConfig ? orgUIConfig.frontendConfig?.uiConfigs?.searchConfig.recommendedProducts : [];
280
+ if (isEnabled && recommendedProductIds && recommendedProductIds.length > 0 && !lastProductIds) performProductRetrieval({ productIds: recommendedProductIds });
281
+ }, [
282
+ isEnabled,
283
+ performProductRetrieval,
284
+ lastProductIds,
285
+ orgUIConfig
286
+ ]);
287
+ return isEnabled ? recommendedProducts : [];
288
+ };
289
+
290
+ //#endregion
45
291
  //#region src/hooks/Search/useSearch.tsx
46
292
  const useSearch = () => {
47
293
  const config = require_NewOrgConfig.useNewOrgConfig();
@@ -49,7 +295,6 @@ const useSearch = () => {
49
295
  const { data: searchData, loading: isLoadingSearch } = (0, jotai.useAtomValue)(require_search.searchAtom);
50
296
  const productList = (0, jotai.useAtomValue)(require_search.filteredSearchProductsAtom);
51
297
  const performSearch = (0, jotai.useSetAtom)(require_search.performSearchAtom);
52
- const [{ results: autocompleteResults, isLoading: isLoadingAutocomplete }, setAutocompleteState] = (0, jotai.useAtom)(require_globalSearch.autocompleteStateAtom);
53
298
  const [{ query }] = (0, jotai.useAtom)(require_search.searchParamsAtom);
54
299
  const [isFilterOpen, setIsFilterOpen] = (0, jotai.useAtom)(require_globalSearch.isFilterOpenAtom);
55
300
  const [selectedFilterOptions] = (0, jotai.useAtom)(require_search.searchSelectedFiltersAtom);
@@ -58,12 +303,26 @@ const useSearch = () => {
58
303
  const [productSorting, setProductSorting] = (0, jotai.useAtom)(require_search.searchProductSortingAtom);
59
304
  const clearFilters = (0, jotai.useSetAtom)(require_search.clearSearchFiltersAtom);
60
305
  const searchFilters = (0, jotai.useAtomValue)(require_search.searchFiltersAtom);
61
- const [isDirty, setIsDirty] = (0, react.useState)(true);
62
- const [focusedIndex, setFocusedIndex] = (0, react.useState)(-1);
63
- const [focusedOptionId, setFocusedOptionId] = (0, react.useState)(void 0);
64
- const [searchText, setSearchText] = (0, react.useState)(query || "");
306
+ const recommendedProducts = useRecommendedProducts();
65
307
  const searchResultsRef = (0, react.useRef)(null);
66
- const debouncedSearchText = require_useDebounce.useDebounce(searchText, 200);
308
+ const scrollToTop = (0, react.useCallback)(() => {
309
+ const container = searchResultsRef.current;
310
+ if (container) container.scrollTo({
311
+ top: 0,
312
+ behavior: "smooth"
313
+ });
314
+ else window.scrollTo({
315
+ top: 0,
316
+ behavior: "smooth"
317
+ });
318
+ }, []);
319
+ const { searchText, focusedIndex, focusedOptionId, autocompleteResults, shouldShowAutocomplete, handleSearchInputChange, handleSearchInputFocus, handleSearchInputBlur, handleKeyDown, handleAutocompleteSelect, handleSubmitSearch, setSearchText } = useSearchInput({
320
+ initialSearchText: query || "",
321
+ searchOrigin: require_models.SpiffyWidgets.SearchResults,
322
+ onSearchSubmit: (searchQuery) => {
323
+ performSearch({ query: searchQuery });
324
+ }
325
+ });
67
326
  const searchResultsState = require_utils.getSearchResultsState(isLoadingSearch, searchData);
68
327
  const dynamicFilters = searchData?.filters || [];
69
328
  const safeProductCardConfig = config?.frontendConfig?.uiConfigs?.productCardConfig || {
@@ -123,76 +382,16 @@ const useSearch = () => {
123
382
  }
124
383
  });
125
384
  addFilter(require_search.createFilterOption("dynamic", filter, dynamicFilterDisplayName));
385
+ scrollToTop();
126
386
  }, [
127
387
  addFilter,
128
388
  searchText,
129
- trackEvent
389
+ scrollToTop
130
390
  ]);
131
391
  const handleRemoveFilter = (0, react.useCallback)((filter) => {
132
392
  removeFilter(filter.id);
133
- }, [removeFilter]);
134
- const handleSubmitSearch = (0, react.useCallback)(async () => {
135
- if (searchText.trim()) {
136
- trackEvent({
137
- eventName: require_amplitudeContext.SpiffyMetricsEventName.SearchQuerySubmitted,
138
- eventProps: {
139
- searchOrigin: require_models.SpiffyWidgets.SearchResults,
140
- queryText: searchText.trim()
141
- },
142
- alsoSendToGoogleAnalytics: true
143
- });
144
- const url = new URL(window.location.href);
145
- url.searchParams.set("esq", searchText.trim());
146
- window.history.pushState({}, "", url);
147
- performSearch({ query: searchText.trim() });
148
- }
149
- }, [
150
- performSearch,
151
- searchText,
152
- trackEvent
153
- ]);
154
- const handleAutocompleteSelect = (0, react.useCallback)((suggestion) => {
155
- setSearchText(suggestion);
156
- handleSubmitSearch();
157
- }, [handleSubmitSearch, setSearchText]);
158
- const handleKeyDown = (0, react.useCallback)((event) => {
159
- if (event.key === "ArrowDown") {
160
- event.preventDefault();
161
- const newIndex = (focusedIndex + 1) % autocompleteResults.length;
162
- setFocusedIndex(newIndex);
163
- setFocusedOptionId(`option-${newIndex}`);
164
- } else if (event.key === "ArrowUp") {
165
- event.preventDefault();
166
- const newIndex = (focusedIndex - 1 + autocompleteResults.length) % autocompleteResults.length;
167
- setFocusedIndex(newIndex);
168
- setFocusedOptionId(`option-${newIndex}`);
169
- } else if (event.key === "Enter") if (focusedIndex === -1) {
170
- event.preventDefault();
171
- handleSubmitSearch();
172
- } else {
173
- event.preventDefault();
174
- const suggestionText = autocompleteResults[focusedIndex];
175
- handleAutocompleteSelect(suggestionText);
176
- }
177
- else if (event.key === "Escape") {
178
- event.preventDefault();
179
- setFocusedIndex(-1);
180
- setFocusedOptionId(void 0);
181
- }
182
- }, [
183
- autocompleteResults,
184
- focusedIndex,
185
- handleAutocompleteSelect,
186
- handleSubmitSearch
187
- ]);
188
- const handleSearchInputChange = (newValue) => {
189
- if (newValue.length === 1) trackEvent({
190
- eventName: require_amplitudeContext.SpiffyMetricsEventName.SearchInputStarted,
191
- eventProps: { searchOrigin: require_models.SpiffyWidgets.SearchResults }
192
- });
193
- setSearchText(newValue);
194
- setIsDirty(true);
195
- };
393
+ scrollToTop();
394
+ }, [removeFilter, scrollToTop]);
196
395
  const handleSelectFilterItem = (0, react.useCallback)(({ filterId, filterItemId, isSelected, displayName }) => {
197
396
  if (filterId === "sort") {
198
397
  const newSort = filterItemId;
@@ -204,8 +403,11 @@ const useSearch = () => {
204
403
  }
205
404
  });
206
405
  setProductSorting(newSort);
207
- } else if (!isSelected) removeFilter(`${filterId}:${filterItemId}`);
208
- else {
406
+ scrollToTop();
407
+ } else if (!isSelected) {
408
+ removeFilter(`${filterId}:${filterItemId}`);
409
+ scrollToTop();
410
+ } else {
209
411
  trackEvent({
210
412
  eventName: require_amplitudeContext.SpiffyMetricsEventName.SearchFilterClicked,
211
413
  eventProps: {
@@ -216,78 +418,44 @@ const useSearch = () => {
216
418
  }
217
419
  });
218
420
  addFilter(require_search.createFilterOption(filterId, filterItemId, displayName));
421
+ scrollToTop();
219
422
  }
220
423
  }, [
221
424
  addFilter,
222
425
  removeFilter,
223
426
  setProductSorting,
224
427
  searchText,
225
- trackEvent
428
+ scrollToTop
226
429
  ]);
227
430
  const handleClearAllFilters = (0, react.useCallback)(() => {
228
431
  setProductSorting(require_types$1.ProductSorting.FEATURED);
229
432
  clearFilters();
230
- }, [setProductSorting, clearFilters]);
433
+ scrollToTop();
434
+ }, [
435
+ setProductSorting,
436
+ clearFilters,
437
+ scrollToTop
438
+ ]);
231
439
  require_TrackComponentVisibleEvent.useTrackComponentVisibleEvent(require_models.SpiffyWidgets.SearchResults, searchResultsRef, {}, require_amplitudeContext.SpiffyMetricsEventName.SearchComponentVisible);
232
440
  (0, react.useEffect)(() => {
233
- if (searchResultsState === require_utils.SearchResultsState.NoResults || searchResultsState === require_utils.SearchResultsState.Results) trackEvent({
441
+ if (searchResultsState === require_utils.SearchResultsState.Results || searchResultsState === require_utils.SearchResultsState.NoResults) trackEvent({
234
442
  eventName: require_amplitudeContext.SpiffyMetricsEventName.SearchResultsViewed,
235
443
  eventProps: {
236
444
  queryText: searchText,
237
445
  resultsCount: productList.length
238
446
  }
239
447
  });
240
- }, [
241
- productList.length,
242
- searchResultsState,
243
- trackEvent
244
- ]);
245
- (0, react.useEffect)(() => {
246
- if (query && query !== searchText) setSearchText(query);
247
- }, [query]);
448
+ }, [productList.length, searchResultsState]);
248
449
  (0, react.useEffect)(() => {
249
- const esq = new URLSearchParams(window.location.search).get("esq");
250
- if (esq) {
251
- setSearchText(esq);
252
- performSearch({ query: esq });
450
+ if (query && query !== searchText) {
451
+ const esq = new URLSearchParams(window.location.search).get("esq");
452
+ setSearchText(query);
453
+ performSearch({ query: esq ?? query });
253
454
  }
254
- }, [performSearch]);
255
- const fetchAutocompleteSuggestions = (_query) => {
256
- return Promise.resolve([]);
257
- };
258
- (0, react.useEffect)(() => {
259
- if (fetchAutocompleteSuggestions === void 0) return;
260
- if (!isDirty || debouncedSearchText.length <= 2) {
261
- setAutocompleteState({
262
- results: [],
263
- isLoading: false
264
- });
265
- return;
266
- }
267
- setAutocompleteState((prev) => ({
268
- ...prev,
269
- isLoading: true
270
- }));
271
- const fetchData = async () => {
272
- try {
273
- const results = await fetchAutocompleteSuggestions?.(debouncedSearchText);
274
- setAutocompleteState({
275
- results: results ?? [],
276
- isLoading: false
277
- });
278
- } catch (error) {
279
- require_logger.logger_default.logError("Failed to fetch autocomplete suggestions:", error);
280
- setAutocompleteState({
281
- results: [],
282
- isLoading: false
283
- });
284
- }
285
- };
286
- fetchData();
287
455
  }, [
288
- debouncedSearchText,
289
- isDirty,
290
- setAutocompleteState
456
+ performSearch,
457
+ query,
458
+ setSearchText
291
459
  ]);
292
460
  return {
293
461
  searchData,
@@ -295,16 +463,17 @@ const useSearch = () => {
295
463
  merchantShortName: safeMerchantShortName,
296
464
  productCardConfig: safeProductCardConfig,
297
465
  productList,
466
+ recommendedProducts,
298
467
  autocompleteResults,
299
468
  searchFilters: filters,
300
469
  availableDynamicFilters,
301
470
  selectedFilterOptions,
302
471
  searchText,
472
+ query: query || "",
303
473
  searchResultsState,
304
- isLoadingAutocomplete,
305
474
  isLoadingSearch,
306
475
  isFilterOpen,
307
- isDirty,
476
+ shouldShowAutocomplete,
308
477
  focusedIndex,
309
478
  focusedOptionId,
310
479
  filterButtonText,
@@ -312,6 +481,8 @@ const useSearch = () => {
312
481
  onSubmitSearch: handleSubmitSearch,
313
482
  onAutocompleteSelect: handleAutocompleteSelect,
314
483
  onKeyDown: handleKeyDown,
484
+ onSearchInputFocus: handleSearchInputFocus,
485
+ onSearchInputBlur: handleSearchInputBlur,
315
486
  onToggleDynamicFilter: handleToggleDynamicFilter,
316
487
  onSelectFilterItem: handleSelectFilterItem,
317
488
  onRemoveFilter: handleRemoveFilter,
@@ -323,4 +494,4 @@ const useSearch = () => {
323
494
 
324
495
  //#endregion
325
496
  exports.useSearch = useSearch;
326
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"index.cjs","names":["useNewOrgConfig","orgShortNameAtom","searchAtom","filteredSearchProductsAtom","performSearchAtom","autocompleteStateAtom","searchParamsAtom","isFilterOpenAtom","searchSelectedFiltersAtom","addSearchFilterAtom","removeSearchFilterAtom","searchProductSortingAtom","clearSearchFiltersAtom","searchFiltersAtom","useDebounce","getSearchResultsState","formatFilterDisplayName","ProductSorting","useAmplitude","SpiffyMetricsEventName","createFilterOption","SpiffyWidgets","handleSelectFilterItem: SelectFilterItem","SearchResultsState"],"sources":["../../../src/hooks/Search/useSearch.tsx"],"sourcesContent":["import { useAtom, useAtomValue, useSetAtom } from \"jotai\";\nimport { useCallback, useEffect, useMemo, useRef, useState } from \"react\";\nimport { useDebounce } from \"src/hooks/Debounce/useDebounce\";\nimport {\n  addSearchFilterAtom,\n  clearSearchFiltersAtom,\n  createFilterOption,\n  filteredSearchProductsAtom,\n  performSearchAtom,\n  removeSearchFilterAtom,\n  searchAtom,\n  searchFiltersAtom,\n  searchParamsAtom,\n  searchProductSortingAtom,\n  searchSelectedFiltersAtom,\n  SelectedFilterOption,\n} from \"src/atoms/search\";\nimport {\n  autocompleteStateAtom,\n  isFilterOpenAtom,\n} from \"src/atoms/globalSearch/globalSearch\";\nimport { formatFilterDisplayName } from \"src/atoms/search/utils\";\nimport { ProductSorting } from \"src/atoms/search/types\";\nimport {\n  SpiffyMetricsEventName,\n  useAmplitude,\n} from \"src/contexts/amplitudeContext/amplitudeContext\";\nimport { SpiffyWidgets } from \"src/application/models/spiffyWidgets\";\nimport { ProductCardConfig } from \"src/contexts/types\";\nimport Logger from \"src/application/logging/logger\";\nimport { SearchResult } from \"src/application/models/api/search\";\nimport { SearchResponseProduct } from \"@spiffy-ai/commerce-api-client\";\nimport {\n  SearchFilterDatum,\n  SelectFilterItem,\n} from \"src/types/search-filter-types\";\nimport { getSearchResultsState, SearchResultsState } from \"../utils\";\nimport { orgShortNameAtom } from \"src/atoms/envive/enviveConfig\";\nimport { useNewOrgConfig } from \"../NewOrgConfig\";\nimport { useTrackComponentVisibleEvent } from \"../TrackComponentVisibleEvent\";\n\nexport interface SearchResultsHocProps {\n  // Data\n  searchData: SearchResult | null;\n  searchResponseId: string;\n  merchantShortName: string;\n  productCardConfig: ProductCardConfig;\n  productList: SearchResponseProduct[];\n  autocompleteResults: string[];\n  searchFilters: SearchFilterDatum[];\n  availableDynamicFilters: { name: string; displayName: string }[];\n  selectedFilterOptions: SelectedFilterOption[];\n\n  // State\n  searchText: string;\n  searchResultsState: SearchResultsState;\n  isLoadingAutocomplete: boolean;\n  isLoadingSearch: boolean;\n  isFilterOpen: boolean;\n  isDirty: boolean;\n  focusedIndex: number;\n  focusedOptionId: string | undefined;\n\n  // UI\n  filterButtonText: string;\n\n  // Event Handlers\n  onSearchInputChange: (value: string) => void;\n  onSubmitSearch: () => void;\n  onAutocompleteSelect: (suggestion: string) => void;\n  onKeyDown: (event: React.KeyboardEvent<HTMLInputElement>) => void;\n  onToggleDynamicFilter: ({\n    filter,\n    dynamicFilterDisplayName,\n  }: {\n    filter: string;\n    dynamicFilterDisplayName: string;\n  }) => void;\n  onSelectFilterItem: SelectFilterItem;\n  onRemoveFilter: (filter: SelectedFilterOption) => void;\n  onClearAllFilters: () => void;\n  setIsFilterOpen: (isFilterOpen: boolean) => void;\n\n  // Refs\n  searchResultsRef: React.RefObject<HTMLDivElement>;\n}\n\nexport const useSearch = (): SearchResultsHocProps => {\n  // Atoms\n  const config = useNewOrgConfig();\n  const orgShortName = useAtomValue(orgShortNameAtom);\n  const { data: searchData, loading: isLoadingSearch } =\n    useAtomValue(searchAtom);\n  const productList = useAtomValue(filteredSearchProductsAtom);\n  const performSearch = useSetAtom(performSearchAtom);\n  const [\n    { results: autocompleteResults, isLoading: isLoadingAutocomplete },\n    setAutocompleteState,\n  ] = useAtom(autocompleteStateAtom);\n  const [{ query }] = useAtom(searchParamsAtom);\n  const [isFilterOpen, setIsFilterOpen] = useAtom(isFilterOpenAtom);\n  const [selectedFilterOptions] = useAtom(searchSelectedFiltersAtom);\n  const addFilter = useSetAtom(addSearchFilterAtom);\n  const removeFilter = useSetAtom(removeSearchFilterAtom);\n  const [productSorting, setProductSorting] = useAtom(searchProductSortingAtom);\n  const clearFilters = useSetAtom(clearSearchFiltersAtom);\n  const searchFilters = useAtomValue(searchFiltersAtom);\n\n  // State\n  const [isDirty, setIsDirty] = useState(true);\n  const [focusedIndex, setFocusedIndex] = useState(-1);\n  const [focusedOptionId, setFocusedOptionId] = useState<string | undefined>(\n    undefined\n  );\n  const [searchText, setSearchText] = useState(query || \"\");\n\n  // Refs\n  const searchResultsRef = useRef<HTMLDivElement>(null);\n\n  // Derived State\n  const debouncedSearchText = useDebounce(searchText, 200);\n  const searchResultsState = getSearchResultsState(isLoadingSearch, searchData);\n\n  const dynamicFilters = searchData?.filters || [];\n\n  // Provide fallback values when orgUIConfig is not yet available\n  const safeProductCardConfig = config?.frontendConfig?.uiConfigs\n    ?.productCardConfig || {\n    variant: \"minimal\",\n    hoverVariant: \"none\",\n    layoutVariant: \"square\",\n  };\n  const safeMerchantShortName = orgShortName || \"\";\n\n  const availableDynamicFilters = useMemo(() => {\n    return dynamicFilters\n      .filter(\n        (dynamicFilterName) =>\n          !selectedFilterOptions.some(\n            (option) => option.id === `dynamic:${dynamicFilterName}`\n          )\n      )\n      .map((dynamicFilterName) => ({\n        name: dynamicFilterName,\n        displayName: formatFilterDisplayName(dynamicFilterName),\n      }));\n  }, [dynamicFilters, selectedFilterOptions]);\n\n  const filters = useMemo(() => {\n    const sortOptions = [\n      {\n        filterItemId: String(ProductSorting.FEATURED),\n        displayName: \"Relevance\",\n        productCount: 0,\n        isSelected: productSorting === ProductSorting.FEATURED,\n      },\n      {\n        filterItemId: String(ProductSorting.PRICE_ASC),\n        displayName: \"Price: Low to High\",\n        productCount: 0,\n        isSelected: productSorting === ProductSorting.PRICE_ASC,\n      },\n      {\n        filterItemId: String(ProductSorting.PRICE_DESC),\n        displayName: \"Price: High to Low\",\n        productCount: 0,\n        isSelected: productSorting === ProductSorting.PRICE_DESC,\n      },\n    ];\n\n    return [\n      { filterId: \"sort\", displayName: \"SORT\", items: sortOptions },\n      ...searchFilters,\n    ] as SearchFilterDatum[];\n  }, [productSorting, searchFilters]);\n\n  const filterButtonText = useMemo(() => {\n    const selectedCount = filters.reduce((acc: number, filter) => {\n      if (filter.filterId === \"sort\") {\n        return acc;\n      }\n      return acc + filter.items.filter((item) => item.isSelected).length;\n    }, 0);\n    if (selectedCount === 0) {\n      return \"Filter & Sort\";\n    }\n    return `Filter & Sort (${selectedCount})`;\n  }, [filters]);\n\n  // Callbacks\n  const { trackEvent } = useAmplitude();\n\n  const handleToggleDynamicFilter = useCallback(\n    ({\n      filter,\n      dynamicFilterDisplayName,\n    }: {\n      filter: string;\n      dynamicFilterDisplayName: string;\n    }) => {\n      trackEvent({\n        eventName: SpiffyMetricsEventName.SearchFilterClicked,\n        eventProps: {\n          filterType: \"Dynamic\",\n          filterValue: filter,\n          queryText: searchText,\n        },\n      });\n      addFilter(\n        createFilterOption(\"dynamic\", filter, dynamicFilterDisplayName)\n      );\n    },\n    [addFilter, searchText, trackEvent]\n  );\n\n  const handleRemoveFilter = useCallback(\n    (filter: SelectedFilterOption) => {\n      removeFilter(filter.id);\n    },\n    [removeFilter]\n  );\n\n  const handleSubmitSearch = useCallback(async () => {\n    if (searchText.trim()) {\n      trackEvent({\n        eventName: SpiffyMetricsEventName.SearchQuerySubmitted,\n        eventProps: {\n          searchOrigin: SpiffyWidgets.SearchResults,\n          queryText: searchText.trim(),\n        },\n        alsoSendToGoogleAnalytics: true,\n      });\n      const url = new URL(window.location.href);\n      url.searchParams.set(\"esq\", searchText.trim());\n      window.history.pushState({}, \"\", url);\n      performSearch({ query: searchText.trim() });\n    }\n  }, [performSearch, searchText, trackEvent]);\n\n  const handleAutocompleteSelect = useCallback(\n    (suggestion: string) => {\n      setSearchText(suggestion);\n      handleSubmitSearch();\n    },\n    [handleSubmitSearch, setSearchText]\n  );\n\n  const handleKeyDown = useCallback(\n    (event: React.KeyboardEvent<HTMLInputElement>) => {\n      if (event.key === \"ArrowDown\") {\n        event.preventDefault();\n        const newIndex = (focusedIndex + 1) % autocompleteResults.length;\n        setFocusedIndex(newIndex);\n        setFocusedOptionId(`option-${newIndex}`);\n      } else if (event.key === \"ArrowUp\") {\n        event.preventDefault();\n        const newIndex =\n          (focusedIndex - 1 + autocompleteResults.length) %\n          autocompleteResults.length;\n        setFocusedIndex(newIndex);\n        setFocusedOptionId(`option-${newIndex}`);\n      } else if (event.key === \"Enter\") {\n        if (focusedIndex === -1) {\n          event.preventDefault();\n          handleSubmitSearch();\n        } else {\n          event.preventDefault();\n          const suggestionText = autocompleteResults[focusedIndex];\n          handleAutocompleteSelect(suggestionText);\n        }\n      } else if (event.key === \"Escape\") {\n        event.preventDefault();\n        setFocusedIndex(-1);\n        setFocusedOptionId(undefined);\n      }\n    },\n    [\n      autocompleteResults,\n      focusedIndex,\n      handleAutocompleteSelect,\n      handleSubmitSearch,\n    ]\n  );\n\n  const handleSearchInputChange = (newValue: string) => {\n    if (newValue.length === 1) {\n      trackEvent({\n        eventName: SpiffyMetricsEventName.SearchInputStarted,\n        eventProps: {\n          searchOrigin: SpiffyWidgets.SearchResults,\n        },\n      });\n    }\n    setSearchText(newValue);\n    setIsDirty(true);\n  };\n\n  const handleSelectFilterItem: SelectFilterItem = useCallback(\n    ({\n      filterId,\n      filterItemId,\n      isSelected,\n      displayName,\n    }: {\n      filterId: string;\n      filterItemId: string;\n      isSelected: boolean;\n      displayName: string;\n    }) => {\n      if (filterId === \"sort\") {\n        const newSort = filterItemId as ProductSorting;\n        trackEvent({\n          eventName: SpiffyMetricsEventName.SearchSortClicked,\n          eventProps: {\n            sortType: newSort,\n            queryText: searchText,\n          },\n        });\n        setProductSorting(newSort);\n      } else if (!isSelected) {\n        removeFilter(`${filterId}:${filterItemId}`);\n      } else {\n        trackEvent({\n          eventName: SpiffyMetricsEventName.SearchFilterClicked,\n          eventProps: {\n            filterType: \"Static\",\n            filterCategory: filterId,\n            filterValue: filterItemId,\n            queryText: searchText,\n          },\n        });\n        addFilter(createFilterOption(filterId, filterItemId, displayName));\n      }\n    },\n    [addFilter, removeFilter, setProductSorting, searchText, trackEvent]\n  );\n\n  const handleClearAllFilters = useCallback(() => {\n    setProductSorting(ProductSorting.FEATURED);\n    clearFilters();\n  }, [setProductSorting, clearFilters]);\n\n  // Side Effects\n  useTrackComponentVisibleEvent(\n    SpiffyWidgets.SearchResults,\n    searchResultsRef,\n    {},\n    SpiffyMetricsEventName.SearchComponentVisible\n  );\n\n  useEffect(() => {\n    if (searchResultsState === SearchResultsState.NoResults || searchResultsState === SearchResultsState.Results) {\n      trackEvent({\n        eventName: SpiffyMetricsEventName.SearchResultsViewed,\n        eventProps: {\n          queryText: searchText,\n          resultsCount: productList.length,\n        },\n      });\n    }\n  }, [productList.length, searchResultsState, trackEvent]);\n\n  useEffect(() => {\n    if (query && query !== searchText) {\n      setSearchText(query);\n    }\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [query]);\n\n  useEffect(() => {\n    const esq = new URLSearchParams(window.location.search).get(\"esq\");\n    if (esq) {\n      setSearchText(esq);\n      performSearch({ query: esq });\n    }\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [performSearch]);\n\n  const fetchAutocompleteSuggestions = (_query: string) => {\n    // TODO: implement autocomplete suggestions\n    return Promise.resolve([]);\n  };\n\n  useEffect(() => {\n    if (fetchAutocompleteSuggestions === undefined) {\n      return;\n    }\n\n    if (!isDirty || debouncedSearchText.length <= 2) {\n      setAutocompleteState({ results: [], isLoading: false });\n      return;\n    }\n\n    setAutocompleteState((prev) => ({ ...prev, isLoading: true }));\n\n    const fetchData = async () => {\n      try {\n        const results = await fetchAutocompleteSuggestions?.(\n          debouncedSearchText\n        );\n        setAutocompleteState({ results: results ?? [], isLoading: false });\n      } catch (error) {\n        Logger.logError(\"Failed to fetch autocomplete suggestions:\", error);\n        setAutocompleteState({ results: [], isLoading: false });\n      }\n    };\n\n    fetchData();\n  }, [debouncedSearchText, isDirty, setAutocompleteState]);\n\n  return {\n    searchData,\n    searchResponseId: searchData?.searchResponseId ?? \"\",\n    merchantShortName: safeMerchantShortName,\n    productCardConfig: safeProductCardConfig,\n    productList,\n    autocompleteResults,\n    searchFilters: filters,\n    availableDynamicFilters,\n    selectedFilterOptions,\n    searchText,\n    searchResultsState,\n    isLoadingAutocomplete,\n    isLoadingSearch,\n    isFilterOpen,\n    isDirty,\n    focusedIndex,\n    focusedOptionId,\n    filterButtonText,\n    onSearchInputChange: handleSearchInputChange,\n    onSubmitSearch: handleSubmitSearch,\n    onAutocompleteSelect: handleAutocompleteSelect,\n    onKeyDown: handleKeyDown,\n    onToggleDynamicFilter: handleToggleDynamicFilter,\n    onSelectFilterItem: handleSelectFilterItem,\n    onRemoveFilter: handleRemoveFilter,\n    onClearAllFilters: handleClearAllFilters,\n    setIsFilterOpen,\n    searchResultsRef,\n  };\n};\n"],"mappings":"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"}
497
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"index.cjs","names":["amplitudeTrackEventAtom","autocompleteStateAtom","Fuse","SpiffyMetricsEventName","productRetrievalFunction:\n  | ((params: ProductRetrievalParams) => Promise<ProductRetrievalResult>)\n  | null","error: unknown","useFeatureFlagService","FeatureGates","useNewOrgConfig","useNewOrgConfig","orgShortNameAtom","searchAtom","filteredSearchProductsAtom","performSearchAtom","searchParamsAtom","isFilterOpenAtom","searchSelectedFiltersAtom","addSearchFilterAtom","removeSearchFilterAtom","searchProductSortingAtom","clearSearchFiltersAtom","searchFiltersAtom","SpiffyWidgets","getSearchResultsState","formatFilterDisplayName","ProductSorting","useAmplitude","SpiffyMetricsEventName","createFilterOption","handleSelectFilterItem: SelectFilterItem","SearchResultsState"],"sources":["../../../src/hooks/Search/useSearchInput.ts","../../../src/atoms/search/productRetrievalAdapter.ts","../../../src/atoms/search/productRetrievalAPI.ts","../../../src/hooks/Search/useRecommendedProducts.ts","../../../src/hooks/Search/useSearch.tsx"],"sourcesContent":["import { useState, useCallback, useRef, useMemo } from \"react\";\nimport { useAtomValue } from \"jotai\";\nimport Fuse from \"fuse.js\";\n\nimport { autocompleteStateAtom } from \"src/atoms/globalSearch\";\nimport { amplitudeTrackEventAtom } from \"src/atoms/amplitude/amplitudeTrackEventAtom\";\nimport { SpiffyMetricsEventName } from \"src/contexts/amplitudeContext\";\nimport { SpiffyWidgets } from \"src/application/models/spiffyWidgets\";\n\nexport interface UseSearchInputProps {\n  initialSearchText?: string;\n  searchOrigin: SpiffyWidgets;\n  onSearchSubmit?: (query: string) => void;\n}\n\nexport interface UseSearchInputReturn {\n  // State\n  searchText: string;\n  hasText: boolean;\n  isFocused: boolean;\n  focusedIndex: number;\n  focusedOptionId: string | undefined;\n  autocompleteResults: string[];\n  shouldShowAutocomplete: boolean;\n  \n  // Handlers\n  handleSearchInputChange: (value: string) => void;\n  handleSearchInputFocus: () => void;\n  handleSearchInputBlur: () => void;\n  handleKeyDown: (event: React.KeyboardEvent<HTMLInputElement>) => void;\n  handleAutocompleteSelect: (suggestion: string, rankPosition?: number) => void;\n  handleSubmitSearch: () => void;\n  \n  // Utilities\n  setSearchText: (text: string) => void;\n  resetSearch: () => void;\n}\n\nexport const useSearchInput = ({\n  initialSearchText = \"\",\n  searchOrigin,\n  onSearchSubmit,\n}: UseSearchInputProps): UseSearchInputReturn => {\n  const track = useAtomValue(amplitudeTrackEventAtom);\n\n  // State\n  const [searchText, setSearchText] = useState(initialSearchText);\n  const [hasText, setHasText] = useState(initialSearchText.trim().length > 0);\n  const [isFocused, setIsFocused] = useState(false);\n  const [focusedIndex, setFocusedIndex] = useState(-1);\n  const [focusedOptionId, setFocusedOptionId] = useState<string | undefined>(\n    undefined\n  );\n  const autocompleteState = useAtomValue(autocompleteStateAtom);\n  const globalAutocompleteResults = autocompleteState.results;\n  const isAutocompleteEnabled = globalAutocompleteResults.length > 0;\n\n  // Refs\n  const isSelectingAutocomplete = useRef(false);\n\n  // Computed\n  const shouldShowAutocomplete = hasText && isFocused && isAutocompleteEnabled;\n\n  const autocompleteResultsLimit = 5;\n\n  // Configure Fuse.js for fuzzy search with custom scoring\n  const fuseOptions = useMemo(\n    () => ({\n      includeScore: true,\n      includeMatches: true,\n      // Fuzzy matching threshold (0.0 = perfect match, 1.0 = match anything)\n      threshold: 0.3,\n      // Location where match is expected (0 = beginning)\n      location: 0,\n      // Distance from location where match can be found - smaller for prefix preference\n      distance: 4,\n      // Minimum character length before fuzzy matching starts\n      minMatchCharLength: 1,\n      // Keys to search (we're searching strings directly, so no keys needed)\n      keys: [],\n      // Use extended search for exact matches and prefix matching\n      useExtendedSearch: false,\n      // Don't ignore location - this helps prioritize matches at the beginning\n      ignoreLocation: false,\n    }),\n    []\n  );\n\n  const fuse = useMemo(() => {\n    if (!globalAutocompleteResults.length) return null;\n    return new Fuse(globalAutocompleteResults, fuseOptions);\n  }, [globalAutocompleteResults, fuseOptions]);\n\n  // Autocomplete fuzzy search using Fuse.js\n  const autocompleteResults = useMemo(() => {\n    if (!isAutocompleteEnabled || !fuse) {\n      return [];\n    }\n\n    if (!searchText.trim()) {\n      return [];\n    }\n\n    const fuseResults = fuse.search(searchText);\n\n    // Use only Fuse.js scoring (results are already sorted by relevance)\n    return fuseResults\n      .slice(0, autocompleteResultsLimit)\n      .map((result) => result.item);\n  }, [isAutocompleteEnabled, fuse, searchText, autocompleteResultsLimit]);\n\n  // Handlers\n  const handleSearchInputChange = useCallback(\n    (newValue: string) => {\n      // If the user is changing text, they must be interacting with the input\n      // So we can safely assume they're focused\n      if (newValue !== searchText) {\n        setIsFocused(true);\n      }\n\n      if (newValue.length === 1) {\n        track?.({\n          eventName: SpiffyMetricsEventName.SearchInputStarted,\n          eventProps: {\n            searchOrigin,\n          },\n        });\n      }\n      setSearchText(newValue);\n      setHasText(newValue.trim().length > 0);\n      setFocusedIndex(-1);\n      setFocusedOptionId(undefined);\n    },\n    [searchOrigin, searchText, track]\n  );\n\n  const handleSearchInputFocus = useCallback(() => {\n    setIsFocused(true);\n  }, []);\n\n  const handleSearchInputBlur = useCallback(() => {\n    setTimeout(() => {\n      if (!isSelectingAutocomplete.current) {\n        setIsFocused(false);\n        setFocusedIndex(-1);\n        setFocusedOptionId(undefined);\n      }\n    }, 150);\n  }, []);\n\n  const handleSubmitSearch = useCallback(() => {\n    setIsFocused(false);\n    if (searchText.trim() && onSearchSubmit) {\n      track?.({\n        eventName: SpiffyMetricsEventName.SearchQuerySubmitted,\n        eventProps: {\n          searchOrigin,\n          queryText: searchText.trim(),\n        },\n        alsoSendToGoogleAnalytics: true,\n      });\n      onSearchSubmit(searchText.trim());\n    }\n  }, [searchText, onSearchSubmit, searchOrigin, track]);\n\n  const handleAutocompleteSelect = useCallback(\n    (suggestion: string, rankPosition?: number) => {\n      isSelectingAutocomplete.current = true;\n      setSearchText(suggestion);\n      setHasText(suggestion.trim().length > 0);\n      setIsFocused(false);\n\n      track?.({\n        eventName: SpiffyMetricsEventName.SearchInputStarted,\n        eventProps: {\n          searchOrigin,\n        },\n      });\n\n      if (onSearchSubmit) {\n        onSearchSubmit(suggestion.trim());\n      }\n\n      setTimeout(() => {\n        isSelectingAutocomplete.current = false;\n      }, 100);\n    },\n    [onSearchSubmit, searchOrigin, track]\n  );\n\n  const handleKeyDown = useCallback(\n    (event: React.KeyboardEvent<HTMLInputElement>) => {\n      if (event.key === \"ArrowDown\") {\n        event.preventDefault();\n        const newIndex = (focusedIndex + 1) % autocompleteResults.length;\n        setFocusedIndex(newIndex);\n        setFocusedOptionId(`option-${newIndex}`);\n      } else if (event.key === \"ArrowUp\") {\n        event.preventDefault();\n        const newIndex =\n          (focusedIndex - 1 + autocompleteResults.length) %\n          autocompleteResults.length;\n        setFocusedIndex(newIndex);\n        setFocusedOptionId(`option-${newIndex}`);\n      } else if (event.key === \"Enter\") {\n        if (focusedIndex === -1) {\n          event.preventDefault();\n          handleSubmitSearch();\n        } else {\n          event.preventDefault();\n          const suggestionText = autocompleteResults[focusedIndex];\n          handleAutocompleteSelect(suggestionText, focusedIndex);\n        }\n      } else if (event.key === \"Escape\") {\n        event.preventDefault();\n        setFocusedIndex(-1);\n        setFocusedOptionId(undefined);\n      }\n    },\n    [\n      autocompleteResults,\n      focusedIndex,\n      handleAutocompleteSelect,\n      handleSubmitSearch,\n    ]\n  );\n\n  const setSearchTextUtility = useCallback((text: string) => {\n    setSearchText(text);\n    setHasText(text.trim().length > 0);\n  }, []);\n\n  const resetSearch = useCallback(() => {\n    setSearchText(\"\");\n    setHasText(false);\n    setIsFocused(false);\n    setFocusedIndex(-1);\n    setFocusedOptionId(undefined);\n  }, []);\n\n  return {\n    // State\n    searchText,\n    hasText,\n    isFocused,\n    focusedIndex,\n    focusedOptionId,\n    autocompleteResults,\n    shouldShowAutocomplete,\n\n    // Handlers\n    handleSearchInputChange,\n    handleSearchInputFocus,\n    handleSearchInputBlur,\n    handleKeyDown,\n    handleAutocompleteSelect,\n    handleSubmitSearch,\n\n    // Utilities\n    setSearchText: setSearchTextUtility,\n    resetSearch,\n  };\n};","import { ProductRetrievalParams, ProductRetrievalResult } from \"./types\";\n\n// This will be set by the ProductRetrievalProvider when it initializes\nlet productRetrievalFunction:\n  | ((params: ProductRetrievalParams) => Promise<ProductRetrievalResult>)\n  | null = null;\n\nexport const setProductRetrievalFunction = (\n  fn: (params: ProductRetrievalParams) => Promise<ProductRetrievalResult>\n) => {\n  productRetrievalFunction = fn;\n};\n\nexport const getProductRetrievalFunction = () => {\n  if (!productRetrievalFunction) {\n    throw new Error(\n      \"Product retrieval function not initialized. Make sure ProductRetrievalProvider is mounted.\"\n    );\n  }\n  return productRetrievalFunction;\n};\n\nexport const clearProductRetrievalFunction = () => {\n  productRetrievalFunction = null;\n};","\nimport { atom } from \"jotai\";\nimport { getProductRetrievalFunction } from \"./productRetrievalAdapter\";\nimport { ProductRetrievalParams, ProductRetrievalResult } from \"./types\";\n\ninterface ProductRetrievalState {\n  data: ProductRetrievalResult | null;\n  loading: boolean;\n  error: string | null;\n  lastProductIds: string[] | null;\n}\n\nexport const productRetrievalAtom = atom<ProductRetrievalState>({\n  data: null,\n  loading: false,\n  error: null,\n  lastProductIds: null,\n});\n\nexport const performProductRetrievalAtom = atom(\n  null,\n  async (get, set, params: ProductRetrievalParams) => {\n    const currentState = get(productRetrievalAtom);\n\n    if (currentState.loading) {\n      return; // Prevent concurrent retrievals\n    }\n\n    set(productRetrievalAtom, {\n      data: null,\n      loading: true,\n      error: null,\n      lastProductIds: params.productIds,\n    });\n\n    try {\n      const retrieveProducts = getProductRetrievalFunction();\n      const result = await retrieveProducts(params);\n      set(productRetrievalAtom, {\n        data: result,\n        loading: false,\n        error: null,\n        lastProductIds: params.productIds,\n      });\n    } catch (error: unknown) {\n      const errorMessage =\n        error instanceof Error ? error.message : \"An unknown error occurred\";\n      set(productRetrievalAtom, {\n        data: null,\n        loading: false,\n        error: errorMessage,\n        lastProductIds: params.productIds,\n      });\n    }\n  }\n);\n\n// Get just the products array (already normalized by service)\nexport const retrievedProductsAtom = atom((get) => {\n  const retrievalData = get(productRetrievalAtom).data;\n  return retrievalData?.products || [];\n});\n\nexport const productRetrievalLoadingAtom = atom((get) => {\n  return get(productRetrievalAtom).loading;\n});\n\nexport const productRetrievalErrorAtom = atom((get) => {\n  return get(productRetrievalAtom).error;\n});","import { useAtomValue, useSetAtom } from \"jotai\";\nimport { useEffect } from \"react\";\nimport { useFeatureFlagService } from \"src/contexts/featureFlagServiceContext/featureFlagServiceContext\";\nimport {\n  retrievedProductsAtom,\n  performProductRetrievalAtom,\n  productRetrievalAtom,\n} from \"src/atoms/search/productRetrievalAPI\";\nimport { useNewOrgConfig } from \"../NewOrgConfig\";\nimport { SearchResponseProductAttributes } from \"src/application/models/api/response\";\nimport { FeatureGates } from \"src/application/models\";\n\n/**\n * A hook to get recommended products.\n * It checks the `IsRecommendedProductsEnabled` feature gate and triggers fetching if needed.\n * If the gate is enabled, it returns the list of recommended products.\n * If the gate is disabled, it returns an empty array.\n *\n * @returns The list of recommended products or an empty array.\n */\nexport const useRecommendedProducts =\n  (): SearchResponseProductAttributes[\"attributes\"][] => {\n    const { featureFlagService } = useFeatureFlagService();\n    const isEnabled = featureFlagService?.isFeatureGateEnabled(\n      FeatureGates.IsRecommendedProductsEnabled\n    );\n    const recommendedProducts = useAtomValue(retrievedProductsAtom);\n    const performProductRetrieval = useSetAtom(performProductRetrievalAtom);\n    const { lastProductIds } = useAtomValue(productRetrievalAtom);\n    const orgUIConfig = useNewOrgConfig();\n\n    useEffect(() => {\n      const recommendedProductIds = orgUIConfig.frontendConfig?.uiConfigs?.searchConfig\n        ? orgUIConfig.frontendConfig?.uiConfigs?.searchConfig.recommendedProducts\n        : [];\n      // Fetch only if the feature is enabled, there are IDs to fetch, and we haven't already fetched them.\n      if (\n        isEnabled &&\n        recommendedProductIds &&\n        recommendedProductIds.length > 0 &&\n        !lastProductIds\n      ) {\n        performProductRetrieval({ productIds: recommendedProductIds });\n      }\n    }, [isEnabled, performProductRetrieval, lastProductIds, orgUIConfig]);\n\n    return isEnabled ? recommendedProducts : [];\n  };","import { useAtom, useAtomValue, useSetAtom } from \"jotai\";\nimport { useCallback, useEffect, useMemo, useRef } from \"react\";\n\nimport {\n  addSearchFilterAtom,\n  clearSearchFiltersAtom,\n  createFilterOption,\n  filteredSearchProductsAtom,\n  performSearchAtom,\n  removeSearchFilterAtom,\n  searchAtom,\n  searchFiltersAtom,\n  searchParamsAtom,\n  searchProductSortingAtom,\n  searchSelectedFiltersAtom,\n  SelectedFilterOption,\n} from \"src/atoms/search\";\nimport {\n  isFilterOpenAtom,\n} from \"src/atoms/globalSearch/globalSearch\";\nimport { formatFilterDisplayName } from \"src/atoms/search/utils\";\nimport { ProductSorting } from \"src/atoms/search/types\";\nimport {\n  SpiffyMetricsEventName,\n  useAmplitude,\n} from \"src/contexts/amplitudeContext/amplitudeContext\";\nimport { SpiffyWidgets } from \"src/application/models/spiffyWidgets\";\nimport { ProductCardConfig } from \"src/contexts/types\";\nimport { SearchResult } from \"src/application/models/api/search\";\nimport { SearchResponseProduct } from \"@spiffy-ai/commerce-api-client\";\nimport {\n  SearchFilterDatum,\n  SelectFilterItem,\n} from \"src/types/search-filter-types\";\nimport { getSearchResultsState, SearchResultsState } from \"../utils\";\nimport { orgShortNameAtom } from \"src/atoms/envive/enviveConfig\";\nimport { useTrackComponentVisibleEvent } from \"../TrackComponentVisibleEvent\";\nimport { amplitudeTrackEventAtom } from \"src/atoms/amplitude/amplitudeTrackEventAtom\";\nimport { newOrgConfigAtom } from \"src/atoms/org\";\nimport { retrievedProductsAtom } from \"src/atoms/search/productRetrievalAPI\";\nimport { useSearchInput } from \"./useSearchInput\";\nimport { SearchResponseProductAttributes } from \"src/application/models\";\nimport { useNewOrgConfig } from \"../NewOrgConfig\";\nimport { useRecommendedProducts } from \"./useRecommendedProducts\";\n\nexport interface SearchResultsHocProps {\n  // Data\n  searchData: SearchResult | null;\n  searchResponseId: string;\n  merchantShortName: string;\n  productCardConfig: ProductCardConfig;\n  productList: SearchResponseProduct[];\n  autocompleteResults: string[];\n  searchFilters: SearchFilterDatum[];\n  availableDynamicFilters: { name: string; displayName: string }[];\n  selectedFilterOptions: SelectedFilterOption[];\n  recommendedProducts: SearchResponseProductAttributes['attributes'][];\n\n  // State\n  searchText: string;\n  query: string;\n  searchResultsState: SearchResultsState;\n  isLoadingSearch: boolean;\n  isFilterOpen: boolean;\n  shouldShowAutocomplete: boolean;\n  focusedIndex: number;\n  focusedOptionId: string | undefined;\n\n  // UI\n  filterButtonText: string;\n\n  // Event Handlers\n  onSearchInputChange: (value: string) => void;\n  onSubmitSearch: () => void;\n  onAutocompleteSelect: (suggestion: string) => void;\n  onKeyDown: (event: React.KeyboardEvent<HTMLInputElement>) => void;\n  onSearchInputFocus: () => void;\n  onSearchInputBlur: () => void;\n  onToggleDynamicFilter: ({ filter, dynamicFilterDisplayName }: { filter: string; dynamicFilterDisplayName: string }) => void;\n  onSelectFilterItem: SelectFilterItem;\n  onRemoveFilter: (filter: SelectedFilterOption) => void;\n  onClearAllFilters: () => void;\n  setIsFilterOpen: (isFilterOpen: boolean) => void;\n\n  // Refs\n  searchResultsRef: React.RefObject<HTMLDivElement>;\n}\n\nexport const useSearch = (): SearchResultsHocProps => {\n  // Atoms\n  const config = useNewOrgConfig();\n  const orgShortName = useAtomValue(orgShortNameAtom);\n  const { data: searchData, loading: isLoadingSearch } =\n    useAtomValue(searchAtom);\n  const productList = useAtomValue(filteredSearchProductsAtom);\n  const performSearch = useSetAtom(performSearchAtom);\n  const [{ query }] = useAtom(searchParamsAtom);\n  const [isFilterOpen, setIsFilterOpen] = useAtom(isFilterOpenAtom);\n  const [selectedFilterOptions] = useAtom(searchSelectedFiltersAtom);\n  const addFilter = useSetAtom(addSearchFilterAtom);\n  const removeFilter = useSetAtom(removeSearchFilterAtom);\n  const [productSorting, setProductSorting] = useAtom(searchProductSortingAtom);\n  const clearFilters = useSetAtom(clearSearchFiltersAtom);\n  const searchFilters = useAtomValue(searchFiltersAtom);\n  const recommendedProducts = useRecommendedProducts();\n\n  // Refs\n  const searchResultsRef = useRef<HTMLDivElement>(null);\n  \n  // Utilities\n  const scrollToTop = useCallback(() => {\n    const container = searchResultsRef.current;\n    if (container) {\n      container.scrollTo({ top: 0, behavior: 'smooth' });\n    } else {\n      window.scrollTo({ top: 0, behavior: 'smooth' });\n    }\n  }, []);\n  \n  // Search Input Hook\n  const searchInput = useSearchInput({\n    initialSearchText: query || '',\n    searchOrigin: SpiffyWidgets.SearchResults,\n    onSearchSubmit: (searchQuery) => {\n      performSearch({ query: searchQuery });\n    },\n  });\n  \n  const {\n    searchText,\n    focusedIndex,\n    focusedOptionId,\n    autocompleteResults,\n    shouldShowAutocomplete,\n    handleSearchInputChange,\n    handleSearchInputFocus,\n    handleSearchInputBlur,\n    handleKeyDown,\n    handleAutocompleteSelect,\n    handleSubmitSearch,\n    setSearchText,\n  } = searchInput;\n  const searchResultsState = getSearchResultsState(isLoadingSearch, searchData);\n\n  const dynamicFilters = searchData?.filters || [];\n\n  // Provide fallback values when orgUIConfig is not yet available\n  const safeProductCardConfig = config?.frontendConfig?.uiConfigs\n    ?.productCardConfig || {\n    variant: \"minimal\",\n    hoverVariant: \"none\",\n    layoutVariant: \"square\",\n  };\n  const safeMerchantShortName = orgShortName || \"\";\n\n  const availableDynamicFilters = useMemo(() => {\n    return dynamicFilters\n      .filter(\n        (dynamicFilterName) =>\n          !selectedFilterOptions.some((option) => option.id === `dynamic:${dynamicFilterName}`),\n      )\n      .map((dynamicFilterName) => ({\n        name: dynamicFilterName,\n        displayName: formatFilterDisplayName(dynamicFilterName),\n      }));\n  }, [dynamicFilters, selectedFilterOptions]);\n\n  const filters = useMemo(() => {\n    const sortOptions = [\n      {\n        filterItemId: String(ProductSorting.FEATURED),\n        displayName: 'Relevance',\n        productCount: 0,\n        isSelected: productSorting === ProductSorting.FEATURED,\n      },\n      {\n        filterItemId: String(ProductSorting.PRICE_ASC),\n        displayName: 'Price: Low to High',\n        productCount: 0,\n        isSelected: productSorting === ProductSorting.PRICE_ASC,\n      },\n      {\n        filterItemId: String(ProductSorting.PRICE_DESC),\n        displayName: 'Price: High to Low',\n        productCount: 0,\n        isSelected: productSorting === ProductSorting.PRICE_DESC,\n      },\n    ];\n\n    return [{ filterId: 'sort', displayName: 'SORT', items: sortOptions }, ...searchFilters] as SearchFilterDatum[];\n  }, [productSorting, searchFilters]);\n\n  const filterButtonText = useMemo(() => {\n    const selectedCount = filters.reduce((acc: number, filter) => {\n      if (filter.filterId === 'sort') {\n        return acc;\n      }\n      return acc + filter.items.filter((item) => item.isSelected).length;\n    }, 0);\n    if (selectedCount === 0) {\n      return 'Filter & Sort';\n    }\n    return `Filter & Sort (${selectedCount})`;\n  }, [filters]);\n\n  // Callbacks\n  const { trackEvent } = useAmplitude();\n\n\n  const handleToggleDynamicFilter = useCallback(\n    ({ filter, dynamicFilterDisplayName }: { filter: string; dynamicFilterDisplayName: string }) => {\n      trackEvent({\n        eventName: SpiffyMetricsEventName.SearchFilterClicked,\n        eventProps: {\n          filterType: 'Dynamic',\n          filterValue: filter,\n          queryText: searchText,\n        },\n      });\n      addFilter(createFilterOption('dynamic', filter, dynamicFilterDisplayName));\n      scrollToTop();\n    },\n    [addFilter, searchText, scrollToTop],\n  );\n\n  const handleRemoveFilter = useCallback(\n    (filter: SelectedFilterOption) => {\n      removeFilter(filter.id);\n      scrollToTop();\n    },\n    [removeFilter, scrollToTop],\n  );\n\n\n  const handleSelectFilterItem: SelectFilterItem = useCallback(\n    ({\n      filterId,\n      filterItemId,\n      isSelected,\n      displayName,\n    }: {\n      filterId: string;\n      filterItemId: string;\n      isSelected: boolean;\n      displayName: string;\n    }) => {\n      if (filterId === 'sort') {\n        const newSort = filterItemId as ProductSorting;\n        trackEvent({\n          eventName: SpiffyMetricsEventName.SearchSortClicked,\n          eventProps: {\n            sortType: newSort,\n            queryText: searchText,\n          },\n        });\n        setProductSorting(newSort);\n        scrollToTop();\n      } else if (!isSelected) {\n        removeFilter(`${filterId}:${filterItemId}`);\n        scrollToTop();\n      } else {\n        trackEvent({\n          eventName: SpiffyMetricsEventName.SearchFilterClicked,\n          eventProps: {\n            filterType: 'Static',\n            filterCategory: filterId,\n            filterValue: filterItemId,\n            queryText: searchText,\n          },\n        });\n        addFilter(createFilterOption(filterId, filterItemId, displayName));\n        scrollToTop();\n      }\n    },\n    [addFilter, removeFilter, setProductSorting, searchText, scrollToTop],\n  );\n\n\n  const handleClearAllFilters = useCallback(() => {\n    setProductSorting(ProductSorting.FEATURED);\n    clearFilters();\n    scrollToTop();\n  }, [setProductSorting, clearFilters, scrollToTop]);\n\n  // Side Effects\n  useTrackComponentVisibleEvent(\n    SpiffyWidgets.SearchResults,\n    searchResultsRef,\n    {},\n    SpiffyMetricsEventName.SearchComponentVisible,\n  );\n\n  useEffect(() => {\n    if (searchResultsState === SearchResultsState.Results || searchResultsState === SearchResultsState.NoResults) {\n      trackEvent({\n        eventName: SpiffyMetricsEventName.SearchResultsViewed,\n        eventProps: {\n          queryText: searchText,\n          resultsCount: productList.length,\n        },\n      });\n    }\n  }, [productList.length, searchResultsState]);\n\n  // This is the single source of truth for the search text triggering a search\n  useEffect(() => {\n    if (query && query !== searchText) {\n      const esq = new URLSearchParams(window.location.search).get('esq');\n      setSearchText(query);\n      performSearch({ query: esq ?? query });\n    }\n  // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [performSearch, query, setSearchText]);\n\n  return {\n    searchData,\n    searchResponseId: searchData?.searchResponseId ?? '',\n    merchantShortName: safeMerchantShortName,\n    productCardConfig: safeProductCardConfig,\n    productList,\n    recommendedProducts,\n    autocompleteResults,\n    searchFilters: filters,\n    availableDynamicFilters,\n    selectedFilterOptions,\n    searchText,\n    query: query || '',\n    searchResultsState,\n    isLoadingSearch,\n    isFilterOpen,\n    shouldShowAutocomplete,\n    focusedIndex,\n    focusedOptionId,\n    filterButtonText,\n    onSearchInputChange: handleSearchInputChange,\n    onSubmitSearch: handleSubmitSearch,\n    onAutocompleteSelect: handleAutocompleteSelect,\n    onKeyDown: handleKeyDown,\n    onSearchInputFocus: handleSearchInputFocus,\n    onSearchInputBlur: handleSearchInputBlur,\n    onToggleDynamicFilter: handleToggleDynamicFilter,\n    onSelectFilterItem: handleSelectFilterItem,\n    onRemoveFilter: handleRemoveFilter,\n    onClearAllFilters: handleClearAllFilters,\n    setIsFilterOpen,\n    searchResultsRef,\n  };\n};"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAsCA,MAAa,kBAAkB,EAC7B,oBAAoB,IACpB,cACA,qBAC+C;CAC/C,MAAM,gCAAqBA,qCAAwB;CAGnD,MAAM,CAAC,YAAY,qCAA0B,kBAAkB;CAC/D,MAAM,CAAC,SAAS,kCAAuB,kBAAkB,MAAM,CAAC,SAAS,EAAE;CAC3E,MAAM,CAAC,WAAW,oCAAyB,MAAM;CACjD,MAAM,CAAC,cAAc,uCAA4B,GAAG;CACpD,MAAM,CAAC,iBAAiB,0CACtB,OACD;CAED,MAAM,oDADiCC,2CAAsB,CACT;CACpD,MAAM,wBAAwB,0BAA0B,SAAS;CAGjE,MAAM,4CAAiC,MAAM;CAG7C,MAAM,yBAAyB,WAAW,aAAa;CAEvD,MAAM,2BAA2B;CAGjC,MAAM,wCACG;EACL,cAAc;EACd,gBAAgB;EAEhB,WAAW;EAEX,UAAU;EAEV,UAAU;EAEV,oBAAoB;EAEpB,MAAM,EAAE;EAER,mBAAmB;EAEnB,gBAAgB;EACjB,GACD,EAAE,CACH;CAED,MAAM,gCAAqB;AACzB,MAAI,CAAC,0BAA0B,OAAQ,QAAO;AAC9C,SAAO,IAAIC,gBAAK,2BAA2B,YAAY;IACtD,CAAC,2BAA2B,YAAY,CAAC;CAG5C,MAAM,+CAAoC;AACxC,MAAI,CAAC,yBAAyB,CAAC,KAC7B,QAAO,EAAE;AAGX,MAAI,CAAC,WAAW,MAAM,CACpB,QAAO,EAAE;AAMX,SAHoB,KAAK,OAAO,WAAW,CAIxC,MAAM,GAAG,yBAAyB,CAClC,KAAK,WAAW,OAAO,KAAK;IAC9B;EAAC;EAAuB;EAAM;EAAY;EAAyB,CAAC;CAGvE,MAAM,kDACH,aAAqB;AAGpB,MAAI,aAAa,WACf,cAAa,KAAK;AAGpB,MAAI,SAAS,WAAW,EACtB,SAAQ;GACN,WAAWC,gDAAuB;GAClC,YAAY,EACV,cACD;GACF,CAAC;AAEJ,gBAAc,SAAS;AACvB,aAAW,SAAS,MAAM,CAAC,SAAS,EAAE;AACtC,kBAAgB,GAAG;AACnB,qBAAmB,OAAU;IAE/B;EAAC;EAAc;EAAY;EAAM,CAClC;CAED,MAAM,sDAA2C;AAC/C,eAAa,KAAK;IACjB,EAAE,CAAC;CAEN,MAAM,qDAA0C;AAC9C,mBAAiB;AACf,OAAI,CAAC,wBAAwB,SAAS;AACpC,iBAAa,MAAM;AACnB,oBAAgB,GAAG;AACnB,uBAAmB,OAAU;;KAE9B,IAAI;IACN,EAAE,CAAC;CAEN,MAAM,kDAAuC;AAC3C,eAAa,MAAM;AACnB,MAAI,WAAW,MAAM,IAAI,gBAAgB;AACvC,WAAQ;IACN,WAAWA,gDAAuB;IAClC,YAAY;KACV;KACA,WAAW,WAAW,MAAM;KAC7B;IACD,2BAA2B;IAC5B,CAAC;AACF,kBAAe,WAAW,MAAM,CAAC;;IAElC;EAAC;EAAY;EAAgB;EAAc;EAAM,CAAC;CAErD,MAAM,mDACH,YAAoB,iBAA0B;AAC7C,0BAAwB,UAAU;AAClC,gBAAc,WAAW;AACzB,aAAW,WAAW,MAAM,CAAC,SAAS,EAAE;AACxC,eAAa,MAAM;AAEnB,UAAQ;GACN,WAAWA,gDAAuB;GAClC,YAAY,EACV,cACD;GACF,CAAC;AAEF,MAAI,eACF,gBAAe,WAAW,MAAM,CAAC;AAGnC,mBAAiB;AACf,2BAAwB,UAAU;KACjC,IAAI;IAET;EAAC;EAAgB;EAAc;EAAM,CACtC;CAED,MAAM,wCACH,UAAiD;AAChD,MAAI,MAAM,QAAQ,aAAa;AAC7B,SAAM,gBAAgB;GACtB,MAAM,YAAY,eAAe,KAAK,oBAAoB;AAC1D,mBAAgB,SAAS;AACzB,sBAAmB,UAAU,WAAW;aAC/B,MAAM,QAAQ,WAAW;AAClC,SAAM,gBAAgB;GACtB,MAAM,YACH,eAAe,IAAI,oBAAoB,UACxC,oBAAoB;AACtB,mBAAgB,SAAS;AACzB,sBAAmB,UAAU,WAAW;aAC/B,MAAM,QAAQ,QACvB,KAAI,iBAAiB,IAAI;AACvB,SAAM,gBAAgB;AACtB,uBAAoB;SACf;AACL,SAAM,gBAAgB;GACtB,MAAM,iBAAiB,oBAAoB;AAC3C,4BAAyB,gBAAgB,aAAa;;WAE/C,MAAM,QAAQ,UAAU;AACjC,SAAM,gBAAgB;AACtB,mBAAgB,GAAG;AACnB,sBAAmB,OAAU;;IAGjC;EACE;EACA;EACA;EACA;EACD,CACF;CAED,MAAM,+CAAoC,SAAiB;AACzD,gBAAc,KAAK;AACnB,aAAW,KAAK,MAAM,CAAC,SAAS,EAAE;IACjC,EAAE,CAAC;CAEN,MAAM,2CAAgC;AACpC,gBAAc,GAAG;AACjB,aAAW,MAAM;AACjB,eAAa,MAAM;AACnB,kBAAgB,GAAG;AACnB,qBAAmB,OAAU;IAC5B,EAAE,CAAC;AAEN,QAAO;EAEL;EACA;EACA;EACA;EACA;EACA;EACA;EAGA;EACA;EACA;EACA;EACA;EACA;EAGA,eAAe;EACf;EACD;;;;;AClQH,IAAIC,2BAEO;AAQX,MAAa,oCAAoC;AAC/C,KAAI,CAAC,yBACH,OAAM,IAAI,MACR,6FACD;AAEH,QAAO;;;;;ACPT,MAAa,uCAAmD;CAC9D,MAAM;CACN,SAAS;CACT,OAAO;CACP,gBAAgB;CACjB,CAAC;AAEF,MAAa,8CACX,MACA,OAAO,KAAK,KAAK,WAAmC;AAGlD,KAFqB,IAAI,qBAAqB,CAE7B,QACf;AAGF,KAAI,sBAAsB;EACxB,MAAM;EACN,SAAS;EACT,OAAO;EACP,gBAAgB,OAAO;EACxB,CAAC;AAEF,KAAI;EAEF,MAAM,SAAS,MADU,6BAA6B,CAChB,OAAO;AAC7C,MAAI,sBAAsB;GACxB,MAAM;GACN,SAAS;GACT,OAAO;GACP,gBAAgB,OAAO;GACxB,CAAC;UACKC,OAAgB;EACvB,MAAM,eACJ,iBAAiB,QAAQ,MAAM,UAAU;AAC3C,MAAI,sBAAsB;GACxB,MAAM;GACN,SAAS;GACT,OAAO;GACP,gBAAgB,OAAO;GACxB,CAAC;;EAGP;AAGD,MAAa,yCAA8B,QAAQ;AAEjD,QADsB,IAAI,qBAAqB,CAAC,MAC1B,YAAY,EAAE;EACpC;AAEF,MAAa,+CAAoC,QAAQ;AACvD,QAAO,IAAI,qBAAqB,CAAC;EACjC;AAEF,MAAa,6CAAkC,QAAQ;AACrD,QAAO,IAAI,qBAAqB,CAAC;EACjC;;;;;;;;;;;;ACjDF,MAAa,+BAC4C;CACrD,MAAM,EAAE,uBAAuBC,yDAAuB;CACtD,MAAM,YAAY,oBAAoB,qBACpCC,kCAAa,6BACd;CACD,MAAM,8CAAmC,sBAAsB;CAC/D,MAAM,gDAAqC,4BAA4B;CACvE,MAAM,EAAE,2CAAgC,qBAAqB;CAC7D,MAAM,cAAcC,sCAAiB;AAErC,4BAAgB;EACd,MAAM,wBAAwB,YAAY,gBAAgB,WAAW,eACjE,YAAY,gBAAgB,WAAW,aAAa,sBACpD,EAAE;AAEN,MACE,aACA,yBACA,sBAAsB,SAAS,KAC/B,CAAC,eAED,yBAAwB,EAAE,YAAY,uBAAuB,CAAC;IAE/D;EAAC;EAAW;EAAyB;EAAgB;EAAY,CAAC;AAErE,QAAO,YAAY,sBAAsB,EAAE;;;;;AC0C/C,MAAa,kBAAyC;CAEpD,MAAM,SAASC,sCAAiB;CAChC,MAAM,uCAA4BC,sCAAiB;CACnD,MAAM,EAAE,MAAM,YAAY,SAAS,4CACpBC,0BAAW;CAC1B,MAAM,sCAA2BC,0CAA2B;CAC5D,MAAM,sCAA2BC,iCAAkB;CACnD,MAAM,CAAC,EAAE,8BAAmBC,gCAAiB;CAC7C,MAAM,CAAC,cAAc,sCAA2BC,sCAAiB;CACjE,MAAM,CAAC,4CAAiCC,yCAA0B;CAClE,MAAM,kCAAuBC,mCAAoB;CACjD,MAAM,qCAA0BC,sCAAuB;CACvD,MAAM,CAAC,gBAAgB,wCAA6BC,wCAAyB;CAC7E,MAAM,qCAA0BC,sCAAuB;CACvD,MAAM,wCAA6BC,iCAAkB;CACrD,MAAM,sBAAsB,wBAAwB;CAGpD,MAAM,qCAA0C,KAAK;CAGrD,MAAM,2CAAgC;EACpC,MAAM,YAAY,iBAAiB;AACnC,MAAI,UACF,WAAU,SAAS;GAAE,KAAK;GAAG,UAAU;GAAU,CAAC;MAElD,QAAO,SAAS;GAAE,KAAK;GAAG,UAAU;GAAU,CAAC;IAEhD,EAAE,CAAC;CAWN,MAAM,EACJ,YACA,cACA,iBACA,qBACA,wBACA,yBACA,wBACA,uBACA,eACA,0BACA,oBACA,kBApBkB,eAAe;EACjC,mBAAmB,SAAS;EAC5B,cAAcC,6BAAc;EAC5B,iBAAiB,gBAAgB;AAC/B,iBAAc,EAAE,OAAO,aAAa,CAAC;;EAExC,CAAC;CAgBF,MAAM,qBAAqBC,oCAAsB,iBAAiB,WAAW;CAE7E,MAAM,iBAAiB,YAAY,WAAW,EAAE;CAGhD,MAAM,wBAAwB,QAAQ,gBAAgB,WAClD,qBAAqB;EACvB,SAAS;EACT,cAAc;EACd,eAAe;EAChB;CACD,MAAM,wBAAwB,gBAAgB;CAE9C,MAAM,mDAAwC;AAC5C,SAAO,eACJ,QACE,sBACC,CAAC,sBAAsB,MAAM,WAAW,OAAO,OAAO,WAAW,oBAAoB,CACxF,CACA,KAAK,uBAAuB;GAC3B,MAAM;GACN,aAAaC,wCAAwB,kBAAkB;GACxD,EAAE;IACJ,CAAC,gBAAgB,sBAAsB,CAAC;CAE3C,MAAM,mCAAwB;AAsB5B,SAAO,CAAC;GAAE,UAAU;GAAQ,aAAa;GAAQ,OArB7B;IAClB;KACE,cAAc,OAAOC,+BAAe,SAAS;KAC7C,aAAa;KACb,cAAc;KACd,YAAY,mBAAmBA,+BAAe;KAC/C;IACD;KACE,cAAc,OAAOA,+BAAe,UAAU;KAC9C,aAAa;KACb,cAAc;KACd,YAAY,mBAAmBA,+BAAe;KAC/C;IACD;KACE,cAAc,OAAOA,+BAAe,WAAW;KAC/C,aAAa;KACb,cAAc;KACd,YAAY,mBAAmBA,+BAAe;KAC/C;IACF;GAEoE,EAAE,GAAG,cAAc;IACvF,CAAC,gBAAgB,cAAc,CAAC;CAEnC,MAAM,4CAAiC;EACrC,MAAM,gBAAgB,QAAQ,QAAQ,KAAa,WAAW;AAC5D,OAAI,OAAO,aAAa,OACtB,QAAO;AAET,UAAO,MAAM,OAAO,MAAM,QAAQ,SAAS,KAAK,WAAW,CAAC;KAC3D,EAAE;AACL,MAAI,kBAAkB,EACpB,QAAO;AAET,SAAO,kBAAkB,cAAc;IACtC,CAAC,QAAQ,CAAC;CAGb,MAAM,EAAE,eAAeC,uCAAc;CAGrC,MAAM,oDACH,EAAE,QAAQ,+BAAqF;AAC9F,aAAW;GACT,WAAWC,gDAAuB;GAClC,YAAY;IACV,YAAY;IACZ,aAAa;IACb,WAAW;IACZ;GACF,CAAC;AACF,YAAUC,kCAAmB,WAAW,QAAQ,yBAAyB,CAAC;AAC1E,eAAa;IAEf;EAAC;EAAW;EAAY;EAAY,CACrC;CAED,MAAM,6CACH,WAAiC;AAChC,eAAa,OAAO,GAAG;AACvB,eAAa;IAEf,CAAC,cAAc,YAAY,CAC5B;CAGD,MAAMC,iDACH,EACC,UACA,cACA,YACA,kBAMI;AACJ,MAAI,aAAa,QAAQ;GACvB,MAAM,UAAU;AAChB,cAAW;IACT,WAAWF,gDAAuB;IAClC,YAAY;KACV,UAAU;KACV,WAAW;KACZ;IACF,CAAC;AACF,qBAAkB,QAAQ;AAC1B,gBAAa;aACJ,CAAC,YAAY;AACtB,gBAAa,GAAG,SAAS,GAAG,eAAe;AAC3C,gBAAa;SACR;AACL,cAAW;IACT,WAAWA,gDAAuB;IAClC,YAAY;KACV,YAAY;KACZ,gBAAgB;KAChB,aAAa;KACb,WAAW;KACZ;IACF,CAAC;AACF,aAAUC,kCAAmB,UAAU,cAAc,YAAY,CAAC;AAClE,gBAAa;;IAGjB;EAAC;EAAW;EAAc;EAAmB;EAAY;EAAY,CACtE;CAGD,MAAM,qDAA0C;AAC9C,oBAAkBH,+BAAe,SAAS;AAC1C,gBAAc;AACd,eAAa;IACZ;EAAC;EAAmB;EAAc;EAAY,CAAC;AAGlD,kEACEH,6BAAc,eACd,kBACA,EAAE,EACFK,gDAAuB,uBACxB;AAED,4BAAgB;AACd,MAAI,uBAAuBG,iCAAmB,WAAW,uBAAuBA,iCAAmB,UACjG,YAAW;GACT,WAAWH,gDAAuB;GAClC,YAAY;IACV,WAAW;IACX,cAAc,YAAY;IAC3B;GACF,CAAC;IAEH,CAAC,YAAY,QAAQ,mBAAmB,CAAC;AAG5C,4BAAgB;AACd,MAAI,SAAS,UAAU,YAAY;GACjC,MAAM,MAAM,IAAI,gBAAgB,OAAO,SAAS,OAAO,CAAC,IAAI,MAAM;AAClE,iBAAc,MAAM;AACpB,iBAAc,EAAE,OAAO,OAAO,OAAO,CAAC;;IAGvC;EAAC;EAAe;EAAO;EAAc,CAAC;AAEzC,QAAO;EACL;EACA,kBAAkB,YAAY,oBAAoB;EAClD,mBAAmB;EACnB,mBAAmB;EACnB;EACA;EACA;EACA,eAAe;EACf;EACA;EACA;EACA,OAAO,SAAS;EAChB;EACA;EACA;EACA;EACA;EACA;EACA;EACA,qBAAqB;EACrB,gBAAgB;EAChB,sBAAsB;EACtB,WAAW;EACX,oBAAoB;EACpB,mBAAmB;EACnB,uBAAuB;EACvB,oBAAoB;EACpB,gBAAgB;EAChB,mBAAmB;EACnB;EACA;EACD"}