@envive-ai/react-hooks 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (385) hide show
  1. package/LICENSE +2 -0
  2. package/README.md +2 -0
  3. package/dist/GridInsertionService-CEYo9pGj.js +22 -0
  4. package/dist/GridInsertionService-CS_bnPh0.cjs +28 -0
  5. package/dist/bandolier-Ble8jEa8.js +1221 -0
  6. package/dist/bandolier-Bm2xAt_j.cjs +1221 -0
  7. package/dist/carpe-Da7b-LCW.cjs +599 -0
  8. package/dist/carpe-W13mhRRP.js +597 -0
  9. package/dist/cdnService-CZ-aXcY6.cjs +23 -0
  10. package/dist/cdnService-zQfKk3Eb.js +18 -0
  11. package/dist/chatElementDisplayLocation-CX8fuNao.d.cts +239 -0
  12. package/dist/chatElementDisplayLocation-CwptS9tx.d.ts +239 -0
  13. package/dist/chunk-CUT6urMc.cjs +30 -0
  14. package/dist/contexts/index.cjs +13 -0
  15. package/dist/contexts/index.d.cts +65 -0
  16. package/dist/contexts/index.d.ts +66 -0
  17. package/dist/contexts/index.js +7 -0
  18. package/dist/contexts-BRjfVq_k.js +5064 -0
  19. package/dist/contexts-BYArqZtK.cjs +5164 -0
  20. package/dist/coterie-3y0D9ko4.cjs +229 -0
  21. package/dist/coterie-DOWcJAYv.js +229 -0
  22. package/dist/custservice-types-CFIFwZ-r.js +10 -0
  23. package/dist/custservice-types-CkfxZiHY.cjs +16 -0
  24. package/dist/default-C2fEZKXk.js +175 -0
  25. package/dist/default-CBUq6Q6G.cjs +4 -0
  26. package/dist/default-CGIFZK6m.js +4 -0
  27. package/dist/default-D_KPZdPJ.cjs +198 -0
  28. package/dist/divIds-Bss-btao.js +49 -0
  29. package/dist/divIds-DnZNd7rA.cjs +223 -0
  30. package/dist/dreamlandBaby-DCIsuU9R.cjs +338 -0
  31. package/dist/dreamlandBaby-DvSaZGrz.js +338 -0
  32. package/dist/entrypoints-D_JUvkgy.cjs +18 -0
  33. package/dist/entrypoints-YLQsbBRD.js +6 -0
  34. package/dist/enviveConfigContext-CUGLpPGU.js +34 -0
  35. package/dist/enviveConfigContext-Dfr2VH6u.cjs +48 -0
  36. package/dist/fiveCbd-B1SESMCO.js +605 -0
  37. package/dist/fiveCbd-CkOlVby_.cjs +605 -0
  38. package/dist/forLoveAndLemons-CfYPMnKS.cjs +660 -0
  39. package/dist/forLoveAndLemons-DmwYZIk0.js +658 -0
  40. package/dist/greenpan-Bsl3ir59.cjs +389 -0
  41. package/dist/greenpan-BtOi45lf.js +389 -0
  42. package/dist/grooveLife-6_dtYsRk.js +334 -0
  43. package/dist/grooveLife-Cmm1PSCL.cjs +334 -0
  44. package/dist/homegrownCannabis-C-kw-74X.js +400 -0
  45. package/dist/homegrownCannabis-CO0uY_mp.cjs +400 -0
  46. package/dist/hooks/index.cjs +16 -0
  47. package/dist/hooks/index.d.cts +357 -0
  48. package/dist/hooks/index.d.ts +357 -0
  49. package/dist/hooks/index.js +7 -0
  50. package/dist/jackArcher-CLVmwwpI.js +719 -0
  51. package/dist/jackArcher-DdYTIzAV.cjs +719 -0
  52. package/dist/jordanCraig-Am-Oor-O.js +1778 -0
  53. package/dist/jordanCraig-_u3-w4Hp.cjs +1778 -0
  54. package/dist/kindredBravely-CWovIDSc.cjs +482 -0
  55. package/dist/kindredBravely-eWp-ud_E.js +482 -0
  56. package/dist/kutFromTheKloth-BMV4BuGQ.js +361 -0
  57. package/dist/kutFromTheKloth-Q589bAOC.cjs +361 -0
  58. package/dist/larryAndSerges-BMUlTgI-.js +252 -0
  59. package/dist/larryAndSerges-CEau764j.cjs +252 -0
  60. package/dist/leapsAndRebounds-DGMzPO7T.js +352 -0
  61. package/dist/leapsAndRebounds-DHAtRTJD.cjs +352 -0
  62. package/dist/logger-Dln20ans.cjs +25 -0
  63. package/dist/logger-pdEEY8T2.js +19 -0
  64. package/dist/longevityrx-CZW8Hxzi.cjs +312 -0
  65. package/dist/longevityrx-jH2JLhNH.js +312 -0
  66. package/dist/lookOptic-BGXP5P_V.js +274 -0
  67. package/dist/lookOptic-CA6RwLbG.cjs +274 -0
  68. package/dist/mantraBrand-Cm9_PBCT.js +742 -0
  69. package/dist/mantraBrand-DByNqpnL.cjs +742 -0
  70. package/dist/medterra-B0wxj_PV.js +575 -0
  71. package/dist/medterra-DnPN2ksU.cjs +575 -0
  72. package/dist/modells-Bmz8Ag5M.js +476 -0
  73. package/dist/modells-CoYgkLSp.cjs +476 -0
  74. package/dist/models-DHdb7QWn.js +51 -0
  75. package/dist/models-ixxUsGL_.cjs +69 -0
  76. package/dist/pressedFloral-DSKs_oVG.js +653 -0
  77. package/dist/pressedFloral-DjBiSoUl.cjs +653 -0
  78. package/dist/skinPerfection-B_3xzVNS.cjs +326 -0
  79. package/dist/skinPerfection-IDrBuAPt.js +326 -0
  80. package/dist/snapSupplements-BJk5T5ba.js +277 -0
  81. package/dist/snapSupplements-BStTsdOZ.cjs +277 -0
  82. package/dist/socialProofClasses-Bhv2Vulz.js +9 -0
  83. package/dist/socialProofClasses-CrQBWdSA.cjs +39 -0
  84. package/dist/spanx-BYg0LE7R.js +653 -0
  85. package/dist/spanx-LwU1zSzq.cjs +655 -0
  86. package/dist/spanxStaging-CfSmuKYB.js +837 -0
  87. package/dist/spanxStaging-OZLV9qix.cjs +840 -0
  88. package/dist/suggestionBarV2-types-BllzwsBD.js +34 -0
  89. package/dist/suggestionBarV2-types-CaovchMP.cjs +46 -0
  90. package/dist/supergoop-BqPXDnKk.cjs +327 -0
  91. package/dist/supergoop-CIlrHND_.js +325 -0
  92. package/dist/types-C4T5UOIW.cjs +230 -0
  93. package/dist/types-CYNvLeSA.js +176 -0
  94. package/dist/uniqueVintage-B30mOqbH.cjs +1205 -0
  95. package/dist/uniqueVintage-CFueJOhO.js +1203 -0
  96. package/dist/venaCbd-DHGZy49P.cjs +357 -0
  97. package/dist/venaCbd-T0CqVD4k.js +357 -0
  98. package/dist/westonJonBoucher-BdMzs_Yg.cjs +414 -0
  99. package/dist/westonJonBoucher-b4TCQ4ev.js +414 -0
  100. package/dist/wineEnthusiast-BLGlOjgr.cjs +932 -0
  101. package/dist/wineEnthusiast-BqR0i_54.js +932 -0
  102. package/dist/wolfMattress-CyyO-LoC.js +362 -0
  103. package/dist/wolfMattress-DNGZOivg.cjs +362 -0
  104. package/dist/wolfTactical-3Mm2fvVF.js +341 -0
  105. package/dist/wolfTactical-BmXYlFjr.cjs +341 -0
  106. package/package.json +66 -0
  107. package/src/adapters/amplitude/amplitudeAdapter.ts +454 -0
  108. package/src/adapters/amplitude/index.ts +2 -0
  109. package/src/adapters/amplitude/stubAmplitudeAdapter.ts +34 -0
  110. package/src/adapters/spiffy/commerce/api.ts +596 -0
  111. package/src/adapters/spiffy/commerce/exceptions/sessionExceptions.ts +6 -0
  112. package/src/adapters/spiffy/commerce/exceptions/unsupportedProductExceptions.ts +6 -0
  113. package/src/adapters/spiffy/commerce/graphql.ts +184 -0
  114. package/src/application/config/generalStaticConfig.ts +37 -0
  115. package/src/application/logging/logger.ts +29 -0
  116. package/src/application/models/api/context.ts +4 -0
  117. package/src/application/models/api/generationParams.ts +4 -0
  118. package/src/application/models/api/nextMessageRequest.ts +11 -0
  119. package/src/application/models/api/orgAnalyticsConfig.ts +19 -0
  120. package/src/application/models/api/orgConfigResults.ts +40 -0
  121. package/src/application/models/api/organizationConfig.ts +12 -0
  122. package/src/application/models/api/response.ts +132 -0
  123. package/src/application/models/api/responseGenerics.ts +67 -0
  124. package/src/application/models/api/search.ts +26 -0
  125. package/src/application/models/api/suggestion.ts +4 -0
  126. package/src/application/models/api/supportedEventRequest.ts +8 -0
  127. package/src/application/models/api/userEvent.ts +101 -0
  128. package/src/application/models/cachedValue.ts +8 -0
  129. package/src/application/models/chatElementDisplayLocation.ts +22 -0
  130. package/src/application/models/clientDetails.ts +18 -0
  131. package/src/application/models/colorsConfig.ts +28 -0
  132. package/src/application/models/conversationalSearchIds.ts +5 -0
  133. package/src/application/models/dataLayer.ts +45 -0
  134. package/src/application/models/domMutationContinuation.ts +7 -0
  135. package/src/application/models/domObservationStrategy.ts +9 -0
  136. package/src/application/models/events.ts +5 -0
  137. package/src/application/models/featureGates.ts +23 -0
  138. package/src/application/models/frontendConfig.ts +14 -0
  139. package/src/application/models/googleAnalyticsEvents.ts +8 -0
  140. package/src/application/models/graphql/index.ts +2 -0
  141. package/src/application/models/graphql/queries/getMerchantColorsQuery.ts +37 -0
  142. package/src/application/models/graphql/queries/getMerchantFrontendConfigQuery.ts +103 -0
  143. package/src/application/models/graphql/queries/getMerchantOrgIdQuery.ts +11 -0
  144. package/src/application/models/guards/api/index.ts +12 -0
  145. package/src/application/models/guards/api/isApiFormResponse.ts +90 -0
  146. package/src/application/models/guards/api/isApiFormSubmittedResponseAttributes.ts +37 -0
  147. package/src/application/models/guards/api/isApiOrderResponseAttributes.ts +155 -0
  148. package/src/application/models/guards/api/isApiOrgConfigResults.ts +277 -0
  149. package/src/application/models/guards/api/isApiOrganizationConfig.ts +207 -0
  150. package/src/application/models/guards/api/isApiPDPEventAttributes.ts +21 -0
  151. package/src/application/models/guards/api/isApiPLPEventAttributes.ts +41 -0
  152. package/src/application/models/guards/api/isApiPageResponseAttributes.ts +21 -0
  153. package/src/application/models/guards/api/isApiProductResponseAttributes.ts +85 -0
  154. package/src/application/models/guards/api/isApiProductSearchAttributes.ts +23 -0
  155. package/src/application/models/guards/api/isApiProductSearchFilterAttributes.ts +15 -0
  156. package/src/application/models/guards/api/isApiQueryTypedEventAttributes.ts +4 -0
  157. package/src/application/models/guards/api/isApiResponse.ts +39 -0
  158. package/src/application/models/guards/api/isApiReviewResponseAttributes.ts +30 -0
  159. package/src/application/models/guards/api/isApiReviewRichInformation.ts +37 -0
  160. package/src/application/models/guards/api/isApiSearchEventAttributes.ts +28 -0
  161. package/src/application/models/guards/api/isApiSuggestion.ts +36 -0
  162. package/src/application/models/guards/api/isApiSuggestionClickedEventAttributes.ts +9 -0
  163. package/src/application/models/guards/api/isApiTextResponseAttributes.ts +9 -0
  164. package/src/application/models/guards/api/isApiUserEvent.ts +25 -0
  165. package/src/application/models/guards/graphQL/isGraphQLColorsConfig.ts +50 -0
  166. package/src/application/models/guards/isBaseEcommerceEvent.ts +17 -0
  167. package/src/application/models/guards/isGA4EcommerceEvent.ts +17 -0
  168. package/src/application/models/guards/isLegacyUAEcommerceEvent.ts +17 -0
  169. package/src/application/models/guards/isMobilePLPChatPlacementParameter.ts +11 -0
  170. package/src/application/models/guards/isSpanxTakeAQuizCtaParameter.ts +4 -0
  171. package/src/application/models/guards/isVariantInfo.ts +37 -0
  172. package/src/application/models/guards/utils.ts +43 -0
  173. package/src/application/models/index.ts +20 -0
  174. package/src/application/models/localStorageEventListener.ts +4 -0
  175. package/src/application/models/message.ts +146 -0
  176. package/src/application/models/mobilePLPChatPlacementParameter.ts +3 -0
  177. package/src/application/models/orgsEnum.ts +36 -0
  178. package/src/application/models/productExperiment.ts +5 -0
  179. package/src/application/models/spanxTakeAQuizCtaParameter.ts +4 -0
  180. package/src/application/models/spiffyWidgets.ts +16 -0
  181. package/src/application/models/supportedOrgs.ts +137 -0
  182. package/src/application/models/utilityTypes/camelCase.ts +87 -0
  183. package/src/application/models/utilityTypes/camelCasedPropertiesDeep.ts +80 -0
  184. package/src/application/models/utilityTypes/delimiterCase.ts +121 -0
  185. package/src/application/models/utilityTypes/delimiterCasedPropertiesDeep.ts +98 -0
  186. package/src/application/models/utilityTypes/index.ts +1 -0
  187. package/src/application/models/utilityTypes/internal.ts +93 -0
  188. package/src/application/models/utilityTypes/primitive.ts +8 -0
  189. package/src/application/models/utilityTypes/snakeCasedPropertiesDeep.ts +49 -0
  190. package/src/application/models/utilityTypes/splitWords.ts +76 -0
  191. package/src/application/models/utilityTypes/trim.ts +28 -0
  192. package/src/application/models/utilityTypes/unknownArray.ts +25 -0
  193. package/src/application/models/utils/snakeToCamelTransformer.ts +90 -0
  194. package/src/application/models/utils/stringToFulfillmentDisplayStatusEnumValue.ts +68 -0
  195. package/src/application/models/validators/validateGraphQLColorsConfig.ts +29 -0
  196. package/src/application/models/validators/validateGraphQLFrontendConfig.ts +594 -0
  197. package/src/application/models/validators/validateGraphQLOrgId.ts +7 -0
  198. package/src/application/models/validators/validateMobilePLPChatPlacementParameter.ts +14 -0
  199. package/src/application/models/validators/validateOrgConfigResults.ts +47 -0
  200. package/src/application/models/validators/validateOrganizationConfig.ts +37 -0
  201. package/src/application/models/validators/validateResponse.ts +187 -0
  202. package/src/application/models/validators/validateSuggestion.ts +16 -0
  203. package/src/application/models/validators/validateUserEvent.ts +110 -0
  204. package/src/application/models/variantInfo/index.ts +1 -0
  205. package/src/application/models/variantInfo/pageVisitInfo.ts +6 -0
  206. package/src/application/models/variantInfo/plpInfo.ts +3 -0
  207. package/src/application/models/variantInfo/productInfo.ts +5 -0
  208. package/src/application/models/variantInfo/variantInfo.ts +23 -0
  209. package/src/application/service/cachingService.ts +84 -0
  210. package/src/application/service/cdnService.ts +18 -0
  211. package/src/application/service/customerService/index.ts +8 -0
  212. package/src/application/service/customerService/providers/UnsupportedCustomerService.ts +15 -0
  213. package/src/application/service/customerService/types.ts +31 -0
  214. package/src/application/service/domMutationObserver.ts +320 -0
  215. package/src/application/service/domMutations/GridInsertionService.ts +123 -0
  216. package/src/application/service/domMutations/dataLayer/dataLayerEventsListener.ts +99 -0
  217. package/src/application/service/domMutations/domInsertionService.ts +90 -0
  218. package/src/application/service/domMutations/domMutationListener.ts +15 -0
  219. package/src/application/service/domMutations/domMutationListenerState.ts +52 -0
  220. package/src/application/service/domMutations/floatingChat/embeddedChatsPlacementsListener.ts +41 -0
  221. package/src/application/service/domMutations/gladly/gladlyListener.ts +61 -0
  222. package/src/application/service/domMutations/spiffy/orgs/common/kustomerVisibilityListener.ts +41 -0
  223. package/src/application/service/domMutations/spiffy/orgs/common/orgsCommonDataLayerListener.ts +119 -0
  224. package/src/application/service/environmentService.ts +51 -0
  225. package/src/application/service/featureFlagService.ts +130 -0
  226. package/src/application/service/kustomerIntegrationService.ts +111 -0
  227. package/src/application/service/localStorageService.ts +77 -0
  228. package/src/application/service/pageVariantService.ts +779 -0
  229. package/src/application/service/searchService.ts +140 -0
  230. package/src/application/service/sessionStorageService.ts +27 -0
  231. package/src/application/service/shopifyUrlService.ts +63 -0
  232. package/src/application/service/userIdentityService.ts +114 -0
  233. package/src/application/service/windowChatToggleService.ts +71 -0
  234. package/src/application/service/windowDataLayerService.ts +181 -0
  235. package/src/application/service/windowFrontendConfigService.ts +104 -0
  236. package/src/application/utils/__tests__/divideArrays.test.ts +14 -0
  237. package/src/application/utils/analyticsUtils.ts +110 -0
  238. package/src/application/utils/coreContextToApiContext.ts +11 -0
  239. package/src/application/utils/coreUserEventToApiUserEvent.ts +106 -0
  240. package/src/application/utils/divideArray.ts +7 -0
  241. package/src/application/utils/domObserver.ts +96 -0
  242. package/src/application/utils/elementObserver.ts +246 -0
  243. package/src/application/utils/imageFilter.ts +12 -0
  244. package/src/application/utils/index.ts +3 -0
  245. package/src/application/utils/merchantUtils.ts +16 -0
  246. package/src/application/utils/messageFromFormSubmittedEvent.ts +31 -0
  247. package/src/application/utils/messageFromQueryEvent.ts +38 -0
  248. package/src/application/utils/messageFromResponse.ts +133 -0
  249. package/src/application/utils/messageFromSuggestionEvent.ts +32 -0
  250. package/src/application/utils/mouseEventTypes.ts +1 -0
  251. package/src/application/utils/mutationHelper.ts +51 -0
  252. package/src/application/utils/nextMessageRequestToApiRequest.ts +31 -0
  253. package/src/application/utils/nodeSelector.ts +133 -0
  254. package/src/application/utils/overrides.ts +196 -0
  255. package/src/application/utils/stringUtils.ts +55 -0
  256. package/src/application/utils/supportedEventRequestToApiRequest.ts +12 -0
  257. package/src/application/utils/urlsParser.ts +53 -0
  258. package/src/application/utils/validation.ts +5 -0
  259. package/src/atoms/app/index.ts +57 -0
  260. package/src/atoms/app/variant.ts +261 -0
  261. package/src/atoms/atomStore.ts +34 -0
  262. package/src/atoms/chat/chatState.ts +44 -0
  263. package/src/atoms/chat/form.ts +19 -0
  264. package/src/atoms/chat/index.ts +38 -0
  265. package/src/atoms/chat/lastMessage.ts +11 -0
  266. package/src/atoms/chat/messageQueue.ts +65 -0
  267. package/src/atoms/chat/performanceMetrics.ts +84 -0
  268. package/src/atoms/chat/renderedWidgetRefs.ts +28 -0
  269. package/src/atoms/chat/replies.ts +51 -0
  270. package/src/atoms/chat/suggestions.ts +36 -0
  271. package/src/atoms/globalSearch.ts +12 -0
  272. package/src/atoms/index.ts +5 -0
  273. package/src/atoms/org/customerService.ts +13 -0
  274. package/src/atoms/org/graphqlConfig.ts +27 -0
  275. package/src/atoms/org/index.ts +7 -0
  276. package/src/atoms/org/merchantCss.ts +44 -0
  277. package/src/atoms/org/org.ts +256 -0
  278. package/src/atoms/org/orgAnalyticsConfig.ts +28 -0
  279. package/src/atoms/org/orgPageConfig.ts +38 -0
  280. package/src/atoms/org/orgUIConfig.ts +122 -0
  281. package/src/atoms/search/chatSearch.ts +293 -0
  282. package/src/atoms/search/index.ts +2 -0
  283. package/src/atoms/search/productFilters.ts +207 -0
  284. package/src/atoms/search/productSorter.ts +23 -0
  285. package/src/atoms/search/searchAPI.ts +194 -0
  286. package/src/atoms/search/types.ts +55 -0
  287. package/src/atoms/search/utils.ts +18 -0
  288. package/src/config/divIds.ts +27 -0
  289. package/src/config/locators/components/chat/entrypoints.ts +13 -0
  290. package/src/config/locators/components/chat/index.ts +23 -0
  291. package/src/config/locators/components/chat/preview.ts +13 -0
  292. package/src/config/locators/components/chat/variants/index.ts +16 -0
  293. package/src/config/locators/components/common/buttons.ts +6 -0
  294. package/src/config/locators/components/common/cards.ts +18 -0
  295. package/src/config/locators/components/common/links.ts +1 -0
  296. package/src/config/locators/components/common/tables.ts +2 -0
  297. package/src/config/locators/components/floating-button.ts +2 -0
  298. package/src/config/locators/components/index.ts +3 -0
  299. package/src/config/locators/components/report-issue.ts +21 -0
  300. package/src/config/locators/components/search/index.ts +5 -0
  301. package/src/config/locators/components/shadow-dom.ts +1 -0
  302. package/src/config/locators/embedded.ts +21 -0
  303. package/src/config/locators/index.ts +3 -0
  304. package/src/config/socialProofClasses.ts +17 -0
  305. package/src/contexts/chatContext.tsx +451 -0
  306. package/src/contexts/enviveConfigContext.tsx +70 -0
  307. package/src/contexts/index.ts +4 -0
  308. package/src/contexts/systemSettingsContext.tsx +61 -0
  309. package/src/contexts/types.ts +1059 -0
  310. package/src/enabled-features.ts +83 -0
  311. package/src/events/event-types.ts +11 -0
  312. package/src/events/index.ts +52 -0
  313. package/src/events/registerAnalyticsListeners.ts +49 -0
  314. package/src/extension.ts +63 -0
  315. package/src/hooks/index.ts +22 -0
  316. package/src/hooks/useBlockBackButton.ts +29 -0
  317. package/src/hooks/useChatToggle.ts +66 -0
  318. package/src/hooks/useCustomerSupportHandoff.ts +39 -0
  319. package/src/hooks/useDebounce.ts +17 -0
  320. package/src/hooks/useDynamicVariants.ts +210 -0
  321. package/src/hooks/useElementObserver.ts +245 -0
  322. package/src/hooks/useFileUpload.ts +61 -0
  323. package/src/hooks/useGrabAndScroll.ts +133 -0
  324. package/src/hooks/useHideElements.ts +82 -0
  325. package/src/hooks/useHorizontalScrollAnimation.ts +115 -0
  326. package/src/hooks/useImageResolver.ts +51 -0
  327. package/src/hooks/useIntersection.ts +28 -0
  328. package/src/hooks/useIsSmallScreen.ts +23 -0
  329. package/src/hooks/useMessageFilter.ts +49 -0
  330. package/src/hooks/useMessageScrollObserver.ts +47 -0
  331. package/src/hooks/useReducedMotionWithOverride.ts +15 -0
  332. package/src/hooks/useSearch.tsx +433 -0
  333. package/src/hooks/useSnapCalculator.ts +38 -0
  334. package/src/hooks/useSnapControl.ts +155 -0
  335. package/src/hooks/useSystemSettingsContext.ts +12 -0
  336. package/src/hooks/useTrackComponentVisibleEvent.ts +52 -0
  337. package/src/hooks/useUpdateAnalyticsProps.ts +56 -0
  338. package/src/hooks/utils.ts +153 -0
  339. package/src/index.ts +31 -0
  340. package/src/initialize.ts +163 -0
  341. package/src/interceptors/types.ts +6 -0
  342. package/src/interceptors/useFormEscalation.ts +40 -0
  343. package/src/interceptors/useMessageInterceptor.ts +32 -0
  344. package/src/main.ts +85 -0
  345. package/src/main.tsx +123 -0
  346. package/src/merchants/bandolier/bandolier.ts +1389 -0
  347. package/src/merchants/carpe/carpe.ts +656 -0
  348. package/src/merchants/coterie/coterie.ts +280 -0
  349. package/src/merchants/default.ts +193 -0
  350. package/src/merchants/dreamlandBaby/dreamlandBaby.ts +375 -0
  351. package/src/merchants/fiveCbd/fiveCbd.ts +697 -0
  352. package/src/merchants/forLoveAndLemons/forLoveAndLemons.ts +721 -0
  353. package/src/merchants/greenpan/greenpan.ts +440 -0
  354. package/src/merchants/grooveLife/grooveLife.ts +386 -0
  355. package/src/merchants/homegrownCannabis/homegrownCannabis.ts +468 -0
  356. package/src/merchants/init-merchant.sh +53 -0
  357. package/src/merchants/jackArcher/jackArcher.ts +974 -0
  358. package/src/merchants/jordanCraig/jordanCraig.ts +1927 -0
  359. package/src/merchants/kindredBravely/kindredBravely.ts +529 -0
  360. package/src/merchants/kutFromTheKloth/kutFromTheKloth.ts +418 -0
  361. package/src/merchants/larryAndSerges/larryAndSerges.ts +314 -0
  362. package/src/merchants/leapsAndRebounds/leapsAndRebounds.ts +424 -0
  363. package/src/merchants/longevityrx/longevityrx.ts +368 -0
  364. package/src/merchants/lookOptic/lookOptic.ts +323 -0
  365. package/src/merchants/mantraBrand/mantraBrand.ts +838 -0
  366. package/src/merchants/medterra/medterra.ts +670 -0
  367. package/src/merchants/modells/modells.ts +546 -0
  368. package/src/merchants/pressedFloral/pressedFloral.ts +734 -0
  369. package/src/merchants/skinPerfection/skinPerfection.ts +379 -0
  370. package/src/merchants/snapSupplements/snapSupplements.ts +325 -0
  371. package/src/merchants/spanx/spanx.ts +810 -0
  372. package/src/merchants/spanx/spanxStaging.ts +942 -0
  373. package/src/merchants/supergoop/supergoop.ts +376 -0
  374. package/src/merchants/uniqueVintage/uniqueVintage.ts +1314 -0
  375. package/src/merchants/uniqueVintage/views/useUniqueVintageChatSearch.ts +147 -0
  376. package/src/merchants/venaCbd/venaCbd.ts +410 -0
  377. package/src/merchants/westonJonBoucher/westonJonBoucher.ts +473 -0
  378. package/src/merchants/wineEnthusiast/wineEnthusiast.ts +990 -0
  379. package/src/merchants/wolfMattress/wolfMattress.ts +411 -0
  380. package/src/merchants/wolfTactical/wolfTactical.ts +389 -0
  381. package/src/types/custservice-types.ts +28 -0
  382. package/src/types/search-filter-types.ts +111 -0
  383. package/src/types/suggestionBarV2-types.ts +4 -0
  384. package/src/types/test-types.ts +3 -0
  385. package/src/types.ts +66 -0
@@ -0,0 +1,379 @@
1
+ import {
2
+ CHAT_PREVIEW_TESTID,
3
+ TOP_SUGGESTION_BAR_TESTID,
4
+ } from "src/config/locators";
5
+ import { OrgShortName, BasicOrgInfoType } from "src/application/models";
6
+ import { ChatElementDisplayLocation } from "src/application/models/chatElementDisplayLocation";
7
+ import { CdnService } from "src/application/service/cdnService";
8
+ import { DOMInsertionType } from "src/application/service/domMutations/domInsertionService";
9
+ import {
10
+ CHAT_PREVIEW_CONTAINER_ID,
11
+ TOP_SUGGESTION_BAR_PDP_ID,
12
+ } from "src/config/divIds";
13
+ import { SuggestionBarLocationForMetrics } from "src/types/suggestionBarV2-types";
14
+ import { defaultOrgUIConfig } from "src/merchants/default";
15
+ import {
16
+ ChatPreviewWidgetConfig,
17
+ ColorMapping,
18
+ ColorNames,
19
+ OrgPageConfig,
20
+ OrgUIConfig,
21
+ PageVariantTestType,
22
+ SuggestionBarWidgetV2Config,
23
+ WidgetType,
24
+ } from "src/contexts/types";
25
+ import { GridInsertionType } from "src/application/service/domMutations/GridInsertionService";
26
+
27
+ const skinPerfectionColors: ColorMapping = {
28
+ [ColorNames.TextPrimary]: "#121212",
29
+ [ColorNames.TextSecondary]: "#121212",
30
+ [ColorNames.TextAccent]: "#99CC02",
31
+ [ColorNames.TextLink]: "#0B8396",
32
+ [ColorNames.TextLight]: "#FFFFFF",
33
+ [ColorNames.BackgroundPrimary]: "#0B8396",
34
+ [ColorNames.BackgroundSecondary]: "#E9E9E9",
35
+ [ColorNames.BackgroundSecondaryDark]: "#ECEAE6",
36
+ [ColorNames.BackgroundTertiary]: "#F8F9FA",
37
+ [ColorNames.BackgroundDark]: "#121212",
38
+ [ColorNames.BackgroundLight]: "#FFFFFF",
39
+ [ColorNames.BackgroundSaturated]: "#CCCCCC",
40
+ [ColorNames.BorderLight]: "#EEEEEE",
41
+ [ColorNames.BorderMedium]: "#E9E9E9",
42
+ [ColorNames.BorderDark]: "#121212",
43
+ [ColorNames.BorderOutline]: "#0B8396",
44
+ [ColorNames.AccentPrimary]: "#0B8396",
45
+ [ColorNames.AccentSecondary]: "#F5F5F5",
46
+ };
47
+ const skinPerfectionOrgUIConfig = (): OrgUIConfig => {
48
+ const defaultSkinPerfectionOrgConfig = defaultOrgUIConfig(
49
+ OrgShortName.SkinPerfection
50
+ );
51
+
52
+ return {
53
+ ...defaultSkinPerfectionOrgConfig,
54
+ chatMessageConfig: {
55
+ ...defaultSkinPerfectionOrgConfig.chatMessageConfig,
56
+ assistantChatTitle: "Skin Perfection AI",
57
+ productLink: {
58
+ ...(defaultSkinPerfectionOrgConfig.chatMessageConfig?.productLink ||
59
+ {}),
60
+ iconVariant: "backgroundPrimary",
61
+ variant: "textLink",
62
+ },
63
+ },
64
+ chatHeader: {
65
+ ...defaultSkinPerfectionOrgConfig.chatHeader,
66
+ imageSrc: CdnService.getAssetURL(
67
+ "skin-perfection-logo.svg",
68
+ OrgShortName.SkinPerfection
69
+ ),
70
+ collapsedColor: skinPerfectionColors[ColorNames.AccentPrimary],
71
+ expandedColor: skinPerfectionColors[ColorNames.AccentPrimary],
72
+ chevronColor: skinPerfectionColors[ColorNames.TextLight],
73
+ customerSupportSwitchConfig: {
74
+ variant: "attached",
75
+ borderColor: skinPerfectionColors[ColorNames.AccentPrimary],
76
+ selectedTextColor: skinPerfectionColors[ColorNames.TextLight],
77
+ backgroundColor: skinPerfectionColors[ColorNames.AccentPrimary],
78
+ unselectedTextColor: skinPerfectionColors[ColorNames.TextLight],
79
+ supportTitle: "Live Support",
80
+ spiffyTitle: "Shop with AI",
81
+ spiffyTitleHasLogo: false,
82
+ },
83
+ },
84
+ chatPreviewConfig: {
85
+ ...defaultSkinPerfectionOrgConfig.chatPreviewConfig!,
86
+ buttonBackgroundColor:
87
+ skinPerfectionColors[ColorNames.BackgroundSecondary],
88
+ buttonTextColor: skinPerfectionColors[ColorNames.TextLink],
89
+ iconFillColor: skinPerfectionColors[ColorNames.TextLink],
90
+ headerConfig: {
91
+ ...defaultSkinPerfectionOrgConfig.chatPreviewConfig!.headerConfig,
92
+ title: "Skin Perfection Assistant",
93
+ imageSrc: CdnService.getAssetURL(
94
+ "skin-perfection-logo.svg",
95
+ OrgShortName.SkinPerfection
96
+ ),
97
+ },
98
+ footerConfig: {
99
+ ...defaultSkinPerfectionOrgConfig.chatPreviewConfig!.footerConfig,
100
+ },
101
+ },
102
+ floatingEntrypointConfig: {
103
+ ...defaultSkinPerfectionOrgConfig.floatingEntrypointConfig!,
104
+ showOption: "always",
105
+ expandedColor: skinPerfectionColors[ColorNames.BackgroundDark],
106
+ expansionText: {
107
+ plp: "Need help perfecting your routine?",
108
+ pdp: "Will this complete your routine?",
109
+ },
110
+ },
111
+ productCardConfig: {
112
+ ...defaultSkinPerfectionOrgConfig.productCardConfig!,
113
+ },
114
+ pageCardConfig: {
115
+ ...defaultSkinPerfectionOrgConfig.pageCardConfig!,
116
+ },
117
+ productReviewConfig: {
118
+ ...defaultSkinPerfectionOrgConfig.productReviewConfig!,
119
+ colorVariant: "brand",
120
+ styleVariant: "standard",
121
+ },
122
+ welcomeSectionConfig: {
123
+ ...defaultSkinPerfectionOrgConfig.welcomeSectionConfig!,
124
+ title: "Welcome to Skin Perfection AI!",
125
+ subtitle:
126
+ "Hi! I'm Lumi, your Skin Perfection personal skincare guide, here to answer your questions about how to use our innovative, natural products. Just tell me your skin type and goals, and I'll help you find your next perfect, anti-aging solutions.",
127
+ variant: "standard",
128
+ colorVariant: "accent",
129
+ iconName: "sparkles",
130
+ },
131
+ floatingChatConfig: {
132
+ ...defaultSkinPerfectionOrgConfig.floatingChatConfig,
133
+ suggestionButtonConfig: {
134
+ variant: "secondary",
135
+ hoverVariant: "dark",
136
+ answerVariant: "outlined",
137
+ },
138
+ replyInputConfig: {
139
+ size: "md",
140
+ sendIcon: "send",
141
+ },
142
+ },
143
+ merchantOverrideCss: `
144
+ /* Suggestion bar icon colors - override Tailwind classes */
145
+ .spiffy-suggestion-bar button svg,
146
+ .spiffy-suggestion-bar button path {
147
+ fill: var(--spiffy-colors-accent-primary) !important;
148
+ stroke: var(--spiffy-colors-accent-primary) !important;
149
+ }
150
+
151
+ /* Target the specific Tailwind classes used by the dark variant */
152
+ .spiffy-tw-fill-\\[--spiffy-colors-text-light\\] {
153
+ fill: var(--spiffy-colors-accent-primary) !important;
154
+ }
155
+
156
+ .spiffy-tw-stroke-\\[--spiffy-colors-text-light\\] {
157
+ stroke: var(--spiffy-colors-accent-primary) !important;
158
+ }
159
+
160
+ /* Chat preview icon colors for PLP and PDP */
161
+ .spiffy-chat-preview button svg,
162
+ .spiffy-chat-preview button path,
163
+ .spiffy-social-proof-content-button button svg,
164
+ .spiffy-social-proof-content-button button path {
165
+ fill: var(--spiffy-colors-accent-primary) !important;
166
+ stroke: var(--spiffy-colors-accent-primary) !important;
167
+ }
168
+
169
+ /* Chat preview button hover states */
170
+ .spiffy-chat-preview button:hover svg,
171
+ .spiffy-chat-preview button:hover path,
172
+ .spiffy-social-proof-content-button button:hover svg,
173
+ .spiffy-social-proof-content-button button:hover path {
174
+ fill: var(--spiffy-colors-accent-primary) !important;
175
+ stroke: var(--spiffy-colors-accent-primary) !important;
176
+ }
177
+
178
+ /* Chat preview customer count text color */
179
+ .spiffy-social-proof-customer-count,
180
+ .spiffy-social-proof-content-container .spiffy-tw-text-\\[--spiffy-colors-text-accent\\] {
181
+ color: var(--spiffy-colors-text-accent) !important;
182
+ }
183
+ /* Product link icon custom styling - force teal background with white arrow */
184
+ .spiffy-product-link-icon-container {
185
+ background-color: #0B8396 !important;
186
+ }
187
+
188
+ .spiffy-product-link-icon {
189
+ fill: #FFFFFF !important;
190
+ }
191
+
192
+ /* Override any existing background and fill classes */
193
+ .spiffy-product-link-icon-container.spiffy-tw-bg-\\[--spiffy-colors-background-primary\\],
194
+ .spiffy-product-link-icon-container.spiffy-tw-bg-\\[--spiffy-colors-text-accent\\],
195
+ .spiffy-product-link-icon-container.spiffy-tw-bg-\\[--spiffy-colors-accent-primary\\] {
196
+ background-color: #0B8396 !important;
197
+ }
198
+
199
+ .spiffy-product-link-icon-container .spiffy-tw-fill-\\[--spiffy-colors-text-light\\],
200
+ .spiffy-product-link-icon-container .spiffy-tw-fill-\\[var\\(--spiffy-colors-text-light\\)\\] {
201
+ fill: #FFFFFF !important;
202
+ }
203
+ `,
204
+ };
205
+ };
206
+
207
+ const skinPerfectionPageConfig = (): OrgPageConfig => ({
208
+ pageVariants: [
209
+ {
210
+ variantId: "plp",
211
+ variantType: "plp",
212
+ variantTests: [{ testType: PageVariantTestType.UrlResolver }],
213
+ plpIdExtractor: "url-resolver-plp-id",
214
+ widgetMounting: [
215
+ {
216
+ mountingConfigId: "chatPreviewPLP",
217
+ widgetConfigId: "chatPreviewPLP",
218
+ },
219
+ ],
220
+ },
221
+ {
222
+ variantId: "pdp",
223
+ variantType: "pdp",
224
+ variantTests: [{ testType: PageVariantTestType.UrlResolver }],
225
+ productIdExtractor: "url-resolver-product-id",
226
+ widgetMounting: [
227
+ {
228
+ mountingConfigId: "topSuggestionBarPDP",
229
+ widgetConfigId: "topSuggestionBar",
230
+ },
231
+ {
232
+ mountingConfigId: "chatPreviewPDP",
233
+ widgetConfigId: "chatPreviewPDP",
234
+ },
235
+ ],
236
+ },
237
+ ],
238
+ widgetConfigs: {
239
+ topSuggestionBar: {
240
+ buttonBorderRadius: "md",
241
+ type: WidgetType.SuggestionBarV2,
242
+ widgetConfigId: "topSuggestionBar",
243
+ contentId: "spiffy-top-suggestion-bar-contents",
244
+ metricDisplayLocation: ChatElementDisplayLocation.TOP_REVIEWS_SNIPPET,
245
+ location: SuggestionBarLocationForMetrics.SUGGESTION_BAR_TOP,
246
+ variant: "dark",
247
+ hoverVariant: "secondaryDark",
248
+ buttonTexts: {
249
+ default: [
250
+ "Summarize the reviews",
251
+ "What results have others seen?",
252
+ "How do I use this?",
253
+ "How does it feel on the skin?",
254
+ "Which skin type is this ideal for?",
255
+ ],
256
+ },
257
+ } satisfies SuggestionBarWidgetV2Config,
258
+ chatPreviewPLP: {
259
+ widgetConfigId: "chatPreviewPLP",
260
+ type: WidgetType.ChatPreview,
261
+ variant: "filled",
262
+ addSeparators: true,
263
+ socialProofConfig: {
264
+ staticPLPImagesLayout: "grid",
265
+ logoName: "skin-perfection-logo.svg",
266
+ customerQuery: "asked which products target wrinkles?",
267
+ headerTitle: "Skin Perfection Assistant",
268
+ suggestionButtonStrings: [
269
+ "How will this improve my skin?",
270
+ "What's best for fine lines?",
271
+ "What's gentle for beginners?",
272
+ "What's popular with other customers?",
273
+ "What will help to brighten my skin?",
274
+ "How can I boost collagen production?",
275
+ ],
276
+ staticPLPImageNames: [
277
+ "plp-image1.png",
278
+ "plp-image2.png",
279
+ "plp-image3.png",
280
+ "plp-image4.png",
281
+ ],
282
+ suggestionButtonVariantDefault: "secondary",
283
+ suggestionButtonVariantAccent: "dark",
284
+ userQueryButtonConfig: {
285
+ placeholderText: "Need help with your routine?",
286
+ icon: "magnifyingGlass",
287
+ },
288
+ },
289
+ } satisfies ChatPreviewWidgetConfig,
290
+ chatPreviewPDP: {
291
+ widgetConfigId: "chatPreviewPDP",
292
+ type: WidgetType.ChatPreview,
293
+ variant: "filled",
294
+ addSeparators: true,
295
+ socialProofConfig: {
296
+ staticPLPImagesLayout: "horizontal",
297
+ logoName: "skin-perfection-logo.svg",
298
+ customerQuery: "asked how will this improve my skin?",
299
+ headerTitle: "Skin Perfection Assistant",
300
+ suggestionButtonStrings: [
301
+ "What are others saying?",
302
+ "What are the key ingredients?",
303
+ "What skin types is this suitable for?",
304
+ "What results might I see?",
305
+ "How do I use this?",
306
+ "Does it mix and match with other products?",
307
+ ],
308
+ staticPLPImageNames: ["plp-image1.png"],
309
+ suggestionButtonVariantDefault: "secondary",
310
+ suggestionButtonVariantAccent: "dark",
311
+ userQueryButtonConfig: {
312
+ placeholderText: "Ask me anything",
313
+ icon: "send",
314
+ },
315
+ },
316
+ } satisfies ChatPreviewWidgetConfig,
317
+ },
318
+ mountingConfigs: {
319
+ chatPreviewPLP: {
320
+ mountingConfigId: "chatPreviewPLP",
321
+ containerId: CHAT_PREVIEW_CONTAINER_ID,
322
+ testId: CHAT_PREVIEW_TESTID,
323
+ insertionPoint: {
324
+ selector: ".product-list",
325
+ insertionType: DOMInsertionType.AFTER,
326
+ },
327
+ gridInsertionType: GridInsertionType.FIXED_3,
328
+ style: {
329
+ width: "100%",
330
+ maxWidth: "100%",
331
+ justifyItems: "start",
332
+ alignItems: "start",
333
+ textAlign: "left",
334
+ },
335
+ },
336
+ chatPreviewPDP: {
337
+ mountingConfigId: "chatPreviewPDP",
338
+ containerId: CHAT_PREVIEW_CONTAINER_ID,
339
+ testId: CHAT_PREVIEW_TESTID,
340
+ insertionPoint: {
341
+ selector: ".accordion-item",
342
+ insertionType: DOMInsertionType.BEFORE,
343
+ },
344
+ style: {
345
+ marginBottom: "16px",
346
+ },
347
+ },
348
+ topSuggestionBarPDP: {
349
+ mountingConfigId: "topSuggestionBarPDP",
350
+ containerId: TOP_SUGGESTION_BAR_PDP_ID,
351
+ testId: TOP_SUGGESTION_BAR_TESTID,
352
+ insertionPoint: {
353
+ selector: ".product-price",
354
+ insertionType: DOMInsertionType.AFTER,
355
+ },
356
+ style: {
357
+ marginBottom: "16px",
358
+ },
359
+ },
360
+ },
361
+ });
362
+
363
+ const skinPerfectionOrgInfo = {
364
+ shortName: OrgShortName.SkinPerfection,
365
+ name: "Skin Perfection AI",
366
+ domain: "naturalorganicskincare.com",
367
+ defaultProductId: "bioderma-sensibio-foaming-gel",
368
+ alwaysEnabledMerchants: true,
369
+ orgUIConfig: skinPerfectionOrgUIConfig,
370
+ orgColors: () => skinPerfectionColors,
371
+ orgPageConfig: skinPerfectionPageConfig,
372
+ } satisfies BasicOrgInfoType;
373
+
374
+ export {
375
+ skinPerfectionOrgInfo,
376
+ skinPerfectionOrgUIConfig,
377
+ skinPerfectionColors,
378
+ skinPerfectionPageConfig,
379
+ };
@@ -0,0 +1,325 @@
1
+ import {
2
+ CHAT_PREVIEW_TESTID,
3
+ TOP_SUGGESTION_BAR_TESTID,
4
+ } from "src/config/locators";
5
+ import { OrgShortName, BasicOrgInfoType } from "src/application/models";
6
+ import { ChatElementDisplayLocation } from "src/application/models/chatElementDisplayLocation";
7
+ import { CdnService } from "src/application/service/cdnService";
8
+ import { GridInsertionType } from "src/application/service/domMutations/GridInsertionService";
9
+ import { DOMInsertionType } from "src/application/service/domMutations/domInsertionService";
10
+ import {
11
+ CHAT_PREVIEW_CONTAINER_ID,
12
+ TOP_SUGGESTION_BAR_PDP_ID,
13
+ } from "src/config/divIds";
14
+ import { SuggestionBarLocationForMetrics } from "src/types/suggestionBarV2-types";
15
+ import {
16
+ ChatPreviewWidgetConfig,
17
+ ColorMapping,
18
+ ColorNames,
19
+ colorVar,
20
+ OrgPageConfig,
21
+ OrgUIConfig,
22
+ PageVariantTestType,
23
+ SuggestionBarWidgetV2Config,
24
+ WidgetType,
25
+ } from "src/contexts/types";
26
+ import { defaultOrgUIConfig } from "src/merchants/default";
27
+
28
+ const snapSupplementsColors: ColorMapping = {
29
+ [ColorNames.TextPrimary]: "#333",
30
+ [ColorNames.TextSecondary]: "#333",
31
+ [ColorNames.TextAccent]: "#346739",
32
+ [ColorNames.TextLink]: "#333",
33
+ [ColorNames.TextLight]: "#FFF",
34
+ [ColorNames.BackgroundPrimary]: "#17311B",
35
+ [ColorNames.BackgroundSecondary]: "#EFEFE9",
36
+ [ColorNames.BackgroundSecondaryDark]: "#E3E3DD",
37
+ [ColorNames.BackgroundTertiary]: "#CCDBBB",
38
+ [ColorNames.BackgroundDark]: "#333",
39
+ [ColorNames.BackgroundLight]: "#FFF",
40
+ [ColorNames.BackgroundSaturated]: "#CCCCCC",
41
+ [ColorNames.BorderLight]: "#EFEFE9",
42
+ [ColorNames.BorderMedium]: "#CCDBBB",
43
+ [ColorNames.BorderDark]: "#333",
44
+ [ColorNames.BorderOutline]: "#333",
45
+ [ColorNames.AccentPrimary]: "#346739",
46
+ [ColorNames.AccentSecondary]: "#CCDBBB",
47
+ };
48
+
49
+ const snapSupplementsOrgUIConfig = (): OrgUIConfig => {
50
+ const defaultSnapSupplementsOrgConfig = defaultOrgUIConfig(
51
+ OrgShortName.SnapSupplements
52
+ );
53
+
54
+ return {
55
+ ...defaultSnapSupplementsOrgConfig,
56
+ chatMessageConfig: {
57
+ ...defaultSnapSupplementsOrgConfig.chatMessageConfig,
58
+ assistantChatTitle: "SNAP Assistant",
59
+ },
60
+ chatHeader: {
61
+ ...defaultSnapSupplementsOrgConfig.chatHeader,
62
+ imageSrc: CdnService.getAssetURL(
63
+ "snap-logo2.png",
64
+ OrgShortName.SnapSupplements
65
+ ),
66
+ },
67
+ chatPreviewConfig: {
68
+ ...defaultSnapSupplementsOrgConfig.chatPreviewConfig!,
69
+ headerConfig: {
70
+ ...defaultSnapSupplementsOrgConfig.chatPreviewConfig!.headerConfig,
71
+ },
72
+ footerConfig: {
73
+ ...defaultSnapSupplementsOrgConfig.chatPreviewConfig!.footerConfig,
74
+ },
75
+ },
76
+ floatingEntrypointConfig: {
77
+ ...defaultSnapSupplementsOrgConfig.floatingEntrypointConfig!,
78
+ showOption: "always",
79
+ expansionText: {
80
+ plp: "Need clean nutrition help?",
81
+ pdp: "How will this enhance your wellness?",
82
+ },
83
+ expandedColor: colorVar(ColorNames.BackgroundDark),
84
+ },
85
+ productCardConfig: {
86
+ ...defaultSnapSupplementsOrgConfig.productCardConfig!,
87
+ },
88
+ pageCardConfig: {
89
+ ...defaultSnapSupplementsOrgConfig.pageCardConfig!,
90
+ variant: "filled",
91
+ },
92
+ productReviewConfig: {
93
+ ...defaultSnapSupplementsOrgConfig.productReviewConfig!,
94
+ colorVariant: "brand",
95
+ },
96
+ welcomeSectionConfig: {
97
+ ...defaultSnapSupplementsOrgConfig.welcomeSectionConfig!,
98
+ title: "Welcome to SNAP AI!",
99
+ subtitle:
100
+ "Hi there! I'm Sarah, your SNAP Supplements guide—here to make personalized recommendations so you can achieve your wellness goals. What can I help you support today?",
101
+ colorVariant: "accent",
102
+ },
103
+ merchantOverrideCss: `
104
+ .spiffy-chat-header-container > div > div > img {
105
+ height: 56px !important;
106
+ }
107
+
108
+ .spiffy-chat-preview-footer-container > div > div > div > button {
109
+ border: 1px solid var(--spiffy-colors-background-secondary-dark) !important;
110
+ }
111
+
112
+ .spiffy-social-proof-content-button > button:hover {
113
+ background: var(--spiffy-colors-background-secondary-dark) !important;
114
+ color: var(--spiffy-colors-text-primary) !important;
115
+ }
116
+ .spiffy-social-proof-content-button > button:hover > svg {
117
+ fill: var(--spiffy-colors-accent-primary) !important;
118
+ stroke: var(--spiffy-colors-accent-primary) !important;
119
+ }
120
+
121
+ /* Suggestion buttons in chat */
122
+ .spiffy-modal-sheet-content button.spiffy-button-base-button[data-testid="spiffy-suggestion-button"] {
123
+ background: var(--spiffy-colors-background-secondary) !important;
124
+ border: 1px solid var(--spiffy-colors-background-secondary-dark) !important;
125
+ }
126
+ .spiffy-modal-sheet-content button.spiffy-button-base-button[data-testid="spiffy-suggestion-button"]:hover {
127
+ color: var(--spiffy-colors-text-primary) !important;
128
+ background: var(--spiffy-colors-background-secondary-dark) !important;
129
+ }
130
+ .spiffy-modal-sheet-content button.spiffy-button-base-button[data-testid="spiffy-suggestion-button"]:hover > svg {
131
+ fill: var(--spiffy-colors-accent-primary) !important;
132
+ stroke: var(--spiffy-colors-accent-primary) !important;
133
+ }
134
+
135
+ :root {
136
+ --chat-preview-pdp-max-width: 1020px;
137
+ --chat-preview-plp-max-width: 958px;
138
+ }
139
+ @media (max-width: 1439px) {
140
+ :root {
141
+ --chat-preview-plp-max-width: 728px;
142
+ }
143
+ }
144
+ @media (max-width: 1023px) {
145
+ :root {
146
+ --chat-preview-pdp-max-width: 720px;
147
+ --chat-preview-plp-max-width: 704px;
148
+ }
149
+ }
150
+ `,
151
+ };
152
+ };
153
+
154
+ const snapSupplementsPageConfig = (): OrgPageConfig => ({
155
+ pageVariants: [
156
+ {
157
+ variantId: "plp",
158
+ variantType: "plp",
159
+ variantTests: [{ testType: PageVariantTestType.UrlResolver }],
160
+ plpIdExtractor: "url-resolver-plp-id",
161
+ widgetMounting: [
162
+ {
163
+ mountingConfigId: "chatPreviewPLP",
164
+ widgetConfigId: "chatPreviewPLP",
165
+ },
166
+ ],
167
+ },
168
+ {
169
+ variantId: "pdp",
170
+ variantType: "pdp",
171
+ variantTests: [{ testType: PageVariantTestType.UrlResolver }],
172
+ productIdExtractor: "url-resolver-product-id",
173
+ widgetMounting: [
174
+ {
175
+ mountingConfigId: "topSuggestionBarPDP",
176
+ widgetConfigId: "topSuggestionBar",
177
+ },
178
+ {
179
+ mountingConfigId: "chatPreviewPDP",
180
+ widgetConfigId: "chatPreviewPDP",
181
+ },
182
+ ],
183
+ },
184
+ ],
185
+ widgetConfigs: {
186
+ topSuggestionBar: {
187
+ type: WidgetType.SuggestionBarV2,
188
+ widgetConfigId: "topSuggestionsBar",
189
+ contentId: "spiffy-top-suggestion-bar-contents",
190
+ metricDisplayLocation: ChatElementDisplayLocation.TOP_REVIEWS_SNIPPET,
191
+ location: SuggestionBarLocationForMetrics.SUGGESTION_BAR_TOP,
192
+ variant: "darkPrimary",
193
+ hoverVariant: "secondaryAccent",
194
+ buttonBorderRadius: "md",
195
+ buttonTexts: {
196
+ default: [
197
+ "Summarize the reviews",
198
+ "What are the main benefits?",
199
+ "What do customers say about results?",
200
+ "How do I take this?",
201
+ "How will this support my health goals?",
202
+ ],
203
+ },
204
+ animationSpeed: "standard",
205
+ } satisfies SuggestionBarWidgetV2Config,
206
+ chatPreviewPLP: {
207
+ widgetConfigId: "chatPreviewPLP",
208
+ type: WidgetType.ChatPreview,
209
+ variant: "filled",
210
+ addSeparators: false,
211
+ socialProofConfig: {
212
+ staticPLPImagesLayout: "grid",
213
+ logoName: "snap-logo1.png",
214
+ customerQuery: 'asked "what are the main benefits?"',
215
+ headerTitle: "Shopping Assistant",
216
+ suggestionButtonStrings: [
217
+ "What are reviewers saying?",
218
+ "What boosts energy levels?",
219
+ "Which products support prostate health?",
220
+ "What’s good for cardio support?",
221
+ "How can I support my digestive health?",
222
+ "What helps with blood sugar?",
223
+ ],
224
+ staticPLPImageNames: [
225
+ "plp-image1.png",
226
+ "plp-image2.png",
227
+ "plp-image3.png",
228
+ "plp-image4.png",
229
+ ],
230
+ suggestionButtonVariantDefault: "secondary",
231
+ suggestionButtonVariantAccent: "primary",
232
+ userQueryButtonConfig: {
233
+ placeholderText: "Ask me anything",
234
+ icon: "magnifyingGlass",
235
+ },
236
+ },
237
+ } satisfies ChatPreviewWidgetConfig,
238
+ chatPreviewPDP: {
239
+ widgetConfigId: "chatPreviewPDP",
240
+ type: WidgetType.ChatPreview,
241
+ variant: "filled",
242
+ addSeparators: false,
243
+ socialProofConfig: {
244
+ staticPLPImagesLayout: "horizontal",
245
+ logoName: "snap-logo1.png",
246
+ customerQuery: 'asked "what results did others see?"',
247
+ headerTitle: "Shopping Assistant",
248
+ suggestionButtonStrings: [
249
+ "What are reviewers saying?",
250
+ "What benefits should I expect?",
251
+ "How should I use this?",
252
+ "Is this right for me?",
253
+ "What are the active ingredients?",
254
+ ],
255
+ staticImageIndex: 0,
256
+ suggestionButtonVariantDefault: "secondary",
257
+ suggestionButtonVariantAccent: "primary",
258
+ userQueryButtonConfig: {
259
+ placeholderText: "Ask me anything",
260
+ icon: "send",
261
+ },
262
+ },
263
+ } satisfies ChatPreviewWidgetConfig,
264
+ },
265
+ mountingConfigs: {
266
+ chatPreviewPLP: {
267
+ mountingConfigId: "chatPreviewPLP",
268
+ containerId: CHAT_PREVIEW_CONTAINER_ID,
269
+ testId: CHAT_PREVIEW_TESTID,
270
+ insertionPoint: {
271
+ selector: ".shop-product-items",
272
+ insertionType: DOMInsertionType.AFTER,
273
+ },
274
+ gridInsertionType: GridInsertionType.FIXED_3,
275
+ style: {
276
+ maxWidth: "var(--chat-preview-plp-max-width, 958px)",
277
+ minWidth: "98%",
278
+ marginLeft: "9px",
279
+ },
280
+ },
281
+ chatPreviewPDP: {
282
+ mountingConfigId: "chatPreviewPDP",
283
+ containerId: CHAT_PREVIEW_CONTAINER_ID,
284
+ testId: CHAT_PREVIEW_TESTID,
285
+ insertionPoint: {
286
+ selector: "#productMainSection",
287
+ insertionType: DOMInsertionType.AFTER,
288
+ },
289
+ style: {
290
+ maxWidth: "var(--chat-preview-pdp-max-width, 1020px)",
291
+ margin: "0px auto 10px auto",
292
+ },
293
+ },
294
+ topSuggestionBarPDP: {
295
+ mountingConfigId: "topSuggestionBarPDP",
296
+ containerId: TOP_SUGGESTION_BAR_PDP_ID,
297
+ testId: TOP_SUGGESTION_BAR_TESTID,
298
+ insertionPoint: {
299
+ selector: ".product__catchline",
300
+ insertionType: DOMInsertionType.AFTER,
301
+ },
302
+ style: {
303
+ marginTop: "12px",
304
+ },
305
+ },
306
+ },
307
+ });
308
+
309
+ const snapSupplementsOrgInfo = {
310
+ shortName: OrgShortName.SnapSupplements,
311
+ name: "SNAP Assistant",
312
+ domain: "snapsupplements.com",
313
+ defaultProductId: "",
314
+ alwaysEnabledMerchants: true,
315
+ orgUIConfig: snapSupplementsOrgUIConfig,
316
+ orgColors: () => snapSupplementsColors,
317
+ orgPageConfig: snapSupplementsPageConfig,
318
+ } satisfies BasicOrgInfoType;
319
+
320
+ export {
321
+ snapSupplementsOrgInfo,
322
+ snapSupplementsOrgUIConfig,
323
+ snapSupplementsColors,
324
+ snapSupplementsPageConfig,
325
+ };