@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,810 @@
1
+ import {
2
+ BOTTOM_SUGGESTION_BAR_PDP_TESTID,
3
+ CHAT_PREVIEW_PDP_TESTID,
4
+ CHAT_PREVIEW_PLP_TESTID,
5
+ TOP_SUGGESTION_BAR_PDP_TESTID,
6
+ } from "src/config/locators";
7
+ import { GrClose } from "react-icons/gr";
8
+ import { OrgShortName, BasicOrgInfoType } from "src/application/models";
9
+ import { ChatElementDisplayLocation } from "src/application/models/chatElementDisplayLocation";
10
+ import { CdnService } from "src/application/service/cdnService";
11
+ import {
12
+ CustomerServiceIntegrationMode,
13
+ CustomerServiceType,
14
+ } from "src/application/service/customerService/types";
15
+ import { GridInsertionType } from "src/application/service/domMutations/GridInsertionService";
16
+ import { DOMInsertionType } from "src/application/service/domMutations/domInsertionService";
17
+ import {
18
+ BOTTOM_PLP_IMAGE_BANNER_ID,
19
+ BOTTOM_REVIEWS_BAR_ID,
20
+ CHAT_PREVIEW_CONTAINER_ID,
21
+ TOP_SUGGESTION_BAR_PDP_ID,
22
+ } from "src/config/divIds";
23
+ import { defaultOrgUIConfig } from "src/merchants/default";
24
+ import { SuggestionBarLocationForMetrics } from "src/types/suggestionBarV2-types";
25
+ import {
26
+ ChatPreviewWidgetConfig,
27
+ ColorMapping,
28
+ ColorNames,
29
+ colorVar,
30
+ ImageBannerWidgetConfig,
31
+ OrgPageConfig,
32
+ OrgUIConfig,
33
+ PageVariantTestType,
34
+ SuggestionBarWidgetV2Config,
35
+ WidgetType,
36
+ } from "src/contexts/types";
37
+ import { ChatState } from "src/types/custservice-types";
38
+ import { BOTTOM_IMAGE_BANNER_PLP_TESTID } from "src/config/locators/components/chat/entrypoints";
39
+
40
+ const spanxPageConfig = (): OrgPageConfig => ({
41
+ pageVariants: [
42
+ {
43
+ variantId: "plp",
44
+ variantType: "plp",
45
+ plpIdExtractor: "url-resolver-plp-id",
46
+ variantTests: [{ testType: PageVariantTestType.UrlResolver }],
47
+ widgetMounting: [
48
+ {
49
+ mountingConfigId: "chatPreviewPLP",
50
+ widgetConfigId: "shapewearChatPreviewPLP",
51
+ },
52
+ {
53
+ mountingConfigId: "bottomImageBannerPLP",
54
+ widgetConfigId: "ImageBannerShapewearPLP",
55
+ },
56
+ ],
57
+ },
58
+ // Not currently supported with the migration to URL resolver
59
+ // TODO: Add back in when we are ready to enable non shapewear PLP
60
+ // {
61
+ // variantId: 'nonShapewearPLP',
62
+ // variantType: 'plp',
63
+ // plpIdExtractor: 'url-resolver-plp-id',
64
+ // variantTests: [
65
+ // { testType: PageVariantTestType.UrlResolver },
66
+ // {
67
+ // testType: PageVariantTestType.CatalogCategory,
68
+ // category: SupportedEventProductCategory.NonShapewear,
69
+ // },
70
+ // {
71
+ // testType: PageVariantTestType.FeatureGate,
72
+ // featureGate: FeatureGates.IsNonShapewearEnabled,
73
+ // },
74
+ // ],
75
+ // widgetMounting: [
76
+ // {
77
+ // mountingConfigId: 'chatPreviewPLP',
78
+ // widgetConfigId: 'nonShapewearChatPreviewPLP',
79
+ // },
80
+ // {
81
+ // mountingConfigId: 'bottomImageBannerPLP',
82
+ // widgetConfigId: 'ImageBannerNonShapewearPLP',
83
+ // },
84
+ // ],
85
+ // },
86
+ {
87
+ variantId: "pdp",
88
+ variantType: "pdp",
89
+ variantTests: [{ testType: PageVariantTestType.UrlResolver }],
90
+ productIdExtractor: "url-resolver-product-id",
91
+ widgetMounting: [
92
+ {
93
+ mountingConfigId: "chatPreviewPDP",
94
+ widgetConfigId: "shapewearChatPreviewPDP",
95
+ },
96
+ {
97
+ mountingConfigId: "topSuggestionBarPDP",
98
+ widgetConfigId: "topSuggestionBarPDP",
99
+ },
100
+ {
101
+ mountingConfigId: "bottomSuggestionBarPDP",
102
+ widgetConfigId: "bottomSuggestionBarPDP",
103
+ },
104
+ ],
105
+ },
106
+ // Not currently supported with the migration to URL resolver
107
+ // TODO: Add back in when we are ready to enable non shapewear PDP
108
+ // {
109
+ // variantId: 'nonShapewearPDP',
110
+ // variantType: 'pdp',
111
+ // variantTests: [
112
+ // { testType: PageVariantTestType.UrlResolver },
113
+ // {
114
+ // testType: PageVariantTestType.CatalogCategory,
115
+ // category: SupportedEventProductCategory.NonShapewear,
116
+ // },
117
+ // {
118
+ // testType: PageVariantTestType.FeatureGate,
119
+ // featureGate: FeatureGates.IsNonShapewearEnabled,
120
+ // },
121
+ // ],
122
+ // productIdExtractor: 'url-resolver-product-id',
123
+ // widgetMounting: [
124
+ // {
125
+ // mountingConfigId: 'chatPreviewPDP',
126
+ // widgetConfigId: 'chatPreviewPDP',
127
+ // },
128
+ // {
129
+ // mountingConfigId: 'topSuggestionBarPDP',
130
+ // widgetConfigId: 'topSuggestionBarPDP',
131
+ // },
132
+ // {
133
+ // mountingConfigId: 'bottomSuggestionBarPDP',
134
+ // widgetConfigId: 'bottomSuggestionBarPDP',
135
+ // },
136
+ // ],
137
+ // },
138
+ {
139
+ variantId: "supportPages",
140
+ variantType: "other",
141
+ variantTests: [{ testType: PageVariantTestType.UrlResolver }],
142
+ // support pages only render the floating button which is currently rendered by FloatingChat
143
+ widgetMounting: [],
144
+ },
145
+ ],
146
+ widgetConfigs: {
147
+ ImageBannerShapewearPLP: {
148
+ widgetConfigId: "ImageBannerShapewearPLP",
149
+ type: WidgetType.ImageBanner,
150
+ imageSrc: "plp_quiz_banner_image.png",
151
+ title: "Need help? We're here.",
152
+ subtitle: "Chat with Spanx AI Assistant",
153
+ assistantMessage: "Can you help me choose the right shapewear?",
154
+ } satisfies ImageBannerWidgetConfig,
155
+ // ImageBannerNonShapewearPLP: {
156
+ // widgetConfigId: 'ImageBannerNonShapewearPLP',
157
+ // type: WidgetType.ImageBanner,
158
+ // imageSrc: 'default_banner_image.webp',
159
+ // title: "Need help? We're here.",
160
+ // subtitle: 'Chat with Spanx AI Assistant',
161
+ // assistantMessage: 'Give me product recommendations',
162
+ // } satisfies ImageBannerWidgetConfig,
163
+ // nonShapewearChatPreviewPLP: {
164
+ // widgetConfigId: 'nonShapewearChatPreviewPLP',
165
+ // variant: 'outlined',
166
+ // type: WidgetType.ChatPreview,
167
+ // socialProofConfig: {
168
+ // logoName: 'spanx-logo.svg',
169
+ // customerQuery: 'asked which styles are the most comfortable for everyday wear...',
170
+ // headerTitle: 'Assistant',
171
+ // suggestionButtonStrings: [
172
+ // 'Which styles do reviewers suggest?',
173
+ // 'Which styles have the most reviews?',
174
+ // 'Which styles are best for my body shape?',
175
+ // 'Which styles are most popular?',
176
+ // 'How does Spanx source its products?',
177
+ // ],
178
+ // staticPLPImageNames: [
179
+ // 'default_plp_embedded_1.webp',
180
+ // 'default_plp_embedded_2.webp',
181
+ // 'default_plp_embedded_3.webp',
182
+ // 'default_plp_embedded_4.webp',
183
+ // ],
184
+ // suggestionButtonVariantDefault: 'outlined',
185
+ // suggestionButtonVariantAccent: 'outlined',
186
+ // staticPLPImagesLayout: 'horizontal',
187
+ // },
188
+ // } satisfies ChatPreviewWidgetConfig,
189
+ shapewearChatPreviewPLP: {
190
+ widgetConfigId: "shapewearChatPreviewPLP",
191
+ variant: "outlined",
192
+ type: WidgetType.ChatPreview,
193
+ socialProofConfig: {
194
+ logoName: "spanx-logo.svg",
195
+ customerQuery: "are looking for shapewear for tummy control...",
196
+ headerTitle: "Assistant",
197
+ suggestionButtonStrings: [
198
+ "What do reviewers think?",
199
+ "Best shapewear for dresses",
200
+ "Styles with the strongest compression",
201
+ "Comfortable for all-day wear",
202
+ "Shapewear that won't show through clothes",
203
+ ],
204
+ staticPLPImageNames: [
205
+ "shapewear_plp_embedded_1.png",
206
+ "shapewear_plp_embedded_2.png",
207
+ "shapewear_plp_embedded_3.png",
208
+ "shapewear_plp_embedded_4.png",
209
+ ],
210
+ suggestionButtonVariantDefault: "outlined",
211
+ suggestionButtonVariantAccent: "outlined",
212
+ staticPLPImagesLayout: "horizontal",
213
+ },
214
+ } satisfies ChatPreviewWidgetConfig,
215
+ shapewearChatPreviewPDP: {
216
+ widgetConfigId: "shapewearChatPreviewPDP",
217
+ variant: "outlined",
218
+ type: WidgetType.ChatPreview,
219
+ socialProofConfig: {
220
+ logoName: "spanx-logo.svg",
221
+ customerQuery: "asked if it shows under clothes...",
222
+ headerTitle: "Assistant",
223
+ suggestionButtonStrings: [
224
+ "What do reviewers think?",
225
+ "Is it easy to wash?",
226
+ "Is it good for curvy figures?",
227
+ "What did reviewers like the best?",
228
+ "Is it comfortable?",
229
+ "What size should I choose?",
230
+ "Is it good for all body shapes?",
231
+ ],
232
+ suggestionButtonVariantDefault: "outlined",
233
+ suggestionButtonVariantAccent: "outlined",
234
+ },
235
+ } satisfies ChatPreviewWidgetConfig,
236
+ chatPreviewPDP: {
237
+ widgetConfigId: "chatPreviewPDP",
238
+ variant: "outlined",
239
+ type: WidgetType.ChatPreview,
240
+ socialProofConfig: {
241
+ logoName: "spanx-logo.svg",
242
+ customerQuery: "asked if it's comfortable...",
243
+ headerTitle: "Assistant",
244
+ suggestionButtonStrings: [
245
+ "What do reviewers think?",
246
+ "Is it easy to wash?",
247
+ "Is it good for curvy figures?",
248
+ "What did reviewers like the best?",
249
+ "Is it comfortable?",
250
+ "What size should I choose?",
251
+ "Is it good for all body shapes?",
252
+ ],
253
+ suggestionButtonVariantDefault: "outlined",
254
+ suggestionButtonVariantAccent: "outlined",
255
+ },
256
+ } satisfies ChatPreviewWidgetConfig,
257
+ topSuggestionBarPDP: {
258
+ widgetConfigId: "topSuggestionBarPDP",
259
+ contentId: "spiffy-top-suggestion-bar-contents",
260
+ type: WidgetType.SuggestionBarV2,
261
+ metricDisplayLocation: ChatElementDisplayLocation.TOP_REVIEWS_SNIPPET,
262
+ location: SuggestionBarLocationForMetrics.SUGGESTION_BAR_TOP,
263
+ variant: "outlined",
264
+ hoverVariant: "secondaryDark",
265
+ buttonTexts: {
266
+ default: [
267
+ "Summarize the reviews",
268
+ "Do reviewers find these effective?",
269
+ "Do these boost reviewers' confidence?",
270
+ "What do reviews say about comfort?",
271
+ "Do reviewers like these for under a dress?",
272
+ ],
273
+ },
274
+ boldFirstButton: true,
275
+ twoRowsOnMobile: false,
276
+ animationSpeed: "none",
277
+ buttonBorderRadius: "md",
278
+ } satisfies SuggestionBarWidgetV2Config,
279
+ bottomSuggestionBarPDP: {
280
+ widgetConfigId: "bottomSuggestionBarPDP",
281
+ metricDisplayLocation: ChatElementDisplayLocation.BOTTOM_REVIEWS_SNIPPET,
282
+
283
+ contentId: "spiffy-bottom-suggestion-bar-contents",
284
+ type: WidgetType.SuggestionBarV2,
285
+ location: SuggestionBarLocationForMetrics.SUGGESTION_BAR_BOTTOM,
286
+ variant: "outlinedLight",
287
+ hoverVariant: "secondaryDark",
288
+ buttonTexts: {
289
+ default: [
290
+ "Summarize the reviews",
291
+ "Do reviewers find these effective?",
292
+ "Do these boost reviewers' confidence?",
293
+ "What do reviews say about comfort?",
294
+ "Do reviewers like these for under a dress?",
295
+ ],
296
+ },
297
+ boldFirstButton: true,
298
+ twoRowsOnMobile: false,
299
+ animationSpeed: "none",
300
+ buttonBorderRadius: "md",
301
+ } satisfies SuggestionBarWidgetV2Config,
302
+ },
303
+ mountingConfigs: {
304
+ bottomImageBannerPLP: {
305
+ mountingConfigId: "bottomImageBannerPLP",
306
+ containerId: BOTTOM_PLP_IMAGE_BANNER_ID,
307
+ testId: BOTTOM_IMAGE_BANNER_PLP_TESTID,
308
+ insertionPoint: {
309
+ selector: "main > section.order-last",
310
+ insertionType: DOMInsertionType.ADJACENT_AFTER_BEGIN,
311
+ },
312
+ style: {
313
+ marginBottom: "30px",
314
+ },
315
+ },
316
+ chatPreviewPLP: {
317
+ mountingConfigId: "chatPreviewPLP",
318
+ containerId: CHAT_PREVIEW_CONTAINER_ID,
319
+ testId: CHAT_PREVIEW_PLP_TESTID,
320
+ gridInsertionType: GridInsertionType.ROW_2,
321
+ insertionPoint: {
322
+ selector: ".grid .grid-flow-row-dense",
323
+ insertionType: DOMInsertionType.ADJACENT_AFTER_END,
324
+ },
325
+ style: {
326
+ marginInline: "8px",
327
+ },
328
+ },
329
+ chatPreviewPDP: {
330
+ mountingConfigId: "chatPreviewPDP",
331
+ containerId: CHAT_PREVIEW_CONTAINER_ID,
332
+ testId: CHAT_PREVIEW_PDP_TESTID,
333
+ insertionPoint: {
334
+ selector: ".content-start .divide-y",
335
+ insertionType: DOMInsertionType.BEFORE,
336
+ },
337
+ className: "grid",
338
+ },
339
+ topSuggestionBarPDP: {
340
+ mountingConfigId: "topSuggestionBarPDP",
341
+ containerId: TOP_SUGGESTION_BAR_PDP_ID,
342
+ testId: TOP_SUGGESTION_BAR_PDP_TESTID,
343
+ insertionPoint: {
344
+ selector: "main section div.grid.gap-2.bg-white",
345
+ insertionType: DOMInsertionType.BEFORE,
346
+ },
347
+ className: "grid",
348
+ },
349
+ bottomSuggestionBarPDP: {
350
+ mountingConfigId: "bottomSuggestionBarPDP",
351
+ containerId: BOTTOM_REVIEWS_BAR_ID,
352
+ testId: BOTTOM_SUGGESTION_BAR_PDP_TESTID,
353
+ insertionPoint: {
354
+ selector: "#reviews > div.w-full.gap-8",
355
+ insertionType: DOMInsertionType.APPEND_CHILD,
356
+ },
357
+ style: {
358
+ maxWidth: "92vw",
359
+ marginInline: "auto",
360
+ marginTop: "15px",
361
+ marginBottom: "-25px",
362
+ },
363
+ },
364
+ },
365
+ });
366
+
367
+ const spanxColors: ColorMapping = {
368
+ [ColorNames.TextPrimary]: "#02081C",
369
+ [ColorNames.TextSecondary]: "#4F586F",
370
+ [ColorNames.TextAccent]: "#5F0F23",
371
+ [ColorNames.TextLink]: "#001846",
372
+ [ColorNames.TextLight]: "#FFFFFF",
373
+ [ColorNames.BackgroundPrimary]: "#02081C",
374
+ [ColorNames.BackgroundSecondary]: "#FFFFFF",
375
+ [ColorNames.BackgroundSecondaryDark]: "#F4F4F6",
376
+ [ColorNames.BackgroundTertiary]: "#4F586F",
377
+ [ColorNames.BackgroundDark]: "#02081C",
378
+ [ColorNames.BackgroundLight]: "#FFFFFF",
379
+ [ColorNames.BackgroundSaturated]: "#FFF1DF",
380
+ [ColorNames.BorderLight]: "#CDCFD6",
381
+ [ColorNames.BorderMedium]: "#B3B7C1",
382
+ [ColorNames.BorderDark]: "#687083",
383
+ [ColorNames.BorderOutline]: "#E6E7EA",
384
+ [ColorNames.AccentPrimary]: "#FF002B",
385
+ [ColorNames.AccentSecondary]: "#02081C",
386
+ };
387
+
388
+ const spanxOrgUIConfig = (): OrgUIConfig => {
389
+ const defaultSpanxOrgConfig = defaultOrgUIConfig(OrgShortName.Spanx);
390
+ return {
391
+ ...defaultSpanxOrgConfig,
392
+ partialViewConfig: {
393
+ maxHeight: 89,
394
+ borderRadius: "0px",
395
+ },
396
+ chatMessageConfig: {
397
+ ...defaultSpanxOrgConfig.chatMessageConfig!,
398
+ assistantChatTitle: "Spanx AI Assistant",
399
+ variant: "premium",
400
+ productLink: {
401
+ ...defaultSpanxOrgConfig.chatMessageConfig.productLink,
402
+ iconVariant: "backgroundPrimary",
403
+ },
404
+ },
405
+ floatingEntrypointConfig: {
406
+ ...defaultSpanxOrgConfig.floatingEntrypointConfig!,
407
+ showOption: "always",
408
+ position: "bottom-right",
409
+ },
410
+ welcomeSectionConfig: {
411
+ ...defaultSpanxOrgConfig.welcomeSectionConfig!,
412
+ variant: "outlined",
413
+ colorVariant: "accent",
414
+ title: "Welcome to SPANX!",
415
+ iconName: "sparkles",
416
+ subtitle:
417
+ "Ask our AI anything to get instant help with everything from product specifics and details, shipping, returns, and more. Need more help? Please click the SPANX Support button above.",
418
+ },
419
+ chatPreviewConfig: {
420
+ ...defaultSpanxOrgConfig.chatPreviewConfig!,
421
+ topMargin: 0,
422
+ largeProductComparison: true,
423
+ iconFillColor: colorVar(ColorNames.TextPrimary),
424
+ buttonTextSecondaryColor: colorVar(ColorNames.TextPrimary),
425
+ buttonTextHoverColor: colorVar(ColorNames.TextPrimary),
426
+ buttonBackgroundColor: colorVar(ColorNames.BackgroundDark),
427
+ buttonBackgroundHoverColor: colorVar(ColorNames.AccentPrimary),
428
+ headerConfig: {
429
+ ...defaultSpanxOrgConfig.chatPreviewConfig!.headerConfig!,
430
+ imageSrc: CdnService.getAssetURL("spanx-logo.svg", OrgShortName.Spanx),
431
+ imageHeight: 16,
432
+ title: "AI Assistant",
433
+ sparklesColor: colorVar(ColorNames.AccentPrimary),
434
+ iconWidth: "16px",
435
+ iconHeight: "16px",
436
+ },
437
+ footerConfig: {
438
+ ...defaultSpanxOrgConfig.chatPreviewConfig!.footerConfig!,
439
+ hasFade: false,
440
+ suggestionButtonVariant: "light",
441
+ replyButtonIcon: "thinMagnifyingGlass",
442
+ replyInputHasShadow: false,
443
+ replyInputHasBorder: true,
444
+ backgroundColor: colorVar(ColorNames.BackgroundSecondaryDark),
445
+ },
446
+ copies: {
447
+ pdp: [
448
+ "what reviewers think about the comfort?",
449
+ "what body areas this targets?",
450
+ "if this will show through clothes?",
451
+ ],
452
+ plp: [
453
+ "something to wear under a strapless dress to a wedding?",
454
+ "the best shapewear for tummy control?",
455
+ "the right shapewear with a pencil skirt for work?",
456
+ ],
457
+ },
458
+ staticSuggestionCopies: {
459
+ pdp: [
460
+ "Is it easy to wash?",
461
+ "Is it good for curvy figures?",
462
+ "What did reviewers like the best?",
463
+ "Is it comfortable?",
464
+ "What size should I choose?",
465
+ "Is it good for all body shapes?",
466
+ ],
467
+ plp: [
468
+ "Which styles have the most reviews?",
469
+ "Which styles are best for my body shape?",
470
+ "Which styles are most popular?",
471
+ "How does Spanx source its products?",
472
+ ],
473
+ },
474
+ staticPLPImages: [
475
+ "default_plp_embedded_1.webp",
476
+ "default_plp_embedded_2.webp",
477
+ "default_plp_embedded_3.webp",
478
+ "default_plp_embedded_4.webp",
479
+ ],
480
+ },
481
+ customerServiceIntegration: {
482
+ ...defaultSpanxOrgConfig.customerServiceIntegration,
483
+ integrationMode: CustomerServiceIntegrationMode.full,
484
+ provider: CustomerServiceType.kustomer,
485
+ welcomeTitle: "Chat with a Spanx Stylist",
486
+ showNameInput: true,
487
+ showWelcomeOnForm: true,
488
+ showAISuggestionsWithinBusinessHours: false,
489
+ chatEnabledDuringBusinessHours: true,
490
+ waitingMessagePosition: "BEFORE_MESSAGES",
491
+ formAiName: "Spanx AI Assistant...",
492
+ legalMessage:
493
+ 'This session will be transcribed for quality purposes. Please see our terms of use within the US <a href="https://spanx.com/pages/interactive-services-consent-and-disclaimers" target="_blank">here</a> and CA <a href="https://spanx.ca/pages/interactive-services-consent-and-disclaimers" target="_blank">here</a>',
494
+ welcomeDescription:
495
+ "Our stylists look forward to assisting you Mon- Fri between 9:30AM to 7:30PM ET, and Sat-Sun 9:30AM to 6:00PM ET!",
496
+ getCustomWaitingMessage: (name?: string) =>
497
+ `Hold tight${name ? ` ${name}` : ""}, your stylist is almost here`,
498
+ withinBusinessHoursMessage:
499
+ "👋 Hi there! We're here to help with any questions or support you need—whether you're tracking an order, finding the perfect product, or anything in between. To keep things quick, some responses might come from AI, but if you'd rather chat with a real person, just let us know—we've got you! <br /><br />Click “send a message” below to get started 💬",
500
+ withinBusinessHoursWaitingMessage:
501
+ "A Spanx Stylist will be with you within 5 minutes. Thanks for your patience.<br /><br />In the meantime, can you give us a little information about yourself?",
502
+ withinBusinessHoursFormMessage:
503
+ "👋 Hi there! We're here to help with any questions or support you need—whether you're tracking an order, finding the perfect product, or anything in between. To keep things quick, some responses might come from AI, but if you'd rather chat with a real person, just let us know—we've got you! <br /><br />Fill out your information and click “send a message” below to get started 💬",
504
+ outsideBusinessHoursMessage:
505
+ "👋 Hi, we’re sorry but this is outside of our service hours.<br /><br />You can leave a message and a stylist will get back to your within 24 hours. If you need an answer right away, ask your Spanx AI shopping assistant for help.",
506
+ outsideBusinessHoursFormMessage:
507
+ "👋 Hi, we’re sorry but this is outside of our service hours.<br /><br />You can leave a message and a stylist will get back to your within 24 hours. If you need an answer right away, ask your Spanx AI shopping assistant for help.",
508
+ outsideBusinessHoursWaitingMessage:
509
+ "⚡⚡ You're all set! A stylist will get back to you within 24 hours with an answer to your question. In the meantime, feel free to use our SPANX AI Shopping Assistant.",
510
+ suggestedAIQuestions: [
511
+ "How can I return or exchange my order?",
512
+ "Where is my order?",
513
+ "My item is damaged what can I do?",
514
+ "Where can I find my order number?",
515
+ ],
516
+ businessHoursStartUTC: "9:30AM",
517
+ businessHoursEndUTC: "7:30PM",
518
+ businessHoursTimezone: "-05:00", // ET
519
+ withinBusinessHoursInitialState: ChatState.INITIAL,
520
+ outsideBusinessHoursInitialState: ChatState.INITIAL,
521
+ withinBusinessHoursButtontext: "Send a message",
522
+ outsideBusinessHoursButtontext: "Leave a message",
523
+ },
524
+ productReviewConfig: {
525
+ ...defaultSpanxOrgConfig.productReviewConfig!,
526
+ styleVariant: "bordered",
527
+ colorVariant: "neutral",
528
+ },
529
+ pageCardConfig: {
530
+ ...defaultSpanxOrgConfig.pageCardConfig!,
531
+ variant: "outlined",
532
+ hoverVariant: "shadow",
533
+ iconVariant: "primary",
534
+ },
535
+ productCardConfig: {
536
+ ...defaultSpanxOrgConfig.productCardConfig!,
537
+ variant: "transparentBordered",
538
+ },
539
+ chatHeader: {
540
+ ...defaultSpanxOrgConfig.chatHeader,
541
+ imageSrc: CdnService.getAssetURL("spanx-logo.svg", OrgShortName.Spanx),
542
+ collapsedColor: colorVar(ColorNames.BackgroundSecondaryDark),
543
+ expandedColor: colorVar(ColorNames.BackgroundLight),
544
+ chevronColor: colorVar(ColorNames.BackgroundDark),
545
+ borderBottom: `1px solid ${colorVar(ColorNames.BorderLight)}`,
546
+ closeIcon: GrClose,
547
+ customerSupportSwitchConfig: {
548
+ ...defaultSpanxOrgConfig.chatHeader.customerSupportSwitchConfig!,
549
+ variant: "detached",
550
+ supportTitle: "Support",
551
+ spiffyTitle: "AI Assistant",
552
+ spiffyTitleHasLogo: true,
553
+ borderColor: colorVar(ColorNames.TextPrimary),
554
+ selectedTextColor: colorVar(ColorNames.TextLight),
555
+ backgroundColor: colorVar(ColorNames.TextPrimary),
556
+ selectedBackgroundColor: colorVar(ColorNames.TextPrimary),
557
+ unselectedBackgroundColor: colorVar(ColorNames.BackgroundSecondaryDark),
558
+ unselectedTextColor: colorVar(ColorNames.TextPrimary),
559
+ },
560
+ },
561
+ floatingChatConfig: {
562
+ ...defaultSpanxOrgConfig.floatingChatConfig,
563
+ neverShowSingleProductCards: false,
564
+ termsAndConditionsConfig: {
565
+ copy: "This session will be transcribed for quality purposes. Please see our terms of use for",
566
+ link: "https://spanx.com/pages/terms-of-use",
567
+ linkText: "SPANX.com here.",
568
+ },
569
+ replyInputConfig: {
570
+ size: "lg",
571
+ sendIcon: "arrowUp",
572
+ },
573
+ suggestionButtonConfig: {
574
+ variant: "outlined",
575
+ hoverVariant: "dark",
576
+ answerVariant: "outlined",
577
+ },
578
+ },
579
+ conversationalSearch: {
580
+ enabled: true,
581
+ suggestions: [
582
+ "Shapewear that won’t show through clothes",
583
+ "Styles with the strongest compression",
584
+ "Comfortable styles for all day wear",
585
+ "Best shapewear for tummy control",
586
+ ],
587
+ entrypointBtnColor: "linear-gradient(to right, #004EA2, #6941C6)",
588
+ entrypointBtnTextColor: "#004EA2",
589
+ entrypointBtnBorderColor: "#004EA2",
590
+ // TODO: Migrate it to the new mount point structure.
591
+ entrypointContainer: "id|shopify-section-header",
592
+ productGridContainer: "id|MainContentWrapper",
593
+ entrypointTrigger: "id|search-input",
594
+ generalSearchBtn: "query|button.header-search__button",
595
+ pageContent: "id|MainContent",
596
+ searchContent: "id|search-content",
597
+ sortingFont: "ivypresto-headline, serif",
598
+ optionsFont: "Inter",
599
+ },
600
+
601
+ merchantVariantSettings: {
602
+ dynamicVariants: {
603
+ enabled: true,
604
+ refreshInterval: 500,
605
+ },
606
+ },
607
+
608
+ merchantOverrideCss: `
609
+ .spiffy-product-review-card-container {
610
+ background: var(--spiffy-colors-background-light) !important;
611
+ }
612
+ .spiffy-star-rating-container {
613
+ background: var(--spiffy-colors-background-secondary-dark) !important;
614
+ }
615
+ .spiffy-star-rating-star {
616
+ fill: var(--spiffy-colors-text-primary) !important;
617
+ }
618
+ .spiffy-product-review-header-reviewer {
619
+ color: var(--spiffy-colors-text-primary) !important;
620
+ }
621
+ .spiffy-mini-verified-buyer-icon {
622
+ fill: var(--spiffy-colors-text-primary) !important;
623
+ }
624
+
625
+ #spiffy-product-review-card-read-more-container {
626
+ text-transform: uppercase;
627
+ font-weight: 600;
628
+ }
629
+
630
+ #spiffy-ai-chat-preview-contents h1, h2, h3, h4, h5, h6 {
631
+ --chakra-fonts-heading: 'inter', 'Poppins', sans-serif;
632
+ }
633
+
634
+ #spiffy-chat-preview-user-query-button {
635
+ margin-top: 8px;
636
+ }
637
+ #spiffy-ai-floating-button {
638
+ z-index: 2147483001 !important;
639
+ }
640
+
641
+ /* SuggestionBarV2 CSS */
642
+ #spiffy-top-suggestion-bar-contents button{
643
+ border-radius: 24px !important;
644
+ }
645
+
646
+ #spiffy-top-suggestion-bar-contents button span{
647
+ font-size: 14px !important;
648
+ font-weight: 500;
649
+ }
650
+
651
+ #spiffy-top-suggestion-bar-contents button svg{
652
+ width: 14px;
653
+ height: 14px;
654
+ }
655
+
656
+ #spiffy-bottom-suggestion-bar-contents button {
657
+ border-color: var(--spiffy-colors-border-outline) !important;
658
+ }
659
+
660
+ #spiffy-bottom-suggestion-bar-contents button:hover {
661
+ background-color: var(--spiffy-colors-border-light) !important;
662
+ border-color:var(--spiffy-colors-border-light) !important;
663
+ }
664
+
665
+ #spiffy-bottom-suggestion-bar-contents button span{
666
+ font-size: 14px !important;
667
+ font-weight: 500;
668
+ }
669
+
670
+ #spiffy-bottom-suggestion-bar-contents button svg{
671
+ width: 14px;
672
+ height: 14px;
673
+ }
674
+
675
+ .spiffy-chat-header-container {
676
+ padding-block: 8px;
677
+ border-bottom: 1px solid ${colorVar(ColorNames.BorderLight)};
678
+ background-color: white;
679
+ }
680
+
681
+ .spiffy-chat-header-close-button {
682
+ background-color: var(--spiffy-colors-text-light);
683
+ color: var(--spiffy-colors-background-primary);
684
+ }
685
+
686
+ .spiffy-suggestion-bar-button {
687
+ border: 1px solid ${colorVar(ColorNames.BorderOutline)};
688
+ border-radius: 24px;
689
+ }
690
+
691
+ .spiffy-suggestion-button-answer-class {
692
+ border: 1px solid ${colorVar(ColorNames.TextPrimary)} !important;
693
+ }
694
+
695
+ .spiffy-suggestion-button-answer-class:hover {
696
+ background-color: ${colorVar(
697
+ ColorNames.BackgroundSecondaryDark
698
+ )} !important;
699
+ border-color: ${colorVar(
700
+ ColorNames.BackgroundSecondaryDark
701
+ )} !important;
702
+ color: ${colorVar(ColorNames.TextLink)} !important;
703
+ }
704
+
705
+ .spiffy-suggestion-button-question-class {
706
+ border: 1px solid ${colorVar(ColorNames.BorderLight)} !important;
707
+ border-radius: 4px;
708
+ }
709
+
710
+ .spiffy-suggestion-button-question-class:hover {
711
+ border-color: ${colorVar(
712
+ ColorNames.BackgroundSecondaryDark
713
+ )} !important;
714
+ background-color: ${colorVar(
715
+ ColorNames.BackgroundSecondaryDark
716
+ )} !important;
717
+ color: ${colorVar(ColorNames.TextPrimary)} !important;
718
+ fill: ${colorVar(ColorNames.TextPrimary)} !important;
719
+ stroke: ${colorVar(ColorNames.TextPrimary)} !important;
720
+ }
721
+
722
+ .spiffy-suggestion-button-text-class {
723
+ font-size: 13px;
724
+ }
725
+
726
+ .spiffy-social-proof-content-image {
727
+ border-radius: 0px;
728
+ box-shadow: none;
729
+ }
730
+
731
+ .spiffy-user-query-button {
732
+ font-size: 12px;
733
+ }
734
+
735
+ .spiffy-image-banner-subtitle {
736
+ text-transform: uppercase;
737
+ }
738
+ .spiffy-customer-service-legal-message a {
739
+ text-decoration-line: underline;
740
+ }
741
+ .spiffy-customer-service-legal-message a:hover {
742
+ color: var(--spiffy-colors-text-link);
743
+ }
744
+ .spiffy-tag-pill-text {
745
+ color: var(--spiffy-colors-text-light);
746
+ }
747
+ .spiffy-product-card-title {
748
+ font-family: var(--chakra-fonts-heading);
749
+ color: var(--spiffy-colors-text-primary);
750
+ }
751
+ .spiffy-product-card-text-color {
752
+ color: var(--spiffy-colors-text-secondary);
753
+ }
754
+ .spiffy-product-card-rating-star-color {
755
+ fill: var(--spiffy-colors-text-primary);
756
+ }
757
+ .spiffy-switch-to-agent-button-unselected-text-color {
758
+ color: var(--spiffy-colors-text-primary);
759
+ }
760
+ .spiffy-switch-to-agent-button-selected-text-color {
761
+ color: var(--spiffy-colors-text-light);
762
+ }
763
+ .spiffy-switch-to-agent-button-selected-background-color {
764
+ background-color: var(--spiffy-colors-text-primary);
765
+ }
766
+ .spiffy-switch-to-agent-button-unselected-background-color {
767
+ background-color: var(--spiffy-colors-background-secondary-dark);
768
+ }
769
+ .spiffy-switch-to-agent-button-border-color {
770
+ border-color: var(--spiffy-colors-text-primary);
771
+ }
772
+ .spiffy-switch-to-agent-button-background-color {
773
+ background-color: var(--spiffy-colors-text-primary);
774
+ }
775
+ .spiffy-switch-to-agent-button-hover-background-color:hover {
776
+ background-color: var(--spiffy-colors-text-primary);
777
+ }
778
+ .spiffy-switch-to-agent-button-hover-text-color:hover {
779
+ color: var(--spiffy-colors-text-light);
780
+ }
781
+ .spiffy-switch-to-agent-button-selected-fill-color {
782
+ fill: var(--spiffy-colors-text-light);
783
+ }
784
+ .spiffy-switch-to-agent-button-unselected-fill-color {
785
+ fill: var(--spiffy-colors-text-primary);
786
+ }
787
+ .spiffy-chat-preview-footer-background-color {
788
+ background-color: var(--spiffy-colors-background-secondary-dark);
789
+ }
790
+ .spiffy-message-content-container {
791
+ font-size: 15px !important;
792
+ font-weight: 300 !important;
793
+ line-height: 160%;
794
+ }
795
+ `,
796
+ };
797
+ };
798
+
799
+ const spanxOrgInfo = {
800
+ shortName: "spanx",
801
+ name: "SPANX",
802
+ domain: "spanx.com",
803
+ defaultProductId: "39773580984531",
804
+ alwaysEnabledMerchants: true,
805
+ orgUIConfig: spanxOrgUIConfig,
806
+ orgColors: () => spanxColors,
807
+ orgPageConfig: spanxPageConfig,
808
+ } satisfies BasicOrgInfoType;
809
+
810
+ export { spanxOrgInfo };