@botonic/react 0.22.0-alpha.0 → 0.22.0-alpha.2

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 (702) hide show
  1. package/lib/cjs/app.d.ts +2 -0
  2. package/lib/cjs/app.js +10 -0
  3. package/lib/cjs/app.js.map +1 -0
  4. package/lib/cjs/botonic-tester.d.ts +18 -0
  5. package/lib/cjs/botonic-tester.js +68 -0
  6. package/lib/cjs/botonic-tester.js.map +1 -0
  7. package/lib/cjs/components/audio.d.ts +8 -0
  8. package/lib/cjs/components/audio.js +23 -0
  9. package/lib/cjs/components/audio.js.map +1 -0
  10. package/lib/cjs/components/button.d.ts +15 -0
  11. package/lib/cjs/components/button.js +145 -0
  12. package/lib/cjs/components/button.js.map +1 -0
  13. package/lib/cjs/components/buttons-disabler.d.ts +24 -0
  14. package/lib/cjs/components/buttons-disabler.js +88 -0
  15. package/lib/cjs/components/buttons-disabler.js.map +1 -0
  16. package/lib/cjs/components/carousel.d.ts +10 -0
  17. package/lib/cjs/components/carousel.js +107 -0
  18. package/lib/cjs/components/carousel.js.map +1 -0
  19. package/lib/cjs/components/components.d.ts +12 -0
  20. package/lib/{components → cjs/components}/components.js +6 -11
  21. package/lib/cjs/components/components.js.map +1 -0
  22. package/lib/cjs/components/custom-message.d.ts +12 -0
  23. package/lib/cjs/components/custom-message.js +59 -0
  24. package/lib/cjs/components/custom-message.js.map +1 -0
  25. package/lib/cjs/components/document.d.ts +8 -0
  26. package/lib/cjs/components/document.js +47 -0
  27. package/lib/cjs/components/document.js.map +1 -0
  28. package/lib/cjs/components/element.d.ts +4 -0
  29. package/lib/cjs/components/element.js +56 -0
  30. package/lib/cjs/components/element.js.map +1 -0
  31. package/lib/cjs/components/handoff.d.ts +1 -0
  32. package/lib/cjs/components/handoff.js +54 -0
  33. package/lib/cjs/components/handoff.js.map +1 -0
  34. package/lib/cjs/components/image.d.ts +8 -0
  35. package/lib/cjs/components/image.js +38 -0
  36. package/lib/cjs/components/image.js.map +1 -0
  37. package/lib/cjs/components/index.d.ts +20 -0
  38. package/lib/cjs/components/index.js +44 -0
  39. package/lib/cjs/components/index.js.map +1 -0
  40. package/lib/cjs/components/location.d.ts +11 -0
  41. package/lib/cjs/components/location.js +32 -0
  42. package/lib/cjs/components/location.js.map +1 -0
  43. package/lib/cjs/components/markdown.d.ts +7 -0
  44. package/lib/cjs/components/markdown.js +162 -0
  45. package/lib/cjs/components/markdown.js.map +1 -0
  46. package/lib/cjs/components/message-template.d.ts +1 -0
  47. package/lib/cjs/components/message-template.js +14 -0
  48. package/lib/cjs/components/message-template.js.map +1 -0
  49. package/lib/cjs/components/message.d.ts +1 -0
  50. package/lib/cjs/components/message.js +188 -0
  51. package/lib/cjs/components/message.js.map +1 -0
  52. package/lib/cjs/components/multichannel/facebook/facebook.d.ts +17 -0
  53. package/lib/cjs/components/multichannel/facebook/facebook.js +47 -0
  54. package/lib/cjs/components/multichannel/facebook/facebook.js.map +1 -0
  55. package/lib/cjs/components/multichannel/index.d.ts +6 -0
  56. package/lib/cjs/components/multichannel/index.js +14 -0
  57. package/lib/cjs/components/multichannel/index.js.map +1 -0
  58. package/lib/cjs/components/multichannel/multichannel-button.d.ts +1 -0
  59. package/lib/cjs/components/multichannel/multichannel-button.js +76 -0
  60. package/lib/cjs/components/multichannel/multichannel-button.js.map +1 -0
  61. package/lib/cjs/components/multichannel/multichannel-carousel.d.ts +1 -0
  62. package/lib/cjs/components/multichannel/multichannel-carousel.js +78 -0
  63. package/lib/cjs/components/multichannel/multichannel-carousel.js.map +1 -0
  64. package/lib/cjs/components/multichannel/multichannel-context.d.ts +11 -0
  65. package/lib/cjs/components/multichannel/multichannel-context.js +16 -0
  66. package/lib/cjs/components/multichannel/multichannel-context.js.map +1 -0
  67. package/lib/cjs/components/multichannel/multichannel-reply.d.ts +1 -0
  68. package/lib/cjs/components/multichannel/multichannel-reply.js +25 -0
  69. package/lib/cjs/components/multichannel/multichannel-reply.js.map +1 -0
  70. package/lib/cjs/components/multichannel/multichannel-text.d.ts +1 -0
  71. package/lib/cjs/components/multichannel/multichannel-text.js +132 -0
  72. package/lib/cjs/components/multichannel/multichannel-text.js.map +1 -0
  73. package/lib/cjs/components/multichannel/multichannel-utils.d.ts +24 -0
  74. package/lib/cjs/components/multichannel/multichannel-utils.js +83 -0
  75. package/lib/cjs/components/multichannel/multichannel-utils.js.map +1 -0
  76. package/lib/cjs/components/multichannel/multichannel.d.ts +1 -0
  77. package/lib/cjs/components/multichannel/multichannel.js +60 -0
  78. package/lib/cjs/components/multichannel/multichannel.js.map +1 -0
  79. package/lib/cjs/components/pic.d.ts +6 -0
  80. package/lib/cjs/components/pic.js +30 -0
  81. package/lib/cjs/components/pic.js.map +1 -0
  82. package/lib/cjs/components/raw.d.ts +9 -0
  83. package/lib/cjs/components/raw.js +44 -0
  84. package/lib/cjs/components/raw.js.map +1 -0
  85. package/lib/cjs/components/reply.d.ts +9 -0
  86. package/lib/cjs/components/reply.js +54 -0
  87. package/lib/cjs/components/reply.js.map +1 -0
  88. package/lib/cjs/components/share-button.d.ts +1 -0
  89. package/lib/cjs/components/share-button.js +14 -0
  90. package/lib/cjs/components/share-button.js.map +1 -0
  91. package/lib/cjs/components/subtitle.d.ts +6 -0
  92. package/lib/cjs/components/subtitle.js +24 -0
  93. package/lib/cjs/components/subtitle.js.map +1 -0
  94. package/lib/cjs/components/text.d.ts +8 -0
  95. package/lib/cjs/components/text.js +47 -0
  96. package/lib/cjs/components/text.js.map +1 -0
  97. package/lib/cjs/components/timestamps.d.ts +10 -0
  98. package/lib/cjs/components/timestamps.js +51 -0
  99. package/lib/cjs/components/timestamps.js.map +1 -0
  100. package/lib/cjs/components/title.d.ts +6 -0
  101. package/lib/cjs/components/title.js +22 -0
  102. package/lib/cjs/components/title.js.map +1 -0
  103. package/lib/cjs/components/video.d.ts +8 -0
  104. package/lib/cjs/components/video.js +31 -0
  105. package/lib/cjs/components/video.js.map +1 -0
  106. package/lib/cjs/components/webchat-settings.d.ts +10 -0
  107. package/lib/cjs/components/webchat-settings.js +79 -0
  108. package/lib/cjs/components/webchat-settings.js.map +1 -0
  109. package/lib/cjs/components/whatsapp-template.d.ts +1 -0
  110. package/lib/cjs/components/whatsapp-template.js +25 -0
  111. package/lib/cjs/components/whatsapp-template.js.map +1 -0
  112. package/lib/cjs/constants.d.ts +168 -0
  113. package/lib/cjs/constants.js +190 -0
  114. package/lib/cjs/constants.js.map +1 -0
  115. package/lib/cjs/contexts.d.ts +69 -0
  116. package/lib/cjs/contexts.js +38 -0
  117. package/lib/cjs/contexts.js.map +1 -0
  118. package/lib/cjs/dev-app.d.ts +30 -0
  119. package/lib/cjs/dev-app.js +72 -0
  120. package/lib/cjs/dev-app.js.map +1 -0
  121. package/lib/cjs/index.d.ts +10 -0
  122. package/lib/cjs/index.js +28 -0
  123. package/lib/cjs/index.js.map +1 -0
  124. package/lib/cjs/message-utils.d.ts +19 -0
  125. package/lib/cjs/message-utils.js +61 -0
  126. package/lib/cjs/message-utils.js.map +1 -0
  127. package/lib/cjs/msg-to-botonic.d.ts +18 -0
  128. package/lib/cjs/msg-to-botonic.js +138 -0
  129. package/lib/cjs/msg-to-botonic.js.map +1 -0
  130. package/lib/cjs/node-app.d.ts +12 -0
  131. package/lib/cjs/node-app.js +25 -0
  132. package/lib/cjs/node-app.js.map +1 -0
  133. package/lib/cjs/react-bot.d.ts +8 -0
  134. package/lib/cjs/react-bot.js +34 -0
  135. package/lib/cjs/react-bot.js.map +1 -0
  136. package/lib/cjs/util/dom.d.ts +13 -0
  137. package/lib/cjs/util/dom.js +55 -0
  138. package/lib/cjs/util/dom.js.map +1 -0
  139. package/lib/cjs/util/environment.d.ts +6 -0
  140. package/lib/cjs/util/environment.js +68 -0
  141. package/lib/cjs/util/environment.js.map +1 -0
  142. package/lib/cjs/util/error-boundary.d.ts +7 -0
  143. package/lib/cjs/util/error-boundary.js +33 -0
  144. package/lib/cjs/util/error-boundary.js.map +1 -0
  145. package/lib/cjs/util/index.d.ts +0 -0
  146. package/lib/cjs/util/index.js +2 -0
  147. package/lib/cjs/util/index.js.map +1 -0
  148. package/lib/cjs/util/logs.d.ts +2 -0
  149. package/lib/cjs/util/logs.js +20 -0
  150. package/lib/cjs/util/logs.js.map +1 -0
  151. package/lib/cjs/util/objects.d.ts +3 -0
  152. package/lib/cjs/util/objects.js +44 -0
  153. package/lib/cjs/util/objects.js.map +1 -0
  154. package/lib/cjs/util/react.d.ts +12 -0
  155. package/lib/cjs/util/react.js +42 -0
  156. package/lib/cjs/util/react.js.map +1 -0
  157. package/lib/cjs/util/regexs.d.ts +2 -0
  158. package/lib/cjs/util/regexs.js +23 -0
  159. package/lib/cjs/util/regexs.js.map +1 -0
  160. package/lib/cjs/util/webchat.d.ts +11 -0
  161. package/lib/cjs/util/webchat.js +62 -0
  162. package/lib/cjs/util/webchat.js.map +1 -0
  163. package/lib/cjs/webchat/actions.d.ts +23 -0
  164. package/lib/cjs/webchat/actions.js +27 -0
  165. package/lib/cjs/webchat/actions.js.map +1 -0
  166. package/lib/cjs/webchat/components/attachment.d.ts +5 -0
  167. package/lib/cjs/webchat/components/attachment.js +29 -0
  168. package/lib/cjs/webchat/components/attachment.js.map +1 -0
  169. package/lib/cjs/webchat/components/common.d.ts +1 -0
  170. package/lib/cjs/webchat/components/common.js +14 -0
  171. package/lib/cjs/webchat/components/common.js.map +1 -0
  172. package/lib/cjs/webchat/components/conditional-animation.d.ts +1 -0
  173. package/lib/cjs/webchat/components/conditional-animation.js +17 -0
  174. package/lib/cjs/webchat/components/conditional-animation.js.map +1 -0
  175. package/lib/cjs/webchat/components/emoji-picker.d.ts +5 -0
  176. package/lib/cjs/webchat/components/emoji-picker.js +43 -0
  177. package/lib/cjs/webchat/components/emoji-picker.js.map +1 -0
  178. package/lib/cjs/webchat/components/persistent-menu.d.ts +10 -0
  179. package/lib/cjs/webchat/components/persistent-menu.js +45 -0
  180. package/lib/cjs/webchat/components/persistent-menu.js.map +1 -0
  181. package/lib/cjs/webchat/components/send-button.d.ts +3 -0
  182. package/lib/cjs/webchat/components/send-button.js +19 -0
  183. package/lib/cjs/webchat/components/send-button.js.map +1 -0
  184. package/lib/cjs/webchat/components/styled-scrollbar.d.ts +1 -0
  185. package/lib/cjs/webchat/components/styled-scrollbar.js +54 -0
  186. package/lib/cjs/webchat/components/styled-scrollbar.js.map +1 -0
  187. package/lib/cjs/webchat/components/typing-indicator.d.ts +1 -0
  188. package/lib/cjs/webchat/components/typing-indicator.js +11 -0
  189. package/lib/cjs/webchat/components/typing-indicator.js.map +1 -0
  190. package/lib/cjs/webchat/devices/device-adapter.d.ts +12 -0
  191. package/lib/cjs/webchat/devices/device-adapter.js +47 -0
  192. package/lib/cjs/webchat/devices/device-adapter.js.map +1 -0
  193. package/lib/cjs/webchat/devices/index.d.ts +11 -0
  194. package/lib/cjs/webchat/devices/index.js +23 -0
  195. package/lib/cjs/webchat/devices/index.js.map +1 -0
  196. package/lib/cjs/webchat/devices/scrollbar-controller.d.ts +12 -0
  197. package/lib/cjs/webchat/devices/scrollbar-controller.js +103 -0
  198. package/lib/cjs/webchat/devices/scrollbar-controller.js.map +1 -0
  199. package/lib/cjs/webchat/devices/webchat-resizer.d.ts +9 -0
  200. package/lib/cjs/webchat/devices/webchat-resizer.js +47 -0
  201. package/lib/cjs/webchat/devices/webchat-resizer.js.map +1 -0
  202. package/lib/cjs/webchat/header.d.ts +3 -0
  203. package/lib/cjs/webchat/header.js +85 -0
  204. package/lib/cjs/webchat/header.js.map +1 -0
  205. package/lib/cjs/webchat/hooks.d.ts +80 -0
  206. package/lib/cjs/webchat/hooks.js +219 -0
  207. package/lib/cjs/webchat/hooks.js.map +1 -0
  208. package/lib/cjs/webchat/index.d.ts +6 -0
  209. package/lib/cjs/webchat/index.js +17 -0
  210. package/lib/cjs/webchat/index.js.map +1 -0
  211. package/lib/cjs/webchat/message-list.d.ts +1 -0
  212. package/lib/cjs/webchat/message-list.js +39 -0
  213. package/lib/cjs/webchat/message-list.js.map +1 -0
  214. package/lib/cjs/webchat/messages-reducer.d.ts +1 -0
  215. package/lib/cjs/webchat/messages-reducer.js +58 -0
  216. package/lib/cjs/webchat/messages-reducer.js.map +1 -0
  217. package/lib/cjs/webchat/replies.d.ts +1 -0
  218. package/lib/cjs/webchat/replies.js +43 -0
  219. package/lib/cjs/webchat/replies.js.map +1 -0
  220. package/lib/cjs/webchat/session-view.d.ts +1 -0
  221. package/lib/cjs/webchat/session-view.js +101 -0
  222. package/lib/cjs/webchat/session-view.js.map +1 -0
  223. package/lib/cjs/webchat/use-storage-state-hook.d.ts +1 -0
  224. package/lib/cjs/webchat/use-storage-state-hook.js +42 -0
  225. package/lib/cjs/webchat/use-storage-state-hook.js.map +1 -0
  226. package/lib/cjs/webchat/webchat-dev.d.ts +7 -0
  227. package/lib/cjs/webchat/webchat-dev.js +60 -0
  228. package/lib/cjs/webchat/webchat-dev.js.map +1 -0
  229. package/lib/cjs/webchat/webchat-reducer.d.ts +1 -0
  230. package/lib/cjs/webchat/webchat-reducer.js +48 -0
  231. package/lib/cjs/webchat/webchat-reducer.js.map +1 -0
  232. package/lib/cjs/webchat/webchat.d.ts +3 -0
  233. package/lib/cjs/webchat/webchat.js +661 -0
  234. package/lib/cjs/webchat/webchat.js.map +1 -0
  235. package/lib/cjs/webchat/webview.d.ts +2 -0
  236. package/lib/cjs/webchat/webview.js +84 -0
  237. package/lib/cjs/webchat/webview.js.map +1 -0
  238. package/lib/cjs/webchat-app.d.ts +99 -0
  239. package/lib/cjs/webchat-app.js +270 -0
  240. package/lib/cjs/webchat-app.js.map +1 -0
  241. package/lib/cjs/webview-app.d.ts +7 -0
  242. package/lib/cjs/webview-app.js +102 -0
  243. package/lib/cjs/webview-app.js.map +1 -0
  244. package/lib/esm/app.d.ts +2 -0
  245. package/lib/esm/app.js +6 -0
  246. package/lib/esm/app.js.map +1 -0
  247. package/lib/esm/assets/attachment-icon.svg +7 -0
  248. package/lib/esm/assets/audio.svg +4 -0
  249. package/lib/esm/assets/botonic_react_logo100x100.png +0 -0
  250. package/lib/esm/assets/document.svg +3 -0
  251. package/lib/esm/assets/emojiButton.svg +6 -0
  252. package/lib/esm/assets/image.svg +4 -0
  253. package/lib/esm/assets/leftArrow.svg +3 -0
  254. package/lib/esm/assets/menuButton.svg +3 -0
  255. package/lib/esm/assets/rightArrow.svg +3 -0
  256. package/lib/esm/assets/send-button.svg +1 -0
  257. package/lib/esm/assets/video.svg +3 -0
  258. package/lib/esm/botonic-tester.d.ts +18 -0
  259. package/lib/esm/botonic-tester.js +62 -0
  260. package/lib/esm/botonic-tester.js.map +1 -0
  261. package/lib/esm/components/audio.d.ts +8 -0
  262. package/lib/esm/components/audio.js +18 -0
  263. package/lib/esm/components/audio.js.map +1 -0
  264. package/lib/esm/components/button.d.ts +15 -0
  265. package/lib/esm/components/button.js +140 -0
  266. package/lib/esm/components/button.js.map +1 -0
  267. package/lib/esm/components/buttons-disabler.d.ts +24 -0
  268. package/lib/esm/components/buttons-disabler.js +84 -0
  269. package/lib/esm/components/buttons-disabler.js.map +1 -0
  270. package/lib/esm/components/carousel.d.ts +9 -0
  271. package/lib/esm/components/carousel.js +102 -0
  272. package/lib/esm/components/carousel.js.map +1 -0
  273. package/lib/esm/components/components.d.ts +12 -0
  274. package/lib/esm/components/components.js +17 -0
  275. package/lib/esm/components/components.js.map +1 -0
  276. package/lib/esm/components/custom-message.d.ts +12 -0
  277. package/lib/esm/components/custom-message.js +55 -0
  278. package/lib/esm/components/custom-message.js.map +1 -0
  279. package/lib/esm/components/document.d.ts +8 -0
  280. package/lib/esm/components/document.js +42 -0
  281. package/lib/esm/components/document.js.map +1 -0
  282. package/lib/esm/components/element.d.ts +4 -0
  283. package/lib/esm/components/element.js +51 -0
  284. package/lib/esm/components/element.js.map +1 -0
  285. package/lib/esm/components/handoff.d.ts +1 -0
  286. package/lib/esm/components/handoff.js +49 -0
  287. package/lib/esm/components/handoff.js.map +1 -0
  288. package/lib/esm/components/image.d.ts +8 -0
  289. package/lib/esm/components/image.js +33 -0
  290. package/lib/esm/components/image.js.map +1 -0
  291. package/lib/esm/components/index.d.ts +19 -0
  292. package/lib/esm/components/index.js +21 -0
  293. package/lib/esm/components/index.js.map +1 -0
  294. package/lib/esm/components/location.d.ts +11 -0
  295. package/lib/esm/components/location.js +27 -0
  296. package/lib/esm/components/location.js.map +1 -0
  297. package/lib/esm/components/markdown.d.ts +7 -0
  298. package/lib/esm/components/markdown.js +152 -0
  299. package/lib/esm/components/markdown.js.map +1 -0
  300. package/lib/esm/components/message-template.d.ts +1 -0
  301. package/lib/esm/components/message-template.js +9 -0
  302. package/lib/esm/components/message-template.js.map +1 -0
  303. package/lib/esm/components/message.d.ts +1 -0
  304. package/lib/esm/components/message.js +184 -0
  305. package/lib/esm/components/message.js.map +1 -0
  306. package/lib/esm/components/multichannel/facebook/facebook.d.ts +17 -0
  307. package/lib/esm/components/multichannel/facebook/facebook.js +43 -0
  308. package/lib/esm/components/multichannel/facebook/facebook.js.map +1 -0
  309. package/lib/esm/components/multichannel/index.d.ts +6 -0
  310. package/lib/esm/components/multichannel/index.js +11 -0
  311. package/lib/esm/components/multichannel/index.js.map +1 -0
  312. package/lib/esm/components/multichannel/multichannel-button.d.ts +1 -0
  313. package/lib/esm/components/multichannel/multichannel-button.js +71 -0
  314. package/lib/esm/components/multichannel/multichannel-button.js.map +1 -0
  315. package/lib/esm/components/multichannel/multichannel-carousel.d.ts +1 -0
  316. package/lib/esm/components/multichannel/multichannel-carousel.js +73 -0
  317. package/lib/esm/components/multichannel/multichannel-carousel.js.map +1 -0
  318. package/lib/esm/components/multichannel/multichannel-context.d.ts +11 -0
  319. package/lib/esm/components/multichannel/multichannel-context.js +12 -0
  320. package/lib/esm/components/multichannel/multichannel-context.js.map +1 -0
  321. package/lib/esm/components/multichannel/multichannel-reply.d.ts +1 -0
  322. package/lib/esm/components/multichannel/multichannel-reply.js +20 -0
  323. package/lib/esm/components/multichannel/multichannel-reply.js.map +1 -0
  324. package/lib/esm/components/multichannel/multichannel-text.d.ts +1 -0
  325. package/lib/esm/components/multichannel/multichannel-text.js +127 -0
  326. package/lib/esm/components/multichannel/multichannel-text.js.map +1 -0
  327. package/lib/esm/components/multichannel/multichannel-utils.d.ts +24 -0
  328. package/lib/esm/components/multichannel/multichannel-utils.js +67 -0
  329. package/lib/esm/components/multichannel/multichannel-utils.js.map +1 -0
  330. package/lib/esm/components/multichannel/multichannel.d.ts +1 -0
  331. package/lib/esm/components/multichannel/multichannel.js +55 -0
  332. package/lib/esm/components/multichannel/multichannel.js.map +1 -0
  333. package/lib/esm/components/pic.d.ts +6 -0
  334. package/lib/esm/components/pic.js +25 -0
  335. package/lib/esm/components/pic.js.map +1 -0
  336. package/lib/esm/components/raw.d.ts +9 -0
  337. package/lib/esm/components/raw.js +39 -0
  338. package/lib/esm/components/raw.js.map +1 -0
  339. package/lib/esm/components/reply.d.ts +9 -0
  340. package/lib/esm/components/reply.js +49 -0
  341. package/lib/esm/components/reply.js.map +1 -0
  342. package/lib/esm/components/share-button.d.ts +1 -0
  343. package/lib/esm/components/share-button.js +9 -0
  344. package/lib/esm/components/share-button.js.map +1 -0
  345. package/lib/esm/components/subtitle.d.ts +6 -0
  346. package/lib/esm/components/subtitle.js +19 -0
  347. package/lib/esm/components/subtitle.js.map +1 -0
  348. package/lib/esm/components/text.d.ts +8 -0
  349. package/lib/esm/components/text.js +42 -0
  350. package/lib/esm/components/text.js.map +1 -0
  351. package/lib/esm/components/timestamps.d.ts +10 -0
  352. package/lib/esm/components/timestamps.js +45 -0
  353. package/lib/esm/components/timestamps.js.map +1 -0
  354. package/lib/esm/components/title.d.ts +6 -0
  355. package/lib/esm/components/title.js +17 -0
  356. package/lib/esm/components/title.js.map +1 -0
  357. package/lib/esm/components/video.d.ts +8 -0
  358. package/lib/esm/components/video.js +26 -0
  359. package/lib/esm/components/video.js.map +1 -0
  360. package/lib/esm/components/webchat-settings.d.ts +10 -0
  361. package/lib/esm/components/webchat-settings.js +73 -0
  362. package/lib/esm/components/webchat-settings.js.map +1 -0
  363. package/lib/esm/components/whatsapp-template.d.ts +1 -0
  364. package/lib/esm/components/whatsapp-template.js +20 -0
  365. package/lib/esm/components/whatsapp-template.js.map +1 -0
  366. package/lib/esm/constants.d.ts +168 -0
  367. package/lib/esm/constants.js +186 -0
  368. package/lib/esm/constants.js.map +1 -0
  369. package/lib/esm/contexts.d.ts +69 -0
  370. package/lib/esm/contexts.js +34 -0
  371. package/lib/esm/contexts.js.map +1 -0
  372. package/lib/esm/dev-app.d.ts +30 -0
  373. package/lib/esm/dev-app.js +68 -0
  374. package/lib/esm/dev-app.js.map +1 -0
  375. package/lib/esm/index.d.ts +9 -0
  376. package/lib/esm/index.js +11 -0
  377. package/lib/esm/index.js.map +1 -0
  378. package/lib/esm/message-utils.d.ts +18 -0
  379. package/lib/esm/message-utils.js +41 -0
  380. package/lib/esm/message-utils.js.map +1 -0
  381. package/lib/esm/msg-to-botonic.d.ts +18 -0
  382. package/lib/esm/msg-to-botonic.js +132 -0
  383. package/lib/esm/msg-to-botonic.js.map +1 -0
  384. package/lib/esm/node-app.d.ts +12 -0
  385. package/lib/esm/node-app.js +21 -0
  386. package/lib/esm/node-app.js.map +1 -0
  387. package/lib/esm/react-bot.d.ts +7 -0
  388. package/lib/esm/react-bot.js +29 -0
  389. package/lib/esm/react-bot.js.map +1 -0
  390. package/lib/esm/util/dom.d.ts +13 -0
  391. package/lib/esm/util/dom.js +46 -0
  392. package/lib/esm/util/dom.js.map +1 -0
  393. package/lib/esm/util/environment.d.ts +6 -0
  394. package/lib/esm/util/environment.js +61 -0
  395. package/lib/esm/util/environment.js.map +1 -0
  396. package/lib/esm/util/error-boundary.d.ts +7 -0
  397. package/lib/esm/util/error-boundary.js +28 -0
  398. package/lib/esm/util/error-boundary.js.map +1 -0
  399. package/lib/esm/util/index.d.ts +0 -0
  400. package/lib/esm/util/index.js +2 -0
  401. package/lib/esm/util/index.js.map +1 -0
  402. package/lib/esm/util/logs.d.ts +2 -0
  403. package/lib/esm/util/logs.js +15 -0
  404. package/lib/esm/util/logs.js.map +1 -0
  405. package/lib/esm/util/objects.d.ts +3 -0
  406. package/lib/esm/util/objects.js +38 -0
  407. package/lib/esm/util/objects.js.map +1 -0
  408. package/lib/esm/util/react.d.ts +12 -0
  409. package/lib/esm/util/react.js +34 -0
  410. package/lib/esm/util/react.js.map +1 -0
  411. package/lib/esm/util/regexs.d.ts +2 -0
  412. package/lib/esm/util/regexs.js +18 -0
  413. package/lib/esm/util/regexs.js.map +1 -0
  414. package/lib/esm/util/webchat.d.ts +11 -0
  415. package/lib/esm/util/webchat.js +53 -0
  416. package/lib/esm/util/webchat.js.map +1 -0
  417. package/lib/esm/webchat/actions.d.ts +23 -0
  418. package/lib/esm/webchat/actions.js +24 -0
  419. package/lib/esm/webchat/actions.js.map +1 -0
  420. package/lib/esm/webchat/components/attachment.d.ts +5 -0
  421. package/lib/esm/webchat/components/attachment.js +24 -0
  422. package/lib/esm/webchat/components/attachment.js.map +1 -0
  423. package/lib/esm/webchat/components/common.d.ts +1 -0
  424. package/lib/esm/webchat/components/common.js +9 -0
  425. package/lib/esm/webchat/components/common.js.map +1 -0
  426. package/lib/esm/webchat/components/conditional-animation.d.ts +1 -0
  427. package/lib/esm/webchat/components/conditional-animation.js +12 -0
  428. package/lib/esm/webchat/components/conditional-animation.js.map +1 -0
  429. package/lib/esm/webchat/components/emoji-picker.d.ts +5 -0
  430. package/lib/esm/webchat/components/emoji-picker.js +37 -0
  431. package/lib/esm/webchat/components/emoji-picker.js.map +1 -0
  432. package/lib/esm/webchat/components/persistent-menu.d.ts +10 -0
  433. package/lib/esm/webchat/components/persistent-menu.js +39 -0
  434. package/lib/esm/webchat/components/persistent-menu.js.map +1 -0
  435. package/lib/esm/webchat/components/send-button.d.ts +3 -0
  436. package/lib/esm/webchat/components/send-button.js +14 -0
  437. package/lib/esm/webchat/components/send-button.js.map +1 -0
  438. package/lib/esm/webchat/components/styled-scrollbar.d.ts +1 -0
  439. package/lib/esm/webchat/components/styled-scrollbar.js +50 -0
  440. package/lib/esm/webchat/components/styled-scrollbar.js.map +1 -0
  441. package/lib/esm/webchat/components/styled-scrollbar.scss +12 -0
  442. package/lib/esm/webchat/components/typing-indicator.d.ts +1 -0
  443. package/lib/esm/webchat/components/typing-indicator.js +6 -0
  444. package/lib/esm/webchat/components/typing-indicator.js.map +1 -0
  445. package/lib/esm/webchat/components/typing-indicator.scss +38 -0
  446. package/lib/esm/webchat/devices/device-adapter.d.ts +12 -0
  447. package/lib/esm/webchat/devices/device-adapter.js +43 -0
  448. package/lib/esm/webchat/devices/device-adapter.js.map +1 -0
  449. package/lib/esm/webchat/devices/index.d.ts +11 -0
  450. package/lib/esm/webchat/devices/index.js +18 -0
  451. package/lib/esm/webchat/devices/index.js.map +1 -0
  452. package/lib/esm/webchat/devices/scrollbar-controller.d.ts +12 -0
  453. package/lib/esm/webchat/devices/scrollbar-controller.js +99 -0
  454. package/lib/esm/webchat/devices/scrollbar-controller.js.map +1 -0
  455. package/lib/esm/webchat/devices/webchat-resizer.d.ts +9 -0
  456. package/lib/esm/webchat/devices/webchat-resizer.js +43 -0
  457. package/lib/esm/webchat/devices/webchat-resizer.js.map +1 -0
  458. package/lib/esm/webchat/header.d.ts +3 -0
  459. package/lib/esm/webchat/header.js +79 -0
  460. package/lib/esm/webchat/header.js.map +1 -0
  461. package/lib/esm/webchat/hooks.d.ts +80 -0
  462. package/lib/esm/webchat/hooks.js +211 -0
  463. package/lib/esm/webchat/hooks.js.map +1 -0
  464. package/lib/esm/webchat/index.d.ts +6 -0
  465. package/lib/esm/webchat/index.js +11 -0
  466. package/lib/esm/webchat/index.js.map +1 -0
  467. package/lib/esm/webchat/message-list.d.ts +1 -0
  468. package/lib/esm/webchat/message-list.js +34 -0
  469. package/lib/esm/webchat/message-list.js.map +1 -0
  470. package/lib/esm/webchat/messages-reducer.d.ts +1 -0
  471. package/lib/esm/webchat/messages-reducer.js +54 -0
  472. package/lib/esm/webchat/messages-reducer.js.map +1 -0
  473. package/lib/esm/webchat/replies.d.ts +1 -0
  474. package/lib/esm/webchat/replies.js +38 -0
  475. package/lib/esm/webchat/replies.js.map +1 -0
  476. package/lib/esm/webchat/session-view.d.ts +1 -0
  477. package/lib/esm/webchat/session-view.js +96 -0
  478. package/lib/esm/webchat/session-view.js.map +1 -0
  479. package/lib/esm/webchat/use-storage-state-hook.d.ts +1 -0
  480. package/lib/esm/webchat/use-storage-state-hook.js +38 -0
  481. package/lib/esm/webchat/use-storage-state-hook.js.map +1 -0
  482. package/lib/esm/webchat/webchat-dev.d.ts +7 -0
  483. package/lib/esm/webchat/webchat-dev.js +56 -0
  484. package/lib/esm/webchat/webchat-dev.js.map +1 -0
  485. package/lib/esm/webchat/webchat-reducer.d.ts +1 -0
  486. package/lib/esm/webchat/webchat-reducer.js +44 -0
  487. package/lib/esm/webchat/webchat-reducer.js.map +1 -0
  488. package/lib/esm/webchat/webchat.d.ts +3 -0
  489. package/lib/esm/webchat/webchat.js +656 -0
  490. package/lib/esm/webchat/webchat.js.map +1 -0
  491. package/lib/esm/webchat/webview.d.ts +2 -0
  492. package/lib/esm/webchat/webview.js +78 -0
  493. package/lib/esm/webchat/webview.js.map +1 -0
  494. package/lib/esm/webchat-app.d.ts +98 -0
  495. package/lib/esm/webchat-app.js +266 -0
  496. package/lib/esm/webchat-app.js.map +1 -0
  497. package/lib/esm/webchat.template.html +37 -0
  498. package/lib/esm/webview-app.d.ts +7 -0
  499. package/lib/esm/webview-app.js +97 -0
  500. package/lib/esm/webview-app.js.map +1 -0
  501. package/lib/esm/webview.template.html +39 -0
  502. package/package.json +40 -27
  503. package/src/components/audio.jsx +2 -0
  504. package/src/components/document.jsx +2 -0
  505. package/src/components/image.jsx +2 -0
  506. package/src/components/location.jsx +2 -2
  507. package/src/components/message.jsx +4 -11
  508. package/src/components/multichannel/multichannel-text.jsx +2 -5
  509. package/src/components/pic.jsx +3 -1
  510. package/src/components/video.jsx +2 -0
  511. package/src/index.js +1 -1
  512. package/src/msg-to-botonic.jsx +11 -11
  513. package/src/util/environment.js +31 -2
  514. package/src/util/error-boundary.jsx +15 -30
  515. package/src/util/webchat.js +12 -13
  516. package/src/webchat/components/attachment.jsx +10 -2
  517. package/src/webchat/components/emoji-picker.jsx +7 -1
  518. package/src/webchat/hooks.js +2 -1
  519. package/src/webchat/use-storage-state-hook.js +13 -2
  520. package/src/webchat/webchat.jsx +5 -7
  521. package/src/{webview.jsx → webview-app.tsx} +7 -1
  522. package/lib/app.js +0 -19
  523. package/lib/app.js.map +0 -1
  524. package/lib/botonic-tester.js +0 -224
  525. package/lib/botonic-tester.js.map +0 -1
  526. package/lib/components/audio.js +0 -48
  527. package/lib/components/audio.js.map +0 -1
  528. package/lib/components/button.js +0 -224
  529. package/lib/components/button.js.map +0 -1
  530. package/lib/components/buttons-disabler.js +0 -133
  531. package/lib/components/buttons-disabler.js.map +0 -1
  532. package/lib/components/carousel.js +0 -194
  533. package/lib/components/carousel.js.map +0 -1
  534. package/lib/components/components.js.map +0 -1
  535. package/lib/components/custom-message.js +0 -131
  536. package/lib/components/custom-message.js.map +0 -1
  537. package/lib/components/document.js +0 -76
  538. package/lib/components/document.js.map +0 -1
  539. package/lib/components/element.js +0 -69
  540. package/lib/components/element.js.map +0 -1
  541. package/lib/components/handoff.js +0 -69
  542. package/lib/components/handoff.js.map +0 -1
  543. package/lib/components/image.js +0 -91
  544. package/lib/components/image.js.map +0 -1
  545. package/lib/components/index.d.ts +0 -228
  546. package/lib/components/index.js +0 -193
  547. package/lib/components/index.js.map +0 -1
  548. package/lib/components/location.js +0 -69
  549. package/lib/components/location.js.map +0 -1
  550. package/lib/components/markdown.js +0 -108
  551. package/lib/components/markdown.js.map +0 -1
  552. package/lib/components/message-template.js +0 -36
  553. package/lib/components/message-template.js.map +0 -1
  554. package/lib/components/message.js +0 -351
  555. package/lib/components/message.js.map +0 -1
  556. package/lib/components/multichannel/facebook/facebook.js +0 -96
  557. package/lib/components/multichannel/facebook/facebook.js.map +0 -1
  558. package/lib/components/multichannel/index.d.ts +0 -65
  559. package/lib/components/multichannel/index.js +0 -46
  560. package/lib/components/multichannel/index.js.map +0 -1
  561. package/lib/components/multichannel/multichannel-button.js +0 -119
  562. package/lib/components/multichannel/multichannel-button.js.map +0 -1
  563. package/lib/components/multichannel/multichannel-carousel.js +0 -143
  564. package/lib/components/multichannel/multichannel-carousel.js.map +0 -1
  565. package/lib/components/multichannel/multichannel-context.js +0 -24
  566. package/lib/components/multichannel/multichannel-context.js.map +0 -1
  567. package/lib/components/multichannel/multichannel-reply.js +0 -46
  568. package/lib/components/multichannel/multichannel-reply.js.map +0 -1
  569. package/lib/components/multichannel/multichannel-text.js +0 -222
  570. package/lib/components/multichannel/multichannel-text.js.map +0 -1
  571. package/lib/components/multichannel/multichannel-utils.js +0 -126
  572. package/lib/components/multichannel/multichannel-utils.js.map +0 -1
  573. package/lib/components/multichannel/multichannel.js +0 -111
  574. package/lib/components/multichannel/multichannel.js.map +0 -1
  575. package/lib/components/pic.js +0 -50
  576. package/lib/components/pic.js.map +0 -1
  577. package/lib/components/raw.js +0 -70
  578. package/lib/components/raw.js.map +0 -1
  579. package/lib/components/reply.js +0 -107
  580. package/lib/components/reply.js.map +0 -1
  581. package/lib/components/share-button.js +0 -36
  582. package/lib/components/share-button.js.map +0 -1
  583. package/lib/components/subtitle.js +0 -54
  584. package/lib/components/subtitle.js.map +0 -1
  585. package/lib/components/text.js +0 -80
  586. package/lib/components/text.js.map +0 -1
  587. package/lib/components/timestamps.js +0 -69
  588. package/lib/components/timestamps.js.map +0 -1
  589. package/lib/components/title.js +0 -52
  590. package/lib/components/title.js.map +0 -1
  591. package/lib/components/video.js +0 -51
  592. package/lib/components/video.js.map +0 -1
  593. package/lib/components/webchat-settings.js +0 -118
  594. package/lib/components/webchat-settings.js.map +0 -1
  595. package/lib/components/whatsapp-template.js +0 -53
  596. package/lib/components/whatsapp-template.js.map +0 -1
  597. package/lib/constants.js +0 -203
  598. package/lib/constants.js.map +0 -1
  599. package/lib/contexts.js +0 -57
  600. package/lib/contexts.js.map +0 -1
  601. package/lib/dev-app.js +0 -241
  602. package/lib/dev-app.js.map +0 -1
  603. package/lib/index.d.ts +0 -238
  604. package/lib/index.js +0 -131
  605. package/lib/index.js.map +0 -1
  606. package/lib/message-utils.js +0 -149
  607. package/lib/message-utils.js.map +0 -1
  608. package/lib/msg-to-botonic.js +0 -199
  609. package/lib/msg-to-botonic.js.map +0 -1
  610. package/lib/node-app.js +0 -97
  611. package/lib/node-app.js.map +0 -1
  612. package/lib/react-bot.js +0 -167
  613. package/lib/react-bot.js.map +0 -1
  614. package/lib/util/dom.js +0 -84
  615. package/lib/util/dom.js.map +0 -1
  616. package/lib/util/environment.js +0 -42
  617. package/lib/util/environment.js.map +0 -1
  618. package/lib/util/error-boundary.js +0 -105
  619. package/lib/util/error-boundary.js.map +0 -1
  620. package/lib/util/index.d.ts +0 -9
  621. package/lib/util/index.js +0 -2
  622. package/lib/util/index.js.map +0 -1
  623. package/lib/util/logs.js +0 -28
  624. package/lib/util/logs.js.map +0 -1
  625. package/lib/util/objects.js +0 -60
  626. package/lib/util/objects.js.map +0 -1
  627. package/lib/util/react.js +0 -75
  628. package/lib/util/react.js.map +0 -1
  629. package/lib/util/regexs.js +0 -31
  630. package/lib/util/regexs.js.map +0 -1
  631. package/lib/util/webchat.js +0 -92
  632. package/lib/util/webchat.js.map +0 -1
  633. package/lib/webchat/actions.js +0 -53
  634. package/lib/webchat/actions.js.map +0 -1
  635. package/lib/webchat/components/attachment.js +0 -68
  636. package/lib/webchat/components/attachment.js.map +0 -1
  637. package/lib/webchat/components/common.js +0 -29
  638. package/lib/webchat/components/common.js.map +0 -1
  639. package/lib/webchat/components/conditional-animation.js +0 -42
  640. package/lib/webchat/components/conditional-animation.js.map +0 -1
  641. package/lib/webchat/components/emoji-picker.js +0 -89
  642. package/lib/webchat/components/emoji-picker.js.map +0 -1
  643. package/lib/webchat/components/persistent-menu.js +0 -104
  644. package/lib/webchat/components/persistent-menu.js.map +0 -1
  645. package/lib/webchat/components/send-button.js +0 -45
  646. package/lib/webchat/components/send-button.js.map +0 -1
  647. package/lib/webchat/components/styled-scrollbar.js +0 -55
  648. package/lib/webchat/components/styled-scrollbar.js.map +0 -1
  649. package/lib/webchat/components/typing-indicator.js +0 -27
  650. package/lib/webchat/components/typing-indicator.js.map +0 -1
  651. package/lib/webchat/devices/device-adapter.js +0 -82
  652. package/lib/webchat/devices/device-adapter.js.map +0 -1
  653. package/lib/webchat/devices/index.js +0 -32
  654. package/lib/webchat/devices/index.js.map +0 -1
  655. package/lib/webchat/devices/scrollbar-controller.js +0 -152
  656. package/lib/webchat/devices/scrollbar-controller.js.map +0 -1
  657. package/lib/webchat/devices/webchat-resizer.js +0 -76
  658. package/lib/webchat/devices/webchat-resizer.js.map +0 -1
  659. package/lib/webchat/header.js +0 -116
  660. package/lib/webchat/header.js.map +0 -1
  661. package/lib/webchat/hooks.js +0 -359
  662. package/lib/webchat/hooks.js.map +0 -1
  663. package/lib/webchat/index.d.ts +0 -62
  664. package/lib/webchat/index.js +0 -32
  665. package/lib/webchat/index.js.map +0 -1
  666. package/lib/webchat/message-list.js +0 -88
  667. package/lib/webchat/message-list.js.map +0 -1
  668. package/lib/webchat/messages-reducer.js +0 -93
  669. package/lib/webchat/messages-reducer.js.map +0 -1
  670. package/lib/webchat/replies.js +0 -78
  671. package/lib/webchat/replies.js.map +0 -1
  672. package/lib/webchat/session-view.js +0 -106
  673. package/lib/webchat/session-view.js.map +0 -1
  674. package/lib/webchat/use-storage-state-hook.js +0 -60
  675. package/lib/webchat/use-storage-state-hook.js.map +0 -1
  676. package/lib/webchat/webchat-dev.js +0 -109
  677. package/lib/webchat/webchat-dev.js.map +0 -1
  678. package/lib/webchat/webchat-reducer.js +0 -108
  679. package/lib/webchat/webchat-reducer.js.map +0 -1
  680. package/lib/webchat/webchat.js +0 -1108
  681. package/lib/webchat/webchat.js.map +0 -1
  682. package/lib/webchat/webview.js +0 -122
  683. package/lib/webchat/webview.js.map +0 -1
  684. package/lib/webchat-app.js +0 -660
  685. package/lib/webchat-app.js.map +0 -1
  686. package/lib/webview.js +0 -231
  687. package/lib/webview.js.map +0 -1
  688. /package/lib/{assets → cjs/assets}/attachment-icon.svg +0 -0
  689. /package/lib/{assets → cjs/assets}/audio.svg +0 -0
  690. /package/lib/{assets → cjs/assets}/botonic_react_logo100x100.png +0 -0
  691. /package/lib/{assets → cjs/assets}/document.svg +0 -0
  692. /package/lib/{assets → cjs/assets}/emojiButton.svg +0 -0
  693. /package/lib/{assets → cjs/assets}/image.svg +0 -0
  694. /package/lib/{assets → cjs/assets}/leftArrow.svg +0 -0
  695. /package/lib/{assets → cjs/assets}/menuButton.svg +0 -0
  696. /package/lib/{assets → cjs/assets}/rightArrow.svg +0 -0
  697. /package/lib/{assets → cjs/assets}/send-button.svg +0 -0
  698. /package/lib/{assets → cjs/assets}/video.svg +0 -0
  699. /package/lib/{webchat → cjs/webchat}/components/styled-scrollbar.scss +0 -0
  700. /package/lib/{webchat → cjs/webchat}/components/typing-indicator.scss +0 -0
  701. /package/lib/{webchat.template.html → cjs/webchat.template.html} +0 -0
  702. /package/lib/{webview.template.html → cjs/webview.template.html} +0 -0
@@ -0,0 +1,661 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Webchat = exports.getParsedAction = 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 = tslib_1.__importStar(require("react"));
9
+ const react_textarea_autosize_1 = tslib_1.__importDefault(require("react-textarea-autosize"));
10
+ const styled_components_1 = tslib_1.__importStar(require("styled-components"));
11
+ const use_async_effect_1 = require("use-async-effect");
12
+ const uuid_1 = require("uuid");
13
+ const components_1 = require("../components");
14
+ const handoff_1 = require("../components/handoff");
15
+ const webchat_settings_1 = require("../components/webchat-settings");
16
+ const constants_1 = require("../constants");
17
+ const contexts_1 = require("../contexts");
18
+ const message_utils_1 = require("../message-utils");
19
+ const msg_to_botonic_1 = require("../msg-to-botonic");
20
+ const dom_1 = require("../util/dom");
21
+ const environment_1 = require("../util/environment");
22
+ const regexs_1 = require("../util/regexs");
23
+ const webchat_1 = require("../util/webchat");
24
+ const attachment_1 = require("./components/attachment");
25
+ const emoji_picker_1 = require("./components/emoji-picker");
26
+ const persistent_menu_1 = require("./components/persistent-menu");
27
+ const send_button_1 = require("./components/send-button");
28
+ const typing_indicator_1 = require("./components/typing-indicator");
29
+ const device_adapter_1 = require("./devices/device-adapter");
30
+ const header_1 = require("./header");
31
+ const hooks_1 = require("./hooks");
32
+ const message_list_1 = require("./message-list");
33
+ const replies_1 = require("./replies");
34
+ const use_storage_state_hook_1 = require("./use-storage-state-hook");
35
+ const webview_1 = require("./webview");
36
+ const getParsedAction = botonicAction => {
37
+ const splittedAction = botonicAction.split('create_case:');
38
+ if (splittedAction.length <= 1)
39
+ return undefined;
40
+ return JSON.parse(splittedAction[1]);
41
+ };
42
+ exports.getParsedAction = getParsedAction;
43
+ const StyledWebchat = styled_components_1.default.div `
44
+ position: fixed;
45
+ right: 20px;
46
+ bottom: 20px;
47
+ width: ${props => props.width}px;
48
+ height: ${props => props.height}px;
49
+ margin: auto;
50
+ background-color: ${constants_1.COLORS.SOLID_WHITE};
51
+ border-radius: 10px;
52
+ box-shadow: ${constants_1.COLORS.SOLID_BLACK_ALPHA_0_2} 0px 0px 12px;
53
+ display: flex;
54
+ flex-direction: column;
55
+ `;
56
+ const StyledTriggerButton = styled_components_1.default.div `
57
+ cursor: pointer;
58
+ position: fixed;
59
+ background: ${constants_1.COLORS.SOLID_WHITE};
60
+ border-radius: 50%;
61
+ display: flex;
62
+ align-items: center;
63
+ justify-content: center;
64
+ overflow: hidden;
65
+ width: 65px;
66
+ height: 65px;
67
+ bottom: 20px;
68
+ right: 10px;
69
+ padding: 8px;
70
+ `;
71
+ const UserInputContainer = styled_components_1.default.div `
72
+ min-height: 52px;
73
+ position: relative;
74
+ display: flex;
75
+ align-items: center;
76
+ justify-content: flex-start;
77
+ gap: 16px;
78
+ padding: 0px 16px;
79
+ z-index: 1;
80
+ border-top: 1px solid ${constants_1.COLORS.SOLID_BLACK_ALPHA_0_5};
81
+ `;
82
+ const TextAreaContainer = styled_components_1.default.div `
83
+ display: flex;
84
+ flex: 1 1 auto;
85
+ align-items: center;
86
+ `;
87
+ const TriggerImage = styled_components_1.default.img `
88
+ max-width: 100%;
89
+ max-height: 100%;
90
+ `;
91
+ const ErrorMessageContainer = styled_components_1.default.div `
92
+ position: relative;
93
+ display: flex;
94
+ z-index: 1;
95
+ justify-content: center;
96
+ width: 100%;
97
+ `;
98
+ const ErrorMessage = styled_components_1.default.div `
99
+ position: absolute;
100
+ top: 10px;
101
+ font-size: 14px;
102
+ line-height: 20px;
103
+ padding: 4px 11px;
104
+ display: flex;
105
+ background-color: ${constants_1.COLORS.ERROR_RED};
106
+ color: ${constants_1.COLORS.CONCRETE_WHITE};
107
+ border-radius: 5px;
108
+ align-items: center;
109
+ justify-content: center;
110
+ font-family: ${constants_1.WEBCHAT.DEFAULTS.FONT_FAMILY};
111
+ `;
112
+ const DarkBackgroundMenu = styled_components_1.default.div `
113
+ background: ${constants_1.COLORS.SOLID_BLACK};
114
+ opacity: 0.3;
115
+ z-index: 1;
116
+ right: 0;
117
+ bottom: 0;
118
+ border-radius: 10px;
119
+ position: absolute;
120
+ width: 100%;
121
+ height: 100%;
122
+ `;
123
+ // eslint-disable-next-line complexity, react/display-name
124
+ exports.Webchat = (0, react_1.forwardRef)((props, ref) => {
125
+ const { webchatState, addMessage, addMessageComponent, updateMessage, updateReplies, updateLatestInput, updateTyping, updateWebview, updateSession, updateLastRoutePath, updateHandoff, updateTheme, updateDevSettings, toggleWebchat, toggleEmojiPicker, togglePersistentMenu, toggleCoverComponent, doRenderCustomComponent, setError, setOnline, clearMessages, openWebviewT, closeWebviewT, updateLastMessageDate, setCurrentAttachment,
126
+ // eslint-disable-next-line react-hooks/rules-of-hooks
127
+ } = props.webchatHooks || (0, hooks_1.useWebchat)();
128
+ const firstUpdate = (0, react_1.useRef)(true);
129
+ const isOnline = () => webchatState.online;
130
+ const currentDateString = () => new Date().toISOString();
131
+ const theme = (0, lodash_merge_1.default)(webchatState.theme, props.theme);
132
+ const { initialSession, initialDevSettings, onStateChange } = props;
133
+ const getThemeProperty = (0, webchat_1._getThemeProperty)(theme);
134
+ const [customComponent, setCustomComponent] = (0, react_1.useState)(null);
135
+ const storage = props.storage;
136
+ const storageKey = typeof props.storageKey === 'function'
137
+ ? props.storageKey()
138
+ : props.storageKey;
139
+ const [botonicState, saveState] = (0, use_storage_state_hook_1.useStorageState)(storage, storageKey);
140
+ const host = props.host || document.body;
141
+ const deviceAdapter = new device_adapter_1.DeviceAdapter();
142
+ const saveWebchatState = webchatState => {
143
+ storage &&
144
+ saveState(JSON.parse((0, regexs_1.stringifyWithRegexs)({
145
+ messages: webchatState.messagesJSON,
146
+ session: webchatState.session,
147
+ lastRoutePath: webchatState.lastRoutePath,
148
+ devSettings: webchatState.devSettings,
149
+ lastMessageUpdate: webchatState.lastMessageUpdate,
150
+ themeUpdates: webchatState.themeUpdates,
151
+ })));
152
+ };
153
+ const handleAttachment = event => {
154
+ if (!(0, message_utils_1.isAllowedSize)(event.target.files[0].size)) {
155
+ throw new Error(`The file is too large. A maximum of ${constants_1.MAX_ALLOWED_SIZE_MB}MB is allowed.`);
156
+ }
157
+ setCurrentAttachment({
158
+ fileName: event.target.files[0].name,
159
+ file: event.target.files[0],
160
+ attachmentType: (0, message_utils_1.getMediaType)(event.target.files[0].type),
161
+ });
162
+ };
163
+ (0, react_1.useEffect)(() => {
164
+ if (webchatState.currentAttachment)
165
+ sendAttachment(webchatState.currentAttachment);
166
+ }, [webchatState.currentAttachment]);
167
+ const sendUserInput = async (input) => {
168
+ props.onUserInput &&
169
+ props.onUserInput({
170
+ user: webchatState.session.user,
171
+ input: input,
172
+ session: webchatState.session,
173
+ lastRoutePath: webchatState.lastRoutePath,
174
+ });
175
+ };
176
+ const sendChatEvent = async (chatEvent) => {
177
+ const chatEventInput = {
178
+ id: (0, uuid_1.v4)(),
179
+ type: core_1.INPUT.CHAT_EVENT,
180
+ data: chatEvent,
181
+ };
182
+ props.onUserInput &&
183
+ props.onUserInput({
184
+ user: webchatState.session.user,
185
+ input: chatEventInput,
186
+ session: webchatState.session,
187
+ lastRoutePath: webchatState.lastRoutePath,
188
+ });
189
+ };
190
+ // Load styles stored in window._botonicInsertStyles by Webpack
191
+ (0, hooks_1.useComponentWillMount)(() => {
192
+ if (window._botonicInsertStyles && window._botonicInsertStyles.length) {
193
+ for (const botonicStyle of window._botonicInsertStyles) {
194
+ // Injecting styles at head is needed even if we use shadowDOM
195
+ // as some dependencies like simplebar rely on creating ephemeral elements
196
+ // on document.body and assume styles will be available globally
197
+ document.head.appendChild(botonicStyle);
198
+ // injecting styles in host node too so that shadowDOM works
199
+ if (props.shadowDOM)
200
+ host.appendChild(botonicStyle.cloneNode(true));
201
+ }
202
+ delete window._botonicInsertStyles;
203
+ }
204
+ if (props.shadowDOM) {
205
+ // emoji-picker-react injects styles in head, so we need to
206
+ // re-inject them in our host node to make it work with shadowDOM
207
+ for (const style of document.querySelectorAll('style')) {
208
+ if (style.textContent &&
209
+ style.textContent.includes('emoji-picker-react'))
210
+ host.appendChild(style.cloneNode(true));
211
+ }
212
+ }
213
+ });
214
+ // Load initial state from storage
215
+ (0, react_1.useEffect)(() => {
216
+ let { messages, session, lastRoutePath, devSettings, lastMessageUpdate, themeUpdates, } = botonicState || {};
217
+ session = (0, webchat_1.initSession)(session);
218
+ updateSession(session);
219
+ if ((0, webchat_1.shouldKeepSessionOnReload)({ initialDevSettings, devSettings })) {
220
+ if (messages) {
221
+ messages.forEach(m => {
222
+ addMessage(m);
223
+ const newComponent = (0, msg_to_botonic_1.msgToBotonic)(Object.assign(Object.assign({}, m), { delay: 0, typing: 0 }), (props.theme.message && props.theme.message.customTypes) ||
224
+ props.theme.customMessageTypes);
225
+ if (newComponent)
226
+ addMessageComponent(newComponent);
227
+ });
228
+ }
229
+ if (initialSession)
230
+ updateSession((0, lodash_merge_1.default)(initialSession, session));
231
+ if (lastRoutePath)
232
+ updateLastRoutePath(lastRoutePath);
233
+ }
234
+ else
235
+ updateSession((0, lodash_merge_1.default)(initialSession, session));
236
+ if (devSettings)
237
+ updateDevSettings(devSettings);
238
+ else if (initialDevSettings)
239
+ updateDevSettings(initialDevSettings);
240
+ if (lastMessageUpdate)
241
+ updateLastMessageDate(lastMessageUpdate);
242
+ if (themeUpdates !== undefined)
243
+ updateTheme((0, lodash_merge_1.default)(props.theme, themeUpdates), themeUpdates);
244
+ if (props.onInit)
245
+ setTimeout(() => props.onInit(), 100);
246
+ }, []);
247
+ (0, react_1.useEffect)(() => {
248
+ if (!webchatState.isWebchatOpen)
249
+ return;
250
+ deviceAdapter.init(host);
251
+ (0, dom_1.scrollToBottom)({ behavior: 'auto', host });
252
+ }, [webchatState.isWebchatOpen]);
253
+ (0, react_1.useEffect)(() => {
254
+ if (onStateChange && typeof onStateChange === 'function')
255
+ onStateChange(webchatState);
256
+ saveWebchatState(webchatState);
257
+ }, [
258
+ webchatState.messagesJSON,
259
+ webchatState.session,
260
+ webchatState.lastRoutePath,
261
+ webchatState.devSettings,
262
+ webchatState.lastMessageUpdate,
263
+ ]);
264
+ (0, use_async_effect_1.useAsyncEffect)(async () => {
265
+ if (!webchatState.online) {
266
+ setError({
267
+ message: (0, webchat_1.getServerErrorMessage)(props.server),
268
+ });
269
+ }
270
+ else {
271
+ if (!firstUpdate.current) {
272
+ setError(undefined);
273
+ }
274
+ }
275
+ }, [webchatState.online]);
276
+ (0, hooks_1.useTyping)({ webchatState, updateTyping, updateMessage, host });
277
+ (0, react_1.useEffect)(() => {
278
+ updateTheme((0, lodash_merge_1.default)(props.theme, theme, webchatState.themeUpdates));
279
+ }, [props.theme, webchatState.themeUpdates]);
280
+ const openWebview = (webviewComponent, params) => updateWebview(webviewComponent, params);
281
+ const handleSelectedEmoji = event => {
282
+ textArea.current.value += event.emoji;
283
+ textArea.current.focus();
284
+ };
285
+ const closeWebview = options => {
286
+ updateWebview();
287
+ if (userInputEnabled) {
288
+ textArea.current.focus();
289
+ }
290
+ if (options && options.payload) {
291
+ sendPayload(options.payload);
292
+ }
293
+ else if (options && options.path) {
294
+ let params = '';
295
+ if (options.params)
296
+ params = (0, core_1.params2queryString)(options.params);
297
+ sendPayload(`__PATH_PAYLOAD__${options.path}?${params}`);
298
+ }
299
+ };
300
+ const handleMenu = () => {
301
+ togglePersistentMenu(!webchatState.isPersistentMenuOpen);
302
+ };
303
+ const handleEmojiClick = () => {
304
+ toggleEmojiPicker(!webchatState.isEmojiPickerOpen);
305
+ };
306
+ const persistentMenuOptions = getThemeProperty(constants_1.WEBCHAT.CUSTOM_PROPERTIES.persistentMenu, props.persistentMenu);
307
+ const darkBackgroundMenu = getThemeProperty(constants_1.WEBCHAT.CUSTOM_PROPERTIES.darkBackgroundMenu, false);
308
+ const getBlockInputs = (rule, inputData) => {
309
+ const processedInput = rule.preprocess
310
+ ? rule.preprocess(inputData)
311
+ : inputData;
312
+ return rule.match.some(regex => {
313
+ if (typeof regex === 'string')
314
+ regex = (0, regexs_1.deserializeRegex)(regex);
315
+ return regex.test(processedInput);
316
+ });
317
+ };
318
+ const checkBlockInput = input => {
319
+ // if is a text we check if it is a serialized RE
320
+ const blockInputs = getThemeProperty(constants_1.WEBCHAT.CUSTOM_PROPERTIES.blockInputs, props.blockInputs);
321
+ if (!Array.isArray(blockInputs))
322
+ return false;
323
+ for (const rule of blockInputs) {
324
+ if (getBlockInputs(rule, input.data)) {
325
+ addMessageComponent((0, jsx_runtime_1.jsx)(components_1.Text, Object.assign({ id: input.id, from: constants_1.SENDERS.user, blob: false, style: {
326
+ backgroundColor: constants_1.COLORS.SCORPION_GRAY,
327
+ borderColor: constants_1.COLORS.SCORPION_GRAY,
328
+ padding: '8px 12px',
329
+ } }, { children: rule.message })));
330
+ updateReplies(false);
331
+ return true;
332
+ }
333
+ }
334
+ return false;
335
+ };
336
+ const closeMenu = () => {
337
+ togglePersistentMenu(false);
338
+ };
339
+ const persistentMenu = () => {
340
+ return ((0, jsx_runtime_1.jsx)(persistent_menu_1.OpenedPersistentMenu, { onClick: closeMenu, options: persistentMenuOptions, borderRadius: webchatState.theme.style.borderRadius || '10px' }));
341
+ };
342
+ const getCoverComponent = () => {
343
+ return getThemeProperty(constants_1.WEBCHAT.CUSTOM_PROPERTIES.coverComponent, props.coverComponent &&
344
+ (props.coverComponent.component || props.coverComponent));
345
+ };
346
+ const CoverComponent = getCoverComponent();
347
+ const closeCoverComponent = () => {
348
+ toggleCoverComponent(false);
349
+ };
350
+ (0, react_1.useEffect)(() => {
351
+ if (!CoverComponent)
352
+ return;
353
+ if (!botonicState ||
354
+ (botonicState.messages && botonicState.messages.length == 0))
355
+ toggleCoverComponent(true);
356
+ }, []);
357
+ const coverComponent = () => {
358
+ const coverComponentProps = getThemeProperty(constants_1.WEBCHAT.CUSTOM_PROPERTIES.coverComponentProps, props.coverComponent && props.coverComponent.props);
359
+ if (CoverComponent && webchatState.isCoverComponentOpen)
360
+ return ((0, jsx_runtime_1.jsx)(CoverComponent, Object.assign({ closeComponent: closeCoverComponent }, coverComponentProps)));
361
+ return null;
362
+ };
363
+ const messageComponentFromInput = input => {
364
+ let messageComponent = null;
365
+ if ((0, message_utils_1.isText)(input)) {
366
+ messageComponent = ((0, jsx_runtime_1.jsx)(components_1.Text, Object.assign({ id: input.id, payload: input.payload, from: constants_1.SENDERS.user }, { children: input.data })));
367
+ }
368
+ else if ((0, message_utils_1.isMedia)(input)) {
369
+ const temporaryDisplayUrl = URL.createObjectURL(input.data);
370
+ const mediaProps = {
371
+ id: input.id,
372
+ from: constants_1.SENDERS.user,
373
+ src: temporaryDisplayUrl,
374
+ };
375
+ if ((0, message_utils_1.isImage)(input))
376
+ messageComponent = (0, jsx_runtime_1.jsx)(components_1.Image, Object.assign({}, mediaProps));
377
+ else if ((0, message_utils_1.isAudio)(input))
378
+ messageComponent = (0, jsx_runtime_1.jsx)(components_1.Audio, Object.assign({}, mediaProps));
379
+ else if ((0, message_utils_1.isVideo)(input))
380
+ messageComponent = (0, jsx_runtime_1.jsx)(components_1.Video, Object.assign({}, mediaProps));
381
+ else if ((0, message_utils_1.isDocument)(input))
382
+ messageComponent = (0, jsx_runtime_1.jsx)(components_1.Document, Object.assign({}, mediaProps));
383
+ }
384
+ return messageComponent;
385
+ };
386
+ const sendInput = async (input) => {
387
+ if (!input || Object.keys(input).length == 0)
388
+ return;
389
+ if ((0, message_utils_1.isText)(input) && (!input.data || !input.data.trim()))
390
+ return; // in case trim() doesn't work in a browser we can use !/\S/.test(input.data)
391
+ if ((0, message_utils_1.isText)(input) && checkBlockInput(input))
392
+ return;
393
+ if (!input.id)
394
+ input.id = (0, uuid_1.v4)();
395
+ const messageComponent = messageComponentFromInput(input);
396
+ if (messageComponent)
397
+ addMessageComponent(messageComponent);
398
+ if ((0, message_utils_1.isMedia)(input))
399
+ input.data = await (0, message_utils_1.readDataURL)(input.data);
400
+ sendUserInput(input);
401
+ updateLatestInput(input);
402
+ isOnline() && updateLastMessageDate(currentDateString());
403
+ updateReplies(false);
404
+ togglePersistentMenu(false);
405
+ toggleEmojiPicker(false);
406
+ };
407
+ /* This is the public API this component exposes to its parents
408
+ https://stackoverflow.com/questions/37949981/call-child-method-from-parent
409
+ */
410
+ const updateSessionWithUser = userToUpdate => updateSession((0, lodash_merge_1.default)(webchatState.session, { user: userToUpdate }));
411
+ (0, react_1.useImperativeHandle)(ref, () => ({
412
+ addBotResponse: ({ response, session, lastRoutePath }) => {
413
+ updateTyping(false);
414
+ if (Array.isArray(response))
415
+ response.map(r => addMessageComponent(r));
416
+ else if (response)
417
+ addMessageComponent(response);
418
+ if (session) {
419
+ updateSession((0, lodash_merge_1.default)(session, { user: webchatState.session.user }));
420
+ const action = session._botonic_action || '';
421
+ const handoff = action.startsWith('create_case');
422
+ if (handoff && environment_1.isDev)
423
+ addMessageComponent((0, jsx_runtime_1.jsx)(handoff_1.Handoff, {}));
424
+ updateHandoff(handoff);
425
+ }
426
+ if (lastRoutePath)
427
+ updateLastRoutePath(lastRoutePath);
428
+ updateLastMessageDate(currentDateString());
429
+ },
430
+ setTyping: typing => updateTyping(typing),
431
+ addUserMessage: message => sendInput(message),
432
+ updateUser: updateSessionWithUser,
433
+ openWebchat: () => toggleWebchat(true),
434
+ closeWebchat: () => toggleWebchat(false),
435
+ toggleWebchat: () => toggleWebchat(!webchatState.isWebchatOpen),
436
+ openCoverComponent: () => toggleCoverComponent(true),
437
+ closeCoverComponent: () => toggleCoverComponent(false),
438
+ renderCustomComponent: _customComponent => {
439
+ setCustomComponent(_customComponent);
440
+ doRenderCustomComponent(true);
441
+ },
442
+ unmountCustomComponent: () => doRenderCustomComponent(false),
443
+ toggleCoverComponent: () => toggleCoverComponent(!webchatState.isCoverComponentOpen),
444
+ openWebviewApi: component => openWebviewT(component),
445
+ setError,
446
+ setOnline,
447
+ getMessages: () => webchatState.messagesJSON,
448
+ isOnline,
449
+ clearMessages: () => {
450
+ clearMessages();
451
+ updateReplies(false);
452
+ },
453
+ getLastMessageUpdate: () => webchatState.lastMessageUpdate,
454
+ updateMessageInfo: (msgId, messageInfo) => {
455
+ const messageToUpdate = webchatState.messagesJSON.filter(m => m.id == msgId)[0];
456
+ const updatedMsg = (0, lodash_merge_1.default)(messageToUpdate, messageInfo);
457
+ if (updatedMsg.ack === 1)
458
+ delete updatedMsg.unsentInput;
459
+ updateMessage(updatedMsg);
460
+ },
461
+ updateWebchatSettings: settings => {
462
+ const themeUpdates = (0, webchat_settings_1.normalizeWebchatSettings)(settings);
463
+ updateTheme((0, lodash_merge_1.default)(webchatState.theme, themeUpdates), themeUpdates);
464
+ },
465
+ }));
466
+ const resolveCase = () => {
467
+ updateHandoff(false);
468
+ updateSession(Object.assign(Object.assign({}, webchatState.session), { _botonic_action: null }));
469
+ };
470
+ const prevSession = (0, hooks_1.usePrevious)(webchatState.session);
471
+ (0, react_1.useEffect)(() => {
472
+ // Resume conversation after handoff
473
+ if (prevSession &&
474
+ prevSession._botonic_action &&
475
+ !webchatState.session._botonic_action) {
476
+ const action = (0, exports.getParsedAction)(prevSession._botonic_action);
477
+ if (action && action.on_finish)
478
+ sendPayload(action.on_finish);
479
+ }
480
+ }, [webchatState.session._botonic_action]);
481
+ const sendText = async (text, payload) => {
482
+ if (!text)
483
+ return;
484
+ const input = { type: core_1.INPUT.TEXT, data: text, payload };
485
+ await sendInput(input);
486
+ };
487
+ const sendPayload = async (payload) => {
488
+ if (!payload)
489
+ return;
490
+ const input = { type: core_1.INPUT.POSTBACK, payload };
491
+ await sendInput(input);
492
+ };
493
+ const sendAttachment = async (attachment) => {
494
+ if (attachment.file) {
495
+ const attachmentType = (0, message_utils_1.getMediaType)(attachment.file.type);
496
+ if (!attachmentType)
497
+ return;
498
+ const input = {
499
+ type: attachmentType,
500
+ data: attachment.file,
501
+ };
502
+ await sendInput(input);
503
+ setCurrentAttachment(undefined);
504
+ }
505
+ };
506
+ const sendTextAreaText = () => {
507
+ sendText(textArea.current.value);
508
+ textArea.current.value = '';
509
+ };
510
+ let isTyping = false;
511
+ let typingTimeout = null;
512
+ function clearTimeoutWithReset(reset) {
513
+ const waitTime = 20 * 1000;
514
+ if (typingTimeout)
515
+ clearTimeout(typingTimeout);
516
+ if (reset)
517
+ typingTimeout = setTimeout(stopTyping, waitTime);
518
+ }
519
+ function startTyping() {
520
+ isTyping = true;
521
+ sendChatEvent('typing_on');
522
+ }
523
+ function stopTyping() {
524
+ clearTimeoutWithReset(false);
525
+ isTyping = false;
526
+ sendChatEvent('typing_off');
527
+ }
528
+ const onKeyDown = event => {
529
+ if (event.keyCode === 13 && event.shiftKey === false) {
530
+ event.preventDefault();
531
+ sendTextAreaText();
532
+ stopTyping();
533
+ }
534
+ };
535
+ const onKeyUp = () => {
536
+ if (textArea.current.value === '') {
537
+ stopTyping();
538
+ return;
539
+ }
540
+ if (!isTyping) {
541
+ startTyping();
542
+ }
543
+ clearTimeoutWithReset(true);
544
+ };
545
+ const webviewRequestContext = {
546
+ getString: stringId => props.getString(stringId, webchatState.session),
547
+ setLocale: locale => props.getString(locale, webchatState.session),
548
+ session: webchatState.session || {},
549
+ params: webchatState.webviewParams || {},
550
+ closeWebview: closeWebview,
551
+ defaultDelay: props.defaultDelay || 0,
552
+ defaultTyping: props.defaultTyping || 0,
553
+ };
554
+ (0, react_1.useEffect)(() => {
555
+ if (firstUpdate.current) {
556
+ firstUpdate.current = false;
557
+ return;
558
+ }
559
+ if (webchatState.isWebchatOpen && props.onOpen)
560
+ props.onOpen();
561
+ if (!webchatState.isWebchatOpen && props.onClose && !firstUpdate.current) {
562
+ props.onClose();
563
+ toggleEmojiPicker(false);
564
+ togglePersistentMenu(false);
565
+ }
566
+ }, [webchatState.isWebchatOpen]);
567
+ const getTriggerImage = () => {
568
+ const triggerImage = getThemeProperty(constants_1.WEBCHAT.CUSTOM_PROPERTIES.triggerButtonImage, null);
569
+ if (triggerImage === null) {
570
+ webchatState.theme.triggerButtonImage = constants_1.WEBCHAT.DEFAULTS.LOGO;
571
+ return null;
572
+ }
573
+ return triggerImage;
574
+ };
575
+ const triggerButtonStyle = getThemeProperty(constants_1.WEBCHAT.CUSTOM_PROPERTIES.triggerButtonStyle);
576
+ const CustomTriggerButton = getThemeProperty(constants_1.WEBCHAT.CUSTOM_PROPERTIES.customTrigger, undefined);
577
+ const triggerButton = () => {
578
+ if (CustomTriggerButton) {
579
+ return (0, jsx_runtime_1.jsx)(CustomTriggerButton, {});
580
+ }
581
+ return ((0, jsx_runtime_1.jsx)(StyledTriggerButton, Object.assign({ role: constants_1.ROLES.TRIGGER_BUTTON, style: Object.assign({}, triggerButtonStyle) }, { children: getTriggerImage() && ((0, jsx_runtime_1.jsx)(TriggerImage, { src: (0, environment_1.resolveImage)(getTriggerImage()) })) })));
582
+ };
583
+ const webchatMessageList = () => ((0, jsx_runtime_1.jsx)(message_list_1.WebchatMessageList, Object.assign({ style: { flex: 1 } }, { children: webchatState.typing && (0, jsx_runtime_1.jsx)(typing_indicator_1.TypingIndicator, {}) })));
584
+ const webchatReplies = () => (0, jsx_runtime_1.jsx)(replies_1.WebchatReplies, { replies: webchatState.replies });
585
+ const isUserInputEnabled = () => {
586
+ const isUserInputEnabled = getThemeProperty(constants_1.WEBCHAT.CUSTOM_PROPERTIES.enableUserInput, props.enableUserInput !== undefined ? props.enableUserInput : true);
587
+ return isUserInputEnabled && !webchatState.isCoverComponentOpen;
588
+ };
589
+ const userInputEnabled = isUserInputEnabled();
590
+ const textArea = (0, react_1.useRef)(null);
591
+ const userInputArea = () => {
592
+ return (userInputEnabled && ((0, jsx_runtime_1.jsxs)(UserInputContainer, Object.assign({ style: Object.assign({}, getThemeProperty(constants_1.WEBCHAT.CUSTOM_PROPERTIES.userInputStyle)), className: 'user-input-container' }, { children: [webchatState.isEmojiPickerOpen && ((0, jsx_runtime_1.jsx)(emoji_picker_1.OpenedEmojiPicker, { height: webchatState.theme.style.height, onEmojiClick: handleSelectedEmoji, onClick: handleEmojiClick })), (0, jsx_runtime_1.jsx)(persistent_menu_1.PersistentMenu, { onClick: handleMenu, persistentMenu: props.persistentMenu }), (0, jsx_runtime_1.jsx)(TextAreaContainer, { children: (0, jsx_runtime_1.jsx)(react_textarea_autosize_1.default, { inputRef: textArea, name: 'text', onFocus: () => deviceAdapter.onFocus(host), onBlur: () => deviceAdapter.onBlur(), maxRows: 4, wrap: 'soft', maxLength: '1000', placeholder: getThemeProperty(constants_1.WEBCHAT.CUSTOM_PROPERTIES.textPlaceholder, constants_1.WEBCHAT.DEFAULTS.PLACEHOLDER), autoFocus: true, onKeyDown: e => onKeyDown(e), onKeyUp: onKeyUp, style: Object.assign({ display: 'flex', fontSize: deviceAdapter.fontSize(14), width: '100%', border: 'none', resize: 'none', overflow: 'auto', outline: 'none', flex: '1 1 auto', padding: 10, paddingLeft: persistentMenuOptions ? 0 : 10, fontFamily: 'inherit' }, getThemeProperty(constants_1.WEBCHAT.CUSTOM_PROPERTIES.userInputBoxStyle)) }) }), (0, jsx_runtime_1.jsx)(emoji_picker_1.EmojiPicker, { enableEmojiPicker: props.enableEmojiPicker, onClick: handleEmojiClick }), (0, jsx_runtime_1.jsx)(attachment_1.Attachment, { enableAttachments: props.enableAttachments, onChange: handleAttachment, accept: (0, message_utils_1.getFullMimeWhitelist)().join(',') }), (0, jsx_runtime_1.jsx)(send_button_1.SendButton, { onClick: sendTextAreaText })] }))));
593
+ };
594
+ const webchatWebview = () => ((0, jsx_runtime_1.jsx)(contexts_1.RequestContext.Provider, Object.assign({ value: webviewRequestContext }, { children: (0, jsx_runtime_1.jsx)(webview_1.WebviewContainer, { style: Object.assign(Object.assign({}, getThemeProperty(constants_1.WEBCHAT.CUSTOM_PROPERTIES.webviewStyle)), mobileStyle), webview: webchatState.webview }) })));
595
+ let mobileStyle = {};
596
+ if ((0, core_1.isMobile)(getThemeProperty(constants_1.WEBCHAT.CUSTOM_PROPERTIES.mobileBreakpoint))) {
597
+ mobileStyle = getThemeProperty(constants_1.WEBCHAT.CUSTOM_PROPERTIES.mobileStyle) || {
598
+ width: '100%',
599
+ height: '100%',
600
+ right: 0,
601
+ bottom: 0,
602
+ borderRadius: 0,
603
+ };
604
+ }
605
+ (0, react_1.useEffect)(() => {
606
+ // Prod mode
607
+ saveWebchatState(webchatState);
608
+ (0, dom_1.scrollToBottom)({ host });
609
+ }, [webchatState.themeUpdates]);
610
+ // Only needed for dev/serve mode
611
+ const updateWebchatDevSettings = settings => {
612
+ // eslint-disable-next-line react-hooks/rules-of-hooks
613
+ (0, react_1.useEffect)(() => {
614
+ const themeUpdates = (0, webchat_settings_1.normalizeWebchatSettings)(settings);
615
+ updateTheme((0, lodash_merge_1.default)(webchatState.theme, themeUpdates), themeUpdates);
616
+ }, [webchatState.messagesJSON]);
617
+ };
618
+ const DarkenBackground = ({ component }) => {
619
+ return ((0, jsx_runtime_1.jsxs)("div", { children: [darkBackgroundMenu && ((0, jsx_runtime_1.jsx)(DarkBackgroundMenu, { style: {
620
+ borderRadius: webchatState.theme.style.borderRadius,
621
+ } })), component] }));
622
+ };
623
+ const _renderCustomComponent = () => {
624
+ if (!customComponent)
625
+ return (0, jsx_runtime_1.jsx)(jsx_runtime_1.Fragment, {});
626
+ else
627
+ return customComponent;
628
+ };
629
+ const WebchatComponent = ((0, jsx_runtime_1.jsxs)(contexts_1.WebchatContext.Provider, Object.assign({ value: {
630
+ sendText,
631
+ sendAttachment,
632
+ sendPayload,
633
+ sendInput,
634
+ openWebview,
635
+ resolveCase,
636
+ webchatState,
637
+ getThemeProperty,
638
+ addMessage,
639
+ toggleWebchat,
640
+ updateMessage,
641
+ updateReplies,
642
+ updateLatestInput,
643
+ updateUser: updateSessionWithUser,
644
+ updateWebchatDevSettings: updateWebchatDevSettings,
645
+ } }, { children: [!webchatState.isWebchatOpen && ((0, jsx_runtime_1.jsx)("div", Object.assign({ onClick: event => {
646
+ toggleWebchat(true);
647
+ event.preventDefault();
648
+ } }, { children: triggerButton() }))), webchatState.isWebchatOpen && ((0, jsx_runtime_1.jsxs)(StyledWebchat
649
+ // TODO: Distinguis between multiple instances of webchat, e.g. `${uniqueId}-botonic-webchat`
650
+ , Object.assign({
651
+ // TODO: Distinguis between multiple instances of webchat, e.g. `${uniqueId}-botonic-webchat`
652
+ role: constants_1.ROLES.WEBCHAT, id: constants_1.WEBCHAT.DEFAULTS.ID, width: webchatState.width, height: webchatState.height, style: Object.assign(Object.assign({}, webchatState.theme.style), mobileStyle) }, { children: [(0, jsx_runtime_1.jsx)(header_1.StyledWebchatHeader, { onCloseClick: () => {
653
+ toggleWebchat(false);
654
+ } }), webchatState.error.message && ((0, jsx_runtime_1.jsx)(ErrorMessageContainer, { children: (0, jsx_runtime_1.jsx)(ErrorMessage, { children: webchatState.error.message }) })), webchatMessageList(), webchatState.replies &&
655
+ Object.keys(webchatState.replies).length > 0 &&
656
+ webchatReplies(), webchatState.isPersistentMenuOpen && ((0, jsx_runtime_1.jsx)(DarkenBackground, { component: persistentMenu() })), !webchatState.handoff && userInputArea(), webchatState.webview && webchatWebview(), webchatState.isCoverComponentOpen && coverComponent(), webchatState.isCustomComponentRendered &&
657
+ customComponent &&
658
+ _renderCustomComponent()] })))] })));
659
+ return props.shadowDOM ? ((0, jsx_runtime_1.jsx)(styled_components_1.StyleSheetManager, Object.assign({ target: host }, { children: WebchatComponent }))) : (WebchatComponent);
660
+ });
661
+ //# sourceMappingURL=webchat.js.map