@botonic/react 0.21.7-alpha.0 → 0.22.0-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 (440) hide show
  1. package/lib/cjs/app.js.map +1 -1
  2. package/lib/cjs/assets/attachment-icon.svg +7 -0
  3. package/lib/cjs/assets/audio.svg +4 -0
  4. package/lib/cjs/assets/botonic_react_logo100x100.png +0 -0
  5. package/lib/cjs/assets/document.svg +3 -0
  6. package/lib/cjs/assets/emojiButton.svg +6 -0
  7. package/lib/cjs/assets/image.svg +4 -0
  8. package/lib/cjs/assets/leftArrow.svg +3 -0
  9. package/lib/cjs/assets/menuButton.svg +3 -0
  10. package/lib/cjs/assets/rightArrow.svg +3 -0
  11. package/lib/cjs/assets/send-button.svg +1 -0
  12. package/lib/cjs/assets/video.svg +3 -0
  13. package/lib/cjs/botonic-tester.d.ts +3 -3
  14. package/lib/cjs/botonic-tester.js +6 -6
  15. package/lib/cjs/botonic-tester.js.map +1 -1
  16. package/lib/cjs/components/audio.js +2 -2
  17. package/lib/cjs/components/audio.js.map +1 -1
  18. package/lib/cjs/components/button.js +4 -4
  19. package/lib/cjs/components/button.js.map +1 -1
  20. package/lib/cjs/components/buttons-disabler.d.ts +1 -1
  21. package/lib/cjs/components/buttons-disabler.js +4 -4
  22. package/lib/cjs/components/buttons-disabler.js.map +1 -1
  23. package/lib/cjs/components/carousel.d.ts +3 -2
  24. package/lib/cjs/components/carousel.js +8 -8
  25. package/lib/cjs/components/carousel.js.map +1 -1
  26. package/lib/cjs/components/components.d.ts +1 -1
  27. package/lib/cjs/components/components.js.map +1 -1
  28. package/lib/cjs/components/custom-message.d.ts +34 -1
  29. package/lib/cjs/components/custom-message.js +3 -3
  30. package/lib/cjs/components/custom-message.js.map +1 -1
  31. package/lib/cjs/components/document.js +3 -3
  32. package/lib/cjs/components/document.js.map +1 -1
  33. package/lib/cjs/components/element.js +1 -1
  34. package/lib/cjs/components/element.js.map +1 -1
  35. package/lib/cjs/components/handoff.js +2 -2
  36. package/lib/cjs/components/handoff.js.map +1 -1
  37. package/lib/cjs/components/image.js +4 -4
  38. package/lib/cjs/components/image.js.map +1 -1
  39. package/lib/cjs/components/index.d.ts +19 -0
  40. package/lib/cjs/components/index.js.map +1 -1
  41. package/lib/cjs/components/location.js +1 -1
  42. package/lib/cjs/components/location.js.map +1 -1
  43. package/lib/cjs/components/markdown.js +2 -2
  44. package/lib/cjs/components/markdown.js.map +1 -1
  45. package/lib/cjs/components/message-template.js +1 -1
  46. package/lib/cjs/components/message-template.js.map +1 -1
  47. package/lib/cjs/components/message.js +14 -14
  48. package/lib/cjs/components/message.js.map +1 -1
  49. package/lib/cjs/components/multichannel/facebook/facebook.js.map +1 -1
  50. package/lib/cjs/components/multichannel/index.d.ts +5 -0
  51. package/lib/cjs/components/multichannel/index.js.map +1 -1
  52. package/lib/cjs/components/multichannel/multichannel-button.js +3 -3
  53. package/lib/cjs/components/multichannel/multichannel-button.js.map +1 -1
  54. package/lib/cjs/components/multichannel/multichannel-carousel.js +7 -7
  55. package/lib/cjs/components/multichannel/multichannel-carousel.js.map +1 -1
  56. package/lib/cjs/components/multichannel/multichannel-context.js.map +1 -1
  57. package/lib/cjs/components/multichannel/multichannel-reply.js +2 -2
  58. package/lib/cjs/components/multichannel/multichannel-reply.js.map +1 -1
  59. package/lib/cjs/components/multichannel/multichannel-text.js +9 -9
  60. package/lib/cjs/components/multichannel/multichannel-text.js.map +1 -1
  61. package/lib/cjs/components/multichannel/multichannel-utils.js.map +1 -1
  62. package/lib/cjs/components/multichannel/multichannel.js +5 -5
  63. package/lib/cjs/components/multichannel/multichannel.js.map +1 -1
  64. package/lib/cjs/components/pic.js +2 -2
  65. package/lib/cjs/components/pic.js.map +1 -1
  66. package/lib/cjs/components/raw.js +2 -2
  67. package/lib/cjs/components/raw.js.map +1 -1
  68. package/lib/cjs/components/reply.js +2 -2
  69. package/lib/cjs/components/reply.js.map +1 -1
  70. package/lib/cjs/components/share-button.js +1 -1
  71. package/lib/cjs/components/share-button.js.map +1 -1
  72. package/lib/cjs/components/subtitle.js +1 -1
  73. package/lib/cjs/components/subtitle.js.map +1 -1
  74. package/lib/cjs/components/text.d.ts +1 -1
  75. package/lib/cjs/components/text.js +3 -3
  76. package/lib/cjs/components/text.js.map +1 -1
  77. package/lib/cjs/components/timestamps.js.map +1 -1
  78. package/lib/cjs/components/title.js +1 -1
  79. package/lib/cjs/components/title.js.map +1 -1
  80. package/lib/cjs/components/video.js +2 -2
  81. package/lib/cjs/components/video.js.map +1 -1
  82. package/lib/cjs/components/webchat-settings.js +4 -4
  83. package/lib/cjs/components/webchat-settings.js.map +1 -1
  84. package/lib/cjs/components/whatsapp-template.js +1 -1
  85. package/lib/cjs/components/whatsapp-template.js.map +1 -1
  86. package/lib/cjs/constants.js.map +1 -1
  87. package/lib/cjs/contexts.js.map +1 -1
  88. package/lib/cjs/dev-app.d.ts +4 -8
  89. package/lib/cjs/dev-app.js +3 -3
  90. package/lib/cjs/dev-app.js.map +1 -1
  91. package/lib/cjs/index.d.ts +7 -0
  92. package/lib/cjs/index.js +2 -2
  93. package/lib/cjs/index.js.map +1 -1
  94. package/lib/cjs/message-utils.d.ts +2 -1
  95. package/lib/cjs/message-utils.js +12 -12
  96. package/lib/cjs/message-utils.js.map +1 -1
  97. package/lib/cjs/msg-to-botonic.js +10 -10
  98. package/lib/cjs/msg-to-botonic.js.map +1 -1
  99. package/lib/cjs/node-app.d.ts +6 -5
  100. package/lib/cjs/node-app.js +1 -1
  101. package/lib/cjs/node-app.js.map +1 -1
  102. package/lib/cjs/react-bot.js.map +1 -1
  103. package/lib/cjs/util/dom.js +3 -3
  104. package/lib/cjs/util/dom.js.map +1 -1
  105. package/lib/cjs/util/environment.js +3 -3
  106. package/lib/cjs/util/environment.js.map +1 -1
  107. package/lib/cjs/util/error-boundary.d.ts +40 -0
  108. package/lib/cjs/util/error-boundary.js +1 -2
  109. package/lib/cjs/util/error-boundary.js.map +1 -1
  110. package/lib/cjs/util/index.js.map +1 -1
  111. package/lib/cjs/util/logs.d.ts +1 -1
  112. package/lib/cjs/util/logs.js +1 -1
  113. package/lib/cjs/util/logs.js.map +1 -1
  114. package/lib/cjs/util/objects.js.map +1 -1
  115. package/lib/cjs/util/react.js +8 -8
  116. package/lib/cjs/util/react.js.map +1 -1
  117. package/lib/cjs/util/regexs.js.map +1 -1
  118. package/lib/cjs/util/webchat.d.ts +1 -1
  119. package/lib/cjs/util/webchat.js +4 -4
  120. package/lib/cjs/util/webchat.js.map +1 -1
  121. package/lib/cjs/webchat/actions.js.map +1 -1
  122. package/lib/cjs/webchat/components/attachment.js +1 -1
  123. package/lib/cjs/webchat/components/attachment.js.map +1 -1
  124. package/lib/cjs/webchat/components/common.js +1 -1
  125. package/lib/cjs/webchat/components/common.js.map +1 -1
  126. package/lib/cjs/webchat/components/conditional-animation.js +1 -1
  127. package/lib/cjs/webchat/components/conditional-animation.js.map +1 -1
  128. package/lib/cjs/webchat/components/emoji-picker.js +2 -2
  129. package/lib/cjs/webchat/components/emoji-picker.js.map +1 -1
  130. package/lib/cjs/webchat/components/persistent-menu.js +3 -3
  131. package/lib/cjs/webchat/components/persistent-menu.js.map +1 -1
  132. package/lib/cjs/webchat/components/send-button.js +1 -1
  133. package/lib/cjs/webchat/components/send-button.js.map +1 -1
  134. package/lib/cjs/webchat/components/styled-scrollbar.js +2 -2
  135. package/lib/cjs/webchat/components/styled-scrollbar.js.map +1 -1
  136. package/lib/cjs/webchat/components/styled-scrollbar.scss +12 -0
  137. package/lib/cjs/webchat/components/typing-indicator.js.map +1 -1
  138. package/lib/cjs/webchat/components/typing-indicator.scss +38 -0
  139. package/lib/cjs/webchat/devices/device-adapter.js +1 -1
  140. package/lib/cjs/webchat/devices/device-adapter.js.map +1 -1
  141. package/lib/cjs/webchat/devices/index.js +1 -1
  142. package/lib/cjs/webchat/devices/index.js.map +1 -1
  143. package/lib/cjs/webchat/devices/scrollbar-controller.js +5 -5
  144. package/lib/cjs/webchat/devices/scrollbar-controller.js.map +1 -1
  145. package/lib/cjs/webchat/devices/webchat-resizer.js +2 -2
  146. package/lib/cjs/webchat/devices/webchat-resizer.js.map +1 -1
  147. package/lib/cjs/webchat/header.js +3 -3
  148. package/lib/cjs/webchat/header.js.map +1 -1
  149. package/lib/cjs/webchat/hooks.d.ts +1 -1
  150. package/lib/cjs/webchat/hooks.js +9 -9
  151. package/lib/cjs/webchat/hooks.js.map +1 -1
  152. package/lib/cjs/webchat/index.d.ts +3 -1
  153. package/lib/cjs/webchat/index.js.map +1 -1
  154. package/lib/cjs/webchat/message-list.js +2 -2
  155. package/lib/cjs/webchat/message-list.js.map +1 -1
  156. package/lib/cjs/webchat/messages-reducer.js.map +1 -1
  157. package/lib/cjs/webchat/replies.js +1 -1
  158. package/lib/cjs/webchat/replies.js.map +1 -1
  159. package/lib/cjs/webchat/session-view.js +1 -1
  160. package/lib/cjs/webchat/session-view.js.map +1 -1
  161. package/lib/cjs/webchat/use-storage-state-hook.js +3 -3
  162. package/lib/cjs/webchat/use-storage-state-hook.js.map +1 -1
  163. package/lib/cjs/webchat/webchat-dev.js +5 -5
  164. package/lib/cjs/webchat/webchat-dev.js.map +1 -1
  165. package/lib/cjs/webchat/webchat-reducer.js +1 -1
  166. package/lib/cjs/webchat/webchat-reducer.js.map +1 -1
  167. package/lib/cjs/webchat/webchat.js +63 -62
  168. package/lib/cjs/webchat/webchat.js.map +1 -1
  169. package/lib/cjs/webchat/webview.js +5 -5
  170. package/lib/cjs/webchat/webview.js.map +1 -1
  171. package/lib/cjs/webchat-app.js +7 -7
  172. package/lib/cjs/webchat-app.js.map +1 -1
  173. package/lib/cjs/webchat.template.html +37 -0
  174. package/lib/cjs/{webview.d.ts → webview-app.d.ts} +1 -3
  175. package/lib/cjs/{webview.js → webview-app.js} +14 -13
  176. package/lib/cjs/webview-app.js.map +1 -0
  177. package/lib/cjs/webview.template.html +39 -0
  178. package/lib/esm/app.d.ts +2 -0
  179. package/lib/esm/app.js +6 -0
  180. package/lib/esm/app.js.map +1 -0
  181. package/lib/esm/assets/attachment-icon.svg +7 -0
  182. package/lib/esm/assets/audio.svg +4 -0
  183. package/lib/esm/assets/botonic_react_logo100x100.png +0 -0
  184. package/lib/esm/assets/document.svg +3 -0
  185. package/lib/esm/assets/emojiButton.svg +6 -0
  186. package/lib/esm/assets/image.svg +4 -0
  187. package/lib/esm/assets/leftArrow.svg +3 -0
  188. package/lib/esm/assets/menuButton.svg +3 -0
  189. package/lib/esm/assets/rightArrow.svg +3 -0
  190. package/lib/esm/assets/send-button.svg +1 -0
  191. package/lib/esm/assets/video.svg +3 -0
  192. package/lib/esm/botonic-tester.d.ts +18 -0
  193. package/lib/esm/botonic-tester.js +64 -0
  194. package/lib/esm/botonic-tester.js.map +1 -0
  195. package/lib/esm/components/audio.d.ts +8 -0
  196. package/lib/esm/components/audio.js +22 -0
  197. package/lib/esm/components/audio.js.map +1 -0
  198. package/lib/esm/components/button.d.ts +15 -0
  199. package/lib/esm/components/button.js +151 -0
  200. package/lib/esm/components/button.js.map +1 -0
  201. package/lib/esm/components/buttons-disabler.d.ts +24 -0
  202. package/lib/esm/components/buttons-disabler.js +84 -0
  203. package/lib/esm/components/buttons-disabler.js.map +1 -0
  204. package/lib/esm/components/carousel.d.ts +9 -0
  205. package/lib/esm/components/carousel.js +115 -0
  206. package/lib/esm/components/carousel.js.map +1 -0
  207. package/lib/esm/components/components.d.ts +12 -0
  208. package/lib/esm/components/components.js +17 -0
  209. package/lib/esm/components/components.js.map +1 -0
  210. package/lib/esm/components/custom-message.d.ts +43 -0
  211. package/lib/esm/components/custom-message.js +61 -0
  212. package/lib/esm/components/custom-message.js.map +1 -0
  213. package/lib/esm/components/document.d.ts +8 -0
  214. package/lib/esm/components/document.js +45 -0
  215. package/lib/esm/components/document.js.map +1 -0
  216. package/lib/esm/components/element.d.ts +4 -0
  217. package/lib/esm/components/element.js +50 -0
  218. package/lib/esm/components/element.js.map +1 -0
  219. package/lib/esm/components/handoff.d.ts +1 -0
  220. package/lib/esm/components/handoff.js +53 -0
  221. package/lib/esm/components/handoff.js.map +1 -0
  222. package/lib/esm/components/image.d.ts +8 -0
  223. package/lib/esm/components/image.js +37 -0
  224. package/lib/esm/components/image.js.map +1 -0
  225. package/lib/esm/components/index.d.ts +19 -0
  226. package/lib/esm/components/index.js +21 -0
  227. package/lib/esm/components/index.js.map +1 -0
  228. package/lib/esm/components/location.d.ts +11 -0
  229. package/lib/esm/components/location.js +33 -0
  230. package/lib/esm/components/location.js.map +1 -0
  231. package/lib/esm/components/markdown.d.ts +7 -0
  232. package/lib/esm/components/markdown.js +152 -0
  233. package/lib/esm/components/markdown.js.map +1 -0
  234. package/lib/esm/components/message-template.d.ts +1 -0
  235. package/lib/esm/components/message-template.js +10 -0
  236. package/lib/esm/components/message-template.js.map +1 -0
  237. package/lib/esm/components/message.d.ts +1 -0
  238. package/lib/esm/components/message.js +202 -0
  239. package/lib/esm/components/message.js.map +1 -0
  240. package/lib/esm/components/multichannel/facebook/facebook.d.ts +17 -0
  241. package/lib/esm/components/multichannel/facebook/facebook.js +43 -0
  242. package/lib/esm/components/multichannel/facebook/facebook.js.map +1 -0
  243. package/lib/esm/components/multichannel/index.d.ts +6 -0
  244. package/lib/esm/components/multichannel/index.js +11 -0
  245. package/lib/esm/components/multichannel/index.js.map +1 -0
  246. package/lib/esm/components/multichannel/multichannel-button.d.ts +1 -0
  247. package/lib/esm/components/multichannel/multichannel-button.js +72 -0
  248. package/lib/esm/components/multichannel/multichannel-button.js.map +1 -0
  249. package/lib/esm/components/multichannel/multichannel-carousel.d.ts +1 -0
  250. package/lib/esm/components/multichannel/multichannel-carousel.js +90 -0
  251. package/lib/esm/components/multichannel/multichannel-carousel.js.map +1 -0
  252. package/lib/esm/components/multichannel/multichannel-context.d.ts +11 -0
  253. package/lib/esm/components/multichannel/multichannel-context.js +12 -0
  254. package/lib/esm/components/multichannel/multichannel-context.js.map +1 -0
  255. package/lib/esm/components/multichannel/multichannel-reply.d.ts +1 -0
  256. package/lib/esm/components/multichannel/multichannel-reply.js +19 -0
  257. package/lib/esm/components/multichannel/multichannel-reply.js.map +1 -0
  258. package/lib/esm/components/multichannel/multichannel-text.d.ts +1 -0
  259. package/lib/esm/components/multichannel/multichannel-text.js +142 -0
  260. package/lib/esm/components/multichannel/multichannel-text.js.map +1 -0
  261. package/lib/esm/components/multichannel/multichannel-utils.d.ts +24 -0
  262. package/lib/esm/components/multichannel/multichannel-utils.js +67 -0
  263. package/lib/esm/components/multichannel/multichannel-utils.js.map +1 -0
  264. package/lib/esm/components/multichannel/multichannel.d.ts +1 -0
  265. package/lib/esm/components/multichannel/multichannel.js +67 -0
  266. package/lib/esm/components/multichannel/multichannel.js.map +1 -0
  267. package/lib/esm/components/pic.d.ts +6 -0
  268. package/lib/esm/components/pic.js +24 -0
  269. package/lib/esm/components/pic.js.map +1 -0
  270. package/lib/esm/components/raw.d.ts +9 -0
  271. package/lib/esm/components/raw.js +48 -0
  272. package/lib/esm/components/raw.js.map +1 -0
  273. package/lib/esm/components/reply.d.ts +9 -0
  274. package/lib/esm/components/reply.js +52 -0
  275. package/lib/esm/components/reply.js.map +1 -0
  276. package/lib/esm/components/share-button.d.ts +1 -0
  277. package/lib/esm/components/share-button.js +10 -0
  278. package/lib/esm/components/share-button.js.map +1 -0
  279. package/lib/esm/components/subtitle.d.ts +6 -0
  280. package/lib/esm/components/subtitle.js +20 -0
  281. package/lib/esm/components/subtitle.js.map +1 -0
  282. package/lib/esm/components/text.d.ts +8 -0
  283. package/lib/esm/components/text.js +45 -0
  284. package/lib/esm/components/text.js.map +1 -0
  285. package/lib/esm/components/timestamps.d.ts +10 -0
  286. package/lib/esm/components/timestamps.js +48 -0
  287. package/lib/esm/components/timestamps.js.map +1 -0
  288. package/lib/esm/components/title.d.ts +6 -0
  289. package/lib/esm/components/title.js +16 -0
  290. package/lib/esm/components/title.js.map +1 -0
  291. package/lib/esm/components/video.d.ts +8 -0
  292. package/lib/esm/components/video.js +29 -0
  293. package/lib/esm/components/video.js.map +1 -0
  294. package/lib/esm/components/webchat-settings.d.ts +10 -0
  295. package/lib/esm/components/webchat-settings.js +72 -0
  296. package/lib/esm/components/webchat-settings.js.map +1 -0
  297. package/lib/esm/components/whatsapp-template.d.ts +1 -0
  298. package/lib/esm/components/whatsapp-template.js +21 -0
  299. package/lib/esm/components/whatsapp-template.js.map +1 -0
  300. package/lib/esm/constants.d.ts +168 -0
  301. package/lib/esm/constants.js +186 -0
  302. package/lib/esm/constants.js.map +1 -0
  303. package/lib/esm/contexts.d.ts +69 -0
  304. package/lib/esm/contexts.js +34 -0
  305. package/lib/esm/contexts.js.map +1 -0
  306. package/lib/esm/dev-app.d.ts +30 -0
  307. package/lib/esm/dev-app.js +67 -0
  308. package/lib/esm/dev-app.js.map +1 -0
  309. package/lib/esm/index.d.ts +9 -0
  310. package/lib/esm/index.js +11 -0
  311. package/lib/esm/index.js.map +1 -0
  312. package/lib/esm/message-utils.d.ts +18 -0
  313. package/lib/esm/message-utils.js +41 -0
  314. package/lib/esm/message-utils.js.map +1 -0
  315. package/lib/esm/msg-to-botonic.d.ts +18 -0
  316. package/lib/esm/msg-to-botonic.js +154 -0
  317. package/lib/esm/msg-to-botonic.js.map +1 -0
  318. package/lib/esm/node-app.d.ts +12 -0
  319. package/lib/esm/node-app.js +21 -0
  320. package/lib/esm/node-app.js.map +1 -0
  321. package/lib/esm/react-bot.d.ts +7 -0
  322. package/lib/esm/react-bot.js +30 -0
  323. package/lib/esm/react-bot.js.map +1 -0
  324. package/lib/esm/util/dom.d.ts +13 -0
  325. package/lib/esm/util/dom.js +46 -0
  326. package/lib/esm/util/dom.js.map +1 -0
  327. package/lib/esm/util/environment.d.ts +6 -0
  328. package/lib/esm/util/environment.js +61 -0
  329. package/lib/esm/util/environment.js.map +1 -0
  330. package/lib/esm/util/error-boundary.d.ts +40 -0
  331. package/lib/esm/util/error-boundary.js +41 -0
  332. package/lib/esm/util/error-boundary.js.map +1 -0
  333. package/lib/esm/util/index.d.ts +0 -0
  334. package/lib/esm/util/index.js +2 -0
  335. package/lib/esm/util/index.js.map +1 -0
  336. package/lib/esm/util/logs.d.ts +2 -0
  337. package/lib/esm/util/logs.js +15 -0
  338. package/lib/esm/util/logs.js.map +1 -0
  339. package/lib/esm/util/objects.d.ts +3 -0
  340. package/lib/esm/util/objects.js +38 -0
  341. package/lib/esm/util/objects.js.map +1 -0
  342. package/lib/esm/util/react.d.ts +12 -0
  343. package/lib/esm/util/react.js +34 -0
  344. package/lib/esm/util/react.js.map +1 -0
  345. package/lib/esm/util/regexs.d.ts +2 -0
  346. package/lib/esm/util/regexs.js +18 -0
  347. package/lib/esm/util/regexs.js.map +1 -0
  348. package/lib/esm/util/webchat.d.ts +11 -0
  349. package/lib/esm/util/webchat.js +53 -0
  350. package/lib/esm/util/webchat.js.map +1 -0
  351. package/lib/esm/webchat/actions.d.ts +23 -0
  352. package/lib/esm/webchat/actions.js +24 -0
  353. package/lib/esm/webchat/actions.js.map +1 -0
  354. package/lib/esm/webchat/components/attachment.d.ts +5 -0
  355. package/lib/esm/webchat/components/attachment.js +27 -0
  356. package/lib/esm/webchat/components/attachment.js.map +1 -0
  357. package/lib/esm/webchat/components/common.d.ts +1 -0
  358. package/lib/esm/webchat/components/common.js +8 -0
  359. package/lib/esm/webchat/components/common.js.map +1 -0
  360. package/lib/esm/webchat/components/conditional-animation.d.ts +1 -0
  361. package/lib/esm/webchat/components/conditional-animation.js +13 -0
  362. package/lib/esm/webchat/components/conditional-animation.js.map +1 -0
  363. package/lib/esm/webchat/components/emoji-picker.d.ts +5 -0
  364. package/lib/esm/webchat/components/emoji-picker.js +46 -0
  365. package/lib/esm/webchat/components/emoji-picker.js.map +1 -0
  366. package/lib/esm/webchat/components/persistent-menu.d.ts +10 -0
  367. package/lib/esm/webchat/components/persistent-menu.js +53 -0
  368. package/lib/esm/webchat/components/persistent-menu.js.map +1 -0
  369. package/lib/esm/webchat/components/send-button.d.ts +3 -0
  370. package/lib/esm/webchat/components/send-button.js +19 -0
  371. package/lib/esm/webchat/components/send-button.js.map +1 -0
  372. package/lib/esm/webchat/components/styled-scrollbar.d.ts +1 -0
  373. package/lib/esm/webchat/components/styled-scrollbar.js +50 -0
  374. package/lib/esm/webchat/components/styled-scrollbar.js.map +1 -0
  375. package/lib/esm/webchat/components/styled-scrollbar.scss +12 -0
  376. package/lib/esm/webchat/components/typing-indicator.d.ts +1 -0
  377. package/lib/esm/webchat/components/typing-indicator.js +9 -0
  378. package/lib/esm/webchat/components/typing-indicator.js.map +1 -0
  379. package/lib/esm/webchat/components/typing-indicator.scss +38 -0
  380. package/lib/esm/webchat/devices/device-adapter.d.ts +12 -0
  381. package/lib/esm/webchat/devices/device-adapter.js +43 -0
  382. package/lib/esm/webchat/devices/device-adapter.js.map +1 -0
  383. package/lib/esm/webchat/devices/index.d.ts +11 -0
  384. package/lib/esm/webchat/devices/index.js +18 -0
  385. package/lib/esm/webchat/devices/index.js.map +1 -0
  386. package/lib/esm/webchat/devices/scrollbar-controller.d.ts +12 -0
  387. package/lib/esm/webchat/devices/scrollbar-controller.js +99 -0
  388. package/lib/esm/webchat/devices/scrollbar-controller.js.map +1 -0
  389. package/lib/esm/webchat/devices/webchat-resizer.d.ts +9 -0
  390. package/lib/esm/webchat/devices/webchat-resizer.js +43 -0
  391. package/lib/esm/webchat/devices/webchat-resizer.js.map +1 -0
  392. package/lib/esm/webchat/header.d.ts +3 -0
  393. package/lib/esm/webchat/header.js +89 -0
  394. package/lib/esm/webchat/header.js.map +1 -0
  395. package/lib/esm/webchat/hooks.d.ts +80 -0
  396. package/lib/esm/webchat/hooks.js +210 -0
  397. package/lib/esm/webchat/hooks.js.map +1 -0
  398. package/lib/esm/webchat/index.d.ts +6 -0
  399. package/lib/esm/webchat/index.js +11 -0
  400. package/lib/esm/webchat/index.js.map +1 -0
  401. package/lib/esm/webchat/message-list.d.ts +1 -0
  402. package/lib/esm/webchat/message-list.js +41 -0
  403. package/lib/esm/webchat/message-list.js.map +1 -0
  404. package/lib/esm/webchat/messages-reducer.d.ts +1 -0
  405. package/lib/esm/webchat/messages-reducer.js +54 -0
  406. package/lib/esm/webchat/messages-reducer.js.map +1 -0
  407. package/lib/esm/webchat/replies.d.ts +1 -0
  408. package/lib/esm/webchat/replies.js +41 -0
  409. package/lib/esm/webchat/replies.js.map +1 -0
  410. package/lib/esm/webchat/session-view.d.ts +1 -0
  411. package/lib/esm/webchat/session-view.js +119 -0
  412. package/lib/esm/webchat/session-view.js.map +1 -0
  413. package/lib/esm/webchat/use-storage-state-hook.d.ts +1 -0
  414. package/lib/esm/webchat/use-storage-state-hook.js +28 -0
  415. package/lib/esm/webchat/use-storage-state-hook.js.map +1 -0
  416. package/lib/esm/webchat/webchat-dev.d.ts +7 -0
  417. package/lib/esm/webchat/webchat-dev.js +60 -0
  418. package/lib/esm/webchat/webchat-dev.js.map +1 -0
  419. package/lib/esm/webchat/webchat-reducer.d.ts +1 -0
  420. package/lib/esm/webchat/webchat-reducer.js +44 -0
  421. package/lib/esm/webchat/webchat-reducer.js.map +1 -0
  422. package/lib/esm/webchat/webchat.d.ts +3 -0
  423. package/lib/esm/webchat/webchat.js +699 -0
  424. package/lib/esm/webchat/webchat.js.map +1 -0
  425. package/lib/esm/webchat/webview.d.ts +2 -0
  426. package/lib/esm/webchat/webview.js +86 -0
  427. package/lib/esm/webchat/webview.js.map +1 -0
  428. package/lib/esm/webchat-app.d.ts +98 -0
  429. package/lib/esm/webchat-app.js +265 -0
  430. package/lib/esm/webchat-app.js.map +1 -0
  431. package/lib/esm/webchat.template.html +37 -0
  432. package/lib/esm/webview-app.d.ts +7 -0
  433. package/lib/esm/webview-app.js +98 -0
  434. package/lib/esm/webview-app.js.map +1 -0
  435. package/lib/esm/webview.template.html +39 -0
  436. package/package.json +16 -9
  437. package/src/index.js +1 -1
  438. package/src/msg-to-botonic.jsx +1 -1
  439. package/src/{webview.jsx → webview-app.tsx} +4 -1
  440. package/lib/cjs/webview.js.map +0 -1
@@ -0,0 +1,48 @@
1
+ import { INPUT, isBrowser } from '@botonic/core';
2
+ import React, { useState } from 'react';
3
+ import styled from 'styled-components';
4
+ import { COLORS, ROLES } from '../constants';
5
+ import { Message } from './message';
6
+ const RawDataButton = styled.div `
7
+ align-self: flex-start;
8
+ background-color: ${COLORS.CURIOUS_BLUE};
9
+ padding: 4px;
10
+ margin: 4px 0px;
11
+ cursor: pointer;
12
+ color: ${COLORS.SOLID_WHITE_ALPHA_0_8};
13
+ font-size: 10px;
14
+ border-radius: 2px;
15
+ `;
16
+ const Popover = styled.div `
17
+ max-width: 100%;
18
+ max-height: 500px;
19
+ overflow: auto;
20
+ background-color: ${COLORS.LIGHT_GRAY};
21
+ padding: 10px;
22
+ pre {
23
+ margin: 0px;
24
+ }
25
+ `;
26
+ const serialize = rawProps => {
27
+ return { data: rawProps.data, alt: rawProps.alt };
28
+ };
29
+ export const Raw = props => {
30
+ let content = props.children;
31
+ const data = JSON.stringify(props.data, null, ' ');
32
+ const [isOpen, setIsOpen] = useState(false);
33
+ if (isBrowser())
34
+ content = (<>
35
+ <div>{props.alt}</div>
36
+ <RawDataButton onClick={() => setIsOpen(!isOpen)}>
37
+ RAW DATA <small>{isOpen ? '▲' : '▼'}</small>
38
+ </RawDataButton>
39
+ {isOpen && (<Popover>
40
+ <pre>{data}</pre>
41
+ </Popover>)}
42
+ </>);
43
+ return (<Message role={ROLES.RAW_MESSAGE} json={serialize(props)} {...props} data={data} type={INPUT.RAW}>
44
+ {content}
45
+ </Message>);
46
+ };
47
+ Raw.serialize = serialize;
48
+ //# sourceMappingURL=raw.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"raw.js","sourceRoot":"src/","sources":["components/raw.jsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,eAAe,CAAA;AAChD,OAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AACvC,OAAO,MAAM,MAAM,mBAAmB,CAAA;AAEtC,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,cAAc,CAAA;AAC5C,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AAEnC,MAAM,aAAa,GAAG,MAAM,CAAC,GAAG,CAAA;;sBAEV,MAAM,CAAC,YAAY;;;;WAI9B,MAAM,CAAC,qBAAqB;;;CAGtC,CAAA;AAED,MAAM,OAAO,GAAG,MAAM,CAAC,GAAG,CAAA;;;;sBAIJ,MAAM,CAAC,UAAU;;;;;CAKtC,CAAA;AAED,MAAM,SAAS,GAAG,QAAQ,CAAC,EAAE;IAC3B,OAAO,EAAE,IAAI,EAAE,QAAQ,CAAC,IAAI,EAAE,GAAG,EAAE,QAAQ,CAAC,GAAG,EAAE,CAAA;AACnD,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,GAAG,GAAG,KAAK,CAAC,EAAE;IACzB,IAAI,OAAO,GAAG,KAAK,CAAC,QAAQ,CAAA;IAC5B,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,EAAE,IAAI,EAAE,GAAG,CAAC,CAAA;IAClD,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;IAC3C,IAAI,SAAS,EAAE;QACb,OAAO,GAAG,CACR,EACE;QAAA,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,GAAG,CACrB;QAAA,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,CAAC,CAC/C;mBAAS,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,KAAK,CAC7C;QAAA,EAAE,aAAa,CACf;QAAA,CAAC,MAAM,IAAI,CACT,CAAC,OAAO,CACN;YAAA,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,GAAG,CAClB;UAAA,EAAE,OAAO,CAAC,CACX,CACH;MAAA,GAAG,CACJ,CAAA;IACH,OAAO,CACL,CAAC,OAAO,CACN,IAAI,CAAC,CAAC,KAAK,CAAC,WAAW,CAAC,CACxB,IAAI,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CACvB,IAAI,KAAK,CAAC,CACV,IAAI,CAAC,CAAC,IAAI,CAAC,CACX,IAAI,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAEhB;MAAA,CAAC,OAAO,CACV;IAAA,EAAE,OAAO,CAAC,CACX,CAAA;AACH,CAAC,CAAA;AAED,GAAG,CAAC,SAAS,GAAG,SAAS,CAAA"}
@@ -0,0 +1,9 @@
1
+ export function Reply(props: any): any;
2
+ export namespace Reply {
3
+ function serialize(replyProps: any): {
4
+ reply: {
5
+ title: any;
6
+ payload: any;
7
+ };
8
+ };
9
+ }
@@ -0,0 +1,52 @@
1
+ import React, { useContext } from 'react';
2
+ import styled from 'styled-components';
3
+ import { COLORS, WEBCHAT } from '../constants';
4
+ import { WebchatContext } from '../contexts';
5
+ import { renderComponent } from '../util/react';
6
+ const StyledButton = styled.button `
7
+ width: 100%;
8
+ padding: 4px 8px;
9
+ font-family: inherit;
10
+ border-radius: 8px;
11
+ cursor: pointer;
12
+ outline: 0;
13
+ `;
14
+ export const Reply = props => {
15
+ const { sendText, getThemeProperty } = useContext(WebchatContext);
16
+ const handleClick = event => {
17
+ event.preventDefault();
18
+ if (props.children) {
19
+ let payload = props.payload;
20
+ if (props.path)
21
+ payload = `__PATH_PAYLOAD__${props.path}`;
22
+ sendText(props.children, payload);
23
+ }
24
+ };
25
+ const renderBrowser = () => {
26
+ const replyStyle = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.replyStyle);
27
+ const CustomReply = getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.customReply);
28
+ if (CustomReply) {
29
+ return (<div onClick={e => handleClick(e)}>
30
+ <CustomReply>{props.children}</CustomReply>
31
+ </div>);
32
+ }
33
+ return (<StyledButton style={Object.assign({ border: `1px solid ${getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.brandColor, COLORS.BOTONIC_BLUE)}`, color: getThemeProperty(WEBCHAT.CUSTOM_PROPERTIES.brandColor, COLORS.BOTONIC_BLUE) }, replyStyle)} onClick={e => handleClick(e)}>
34
+ {props.children}
35
+ </StyledButton>);
36
+ };
37
+ const renderNode = () => {
38
+ if (props.path) {
39
+ const payload = `__PATH_PAYLOAD__${props.path}`;
40
+ return <reply payload={payload}>{props.children}</reply>;
41
+ }
42
+ return <reply payload={props.payload}>{props.children}</reply>;
43
+ };
44
+ return renderComponent({ renderBrowser, renderNode });
45
+ };
46
+ Reply.serialize = replyProps => {
47
+ let payload = replyProps.payload;
48
+ if (replyProps.path)
49
+ payload = `__PATH_PAYLOAD__${replyProps.path}`;
50
+ return { reply: { title: replyProps.children, payload } };
51
+ };
52
+ //# sourceMappingURL=reply.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"reply.js","sourceRoot":"src/","sources":["components/reply.jsx"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ export function ShareButton(props: any): any;
@@ -0,0 +1,10 @@
1
+ import React from 'react';
2
+ import { renderComponent } from '../util/react';
3
+ export const ShareButton = props => {
4
+ const renderBrowser = () => null;
5
+ const renderNode = () => (<button type='element_share'>
6
+ <pre dangerouslySetInnerHTML={{ __html: JSON.stringify(props.payload) }}/>
7
+ </button>);
8
+ return renderComponent({ renderBrowser, renderNode });
9
+ };
10
+ //# sourceMappingURL=share-button.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"share-button.js","sourceRoot":"src/","sources":["components/share-button.jsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAA;AAE/C,MAAM,CAAC,MAAM,WAAW,GAAG,KAAK,CAAC,EAAE;IACjC,MAAM,aAAa,GAAG,GAAG,EAAE,CAAC,IAAI,CAAA;IAChC,MAAM,UAAU,GAAG,GAAG,EAAE,CAAC,CACvB,CAAC,MAAM,CAAC,IAAI,CAAC,eAAe,CAC1B;MAAA,CAAC,GAAG,CACF,uBAAuB,CAAC,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC,EAEvE;IAAA,EAAE,MAAM,CAAC,CACV,CAAA;IAED,OAAO,eAAe,CAAC,EAAE,aAAa,EAAE,UAAU,EAAE,CAAC,CAAA;AACvD,CAAC,CAAA"}
@@ -0,0 +1,6 @@
1
+ export function Subtitle(props: any): any;
2
+ export namespace Subtitle {
3
+ function serialize(subtitleProps: any): {
4
+ subtitle: any;
5
+ };
6
+ }
@@ -0,0 +1,20 @@
1
+ import React from 'react';
2
+ import styled from 'styled-components';
3
+ import { COLORS } from '../constants';
4
+ import { renderComponent } from '../util/react';
5
+ const SubtitleContainer = styled.div `
6
+ font-size: 12px;
7
+ padding: 0px 15px 10px 15px;
8
+ color: ${COLORS.MID_GRAY};
9
+ `;
10
+ export const Subtitle = props => {
11
+ const renderBrowser = () => (<SubtitleContainer style={Object.assign({}, props.style)}>
12
+ {props.children}
13
+ </SubtitleContainer>);
14
+ const renderNode = () => <desc>{props.children}</desc>;
15
+ return renderComponent({ renderBrowser, renderNode });
16
+ };
17
+ Subtitle.serialize = subtitleProps => {
18
+ return { subtitle: subtitleProps.children };
19
+ };
20
+ //# sourceMappingURL=subtitle.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"subtitle.js","sourceRoot":"src/","sources":["components/subtitle.jsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,MAAM,MAAM,mBAAmB,CAAA;AAEtC,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAA;AACrC,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAA;AAE/C,MAAM,iBAAiB,GAAG,MAAM,CAAC,GAAG,CAAA;;;WAGzB,MAAM,CAAC,QAAQ;CACzB,CAAA;AACD,MAAM,CAAC,MAAM,QAAQ,GAAG,KAAK,CAAC,EAAE;IAC9B,MAAM,aAAa,GAAG,GAAG,EAAE,CAAC,CAC1B,CAAC,iBAAiB,CAChB,KAAK,CAAC,mBACD,KAAK,CAAC,KAAK,EACd,CAEF;MAAA,CAAC,KAAK,CAAC,QAAQ,CACjB;IAAA,EAAE,iBAAiB,CAAC,CACrB,CAAA;IACD,MAAM,UAAU,GAAG,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,IAAI,CAAC,CAAA;IAEtD,OAAO,eAAe,CAAC,EAAE,aAAa,EAAE,UAAU,EAAE,CAAC,CAAA;AACvD,CAAC,CAAA;AAED,QAAQ,CAAC,SAAS,GAAG,aAAa,CAAC,EAAE;IACnC,OAAO,EAAE,QAAQ,EAAE,aAAa,CAAC,QAAQ,EAAE,CAAA;AAC7C,CAAC,CAAA"}
@@ -0,0 +1,8 @@
1
+ export function Text(props: TextProps): JSX.Element;
2
+ export namespace Text {
3
+ export { serialize };
4
+ }
5
+ declare function serialize(textProps: any): {
6
+ text: any;
7
+ };
8
+ export {};
@@ -0,0 +1,45 @@
1
+ import { INPUT } from '@botonic/core';
2
+ import React, { Children } from 'react';
3
+ import { mapObjectNonBooleanValues } from '../util/react';
4
+ import { serializeMarkdown, toMarkdownChildren } from './markdown';
5
+ import { Message } from './message';
6
+ const serializeText = children => {
7
+ children = Array.isArray(children) ? children : [children];
8
+ const text = children
9
+ .filter(e => !e.type)
10
+ .map(e => {
11
+ if (Array.isArray(e))
12
+ return serializeText(e);
13
+ else
14
+ return String(e);
15
+ })
16
+ .join('');
17
+ return text;
18
+ };
19
+ const serialize = textProps => {
20
+ if (!textProps.markdown)
21
+ return {
22
+ text: serializeText(textProps.children),
23
+ };
24
+ return { text: serializeMarkdown(textProps.children) };
25
+ };
26
+ /**
27
+ *
28
+ * @param {TextProps} props
29
+ * @returns {JSX.Element}
30
+ */
31
+ export const Text = props => {
32
+ const defaultTextProps = {
33
+ markdown: props.markdown === undefined ? true : props.markdown,
34
+ };
35
+ const textProps = mapObjectNonBooleanValues(Object.assign(Object.assign(Object.assign({}, props), defaultTextProps), { children: Children.toArray(props.children) }));
36
+ if (!textProps.markdown)
37
+ return (<Message json={serialize(textProps)} {...textProps} type={INPUT.TEXT}>
38
+ {textProps.children}
39
+ </Message>);
40
+ return (<Message json={serialize(textProps)} {...textProps} type={INPUT.TEXT}>
41
+ {toMarkdownChildren(textProps.children)}
42
+ </Message>);
43
+ };
44
+ Text.serialize = serialize;
45
+ //# sourceMappingURL=text.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"text.js","sourceRoot":"src/","sources":["components/text.jsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AACrC,OAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAEvC,OAAO,EAAE,yBAAyB,EAAE,MAAM,eAAe,CAAA;AACzD,OAAO,EAAE,iBAAiB,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAA;AAClE,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AAEnC,MAAM,aAAa,GAAG,QAAQ,CAAC,EAAE;IAC/B,QAAQ,GAAG,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAA;IAC1D,MAAM,IAAI,GAAG,QAAQ;SAClB,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;SACpB,GAAG,CAAC,CAAC,CAAC,EAAE;QACP,IAAI,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC;YAAE,OAAO,aAAa,CAAC,CAAC,CAAC,CAAA;;YACxC,OAAO,MAAM,CAAC,CAAC,CAAC,CAAA;IACvB,CAAC,CAAC;SACD,IAAI,CAAC,EAAE,CAAC,CAAA;IACX,OAAO,IAAI,CAAA;AACb,CAAC,CAAA;AAED,MAAM,SAAS,GAAG,SAAS,CAAC,EAAE;IAC5B,IAAI,CAAC,SAAS,CAAC,QAAQ;QACrB,OAAO;YACL,IAAI,EAAE,aAAa,CAAC,SAAS,CAAC,QAAQ,CAAC;SACxC,CAAA;IACH,OAAO,EAAE,IAAI,EAAE,iBAAiB,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE,CAAA;AACxD,CAAC,CAAA;AAED;;;;GAIG;AACH,MAAM,CAAC,MAAM,IAAI,GAAG,KAAK,CAAC,EAAE;IAC1B,MAAM,gBAAgB,GAAG;QACvB,QAAQ,EAAE,KAAK,CAAC,QAAQ,KAAK,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,QAAQ;KAC/D,CAAA;IACD,MAAM,SAAS,GAAG,yBAAyB,+CACtC,KAAK,GACL,gBAAgB,GAChB,EAAE,QAAQ,EAAE,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,EACjD,CAAA;IACF,IAAI,CAAC,SAAS,CAAC,QAAQ;QACrB,OAAO,CACL,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,SAAS,CAAC,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CACnE;QAAA,CAAC,SAAS,CAAC,QAAQ,CACrB;MAAA,EAAE,OAAO,CAAC,CACX,CAAA;IACH,OAAO,CACL,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,SAAS,CAAC,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CACnE;MAAA,CAAC,kBAAkB,CAAC,SAAS,CAAC,QAAQ,CAAC,CACzC;IAAA,EAAE,OAAO,CAAC,CACX,CAAA;AACH,CAAC,CAAA;AAED,IAAI,CAAC,SAAS,GAAG,SAAS,CAAA"}
@@ -0,0 +1,10 @@
1
+ export function resolveMessageTimestamps(getThemeFn: any, messageTimestampEnabled: any): {
2
+ timestampsEnabled: boolean;
3
+ getFormattedTimestamp: any;
4
+ timestampStyle: any;
5
+ };
6
+ export function MessageTimestamp({ timestamp, style, isfromuser }: {
7
+ timestamp: any;
8
+ style: any;
9
+ isfromuser: any;
10
+ }): JSX.Element;
@@ -0,0 +1,48 @@
1
+ import React from 'react';
2
+ import styled from 'styled-components';
3
+ import { COLORS } from '../constants';
4
+ export const resolveMessageTimestamps = (getThemeFn, messageTimestampEnabled) => {
5
+ const timestampsFormat = getThemeFn('message.timestamps.format');
6
+ const timestampStyle = getThemeFn('message.timestamps.style');
7
+ const timestampsEnabled = Boolean(messageTimestampEnabled !== undefined
8
+ ? messageTimestampEnabled
9
+ : getThemeFn('message.timestamps.enable', Boolean(timestampStyle) || Boolean(timestampsFormat) || false));
10
+ const defaultTimestampFormat = {
11
+ month: 'short',
12
+ day: 'numeric',
13
+ hour: 'numeric',
14
+ minute: 'numeric',
15
+ second: 'numeric',
16
+ };
17
+ const getFormattedTimestamp = (timestampsFormat && timestampsFormat()) ||
18
+ new Date().toLocaleString(undefined, defaultTimestampFormat);
19
+ return {
20
+ timestampsEnabled,
21
+ getFormattedTimestamp,
22
+ timestampStyle,
23
+ };
24
+ };
25
+ const TimestampContainer = styled.div `
26
+ display: flex;
27
+ position: relative;
28
+ align-items: flex-start;
29
+ `;
30
+ const TimestampText = styled.div `
31
+ @import url('https://fonts.googleapis.com/css?family=Lato');
32
+ font-family: Lato;
33
+ font-size: 10px;
34
+ color: ${COLORS.SOLID_BLACK};
35
+ width: 100%;
36
+ text-align: ${props => (props.isfromuser ? 'right' : 'left')};
37
+ padding: ${props => (props.isfromuser ? '0px 15px' : '0px 50px')};
38
+ margin-bottom: 5px;
39
+ `;
40
+ export const MessageTimestamp = ({ timestamp, style, isfromuser }) => {
41
+ const classSufix = isfromuser ? 'user' : 'bot';
42
+ return (<TimestampContainer className={`botonic-timestamp-${classSufix}`}>
43
+ <TimestampText isfromuser={isfromuser} style={Object.assign({}, style)}>
44
+ {timestamp}
45
+ </TimestampText>
46
+ </TimestampContainer>);
47
+ };
48
+ //# sourceMappingURL=timestamps.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"timestamps.js","sourceRoot":"src/","sources":["components/timestamps.jsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,MAAM,MAAM,mBAAmB,CAAA;AAEtC,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAA;AAErC,MAAM,CAAC,MAAM,wBAAwB,GAAG,CACtC,UAAU,EACV,uBAAuB,EACvB,EAAE;IACF,MAAM,gBAAgB,GAAG,UAAU,CAAC,2BAA2B,CAAC,CAAA;IAChE,MAAM,cAAc,GAAG,UAAU,CAAC,0BAA0B,CAAC,CAAA;IAC7D,MAAM,iBAAiB,GAAG,OAAO,CAC/B,uBAAuB,KAAK,SAAS;QACnC,CAAC,CAAC,uBAAuB;QACzB,CAAC,CAAC,UAAU,CACR,2BAA2B,EAC3B,OAAO,CAAC,cAAc,CAAC,IAAI,OAAO,CAAC,gBAAgB,CAAC,IAAI,KAAK,CAC9D,CACN,CAAA;IACD,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;IACD,MAAM,qBAAqB,GACzB,CAAC,gBAAgB,IAAI,gBAAgB,EAAE,CAAC;QACxC,IAAI,IAAI,EAAE,CAAC,cAAc,CAAC,SAAS,EAAE,sBAAsB,CAAC,CAAA;IAC9D,OAAO;QACL,iBAAiB;QACjB,qBAAqB;QACrB,cAAc;KACf,CAAA;AACH,CAAC,CAAA;AAED,MAAM,kBAAkB,GAAG,MAAM,CAAC,GAAG,CAAA;;;;CAIpC,CAAA;AAED,MAAM,aAAa,GAAG,MAAM,CAAC,GAAG,CAAA;;;;WAIrB,MAAM,CAAC,WAAW;;gBAEb,KAAK,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC;aACjD,KAAK,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC;;CAEjE,CAAA;AAED,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,UAAU,EAAE,EAAE,EAAE;IACnE,MAAM,UAAU,GAAG,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAA;IAC9C,OAAO,CACL,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC,qBAAqB,UAAU,EAAE,CAAC,CAC/D;MAAA,CAAC,aAAa,CACZ,UAAU,CAAC,CAAC,UAAU,CAAC,CACvB,KAAK,CAAC,mBACD,KAAK,EACR,CAEF;QAAA,CAAC,SAAS,CACZ;MAAA,EAAE,aAAa,CACjB;IAAA,EAAE,kBAAkB,CAAC,CACtB,CAAA;AACH,CAAC,CAAA"}
@@ -0,0 +1,6 @@
1
+ export function Title(props: any): any;
2
+ export namespace Title {
3
+ function serialize(titleProps: any): {
4
+ title: any;
5
+ };
6
+ }
@@ -0,0 +1,16 @@
1
+ import React from 'react';
2
+ import styled from 'styled-components';
3
+ import { renderComponent } from '../util/react';
4
+ const TitleContainer = styled.div `
5
+ font-size: 14px;
6
+ padding: 10px 15px;
7
+ `;
8
+ export const Title = props => {
9
+ const renderBrowser = () => (<TitleContainer style={Object.assign({}, props.style)}>{props.children}</TitleContainer>);
10
+ const renderNode = () => <title>{props.children}</title>;
11
+ return renderComponent({ renderBrowser, renderNode });
12
+ };
13
+ Title.serialize = titleProps => {
14
+ return { title: titleProps.children };
15
+ };
16
+ //# sourceMappingURL=title.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"title.js","sourceRoot":"src/","sources":["components/title.jsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,MAAM,MAAM,mBAAmB,CAAA;AAEtC,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAA;AAE/C,MAAM,cAAc,GAAG,MAAM,CAAC,GAAG,CAAA;;;CAGhC,CAAA;AAED,MAAM,CAAC,MAAM,KAAK,GAAG,KAAK,CAAC,EAAE;IAC3B,MAAM,aAAa,GAAG,GAAG,EAAE,CAAC,CAC1B,CAAC,cAAc,CAAC,KAAK,CAAC,mBAAM,KAAK,CAAC,KAAK,EAAG,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,cAAc,CAAC,CAC7E,CAAA;IACD,MAAM,UAAU,GAAG,GAAG,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,KAAK,CAAC,CAAA;IAExD,OAAO,eAAe,CAAC,EAAE,aAAa,EAAE,UAAU,EAAE,CAAC,CAAA;AACvD,CAAC,CAAA;AAED,KAAK,CAAC,SAAS,GAAG,UAAU,CAAC,EAAE;IAC7B,OAAO,EAAE,KAAK,EAAE,UAAU,CAAC,QAAQ,EAAE,CAAA;AACvC,CAAC,CAAA"}
@@ -0,0 +1,8 @@
1
+ export function Video(props: any): JSX.Element;
2
+ export namespace Video {
3
+ export { serialize };
4
+ }
5
+ declare function serialize(videoProps: any): {
6
+ video: any;
7
+ };
8
+ export {};
@@ -0,0 +1,29 @@
1
+ import { INPUT, isBrowser } from '@botonic/core';
2
+ import React from 'react';
3
+ import styled from 'styled-components';
4
+ import { COLORS, ROLES } from '../constants';
5
+ import { staticAsset } from '../util/environment';
6
+ import { Message } from './message';
7
+ const StyledVideo = styled.video `
8
+ background-color: ${COLORS.SOLID_BLACK_ALPHA_0_5};
9
+ border-radius: 8px;
10
+ max-height: 180px;
11
+ max-width: 300px;
12
+ margin: 10px;
13
+ `;
14
+ const serialize = videoProps => {
15
+ return { video: videoProps.src };
16
+ };
17
+ export const Video = props => {
18
+ props = Object.assign(Object.assign({}, props), { src: staticAsset(props.src) });
19
+ let content = props.children;
20
+ if (isBrowser())
21
+ content = (<StyledVideo controls>
22
+ <source src={props.src}/>
23
+ </StyledVideo>);
24
+ return (<Message role={ROLES.VIDEO_MESSAGE} json={serialize(props)} {...props} type={INPUT.VIDEO}>
25
+ {content}
26
+ </Message>);
27
+ };
28
+ Video.serialize = serialize;
29
+ //# sourceMappingURL=video.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"video.js","sourceRoot":"src/","sources":["components/video.jsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,eAAe,CAAA;AAChD,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,MAAM,MAAM,mBAAmB,CAAA;AAEtC,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,cAAc,CAAA;AAC5C,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAA;AACjD,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AAEnC,MAAM,WAAW,GAAG,MAAM,CAAC,KAAK,CAAA;sBACV,MAAM,CAAC,qBAAqB;;;;;CAKjD,CAAA;AAED,MAAM,SAAS,GAAG,UAAU,CAAC,EAAE;IAC7B,OAAO,EAAE,KAAK,EAAE,UAAU,CAAC,GAAG,EAAE,CAAA;AAClC,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,KAAK,GAAG,KAAK,CAAC,EAAE;IAC3B,KAAK,mCAAQ,KAAK,KAAE,GAAG,EAAE,WAAW,CAAC,KAAK,CAAC,GAAG,CAAC,GAAE,CAAA;IACjD,IAAI,OAAO,GAAG,KAAK,CAAC,QAAQ,CAAA;IAC5B,IAAI,SAAS,EAAE;QACb,OAAO,GAAG,CACR,CAAC,WAAW,CAAC,QAAQ,CACnB;QAAA,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,EACzB;MAAA,EAAE,WAAW,CAAC,CACf,CAAA;IACH,OAAO,CACL,CAAC,OAAO,CACN,IAAI,CAAC,CAAC,KAAK,CAAC,aAAa,CAAC,CAC1B,IAAI,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CACvB,IAAI,KAAK,CAAC,CACV,IAAI,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAElB;MAAA,CAAC,OAAO,CACV;IAAA,EAAE,OAAO,CAAC,CACX,CAAA;AACH,CAAC,CAAA;AAED,KAAK,CAAC,SAAS,GAAG,SAAS,CAAA"}
@@ -0,0 +1,10 @@
1
+ export function WebchatSettings({ theme, blockInputs, persistentMenu, enableEmojiPicker, enableAttachments, enableUserInput, enableAnimations, }: {
2
+ theme: any;
3
+ blockInputs: any;
4
+ persistentMenu: any;
5
+ enableEmojiPicker: any;
6
+ enableAttachments: any;
7
+ enableUserInput: any;
8
+ enableAnimations: any;
9
+ }): any;
10
+ export function normalizeWebchatSettings(settings: any): any;
@@ -0,0 +1,72 @@
1
+ import { INPUT } from '@botonic/core';
2
+ import React, { useContext } from 'react';
3
+ import { WebchatContext } from '../contexts';
4
+ import { renderComponent } from '../util/react';
5
+ import { stringifyWithRegexs } from '../util/regexs';
6
+ export const WebchatSettings = ({ theme, blockInputs, persistentMenu, enableEmojiPicker, enableAttachments, enableUserInput, enableAnimations, }) => {
7
+ const renderBrowser = () => {
8
+ // eslint-disable-next-line react-hooks/rules-of-hooks
9
+ const { updateWebchatDevSettings } = useContext(WebchatContext);
10
+ updateWebchatDevSettings({
11
+ theme,
12
+ blockInputs,
13
+ persistentMenu,
14
+ enableEmojiPicker,
15
+ enableAttachments,
16
+ enableUserInput,
17
+ enableAnimations,
18
+ });
19
+ return null;
20
+ };
21
+ const renderNode = () => {
22
+ const updatedTheme = normalizeWebchatSettings({
23
+ theme,
24
+ blockInputs,
25
+ persistentMenu,
26
+ enableEmojiPicker,
27
+ enableAttachments,
28
+ enableUserInput,
29
+ enableAnimations,
30
+ });
31
+ return (<message type={INPUT.WEBCHAT_SETTINGS} settings={stringifyWithRegexs({ theme: updatedTheme })}></message>);
32
+ };
33
+ return renderComponent({ renderBrowser, renderNode });
34
+ };
35
+ export const normalizeWebchatSettings = settings => {
36
+ let { theme, blockInputs, persistentMenu, enableEmojiPicker, enableAttachments, enableUserInput, enableAnimations, } = settings;
37
+ if (!theme)
38
+ theme = {};
39
+ if (!theme.userInput)
40
+ theme.userInput = {};
41
+ if (!theme.animations)
42
+ theme.animations = {};
43
+ if (persistentMenu !== undefined) {
44
+ if (!theme.userInput.persistentMenu)
45
+ theme.userInput.persistentMenu = {};
46
+ theme.userInput.persistentMenu = persistentMenu;
47
+ }
48
+ if (enableEmojiPicker !== undefined) {
49
+ if (!theme.userInput.emojiPicker)
50
+ theme.userInput.emojiPicker = {};
51
+ theme.userInput.emojiPicker.enable = enableEmojiPicker;
52
+ }
53
+ if (enableAttachments !== undefined) {
54
+ if (!theme.userInput.attachments)
55
+ theme.userInput.attachments = {};
56
+ theme.userInput.attachments.enable = enableAttachments;
57
+ }
58
+ if (enableUserInput !== undefined) {
59
+ if (!theme.userInput.enable)
60
+ theme.userInput.enable = {};
61
+ theme.userInput.enable = enableUserInput;
62
+ }
63
+ if (enableAnimations !== undefined) {
64
+ if (!theme.animations.enable)
65
+ theme.animations.enable = {};
66
+ theme.animations.enable = enableAnimations;
67
+ }
68
+ if (blockInputs !== undefined)
69
+ theme.userInput.blockInputs = blockInputs;
70
+ return theme;
71
+ };
72
+ //# sourceMappingURL=webchat-settings.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"webchat-settings.js","sourceRoot":"src/","sources":["components/webchat-settings.jsx"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ export function WhatsappTemplate(props: any): any;
@@ -0,0 +1,21 @@
1
+ import { INPUT } from '@botonic/core';
2
+ import React from 'react';
3
+ import { renderComponent } from '../util/react';
4
+ import { Message } from './message';
5
+ const serialize = whatsappTemplateProps => {
6
+ return { text: whatsappTemplateProps };
7
+ };
8
+ export const WhatsappTemplate = props => {
9
+ const renderBrowser = () => {
10
+ // Return a dummy message for browser
11
+ const message = `Template ${props.name} with namespace ${props.namespace} would be sent to the user.`;
12
+ return (<Message json={serialize(message)} {...props} type={INPUT.TEXT}>
13
+ {message}
14
+ </Message>);
15
+ };
16
+ const renderNode = () => {
17
+ return (<message {...props} header={props.header && JSON.stringify(props.header)} body={props.body && JSON.stringify(props.body)} footer={props.footer && JSON.stringify(props.footer)} type={INPUT.WHATSAPP_TEMPLATE}/>);
18
+ };
19
+ return renderComponent({ renderBrowser, renderNode });
20
+ };
21
+ //# sourceMappingURL=whatsapp-template.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"whatsapp-template.js","sourceRoot":"src/","sources":["components/whatsapp-template.jsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AACrC,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAA;AAC/C,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AAEnC,MAAM,SAAS,GAAG,qBAAqB,CAAC,EAAE;IACxC,OAAO,EAAE,IAAI,EAAE,qBAAqB,EAAE,CAAA;AACxC,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,gBAAgB,GAAG,KAAK,CAAC,EAAE;IACtC,MAAM,aAAa,GAAG,GAAG,EAAE;QACzB,qCAAqC;QACrC,MAAM,OAAO,GAAG,YAAY,KAAK,CAAC,IAAI,mBAAmB,KAAK,CAAC,SAAS,6BAA6B,CAAA;QACrG,OAAO,CACL,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAC7D;QAAA,CAAC,OAAO,CACV;MAAA,EAAE,OAAO,CAAC,CACX,CAAA;IACH,CAAC,CAAA;IAED,MAAM,UAAU,GAAG,GAAG,EAAE;QACtB,OAAO,CACL,CAAC,OAAO,CACN,IAAI,KAAK,CAAC,CACV,MAAM,CAAC,CAAC,KAAK,CAAC,MAAM,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CACrD,IAAI,CAAC,CAAC,KAAK,CAAC,IAAI,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAC/C,MAAM,CAAC,CAAC,KAAK,CAAC,MAAM,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CACrD,IAAI,CAAC,CAAC,KAAK,CAAC,iBAAiB,CAAC,EAC9B,CACH,CAAA;IACH,CAAC,CAAA;IAED,OAAO,eAAe,CAAC,EAAE,aAAa,EAAE,UAAU,EAAE,CAAC,CAAA;AACvD,CAAC,CAAA"}