@botonic/react 0.24.0-alpha.3 → 0.24.0-alpha.4

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