@botonic/react 0.30.8-alpha.0 → 0.30.8-alpha.1

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 (378) hide show
  1. package/lib/cjs/components/carousel.d.ts +2 -1
  2. package/lib/cjs/contexts.d.ts +1 -0
  3. package/lib/cjs/message-utils.d.ts +2 -1
  4. package/lib/cjs/node-app.d.ts +1 -1
  5. package/lib/cjs/react-bot.d.ts +2 -1
  6. package/lib/cjs/webchat/hooks/use-webchat.d.ts +1 -0
  7. package/lib/cjs/webchat/utils.d.ts +1 -0
  8. package/lib/cjs/webchat-app.d.ts +4 -3
  9. package/lib/esm/app.d.ts +2 -0
  10. package/lib/esm/app.js +6 -0
  11. package/lib/esm/app.js.map +1 -0
  12. package/lib/esm/botonic-tester.d.ts +30 -0
  13. package/lib/esm/botonic-tester.js +78 -0
  14. package/lib/esm/botonic-tester.js.map +1 -0
  15. package/lib/esm/components/audio.d.ts +8 -0
  16. package/lib/esm/components/audio.js +18 -0
  17. package/lib/esm/components/audio.js.map +1 -0
  18. package/lib/esm/components/button.d.ts +17 -0
  19. package/lib/esm/components/button.js +160 -0
  20. package/lib/esm/components/button.js.map +1 -0
  21. package/lib/esm/components/buttons-disabler.d.ts +24 -0
  22. package/lib/esm/components/buttons-disabler.js +84 -0
  23. package/lib/esm/components/buttons-disabler.js.map +1 -0
  24. package/lib/esm/components/carousel.d.ts +10 -0
  25. package/lib/esm/components/carousel.js +105 -0
  26. package/lib/esm/components/carousel.js.map +1 -0
  27. package/lib/esm/components/components.d.ts +12 -0
  28. package/lib/esm/components/components.js +17 -0
  29. package/lib/esm/components/components.js.map +1 -0
  30. package/lib/esm/components/custom-message.d.ts +12 -0
  31. package/lib/esm/components/custom-message.js +56 -0
  32. package/lib/esm/components/custom-message.js.map +1 -0
  33. package/lib/esm/components/document.d.ts +8 -0
  34. package/lib/esm/components/document.js +42 -0
  35. package/lib/esm/components/document.js.map +1 -0
  36. package/lib/esm/components/element.d.ts +4 -0
  37. package/lib/esm/components/element.js +51 -0
  38. package/lib/esm/components/element.js.map +1 -0
  39. package/lib/esm/components/handoff.d.ts +1 -0
  40. package/lib/esm/components/handoff.js +49 -0
  41. package/lib/esm/components/handoff.js.map +1 -0
  42. package/lib/esm/components/image.d.ts +8 -0
  43. package/lib/esm/components/image.js +35 -0
  44. package/lib/esm/components/image.js.map +1 -0
  45. package/lib/esm/components/index-types.d.ts +186 -0
  46. package/lib/esm/components/index-types.js +2 -0
  47. package/lib/esm/components/index-types.js.map +1 -0
  48. package/lib/esm/components/index.d.ts +24 -0
  49. package/lib/esm/components/index.js +25 -0
  50. package/lib/esm/components/index.js.map +1 -0
  51. package/lib/esm/components/location.d.ts +11 -0
  52. package/lib/esm/components/location.js +27 -0
  53. package/lib/esm/components/location.js.map +1 -0
  54. package/lib/esm/components/markdown.d.ts +7 -0
  55. package/lib/esm/components/markdown.js +152 -0
  56. package/lib/esm/components/markdown.js.map +1 -0
  57. package/lib/esm/components/message/index.d.ts +1 -0
  58. package/lib/esm/components/message/index.js +146 -0
  59. package/lib/esm/components/message/index.js.map +1 -0
  60. package/lib/esm/components/message/message-feedback.d.ts +7 -0
  61. package/lib/esm/components/message/message-feedback.js +59 -0
  62. package/lib/esm/components/message/message-feedback.js.map +1 -0
  63. package/lib/esm/components/message/message-footer.d.ts +11 -0
  64. package/lib/esm/components/message/message-footer.js +17 -0
  65. package/lib/esm/components/message/message-footer.js.map +1 -0
  66. package/lib/esm/components/message/message-image.d.ts +7 -0
  67. package/lib/esm/components/message/message-image.js +19 -0
  68. package/lib/esm/components/message/message-image.js.map +1 -0
  69. package/lib/esm/components/message/styles.d.ts +33 -0
  70. package/lib/esm/components/message/styles.js +118 -0
  71. package/lib/esm/components/message/styles.js.map +1 -0
  72. package/lib/esm/components/message/timestamps.d.ts +13 -0
  73. package/lib/esm/components/message/timestamps.js +40 -0
  74. package/lib/esm/components/message/timestamps.js.map +1 -0
  75. package/lib/esm/components/message-template.d.ts +1 -0
  76. package/lib/esm/components/message-template.js +9 -0
  77. package/lib/esm/components/message-template.js.map +1 -0
  78. package/lib/esm/components/multichannel/facebook/facebook.d.ts +17 -0
  79. package/lib/esm/components/multichannel/facebook/facebook.js +43 -0
  80. package/lib/esm/components/multichannel/facebook/facebook.js.map +1 -0
  81. package/lib/esm/components/multichannel/index-types.d.ts +46 -0
  82. package/lib/esm/components/multichannel/index-types.js +2 -0
  83. package/lib/esm/components/multichannel/index-types.js.map +1 -0
  84. package/lib/esm/components/multichannel/index.d.ts +11 -0
  85. package/lib/esm/components/multichannel/index.js +12 -0
  86. package/lib/esm/components/multichannel/index.js.map +1 -0
  87. package/lib/esm/components/multichannel/multichannel-button.d.ts +1 -0
  88. package/lib/esm/components/multichannel/multichannel-button.js +67 -0
  89. package/lib/esm/components/multichannel/multichannel-button.js.map +1 -0
  90. package/lib/esm/components/multichannel/multichannel-carousel.d.ts +1 -0
  91. package/lib/esm/components/multichannel/multichannel-carousel.js +74 -0
  92. package/lib/esm/components/multichannel/multichannel-carousel.js.map +1 -0
  93. package/lib/esm/components/multichannel/multichannel-context.d.ts +11 -0
  94. package/lib/esm/components/multichannel/multichannel-context.js +12 -0
  95. package/lib/esm/components/multichannel/multichannel-context.js.map +1 -0
  96. package/lib/esm/components/multichannel/multichannel-reply.d.ts +1 -0
  97. package/lib/esm/components/multichannel/multichannel-reply.js +20 -0
  98. package/lib/esm/components/multichannel/multichannel-reply.js.map +1 -0
  99. package/lib/esm/components/multichannel/multichannel-text.d.ts +1 -0
  100. package/lib/esm/components/multichannel/multichannel-text.js +160 -0
  101. package/lib/esm/components/multichannel/multichannel-text.js.map +1 -0
  102. package/lib/esm/components/multichannel/multichannel-utils.d.ts +21 -0
  103. package/lib/esm/components/multichannel/multichannel-utils.js +81 -0
  104. package/lib/esm/components/multichannel/multichannel-utils.js.map +1 -0
  105. package/lib/esm/components/multichannel/multichannel.d.ts +1 -0
  106. package/lib/esm/components/multichannel/multichannel.js +57 -0
  107. package/lib/esm/components/multichannel/multichannel.js.map +1 -0
  108. package/lib/esm/components/multichannel/whatsapp/constants.d.ts +11 -0
  109. package/lib/esm/components/multichannel/whatsapp/constants.js +10 -0
  110. package/lib/esm/components/multichannel/whatsapp/constants.js.map +1 -0
  111. package/lib/esm/components/multichannel/whatsapp/markdown-meta.d.ts +1 -0
  112. package/lib/esm/components/multichannel/whatsapp/markdown-meta.js +38 -0
  113. package/lib/esm/components/multichannel/whatsapp/markdown-meta.js.map +1 -0
  114. package/lib/esm/components/pic.d.ts +6 -0
  115. package/lib/esm/components/pic.js +25 -0
  116. package/lib/esm/components/pic.js.map +1 -0
  117. package/lib/esm/components/raw.d.ts +9 -0
  118. package/lib/esm/components/raw.js +39 -0
  119. package/lib/esm/components/raw.js.map +1 -0
  120. package/lib/esm/components/reply.d.ts +9 -0
  121. package/lib/esm/components/reply.js +49 -0
  122. package/lib/esm/components/reply.js.map +1 -0
  123. package/lib/esm/components/share-button.d.ts +1 -0
  124. package/lib/esm/components/share-button.js +9 -0
  125. package/lib/esm/components/share-button.js.map +1 -0
  126. package/lib/esm/components/subtitle.d.ts +6 -0
  127. package/lib/esm/components/subtitle.js +19 -0
  128. package/lib/esm/components/subtitle.js.map +1 -0
  129. package/lib/esm/components/text.d.ts +7 -0
  130. package/lib/esm/components/text.js +40 -0
  131. package/lib/esm/components/text.js.map +1 -0
  132. package/lib/esm/components/title.d.ts +6 -0
  133. package/lib/esm/components/title.js +17 -0
  134. package/lib/esm/components/title.js.map +1 -0
  135. package/lib/esm/components/video.d.ts +8 -0
  136. package/lib/esm/components/video.js +26 -0
  137. package/lib/esm/components/video.js.map +1 -0
  138. package/lib/esm/components/webchat-settings.d.ts +3 -0
  139. package/lib/esm/components/webchat-settings.js +69 -0
  140. package/lib/esm/components/webchat-settings.js.map +1 -0
  141. package/lib/esm/components/whatsapp-button-list.d.ts +20 -0
  142. package/lib/esm/components/whatsapp-button-list.js +47 -0
  143. package/lib/esm/components/whatsapp-button-list.js.map +1 -0
  144. package/lib/esm/components/whatsapp-cta-url-button.d.ts +15 -0
  145. package/lib/esm/components/whatsapp-cta-url-button.js +33 -0
  146. package/lib/esm/components/whatsapp-cta-url-button.js.map +1 -0
  147. package/lib/esm/components/whatsapp-template.d.ts +1 -0
  148. package/lib/esm/components/whatsapp-template.js +20 -0
  149. package/lib/esm/components/whatsapp-template.js.map +1 -0
  150. package/lib/esm/constants.d.ts +165 -0
  151. package/lib/esm/constants.js +187 -0
  152. package/lib/esm/constants.js.map +1 -0
  153. package/lib/esm/contexts.d.ts +19 -0
  154. package/lib/esm/contexts.js +95 -0
  155. package/lib/esm/contexts.js.map +1 -0
  156. package/lib/esm/dev-app.d.ts +31 -0
  157. package/lib/esm/dev-app.js +78 -0
  158. package/lib/esm/dev-app.js.map +1 -0
  159. package/lib/esm/index-types.d.ts +150 -0
  160. package/lib/esm/index-types.js +12 -0
  161. package/lib/esm/index-types.js.map +1 -0
  162. package/lib/esm/index.d.ts +11 -0
  163. package/lib/esm/index.js +12 -0
  164. package/lib/esm/index.js.map +1 -0
  165. package/lib/esm/message-utils.d.ts +19 -0
  166. package/lib/esm/message-utils.js +41 -0
  167. package/lib/esm/message-utils.js.map +1 -0
  168. package/lib/esm/msg-to-botonic.d.ts +18 -0
  169. package/lib/esm/msg-to-botonic.js +135 -0
  170. package/lib/esm/msg-to-botonic.js.map +1 -0
  171. package/lib/esm/node-app.d.ts +7 -0
  172. package/lib/esm/node-app.js +19 -0
  173. package/lib/esm/node-app.js.map +1 -0
  174. package/lib/esm/react-bot.d.ts +8 -0
  175. package/lib/esm/react-bot.js +32 -0
  176. package/lib/esm/react-bot.js.map +1 -0
  177. package/lib/esm/shared/styles.d.ts +2 -0
  178. package/lib/esm/shared/styles.js +28 -0
  179. package/lib/esm/shared/styles.js.map +1 -0
  180. package/lib/esm/util/dom.d.ts +4 -0
  181. package/lib/esm/util/dom.js +24 -0
  182. package/lib/esm/util/dom.js.map +1 -0
  183. package/lib/esm/util/environment.d.ts +6 -0
  184. package/lib/esm/util/environment.js +61 -0
  185. package/lib/esm/util/environment.js.map +1 -0
  186. package/lib/esm/util/error-boundary.d.ts +7 -0
  187. package/lib/esm/util/error-boundary.js +28 -0
  188. package/lib/esm/util/error-boundary.js.map +1 -0
  189. package/lib/esm/util/index.d.ts +9 -0
  190. package/lib/esm/util/index.js +10 -0
  191. package/lib/esm/util/index.js.map +1 -0
  192. package/lib/esm/util/logs.d.ts +2 -0
  193. package/lib/esm/util/logs.js +15 -0
  194. package/lib/esm/util/logs.js.map +1 -0
  195. package/lib/esm/util/objects.d.ts +3 -0
  196. package/lib/esm/util/objects.js +38 -0
  197. package/lib/esm/util/objects.js.map +1 -0
  198. package/lib/esm/util/react.d.ts +12 -0
  199. package/lib/esm/util/react.js +34 -0
  200. package/lib/esm/util/react.js.map +1 -0
  201. package/lib/esm/util/regexs.d.ts +2 -0
  202. package/lib/esm/util/regexs.js +18 -0
  203. package/lib/esm/util/regexs.js.map +1 -0
  204. package/lib/esm/util/strings.d.ts +1 -0
  205. package/lib/esm/util/strings.js +7 -0
  206. package/lib/esm/util/strings.js.map +1 -0
  207. package/lib/esm/util/webchat.d.ts +11 -0
  208. package/lib/esm/util/webchat.js +53 -0
  209. package/lib/esm/util/webchat.js.map +1 -0
  210. package/lib/esm/util/webviews.d.ts +1 -0
  211. package/lib/esm/util/webviews.js +6 -0
  212. package/lib/esm/util/webviews.js.map +1 -0
  213. package/lib/esm/webchat/actions.d.ts +27 -0
  214. package/lib/esm/webchat/actions.js +29 -0
  215. package/lib/esm/webchat/actions.js.map +1 -0
  216. package/lib/esm/webchat/chat-area/index.d.ts +1 -0
  217. package/lib/esm/webchat/chat-area/index.js +18 -0
  218. package/lib/esm/webchat/chat-area/index.js.map +1 -0
  219. package/lib/esm/webchat/chat-area/styles.d.ts +3 -0
  220. package/lib/esm/webchat/chat-area/styles.js +9 -0
  221. package/lib/esm/webchat/chat-area/styles.js.map +1 -0
  222. package/lib/esm/webchat/components/common.d.ts +1 -0
  223. package/lib/esm/webchat/components/common.js +9 -0
  224. package/lib/esm/webchat/components/common.js.map +1 -0
  225. package/lib/esm/webchat/components/conditional-animation.d.ts +1 -0
  226. package/lib/esm/webchat/components/conditional-animation.js +12 -0
  227. package/lib/esm/webchat/components/conditional-animation.js.map +1 -0
  228. package/lib/esm/webchat/components/opened-persistent-menu.d.ts +6 -0
  229. package/lib/esm/webchat/components/opened-persistent-menu.js +30 -0
  230. package/lib/esm/webchat/components/opened-persistent-menu.js.map +1 -0
  231. package/lib/esm/webchat/constants.d.ts +8 -0
  232. package/lib/esm/webchat/constants.js +10 -0
  233. package/lib/esm/webchat/constants.js.map +1 -0
  234. package/lib/esm/webchat/cover-component/index.d.ts +6 -0
  235. package/lib/esm/webchat/cover-component/index.js +17 -0
  236. package/lib/esm/webchat/cover-component/index.js.map +1 -0
  237. package/lib/esm/webchat/devices/index.d.ts +11 -0
  238. package/lib/esm/webchat/devices/index.js +18 -0
  239. package/lib/esm/webchat/devices/index.js.map +1 -0
  240. package/lib/esm/webchat/header.d.ts +3 -0
  241. package/lib/esm/webchat/header.js +81 -0
  242. package/lib/esm/webchat/header.js.map +1 -0
  243. package/lib/esm/webchat/hooks/index.d.ts +11 -0
  244. package/lib/esm/webchat/hooks/index.js +12 -0
  245. package/lib/esm/webchat/hooks/index.js.map +1 -0
  246. package/lib/esm/webchat/hooks/use-component-visible.d.ts +8 -0
  247. package/lib/esm/webchat/hooks/use-component-visible.js +20 -0
  248. package/lib/esm/webchat/hooks/use-component-visible.js.map +1 -0
  249. package/lib/esm/webchat/hooks/use-component-will-mount.d.ts +1 -0
  250. package/lib/esm/webchat/hooks/use-component-will-mount.js +5 -0
  251. package/lib/esm/webchat/hooks/use-component-will-mount.js.map +1 -0
  252. package/lib/esm/webchat/hooks/use-device-adapter.d.ts +3 -0
  253. package/lib/esm/webchat/hooks/use-device-adapter.js +42 -0
  254. package/lib/esm/webchat/hooks/use-device-adapter.js.map +1 -0
  255. package/lib/esm/webchat/hooks/use-previous.d.ts +1 -0
  256. package/lib/esm/webchat/hooks/use-previous.js +9 -0
  257. package/lib/esm/webchat/hooks/use-previous.js.map +1 -0
  258. package/lib/esm/webchat/hooks/use-scroll-to-bottom.d.ts +6 -0
  259. package/lib/esm/webchat/hooks/use-scroll-to-bottom.js +18 -0
  260. package/lib/esm/webchat/hooks/use-scroll-to-bottom.js.map +1 -0
  261. package/lib/esm/webchat/hooks/use-scrollbar-controller.d.ts +6 -0
  262. package/lib/esm/webchat/hooks/use-scrollbar-controller.js +136 -0
  263. package/lib/esm/webchat/hooks/use-scrollbar-controller.js.map +1 -0
  264. package/lib/esm/webchat/hooks/use-typing.d.ts +10 -0
  265. package/lib/esm/webchat/hooks/use-typing.js +28 -0
  266. package/lib/esm/webchat/hooks/use-typing.js.map +1 -0
  267. package/lib/esm/webchat/hooks/use-virtual-keyboard-detection.d.ts +3 -0
  268. package/lib/esm/webchat/hooks/use-virtual-keyboard-detection.js +24 -0
  269. package/lib/esm/webchat/hooks/use-virtual-keyboard-detection.js.map +1 -0
  270. package/lib/esm/webchat/hooks/use-webchat-dimensions.d.ts +4 -0
  271. package/lib/esm/webchat/hooks/use-webchat-dimensions.js +36 -0
  272. package/lib/esm/webchat/hooks/use-webchat-dimensions.js.map +1 -0
  273. package/lib/esm/webchat/hooks/use-webchat-resizer.d.ts +4 -0
  274. package/lib/esm/webchat/hooks/use-webchat-resizer.js +30 -0
  275. package/lib/esm/webchat/hooks/use-webchat-resizer.js.map +1 -0
  276. package/lib/esm/webchat/hooks/use-webchat.d.ts +47 -0
  277. package/lib/esm/webchat/hooks/use-webchat.js +189 -0
  278. package/lib/esm/webchat/hooks/use-webchat.js.map +1 -0
  279. package/lib/esm/webchat/index-types.d.ts +62 -0
  280. package/lib/esm/webchat/index-types.js +2 -0
  281. package/lib/esm/webchat/index-types.js.map +1 -0
  282. package/lib/esm/webchat/index.d.ts +4 -0
  283. package/lib/esm/webchat/index.js +10 -0
  284. package/lib/esm/webchat/index.js.map +1 -0
  285. package/lib/esm/webchat/input-panel/attachment.d.ts +7 -0
  286. package/lib/esm/webchat/input-panel/attachment.js +26 -0
  287. package/lib/esm/webchat/input-panel/attachment.js.map +1 -0
  288. package/lib/esm/webchat/input-panel/emoji-picker.d.ts +6 -0
  289. package/lib/esm/webchat/input-panel/emoji-picker.js +23 -0
  290. package/lib/esm/webchat/input-panel/emoji-picker.js.map +1 -0
  291. package/lib/esm/webchat/input-panel/index.d.ts +12 -0
  292. package/lib/esm/webchat/input-panel/index.js +50 -0
  293. package/lib/esm/webchat/input-panel/index.js.map +1 -0
  294. package/lib/esm/webchat/input-panel/opened-emoji-picker.d.ts +6 -0
  295. package/lib/esm/webchat/input-panel/opened-emoji-picker.js +10 -0
  296. package/lib/esm/webchat/input-panel/opened-emoji-picker.js.map +1 -0
  297. package/lib/esm/webchat/input-panel/persistent-menu.d.ts +6 -0
  298. package/lib/esm/webchat/input-panel/persistent-menu.js +14 -0
  299. package/lib/esm/webchat/input-panel/persistent-menu.js.map +1 -0
  300. package/lib/esm/webchat/input-panel/send-button.d.ts +5 -0
  301. package/lib/esm/webchat/input-panel/send-button.js +14 -0
  302. package/lib/esm/webchat/input-panel/send-button.js.map +1 -0
  303. package/lib/esm/webchat/input-panel/styles.d.ts +3 -0
  304. package/lib/esm/webchat/input-panel/styles.js +27 -0
  305. package/lib/esm/webchat/input-panel/styles.js.map +1 -0
  306. package/lib/esm/webchat/input-panel/textarea.d.ts +11 -0
  307. package/lib/esm/webchat/input-panel/textarea.js +56 -0
  308. package/lib/esm/webchat/input-panel/textarea.js.map +1 -0
  309. package/lib/esm/webchat/message-list/index.d.ts +1 -0
  310. package/lib/esm/webchat/message-list/index.js +107 -0
  311. package/lib/esm/webchat/message-list/index.js.map +1 -0
  312. package/lib/esm/webchat/message-list/intro-message.d.ts +1 -0
  313. package/lib/esm/webchat/message-list/intro-message.js +18 -0
  314. package/lib/esm/webchat/message-list/intro-message.js.map +1 -0
  315. package/lib/esm/webchat/message-list/scroll-button.d.ts +5 -0
  316. package/lib/esm/webchat/message-list/scroll-button.js +12 -0
  317. package/lib/esm/webchat/message-list/scroll-button.js.map +1 -0
  318. package/lib/esm/webchat/message-list/styles.d.ts +5 -0
  319. package/lib/esm/webchat/message-list/styles.js +56 -0
  320. package/lib/esm/webchat/message-list/styles.js.map +1 -0
  321. package/lib/esm/webchat/message-list/unread-messages-banner.d.ts +6 -0
  322. package/lib/esm/webchat/message-list/unread-messages-banner.js +13 -0
  323. package/lib/esm/webchat/message-list/unread-messages-banner.js.map +1 -0
  324. package/lib/esm/webchat/message-list/use-debounce.d.ts +1 -0
  325. package/lib/esm/webchat/message-list/use-debounce.js +14 -0
  326. package/lib/esm/webchat/message-list/use-debounce.js.map +1 -0
  327. package/lib/esm/webchat/message-list/use-notifications.d.ts +7 -0
  328. package/lib/esm/webchat/message-list/use-notifications.js +20 -0
  329. package/lib/esm/webchat/message-list/use-notifications.js.map +1 -0
  330. package/lib/esm/webchat/messages-reducer.d.ts +6 -0
  331. package/lib/esm/webchat/messages-reducer.js +83 -0
  332. package/lib/esm/webchat/messages-reducer.js.map +1 -0
  333. package/lib/esm/webchat/replies.d.ts +1 -0
  334. package/lib/esm/webchat/replies.js +42 -0
  335. package/lib/esm/webchat/replies.js.map +1 -0
  336. package/lib/esm/webchat/session-view.d.ts +1 -0
  337. package/lib/esm/webchat/session-view.js +96 -0
  338. package/lib/esm/webchat/session-view.js.map +1 -0
  339. package/lib/esm/webchat/tracking.d.ts +7 -0
  340. package/lib/esm/webchat/tracking.js +10 -0
  341. package/lib/esm/webchat/tracking.js.map +1 -0
  342. package/lib/esm/webchat/trigger-button/index.d.ts +1 -0
  343. package/lib/esm/webchat/trigger-button/index.js +28 -0
  344. package/lib/esm/webchat/trigger-button/index.js.map +1 -0
  345. package/lib/esm/webchat/trigger-button/styles.d.ts +3 -0
  346. package/lib/esm/webchat/trigger-button/styles.js +36 -0
  347. package/lib/esm/webchat/trigger-button/styles.js.map +1 -0
  348. package/lib/esm/webchat/typing-indicator/index.d.ts +3 -0
  349. package/lib/esm/webchat/typing-indicator/index.js +8 -0
  350. package/lib/esm/webchat/typing-indicator/index.js.map +1 -0
  351. package/lib/esm/webchat/typing-indicator/styles.d.ts +7 -0
  352. package/lib/esm/webchat/typing-indicator/styles.js +46 -0
  353. package/lib/esm/webchat/typing-indicator/styles.js.map +1 -0
  354. package/lib/esm/webchat/use-storage-state-hook.d.ts +1 -0
  355. package/lib/esm/webchat/use-storage-state-hook.js +38 -0
  356. package/lib/esm/webchat/use-storage-state-hook.js.map +1 -0
  357. package/lib/esm/webchat/utils.d.ts +2 -0
  358. package/lib/esm/webchat/utils.js +8 -0
  359. package/lib/esm/webchat/utils.js.map +1 -0
  360. package/lib/esm/webchat/webchat-dev.d.ts +7 -0
  361. package/lib/esm/webchat/webchat-dev.js +56 -0
  362. package/lib/esm/webchat/webchat-dev.js.map +1 -0
  363. package/lib/esm/webchat/webchat-reducer.d.ts +6 -0
  364. package/lib/esm/webchat/webchat-reducer.js +46 -0
  365. package/lib/esm/webchat/webchat-reducer.js.map +1 -0
  366. package/lib/esm/webchat/webchat.d.ts +2 -0
  367. package/lib/esm/webchat/webchat.js +543 -0
  368. package/lib/esm/webchat/webchat.js.map +1 -0
  369. package/lib/esm/webchat/webview.d.ts +2 -0
  370. package/lib/esm/webchat/webview.js +70 -0
  371. package/lib/esm/webchat/webview.js.map +1 -0
  372. package/lib/esm/webchat-app.d.ts +102 -0
  373. package/lib/esm/webchat-app.js +299 -0
  374. package/lib/esm/webchat-app.js.map +1 -0
  375. package/lib/esm/webview-app.d.ts +7 -0
  376. package/lib/esm/webview-app.js +102 -0
  377. package/lib/esm/webview-app.js.map +1 -0
  378. package/package.json +1 -1
@@ -0,0 +1,12 @@
1
+ import { jsx as _jsx, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import ArrowScrollDown from '../../assets/arrow-scroll-down.svg';
3
+ import { resolveImage } from '../../util/environment';
4
+ import { ContainerScrollButton } from './styles';
5
+ import { useDebounce } from './use-debounce';
6
+ import { useNotifications } from './use-notifications';
7
+ export const ScrollButton = ({ handleClick, }) => {
8
+ const { CustomScrollButton, scrollButtonEnabled } = useNotifications();
9
+ const show = useDebounce();
10
+ return (_jsx(_Fragment, { children: scrollButtonEnabled && show ? (_jsx(_Fragment, { children: CustomScrollButton ? (_jsx(CustomScrollButton, { handleScrollToBottom: handleClick })) : (_jsx(ContainerScrollButton, Object.assign({ onClick: handleClick }, { children: _jsx("img", { src: resolveImage(ArrowScrollDown) }) }))) })) : null }));
11
+ };
12
+ //# sourceMappingURL=scroll-button.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scroll-button.js","sourceRoot":"","sources":["../../../../src/webchat/message-list/scroll-button.tsx"],"names":[],"mappings":";AAEA,OAAO,eAAe,MAAM,oCAAoC,CAAA;AAChE,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAA;AACrD,OAAO,EAAE,qBAAqB,EAAE,MAAM,UAAU,CAAA;AAChD,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAA;AAC5C,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAA;AAMtD,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,EAC3B,WAAW,GACO,EAAe,EAAE;IACnC,MAAM,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,GAAG,gBAAgB,EAAE,CAAA;IAEtE,MAAM,IAAI,GAAG,WAAW,EAAE,CAAA;IAE1B,OAAO,CACL,4BACG,mBAAmB,IAAI,IAAI,CAAC,CAAC,CAAC,CAC7B,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,CAAC,CAAC,CAAC,IAAI,GACP,CACJ,CAAA;AACH,CAAC,CAAA"}
@@ -0,0 +1,5 @@
1
+ export declare const ContainerMessage: import("styled-components").StyledComponent<"div", any, {}, never>;
2
+ export declare const DefaultIntroImage: import("styled-components").StyledComponent<"img", any, {}, never>;
3
+ export declare const ContainerScrollButton: import("styled-components").StyledComponent<"div", any, {}, never>;
4
+ export declare const ContainerUnreadMessagesBanner: import("styled-components").StyledComponent<"div", any, {}, never>;
5
+ export declare const ScrollableMessageList: import("styled-components").StyledComponent<"div", any, {}, never>;
@@ -0,0 +1,56 @@
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: sticky;
16
+ left: 85%;
17
+ bottom: 15px;
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
+ export const ScrollableMessageList = styled.div `
47
+ display: flex;
48
+ flex: 1;
49
+ flex-direction: column;
50
+ overflow-y: auto;
51
+ overflow-x: hidden;
52
+ overscroll-behavior: contain; // https://css-tricks.com/almanac/properties/o/overscroll-behavior/
53
+ scroll-behavior: smooth;
54
+ -webkit-overflow-scrolling: touch;
55
+ `;
56
+ //# sourceMappingURL=styles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"styles.js","sourceRoot":"","sources":["../../../../src/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;AAED,MAAM,CAAC,MAAM,qBAAqB,GAAG,MAAM,CAAC,GAAG,CAAA;;;;;;;;;CAS9C,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,13 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import { useContext } from 'react';
3
+ import ArrowDown from '../../assets/arrow-down.svg';
4
+ import { WebchatContext } from '../../contexts';
5
+ import { resolveImage } from '../../util/environment';
6
+ import { ContainerUnreadMessagesBanner } from './styles';
7
+ import { useNotifications } from './use-notifications';
8
+ export const UnreadMessagesBanner = ({ unreadMessagesBannerRef, }) => {
9
+ const { webchatState } = useContext(WebchatContext);
10
+ const { notificationsEnabled, CustomUnreadMessagesBanner, bannerText } = useNotifications();
11
+ return (_jsx(_Fragment, { children: notificationsEnabled ? (_jsx("div", Object.assign({ ref: unreadMessagesBannerRef }, { children: CustomUnreadMessagesBanner ? (_jsx(CustomUnreadMessagesBanner, {})) : (_jsxs(ContainerUnreadMessagesBanner, { children: [_jsx("img", { src: resolveImage(ArrowDown) }), webchatState.numUnreadMessages, " ", bannerText] })) }))) : null }));
12
+ };
13
+ //# sourceMappingURL=unread-messages-banner.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"unread-messages-banner.js","sourceRoot":"","sources":["../../../../src/webchat/message-list/unread-messages-banner.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AAEzC,OAAO,SAAS,MAAM,6BAA6B,CAAA;AACnD,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAC/C,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAA;AACrD,OAAO,EAAE,6BAA6B,EAAE,MAAM,UAAU,CAAA;AACxD,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAA;AAMtD,MAAM,CAAC,MAAM,oBAAoB,GAAG,CAAC,EACnC,uBAAuB,GACG,EAAe,EAAE;IAC3C,MAAM,EAAE,YAAY,EAAE,GAAG,UAAU,CAAC,cAAc,CAAC,CAAA;IAEnD,MAAM,EAAE,oBAAoB,EAAE,0BAA0B,EAAE,UAAU,EAAE,GACpE,gBAAgB,EAAE,CAAA;IAEpB,OAAO,CACL,4BACG,oBAAoB,CAAC,CAAC,CAAC,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,UAAU,IACd,CACjC,IACG,CACP,CAAC,CAAC,CAAC,IAAI,GACP,CACJ,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":"","sources":["../../../../src/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,7 @@
1
+ export declare function useNotifications(): {
2
+ notificationsEnabled: any;
3
+ bannerText: any;
4
+ CustomUnreadMessagesBanner: any;
5
+ CustomScrollButton: any;
6
+ scrollButtonEnabled: any;
7
+ };
@@ -0,0 +1,20 @@
1
+ import { useContext } from 'react';
2
+ import { WEBCHAT } from '../../constants';
3
+ import { WebchatContext } from '../../contexts';
4
+ export function useNotifications() {
5
+ const { getThemeProperty } = useContext(WebchatContext);
6
+ const CustomUnreadMessagesBanner = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.notificationsBannerCustom, undefined);
7
+ const notificationsBannerEnabled = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.notificationsBannerEnabled, undefined);
8
+ const notificationsEnabled = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.notificationsEnabled, CustomUnreadMessagesBanner || notificationsBannerEnabled);
9
+ const bannerText = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.notificationsBannerText, 'unread messages');
10
+ const CustomScrollButton = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.scrollButtonCustom, undefined);
11
+ const scrollButtonEnabled = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.scrollButtonEnabled, CustomScrollButton);
12
+ return {
13
+ notificationsEnabled,
14
+ bannerText,
15
+ CustomUnreadMessagesBanner,
16
+ CustomScrollButton,
17
+ scrollButtonEnabled,
18
+ };
19
+ }
20
+ //# sourceMappingURL=use-notifications.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-notifications.js","sourceRoot":"","sources":["../../../../src/webchat/message-list/use-notifications.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AAElC,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAA;AACzC,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAE/C,MAAM,UAAU,gBAAgB;IAC9B,MAAM,EAAE,gBAAgB,EAAE,GAAG,UAAU,CAAC,cAAc,CAAC,CAAA;IAEvD,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,UAAU,GAAG,gBAAgB,CACjC,OAAO,CAAC,iBAAiB,CAAC,uBAAuB,EACjD,iBAAiB,CAClB,CAAA;IAED,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;QACL,oBAAoB;QACpB,UAAU;QACV,0BAA0B;QAC1B,kBAAkB;QAClB,mBAAmB;KACpB,CAAA;AACH,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,83 @@
1
+ import { SENDERS } from '../index-types';
2
+ import { WebchatAction } from './actions';
3
+ export const messagesReducer = (state, action) => {
4
+ switch (action.type) {
5
+ case WebchatAction.ADD_MESSAGE:
6
+ return addMessageReducer(state, action);
7
+ case WebchatAction.ADD_MESSAGE_COMPONENT:
8
+ return addMessageComponent(state, action);
9
+ case WebchatAction.UPDATE_MESSAGE:
10
+ return updateMessageReducer(state, action);
11
+ case WebchatAction.UPDATE_REPLIES:
12
+ return Object.assign(Object.assign({}, state), { replies: action.payload });
13
+ case WebchatAction.CLEAR_MESSAGES:
14
+ return Object.assign(Object.assign({}, state), { messagesJSON: [], messagesComponents: [], numUnreadMessages: 0 });
15
+ case WebchatAction.UPDATE_LAST_MESSAGE_DATE:
16
+ return Object.assign(Object.assign({}, state), { lastMessageUpdate: action.payload });
17
+ case WebchatAction.RESET_UNREAD_MESSAGES:
18
+ return resetUnreadMessages(state);
19
+ case WebchatAction.SET_LAST_MESSAGE_VISIBLE:
20
+ return Object.assign(Object.assign({}, state), { isLastMessageVisible: action.payload });
21
+ default:
22
+ throw new Error();
23
+ }
24
+ };
25
+ function addMessageComponent(state, action) {
26
+ var _a, _b;
27
+ const messageComponent = action.payload;
28
+ const isUnreadMessage = ((_a = messageComponent.props) === null || _a === void 0 ? void 0 : _a.isUnread) &&
29
+ ((_b = messageComponent.props) === null || _b === void 0 ? void 0 : _b.sentBy) !== SENDERS.user;
30
+ const numUnreadMessages = isUnreadMessage
31
+ ? state.numUnreadMessages + 1
32
+ : state.numUnreadMessages;
33
+ return Object.assign(Object.assign({}, state), { messagesComponents: [...(state.messagesComponents || []), messageComponent], numUnreadMessages });
34
+ }
35
+ function resetUnreadMessages(state) {
36
+ const messagesComponents = state.messagesComponents.map(messageComponent => {
37
+ if (messageComponent.props.isUnread) {
38
+ messageComponent = Object.assign(Object.assign({}, messageComponent), { props: Object.assign(Object.assign({}, messageComponent.props), { isUnread: false }) });
39
+ }
40
+ return messageComponent;
41
+ });
42
+ const messagesJSON = state.messagesJSON.map(messageJSON => {
43
+ if (messageJSON.isUnread) {
44
+ messageJSON.isUnread = false;
45
+ }
46
+ return messageJSON;
47
+ });
48
+ return Object.assign(Object.assign({}, state), { messagesComponents,
49
+ messagesJSON, numUnreadMessages: 0 });
50
+ }
51
+ function updateMessageReducer(state, action) {
52
+ const msgIndex = state.messagesJSON.map(m => m.id).indexOf(action.payload.id);
53
+ if (msgIndex > -1) {
54
+ const msgComponent = state.messagesComponents[msgIndex];
55
+ let updatedMessageComponents = {};
56
+ if (msgComponent) {
57
+ const updatedMsgComponent = Object.assign(Object.assign({}, msgComponent), {
58
+ props: Object.assign(Object.assign({}, msgComponent.props), { ack: action.payload.ack }),
59
+ });
60
+ updatedMessageComponents = {
61
+ messagesComponents: [
62
+ ...state.messagesComponents.slice(0, msgIndex),
63
+ Object.assign({}, updatedMsgComponent),
64
+ ...state.messagesComponents.slice(msgIndex + 1),
65
+ ],
66
+ };
67
+ }
68
+ const numUnreadMessages = state.messagesComponents.filter(messageComponent => messageComponent.props.isUnread).length;
69
+ return Object.assign(Object.assign(Object.assign(Object.assign({}, state), { messagesJSON: [
70
+ ...state.messagesJSON.slice(0, msgIndex),
71
+ Object.assign({}, action.payload),
72
+ ...state.messagesJSON.slice(msgIndex + 1),
73
+ ] }), updatedMessageComponents), { numUnreadMessages });
74
+ }
75
+ return state;
76
+ }
77
+ function addMessageReducer(state, action) {
78
+ if (state.messagesJSON &&
79
+ state.messagesJSON.find(m => m.id === action.payload.id))
80
+ return state;
81
+ return Object.assign(Object.assign({}, state), { messagesJSON: [...(state.messagesJSON || []), action.payload] });
82
+ }
83
+ //# sourceMappingURL=messages-reducer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"messages-reducer.js","sourceRoot":"","sources":["../../../src/webchat/messages-reducer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,gBAAgB,CAAA;AACxC,OAAO,EAAE,aAAa,EAAE,MAAM,WAAW,CAAA;AAGzC,MAAM,CAAC,MAAM,eAAe,GAAG,CAC7B,KAAmB,EACnB,MAA8C,EAChC,EAAE;IAChB,QAAQ,MAAM,CAAC,IAAI,EAAE;QACnB,KAAK,aAAa,CAAC,WAAW;YAC5B,OAAO,iBAAiB,CAAC,KAAK,EAAE,MAAM,CAAC,CAAA;QACzC,KAAK,aAAa,CAAC,qBAAqB;YACtC,OAAO,mBAAmB,CAAC,KAAK,EAAE,MAAM,CAAC,CAAA;QAC3C,KAAK,aAAa,CAAC,cAAc;YAC/B,OAAO,oBAAoB,CAAC,KAAK,EAAE,MAAM,CAAC,CAAA;QAC5C,KAAK,aAAa,CAAC,cAAc;YAC/B,uCAAY,KAAK,KAAE,OAAO,EAAE,MAAM,CAAC,OAAO,IAAE;QAC9C,KAAK,aAAa,CAAC,cAAc;YAC/B,uCACK,KAAK,KACR,YAAY,EAAE,EAAE,EAChB,kBAAkB,EAAE,EAAE,EACtB,iBAAiB,EAAE,CAAC,IACrB;QACH,KAAK,aAAa,CAAC,wBAAwB;YACzC,uCACK,KAAK,KACR,iBAAiB,EAAE,MAAM,CAAC,OAAO,IAClC;QACH,KAAK,aAAa,CAAC,qBAAqB;YACtC,OAAO,mBAAmB,CAAC,KAAK,CAAC,CAAA;QACnC,KAAK,aAAa,CAAC,wBAAwB;YACzC,uCACK,KAAK,KACR,oBAAoB,EAAE,MAAM,CAAC,OAAO,IACrC;QACH;YACE,MAAM,IAAI,KAAK,EAAE,CAAA;KACpB;AACH,CAAC,CAAA;AAED,SAAS,mBAAmB,CAC1B,KAAmB,EACnB,MAA8C;;IAE9C,MAAM,gBAAgB,GAAG,MAAM,CAAC,OAAO,CAAA;IACvC,MAAM,eAAe,GACnB,CAAA,MAAA,gBAAgB,CAAC,KAAK,0CAAE,QAAQ;QAChC,CAAA,MAAA,gBAAgB,CAAC,KAAK,0CAAE,MAAM,MAAK,OAAO,CAAC,IAAI,CAAA;IAEjD,MAAM,iBAAiB,GAAG,eAAe;QACvC,CAAC,CAAC,KAAK,CAAC,iBAAiB,GAAG,CAAC;QAC7B,CAAC,CAAC,KAAK,CAAC,iBAAiB,CAAA;IAE3B,uCACK,KAAK,KACR,kBAAkB,EAAE,CAAC,GAAG,CAAC,KAAK,CAAC,kBAAkB,IAAI,EAAE,CAAC,EAAE,gBAAgB,CAAC,EAC3E,iBAAiB,IAClB;AACH,CAAC;AAED,SAAS,mBAAmB,CAAC,KAAmB;IAC9C,MAAM,kBAAkB,GAAG,KAAK,CAAC,kBAAkB,CAAC,GAAG,CAAC,gBAAgB,CAAC,EAAE;QACzE,IAAI,gBAAgB,CAAC,KAAK,CAAC,QAAQ,EAAE;YACnC,gBAAgB,mCACX,gBAAgB,KACnB,KAAK,kCAAO,gBAAgB,CAAC,KAAK,KAAE,QAAQ,EAAE,KAAK,MACpD,CAAA;SACF;QACD,OAAO,gBAAgB,CAAA;IACzB,CAAC,CAAC,CAAA;IACF,MAAM,YAAY,GAAG,KAAK,CAAC,YAAY,CAAC,GAAG,CAAC,WAAW,CAAC,EAAE;QACxD,IAAI,WAAW,CAAC,QAAQ,EAAE;YACxB,WAAW,CAAC,QAAQ,GAAG,KAAK,CAAA;SAC7B;QACD,OAAO,WAAW,CAAA;IACpB,CAAC,CAAC,CAAA;IACF,uCACK,KAAK,KACR,kBAAkB;QAClB,YAAY,EACZ,iBAAiB,EAAE,CAAC,IACrB;AACH,CAAC;AAED,SAAS,oBAAoB,CAC3B,KAAmB,EACnB,MAA8C;IAE9C,MAAM,QAAQ,GAAG,KAAK,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,CAAA;IAC7E,IAAI,QAAQ,GAAG,CAAC,CAAC,EAAE;QACjB,MAAM,YAAY,GAAG,KAAK,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAA;QACvD,IAAI,wBAAwB,GAAG,EAAE,CAAA;QACjC,IAAI,YAAY,EAAE;YAChB,MAAM,mBAAmB,mCACpB,YAAY,GACZ;gBACD,KAAK,kCAAO,YAAY,CAAC,KAAK,KAAE,GAAG,EAAE,MAAM,CAAC,OAAO,CAAC,GAAG,GAAE;aAC1D,CACF,CAAA;YACD,wBAAwB,GAAG;gBACzB,kBAAkB,EAAE;oBAClB,GAAG,KAAK,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC,EAAE,QAAQ,CAAC;sCACzC,mBAAmB;oBACxB,GAAG,KAAK,CAAC,kBAAkB,CAAC,KAAK,CAAC,QAAQ,GAAG,CAAC,CAAC;iBAChD;aACF,CAAA;SACF;QAED,MAAM,iBAAiB,GAAG,KAAK,CAAC,kBAAkB,CAAC,MAAM,CACvD,gBAAgB,CAAC,EAAE,CAAC,gBAAgB,CAAC,KAAK,CAAC,QAAQ,CACpD,CAAC,MAAM,CAAA;QAER,mEACK,KAAK,KACR,YAAY,EAAE;gBACZ,GAAG,KAAK,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,EAAE,QAAQ,CAAC;kCACnC,MAAM,CAAC,OAAO;gBACnB,GAAG,KAAK,CAAC,YAAY,CAAC,KAAK,CAAC,QAAQ,GAAG,CAAC,CAAC;aAC1C,KACE,wBAAwB,KAC3B,iBAAiB,IAClB;KACF;IAED,OAAO,KAAK,CAAA;AACd,CAAC;AAED,SAAS,iBAAiB,CACxB,KAAmB,EACnB,MAA8C;IAE9C,IACE,KAAK,CAAC,YAAY;QAClB,KAAK,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC;QAExD,OAAO,KAAK,CAAA;IACd,uCACK,KAAK,KACR,YAAY,EAAE,CAAC,GAAG,CAAC,KAAK,CAAC,YAAY,IAAI,EAAE,CAAC,EAAE,MAAM,CAAC,OAAO,CAAC,IAC9D;AACH,CAAC"}
@@ -0,0 +1 @@
1
+ export function WebchatReplies(props: any): JSX.Element;
@@ -0,0 +1,42 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import React, { useContext } from 'react';
3
+ import styled from 'styled-components';
4
+ import { WEBCHAT } from '../constants';
5
+ import { WebchatContext } from '../contexts';
6
+ import { BotonicContainerId } from './constants';
7
+ const ScrollableReplies = styled.div `
8
+ overscroll-behavior: contain;
9
+ -webkit-overflow-scrolling: touch;
10
+ `;
11
+ const RepliesContainer = styled.div `
12
+ display: flex;
13
+ text-align: center;
14
+ justify-content: ${props => props.justify};
15
+ flex-wrap: ${props => props.wrap};
16
+ padding-bottom: 10px;
17
+ margin-left: 5px;
18
+ margin-right: 5px;
19
+ overflow-x: scroll;
20
+ `;
21
+ const ReplyContainer = styled.div `
22
+ flex: none;
23
+ display: inline-block;
24
+ margin: 3px;
25
+ `;
26
+ const options = {
27
+ left: 'flex-start',
28
+ center: 'center',
29
+ right: 'flex-end',
30
+ };
31
+ export const WebchatReplies = props => {
32
+ const { webchatState, getThemeProperty, repliesRef } = useContext(WebchatContext);
33
+ let justifyContent = 'center';
34
+ const flexWrap = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.wrapReplies, 'wrap');
35
+ if (flexWrap == 'nowrap')
36
+ justifyContent = 'flex-start';
37
+ else if (getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.alignReplies))
38
+ justifyContent =
39
+ options[getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.alignReplies)];
40
+ return (_jsx(ScrollableReplies, { children: _jsx(RepliesContainer, Object.assign({ id: BotonicContainerId.RepliesContainer, ref: repliesRef, className: 'replies-container', justify: justifyContent, wrap: flexWrap }, { children: webchatState.replies.map((r, i) => (_jsx(ReplyContainer, { children: r }, i))) })) }));
41
+ };
42
+ //# sourceMappingURL=replies.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"replies.js","sourceRoot":"","sources":["../../../src/webchat/replies.jsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AACzC,OAAO,MAAM,MAAM,mBAAmB,CAAA;AAEtC,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAA;AACtC,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAA;AAC5C,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAA;AAEhD,MAAM,iBAAiB,GAAG,MAAM,CAAC,GAAG,CAAA;;;CAGnC,CAAA;AAED,MAAM,gBAAgB,GAAG,MAAM,CAAC,GAAG,CAAA;;;qBAGd,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,OAAO;eAC5B,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,IAAI;;;;;CAKjC,CAAA;AAED,MAAM,cAAc,GAAG,MAAM,CAAC,GAAG,CAAA;;;;CAIhC,CAAA;AAED,MAAM,OAAO,GAAG;IACd,IAAI,EAAE,YAAY;IAClB,MAAM,EAAE,QAAQ;IAChB,KAAK,EAAE,UAAU;CAClB,CAAA;AAED,MAAM,CAAC,MAAM,cAAc,GAAG,KAAK,CAAC,EAAE;IACpC,MAAM,EAAE,YAAY,EAAE,gBAAgB,EAAE,UAAU,EAAE,GAClD,UAAU,CAAC,cAAc,CAAC,CAAA;IAC5B,IAAI,cAAc,GAAG,QAAQ,CAAA;IAC7B,MAAM,QAAQ,GAAG,gBAAgB,CAC/B,OAAO,CAAC,iBAAiB,CAAC,WAAW,EACrC,MAAM,CACP,CAAA;IACD,IAAI,QAAQ,IAAI,QAAQ;QAAE,cAAc,GAAG,YAAY,CAAA;SAClD,IAAI,gBAAgB,CAAC,OAAO,CAAC,iBAAiB,CAAC,YAAY,CAAC;QAC/D,cAAc;YACZ,OAAO,CAAC,gBAAgB,CAAC,OAAO,CAAC,iBAAiB,CAAC,YAAY,CAAC,CAAC,CAAA;IAErE,OAAO,CACL,KAAC,iBAAiB,cAChB,KAAC,gBAAgB,kBACf,EAAE,EAAE,kBAAkB,CAAC,gBAAgB,EACvC,GAAG,EAAE,UAAU,EACf,SAAS,EAAC,mBAAmB,EAC7B,OAAO,EAAE,cAAc,EACvB,IAAI,EAAE,QAAQ,gBAEb,YAAY,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAClC,KAAC,cAAc,cAAU,CAAC,IAAL,CAAC,CAAsB,CAC7C,CAAC,IACe,GACD,CACrB,CAAA;AACH,CAAC,CAAA"}
@@ -0,0 +1 @@
1
+ export function SessionView(props: any): JSX.Element;
@@ -0,0 +1,96 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import React from 'react';
3
+ import JSONTree from 'react-json-tree';
4
+ import styled from 'styled-components';
5
+ import { COLORS } from '../constants';
6
+ import { useWebchat } from './hooks';
7
+ const AttributeContainer = styled.div `
8
+ display: flex;
9
+ flex: none;
10
+ padding: 12px;
11
+ padding-bottom: 0px;
12
+ font-size: 12px;
13
+ font-weight: 600;
14
+ color: ${COLORS.SOLID_WHITE};
15
+ align-items: center;
16
+ `;
17
+ const Label = styled.div `
18
+ flex: none;
19
+ `;
20
+ const Value = styled.div `
21
+ flex: 1 1 auto;
22
+ max-height: 20px;
23
+ font-size: 16px;
24
+ font-weight: 400;
25
+ margin-left: 6px;
26
+ color: ${COLORS.CURIOUS_BLUE};
27
+ overflow-x: hidden;
28
+ `;
29
+ const SessionViewAttribute = props => (_jsxs(AttributeContainer, { children: [_jsx(Label, { children: props.label }), _jsx(Value, { children: props.value })] }));
30
+ const SessionViewContent = styled.div `
31
+ position: relative;
32
+ width: ${props => (props.show ? '100%' : '0%')};
33
+ height: 100%;
34
+ display: flex;
35
+ background-color: ${COLORS.DAINTREE_BLUE};
36
+ font-family: Arial, Helvetica, sans-serif;
37
+ flex-direction: column;
38
+ z-index: 100000;
39
+ transition: all 0.2s ease-in-out;
40
+ `;
41
+ const ToggleTab = styled.div `
42
+ position: absolute;
43
+ top: 10px;
44
+ right: -32px;
45
+ width: 32px;
46
+ height: 32px;
47
+ cursor: pointer;
48
+ display: flex;
49
+ align-items: center;
50
+ justify-content: center;
51
+ color: ${COLORS.SOLID_WHITE_ALPHA_0_8};
52
+ font-size: 14px;
53
+ font-weight: 600;
54
+ background-color: ${COLORS.DAINTREE_BLUE};
55
+ flex-direction: column;
56
+ z-index: 100000;
57
+ border-top-right-radius: 6px;
58
+ border-bottom-right-radius: 6px;
59
+ `;
60
+ const ContentContainer = styled.div `
61
+ overflow-y: auto;
62
+ overflow-x: auto;
63
+ display: flex;
64
+ flex: 1 1 auto;
65
+ flex-direction: column;
66
+ `;
67
+ const Title = styled.div `
68
+ padding: 12px;
69
+ text-align: center;
70
+ color: ${COLORS.SOLID_WHITE};
71
+ border-bottom: 1px solid ${COLORS.SOLID_WHITE_ALPHA_0_2};
72
+ `;
73
+ const SessionContainer = styled.div `
74
+ flex: 1 1 auto;
75
+ height: 100%;
76
+ overflow-y: auto;
77
+ `;
78
+ const KeepSessionContainer = styled.div `
79
+ flex: none;
80
+ padding: 12px;
81
+ color: ${COLORS.SOLID_WHITE_ALPHA_0_8};
82
+ font-size: 12px;
83
+ `;
84
+ export const SessionView = props => {
85
+ // eslint-disable-next-line react-hooks/rules-of-hooks
86
+ const { webchatState, updateDevSettings } = props.webchatHooks || useWebchat();
87
+ const { latestInput: input, session, lastRoutePath } = webchatState;
88
+ const toggleSessionView = () => updateDevSettings(Object.assign(Object.assign({}, webchatState.devSettings), { showSessionView: !webchatState.devSettings.showSessionView }));
89
+ const toggleKeepSessionOnReload = () => updateDevSettings(Object.assign(Object.assign({}, webchatState.devSettings), { keepSessionOnReload: !webchatState.devSettings.keepSessionOnReload }));
90
+ return (_jsxs(SessionViewContent, Object.assign({ show: webchatState.devSettings.showSessionView }, { children: [_jsx(ToggleTab, Object.assign({ onClick: toggleSessionView }, { children: webchatState.devSettings.showSessionView ? '⇤' : '⇥' })), _jsxs(ContentContainer, { children: [_jsx(Title, { children: "Botonic Dev Console" }), _jsx(SessionViewAttribute, { label: 'INPUT:', value: input && Object.keys(input).length
91
+ ? `[${input.type}] ${input.data || ''}`
92
+ : '' }), _jsx(SessionViewAttribute, { label: 'PAYLOAD:', value: input.payload }), _jsx(SessionViewAttribute, { label: 'INTENT:', value: input.intent
93
+ ? `${input.intent} (${(input.confidence * 100).toFixed(1)}%)`
94
+ : '' }), _jsx(SessionViewAttribute, { label: 'PATH:', value: lastRoutePath ? `/${lastRoutePath}` : '/' }), _jsx(SessionViewAttribute, { label: 'SESSION:' }), _jsx(SessionContainer, { children: _jsx(JSONTree, { data: session, hideRoot: true }) }), _jsx(KeepSessionContainer, { children: _jsxs("label", { children: [_jsx("input", { type: 'checkbox', name: 'toggleKeepSessionOnReload', checked: Boolean(webchatState.devSettings.keepSessionOnReload), onChange: toggleKeepSessionOnReload }), "Keep session on reload"] }) })] })] })));
95
+ };
96
+ //# sourceMappingURL=session-view.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"session-view.js","sourceRoot":"","sources":["../../../src/webchat/session-view.jsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ export declare enum EventAction {
2
+ FeedbackKnowledgebase = "feedback_knowledgebase"
3
+ }
4
+ export declare enum FeedbackOption {
5
+ ThumbsUp = "thumbsUp",
6
+ ThumbsDown = "thumbsDown"
7
+ }
@@ -0,0 +1,10 @@
1
+ export var EventAction;
2
+ (function (EventAction) {
3
+ EventAction["FeedbackKnowledgebase"] = "feedback_knowledgebase";
4
+ })(EventAction || (EventAction = {}));
5
+ export var FeedbackOption;
6
+ (function (FeedbackOption) {
7
+ FeedbackOption["ThumbsUp"] = "thumbsUp";
8
+ FeedbackOption["ThumbsDown"] = "thumbsDown";
9
+ })(FeedbackOption || (FeedbackOption = {}));
10
+ //# sourceMappingURL=tracking.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tracking.js","sourceRoot":"","sources":["../../../src/webchat/tracking.ts"],"names":[],"mappings":"AAAA,MAAM,CAAN,IAAY,WAEX;AAFD,WAAY,WAAW;IACrB,+DAAgD,CAAA;AAClD,CAAC,EAFW,WAAW,KAAX,WAAW,QAEtB;AAED,MAAM,CAAN,IAAY,cAGX;AAHD,WAAY,cAAc;IACxB,uCAAqB,CAAA;IACrB,2CAAyB,CAAA;AAC3B,CAAC,EAHW,cAAc,KAAd,cAAc,QAGzB"}
@@ -0,0 +1 @@
1
+ export declare const TriggerButton: () => JSX.Element;
@@ -0,0 +1,28 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useContext } from 'react';
3
+ import { ROLES, WEBCHAT } from '../../constants';
4
+ import { WebchatContext } from '../../contexts';
5
+ import { resolveImage } from '../../util/environment';
6
+ import { StyledTriggerButton, TriggerImage, UnreadMessagesCounter, } from './styles';
7
+ export const TriggerButton = () => {
8
+ const { webchatState, getThemeProperty, toggleWebchat } = useContext(WebchatContext);
9
+ const getTriggerImage = () => {
10
+ const image = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.triggerButtonImage, undefined);
11
+ if (!image) {
12
+ webchatState.theme.triggerButtonImage = WEBCHAT.DEFAULTS.LOGO;
13
+ return null;
14
+ }
15
+ return image;
16
+ };
17
+ const triggerButtonImage = getTriggerImage();
18
+ const triggerButtonStyle = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.triggerButtonStyle);
19
+ const notificationsTriggerButtonEnabled = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.notificationsTriggerButtonEnabled, false);
20
+ const notificationsEnabled = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.notificationsEnabled, notificationsTriggerButtonEnabled);
21
+ const CustomTriggerButton = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.customTrigger, undefined);
22
+ const handleClick = (event) => {
23
+ toggleWebchat(true);
24
+ event.preventDefault();
25
+ };
26
+ return (_jsxs("div", Object.assign({ onClick: handleClick }, { children: [webchatState.numUnreadMessages !== 0 && notificationsEnabled && (_jsx(UnreadMessagesCounter, Object.assign({ className: 'trigger-notifications' }, { children: webchatState.numUnreadMessages }))), CustomTriggerButton ? (_jsx(CustomTriggerButton, {})) : (_jsx(StyledTriggerButton, Object.assign({ role: ROLES.TRIGGER_BUTTON, style: triggerButtonStyle }, { children: triggerButtonImage && (_jsx(TriggerImage, { src: resolveImage(triggerButtonImage) })) })))] })));
27
+ };
28
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/webchat/trigger-button/index.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AAEzC,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAA;AAChD,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAC/C,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAA;AACrD,OAAO,EACL,mBAAmB,EACnB,YAAY,EACZ,qBAAqB,GACtB,MAAM,UAAU,CAAA;AAEjB,MAAM,CAAC,MAAM,aAAa,GAAG,GAAgB,EAAE;IAC7C,MAAM,EAAE,YAAY,EAAE,gBAAgB,EAAE,aAAa,EAAE,GACrD,UAAU,CAAC,cAAc,CAAC,CAAA;IAE5B,MAAM,eAAe,GAAG,GAAG,EAAE;QAC3B,MAAM,KAAK,GAAG,gBAAgB,CAC5B,OAAO,CAAC,iBAAiB,CAAC,kBAAkB,EAC5C,SAAS,CACV,CAAA;QAED,IAAI,CAAC,KAAK,EAAE;YACV,YAAY,CAAC,KAAK,CAAC,kBAAkB,GAAG,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAA;YAC7D,OAAO,IAAI,CAAA;SACZ;QACD,OAAO,KAAK,CAAA;IACd,CAAC,CAAA;IAED,MAAM,kBAAkB,GAAG,eAAe,EAAE,CAAA;IAE5C,MAAM,kBAAkB,GAAG,gBAAgB,CACzC,OAAO,CAAC,iBAAiB,CAAC,kBAAkB,CAC7C,CAAA;IAED,MAAM,iCAAiC,GAAG,gBAAgB,CACxD,OAAO,CAAC,iBAAiB,CAAC,iCAAiC,EAC3D,KAAK,CACN,CAAA;IAED,MAAM,oBAAoB,GAAG,gBAAgB,CAC3C,OAAO,CAAC,iBAAiB,CAAC,oBAAoB,EAC9C,iCAAiC,CAClC,CAAA;IAED,MAAM,mBAAmB,GAAG,gBAAgB,CAC1C,OAAO,CAAC,iBAAiB,CAAC,aAAa,EACvC,SAAS,CACV,CAAA;IAED,MAAM,WAAW,GAAG,CAAC,KAAU,EAAE,EAAE;QACjC,aAAa,CAAC,IAAI,CAAC,CAAA;QACnB,KAAK,CAAC,cAAc,EAAE,CAAA;IACxB,CAAC,CAAA;IAED,OAAO,CACL,6BAAK,OAAO,EAAE,WAAW,iBACtB,YAAY,CAAC,iBAAiB,KAAK,CAAC,IAAI,oBAAoB,IAAI,CAC/D,KAAC,qBAAqB,kBAAC,SAAS,EAAC,uBAAuB,gBACrD,YAAY,CAAC,iBAAiB,IACT,CACzB,EACA,mBAAmB,CAAC,CAAC,CAAC,CACrB,KAAC,mBAAmB,KAAG,CACxB,CAAC,CAAC,CAAC,CACF,KAAC,mBAAmB,kBAClB,IAAI,EAAE,KAAK,CAAC,cAAc,EAC1B,KAAK,EAAE,kBAAkB,gBAExB,kBAAkB,IAAI,CACrB,KAAC,YAAY,IAAC,GAAG,EAAE,YAAY,CAAC,kBAAkB,CAAC,GAAI,CACxD,IACmB,CACvB,KACG,CACP,CAAA;AACH,CAAC,CAAA"}
@@ -0,0 +1,3 @@
1
+ export declare const StyledTriggerButton: import("styled-components").StyledComponent<"div", any, {}, never>;
2
+ export declare const UnreadMessagesCounter: import("styled-components").StyledComponent<"div", any, {}, never>;
3
+ export declare const TriggerImage: import("styled-components").StyledComponent<"img", any, {}, never>;
@@ -0,0 +1,36 @@
1
+ import styled from 'styled-components';
2
+ import { COLORS } from '../../constants';
3
+ export const StyledTriggerButton = styled.div `
4
+ cursor: pointer;
5
+ position: fixed;
6
+ background: ${COLORS.SOLID_WHITE};
7
+ border-radius: 50%;
8
+ display: flex;
9
+ align-items: center;
10
+ justify-content: center;
11
+ overflow: hidden;
12
+ width: 65px;
13
+ height: 65px;
14
+ bottom: 20px;
15
+ right: 10px;
16
+ padding: 8px;
17
+ `;
18
+ export const UnreadMessagesCounter = styled.div `
19
+ display: flex;
20
+ justify-content: center;
21
+ align-items: center;
22
+ border-radius: 50%;
23
+ position: fixed;
24
+ right: 20px;
25
+ bottom: 80px;
26
+ width: 24px;
27
+ height: 24px;
28
+ background-color: ${COLORS.RED_NOTIFICATIONS};
29
+ color: white;
30
+ z-index: 10;
31
+ `;
32
+ export const TriggerImage = styled.img `
33
+ max-width: 100%;
34
+ max-height: 100%;
35
+ `;
36
+ //# sourceMappingURL=styles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"styles.js","sourceRoot":"","sources":["../../../../src/webchat/trigger-button/styles.ts"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,mBAAmB,CAAA;AAEtC,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAA;AAExC,MAAM,CAAC,MAAM,mBAAmB,GAAG,MAAM,CAAC,GAAG,CAAA;;;gBAG7B,MAAM,CAAC,WAAW;;;;;;;;;;;CAWjC,CAAA;AAED,MAAM,CAAC,MAAM,qBAAqB,GAAG,MAAM,CAAC,GAAG,CAAA;;;;;;;;;;sBAUzB,MAAM,CAAC,iBAAiB;;;CAG7C,CAAA;AAED,MAAM,CAAC,MAAM,YAAY,GAAG,MAAM,CAAC,GAAG,CAAA;;;CAGrC,CAAA"}
@@ -0,0 +1,3 @@
1
+ import React from 'react';
2
+ declare const TypingIndicator: React.ForwardRefExoticComponent<Pick<any, string | number | symbol> & React.RefAttributes<HTMLDivElement>>;
3
+ export default TypingIndicator;
@@ -0,0 +1,8 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { forwardRef } from 'react';
3
+ import { COLORS, ROLES } from '../../constants';
4
+ import { Dot, TypingContainer, TypingMsgWrapper } from './styles';
5
+ const TypingIndicator = forwardRef((_props, ref) => (_jsx(TypingContainer, Object.assign({ ref: ref }, { children: _jsxs(TypingMsgWrapper, Object.assign({ role: ROLES.TYPING_INDICATOR, className: 'typing-indicator', backgroundColor: COLORS.SEASHELL_WHITE }, { children: [_jsx(Dot, {}), _jsx(Dot, {}), _jsx(Dot, {})] })) }))));
6
+ TypingIndicator.displayName = 'TypingIndicator';
7
+ export default TypingIndicator;
8
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/webchat/typing-indicator/index.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAgB,UAAU,EAAE,MAAM,OAAO,CAAA;AAEvD,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAA;AAC/C,OAAO,EAAE,GAAG,EAAE,eAAe,EAAE,gBAAgB,EAAE,MAAM,UAAU,CAAA;AAEjE,MAAM,eAAe,GAAG,UAAU,CAChC,CAAC,MAAM,EAAE,GAAiC,EAAE,EAAE,CAAC,CAC7C,KAAC,eAAe,kBAAC,GAAG,EAAE,GAAG,gBACvB,MAAC,gBAAgB,kBACf,IAAI,EAAE,KAAK,CAAC,gBAAgB,EAC5B,SAAS,EAAC,kBAAkB,EAC5B,eAAe,EAAE,MAAM,CAAC,cAAc,iBAEtC,KAAC,GAAG,KAAG,EACP,KAAC,GAAG,KAAG,EACP,KAAC,GAAG,KAAG,KACU,IACH,CACnB,CACF,CAAA;AAED,eAAe,CAAC,WAAW,GAAG,iBAAiB,CAAA;AAE/C,eAAe,eAAe,CAAA"}
@@ -0,0 +1,7 @@
1
+ export declare const TypingContainer: import("styled-components").StyledComponent<"div", any, {}, never>;
2
+ interface TypingMsgWrapperProps {
3
+ backgroundColor: string;
4
+ }
5
+ export declare const TypingMsgWrapper: import("styled-components").StyledComponent<"div", any, TypingMsgWrapperProps, never>;
6
+ export declare const Dot: import("styled-components").StyledComponent<"span", any, {}, never>;
7
+ export {};
@@ -0,0 +1,46 @@
1
+ import styled, { keyframes } from 'styled-components';
2
+ const blink = keyframes `
3
+ 50% {
4
+ opacity: 1;
5
+ }
6
+ `;
7
+ const bulge = keyframes `
8
+ 50% {
9
+ transform: scale(1.05);
10
+ }
11
+ `;
12
+ export const TypingContainer = styled.div `
13
+ padding: 0px 8px 8px 8px;
14
+ `;
15
+ export const TypingMsgWrapper = styled.div `
16
+ will-change: transform;
17
+ width: 44px;
18
+ line-height: 0px;
19
+ border-radius: 20px;
20
+ padding: 8px 2px;
21
+ text-align: center;
22
+ display: block;
23
+ margin: 8px;
24
+ position: relative;
25
+ animation: 2s ${bulge} infinite ease-out;
26
+ background-color: ${props => props.backgroundColor};
27
+ `;
28
+ export const Dot = styled.span `
29
+ height: 6px;
30
+ width: 6px;
31
+ margin: 0 1px;
32
+ background-color: #9e9ea1;
33
+ display: inline-block;
34
+ border-radius: 50%;
35
+ opacity: 0.4;
36
+ &:nth-of-type(1) {
37
+ animation: 1s ${blink} infinite 0.3333s;
38
+ }
39
+ &:nth-of-type(2) {
40
+ animation: 1s ${blink} infinite 0.6666s;
41
+ }
42
+ &:nth-of-type(3) {
43
+ animation: 1s ${blink} infinite 1s;
44
+ }
45
+ `;
46
+ //# sourceMappingURL=styles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"styles.js","sourceRoot":"","sources":["../../../../src/webchat/typing-indicator/styles.ts"],"names":[],"mappings":"AAAA,OAAO,MAAM,EAAE,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAA;AAErD,MAAM,KAAK,GAAG,SAAS,CAAA;;;;CAItB,CAAA;AAED,MAAM,KAAK,GAAG,SAAS,CAAA;;;;CAItB,CAAA;AAED,MAAM,CAAC,MAAM,eAAe,GAAG,MAAM,CAAC,GAAG,CAAA;;CAExC,CAAA;AAMD,MAAM,CAAC,MAAM,gBAAgB,GAAG,MAAM,CAAC,GAAG,CAAuB;;;;;;;;;;kBAU/C,KAAK;sBACD,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,eAAe;CACnD,CAAA;AAED,MAAM,CAAC,MAAM,GAAG,GAAG,MAAM,CAAC,IAAI,CAAA;;;;;;;;;oBASV,KAAK;;;oBAGL,KAAK;;;oBAGL,KAAK;;CAExB,CAAA"}
@@ -0,0 +1 @@
1
+ export function useStorageState(storage: any, key: any, defaultValue: any): any[];