@botonic/react 0.31.1-alpha.0 → 0.31.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 (452) hide show
  1. package/lib/cjs/webchat/context/index.js +4 -1
  2. package/lib/cjs/webchat/context/index.js.map +1 -1
  3. package/lib/cjs/webchat/context/types.d.ts +3 -1
  4. package/lib/cjs/webchat/context/use-webchat.d.ts +1 -1
  5. package/lib/cjs/webchat/context/use-webchat.js +2 -2
  6. package/lib/cjs/webchat/context/use-webchat.js.map +1 -1
  7. package/lib/cjs/webchat/hooks/use-scrollbar-controller.js +14 -14
  8. package/lib/cjs/webchat/hooks/use-scrollbar-controller.js.map +1 -1
  9. package/lib/cjs/webchat/hooks/use-webchat-dimensions.js +3 -3
  10. package/lib/cjs/webchat/hooks/use-webchat-dimensions.js.map +1 -1
  11. package/lib/cjs/webchat/hooks/use-webchat-resizer.js +5 -5
  12. package/lib/cjs/webchat/hooks/use-webchat-resizer.js.map +1 -1
  13. package/lib/cjs/webchat/webchat.js +9 -14
  14. package/lib/cjs/webchat/webchat.js.map +1 -1
  15. package/lib/cjs/webchat/webview/header.d.ts +1 -0
  16. package/lib/cjs/webchat/webview/header.js +16 -0
  17. package/lib/cjs/webchat/webview/header.js.map +1 -0
  18. package/lib/cjs/webchat/webview/index.d.ts +1 -0
  19. package/lib/cjs/webchat/webview/index.js +49 -0
  20. package/lib/cjs/webchat/webview/index.js.map +1 -0
  21. package/lib/cjs/webchat/webview/styles.d.ts +7 -0
  22. package/lib/cjs/webchat/webview/styles.js +46 -0
  23. package/lib/cjs/webchat/webview/styles.js.map +1 -0
  24. package/lib/esm/app.d.ts +2 -0
  25. package/lib/esm/app.js +6 -0
  26. package/lib/esm/app.js.map +1 -0
  27. package/lib/esm/botonic-tester.d.ts +30 -0
  28. package/lib/esm/botonic-tester.js +78 -0
  29. package/lib/esm/botonic-tester.js.map +1 -0
  30. package/lib/esm/components/audio.d.ts +9 -0
  31. package/lib/esm/components/audio.js +21 -0
  32. package/lib/esm/components/audio.js.map +1 -0
  33. package/lib/esm/components/button.d.ts +17 -0
  34. package/lib/esm/components/button.js +159 -0
  35. package/lib/esm/components/button.js.map +1 -0
  36. package/lib/esm/components/buttons-disabler.d.ts +24 -0
  37. package/lib/esm/components/buttons-disabler.js +84 -0
  38. package/lib/esm/components/buttons-disabler.js.map +1 -0
  39. package/lib/esm/components/carousel.d.ts +10 -0
  40. package/lib/esm/components/carousel.js +105 -0
  41. package/lib/esm/components/carousel.js.map +1 -0
  42. package/lib/esm/components/components.d.ts +12 -0
  43. package/lib/esm/components/components.js +17 -0
  44. package/lib/esm/components/components.js.map +1 -0
  45. package/lib/esm/components/custom-message.d.ts +16 -0
  46. package/lib/esm/components/custom-message.js +50 -0
  47. package/lib/esm/components/custom-message.js.map +1 -0
  48. package/lib/esm/components/document.d.ts +9 -0
  49. package/lib/esm/components/document.js +42 -0
  50. package/lib/esm/components/document.js.map +1 -0
  51. package/lib/esm/components/element.d.ts +4 -0
  52. package/lib/esm/components/element.js +51 -0
  53. package/lib/esm/components/element.js.map +1 -0
  54. package/lib/esm/components/handoff.d.ts +1 -0
  55. package/lib/esm/components/handoff.js +49 -0
  56. package/lib/esm/components/handoff.js.map +1 -0
  57. package/lib/esm/components/image.d.ts +9 -0
  58. package/lib/esm/components/image.js +35 -0
  59. package/lib/esm/components/image.js.map +1 -0
  60. package/lib/esm/components/index-types.d.ts +89 -0
  61. package/lib/esm/components/index-types.js +2 -0
  62. package/lib/esm/components/index-types.js.map +1 -0
  63. package/lib/esm/components/index.d.ts +30 -0
  64. package/lib/esm/components/index.js +31 -0
  65. package/lib/esm/components/index.js.map +1 -0
  66. package/lib/esm/components/location.d.ts +11 -0
  67. package/lib/esm/components/location.js +27 -0
  68. package/lib/esm/components/location.js.map +1 -0
  69. package/lib/esm/components/markdown.d.ts +7 -0
  70. package/lib/esm/components/markdown.js +152 -0
  71. package/lib/esm/components/markdown.js.map +1 -0
  72. package/lib/esm/components/message/index.d.ts +1 -0
  73. package/lib/esm/components/message/index.js +147 -0
  74. package/lib/esm/components/message/index.js.map +1 -0
  75. package/lib/esm/components/message/message-feedback.d.ts +7 -0
  76. package/lib/esm/components/message/message-feedback.js +59 -0
  77. package/lib/esm/components/message/message-feedback.js.map +1 -0
  78. package/lib/esm/components/message/message-footer.d.ts +11 -0
  79. package/lib/esm/components/message/message-footer.js +17 -0
  80. package/lib/esm/components/message/message-footer.js.map +1 -0
  81. package/lib/esm/components/message/message-image.d.ts +7 -0
  82. package/lib/esm/components/message/message-image.js +19 -0
  83. package/lib/esm/components/message/message-image.js.map +1 -0
  84. package/lib/esm/components/message/styles.d.ts +33 -0
  85. package/lib/esm/components/message/styles.js +118 -0
  86. package/lib/esm/components/message/styles.js.map +1 -0
  87. package/lib/esm/components/message/timestamps.d.ts +13 -0
  88. package/lib/esm/components/message/timestamps.js +40 -0
  89. package/lib/esm/components/message/timestamps.js.map +1 -0
  90. package/lib/esm/components/message-template.d.ts +1 -0
  91. package/lib/esm/components/message-template.js +9 -0
  92. package/lib/esm/components/message-template.js.map +1 -0
  93. package/lib/esm/components/multichannel/facebook/facebook.d.ts +17 -0
  94. package/lib/esm/components/multichannel/facebook/facebook.js +43 -0
  95. package/lib/esm/components/multichannel/facebook/facebook.js.map +1 -0
  96. package/lib/esm/components/multichannel/index-types.d.ts +46 -0
  97. package/lib/esm/components/multichannel/index-types.js +2 -0
  98. package/lib/esm/components/multichannel/index-types.js.map +1 -0
  99. package/lib/esm/components/multichannel/index.d.ts +11 -0
  100. package/lib/esm/components/multichannel/index.js +12 -0
  101. package/lib/esm/components/multichannel/index.js.map +1 -0
  102. package/lib/esm/components/multichannel/multichannel-button.d.ts +1 -0
  103. package/lib/esm/components/multichannel/multichannel-button.js +67 -0
  104. package/lib/esm/components/multichannel/multichannel-button.js.map +1 -0
  105. package/lib/esm/components/multichannel/multichannel-carousel.d.ts +1 -0
  106. package/lib/esm/components/multichannel/multichannel-carousel.js +74 -0
  107. package/lib/esm/components/multichannel/multichannel-carousel.js.map +1 -0
  108. package/lib/esm/components/multichannel/multichannel-context.d.ts +11 -0
  109. package/lib/esm/components/multichannel/multichannel-context.js +12 -0
  110. package/lib/esm/components/multichannel/multichannel-context.js.map +1 -0
  111. package/lib/esm/components/multichannel/multichannel-reply.d.ts +1 -0
  112. package/lib/esm/components/multichannel/multichannel-reply.js +20 -0
  113. package/lib/esm/components/multichannel/multichannel-reply.js.map +1 -0
  114. package/lib/esm/components/multichannel/multichannel-text.d.ts +1 -0
  115. package/lib/esm/components/multichannel/multichannel-text.js +160 -0
  116. package/lib/esm/components/multichannel/multichannel-text.js.map +1 -0
  117. package/lib/esm/components/multichannel/multichannel-utils.d.ts +21 -0
  118. package/lib/esm/components/multichannel/multichannel-utils.js +81 -0
  119. package/lib/esm/components/multichannel/multichannel-utils.js.map +1 -0
  120. package/lib/esm/components/multichannel/multichannel.d.ts +1 -0
  121. package/lib/esm/components/multichannel/multichannel.js +57 -0
  122. package/lib/esm/components/multichannel/multichannel.js.map +1 -0
  123. package/lib/esm/components/multichannel/whatsapp/constants.d.ts +11 -0
  124. package/lib/esm/components/multichannel/whatsapp/constants.js +10 -0
  125. package/lib/esm/components/multichannel/whatsapp/constants.js.map +1 -0
  126. package/lib/esm/components/multichannel/whatsapp/markdown-meta.d.ts +1 -0
  127. package/lib/esm/components/multichannel/whatsapp/markdown-meta.js +38 -0
  128. package/lib/esm/components/multichannel/whatsapp/markdown-meta.js.map +1 -0
  129. package/lib/esm/components/pic.d.ts +6 -0
  130. package/lib/esm/components/pic.js +25 -0
  131. package/lib/esm/components/pic.js.map +1 -0
  132. package/lib/esm/components/raw.d.ts +9 -0
  133. package/lib/esm/components/raw.js +39 -0
  134. package/lib/esm/components/raw.js.map +1 -0
  135. package/lib/esm/components/reply.d.ts +10 -0
  136. package/lib/esm/components/reply.js +53 -0
  137. package/lib/esm/components/reply.js.map +1 -0
  138. package/lib/esm/components/share-button.d.ts +1 -0
  139. package/lib/esm/components/share-button.js +9 -0
  140. package/lib/esm/components/share-button.js.map +1 -0
  141. package/lib/esm/components/subtitle.d.ts +6 -0
  142. package/lib/esm/components/subtitle.js +19 -0
  143. package/lib/esm/components/subtitle.js.map +1 -0
  144. package/lib/esm/components/text.d.ts +7 -0
  145. package/lib/esm/components/text.js +40 -0
  146. package/lib/esm/components/text.js.map +1 -0
  147. package/lib/esm/components/title.d.ts +6 -0
  148. package/lib/esm/components/title.js +17 -0
  149. package/lib/esm/components/title.js.map +1 -0
  150. package/lib/esm/components/video.d.ts +9 -0
  151. package/lib/esm/components/video.js +25 -0
  152. package/lib/esm/components/video.js.map +1 -0
  153. package/lib/esm/components/webchat-settings.d.ts +16 -0
  154. package/lib/esm/components/webchat-settings.js +69 -0
  155. package/lib/esm/components/webchat-settings.js.map +1 -0
  156. package/lib/esm/components/whatsapp-button-list.d.ts +20 -0
  157. package/lib/esm/components/whatsapp-button-list.js +47 -0
  158. package/lib/esm/components/whatsapp-button-list.js.map +1 -0
  159. package/lib/esm/components/whatsapp-catalog.d.ts +6 -0
  160. package/lib/esm/components/whatsapp-catalog.js +21 -0
  161. package/lib/esm/components/whatsapp-catalog.js.map +1 -0
  162. package/lib/esm/components/whatsapp-cta-url-button.d.ts +15 -0
  163. package/lib/esm/components/whatsapp-cta-url-button.js +33 -0
  164. package/lib/esm/components/whatsapp-cta-url-button.js.map +1 -0
  165. package/lib/esm/components/whatsapp-media-carousel.d.ts +46 -0
  166. package/lib/esm/components/whatsapp-media-carousel.js +36 -0
  167. package/lib/esm/components/whatsapp-media-carousel.js.map +1 -0
  168. package/lib/esm/components/whatsapp-product-carousel.d.ts +32 -0
  169. package/lib/esm/components/whatsapp-product-carousel.js +30 -0
  170. package/lib/esm/components/whatsapp-product-carousel.js.map +1 -0
  171. package/lib/esm/components/whatsapp-product-list.d.ts +15 -0
  172. package/lib/esm/components/whatsapp-product-list.js +22 -0
  173. package/lib/esm/components/whatsapp-product-list.js.map +1 -0
  174. package/lib/esm/components/whatsapp-product.d.ts +7 -0
  175. package/lib/esm/components/whatsapp-product.js +21 -0
  176. package/lib/esm/components/whatsapp-product.js.map +1 -0
  177. package/lib/esm/components/whatsapp-template.d.ts +1 -0
  178. package/lib/esm/components/whatsapp-template.js +20 -0
  179. package/lib/esm/components/whatsapp-template.js.map +1 -0
  180. package/lib/esm/constants.d.ts +165 -0
  181. package/lib/esm/constants.js +187 -0
  182. package/lib/esm/constants.js.map +1 -0
  183. package/lib/esm/contexts.d.ts +18 -0
  184. package/lib/esm/contexts.js +18 -0
  185. package/lib/esm/contexts.js.map +1 -0
  186. package/lib/esm/dev-app.d.ts +38 -0
  187. package/lib/esm/dev-app.js +81 -0
  188. package/lib/esm/dev-app.js.map +1 -0
  189. package/lib/esm/index-types.d.ts +178 -0
  190. package/lib/esm/index-types.js +12 -0
  191. package/lib/esm/index-types.js.map +1 -0
  192. package/lib/esm/index.d.ts +11 -0
  193. package/lib/esm/index.js +12 -0
  194. package/lib/esm/index.js.map +1 -0
  195. package/lib/esm/message-utils.d.ts +19 -0
  196. package/lib/esm/message-utils.js +41 -0
  197. package/lib/esm/message-utils.js.map +1 -0
  198. package/lib/esm/msg-to-botonic.d.ts +18 -0
  199. package/lib/esm/msg-to-botonic.js +132 -0
  200. package/lib/esm/msg-to-botonic.js.map +1 -0
  201. package/lib/esm/node-app.d.ts +7 -0
  202. package/lib/esm/node-app.js +19 -0
  203. package/lib/esm/node-app.js.map +1 -0
  204. package/lib/esm/react-bot.d.ts +8 -0
  205. package/lib/esm/react-bot.js +32 -0
  206. package/lib/esm/react-bot.js.map +1 -0
  207. package/lib/esm/shared/styles.d.ts +2 -0
  208. package/lib/esm/shared/styles.js +28 -0
  209. package/lib/esm/shared/styles.js.map +1 -0
  210. package/lib/esm/util/dom.d.ts +4 -0
  211. package/lib/esm/util/dom.js +24 -0
  212. package/lib/esm/util/dom.js.map +1 -0
  213. package/lib/esm/util/environment.d.ts +6 -0
  214. package/lib/esm/util/environment.js +61 -0
  215. package/lib/esm/util/environment.js.map +1 -0
  216. package/lib/esm/util/error-boundary.d.ts +7 -0
  217. package/lib/esm/util/error-boundary.js +28 -0
  218. package/lib/esm/util/error-boundary.js.map +1 -0
  219. package/lib/esm/util/functional.d.ts +3 -0
  220. package/lib/esm/util/functional.js +26 -0
  221. package/lib/esm/util/functional.js.map +1 -0
  222. package/lib/esm/util/index.d.ts +9 -0
  223. package/lib/esm/util/index.js +10 -0
  224. package/lib/esm/util/index.js.map +1 -0
  225. package/lib/esm/util/logs.d.ts +2 -0
  226. package/lib/esm/util/logs.js +15 -0
  227. package/lib/esm/util/logs.js.map +1 -0
  228. package/lib/esm/util/objects.d.ts +3 -0
  229. package/lib/esm/util/objects.js +38 -0
  230. package/lib/esm/util/objects.js.map +1 -0
  231. package/lib/esm/util/react.d.ts +12 -0
  232. package/lib/esm/util/react.js +34 -0
  233. package/lib/esm/util/react.js.map +1 -0
  234. package/lib/esm/util/regexs.d.ts +2 -0
  235. package/lib/esm/util/regexs.js +18 -0
  236. package/lib/esm/util/regexs.js.map +1 -0
  237. package/lib/esm/util/strings.d.ts +1 -0
  238. package/lib/esm/util/strings.js +7 -0
  239. package/lib/esm/util/strings.js.map +1 -0
  240. package/lib/esm/util/webchat.d.ts +22 -0
  241. package/lib/esm/util/webchat.js +55 -0
  242. package/lib/esm/util/webchat.js.map +1 -0
  243. package/lib/esm/util/webviews.d.ts +1 -0
  244. package/lib/esm/util/webviews.js +6 -0
  245. package/lib/esm/util/webviews.js.map +1 -0
  246. package/lib/esm/webchat/chat-area/index.d.ts +1 -0
  247. package/lib/esm/webchat/chat-area/index.js +18 -0
  248. package/lib/esm/webchat/chat-area/index.js.map +1 -0
  249. package/lib/esm/webchat/chat-area/styles.d.ts +3 -0
  250. package/lib/esm/webchat/chat-area/styles.js +9 -0
  251. package/lib/esm/webchat/chat-area/styles.js.map +1 -0
  252. package/lib/esm/webchat/components/common.d.ts +1 -0
  253. package/lib/esm/webchat/components/common.js +9 -0
  254. package/lib/esm/webchat/components/common.js.map +1 -0
  255. package/lib/esm/webchat/components/conditional-animation.d.ts +1 -0
  256. package/lib/esm/webchat/components/conditional-animation.js +12 -0
  257. package/lib/esm/webchat/components/conditional-animation.js.map +1 -0
  258. package/lib/esm/webchat/components/opened-persistent-menu.d.ts +6 -0
  259. package/lib/esm/webchat/components/opened-persistent-menu.js +30 -0
  260. package/lib/esm/webchat/components/opened-persistent-menu.js.map +1 -0
  261. package/lib/esm/webchat/constants.d.ts +8 -0
  262. package/lib/esm/webchat/constants.js +10 -0
  263. package/lib/esm/webchat/constants.js.map +1 -0
  264. package/lib/esm/webchat/context/actions.d.ts +29 -0
  265. package/lib/esm/webchat/context/actions.js +32 -0
  266. package/lib/esm/webchat/context/actions.js.map +1 -0
  267. package/lib/esm/webchat/context/index.d.ts +5 -0
  268. package/lib/esm/webchat/context/index.js +81 -0
  269. package/lib/esm/webchat/context/index.js.map +1 -0
  270. package/lib/esm/webchat/context/messages-reducer.d.ts +6 -0
  271. package/lib/esm/webchat/context/messages-reducer.js +85 -0
  272. package/lib/esm/webchat/context/messages-reducer.js.map +1 -0
  273. package/lib/esm/webchat/context/types.d.ts +76 -0
  274. package/lib/esm/webchat/context/types.js +2 -0
  275. package/lib/esm/webchat/context/types.js.map +1 -0
  276. package/lib/esm/webchat/context/use-webchat.d.ts +47 -0
  277. package/lib/esm/webchat/context/use-webchat.js +195 -0
  278. package/lib/esm/webchat/context/use-webchat.js.map +1 -0
  279. package/lib/esm/webchat/context/webchat-reducer.d.ts +6 -0
  280. package/lib/esm/webchat/context/webchat-reducer.js +48 -0
  281. package/lib/esm/webchat/context/webchat-reducer.js.map +1 -0
  282. package/lib/esm/webchat/cover-component/index.d.ts +6 -0
  283. package/lib/esm/webchat/cover-component/index.js +17 -0
  284. package/lib/esm/webchat/cover-component/index.js.map +1 -0
  285. package/lib/esm/webchat/devices/index.d.ts +11 -0
  286. package/lib/esm/webchat/devices/index.js +18 -0
  287. package/lib/esm/webchat/devices/index.js.map +1 -0
  288. package/lib/esm/webchat/header/default-header.d.ts +1 -0
  289. package/lib/esm/webchat/header/default-header.js +21 -0
  290. package/lib/esm/webchat/header/default-header.js.map +1 -0
  291. package/lib/esm/webchat/header/index.d.ts +2 -0
  292. package/lib/esm/webchat/header/index.js +20 -0
  293. package/lib/esm/webchat/header/index.js.map +1 -0
  294. package/lib/esm/webchat/header/styles.d.ts +7 -0
  295. package/lib/esm/webchat/header/styles.js +55 -0
  296. package/lib/esm/webchat/header/styles.js.map +1 -0
  297. package/lib/esm/webchat/hooks/index.d.ts +10 -0
  298. package/lib/esm/webchat/hooks/index.js +11 -0
  299. package/lib/esm/webchat/hooks/index.js.map +1 -0
  300. package/lib/esm/webchat/hooks/use-component-visible.d.ts +8 -0
  301. package/lib/esm/webchat/hooks/use-component-visible.js +20 -0
  302. package/lib/esm/webchat/hooks/use-component-visible.js.map +1 -0
  303. package/lib/esm/webchat/hooks/use-component-will-mount.d.ts +1 -0
  304. package/lib/esm/webchat/hooks/use-component-will-mount.js +5 -0
  305. package/lib/esm/webchat/hooks/use-component-will-mount.js.map +1 -0
  306. package/lib/esm/webchat/hooks/use-device-adapter.d.ts +3 -0
  307. package/lib/esm/webchat/hooks/use-device-adapter.js +42 -0
  308. package/lib/esm/webchat/hooks/use-device-adapter.js.map +1 -0
  309. package/lib/esm/webchat/hooks/use-previous.d.ts +1 -0
  310. package/lib/esm/webchat/hooks/use-previous.js +9 -0
  311. package/lib/esm/webchat/hooks/use-previous.js.map +1 -0
  312. package/lib/esm/webchat/hooks/use-scroll-to-bottom.d.ts +9 -0
  313. package/lib/esm/webchat/hooks/use-scroll-to-bottom.js +19 -0
  314. package/lib/esm/webchat/hooks/use-scroll-to-bottom.js.map +1 -0
  315. package/lib/esm/webchat/hooks/use-scrollbar-controller.d.ts +6 -0
  316. package/lib/esm/webchat/hooks/use-scrollbar-controller.js +136 -0
  317. package/lib/esm/webchat/hooks/use-scrollbar-controller.js.map +1 -0
  318. package/lib/esm/webchat/hooks/use-typing.d.ts +10 -0
  319. package/lib/esm/webchat/hooks/use-typing.js +28 -0
  320. package/lib/esm/webchat/hooks/use-typing.js.map +1 -0
  321. package/lib/esm/webchat/hooks/use-virtual-keyboard-detection.d.ts +3 -0
  322. package/lib/esm/webchat/hooks/use-virtual-keyboard-detection.js +24 -0
  323. package/lib/esm/webchat/hooks/use-virtual-keyboard-detection.js.map +1 -0
  324. package/lib/esm/webchat/hooks/use-webchat-dimensions.d.ts +4 -0
  325. package/lib/esm/webchat/hooks/use-webchat-dimensions.js +36 -0
  326. package/lib/esm/webchat/hooks/use-webchat-dimensions.js.map +1 -0
  327. package/lib/esm/webchat/hooks/use-webchat-resizer.d.ts +4 -0
  328. package/lib/esm/webchat/hooks/use-webchat-resizer.js +30 -0
  329. package/lib/esm/webchat/hooks/use-webchat-resizer.js.map +1 -0
  330. package/lib/esm/webchat/index-types.d.ts +18 -0
  331. package/lib/esm/webchat/index-types.js +2 -0
  332. package/lib/esm/webchat/index-types.js.map +1 -0
  333. package/lib/esm/webchat/index.d.ts +5 -0
  334. package/lib/esm/webchat/index.js +11 -0
  335. package/lib/esm/webchat/index.js.map +1 -0
  336. package/lib/esm/webchat/input-panel/attachment.d.ts +7 -0
  337. package/lib/esm/webchat/input-panel/attachment.js +26 -0
  338. package/lib/esm/webchat/input-panel/attachment.js.map +1 -0
  339. package/lib/esm/webchat/input-panel/emoji-picker.d.ts +6 -0
  340. package/lib/esm/webchat/input-panel/emoji-picker.js +23 -0
  341. package/lib/esm/webchat/input-panel/emoji-picker.js.map +1 -0
  342. package/lib/esm/webchat/input-panel/index.d.ts +12 -0
  343. package/lib/esm/webchat/input-panel/index.js +55 -0
  344. package/lib/esm/webchat/input-panel/index.js.map +1 -0
  345. package/lib/esm/webchat/input-panel/opened-emoji-picker.d.ts +6 -0
  346. package/lib/esm/webchat/input-panel/opened-emoji-picker.js +10 -0
  347. package/lib/esm/webchat/input-panel/opened-emoji-picker.js.map +1 -0
  348. package/lib/esm/webchat/input-panel/persistent-menu.d.ts +6 -0
  349. package/lib/esm/webchat/input-panel/persistent-menu.js +14 -0
  350. package/lib/esm/webchat/input-panel/persistent-menu.js.map +1 -0
  351. package/lib/esm/webchat/input-panel/send-button.d.ts +5 -0
  352. package/lib/esm/webchat/input-panel/send-button.js +14 -0
  353. package/lib/esm/webchat/input-panel/send-button.js.map +1 -0
  354. package/lib/esm/webchat/input-panel/styles.d.ts +3 -0
  355. package/lib/esm/webchat/input-panel/styles.js +27 -0
  356. package/lib/esm/webchat/input-panel/styles.js.map +1 -0
  357. package/lib/esm/webchat/input-panel/textarea.d.ts +11 -0
  358. package/lib/esm/webchat/input-panel/textarea.js +58 -0
  359. package/lib/esm/webchat/input-panel/textarea.js.map +1 -0
  360. package/lib/esm/webchat/message-list/index.d.ts +1 -0
  361. package/lib/esm/webchat/message-list/index.js +107 -0
  362. package/lib/esm/webchat/message-list/index.js.map +1 -0
  363. package/lib/esm/webchat/message-list/intro-message.d.ts +1 -0
  364. package/lib/esm/webchat/message-list/intro-message.js +18 -0
  365. package/lib/esm/webchat/message-list/intro-message.js.map +1 -0
  366. package/lib/esm/webchat/message-list/scroll-button.d.ts +6 -0
  367. package/lib/esm/webchat/message-list/scroll-button.js +12 -0
  368. package/lib/esm/webchat/message-list/scroll-button.js.map +1 -0
  369. package/lib/esm/webchat/message-list/styles.d.ts +5 -0
  370. package/lib/esm/webchat/message-list/styles.js +56 -0
  371. package/lib/esm/webchat/message-list/styles.js.map +1 -0
  372. package/lib/esm/webchat/message-list/unread-messages-banner.d.ts +6 -0
  373. package/lib/esm/webchat/message-list/unread-messages-banner.js +13 -0
  374. package/lib/esm/webchat/message-list/unread-messages-banner.js.map +1 -0
  375. package/lib/esm/webchat/message-list/use-debounce.d.ts +1 -0
  376. package/lib/esm/webchat/message-list/use-debounce.js +14 -0
  377. package/lib/esm/webchat/message-list/use-debounce.js.map +1 -0
  378. package/lib/esm/webchat/message-list/use-notifications.d.ts +7 -0
  379. package/lib/esm/webchat/message-list/use-notifications.js +20 -0
  380. package/lib/esm/webchat/message-list/use-notifications.js.map +1 -0
  381. package/lib/esm/webchat/replies/index.d.ts +1 -0
  382. package/lib/esm/webchat/replies/index.js +28 -0
  383. package/lib/esm/webchat/replies/index.js.map +1 -0
  384. package/lib/esm/webchat/replies/styles.d.ts +8 -0
  385. package/lib/esm/webchat/replies/styles.js +21 -0
  386. package/lib/esm/webchat/replies/styles.js.map +1 -0
  387. package/lib/esm/webchat/session-view.d.ts +1 -0
  388. package/lib/esm/webchat/session-view.js +96 -0
  389. package/lib/esm/webchat/session-view.js.map +1 -0
  390. package/lib/esm/webchat/styles.d.ts +9 -0
  391. package/lib/esm/webchat/styles.js +50 -0
  392. package/lib/esm/webchat/styles.js.map +1 -0
  393. package/lib/esm/webchat/theme/types.d.ts +167 -0
  394. package/lib/esm/webchat/theme/types.js +2 -0
  395. package/lib/esm/webchat/theme/types.js.map +1 -0
  396. package/lib/esm/webchat/tracking.d.ts +7 -0
  397. package/lib/esm/webchat/tracking.js +10 -0
  398. package/lib/esm/webchat/tracking.js.map +1 -0
  399. package/lib/esm/webchat/trigger-button/index.d.ts +2 -0
  400. package/lib/esm/webchat/trigger-button/index.js +28 -0
  401. package/lib/esm/webchat/trigger-button/index.js.map +1 -0
  402. package/lib/esm/webchat/trigger-button/styles.d.ts +3 -0
  403. package/lib/esm/webchat/trigger-button/styles.js +36 -0
  404. package/lib/esm/webchat/trigger-button/styles.js.map +1 -0
  405. package/lib/esm/webchat/typing-indicator/index.d.ts +3 -0
  406. package/lib/esm/webchat/typing-indicator/index.js +8 -0
  407. package/lib/esm/webchat/typing-indicator/index.js.map +1 -0
  408. package/lib/esm/webchat/typing-indicator/styles.d.ts +7 -0
  409. package/lib/esm/webchat/typing-indicator/styles.js +46 -0
  410. package/lib/esm/webchat/typing-indicator/styles.js.map +1 -0
  411. package/lib/esm/webchat/use-storage-state-hook.d.ts +1 -0
  412. package/lib/esm/webchat/use-storage-state-hook.js +38 -0
  413. package/lib/esm/webchat/use-storage-state-hook.js.map +1 -0
  414. package/lib/esm/webchat/utils.d.ts +2 -0
  415. package/lib/esm/webchat/utils.js +8 -0
  416. package/lib/esm/webchat/utils.js.map +1 -0
  417. package/lib/esm/webchat/webchat-dev.d.ts +7 -0
  418. package/lib/esm/webchat/webchat-dev.js +56 -0
  419. package/lib/esm/webchat/webchat-dev.js.map +1 -0
  420. package/lib/esm/webchat/webchat.d.ts +4 -0
  421. package/lib/esm/webchat/webchat.js +517 -0
  422. package/lib/esm/webchat/webchat.js.map +1 -0
  423. package/lib/esm/webchat/webview/header.d.ts +1 -0
  424. package/lib/esm/webchat/webview/header.js +12 -0
  425. package/lib/esm/webchat/webview/header.js.map +1 -0
  426. package/lib/esm/webchat/webview/index.d.ts +1 -0
  427. package/lib/esm/webchat/webview/index.js +45 -0
  428. package/lib/esm/webchat/webview/index.js.map +1 -0
  429. package/lib/esm/webchat/webview/styles.d.ts +7 -0
  430. package/lib/esm/webchat/webview/styles.js +42 -0
  431. package/lib/esm/webchat/webview/styles.js.map +1 -0
  432. package/lib/esm/webchat-app.d.ts +78 -0
  433. package/lib/esm/webchat-app.js +363 -0
  434. package/lib/esm/webchat-app.js.map +1 -0
  435. package/lib/esm/webview-app.d.ts +7 -0
  436. package/lib/esm/webview-app.js +105 -0
  437. package/lib/esm/webview-app.js.map +1 -0
  438. package/package.json +2 -2
  439. package/src/webchat/context/index.tsx +4 -1
  440. package/src/webchat/context/types.ts +3 -1
  441. package/src/webchat/context/use-webchat.ts +3 -3
  442. package/src/webchat/hooks/use-scrollbar-controller.ts +20 -15
  443. package/src/webchat/hooks/use-webchat-dimensions.ts +3 -3
  444. package/src/webchat/hooks/use-webchat-resizer.ts +5 -5
  445. package/src/webchat/webchat.tsx +10 -29
  446. package/src/webchat/webview/header.tsx +22 -0
  447. package/src/webchat/webview/index.tsx +80 -0
  448. package/src/webchat/webview/styles.ts +48 -0
  449. package/lib/cjs/webchat/webview.d.ts +0 -2
  450. package/lib/cjs/webchat/webview.js +0 -76
  451. package/lib/cjs/webchat/webview.js.map +0 -1
  452. package/src/webchat/webview.jsx +0 -106
@@ -0,0 +1,69 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { INPUT } from '@botonic/core';
3
+ import { useContext } from 'react';
4
+ import { renderComponent } from '../util/react';
5
+ import { stringifyWithRegexs } from '../util/regexs';
6
+ import { WebchatContext } from '../webchat/context';
7
+ export const WebchatSettings = ({ theme, blockInputs, persistentMenu, enableEmojiPicker, enableAttachments, enableUserInput, enableAnimations, user, }) => {
8
+ const renderBrowser = () => {
9
+ // eslint-disable-next-line react-hooks/rules-of-hooks
10
+ const { updateWebchatDevSettings } = useContext(WebchatContext);
11
+ updateWebchatDevSettings({
12
+ theme,
13
+ blockInputs,
14
+ persistentMenu,
15
+ enableEmojiPicker,
16
+ enableAttachments,
17
+ enableUserInput,
18
+ enableAnimations,
19
+ });
20
+ return null;
21
+ };
22
+ const renderNode = () => {
23
+ const updatedTheme = normalizeWebchatSettings({
24
+ theme,
25
+ blockInputs,
26
+ persistentMenu,
27
+ enableEmojiPicker,
28
+ enableAttachments,
29
+ enableUserInput,
30
+ enableAnimations,
31
+ });
32
+ return (
33
+ //@ts-ignore
34
+ _jsx("message", { type: INPUT.WEBCHAT_SETTINGS, settings: stringifyWithRegexs({ theme: updatedTheme, user }) }));
35
+ };
36
+ return renderComponent({ renderBrowser, renderNode });
37
+ };
38
+ export const normalizeWebchatSettings = (settings) => {
39
+ let { theme, blockInputs, persistentMenu, enableEmojiPicker, enableAttachments, enableUserInput, enableAnimations, } = settings;
40
+ if (!theme)
41
+ theme = {};
42
+ if (!theme.userInput)
43
+ theme.userInput = {};
44
+ if (persistentMenu !== undefined) {
45
+ theme.userInput.persistentMenu = persistentMenu;
46
+ }
47
+ if (enableEmojiPicker !== undefined) {
48
+ if (!theme.userInput.emojiPicker)
49
+ theme.userInput.emojiPicker = {};
50
+ theme.userInput.emojiPicker.enable = enableEmojiPicker;
51
+ }
52
+ if (enableAttachments !== undefined) {
53
+ if (!theme.userInput.attachments)
54
+ theme.userInput.attachments = {};
55
+ theme.userInput.attachments.enable = enableAttachments;
56
+ }
57
+ if (enableUserInput !== undefined) {
58
+ theme.userInput.enable = enableUserInput;
59
+ }
60
+ if (blockInputs !== undefined)
61
+ theme.userInput.blockInputs = blockInputs;
62
+ if (!theme.animations)
63
+ theme.animations = {};
64
+ if (enableAnimations !== undefined) {
65
+ theme.animations.enable = enableAnimations;
66
+ }
67
+ return theme;
68
+ };
69
+ //# sourceMappingURL=webchat-settings.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"webchat-settings.js","sourceRoot":"","sources":["../../../src/components/webchat-settings.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AACrC,OAAc,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AAEzC,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAA;AAC/C,OAAO,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAA;AACpD,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAA;AAenD,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,EAC9B,KAAK,EACL,WAAW,EACX,cAAc,EACd,iBAAiB,EACjB,iBAAiB,EACjB,eAAe,EACf,gBAAgB,EAChB,IAAI,GACiB,EAAE,EAAE;IACzB,MAAM,aAAa,GAAG,GAAG,EAAE;QACzB,sDAAsD;QACtD,MAAM,EAAE,wBAAwB,EAAE,GAAG,UAAU,CAAC,cAAc,CAAC,CAAA;QAC/D,wBAAwB,CAAC;YACvB,KAAK;YACL,WAAW;YACX,cAAc;YACd,iBAAiB;YACjB,iBAAiB;YACjB,eAAe;YACf,gBAAgB;SACjB,CAAC,CAAA;QACF,OAAO,IAAI,CAAA;IACb,CAAC,CAAA;IACD,MAAM,UAAU,GAAG,GAAG,EAAE;QACtB,MAAM,YAAY,GAAG,wBAAwB,CAAC;YAC5C,KAAK;YACL,WAAW;YACX,cAAc;YACd,iBAAiB;YACjB,iBAAiB;YACjB,eAAe;YACf,gBAAgB;SACjB,CAAC,CAAA;QACF,OAAO;QACL,YAAY;QACZ,kBACE,IAAI,EAAE,KAAK,CAAC,gBAAgB,EAC5B,QAAQ,EAAE,mBAAmB,CAAC,EAAE,KAAK,EAAE,YAAY,EAAE,IAAI,EAAE,CAAC,GAC5D,CACH,CAAA;IACH,CAAC,CAAA;IACD,OAAO,eAAe,CAAC,EAAE,aAAa,EAAE,UAAU,EAAE,CAAC,CAAA;AACvD,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,wBAAwB,GAAG,CAAC,QAA8B,EAAE,EAAE;IACzE,IAAI,EACF,KAAK,EACL,WAAW,EACX,cAAc,EACd,iBAAiB,EACjB,iBAAiB,EACjB,eAAe,EACf,gBAAgB,GACjB,GAAG,QAAQ,CAAA;IACZ,IAAI,CAAC,KAAK;QAAE,KAAK,GAAG,EAAE,CAAA;IACtB,IAAI,CAAC,KAAK,CAAC,SAAS;QAAE,KAAK,CAAC,SAAS,GAAG,EAAE,CAAA;IAC1C,IAAI,cAAc,KAAK,SAAS,EAAE;QAChC,KAAK,CAAC,SAAS,CAAC,cAAc,GAAG,cAAc,CAAA;KAChD;IACD,IAAI,iBAAiB,KAAK,SAAS,EAAE;QACnC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,WAAW;YAAE,KAAK,CAAC,SAAS,CAAC,WAAW,GAAG,EAAE,CAAA;QAClE,KAAK,CAAC,SAAS,CAAC,WAAW,CAAC,MAAM,GAAG,iBAAiB,CAAA;KACvD;IACD,IAAI,iBAAiB,KAAK,SAAS,EAAE;QACnC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,WAAW;YAAE,KAAK,CAAC,SAAS,CAAC,WAAW,GAAG,EAAE,CAAA;QAClE,KAAK,CAAC,SAAS,CAAC,WAAW,CAAC,MAAM,GAAG,iBAAiB,CAAA;KACvD;IACD,IAAI,eAAe,KAAK,SAAS,EAAE;QACjC,KAAK,CAAC,SAAS,CAAC,MAAM,GAAG,eAAe,CAAA;KACzC;IACD,IAAI,WAAW,KAAK,SAAS;QAAE,KAAK,CAAC,SAAS,CAAC,WAAW,GAAG,WAAW,CAAA;IAExE,IAAI,CAAC,KAAK,CAAC,UAAU;QAAE,KAAK,CAAC,UAAU,GAAG,EAAE,CAAA;IAC5C,IAAI,gBAAgB,KAAK,SAAS,EAAE;QAClC,KAAK,CAAC,UAAU,CAAC,MAAM,GAAG,gBAAgB,CAAA;KAC3C;IACD,OAAO,KAAK,CAAA;AACd,CAAC,CAAA"}
@@ -0,0 +1,20 @@
1
+ export declare const WHATSAPP_MAX_BUTTON_LIST_CHARS = 24;
2
+ export declare const WHATSAPP_MAX_BUTTON_LIST_DESCRIPTION_CHARS = 72;
3
+ export declare const WHATSAPP_MAX_BUTTON_LIST_ID_CHARS = 200;
4
+ export interface WhatsappButtonListSectionProps {
5
+ title?: string;
6
+ rows: WhatsappButtonListRowProps[];
7
+ }
8
+ export interface WhatsappButtonListRowProps {
9
+ id: string;
10
+ title: string;
11
+ description?: string;
12
+ }
13
+ export interface WhatsappButtonListProps {
14
+ header?: string;
15
+ body: string;
16
+ footer?: string;
17
+ button: string;
18
+ sections: WhatsappButtonListSectionProps[];
19
+ }
20
+ export declare const WhatsappButtonList: (props: WhatsappButtonListProps) => any;
@@ -0,0 +1,47 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { INPUT } from '@botonic/core';
3
+ import { truncateText } from '../util';
4
+ import { renderComponent } from '../util/react';
5
+ import { Message } from './message';
6
+ import { WHATSAPP_MAX_BUTTON_CHARS } from './multichannel/whatsapp/constants';
7
+ import { convertToMarkdownMeta } from './multichannel/whatsapp/markdown-meta';
8
+ // TODO: Add validation in component
9
+ export const WHATSAPP_MAX_BUTTON_LIST_CHARS = 24;
10
+ export const WHATSAPP_MAX_BUTTON_LIST_DESCRIPTION_CHARS = 72;
11
+ export const WHATSAPP_MAX_BUTTON_LIST_ID_CHARS = 200;
12
+ const serialize = _whatsappButtonListProps => {
13
+ // TODO: Implement to have data persistance in localStorage, not needed for this WhatsApp development
14
+ return {};
15
+ };
16
+ export const WhatsappButtonList = (props) => {
17
+ const trucateSectionsContents = (sections) => {
18
+ const trucateRowContents = (row) => {
19
+ const title = truncateText(row.title, WHATSAPP_MAX_BUTTON_LIST_CHARS);
20
+ const description = row.description
21
+ ? truncateText(row.description, WHATSAPP_MAX_BUTTON_LIST_DESCRIPTION_CHARS)
22
+ : undefined;
23
+ if (row.id.length > WHATSAPP_MAX_BUTTON_LIST_ID_CHARS) {
24
+ console.error(`Button id "${row.id}" exceeds the maximum length of ${WHATSAPP_MAX_BUTTON_LIST_ID_CHARS} characters`);
25
+ }
26
+ return Object.assign(Object.assign({}, row), { title, description });
27
+ };
28
+ return sections.map(section => ({
29
+ title: section.title
30
+ ? truncateText(section.title, WHATSAPP_MAX_BUTTON_LIST_CHARS)
31
+ : undefined,
32
+ rows: section.rows.map(trucateRowContents),
33
+ }));
34
+ };
35
+ const renderBrowser = () => {
36
+ // Return a dummy message for browser
37
+ const message = `${JSON.stringify(props)}`;
38
+ return (_jsx(Message, Object.assign({ json: serialize(message) }, props, { type: INPUT.WHATSAPP_BUTTON_LIST }, { children: message })));
39
+ };
40
+ const renderNode = () => {
41
+ return (
42
+ // @ts-ignore Property 'message' does not exist on type 'JSX.IntrinsicElements'.
43
+ _jsx("message", Object.assign({}, props, { body: convertToMarkdownMeta(props.body), button: truncateText(props.button, WHATSAPP_MAX_BUTTON_CHARS), sections: JSON.stringify(trucateSectionsContents(props.sections)), type: INPUT.WHATSAPP_BUTTON_LIST })));
44
+ };
45
+ return renderComponent({ renderBrowser, renderNode });
46
+ };
47
+ //# sourceMappingURL=whatsapp-button-list.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"whatsapp-button-list.js","sourceRoot":"","sources":["../../../src/components/whatsapp-button-list.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AAGrC,OAAO,EAAE,YAAY,EAAE,MAAM,SAAS,CAAA;AACtC,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAA;AAC/C,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AACnC,OAAO,EAAE,yBAAyB,EAAE,MAAM,mCAAmC,CAAA;AAC7E,OAAO,EAAE,qBAAqB,EAAE,MAAM,uCAAuC,CAAA;AAE7E,oCAAoC;AAEpC,MAAM,CAAC,MAAM,8BAA8B,GAAG,EAAE,CAAA;AAChD,MAAM,CAAC,MAAM,0CAA0C,GAAG,EAAE,CAAA;AAC5D,MAAM,CAAC,MAAM,iCAAiC,GAAG,GAAG,CAAA;AAoBpD,MAAM,SAAS,GAAG,wBAAwB,CAAC,EAAE;IAC3C,qGAAqG;IACrG,OAAO,EAAE,CAAA;AACX,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,KAA8B,EAAE,EAAE;IACnE,MAAM,uBAAuB,GAAG,CAC9B,QAA0C,EACR,EAAE;QACpC,MAAM,kBAAkB,GAAG,CACzB,GAA+B,EACH,EAAE;YAC9B,MAAM,KAAK,GAAG,YAAY,CAAC,GAAG,CAAC,KAAK,EAAE,8BAA8B,CAAC,CAAA;YACrE,MAAM,WAAW,GAAG,GAAG,CAAC,WAAW;gBACjC,CAAC,CAAC,YAAY,CACV,GAAG,CAAC,WAAW,EACf,0CAA0C,CAC3C;gBACH,CAAC,CAAC,SAAS,CAAA;YACb,IAAI,GAAG,CAAC,EAAE,CAAC,MAAM,GAAG,iCAAiC,EAAE;gBACrD,OAAO,CAAC,KAAK,CACX,cAAc,GAAG,CAAC,EAAE,mCAAmC,iCAAiC,aAAa,CACtG,CAAA;aACF;YACD,uCAAY,GAAG,KAAE,KAAK,EAAE,WAAW,IAAE;QACvC,CAAC,CAAA;QAED,OAAO,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;YAC9B,KAAK,EAAE,OAAO,CAAC,KAAK;gBAClB,CAAC,CAAC,YAAY,CAAC,OAAO,CAAC,KAAK,EAAE,8BAA8B,CAAC;gBAC7D,CAAC,CAAC,SAAS;YACb,IAAI,EAAE,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,kBAAkB,CAAC;SAC3C,CAAC,CAAC,CAAA;IACL,CAAC,CAAA;IAED,MAAM,aAAa,GAAG,GAAG,EAAE;QACzB,qCAAqC;QACrC,MAAM,OAAO,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,CAAA;QAC1C,OAAO,CACL,KAAC,OAAO,kBACN,IAAI,EAAE,SAAS,CAAC,OAAO,CAAC,IACpB,KAAK,IACT,IAAI,EAAE,KAAK,CAAC,oBAAoB,gBAE/B,OAAO,IACA,CACX,CAAA;IACH,CAAC,CAAA;IAED,MAAM,UAAU,GAAG,GAAG,EAAE;QACtB,OAAO;QACL,gFAAgF;QAChF,kCACM,KAAK,IACT,IAAI,EAAE,qBAAqB,CAAC,KAAK,CAAC,IAAI,CAAC,EACvC,MAAM,EAAE,YAAY,CAAC,KAAK,CAAC,MAAM,EAAE,yBAAyB,CAAC,EAC7D,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,uBAAuB,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,EACjE,IAAI,EAAE,KAAK,CAAC,oBAAoB,IAChC,CACH,CAAA;IACH,CAAC,CAAA;IAED,OAAO,eAAe,CAAC,EAAE,aAAa,EAAE,UAAU,EAAE,CAAC,CAAA;AACvD,CAAC,CAAA"}
@@ -0,0 +1,6 @@
1
+ export interface WhatsappCatalogProps {
2
+ body: string;
3
+ footer?: string;
4
+ thumbnailProductId?: string;
5
+ }
6
+ export declare const WhatsappCatalog: (props: WhatsappCatalogProps) => any;
@@ -0,0 +1,21 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { INPUT } from '@botonic/core';
3
+ import { renderComponent } from '../util/react';
4
+ import { Message } from './message';
5
+ const serialize = (message) => {
6
+ return { text: message };
7
+ };
8
+ export const WhatsappCatalog = (props) => {
9
+ const renderBrowser = () => {
10
+ // Return a dummy message for browser
11
+ const message = `WhatsApp Catalog would be sent to the user.`;
12
+ return (_jsx(Message, Object.assign({ json: serialize(message) }, props, { type: INPUT.TEXT }, { children: message })));
13
+ };
14
+ const renderNode = () => {
15
+ return (
16
+ // @ts-ignore Property 'message' does not exist on type 'JSX.IntrinsicElements'.
17
+ _jsx("message", Object.assign({}, props, { body: props.body, footer: props.footer, thumbnailProductId: props.thumbnailProductId, type: INPUT.WHATSAPP_CATALOG })));
18
+ };
19
+ return renderComponent({ renderBrowser, renderNode });
20
+ };
21
+ //# sourceMappingURL=whatsapp-catalog.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"whatsapp-catalog.js","sourceRoot":"","sources":["../../../src/components/whatsapp-catalog.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AAGrC,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAA;AAC/C,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AAQnC,MAAM,SAAS,GAAG,CAAC,OAAe,EAAE,EAAE;IACpC,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,CAAA;AAC1B,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,KAA2B,EAAE,EAAE;IAC7D,MAAM,aAAa,GAAG,GAAG,EAAE;QACzB,qCAAqC;QACrC,MAAM,OAAO,GAAG,6CAA6C,CAAA;QAC7D,OAAO,CACL,KAAC,OAAO,kBAAC,IAAI,EAAE,SAAS,CAAC,OAAO,CAAC,IAAM,KAAK,IAAE,IAAI,EAAE,KAAK,CAAC,IAAI,gBAC3D,OAAO,IACA,CACX,CAAA;IACH,CAAC,CAAA;IAED,MAAM,UAAU,GAAG,GAAG,EAAE;QACtB,OAAO;QACL,gFAAgF;QAChF,kCACM,KAAK,IACT,IAAI,EAAE,KAAK,CAAC,IAAI,EAChB,MAAM,EAAE,KAAK,CAAC,MAAM,EACpB,kBAAkB,EAAE,KAAK,CAAC,kBAAkB,EAC5C,IAAI,EAAE,KAAK,CAAC,gBAAgB,IAC5B,CACH,CAAA;IACH,CAAC,CAAA;IAED,OAAO,eAAe,CAAC,EAAE,aAAa,EAAE,UAAU,EAAE,CAAC,CAAA;AACvD,CAAC,CAAA"}
@@ -0,0 +1,15 @@
1
+ export interface WhatsappCTAUrlButtonCommonProps {
2
+ header?: string;
3
+ body: string;
4
+ footer?: string;
5
+ displayText: string;
6
+ }
7
+ export interface WhatsappCTAUrlButtonUrlProps extends WhatsappCTAUrlButtonCommonProps {
8
+ url: string;
9
+ }
10
+ export interface WhatsappCTAUrlButtonWebviewProps extends WhatsappCTAUrlButtonCommonProps {
11
+ webview: any;
12
+ params?: any;
13
+ }
14
+ export type WhatsappCTAUrlButtonProps = WhatsappCTAUrlButtonUrlProps | WhatsappCTAUrlButtonWebviewProps;
15
+ export declare const WhatsappCTAUrlButton: (props: WhatsappCTAUrlButtonProps) => any;
@@ -0,0 +1,33 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { INPUT } from '@botonic/core';
3
+ import { truncateText } from '../util';
4
+ import { renderComponent } from '../util/react';
5
+ import { generateWebviewUrlWithParams } from '../util/webviews';
6
+ import { Message } from './message';
7
+ import { WHATSAPP_MAX_BODY_CHARS, WHATSAPP_MAX_BUTTON_CHARS, WHATSAPP_MAX_FOOTER_CHARS, WHATSAPP_MAX_HEADER_CHARS, } from './multichannel/whatsapp/constants';
8
+ import { convertToMarkdownMeta } from './multichannel/whatsapp/markdown-meta';
9
+ const serialize = _whatsappCTAUrlButtonProps => {
10
+ // TODO: Implement to have data persistance in localStorage, not needed for this WhatsApp development
11
+ return {};
12
+ };
13
+ export const WhatsappCTAUrlButton = (props) => {
14
+ const renderBrowser = () => {
15
+ // Return a dummy message for browser
16
+ const message = `${JSON.stringify(props)}`;
17
+ return (_jsx(Message, Object.assign({ json: serialize(message) }, props, { type: INPUT.WHATSAPP_CTA_URL_BUTTON }, { children: message })));
18
+ };
19
+ const renderNode = () => {
20
+ const validatedProps = Object.assign(Object.assign({}, props), { header: props.header
21
+ ? truncateText(props.header, WHATSAPP_MAX_HEADER_CHARS)
22
+ : undefined, body: truncateText(convertToMarkdownMeta(props.body), WHATSAPP_MAX_BODY_CHARS), footer: props.footer
23
+ ? truncateText(props.footer, WHATSAPP_MAX_FOOTER_CHARS)
24
+ : undefined, displayText: truncateText(props.displayText, WHATSAPP_MAX_BUTTON_CHARS), url: 'webview' in props
25
+ ? generateWebviewUrlWithParams(props.webview, props.params)
26
+ : props.url });
27
+ return (
28
+ // @ts-ignore Property 'message' does not exist on type 'JSX.IntrinsicElements'.
29
+ _jsx("message", Object.assign({}, validatedProps, { type: INPUT.WHATSAPP_CTA_URL_BUTTON })));
30
+ };
31
+ return renderComponent({ renderBrowser, renderNode });
32
+ };
33
+ //# sourceMappingURL=whatsapp-cta-url-button.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"whatsapp-cta-url-button.js","sourceRoot":"","sources":["../../../src/components/whatsapp-cta-url-button.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AAGrC,OAAO,EAAE,YAAY,EAAE,MAAM,SAAS,CAAA;AACtC,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAA;AAC/C,OAAO,EAAE,4BAA4B,EAAE,MAAM,kBAAkB,CAAA;AAC/D,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AACnC,OAAO,EACL,uBAAuB,EACvB,yBAAyB,EACzB,yBAAyB,EACzB,yBAAyB,GAC1B,MAAM,mCAAmC,CAAA;AAC1C,OAAO,EAAE,qBAAqB,EAAE,MAAM,uCAAuC,CAAA;AAwB7E,MAAM,SAAS,GAAG,0BAA0B,CAAC,EAAE;IAC7C,qGAAqG;IACrG,OAAO,EAAE,CAAA;AACX,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,oBAAoB,GAAG,CAAC,KAAgC,EAAE,EAAE;IACvE,MAAM,aAAa,GAAG,GAAG,EAAE;QACzB,qCAAqC;QACrC,MAAM,OAAO,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,CAAA;QAC1C,OAAO,CACL,KAAC,OAAO,kBACN,IAAI,EAAE,SAAS,CAAC,OAAO,CAAC,IACpB,KAAK,IACT,IAAI,EAAE,KAAK,CAAC,uBAAuB,gBAElC,OAAO,IACA,CACX,CAAA;IACH,CAAC,CAAA;IAED,MAAM,UAAU,GAAG,GAAG,EAAE;QACtB,MAAM,cAAc,mCACf,KAAK,KACR,MAAM,EAAE,KAAK,CAAC,MAAM;gBAClB,CAAC,CAAC,YAAY,CAAC,KAAK,CAAC,MAAM,EAAE,yBAAyB,CAAC;gBACvD,CAAC,CAAC,SAAS,EACb,IAAI,EAAE,YAAY,CAChB,qBAAqB,CAAC,KAAK,CAAC,IAAI,CAAC,EACjC,uBAAuB,CACxB,EACD,MAAM,EAAE,KAAK,CAAC,MAAM;gBAClB,CAAC,CAAC,YAAY,CAAC,KAAK,CAAC,MAAM,EAAE,yBAAyB,CAAC;gBACvD,CAAC,CAAC,SAAS,EACb,WAAW,EAAE,YAAY,CAAC,KAAK,CAAC,WAAW,EAAE,yBAAyB,CAAC,EACvE,GAAG,EACD,SAAS,IAAI,KAAK;gBAChB,CAAC,CAAC,4BAA4B,CAAC,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC,MAAM,CAAC;gBAC3D,CAAC,CAAC,KAAK,CAAC,GAAG,GAChB,CAAA;QACD,OAAO;QACL,gFAAgF;QAChF,kCAAa,cAAc,IAAE,IAAI,EAAE,KAAK,CAAC,uBAAuB,IAAI,CACrE,CAAA;IACH,CAAC,CAAA;IAED,OAAO,eAAe,CAAC,EAAE,aAAa,EAAE,UAAU,EAAE,CAAC,CAAA;AACvD,CAAC,CAAA"}
@@ -0,0 +1,46 @@
1
+ type Parameters = TextParameter | CurrencyParameter | DateTimeParameter;
2
+ interface TextParameter {
3
+ type: 'text';
4
+ text: string;
5
+ }
6
+ interface CurrencyParameter {
7
+ type: 'currency';
8
+ currency: {
9
+ fallbackValue: string;
10
+ code: string;
11
+ amount1000: number;
12
+ };
13
+ }
14
+ interface DateTimeParameter {
15
+ type: 'date_time';
16
+ dateTime: {
17
+ fallbackValue: string;
18
+ };
19
+ }
20
+ type CardButton = QuickReplyButton | UrlButton;
21
+ interface Button {
22
+ type: 'quick_reply' | 'url';
23
+ buttonIndex?: number;
24
+ }
25
+ interface QuickReplyButton extends Button {
26
+ payload: string;
27
+ }
28
+ interface UrlButton extends Button {
29
+ urlVariable: string;
30
+ }
31
+ interface Card {
32
+ fileType: 'image' | 'video';
33
+ fileId: string;
34
+ cardIndex?: number;
35
+ bodyParameters?: Parameters[];
36
+ buttons?: CardButton[];
37
+ extraComponents?: Record<string, any>[];
38
+ }
39
+ export interface WhatsappMediaCarouselProps {
40
+ templateName: string;
41
+ templateLanguage: string;
42
+ cards: Card[];
43
+ bodyParameters?: Parameters[];
44
+ }
45
+ export declare const WhatsappMediaCarousel: (props: WhatsappMediaCarouselProps) => any;
46
+ export {};
@@ -0,0 +1,36 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { INPUT } from '@botonic/core';
3
+ import { toSnakeCaseKeys } from '../util/functional';
4
+ import { renderComponent } from '../util/react';
5
+ import { Message } from './message';
6
+ const serialize = (message) => {
7
+ return { text: message };
8
+ };
9
+ export const WhatsappMediaCarousel = (props) => {
10
+ const renderBrowser = () => {
11
+ // Return a dummy message for browser
12
+ const message = `WhatsApp Media Carousel would be sent to the user.`;
13
+ return (_jsx(Message, Object.assign({ json: serialize(message) }, props, { type: INPUT.TEXT }, { children: message })));
14
+ };
15
+ const getCards = (cards) => {
16
+ cards.forEach((card, index) => {
17
+ var _a;
18
+ if (!card.cardIndex) {
19
+ card.cardIndex = index;
20
+ }
21
+ (_a = card.buttons) === null || _a === void 0 ? void 0 : _a.forEach((button, index) => {
22
+ if (!button.buttonIndex) {
23
+ button.buttonIndex = index;
24
+ }
25
+ });
26
+ });
27
+ return toSnakeCaseKeys(cards);
28
+ };
29
+ const renderNode = () => {
30
+ return (
31
+ // @ts-ignore Property 'message' does not exist on type 'JSX.IntrinsicElements'.
32
+ _jsx("message", Object.assign({}, props, { bodyParameters: JSON.stringify(toSnakeCaseKeys(props.bodyParameters)), cards: JSON.stringify(getCards(props.cards)), templateName: props.templateName, templateLanguage: props.templateLanguage, type: INPUT.WHATSAPP_MEDIA_CAROUSEL })));
33
+ };
34
+ return renderComponent({ renderBrowser, renderNode });
35
+ };
36
+ //# sourceMappingURL=whatsapp-media-carousel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"whatsapp-media-carousel.js","sourceRoot":"","sources":["../../../src/components/whatsapp-media-carousel.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AAGrC,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAA;AACpD,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAA;AAC/C,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AAsDnC,MAAM,SAAS,GAAG,CAAC,OAAe,EAAE,EAAE;IACpC,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,CAAA;AAC1B,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,qBAAqB,GAAG,CAAC,KAAiC,EAAE,EAAE;IACzE,MAAM,aAAa,GAAG,GAAG,EAAE;QACzB,qCAAqC;QACrC,MAAM,OAAO,GAAG,oDAAoD,CAAA;QACpE,OAAO,CACL,KAAC,OAAO,kBAAC,IAAI,EAAE,SAAS,CAAC,OAAO,CAAC,IAAM,KAAK,IAAE,IAAI,EAAE,KAAK,CAAC,IAAI,gBAC3D,OAAO,IACA,CACX,CAAA;IACH,CAAC,CAAA;IAED,MAAM,QAAQ,GAAG,CAAC,KAAa,EAAE,EAAE;QACjC,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;;YAC5B,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;gBACnB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAA;aACvB;YACD,MAAA,IAAI,CAAC,OAAO,0CAAE,OAAO,CAAC,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE;gBACtC,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE;oBACvB,MAAM,CAAC,WAAW,GAAG,KAAK,CAAA;iBAC3B;YACH,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;QACF,OAAO,eAAe,CAAC,KAAK,CAAC,CAAA;IAC/B,CAAC,CAAA;IAED,MAAM,UAAU,GAAG,GAAG,EAAE;QACtB,OAAO;QACL,gFAAgF;QAChF,kCACM,KAAK,IACT,cAAc,EAAE,IAAI,CAAC,SAAS,CAAC,eAAe,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC,EACrE,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAC5C,YAAY,EAAE,KAAK,CAAC,YAAY,EAChC,gBAAgB,EAAE,KAAK,CAAC,gBAAgB,EACxC,IAAI,EAAE,KAAK,CAAC,uBAAuB,IACnC,CACH,CAAA;IACH,CAAC,CAAA;IAED,OAAO,eAAe,CAAC,EAAE,aAAa,EAAE,UAAU,EAAE,CAAC,CAAA;AACvD,CAAC,CAAA"}
@@ -0,0 +1,32 @@
1
+ type Parameters = TextParameter | CurrencyParameter | DateTimeParameter;
2
+ interface TextParameter {
3
+ type: 'text';
4
+ text: string;
5
+ }
6
+ interface CurrencyParameter {
7
+ type: 'currency';
8
+ currency: {
9
+ fallbackValue: string;
10
+ code: string;
11
+ amount1000: number;
12
+ };
13
+ }
14
+ interface DateTimeParameter {
15
+ type: 'date_time';
16
+ dateTime: {
17
+ fallbackValue: string;
18
+ };
19
+ }
20
+ interface Card {
21
+ productRetailerId: string;
22
+ catalogId: string;
23
+ cardIndex?: number;
24
+ }
25
+ export interface WhatsappProductCarouselProps {
26
+ templateName: string;
27
+ templateLanguage: string;
28
+ cards: Card[];
29
+ bodyParameters?: Parameters[];
30
+ }
31
+ export declare const WhatsappProductCarousel: (props: WhatsappProductCarouselProps) => any;
32
+ export {};
@@ -0,0 +1,30 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { INPUT } from '@botonic/core';
3
+ import { toSnakeCaseKeys } from '../util/functional';
4
+ import { renderComponent } from '../util/react';
5
+ import { Message } from './message';
6
+ const serialize = (message) => {
7
+ return { text: message };
8
+ };
9
+ export const WhatsappProductCarousel = (props) => {
10
+ const renderBrowser = () => {
11
+ // Return a dummy message for browser
12
+ const message = `WhatsApp Product Carousel would be sent to the user.`;
13
+ return (_jsx(Message, Object.assign({ json: serialize(message) }, props, { type: INPUT.TEXT }, { children: message })));
14
+ };
15
+ const getCards = (cards) => {
16
+ cards.forEach((card, index) => {
17
+ if (!card.cardIndex) {
18
+ card.cardIndex = index;
19
+ }
20
+ });
21
+ return toSnakeCaseKeys(cards);
22
+ };
23
+ const renderNode = () => {
24
+ return (
25
+ // @ts-ignore Property 'message' does not exist on type 'JSX.IntrinsicElements'.
26
+ _jsx("message", Object.assign({}, props, { bodyParameters: JSON.stringify(toSnakeCaseKeys(props.bodyParameters)), cards: JSON.stringify(getCards(props.cards)), templateName: props.templateName, templateLanguage: props.templateLanguage, type: INPUT.WHATSAPP_PRODUCT_CAROUSEL })));
27
+ };
28
+ return renderComponent({ renderBrowser, renderNode });
29
+ };
30
+ //# sourceMappingURL=whatsapp-product-carousel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"whatsapp-product-carousel.js","sourceRoot":"","sources":["../../../src/components/whatsapp-product-carousel.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AAGrC,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAA;AACpD,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAA;AAC/C,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AAoCnC,MAAM,SAAS,GAAG,CAAC,OAAe,EAAE,EAAE;IACpC,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,CAAA;AAC1B,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,uBAAuB,GAAG,CACrC,KAAmC,EACnC,EAAE;IACF,MAAM,aAAa,GAAG,GAAG,EAAE;QACzB,qCAAqC;QACrC,MAAM,OAAO,GAAG,sDAAsD,CAAA;QACtE,OAAO,CACL,KAAC,OAAO,kBAAC,IAAI,EAAE,SAAS,CAAC,OAAO,CAAC,IAAM,KAAK,IAAE,IAAI,EAAE,KAAK,CAAC,IAAI,gBAC3D,OAAO,IACA,CACX,CAAA;IACH,CAAC,CAAA;IAED,MAAM,QAAQ,GAAG,CAAC,KAAa,EAAE,EAAE;QACjC,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;YAC5B,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;gBACnB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAA;aACvB;QACH,CAAC,CAAC,CAAA;QACF,OAAO,eAAe,CAAC,KAAK,CAAC,CAAA;IAC/B,CAAC,CAAA;IAED,MAAM,UAAU,GAAG,GAAG,EAAE;QACtB,OAAO;QACL,gFAAgF;QAChF,kCACM,KAAK,IACT,cAAc,EAAE,IAAI,CAAC,SAAS,CAAC,eAAe,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC,EACrE,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAC5C,YAAY,EAAE,KAAK,CAAC,YAAY,EAChC,gBAAgB,EAAE,KAAK,CAAC,gBAAgB,EACxC,IAAI,EAAE,KAAK,CAAC,yBAAyB,IACrC,CACH,CAAA;IACH,CAAC,CAAA;IAED,OAAO,eAAe,CAAC,EAAE,aAAa,EAAE,UAAU,EAAE,CAAC,CAAA;AACvD,CAAC,CAAA"}
@@ -0,0 +1,15 @@
1
+ export interface ProductItem {
2
+ productRetailerId: string;
3
+ }
4
+ export interface WhatsappProductListSection {
5
+ title: string;
6
+ productItems: ProductItem[];
7
+ }
8
+ export interface WhatsappProductListProps {
9
+ body: string;
10
+ header: string;
11
+ catalogId: string;
12
+ sections: WhatsappProductListSection[];
13
+ footer?: string;
14
+ }
15
+ export declare const WhatsappProductList: (props: WhatsappProductListProps) => any;
@@ -0,0 +1,22 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { INPUT } from '@botonic/core';
3
+ import { toSnakeCaseKeys } from '../util/functional';
4
+ import { renderComponent } from '../util/react';
5
+ import { Message } from './message';
6
+ const serialize = (message) => {
7
+ return { text: message };
8
+ };
9
+ export const WhatsappProductList = (props) => {
10
+ const renderBrowser = () => {
11
+ // Return a dummy message for browser
12
+ const message = `WhatsApp Product List would be sent to the user.`;
13
+ return (_jsx(Message, Object.assign({ json: serialize(message) }, props, { type: INPUT.TEXT }, { children: message })));
14
+ };
15
+ const renderNode = () => {
16
+ return (
17
+ // @ts-ignore Property 'message' does not exist on type 'JSX.IntrinsicElements'.
18
+ _jsx("message", Object.assign({}, props, { body: props.body, footer: props.footer, header: props.header, sections: JSON.stringify(toSnakeCaseKeys(props.sections)), catalogId: props.catalogId, type: INPUT.WHATSAPP_PRODUCT_LIST })));
19
+ };
20
+ return renderComponent({ renderBrowser, renderNode });
21
+ };
22
+ //# sourceMappingURL=whatsapp-product-list.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"whatsapp-product-list.js","sourceRoot":"","sources":["../../../src/components/whatsapp-product-list.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AAGrC,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAA;AACpD,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAA;AAC/C,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AAmBnC,MAAM,SAAS,GAAG,CAAC,OAAe,EAAE,EAAE;IACpC,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,CAAA;AAC1B,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,mBAAmB,GAAG,CAAC,KAA+B,EAAE,EAAE;IACrE,MAAM,aAAa,GAAG,GAAG,EAAE;QACzB,qCAAqC;QACrC,MAAM,OAAO,GAAG,kDAAkD,CAAA;QAClE,OAAO,CACL,KAAC,OAAO,kBAAC,IAAI,EAAE,SAAS,CAAC,OAAO,CAAC,IAAM,KAAK,IAAE,IAAI,EAAE,KAAK,CAAC,IAAI,gBAC3D,OAAO,IACA,CACX,CAAA;IACH,CAAC,CAAA;IAED,MAAM,UAAU,GAAG,GAAG,EAAE;QACtB,OAAO;QACL,gFAAgF;QAChF,kCACM,KAAK,IACT,IAAI,EAAE,KAAK,CAAC,IAAI,EAChB,MAAM,EAAE,KAAK,CAAC,MAAM,EACpB,MAAM,EAAE,KAAK,CAAC,MAAM,EACpB,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,eAAe,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,EACzD,SAAS,EAAE,KAAK,CAAC,SAAS,EAC1B,IAAI,EAAE,KAAK,CAAC,qBAAqB,IACjC,CACH,CAAA;IACH,CAAC,CAAA;IAED,OAAO,eAAe,CAAC,EAAE,aAAa,EAAE,UAAU,EAAE,CAAC,CAAA;AACvD,CAAC,CAAA"}
@@ -0,0 +1,7 @@
1
+ export interface WhatsappProductProps {
2
+ body: string;
3
+ catalogId: string;
4
+ productId: string;
5
+ footer?: string;
6
+ }
7
+ export declare const WhatsappProduct: (props: WhatsappProductProps) => any;
@@ -0,0 +1,21 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { INPUT } from '@botonic/core';
3
+ import { renderComponent } from '../util/react';
4
+ import { Message } from './message';
5
+ const serialize = (message) => {
6
+ return { text: message };
7
+ };
8
+ export const WhatsappProduct = (props) => {
9
+ const renderBrowser = () => {
10
+ // Return a dummy message for browser
11
+ const message = `WhatsApp Product would be sent to the user.`;
12
+ return (_jsx(Message, Object.assign({ json: serialize(message) }, props, { type: INPUT.TEXT }, { children: message })));
13
+ };
14
+ const renderNode = () => {
15
+ return (
16
+ // @ts-ignore Property 'message' does not exist on type 'JSX.IntrinsicElements'.
17
+ _jsx("message", Object.assign({}, props, { body: props.body, footer: props.footer, catalogId: props.catalogId, productId: props.productId, type: INPUT.WHATSAPP_PRODUCT })));
18
+ };
19
+ return renderComponent({ renderBrowser, renderNode });
20
+ };
21
+ //# sourceMappingURL=whatsapp-product.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"whatsapp-product.js","sourceRoot":"","sources":["../../../src/components/whatsapp-product.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AAGrC,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAA;AAC/C,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AASnC,MAAM,SAAS,GAAG,CAAC,OAAe,EAAE,EAAE;IACpC,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,CAAA;AAC1B,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,KAA2B,EAAE,EAAE;IAC7D,MAAM,aAAa,GAAG,GAAG,EAAE;QACzB,qCAAqC;QACrC,MAAM,OAAO,GAAG,6CAA6C,CAAA;QAC7D,OAAO,CACL,KAAC,OAAO,kBAAC,IAAI,EAAE,SAAS,CAAC,OAAO,CAAC,IAAM,KAAK,IAAE,IAAI,EAAE,KAAK,CAAC,IAAI,gBAC3D,OAAO,IACA,CACX,CAAA;IACH,CAAC,CAAA;IAED,MAAM,UAAU,GAAG,GAAG,EAAE;QACtB,OAAO;QACL,gFAAgF;QAChF,kCACM,KAAK,IACT,IAAI,EAAE,KAAK,CAAC,IAAI,EAChB,MAAM,EAAE,KAAK,CAAC,MAAM,EACpB,SAAS,EAAE,KAAK,CAAC,SAAS,EAC1B,SAAS,EAAE,KAAK,CAAC,SAAS,EAC1B,IAAI,EAAE,KAAK,CAAC,gBAAgB,IAC5B,CACH,CAAA;IACH,CAAC,CAAA;IAED,OAAO,eAAe,CAAC,EAAE,aAAa,EAAE,UAAU,EAAE,CAAC,CAAA;AACvD,CAAC,CAAA"}
@@ -0,0 +1 @@
1
+ export function WhatsappTemplate(props: any): any;
@@ -0,0 +1,20 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { INPUT } from '@botonic/core';
3
+ import React from 'react';
4
+ import { renderComponent } from '../util/react';
5
+ import { Message } from './message';
6
+ const serialize = whatsappTemplateProps => {
7
+ return { text: whatsappTemplateProps };
8
+ };
9
+ export const WhatsappTemplate = props => {
10
+ const renderBrowser = () => {
11
+ // Return a dummy message for browser
12
+ const message = `Template ${props.name} with namespace ${props.namespace} would be sent to the user.`;
13
+ return (_jsx(Message, Object.assign({ json: serialize(message) }, props, { type: INPUT.TEXT }, { children: message })));
14
+ };
15
+ const renderNode = () => {
16
+ return (_jsx("message", Object.assign({}, 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 })));
17
+ };
18
+ return renderComponent({ renderBrowser, renderNode });
19
+ };
20
+ //# sourceMappingURL=whatsapp-template.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"whatsapp-template.js","sourceRoot":"","sources":["../../../src/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,KAAC,OAAO,kBAAC,IAAI,EAAE,SAAS,CAAC,OAAO,CAAC,IAAM,KAAK,IAAE,IAAI,EAAE,KAAK,CAAC,IAAI,gBAC3D,OAAO,IACA,CACX,CAAA;IACH,CAAC,CAAA;IAED,MAAM,UAAU,GAAG,GAAG,EAAE;QACtB,OAAO,CACL,kCACM,KAAK,IACT,MAAM,EAAE,KAAK,CAAC,MAAM,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,MAAM,CAAC,EACpD,IAAI,EAAE,KAAK,CAAC,IAAI,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,EAC9C,MAAM,EAAE,KAAK,CAAC,MAAM,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,MAAM,CAAC,EACpD,IAAI,EAAE,KAAK,CAAC,iBAAiB,IAC7B,CACH,CAAA;IACH,CAAC,CAAA;IAED,OAAO,eAAe,CAAC,EAAE,aAAa,EAAE,UAAU,EAAE,CAAC,CAAA;AACvD,CAAC,CAAA"}