@botonic/react 0.43.1 → 0.44.0-alpha.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 (709) hide show
  1. package/lib/cjs/botonic-tester.js +20 -26
  2. package/lib/cjs/botonic-tester.js.map +1 -1
  3. package/lib/cjs/components/audio.js +3 -3
  4. package/lib/cjs/components/audio.js.map +1 -1
  5. package/lib/cjs/components/button/index.d.ts +3 -3
  6. package/lib/cjs/components/button/index.js +20 -16
  7. package/lib/cjs/components/button/index.js.map +1 -1
  8. package/lib/cjs/components/button/styles.js +18 -18
  9. package/lib/cjs/components/button/styles.js.map +1 -1
  10. package/lib/cjs/components/buttons-disabler.js +25 -10
  11. package/lib/cjs/components/buttons-disabler.js.map +1 -1
  12. package/lib/cjs/components/carousel.js +11 -9
  13. package/lib/cjs/components/carousel.js.map +1 -1
  14. package/lib/cjs/components/components.js +2 -3
  15. package/lib/cjs/components/components.js.map +1 -1
  16. package/lib/cjs/components/custom-message.js +9 -4
  17. package/lib/cjs/components/custom-message.js.map +1 -1
  18. package/lib/cjs/components/document.js +5 -3
  19. package/lib/cjs/components/document.js.map +1 -1
  20. package/lib/cjs/components/element.js +5 -7
  21. package/lib/cjs/components/element.js.map +1 -1
  22. package/lib/cjs/components/handoff.js +2 -2
  23. package/lib/cjs/components/handoff.js.map +1 -1
  24. package/lib/cjs/components/image.js +4 -4
  25. package/lib/cjs/components/image.js.map +1 -1
  26. package/lib/cjs/components/location.js +2 -2
  27. package/lib/cjs/components/location.js.map +1 -1
  28. package/lib/cjs/components/message/index.js +26 -9
  29. package/lib/cjs/components/message/index.js.map +1 -1
  30. package/lib/cjs/components/message/message-feedback.js +8 -5
  31. package/lib/cjs/components/message/message-feedback.js.map +1 -1
  32. package/lib/cjs/components/message/message-footer.js +1 -1
  33. package/lib/cjs/components/message/message-footer.js.map +1 -1
  34. package/lib/cjs/components/message/message-image.js +4 -1
  35. package/lib/cjs/components/message/message-image.js.map +1 -1
  36. package/lib/cjs/components/message/timestamps.js +1 -1
  37. package/lib/cjs/components/message/timestamps.js.map +1 -1
  38. package/lib/cjs/components/message-template.js +1 -1
  39. package/lib/cjs/components/message-template.js.map +1 -1
  40. package/lib/cjs/components/multichannel/facebook/facebook.js +2 -2
  41. package/lib/cjs/components/multichannel/facebook/facebook.js.map +1 -1
  42. package/lib/cjs/components/multichannel/multichannel-button.js +5 -7
  43. package/lib/cjs/components/multichannel/multichannel-button.js.map +1 -1
  44. package/lib/cjs/components/multichannel/multichannel-carousel.js +3 -3
  45. package/lib/cjs/components/multichannel/multichannel-carousel.js.map +1 -1
  46. package/lib/cjs/components/multichannel/multichannel-context.d.ts +1 -1
  47. package/lib/cjs/components/multichannel/multichannel-reply.js +1 -1
  48. package/lib/cjs/components/multichannel/multichannel-reply.js.map +1 -1
  49. package/lib/cjs/components/multichannel/multichannel-text.js +11 -12
  50. package/lib/cjs/components/multichannel/multichannel-text.js.map +1 -1
  51. package/lib/cjs/components/multichannel/multichannel-utils.d.ts +3 -3
  52. package/lib/cjs/components/multichannel/multichannel-utils.js +21 -25
  53. package/lib/cjs/components/multichannel/multichannel-utils.js.map +1 -1
  54. package/lib/cjs/components/multichannel/multichannel.js +9 -9
  55. package/lib/cjs/components/multichannel/multichannel.js.map +1 -1
  56. package/lib/cjs/components/multichannel/whatsapp/markdown-meta.js +1 -2
  57. package/lib/cjs/components/multichannel/whatsapp/markdown-meta.js.map +1 -1
  58. package/lib/cjs/components/pic.js +1 -1
  59. package/lib/cjs/components/pic.js.map +1 -1
  60. package/lib/cjs/components/raw.js +2 -2
  61. package/lib/cjs/components/raw.js.map +1 -1
  62. package/lib/cjs/components/reply.js +8 -6
  63. package/lib/cjs/components/reply.js.map +1 -1
  64. package/lib/cjs/components/share-button.js +1 -1
  65. package/lib/cjs/components/share-button.js.map +1 -1
  66. package/lib/cjs/components/system-debug-trace/debug-message.js +3 -5
  67. package/lib/cjs/components/system-debug-trace/debug-message.js.map +1 -1
  68. package/lib/cjs/components/system-debug-trace/events/ai-agent.js +2 -3
  69. package/lib/cjs/components/system-debug-trace/events/ai-agent.js.map +1 -1
  70. package/lib/cjs/components/system-debug-trace/events/components/guardrail-item.js +1 -1
  71. package/lib/cjs/components/system-debug-trace/events/components/guardrail-item.js.map +1 -1
  72. package/lib/cjs/components/system-debug-trace/events/components/sources-section.js +4 -5
  73. package/lib/cjs/components/system-debug-trace/events/components/sources-section.js.map +1 -1
  74. package/lib/cjs/components/system-debug-trace/events/handoff-success.js +3 -4
  75. package/lib/cjs/components/system-debug-trace/events/handoff-success.js.map +1 -1
  76. package/lib/cjs/components/system-debug-trace/events/knowledge-base.js +2 -2
  77. package/lib/cjs/components/system-debug-trace/events/knowledge-base.js.map +1 -1
  78. package/lib/cjs/components/system-debug-trace/hooks/use-knowledge-base-info.js +16 -12
  79. package/lib/cjs/components/system-debug-trace/hooks/use-knowledge-base-info.js.map +1 -1
  80. package/lib/cjs/components/system-debug-trace/hooks/use-last-label-position.js +3 -5
  81. package/lib/cjs/components/system-debug-trace/hooks/use-last-label-position.js.map +1 -1
  82. package/lib/cjs/components/system-debug-trace/icons/arrow-progress.js +1 -1
  83. package/lib/cjs/components/system-debug-trace/icons/arrow-progress.js.map +1 -1
  84. package/lib/cjs/components/system-debug-trace/icons/brain.js +1 -1
  85. package/lib/cjs/components/system-debug-trace/icons/brain.js.map +1 -1
  86. package/lib/cjs/components/system-debug-trace/icons/caret-down.js +1 -1
  87. package/lib/cjs/components/system-debug-trace/icons/caret-down.js.map +1 -1
  88. package/lib/cjs/components/system-debug-trace/icons/caret-up.js +1 -1
  89. package/lib/cjs/components/system-debug-trace/icons/caret-up.js.map +1 -1
  90. package/lib/cjs/components/system-debug-trace/icons/circle-check.js +1 -1
  91. package/lib/cjs/components/system-debug-trace/icons/circle-check.js.map +1 -1
  92. package/lib/cjs/components/system-debug-trace/icons/code.js +1 -1
  93. package/lib/cjs/components/system-debug-trace/icons/code.js.map +1 -1
  94. package/lib/cjs/components/system-debug-trace/icons/file-pdf.js +1 -1
  95. package/lib/cjs/components/system-debug-trace/icons/file-pdf.js.map +1 -1
  96. package/lib/cjs/components/system-debug-trace/icons/file-word.js +1 -1
  97. package/lib/cjs/components/system-debug-trace/icons/file-word.js.map +1 -1
  98. package/lib/cjs/components/system-debug-trace/icons/hand.js +1 -1
  99. package/lib/cjs/components/system-debug-trace/icons/hand.js.map +1 -1
  100. package/lib/cjs/components/system-debug-trace/icons/head-set.js +1 -1
  101. package/lib/cjs/components/system-debug-trace/icons/head-set.js.map +1 -1
  102. package/lib/cjs/components/system-debug-trace/icons/life-ring.js +1 -1
  103. package/lib/cjs/components/system-debug-trace/icons/life-ring.js.map +1 -1
  104. package/lib/cjs/components/system-debug-trace/icons/link.js +1 -1
  105. package/lib/cjs/components/system-debug-trace/icons/link.js.map +1 -1
  106. package/lib/cjs/components/system-debug-trace/icons/quote-right.js +1 -1
  107. package/lib/cjs/components/system-debug-trace/icons/quote-right.js.map +1 -1
  108. package/lib/cjs/components/system-debug-trace/icons/screwdriver-wrench.js +1 -1
  109. package/lib/cjs/components/system-debug-trace/icons/screwdriver-wrench.js.map +1 -1
  110. package/lib/cjs/components/system-debug-trace/icons/split.js +1 -1
  111. package/lib/cjs/components/system-debug-trace/icons/split.js.map +1 -1
  112. package/lib/cjs/components/system-debug-trace/icons/wand.js +1 -1
  113. package/lib/cjs/components/system-debug-trace/icons/wand.js.map +1 -1
  114. package/lib/cjs/components/system-debug-trace/icons/window-restore.js +1 -1
  115. package/lib/cjs/components/system-debug-trace/icons/window-restore.js.map +1 -1
  116. package/lib/cjs/components/system-debug-trace/index.js +5 -6
  117. package/lib/cjs/components/system-debug-trace/index.js.map +1 -1
  118. package/lib/cjs/components/text.js +7 -3
  119. package/lib/cjs/components/text.js.map +1 -1
  120. package/lib/cjs/components/video.js +3 -3
  121. package/lib/cjs/components/video.js.map +1 -1
  122. package/lib/cjs/components/webchat-settings.js.map +1 -1
  123. package/lib/cjs/components/whatsapp-button-list.js +3 -3
  124. package/lib/cjs/components/whatsapp-button-list.js.map +1 -1
  125. package/lib/cjs/components/whatsapp-catalog.js +2 -2
  126. package/lib/cjs/components/whatsapp-catalog.js.map +1 -1
  127. package/lib/cjs/components/whatsapp-cta-url-button.js +21 -10
  128. package/lib/cjs/components/whatsapp-cta-url-button.js.map +1 -1
  129. package/lib/cjs/components/whatsapp-interactive-media-carousel.js +3 -3
  130. package/lib/cjs/components/whatsapp-interactive-media-carousel.js.map +1 -1
  131. package/lib/cjs/components/whatsapp-media-carousel.js +3 -4
  132. package/lib/cjs/components/whatsapp-media-carousel.js.map +1 -1
  133. package/lib/cjs/components/whatsapp-product-carousel.js +2 -2
  134. package/lib/cjs/components/whatsapp-product-carousel.js.map +1 -1
  135. package/lib/cjs/components/whatsapp-product-list.js +2 -2
  136. package/lib/cjs/components/whatsapp-product-list.js.map +1 -1
  137. package/lib/cjs/components/whatsapp-product.js +2 -2
  138. package/lib/cjs/components/whatsapp-product.js.map +1 -1
  139. package/lib/cjs/components/whatsapp-template/index.js +2 -2
  140. package/lib/cjs/components/whatsapp-template/index.js.map +1 -1
  141. package/lib/cjs/components/whatsapp-template/types.js +3 -3
  142. package/lib/cjs/components/whatsapp-template/types.js.map +1 -1
  143. package/lib/cjs/constants.d.ts +145 -145
  144. package/lib/cjs/contexts.d.ts +0 -1
  145. package/lib/cjs/contexts.js +1 -2
  146. package/lib/cjs/contexts.js.map +1 -1
  147. package/lib/cjs/dev-app.d.ts +2 -8
  148. package/lib/cjs/dev-app.js +19 -20
  149. package/lib/cjs/dev-app.js.map +1 -1
  150. package/lib/cjs/index-types.js +2 -2
  151. package/lib/cjs/index-types.js.map +1 -1
  152. package/lib/cjs/message-utils.d.ts +1 -1
  153. package/lib/cjs/msg-to-botonic.d.ts +3 -3
  154. package/lib/cjs/msg-to-botonic.js +17 -19
  155. package/lib/cjs/msg-to-botonic.js.map +1 -1
  156. package/lib/cjs/node-app.d.ts +1 -1
  157. package/lib/cjs/node-app.js +8 -8
  158. package/lib/cjs/node-app.js.map +1 -1
  159. package/lib/cjs/react-bot.js +17 -16
  160. package/lib/cjs/react-bot.js.map +1 -1
  161. package/lib/cjs/util/dom.js.map +1 -1
  162. package/lib/cjs/util/environment.js +3 -3
  163. package/lib/cjs/util/environment.js.map +1 -1
  164. package/lib/cjs/util/error-boundary.js.map +1 -1
  165. package/lib/cjs/util/functional.js +1 -2
  166. package/lib/cjs/util/functional.js.map +1 -1
  167. package/lib/cjs/util/logs.js +2 -3
  168. package/lib/cjs/util/logs.js.map +1 -1
  169. package/lib/cjs/util/objects.js +2 -2
  170. package/lib/cjs/util/objects.js.map +1 -1
  171. package/lib/cjs/util/react.js +2 -2
  172. package/lib/cjs/util/react.js.map +1 -1
  173. package/lib/cjs/util/strings.js.map +1 -1
  174. package/lib/cjs/util/webchat.js +7 -10
  175. package/lib/cjs/util/webchat.js.map +1 -1
  176. package/lib/cjs/util/webviews.js +1 -2
  177. package/lib/cjs/util/webviews.js.map +1 -1
  178. package/lib/cjs/webchat/chat-area/index.js +1 -1
  179. package/lib/cjs/webchat/chat-area/index.js.map +1 -1
  180. package/lib/cjs/webchat/components/conditional-animation.js +1 -1
  181. package/lib/cjs/webchat/components/conditional-animation.js.map +1 -1
  182. package/lib/cjs/webchat/components/opened-persistent-menu.js +3 -3
  183. package/lib/cjs/webchat/components/opened-persistent-menu.js.map +1 -1
  184. package/lib/cjs/webchat/context/actions.js +1 -1
  185. package/lib/cjs/webchat/context/actions.js.map +1 -1
  186. package/lib/cjs/webchat/context/index.d.ts +0 -1
  187. package/lib/cjs/webchat/context/index.js +17 -18
  188. package/lib/cjs/webchat/context/index.js.map +1 -1
  189. package/lib/cjs/webchat/context/messages-reducer.js +69 -29
  190. package/lib/cjs/webchat/context/messages-reducer.js.map +1 -1
  191. package/lib/cjs/webchat/context/types.d.ts +0 -1
  192. package/lib/cjs/webchat/context/use-webchat.d.ts +0 -1
  193. package/lib/cjs/webchat/context/use-webchat.js +1 -2
  194. package/lib/cjs/webchat/context/use-webchat.js.map +1 -1
  195. package/lib/cjs/webchat/context/webchat-reducer.js +25 -20
  196. package/lib/cjs/webchat/context/webchat-reducer.js.map +1 -1
  197. package/lib/cjs/webchat/cover-component/index.js +1 -1
  198. package/lib/cjs/webchat/cover-component/index.js.map +1 -1
  199. package/lib/cjs/webchat/custom-messages/index.js +2 -4
  200. package/lib/cjs/webchat/custom-messages/index.js.map +1 -1
  201. package/lib/cjs/webchat/custom-messages/rating/icons/face-angry.js +1 -1
  202. package/lib/cjs/webchat/custom-messages/rating/icons/face-angry.js.map +1 -1
  203. package/lib/cjs/webchat/custom-messages/rating/icons/face-frown.js +1 -1
  204. package/lib/cjs/webchat/custom-messages/rating/icons/face-frown.js.map +1 -1
  205. package/lib/cjs/webchat/custom-messages/rating/icons/face-grin-beam.js +1 -1
  206. package/lib/cjs/webchat/custom-messages/rating/icons/face-grin-beam.js.map +1 -1
  207. package/lib/cjs/webchat/custom-messages/rating/icons/face-meh.js +1 -1
  208. package/lib/cjs/webchat/custom-messages/rating/icons/face-meh.js.map +1 -1
  209. package/lib/cjs/webchat/custom-messages/rating/icons/face-smile.js +1 -1
  210. package/lib/cjs/webchat/custom-messages/rating/icons/face-smile.js.map +1 -1
  211. package/lib/cjs/webchat/custom-messages/rating/icons/star.js +1 -1
  212. package/lib/cjs/webchat/custom-messages/rating/icons/star.js.map +1 -1
  213. package/lib/cjs/webchat/custom-messages/rating/index.js +2 -3
  214. package/lib/cjs/webchat/custom-messages/rating/index.js.map +1 -1
  215. package/lib/cjs/webchat/custom-messages/rating/rating-selector.js +3 -3
  216. package/lib/cjs/webchat/custom-messages/rating/rating-selector.js.map +1 -1
  217. package/lib/cjs/webchat/custom-messages/rating/types.js +1 -1
  218. package/lib/cjs/webchat/custom-messages/rating/types.js.map +1 -1
  219. package/lib/cjs/webchat/header/default-header.js +1 -1
  220. package/lib/cjs/webchat/header/default-header.js.map +1 -1
  221. package/lib/cjs/webchat/header/index.js +2 -2
  222. package/lib/cjs/webchat/header/index.js.map +1 -1
  223. package/lib/cjs/webchat/header/styles.js +2 -2
  224. package/lib/cjs/webchat/header/styles.js.map +1 -1
  225. package/lib/cjs/webchat/hooks/use-component-visible.d.ts +0 -1
  226. package/lib/cjs/webchat/hooks/use-component-visible.js +1 -2
  227. package/lib/cjs/webchat/hooks/use-component-visible.js.map +1 -1
  228. package/lib/cjs/webchat/hooks/use-device-adapter.js.map +1 -1
  229. package/lib/cjs/webchat/hooks/use-previous.js +1 -2
  230. package/lib/cjs/webchat/hooks/use-previous.js.map +1 -1
  231. package/lib/cjs/webchat/hooks/use-scrollbar-controller.js +5 -6
  232. package/lib/cjs/webchat/hooks/use-scrollbar-controller.js.map +1 -1
  233. package/lib/cjs/webchat/hooks/use-typing.js +2 -3
  234. package/lib/cjs/webchat/hooks/use-typing.js.map +1 -1
  235. package/lib/cjs/webchat/hooks/use-virtual-keyboard-detection.js.map +1 -1
  236. package/lib/cjs/webchat/hooks/use-webchat-resizer.js.map +1 -1
  237. package/lib/cjs/webchat/index.js +2 -2
  238. package/lib/cjs/webchat/index.js.map +1 -1
  239. package/lib/cjs/webchat/input-panel/attachment.js +3 -5
  240. package/lib/cjs/webchat/input-panel/attachment.js.map +1 -1
  241. package/lib/cjs/webchat/input-panel/emoji-picker.js +3 -5
  242. package/lib/cjs/webchat/input-panel/emoji-picker.js.map +1 -1
  243. package/lib/cjs/webchat/input-panel/index.js +8 -8
  244. package/lib/cjs/webchat/input-panel/index.js.map +1 -1
  245. package/lib/cjs/webchat/input-panel/opened-emoji-picker.js +1 -1
  246. package/lib/cjs/webchat/input-panel/opened-emoji-picker.js.map +1 -1
  247. package/lib/cjs/webchat/input-panel/persistent-menu.js +3 -4
  248. package/lib/cjs/webchat/input-panel/persistent-menu.js.map +1 -1
  249. package/lib/cjs/webchat/input-panel/send-button.js +3 -5
  250. package/lib/cjs/webchat/input-panel/send-button.js.map +1 -1
  251. package/lib/cjs/webchat/input-panel/textarea.js +17 -5
  252. package/lib/cjs/webchat/input-panel/textarea.js.map +1 -1
  253. package/lib/cjs/webchat/message-list/index.js +9 -14
  254. package/lib/cjs/webchat/message-list/index.js.map +1 -1
  255. package/lib/cjs/webchat/message-list/intro-message.js +4 -2
  256. package/lib/cjs/webchat/message-list/intro-message.js.map +1 -1
  257. package/lib/cjs/webchat/message-list/scroll-button.d.ts +0 -1
  258. package/lib/cjs/webchat/message-list/scroll-button.js +1 -1
  259. package/lib/cjs/webchat/message-list/scroll-button.js.map +1 -1
  260. package/lib/cjs/webchat/message-list/unread-messages-banner.js +1 -1
  261. package/lib/cjs/webchat/message-list/unread-messages-banner.js.map +1 -1
  262. package/lib/cjs/webchat/message-list/use-debounce.js +1 -2
  263. package/lib/cjs/webchat/message-list/use-debounce.js.map +1 -1
  264. package/lib/cjs/webchat/message-list/use-notifications.js +1 -2
  265. package/lib/cjs/webchat/message-list/use-notifications.js.map +1 -1
  266. package/lib/cjs/webchat/replies/index.js +2 -3
  267. package/lib/cjs/webchat/replies/index.js.map +1 -1
  268. package/lib/cjs/webchat/session-view.js +10 -4
  269. package/lib/cjs/webchat/session-view.js.map +1 -1
  270. package/lib/cjs/webchat/theme/types.d.ts +0 -1
  271. package/lib/cjs/webchat/tracking.js +21 -21
  272. package/lib/cjs/webchat/tracking.js.map +1 -1
  273. package/lib/cjs/webchat/trigger-button/index.d.ts +0 -1
  274. package/lib/cjs/webchat/trigger-button/index.js +1 -1
  275. package/lib/cjs/webchat/trigger-button/index.js.map +1 -1
  276. package/lib/cjs/webchat/typing-indicator/index.js +1 -1
  277. package/lib/cjs/webchat/typing-indicator/index.js.map +1 -1
  278. package/lib/cjs/webchat/use-storage-state-hook.js +5 -7
  279. package/lib/cjs/webchat/use-storage-state-hook.js.map +1 -1
  280. package/lib/cjs/webchat/webchat-dev.d.ts +1 -1
  281. package/lib/cjs/webchat/webchat-dev.js +3 -6
  282. package/lib/cjs/webchat/webchat-dev.js.map +1 -1
  283. package/lib/cjs/webchat/webchat.js +51 -49
  284. package/lib/cjs/webchat/webchat.js.map +1 -1
  285. package/lib/cjs/webchat/webview/header.js +3 -1
  286. package/lib/cjs/webchat/webview/header.js.map +1 -1
  287. package/lib/cjs/webchat/webview/index.d.ts +1 -1
  288. package/lib/cjs/webchat/webview/index.js +16 -15
  289. package/lib/cjs/webchat/webview/index.js.map +1 -1
  290. package/lib/cjs/webchat/webview/styles.js +1 -1
  291. package/lib/cjs/webchat/webview/styles.js.map +1 -1
  292. package/lib/cjs/webchat-app.d.ts +18 -18
  293. package/lib/cjs/webchat-app.js +133 -141
  294. package/lib/cjs/webchat-app.js.map +1 -1
  295. package/lib/cjs/webview-app.js +89 -99
  296. package/lib/cjs/webview-app.js.map +1 -1
  297. package/lib/esm/app.js +5 -1
  298. package/lib/esm/app.js.map +1 -1
  299. package/lib/esm/botonic-tester.js +35 -36
  300. package/lib/esm/botonic-tester.js.map +1 -1
  301. package/lib/esm/components/audio.js +18 -13
  302. package/lib/esm/components/audio.js.map +1 -1
  303. package/lib/esm/components/button/index.d.ts +3 -3
  304. package/lib/esm/components/button/index.js +44 -36
  305. package/lib/esm/components/button/index.js.map +1 -1
  306. package/lib/esm/components/button/styles.js +25 -21
  307. package/lib/esm/components/button/styles.js.map +1 -1
  308. package/lib/esm/components/buttons-disabler.js +38 -19
  309. package/lib/esm/components/buttons-disabler.js.map +1 -1
  310. package/lib/esm/components/carousel.js +49 -42
  311. package/lib/esm/components/carousel.js.map +1 -1
  312. package/lib/esm/components/components.js +6 -2
  313. package/lib/esm/components/components.js.map +1 -1
  314. package/lib/esm/components/custom-message.js +29 -20
  315. package/lib/esm/components/custom-message.js.map +1 -1
  316. package/lib/esm/components/document.js +24 -17
  317. package/lib/esm/components/document.js.map +1 -1
  318. package/lib/esm/components/element.js +24 -21
  319. package/lib/esm/components/element.js.map +1 -1
  320. package/lib/esm/components/handoff.js +24 -19
  321. package/lib/esm/components/handoff.js.map +1 -1
  322. package/lib/esm/components/image.js +25 -20
  323. package/lib/esm/components/image.js.map +1 -1
  324. package/lib/esm/components/index-types.js +2 -1
  325. package/lib/esm/components/index.js +68 -32
  326. package/lib/esm/components/index.js.map +1 -1
  327. package/lib/esm/components/location.js +17 -12
  328. package/lib/esm/components/location.js.map +1 -1
  329. package/lib/esm/components/markdown.js +26 -16
  330. package/lib/esm/components/markdown.js.map +1 -1
  331. package/lib/esm/components/message/index.js +83 -62
  332. package/lib/esm/components/message/index.js.map +1 -1
  333. package/lib/esm/components/message/message-feedback.js +28 -21
  334. package/lib/esm/components/message/message-feedback.js.map +1 -1
  335. package/lib/esm/components/message/message-footer.js +16 -12
  336. package/lib/esm/components/message/message-footer.js.map +1 -1
  337. package/lib/esm/components/message/message-image.js +22 -15
  338. package/lib/esm/components/message/message-image.js.map +1 -1
  339. package/lib/esm/components/message/styles.js +19 -15
  340. package/lib/esm/components/message/styles.js.map +1 -1
  341. package/lib/esm/components/message/timestamps.js +24 -19
  342. package/lib/esm/components/message/timestamps.js.map +1 -1
  343. package/lib/esm/components/message-template.js +11 -6
  344. package/lib/esm/components/message-template.js.map +1 -1
  345. package/lib/esm/components/multichannel/facebook/facebook.js +10 -6
  346. package/lib/esm/components/multichannel/facebook/facebook.js.map +1 -1
  347. package/lib/esm/components/multichannel/index-types.js +2 -1
  348. package/lib/esm/components/multichannel/index.js +15 -11
  349. package/lib/esm/components/multichannel/index.js.map +1 -1
  350. package/lib/esm/components/multichannel/multichannel-button.js +22 -19
  351. package/lib/esm/components/multichannel/multichannel-button.js.map +1 -1
  352. package/lib/esm/components/multichannel/multichannel-carousel.js +35 -30
  353. package/lib/esm/components/multichannel/multichannel-carousel.js.map +1 -1
  354. package/lib/esm/components/multichannel/multichannel-context.d.ts +1 -1
  355. package/lib/esm/components/multichannel/multichannel-context.js +6 -2
  356. package/lib/esm/components/multichannel/multichannel-context.js.map +1 -1
  357. package/lib/esm/components/multichannel/multichannel-reply.js +14 -9
  358. package/lib/esm/components/multichannel/multichannel-reply.js.map +1 -1
  359. package/lib/esm/components/multichannel/multichannel-text.js +57 -53
  360. package/lib/esm/components/multichannel/multichannel-text.js.map +1 -1
  361. package/lib/esm/components/multichannel/multichannel-utils.d.ts +3 -3
  362. package/lib/esm/components/multichannel/multichannel-utils.js +61 -46
  363. package/lib/esm/components/multichannel/multichannel-utils.js.map +1 -1
  364. package/lib/esm/components/multichannel/multichannel.js +42 -37
  365. package/lib/esm/components/multichannel/multichannel.js.map +1 -1
  366. package/lib/esm/components/multichannel/whatsapp/constants.js +13 -10
  367. package/lib/esm/components/multichannel/whatsapp/constants.js.map +1 -1
  368. package/lib/esm/components/multichannel/whatsapp/markdown-meta.js +4 -1
  369. package/lib/esm/components/multichannel/whatsapp/markdown-meta.js.map +1 -1
  370. package/lib/esm/components/pic.js +20 -15
  371. package/lib/esm/components/pic.js.map +1 -1
  372. package/lib/esm/components/raw.js +22 -17
  373. package/lib/esm/components/raw.js.map +1 -1
  374. package/lib/esm/components/reply.js +26 -19
  375. package/lib/esm/components/reply.js.map +1 -1
  376. package/lib/esm/components/share-button.js +11 -6
  377. package/lib/esm/components/share-button.js.map +1 -1
  378. package/lib/esm/components/subtitle.js +16 -11
  379. package/lib/esm/components/subtitle.js.map +1 -1
  380. package/lib/esm/components/system-debug-trace/debug-message.js +47 -45
  381. package/lib/esm/components/system-debug-trace/debug-message.js.map +1 -1
  382. package/lib/esm/components/system-debug-trace/events/ai-agent.js +26 -22
  383. package/lib/esm/components/system-debug-trace/events/ai-agent.js.map +1 -1
  384. package/lib/esm/components/system-debug-trace/events/bot-action.js +11 -7
  385. package/lib/esm/components/system-debug-trace/events/bot-action.js.map +1 -1
  386. package/lib/esm/components/system-debug-trace/events/components/guardrail-item.js +11 -6
  387. package/lib/esm/components/system-debug-trace/events/components/guardrail-item.js.map +1 -1
  388. package/lib/esm/components/system-debug-trace/events/components/index.js +5 -2
  389. package/lib/esm/components/system-debug-trace/events/components/index.js.map +1 -1
  390. package/lib/esm/components/system-debug-trace/events/components/sources-section.js +13 -10
  391. package/lib/esm/components/system-debug-trace/events/components/sources-section.js.map +1 -1
  392. package/lib/esm/components/system-debug-trace/events/conditional-channel.js +11 -7
  393. package/lib/esm/components/system-debug-trace/events/conditional-channel.js.map +1 -1
  394. package/lib/esm/components/system-debug-trace/events/conditional-country.js +11 -7
  395. package/lib/esm/components/system-debug-trace/events/conditional-country.js.map +1 -1
  396. package/lib/esm/components/system-debug-trace/events/conditional-custom.js +11 -7
  397. package/lib/esm/components/system-debug-trace/events/conditional-custom.js.map +1 -1
  398. package/lib/esm/components/system-debug-trace/events/conditional-queue-status.js +19 -14
  399. package/lib/esm/components/system-debug-trace/events/conditional-queue-status.js.map +1 -1
  400. package/lib/esm/components/system-debug-trace/events/constants.js +4 -1
  401. package/lib/esm/components/system-debug-trace/events/constants.js.map +1 -1
  402. package/lib/esm/components/system-debug-trace/events/fallback.js +11 -7
  403. package/lib/esm/components/system-debug-trace/events/fallback.js.map +1 -1
  404. package/lib/esm/components/system-debug-trace/events/handoff-success.js +27 -23
  405. package/lib/esm/components/system-debug-trace/events/handoff-success.js.map +1 -1
  406. package/lib/esm/components/system-debug-trace/events/index.js +17 -14
  407. package/lib/esm/components/system-debug-trace/events/index.js.map +1 -1
  408. package/lib/esm/components/system-debug-trace/events/keyword.js +11 -7
  409. package/lib/esm/components/system-debug-trace/events/keyword.js.map +1 -1
  410. package/lib/esm/components/system-debug-trace/events/knowledge-base.js +24 -19
  411. package/lib/esm/components/system-debug-trace/events/knowledge-base.js.map +1 -1
  412. package/lib/esm/components/system-debug-trace/events/knowledge-bases-types.js +2 -1
  413. package/lib/esm/components/system-debug-trace/events/redirect-flow.js +11 -7
  414. package/lib/esm/components/system-debug-trace/events/redirect-flow.js.map +1 -1
  415. package/lib/esm/components/system-debug-trace/events/smart-intent.js +11 -7
  416. package/lib/esm/components/system-debug-trace/events/smart-intent.js.map +1 -1
  417. package/lib/esm/components/system-debug-trace/events/webview-action-triggered.js +11 -7
  418. package/lib/esm/components/system-debug-trace/events/webview-action-triggered.js.map +1 -1
  419. package/lib/esm/components/system-debug-trace/hooks/use-knowledge-base-info.js +38 -30
  420. package/lib/esm/components/system-debug-trace/hooks/use-knowledge-base-info.js.map +1 -1
  421. package/lib/esm/components/system-debug-trace/hooks/use-last-label-position.js +8 -6
  422. package/lib/esm/components/system-debug-trace/hooks/use-last-label-position.js.map +1 -1
  423. package/lib/esm/components/system-debug-trace/icons/arrow-progress.js +8 -4
  424. package/lib/esm/components/system-debug-trace/icons/arrow-progress.js.map +1 -1
  425. package/lib/esm/components/system-debug-trace/icons/brain.js +8 -4
  426. package/lib/esm/components/system-debug-trace/icons/brain.js.map +1 -1
  427. package/lib/esm/components/system-debug-trace/icons/caret-down.js +8 -4
  428. package/lib/esm/components/system-debug-trace/icons/caret-down.js.map +1 -1
  429. package/lib/esm/components/system-debug-trace/icons/caret-up.js +8 -4
  430. package/lib/esm/components/system-debug-trace/icons/caret-up.js.map +1 -1
  431. package/lib/esm/components/system-debug-trace/icons/circle-check.js +8 -4
  432. package/lib/esm/components/system-debug-trace/icons/circle-check.js.map +1 -1
  433. package/lib/esm/components/system-debug-trace/icons/code.js +8 -4
  434. package/lib/esm/components/system-debug-trace/icons/code.js.map +1 -1
  435. package/lib/esm/components/system-debug-trace/icons/file-pdf.js +8 -4
  436. package/lib/esm/components/system-debug-trace/icons/file-pdf.js.map +1 -1
  437. package/lib/esm/components/system-debug-trace/icons/file-word.js +8 -4
  438. package/lib/esm/components/system-debug-trace/icons/file-word.js.map +1 -1
  439. package/lib/esm/components/system-debug-trace/icons/hand.js +8 -4
  440. package/lib/esm/components/system-debug-trace/icons/hand.js.map +1 -1
  441. package/lib/esm/components/system-debug-trace/icons/head-set.js +8 -4
  442. package/lib/esm/components/system-debug-trace/icons/head-set.js.map +1 -1
  443. package/lib/esm/components/system-debug-trace/icons/index.js +16 -13
  444. package/lib/esm/components/system-debug-trace/icons/index.js.map +1 -1
  445. package/lib/esm/components/system-debug-trace/icons/life-ring.js +8 -4
  446. package/lib/esm/components/system-debug-trace/icons/life-ring.js.map +1 -1
  447. package/lib/esm/components/system-debug-trace/icons/link.js +8 -4
  448. package/lib/esm/components/system-debug-trace/icons/link.js.map +1 -1
  449. package/lib/esm/components/system-debug-trace/icons/quote-right.js +8 -4
  450. package/lib/esm/components/system-debug-trace/icons/quote-right.js.map +1 -1
  451. package/lib/esm/components/system-debug-trace/icons/screwdriver-wrench.js +8 -4
  452. package/lib/esm/components/system-debug-trace/icons/screwdriver-wrench.js.map +1 -1
  453. package/lib/esm/components/system-debug-trace/icons/split.js +8 -4
  454. package/lib/esm/components/system-debug-trace/icons/split.js.map +1 -1
  455. package/lib/esm/components/system-debug-trace/icons/wand.js +8 -4
  456. package/lib/esm/components/system-debug-trace/icons/wand.js.map +1 -1
  457. package/lib/esm/components/system-debug-trace/icons/window-restore.js +8 -4
  458. package/lib/esm/components/system-debug-trace/icons/window-restore.js.map +1 -1
  459. package/lib/esm/components/system-debug-trace/index.js +17 -14
  460. package/lib/esm/components/system-debug-trace/index.js.map +1 -1
  461. package/lib/esm/components/system-debug-trace/styles.js +44 -40
  462. package/lib/esm/components/system-debug-trace/styles.js.map +1 -1
  463. package/lib/esm/components/system-debug-trace/types.js +2 -1
  464. package/lib/esm/components/text.js +20 -12
  465. package/lib/esm/components/text.js.map +1 -1
  466. package/lib/esm/components/title.js +14 -9
  467. package/lib/esm/components/title.js.map +1 -1
  468. package/lib/esm/components/video.js +19 -14
  469. package/lib/esm/components/video.js.map +1 -1
  470. package/lib/esm/components/webchat-settings.js +17 -12
  471. package/lib/esm/components/webchat-settings.js.map +1 -1
  472. package/lib/esm/components/whatsapp-button-list.js +24 -20
  473. package/lib/esm/components/whatsapp-button-list.js.map +1 -1
  474. package/lib/esm/components/whatsapp-catalog.js +12 -8
  475. package/lib/esm/components/whatsapp-catalog.js.map +1 -1
  476. package/lib/esm/components/whatsapp-cta-url-button.js +39 -24
  477. package/lib/esm/components/whatsapp-cta-url-button.js.map +1 -1
  478. package/lib/esm/components/whatsapp-interactive-media-carousel.js +17 -13
  479. package/lib/esm/components/whatsapp-interactive-media-carousel.js.map +1 -1
  480. package/lib/esm/components/whatsapp-media-carousel.js +15 -12
  481. package/lib/esm/components/whatsapp-media-carousel.js.map +1 -1
  482. package/lib/esm/components/whatsapp-product-carousel.js +14 -10
  483. package/lib/esm/components/whatsapp-product-carousel.js.map +1 -1
  484. package/lib/esm/components/whatsapp-product-list.js +13 -9
  485. package/lib/esm/components/whatsapp-product-list.js.map +1 -1
  486. package/lib/esm/components/whatsapp-product.js +12 -8
  487. package/lib/esm/components/whatsapp-product.js.map +1 -1
  488. package/lib/esm/components/whatsapp-template/index.js +12 -8
  489. package/lib/esm/components/whatsapp-template/index.js.map +1 -1
  490. package/lib/esm/components/whatsapp-template/types.js +9 -6
  491. package/lib/esm/components/whatsapp-template/types.js.map +1 -1
  492. package/lib/esm/constants.d.ts +145 -145
  493. package/lib/esm/constants.js +13 -9
  494. package/lib/esm/constants.js.map +1 -1
  495. package/lib/esm/contexts.d.ts +0 -1
  496. package/lib/esm/contexts.js +7 -5
  497. package/lib/esm/contexts.js.map +1 -1
  498. package/lib/esm/dev-app.d.ts +2 -8
  499. package/lib/esm/dev-app.js +35 -32
  500. package/lib/esm/dev-app.js.map +1 -1
  501. package/lib/esm/index-types.js +7 -4
  502. package/lib/esm/index-types.js.map +1 -1
  503. package/lib/esm/index.js +23 -11
  504. package/lib/esm/index.js.map +1 -1
  505. package/lib/esm/message-utils.d.ts +1 -1
  506. package/lib/esm/message-utils.js +48 -27
  507. package/lib/esm/message-utils.js.map +1 -1
  508. package/lib/esm/msg-to-botonic.d.ts +3 -3
  509. package/lib/esm/msg-to-botonic.js +54 -50
  510. package/lib/esm/msg-to-botonic.js.map +1 -1
  511. package/lib/esm/node-app.d.ts +1 -1
  512. package/lib/esm/node-app.js +15 -11
  513. package/lib/esm/node-app.js.map +1 -1
  514. package/lib/esm/react-bot.js +27 -22
  515. package/lib/esm/react-bot.js.map +1 -1
  516. package/lib/esm/shared/styles.js +10 -6
  517. package/lib/esm/shared/styles.js.map +1 -1
  518. package/lib/esm/time-zone-to-country-code.js +4 -1
  519. package/lib/esm/time-zone-to-country-code.js.map +1 -1
  520. package/lib/esm/util/dom.js +12 -5
  521. package/lib/esm/util/dom.js.map +1 -1
  522. package/lib/esm/util/environment.js +18 -10
  523. package/lib/esm/util/environment.js.map +1 -1
  524. package/lib/esm/util/error-boundary.js +12 -7
  525. package/lib/esm/util/error-boundary.js.map +1 -1
  526. package/lib/esm/util/functional.js +4 -1
  527. package/lib/esm/util/functional.js.map +1 -1
  528. package/lib/esm/util/index.js +12 -9
  529. package/lib/esm/util/index.js.map +1 -1
  530. package/lib/esm/util/logs.js +8 -4
  531. package/lib/esm/util/logs.js.map +1 -1
  532. package/lib/esm/util/objects.js +9 -3
  533. package/lib/esm/util/objects.js.map +1 -1
  534. package/lib/esm/util/react.js +25 -17
  535. package/lib/esm/util/react.js.map +1 -1
  536. package/lib/esm/util/regexs.js +7 -2
  537. package/lib/esm/util/regexs.js.map +1 -1
  538. package/lib/esm/util/strings.js +5 -1
  539. package/lib/esm/util/strings.js.map +1 -1
  540. package/lib/esm/util/webchat.js +34 -27
  541. package/lib/esm/util/webchat.js.map +1 -1
  542. package/lib/esm/util/webviews.js +6 -3
  543. package/lib/esm/util/webviews.js.map +1 -1
  544. package/lib/esm/webchat/chat-area/index.js +18 -14
  545. package/lib/esm/webchat/chat-area/index.js.map +1 -1
  546. package/lib/esm/webchat/chat-area/styles.js +6 -2
  547. package/lib/esm/webchat/chat-area/styles.js.map +1 -1
  548. package/lib/esm/webchat/components/common.js +11 -6
  549. package/lib/esm/webchat/components/common.js.map +1 -1
  550. package/lib/esm/webchat/components/conditional-animation.js +15 -10
  551. package/lib/esm/webchat/components/conditional-animation.js.map +1 -1
  552. package/lib/esm/webchat/components/opened-persistent-menu.js +21 -16
  553. package/lib/esm/webchat/components/opened-persistent-menu.js.map +1 -1
  554. package/lib/esm/webchat/constants.js +4 -1
  555. package/lib/esm/webchat/constants.js.map +1 -1
  556. package/lib/esm/webchat/context/actions.js +5 -2
  557. package/lib/esm/webchat/context/actions.js.map +1 -1
  558. package/lib/esm/webchat/context/index.d.ts +0 -1
  559. package/lib/esm/webchat/context/index.js +24 -21
  560. package/lib/esm/webchat/context/index.js.map +1 -1
  561. package/lib/esm/webchat/context/messages-reducer.js +86 -42
  562. package/lib/esm/webchat/context/messages-reducer.js.map +1 -1
  563. package/lib/esm/webchat/context/types.d.ts +0 -1
  564. package/lib/esm/webchat/context/types.js +2 -1
  565. package/lib/esm/webchat/context/use-webchat.d.ts +0 -1
  566. package/lib/esm/webchat/context/use-webchat.js +44 -41
  567. package/lib/esm/webchat/context/use-webchat.js.map +1 -1
  568. package/lib/esm/webchat/context/webchat-reducer.js +49 -40
  569. package/lib/esm/webchat/context/webchat-reducer.js.map +1 -1
  570. package/lib/esm/webchat/cover-component/index.js +12 -8
  571. package/lib/esm/webchat/cover-component/index.js.map +1 -1
  572. package/lib/esm/webchat/custom-messages/index.js +6 -1
  573. package/lib/esm/webchat/custom-messages/index.js.map +1 -1
  574. package/lib/esm/webchat/custom-messages/rating/icons/face-angry.js +7 -3
  575. package/lib/esm/webchat/custom-messages/rating/icons/face-angry.js.map +1 -1
  576. package/lib/esm/webchat/custom-messages/rating/icons/face-frown.js +7 -3
  577. package/lib/esm/webchat/custom-messages/rating/icons/face-frown.js.map +1 -1
  578. package/lib/esm/webchat/custom-messages/rating/icons/face-grin-beam.js +7 -3
  579. package/lib/esm/webchat/custom-messages/rating/icons/face-grin-beam.js.map +1 -1
  580. package/lib/esm/webchat/custom-messages/rating/icons/face-meh.js +7 -3
  581. package/lib/esm/webchat/custom-messages/rating/icons/face-meh.js.map +1 -1
  582. package/lib/esm/webchat/custom-messages/rating/icons/face-smile.js +7 -3
  583. package/lib/esm/webchat/custom-messages/rating/icons/face-smile.js.map +1 -1
  584. package/lib/esm/webchat/custom-messages/rating/icons/index.js +9 -6
  585. package/lib/esm/webchat/custom-messages/rating/icons/index.js.map +1 -1
  586. package/lib/esm/webchat/custom-messages/rating/icons/star.js +7 -3
  587. package/lib/esm/webchat/custom-messages/rating/icons/star.js.map +1 -1
  588. package/lib/esm/webchat/custom-messages/rating/index.js +18 -17
  589. package/lib/esm/webchat/custom-messages/rating/index.js.map +1 -1
  590. package/lib/esm/webchat/custom-messages/rating/rating-selector.js +15 -11
  591. package/lib/esm/webchat/custom-messages/rating/rating-selector.js.map +1 -1
  592. package/lib/esm/webchat/custom-messages/rating/smileys.js +13 -9
  593. package/lib/esm/webchat/custom-messages/rating/smileys.js.map +1 -1
  594. package/lib/esm/webchat/custom-messages/rating/stars.js +8 -4
  595. package/lib/esm/webchat/custom-messages/rating/stars.js.map +1 -1
  596. package/lib/esm/webchat/custom-messages/rating/styles.js +7 -3
  597. package/lib/esm/webchat/custom-messages/rating/styles.js.map +1 -1
  598. package/lib/esm/webchat/custom-messages/rating/types.js +5 -2
  599. package/lib/esm/webchat/custom-messages/rating/types.js.map +1 -1
  600. package/lib/esm/webchat/devices/index.js +9 -4
  601. package/lib/esm/webchat/devices/index.js.map +1 -1
  602. package/lib/esm/webchat/header/default-header.js +20 -16
  603. package/lib/esm/webchat/header/default-header.js.map +1 -1
  604. package/lib/esm/webchat/header/index.js +16 -13
  605. package/lib/esm/webchat/header/index.js.map +1 -1
  606. package/lib/esm/webchat/header/styles.js +20 -16
  607. package/lib/esm/webchat/header/styles.js.map +1 -1
  608. package/lib/esm/webchat/hooks/index.js +23 -10
  609. package/lib/esm/webchat/hooks/index.js.map +1 -1
  610. package/lib/esm/webchat/hooks/use-component-visible.d.ts +0 -1
  611. package/lib/esm/webchat/hooks/use-component-visible.js +8 -5
  612. package/lib/esm/webchat/hooks/use-component-visible.js.map +1 -1
  613. package/lib/esm/webchat/hooks/use-component-will-mount.js +7 -3
  614. package/lib/esm/webchat/hooks/use-component-will-mount.js.map +1 -1
  615. package/lib/esm/webchat/hooks/use-device-adapter.js +19 -15
  616. package/lib/esm/webchat/hooks/use-device-adapter.js.map +1 -1
  617. package/lib/esm/webchat/hooks/use-previous.js +7 -4
  618. package/lib/esm/webchat/hooks/use-previous.js.map +1 -1
  619. package/lib/esm/webchat/hooks/use-scroll-to-bottom.js +8 -4
  620. package/lib/esm/webchat/hooks/use-scroll-to-bottom.js.map +1 -1
  621. package/lib/esm/webchat/hooks/use-scrollbar-controller.js +18 -15
  622. package/lib/esm/webchat/hooks/use-scrollbar-controller.js.map +1 -1
  623. package/lib/esm/webchat/hooks/use-typing.js +7 -4
  624. package/lib/esm/webchat/hooks/use-typing.js.map +1 -1
  625. package/lib/esm/webchat/hooks/use-virtual-keyboard-detection.js +8 -4
  626. package/lib/esm/webchat/hooks/use-virtual-keyboard-detection.js.map +1 -1
  627. package/lib/esm/webchat/hooks/use-webchat-dimensions.js +10 -6
  628. package/lib/esm/webchat/hooks/use-webchat-dimensions.js.map +1 -1
  629. package/lib/esm/webchat/hooks/use-webchat-resizer.js +10 -6
  630. package/lib/esm/webchat/hooks/use-webchat-resizer.js.map +1 -1
  631. package/lib/esm/webchat/index-types.js +2 -1
  632. package/lib/esm/webchat/index.js +14 -6
  633. package/lib/esm/webchat/index.js.map +1 -1
  634. package/lib/esm/webchat/input-panel/attachment.js +18 -15
  635. package/lib/esm/webchat/input-panel/attachment.js.map +1 -1
  636. package/lib/esm/webchat/input-panel/emoji-picker.js +17 -14
  637. package/lib/esm/webchat/input-panel/emoji-picker.js.map +1 -1
  638. package/lib/esm/webchat/input-panel/index.js +31 -27
  639. package/lib/esm/webchat/input-panel/index.js.map +1 -1
  640. package/lib/esm/webchat/input-panel/opened-emoji-picker.js +13 -8
  641. package/lib/esm/webchat/input-panel/opened-emoji-picker.js.map +1 -1
  642. package/lib/esm/webchat/input-panel/persistent-menu.js +17 -13
  643. package/lib/esm/webchat/input-panel/persistent-menu.js.map +1 -1
  644. package/lib/esm/webchat/input-panel/send-button.js +17 -14
  645. package/lib/esm/webchat/input-panel/send-button.js.map +1 -1
  646. package/lib/esm/webchat/input-panel/styles.js +10 -6
  647. package/lib/esm/webchat/input-panel/styles.js.map +1 -1
  648. package/lib/esm/webchat/input-panel/textarea.js +34 -17
  649. package/lib/esm/webchat/input-panel/textarea.js.map +1 -1
  650. package/lib/esm/webchat/message-list/index.js +37 -37
  651. package/lib/esm/webchat/message-list/index.js.map +1 -1
  652. package/lib/esm/webchat/message-list/intro-message.js +22 -16
  653. package/lib/esm/webchat/message-list/intro-message.js.map +1 -1
  654. package/lib/esm/webchat/message-list/scroll-button.d.ts +0 -1
  655. package/lib/esm/webchat/message-list/scroll-button.js +15 -10
  656. package/lib/esm/webchat/message-list/scroll-button.js.map +1 -1
  657. package/lib/esm/webchat/message-list/styles.js +10 -6
  658. package/lib/esm/webchat/message-list/styles.js.map +1 -1
  659. package/lib/esm/webchat/message-list/unread-messages-banner.js +16 -11
  660. package/lib/esm/webchat/message-list/unread-messages-banner.js.map +1 -1
  661. package/lib/esm/webchat/message-list/use-debounce.js +7 -4
  662. package/lib/esm/webchat/message-list/use-debounce.js.map +1 -1
  663. package/lib/esm/webchat/message-list/use-notifications.js +14 -11
  664. package/lib/esm/webchat/message-list/use-notifications.js.map +1 -1
  665. package/lib/esm/webchat/replies/index.js +17 -14
  666. package/lib/esm/webchat/replies/index.js.map +1 -1
  667. package/lib/esm/webchat/replies/styles.js +8 -4
  668. package/lib/esm/webchat/replies/styles.js.map +1 -1
  669. package/lib/esm/webchat/session-view.js +41 -30
  670. package/lib/esm/webchat/session-view.js.map +1 -1
  671. package/lib/esm/webchat/styles.js +13 -9
  672. package/lib/esm/webchat/styles.js.map +1 -1
  673. package/lib/esm/webchat/theme/default-theme.js +17 -14
  674. package/lib/esm/webchat/theme/default-theme.js.map +1 -1
  675. package/lib/esm/webchat/theme/types.d.ts +0 -1
  676. package/lib/esm/webchat/theme/types.js +2 -1
  677. package/lib/esm/webchat/tracking.js +30 -26
  678. package/lib/esm/webchat/tracking.js.map +1 -1
  679. package/lib/esm/webchat/trigger-button/index.d.ts +0 -1
  680. package/lib/esm/webchat/trigger-button/index.js +19 -15
  681. package/lib/esm/webchat/trigger-button/index.js.map +1 -1
  682. package/lib/esm/webchat/trigger-button/styles.js +11 -7
  683. package/lib/esm/webchat/trigger-button/styles.js.map +1 -1
  684. package/lib/esm/webchat/typing-indicator/index.js +8 -6
  685. package/lib/esm/webchat/typing-indicator/index.js.map +1 -1
  686. package/lib/esm/webchat/typing-indicator/styles.js +10 -6
  687. package/lib/esm/webchat/typing-indicator/styles.js.map +1 -1
  688. package/lib/esm/webchat/use-storage-state-hook.js +12 -10
  689. package/lib/esm/webchat/use-storage-state-hook.js.map +1 -1
  690. package/lib/esm/webchat/utils.js +7 -3
  691. package/lib/esm/webchat/utils.js.map +1 -1
  692. package/lib/esm/webchat/webchat-dev.d.ts +1 -1
  693. package/lib/esm/webchat/webchat-dev.js +23 -22
  694. package/lib/esm/webchat/webchat-dev.js.map +1 -1
  695. package/lib/esm/webchat/webchat.js +156 -151
  696. package/lib/esm/webchat/webchat.js.map +1 -1
  697. package/lib/esm/webchat/webview/header.js +16 -10
  698. package/lib/esm/webchat/webview/header.js.map +1 -1
  699. package/lib/esm/webchat/webview/index.d.ts +1 -1
  700. package/lib/esm/webchat/webview/index.js +32 -27
  701. package/lib/esm/webchat/webview/index.js.map +1 -1
  702. package/lib/esm/webchat/webview/styles.js +20 -16
  703. package/lib/esm/webchat/webview/styles.js.map +1 -1
  704. package/lib/esm/webchat-app.d.ts +18 -18
  705. package/lib/esm/webchat-app.js +162 -166
  706. package/lib/esm/webchat-app.js.map +1 -1
  707. package/lib/esm/webview-app.js +105 -111
  708. package/lib/esm/webview-app.js.map +1 -1
  709. package/package.json +3 -4
@@ -1,54 +1,56 @@
1
- import { __awaiter } from "tslib";
2
- import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
3
- import { BotonicAction, INPUT, params2queryString } from '@botonic/core';
4
- import merge from 'lodash.merge';
5
- import { forwardRef, useEffect, useImperativeHandle, useRef, useState, } from 'react';
6
- import { StyleSheetManager, ThemeProvider } from 'styled-components';
7
- import { v7 as uuidv7 } from 'uuid';
8
- import { Audio, Document, Handoff, Image, normalizeWebchatSettings, Text, Video, } from '../components';
9
- import { COLORS, MAX_ALLOWED_SIZE_MB, ROLES, WEBCHAT } from '../constants';
10
- import { SENDERS } from '../index-types';
11
- import { getMediaType, isAllowedSize, isAudio, isDocument, isImage, isMedia, isText, isVideo, readDataURL, } from '../message-utils';
12
- import { msgToBotonic } from '../msg-to-botonic';
13
- import { isDev } from '../util/environment';
14
- import { deserializeRegex, stringifyWithRegexs } from '../util/regexs';
15
- import { _getThemeProperty, getServerErrorMessage, initSession, shouldKeepSessionOnReload, updateUserLocaleAndCountry, } from '../util/webchat';
16
- import { ChatArea } from './chat-area';
17
- import { OpenedPersistentMenu } from './components/opened-persistent-menu';
18
- import { BotonicContainerId } from './constants';
19
- import { useWebchat, WebchatContext } from './context';
20
- import { CoverComponent } from './cover-component';
21
- import { WebchatHeader } from './header';
22
- import { useComponentWillMount, usePrevious, useScrollToBottom, useTyping, } from './hooks';
23
- import { InputPanel } from './input-panel';
24
- import { DarkBackgroundMenu, ErrorMessage, ErrorMessageContainer, StyledWebchat, } from './styles';
25
- import { TriggerButton } from './trigger-button';
26
- import { useStorageState } from './use-storage-state-hook';
27
- import { getParsedAction } from './utils';
28
- import { WebviewContainer } from './webview/index';
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Webchat = void 0;
4
+ const tslib_1 = require("tslib");
5
+ const jsx_runtime_1 = require("react/jsx-runtime");
6
+ const core_1 = require("@botonic/core");
7
+ const lodash_merge_1 = tslib_1.__importDefault(require("lodash.merge"));
8
+ const react_1 = require("react");
9
+ const styled_components_1 = require("styled-components");
10
+ const uuid_1 = require("uuid");
11
+ const components_1 = require("../components");
12
+ const constants_1 = require("../constants");
13
+ const index_types_1 = require("../index-types");
14
+ const message_utils_1 = require("../message-utils");
15
+ const msg_to_botonic_1 = require("../msg-to-botonic");
16
+ const environment_1 = require("../util/environment");
17
+ const regexs_1 = require("../util/regexs");
18
+ const webchat_1 = require("../util/webchat");
19
+ const chat_area_1 = require("./chat-area");
20
+ const opened_persistent_menu_1 = require("./components/opened-persistent-menu");
21
+ const constants_2 = require("./constants");
22
+ const context_1 = require("./context");
23
+ const cover_component_1 = require("./cover-component");
24
+ const header_1 = require("./header");
25
+ const hooks_1 = require("./hooks");
26
+ const input_panel_1 = require("./input-panel");
27
+ const styles_1 = require("./styles");
28
+ const trigger_button_1 = require("./trigger-button");
29
+ const use_storage_state_hook_1 = require("./use-storage-state-hook");
30
+ const utils_1 = require("./utils");
31
+ const index_1 = require("./webview/index");
29
32
  // eslint-disable-next-line complexity, react/display-name
30
- const Webchat = forwardRef((props, ref) => {
31
- var _a;
33
+ const Webchat = (0, react_1.forwardRef)((props, ref) => {
32
34
  const { addMessage, addMessageComponent, clearMessages, doRenderCustomComponent, resetUnreadMessages, setCurrentAttachment, setError, setIsInputFocused, setLastMessageVisible, setOnline, toggleCoverComponent, toggleEmojiPicker, togglePersistentMenu, toggleWebchat, updateCustomMessageProps, updateDevSettings, updateHandoff, updateLastMessageDate, updateLastRoutePath, updateLatestInput, updateMessage, updateReplies, updateSession, updateTheme, updateTyping, updateWebview, removeWebview, removeReplies, webchatState, webchatContainerRef, chatAreaRef, inputPanelRef, headerRef, repliesRef, scrollableMessagesListRef,
33
35
  // eslint-disable-next-line react-hooks/rules-of-hooks
34
- } = props.webchatHooks || useWebchat(props.theme);
35
- const firstUpdate = useRef(true);
36
+ } = props.webchatHooks || (0, context_1.useWebchat)(props.theme);
37
+ const firstUpdate = (0, react_1.useRef)(true);
36
38
  const isOnline = () => webchatState.online;
37
39
  const currentDateString = () => new Date().toISOString();
38
- const theme = merge(webchatState.theme, props.theme);
40
+ const theme = (0, lodash_merge_1.default)(webchatState.theme, props.theme);
39
41
  const { initialSession, initialDevSettings, onStateChange } = props;
40
- const getThemeProperty = _getThemeProperty(theme);
41
- const [customComponent, setCustomComponent] = useState(null);
42
+ const getThemeProperty = (0, webchat_1._getThemeProperty)(theme);
43
+ const [customComponent, setCustomComponent] = (0, react_1.useState)(null);
42
44
  const storage = props.storage;
43
45
  const storageKey = typeof props.storageKey === 'function'
44
46
  ? props.storageKey()
45
47
  : props.storageKey;
46
- const [botonicState, saveState] = useStorageState(storage, storageKey);
48
+ const [botonicState, saveState] = (0, use_storage_state_hook_1.useStorageState)(storage, storageKey);
47
49
  const host = props.host || document.body;
48
- const { scrollToBottom } = useScrollToBottom({ host });
50
+ const { scrollToBottom } = (0, hooks_1.useScrollToBottom)({ host });
49
51
  const saveWebchatState = (webchatState) => {
50
52
  storage &&
51
- saveState(JSON.parse(stringifyWithRegexs({
53
+ saveState(JSON.parse((0, regexs_1.stringifyWithRegexs)({
52
54
  messages: webchatState.messagesJSON,
53
55
  session: webchatState.session,
54
56
  lastRoutePath: webchatState.lastRoutePath,
@@ -58,18 +60,18 @@ const Webchat = forwardRef((props, ref) => {
58
60
  })));
59
61
  };
60
62
  const handleAttachment = (event) => {
61
- if (!isAllowedSize(event.target.files[0].size)) {
62
- throw new Error(`The file is too large. A maximum of ${MAX_ALLOWED_SIZE_MB}MB is allowed.`);
63
+ if (!(0, message_utils_1.isAllowedSize)(event.target.files[0].size)) {
64
+ throw new Error(`The file is too large. A maximum of ${constants_1.MAX_ALLOWED_SIZE_MB}MB is allowed.`);
63
65
  }
64
66
  // TODO: Attach more files?
65
67
  setCurrentAttachment(event.target.files[0]);
66
68
  };
67
- useEffect(() => {
69
+ (0, react_1.useEffect)(() => {
68
70
  if (webchatState.currentAttachment) {
69
71
  sendAttachment(webchatState.currentAttachment);
70
72
  }
71
73
  }, [webchatState.currentAttachment]);
72
- const sendUserInput = (input) => __awaiter(void 0, void 0, void 0, function* () {
74
+ const sendUserInput = async (input) => {
73
75
  if (props.onUserInput) {
74
76
  resetUnreadMessages();
75
77
  scrollToBottom();
@@ -83,9 +85,9 @@ const Webchat = forwardRef((props, ref) => {
83
85
  lastRoutePath: webchatState.lastRoutePath,
84
86
  });
85
87
  }
86
- });
88
+ };
87
89
  // Load styles stored in window._botonicInsertStyles by Webpack
88
- useComponentWillMount(() => {
90
+ (0, hooks_1.useComponentWillMount)(() => {
89
91
  if (window._botonicInsertStyles && window._botonicInsertStyles.length) {
90
92
  for (const botonicStyle of window._botonicInsertStyles) {
91
93
  // Injecting styles at head is needed even if we use shadowDOM
@@ -109,28 +111,27 @@ const Webchat = forwardRef((props, ref) => {
109
111
  }
110
112
  });
111
113
  // Load initial state from storage
112
- useEffect(() => {
114
+ (0, react_1.useEffect)(() => {
113
115
  let { messages, session, lastRoutePath, devSettings, lastMessageUpdate, themeUpdates, } = botonicState || {};
114
- session = initSession(session);
116
+ session = (0, webchat_1.initSession)(session);
115
117
  updateSession(session);
116
- if (shouldKeepSessionOnReload({ initialDevSettings, devSettings })) {
118
+ if ((0, webchat_1.shouldKeepSessionOnReload)({ initialDevSettings, devSettings })) {
117
119
  if (messages) {
118
120
  messages.forEach(message => {
119
- var _a, _b;
120
121
  addMessage(message);
121
- const newMessageComponent = msgToBotonic(Object.assign(Object.assign({}, message), { delay: 0, typing: 0 }), (_b = (_a = props.theme) === null || _a === void 0 ? void 0 : _a.message) === null || _b === void 0 ? void 0 : _b.customTypes);
122
+ const newMessageComponent = (0, msg_to_botonic_1.msgToBotonic)({ ...message, delay: 0, typing: 0 }, props.theme?.message?.customTypes);
122
123
  //@ts-ignore
123
124
  if (newMessageComponent)
124
125
  addMessageComponent(newMessageComponent);
125
126
  });
126
127
  }
127
128
  if (initialSession)
128
- updateSession(merge(initialSession, session));
129
+ updateSession((0, lodash_merge_1.default)(initialSession, session));
129
130
  if (lastRoutePath)
130
131
  updateLastRoutePath(lastRoutePath);
131
132
  }
132
133
  else
133
- updateSession(merge(initialSession, session));
134
+ updateSession((0, lodash_merge_1.default)(initialSession, session));
134
135
  if (devSettings)
135
136
  updateDevSettings(devSettings);
136
137
  else if (initialDevSettings)
@@ -139,18 +140,18 @@ const Webchat = forwardRef((props, ref) => {
139
140
  updateLastMessageDate(lastMessageUpdate);
140
141
  }
141
142
  if (themeUpdates !== undefined) {
142
- updateTheme(merge(props.theme, themeUpdates), themeUpdates);
143
+ updateTheme((0, lodash_merge_1.default)(props.theme, themeUpdates), themeUpdates);
143
144
  }
144
145
  if (props.onInit) {
145
146
  setTimeout(() => {
146
147
  if (typeof props.onInit === 'function') {
147
148
  props.onInit();
148
- session.user = updateUserLocaleAndCountry(session.user);
149
+ session.user = (0, webchat_1.updateUserLocaleAndCountry)(session.user);
149
150
  }
150
151
  }, 100);
151
152
  }
152
153
  }, []);
153
- useEffect(() => {
154
+ (0, react_1.useEffect)(() => {
154
155
  if (!webchatState.isWebchatOpen) {
155
156
  if (webchatState.isLastMessageVisible) {
156
157
  resetUnreadMessages();
@@ -158,7 +159,7 @@ const Webchat = forwardRef((props, ref) => {
158
159
  return;
159
160
  }
160
161
  }, [webchatState.isWebchatOpen]);
161
- useEffect(() => {
162
+ (0, react_1.useEffect)(() => {
162
163
  const { messagesJSON, session } = webchatState;
163
164
  if (onStateChange && typeof onStateChange === 'function' && session.user) {
164
165
  onStateChange({ messagesJSON, user: session.user });
@@ -171,10 +172,10 @@ const Webchat = forwardRef((props, ref) => {
171
172
  webchatState.devSettings,
172
173
  webchatState.lastMessageUpdate,
173
174
  ]);
174
- useEffect(() => {
175
+ (0, react_1.useEffect)(() => {
175
176
  if (!webchatState.online) {
176
177
  setError({
177
- message: getServerErrorMessage(props.server),
178
+ message: (0, webchat_1.getServerErrorMessage)(props.server),
178
179
  });
179
180
  }
180
181
  else {
@@ -183,61 +184,59 @@ const Webchat = forwardRef((props, ref) => {
183
184
  }
184
185
  }
185
186
  }, [webchatState.online]);
186
- useTyping({ webchatState, updateTyping, updateMessage, host });
187
- useEffect(() => {
188
- updateTheme(merge(props.theme, theme, webchatState.themeUpdates));
187
+ (0, hooks_1.useTyping)({ webchatState, updateTyping, updateMessage, host });
188
+ (0, react_1.useEffect)(() => {
189
+ updateTheme((0, lodash_merge_1.default)(props.theme, theme, webchatState.themeUpdates));
189
190
  }, [props.theme, webchatState.themeUpdates]);
190
191
  const openWebview = (webviewComponent, params) => {
191
192
  updateWebview(webviewComponent, params);
192
193
  };
193
- const textareaRef = useRef();
194
- const closeWebview = (options) => __awaiter(void 0, void 0, void 0, function* () {
195
- var _b;
194
+ const textareaRef = (0, react_1.useRef)();
195
+ const closeWebview = async (options) => {
196
196
  removeWebview();
197
197
  if (userInputEnabled) {
198
- (_b = textareaRef.current) === null || _b === void 0 ? void 0 : _b.focus();
198
+ textareaRef.current?.focus();
199
199
  }
200
- if (options === null || options === void 0 ? void 0 : options.payload) {
201
- yield sendPayload(options.payload);
200
+ if (options?.payload) {
201
+ await sendPayload(options.payload);
202
202
  }
203
- else if (options === null || options === void 0 ? void 0 : options.path) {
204
- const params = options.params ? params2queryString(options.params) : '';
205
- yield sendPayload(`__PATH_PAYLOAD__${options.path}?${params}`);
203
+ else if (options?.path) {
204
+ const params = options.params ? (0, core_1.params2queryString)(options.params) : '';
205
+ await sendPayload(`__PATH_PAYLOAD__${options.path}?${params}`);
206
206
  }
207
- });
208
- const persistentMenuOptions = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.persistentMenu);
209
- const darkBackgroundMenu = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.darkBackgroundMenu);
207
+ };
208
+ const persistentMenuOptions = getThemeProperty(constants_1.WEBCHAT.CUSTOM_PROPERTIES.persistentMenu);
209
+ const darkBackgroundMenu = getThemeProperty(constants_1.WEBCHAT.CUSTOM_PROPERTIES.darkBackgroundMenu);
210
210
  const getBlockInputs = (rule, inputData) => {
211
211
  const processedInput = rule.preprocess
212
212
  ? rule.preprocess(inputData)
213
213
  : inputData;
214
214
  return rule.match.some(regex => {
215
215
  if (typeof regex === 'string')
216
- regex = deserializeRegex(regex);
216
+ regex = (0, regexs_1.deserializeRegex)(regex);
217
217
  return regex.test(processedInput);
218
218
  });
219
219
  };
220
220
  const checkBlockInput = input => {
221
- var _a;
222
221
  // if is a text we check if it is a serialized RE
223
- const blockInputs = (_a = webchatState.theme.userInput) === null || _a === void 0 ? void 0 : _a.blockInputs;
222
+ const blockInputs = webchatState.theme.userInput?.blockInputs;
224
223
  if (!Array.isArray(blockInputs))
225
224
  return false;
226
225
  for (const rule of blockInputs) {
227
226
  if (getBlockInputs(rule, input.data)) {
228
- addMessageComponent(_jsx(Text
227
+ addMessageComponent((0, jsx_runtime_1.jsx)(components_1.Text
229
228
  // Is necessary to add the id of the input
230
229
  // to keep the input.id generated in the frontend as id of the message
231
230
  // @ts-ignore
232
- , Object.assign({
231
+ , {
233
232
  // Is necessary to add the id of the input
234
233
  // to keep the input.id generated in the frontend as id of the message
235
234
  // @ts-ignore
236
- id: input.id, sentBy: SENDERS.user, blob: false, style: {
237
- backgroundColor: COLORS.SCORPION_GRAY,
238
- borderColor: COLORS.SCORPION_GRAY,
235
+ id: input.id, sentBy: index_types_1.SENDERS.user, blob: false, style: {
236
+ backgroundColor: constants_1.COLORS.SCORPION_GRAY,
237
+ borderColor: constants_1.COLORS.SCORPION_GRAY,
239
238
  padding: '8px 12px',
240
- } }, { children: rule.message })));
239
+ }, children: rule.message }));
241
240
  removeReplies();
242
241
  return true;
243
242
  }
@@ -248,11 +247,11 @@ const Webchat = forwardRef((props, ref) => {
248
247
  togglePersistentMenu(false);
249
248
  };
250
249
  const persistentMenu = () => {
251
- return (_jsx(OpenedPersistentMenu, { onClick: closeMenu, options: persistentMenuOptions, borderRadius: webchatState.theme.style.borderRadius || '10px' }));
250
+ return ((0, jsx_runtime_1.jsx)(opened_persistent_menu_1.OpenedPersistentMenu, { onClick: closeMenu, options: persistentMenuOptions, borderRadius: webchatState.theme.style.borderRadius || '10px' }));
252
251
  };
253
252
  const coverComponent = webchatState.theme.coverComponent;
254
- const coverComponentProps = (_a = webchatState.theme.coverComponent) === null || _a === void 0 ? void 0 : _a.props;
255
- useEffect(() => {
253
+ const coverComponentProps = webchatState.theme.coverComponent?.props;
254
+ (0, react_1.useEffect)(() => {
256
255
  if (!coverComponent)
257
256
  return;
258
257
  if (!botonicState ||
@@ -261,87 +260,90 @@ const Webchat = forwardRef((props, ref) => {
261
260
  }, []);
262
261
  const messageComponentFromInput = input => {
263
262
  let messageComponent = null;
264
- if (isText(input)) {
265
- messageComponent = (_jsx(Text
263
+ if ((0, message_utils_1.isText)(input)) {
264
+ messageComponent = ((0, jsx_runtime_1.jsx)(components_1.Text
266
265
  // Is necessary to add the id of the input
267
266
  // to keep the input.id generated in the frontend as id of the message
268
267
  // @ts-ignore
269
- , Object.assign({
268
+ , {
270
269
  // Is necessary to add the id of the input
271
270
  // to keep the input.id generated in the frontend as id of the message
272
271
  // @ts-ignore
273
272
  id: input.id,
274
273
  // Is necessary to add the payload of the input when user clicks a button
275
274
  // @ts-ignore
276
- payload: input.payload, sentBy: SENDERS.user }, { children: input.data })));
275
+ payload: input.payload, sentBy: index_types_1.SENDERS.user, children: input.data }));
277
276
  }
278
- else if (isMedia(input)) {
277
+ else if ((0, message_utils_1.isMedia)(input)) {
279
278
  const temporaryDisplayUrl = URL.createObjectURL(input.data);
280
279
  // TODO: We should use URL.revokeObjectURL(temporaryDisplayUrl) when the component is unmounted
281
280
  // https://developer.mozilla.org/en-US/docs/Web/API/URL/createObjectURL_static#memory_management
282
281
  const mediaProps = {
283
282
  id: input.id,
284
- sentBy: SENDERS.user,
283
+ sentBy: index_types_1.SENDERS.user,
285
284
  src: temporaryDisplayUrl,
286
285
  };
287
- if (isImage(input)) {
286
+ if ((0, message_utils_1.isImage)(input)) {
288
287
  mediaProps.input = input;
289
- messageComponent = _jsx(Image, Object.assign({}, mediaProps));
288
+ messageComponent = (0, jsx_runtime_1.jsx)(components_1.Image, { ...mediaProps });
290
289
  }
291
- else if (isAudio(input))
292
- messageComponent = _jsx(Audio, Object.assign({}, mediaProps));
293
- else if (isVideo(input))
294
- messageComponent = _jsx(Video, Object.assign({}, mediaProps));
295
- else if (isDocument(input))
296
- messageComponent = _jsx(Document, Object.assign({}, mediaProps));
290
+ else if ((0, message_utils_1.isAudio)(input))
291
+ messageComponent = (0, jsx_runtime_1.jsx)(components_1.Audio, { ...mediaProps });
292
+ else if ((0, message_utils_1.isVideo)(input))
293
+ messageComponent = (0, jsx_runtime_1.jsx)(components_1.Video, { ...mediaProps });
294
+ else if ((0, message_utils_1.isDocument)(input))
295
+ messageComponent = (0, jsx_runtime_1.jsx)(components_1.Document, { ...mediaProps });
297
296
  }
298
297
  return messageComponent;
299
298
  };
300
- const sendInput = (input) => __awaiter(void 0, void 0, void 0, function* () {
299
+ const sendInput = async (input) => {
301
300
  if (!input || Object.keys(input).length == 0)
302
301
  return;
303
- if (isText(input) && (!input.data || !input.data.trim()))
302
+ if ((0, message_utils_1.isText)(input) && (!input.data || !input.data.trim()))
304
303
  return; // in case trim() doesn't work in a browser we can use !/\S/.test(input.data)
305
- if (isText(input) && checkBlockInput(input))
304
+ if ((0, message_utils_1.isText)(input) && checkBlockInput(input))
306
305
  return;
307
306
  if (!input.id)
308
- input.id = uuidv7();
307
+ input.id = (0, uuid_1.v7)();
309
308
  const messageComponent = messageComponentFromInput(input);
310
309
  if (messageComponent)
311
310
  addMessageComponent(messageComponent);
312
- if (isMedia(input))
313
- input.data = yield readDataURL(input.data);
311
+ if ((0, message_utils_1.isMedia)(input))
312
+ input.data = await (0, message_utils_1.readDataURL)(input.data);
314
313
  sendUserInput(input);
315
314
  updateLatestInput(input);
316
315
  isOnline() && updateLastMessageDate(currentDateString());
317
316
  removeReplies();
318
317
  togglePersistentMenu(false);
319
318
  toggleEmojiPicker(false);
320
- });
319
+ };
321
320
  /* This is the public API this component exposes to its parents
322
321
  https://stackoverflow.com/questions/37949981/call-child-method-from-parent
323
322
  */
324
323
  const updateSessionWithUser = (userToUpdate) => {
325
- updateSession(merge(webchatState.session, { user: userToUpdate }));
324
+ updateSession((0, lodash_merge_1.default)(webchatState.session, { user: userToUpdate }));
326
325
  };
327
- useImperativeHandle(ref, () => ({
326
+ (0, react_1.useImperativeHandle)(ref, () => ({
328
327
  addBotResponse: ({ response, session, lastRoutePath }) => {
329
328
  updateTyping(false);
330
329
  const isUnread = !webchatState.isLastMessageVisible || webchatState.numUnreadMessages > 0;
331
330
  if (Array.isArray(response)) {
332
331
  response.forEach(r => {
333
- addMessageComponent(Object.assign(Object.assign({}, r), { props: Object.assign(Object.assign({}, r.props), { isUnread }) }));
332
+ addMessageComponent({ ...r, props: { ...r.props, isUnread } });
334
333
  });
335
334
  }
336
335
  else if (response) {
337
- addMessageComponent(Object.assign(Object.assign({}, response), { props: Object.assign(Object.assign({}, response.props), { isUnread }) }));
336
+ addMessageComponent({
337
+ ...response,
338
+ props: { ...response.props, isUnread },
339
+ });
338
340
  }
339
341
  if (session) {
340
- updateSession(merge(session, { user: webchatState.session.user }));
342
+ updateSession((0, lodash_merge_1.default)(session, { user: webchatState.session.user }));
341
343
  const action = session._botonic_action || '';
342
- const handoff = action.startsWith(BotonicAction.CreateCase);
343
- if (handoff && isDev)
344
- addMessageComponent(_jsx(Handoff, {}));
344
+ const handoff = action.startsWith(core_1.BotonicAction.CreateCase);
345
+ if (handoff && environment_1.isDev)
346
+ addMessageComponent((0, jsx_runtime_1.jsx)(components_1.Handoff, {}));
345
347
  updateHandoff(handoff);
346
348
  }
347
349
  if (lastRoutePath)
@@ -351,11 +353,14 @@ const Webchat = forwardRef((props, ref) => {
351
353
  addSystemResponse: ({ response }) => {
352
354
  if (Array.isArray(response)) {
353
355
  response.forEach(r => {
354
- addMessageComponent(Object.assign(Object.assign({}, r), { props: Object.assign(Object.assign({}, r.props), { isUnread: false }) }));
356
+ addMessageComponent({ ...r, props: { ...r.props, isUnread: false } });
355
357
  });
356
358
  }
357
359
  else if (response) {
358
- addMessageComponent(Object.assign(Object.assign({}, response), { props: Object.assign(Object.assign({}, response.props), { isUnread: false }) }));
360
+ addMessageComponent({
361
+ ...response,
362
+ props: { ...response.props, isUnread: false },
363
+ });
359
364
  }
360
365
  updateLastMessageDate(currentDateString());
361
366
  },
@@ -383,7 +388,7 @@ const Webchat = forwardRef((props, ref) => {
383
388
  getLastMessageUpdate: () => webchatState.lastMessageUpdate,
384
389
  updateMessageInfo: (msgId, messageInfo) => {
385
390
  const messageToUpdate = webchatState.messagesJSON.filter(m => m.id === msgId)[0];
386
- const updatedMsg = merge(messageToUpdate, messageInfo);
391
+ const updatedMsg = (0, lodash_merge_1.default)(messageToUpdate, messageInfo);
387
392
  if (updatedMsg.ack === 1)
388
393
  delete updatedMsg.unsentInput;
389
394
  updateMessage(updatedMsg);
@@ -392,51 +397,51 @@ const Webchat = forwardRef((props, ref) => {
392
397
  if (settings.user) {
393
398
  updateSessionWithUser(settings.user);
394
399
  }
395
- const themeUpdates = normalizeWebchatSettings(settings);
396
- updateTheme(merge(webchatState.theme, themeUpdates), themeUpdates);
400
+ const themeUpdates = (0, components_1.normalizeWebchatSettings)(settings);
401
+ updateTheme((0, lodash_merge_1.default)(webchatState.theme, themeUpdates), themeUpdates);
397
402
  updateTyping(false);
398
403
  },
399
- closeWebview: (options) => __awaiter(void 0, void 0, void 0, function* () { return closeWebview(options); }),
404
+ closeWebview: async (options) => closeWebview(options),
400
405
  }));
401
406
  const resolveCase = () => {
402
407
  updateHandoff(false);
403
- updateSession(Object.assign(Object.assign({}, webchatState.session), { _botonic_action: undefined }));
408
+ updateSession({ ...webchatState.session, _botonic_action: undefined });
404
409
  };
405
- const prevSession = usePrevious(webchatState.session);
406
- useEffect(() => {
410
+ const prevSession = (0, hooks_1.usePrevious)(webchatState.session);
411
+ (0, react_1.useEffect)(() => {
407
412
  // Resume conversation after handoff
408
- if ((prevSession === null || prevSession === void 0 ? void 0 : prevSession._botonic_action) && !webchatState.session._botonic_action) {
409
- const action = getParsedAction(prevSession._botonic_action);
410
- if (action === null || action === void 0 ? void 0 : action.on_finish)
413
+ if (prevSession?._botonic_action && !webchatState.session._botonic_action) {
414
+ const action = (0, utils_1.getParsedAction)(prevSession._botonic_action);
415
+ if (action?.on_finish)
411
416
  sendPayload(action.on_finish);
412
417
  }
413
418
  }, [webchatState.session._botonic_action]);
414
- const sendText = (text, payload) => __awaiter(void 0, void 0, void 0, function* () {
419
+ const sendText = async (text, payload) => {
415
420
  if (!text)
416
421
  return;
417
- const input = { type: INPUT.TEXT, data: text, payload };
418
- yield sendInput(input);
419
- });
420
- const sendPayload = (payload) => __awaiter(void 0, void 0, void 0, function* () {
422
+ const input = { type: core_1.INPUT.TEXT, data: text, payload };
423
+ await sendInput(input);
424
+ };
425
+ const sendPayload = async (payload) => {
421
426
  if (!payload)
422
427
  return;
423
- const input = { type: INPUT.POSTBACK, payload };
424
- yield sendInput(input);
425
- });
426
- const sendAttachment = (attachment) => __awaiter(void 0, void 0, void 0, function* () {
428
+ const input = { type: core_1.INPUT.POSTBACK, payload };
429
+ await sendInput(input);
430
+ };
431
+ const sendAttachment = async (attachment) => {
427
432
  if (attachment) {
428
- const attachmentType = getMediaType(attachment.type);
433
+ const attachmentType = (0, message_utils_1.getMediaType)(attachment.type);
429
434
  if (!attachmentType)
430
435
  return;
431
436
  const input = {
432
437
  type: attachmentType,
433
438
  data: attachment,
434
439
  };
435
- yield sendInput(input);
440
+ await sendInput(input);
436
441
  setCurrentAttachment();
437
442
  }
438
- });
439
- useEffect(() => {
443
+ };
444
+ (0, react_1.useEffect)(() => {
440
445
  if (firstUpdate.current) {
441
446
  firstUpdate.current = false;
442
447
  return;
@@ -450,34 +455,34 @@ const Webchat = forwardRef((props, ref) => {
450
455
  }
451
456
  }, [webchatState.isWebchatOpen]);
452
457
  const isUserInputEnabled = () => {
453
- const isUserInputEnabled = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.enableUserInput);
458
+ const isUserInputEnabled = getThemeProperty(constants_1.WEBCHAT.CUSTOM_PROPERTIES.enableUserInput);
454
459
  return isUserInputEnabled && !webchatState.isCoverComponentOpen;
455
460
  };
456
461
  const userInputEnabled = isUserInputEnabled();
457
- useEffect(() => {
462
+ (0, react_1.useEffect)(() => {
458
463
  // Prod mode
459
464
  saveWebchatState(webchatState);
460
465
  }, [webchatState.themeUpdates]);
461
466
  // Only needed for dev/serve mode
462
467
  const updateWebchatDevSettings = settings => {
463
468
  // eslint-disable-next-line react-hooks/rules-of-hooks
464
- useEffect(() => {
465
- const themeUpdates = normalizeWebchatSettings(settings);
466
- updateTheme(merge(webchatState.theme, themeUpdates), themeUpdates);
469
+ (0, react_1.useEffect)(() => {
470
+ const themeUpdates = (0, components_1.normalizeWebchatSettings)(settings);
471
+ updateTheme((0, lodash_merge_1.default)(webchatState.theme, themeUpdates), themeUpdates);
467
472
  }, [webchatState.messagesJSON]);
468
473
  };
469
474
  const DarkenBackground = ({ component }) => {
470
- return (_jsxs("div", { children: [darkBackgroundMenu && (_jsx(DarkBackgroundMenu, { style: {
475
+ return ((0, jsx_runtime_1.jsxs)("div", { children: [darkBackgroundMenu && ((0, jsx_runtime_1.jsx)(styles_1.DarkBackgroundMenu, { style: {
471
476
  borderRadius: webchatState.theme.style.borderRadius,
472
477
  } })), component] }));
473
478
  };
474
479
  const _renderCustomComponent = () => {
475
480
  if (!customComponent)
476
- return _jsx(_Fragment, {});
481
+ return (0, jsx_runtime_1.jsx)(jsx_runtime_1.Fragment, {});
477
482
  else
478
483
  return customComponent;
479
484
  };
480
- const WebchatComponent = (_jsx(WebchatContext.Provider, Object.assign({ value: {
485
+ const WebchatComponent = ((0, jsx_runtime_1.jsx)(context_1.WebchatContext.Provider, { value: {
481
486
  addMessage,
482
487
  getThemeProperty,
483
488
  closeWebview,
@@ -509,13 +514,13 @@ const Webchat = forwardRef((props, ref) => {
509
514
  headerRef,
510
515
  repliesRef,
511
516
  scrollableMessagesListRef,
512
- } }, { children: _jsxs(ThemeProvider, Object.assign({ theme: webchatState.theme }, { children: [!webchatState.isWebchatOpen && _jsx(TriggerButton, {}), webchatState.isWebchatOpen && (_jsxs(StyledWebchat, Object.assign({ id: BotonicContainerId.Webchat, ref: webchatContainerRef,
517
+ }, children: (0, jsx_runtime_1.jsxs)(styled_components_1.ThemeProvider, { theme: webchatState.theme, children: [!webchatState.isWebchatOpen && (0, jsx_runtime_1.jsx)(trigger_button_1.TriggerButton, {}), webchatState.isWebchatOpen && ((0, jsx_runtime_1.jsxs)(styles_1.StyledWebchat, { id: constants_2.BotonicContainerId.Webchat, ref: webchatContainerRef,
513
518
  // TODO: Distinguish between multiple instances of webchat, e.g. `${uniqueId}-botonic-webchat`
514
- role: ROLES.WEBCHAT }, { children: [_jsx(WebchatHeader, { ref: headerRef }), webchatState.isCoverComponentOpen ? (_jsx(CoverComponent, { component: coverComponent, componentProps: coverComponentProps })) : (_jsxs(_Fragment, { children: [webchatState.error.message && (_jsx(ErrorMessageContainer, { children: _jsx(ErrorMessage, { children: webchatState.error.message }) })), _jsx(ChatArea, {}), webchatState.isPersistentMenuOpen && (_jsx(DarkenBackground, { component: persistentMenu() })), !webchatState.handoff && userInputEnabled && (_jsx(InputPanel, { handleAttachment: handleAttachment, textareaRef: textareaRef, host: host, onUserInput: props.onUserInput })), webchatState.webview && (_jsx(WebviewContainer, { localWebviews: props.localWebviews })), webchatState.isCustomComponentRendered &&
519
+ role: constants_1.ROLES.WEBCHAT, children: [(0, jsx_runtime_1.jsx)(header_1.WebchatHeader, { ref: headerRef }), webchatState.isCoverComponentOpen ? ((0, jsx_runtime_1.jsx)(cover_component_1.CoverComponent, { component: coverComponent, componentProps: coverComponentProps })) : ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [webchatState.error.message && ((0, jsx_runtime_1.jsx)(styles_1.ErrorMessageContainer, { children: (0, jsx_runtime_1.jsx)(styles_1.ErrorMessage, { children: webchatState.error.message }) })), (0, jsx_runtime_1.jsx)(chat_area_1.ChatArea, {}), webchatState.isPersistentMenuOpen && ((0, jsx_runtime_1.jsx)(DarkenBackground, { component: persistentMenu() })), !webchatState.handoff && userInputEnabled && ((0, jsx_runtime_1.jsx)(input_panel_1.InputPanel, { handleAttachment: handleAttachment, textareaRef: textareaRef, host: host, onUserInput: props.onUserInput })), webchatState.webview && ((0, jsx_runtime_1.jsx)(index_1.WebviewContainer, { localWebviews: props.localWebviews })), webchatState.isCustomComponentRendered &&
515
520
  customComponent &&
516
- _renderCustomComponent()] }))] })))] })) })));
517
- return props.shadowDOM ? (_jsx(StyleSheetManager, Object.assign({ target: host }, { children: WebchatComponent }))) : (WebchatComponent);
521
+ _renderCustomComponent()] }))] }))] }) }));
522
+ return props.shadowDOM ? ((0, jsx_runtime_1.jsx)(styled_components_1.StyleSheetManager, { target: host, children: WebchatComponent })) : (WebchatComponent);
518
523
  });
524
+ exports.Webchat = Webchat;
519
525
  Webchat.displayName = 'Webchat';
520
- export { Webchat };
521
526
  //# sourceMappingURL=webchat.js.map