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

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 (359) hide show
  1. package/lib/cjs/components/index-types.d.ts +3 -1
  2. package/lib/cjs/components/index-types.js.map +1 -1
  3. package/lib/cjs/components/{message.js → message/index.js} +20 -66
  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 +23 -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 +77 -0
  10. package/lib/cjs/components/message/styles.js.map +1 -0
  11. package/lib/cjs/components/message/timestamps.d.ts +13 -0
  12. package/lib/cjs/components/message/timestamps.js +45 -0
  13. package/lib/cjs/components/message/timestamps.js.map +1 -0
  14. package/lib/cjs/constants.d.ts +2 -0
  15. package/lib/cjs/constants.js +3 -0
  16. package/lib/cjs/constants.js.map +1 -1
  17. package/lib/cjs/index-types.d.ts +1 -1
  18. package/lib/cjs/webchat/components/styled-scrollbar.js +1 -1
  19. package/lib/cjs/webchat/components/styled-scrollbar.js.map +1 -1
  20. package/lib/cjs/webchat/devices/device-adapter.js +0 -4
  21. package/lib/cjs/webchat/devices/device-adapter.js.map +1 -1
  22. package/lib/cjs/webchat/message-list/index.js +1 -1
  23. package/lib/cjs/webchat/message-list/index.js.map +1 -1
  24. package/lib/cjs/webchat/message-list/unread-messages-banner.js +8 -0
  25. package/lib/cjs/webchat/message-list/unread-messages-banner.js.map +1 -1
  26. package/lib/cjs/webchat/replies.js +1 -1
  27. package/lib/cjs/webchat/replies.js.map +1 -1
  28. package/lib/cjs/webchat/trigger-button/index.js +3 -2
  29. package/lib/cjs/webchat/trigger-button/index.js.map +1 -1
  30. package/lib/cjs/webchat/webchat.js +1 -3
  31. package/lib/cjs/webchat/webchat.js.map +1 -1
  32. package/lib/esm/app.d.ts +2 -0
  33. package/lib/esm/app.js +6 -0
  34. package/lib/esm/app.js.map +1 -0
  35. package/lib/esm/assets/index-types.d.ts +4 -0
  36. package/lib/esm/assets/index-types.js +2 -0
  37. package/lib/esm/assets/index-types.js.map +1 -0
  38. package/lib/esm/botonic-tester.d.ts +18 -0
  39. package/lib/esm/botonic-tester.js +62 -0
  40. package/lib/esm/botonic-tester.js.map +1 -0
  41. package/lib/esm/components/audio.d.ts +8 -0
  42. package/lib/esm/components/audio.js +18 -0
  43. package/lib/esm/components/audio.js.map +1 -0
  44. package/lib/esm/components/button.d.ts +15 -0
  45. package/lib/esm/components/button.js +140 -0
  46. package/lib/esm/components/button.js.map +1 -0
  47. package/lib/esm/components/buttons-disabler.d.ts +24 -0
  48. package/lib/esm/components/buttons-disabler.js +84 -0
  49. package/lib/esm/components/buttons-disabler.js.map +1 -0
  50. package/lib/esm/components/carousel.d.ts +10 -0
  51. package/lib/esm/components/carousel.js +102 -0
  52. package/lib/esm/components/carousel.js.map +1 -0
  53. package/lib/esm/components/components.d.ts +12 -0
  54. package/lib/esm/components/components.js +17 -0
  55. package/lib/esm/components/components.js.map +1 -0
  56. package/lib/esm/components/custom-message.d.ts +12 -0
  57. package/lib/esm/components/custom-message.js +55 -0
  58. package/lib/esm/components/custom-message.js.map +1 -0
  59. package/lib/esm/components/document.d.ts +8 -0
  60. package/lib/esm/components/document.js +42 -0
  61. package/lib/esm/components/document.js.map +1 -0
  62. package/lib/esm/components/element.d.ts +4 -0
  63. package/lib/esm/components/element.js +51 -0
  64. package/lib/esm/components/element.js.map +1 -0
  65. package/lib/esm/components/handoff.d.ts +1 -0
  66. package/lib/esm/components/handoff.js +49 -0
  67. package/lib/esm/components/handoff.js.map +1 -0
  68. package/lib/esm/components/image.d.ts +8 -0
  69. package/lib/esm/components/image.js +35 -0
  70. package/lib/esm/components/image.js.map +1 -0
  71. package/lib/esm/components/index-types.d.ts +191 -0
  72. package/lib/esm/components/index-types.js +16 -0
  73. package/lib/esm/components/index-types.js.map +1 -0
  74. package/lib/esm/components/index.d.ts +23 -0
  75. package/lib/esm/components/index.js +24 -0
  76. package/lib/esm/components/index.js.map +1 -0
  77. package/lib/esm/components/location.d.ts +11 -0
  78. package/lib/esm/components/location.js +27 -0
  79. package/lib/esm/components/location.js.map +1 -0
  80. package/lib/esm/components/markdown.d.ts +7 -0
  81. package/lib/esm/components/markdown.js +152 -0
  82. package/lib/esm/components/markdown.js.map +1 -0
  83. package/lib/esm/components/message/index.d.ts +1 -0
  84. package/lib/esm/components/message/index.js +142 -0
  85. package/lib/esm/components/message/index.js.map +1 -0
  86. package/lib/esm/components/message/message-image.d.ts +7 -0
  87. package/lib/esm/components/message/message-image.js +19 -0
  88. package/lib/esm/components/message/message-image.js.map +1 -0
  89. package/lib/esm/components/message/styles.d.ts +8 -0
  90. package/lib/esm/components/message/styles.js +73 -0
  91. package/lib/esm/components/message/styles.js.map +1 -0
  92. package/lib/esm/components/message/timestamps.d.ts +13 -0
  93. package/lib/esm/components/message/timestamps.js +40 -0
  94. package/lib/esm/components/message/timestamps.js.map +1 -0
  95. package/lib/esm/components/message-template.d.ts +1 -0
  96. package/lib/esm/components/message-template.js +9 -0
  97. package/lib/esm/components/message-template.js.map +1 -0
  98. package/lib/esm/components/multichannel/facebook/facebook.d.ts +17 -0
  99. package/lib/esm/components/multichannel/facebook/facebook.js +43 -0
  100. package/lib/esm/components/multichannel/facebook/facebook.js.map +1 -0
  101. package/lib/esm/components/multichannel/index-types.d.ts +46 -0
  102. package/lib/esm/components/multichannel/index-types.js +2 -0
  103. package/lib/esm/components/multichannel/index-types.js.map +1 -0
  104. package/lib/esm/components/multichannel/index.d.ts +11 -0
  105. package/lib/esm/components/multichannel/index.js +12 -0
  106. package/lib/esm/components/multichannel/index.js.map +1 -0
  107. package/lib/esm/components/multichannel/multichannel-button.d.ts +1 -0
  108. package/lib/esm/components/multichannel/multichannel-button.js +71 -0
  109. package/lib/esm/components/multichannel/multichannel-button.js.map +1 -0
  110. package/lib/esm/components/multichannel/multichannel-carousel.d.ts +1 -0
  111. package/lib/esm/components/multichannel/multichannel-carousel.js +73 -0
  112. package/lib/esm/components/multichannel/multichannel-carousel.js.map +1 -0
  113. package/lib/esm/components/multichannel/multichannel-context.d.ts +11 -0
  114. package/lib/esm/components/multichannel/multichannel-context.js +12 -0
  115. package/lib/esm/components/multichannel/multichannel-context.js.map +1 -0
  116. package/lib/esm/components/multichannel/multichannel-reply.d.ts +1 -0
  117. package/lib/esm/components/multichannel/multichannel-reply.js +20 -0
  118. package/lib/esm/components/multichannel/multichannel-reply.js.map +1 -0
  119. package/lib/esm/components/multichannel/multichannel-text.d.ts +1 -0
  120. package/lib/esm/components/multichannel/multichannel-text.js +153 -0
  121. package/lib/esm/components/multichannel/multichannel-text.js.map +1 -0
  122. package/lib/esm/components/multichannel/multichannel-utils.d.ts +26 -0
  123. package/lib/esm/components/multichannel/multichannel-utils.js +69 -0
  124. package/lib/esm/components/multichannel/multichannel-utils.js.map +1 -0
  125. package/lib/esm/components/multichannel/multichannel.d.ts +1 -0
  126. package/lib/esm/components/multichannel/multichannel.js +55 -0
  127. package/lib/esm/components/multichannel/multichannel.js.map +1 -0
  128. package/lib/esm/components/multichannel/whatsapp/markdown.d.ts +1 -0
  129. package/lib/esm/components/multichannel/whatsapp/markdown.js +53 -0
  130. package/lib/esm/components/multichannel/whatsapp/markdown.js.map +1 -0
  131. package/lib/esm/components/pic.d.ts +6 -0
  132. package/lib/esm/components/pic.js +25 -0
  133. package/lib/esm/components/pic.js.map +1 -0
  134. package/lib/esm/components/raw.d.ts +9 -0
  135. package/lib/esm/components/raw.js +39 -0
  136. package/lib/esm/components/raw.js.map +1 -0
  137. package/lib/esm/components/reply.d.ts +9 -0
  138. package/lib/esm/components/reply.js +49 -0
  139. package/lib/esm/components/reply.js.map +1 -0
  140. package/lib/esm/components/share-button.d.ts +1 -0
  141. package/lib/esm/components/share-button.js +9 -0
  142. package/lib/esm/components/share-button.js.map +1 -0
  143. package/lib/esm/components/subtitle.d.ts +6 -0
  144. package/lib/esm/components/subtitle.js +19 -0
  145. package/lib/esm/components/subtitle.js.map +1 -0
  146. package/lib/esm/components/text.d.ts +8 -0
  147. package/lib/esm/components/text.js +42 -0
  148. package/lib/esm/components/text.js.map +1 -0
  149. package/lib/esm/components/title.d.ts +6 -0
  150. package/lib/esm/components/title.js +17 -0
  151. package/lib/esm/components/title.js.map +1 -0
  152. package/lib/esm/components/video.d.ts +8 -0
  153. package/lib/esm/components/video.js +26 -0
  154. package/lib/esm/components/video.js.map +1 -0
  155. package/lib/esm/components/webchat-settings.d.ts +3 -0
  156. package/lib/esm/components/webchat-settings.js +69 -0
  157. package/lib/esm/components/webchat-settings.js.map +1 -0
  158. package/lib/esm/components/whatsapp-button-list.d.ts +17 -0
  159. package/lib/esm/components/whatsapp-button-list.js +22 -0
  160. package/lib/esm/components/whatsapp-button-list.js.map +1 -0
  161. package/lib/esm/components/whatsapp-template.d.ts +1 -0
  162. package/lib/esm/components/whatsapp-template.js +20 -0
  163. package/lib/esm/components/whatsapp-template.js.map +1 -0
  164. package/lib/esm/constants.d.ts +174 -0
  165. package/lib/esm/constants.js +195 -0
  166. package/lib/esm/constants.js.map +1 -0
  167. package/lib/esm/contexts.d.ts +12 -0
  168. package/lib/esm/contexts.js +67 -0
  169. package/lib/esm/contexts.js.map +1 -0
  170. package/lib/esm/dev-app.d.ts +30 -0
  171. package/lib/esm/dev-app.js +74 -0
  172. package/lib/esm/dev-app.js.map +1 -0
  173. package/lib/esm/index-types.d.ts +128 -0
  174. package/lib/esm/index-types.js +12 -0
  175. package/lib/esm/index-types.js.map +1 -0
  176. package/lib/esm/index.d.ts +11 -0
  177. package/lib/esm/index.js +12 -0
  178. package/lib/esm/index.js.map +1 -0
  179. package/lib/esm/message-utils.d.ts +19 -0
  180. package/lib/esm/message-utils.js +41 -0
  181. package/lib/esm/message-utils.js.map +1 -0
  182. package/lib/esm/msg-to-botonic.d.ts +18 -0
  183. package/lib/esm/msg-to-botonic.js +135 -0
  184. package/lib/esm/msg-to-botonic.js.map +1 -0
  185. package/lib/esm/node-app.d.ts +12 -0
  186. package/lib/esm/node-app.js +21 -0
  187. package/lib/esm/node-app.js.map +1 -0
  188. package/lib/esm/react-bot.d.ts +8 -0
  189. package/lib/esm/react-bot.js +29 -0
  190. package/lib/esm/react-bot.js.map +1 -0
  191. package/lib/esm/util/dom.d.ts +13 -0
  192. package/lib/esm/util/dom.js +46 -0
  193. package/lib/esm/util/dom.js.map +1 -0
  194. package/lib/esm/util/environment.d.ts +6 -0
  195. package/lib/esm/util/environment.js +61 -0
  196. package/lib/esm/util/environment.js.map +1 -0
  197. package/lib/esm/util/error-boundary.d.ts +7 -0
  198. package/lib/esm/util/error-boundary.js +28 -0
  199. package/lib/esm/util/error-boundary.js.map +1 -0
  200. package/lib/esm/util/index.d.ts +8 -0
  201. package/lib/esm/util/index.js +9 -0
  202. package/lib/esm/util/index.js.map +1 -0
  203. package/lib/esm/util/logs.d.ts +2 -0
  204. package/lib/esm/util/logs.js +15 -0
  205. package/lib/esm/util/logs.js.map +1 -0
  206. package/lib/esm/util/objects.d.ts +3 -0
  207. package/lib/esm/util/objects.js +38 -0
  208. package/lib/esm/util/objects.js.map +1 -0
  209. package/lib/esm/util/react.d.ts +12 -0
  210. package/lib/esm/util/react.js +34 -0
  211. package/lib/esm/util/react.js.map +1 -0
  212. package/lib/esm/util/regexs.d.ts +2 -0
  213. package/lib/esm/util/regexs.js +18 -0
  214. package/lib/esm/util/regexs.js.map +1 -0
  215. package/lib/esm/util/webchat.d.ts +11 -0
  216. package/lib/esm/util/webchat.js +53 -0
  217. package/lib/esm/util/webchat.js.map +1 -0
  218. package/lib/esm/webchat/actions.d.ts +27 -0
  219. package/lib/esm/webchat/actions.js +29 -0
  220. package/lib/esm/webchat/actions.js.map +1 -0
  221. package/lib/esm/webchat/components/attachment.d.ts +5 -0
  222. package/lib/esm/webchat/components/attachment.js +24 -0
  223. package/lib/esm/webchat/components/attachment.js.map +1 -0
  224. package/lib/esm/webchat/components/common.d.ts +1 -0
  225. package/lib/esm/webchat/components/common.js +9 -0
  226. package/lib/esm/webchat/components/common.js.map +1 -0
  227. package/lib/esm/webchat/components/conditional-animation.d.ts +1 -0
  228. package/lib/esm/webchat/components/conditional-animation.js +12 -0
  229. package/lib/esm/webchat/components/conditional-animation.js.map +1 -0
  230. package/lib/esm/webchat/components/emoji-picker.d.ts +5 -0
  231. package/lib/esm/webchat/components/emoji-picker.js +37 -0
  232. package/lib/esm/webchat/components/emoji-picker.js.map +1 -0
  233. package/lib/esm/webchat/components/persistent-menu.d.ts +10 -0
  234. package/lib/esm/webchat/components/persistent-menu.js +39 -0
  235. package/lib/esm/webchat/components/persistent-menu.js.map +1 -0
  236. package/lib/esm/webchat/components/send-button.d.ts +3 -0
  237. package/lib/esm/webchat/components/send-button.js +14 -0
  238. package/lib/esm/webchat/components/send-button.js.map +1 -0
  239. package/lib/esm/webchat/components/styled-scrollbar.d.ts +1 -0
  240. package/lib/esm/webchat/components/styled-scrollbar.js +50 -0
  241. package/lib/esm/webchat/components/styled-scrollbar.js.map +1 -0
  242. package/lib/esm/webchat/components/typing-indicator.d.ts +1 -0
  243. package/lib/esm/webchat/components/typing-indicator.js +6 -0
  244. package/lib/esm/webchat/components/typing-indicator.js.map +1 -0
  245. package/lib/esm/webchat/devices/device-adapter.d.ts +12 -0
  246. package/lib/esm/webchat/devices/device-adapter.js +39 -0
  247. package/lib/esm/webchat/devices/device-adapter.js.map +1 -0
  248. package/lib/esm/webchat/devices/index.d.ts +11 -0
  249. package/lib/esm/webchat/devices/index.js +18 -0
  250. package/lib/esm/webchat/devices/index.js.map +1 -0
  251. package/lib/esm/webchat/devices/scrollbar-controller.d.ts +12 -0
  252. package/lib/esm/webchat/devices/scrollbar-controller.js +99 -0
  253. package/lib/esm/webchat/devices/scrollbar-controller.js.map +1 -0
  254. package/lib/esm/webchat/devices/webchat-resizer.d.ts +9 -0
  255. package/lib/esm/webchat/devices/webchat-resizer.js +43 -0
  256. package/lib/esm/webchat/devices/webchat-resizer.js.map +1 -0
  257. package/lib/esm/webchat/header.d.ts +3 -0
  258. package/lib/esm/webchat/header.js +79 -0
  259. package/lib/esm/webchat/header.js.map +1 -0
  260. package/lib/esm/webchat/hooks/index.d.ts +5 -0
  261. package/lib/esm/webchat/hooks/index.js +6 -0
  262. package/lib/esm/webchat/hooks/index.js.map +1 -0
  263. package/lib/esm/webchat/hooks/use-component-visible.d.ts +8 -0
  264. package/lib/esm/webchat/hooks/use-component-visible.js +20 -0
  265. package/lib/esm/webchat/hooks/use-component-visible.js.map +1 -0
  266. package/lib/esm/webchat/hooks/use-component-will-mount.d.ts +1 -0
  267. package/lib/esm/webchat/hooks/use-component-will-mount.js +5 -0
  268. package/lib/esm/webchat/hooks/use-component-will-mount.js.map +1 -0
  269. package/lib/esm/webchat/hooks/use-previous.d.ts +1 -0
  270. package/lib/esm/webchat/hooks/use-previous.js +9 -0
  271. package/lib/esm/webchat/hooks/use-previous.js.map +1 -0
  272. package/lib/esm/webchat/hooks/use-typing.d.ts +10 -0
  273. package/lib/esm/webchat/hooks/use-typing.js +26 -0
  274. package/lib/esm/webchat/hooks/use-typing.js.map +1 -0
  275. package/lib/esm/webchat/hooks/use-webchat.d.ts +41 -0
  276. package/lib/esm/webchat/hooks/use-webchat.js +177 -0
  277. package/lib/esm/webchat/hooks/use-webchat.js.map +1 -0
  278. package/lib/esm/webchat/index-types.d.ts +62 -0
  279. package/lib/esm/webchat/index-types.js +2 -0
  280. package/lib/esm/webchat/index-types.js.map +1 -0
  281. package/lib/esm/webchat/index.d.ts +4 -0
  282. package/lib/esm/webchat/index.js +10 -0
  283. package/lib/esm/webchat/index.js.map +1 -0
  284. package/lib/esm/webchat/message-list/index.d.ts +1 -0
  285. package/lib/esm/webchat/message-list/index.js +73 -0
  286. package/lib/esm/webchat/message-list/index.js.map +1 -0
  287. package/lib/esm/webchat/message-list/intro-message.d.ts +1 -0
  288. package/lib/esm/webchat/message-list/intro-message.js +18 -0
  289. package/lib/esm/webchat/message-list/intro-message.js.map +1 -0
  290. package/lib/esm/webchat/message-list/scroll-button.d.ts +5 -0
  291. package/lib/esm/webchat/message-list/scroll-button.js +17 -0
  292. package/lib/esm/webchat/message-list/scroll-button.js.map +1 -0
  293. package/lib/esm/webchat/message-list/styles.d.ts +4 -0
  294. package/lib/esm/webchat/message-list/styles.js +46 -0
  295. package/lib/esm/webchat/message-list/styles.js.map +1 -0
  296. package/lib/esm/webchat/message-list/unread-messages-banner.d.ts +6 -0
  297. package/lib/esm/webchat/message-list/unread-messages-banner.js +24 -0
  298. package/lib/esm/webchat/message-list/unread-messages-banner.js.map +1 -0
  299. package/lib/esm/webchat/message-list/use-debounce.d.ts +1 -0
  300. package/lib/esm/webchat/message-list/use-debounce.js +14 -0
  301. package/lib/esm/webchat/message-list/use-debounce.js.map +1 -0
  302. package/lib/esm/webchat/messages-reducer.d.ts +6 -0
  303. package/lib/esm/webchat/messages-reducer.js +82 -0
  304. package/lib/esm/webchat/messages-reducer.js.map +1 -0
  305. package/lib/esm/webchat/replies.d.ts +1 -0
  306. package/lib/esm/webchat/replies.js +38 -0
  307. package/lib/esm/webchat/replies.js.map +1 -0
  308. package/lib/esm/webchat/session-view.d.ts +1 -0
  309. package/lib/esm/webchat/session-view.js +96 -0
  310. package/lib/esm/webchat/session-view.js.map +1 -0
  311. package/lib/esm/webchat/trigger-button/index.d.ts +1 -0
  312. package/lib/esm/webchat/trigger-button/index.js +28 -0
  313. package/lib/esm/webchat/trigger-button/index.js.map +1 -0
  314. package/lib/esm/webchat/trigger-button/styles.d.ts +3 -0
  315. package/lib/esm/webchat/trigger-button/styles.js +36 -0
  316. package/lib/esm/webchat/trigger-button/styles.js.map +1 -0
  317. package/lib/esm/webchat/use-storage-state-hook.d.ts +1 -0
  318. package/lib/esm/webchat/use-storage-state-hook.js +38 -0
  319. package/lib/esm/webchat/use-storage-state-hook.js.map +1 -0
  320. package/lib/esm/webchat/webchat-dev.d.ts +7 -0
  321. package/lib/esm/webchat/webchat-dev.js +56 -0
  322. package/lib/esm/webchat/webchat-dev.js.map +1 -0
  323. package/lib/esm/webchat/webchat-reducer.d.ts +6 -0
  324. package/lib/esm/webchat/webchat-reducer.js +46 -0
  325. package/lib/esm/webchat/webchat-reducer.js.map +1 -0
  326. package/lib/esm/webchat/webchat.d.ts +3 -0
  327. package/lib/esm/webchat/webchat.js +635 -0
  328. package/lib/esm/webchat/webchat.js.map +1 -0
  329. package/lib/esm/webchat/webview.d.ts +2 -0
  330. package/lib/esm/webchat/webview.js +78 -0
  331. package/lib/esm/webchat/webview.js.map +1 -0
  332. package/lib/esm/webchat-app.d.ts +99 -0
  333. package/lib/esm/webchat-app.js +281 -0
  334. package/lib/esm/webchat-app.js.map +1 -0
  335. package/lib/esm/webview-app.d.ts +7 -0
  336. package/lib/esm/webview-app.js +95 -0
  337. package/lib/esm/webview-app.js.map +1 -0
  338. package/package.json +2 -2
  339. package/src/.DS_Store +0 -0
  340. package/src/components/index-types.ts +3 -1
  341. package/src/components/{message.jsx → message/index.jsx} +27 -93
  342. package/src/components/message/message-image.tsx +56 -0
  343. package/src/components/message/styles.ts +81 -0
  344. package/src/components/message/timestamps.tsx +100 -0
  345. package/src/constants.js +3 -0
  346. package/src/index-types.ts +1 -1
  347. package/src/webchat/components/styled-scrollbar.jsx +1 -1
  348. package/src/webchat/devices/device-adapter.js +0 -4
  349. package/src/webchat/message-list/index.tsx +1 -1
  350. package/src/webchat/message-list/unread-messages-banner.tsx +10 -1
  351. package/src/webchat/replies.jsx +1 -3
  352. package/src/webchat/trigger-button/index.tsx +10 -5
  353. package/src/webchat/webchat.jsx +4 -4
  354. package/lib/cjs/components/message.js.map +0 -1
  355. package/lib/cjs/components/timestamps.d.ts +0 -10
  356. package/lib/cjs/components/timestamps.js +0 -51
  357. package/lib/cjs/components/timestamps.js.map +0 -1
  358. package/src/components/timestamps.jsx +0 -68
  359. /package/lib/cjs/components/{message.d.ts → message/index.d.ts} +0 -0
@@ -0,0 +1,177 @@
1
+ import { useReducer } from 'react';
2
+ import { COLORS, WEBCHAT } from '../../constants';
3
+ import { WebchatAction } from '../actions';
4
+ import { webchatReducer } from '../webchat-reducer';
5
+ export const webchatInitialState = {
6
+ width: WEBCHAT.DEFAULTS.WIDTH,
7
+ height: WEBCHAT.DEFAULTS.HEIGHT,
8
+ messagesJSON: [],
9
+ messagesComponents: [],
10
+ replies: [],
11
+ latestInput: {},
12
+ typing: false,
13
+ webview: null,
14
+ webviewParams: null,
15
+ session: { user: undefined },
16
+ lastRoutePath: null,
17
+ handoff: false,
18
+ theme: {
19
+ headerTitle: WEBCHAT.DEFAULTS.TITLE,
20
+ brandColor: COLORS.BOTONIC_BLUE,
21
+ brandImage: WEBCHAT.DEFAULTS.LOGO,
22
+ triggerButtonImage: undefined,
23
+ textPlaceholder: WEBCHAT.DEFAULTS.PLACEHOLDER,
24
+ style: {
25
+ fontFamily: WEBCHAT.DEFAULTS.FONT_FAMILY,
26
+ },
27
+ },
28
+ themeUpdates: {},
29
+ error: {},
30
+ online: true,
31
+ devSettings: { keepSessionOnReload: false },
32
+ isWebchatOpen: false,
33
+ isEmojiPickerOpen: false,
34
+ isPersistentMenuOpen: false,
35
+ isCoverComponentOpen: false,
36
+ isCustomComponentRendered: false,
37
+ lastMessageUpdate: undefined,
38
+ currentAttachment: undefined,
39
+ jwt: undefined,
40
+ numUnreadMessages: 0,
41
+ isLastMessageVisible: true,
42
+ };
43
+ export function useWebchat() {
44
+ const [webchatState, webchatDispatch] = useReducer(webchatReducer, webchatInitialState);
45
+ const addMessage = (message) => webchatDispatch({ type: WebchatAction.ADD_MESSAGE, payload: message });
46
+ const addMessageComponent = (message) => webchatDispatch({
47
+ type: WebchatAction.ADD_MESSAGE_COMPONENT,
48
+ payload: message,
49
+ });
50
+ const updateMessage = (message) => webchatDispatch({ type: WebchatAction.UPDATE_MESSAGE, payload: message });
51
+ const updateReplies = replies => webchatDispatch({ type: WebchatAction.UPDATE_REPLIES, payload: replies });
52
+ const updateLatestInput = (input) => webchatDispatch({ type: WebchatAction.UPDATE_LATEST_INPUT, payload: input });
53
+ const updateTyping = (typing) => webchatDispatch({ type: WebchatAction.UPDATE_TYPING, payload: typing });
54
+ const updateWebview = (webview, params) => webchatDispatch({
55
+ type: WebchatAction.UPDATE_WEBVIEW,
56
+ payload: { webview, webviewParams: params },
57
+ });
58
+ const updateSession = (session) => {
59
+ webchatDispatch({
60
+ type: WebchatAction.UPDATE_SESSION,
61
+ payload: session,
62
+ });
63
+ };
64
+ const updateLastRoutePath = (path) => webchatDispatch({
65
+ type: WebchatAction.UPDATE_LAST_ROUTE_PATH,
66
+ payload: path,
67
+ });
68
+ const updateHandoff = (handoff) => webchatDispatch({
69
+ type: WebchatAction.UPDATE_HANDOFF,
70
+ payload: handoff,
71
+ });
72
+ const updateTheme = (theme, themeUpdates) => {
73
+ const payload = themeUpdates !== undefined ? { theme, themeUpdates } : { theme };
74
+ webchatDispatch({
75
+ type: WebchatAction.UPDATE_THEME,
76
+ payload,
77
+ });
78
+ };
79
+ const updateDevSettings = (settings) => webchatDispatch({
80
+ type: WebchatAction.UPDATE_DEV_SETTINGS,
81
+ payload: settings,
82
+ });
83
+ const toggleWebchat = (toggle) => {
84
+ webchatDispatch({
85
+ type: WebchatAction.TOGGLE_WEBCHAT,
86
+ payload: toggle,
87
+ });
88
+ };
89
+ const toggleEmojiPicker = (toggle) => webchatDispatch({
90
+ type: WebchatAction.TOGGLE_EMOJI_PICKER,
91
+ payload: toggle,
92
+ });
93
+ const togglePersistentMenu = (toggle) => webchatDispatch({
94
+ type: WebchatAction.TOGGLE_PERSISTENT_MENU,
95
+ payload: toggle,
96
+ });
97
+ const toggleCoverComponent = (toggle) => webchatDispatch({
98
+ type: WebchatAction.TOGGLE_COVER_COMPONENT,
99
+ payload: toggle,
100
+ });
101
+ const doRenderCustomComponent = (toggle) => webchatDispatch({
102
+ type: WebchatAction.DO_RENDER_CUSTOM_COMPONENT,
103
+ payload: toggle,
104
+ });
105
+ const setError = (error) => webchatDispatch({
106
+ type: WebchatAction.SET_ERROR,
107
+ payload: error,
108
+ });
109
+ const setOnline = (online) => webchatDispatch({
110
+ type: WebchatAction.SET_ONLINE,
111
+ payload: online,
112
+ });
113
+ const clearMessages = () => {
114
+ webchatDispatch({
115
+ type: WebchatAction.CLEAR_MESSAGES,
116
+ });
117
+ };
118
+ const updateLastMessageDate = (date) => {
119
+ webchatDispatch({
120
+ type: WebchatAction.UPDATE_LAST_MESSAGE_DATE,
121
+ payload: date,
122
+ });
123
+ };
124
+ const setCurrentAttachment = (attachment) => {
125
+ webchatDispatch({
126
+ type: WebchatAction.SET_CURRENT_ATTACHMENT,
127
+ payload: attachment,
128
+ });
129
+ };
130
+ const updateJwt = (jwt) => {
131
+ webchatDispatch({
132
+ type: WebchatAction.UPDATE_JWT,
133
+ payload: jwt,
134
+ });
135
+ };
136
+ const resetUnreadMessages = () => {
137
+ webchatDispatch({
138
+ type: WebchatAction.RESET_UNREAD_MESSAGES,
139
+ });
140
+ };
141
+ const setLastMessageVisible = (isLastMessageVisible) => {
142
+ webchatDispatch({
143
+ type: WebchatAction.SET_LAST_MESSAGE_VISIBLE,
144
+ payload: isLastMessageVisible,
145
+ });
146
+ };
147
+ return {
148
+ addMessage,
149
+ addMessageComponent,
150
+ clearMessages,
151
+ doRenderCustomComponent,
152
+ resetUnreadMessages,
153
+ setCurrentAttachment,
154
+ setError,
155
+ setLastMessageVisible,
156
+ setOnline,
157
+ toggleCoverComponent,
158
+ toggleEmojiPicker,
159
+ togglePersistentMenu,
160
+ toggleWebchat,
161
+ updateDevSettings,
162
+ updateHandoff,
163
+ updateJwt,
164
+ updateLastMessageDate,
165
+ updateLastRoutePath,
166
+ updateLatestInput,
167
+ updateMessage,
168
+ updateReplies,
169
+ updateSession,
170
+ updateTheme,
171
+ updateTyping,
172
+ updateWebview,
173
+ webchatDispatch,
174
+ webchatState,
175
+ };
176
+ }
177
+ //# sourceMappingURL=use-webchat.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-webchat.js","sourceRoot":"src/","sources":["webchat/hooks/use-webchat.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,62 @@
1
+ import type { Input as CoreInput, Session as CoreSession } from '@botonic/core';
2
+ import { RefObject } from 'react';
3
+ import { Webview } from '../components/index-types';
4
+ export interface WebchatStateTheme {
5
+ headerTitle: string;
6
+ brandColor: string;
7
+ brandImage: string;
8
+ triggerButtonImage: undefined;
9
+ textPlaceholder: string;
10
+ style: {
11
+ fontFamily: string;
12
+ };
13
+ }
14
+ export interface ErrorMessage {
15
+ message?: string;
16
+ }
17
+ export interface DevSettings {
18
+ keepSessionOnReload?: boolean;
19
+ showSessionView?: boolean;
20
+ }
21
+ export interface WebchatState {
22
+ width: number;
23
+ height: number;
24
+ messagesJSON: any[];
25
+ messagesComponents: any[];
26
+ replies: any[];
27
+ latestInput: Partial<CoreInput>;
28
+ typing: boolean;
29
+ webview: Webview | null;
30
+ webviewParams: null;
31
+ session: Partial<CoreSession>;
32
+ lastRoutePath: string | null;
33
+ handoff: boolean;
34
+ theme: WebchatStateTheme;
35
+ themeUpdates: Partial<WebchatStateTheme>;
36
+ error: ErrorMessage;
37
+ online: boolean;
38
+ devSettings: DevSettings;
39
+ isWebchatOpen: boolean;
40
+ isEmojiPickerOpen: boolean;
41
+ isPersistentMenuOpen: boolean;
42
+ isCoverComponentOpen: boolean;
43
+ isCustomComponentRendered: boolean;
44
+ lastMessageUpdate?: string;
45
+ currentAttachment?: File;
46
+ jwt?: string;
47
+ numUnreadMessages: number;
48
+ isLastMessageVisible: boolean;
49
+ }
50
+ export interface WebchatProps {
51
+ ref: RefObject<any>;
52
+ onConnectionRegained?: () => Promise<void>;
53
+ }
54
+ export interface WebchatDevProps extends WebchatProps {
55
+ initialDevSettings?: {
56
+ keepSessionOnReload?: boolean;
57
+ showSessionView?: boolean;
58
+ };
59
+ }
60
+ export interface CoverComponentProps {
61
+ closeComponent: () => void;
62
+ }
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=index-types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index-types.js","sourceRoot":"src/","sources":["webchat/index-types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,4 @@
1
+ export { Webchat } from './webchat';
2
+ export { WebchatDev } from './webchat-dev';
3
+ export declare function getBotonicApp(): any;
4
+ export * from './index-types';
@@ -0,0 +1,10 @@
1
+ // @ts-nocheck
2
+ export { Webchat } from './webchat';
3
+ export { WebchatDev } from './webchat-dev';
4
+ export function getBotonicApp() {
5
+ // Botonic is exported from your bot
6
+ // eslint-disable-next-line no-undef
7
+ return Botonic;
8
+ }
9
+ export * from './index-types';
10
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"src/","sources":["webchat/index.ts"],"names":[],"mappings":"AAAA,cAAc;AACd,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AACnC,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAE1C,MAAM,UAAU,aAAa;IAC3B,oCAAoC;IACpC,oCAAoC;IACpC,OAAO,OAAO,CAAA;AAChB,CAAC;AAED,cAAc,eAAe,CAAA"}
@@ -0,0 +1 @@
1
+ export declare const WebchatMessageList: (props: any) => JSX.Element;
@@ -0,0 +1,73 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import { useContext, useEffect, useRef, useState } from 'react';
3
+ import { ROLES, WEBCHAT } from '../../constants';
4
+ import { WebchatContext } from '../../contexts';
5
+ import { scrollToBottom } from '../../util';
6
+ import { StyledScrollbar } from '../components/styled-scrollbar';
7
+ import { TypingIndicator } from '../components/typing-indicator';
8
+ import { IntroMessage } from './intro-message';
9
+ import { ScrollButton } from './scroll-button';
10
+ import { ContainerMessage } from './styles';
11
+ import { UnreadMessagesBanner } from './unread-messages-banner';
12
+ export const WebchatMessageList = props => {
13
+ const { webchatState, getThemeProperty, resetUnreadMessages, setLastMessageVisible, } = useContext(WebchatContext);
14
+ const scrollbarOptions = Object.assign({ enable: true, autoHide: true }, getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.scrollbar));
15
+ const [firstUnreadMessageId, setFirstUnreadMessageId] = useState();
16
+ const lastMessageRef = useRef(null);
17
+ const handleScrollToBottom = () => {
18
+ resetUnreadMessages();
19
+ scrollToBottom({ host: props.host });
20
+ };
21
+ const showUnreadMessagesBanner = (messageComponentId) => firstUnreadMessageId &&
22
+ messageComponentId === firstUnreadMessageId &&
23
+ webchatState.numUnreadMessages > 0;
24
+ const unreadMessagesBannerRef = useRef(null);
25
+ useEffect(() => {
26
+ var _a;
27
+ const firstUnreadMessage = webchatState.messagesComponents.find(message => message.props.isUnread);
28
+ setFirstUnreadMessageId((_a = firstUnreadMessage === null || firstUnreadMessage === void 0 ? void 0 : firstUnreadMessage.props) === null || _a === void 0 ? void 0 : _a.id);
29
+ }, [webchatState.messagesComponents]);
30
+ useEffect(() => {
31
+ if (webchatState.messagesComponents.length > 0 && lastMessageRef.current) {
32
+ const observer = new IntersectionObserver(entries => {
33
+ entries.forEach(entry => {
34
+ setLastMessageVisible(entry.isIntersecting);
35
+ });
36
+ });
37
+ observer.observe(lastMessageRef.current);
38
+ }
39
+ }, [webchatState.messagesComponents]);
40
+ useEffect(() => {
41
+ if (webchatState.isLastMessageVisible && webchatState.typing) {
42
+ scrollToBottom({ host: props.host });
43
+ }
44
+ if (webchatState.isLastMessageVisible) {
45
+ scrollToBottom({ host: props.host });
46
+ }
47
+ }, [webchatState.typing, webchatState.isLastMessageVisible]);
48
+ useEffect(() => {
49
+ if (firstUnreadMessageId) {
50
+ if (unreadMessagesBannerRef.current) {
51
+ unreadMessagesBannerRef.current.scrollIntoView({
52
+ behavior: 'smooth',
53
+ block: 'center',
54
+ });
55
+ return;
56
+ }
57
+ }
58
+ else if (lastMessageRef.current) {
59
+ lastMessageRef.current.scrollIntoView({
60
+ behavior: 'smooth',
61
+ block: 'end',
62
+ });
63
+ return;
64
+ }
65
+ }, [firstUnreadMessageId]);
66
+ const showScrollButton = webchatState.numUnreadMessages > 0 && !webchatState.isLastMessageVisible;
67
+ return (_jsxs(_Fragment, { children: [_jsxs(StyledScrollbar, Object.assign({ role: ROLES.MESSAGE_LIST,
68
+ // TODO: Distinguis between multiple instances of webchat, e.g. `${uniqueId}-botonic-scrollable`
69
+ id: 'botonic-scrollable-content', scrollbar: scrollbarOptions, autoHide: scrollbarOptions.autoHide, ismessagescontainer: true.toString(), style: Object.assign({}, props.style) }, { children: [_jsx(IntroMessage, {}), webchatState.messagesComponents.map((messageComponent, index) => {
70
+ return (_jsxs(ContainerMessage, Object.assign({ role: ROLES.MESSAGE }, { children: [showUnreadMessagesBanner(messageComponent.props.id) && (_jsx(UnreadMessagesBanner, { unreadMessagesBannerRef: unreadMessagesBannerRef })), index === webchatState.messagesComponents.length - 1 && (_jsx("div", { ref: lastMessageRef, style: { content: '' } })), messageComponent] }), index));
71
+ }), webchatState.typing && _jsx(TypingIndicator, {})] })), showScrollButton && _jsx(ScrollButton, { handleClick: handleScrollToBottom })] }));
72
+ };
73
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"src/","sources":["webchat/message-list/index.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ export declare const IntroMessage: () => JSX.Element | null;
@@ -0,0 +1,18 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { useContext } from 'react';
3
+ import Fade from 'react-reveal/Fade';
4
+ import { WEBCHAT } from '../../constants';
5
+ import { WebchatContext } from '../../contexts';
6
+ import { resolveImage } from '../../util/environment';
7
+ import { ConditionalWrapper } from '../../util/react';
8
+ import { DefaultIntroImage } from './styles';
9
+ export const IntroMessage = () => {
10
+ const { getThemeProperty } = useContext(WebchatContext);
11
+ const animationsEnabled = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.enableAnimations, true);
12
+ const CustomIntro = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.customIntro);
13
+ const introImage = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.introImage);
14
+ const introStyle = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.introStyle);
15
+ const DefaultIntro = introImage && (_jsx(DefaultIntroImage, { style: Object.assign({}, introStyle), src: resolveImage(introImage) }));
16
+ return CustomIntro || DefaultIntro ? (_jsx(ConditionalWrapper, Object.assign({ condition: animationsEnabled, wrapper: children => _jsx(Fade, { children: children }) }, { children: CustomIntro ? _jsx(CustomIntro, {}) : DefaultIntro }))) : null;
17
+ };
18
+ //# sourceMappingURL=intro-message.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"intro-message.js","sourceRoot":"src/","sources":["webchat/message-list/intro-message.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AACzC,OAAO,IAAI,MAAM,mBAAmB,CAAA;AAEpC,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAA;AACzC,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAC/C,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAA;AACrD,OAAO,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAA;AACrD,OAAO,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAA;AAE5C,MAAM,CAAC,MAAM,YAAY,GAAG,GAAG,EAAE;IAC/B,MAAM,EAAE,gBAAgB,EAAE,GAAG,UAAU,CAAC,cAAc,CAAC,CAAA;IAEvD,MAAM,iBAAiB,GAAG,gBAAgB,CACxC,OAAO,CAAC,iBAAiB,CAAC,gBAAgB,EAC1C,IAAI,CACL,CAAA;IACD,MAAM,WAAW,GAAG,gBAAgB,CAAC,OAAO,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAA;IAC3E,MAAM,UAAU,GAAG,gBAAgB,CAAC,OAAO,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAA;IACzE,MAAM,UAAU,GAAG,gBAAgB,CAAC,OAAO,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAA;IAEzE,MAAM,YAAY,GAAG,UAAU,IAAI,CACjC,KAAC,iBAAiB,IAChB,KAAK,oBACA,UAAU,GAEf,GAAG,EAAE,YAAY,CAAC,UAAU,CAAC,GAC7B,CACH,CAAA;IAED,OAAO,WAAW,IAAI,YAAY,CAAC,CAAC,CAAC,CACnC,KAAC,kBAAkB,kBACjB,SAAS,EAAE,iBAAiB,EAC5B,OAAO,EAAE,QAAQ,CAAC,EAAE,CAAC,KAAC,IAAI,cAAE,QAAQ,GAAQ,gBAE3C,WAAW,CAAC,CAAC,CAAC,KAAC,WAAW,KAAG,CAAC,CAAC,CAAC,YAAY,IAC1B,CACtB,CAAC,CAAC,CAAC,IAAI,CAAA;AACV,CAAC,CAAA"}
@@ -0,0 +1,5 @@
1
+ interface ScrollButtonProps {
2
+ handleClick: () => void;
3
+ }
4
+ export declare const ScrollButton: ({ handleClick, }: ScrollButtonProps) => JSX.Element;
5
+ export {};
@@ -0,0 +1,17 @@
1
+ import { jsx as _jsx, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import { useContext } from 'react';
3
+ import ArrowScrollDown from '../../assets/arrow-scroll-down.svg';
4
+ import { WEBCHAT } from '../../constants';
5
+ import { WebchatContext } from '../../contexts';
6
+ import { resolveImage } from '../../util/environment';
7
+ import { ContainerScrollButton } from './styles';
8
+ import { useDebounce } from './use-debounce';
9
+ export const ScrollButton = ({ handleClick, }) => {
10
+ const { getThemeProperty } = useContext(WebchatContext);
11
+ const show = useDebounce();
12
+ const CustomScrollButton = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.scrollButtonCustom, undefined);
13
+ const scrollButtonEnabled = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.scrollButtonEnabled, CustomScrollButton);
14
+ return (scrollButtonEnabled &&
15
+ show && (_jsx(_Fragment, { children: CustomScrollButton ? (_jsx(CustomScrollButton, { handleScrollToBottom: handleClick })) : (_jsx(ContainerScrollButton, Object.assign({ onClick: handleClick }, { children: _jsx("img", { src: resolveImage(ArrowScrollDown) }) }))) })));
16
+ };
17
+ //# sourceMappingURL=scroll-button.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scroll-button.js","sourceRoot":"src/","sources":["webchat/message-list/scroll-button.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AAEzC,OAAO,eAAe,MAAM,oCAAoC,CAAA;AAChE,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAA;AACzC,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAC/C,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAA;AACrD,OAAO,EAAE,qBAAqB,EAAE,MAAM,UAAU,CAAA;AAChD,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAA;AAM5C,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,EAC3B,WAAW,GACO,EAAe,EAAE;IACnC,MAAM,EAAE,gBAAgB,EAAE,GAAG,UAAU,CAAC,cAAc,CAAC,CAAA;IAEvD,MAAM,IAAI,GAAG,WAAW,EAAE,CAAA;IAE1B,MAAM,kBAAkB,GAAG,gBAAgB,CACzC,OAAO,CAAC,iBAAiB,CAAC,kBAAkB,EAC5C,SAAS,CACV,CAAA;IAED,MAAM,mBAAmB,GAAG,gBAAgB,CAC1C,OAAO,CAAC,iBAAiB,CAAC,mBAAmB,EAC7C,kBAAkB,CACnB,CAAA;IAED,OAAO,CACL,mBAAmB;QACnB,IAAI,IAAI,CACN,4BACG,kBAAkB,CAAC,CAAC,CAAC,CACpB,KAAC,kBAAkB,IAAC,oBAAoB,EAAE,WAAW,GAAI,CAC1D,CAAC,CAAC,CAAC,CACF,KAAC,qBAAqB,kBAAC,OAAO,EAAE,WAAW,gBACzC,cAAK,GAAG,EAAE,YAAY,CAAC,eAAe,CAAC,GAAI,IACrB,CACzB,GACA,CACJ,CACF,CAAA;AACH,CAAC,CAAA"}
@@ -0,0 +1,4 @@
1
+ export declare const ContainerMessage: any;
2
+ export declare const DefaultIntroImage: any;
3
+ export declare const ContainerScrollButton: any;
4
+ export declare const ContainerUnreadMessagesBanner: any;
@@ -0,0 +1,46 @@
1
+ import styled from 'styled-components';
2
+ export const ContainerMessage = styled.div `
3
+ display: flex;
4
+ overflow-x: hidden;
5
+ flex-direction: column;
6
+ flex: none;
7
+ white-space: pre;
8
+ word-wrap: break-word;
9
+ `;
10
+ export const DefaultIntroImage = styled.img `
11
+ max-height: 50%;
12
+ width: 100%;
13
+ `;
14
+ export const ContainerScrollButton = styled.div `
15
+ position: absolute;
16
+ right: 10px;
17
+ bottom: 65px;
18
+
19
+ background-color: #6d6a78;
20
+ cursor: pointer;
21
+ display: flex;
22
+ align-items: center;
23
+ justify-content: center;
24
+
25
+ width: 37px;
26
+ height: 37px;
27
+ border-radius: 50%;
28
+ `;
29
+ export const ContainerUnreadMessagesBanner = styled.div `
30
+ display: flex;
31
+ justify-content: center;
32
+ align-items: center;
33
+ gap: 5px;
34
+
35
+ border-top: 1px solid #e8e8ea;
36
+ padding: 8px;
37
+ color: #6d6a78;
38
+ font-size: 14px;
39
+ font-weight: 400;
40
+ width: 100%;
41
+
42
+ img {
43
+ width: 10px;
44
+ }
45
+ `;
46
+ //# sourceMappingURL=styles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"styles.js","sourceRoot":"src/","sources":["webchat/message-list/styles.ts"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,mBAAmB,CAAA;AAEtC,MAAM,CAAC,MAAM,gBAAgB,GAAG,MAAM,CAAC,GAAG,CAAA;;;;;;;CAOzC,CAAA;AAED,MAAM,CAAC,MAAM,iBAAiB,GAAG,MAAM,CAAC,GAAG,CAAA;;;CAG1C,CAAA;AAED,MAAM,CAAC,MAAM,qBAAqB,GAAG,MAAM,CAAC,GAAG,CAAA;;;;;;;;;;;;;;CAc9C,CAAA;AAED,MAAM,CAAC,MAAM,6BAA6B,GAAG,MAAM,CAAC,GAAG,CAAA;;;;;;;;;;;;;;;;CAgBtD,CAAA"}
@@ -0,0 +1,6 @@
1
+ import React from 'react';
2
+ interface UnreadMessagesBannerProps {
3
+ unreadMessagesBannerRef: React.RefObject<HTMLDivElement>;
4
+ }
5
+ export declare const UnreadMessagesBanner: ({ unreadMessagesBannerRef, }: UnreadMessagesBannerProps) => JSX.Element;
6
+ export {};
@@ -0,0 +1,24 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useContext, useEffect } from 'react';
3
+ import ArrowDown from '../../assets/arrow-down.svg';
4
+ import { WEBCHAT } from '../../constants';
5
+ import { WebchatContext } from '../../contexts';
6
+ import { resolveImage } from '../../util/environment';
7
+ import { ContainerUnreadMessagesBanner } from './styles';
8
+ export const UnreadMessagesBanner = ({ unreadMessagesBannerRef, }) => {
9
+ const { getThemeProperty, webchatState } = useContext(WebchatContext);
10
+ const CustomUnreadMessagesBanner = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.notificationsBannerCustom, undefined);
11
+ const notificationsBannerEnabled = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.notificationsBannerEnabled, undefined);
12
+ const notificationsEnabled = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.notificationsEnabled, CustomUnreadMessagesBanner || notificationsBannerEnabled);
13
+ const text = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.notificationsBannerText, 'unread messages');
14
+ useEffect(() => {
15
+ if (webchatState.isWebchatOpen && unreadMessagesBannerRef.current) {
16
+ unreadMessagesBannerRef.current.scrollIntoView({
17
+ behavior: 'smooth',
18
+ block: 'center',
19
+ });
20
+ }
21
+ }, [webchatState.isWebchatOpen, unreadMessagesBannerRef]);
22
+ return (notificationsEnabled && (_jsx("div", Object.assign({ ref: unreadMessagesBannerRef }, { children: CustomUnreadMessagesBanner ? (_jsx(CustomUnreadMessagesBanner, {})) : (_jsxs(ContainerUnreadMessagesBanner, { children: [_jsx("img", { src: resolveImage(ArrowDown) }), webchatState.numUnreadMessages, " ", text] })) }))));
23
+ };
24
+ //# sourceMappingURL=unread-messages-banner.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"unread-messages-banner.js","sourceRoot":"src/","sources":["webchat/message-list/unread-messages-banner.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,OAAO,CAAA;AAEpD,OAAO,SAAS,MAAM,6BAA6B,CAAA;AACnD,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAA;AACzC,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAC/C,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAA;AACrD,OAAO,EAAE,6BAA6B,EAAE,MAAM,UAAU,CAAA;AAMxD,MAAM,CAAC,MAAM,oBAAoB,GAAG,CAAC,EACnC,uBAAuB,GACG,EAAe,EAAE;IAC3C,MAAM,EAAE,gBAAgB,EAAE,YAAY,EAAE,GAAG,UAAU,CAAC,cAAc,CAAC,CAAA;IAErE,MAAM,0BAA0B,GAAG,gBAAgB,CACjD,OAAO,CAAC,iBAAiB,CAAC,yBAAyB,EACnD,SAAS,CACV,CAAA;IAED,MAAM,0BAA0B,GAAG,gBAAgB,CACjD,OAAO,CAAC,iBAAiB,CAAC,0BAA0B,EACpD,SAAS,CACV,CAAA;IAED,MAAM,oBAAoB,GAAG,gBAAgB,CAC3C,OAAO,CAAC,iBAAiB,CAAC,oBAAoB,EAC9C,0BAA0B,IAAI,0BAA0B,CACzD,CAAA;IAED,MAAM,IAAI,GAAG,gBAAgB,CAC3B,OAAO,CAAC,iBAAiB,CAAC,uBAAuB,EACjD,iBAAiB,CAClB,CAAA;IAED,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,YAAY,CAAC,aAAa,IAAI,uBAAuB,CAAC,OAAO,EAAE;YACjE,uBAAuB,CAAC,OAAO,CAAC,cAAc,CAAC;gBAC7C,QAAQ,EAAE,QAAQ;gBAClB,KAAK,EAAE,QAAQ;aAChB,CAAC,CAAA;SACH;IACH,CAAC,EAAE,CAAC,YAAY,CAAC,aAAa,EAAE,uBAAuB,CAAC,CAAC,CAAA;IAEzD,OAAO,CACL,oBAAoB,IAAI,CACtB,4BAAK,GAAG,EAAE,uBAAuB,gBAC9B,0BAA0B,CAAC,CAAC,CAAC,CAC5B,KAAC,0BAA0B,KAAG,CAC/B,CAAC,CAAC,CAAC,CACF,MAAC,6BAA6B,eAC5B,cAAK,GAAG,EAAE,YAAY,CAAC,SAAS,CAAC,GAAI,EACpC,YAAY,CAAC,iBAAiB,OAAG,IAAI,IACR,CACjC,IACG,CACP,CACF,CAAA;AACH,CAAC,CAAA"}
@@ -0,0 +1 @@
1
+ export declare function useDebounce(delay?: number): boolean;
@@ -0,0 +1,14 @@
1
+ import { useEffect, useState } from 'react';
2
+ export function useDebounce(delay) {
3
+ const [show, setShow] = useState(false);
4
+ useEffect(() => {
5
+ const timeoutId = setTimeout(() => {
6
+ setShow(true);
7
+ }, delay || 500);
8
+ return () => {
9
+ clearTimeout(timeoutId);
10
+ };
11
+ }, []);
12
+ return show;
13
+ }
14
+ //# sourceMappingURL=use-debounce.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-debounce.js","sourceRoot":"src/","sources":["webchat/message-list/use-debounce.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAE3C,MAAM,UAAU,WAAW,CAAC,KAAc;IACxC,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;IACvC,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,SAAS,GAAG,UAAU,CAAC,GAAG,EAAE;YAChC,OAAO,CAAC,IAAI,CAAC,CAAA;QACf,CAAC,EAAE,KAAK,IAAI,GAAG,CAAC,CAAA;QAEhB,OAAO,GAAG,EAAE;YACV,YAAY,CAAC,SAAS,CAAC,CAAA;QACzB,CAAC,CAAA;IACH,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,OAAO,IAAI,CAAA;AACb,CAAC"}
@@ -0,0 +1,6 @@
1
+ import { WebchatAction } from './actions';
2
+ import { WebchatState } from './index-types';
3
+ export declare const messagesReducer: (state: WebchatState, action: {
4
+ type: WebchatAction;
5
+ payload?: any;
6
+ }) => WebchatState;
@@ -0,0 +1,82 @@
1
+ import { WebchatAction } from './actions';
2
+ export const messagesReducer = (state, action) => {
3
+ switch (action.type) {
4
+ case WebchatAction.ADD_MESSAGE:
5
+ return addMessageReducer(state, action);
6
+ case WebchatAction.ADD_MESSAGE_COMPONENT:
7
+ return addMessageComponent(state, action);
8
+ case WebchatAction.UPDATE_MESSAGE:
9
+ return updateMessageReducer(state, action);
10
+ case WebchatAction.UPDATE_REPLIES:
11
+ return Object.assign(Object.assign({}, state), { replies: action.payload });
12
+ case WebchatAction.CLEAR_MESSAGES:
13
+ return Object.assign(Object.assign({}, state), { messagesJSON: [], messagesComponents: [], numUnreadMessages: 0 });
14
+ case WebchatAction.UPDATE_LAST_MESSAGE_DATE:
15
+ return Object.assign(Object.assign({}, state), { lastMessageUpdate: action.payload });
16
+ case WebchatAction.RESET_UNREAD_MESSAGES:
17
+ return resetUnreadMessages(state);
18
+ case WebchatAction.SET_LAST_MESSAGE_VISIBLE:
19
+ return Object.assign(Object.assign({}, state), { isLastMessageVisible: action.payload });
20
+ default:
21
+ throw new Error();
22
+ }
23
+ };
24
+ function addMessageComponent(state, action) {
25
+ var _a, _b;
26
+ const messageComponent = action.payload;
27
+ const isUnreadMessage = ((_a = messageComponent.props) === null || _a === void 0 ? void 0 : _a.isUnread) &&
28
+ ((_b = messageComponent.props) === null || _b === void 0 ? void 0 : _b.sent_by) !== 'user';
29
+ const numUnreadMessages = isUnreadMessage
30
+ ? state.numUnreadMessages + 1
31
+ : state.numUnreadMessages;
32
+ return Object.assign(Object.assign({}, state), { messagesComponents: [...(state.messagesComponents || []), messageComponent], numUnreadMessages });
33
+ }
34
+ function resetUnreadMessages(state) {
35
+ const messagesComponents = state.messagesComponents.map(messageComponent => {
36
+ if (messageComponent.props.isUnread) {
37
+ messageComponent.props.isUnread = false;
38
+ }
39
+ return messageComponent;
40
+ });
41
+ const messagesJSON = state.messagesJSON.map(messageJSON => {
42
+ if (messageJSON.isUnread) {
43
+ messageJSON.isUnread = false;
44
+ }
45
+ return messageJSON;
46
+ });
47
+ return Object.assign(Object.assign({}, state), { messagesComponents,
48
+ messagesJSON, numUnreadMessages: 0 });
49
+ }
50
+ function updateMessageReducer(state, action) {
51
+ const msgIndex = state.messagesJSON.map(m => m.id).indexOf(action.payload.id);
52
+ if (msgIndex > -1) {
53
+ const msgComponent = state.messagesComponents[msgIndex];
54
+ let updatedMessageComponents = {};
55
+ if (msgComponent) {
56
+ const updatedMsgComponent = Object.assign(Object.assign({}, msgComponent), {
57
+ props: Object.assign(Object.assign({}, msgComponent.props), { ack: action.payload.ack }),
58
+ });
59
+ updatedMessageComponents = {
60
+ messagesComponents: [
61
+ ...state.messagesComponents.slice(0, msgIndex),
62
+ Object.assign({}, updatedMsgComponent),
63
+ ...state.messagesComponents.slice(msgIndex + 1),
64
+ ],
65
+ };
66
+ }
67
+ const numUnreadMessages = state.messagesComponents.filter(messageComponent => messageComponent.props.isUnread).length;
68
+ return Object.assign(Object.assign(Object.assign(Object.assign({}, state), { messagesJSON: [
69
+ ...state.messagesJSON.slice(0, msgIndex),
70
+ Object.assign({}, action.payload),
71
+ ...state.messagesJSON.slice(msgIndex + 1),
72
+ ] }), updatedMessageComponents), { numUnreadMessages });
73
+ }
74
+ return state;
75
+ }
76
+ function addMessageReducer(state, action) {
77
+ if (state.messagesJSON &&
78
+ state.messagesJSON.find(m => m.id === action.payload.id))
79
+ return state;
80
+ return Object.assign(Object.assign({}, state), { messagesJSON: [...(state.messagesJSON || []), action.payload] });
81
+ }
82
+ //# sourceMappingURL=messages-reducer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"messages-reducer.js","sourceRoot":"src/","sources":["webchat/messages-reducer.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ export function WebchatReplies(props: any): JSX.Element;