@botonic/react 0.30.8-alpha.0 → 0.30.8

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 +2 -2
@@ -0,0 +1,118 @@
1
+ import styled from 'styled-components';
2
+ import { COLORS } from '../../constants';
3
+ export const MessageContainer = styled.div `
4
+ display: flex;
5
+ justify-content: ${props => (props.isSentByUser ? 'flex-end' : 'flex-start')};
6
+ position: relative;
7
+ padding: 0px 6px;
8
+ `;
9
+ export const BotMessageImageContainer = styled.div `
10
+ width: 28px;
11
+ padding: 12px 4px;
12
+ flex: none;
13
+ display: flex;
14
+ align-items: center;
15
+ justify-content: center;
16
+ `;
17
+ export const BlobContainer = styled.div `
18
+ position: relative;
19
+ margin: 8px;
20
+ border-radius: 8px;
21
+ background-color: ${props => props.bgcolor};
22
+ color: ${props => props.color};
23
+ max-width: ${props => props.blob
24
+ ? props.blobwidth
25
+ ? props.blobwidth
26
+ : '60%'
27
+ : 'calc(100% - 16px)'};
28
+ `;
29
+ export const BlobText = styled.div `
30
+ padding: ${props => (props.blob ? '8px 12px' : '0px')};
31
+ display: flex;
32
+ flex-direction: column;
33
+ white-space: pre-line;
34
+ ${props => props.markdownstyle}
35
+ `;
36
+ export const BlobTickContainer = styled.div `
37
+ position: absolute;
38
+ box-sizing: border-box;
39
+ height: 100%;
40
+ padding: 18px 0px 18px 0px;
41
+ display: flex;
42
+ top: 0;
43
+ align-items: center;
44
+ `;
45
+ export const BlobTick = styled.div `
46
+ position: relative;
47
+ margin: -${props => props.pointerSize}px 0px;
48
+ border: ${props => props.pointerSize}px solid ${COLORS.TRANSPARENT};
49
+ `;
50
+ export const TimestampContainer = styled.div `
51
+ display: flex;
52
+ position: relative;
53
+ justify-content: ${props => (props.isSentByUser ? 'flex-end' : 'flex-start')};
54
+ align-items: center;
55
+ gap: 10px;
56
+
57
+ box-sizing: border-box;
58
+ width: 100%;
59
+
60
+ img {
61
+ max-width: 20px;
62
+ }
63
+ `;
64
+ export const TimestampText = styled.div `
65
+ @import url('https://fonts.googleapis.com/css?family=Lato');
66
+ font-family: Lato;
67
+ font-size: 10px;
68
+ color: ${COLORS.SOLID_BLACK};
69
+ text-align: ${props => (props.isSentByUser ? 'right' : 'left')};
70
+ `;
71
+ export const MessageFooterContainer = styled.div `
72
+ display: flex;
73
+ justify-content: space-between;
74
+ align-items: center;
75
+
76
+ box-sizing: border-box;
77
+ padding: 0px 15px 4px 15px;
78
+ padding-top: ${props => (props.isSentByUser ? '0px' : '4px')};
79
+ width: 100%;
80
+ `;
81
+ export const FeedbackMessageContainer = styled.div `
82
+ display: flex;
83
+ justify-content: space-between;
84
+ align-items: center;
85
+ gap: 4px;
86
+
87
+ box-sizing: border-box;
88
+ `;
89
+ export const FeedbackButton = styled.button `
90
+ display: flex;
91
+ justify-content: center;
92
+ align-items: center;
93
+
94
+ background: none;
95
+ box-sizing: border-box;
96
+ border: none;
97
+ border-radius: 4px;
98
+ padding: 8px 8px;
99
+ height: 24px;
100
+ width: 24px;
101
+
102
+ &:hover {
103
+ cursor: pointer;
104
+ background-color: #f4f3f4;
105
+ }
106
+
107
+ &:disabled {
108
+ cursor: default;
109
+ background: none;
110
+ opacity: 0.3;
111
+ }
112
+
113
+ &.clicked {
114
+ opacity: 0;
115
+ transition: 1s 1s;
116
+ }
117
+ `;
118
+ //# sourceMappingURL=styles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"styles.js","sourceRoot":"","sources":["../../../../src/components/message/styles.ts"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,mBAAmB,CAAA;AAEtC,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAA;AAMxC,MAAM,CAAC,MAAM,gBAAgB,GAAG,MAAM,CAAC,GAAG,CAAuB;;qBAE5C,KAAK,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,YAAY,CAAC;;;CAG7E,CAAA;AAED,MAAM,CAAC,MAAM,wBAAwB,GAAG,MAAM,CAAC,GAAG,CAAA;;;;;;;CAOjD,CAAA;AAOD,MAAM,CAAC,MAAM,aAAa,GAAG,MAAM,CAAC,GAAG,CAAoB;;;;sBAIrC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,OAAO;WACjC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,KAAK;eAChB,KAAK,CAAC,EAAE,CACnB,KAAK,CAAC,IAAI;IACR,CAAC,CAAC,KAAK,CAAC,SAAS;QACf,CAAC,CAAC,KAAK,CAAC,SAAS;QACjB,CAAC,CAAC,KAAK;IACT,CAAC,CAAC,mBAAmB;CAC1B,CAAA;AAMD,MAAM,CAAC,MAAM,QAAQ,GAAG,MAAM,CAAC,GAAG,CAAe;aACpC,KAAK,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,KAAK,CAAC;;;;IAInD,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,aAAa;CAC/B,CAAA;AAED,MAAM,CAAC,MAAM,iBAAiB,GAAG,MAAM,CAAC,GAAG,CAAA;;;;;;;;CAQ1C,CAAA;AAMD,MAAM,CAAC,MAAM,QAAQ,GAAG,MAAM,CAAC,GAAG,CAAe;;aAEpC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,WAAW;YAC3B,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,WAAW,YAAY,MAAM,CAAC,WAAW;CACnE,CAAA;AAKD,MAAM,CAAC,MAAM,kBAAkB,GAAG,MAAM,CAAC,GAAG,CAAyB;;;qBAGhD,KAAK,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,YAAY,CAAC;;;;;;;;;;CAU7E,CAAA;AAKD,MAAM,CAAC,MAAM,aAAa,GAAG,MAAM,CAAC,GAAG,CAAoB;;;;WAIhD,MAAM,CAAC,WAAW;gBACb,KAAK,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC;CAC/D,CAAA;AAED,MAAM,CAAC,MAAM,sBAAsB,GAAG,MAAM,CAAC,GAAG,CAAyB;;;;;;;iBAOxD,KAAK,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC;;CAE7D,CAAA;AAED,MAAM,CAAC,MAAM,wBAAwB,GAAG,MAAM,CAAC,GAAG,CAAA;;;;;;;CAOjD,CAAA;AAED,MAAM,CAAC,MAAM,cAAc,GAAG,MAAM,CAAC,MAAM,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA4B1C,CAAA"}
@@ -0,0 +1,13 @@
1
+ import { SENDERS } from '../../index-types';
2
+ export declare const resolveMessageTimestamps: (getThemeProperty: any, timestampEnabled: any) => {
3
+ timestampsEnabled: boolean;
4
+ getFormattedTimestamp: any;
5
+ timestampStyle: any;
6
+ };
7
+ interface MessageTimestampProps {
8
+ timestamp: string;
9
+ style: Record<string, unknown>;
10
+ sentBy: SENDERS;
11
+ }
12
+ export declare const MessageTimestamp: ({ timestamp, style, sentBy, }: MessageTimestampProps) => JSX.Element;
13
+ export {};
@@ -0,0 +1,40 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useContext } from 'react';
3
+ import { WEBCHAT } from '../../constants';
4
+ import { WebchatContext } from '../../contexts';
5
+ import { SENDERS } from '../../index-types';
6
+ import { resolveImage } from '../../util';
7
+ import { TimestampContainer, TimestampText } from './styles';
8
+ export const resolveMessageTimestamps = (getThemeProperty, timestampEnabled) => {
9
+ const timestampsFormat = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.messageTimestampsFormat);
10
+ const timestampStyle = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.messageTimestampsStyle);
11
+ const timestampsEnabled = Boolean(timestampEnabled !== undefined
12
+ ? timestampEnabled
13
+ : getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.enableMessageTimestamps, Boolean(timestampStyle) || Boolean(timestampsFormat) || false));
14
+ const defaultTimestampFormat = {
15
+ month: 'short',
16
+ day: 'numeric',
17
+ hour: 'numeric',
18
+ minute: 'numeric',
19
+ second: 'numeric',
20
+ };
21
+ const getFormattedTimestamp = timestampsFormat
22
+ ? timestampsFormat()
23
+ : // @ts-ignore
24
+ new Date().toLocaleString(undefined, defaultTimestampFormat);
25
+ return {
26
+ timestampsEnabled,
27
+ getFormattedTimestamp,
28
+ timestampStyle,
29
+ };
30
+ };
31
+ export const MessageTimestamp = ({ timestamp, style, sentBy, }) => {
32
+ const { getThemeProperty } = useContext(WebchatContext);
33
+ const isSentByUser = sentBy === SENDERS.user;
34
+ const isSentByAgent = sentBy === SENDERS.agent;
35
+ const BotMessageImage = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.botMessageImage, undefined);
36
+ const AgentMessageImage = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.agentMessageImage, BotMessageImage);
37
+ const timestampsWithImage = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.messageTimestampsWithImage);
38
+ return (_jsxs(TimestampContainer, Object.assign({ className: `botonic-timestamp-container ${sentBy}`, isSentByUser: isSentByUser }, { children: [timestampsWithImage && BotMessageImage && !isSentByUser && (_jsx("img", { src: resolveImage(isSentByAgent ? AgentMessageImage : BotMessageImage) })), _jsx(TimestampText, Object.assign({ isSentByUser: isSentByUser, style: style }, { children: timestamp }))] })));
39
+ };
40
+ //# sourceMappingURL=timestamps.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"timestamps.js","sourceRoot":"","sources":["../../../../src/components/message/timestamps.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AAEzC,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAA;AACzC,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAC/C,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAA;AAC3C,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAA;AACzC,OAAO,EAAE,kBAAkB,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA;AAE5D,MAAM,CAAC,MAAM,wBAAwB,GAAG,CACtC,gBAAgB,EAChB,gBAAgB,EAChB,EAAE;IACF,MAAM,gBAAgB,GAAG,gBAAgB,CACvC,OAAO,CAAC,iBAAiB,CAAC,uBAAuB,CAClD,CAAA;IACD,MAAM,cAAc,GAAG,gBAAgB,CACrC,OAAO,CAAC,iBAAiB,CAAC,sBAAsB,CACjD,CAAA;IACD,MAAM,iBAAiB,GAAG,OAAO,CAC/B,gBAAgB,KAAK,SAAS;QAC5B,CAAC,CAAC,gBAAgB;QAClB,CAAC,CAAC,gBAAgB,CACd,OAAO,CAAC,iBAAiB,CAAC,uBAAuB,EACjD,OAAO,CAAC,cAAc,CAAC,IAAI,OAAO,CAAC,gBAAgB,CAAC,IAAI,KAAK,CAC9D,CACN,CAAA;IAED,MAAM,sBAAsB,GAAG;QAC7B,KAAK,EAAE,OAAO;QACd,GAAG,EAAE,SAAS;QACd,IAAI,EAAE,SAAS;QACf,MAAM,EAAE,SAAS;QACjB,MAAM,EAAE,SAAS;KAClB,CAAA;IAED,MAAM,qBAAqB,GAAG,gBAAgB;QAC5C,CAAC,CAAC,gBAAgB,EAAE;QACpB,CAAC,CAAC,aAAa;YACb,IAAI,IAAI,EAAE,CAAC,cAAc,CAAC,SAAS,EAAE,sBAAsB,CAAC,CAAA;IAEhE,OAAO;QACL,iBAAiB;QACjB,qBAAqB;QACrB,cAAc;KACf,CAAA;AACH,CAAC,CAAA;AAQD,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,EAC/B,SAAS,EACT,KAAK,EACL,MAAM,GACgB,EAAE,EAAE;IAC1B,MAAM,EAAE,gBAAgB,EAAE,GAAG,UAAU,CAAC,cAAc,CAAC,CAAA;IAEvD,MAAM,YAAY,GAAG,MAAM,KAAK,OAAO,CAAC,IAAI,CAAA;IAC5C,MAAM,aAAa,GAAG,MAAM,KAAK,OAAO,CAAC,KAAK,CAAA;IAE9C,MAAM,eAAe,GAAG,gBAAgB,CACtC,OAAO,CAAC,iBAAiB,CAAC,eAAe,EACzC,SAAS,CACV,CAAA;IAED,MAAM,iBAAiB,GAAG,gBAAgB,CACxC,OAAO,CAAC,iBAAiB,CAAC,iBAAiB,EAC3C,eAAe,CAChB,CAAA;IAED,MAAM,mBAAmB,GAAG,gBAAgB,CAC1C,OAAO,CAAC,iBAAiB,CAAC,0BAA0B,CACrD,CAAA;IAED,OAAO,CACL,MAAC,kBAAkB,kBACjB,SAAS,EAAE,+BAA+B,MAAM,EAAE,EAClD,YAAY,EAAE,YAAY,iBAEzB,mBAAmB,IAAI,eAAe,IAAI,CAAC,YAAY,IAAI,CAC1D,cACE,GAAG,EAAE,YAAY,CACf,aAAa,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,eAAe,CACpD,GACD,CACH,EACD,KAAC,aAAa,kBAAC,YAAY,EAAE,YAAY,EAAE,KAAK,EAAE,KAAK,gBACpD,SAAS,IACI,KACG,CACtB,CAAA;AACH,CAAC,CAAA"}
@@ -0,0 +1 @@
1
+ export function MessageTemplate(props: any): any;
@@ -0,0 +1,9 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import React from 'react';
3
+ import { renderComponent } from '../util/react';
4
+ export const MessageTemplate = props => {
5
+ const renderBrowser = () => null;
6
+ const renderNode = () => (_jsx("message", Object.assign({ type: 'template' }, { children: _jsx("pre", { dangerouslySetInnerHTML: { __html: JSON.stringify(props.payload) } }) })));
7
+ return renderComponent({ renderBrowser, renderNode });
8
+ };
9
+ //# sourceMappingURL=message-template.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"message-template.js","sourceRoot":"","sources":["../../../src/components/message-template.jsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAA;AAE/C,MAAM,CAAC,MAAM,eAAe,GAAG,KAAK,CAAC,EAAE;IACrC,MAAM,aAAa,GAAG,GAAG,EAAE,CAAC,IAAI,CAAA;IAChC,MAAM,UAAU,GAAG,GAAG,EAAE,CAAC,CACvB,gCAAS,IAAI,EAAC,UAAU,gBACtB,cACE,uBAAuB,EAAE,EAAE,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,GAClE,IACM,CACX,CAAA;IACD,OAAO,eAAe,CAAC,EAAE,aAAa,EAAE,UAAU,EAAE,CAAC,CAAA;AACvD,CAAC,CAAA"}
@@ -0,0 +1,17 @@
1
+ export const MAX_CHARACTERS_FACEBOOK: 640;
2
+ export class MultichannelFacebook {
3
+ convertText(props: any, originalText: any): {
4
+ texts: any[];
5
+ propsLastText: any;
6
+ propsWithoutChildren: any;
7
+ } | {
8
+ propsLastText: any;
9
+ texts?: undefined;
10
+ propsWithoutChildren?: undefined;
11
+ };
12
+ splitText(originalText: any): any[];
13
+ getNewProps(props: any, lastText: any): {
14
+ propsLastText: any;
15
+ propsWithoutChildren: any;
16
+ };
17
+ }
@@ -0,0 +1,43 @@
1
+ export const MAX_CHARACTERS_FACEBOOK = 640;
2
+ export class MultichannelFacebook {
3
+ constructor() { }
4
+ convertText(props, originalText) {
5
+ if (originalText.length > MAX_CHARACTERS_FACEBOOK) {
6
+ const texts = this.splitText(originalText);
7
+ const lastText = texts.pop();
8
+ const { propsLastText, propsWithoutChildren } = this.getNewProps(props, lastText);
9
+ return { texts, propsLastText, propsWithoutChildren };
10
+ }
11
+ return { propsLastText: props };
12
+ }
13
+ splitText(originalText) {
14
+ const lines = originalText.split('\n');
15
+ const initialText = lines.shift();
16
+ const texts = [initialText];
17
+ let index = 0;
18
+ lines.forEach(currentText => {
19
+ if (texts[index].length + currentText.length > MAX_CHARACTERS_FACEBOOK) {
20
+ index++;
21
+ texts.push(currentText);
22
+ }
23
+ else {
24
+ texts[index] = texts[index].concat('\n', currentText);
25
+ }
26
+ });
27
+ return texts;
28
+ }
29
+ // modifies the props to keep the children only for the last text message, this message will be the one with buttons and replies
30
+ getNewProps(props, lastText) {
31
+ const propsLastText = Object.assign({}, props);
32
+ propsLastText.children = [lastText];
33
+ if (Array.isArray(props.children)) {
34
+ props.children
35
+ .filter(e => e.type)
36
+ .forEach(e => propsLastText.children.push(e));
37
+ }
38
+ const propsWithoutChildren = Object.assign({}, props);
39
+ delete propsWithoutChildren.children;
40
+ return { propsLastText, propsWithoutChildren };
41
+ }
42
+ }
43
+ //# sourceMappingURL=facebook.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"facebook.js","sourceRoot":"","sources":["../../../../../src/components/multichannel/facebook/facebook.jsx"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,uBAAuB,GAAG,GAAG,CAAA;AAE1C,MAAM,OAAO,oBAAoB;IAC/B,gBAAe,CAAC;IAEhB,WAAW,CAAC,KAAK,EAAE,YAAY;QAC7B,IAAI,YAAY,CAAC,MAAM,GAAG,uBAAuB,EAAE;YACjD,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,CAAA;YAC1C,MAAM,QAAQ,GAAG,KAAK,CAAC,GAAG,EAAE,CAAA;YAC5B,MAAM,EAAE,aAAa,EAAE,oBAAoB,EAAE,GAAG,IAAI,CAAC,WAAW,CAC9D,KAAK,EACL,QAAQ,CACT,CAAA;YACD,OAAO,EAAE,KAAK,EAAE,aAAa,EAAE,oBAAoB,EAAE,CAAA;SACtD;QACD,OAAO,EAAE,aAAa,EAAE,KAAK,EAAE,CAAA;IACjC,CAAC;IAED,SAAS,CAAC,YAAY;QACpB,MAAM,KAAK,GAAG,YAAY,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;QACtC,MAAM,WAAW,GAAG,KAAK,CAAC,KAAK,EAAE,CAAA;QACjC,MAAM,KAAK,GAAG,CAAC,WAAW,CAAC,CAAA;QAC3B,IAAI,KAAK,GAAG,CAAC,CAAA;QACb,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE;YAC1B,IAAI,KAAK,CAAC,KAAK,CAAC,CAAC,MAAM,GAAG,WAAW,CAAC,MAAM,GAAG,uBAAuB,EAAE;gBACtE,KAAK,EAAE,CAAA;gBACP,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA;aACxB;iBAAM;gBACL,KAAK,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,IAAI,EAAE,WAAW,CAAC,CAAA;aACtD;QACH,CAAC,CAAC,CAAA;QACF,OAAO,KAAK,CAAA;IACd,CAAC;IAED,gIAAgI;IAChI,WAAW,CAAC,KAAK,EAAE,QAAQ;QACzB,MAAM,aAAa,qBAAQ,KAAK,CAAE,CAAA;QAClC,aAAa,CAAC,QAAQ,GAAG,CAAC,QAAQ,CAAC,CAAA;QACnC,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE;YACjC,KAAK,CAAC,QAAQ;iBACX,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;iBACnB,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,aAAa,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAA;SAChD;QACD,MAAM,oBAAoB,qBAAQ,KAAK,CAAE,CAAA;QACzC,OAAO,oBAAoB,CAAC,QAAQ,CAAA;QACpC,OAAO,EAAE,aAAa,EAAE,oBAAoB,EAAE,CAAA;IAChD,CAAC;CACF"}
@@ -0,0 +1,46 @@
1
+ export type IndexMode = 'number' | 'letter' | undefined;
2
+ export interface MultichannelViewOptions {
3
+ boldIndex?: boolean;
4
+ indexSeparator?: string;
5
+ }
6
+ export interface MultichannelContextType extends MultichannelViewOptions {
7
+ currentIndex: number | string;
8
+ /** @see same field at MultichannelProps */
9
+ messageSeparator?: string;
10
+ }
11
+ export interface MultichannelTextProps extends MultichannelViewOptions {
12
+ index?: string;
13
+ indexMode?: IndexMode;
14
+ /** Defaults to no separator between lines*/
15
+ newline?: string;
16
+ buttonsAsText?: boolean;
17
+ buttonsTextSeparator?: string;
18
+ menuButtonTextWhatsappList?: string;
19
+ }
20
+ export interface MultichannelCarouselProps extends MultichannelViewOptions {
21
+ enableURL?: boolean;
22
+ indexMode?: IndexMode;
23
+ showTitle?: boolean;
24
+ showSubtitle?: boolean;
25
+ buttonsAsText?: boolean;
26
+ }
27
+ export interface MultichannelButtonProps {
28
+ newline?: string;
29
+ path?: string;
30
+ payload?: string;
31
+ url?: string;
32
+ webview?: string;
33
+ asText?: boolean;
34
+ }
35
+ export interface MultichannelProps extends MultichannelViewOptions {
36
+ firstIndex?: number | string;
37
+ carousel?: MultichannelCarouselProps;
38
+ text?: MultichannelTextProps;
39
+ /**
40
+ * If undefined, each component will be served in a different botonic message
41
+ * '' will concatenate in the same line
42
+ * '\n' will split in different lines
43
+ * '\n\n' will separate with an empty line
44
+ **/
45
+ messageSeparator?: string;
46
+ }
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=index-types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index-types.js","sourceRoot":"","sources":["../../../../src/components/multichannel/index-types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,11 @@
1
+ import { Multichannel } from './multichannel';
2
+ import { MultichannelButton } from './multichannel-button';
3
+ import { MultichannelCarousel } from './multichannel-carousel';
4
+ import { MultichannelReply } from './multichannel-reply';
5
+ import { MultichannelText } from './multichannel-text';
6
+ export { Multichannel };
7
+ export { MultichannelText };
8
+ export { MultichannelButton };
9
+ export { MultichannelReply };
10
+ export { MultichannelCarousel };
11
+ export * from './index-types';
@@ -0,0 +1,12 @@
1
+ import { Multichannel } from './multichannel';
2
+ import { MultichannelButton } from './multichannel-button';
3
+ import { MultichannelCarousel } from './multichannel-carousel';
4
+ import { MultichannelReply } from './multichannel-reply';
5
+ import { MultichannelText } from './multichannel-text';
6
+ export { Multichannel };
7
+ export { MultichannelText };
8
+ export { MultichannelButton };
9
+ export { MultichannelReply };
10
+ export { MultichannelCarousel };
11
+ export * from './index-types';
12
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/multichannel/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAA;AAC7C,OAAO,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAA;AAC1D,OAAO,EAAE,oBAAoB,EAAE,MAAM,yBAAyB,CAAA;AAC9D,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAA;AACxD,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAA;AAEtD,OAAO,EAAE,YAAY,EAAE,CAAA;AACvB,OAAO,EAAE,gBAAgB,EAAE,CAAA;AAC3B,OAAO,EAAE,kBAAkB,EAAE,CAAA;AAC7B,OAAO,EAAE,iBAAiB,EAAE,CAAA;AAC5B,OAAO,EAAE,oBAAoB,EAAE,CAAA;AAE/B,cAAc,eAAe,CAAA"}
@@ -0,0 +1 @@
1
+ export function MultichannelButton(props: any): string | JSX.Element;
@@ -0,0 +1,67 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { isWhatsapp } from '@botonic/core';
3
+ import React, { useContext } from 'react';
4
+ import { RequestContext } from '../../contexts';
5
+ import { truncateText } from '../../util';
6
+ import { Button } from '../button';
7
+ import { MultichannelContext } from './multichannel-context';
8
+ import { WHATSAPP_MAX_BUTTON_CHARS } from './whatsapp/constants';
9
+ export const MultichannelButton = props => {
10
+ var _a;
11
+ const requestContext = useContext(RequestContext);
12
+ const multichannelContext = useContext(MultichannelContext);
13
+ const hasUrl = () => Boolean(props.url);
14
+ const hasPath = () => Boolean(props.path);
15
+ const hasPayload = () => Boolean(props.payload);
16
+ const hasPostback = () => hasPath() || hasPayload();
17
+ const hasWebview = () => Boolean(props.webview);
18
+ const getUrl = () => props.url;
19
+ const getWebview = () => props.webview;
20
+ const increaseCurrentIndex = () => {
21
+ if (typeof multichannelContext.currentIndex === 'number') {
22
+ multichannelContext.currentIndex += 1;
23
+ }
24
+ else if (typeof multichannelContext.currentIndex === 'string') {
25
+ const lastChar = multichannelContext.currentIndex.charCodeAt(multichannelContext.currentIndex.length - 1);
26
+ multichannelContext.currentIndex = String.fromCharCode(lastChar + 1);
27
+ }
28
+ };
29
+ const formatIndex = index => {
30
+ var _a;
31
+ const boldIndex = (_a = multichannelContext.boldIndex) !== null && _a !== void 0 ? _a : false;
32
+ return boldIndex ? `*${index}*` : index;
33
+ };
34
+ const getText = () => {
35
+ let text = props.children;
36
+ const newline = props.newline || '';
37
+ const separator = multichannelContext.indexSeparator || ' ';
38
+ const index = multichannelContext.currentIndex
39
+ ? `${formatIndex(multichannelContext.currentIndex + separator)} `
40
+ : '';
41
+ if (hasPostback()) {
42
+ text = newline + `${index}${text}`;
43
+ }
44
+ else if (hasUrl()) {
45
+ text = newline + `- ${text}`;
46
+ }
47
+ return text;
48
+ };
49
+ if (isWhatsapp(requestContext.session)) {
50
+ const asText = (_a = props.asText) !== null && _a !== void 0 ? _a : true;
51
+ if (asText) {
52
+ if (hasUrl()) {
53
+ return `${getText()}: ${getUrl()}`;
54
+ }
55
+ else if (hasPath() || hasPayload()) {
56
+ const text = getText();
57
+ increaseCurrentIndex();
58
+ return `${text}`;
59
+ }
60
+ else if (hasWebview())
61
+ return _jsx(Button, Object.assign({}, props, { children: getText() }));
62
+ }
63
+ return (_jsx(Button, Object.assign({}, props, { children: truncateText(props.children, WHATSAPP_MAX_BUTTON_CHARS) })));
64
+ }
65
+ return _jsx(Button, Object.assign({}, props, { children: props.children }));
66
+ };
67
+ //# sourceMappingURL=multichannel-button.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"multichannel-button.js","sourceRoot":"","sources":["../../../../src/components/multichannel/multichannel-button.jsx"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ export function MultichannelCarousel(props: any): any;
@@ -0,0 +1,74 @@
1
+ import { jsxs as _jsxs, jsx as _jsx } from "react/jsx-runtime";
2
+ import { isWhatsapp } from '@botonic/core';
3
+ import React, { useContext } from 'react';
4
+ import { RequestContext } from '../../contexts';
5
+ import { Carousel } from '../carousel';
6
+ import { MultichannelText } from './multichannel-text';
7
+ import { getFilteredElements, isMultichannelButton, isNodePic, isNodeSubtitle, isNodeTitle, } from './multichannel-utils';
8
+ export const MultichannelCarousel = props => {
9
+ const requestContext = useContext(RequestContext);
10
+ const getButtons = node => [].concat(getFilteredElements(node, isMultichannelButton));
11
+ if (isWhatsapp(requestContext.session)) {
12
+ const elements = props.children
13
+ .map(e => e.props.children)
14
+ .map((element, i) => {
15
+ let imageProps = undefined;
16
+ let title = undefined;
17
+ let subtitle = undefined;
18
+ const buttons = [];
19
+ for (const node of element) {
20
+ if (isNodePic(node)) {
21
+ imageProps = node.props;
22
+ }
23
+ if (isNodeTitle(node)) {
24
+ title = node.props.children;
25
+ }
26
+ if (isNodeSubtitle(node)) {
27
+ subtitle = node.props.children;
28
+ }
29
+ if (isMultichannelButton(node)) {
30
+ buttons.push(node);
31
+ }
32
+ //TODO support fragment containing an array
33
+ if (Array.isArray(node)) {
34
+ buttons.push(getButtons(node));
35
+ }
36
+ }
37
+ let header = '';
38
+ if (props.showTitle && title) {
39
+ header += `${title ? `**${title}**` : ''}`;
40
+ if (title && subtitle) {
41
+ header += ' ';
42
+ }
43
+ }
44
+ if (props.showSubtitle && subtitle) {
45
+ header += `_${subtitle}_`;
46
+ }
47
+ return (
48
+ // TODO: newkey only for 1 nested button
49
+ _jsxs(MultichannelText, Object.assign({ newkey: i, indexMode: props.indexMode, buttonsAsText: props.buttonsAsText }, { children: [header || null, buttons] }), i));
50
+ // TODO: in the future, this would be the default mode
51
+ // } else {
52
+ // return (
53
+ // <React.Fragment key={i}>
54
+ // <Image
55
+ // src={imageSrc}
56
+ // caption={carouselToCaption(
57
+ // i + 1,
58
+ // title,
59
+ // subtitle,
60
+ // imageSrc,
61
+ // buttonProps
62
+ // )}
63
+ // ></Image>
64
+ // </React.Fragment>
65
+ // )
66
+ // }
67
+ });
68
+ return elements;
69
+ }
70
+ else {
71
+ return _jsx(Carousel, Object.assign({}, props, { children: props.children }));
72
+ }
73
+ };
74
+ //# sourceMappingURL=multichannel-carousel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"multichannel-carousel.js","sourceRoot":"","sources":["../../../../src/components/multichannel/multichannel-carousel.jsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,11 @@
1
+ export const MultichannelContext: React.Context<{
2
+ boldIndex: boolean;
3
+ carousel: {
4
+ indexMode: undefined;
5
+ };
6
+ text: {
7
+ indexMode: string;
8
+ };
9
+ indexSeparator: string;
10
+ }>;
11
+ import React from "react";
@@ -0,0 +1,12 @@
1
+ import React from 'react';
2
+ export const MultichannelContext = React.createContext({
3
+ boldIndex: true,
4
+ carousel: {
5
+ indexMode: undefined,
6
+ },
7
+ text: {
8
+ indexMode: 'letter',
9
+ },
10
+ indexSeparator: '.',
11
+ });
12
+ //# sourceMappingURL=multichannel-context.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"multichannel-context.js","sourceRoot":"","sources":["../../../../src/components/multichannel/multichannel-context.jsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,MAAM,CAAC,MAAM,mBAAmB,GAAG,KAAK,CAAC,aAAa,CAAC;IACrD,SAAS,EAAE,IAAI;IACf,QAAQ,EAAE;QACR,SAAS,EAAE,SAAS;KACrB;IACD,IAAI,EAAE;QACJ,SAAS,EAAE,QAAQ;KACpB;IACD,cAAc,EAAE,GAAG;CACpB,CAAC,CAAA"}
@@ -0,0 +1 @@
1
+ export function MultichannelReply(props: any): string | JSX.Element | null;
@@ -0,0 +1,20 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { isWhatsapp } from '@botonic/core';
3
+ import React, { useContext } from 'react';
4
+ import { RequestContext } from '../../contexts';
5
+ import { Reply } from '../reply';
6
+ export const MultichannelReply = props => {
7
+ const requestContext = useContext(RequestContext);
8
+ const hasPath = () => Boolean(props.path);
9
+ const hasPayload = () => Boolean(props.payload);
10
+ const getText = () => `${props.children}`;
11
+ if (isWhatsapp(requestContext.session)) {
12
+ if (hasPath() || hasPayload())
13
+ return `${getText()}`;
14
+ return null;
15
+ }
16
+ else {
17
+ return _jsx(Reply, Object.assign({}, props, { children: props.children }));
18
+ }
19
+ };
20
+ //# sourceMappingURL=multichannel-reply.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"multichannel-reply.js","sourceRoot":"","sources":["../../../../src/components/multichannel/multichannel-reply.jsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAC1C,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AAEzC,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAC/C,OAAO,EAAE,KAAK,EAAE,MAAM,UAAU,CAAA;AAEhC,MAAM,CAAC,MAAM,iBAAiB,GAAG,KAAK,CAAC,EAAE;IACvC,MAAM,cAAc,GAAG,UAAU,CAAC,cAAc,CAAC,CAAA;IACjD,MAAM,OAAO,GAAG,GAAG,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;IACzC,MAAM,UAAU,GAAG,GAAG,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;IAC/C,MAAM,OAAO,GAAG,GAAG,EAAE,CAAC,GAAG,KAAK,CAAC,QAAQ,EAAE,CAAA;IAEzC,IAAI,UAAU,CAAC,cAAc,CAAC,OAAO,CAAC,EAAE;QACtC,IAAI,OAAO,EAAE,IAAI,UAAU,EAAE;YAAE,OAAO,GAAG,OAAO,EAAE,EAAE,CAAA;QACpD,OAAO,IAAI,CAAA;KACZ;SAAM;QACL,OAAO,KAAC,KAAK,oBAAK,KAAK,cAAG,KAAK,CAAC,QAAQ,IAAS,CAAA;KAClD;AACH,CAAC,CAAA"}
@@ -0,0 +1 @@
1
+ export function MultichannelText(props: any): never[] | JSX.Element;