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

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 (328) hide show
  1. package/lib/cjs/botonic-tester.js +4 -4
  2. package/lib/cjs/botonic-tester.js.map +1 -1
  3. package/lib/cjs/components/multichannel/multichannel-text.js +4 -4
  4. package/lib/cjs/components/multichannel/multichannel-text.js.map +1 -1
  5. package/lib/cjs/index-types.d.ts +1 -1
  6. package/lib/cjs/message-utils.d.ts +1 -1
  7. package/lib/cjs/message-utils.js +16 -16
  8. package/lib/cjs/message-utils.js.map +1 -1
  9. package/lib/cjs/node-app.d.ts +1 -1
  10. package/lib/cjs/react-bot.d.ts +1 -1
  11. package/lib/cjs/react-bot.js +2 -2
  12. package/lib/cjs/react-bot.js.map +1 -1
  13. package/lib/cjs/webchat/trigger-button/index.js +2 -3
  14. package/lib/cjs/webchat/trigger-button/index.js.map +1 -1
  15. package/lib/cjs/webchat-app.js +3 -4
  16. package/lib/cjs/webchat-app.js.map +1 -1
  17. package/lib/cjs/webview-app.js +10 -12
  18. package/lib/cjs/webview-app.js.map +1 -1
  19. package/package.json +1 -1
  20. package/src/botonic-tester.jsx +1 -1
  21. package/src/components/multichannel/multichannel-text.jsx +1 -1
  22. package/src/index-types.ts +1 -1
  23. package/src/message-utils.js +1 -1
  24. package/src/react-bot.jsx +1 -1
  25. package/src/webchat/trigger-button/index.tsx +5 -10
  26. package/src/webchat-app.jsx +1 -2
  27. package/src/webview-app.tsx +1 -3
  28. package/lib/esm/app.d.ts +0 -2
  29. package/lib/esm/app.js +0 -6
  30. package/lib/esm/app.js.map +0 -1
  31. package/lib/esm/assets/index-types.d.ts +0 -4
  32. package/lib/esm/assets/index-types.js +0 -2
  33. package/lib/esm/assets/index-types.js.map +0 -1
  34. package/lib/esm/botonic-tester.d.ts +0 -18
  35. package/lib/esm/botonic-tester.js +0 -62
  36. package/lib/esm/botonic-tester.js.map +0 -1
  37. package/lib/esm/components/audio.d.ts +0 -8
  38. package/lib/esm/components/audio.js +0 -18
  39. package/lib/esm/components/audio.js.map +0 -1
  40. package/lib/esm/components/button.d.ts +0 -15
  41. package/lib/esm/components/button.js +0 -140
  42. package/lib/esm/components/button.js.map +0 -1
  43. package/lib/esm/components/buttons-disabler.d.ts +0 -24
  44. package/lib/esm/components/buttons-disabler.js +0 -84
  45. package/lib/esm/components/buttons-disabler.js.map +0 -1
  46. package/lib/esm/components/carousel.d.ts +0 -10
  47. package/lib/esm/components/carousel.js +0 -102
  48. package/lib/esm/components/carousel.js.map +0 -1
  49. package/lib/esm/components/components.d.ts +0 -12
  50. package/lib/esm/components/components.js +0 -17
  51. package/lib/esm/components/components.js.map +0 -1
  52. package/lib/esm/components/custom-message.d.ts +0 -12
  53. package/lib/esm/components/custom-message.js +0 -55
  54. package/lib/esm/components/custom-message.js.map +0 -1
  55. package/lib/esm/components/document.d.ts +0 -8
  56. package/lib/esm/components/document.js +0 -42
  57. package/lib/esm/components/document.js.map +0 -1
  58. package/lib/esm/components/element.d.ts +0 -4
  59. package/lib/esm/components/element.js +0 -51
  60. package/lib/esm/components/element.js.map +0 -1
  61. package/lib/esm/components/handoff.d.ts +0 -1
  62. package/lib/esm/components/handoff.js +0 -49
  63. package/lib/esm/components/handoff.js.map +0 -1
  64. package/lib/esm/components/image.d.ts +0 -8
  65. package/lib/esm/components/image.js +0 -35
  66. package/lib/esm/components/image.js.map +0 -1
  67. package/lib/esm/components/index-types.d.ts +0 -189
  68. package/lib/esm/components/index-types.js +0 -16
  69. package/lib/esm/components/index-types.js.map +0 -1
  70. package/lib/esm/components/index.d.ts +0 -23
  71. package/lib/esm/components/index.js +0 -24
  72. package/lib/esm/components/index.js.map +0 -1
  73. package/lib/esm/components/location.d.ts +0 -11
  74. package/lib/esm/components/location.js +0 -27
  75. package/lib/esm/components/location.js.map +0 -1
  76. package/lib/esm/components/markdown.d.ts +0 -7
  77. package/lib/esm/components/markdown.js +0 -152
  78. package/lib/esm/components/markdown.js.map +0 -1
  79. package/lib/esm/components/message-template.d.ts +0 -1
  80. package/lib/esm/components/message-template.js +0 -9
  81. package/lib/esm/components/message-template.js.map +0 -1
  82. package/lib/esm/components/message.d.ts +0 -1
  83. package/lib/esm/components/message.js +0 -188
  84. package/lib/esm/components/message.js.map +0 -1
  85. package/lib/esm/components/multichannel/facebook/facebook.d.ts +0 -17
  86. package/lib/esm/components/multichannel/facebook/facebook.js +0 -43
  87. package/lib/esm/components/multichannel/facebook/facebook.js.map +0 -1
  88. package/lib/esm/components/multichannel/index-types.d.ts +0 -46
  89. package/lib/esm/components/multichannel/index-types.js +0 -2
  90. package/lib/esm/components/multichannel/index-types.js.map +0 -1
  91. package/lib/esm/components/multichannel/index.d.ts +0 -11
  92. package/lib/esm/components/multichannel/index.js +0 -12
  93. package/lib/esm/components/multichannel/index.js.map +0 -1
  94. package/lib/esm/components/multichannel/multichannel-button.d.ts +0 -1
  95. package/lib/esm/components/multichannel/multichannel-button.js +0 -71
  96. package/lib/esm/components/multichannel/multichannel-button.js.map +0 -1
  97. package/lib/esm/components/multichannel/multichannel-carousel.d.ts +0 -1
  98. package/lib/esm/components/multichannel/multichannel-carousel.js +0 -73
  99. package/lib/esm/components/multichannel/multichannel-carousel.js.map +0 -1
  100. package/lib/esm/components/multichannel/multichannel-context.d.ts +0 -11
  101. package/lib/esm/components/multichannel/multichannel-context.js +0 -12
  102. package/lib/esm/components/multichannel/multichannel-context.js.map +0 -1
  103. package/lib/esm/components/multichannel/multichannel-reply.d.ts +0 -1
  104. package/lib/esm/components/multichannel/multichannel-reply.js +0 -20
  105. package/lib/esm/components/multichannel/multichannel-reply.js.map +0 -1
  106. package/lib/esm/components/multichannel/multichannel-text.d.ts +0 -1
  107. package/lib/esm/components/multichannel/multichannel-text.js +0 -153
  108. package/lib/esm/components/multichannel/multichannel-text.js.map +0 -1
  109. package/lib/esm/components/multichannel/multichannel-utils.d.ts +0 -26
  110. package/lib/esm/components/multichannel/multichannel-utils.js +0 -69
  111. package/lib/esm/components/multichannel/multichannel-utils.js.map +0 -1
  112. package/lib/esm/components/multichannel/multichannel.d.ts +0 -1
  113. package/lib/esm/components/multichannel/multichannel.js +0 -55
  114. package/lib/esm/components/multichannel/multichannel.js.map +0 -1
  115. package/lib/esm/components/multichannel/whatsapp/markdown.d.ts +0 -1
  116. package/lib/esm/components/multichannel/whatsapp/markdown.js +0 -53
  117. package/lib/esm/components/multichannel/whatsapp/markdown.js.map +0 -1
  118. package/lib/esm/components/pic.d.ts +0 -6
  119. package/lib/esm/components/pic.js +0 -25
  120. package/lib/esm/components/pic.js.map +0 -1
  121. package/lib/esm/components/raw.d.ts +0 -9
  122. package/lib/esm/components/raw.js +0 -39
  123. package/lib/esm/components/raw.js.map +0 -1
  124. package/lib/esm/components/reply.d.ts +0 -9
  125. package/lib/esm/components/reply.js +0 -49
  126. package/lib/esm/components/reply.js.map +0 -1
  127. package/lib/esm/components/share-button.d.ts +0 -1
  128. package/lib/esm/components/share-button.js +0 -9
  129. package/lib/esm/components/share-button.js.map +0 -1
  130. package/lib/esm/components/subtitle.d.ts +0 -6
  131. package/lib/esm/components/subtitle.js +0 -19
  132. package/lib/esm/components/subtitle.js.map +0 -1
  133. package/lib/esm/components/text.d.ts +0 -8
  134. package/lib/esm/components/text.js +0 -42
  135. package/lib/esm/components/text.js.map +0 -1
  136. package/lib/esm/components/timestamps.d.ts +0 -10
  137. package/lib/esm/components/timestamps.js +0 -45
  138. package/lib/esm/components/timestamps.js.map +0 -1
  139. package/lib/esm/components/title.d.ts +0 -6
  140. package/lib/esm/components/title.js +0 -17
  141. package/lib/esm/components/title.js.map +0 -1
  142. package/lib/esm/components/video.d.ts +0 -8
  143. package/lib/esm/components/video.js +0 -26
  144. package/lib/esm/components/video.js.map +0 -1
  145. package/lib/esm/components/webchat-settings.d.ts +0 -3
  146. package/lib/esm/components/webchat-settings.js +0 -69
  147. package/lib/esm/components/webchat-settings.js.map +0 -1
  148. package/lib/esm/components/whatsapp-button-list.d.ts +0 -17
  149. package/lib/esm/components/whatsapp-button-list.js +0 -22
  150. package/lib/esm/components/whatsapp-button-list.js.map +0 -1
  151. package/lib/esm/components/whatsapp-template.d.ts +0 -1
  152. package/lib/esm/components/whatsapp-template.js +0 -20
  153. package/lib/esm/components/whatsapp-template.js.map +0 -1
  154. package/lib/esm/constants.d.ts +0 -172
  155. package/lib/esm/constants.js +0 -192
  156. package/lib/esm/constants.js.map +0 -1
  157. package/lib/esm/contexts.d.ts +0 -12
  158. package/lib/esm/contexts.js +0 -67
  159. package/lib/esm/contexts.js.map +0 -1
  160. package/lib/esm/dev-app.d.ts +0 -30
  161. package/lib/esm/dev-app.js +0 -74
  162. package/lib/esm/dev-app.js.map +0 -1
  163. package/lib/esm/index-types.d.ts +0 -128
  164. package/lib/esm/index-types.js +0 -12
  165. package/lib/esm/index-types.js.map +0 -1
  166. package/lib/esm/index.d.ts +0 -11
  167. package/lib/esm/index.js +0 -12
  168. package/lib/esm/index.js.map +0 -1
  169. package/lib/esm/message-utils.d.ts +0 -19
  170. package/lib/esm/message-utils.js +0 -41
  171. package/lib/esm/message-utils.js.map +0 -1
  172. package/lib/esm/msg-to-botonic.d.ts +0 -18
  173. package/lib/esm/msg-to-botonic.js +0 -135
  174. package/lib/esm/msg-to-botonic.js.map +0 -1
  175. package/lib/esm/node-app.d.ts +0 -12
  176. package/lib/esm/node-app.js +0 -21
  177. package/lib/esm/node-app.js.map +0 -1
  178. package/lib/esm/react-bot.d.ts +0 -8
  179. package/lib/esm/react-bot.js +0 -29
  180. package/lib/esm/react-bot.js.map +0 -1
  181. package/lib/esm/util/dom.d.ts +0 -13
  182. package/lib/esm/util/dom.js +0 -46
  183. package/lib/esm/util/dom.js.map +0 -1
  184. package/lib/esm/util/environment.d.ts +0 -6
  185. package/lib/esm/util/environment.js +0 -61
  186. package/lib/esm/util/environment.js.map +0 -1
  187. package/lib/esm/util/error-boundary.d.ts +0 -7
  188. package/lib/esm/util/error-boundary.js +0 -28
  189. package/lib/esm/util/error-boundary.js.map +0 -1
  190. package/lib/esm/util/index.d.ts +0 -8
  191. package/lib/esm/util/index.js +0 -9
  192. package/lib/esm/util/index.js.map +0 -1
  193. package/lib/esm/util/logs.d.ts +0 -2
  194. package/lib/esm/util/logs.js +0 -15
  195. package/lib/esm/util/logs.js.map +0 -1
  196. package/lib/esm/util/objects.d.ts +0 -3
  197. package/lib/esm/util/objects.js +0 -38
  198. package/lib/esm/util/objects.js.map +0 -1
  199. package/lib/esm/util/react.d.ts +0 -12
  200. package/lib/esm/util/react.js +0 -34
  201. package/lib/esm/util/react.js.map +0 -1
  202. package/lib/esm/util/regexs.d.ts +0 -2
  203. package/lib/esm/util/regexs.js +0 -18
  204. package/lib/esm/util/regexs.js.map +0 -1
  205. package/lib/esm/util/webchat.d.ts +0 -11
  206. package/lib/esm/util/webchat.js +0 -53
  207. package/lib/esm/util/webchat.js.map +0 -1
  208. package/lib/esm/webchat/actions.d.ts +0 -27
  209. package/lib/esm/webchat/actions.js +0 -29
  210. package/lib/esm/webchat/actions.js.map +0 -1
  211. package/lib/esm/webchat/components/attachment.d.ts +0 -5
  212. package/lib/esm/webchat/components/attachment.js +0 -24
  213. package/lib/esm/webchat/components/attachment.js.map +0 -1
  214. package/lib/esm/webchat/components/common.d.ts +0 -1
  215. package/lib/esm/webchat/components/common.js +0 -9
  216. package/lib/esm/webchat/components/common.js.map +0 -1
  217. package/lib/esm/webchat/components/conditional-animation.d.ts +0 -1
  218. package/lib/esm/webchat/components/conditional-animation.js +0 -12
  219. package/lib/esm/webchat/components/conditional-animation.js.map +0 -1
  220. package/lib/esm/webchat/components/emoji-picker.d.ts +0 -5
  221. package/lib/esm/webchat/components/emoji-picker.js +0 -37
  222. package/lib/esm/webchat/components/emoji-picker.js.map +0 -1
  223. package/lib/esm/webchat/components/persistent-menu.d.ts +0 -10
  224. package/lib/esm/webchat/components/persistent-menu.js +0 -39
  225. package/lib/esm/webchat/components/persistent-menu.js.map +0 -1
  226. package/lib/esm/webchat/components/send-button.d.ts +0 -3
  227. package/lib/esm/webchat/components/send-button.js +0 -14
  228. package/lib/esm/webchat/components/send-button.js.map +0 -1
  229. package/lib/esm/webchat/components/styled-scrollbar.d.ts +0 -1
  230. package/lib/esm/webchat/components/styled-scrollbar.js +0 -50
  231. package/lib/esm/webchat/components/styled-scrollbar.js.map +0 -1
  232. package/lib/esm/webchat/components/typing-indicator.d.ts +0 -1
  233. package/lib/esm/webchat/components/typing-indicator.js +0 -6
  234. package/lib/esm/webchat/components/typing-indicator.js.map +0 -1
  235. package/lib/esm/webchat/devices/device-adapter.d.ts +0 -12
  236. package/lib/esm/webchat/devices/device-adapter.js +0 -43
  237. package/lib/esm/webchat/devices/device-adapter.js.map +0 -1
  238. package/lib/esm/webchat/devices/index.d.ts +0 -11
  239. package/lib/esm/webchat/devices/index.js +0 -18
  240. package/lib/esm/webchat/devices/index.js.map +0 -1
  241. package/lib/esm/webchat/devices/scrollbar-controller.d.ts +0 -12
  242. package/lib/esm/webchat/devices/scrollbar-controller.js +0 -99
  243. package/lib/esm/webchat/devices/scrollbar-controller.js.map +0 -1
  244. package/lib/esm/webchat/devices/webchat-resizer.d.ts +0 -9
  245. package/lib/esm/webchat/devices/webchat-resizer.js +0 -43
  246. package/lib/esm/webchat/devices/webchat-resizer.js.map +0 -1
  247. package/lib/esm/webchat/header.d.ts +0 -3
  248. package/lib/esm/webchat/header.js +0 -79
  249. package/lib/esm/webchat/header.js.map +0 -1
  250. package/lib/esm/webchat/hooks/index.d.ts +0 -5
  251. package/lib/esm/webchat/hooks/index.js +0 -6
  252. package/lib/esm/webchat/hooks/index.js.map +0 -1
  253. package/lib/esm/webchat/hooks/use-component-visible.d.ts +0 -8
  254. package/lib/esm/webchat/hooks/use-component-visible.js +0 -20
  255. package/lib/esm/webchat/hooks/use-component-visible.js.map +0 -1
  256. package/lib/esm/webchat/hooks/use-component-will-mount.d.ts +0 -1
  257. package/lib/esm/webchat/hooks/use-component-will-mount.js +0 -5
  258. package/lib/esm/webchat/hooks/use-component-will-mount.js.map +0 -1
  259. package/lib/esm/webchat/hooks/use-previous.d.ts +0 -1
  260. package/lib/esm/webchat/hooks/use-previous.js +0 -9
  261. package/lib/esm/webchat/hooks/use-previous.js.map +0 -1
  262. package/lib/esm/webchat/hooks/use-typing.d.ts +0 -10
  263. package/lib/esm/webchat/hooks/use-typing.js +0 -26
  264. package/lib/esm/webchat/hooks/use-typing.js.map +0 -1
  265. package/lib/esm/webchat/hooks/use-webchat.d.ts +0 -41
  266. package/lib/esm/webchat/hooks/use-webchat.js +0 -177
  267. package/lib/esm/webchat/hooks/use-webchat.js.map +0 -1
  268. package/lib/esm/webchat/index-types.d.ts +0 -62
  269. package/lib/esm/webchat/index-types.js +0 -2
  270. package/lib/esm/webchat/index-types.js.map +0 -1
  271. package/lib/esm/webchat/index.d.ts +0 -4
  272. package/lib/esm/webchat/index.js +0 -10
  273. package/lib/esm/webchat/index.js.map +0 -1
  274. package/lib/esm/webchat/message-list/index.d.ts +0 -1
  275. package/lib/esm/webchat/message-list/index.js +0 -73
  276. package/lib/esm/webchat/message-list/index.js.map +0 -1
  277. package/lib/esm/webchat/message-list/intro-message.d.ts +0 -1
  278. package/lib/esm/webchat/message-list/intro-message.js +0 -18
  279. package/lib/esm/webchat/message-list/intro-message.js.map +0 -1
  280. package/lib/esm/webchat/message-list/scroll-button.d.ts +0 -5
  281. package/lib/esm/webchat/message-list/scroll-button.js +0 -17
  282. package/lib/esm/webchat/message-list/scroll-button.js.map +0 -1
  283. package/lib/esm/webchat/message-list/styles.d.ts +0 -4
  284. package/lib/esm/webchat/message-list/styles.js +0 -46
  285. package/lib/esm/webchat/message-list/styles.js.map +0 -1
  286. package/lib/esm/webchat/message-list/unread-messages-banner.d.ts +0 -6
  287. package/lib/esm/webchat/message-list/unread-messages-banner.js +0 -16
  288. package/lib/esm/webchat/message-list/unread-messages-banner.js.map +0 -1
  289. package/lib/esm/webchat/message-list/use-debounce.d.ts +0 -1
  290. package/lib/esm/webchat/message-list/use-debounce.js +0 -14
  291. package/lib/esm/webchat/message-list/use-debounce.js.map +0 -1
  292. package/lib/esm/webchat/messages-reducer.d.ts +0 -6
  293. package/lib/esm/webchat/messages-reducer.js +0 -82
  294. package/lib/esm/webchat/messages-reducer.js.map +0 -1
  295. package/lib/esm/webchat/replies.d.ts +0 -1
  296. package/lib/esm/webchat/replies.js +0 -38
  297. package/lib/esm/webchat/replies.js.map +0 -1
  298. package/lib/esm/webchat/session-view.d.ts +0 -1
  299. package/lib/esm/webchat/session-view.js +0 -96
  300. package/lib/esm/webchat/session-view.js.map +0 -1
  301. package/lib/esm/webchat/trigger-button/index.d.ts +0 -1
  302. package/lib/esm/webchat/trigger-button/index.js +0 -28
  303. package/lib/esm/webchat/trigger-button/index.js.map +0 -1
  304. package/lib/esm/webchat/trigger-button/styles.d.ts +0 -3
  305. package/lib/esm/webchat/trigger-button/styles.js +0 -36
  306. package/lib/esm/webchat/trigger-button/styles.js.map +0 -1
  307. package/lib/esm/webchat/use-storage-state-hook.d.ts +0 -1
  308. package/lib/esm/webchat/use-storage-state-hook.js +0 -38
  309. package/lib/esm/webchat/use-storage-state-hook.js.map +0 -1
  310. package/lib/esm/webchat/webchat-dev.d.ts +0 -7
  311. package/lib/esm/webchat/webchat-dev.js +0 -56
  312. package/lib/esm/webchat/webchat-dev.js.map +0 -1
  313. package/lib/esm/webchat/webchat-reducer.d.ts +0 -6
  314. package/lib/esm/webchat/webchat-reducer.js +0 -46
  315. package/lib/esm/webchat/webchat-reducer.js.map +0 -1
  316. package/lib/esm/webchat/webchat.d.ts +0 -3
  317. package/lib/esm/webchat/webchat.js +0 -637
  318. package/lib/esm/webchat/webchat.js.map +0 -1
  319. package/lib/esm/webchat/webview.d.ts +0 -2
  320. package/lib/esm/webchat/webview.js +0 -78
  321. package/lib/esm/webchat/webview.js.map +0 -1
  322. package/lib/esm/webchat-app.d.ts +0 -99
  323. package/lib/esm/webchat-app.js +0 -282
  324. package/lib/esm/webchat-app.js.map +0 -1
  325. package/lib/esm/webview-app.d.ts +0 -7
  326. package/lib/esm/webview-app.js +0 -97
  327. package/lib/esm/webview-app.js.map +0 -1
  328. package/src/.DS_Store +0 -0
@@ -1,637 +0,0 @@
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