@envive-ai/react-toolkit-v3 0.3.6 → 0.3.8

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 (538) hide show
  1. package/dist/AnimatedText/AnimatedText.cjs +19 -4
  2. package/dist/AnimatedText/AnimatedText.d.cts +3 -3
  3. package/dist/AnimatedText/AnimatedText.d.ts +3 -3
  4. package/dist/AnimatedText/AnimatedText.js +20 -5
  5. package/dist/AnimatedText/types/types.d.cts +0 -4
  6. package/dist/AnimatedText/types/types.d.ts +0 -4
  7. package/dist/CSSVariablesEditor/CssVariablesEditorComponent.d.cts +2 -2
  8. package/dist/CSSVariablesEditor/CssVariablesEditorComponent.d.ts +2 -2
  9. package/dist/CSSVariablesEditor/hooks/useGetCssVariablesOptions.cjs +3 -3
  10. package/dist/CSSVariablesEditor/hooks/useGetCssVariablesOptions.js +3 -3
  11. package/dist/CSSVariablesEditor/hooks/useGetCurrentMerchantColors.cjs +1 -1
  12. package/dist/CSSVariablesEditor/hooks/useGetCurrentMerchantColors.js +1 -1
  13. package/dist/CSSVariablesEditor/hooks/useGetDefaultCssVariables.cjs +10 -10
  14. package/dist/CSSVariablesEditor/hooks/useGetDefaultCssVariables.js +10 -10
  15. package/dist/CSSVariablesEditor/hooks/useHandleUpdateCssVars.cjs +9 -9
  16. package/dist/CSSVariablesEditor/hooks/useHandleUpdateCssVars.js +9 -9
  17. package/dist/CSSVariablesEditor/utils/functions.cjs +2 -2
  18. package/dist/CSSVariablesEditor/utils/functions.js +2 -2
  19. package/dist/Carousel/Carousel.cjs +2 -2
  20. package/dist/Carousel/Carousel.d.cts +2 -2
  21. package/dist/Carousel/Carousel.d.ts +2 -2
  22. package/dist/Carousel/Carousel.js +2 -2
  23. package/dist/Carousel/components/Container.cjs +2 -2
  24. package/dist/Carousel/components/Container.js +2 -2
  25. package/dist/Carousel/hooks/useGetBadgeProperties.cjs +1 -1
  26. package/dist/Carousel/hooks/useGetBadgeProperties.js +1 -1
  27. package/dist/Carousel/types/types.d.ts +1 -1
  28. package/dist/ChatFooter/ChatFooter.cjs +2 -2
  29. package/dist/ChatFooter/ChatFooter.d.cts +2 -2
  30. package/dist/ChatFooter/ChatFooter.js +2 -2
  31. package/dist/ChatFooter/components/Layout.cjs +2 -2
  32. package/dist/ChatFooter/components/Layout.d.ts +1 -1
  33. package/dist/ChatFooter/components/Layout.js +2 -2
  34. package/dist/ChatFooter/components/PromptSuggestions.d.ts +1 -1
  35. package/dist/ChatFooter/components/index.d.cts +5 -5
  36. package/dist/ChatFooter/components/index.d.ts +5 -5
  37. package/dist/ChatFooter/hooks/useGetChatScrollProperties.cjs +1 -1
  38. package/dist/ChatFooter/hooks/useGetChatScrollProperties.js +1 -1
  39. package/dist/ChatFooter/hooks/useGetContainerProperties.cjs +10 -9
  40. package/dist/ChatFooter/hooks/useGetContainerProperties.js +10 -9
  41. package/dist/ChatFooter/types/types.d.ts +1 -1
  42. package/dist/ChatHeader/ChatHeader.cjs +4 -3
  43. package/dist/ChatHeader/ChatHeader.d.cts +3 -2
  44. package/dist/ChatHeader/ChatHeader.d.ts +3 -2
  45. package/dist/ChatHeader/ChatHeader.js +4 -3
  46. package/dist/ChatHeader/components/CloseButton.cjs +1 -1
  47. package/dist/ChatHeader/components/CloseButton.js +1 -1
  48. package/dist/ChatHeader/components/Handle.cjs +38 -4
  49. package/dist/ChatHeader/components/Handle.js +38 -4
  50. package/dist/ChatHeader/components/Toggle.cjs +4 -4
  51. package/dist/ChatHeader/components/Toggle.js +4 -4
  52. package/dist/ChatHeader/hooks/useGetCloseButtonProperties.cjs +1 -1
  53. package/dist/ChatHeader/hooks/useGetCloseButtonProperties.js +1 -1
  54. package/dist/ChatHeader/hooks/useGetHandleProperties.cjs +17 -17
  55. package/dist/ChatHeader/hooks/useGetHandleProperties.js +17 -17
  56. package/dist/ChatHeader/hooks/useGetLayoutProperties.cjs +8 -8
  57. package/dist/ChatHeader/hooks/useGetLayoutProperties.js +8 -8
  58. package/dist/ChatHeader/hooks/useGetToggleOptionProperties.cjs +17 -17
  59. package/dist/ChatHeader/hooks/useGetToggleOptionProperties.js +17 -17
  60. package/dist/ChatHeader/hooks/useGetToggleProperties.cjs +3 -3
  61. package/dist/ChatHeader/hooks/useGetToggleProperties.js +3 -3
  62. package/dist/ChatHeader/hooks/useToggleLogoSelector.cjs +1 -1
  63. package/dist/ChatHeader/hooks/useToggleLogoSelector.js +1 -1
  64. package/dist/ChatHeader/types/index.d.cts +2 -0
  65. package/dist/ChatHeader/types/index.d.ts +4 -2
  66. package/dist/ChatPreview/ChatPreview.cjs +2 -2
  67. package/dist/ChatPreview/ChatPreview.d.ts +2 -2
  68. package/dist/ChatPreview/ChatPreview.js +2 -2
  69. package/dist/ChatPreview/components/Message.cjs +4 -3
  70. package/dist/ChatPreview/components/Message.js +4 -3
  71. package/dist/ChatPreview/types/types.d.ts +1 -1
  72. package/dist/ChatPreviewComparison/ChatPreviewComparison.cjs +2 -2
  73. package/dist/ChatPreviewComparison/ChatPreviewComparison.d.cts +2 -2
  74. package/dist/ChatPreviewComparison/ChatPreviewComparison.d.ts +2 -2
  75. package/dist/ChatPreviewComparison/ChatPreviewComparison.js +2 -2
  76. package/dist/ChatPreviewComparison/components/Headline.cjs +3 -3
  77. package/dist/ChatPreviewComparison/components/Headline.js +3 -3
  78. package/dist/ChatPreviewComparison/components/Layout.cjs +7 -7
  79. package/dist/ChatPreviewComparison/components/Layout.js +7 -7
  80. package/dist/ChatPreviewComparison/components/Message.cjs +7 -6
  81. package/dist/ChatPreviewComparison/components/Message.js +7 -6
  82. package/dist/ChatPreviewComparison/types/types.d.ts +1 -1
  83. package/dist/ChatPreviewLoading/ChatPreviewLoading.d.cts +2 -2
  84. package/dist/ChatPreviewLoading/ChatPreviewLoading.d.ts +2 -2
  85. package/dist/Container/Container.d.cts +174 -174
  86. package/dist/Container/Container.d.ts +174 -174
  87. package/dist/DesignTokens/DesignTokensComponent.d.cts +2 -2
  88. package/dist/DesignTokens/DesignTokensComponent.d.ts +2 -2
  89. package/dist/DesignTokens/components/Typography.cjs +1 -1
  90. package/dist/DesignTokens/components/Typography.js +1 -1
  91. package/dist/Disclaimer/Disclaimer.cjs +23 -0
  92. package/dist/Disclaimer/Disclaimer.d.cts +19 -0
  93. package/dist/Disclaimer/Disclaimer.d.ts +19 -0
  94. package/dist/Disclaimer/Disclaimer.js +22 -0
  95. package/dist/Disclaimer/components/Container.cjs +26 -0
  96. package/dist/Disclaimer/components/Container.js +24 -0
  97. package/dist/Disclaimer/components/DisclaimerContent.cjs +19 -0
  98. package/dist/Disclaimer/components/DisclaimerContent.js +18 -0
  99. package/dist/Disclaimer/components/index.cjs +11 -0
  100. package/dist/Disclaimer/components/index.js +11 -0
  101. package/dist/Disclaimer/index.cjs +3 -0
  102. package/dist/Disclaimer/index.d.cts +2 -0
  103. package/dist/Disclaimer/index.d.ts +2 -0
  104. package/dist/Disclaimer/index.js +3 -0
  105. package/dist/Disclaimer/types/types.d.cts +30 -0
  106. package/dist/Disclaimer/types/types.d.ts +30 -0
  107. package/dist/DocumentRetrievalCard/DocumentRetrievalCard.d.cts +2 -2
  108. package/dist/DocumentRetrievalCard/DocumentRetrievalCard.d.ts +2 -2
  109. package/dist/DocumentRetrievalCard/components/Layout.cjs +2 -2
  110. package/dist/DocumentRetrievalCard/components/Layout.js +2 -2
  111. package/dist/DocumentRetrievalCard/components/ViewArticleButton/components/Icon.cjs +1 -1
  112. package/dist/DocumentRetrievalCard/components/ViewArticleButton/components/Icon.js +1 -1
  113. package/dist/DocumentRetrievalCard/hooks/useGetBackgroundColorsProperties.cjs +1 -1
  114. package/dist/DocumentRetrievalCard/hooks/useGetBackgroundColorsProperties.js +1 -1
  115. package/dist/DocumentRetrievalCard/hooks/useGetBorderProperties.cjs +1 -1
  116. package/dist/DocumentRetrievalCard/hooks/useGetBorderProperties.js +1 -1
  117. package/dist/DocumentRetrievalCard/hooks/useGetBorderRadiusProperties.cjs +1 -1
  118. package/dist/DocumentRetrievalCard/hooks/useGetBorderRadiusProperties.js +1 -1
  119. package/dist/DocumentRetrievalCard/hooks/useGetIconBackgroundProperties.cjs +1 -1
  120. package/dist/DocumentRetrievalCard/hooks/useGetIconBackgroundProperties.js +1 -1
  121. package/dist/DocumentRetrievalCard/hooks/useGetIconColorProperties.cjs +1 -1
  122. package/dist/DocumentRetrievalCard/hooks/useGetIconColorProperties.js +1 -1
  123. package/dist/DocumentRetrievalCard/hooks/useGetLabelTextCaseProperties.cjs +1 -1
  124. package/dist/DocumentRetrievalCard/hooks/useGetLabelTextCaseProperties.js +1 -1
  125. package/dist/DocumentRetrievalCard/hooks/useGetLabelTypographyProperties.cjs +1 -1
  126. package/dist/DocumentRetrievalCard/hooks/useGetLabelTypographyProperties.js +1 -1
  127. package/dist/DocumentRetrievalCard/index.cjs +1 -1
  128. package/dist/DocumentRetrievalCard/index.d.ts +1 -1
  129. package/dist/DocumentRetrievalCard/index.js +1 -1
  130. package/dist/DocumentRetrievalCard/types/index.d.ts +1 -1
  131. package/dist/DocumentRetrievalCard/utils/functions.cjs +1 -1
  132. package/dist/DocumentRetrievalCard/utils/functions.js +1 -1
  133. package/dist/FloatingButton/FloatingButton.cjs +2 -1
  134. package/dist/FloatingButton/FloatingButton.d.cts +4 -3
  135. package/dist/FloatingButton/FloatingButton.d.ts +4 -3
  136. package/dist/FloatingButton/FloatingButton.js +2 -1
  137. package/dist/FloatingButton/components/Container.cjs +2 -2
  138. package/dist/FloatingButton/components/Container.js +2 -2
  139. package/dist/FloatingButton/hooks/useGetButtonProperties.cjs +2 -2
  140. package/dist/FloatingButton/hooks/useGetButtonProperties.js +2 -2
  141. package/dist/FloatingButton/hooks/useGetContainerProperties.cjs +2 -2
  142. package/dist/FloatingButton/hooks/useGetContainerProperties.js +2 -2
  143. package/dist/FloatingButton/types/types.cjs +4 -4
  144. package/dist/FloatingButton/types/types.d.cts +8 -4
  145. package/dist/FloatingButton/types/types.d.ts +9 -5
  146. package/dist/FloatingButton/types/types.js +4 -4
  147. package/dist/FloatingChat/FloatingChat.cjs +121 -44
  148. package/dist/FloatingChat/FloatingChat.d.cts +4 -2
  149. package/dist/FloatingChat/FloatingChat.d.ts +4 -2
  150. package/dist/FloatingChat/FloatingChat.js +123 -46
  151. package/dist/FloatingChat/components/AgentMessage.cjs +49 -24
  152. package/dist/FloatingChat/components/AgentMessage.js +49 -24
  153. package/dist/FloatingChat/components/ChatMessages.cjs +63 -44
  154. package/dist/FloatingChat/components/ChatMessages.js +62 -43
  155. package/dist/FloatingChat/components/DocumentRetrievalCardsCarousel.cjs +2 -1
  156. package/dist/FloatingChat/components/DocumentRetrievalCardsCarousel.js +2 -1
  157. package/dist/FloatingChat/components/Layout.cjs +20 -16
  158. package/dist/FloatingChat/components/Layout.js +20 -16
  159. package/dist/FloatingChat/components/MessageDivider.cjs +8 -2
  160. package/dist/FloatingChat/components/MessageDivider.js +8 -2
  161. package/dist/FloatingChat/components/ModalSheet.cjs +184 -0
  162. package/dist/FloatingChat/components/ModalSheet.js +182 -0
  163. package/dist/FloatingChat/components/SalesAgentProductCardsCarousel.cjs +3 -2
  164. package/dist/FloatingChat/components/SalesAgentProductCardsCarousel.js +3 -2
  165. package/dist/FloatingChat/components/index.cjs +1 -0
  166. package/dist/FloatingChat/components/index.js +1 -0
  167. package/dist/FloatingChat/hooks/useChatSuggestions.cjs +25 -0
  168. package/dist/FloatingChat/hooks/useChatSuggestions.js +24 -0
  169. package/dist/FloatingChat/hooks/useFilteredChatMessages.cjs +24 -0
  170. package/dist/FloatingChat/hooks/useFilteredChatMessages.js +23 -0
  171. package/dist/FloatingChat/hooks/usePreventScroll.cjs +117 -0
  172. package/dist/FloatingChat/hooks/usePreventScroll.js +116 -0
  173. package/dist/FloatingChat/hooks/useScrollToBottom.cjs +109 -11
  174. package/dist/FloatingChat/hooks/useScrollToBottom.js +110 -12
  175. package/dist/FloatingChat/hooks/useSnapCalculator.cjs +37 -0
  176. package/dist/FloatingChat/hooks/useSnapCalculator.js +35 -0
  177. package/dist/FloatingChat/hooks/useSnapControl.cjs +82 -0
  178. package/dist/FloatingChat/hooks/useSnapControl.js +81 -0
  179. package/dist/FloatingChat/hooks/useSnapSetup.cjs +56 -0
  180. package/dist/FloatingChat/hooks/useSnapSetup.js +55 -0
  181. package/dist/FloatingChat/types/types.d.cts +9 -5
  182. package/dist/FloatingChat/types/types.d.ts +10 -6
  183. package/dist/FloatingChat/utils/functions.cjs +1 -0
  184. package/dist/FloatingChat/utils/functions.js +1 -0
  185. package/dist/Image/Image.d.cts +2 -2
  186. package/dist/Image/Image.d.ts +2 -2
  187. package/dist/ImageGallery/ImageGallery.cjs +1 -1
  188. package/dist/ImageGallery/ImageGallery.d.cts +2 -2
  189. package/dist/ImageGallery/ImageGallery.d.ts +2 -2
  190. package/dist/ImageGallery/ImageGallery.js +1 -1
  191. package/dist/ImageGallery/components/Layout.cjs +2 -2
  192. package/dist/ImageGallery/components/Layout.js +2 -2
  193. package/dist/ImageGallery/types/types.d.ts +1 -1
  194. package/dist/ImageGallery/utils/functions.cjs +1 -1
  195. package/dist/ImageGallery/utils/functions.js +1 -1
  196. package/dist/MarkdownProcessor/MarkdownProcessor.d.cts +2 -2
  197. package/dist/MarkdownProcessor/MarkdownProcessor.d.ts +2 -2
  198. package/dist/MarkdownProcessor/components/MarkdownLink.cjs +4 -1
  199. package/dist/MarkdownProcessor/components/MarkdownLink.js +4 -1
  200. package/dist/Message/components/AgentContent.cjs +6 -2
  201. package/dist/Message/components/AgentContent.js +6 -2
  202. package/dist/Message/components/LinkButton.cjs +3 -3
  203. package/dist/Message/components/LinkButton.d.cts +5 -1
  204. package/dist/Message/components/LinkButton.d.ts +5 -1
  205. package/dist/Message/components/LinkButton.js +3 -3
  206. package/dist/Message/hooks/useGetLinkButtonProperties.cjs +1 -1
  207. package/dist/Message/hooks/useGetLinkButtonProperties.js +1 -1
  208. package/dist/OrderLookupCard/OrderLookupCard.cjs +2 -2
  209. package/dist/OrderLookupCard/OrderLookupCard.js +2 -2
  210. package/dist/OrderLookupCard/hooks/useGetContainerProperties.cjs +1 -1
  211. package/dist/OrderLookupCard/hooks/useGetContainerProperties.js +1 -1
  212. package/dist/OrderLookupCard/hooks/useGetImageBorderRadiusProperties.cjs +1 -1
  213. package/dist/OrderLookupCard/hooks/useGetImageBorderRadiusProperties.js +1 -1
  214. package/dist/OrderLookupCard/hooks/useGetStatusLabelProperties.cjs +1 -1
  215. package/dist/OrderLookupCard/hooks/useGetStatusLabelProperties.js +1 -1
  216. package/dist/OrderLookupCard/hooks/useGetTrackOrderLinkProperties.cjs +1 -1
  217. package/dist/OrderLookupCard/hooks/useGetTrackOrderLinkProperties.js +1 -1
  218. package/dist/OrderLookupCard/types/index.d.ts +1 -1
  219. package/dist/ProductCard/ProductCard.cjs +43 -0
  220. package/dist/ProductCard/ProductCard.d.cts +23 -0
  221. package/dist/ProductCard/ProductCard.d.ts +23 -0
  222. package/dist/ProductCard/ProductCard.js +42 -0
  223. package/dist/ProductCard/components/Carousel.cjs +25 -0
  224. package/dist/ProductCard/components/Carousel.js +24 -0
  225. package/dist/ProductCard/components/Header.cjs +42 -0
  226. package/dist/ProductCard/components/Header.js +41 -0
  227. package/dist/ProductCard/components/Poster.cjs +18 -0
  228. package/dist/ProductCard/components/Poster.js +17 -0
  229. package/dist/ProductCard/components/index.cjs +13 -0
  230. package/dist/ProductCard/components/index.js +13 -0
  231. package/dist/ProductCard/hooks/useGetCarouselProperties.cjs +8 -0
  232. package/dist/ProductCard/hooks/useGetCarouselProperties.js +7 -0
  233. package/dist/ProductCard/hooks/useGetHeaderProperties.cjs +11 -0
  234. package/dist/ProductCard/hooks/useGetHeaderProperties.js +10 -0
  235. package/dist/ProductCard/hooks/useGetPosterProperties.cjs +13 -0
  236. package/dist/ProductCard/hooks/useGetPosterProperties.js +12 -0
  237. package/dist/ProductCard/index.cjs +3 -0
  238. package/dist/ProductCard/index.d.cts +3 -0
  239. package/dist/ProductCard/index.d.ts +3 -0
  240. package/dist/ProductCard/index.js +3 -0
  241. package/dist/ProductCard/types/index.d.cts +74 -0
  242. package/dist/ProductCard/types/index.d.ts +74 -0
  243. package/dist/PromptButton/PromptButton.cjs +1 -1
  244. package/dist/PromptButton/PromptButton.d.cts +2 -2
  245. package/dist/PromptButton/PromptButton.d.ts +2 -2
  246. package/dist/PromptButton/PromptButton.js +1 -1
  247. package/dist/PromptButton/hooks/useGetIconColorsProperties.cjs +1 -1
  248. package/dist/PromptButton/hooks/useGetIconColorsProperties.js +1 -1
  249. package/dist/PromptButton/types/index.d.ts +1 -1
  250. package/dist/PromptButtonCarouselWithImage/PromptButtonCarouselWithImage.cjs +1 -1
  251. package/dist/PromptButtonCarouselWithImage/PromptButtonCarouselWithImage.d.cts +2 -2
  252. package/dist/PromptButtonCarouselWithImage/PromptButtonCarouselWithImage.js +1 -1
  253. package/dist/PromptButtonCarouselWithImage/types/types.d.ts +1 -1
  254. package/dist/PromptCarousel/PromptCarousel.cjs +2 -3
  255. package/dist/PromptCarousel/PromptCarousel.d.cts +2 -2
  256. package/dist/PromptCarousel/PromptCarousel.d.ts +2 -2
  257. package/dist/PromptCarousel/PromptCarousel.js +2 -3
  258. package/dist/PromptCarousel/hooks/useCarouselRefs.cjs +1 -1
  259. package/dist/PromptCarousel/hooks/useCarouselRefs.js +2 -2
  260. package/dist/PromptCarousel/types/types.d.ts +1 -1
  261. package/dist/ReviewCard/ReviewCard.cjs +1 -1
  262. package/dist/ReviewCard/ReviewCard.d.cts +2 -2
  263. package/dist/ReviewCard/ReviewCard.d.ts +2 -2
  264. package/dist/ReviewCard/ReviewCard.js +1 -1
  265. package/dist/ReviewCard/components/Container.cjs +2 -2
  266. package/dist/ReviewCard/components/Container.d.ts +1 -1
  267. package/dist/ReviewCard/components/Container.js +2 -2
  268. package/dist/ReviewCard/components/Rating.d.ts +1 -1
  269. package/dist/ReviewCard/components/ReadMoreButton.cjs +2 -2
  270. package/dist/ReviewCard/components/ReadMoreButton.d.ts +1 -1
  271. package/dist/ReviewCard/components/ReadMoreButton.js +2 -2
  272. package/dist/ReviewCard/components/index.d.cts +6 -6
  273. package/dist/ReviewCard/components/index.d.ts +5 -5
  274. package/dist/ReviewCard/hooks/useGetBackgroundColorsProperties.cjs +1 -1
  275. package/dist/ReviewCard/hooks/useGetBackgroundColorsProperties.js +1 -1
  276. package/dist/ReviewCard/hooks/useGetBorderProperties.cjs +1 -1
  277. package/dist/ReviewCard/hooks/useGetBorderProperties.js +1 -1
  278. package/dist/ReviewCard/hooks/useGetBorderRadiusProperties.cjs +1 -1
  279. package/dist/ReviewCard/hooks/useGetBorderRadiusProperties.js +1 -1
  280. package/dist/ReviewCard/hooks/useGetRatingBackgroundProperties.cjs +1 -1
  281. package/dist/ReviewCard/hooks/useGetRatingBackgroundProperties.js +1 -1
  282. package/dist/ReviewCard/hooks/useGetReadMoreTypographyProperties.cjs +1 -1
  283. package/dist/ReviewCard/hooks/useGetReadMoreTypographyProperties.js +1 -1
  284. package/dist/ReviewCard/hooks/useGetStarIconProperties.cjs +1 -1
  285. package/dist/ReviewCard/hooks/useGetStarIconProperties.js +1 -1
  286. package/dist/ReviewCard/types/types.d.ts +1 -1
  287. package/dist/SalesAgentProductCard/SalesAgentProductCard.cjs +1 -1
  288. package/dist/SalesAgentProductCard/SalesAgentProductCard.d.cts +2 -2
  289. package/dist/SalesAgentProductCard/SalesAgentProductCard.d.ts +2 -2
  290. package/dist/SalesAgentProductCard/SalesAgentProductCard.js +1 -1
  291. package/dist/SalesAgentProductCard/components/Container.cjs +3 -3
  292. package/dist/SalesAgentProductCard/components/Container.d.ts +1 -1
  293. package/dist/SalesAgentProductCard/components/Container.js +3 -3
  294. package/dist/SalesAgentProductCard/components/ProductName.cjs +1 -1
  295. package/dist/SalesAgentProductCard/components/ProductName.d.ts +1 -1
  296. package/dist/SalesAgentProductCard/components/ProductName.js +1 -1
  297. package/dist/SalesAgentProductCard/components/Rate.cjs +1 -1
  298. package/dist/SalesAgentProductCard/components/Rate.d.ts +1 -1
  299. package/dist/SalesAgentProductCard/components/Rate.js +1 -1
  300. package/dist/SalesAgentProductCard/components/index.d.cts +2 -2
  301. package/dist/SalesAgentProductCard/components/index.d.ts +7 -7
  302. package/dist/SalesAgentProductCard/hooks/useGetContainerProperties.cjs +1 -1
  303. package/dist/SalesAgentProductCard/hooks/useGetContainerProperties.js +1 -1
  304. package/dist/SalesAgentProductCard/hooks/useGetProductDescriptionProperties.cjs +1 -1
  305. package/dist/SalesAgentProductCard/hooks/useGetProductDescriptionProperties.js +1 -1
  306. package/dist/SalesAgentProductCard/hooks/useGetProductNameProperties.cjs +1 -1
  307. package/dist/SalesAgentProductCard/hooks/useGetProductNameProperties.js +1 -1
  308. package/dist/SalesAgentProductCard/hooks/useGetStarIconProperties.cjs +1 -1
  309. package/dist/SalesAgentProductCard/hooks/useGetStarIconProperties.js +1 -1
  310. package/dist/SalesAgentProductCard/types/types.d.ts +1 -1
  311. package/dist/SocialProof/SocialProof.cjs +23 -11
  312. package/dist/SocialProof/SocialProof.d.cts +2 -2
  313. package/dist/SocialProof/SocialProof.d.ts +2 -2
  314. package/dist/SocialProof/SocialProof.js +22 -10
  315. package/dist/SocialProof/components/Headline.cjs +4 -4
  316. package/dist/SocialProof/components/Headline.js +4 -4
  317. package/dist/SocialProof/components/LayoutFourHorizontal.cjs +2 -2
  318. package/dist/SocialProof/components/LayoutFourHorizontal.js +2 -2
  319. package/dist/SocialProof/components/Subheadline.cjs +2 -2
  320. package/dist/SocialProof/components/Subheadline.js +2 -2
  321. package/dist/SocialProof/components/Textfield.cjs +4 -2
  322. package/dist/SocialProof/components/Textfield.js +4 -2
  323. package/dist/SocialProof/hooks/index.cjs +1 -0
  324. package/dist/SocialProof/hooks/index.js +3 -0
  325. package/dist/SocialProof/hooks/useSocialProofCount.cjs +48 -0
  326. package/dist/SocialProof/hooks/useSocialProofCount.d.cts +15 -0
  327. package/dist/SocialProof/hooks/useSocialProofCount.d.ts +15 -0
  328. package/dist/SocialProof/hooks/useSocialProofCount.js +46 -0
  329. package/dist/SocialProof/index.cjs +6 -1
  330. package/dist/SocialProof/index.d.cts +3 -2
  331. package/dist/SocialProof/index.d.ts +3 -2
  332. package/dist/SocialProof/index.js +4 -2
  333. package/dist/SocialProof/types/types.cjs +14 -1
  334. package/dist/SocialProof/types/types.d.cts +26 -6
  335. package/dist/SocialProof/types/types.d.ts +27 -7
  336. package/dist/SocialProof/types/types.js +12 -1
  337. package/dist/SocialProof/utils/functions.cjs +1 -1
  338. package/dist/SocialProof/utils/functions.js +1 -1
  339. package/dist/Stack/Stack.d.cts +2 -2
  340. package/dist/TextField/TextField.cjs +1 -1
  341. package/dist/TextField/TextField.js +1 -1
  342. package/dist/TextField/components/Input.cjs +1 -1
  343. package/dist/TextField/components/Input.js +1 -1
  344. package/dist/TextField/hooks/useGetContainerProperties.cjs +5 -5
  345. package/dist/TextField/hooks/useGetContainerProperties.js +5 -5
  346. package/dist/TextField/types/index.d.ts +1 -1
  347. package/dist/TextField/utils/getInputClasses.cjs +1 -1
  348. package/dist/TextField/utils/getInputClasses.js +1 -1
  349. package/dist/TextField/utils/getSendIconElement.cjs +1 -1
  350. package/dist/TextField/utils/getSendIconElement.js +1 -1
  351. package/dist/TitledPromptCarousel/TitledPromptCarousel.cjs +2 -2
  352. package/dist/TitledPromptCarousel/TitledPromptCarousel.d.cts +2 -2
  353. package/dist/TitledPromptCarousel/TitledPromptCarousel.d.ts +2 -2
  354. package/dist/TitledPromptCarousel/TitledPromptCarousel.js +2 -2
  355. package/dist/TitledPromptCarousel/types/index.d.ts +1 -1
  356. package/dist/Tokens/index.cjs +13 -13
  357. package/dist/Tokens/index.d.ts +13 -13
  358. package/dist/Tokens/index.js +13 -13
  359. package/dist/TypingAnimation/TypingAnimation.cjs +2 -2
  360. package/dist/TypingAnimation/TypingAnimation.d.cts +2 -2
  361. package/dist/TypingAnimation/TypingAnimation.d.ts +2 -2
  362. package/dist/TypingAnimation/TypingAnimation.js +2 -2
  363. package/dist/TypingAnimation/hooks/useGetTypographyVariant.cjs +2 -2
  364. package/dist/TypingAnimation/hooks/useGetTypographyVariant.js +2 -2
  365. package/dist/TypingAnimation/types/index.d.ts +1 -1
  366. package/dist/Typography/Typography.d.cts +4 -4
  367. package/dist/Typography/Typography.d.ts +4 -4
  368. package/dist/WelcomeMessage/WelcomeMessage.cjs +1 -1
  369. package/dist/WelcomeMessage/WelcomeMessage.js +1 -1
  370. package/dist/WelcomeMessage/components/Container.cjs +2 -2
  371. package/dist/WelcomeMessage/components/Container.js +2 -2
  372. package/dist/WelcomeMessage/hooks/useGetContainerProperties.cjs +1 -1
  373. package/dist/WelcomeMessage/hooks/useGetContainerProperties.js +1 -1
  374. package/dist/WelcomeMessage/hooks/useGetSparkleIconProperties.cjs +3 -1
  375. package/dist/WelcomeMessage/hooks/useGetSparkleIconProperties.js +3 -1
  376. package/dist/WelcomeMessage/types/types.cjs +1 -1
  377. package/dist/WelcomeMessage/types/types.d.ts +1 -1
  378. package/dist/WelcomeMessage/types/types.js +1 -1
  379. package/dist/WidgetTextField/WidgetTextField.cjs +7 -3
  380. package/dist/WidgetTextField/WidgetTextField.d.cts +3 -2
  381. package/dist/WidgetTextField/WidgetTextField.d.ts +3 -2
  382. package/dist/WidgetTextField/WidgetTextField.js +7 -3
  383. package/dist/WidgetTextField/components/Container.cjs +9 -3
  384. package/dist/WidgetTextField/components/Container.js +9 -3
  385. package/dist/WidgetTextField/components/Icon.cjs +45 -14
  386. package/dist/WidgetTextField/components/Icon.js +43 -14
  387. package/dist/WidgetTextField/components/Skeleton.cjs +1 -1
  388. package/dist/WidgetTextField/components/Skeleton.js +1 -1
  389. package/dist/WidgetTextField/hooks/useGetContainerProperties.cjs +5 -4
  390. package/dist/WidgetTextField/hooks/useGetContainerProperties.js +5 -4
  391. package/dist/WidgetTextField/types/types.cjs +10 -0
  392. package/dist/WidgetTextField/types/types.d.cts +9 -0
  393. package/dist/WidgetTextField/types/types.d.ts +10 -1
  394. package/dist/WidgetTextField/types/types.js +9 -0
  395. package/dist/WidgetWrapper/WidgetWrapper.d.cts +2 -2
  396. package/dist/WidgetWrapper/WidgetWrapper.d.ts +2 -2
  397. package/dist/WidgetWrapperWithTitle/WidgetWrapperWithTitle.d.cts +2 -2
  398. package/dist/WidgetWrapperWithTitle/WidgetWrapperWithTitle.d.ts +2 -2
  399. package/dist/node_modules/jotai/esm/react.cjs +44 -0
  400. package/dist/node_modules/jotai/esm/react.js +42 -0
  401. package/dist/node_modules/jotai/esm/vanilla/internals.cjs +523 -0
  402. package/dist/node_modules/jotai/esm/vanilla/internals.js +522 -0
  403. package/dist/node_modules/jotai/esm/vanilla.cjs +22 -0
  404. package/dist/node_modules/jotai/esm/vanilla.js +22 -0
  405. package/dist/{src → packages/components-v3/src}/models/colorsConfig.cjs +1 -3
  406. package/dist/{src → packages/components-v3/src}/models/colorsConfig.js +1 -2
  407. package/dist/packages/components-v3/tokens/utils.cjs +14 -0
  408. package/dist/packages/components-v3/tokens/utils.js +12 -0
  409. package/dist/styles.css +1 -1
  410. package/dist/utils/resolveTheme.cjs +1 -1
  411. package/dist/utils/resolveTheme.js +1 -1
  412. package/dist/utils/useCheckIsMobile.cjs +1 -1
  413. package/dist/utils/useCheckIsMobile.js +1 -1
  414. package/dist/utils/useResponsiveValue.cjs +1 -1
  415. package/dist/utils/useResponsiveValue.d.ts +1 -1
  416. package/dist/utils/useResponsiveValue.js +1 -1
  417. package/package.json +9 -1
  418. package/src/components/AnimatedText/AnimatedText.tsx +25 -6
  419. package/src/components/AnimatedText/types/types.ts +0 -4
  420. package/src/components/ChatFooter/hooks/useGetContainerProperties.ts +3 -4
  421. package/src/components/ChatHeader/ChatHeader.tsx +2 -0
  422. package/src/components/ChatHeader/components/Handle.tsx +37 -3
  423. package/src/components/ChatHeader/hooks/useGetHandleProperties.ts +16 -16
  424. package/src/components/ChatHeader/hooks/useGetLayoutProperties.ts +8 -10
  425. package/src/components/ChatHeader/hooks/useGetToggleOptionProperties.ts +16 -16
  426. package/src/components/ChatHeader/hooks/useGetToggleProperties.ts +2 -2
  427. package/src/components/ChatHeader/types/index.ts +3 -0
  428. package/src/components/ChatPreview/__tests__/ChatPreview.test.tsx +17 -8
  429. package/src/components/ChatPreview/components/Message.tsx +13 -7
  430. package/src/components/ChatPreviewComparison/__tests__/ChatPreviewComparison.test.tsx +16 -6
  431. package/src/components/ChatPreviewComparison/components/Message.tsx +13 -7
  432. package/src/components/DesignTokens/components/Typography.tsx +1 -1
  433. package/src/components/Disclaimer/Disclaimer.tsx +27 -0
  434. package/src/components/Disclaimer/components/Container.tsx +35 -0
  435. package/src/components/Disclaimer/components/DisclaimerContent.tsx +18 -0
  436. package/src/components/Disclaimer/components/index.ts +7 -0
  437. package/src/components/Disclaimer/index.ts +1 -0
  438. package/src/components/Disclaimer/types/types.ts +27 -0
  439. package/src/components/FloatingButton/FloatingButton.tsx +2 -0
  440. package/src/components/FloatingButton/components/Container.tsx +3 -0
  441. package/src/components/FloatingButton/hooks/useGetButtonProperties.ts +4 -3
  442. package/src/components/FloatingButton/hooks/useGetContainerProperties.ts +2 -1
  443. package/src/components/FloatingButton/types/types.ts +9 -4
  444. package/src/components/FloatingChat/FloatingChat.tsx +186 -64
  445. package/src/components/FloatingChat/components/AgentMessage.tsx +51 -19
  446. package/src/components/FloatingChat/components/ChatMessages.tsx +35 -2
  447. package/src/components/FloatingChat/components/DocumentRetrievalCardsCarousel.tsx +3 -0
  448. package/src/components/FloatingChat/components/Layout.tsx +28 -6
  449. package/src/components/FloatingChat/components/MessageDivider.tsx +8 -2
  450. package/src/components/FloatingChat/components/ModalSheet.tsx +288 -0
  451. package/src/components/FloatingChat/components/SalesAgentProductCardsCarousel.tsx +7 -2
  452. package/src/components/FloatingChat/components/index.ts +3 -0
  453. package/src/components/FloatingChat/hooks/useChatSuggestions.ts +49 -0
  454. package/src/components/FloatingChat/hooks/useFilteredChatMessages.ts +43 -0
  455. package/src/components/FloatingChat/hooks/usePreventScroll.ts +207 -0
  456. package/src/components/FloatingChat/hooks/useScrollToBottom.ts +153 -11
  457. package/src/components/FloatingChat/hooks/useSnapCalculator.ts +41 -0
  458. package/src/components/FloatingChat/hooks/useSnapControl.ts +131 -0
  459. package/src/components/FloatingChat/hooks/useSnapSetup.ts +103 -0
  460. package/src/components/FloatingChat/types/types.ts +9 -5
  461. package/src/components/FloatingChat/utils/functions.ts +1 -0
  462. package/src/components/MarkdownProcessor/components/MarkdownLink.tsx +2 -0
  463. package/src/components/Message/__tests__/Message.test.tsx +40 -2
  464. package/src/components/Message/components/AgentContent.tsx +10 -2
  465. package/src/components/Message/components/LinkButton.tsx +3 -2
  466. package/src/components/Message/hooks/useGetLinkButtonProperties.ts +1 -1
  467. package/src/components/ProductCard/ProductCard.tsx +54 -0
  468. package/src/components/ProductCard/__tests__/ProductCard.test.tsx +191 -0
  469. package/src/components/ProductCard/components/Carousel.tsx +26 -0
  470. package/src/components/ProductCard/components/Header.tsx +53 -0
  471. package/src/components/ProductCard/components/Poster.tsx +15 -0
  472. package/src/components/ProductCard/components/index.ts +9 -0
  473. package/src/components/ProductCard/hooks/useGetCarouselProperties.ts +7 -0
  474. package/src/components/ProductCard/hooks/useGetHeaderProperties.ts +9 -0
  475. package/src/components/ProductCard/hooks/useGetInputProperties.ts +22 -0
  476. package/src/components/ProductCard/hooks/useGetPosterProperties.ts +19 -0
  477. package/src/components/ProductCard/index.ts +2 -0
  478. package/src/components/ProductCard/types/index.ts +79 -0
  479. package/src/components/PromptCarousel/PromptCarousel.tsx +0 -1
  480. package/src/components/PromptCarousel/hooks/useCarouselRefs.ts +5 -4
  481. package/src/components/SocialProof/SocialProof.tsx +25 -12
  482. package/src/components/SocialProof/__tests__/SocialProof.test.tsx +66 -17
  483. package/src/components/SocialProof/components/Textfield.tsx +4 -0
  484. package/src/components/SocialProof/hooks/index.ts +2 -0
  485. package/src/components/SocialProof/hooks/useSocialProofCount.ts +67 -0
  486. package/src/components/SocialProof/index.ts +2 -1
  487. package/src/components/SocialProof/types/types.ts +30 -6
  488. package/src/components/TextField/components/Input.tsx +6 -1
  489. package/src/components/TextField/hooks/useGetContainerProperties.ts +4 -4
  490. package/src/components/WelcomeMessage/hooks/useGetSparkleIconProperties.ts +5 -2
  491. package/src/components/WidgetTextField/WidgetTextField.tsx +8 -2
  492. package/src/components/WidgetTextField/__tests__/WidgetTextField.test.tsx +54 -0
  493. package/src/components/WidgetTextField/components/Container.tsx +2 -2
  494. package/src/components/WidgetTextField/components/Icon.tsx +50 -7
  495. package/src/components/WidgetTextField/hooks/useGetContainerProperties.ts +5 -3
  496. package/src/components/WidgetTextField/types/types.ts +10 -0
  497. package/dist/tokens/utils.cjs +0 -6
  498. package/dist/tokens/utils.js +0 -5
  499. /package/dist/{src → packages/components-v3/src}/models/colorsConfig.d.ts +0 -0
  500. /package/dist/{tokens → packages/components-v3/tokens}/aspectRatio/aspectRatio.cjs +0 -0
  501. /package/dist/{tokens → packages/components-v3/tokens}/aspectRatio/aspectRatio.d.ts +0 -0
  502. /package/dist/{tokens → packages/components-v3/tokens}/aspectRatio/aspectRatio.js +0 -0
  503. /package/dist/{tokens → packages/components-v3/tokens}/breakpoints/breakpoints.cjs +0 -0
  504. /package/dist/{tokens → packages/components-v3/tokens}/breakpoints/breakpoints.d.ts +0 -0
  505. /package/dist/{tokens → packages/components-v3/tokens}/breakpoints/breakpoints.js +0 -0
  506. /package/dist/{tokens → packages/components-v3/tokens}/colors/colors.cjs +0 -0
  507. /package/dist/{tokens → packages/components-v3/tokens}/colors/colors.d.ts +0 -0
  508. /package/dist/{tokens → packages/components-v3/tokens}/colors/colors.js +0 -0
  509. /package/dist/{tokens → packages/components-v3/tokens}/montion/motion.cjs +0 -0
  510. /package/dist/{tokens → packages/components-v3/tokens}/montion/motion.d.ts +0 -0
  511. /package/dist/{tokens → packages/components-v3/tokens}/montion/motion.js +0 -0
  512. /package/dist/{tokens → packages/components-v3/tokens}/radius/radius.cjs +0 -0
  513. /package/dist/{tokens → packages/components-v3/tokens}/radius/radius.d.ts +0 -0
  514. /package/dist/{tokens → packages/components-v3/tokens}/radius/radius.js +0 -0
  515. /package/dist/{tokens → packages/components-v3/tokens}/spacing/spacing.cjs +0 -0
  516. /package/dist/{tokens → packages/components-v3/tokens}/spacing/spacing.d.ts +0 -0
  517. /package/dist/{tokens → packages/components-v3/tokens}/spacing/spacing.js +0 -0
  518. /package/dist/{tokens → packages/components-v3/tokens}/theme/theme.cjs +0 -0
  519. /package/dist/{tokens → packages/components-v3/tokens}/theme/theme.d.ts +0 -0
  520. /package/dist/{tokens → packages/components-v3/tokens}/theme/theme.js +0 -0
  521. /package/dist/{tokens → packages/components-v3/tokens}/typography/fontFamily.cjs +0 -0
  522. /package/dist/{tokens → packages/components-v3/tokens}/typography/fontFamily.d.ts +0 -0
  523. /package/dist/{tokens → packages/components-v3/tokens}/typography/fontFamily.js +0 -0
  524. /package/dist/{tokens → packages/components-v3/tokens}/typography/fontSize.cjs +0 -0
  525. /package/dist/{tokens → packages/components-v3/tokens}/typography/fontSize.d.ts +0 -0
  526. /package/dist/{tokens → packages/components-v3/tokens}/typography/fontSize.js +0 -0
  527. /package/dist/{tokens → packages/components-v3/tokens}/typography/fontWeight.cjs +0 -0
  528. /package/dist/{tokens → packages/components-v3/tokens}/typography/fontWeight.d.ts +0 -0
  529. /package/dist/{tokens → packages/components-v3/tokens}/typography/fontWeight.js +0 -0
  530. /package/dist/{tokens → packages/components-v3/tokens}/typography/letterSpacing.cjs +0 -0
  531. /package/dist/{tokens → packages/components-v3/tokens}/typography/letterSpacing.d.ts +0 -0
  532. /package/dist/{tokens → packages/components-v3/tokens}/typography/letterSpacing.js +0 -0
  533. /package/dist/{tokens → packages/components-v3/tokens}/typography/lineHeight.cjs +0 -0
  534. /package/dist/{tokens → packages/components-v3/tokens}/typography/lineHeight.d.ts +0 -0
  535. /package/dist/{tokens → packages/components-v3/tokens}/typography/lineHeight.js +0 -0
  536. /package/dist/{tokens → packages/components-v3/tokens}/typography/typography.cjs +0 -0
  537. /package/dist/{tokens → packages/components-v3/tokens}/typography/typography.d.ts +0 -0
  538. /package/dist/{tokens → packages/components-v3/tokens}/typography/typography.js +0 -0
@@ -2,12 +2,15 @@ import '@testing-library/jest-dom';
2
2
  import { beforeEach, describe, expect, it, vi } from 'vitest';
3
3
  import { fireEvent, render, screen, waitFor } from '@testing-library/react';
4
4
  import { SocialProof } from '../SocialProof';
5
- import { DynamicLayout } from '../types/types';
5
+ import { DynamicLayout, PageVariant } from '../types/types';
6
6
  import { ImageGalleryLayout } from '../../ImageGallery/types/types';
7
7
  import { PromptButtonVariant } from '../../PromptButton/types';
8
8
  import { PromptCarouselRows } from '../../PromptCarousel/types/types';
9
9
  import { WidgetWrapperVariant } from '../../WidgetWrapper/types/types';
10
10
  import { Theme } from '../../Tokens';
11
+ import { SOCIAL_PROOF_COUNT_KEY } from '../hooks';
12
+
13
+ const COUNT_KEY_MOCK = 'test-social-proof';
11
14
 
12
15
  const mockUseCheckIsMobile = vi.fn(() => ({ isMobile: false, viewportWidth: 1024 }));
13
16
  vi.mock('../../utils/useCheckIsMobile', () => ({
@@ -26,12 +29,35 @@ vi.mock('src/components/utils/useGetContentSize', () => ({
26
29
  }),
27
30
  }));
28
31
 
32
+ const localStorageMock = (() => {
33
+ let store: Record<string, string> = {};
34
+ return {
35
+ getItem: (key: string) => store[key] || null,
36
+ setItem: (key: string, value: string) => {
37
+ store[key] = value.toString();
38
+ },
39
+ removeItem: (key: string) => {
40
+ delete store[key];
41
+ },
42
+ clear: () => {
43
+ store = {};
44
+ },
45
+ };
46
+ })();
47
+
48
+ Object.defineProperty(window, 'localStorage', {
49
+ value: localStorageMock,
50
+ });
51
+
29
52
  describe('SocialProof', () => {
30
53
  const defaultProps = {
31
- baseProps: {},
54
+ baseProps: {
55
+ id: 'test-social-proof',
56
+ pageVariant: PageVariant.PageVisit,
57
+ countKey: COUNT_KEY_MOCK,
58
+ },
32
59
  widgetContentProps: {
33
60
  titleLabel: 'Shopping Assistant',
34
- numberOfCustomersText: '114 customers',
35
61
  customerQueryText: 'asked which products are best for gifting...',
36
62
  primaryButtonText: 'This is a prompt button',
37
63
  secondaryButtonTitleText: 'What else are customers asking?',
@@ -61,14 +87,37 @@ describe('SocialProof', () => {
61
87
  beforeEach(() => {
62
88
  vi.clearAllMocks();
63
89
  mockUseCheckIsMobile.mockReturnValue({ isMobile: false, viewportWidth: 1024 });
90
+ localStorageMock.clear();
64
91
  });
65
92
 
66
93
  describe('Basic rendering', () => {
67
- it('should render with default props', () => {
94
+ it('should render with default props', async () => {
68
95
  render(<SocialProof {...defaultProps} />);
69
- expect(screen.getByText('114 customers')).toBeInTheDocument();
96
+ // Customer count should be between 100-200 and formatted as "{number} customers"
97
+ const customerCountText = screen.getByText(/\d+ customers/);
98
+ expect(customerCountText).toBeInTheDocument();
99
+ const match = customerCountText.textContent?.match(/(\d+)/);
100
+ if (match) {
101
+ const count = parseInt(match[1], 10);
102
+ expect(count).toBeGreaterThanOrEqual(100);
103
+ expect(count).toBeLessThanOrEqual(200);
104
+ }
70
105
  expect(screen.getByText('asked which products are best for gifting...')).toBeInTheDocument();
71
106
  expect(screen.getByText('This is a prompt button')).toBeInTheDocument();
107
+
108
+ // Verify persistence of customer count in localStorage:
109
+ await waitFor(() => {
110
+ const storedData = localStorageMock.getItem(SOCIAL_PROOF_COUNT_KEY);
111
+ expect(storedData).not.toBeNull();
112
+ if (storedData) {
113
+ const customerCountMap = JSON.parse(storedData);
114
+ expect(customerCountMap).toHaveProperty(PageVariant.PageVisit);
115
+ expect(customerCountMap[PageVariant.PageVisit]).toHaveProperty(COUNT_KEY_MOCK);
116
+ const storedCount = customerCountMap[PageVariant.PageVisit][COUNT_KEY_MOCK];
117
+ expect(storedCount).toBeGreaterThanOrEqual(100);
118
+ expect(storedCount).toBeLessThanOrEqual(200);
119
+ }
120
+ });
72
121
  });
73
122
 
74
123
  it('should apply id attribute when provided', () => {
@@ -124,7 +173,7 @@ describe('SocialProof', () => {
124
173
  widgetStyleProps={{ imageGalleryLayout: ImageGalleryLayout.FOUR_GRID }}
125
174
  />,
126
175
  );
127
- expect(screen.getByText('114 customers')).toBeInTheDocument();
176
+ expect(screen.getByText(/\d+ customers/)).toBeInTheDocument();
128
177
  expect(screen.getByText('This is a prompt button')).toBeInTheDocument();
129
178
  });
130
179
 
@@ -135,7 +184,7 @@ describe('SocialProof', () => {
135
184
  widgetStyleProps={{ imageGalleryLayout: ImageGalleryLayout.FOUR_HORIZONTAL }}
136
185
  />,
137
186
  );
138
- expect(screen.getByText('114 customers')).toBeInTheDocument();
187
+ expect(screen.getByText(/\d+ customers/)).toBeInTheDocument();
139
188
  expect(screen.getByText('This is a prompt button')).toBeInTheDocument();
140
189
  });
141
190
 
@@ -146,7 +195,7 @@ describe('SocialProof', () => {
146
195
  widgetStyleProps={{ imageGalleryLayout: ImageGalleryLayout.SINGLE }}
147
196
  />,
148
197
  );
149
- expect(screen.getByText('114 customers')).toBeInTheDocument();
198
+ expect(screen.getByText(/\d+ customers/)).toBeInTheDocument();
150
199
  expect(screen.getByText('This is a prompt button')).toBeInTheDocument();
151
200
  });
152
201
 
@@ -158,7 +207,7 @@ describe('SocialProof', () => {
158
207
  widgetStyleProps={{ imageGalleryLayout: ImageGalleryLayout.FOUR_GRID }}
159
208
  />,
160
209
  );
161
- expect(screen.getByText('114 customers')).toBeInTheDocument();
210
+ expect(screen.getByText(/\d+ customers/)).toBeInTheDocument();
162
211
  expect(screen.getByText('This is a prompt button')).toBeInTheDocument();
163
212
  });
164
213
 
@@ -172,7 +221,7 @@ describe('SocialProof', () => {
172
221
  }}
173
222
  />,
174
223
  );
175
- expect(screen.getByText('114 customers')).toBeInTheDocument();
224
+ expect(screen.getByText(/\d+ customers/)).toBeInTheDocument();
176
225
  expect(screen.getByText('This is a prompt button')).toBeInTheDocument();
177
226
  });
178
227
  });
@@ -199,7 +248,7 @@ describe('SocialProof', () => {
199
248
  widgetStyleProps={{ hideImage: false, imageGalleryLayout: ImageGalleryLayout.FOUR_GRID }}
200
249
  />,
201
250
  );
202
- expect(screen.getByText('114 customers')).toBeInTheDocument();
251
+ expect(screen.getByText(/\d+ customers/)).toBeInTheDocument();
203
252
  });
204
253
 
205
254
  it('should hide textfield when hideTextField is true', () => {
@@ -311,7 +360,7 @@ describe('SocialProof', () => {
311
360
  widgetStyleProps={{ theme, imageGalleryLayout: ImageGalleryLayout.FOUR_GRID }}
312
361
  />,
313
362
  );
314
- expect(screen.getByText('114 customers')).toBeInTheDocument();
363
+ expect(screen.getByText(/\d+ customers/)).toBeInTheDocument();
315
364
  unmount();
316
365
  });
317
366
  });
@@ -331,7 +380,7 @@ describe('SocialProof', () => {
331
380
  widgetStyleProps={{ variant, imageGalleryLayout: ImageGalleryLayout.FOUR_GRID }}
332
381
  />,
333
382
  );
334
- expect(screen.getByText('114 customers')).toBeInTheDocument();
383
+ expect(screen.getByText(/\d+ customers/)).toBeInTheDocument();
335
384
  unmount();
336
385
  });
337
386
  });
@@ -416,7 +465,7 @@ describe('SocialProof', () => {
416
465
  }}
417
466
  />,
418
467
  );
419
- expect(screen.getByText('114 customers')).toBeInTheDocument();
468
+ expect(screen.getByText(/\d+ customers/)).toBeInTheDocument();
420
469
  });
421
470
 
422
471
  it('should render with dynamicLayout WIDE', () => {
@@ -429,7 +478,7 @@ describe('SocialProof', () => {
429
478
  }}
430
479
  />,
431
480
  );
432
- expect(screen.getByText('114 customers')).toBeInTheDocument();
481
+ expect(screen.getByText(/\d+ customers/)).toBeInTheDocument();
433
482
  });
434
483
  });
435
484
 
@@ -450,7 +499,7 @@ describe('SocialProof', () => {
450
499
  widgetEventProps={{ handleTextFieldClick: vi.fn() }}
451
500
  />,
452
501
  );
453
- expect(screen.getByText('114 customers')).toBeInTheDocument();
502
+ expect(screen.getByText(/\d+ customers/)).toBeInTheDocument();
454
503
  });
455
504
 
456
505
  it('should render with empty secondaryButtonTexts array', () => {
@@ -463,7 +512,7 @@ describe('SocialProof', () => {
463
512
  }}
464
513
  />,
465
514
  );
466
- expect(screen.getByText('114 customers')).toBeInTheDocument();
515
+ expect(screen.getByText(/\d+ customers/)).toBeInTheDocument();
467
516
  });
468
517
  });
469
518
  });
@@ -1,17 +1,20 @@
1
1
  import { WidgetTextField } from '../../WidgetTextField';
2
2
  import { resolveTheme } from '../../utils/resolveTheme';
3
3
  import { Theme } from '../../../../tokens/theme/theme';
4
+ import { IconVariant } from '../../WidgetTextField/types/types';
4
5
 
5
6
  export type TextfieldProps = {
6
7
  theme: Theme;
7
8
  placeholder: string;
8
9
  handleTextFieldClick: (text: string) => void;
10
+ iconVariant?: IconVariant;
9
11
  };
10
12
 
11
13
  export const Textfield = ({
12
14
  theme = Theme.GLOBAL_CUSTOM,
13
15
  placeholder,
14
16
  handleTextFieldClick,
17
+ iconVariant = IconVariant.DEFAULT,
15
18
  }: TextfieldProps) => {
16
19
  const finalTheme = resolveTheme(theme);
17
20
 
@@ -19,6 +22,7 @@ export const Textfield = ({
19
22
  <WidgetTextField
20
23
  theme={finalTheme}
21
24
  placeholder={placeholder}
25
+ iconVariant={iconVariant}
22
26
  onClick={() => handleTextFieldClick(placeholder)}
23
27
  />
24
28
  );
@@ -0,0 +1,2 @@
1
+ export { useSocialProofCount } from './useSocialProofCount';
2
+ export { SOCIAL_PROOF_COUNT_KEY } from './useSocialProofCount';
@@ -0,0 +1,67 @@
1
+ import { useEffect, useState } from 'react';
2
+ import { PageVariant } from '../types/types';
3
+
4
+ const RANDOM_NUMBER_MIN = 100;
5
+ const RANDOM_NUMBER_MAX = 200;
6
+ export const SOCIAL_PROOF_COUNT_KEY = 'v3_social_proof_values';
7
+
8
+ type SocialProofCount = Record<string, Record<string, number>>;
9
+
10
+ interface UseSocialProofCountParams {
11
+ pageVariant?: PageVariant;
12
+ countKey?: string;
13
+ id?: string;
14
+ }
15
+
16
+ export const useSocialProofCount = ({
17
+ pageVariant,
18
+ countKey,
19
+ id,
20
+ }: UseSocialProofCountParams): string => {
21
+ const [customerCount, setCustomerCount] = useState<number>(() =>
22
+ Math.floor(Math.random() * (RANDOM_NUMBER_MAX - RANDOM_NUMBER_MIN + 1) + RANDOM_NUMBER_MIN),
23
+ );
24
+
25
+ useEffect(() => {
26
+ const variant = pageVariant || PageVariant.PageVisit;
27
+ const key = countKey || id || 'default';
28
+
29
+ try {
30
+ const storedData = localStorage.getItem(SOCIAL_PROOF_COUNT_KEY);
31
+ let customerCountMap: SocialProofCount = {};
32
+
33
+ if (storedData) {
34
+ try {
35
+ customerCountMap = JSON.parse(storedData) as SocialProofCount;
36
+ } catch (parseError) {
37
+ console.warn('Failed to parse social proof count from localStorage:', parseError);
38
+ return;
39
+ }
40
+ }
41
+
42
+ if (customerCountMap[variant]?.[key]) {
43
+ setCustomerCount(customerCountMap[variant][key]);
44
+ } else {
45
+ const randomCount = Math.floor(
46
+ Math.random() * (RANDOM_NUMBER_MAX - RANDOM_NUMBER_MIN + 1) + RANDOM_NUMBER_MIN,
47
+ );
48
+
49
+ if (!customerCountMap[variant]) {
50
+ customerCountMap[variant] = {};
51
+ }
52
+ customerCountMap[variant][key] = randomCount;
53
+
54
+ try {
55
+ localStorage.setItem(SOCIAL_PROOF_COUNT_KEY, JSON.stringify(customerCountMap));
56
+ setCustomerCount(randomCount);
57
+ } catch (storageError) {
58
+ console.warn('Failed to save social proof count to localStorage:', storageError);
59
+ }
60
+ }
61
+ } catch (error) {
62
+ console.warn('Error managing social proof count:', error);
63
+ }
64
+ }, [pageVariant, countKey, id]);
65
+
66
+ return `${customerCount} customers`;
67
+ };
@@ -1,3 +1,4 @@
1
1
  export { SocialProof } from './SocialProof';
2
2
  export type { SocialProofProps } from './types/types';
3
- export { DynamicLayout } from './types/types';
3
+ export { DynamicLayout, PageVariant, WidgetKind } from './types/types';
4
+ export { useSocialProofCount } from './hooks';
@@ -9,6 +9,17 @@ export enum DynamicLayout {
9
9
  WIDE = 'wide',
10
10
  }
11
11
 
12
+ export enum PageVariant {
13
+ PLP = 'PLP',
14
+ PDP = 'PDP',
15
+ PageVisit = 'PageVisit',
16
+ }
17
+
18
+ export enum WidgetKind {
19
+ STATIC = 'static',
20
+ DYNAMIC = 'dynamic',
21
+ }
22
+
12
23
  /**
13
24
  * Base props for the SocialProof component container.
14
25
  *
@@ -34,6 +45,18 @@ export type BaseProps = {
34
45
  * Inline styles to apply to the container.
35
46
  */
36
47
  style?: React.CSSProperties;
48
+
49
+ /**
50
+ * Page variant for localStorage persistence of customer counts (PLP, PDP, or PageVisit).
51
+ */
52
+ pageVariant?: PageVariant;
53
+
54
+ /**
55
+ * Specific identifier for the pageVariant (e.g., productId for PDP, plpId for PLP, category for PageVisit).
56
+ * Used as the key for localStorage persistence.
57
+ * Falls back to the `id` prop if not provided.
58
+ */
59
+ countKey?: string;
37
60
  };
38
61
 
39
62
  /**
@@ -53,12 +76,6 @@ export type WidgetContentProps = {
53
76
  */
54
77
  titleLabel: string;
55
78
 
56
- /**
57
- * Text displaying the number of customers (e.g., "114 customers").
58
- * Displayed in the headline section.
59
- */
60
- numberOfCustomersText?: string;
61
-
62
79
  /**
63
80
  * Text displaying what customers asked (e.g., "asked which products are best for gifting...").
64
81
  * Displayed in the headline section alongside the customer count.
@@ -120,6 +137,13 @@ export type WidgetStyleProps = {
120
137
  */
121
138
  variant?: WidgetWrapperVariant;
122
139
 
140
+ /**
141
+ * Kind of the social proof widget.
142
+ *
143
+ * @default WidgetKind.STATIC
144
+ */
145
+ kind?: WidgetKind;
146
+
123
147
  /**
124
148
  * Custom hex color for the card background (e.g., "#FF5733").
125
149
  * Overrides theme colors when provided.
@@ -49,7 +49,12 @@ export const Input = ({
49
49
  onFocus={onFocus}
50
50
  onBlur={onBlur}
51
51
  disabled={disabled}
52
- className={classNames(inputClasses, className, disabled && 'envive-tw-cursor-not-allowed')}
52
+ className={classNames(
53
+ inputClasses,
54
+ 'focus-visible:envive-tw-shadow-none focus-visible:envive-tw-outline-none',
55
+ className,
56
+ disabled && 'envive-tw-cursor-not-allowed',
57
+ )}
53
58
  style={style}
54
59
  aria-label={ariaLabel}
55
60
  aria-disabled={disabled}
@@ -22,7 +22,7 @@ export const useGetContainerProperties = ({
22
22
  const containerClassesMap: Record<Theme, ContainerProperties> = {
23
23
  [Theme.STANDARD]: {
24
24
  containerLayoutClasses:
25
- 'envive-tw-flex envive-tw-min-w-[358px] envive-tw-h-[40px] envive-tw-py-2 envive-tw-px-4 envive-tw-justify-between envive-tw-items-center envive-tw-flex-shrink-0',
25
+ 'envive-tw-flex envive-tw-h-[40px] envive-tw-py-2 envive-tw-px-4 envive-tw-justify-between envive-tw-items-center envive-tw-flex-shrink-0',
26
26
  containerDefaultClasses:
27
27
  'envive-tw-border envive-tw-border-solid envive-tw-bg-background-light envive-tw-rounded-global-custom',
28
28
  containerBorderClasses: 'envive-tw-border-border-light',
@@ -33,7 +33,7 @@ export const useGetContainerProperties = ({
33
33
  },
34
34
  [Theme.MODERN]: {
35
35
  containerLayoutClasses:
36
- 'envive-tw-flex envive-tw-min-w-[358px] envive-tw-h-[40px] envive-tw-py-2 envive-tw-pr-2 envive-tw-pl-4 envive-tw-justify-between envive-tw-items-center envive-tw-flex-shrink-0',
36
+ 'envive-tw-flex envive-tw-h-[40px] envive-tw-py-2 envive-tw-pr-2 envive-tw-pl-4 envive-tw-justify-between envive-tw-items-center envive-tw-flex-shrink-0',
37
37
  containerDefaultClasses:
38
38
  'envive-tw-border envive-tw-border-solid envive-tw-bg-background-light envive-tw-rounded-[4px]',
39
39
  containerBorderClasses: 'envive-tw-border-border-light',
@@ -44,7 +44,7 @@ export const useGetContainerProperties = ({
44
44
  },
45
45
  [Theme.MINIMAL]: {
46
46
  containerLayoutClasses:
47
- 'envive-tw-flex envive-tw-min-w-[358px] envive-tw-h-[40px] envive-tw-py-2 envive-tw-pr-2 envive-tw-justify-between envive-tw-items-center envive-tw-flex-shrink-0',
47
+ 'envive-tw-flex envive-tw-h-[40px] envive-tw-py-2 envive-tw-pr-2 envive-tw-justify-between envive-tw-items-center envive-tw-flex-shrink-0',
48
48
  containerDefaultClasses:
49
49
  'envive-tw-border-b envive-tw-border-solid envive-tw-bg-background-light',
50
50
  containerBorderClasses: 'envive-tw-border-b-border-medium',
@@ -55,7 +55,7 @@ export const useGetContainerProperties = ({
55
55
  },
56
56
  [Theme.GLOBAL_CUSTOM]: {
57
57
  containerLayoutClasses:
58
- 'envive-tw-flex envive-tw-min-w-[358px] envive-tw-h-[40px] envive-tw-py-2 envive-tw-px-4 envive-tw-justify-between envive-tw-items-center envive-tw-flex-shrink-0',
58
+ 'envive-tw-flex envive-tw-h-[40px] envive-tw-py-2 envive-tw-px-4 envive-tw-justify-between envive-tw-items-center envive-tw-flex-shrink-0',
59
59
  containerDefaultClasses:
60
60
  'envive-tw-border envive-tw-border-solid envive-tw-bg-background-light envive-tw-rounded-global-custom',
61
61
  containerBorderClasses: 'envive-tw-border-border-light',
@@ -1,4 +1,5 @@
1
1
  import { useMemo } from 'react';
2
+ import { extractColorNameFromCssVar } from 'tokens/utils';
2
3
  import { SparkleIconColor } from '../types/types';
3
4
 
4
5
  export type UseGetSparkleIconPropertiesProps = {
@@ -9,7 +10,9 @@ export const useGetSparkleIconProperties = ({
9
10
  sparkleIconColor,
10
11
  }: UseGetSparkleIconPropertiesProps) => {
11
12
  const sparkleIconStyle = useMemo(() => {
12
- const sparkleIconStyleMap: Record<SparkleIconColor, { fill: string; stroke: string }> = {
13
+ const colorName = extractColorNameFromCssVar(sparkleIconColor);
14
+
15
+ const sparkleIconStyleMap: Record<string, { fill: string; stroke: string }> = {
13
16
  [SparkleIconColor.ACCENT_PRIMARY]: {
14
17
  fill: 'var(--envive-colors-accent-primary)',
15
18
  stroke: 'var(--envive-colors-accent-primary)',
@@ -28,7 +31,7 @@ export const useGetSparkleIconProperties = ({
28
31
  },
29
32
  };
30
33
 
31
- return sparkleIconStyleMap[sparkleIconColor] ?? { fill: '' };
34
+ return sparkleIconStyleMap[colorName] ?? { fill: '' };
32
35
  }, [sparkleIconColor]);
33
36
 
34
37
  return sparkleIconStyle;
@@ -1,7 +1,7 @@
1
1
  import { Theme } from '../../../tokens/theme/theme';
2
2
  import { resolveTheme } from '../utils/resolveTheme';
3
3
  import { WidgetTextFieldComponents } from './components';
4
- import { type WidgetTextFieldProps } from './types/types';
4
+ import { IconVariant, type WidgetTextFieldProps } from './types/types';
5
5
 
6
6
  export const WidgetTextField = ({
7
7
  id,
@@ -9,6 +9,7 @@ export const WidgetTextField = ({
9
9
  style,
10
10
  className,
11
11
  theme = Theme.GLOBAL_CUSTOM,
12
+ iconVariant = IconVariant.DEFAULT,
12
13
  placeholder,
13
14
  ariaLabel,
14
15
  disabled,
@@ -31,7 +32,12 @@ export const WidgetTextField = ({
31
32
  theme={resolvedTheme}
32
33
  disabled={disabled}
33
34
  ariaLabel={ariaLabel}
34
- icon={<WidgetTextFieldComponents.Icon theme={resolvedTheme} />}
35
+ icon={
36
+ <WidgetTextFieldComponents.Icon
37
+ variant={iconVariant}
38
+ theme={resolvedTheme}
39
+ />
40
+ }
35
41
  text={<WidgetTextFieldComponents.FakeTextInput placeholder={placeholder} />}
36
42
  />
37
43
  );
@@ -3,6 +3,7 @@ import { describe, expect, it, vi } from 'vitest';
3
3
  import { fireEvent, render, screen } from '@testing-library/react';
4
4
  import { WidgetTextField } from '../WidgetTextField';
5
5
  import { Theme } from '../../../../tokens/theme/theme';
6
+ import { IconVariant } from '../types/types';
6
7
 
7
8
  describe('WidgetTextField', () => {
8
9
  describe('Basic rendering', () => {
@@ -292,6 +293,59 @@ describe('WidgetTextField', () => {
292
293
  });
293
294
  });
294
295
 
296
+ describe('Icon variants', () => {
297
+ it('should render with DEFAULT icon variant', () => {
298
+ const { container } = render(
299
+ <WidgetTextField
300
+ placeholder="Test"
301
+ theme={Theme.STANDARD}
302
+ iconVariant={IconVariant.DEFAULT}
303
+ />,
304
+ );
305
+ const svg = container.querySelector('svg');
306
+ expect(svg).toBeInTheDocument();
307
+ });
308
+
309
+ it('should render with SEARCH icon variant', () => {
310
+ const { container } = render(
311
+ <WidgetTextField
312
+ placeholder="Test"
313
+ theme={Theme.STANDARD}
314
+ iconVariant={IconVariant.SEARCH}
315
+ />,
316
+ );
317
+ const svg = container.querySelector('svg');
318
+ expect(svg).toBeInTheDocument();
319
+ });
320
+
321
+ it('should default to DEFAULT icon variant when not provided', () => {
322
+ const { container } = render(
323
+ <WidgetTextField
324
+ placeholder="Test"
325
+ theme={Theme.STANDARD}
326
+ />,
327
+ );
328
+ const svg = container.querySelector('svg');
329
+ expect(svg).toBeInTheDocument();
330
+ });
331
+
332
+ it('should work with iconVariant across different themes', () => {
333
+ const themes = [Theme.STANDARD, Theme.MODERN, Theme.MINIMAL, Theme.GLOBAL_CUSTOM];
334
+ themes.forEach(theme => {
335
+ const { container, unmount } = render(
336
+ <WidgetTextField
337
+ placeholder="Test"
338
+ theme={theme}
339
+ iconVariant={IconVariant.SEARCH}
340
+ />,
341
+ );
342
+ const svg = container.querySelector('svg');
343
+ expect(svg).toBeInTheDocument();
344
+ unmount();
345
+ });
346
+ });
347
+ });
348
+
295
349
  describe('Component structure', () => {
296
350
  it('should render Container with correct props', () => {
297
351
  const { container } = render(
@@ -58,8 +58,8 @@ export const Container = ({
58
58
  justify="between"
59
59
  gap="2"
60
60
  >
61
- {text}
62
- {icon}
61
+ <div className="envive-tw-min-w-0 envive-tw-flex-1 envive-tw-overflow-hidden">{text}</div>
62
+ <div className="envive-tw-flex-shrink-0">{icon}</div>
63
63
  </Stack>
64
64
  </ContainerComponent>
65
65
  );
@@ -1,45 +1,88 @@
1
+ import SvgSendStandard from '@envive-ai/react-icons/MagnifyingGlass';
2
+ import SvgSendModern from '@envive-ai/react-icons/MagnifyingThin';
3
+ import SendMinimalist from '@envive-ai/react-icons/SendMinimalist';
1
4
  import SendModern from '@envive-ai/react-icons/SendModern';
2
5
  import SendStandard from '@envive-ai/react-icons/SendStandard';
3
- import SendMinimalist from '@envive-ai/react-icons/SendMinimalist';
4
6
  import { Theme } from '../../../../tokens/theme/theme';
5
7
  import { CustomIcon } from '../../utils/CustomIcon';
8
+ import { IconVariant } from '../types/types';
6
9
 
7
10
  type IconProps = {
8
11
  theme: Theme;
12
+ variant: IconVariant;
9
13
  };
10
14
 
11
- export const Icon = ({ theme }: IconProps) => {
15
+ export const Icon = ({ variant, theme }: IconProps) => {
12
16
  if (theme === Theme.STANDARD) {
17
+ if (variant === IconVariant.DEFAULT) {
18
+ return (
19
+ <CustomIcon
20
+ IconComponent={<SendStandard />}
21
+ className="envive-tw-h-6 envive-tw-w-6"
22
+ fill="var(--envive-colors-border-medium)"
23
+ />
24
+ );
25
+ }
13
26
  return (
14
27
  <CustomIcon
15
- IconComponent={<SendStandard />}
28
+ IconComponent={<SvgSendStandard />}
16
29
  className="envive-tw-h-6 envive-tw-w-6"
17
30
  fill="var(--envive-colors-border-medium)"
18
31
  />
19
32
  );
20
33
  }
34
+
21
35
  if (theme === Theme.MODERN) {
36
+ if (variant === IconVariant.DEFAULT) {
37
+ return (
38
+ <CustomIcon
39
+ IconComponent={<SendModern />}
40
+ className="envive-tw-h-6 envive-tw-w-6"
41
+ fill="var(--envive-colors-border-medium)"
42
+ />
43
+ );
44
+ }
22
45
  return (
23
46
  <CustomIcon
24
- IconComponent={<SendModern />}
47
+ IconComponent={<SvgSendModern />}
25
48
  className="envive-tw-h-6 envive-tw-w-6"
26
- fill="var(--envive-colors-border-medium)"
49
+ stroke="var(--envive-colors-border-medium)"
27
50
  />
28
51
  );
29
52
  }
53
+
30
54
  if (theme === Theme.MINIMAL) {
55
+ if (variant === IconVariant.DEFAULT) {
56
+ return (
57
+ <CustomIcon
58
+ IconComponent={<SendMinimalist />}
59
+ className="envive-tw-h-6 envive-tw-w-6"
60
+ stroke="var(--envive-colors-text-secondary)"
61
+ />
62
+ );
63
+ }
31
64
  return (
32
65
  <CustomIcon
33
66
  IconComponent={<SendMinimalist />}
34
67
  className="envive-tw-h-6 envive-tw-w-6"
35
- stroke="var(--envive-colors-text-secondary)"
68
+ stroke="var(--envive-colors-text-light)"
69
+ />
70
+ );
71
+ }
72
+
73
+ if (variant === IconVariant.DEFAULT) {
74
+ return (
75
+ <CustomIcon
76
+ IconComponent={<SendStandard />}
77
+ className="envive-tw-h-6 envive-tw-w-6"
78
+ fill="var(--envive-colors-border-medium)"
36
79
  />
37
80
  );
38
81
  }
39
82
 
40
83
  return (
41
84
  <CustomIcon
42
- IconComponent={<SendStandard />}
85
+ IconComponent={<SvgSendStandard />}
43
86
  className="envive-tw-h-6 envive-tw-w-6"
44
87
  fill="var(--envive-colors-border-medium)"
45
88
  />
@@ -7,12 +7,14 @@ export type UseGetContainerPropertiesProps = {
7
7
 
8
8
  export const useGetContainerProperties = ({ theme }: UseGetContainerPropertiesProps) => {
9
9
  const baseClassName =
10
- 'envive-tw-cursor-text envive-tw-border-[1px] envive-tw-border-solid envive-tw-border-border-light envive-tw-px-4 envive-tw-py-2';
10
+ 'envive-tw-cursor-text envive-tw-border-solid envive-tw-px-4 envive-tw-py-2';
11
11
 
12
12
  const themeContainerClassName = useMemo(() => {
13
13
  const themeCotainerMap = {
14
- [Theme.STANDARD]: 'envive-tw-rounded-global-custom',
15
- [Theme.MODERN]: 'envive-tw-rounded-4',
14
+ [Theme.STANDARD]:
15
+ 'envive-tw-border-[1px] envive-tw-border-border-light envive-tw-rounded-global-custom',
16
+ [Theme.MODERN]: 'envive-tw-border-[1px] envive-tw-border-border-light envive-tw-rounded-4',
17
+ [Theme.MINIMAL]: 'envive-tw-border-b-[1px] envive-tw-border-text-light',
16
18
  };
17
19
  return themeCotainerMap[theme] ?? '';
18
20
  }, [theme]);