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

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 (338) hide show
  1. package/lib/cjs/components/index-types.d.ts +1 -0
  2. package/lib/cjs/components/index-types.js.map +1 -1
  3. package/lib/cjs/components/{message.js → message/index.js} +20 -65
  4. package/lib/cjs/components/message/index.js.map +1 -0
  5. package/lib/cjs/components/message/message-image.d.ts +7 -0
  6. package/lib/cjs/components/message/message-image.js +18 -0
  7. package/lib/cjs/components/message/message-image.js.map +1 -0
  8. package/lib/cjs/components/message/styles.d.ts +8 -0
  9. package/lib/cjs/components/message/styles.js +69 -0
  10. package/lib/cjs/components/message/styles.js.map +1 -0
  11. package/lib/cjs/components/{timestamps.d.ts → message/timestamps.d.ts} +2 -1
  12. package/lib/cjs/components/message/timestamps.js +36 -0
  13. package/lib/cjs/components/message/timestamps.js.map +1 -0
  14. package/lib/cjs/constants.d.ts +1 -0
  15. package/lib/cjs/constants.js +2 -0
  16. package/lib/cjs/constants.js.map +1 -1
  17. package/lib/cjs/webchat/trigger-button/index.js +3 -2
  18. package/lib/cjs/webchat/trigger-button/index.js.map +1 -1
  19. package/lib/esm/app.d.ts +2 -0
  20. package/lib/esm/app.js +6 -0
  21. package/lib/esm/app.js.map +1 -0
  22. package/lib/esm/assets/index-types.d.ts +4 -0
  23. package/lib/esm/assets/index-types.js +2 -0
  24. package/lib/esm/assets/index-types.js.map +1 -0
  25. package/lib/esm/botonic-tester.d.ts +18 -0
  26. package/lib/esm/botonic-tester.js +62 -0
  27. package/lib/esm/botonic-tester.js.map +1 -0
  28. package/lib/esm/components/audio.d.ts +8 -0
  29. package/lib/esm/components/audio.js +18 -0
  30. package/lib/esm/components/audio.js.map +1 -0
  31. package/lib/esm/components/button.d.ts +15 -0
  32. package/lib/esm/components/button.js +140 -0
  33. package/lib/esm/components/button.js.map +1 -0
  34. package/lib/esm/components/buttons-disabler.d.ts +24 -0
  35. package/lib/esm/components/buttons-disabler.js +84 -0
  36. package/lib/esm/components/buttons-disabler.js.map +1 -0
  37. package/lib/esm/components/carousel.d.ts +10 -0
  38. package/lib/esm/components/carousel.js +102 -0
  39. package/lib/esm/components/carousel.js.map +1 -0
  40. package/lib/esm/components/components.d.ts +12 -0
  41. package/lib/esm/components/components.js +17 -0
  42. package/lib/esm/components/components.js.map +1 -0
  43. package/lib/esm/components/custom-message.d.ts +12 -0
  44. package/lib/esm/components/custom-message.js +55 -0
  45. package/lib/esm/components/custom-message.js.map +1 -0
  46. package/lib/esm/components/document.d.ts +8 -0
  47. package/lib/esm/components/document.js +42 -0
  48. package/lib/esm/components/document.js.map +1 -0
  49. package/lib/esm/components/element.d.ts +4 -0
  50. package/lib/esm/components/element.js +51 -0
  51. package/lib/esm/components/element.js.map +1 -0
  52. package/lib/esm/components/handoff.d.ts +1 -0
  53. package/lib/esm/components/handoff.js +49 -0
  54. package/lib/esm/components/handoff.js.map +1 -0
  55. package/lib/esm/components/image.d.ts +8 -0
  56. package/lib/esm/components/image.js +35 -0
  57. package/lib/esm/components/image.js.map +1 -0
  58. package/lib/esm/components/index-types.d.ts +190 -0
  59. package/lib/esm/components/index-types.js +16 -0
  60. package/lib/esm/components/index-types.js.map +1 -0
  61. package/lib/esm/components/index.d.ts +23 -0
  62. package/lib/esm/components/index.js +24 -0
  63. package/lib/esm/components/index.js.map +1 -0
  64. package/lib/esm/components/location.d.ts +11 -0
  65. package/lib/esm/components/location.js +27 -0
  66. package/lib/esm/components/location.js.map +1 -0
  67. package/lib/esm/components/markdown.d.ts +7 -0
  68. package/lib/esm/components/markdown.js +152 -0
  69. package/lib/esm/components/markdown.js.map +1 -0
  70. package/lib/esm/components/message/index.d.ts +1 -0
  71. package/lib/esm/components/message/index.js +143 -0
  72. package/lib/esm/components/message/index.js.map +1 -0
  73. package/lib/esm/components/message/message-image.d.ts +7 -0
  74. package/lib/esm/components/message/message-image.js +14 -0
  75. package/lib/esm/components/message/message-image.js.map +1 -0
  76. package/lib/esm/components/message/styles.d.ts +8 -0
  77. package/lib/esm/components/message/styles.js +65 -0
  78. package/lib/esm/components/message/styles.js.map +1 -0
  79. package/lib/esm/components/message/timestamps.d.ts +11 -0
  80. package/lib/esm/components/message/timestamps.js +30 -0
  81. package/lib/esm/components/message/timestamps.js.map +1 -0
  82. package/lib/esm/components/message-template.d.ts +1 -0
  83. package/lib/esm/components/message-template.js +9 -0
  84. package/lib/esm/components/message-template.js.map +1 -0
  85. package/lib/esm/components/multichannel/facebook/facebook.d.ts +17 -0
  86. package/lib/esm/components/multichannel/facebook/facebook.js +43 -0
  87. package/lib/esm/components/multichannel/facebook/facebook.js.map +1 -0
  88. package/lib/esm/components/multichannel/index-types.d.ts +46 -0
  89. package/lib/esm/components/multichannel/index-types.js +2 -0
  90. package/lib/esm/components/multichannel/index-types.js.map +1 -0
  91. package/lib/esm/components/multichannel/index.d.ts +11 -0
  92. package/lib/esm/components/multichannel/index.js +12 -0
  93. package/lib/esm/components/multichannel/index.js.map +1 -0
  94. package/lib/esm/components/multichannel/multichannel-button.d.ts +1 -0
  95. package/lib/esm/components/multichannel/multichannel-button.js +71 -0
  96. package/lib/esm/components/multichannel/multichannel-button.js.map +1 -0
  97. package/lib/esm/components/multichannel/multichannel-carousel.d.ts +1 -0
  98. package/lib/esm/components/multichannel/multichannel-carousel.js +73 -0
  99. package/lib/esm/components/multichannel/multichannel-carousel.js.map +1 -0
  100. package/lib/esm/components/multichannel/multichannel-context.d.ts +11 -0
  101. package/lib/esm/components/multichannel/multichannel-context.js +12 -0
  102. package/lib/esm/components/multichannel/multichannel-context.js.map +1 -0
  103. package/lib/esm/components/multichannel/multichannel-reply.d.ts +1 -0
  104. package/lib/esm/components/multichannel/multichannel-reply.js +20 -0
  105. package/lib/esm/components/multichannel/multichannel-reply.js.map +1 -0
  106. package/lib/esm/components/multichannel/multichannel-text.d.ts +1 -0
  107. package/lib/esm/components/multichannel/multichannel-text.js +153 -0
  108. package/lib/esm/components/multichannel/multichannel-text.js.map +1 -0
  109. package/lib/esm/components/multichannel/multichannel-utils.d.ts +26 -0
  110. package/lib/esm/components/multichannel/multichannel-utils.js +69 -0
  111. package/lib/esm/components/multichannel/multichannel-utils.js.map +1 -0
  112. package/lib/esm/components/multichannel/multichannel.d.ts +1 -0
  113. package/lib/esm/components/multichannel/multichannel.js +55 -0
  114. package/lib/esm/components/multichannel/multichannel.js.map +1 -0
  115. package/lib/esm/components/multichannel/whatsapp/markdown.d.ts +1 -0
  116. package/lib/esm/components/multichannel/whatsapp/markdown.js +53 -0
  117. package/lib/esm/components/multichannel/whatsapp/markdown.js.map +1 -0
  118. package/lib/esm/components/pic.d.ts +6 -0
  119. package/lib/esm/components/pic.js +25 -0
  120. package/lib/esm/components/pic.js.map +1 -0
  121. package/lib/esm/components/raw.d.ts +9 -0
  122. package/lib/esm/components/raw.js +39 -0
  123. package/lib/esm/components/raw.js.map +1 -0
  124. package/lib/esm/components/reply.d.ts +9 -0
  125. package/lib/esm/components/reply.js +49 -0
  126. package/lib/esm/components/reply.js.map +1 -0
  127. package/lib/esm/components/share-button.d.ts +1 -0
  128. package/lib/esm/components/share-button.js +9 -0
  129. package/lib/esm/components/share-button.js.map +1 -0
  130. package/lib/esm/components/subtitle.d.ts +6 -0
  131. package/lib/esm/components/subtitle.js +19 -0
  132. package/lib/esm/components/subtitle.js.map +1 -0
  133. package/lib/esm/components/text.d.ts +8 -0
  134. package/lib/esm/components/text.js +42 -0
  135. package/lib/esm/components/text.js.map +1 -0
  136. package/lib/esm/components/title.d.ts +6 -0
  137. package/lib/esm/components/title.js +17 -0
  138. package/lib/esm/components/title.js.map +1 -0
  139. package/lib/esm/components/video.d.ts +8 -0
  140. package/lib/esm/components/video.js +26 -0
  141. package/lib/esm/components/video.js.map +1 -0
  142. package/lib/esm/components/webchat-settings.d.ts +3 -0
  143. package/lib/esm/components/webchat-settings.js +69 -0
  144. package/lib/esm/components/webchat-settings.js.map +1 -0
  145. package/lib/esm/components/whatsapp-button-list.d.ts +17 -0
  146. package/lib/esm/components/whatsapp-button-list.js +22 -0
  147. package/lib/esm/components/whatsapp-button-list.js.map +1 -0
  148. package/lib/esm/components/whatsapp-template.d.ts +1 -0
  149. package/lib/esm/components/whatsapp-template.js +20 -0
  150. package/lib/esm/components/whatsapp-template.js.map +1 -0
  151. package/lib/esm/constants.d.ts +173 -0
  152. package/lib/esm/constants.js +194 -0
  153. package/lib/esm/constants.js.map +1 -0
  154. package/lib/esm/contexts.d.ts +12 -0
  155. package/lib/esm/contexts.js +67 -0
  156. package/lib/esm/contexts.js.map +1 -0
  157. package/lib/esm/dev-app.d.ts +30 -0
  158. package/lib/esm/dev-app.js +74 -0
  159. package/lib/esm/dev-app.js.map +1 -0
  160. package/lib/esm/index-types.d.ts +128 -0
  161. package/lib/esm/index-types.js +12 -0
  162. package/lib/esm/index-types.js.map +1 -0
  163. package/lib/esm/index.d.ts +11 -0
  164. package/lib/esm/index.js +12 -0
  165. package/lib/esm/index.js.map +1 -0
  166. package/lib/esm/message-utils.d.ts +19 -0
  167. package/lib/esm/message-utils.js +41 -0
  168. package/lib/esm/message-utils.js.map +1 -0
  169. package/lib/esm/msg-to-botonic.d.ts +18 -0
  170. package/lib/esm/msg-to-botonic.js +135 -0
  171. package/lib/esm/msg-to-botonic.js.map +1 -0
  172. package/lib/esm/node-app.d.ts +12 -0
  173. package/lib/esm/node-app.js +21 -0
  174. package/lib/esm/node-app.js.map +1 -0
  175. package/lib/esm/react-bot.d.ts +8 -0
  176. package/lib/esm/react-bot.js +29 -0
  177. package/lib/esm/react-bot.js.map +1 -0
  178. package/lib/esm/util/dom.d.ts +13 -0
  179. package/lib/esm/util/dom.js +46 -0
  180. package/lib/esm/util/dom.js.map +1 -0
  181. package/lib/esm/util/environment.d.ts +6 -0
  182. package/lib/esm/util/environment.js +61 -0
  183. package/lib/esm/util/environment.js.map +1 -0
  184. package/lib/esm/util/error-boundary.d.ts +7 -0
  185. package/lib/esm/util/error-boundary.js +28 -0
  186. package/lib/esm/util/error-boundary.js.map +1 -0
  187. package/lib/esm/util/index.d.ts +8 -0
  188. package/lib/esm/util/index.js +9 -0
  189. package/lib/esm/util/index.js.map +1 -0
  190. package/lib/esm/util/logs.d.ts +2 -0
  191. package/lib/esm/util/logs.js +15 -0
  192. package/lib/esm/util/logs.js.map +1 -0
  193. package/lib/esm/util/objects.d.ts +3 -0
  194. package/lib/esm/util/objects.js +38 -0
  195. package/lib/esm/util/objects.js.map +1 -0
  196. package/lib/esm/util/react.d.ts +12 -0
  197. package/lib/esm/util/react.js +34 -0
  198. package/lib/esm/util/react.js.map +1 -0
  199. package/lib/esm/util/regexs.d.ts +2 -0
  200. package/lib/esm/util/regexs.js +18 -0
  201. package/lib/esm/util/regexs.js.map +1 -0
  202. package/lib/esm/util/webchat.d.ts +11 -0
  203. package/lib/esm/util/webchat.js +53 -0
  204. package/lib/esm/util/webchat.js.map +1 -0
  205. package/lib/esm/webchat/actions.d.ts +27 -0
  206. package/lib/esm/webchat/actions.js +29 -0
  207. package/lib/esm/webchat/actions.js.map +1 -0
  208. package/lib/esm/webchat/components/attachment.d.ts +5 -0
  209. package/lib/esm/webchat/components/attachment.js +24 -0
  210. package/lib/esm/webchat/components/attachment.js.map +1 -0
  211. package/lib/esm/webchat/components/common.d.ts +1 -0
  212. package/lib/esm/webchat/components/common.js +9 -0
  213. package/lib/esm/webchat/components/common.js.map +1 -0
  214. package/lib/esm/webchat/components/conditional-animation.d.ts +1 -0
  215. package/lib/esm/webchat/components/conditional-animation.js +12 -0
  216. package/lib/esm/webchat/components/conditional-animation.js.map +1 -0
  217. package/lib/esm/webchat/components/emoji-picker.d.ts +5 -0
  218. package/lib/esm/webchat/components/emoji-picker.js +37 -0
  219. package/lib/esm/webchat/components/emoji-picker.js.map +1 -0
  220. package/lib/esm/webchat/components/persistent-menu.d.ts +10 -0
  221. package/lib/esm/webchat/components/persistent-menu.js +39 -0
  222. package/lib/esm/webchat/components/persistent-menu.js.map +1 -0
  223. package/lib/esm/webchat/components/send-button.d.ts +3 -0
  224. package/lib/esm/webchat/components/send-button.js +14 -0
  225. package/lib/esm/webchat/components/send-button.js.map +1 -0
  226. package/lib/esm/webchat/components/styled-scrollbar.d.ts +1 -0
  227. package/lib/esm/webchat/components/styled-scrollbar.js +50 -0
  228. package/lib/esm/webchat/components/styled-scrollbar.js.map +1 -0
  229. package/lib/esm/webchat/components/typing-indicator.d.ts +1 -0
  230. package/lib/esm/webchat/components/typing-indicator.js +6 -0
  231. package/lib/esm/webchat/components/typing-indicator.js.map +1 -0
  232. package/lib/esm/webchat/devices/device-adapter.d.ts +12 -0
  233. package/lib/esm/webchat/devices/device-adapter.js +43 -0
  234. package/lib/esm/webchat/devices/device-adapter.js.map +1 -0
  235. package/lib/esm/webchat/devices/index.d.ts +11 -0
  236. package/lib/esm/webchat/devices/index.js +18 -0
  237. package/lib/esm/webchat/devices/index.js.map +1 -0
  238. package/lib/esm/webchat/devices/scrollbar-controller.d.ts +12 -0
  239. package/lib/esm/webchat/devices/scrollbar-controller.js +99 -0
  240. package/lib/esm/webchat/devices/scrollbar-controller.js.map +1 -0
  241. package/lib/esm/webchat/devices/webchat-resizer.d.ts +9 -0
  242. package/lib/esm/webchat/devices/webchat-resizer.js +43 -0
  243. package/lib/esm/webchat/devices/webchat-resizer.js.map +1 -0
  244. package/lib/esm/webchat/header.d.ts +3 -0
  245. package/lib/esm/webchat/header.js +79 -0
  246. package/lib/esm/webchat/header.js.map +1 -0
  247. package/lib/esm/webchat/hooks/index.d.ts +5 -0
  248. package/lib/esm/webchat/hooks/index.js +6 -0
  249. package/lib/esm/webchat/hooks/index.js.map +1 -0
  250. package/lib/esm/webchat/hooks/use-component-visible.d.ts +8 -0
  251. package/lib/esm/webchat/hooks/use-component-visible.js +20 -0
  252. package/lib/esm/webchat/hooks/use-component-visible.js.map +1 -0
  253. package/lib/esm/webchat/hooks/use-component-will-mount.d.ts +1 -0
  254. package/lib/esm/webchat/hooks/use-component-will-mount.js +5 -0
  255. package/lib/esm/webchat/hooks/use-component-will-mount.js.map +1 -0
  256. package/lib/esm/webchat/hooks/use-previous.d.ts +1 -0
  257. package/lib/esm/webchat/hooks/use-previous.js +9 -0
  258. package/lib/esm/webchat/hooks/use-previous.js.map +1 -0
  259. package/lib/esm/webchat/hooks/use-typing.d.ts +10 -0
  260. package/lib/esm/webchat/hooks/use-typing.js +26 -0
  261. package/lib/esm/webchat/hooks/use-typing.js.map +1 -0
  262. package/lib/esm/webchat/hooks/use-webchat.d.ts +41 -0
  263. package/lib/esm/webchat/hooks/use-webchat.js +177 -0
  264. package/lib/esm/webchat/hooks/use-webchat.js.map +1 -0
  265. package/lib/esm/webchat/index-types.d.ts +62 -0
  266. package/lib/esm/webchat/index-types.js +2 -0
  267. package/lib/esm/webchat/index-types.js.map +1 -0
  268. package/lib/esm/webchat/index.d.ts +4 -0
  269. package/lib/esm/webchat/index.js +10 -0
  270. package/lib/esm/webchat/index.js.map +1 -0
  271. package/lib/esm/webchat/message-list/index.d.ts +1 -0
  272. package/lib/esm/webchat/message-list/index.js +73 -0
  273. package/lib/esm/webchat/message-list/index.js.map +1 -0
  274. package/lib/esm/webchat/message-list/intro-message.d.ts +1 -0
  275. package/lib/esm/webchat/message-list/intro-message.js +18 -0
  276. package/lib/esm/webchat/message-list/intro-message.js.map +1 -0
  277. package/lib/esm/webchat/message-list/scroll-button.d.ts +5 -0
  278. package/lib/esm/webchat/message-list/scroll-button.js +17 -0
  279. package/lib/esm/webchat/message-list/scroll-button.js.map +1 -0
  280. package/lib/esm/webchat/message-list/styles.d.ts +4 -0
  281. package/lib/esm/webchat/message-list/styles.js +46 -0
  282. package/lib/esm/webchat/message-list/styles.js.map +1 -0
  283. package/lib/esm/webchat/message-list/unread-messages-banner.d.ts +6 -0
  284. package/lib/esm/webchat/message-list/unread-messages-banner.js +16 -0
  285. package/lib/esm/webchat/message-list/unread-messages-banner.js.map +1 -0
  286. package/lib/esm/webchat/message-list/use-debounce.d.ts +1 -0
  287. package/lib/esm/webchat/message-list/use-debounce.js +14 -0
  288. package/lib/esm/webchat/message-list/use-debounce.js.map +1 -0
  289. package/lib/esm/webchat/messages-reducer.d.ts +6 -0
  290. package/lib/esm/webchat/messages-reducer.js +82 -0
  291. package/lib/esm/webchat/messages-reducer.js.map +1 -0
  292. package/lib/esm/webchat/replies.d.ts +1 -0
  293. package/lib/esm/webchat/replies.js +38 -0
  294. package/lib/esm/webchat/replies.js.map +1 -0
  295. package/lib/esm/webchat/session-view.d.ts +1 -0
  296. package/lib/esm/webchat/session-view.js +96 -0
  297. package/lib/esm/webchat/session-view.js.map +1 -0
  298. package/lib/esm/webchat/trigger-button/index.d.ts +1 -0
  299. package/lib/esm/webchat/trigger-button/index.js +28 -0
  300. package/lib/esm/webchat/trigger-button/index.js.map +1 -0
  301. package/lib/esm/webchat/trigger-button/styles.d.ts +3 -0
  302. package/lib/esm/webchat/trigger-button/styles.js +36 -0
  303. package/lib/esm/webchat/trigger-button/styles.js.map +1 -0
  304. package/lib/esm/webchat/use-storage-state-hook.d.ts +1 -0
  305. package/lib/esm/webchat/use-storage-state-hook.js +38 -0
  306. package/lib/esm/webchat/use-storage-state-hook.js.map +1 -0
  307. package/lib/esm/webchat/webchat-dev.d.ts +7 -0
  308. package/lib/esm/webchat/webchat-dev.js +56 -0
  309. package/lib/esm/webchat/webchat-dev.js.map +1 -0
  310. package/lib/esm/webchat/webchat-reducer.d.ts +6 -0
  311. package/lib/esm/webchat/webchat-reducer.js +46 -0
  312. package/lib/esm/webchat/webchat-reducer.js.map +1 -0
  313. package/lib/esm/webchat/webchat.d.ts +3 -0
  314. package/lib/esm/webchat/webchat.js +637 -0
  315. package/lib/esm/webchat/webchat.js.map +1 -0
  316. package/lib/esm/webchat/webview.d.ts +2 -0
  317. package/lib/esm/webchat/webview.js +78 -0
  318. package/lib/esm/webchat/webview.js.map +1 -0
  319. package/lib/esm/webchat-app.d.ts +99 -0
  320. package/lib/esm/webchat-app.js +281 -0
  321. package/lib/esm/webchat-app.js.map +1 -0
  322. package/lib/esm/webview-app.d.ts +7 -0
  323. package/lib/esm/webview-app.js +95 -0
  324. package/lib/esm/webview-app.js.map +1 -0
  325. package/package.json +2 -2
  326. package/src/.DS_Store +0 -0
  327. package/src/components/index-types.ts +1 -0
  328. package/src/components/{message.jsx → message/index.jsx} +32 -92
  329. package/src/components/message/message-image.tsx +52 -0
  330. package/src/components/message/styles.ts +73 -0
  331. package/src/components/message/timestamps.jsx +62 -0
  332. package/src/constants.js +2 -0
  333. package/src/webchat/trigger-button/index.tsx +10 -5
  334. package/lib/cjs/components/message.js.map +0 -1
  335. package/lib/cjs/components/timestamps.js +0 -51
  336. package/lib/cjs/components/timestamps.js.map +0 -1
  337. package/src/components/timestamps.jsx +0 -68
  338. /package/lib/cjs/components/{message.d.ts → message/index.d.ts} +0 -0
@@ -0,0 +1,73 @@
1
+ import { jsxs as _jsxs, jsx as _jsx } from "react/jsx-runtime";
2
+ import React, { useContext } from 'react';
3
+ import { RequestContext } from '../../contexts';
4
+ import { Carousel } from '../carousel';
5
+ import { MultichannelText } from './multichannel-text';
6
+ import { getFilteredElements, isMultichannelButton, isNodeKind, isWhatsapp, } from './multichannel-utils';
7
+ export const MultichannelCarousel = props => {
8
+ const requestContext = useContext(RequestContext);
9
+ const getButtons = node => [].concat(getFilteredElements(node, isMultichannelButton));
10
+ if (isWhatsapp(requestContext)) {
11
+ const elements = props.children
12
+ .map(e => e.props.children)
13
+ .map((element, i) => {
14
+ let imageProps = undefined;
15
+ let title = undefined;
16
+ let subtitle = undefined;
17
+ const buttons = [];
18
+ for (const node of element) {
19
+ if (isNodeKind(node, 'Pic')) {
20
+ imageProps = node.props;
21
+ }
22
+ if (isNodeKind(node, 'Title')) {
23
+ title = node.props.children;
24
+ }
25
+ if (isNodeKind(node, 'Subtitle')) {
26
+ subtitle = node.props.children;
27
+ }
28
+ if (isNodeKind(node, 'MultichannelButton')) {
29
+ buttons.push(node);
30
+ }
31
+ //TODO support fragment containing an array
32
+ if (Array.isArray(node)) {
33
+ buttons.push(getButtons(node));
34
+ }
35
+ }
36
+ let header = '';
37
+ if (props.showTitle && title) {
38
+ header += `${title ? `**${title}**` : ''}`;
39
+ if (title && subtitle) {
40
+ header += ' ';
41
+ }
42
+ }
43
+ if (props.showSubtitle && subtitle) {
44
+ header += `_${subtitle}_`;
45
+ }
46
+ return (
47
+ // TODO: newkey only for 1 nested button
48
+ _jsxs(MultichannelText, Object.assign({ newkey: i, indexMode: props.indexMode, buttonsAsText: props.buttonsAsText }, { children: [header || null, buttons] }), i));
49
+ // TODO: in the future, this would be the default mode
50
+ // } else {
51
+ // return (
52
+ // <React.Fragment key={i}>
53
+ // <Image
54
+ // src={imageSrc}
55
+ // caption={carouselToCaption(
56
+ // i + 1,
57
+ // title,
58
+ // subtitle,
59
+ // imageSrc,
60
+ // buttonProps
61
+ // )}
62
+ // ></Image>
63
+ // </React.Fragment>
64
+ // )
65
+ // }
66
+ });
67
+ return elements;
68
+ }
69
+ else {
70
+ return _jsx(Carousel, Object.assign({}, props, { children: props.children }));
71
+ }
72
+ };
73
+ //# sourceMappingURL=multichannel-carousel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"multichannel-carousel.js","sourceRoot":"src/","sources":["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":"src/","sources":["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 React, { useContext } from 'react';
3
+ import { RequestContext } from '../../contexts';
4
+ import { Reply } from '../reply';
5
+ import { isWhatsapp } from './multichannel-utils';
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)) {
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":"src/","sources":["components/multichannel/multichannel-reply.jsx"],"names":[],"mappings":";AAAA,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;AAChC,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAA;AAEjD,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,EAAE;QAC9B,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;
@@ -0,0 +1,153 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import { INPUT } from '@botonic/core';
3
+ import React, { useContext } from 'react';
4
+ import { RequestContext } from '../../contexts';
5
+ import { WhatsappButtonList } from '..';
6
+ import { Text } from '../text';
7
+ import { MultichannelFacebook } from './facebook/facebook';
8
+ import { MultichannelButton } from './multichannel-button';
9
+ import { MultichannelContext } from './multichannel-context';
10
+ import { buttonTypes, DEFAULT_WHATSAPP_MAX_BUTTON_SEPARATOR, elementHasPostback, elementHasUrl, elementHasWebview, getButtonType, getMultichannelButtons, getMultichannelReplies, isFacebook, isWhatsapp, MENU_BUTTON_WHATSAPP_BUTTON_LIST, MULTICHANNEL_WHATSAPP_PROPS, WHATSAPP_LIST_MAX_BUTTONS, WHATSAPP_MAX_BUTTONS, } from './multichannel-utils';
11
+ import { whatsappMarkdown } from './whatsapp/markdown';
12
+ export const MultichannelText = props => {
13
+ var _a;
14
+ const requestContext = useContext(RequestContext);
15
+ const multichannelContext = useContext(MultichannelContext);
16
+ const postbackButtonsAsText = (_a = props.buttonsAsText) !== null && _a !== void 0 ? _a : true;
17
+ let elements = [];
18
+ const getText = children => {
19
+ children = Array.isArray(children) ? children : [children];
20
+ const text = children
21
+ .filter(e => e && !e.type)
22
+ .map(e => {
23
+ if (Array.isArray(e))
24
+ return getText(e);
25
+ else
26
+ return String(e);
27
+ })
28
+ .join('');
29
+ if (text == undefined) {
30
+ return [];
31
+ }
32
+ return [text].filter(t => t !== ''); // to avoid line breaks when the carousel doesn't have title or subtitle
33
+ };
34
+ const getButtonsAndReplies = () => [].concat(getMultichannelButtons(React.Children.toArray(props.children)), getMultichannelReplies(React.Children.toArray(props.children)));
35
+ const getWhatsappButtons = () => {
36
+ const postbackButtons = [];
37
+ const urlButtons = [];
38
+ const webviewButtons = [];
39
+ for (const button of getButtonsAndReplies()) {
40
+ if (elementHasUrl(button))
41
+ urlButtons.push(button);
42
+ else if (elementHasWebview(button))
43
+ webviewButtons.push(button);
44
+ else if (elementHasPostback(button))
45
+ postbackButtons.push(button);
46
+ }
47
+ return { postbackButtons, urlButtons, webviewButtons };
48
+ };
49
+ const getDefaultIndex = () => {
50
+ if (props.indexMode == undefined) {
51
+ return undefined;
52
+ }
53
+ if (multichannelContext.currentIndex != null) {
54
+ return multichannelContext.currentIndex;
55
+ }
56
+ return props.indexMode === 'letter' ? 'a' : 1;
57
+ };
58
+ const regenerateMultichannelButtons = (newLineFirstButton = true) => {
59
+ const generator = (multichannelButton, i) => {
60
+ const type = getButtonType(multichannelButton);
61
+ const asText = type === buttonTypes.POSTBACK ? postbackButtonsAsText : true;
62
+ const newline = multichannelContext.messageSeparator == null &&
63
+ !newLineFirstButton &&
64
+ i === 0
65
+ ? ''
66
+ : '\n';
67
+ return (_jsx(MultichannelButton, Object.assign({ newline: newline, asText: asText }, multichannelButton.props, { children: multichannelButton.props.children }), `${type}${i}`));
68
+ };
69
+ return generator;
70
+ };
71
+ const splitInWhatsappListButtons = postbackButtons => {
72
+ const messages = [];
73
+ for (let i = 0; i < postbackButtons.length; i += WHATSAPP_LIST_MAX_BUTTONS) {
74
+ messages.push(postbackButtons.slice(i, i + WHATSAPP_LIST_MAX_BUTTONS));
75
+ }
76
+ return messages;
77
+ };
78
+ if (isWhatsapp(requestContext)) {
79
+ const texts = getText(props.children);
80
+ const { postbackButtons, urlButtons, webviewButtons } = getWhatsappButtons();
81
+ const textElements = texts.map(text => {
82
+ const textWithMarkdown = whatsappMarkdown(text);
83
+ return (props.newline || '') + textWithMarkdown;
84
+ });
85
+ const webviewButtonElements = webviewButtons.map(regenerateMultichannelButtons(false));
86
+ const buttonsTextSeparator = props.buttonsTextSeparator || DEFAULT_WHATSAPP_MAX_BUTTON_SEPARATOR;
87
+ const exceedWhatsAppMaxButtonNumber = !postbackButtonsAsText && postbackButtons.length > WHATSAPP_MAX_BUTTONS;
88
+ if (exceedWhatsAppMaxButtonNumber) {
89
+ const menuButtonTextWhatsappList = props.menuButtonTextWhatsappList || MENU_BUTTON_WHATSAPP_BUTTON_LIST;
90
+ const urlButtonElements = urlButtons.map(regenerateMultichannelButtons(!!texts.length));
91
+ const postbackButtonElements = postbackButtons.map(regenerateMultichannelButtons(!!texts.length || !!urlButtons.length));
92
+ const messagesPostbackButtonList = splitInWhatsappListButtons(postbackButtonElements);
93
+ const messages = messagesPostbackButtonList.map((postbackButtons, index) => {
94
+ if (postbackButtons.length <= WHATSAPP_MAX_BUTTONS) {
95
+ return {
96
+ type: INPUT.TEXT,
97
+ children: [...buttonsTextSeparator, ...postbackButtons],
98
+ };
99
+ }
100
+ const rows = postbackButtons.map(postbackButton => {
101
+ const row = {
102
+ id: postbackButton.props.path
103
+ ? `__PATH_PAYLOAD__${postbackButton.props.path}`
104
+ : postbackButton.props.payload,
105
+ title: postbackButton.props.children,
106
+ };
107
+ return row;
108
+ });
109
+ const whatsbuttonlistProps = {
110
+ body: index === 0 ? textElements : buttonsTextSeparator,
111
+ button: menuButtonTextWhatsappList,
112
+ sections: [{ rows }],
113
+ };
114
+ return {
115
+ type: INPUT.WHATSAPP_BUTTON_LIST,
116
+ props: whatsbuttonlistProps,
117
+ };
118
+ });
119
+ const messageWithUrlButtonElements = (_jsx(Text, Object.assign({}, MULTICHANNEL_WHATSAPP_PROPS, props, { children: urlButtonElements }), `msg-with-url-button`));
120
+ const messageWithWebviewButtonElements = (_jsxs(Text, Object.assign({}, MULTICHANNEL_WHATSAPP_PROPS, props, { children: [buttonsTextSeparator, webviewButtonElements] }), `msg-with-webview-button`));
121
+ return (_jsxs(_Fragment, { children: [messages.map((message, i) => {
122
+ if (message.type === INPUT.WHATSAPP_BUTTON_LIST)
123
+ return (_jsx(WhatsappButtonList, Object.assign({}, message.props), `msg-${i}-whatsapp-list`));
124
+ return (_jsx(Text, Object.assign({}, MULTICHANNEL_WHATSAPP_PROPS, props, { children: message.children }), `msg-${i}-with-postback-buttons`));
125
+ }), urlButtonElements.length > 0 && messageWithUrlButtonElements, webviewButtonElements.length > 0 && messageWithWebviewButtonElements] }));
126
+ }
127
+ multichannelContext.currentIndex = getDefaultIndex();
128
+ const postbackButtonElements = postbackButtons.map(regenerateMultichannelButtons(!!texts.length));
129
+ const urlButtonElements = urlButtons.map(regenerateMultichannelButtons(!!texts.length || !!postbackButtons.length));
130
+ elements = [].concat([...textElements], [...postbackButtonElements], [...urlButtonElements]);
131
+ if (multichannelContext.messageSeparator != null) {
132
+ return elements;
133
+ }
134
+ const messages = [
135
+ _jsx(Text, Object.assign({}, MULTICHANNEL_WHATSAPP_PROPS, props, { children: elements }), 0),
136
+ ];
137
+ if (webviewButtonElements.length) {
138
+ messages.push(_jsxs(Text, Object.assign({}, MULTICHANNEL_WHATSAPP_PROPS, props, { children: [buttonsTextSeparator, webviewButtonElements] }), 1));
139
+ }
140
+ return _jsx(_Fragment, { children: messages });
141
+ }
142
+ if (isFacebook(requestContext)) {
143
+ const text = getText(props.children);
144
+ const multichannelFacebook = new MultichannelFacebook();
145
+ const { texts, propsLastText, propsWithoutChildren } = multichannelFacebook.convertText(props, text[0]);
146
+ return (_jsxs(_Fragment, { children: [texts &&
147
+ texts.map((e, i) => (_jsx(Text, Object.assign({}, propsWithoutChildren, { children: e }), i))), _jsx(Text, Object.assign({}, propsLastText, { children: propsLastText.children }))] }));
148
+ }
149
+ else {
150
+ return _jsx(Text, Object.assign({}, props, { children: props.children }));
151
+ }
152
+ };
153
+ //# sourceMappingURL=multichannel-text.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"multichannel-text.js","sourceRoot":"src/","sources":["components/multichannel/multichannel-text.jsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,26 @@
1
+ export function isMultichannelButton(node: any): any;
2
+ export function isMultichannelReply(node: any): any;
3
+ export function isButton(node: any): any;
4
+ export function isNodeKind(node: any, kind: any): any;
5
+ export function elementHasUrl(element: any): any;
6
+ export function elementHasPostback(element: any): any;
7
+ export function elementHasWebview(element: any): any;
8
+ export function getButtonType(multichannelButton: any): string | undefined;
9
+ export function getFilteredElements(node: any, filter: any): any[];
10
+ export function getMultichannelButtons(node: any): any[];
11
+ export function getMultichannelReplies(node: any): any[];
12
+ export namespace MULTICHANNEL_WHATSAPP_PROPS {
13
+ const markdown: boolean;
14
+ }
15
+ export const WHATSAPP_MAX_BUTTONS: 3;
16
+ export const WHATSAPP_LIST_MAX_BUTTONS: 10;
17
+ export const WHATSAPP_MAX_BUTTON_CHARS: 20;
18
+ export const DEFAULT_WHATSAPP_MAX_BUTTON_SEPARATOR: "More options:";
19
+ export const MENU_BUTTON_WHATSAPP_BUTTON_LIST: "Show options";
20
+ export namespace buttonTypes {
21
+ const POSTBACK: string;
22
+ const URL: string;
23
+ const WEBVIEW: string;
24
+ }
25
+ export function isWhatsapp(context: any): any;
26
+ export function isFacebook(context: any): any;
@@ -0,0 +1,69 @@
1
+ import { Providers } from '@botonic/core';
2
+ /**
3
+ *
4
+ * Whatsapp does not support Markdown
5
+ * (its markup syntax is different)
6
+ */
7
+ export const MULTICHANNEL_WHATSAPP_PROPS = { markdown: false };
8
+ export const WHATSAPP_MAX_BUTTONS = 3;
9
+ export const WHATSAPP_LIST_MAX_BUTTONS = 10;
10
+ export const WHATSAPP_MAX_BUTTON_CHARS = 20;
11
+ export const DEFAULT_WHATSAPP_MAX_BUTTON_SEPARATOR = 'More options:';
12
+ export const MENU_BUTTON_WHATSAPP_BUTTON_LIST = 'Show options';
13
+ export function isMultichannelButton(node) {
14
+ return isNodeKind(node, 'MultichannelButton');
15
+ }
16
+ export function isMultichannelReply(node) {
17
+ return isNodeKind(node, 'MultichannelReply');
18
+ }
19
+ export function isButton(node) {
20
+ return isNodeKind(node, 'Button');
21
+ }
22
+ export function isNodeKind(node, kind) {
23
+ return node.type && node.type.name == kind;
24
+ }
25
+ export function elementHasUrl(element) {
26
+ return element.props && element.props.url;
27
+ }
28
+ export function elementHasPostback(element) {
29
+ return ((element.props && element.props.payload) ||
30
+ (element.props && element.props.path));
31
+ }
32
+ export function elementHasWebview(element) {
33
+ return element.props && element.props.webview;
34
+ }
35
+ export const buttonTypes = {
36
+ POSTBACK: 'postback',
37
+ URL: 'url',
38
+ WEBVIEW: 'webview',
39
+ };
40
+ export function getButtonType(multichannelButton) {
41
+ if (elementHasUrl(multichannelButton))
42
+ return buttonTypes.URL;
43
+ if (elementHasPostback(multichannelButton))
44
+ return buttonTypes.POSTBACK;
45
+ if (elementHasWebview(multichannelButton))
46
+ return buttonTypes.WEBVIEW;
47
+ return undefined;
48
+ }
49
+ export function getFilteredElements(node, filter) {
50
+ const elements = [];
51
+ for (const n of node) {
52
+ if (filter(n))
53
+ elements.push(n);
54
+ }
55
+ return elements;
56
+ }
57
+ export function getMultichannelButtons(node) {
58
+ return getFilteredElements(node, isMultichannelButton);
59
+ }
60
+ export function getMultichannelReplies(node) {
61
+ return getFilteredElements(node, isMultichannelReply);
62
+ }
63
+ export const isWhatsapp = context => context.session &&
64
+ context.session.user &&
65
+ context.session.user.provider == Providers.Messaging.WHATSAPP;
66
+ export const isFacebook = context => context.session &&
67
+ context.session.user &&
68
+ context.session.user.provider == Providers.Messaging.FACEBOOK;
69
+ //# sourceMappingURL=multichannel-utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"multichannel-utils.js","sourceRoot":"src/","sources":["components/multichannel/multichannel-utils.js"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ export function Multichannel(props: any): any;
@@ -0,0 +1,55 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { createElement as _createElement } from "react";
3
+ import React, { useContext } from 'react';
4
+ import { COMPONENT_TYPE } from '../../constants';
5
+ import { RequestContext } from '../../contexts';
6
+ import { deepMapWithIndex } from '../../util/react';
7
+ import { Text } from '../text';
8
+ import { MultichannelButton } from './multichannel-button';
9
+ import { MultichannelCarousel } from './multichannel-carousel';
10
+ import { MultichannelContext } from './multichannel-context';
11
+ import { MultichannelReply } from './multichannel-reply';
12
+ import { MultichannelText } from './multichannel-text';
13
+ import { isFacebook, isWhatsapp, MULTICHANNEL_WHATSAPP_PROPS, } from './multichannel-utils';
14
+ export const Multichannel = props => {
15
+ const requestContext = useContext(RequestContext);
16
+ if (!isWhatsapp(requestContext) && !isFacebook(requestContext)) {
17
+ return props.children;
18
+ }
19
+ if (isFacebook(requestContext)) {
20
+ const newChildren = deepMapWithIndex(props.children, child => {
21
+ if (child && child.type && child.type.name === COMPONENT_TYPE.TEXT) {
22
+ return (_createElement(MultichannelText, Object.assign({}, child.props, { key: child.key }), child.props.children));
23
+ }
24
+ return child;
25
+ });
26
+ return newChildren;
27
+ }
28
+ let newChildren = deepMapWithIndex(props.children, (child, index) => {
29
+ if (child && child.type && child.type.name === COMPONENT_TYPE.BUTTON) {
30
+ return (_createElement(MultichannelButton, Object.assign({}, child.props, { key: child.key }), child.props.children));
31
+ }
32
+ if (child && child.type && child.type.name === COMPONENT_TYPE.REPLY) {
33
+ return (_createElement(MultichannelReply, Object.assign({}, child.props, { key: child.key }), child.props.children));
34
+ }
35
+ if (child && child.type && child.type.name === COMPONENT_TYPE.TEXT) {
36
+ return (_createElement(MultichannelText, Object.assign({}, child.props, props.text, { key: child.key }, (props.messageSeparator &&
37
+ index > 0 && { newline: props.messageSeparator })), child.props.children));
38
+ }
39
+ if (child && child.type && child.type.name === COMPONENT_TYPE.CAROUSEL) {
40
+ return (_createElement(MultichannelCarousel, Object.assign({}, child.props, props.carousel, { key: child.key }), child.props.children));
41
+ }
42
+ return child;
43
+ });
44
+ if (props.messageSeparator != null) {
45
+ newChildren = newChildren.map((c, index) => index > 0 && typeof c === 'string' ? props.messageSeparator + c : c);
46
+ newChildren = (_jsx(Text, Object.assign({}, MULTICHANNEL_WHATSAPP_PROPS, { children: newChildren }), props.key));
47
+ }
48
+ return (_jsx(MultichannelContext.Provider, Object.assign({ value: {
49
+ currentIndex: props.firstIndex,
50
+ boldIndex: props.boldIndex,
51
+ indexSeparator: props.indexSeparator,
52
+ messageSeparator: props.messageSeparator,
53
+ } }, { children: newChildren })));
54
+ };
55
+ //# sourceMappingURL=multichannel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"multichannel.js","sourceRoot":"src/","sources":["components/multichannel/multichannel.jsx"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ export declare function whatsappMarkdown(text: string): string;
@@ -0,0 +1,53 @@
1
+ const MARKDOWN_BOLD_OPTION_1 = '**';
2
+ const MARKDOWN_BOLD_OPTION_2 = '__';
3
+ const MARKDOWN_WHATSAPP_BOLD = '*';
4
+ const MARKDOWN_ITALIC_OPTION_1 = '*';
5
+ const MARKDOWN_WHATSAPP_ITALIC = '_';
6
+ const MARKDOWN_BOLD_OR_ITALIC_REGEX = /(\*\*|__)(.*?)\1|(\*|_)(.*?)\3/g;
7
+ const MARKDOWN_NORMALIZED_BOLD_ITALIC_OPEN = '**_';
8
+ const MARKDOWN_NORMALIZED_BOLD_ITALIC_CLOSE = '_**';
9
+ const MARKDOWN_BOLD_AND_ITALIC_OPTION1 = /(_\*\*)(.*?)(\*\*_)/g;
10
+ const MARKDOWN_BOLD_AND_ITALIC_OPTION2 = /(\*__)(.*?)(__\*)/g;
11
+ const MARKDOWN_BOLD_AND_ITALIC_OPTION3 = /(__\*)(.*?)(\*__)/g;
12
+ export function whatsappMarkdown(text) {
13
+ const textNormalized = normalizeMarkdown(text);
14
+ const matches = textNormalized.match(MARKDOWN_BOLD_OR_ITALIC_REGEX);
15
+ if (matches) {
16
+ const matchesResult = matches.map(match => {
17
+ if (match.startsWith(MARKDOWN_BOLD_OPTION_1)) {
18
+ return replaceAllOccurrences(match, MARKDOWN_BOLD_OPTION_1, MARKDOWN_WHATSAPP_BOLD);
19
+ }
20
+ if (match.startsWith(MARKDOWN_BOLD_OPTION_2)) {
21
+ return replaceAllOccurrences(match, MARKDOWN_BOLD_OPTION_2, MARKDOWN_WHATSAPP_BOLD);
22
+ }
23
+ if (match.startsWith(MARKDOWN_ITALIC_OPTION_1)) {
24
+ return replaceAllOccurrences(match, MARKDOWN_ITALIC_OPTION_1, MARKDOWN_WHATSAPP_ITALIC);
25
+ }
26
+ return match;
27
+ });
28
+ let textWhatsapp = textNormalized;
29
+ for (let i = 0; i < matches.length; i++) {
30
+ textWhatsapp = replaceAllOccurrences(textWhatsapp, matches[i], matchesResult[i]);
31
+ }
32
+ return textWhatsapp;
33
+ }
34
+ return text;
35
+ }
36
+ function normalizeMarkdown(text) {
37
+ text = replaceBoldItalic(text, MARKDOWN_BOLD_AND_ITALIC_OPTION1);
38
+ text = replaceBoldItalic(text, MARKDOWN_BOLD_AND_ITALIC_OPTION2);
39
+ text = replaceBoldItalic(text, MARKDOWN_BOLD_AND_ITALIC_OPTION3);
40
+ return text;
41
+ }
42
+ function replaceBoldItalic(text, regex) {
43
+ return text.replace(regex, (match, markdownOpen, textInsideMarkdown, markdownClose) => {
44
+ if (match.startsWith(markdownOpen) && match.endsWith(markdownClose)) {
45
+ return `${MARKDOWN_NORMALIZED_BOLD_ITALIC_OPEN}${textInsideMarkdown}${MARKDOWN_NORMALIZED_BOLD_ITALIC_CLOSE}`;
46
+ }
47
+ return match;
48
+ });
49
+ }
50
+ function replaceAllOccurrences(text, searchValue, replaceValue) {
51
+ return text.split(searchValue).join(replaceValue);
52
+ }
53
+ //# sourceMappingURL=markdown.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"markdown.js","sourceRoot":"src/","sources":["components/multichannel/whatsapp/markdown.ts"],"names":[],"mappings":"AAAA,MAAM,sBAAsB,GAAG,IAAI,CAAA;AACnC,MAAM,sBAAsB,GAAG,IAAI,CAAA;AACnC,MAAM,sBAAsB,GAAG,GAAG,CAAA;AAElC,MAAM,wBAAwB,GAAG,GAAG,CAAA;AACpC,MAAM,wBAAwB,GAAG,GAAG,CAAA;AAEpC,MAAM,6BAA6B,GAAG,iCAAiC,CAAA;AAEvE,MAAM,oCAAoC,GAAG,KAAK,CAAA;AAClD,MAAM,qCAAqC,GAAG,KAAK,CAAA;AAEnD,MAAM,gCAAgC,GAAG,sBAAsB,CAAA;AAC/D,MAAM,gCAAgC,GAAG,oBAAoB,CAAA;AAC7D,MAAM,gCAAgC,GAAG,oBAAoB,CAAA;AAE7D,MAAM,UAAU,gBAAgB,CAAC,IAAY;IAC3C,MAAM,cAAc,GAAG,iBAAiB,CAAC,IAAI,CAAC,CAAA;IAC9C,MAAM,OAAO,GAAG,cAAc,CAAC,KAAK,CAAC,6BAA6B,CAAC,CAAA;IACnE,IAAI,OAAO,EAAE;QACX,MAAM,aAAa,GAAG,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE;YACxC,IAAI,KAAK,CAAC,UAAU,CAAC,sBAAsB,CAAC,EAAE;gBAC5C,OAAO,qBAAqB,CAC1B,KAAK,EACL,sBAAsB,EACtB,sBAAsB,CACvB,CAAA;aACF;YACD,IAAI,KAAK,CAAC,UAAU,CAAC,sBAAsB,CAAC,EAAE;gBAC5C,OAAO,qBAAqB,CAC1B,KAAK,EACL,sBAAsB,EACtB,sBAAsB,CACvB,CAAA;aACF;YACD,IAAI,KAAK,CAAC,UAAU,CAAC,wBAAwB,CAAC,EAAE;gBAC9C,OAAO,qBAAqB,CAC1B,KAAK,EACL,wBAAwB,EACxB,wBAAwB,CACzB,CAAA;aACF;YACD,OAAO,KAAK,CAAA;QACd,CAAC,CAAC,CAAA;QACF,IAAI,YAAY,GAAG,cAAc,CAAA;QACjC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YACvC,YAAY,GAAG,qBAAqB,CAClC,YAAY,EACZ,OAAO,CAAC,CAAC,CAAC,EACV,aAAa,CAAC,CAAC,CAAC,CACjB,CAAA;SACF;QACD,OAAO,YAAY,CAAA;KACpB;IACD,OAAO,IAAI,CAAA;AACb,CAAC;AAED,SAAS,iBAAiB,CAAC,IAAY;IACrC,IAAI,GAAG,iBAAiB,CAAC,IAAI,EAAE,gCAAgC,CAAC,CAAA;IAChE,IAAI,GAAG,iBAAiB,CAAC,IAAI,EAAE,gCAAgC,CAAC,CAAA;IAChE,IAAI,GAAG,iBAAiB,CAAC,IAAI,EAAE,gCAAgC,CAAC,CAAA;IAChE,OAAO,IAAI,CAAA;AACb,CAAC;AAED,SAAS,iBAAiB,CAAC,IAAY,EAAE,KAAa;IACpD,OAAO,IAAI,CAAC,OAAO,CACjB,KAAK,EACL,CACE,KAAa,EACb,YAAoB,EACpB,kBAA0B,EAC1B,aAAqB,EACrB,EAAE;QACF,IAAI,KAAK,CAAC,UAAU,CAAC,YAAY,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,aAAa,CAAC,EAAE;YACnE,OAAO,GAAG,oCAAoC,GAAG,kBAAkB,GAAG,qCAAqC,EAAE,CAAA;SAC9G;QACD,OAAO,KAAK,CAAA;IACd,CAAC,CACF,CAAA;AACH,CAAC;AAED,SAAS,qBAAqB,CAC5B,IAAY,EACZ,WAAmB,EACnB,YAAoB;IAEpB,OAAO,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAA;AACnD,CAAC"}
@@ -0,0 +1,6 @@
1
+ export function Pic(props: any): any;
2
+ export namespace Pic {
3
+ function serialize(picProps: any): {
4
+ pic: any;
5
+ };
6
+ }
@@ -0,0 +1,25 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import React from 'react';
3
+ import styled from 'styled-components';
4
+ import { COLORS, WEBCHAT } from '../constants';
5
+ import { staticAsset } from '../util/environment';
6
+ import { renderComponent } from '../util/react';
7
+ const PicStyled = styled.img `
8
+ border-top-left-radius: 8px;
9
+ border-top-right-radius: 8px;
10
+ width: ${WEBCHAT.DEFAULTS.ELEMENT_WIDTH}px;
11
+ height: 140px;
12
+ background: ${COLORS.SOLID_WHITE} url(${props => props.src}) no-repeat
13
+ center/cover;
14
+ border-bottom: 1px solid ${COLORS.SEASHELL_WHITE};
15
+ `;
16
+ export const Pic = props => {
17
+ props = Object.assign(Object.assign({}, props), { src: staticAsset(props.src) });
18
+ const renderBrowser = () => _jsx(PicStyled, { src: props.src });
19
+ const renderNode = () => _jsx("pic", { children: props.src });
20
+ return renderComponent({ renderBrowser, renderNode });
21
+ };
22
+ Pic.serialize = picProps => {
23
+ return { pic: picProps.src };
24
+ };
25
+ //# sourceMappingURL=pic.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pic.js","sourceRoot":"src/","sources":["components/pic.jsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,MAAM,MAAM,mBAAmB,CAAA;AAEtC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,cAAc,CAAA;AAC9C,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAA;AACjD,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAA;AAE/C,MAAM,SAAS,GAAG,MAAM,CAAC,GAAG,CAAA;;;WAGjB,OAAO,CAAC,QAAQ,CAAC,aAAa;;gBAEzB,MAAM,CAAC,WAAW,QAAQ,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,GAAG;;6BAE/B,MAAM,CAAC,cAAc;CACjD,CAAA;AAED,MAAM,CAAC,MAAM,GAAG,GAAG,KAAK,CAAC,EAAE;IACzB,KAAK,mCAAQ,KAAK,KAAE,GAAG,EAAE,WAAW,CAAC,KAAK,CAAC,GAAG,CAAC,GAAE,CAAA;IACjD,MAAM,aAAa,GAAG,GAAG,EAAE,CAAC,KAAC,SAAS,IAAC,GAAG,EAAE,KAAK,CAAC,GAAG,GAAI,CAAA;IACzD,MAAM,UAAU,GAAG,GAAG,EAAE,CAAC,wBAAM,KAAK,CAAC,GAAG,GAAO,CAAA;IAC/C,OAAO,eAAe,CAAC,EAAE,aAAa,EAAE,UAAU,EAAE,CAAC,CAAA;AACvD,CAAC,CAAA;AAED,GAAG,CAAC,SAAS,GAAG,QAAQ,CAAC,EAAE;IACzB,OAAO,EAAE,GAAG,EAAE,QAAQ,CAAC,GAAG,EAAE,CAAA;AAC9B,CAAC,CAAA"}
@@ -0,0 +1,9 @@
1
+ export function Raw(props: any): JSX.Element;
2
+ export namespace Raw {
3
+ export { serialize };
4
+ }
5
+ declare function serialize(rawProps: any): {
6
+ data: any;
7
+ alt: any;
8
+ };
9
+ export {};
@@ -0,0 +1,39 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import { INPUT, isBrowser } from '@botonic/core';
3
+ import React, { useState } from 'react';
4
+ import styled from 'styled-components';
5
+ import { COLORS, ROLES } from '../constants';
6
+ import { Message } from './message';
7
+ const RawDataButton = styled.div `
8
+ align-self: flex-start;
9
+ background-color: ${COLORS.CURIOUS_BLUE};
10
+ padding: 4px;
11
+ margin: 4px 0px;
12
+ cursor: pointer;
13
+ color: ${COLORS.SOLID_WHITE_ALPHA_0_8};
14
+ font-size: 10px;
15
+ border-radius: 2px;
16
+ `;
17
+ const Popover = styled.div `
18
+ max-width: 100%;
19
+ max-height: 500px;
20
+ overflow: auto;
21
+ background-color: ${COLORS.LIGHT_GRAY};
22
+ padding: 10px;
23
+ pre {
24
+ margin: 0px;
25
+ }
26
+ `;
27
+ const serialize = rawProps => {
28
+ return { data: rawProps.data, alt: rawProps.alt };
29
+ };
30
+ export const Raw = props => {
31
+ let content = props.children;
32
+ const data = JSON.stringify(props.data, null, ' ');
33
+ const [isOpen, setIsOpen] = useState(false);
34
+ if (isBrowser())
35
+ content = (_jsxs(_Fragment, { children: [_jsx("div", { children: props.alt }), _jsxs(RawDataButton, Object.assign({ onClick: () => setIsOpen(!isOpen) }, { children: ["RAW DATA ", _jsx("small", { children: isOpen ? '▲' : '▼' })] })), isOpen && (_jsx(Popover, { children: _jsx("pre", { children: data }) }))] }));
36
+ return (_jsx(Message, Object.assign({ role: ROLES.RAW_MESSAGE, json: serialize(props) }, props, { data: data, type: INPUT.RAW }, { children: content })));
37
+ };
38
+ Raw.serialize = serialize;
39
+ //# sourceMappingURL=raw.js.map