@botonic/react 0.21.7-alpha.0 → 0.22.0-alpha.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/cjs/app.js.map +1 -1
- package/lib/cjs/assets/attachment-icon.svg +7 -0
- package/lib/cjs/assets/audio.svg +4 -0
- package/lib/cjs/assets/botonic_react_logo100x100.png +0 -0
- package/lib/cjs/assets/document.svg +3 -0
- package/lib/cjs/assets/emojiButton.svg +6 -0
- package/lib/cjs/assets/image.svg +4 -0
- package/lib/cjs/assets/leftArrow.svg +3 -0
- package/lib/cjs/assets/menuButton.svg +3 -0
- package/lib/cjs/assets/rightArrow.svg +3 -0
- package/lib/cjs/assets/send-button.svg +1 -0
- package/lib/cjs/assets/video.svg +3 -0
- package/lib/cjs/botonic-tester.d.ts +3 -3
- package/lib/cjs/botonic-tester.js +6 -6
- package/lib/cjs/botonic-tester.js.map +1 -1
- package/lib/cjs/components/audio.js +2 -2
- package/lib/cjs/components/audio.js.map +1 -1
- package/lib/cjs/components/button.js +4 -4
- package/lib/cjs/components/button.js.map +1 -1
- package/lib/cjs/components/buttons-disabler.d.ts +1 -1
- package/lib/cjs/components/buttons-disabler.js +4 -4
- package/lib/cjs/components/buttons-disabler.js.map +1 -1
- package/lib/cjs/components/carousel.d.ts +3 -2
- package/lib/cjs/components/carousel.js +8 -8
- package/lib/cjs/components/carousel.js.map +1 -1
- package/lib/cjs/components/components.d.ts +1 -1
- package/lib/cjs/components/components.js.map +1 -1
- package/lib/cjs/components/custom-message.d.ts +34 -1
- package/lib/cjs/components/custom-message.js +3 -3
- package/lib/cjs/components/custom-message.js.map +1 -1
- package/lib/cjs/components/document.js +3 -3
- package/lib/cjs/components/document.js.map +1 -1
- package/lib/cjs/components/element.js +1 -1
- package/lib/cjs/components/element.js.map +1 -1
- package/lib/cjs/components/handoff.js +2 -2
- package/lib/cjs/components/handoff.js.map +1 -1
- package/lib/cjs/components/image.js +4 -4
- package/lib/cjs/components/image.js.map +1 -1
- package/lib/cjs/components/index.d.ts +19 -0
- package/lib/cjs/components/index.js.map +1 -1
- package/lib/cjs/components/location.js +1 -1
- package/lib/cjs/components/location.js.map +1 -1
- package/lib/cjs/components/markdown.js +2 -2
- package/lib/cjs/components/markdown.js.map +1 -1
- package/lib/cjs/components/message-template.js +1 -1
- package/lib/cjs/components/message-template.js.map +1 -1
- package/lib/cjs/components/message.js +14 -14
- package/lib/cjs/components/message.js.map +1 -1
- package/lib/cjs/components/multichannel/facebook/facebook.js.map +1 -1
- package/lib/cjs/components/multichannel/index.d.ts +5 -0
- package/lib/cjs/components/multichannel/index.js.map +1 -1
- package/lib/cjs/components/multichannel/multichannel-button.js +3 -3
- package/lib/cjs/components/multichannel/multichannel-button.js.map +1 -1
- package/lib/cjs/components/multichannel/multichannel-carousel.js +7 -7
- package/lib/cjs/components/multichannel/multichannel-carousel.js.map +1 -1
- package/lib/cjs/components/multichannel/multichannel-context.js.map +1 -1
- package/lib/cjs/components/multichannel/multichannel-reply.js +2 -2
- package/lib/cjs/components/multichannel/multichannel-reply.js.map +1 -1
- package/lib/cjs/components/multichannel/multichannel-text.js +9 -9
- package/lib/cjs/components/multichannel/multichannel-text.js.map +1 -1
- package/lib/cjs/components/multichannel/multichannel-utils.js.map +1 -1
- package/lib/cjs/components/multichannel/multichannel.js +5 -5
- package/lib/cjs/components/multichannel/multichannel.js.map +1 -1
- package/lib/cjs/components/pic.js +2 -2
- package/lib/cjs/components/pic.js.map +1 -1
- package/lib/cjs/components/raw.js +2 -2
- package/lib/cjs/components/raw.js.map +1 -1
- package/lib/cjs/components/reply.js +2 -2
- package/lib/cjs/components/reply.js.map +1 -1
- package/lib/cjs/components/share-button.js +1 -1
- package/lib/cjs/components/share-button.js.map +1 -1
- package/lib/cjs/components/subtitle.js +1 -1
- package/lib/cjs/components/subtitle.js.map +1 -1
- package/lib/cjs/components/text.d.ts +1 -1
- package/lib/cjs/components/text.js +3 -3
- package/lib/cjs/components/text.js.map +1 -1
- package/lib/cjs/components/timestamps.js.map +1 -1
- package/lib/cjs/components/title.js +1 -1
- package/lib/cjs/components/title.js.map +1 -1
- package/lib/cjs/components/video.js +2 -2
- package/lib/cjs/components/video.js.map +1 -1
- package/lib/cjs/components/webchat-settings.js +4 -4
- package/lib/cjs/components/webchat-settings.js.map +1 -1
- package/lib/cjs/components/whatsapp-template.js +1 -1
- package/lib/cjs/components/whatsapp-template.js.map +1 -1
- package/lib/cjs/constants.js.map +1 -1
- package/lib/cjs/contexts.js.map +1 -1
- package/lib/cjs/dev-app.d.ts +4 -8
- package/lib/cjs/dev-app.js +3 -3
- package/lib/cjs/dev-app.js.map +1 -1
- package/lib/cjs/index.d.ts +7 -0
- package/lib/cjs/index.js +2 -2
- package/lib/cjs/index.js.map +1 -1
- package/lib/cjs/message-utils.d.ts +2 -1
- package/lib/cjs/message-utils.js +12 -12
- package/lib/cjs/message-utils.js.map +1 -1
- package/lib/cjs/msg-to-botonic.js +10 -10
- package/lib/cjs/msg-to-botonic.js.map +1 -1
- package/lib/cjs/node-app.d.ts +6 -5
- package/lib/cjs/node-app.js +1 -1
- package/lib/cjs/node-app.js.map +1 -1
- package/lib/cjs/react-bot.js.map +1 -1
- package/lib/cjs/util/dom.js +3 -3
- package/lib/cjs/util/dom.js.map +1 -1
- package/lib/cjs/util/environment.js +3 -3
- package/lib/cjs/util/environment.js.map +1 -1
- package/lib/cjs/util/error-boundary.d.ts +40 -0
- package/lib/cjs/util/error-boundary.js +1 -2
- package/lib/cjs/util/error-boundary.js.map +1 -1
- package/lib/cjs/util/index.js.map +1 -1
- package/lib/cjs/util/logs.d.ts +1 -1
- package/lib/cjs/util/logs.js +1 -1
- package/lib/cjs/util/logs.js.map +1 -1
- package/lib/cjs/util/objects.js.map +1 -1
- package/lib/cjs/util/react.js +8 -8
- package/lib/cjs/util/react.js.map +1 -1
- package/lib/cjs/util/regexs.js.map +1 -1
- package/lib/cjs/util/webchat.d.ts +1 -1
- package/lib/cjs/util/webchat.js +4 -4
- package/lib/cjs/util/webchat.js.map +1 -1
- package/lib/cjs/webchat/actions.js.map +1 -1
- package/lib/cjs/webchat/components/attachment.js +1 -1
- package/lib/cjs/webchat/components/attachment.js.map +1 -1
- package/lib/cjs/webchat/components/common.js +1 -1
- package/lib/cjs/webchat/components/common.js.map +1 -1
- package/lib/cjs/webchat/components/conditional-animation.js +1 -1
- package/lib/cjs/webchat/components/conditional-animation.js.map +1 -1
- package/lib/cjs/webchat/components/emoji-picker.js +2 -2
- package/lib/cjs/webchat/components/emoji-picker.js.map +1 -1
- package/lib/cjs/webchat/components/persistent-menu.js +3 -3
- package/lib/cjs/webchat/components/persistent-menu.js.map +1 -1
- package/lib/cjs/webchat/components/send-button.js +1 -1
- package/lib/cjs/webchat/components/send-button.js.map +1 -1
- package/lib/cjs/webchat/components/styled-scrollbar.js +2 -2
- package/lib/cjs/webchat/components/styled-scrollbar.js.map +1 -1
- package/lib/cjs/webchat/components/styled-scrollbar.scss +12 -0
- package/lib/cjs/webchat/components/typing-indicator.js.map +1 -1
- package/lib/cjs/webchat/components/typing-indicator.scss +38 -0
- package/lib/cjs/webchat/devices/device-adapter.js +1 -1
- package/lib/cjs/webchat/devices/device-adapter.js.map +1 -1
- package/lib/cjs/webchat/devices/index.js +1 -1
- package/lib/cjs/webchat/devices/index.js.map +1 -1
- package/lib/cjs/webchat/devices/scrollbar-controller.js +5 -5
- package/lib/cjs/webchat/devices/scrollbar-controller.js.map +1 -1
- package/lib/cjs/webchat/devices/webchat-resizer.js +2 -2
- package/lib/cjs/webchat/devices/webchat-resizer.js.map +1 -1
- package/lib/cjs/webchat/header.js +3 -3
- package/lib/cjs/webchat/header.js.map +1 -1
- package/lib/cjs/webchat/hooks.d.ts +1 -1
- package/lib/cjs/webchat/hooks.js +9 -9
- package/lib/cjs/webchat/hooks.js.map +1 -1
- package/lib/cjs/webchat/index.d.ts +3 -1
- package/lib/cjs/webchat/index.js.map +1 -1
- package/lib/cjs/webchat/message-list.js +2 -2
- package/lib/cjs/webchat/message-list.js.map +1 -1
- package/lib/cjs/webchat/messages-reducer.js.map +1 -1
- package/lib/cjs/webchat/replies.js +1 -1
- package/lib/cjs/webchat/replies.js.map +1 -1
- package/lib/cjs/webchat/session-view.js +1 -1
- package/lib/cjs/webchat/session-view.js.map +1 -1
- package/lib/cjs/webchat/use-storage-state-hook.js +3 -3
- package/lib/cjs/webchat/use-storage-state-hook.js.map +1 -1
- package/lib/cjs/webchat/webchat-dev.js +5 -5
- package/lib/cjs/webchat/webchat-dev.js.map +1 -1
- package/lib/cjs/webchat/webchat-reducer.js +1 -1
- package/lib/cjs/webchat/webchat-reducer.js.map +1 -1
- package/lib/cjs/webchat/webchat.js +63 -62
- package/lib/cjs/webchat/webchat.js.map +1 -1
- package/lib/cjs/webchat/webview.js +5 -5
- package/lib/cjs/webchat/webview.js.map +1 -1
- package/lib/cjs/webchat-app.js +7 -7
- package/lib/cjs/webchat-app.js.map +1 -1
- package/lib/cjs/webchat.template.html +37 -0
- package/lib/cjs/{webview.d.ts → webview-app.d.ts} +1 -3
- package/lib/cjs/{webview.js → webview-app.js} +14 -13
- package/lib/cjs/webview-app.js.map +1 -0
- package/lib/cjs/webview.template.html +39 -0
- package/lib/esm/app.d.ts +2 -0
- package/lib/esm/app.js +6 -0
- package/lib/esm/app.js.map +1 -0
- package/lib/esm/assets/attachment-icon.svg +7 -0
- package/lib/esm/assets/audio.svg +4 -0
- package/lib/esm/assets/botonic_react_logo100x100.png +0 -0
- package/lib/esm/assets/document.svg +3 -0
- package/lib/esm/assets/emojiButton.svg +6 -0
- package/lib/esm/assets/image.svg +4 -0
- package/lib/esm/assets/leftArrow.svg +3 -0
- package/lib/esm/assets/menuButton.svg +3 -0
- package/lib/esm/assets/rightArrow.svg +3 -0
- package/lib/esm/assets/send-button.svg +1 -0
- package/lib/esm/assets/video.svg +3 -0
- package/lib/esm/botonic-tester.d.ts +18 -0
- package/lib/esm/botonic-tester.js +64 -0
- package/lib/esm/botonic-tester.js.map +1 -0
- package/lib/esm/components/audio.d.ts +8 -0
- package/lib/esm/components/audio.js +22 -0
- package/lib/esm/components/audio.js.map +1 -0
- package/lib/esm/components/button.d.ts +15 -0
- package/lib/esm/components/button.js +151 -0
- package/lib/esm/components/button.js.map +1 -0
- package/lib/esm/components/buttons-disabler.d.ts +24 -0
- package/lib/esm/components/buttons-disabler.js +84 -0
- package/lib/esm/components/buttons-disabler.js.map +1 -0
- package/lib/esm/components/carousel.d.ts +9 -0
- package/lib/esm/components/carousel.js +115 -0
- package/lib/esm/components/carousel.js.map +1 -0
- package/lib/esm/components/components.d.ts +12 -0
- package/lib/esm/components/components.js +17 -0
- package/lib/esm/components/components.js.map +1 -0
- package/lib/esm/components/custom-message.d.ts +43 -0
- package/lib/esm/components/custom-message.js +61 -0
- package/lib/esm/components/custom-message.js.map +1 -0
- package/lib/esm/components/document.d.ts +8 -0
- package/lib/esm/components/document.js +45 -0
- package/lib/esm/components/document.js.map +1 -0
- package/lib/esm/components/element.d.ts +4 -0
- package/lib/esm/components/element.js +50 -0
- package/lib/esm/components/element.js.map +1 -0
- package/lib/esm/components/handoff.d.ts +1 -0
- package/lib/esm/components/handoff.js +53 -0
- package/lib/esm/components/handoff.js.map +1 -0
- package/lib/esm/components/image.d.ts +8 -0
- package/lib/esm/components/image.js +37 -0
- package/lib/esm/components/image.js.map +1 -0
- package/lib/esm/components/index.d.ts +19 -0
- package/lib/esm/components/index.js +21 -0
- package/lib/esm/components/index.js.map +1 -0
- package/lib/esm/components/location.d.ts +11 -0
- package/lib/esm/components/location.js +33 -0
- package/lib/esm/components/location.js.map +1 -0
- package/lib/esm/components/markdown.d.ts +7 -0
- package/lib/esm/components/markdown.js +152 -0
- package/lib/esm/components/markdown.js.map +1 -0
- package/lib/esm/components/message-template.d.ts +1 -0
- package/lib/esm/components/message-template.js +10 -0
- package/lib/esm/components/message-template.js.map +1 -0
- package/lib/esm/components/message.d.ts +1 -0
- package/lib/esm/components/message.js +202 -0
- package/lib/esm/components/message.js.map +1 -0
- package/lib/esm/components/multichannel/facebook/facebook.d.ts +17 -0
- package/lib/esm/components/multichannel/facebook/facebook.js +43 -0
- package/lib/esm/components/multichannel/facebook/facebook.js.map +1 -0
- package/lib/esm/components/multichannel/index.d.ts +6 -0
- package/lib/esm/components/multichannel/index.js +11 -0
- package/lib/esm/components/multichannel/index.js.map +1 -0
- package/lib/esm/components/multichannel/multichannel-button.d.ts +1 -0
- package/lib/esm/components/multichannel/multichannel-button.js +72 -0
- package/lib/esm/components/multichannel/multichannel-button.js.map +1 -0
- package/lib/esm/components/multichannel/multichannel-carousel.d.ts +1 -0
- package/lib/esm/components/multichannel/multichannel-carousel.js +90 -0
- package/lib/esm/components/multichannel/multichannel-carousel.js.map +1 -0
- package/lib/esm/components/multichannel/multichannel-context.d.ts +11 -0
- package/lib/esm/components/multichannel/multichannel-context.js +12 -0
- package/lib/esm/components/multichannel/multichannel-context.js.map +1 -0
- package/lib/esm/components/multichannel/multichannel-reply.d.ts +1 -0
- package/lib/esm/components/multichannel/multichannel-reply.js +19 -0
- package/lib/esm/components/multichannel/multichannel-reply.js.map +1 -0
- package/lib/esm/components/multichannel/multichannel-text.d.ts +1 -0
- package/lib/esm/components/multichannel/multichannel-text.js +142 -0
- package/lib/esm/components/multichannel/multichannel-text.js.map +1 -0
- package/lib/esm/components/multichannel/multichannel-utils.d.ts +24 -0
- package/lib/esm/components/multichannel/multichannel-utils.js +67 -0
- package/lib/esm/components/multichannel/multichannel-utils.js.map +1 -0
- package/lib/esm/components/multichannel/multichannel.d.ts +1 -0
- package/lib/esm/components/multichannel/multichannel.js +67 -0
- package/lib/esm/components/multichannel/multichannel.js.map +1 -0
- package/lib/esm/components/pic.d.ts +6 -0
- package/lib/esm/components/pic.js +24 -0
- package/lib/esm/components/pic.js.map +1 -0
- package/lib/esm/components/raw.d.ts +9 -0
- package/lib/esm/components/raw.js +48 -0
- package/lib/esm/components/raw.js.map +1 -0
- package/lib/esm/components/reply.d.ts +9 -0
- package/lib/esm/components/reply.js +52 -0
- package/lib/esm/components/reply.js.map +1 -0
- package/lib/esm/components/share-button.d.ts +1 -0
- package/lib/esm/components/share-button.js +10 -0
- package/lib/esm/components/share-button.js.map +1 -0
- package/lib/esm/components/subtitle.d.ts +6 -0
- package/lib/esm/components/subtitle.js +20 -0
- package/lib/esm/components/subtitle.js.map +1 -0
- package/lib/esm/components/text.d.ts +8 -0
- package/lib/esm/components/text.js +45 -0
- package/lib/esm/components/text.js.map +1 -0
- package/lib/esm/components/timestamps.d.ts +10 -0
- package/lib/esm/components/timestamps.js +48 -0
- package/lib/esm/components/timestamps.js.map +1 -0
- package/lib/esm/components/title.d.ts +6 -0
- package/lib/esm/components/title.js +16 -0
- package/lib/esm/components/title.js.map +1 -0
- package/lib/esm/components/video.d.ts +8 -0
- package/lib/esm/components/video.js +29 -0
- package/lib/esm/components/video.js.map +1 -0
- package/lib/esm/components/webchat-settings.d.ts +10 -0
- package/lib/esm/components/webchat-settings.js +72 -0
- package/lib/esm/components/webchat-settings.js.map +1 -0
- package/lib/esm/components/whatsapp-template.d.ts +1 -0
- package/lib/esm/components/whatsapp-template.js +21 -0
- package/lib/esm/components/whatsapp-template.js.map +1 -0
- package/lib/esm/constants.d.ts +168 -0
- package/lib/esm/constants.js +186 -0
- package/lib/esm/constants.js.map +1 -0
- package/lib/esm/contexts.d.ts +69 -0
- package/lib/esm/contexts.js +34 -0
- package/lib/esm/contexts.js.map +1 -0
- package/lib/esm/dev-app.d.ts +30 -0
- package/lib/esm/dev-app.js +67 -0
- package/lib/esm/dev-app.js.map +1 -0
- package/lib/esm/index.d.ts +9 -0
- package/lib/esm/index.js +11 -0
- package/lib/esm/index.js.map +1 -0
- package/lib/esm/message-utils.d.ts +18 -0
- package/lib/esm/message-utils.js +41 -0
- package/lib/esm/message-utils.js.map +1 -0
- package/lib/esm/msg-to-botonic.d.ts +18 -0
- package/lib/esm/msg-to-botonic.js +154 -0
- package/lib/esm/msg-to-botonic.js.map +1 -0
- package/lib/esm/node-app.d.ts +12 -0
- package/lib/esm/node-app.js +21 -0
- package/lib/esm/node-app.js.map +1 -0
- package/lib/esm/react-bot.d.ts +7 -0
- package/lib/esm/react-bot.js +30 -0
- package/lib/esm/react-bot.js.map +1 -0
- package/lib/esm/util/dom.d.ts +13 -0
- package/lib/esm/util/dom.js +46 -0
- package/lib/esm/util/dom.js.map +1 -0
- package/lib/esm/util/environment.d.ts +6 -0
- package/lib/esm/util/environment.js +61 -0
- package/lib/esm/util/environment.js.map +1 -0
- package/lib/esm/util/error-boundary.d.ts +40 -0
- package/lib/esm/util/error-boundary.js +41 -0
- package/lib/esm/util/error-boundary.js.map +1 -0
- package/lib/esm/util/index.d.ts +0 -0
- package/lib/esm/util/index.js +2 -0
- package/lib/esm/util/index.js.map +1 -0
- package/lib/esm/util/logs.d.ts +2 -0
- package/lib/esm/util/logs.js +15 -0
- package/lib/esm/util/logs.js.map +1 -0
- package/lib/esm/util/objects.d.ts +3 -0
- package/lib/esm/util/objects.js +38 -0
- package/lib/esm/util/objects.js.map +1 -0
- package/lib/esm/util/react.d.ts +12 -0
- package/lib/esm/util/react.js +34 -0
- package/lib/esm/util/react.js.map +1 -0
- package/lib/esm/util/regexs.d.ts +2 -0
- package/lib/esm/util/regexs.js +18 -0
- package/lib/esm/util/regexs.js.map +1 -0
- package/lib/esm/util/webchat.d.ts +11 -0
- package/lib/esm/util/webchat.js +53 -0
- package/lib/esm/util/webchat.js.map +1 -0
- package/lib/esm/webchat/actions.d.ts +23 -0
- package/lib/esm/webchat/actions.js +24 -0
- package/lib/esm/webchat/actions.js.map +1 -0
- package/lib/esm/webchat/components/attachment.d.ts +5 -0
- package/lib/esm/webchat/components/attachment.js +27 -0
- package/lib/esm/webchat/components/attachment.js.map +1 -0
- package/lib/esm/webchat/components/common.d.ts +1 -0
- package/lib/esm/webchat/components/common.js +8 -0
- package/lib/esm/webchat/components/common.js.map +1 -0
- package/lib/esm/webchat/components/conditional-animation.d.ts +1 -0
- package/lib/esm/webchat/components/conditional-animation.js +13 -0
- package/lib/esm/webchat/components/conditional-animation.js.map +1 -0
- package/lib/esm/webchat/components/emoji-picker.d.ts +5 -0
- package/lib/esm/webchat/components/emoji-picker.js +46 -0
- package/lib/esm/webchat/components/emoji-picker.js.map +1 -0
- package/lib/esm/webchat/components/persistent-menu.d.ts +10 -0
- package/lib/esm/webchat/components/persistent-menu.js +53 -0
- package/lib/esm/webchat/components/persistent-menu.js.map +1 -0
- package/lib/esm/webchat/components/send-button.d.ts +3 -0
- package/lib/esm/webchat/components/send-button.js +19 -0
- package/lib/esm/webchat/components/send-button.js.map +1 -0
- package/lib/esm/webchat/components/styled-scrollbar.d.ts +1 -0
- package/lib/esm/webchat/components/styled-scrollbar.js +50 -0
- package/lib/esm/webchat/components/styled-scrollbar.js.map +1 -0
- package/lib/esm/webchat/components/styled-scrollbar.scss +12 -0
- package/lib/esm/webchat/components/typing-indicator.d.ts +1 -0
- package/lib/esm/webchat/components/typing-indicator.js +9 -0
- package/lib/esm/webchat/components/typing-indicator.js.map +1 -0
- package/lib/esm/webchat/components/typing-indicator.scss +38 -0
- package/lib/esm/webchat/devices/device-adapter.d.ts +12 -0
- package/lib/esm/webchat/devices/device-adapter.js +43 -0
- package/lib/esm/webchat/devices/device-adapter.js.map +1 -0
- package/lib/esm/webchat/devices/index.d.ts +11 -0
- package/lib/esm/webchat/devices/index.js +18 -0
- package/lib/esm/webchat/devices/index.js.map +1 -0
- package/lib/esm/webchat/devices/scrollbar-controller.d.ts +12 -0
- package/lib/esm/webchat/devices/scrollbar-controller.js +99 -0
- package/lib/esm/webchat/devices/scrollbar-controller.js.map +1 -0
- package/lib/esm/webchat/devices/webchat-resizer.d.ts +9 -0
- package/lib/esm/webchat/devices/webchat-resizer.js +43 -0
- package/lib/esm/webchat/devices/webchat-resizer.js.map +1 -0
- package/lib/esm/webchat/header.d.ts +3 -0
- package/lib/esm/webchat/header.js +89 -0
- package/lib/esm/webchat/header.js.map +1 -0
- package/lib/esm/webchat/hooks.d.ts +80 -0
- package/lib/esm/webchat/hooks.js +210 -0
- package/lib/esm/webchat/hooks.js.map +1 -0
- package/lib/esm/webchat/index.d.ts +6 -0
- package/lib/esm/webchat/index.js +11 -0
- package/lib/esm/webchat/index.js.map +1 -0
- package/lib/esm/webchat/message-list.d.ts +1 -0
- package/lib/esm/webchat/message-list.js +41 -0
- package/lib/esm/webchat/message-list.js.map +1 -0
- package/lib/esm/webchat/messages-reducer.d.ts +1 -0
- package/lib/esm/webchat/messages-reducer.js +54 -0
- package/lib/esm/webchat/messages-reducer.js.map +1 -0
- package/lib/esm/webchat/replies.d.ts +1 -0
- package/lib/esm/webchat/replies.js +41 -0
- package/lib/esm/webchat/replies.js.map +1 -0
- package/lib/esm/webchat/session-view.d.ts +1 -0
- package/lib/esm/webchat/session-view.js +119 -0
- package/lib/esm/webchat/session-view.js.map +1 -0
- package/lib/esm/webchat/use-storage-state-hook.d.ts +1 -0
- package/lib/esm/webchat/use-storage-state-hook.js +28 -0
- package/lib/esm/webchat/use-storage-state-hook.js.map +1 -0
- package/lib/esm/webchat/webchat-dev.d.ts +7 -0
- package/lib/esm/webchat/webchat-dev.js +60 -0
- package/lib/esm/webchat/webchat-dev.js.map +1 -0
- package/lib/esm/webchat/webchat-reducer.d.ts +1 -0
- package/lib/esm/webchat/webchat-reducer.js +44 -0
- package/lib/esm/webchat/webchat-reducer.js.map +1 -0
- package/lib/esm/webchat/webchat.d.ts +3 -0
- package/lib/esm/webchat/webchat.js +699 -0
- package/lib/esm/webchat/webchat.js.map +1 -0
- package/lib/esm/webchat/webview.d.ts +2 -0
- package/lib/esm/webchat/webview.js +86 -0
- package/lib/esm/webchat/webview.js.map +1 -0
- package/lib/esm/webchat-app.d.ts +98 -0
- package/lib/esm/webchat-app.js +265 -0
- package/lib/esm/webchat-app.js.map +1 -0
- package/lib/esm/webchat.template.html +37 -0
- package/lib/esm/webview-app.d.ts +7 -0
- package/lib/esm/webview-app.js +98 -0
- package/lib/esm/webview-app.js.map +1 -0
- package/lib/esm/webview.template.html +39 -0
- package/package.json +16 -9
- package/src/index.js +1 -1
- package/src/msg-to-botonic.jsx +1 -1
- package/src/{webview.jsx → webview-app.tsx} +4 -1
- package/lib/cjs/webview.js.map +0 -1
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
import React, { useContext } from 'react';
|
|
2
|
+
import { RequestContext } from '../../contexts';
|
|
3
|
+
import { Button } from '../button';
|
|
4
|
+
import { MultichannelContext } from './multichannel-context';
|
|
5
|
+
import { isWhatsapp, WHATSAPP_MAX_BUTTON_CHARS } from './multichannel-utils';
|
|
6
|
+
export const MultichannelButton = props => {
|
|
7
|
+
var _a;
|
|
8
|
+
const requestContext = useContext(RequestContext);
|
|
9
|
+
const multichannelContext = useContext(MultichannelContext);
|
|
10
|
+
const hasUrl = () => Boolean(props.url);
|
|
11
|
+
const hasPath = () => Boolean(props.path);
|
|
12
|
+
const hasPayload = () => Boolean(props.payload);
|
|
13
|
+
const hasPostback = () => hasPath() || hasPayload();
|
|
14
|
+
const hasWebview = () => Boolean(props.webview);
|
|
15
|
+
const getUrl = () => props.url;
|
|
16
|
+
const getWebview = () => props.webview;
|
|
17
|
+
const increaseCurrentIndex = () => {
|
|
18
|
+
if (typeof multichannelContext.currentIndex === 'number') {
|
|
19
|
+
multichannelContext.currentIndex += 1;
|
|
20
|
+
}
|
|
21
|
+
else if (typeof multichannelContext.currentIndex === 'string') {
|
|
22
|
+
const lastChar = multichannelContext.currentIndex.charCodeAt(multichannelContext.currentIndex.length - 1);
|
|
23
|
+
multichannelContext.currentIndex = String.fromCharCode(lastChar + 1);
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
const formatIndex = index => {
|
|
27
|
+
var _a;
|
|
28
|
+
const boldIndex = (_a = multichannelContext.boldIndex) !== null && _a !== void 0 ? _a : false;
|
|
29
|
+
return boldIndex ? `*${index}*` : index;
|
|
30
|
+
};
|
|
31
|
+
const getText = () => {
|
|
32
|
+
let text = props.children;
|
|
33
|
+
const newline = props.newline || '';
|
|
34
|
+
const separator = multichannelContext.indexSeparator || ' ';
|
|
35
|
+
const index = multichannelContext.currentIndex
|
|
36
|
+
? `${formatIndex(multichannelContext.currentIndex + separator)} `
|
|
37
|
+
: '';
|
|
38
|
+
if (hasPostback()) {
|
|
39
|
+
text = newline + `${index}${text}`;
|
|
40
|
+
}
|
|
41
|
+
else if (hasUrl()) {
|
|
42
|
+
text = newline + `- ${text}`;
|
|
43
|
+
}
|
|
44
|
+
return text;
|
|
45
|
+
};
|
|
46
|
+
const truncateText = (text, maxLength, ellipsis = '...') => {
|
|
47
|
+
if (text.length > maxLength) {
|
|
48
|
+
return text.substring(0, maxLength - ellipsis.length) + ellipsis;
|
|
49
|
+
}
|
|
50
|
+
return text;
|
|
51
|
+
};
|
|
52
|
+
if (isWhatsapp(requestContext)) {
|
|
53
|
+
const asText = (_a = props.asText) !== null && _a !== void 0 ? _a : true;
|
|
54
|
+
if (asText) {
|
|
55
|
+
if (hasUrl()) {
|
|
56
|
+
return `${getText()}: ${getUrl()}`;
|
|
57
|
+
}
|
|
58
|
+
else if (hasPath() || hasPayload()) {
|
|
59
|
+
const text = getText();
|
|
60
|
+
increaseCurrentIndex();
|
|
61
|
+
return `${text}`;
|
|
62
|
+
}
|
|
63
|
+
else if (hasWebview())
|
|
64
|
+
return <Button {...props}>{getText()}</Button>;
|
|
65
|
+
}
|
|
66
|
+
return (<Button {...props}>
|
|
67
|
+
{truncateText(props.children, WHATSAPP_MAX_BUTTON_CHARS)}
|
|
68
|
+
</Button>);
|
|
69
|
+
}
|
|
70
|
+
return <Button {...props}>{props.children}</Button>;
|
|
71
|
+
};
|
|
72
|
+
//# sourceMappingURL=multichannel-button.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"multichannel-button.js","sourceRoot":"src/","sources":["components/multichannel/multichannel-button.jsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export function MultichannelCarousel(props: any): any;
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
import React, { useContext } from 'react';
|
|
2
|
+
import { RequestContext } from '../../contexts';
|
|
3
|
+
import { Carousel } from '../carousel';
|
|
4
|
+
import { MultichannelText } from './multichannel-text';
|
|
5
|
+
import { getFilteredElements, isMultichannelButton, isNodeKind, isWhatsapp, } from './multichannel-utils';
|
|
6
|
+
export const MultichannelCarousel = props => {
|
|
7
|
+
const requestContext = useContext(RequestContext);
|
|
8
|
+
const getButtons = node => [].concat(getFilteredElements(node, isMultichannelButton));
|
|
9
|
+
if (isWhatsapp(requestContext)) {
|
|
10
|
+
const elements = props.children
|
|
11
|
+
.map(e => e.props.children)
|
|
12
|
+
.map((element, i) => {
|
|
13
|
+
let imageProps = undefined;
|
|
14
|
+
let title = undefined;
|
|
15
|
+
let subtitle = undefined;
|
|
16
|
+
const buttons = [];
|
|
17
|
+
for (const node of element) {
|
|
18
|
+
if (isNodeKind(node, 'Pic')) {
|
|
19
|
+
imageProps = node.props;
|
|
20
|
+
}
|
|
21
|
+
if (isNodeKind(node, 'Title')) {
|
|
22
|
+
title = node.props.children;
|
|
23
|
+
}
|
|
24
|
+
if (isNodeKind(node, 'Subtitle')) {
|
|
25
|
+
subtitle = node.props.children;
|
|
26
|
+
}
|
|
27
|
+
if (isNodeKind(node, 'MultichannelButton')) {
|
|
28
|
+
buttons.push(node);
|
|
29
|
+
}
|
|
30
|
+
//TODO support fragment containing an array
|
|
31
|
+
if (Array.isArray(node)) {
|
|
32
|
+
buttons.push(getButtons(node));
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
let header = '';
|
|
36
|
+
if (props.showTitle && title) {
|
|
37
|
+
header += `${title ? `*${title}*` : ''}`;
|
|
38
|
+
if (title && subtitle) {
|
|
39
|
+
header += ' ';
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
if (props.showSubtitle && subtitle) {
|
|
43
|
+
header += `_${subtitle}_`;
|
|
44
|
+
}
|
|
45
|
+
return (
|
|
46
|
+
// TODO: newkey only for 1 nested button
|
|
47
|
+
<MultichannelText key={i} newkey={i} indexMode={props.indexMode} buttonsAsText={props.buttonsAsText}>
|
|
48
|
+
{header || null}
|
|
49
|
+
{buttons}
|
|
50
|
+
</MultichannelText>);
|
|
51
|
+
// TODO: in the future, this would be the default mode
|
|
52
|
+
// } else {
|
|
53
|
+
// return (
|
|
54
|
+
// <React.Fragment key={i}>
|
|
55
|
+
// <Image
|
|
56
|
+
// src={imageSrc}
|
|
57
|
+
// caption={carouselToCaption(
|
|
58
|
+
// i + 1,
|
|
59
|
+
// title,
|
|
60
|
+
// subtitle,
|
|
61
|
+
// imageSrc,
|
|
62
|
+
// buttonProps
|
|
63
|
+
// )}
|
|
64
|
+
// ></Image>
|
|
65
|
+
// </React.Fragment>
|
|
66
|
+
// )
|
|
67
|
+
// }
|
|
68
|
+
});
|
|
69
|
+
return elements;
|
|
70
|
+
}
|
|
71
|
+
else {
|
|
72
|
+
return <Carousel {...props}>{props.children}</Carousel>;
|
|
73
|
+
}
|
|
74
|
+
};
|
|
75
|
+
// const carouselToCaption = (index, title, subtitle, imageSrc, buttonProps) => {
|
|
76
|
+
// let caption = ''
|
|
77
|
+
// let header = `${title ? `*${title}*` : ''}`
|
|
78
|
+
// header += `${subtitle ? ` - _${subtitle}_` : ''}`
|
|
79
|
+
// let buttons = ''
|
|
80
|
+
// if (buttonProps.url) {
|
|
81
|
+
// buttons += ` - ${buttonProps.children}: ${buttonProps.url}`
|
|
82
|
+
// caption = `${header ? `${header}\n` : ''}${buttons}`
|
|
83
|
+
// }
|
|
84
|
+
// if (buttonProps.payload || buttonProps.path) {
|
|
85
|
+
// buttons += `${index}. `
|
|
86
|
+
// caption = `${buttons}${buttonProps.children}`
|
|
87
|
+
// }
|
|
88
|
+
// return caption
|
|
89
|
+
// }
|
|
90
|
+
//# 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,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,19 @@
|
|
|
1
|
+
import React, { useContext } from 'react';
|
|
2
|
+
import { RequestContext } from '../../contexts';
|
|
3
|
+
import { Reply } from '../reply';
|
|
4
|
+
import { isWhatsapp } from './multichannel-utils';
|
|
5
|
+
export const MultichannelReply = props => {
|
|
6
|
+
const requestContext = useContext(RequestContext);
|
|
7
|
+
const hasPath = () => Boolean(props.path);
|
|
8
|
+
const hasPayload = () => Boolean(props.payload);
|
|
9
|
+
const getText = () => `${props.children}`;
|
|
10
|
+
if (isWhatsapp(requestContext)) {
|
|
11
|
+
if (hasPath() || hasPayload())
|
|
12
|
+
return `${getText()}`;
|
|
13
|
+
return null;
|
|
14
|
+
}
|
|
15
|
+
else {
|
|
16
|
+
return <Reply {...props}>{props.children}</Reply>;
|
|
17
|
+
}
|
|
18
|
+
};
|
|
19
|
+
//# 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,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,KAAK,CAAC,CAAA;KAClD;AACH,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export function MultichannelText(props: any): JSX.Element | never[];
|
|
@@ -0,0 +1,142 @@
|
|
|
1
|
+
import React, { useContext } from 'react';
|
|
2
|
+
import { RequestContext } from '../../contexts';
|
|
3
|
+
import { Text } from '../text';
|
|
4
|
+
import { MultichannelFacebook } from './facebook/facebook';
|
|
5
|
+
import { MultichannelButton } from './multichannel-button';
|
|
6
|
+
import { MultichannelContext } from './multichannel-context';
|
|
7
|
+
import { buttonTypes, DEFAULT_WHATSAPP_MAX_BUTTON_SEPARATOR, elementHasPostback, elementHasUrl, elementHasWebview, getButtonType, getMultichannelButtons, getMultichannelReplies, isFacebook, isWhatsapp, MULTICHANNEL_WHATSAPP_PROPS, WHATSAPP_MAX_BUTTONS, } from './multichannel-utils';
|
|
8
|
+
export const MultichannelText = props => {
|
|
9
|
+
var _a;
|
|
10
|
+
const requestContext = useContext(RequestContext);
|
|
11
|
+
const multichannelContext = useContext(MultichannelContext);
|
|
12
|
+
const postbackButtonsAsText = (_a = props.buttonsAsText) !== null && _a !== void 0 ? _a : true;
|
|
13
|
+
let elements = [];
|
|
14
|
+
const getText = children => {
|
|
15
|
+
children = Array.isArray(children) ? children : [children];
|
|
16
|
+
const text = children
|
|
17
|
+
.filter(e => e && !e.type)
|
|
18
|
+
.map(e => {
|
|
19
|
+
if (Array.isArray(e))
|
|
20
|
+
return getText(e);
|
|
21
|
+
else
|
|
22
|
+
return String(e);
|
|
23
|
+
})
|
|
24
|
+
.join('');
|
|
25
|
+
if (text == undefined) {
|
|
26
|
+
return [];
|
|
27
|
+
}
|
|
28
|
+
return [text].filter(t => t !== ''); // to avoid line breaks when the carousel doesn't have title or subtitle
|
|
29
|
+
};
|
|
30
|
+
const getButtonsAndReplies = () => [].concat(getMultichannelButtons(React.Children.toArray(props.children)), getMultichannelReplies(React.Children.toArray(props.children)));
|
|
31
|
+
const getWhatsappButtons = () => {
|
|
32
|
+
const postbackButtons = [];
|
|
33
|
+
const urlButtons = [];
|
|
34
|
+
const webviewButtons = [];
|
|
35
|
+
for (const button of getButtonsAndReplies()) {
|
|
36
|
+
if (elementHasUrl(button))
|
|
37
|
+
urlButtons.push(button);
|
|
38
|
+
if (elementHasPostback(button))
|
|
39
|
+
postbackButtons.push(button);
|
|
40
|
+
if (elementHasWebview(button))
|
|
41
|
+
webviewButtons.push(button);
|
|
42
|
+
}
|
|
43
|
+
return { postbackButtons, urlButtons, webviewButtons };
|
|
44
|
+
};
|
|
45
|
+
const getDefaultIndex = () => {
|
|
46
|
+
if (props.indexMode == undefined) {
|
|
47
|
+
return undefined;
|
|
48
|
+
}
|
|
49
|
+
if (multichannelContext.currentIndex != null) {
|
|
50
|
+
return multichannelContext.currentIndex;
|
|
51
|
+
}
|
|
52
|
+
return props.indexMode === 'letter' ? 'a' : 1;
|
|
53
|
+
};
|
|
54
|
+
const regenerateMultichannelButtons = (newLineFirstButton = true) => {
|
|
55
|
+
const generator = (multichannelButton, i) => {
|
|
56
|
+
const type = getButtonType(multichannelButton);
|
|
57
|
+
const asText = type === buttonTypes.POSTBACK ? postbackButtonsAsText : true;
|
|
58
|
+
const newline = multichannelContext.messageSeparator == null &&
|
|
59
|
+
!newLineFirstButton &&
|
|
60
|
+
i === 0
|
|
61
|
+
? ''
|
|
62
|
+
: '\n';
|
|
63
|
+
return (<MultichannelButton key={`${type}${i}`} newline={newline} asText={asText} {...multichannelButton.props}>
|
|
64
|
+
{multichannelButton.props.children}
|
|
65
|
+
</MultichannelButton>);
|
|
66
|
+
};
|
|
67
|
+
return generator;
|
|
68
|
+
};
|
|
69
|
+
const splitPostbackButtons = postbackButtons => {
|
|
70
|
+
const messages = [];
|
|
71
|
+
for (let i = 0; i < postbackButtons.length; i += WHATSAPP_MAX_BUTTONS) {
|
|
72
|
+
messages.push(postbackButtons.slice(i, i + WHATSAPP_MAX_BUTTONS));
|
|
73
|
+
}
|
|
74
|
+
return messages;
|
|
75
|
+
};
|
|
76
|
+
if (isWhatsapp(requestContext)) {
|
|
77
|
+
const texts = getText(props.children);
|
|
78
|
+
const { postbackButtons, urlButtons, webviewButtons } = getWhatsappButtons();
|
|
79
|
+
const textElements = texts.map(text => {
|
|
80
|
+
return (props.newline || '') + text;
|
|
81
|
+
});
|
|
82
|
+
const webviewButtonElements = webviewButtons.map(regenerateMultichannelButtons(false));
|
|
83
|
+
const buttonsTextSeparator = props.buttonsTextSeparator || DEFAULT_WHATSAPP_MAX_BUTTON_SEPARATOR;
|
|
84
|
+
if (!postbackButtonsAsText &&
|
|
85
|
+
postbackButtons.length > WHATSAPP_MAX_BUTTONS) {
|
|
86
|
+
const urlButtonElements = urlButtons.map(regenerateMultichannelButtons(!!texts.length));
|
|
87
|
+
const postbackButtonElements = postbackButtons.map(regenerateMultichannelButtons(!!texts.length || !!urlButtons.length));
|
|
88
|
+
const messagesPostbackButtons = splitPostbackButtons(postbackButtonElements);
|
|
89
|
+
const messages = messagesPostbackButtons.map((postbackButtons, i) => {
|
|
90
|
+
if (i === 0) {
|
|
91
|
+
return [].concat(...textElements, ...urlButtonElements, ...postbackButtons);
|
|
92
|
+
}
|
|
93
|
+
else {
|
|
94
|
+
return [].concat(buttonsTextSeparator, ...postbackButtons);
|
|
95
|
+
}
|
|
96
|
+
});
|
|
97
|
+
if (webviewButtonElements.length) {
|
|
98
|
+
messages.push([buttonsTextSeparator, ...webviewButtonElements]);
|
|
99
|
+
}
|
|
100
|
+
return (<>
|
|
101
|
+
{messages.map((message, i) => (<Text key={i} {...MULTICHANNEL_WHATSAPP_PROPS} {...props}>
|
|
102
|
+
{message}
|
|
103
|
+
</Text>))}
|
|
104
|
+
</>);
|
|
105
|
+
}
|
|
106
|
+
multichannelContext.currentIndex = getDefaultIndex();
|
|
107
|
+
const postbackButtonElements = postbackButtons.map(regenerateMultichannelButtons(!!texts.length));
|
|
108
|
+
const urlButtonElements = urlButtons.map(regenerateMultichannelButtons(!!texts.length || !!postbackButtons.length));
|
|
109
|
+
elements = [].concat([...textElements], [...postbackButtonElements], [...urlButtonElements]);
|
|
110
|
+
if (multichannelContext.messageSeparator != null) {
|
|
111
|
+
return elements;
|
|
112
|
+
}
|
|
113
|
+
const messages = [
|
|
114
|
+
<Text key={0} {...MULTICHANNEL_WHATSAPP_PROPS} {...props}>
|
|
115
|
+
{elements}
|
|
116
|
+
</Text>,
|
|
117
|
+
];
|
|
118
|
+
if (webviewButtonElements.length) {
|
|
119
|
+
messages.push(<Text key={1} {...MULTICHANNEL_WHATSAPP_PROPS} {...props}>
|
|
120
|
+
{buttonsTextSeparator}
|
|
121
|
+
{webviewButtonElements}
|
|
122
|
+
</Text>);
|
|
123
|
+
}
|
|
124
|
+
return <>{messages}</>;
|
|
125
|
+
}
|
|
126
|
+
if (isFacebook(requestContext)) {
|
|
127
|
+
const text = getText(props.children);
|
|
128
|
+
const multichannelFacebook = new MultichannelFacebook();
|
|
129
|
+
const { texts, propsLastText, propsWithoutChildren, } = multichannelFacebook.convertText(props, text[0]);
|
|
130
|
+
return (<>
|
|
131
|
+
{texts &&
|
|
132
|
+
texts.map((e, i) => (<Text key={i} {...propsWithoutChildren}>
|
|
133
|
+
{e}
|
|
134
|
+
</Text>))}
|
|
135
|
+
<Text {...propsLastText}>{propsLastText.children}</Text>
|
|
136
|
+
</>);
|
|
137
|
+
}
|
|
138
|
+
else {
|
|
139
|
+
return <Text {...props}>{props.children}</Text>;
|
|
140
|
+
}
|
|
141
|
+
};
|
|
142
|
+
//# 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,24 @@
|
|
|
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_MAX_BUTTON_CHARS: 20;
|
|
17
|
+
export const DEFAULT_WHATSAPP_MAX_BUTTON_SEPARATOR: "More options:";
|
|
18
|
+
export namespace buttonTypes {
|
|
19
|
+
const POSTBACK: string;
|
|
20
|
+
const URL: string;
|
|
21
|
+
const WEBVIEW: string;
|
|
22
|
+
}
|
|
23
|
+
export function isWhatsapp(context: any): any;
|
|
24
|
+
export function isFacebook(context: any): any;
|
|
@@ -0,0 +1,67 @@
|
|
|
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_MAX_BUTTON_CHARS = 20;
|
|
10
|
+
export const DEFAULT_WHATSAPP_MAX_BUTTON_SEPARATOR = 'More options:';
|
|
11
|
+
export function isMultichannelButton(node) {
|
|
12
|
+
return isNodeKind(node, 'MultichannelButton');
|
|
13
|
+
}
|
|
14
|
+
export function isMultichannelReply(node) {
|
|
15
|
+
return isNodeKind(node, 'MultichannelReply');
|
|
16
|
+
}
|
|
17
|
+
export function isButton(node) {
|
|
18
|
+
return isNodeKind(node, 'Button');
|
|
19
|
+
}
|
|
20
|
+
export function isNodeKind(node, kind) {
|
|
21
|
+
return node.type && node.type.name == kind;
|
|
22
|
+
}
|
|
23
|
+
export function elementHasUrl(element) {
|
|
24
|
+
return element.props && element.props.url;
|
|
25
|
+
}
|
|
26
|
+
export function elementHasPostback(element) {
|
|
27
|
+
return ((element.props && element.props.payload) ||
|
|
28
|
+
(element.props && element.props.path));
|
|
29
|
+
}
|
|
30
|
+
export function elementHasWebview(element) {
|
|
31
|
+
return element.props && element.props.webview;
|
|
32
|
+
}
|
|
33
|
+
export const buttonTypes = {
|
|
34
|
+
POSTBACK: 'postback',
|
|
35
|
+
URL: 'url',
|
|
36
|
+
WEBVIEW: 'webview',
|
|
37
|
+
};
|
|
38
|
+
export function getButtonType(multichannelButton) {
|
|
39
|
+
if (elementHasUrl(multichannelButton))
|
|
40
|
+
return buttonTypes.URL;
|
|
41
|
+
if (elementHasPostback(multichannelButton))
|
|
42
|
+
return buttonTypes.POSTBACK;
|
|
43
|
+
if (elementHasWebview(multichannelButton))
|
|
44
|
+
return buttonTypes.WEBVIEW;
|
|
45
|
+
return undefined;
|
|
46
|
+
}
|
|
47
|
+
export function getFilteredElements(node, filter) {
|
|
48
|
+
const elements = [];
|
|
49
|
+
for (const n of node) {
|
|
50
|
+
if (filter(n))
|
|
51
|
+
elements.push(n);
|
|
52
|
+
}
|
|
53
|
+
return elements;
|
|
54
|
+
}
|
|
55
|
+
export function getMultichannelButtons(node) {
|
|
56
|
+
return getFilteredElements(node, isMultichannelButton);
|
|
57
|
+
}
|
|
58
|
+
export function getMultichannelReplies(node) {
|
|
59
|
+
return getFilteredElements(node, isMultichannelReply);
|
|
60
|
+
}
|
|
61
|
+
export const isWhatsapp = context => context.session &&
|
|
62
|
+
context.session.user &&
|
|
63
|
+
context.session.user.provider == Providers.Messaging.WHATSAPP;
|
|
64
|
+
export const isFacebook = context => context.session &&
|
|
65
|
+
context.session.user &&
|
|
66
|
+
context.session.user.provider == Providers.Messaging.FACEBOOK;
|
|
67
|
+
//# 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,67 @@
|
|
|
1
|
+
import React, { useContext } from 'react';
|
|
2
|
+
import { COMPONENT_TYPE } from '../../constants';
|
|
3
|
+
import { RequestContext } from '../../contexts';
|
|
4
|
+
import { deepMapWithIndex } from '../../util/react';
|
|
5
|
+
import { Text } from '../text';
|
|
6
|
+
import { MultichannelButton } from './multichannel-button';
|
|
7
|
+
import { MultichannelCarousel } from './multichannel-carousel';
|
|
8
|
+
import { MultichannelContext } from './multichannel-context';
|
|
9
|
+
import { MultichannelReply } from './multichannel-reply';
|
|
10
|
+
import { MultichannelText } from './multichannel-text';
|
|
11
|
+
import { isFacebook, isWhatsapp, MULTICHANNEL_WHATSAPP_PROPS, } from './multichannel-utils';
|
|
12
|
+
export const Multichannel = props => {
|
|
13
|
+
const requestContext = useContext(RequestContext);
|
|
14
|
+
if (!isWhatsapp(requestContext) && !isFacebook(requestContext)) {
|
|
15
|
+
return props.children;
|
|
16
|
+
}
|
|
17
|
+
if (isFacebook(requestContext)) {
|
|
18
|
+
const newChildren = deepMapWithIndex(props.children, child => {
|
|
19
|
+
if (child && child.type && child.type.name === COMPONENT_TYPE.TEXT) {
|
|
20
|
+
return (<MultichannelText {...child.props} key={child.key}>
|
|
21
|
+
{child.props.children}
|
|
22
|
+
</MultichannelText>);
|
|
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 (<MultichannelButton {...child.props} key={child.key}>
|
|
31
|
+
{child.props.children}
|
|
32
|
+
</MultichannelButton>);
|
|
33
|
+
}
|
|
34
|
+
if (child && child.type && child.type.name === COMPONENT_TYPE.REPLY) {
|
|
35
|
+
return (<MultichannelReply {...child.props} key={child.key}>
|
|
36
|
+
{child.props.children}
|
|
37
|
+
</MultichannelReply>);
|
|
38
|
+
}
|
|
39
|
+
if (child && child.type && child.type.name === COMPONENT_TYPE.TEXT) {
|
|
40
|
+
return (<MultichannelText {...child.props} {...props.text} key={child.key} {...(props.messageSeparator &&
|
|
41
|
+
index > 0 && { newline: props.messageSeparator })}>
|
|
42
|
+
{child.props.children}
|
|
43
|
+
</MultichannelText>);
|
|
44
|
+
}
|
|
45
|
+
if (child && child.type && child.type.name === COMPONENT_TYPE.CAROUSEL) {
|
|
46
|
+
return (<MultichannelCarousel {...child.props} {...props.carousel} key={child.key}>
|
|
47
|
+
{child.props.children}
|
|
48
|
+
</MultichannelCarousel>);
|
|
49
|
+
}
|
|
50
|
+
return child;
|
|
51
|
+
});
|
|
52
|
+
if (props.messageSeparator != null) {
|
|
53
|
+
newChildren = newChildren.map((c, index) => index > 0 && typeof c === 'string' ? props.messageSeparator + c : c);
|
|
54
|
+
newChildren = (<Text key={props.key} {...MULTICHANNEL_WHATSAPP_PROPS}>
|
|
55
|
+
{newChildren}
|
|
56
|
+
</Text>);
|
|
57
|
+
}
|
|
58
|
+
return (<MultichannelContext.Provider value={{
|
|
59
|
+
currentIndex: props.firstIndex,
|
|
60
|
+
boldIndex: props.boldIndex,
|
|
61
|
+
indexSeparator: props.indexSeparator,
|
|
62
|
+
messageSeparator: props.messageSeparator,
|
|
63
|
+
}}>
|
|
64
|
+
{newChildren}
|
|
65
|
+
</MultichannelContext.Provider>);
|
|
66
|
+
};
|
|
67
|
+
//# sourceMappingURL=multichannel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"multichannel.js","sourceRoot":"src/","sources":["components/multichannel/multichannel.jsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AAEzC,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAA;AAChD,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAC/C,OAAO,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAA;AACnD,OAAO,EAAE,IAAI,EAAE,MAAM,SAAS,CAAA;AAC9B,OAAO,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAA;AAC1D,OAAO,EAAE,oBAAoB,EAAE,MAAM,yBAAyB,CAAA;AAC9D,OAAO,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAA;AAC5D,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAA;AACxD,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAA;AACtD,OAAO,EACL,UAAU,EACV,UAAU,EACV,2BAA2B,GAC5B,MAAM,sBAAsB,CAAA;AAE7B,MAAM,CAAC,MAAM,YAAY,GAAG,KAAK,CAAC,EAAE;IAClC,MAAM,cAAc,GAAG,UAAU,CAAC,cAAc,CAAC,CAAA;IAEjD,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC,EAAE;QAC9D,OAAO,KAAK,CAAC,QAAQ,CAAA;KACtB;IACD,IAAI,UAAU,CAAC,cAAc,CAAC,EAAE;QAC9B,MAAM,WAAW,GAAG,gBAAgB,CAAC,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,EAAE;YAC3D,IAAI,KAAK,IAAI,KAAK,CAAC,IAAI,IAAI,KAAK,CAAC,IAAI,CAAC,IAAI,KAAK,cAAc,CAAC,IAAI,EAAE;gBAClE,OAAO,CACL,CAAC,gBAAgB,CAAC,IAAI,KAAK,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAChD;YAAA,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,CACvB;UAAA,EAAE,gBAAgB,CAAC,CACpB,CAAA;aACF;YACD,OAAO,KAAK,CAAA;QACd,CAAC,CAAC,CAAA;QACF,OAAO,WAAW,CAAA;KACnB;IAED,IAAI,WAAW,GAAG,gBAAgB,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE;QAClE,IAAI,KAAK,IAAI,KAAK,CAAC,IAAI,IAAI,KAAK,CAAC,IAAI,CAAC,IAAI,KAAK,cAAc,CAAC,MAAM,EAAE;YACpE,OAAO,CACL,CAAC,kBAAkB,CAAC,IAAI,KAAK,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAClD;UAAA,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,CACvB;QAAA,EAAE,kBAAkB,CAAC,CACtB,CAAA;SACF;QACD,IAAI,KAAK,IAAI,KAAK,CAAC,IAAI,IAAI,KAAK,CAAC,IAAI,CAAC,IAAI,KAAK,cAAc,CAAC,KAAK,EAAE;YACnE,OAAO,CACL,CAAC,iBAAiB,CAAC,IAAI,KAAK,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CACjD;UAAA,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,CACvB;QAAA,EAAE,iBAAiB,CAAC,CACrB,CAAA;SACF;QACD,IAAI,KAAK,IAAI,KAAK,CAAC,IAAI,IAAI,KAAK,CAAC,IAAI,CAAC,IAAI,KAAK,cAAc,CAAC,IAAI,EAAE;YAClE,OAAO,CACL,CAAC,gBAAgB,CACf,IAAI,KAAK,CAAC,KAAK,CAAC,CAChB,IAAI,KAAK,CAAC,IAAI,CAAC,CACf,GAAG,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CACf,IAAI,CAAC,KAAK,CAAC,gBAAgB;gBACzB,KAAK,GAAG,CAAC,IAAI,EAAE,OAAO,EAAE,KAAK,CAAC,gBAAgB,EAAE,CAAC,CAAC,CAEpD;UAAA,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,CACvB;QAAA,EAAE,gBAAgB,CAAC,CACpB,CAAA;SACF;QACD,IAAI,KAAK,IAAI,KAAK,CAAC,IAAI,IAAI,KAAK,CAAC,IAAI,CAAC,IAAI,KAAK,cAAc,CAAC,QAAQ,EAAE;YACtE,OAAO,CACL,CAAC,oBAAoB,CACnB,IAAI,KAAK,CAAC,KAAK,CAAC,CAChB,IAAI,KAAK,CAAC,QAAQ,CAAC,CACnB,GAAG,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAEf;UAAA,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,CACvB;QAAA,EAAE,oBAAoB,CAAC,CACxB,CAAA;SACF;QACD,OAAO,KAAK,CAAA;IACd,CAAC,CAAC,CAAA;IACF,IAAI,KAAK,CAAC,gBAAgB,IAAI,IAAI,EAAE;QAClC,WAAW,GAAG,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,CACzC,KAAK,GAAG,CAAC,IAAI,OAAO,CAAC,KAAK,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,gBAAgB,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CACpE,CAAA;QACD,WAAW,GAAG,CACZ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,2BAA2B,CAAC,CACpD;QAAA,CAAC,WAAW,CACd;MAAA,EAAE,IAAI,CAAC,CACR,CAAA;KACF;IACD,OAAO,CACL,CAAC,mBAAmB,CAAC,QAAQ,CAC3B,KAAK,CAAC,CAAC;YACL,YAAY,EAAE,KAAK,CAAC,UAAU;YAC9B,SAAS,EAAE,KAAK,CAAC,SAAS;YAC1B,cAAc,EAAE,KAAK,CAAC,cAAc;YACpC,gBAAgB,EAAE,KAAK,CAAC,gBAAgB;SACzC,CAAC,CAEF;MAAA,CAAC,WAAW,CACd;IAAA,EAAE,mBAAmB,CAAC,QAAQ,CAAC,CAChC,CAAA;AACH,CAAC,CAAA"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import styled from 'styled-components';
|
|
3
|
+
import { COLORS, WEBCHAT } from '../constants';
|
|
4
|
+
import { staticAsset } from '../util/environment';
|
|
5
|
+
import { renderComponent } from '../util/react';
|
|
6
|
+
const PicStyled = styled.img `
|
|
7
|
+
border-top-left-radius: 8px;
|
|
8
|
+
border-top-right-radius: 8px;
|
|
9
|
+
width: ${WEBCHAT.DEFAULTS.ELEMENT_WIDTH}px;
|
|
10
|
+
height: 140px;
|
|
11
|
+
background: ${COLORS.SOLID_WHITE} url(${props => props.src}) no-repeat
|
|
12
|
+
center/cover;
|
|
13
|
+
border-bottom: 1px solid ${COLORS.SEASHELL_WHITE};
|
|
14
|
+
`;
|
|
15
|
+
export const Pic = props => {
|
|
16
|
+
props = Object.assign(Object.assign({}, props), { src: staticAsset(props.src) });
|
|
17
|
+
const renderBrowser = () => <PicStyled src={props.src}/>;
|
|
18
|
+
const renderNode = () => <pic>{props.src}</pic>;
|
|
19
|
+
return renderComponent({ renderBrowser, renderNode });
|
|
20
|
+
};
|
|
21
|
+
Pic.serialize = picProps => {
|
|
22
|
+
return { pic: picProps.src };
|
|
23
|
+
};
|
|
24
|
+
//# 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,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,EAAG,CAAA;IACzD,MAAM,UAAU,GAAG,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,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"}
|