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