@botonic/react 0.21.6 → 0.21.7-alpha.0
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.d.ts +2 -0
- package/lib/cjs/app.js +10 -0
- package/lib/cjs/app.js.map +1 -0
- package/lib/cjs/botonic-tester.d.ts +18 -0
- package/lib/cjs/botonic-tester.js +70 -0
- package/lib/cjs/botonic-tester.js.map +1 -0
- package/lib/cjs/components/audio.d.ts +8 -0
- package/lib/cjs/components/audio.js +27 -0
- package/lib/cjs/components/audio.js.map +1 -0
- package/lib/cjs/components/button.d.ts +15 -0
- package/lib/cjs/components/button.js +156 -0
- package/lib/cjs/components/button.js.map +1 -0
- package/lib/cjs/components/buttons-disabler.d.ts +24 -0
- package/lib/cjs/components/buttons-disabler.js +88 -0
- package/lib/cjs/components/buttons-disabler.js.map +1 -0
- package/lib/cjs/components/carousel.d.ts +9 -0
- package/lib/cjs/components/carousel.js +120 -0
- package/lib/cjs/components/carousel.js.map +1 -0
- package/lib/cjs/components/components.d.ts +12 -0
- package/lib/{components → cjs/components}/components.js +6 -11
- package/lib/cjs/components/components.js.map +1 -0
- package/lib/cjs/components/custom-message.d.ts +10 -0
- package/lib/cjs/components/custom-message.js +65 -0
- package/lib/cjs/components/custom-message.js.map +1 -0
- package/lib/cjs/components/document.d.ts +8 -0
- package/lib/cjs/components/document.js +50 -0
- package/lib/cjs/components/document.js.map +1 -0
- package/lib/cjs/components/element.d.ts +4 -0
- package/lib/cjs/components/element.js +55 -0
- package/lib/cjs/components/element.js.map +1 -0
- package/lib/cjs/components/handoff.d.ts +1 -0
- package/lib/cjs/components/handoff.js +58 -0
- package/lib/cjs/components/handoff.js.map +1 -0
- package/lib/cjs/components/image.d.ts +8 -0
- package/lib/cjs/components/image.js +42 -0
- package/lib/cjs/components/image.js.map +1 -0
- package/lib/cjs/components/index.d.ts +1 -0
- package/lib/cjs/components/index.js +44 -0
- package/lib/cjs/components/index.js.map +1 -0
- package/lib/cjs/components/location.d.ts +11 -0
- package/lib/cjs/components/location.js +38 -0
- package/lib/cjs/components/location.js.map +1 -0
- package/lib/cjs/components/markdown.d.ts +7 -0
- package/lib/cjs/components/markdown.js +162 -0
- package/lib/cjs/components/markdown.js.map +1 -0
- package/lib/cjs/components/message-template.d.ts +1 -0
- package/lib/cjs/components/message-template.js +15 -0
- package/lib/cjs/components/message-template.js.map +1 -0
- package/lib/cjs/components/message.d.ts +1 -0
- package/lib/cjs/components/message.js +206 -0
- package/lib/cjs/components/message.js.map +1 -0
- package/lib/cjs/components/multichannel/facebook/facebook.d.ts +17 -0
- package/lib/cjs/components/multichannel/facebook/facebook.js +47 -0
- package/lib/cjs/components/multichannel/facebook/facebook.js.map +1 -0
- package/lib/cjs/components/multichannel/index.d.ts +1 -0
- package/lib/cjs/components/multichannel/index.js +14 -0
- package/lib/cjs/components/multichannel/index.js.map +1 -0
- package/lib/cjs/components/multichannel/multichannel-button.d.ts +1 -0
- package/lib/cjs/components/multichannel/multichannel-button.js +77 -0
- package/lib/cjs/components/multichannel/multichannel-button.js.map +1 -0
- package/lib/cjs/components/multichannel/multichannel-carousel.d.ts +1 -0
- package/lib/cjs/components/multichannel/multichannel-carousel.js +95 -0
- package/lib/cjs/components/multichannel/multichannel-carousel.js.map +1 -0
- package/lib/cjs/components/multichannel/multichannel-context.d.ts +11 -0
- package/lib/cjs/components/multichannel/multichannel-context.js +16 -0
- package/lib/cjs/components/multichannel/multichannel-context.js.map +1 -0
- package/lib/cjs/components/multichannel/multichannel-reply.d.ts +1 -0
- package/lib/cjs/components/multichannel/multichannel-reply.js +24 -0
- package/lib/cjs/components/multichannel/multichannel-reply.js.map +1 -0
- package/lib/cjs/components/multichannel/multichannel-text.d.ts +1 -0
- package/lib/cjs/components/multichannel/multichannel-text.js +147 -0
- package/lib/cjs/components/multichannel/multichannel-text.js.map +1 -0
- package/lib/cjs/components/multichannel/multichannel-utils.d.ts +24 -0
- package/lib/cjs/components/multichannel/multichannel-utils.js +83 -0
- package/lib/cjs/components/multichannel/multichannel-utils.js.map +1 -0
- package/lib/cjs/components/multichannel/multichannel.d.ts +1 -0
- package/lib/cjs/components/multichannel/multichannel.js +72 -0
- package/lib/cjs/components/multichannel/multichannel.js.map +1 -0
- package/lib/cjs/components/pic.d.ts +6 -0
- package/lib/cjs/components/pic.js +29 -0
- package/lib/cjs/components/pic.js.map +1 -0
- package/lib/cjs/components/raw.d.ts +9 -0
- package/lib/cjs/components/raw.js +53 -0
- package/lib/cjs/components/raw.js.map +1 -0
- package/lib/cjs/components/reply.d.ts +9 -0
- package/lib/cjs/components/reply.js +57 -0
- package/lib/cjs/components/reply.js.map +1 -0
- package/lib/cjs/components/share-button.d.ts +1 -0
- package/lib/cjs/components/share-button.js +15 -0
- package/lib/cjs/components/share-button.js.map +1 -0
- package/lib/cjs/components/subtitle.d.ts +6 -0
- package/lib/cjs/components/subtitle.js +25 -0
- package/lib/cjs/components/subtitle.js.map +1 -0
- package/lib/cjs/components/text.d.ts +8 -0
- package/lib/cjs/components/text.js +50 -0
- package/lib/cjs/components/text.js.map +1 -0
- package/lib/cjs/components/timestamps.d.ts +10 -0
- package/lib/cjs/components/timestamps.js +54 -0
- package/lib/cjs/components/timestamps.js.map +1 -0
- package/lib/cjs/components/title.d.ts +6 -0
- package/lib/cjs/components/title.js +21 -0
- package/lib/cjs/components/title.js.map +1 -0
- package/lib/cjs/components/video.d.ts +8 -0
- package/lib/cjs/components/video.js +34 -0
- package/lib/cjs/components/video.js.map +1 -0
- package/lib/cjs/components/webchat-settings.d.ts +10 -0
- package/lib/cjs/components/webchat-settings.js +78 -0
- package/lib/cjs/components/webchat-settings.js.map +1 -0
- package/lib/cjs/components/whatsapp-template.d.ts +1 -0
- package/lib/cjs/components/whatsapp-template.js +26 -0
- package/lib/cjs/components/whatsapp-template.js.map +1 -0
- package/lib/cjs/constants.d.ts +168 -0
- package/lib/cjs/constants.js +190 -0
- package/lib/cjs/constants.js.map +1 -0
- package/lib/cjs/contexts.d.ts +69 -0
- package/lib/cjs/contexts.js +38 -0
- package/lib/cjs/contexts.js.map +1 -0
- package/lib/cjs/dev-app.d.ts +34 -0
- package/lib/cjs/dev-app.js +71 -0
- package/lib/cjs/dev-app.js.map +1 -0
- package/lib/cjs/index.d.ts +3 -0
- package/lib/cjs/index.js +28 -0
- package/lib/cjs/index.js.map +1 -0
- package/lib/cjs/message-utils.d.ts +18 -0
- package/lib/cjs/message-utils.js +61 -0
- package/lib/cjs/message-utils.js.map +1 -0
- package/lib/cjs/msg-to-botonic.d.ts +18 -0
- package/lib/cjs/msg-to-botonic.js +160 -0
- package/lib/cjs/msg-to-botonic.js.map +1 -0
- package/lib/cjs/node-app.d.ts +11 -0
- package/lib/cjs/node-app.js +25 -0
- package/lib/cjs/node-app.js.map +1 -0
- package/lib/cjs/react-bot.d.ts +8 -0
- package/lib/cjs/react-bot.js +35 -0
- package/lib/cjs/react-bot.js.map +1 -0
- package/lib/cjs/util/dom.d.ts +13 -0
- package/lib/cjs/util/dom.js +55 -0
- package/lib/cjs/util/dom.js.map +1 -0
- package/lib/cjs/util/environment.d.ts +6 -0
- package/lib/cjs/util/environment.js +68 -0
- package/lib/cjs/util/environment.js.map +1 -0
- package/lib/cjs/util/error-boundary.js +47 -0
- package/lib/cjs/util/error-boundary.js.map +1 -0
- package/lib/cjs/util/index.d.ts +0 -0
- package/lib/cjs/util/index.js +2 -0
- package/lib/cjs/util/index.js.map +1 -0
- package/lib/cjs/util/logs.d.ts +2 -0
- package/lib/cjs/util/logs.js +20 -0
- package/lib/cjs/util/logs.js.map +1 -0
- package/lib/cjs/util/objects.d.ts +3 -0
- package/lib/cjs/util/objects.js +44 -0
- package/lib/cjs/util/objects.js.map +1 -0
- package/lib/cjs/util/react.d.ts +12 -0
- package/lib/cjs/util/react.js +42 -0
- package/lib/cjs/util/react.js.map +1 -0
- package/lib/cjs/util/regexs.d.ts +2 -0
- package/lib/cjs/util/regexs.js +23 -0
- package/lib/cjs/util/regexs.js.map +1 -0
- package/lib/cjs/util/webchat.d.ts +11 -0
- package/lib/cjs/util/webchat.js +62 -0
- package/lib/cjs/util/webchat.js.map +1 -0
- package/lib/cjs/webchat/actions.d.ts +23 -0
- package/lib/cjs/webchat/actions.js +27 -0
- package/lib/cjs/webchat/actions.js.map +1 -0
- package/lib/cjs/webchat/components/attachment.d.ts +5 -0
- package/lib/cjs/webchat/components/attachment.js +32 -0
- package/lib/cjs/webchat/components/attachment.js.map +1 -0
- package/lib/cjs/webchat/components/common.d.ts +1 -0
- package/lib/cjs/webchat/components/common.js +13 -0
- package/lib/cjs/webchat/components/common.js.map +1 -0
- package/lib/cjs/webchat/components/conditional-animation.d.ts +1 -0
- package/lib/cjs/webchat/components/conditional-animation.js +18 -0
- package/lib/cjs/webchat/components/conditional-animation.js.map +1 -0
- package/lib/cjs/webchat/components/emoji-picker.d.ts +5 -0
- package/lib/cjs/webchat/components/emoji-picker.js +52 -0
- package/lib/cjs/webchat/components/emoji-picker.js.map +1 -0
- package/lib/cjs/webchat/components/persistent-menu.d.ts +10 -0
- package/lib/cjs/webchat/components/persistent-menu.js +59 -0
- package/lib/cjs/webchat/components/persistent-menu.js.map +1 -0
- package/lib/cjs/webchat/components/send-button.d.ts +3 -0
- package/lib/cjs/webchat/components/send-button.js +24 -0
- package/lib/cjs/webchat/components/send-button.js.map +1 -0
- package/lib/cjs/webchat/components/styled-scrollbar.d.ts +1 -0
- package/lib/cjs/webchat/components/styled-scrollbar.js +54 -0
- package/lib/cjs/webchat/components/styled-scrollbar.js.map +1 -0
- package/lib/cjs/webchat/components/typing-indicator.d.ts +1 -0
- package/lib/cjs/webchat/components/typing-indicator.js +14 -0
- package/lib/cjs/webchat/components/typing-indicator.js.map +1 -0
- package/lib/cjs/webchat/devices/device-adapter.d.ts +12 -0
- package/lib/cjs/webchat/devices/device-adapter.js +47 -0
- package/lib/cjs/webchat/devices/device-adapter.js.map +1 -0
- package/lib/cjs/webchat/devices/index.d.ts +11 -0
- package/lib/cjs/webchat/devices/index.js +23 -0
- package/lib/cjs/webchat/devices/index.js.map +1 -0
- package/lib/cjs/webchat/devices/scrollbar-controller.d.ts +12 -0
- package/lib/cjs/webchat/devices/scrollbar-controller.js +103 -0
- package/lib/cjs/webchat/devices/scrollbar-controller.js.map +1 -0
- package/lib/cjs/webchat/devices/webchat-resizer.d.ts +9 -0
- package/lib/cjs/webchat/devices/webchat-resizer.js +47 -0
- package/lib/cjs/webchat/devices/webchat-resizer.js.map +1 -0
- package/lib/cjs/webchat/header.d.ts +3 -0
- package/lib/cjs/webchat/header.js +95 -0
- package/lib/cjs/webchat/header.js.map +1 -0
- package/lib/cjs/webchat/hooks.d.ts +80 -0
- package/lib/cjs/webchat/hooks.js +218 -0
- package/lib/cjs/webchat/hooks.js.map +1 -0
- package/lib/cjs/webchat/index.d.ts +4 -0
- package/lib/cjs/webchat/index.js +17 -0
- package/lib/cjs/webchat/index.js.map +1 -0
- package/lib/cjs/webchat/message-list.d.ts +1 -0
- package/lib/cjs/webchat/message-list.js +46 -0
- package/lib/cjs/webchat/message-list.js.map +1 -0
- package/lib/cjs/webchat/messages-reducer.d.ts +1 -0
- package/lib/cjs/webchat/messages-reducer.js +58 -0
- package/lib/cjs/webchat/messages-reducer.js.map +1 -0
- package/lib/cjs/webchat/replies.d.ts +1 -0
- package/lib/cjs/webchat/replies.js +46 -0
- package/lib/cjs/webchat/replies.js.map +1 -0
- package/lib/cjs/webchat/session-view.d.ts +1 -0
- package/lib/cjs/webchat/session-view.js +124 -0
- package/lib/cjs/webchat/session-view.js.map +1 -0
- package/lib/cjs/webchat/use-storage-state-hook.d.ts +1 -0
- package/lib/cjs/webchat/use-storage-state-hook.js +32 -0
- package/lib/cjs/webchat/use-storage-state-hook.js.map +1 -0
- package/lib/cjs/webchat/webchat-dev.d.ts +7 -0
- package/lib/cjs/webchat/webchat-dev.js +64 -0
- package/lib/cjs/webchat/webchat-dev.js.map +1 -0
- package/lib/cjs/webchat/webchat-reducer.d.ts +1 -0
- package/lib/cjs/webchat/webchat-reducer.js +48 -0
- package/lib/cjs/webchat/webchat-reducer.js.map +1 -0
- package/lib/cjs/webchat/webchat.d.ts +3 -0
- package/lib/cjs/webchat/webchat.js +703 -0
- package/lib/cjs/webchat/webchat.js.map +1 -0
- package/lib/cjs/webchat/webview.d.ts +2 -0
- package/lib/cjs/webchat/webview.js +92 -0
- package/lib/cjs/webchat/webview.js.map +1 -0
- package/lib/cjs/webchat-app.d.ts +99 -0
- package/lib/cjs/webchat-app.js +269 -0
- package/lib/cjs/webchat-app.js.map +1 -0
- package/lib/cjs/webview.d.ts +9 -0
- package/lib/cjs/webview.js +102 -0
- package/lib/cjs/webview.js.map +1 -0
- package/package.json +3 -3
- package/lib/app.js +0 -19
- package/lib/app.js.map +0 -1
- package/lib/assets/attachment-icon.svg +0 -7
- package/lib/assets/audio.svg +0 -4
- package/lib/assets/botonic_react_logo100x100.png +0 -0
- package/lib/assets/document.svg +0 -3
- package/lib/assets/emojiButton.svg +0 -6
- package/lib/assets/image.svg +0 -4
- package/lib/assets/leftArrow.svg +0 -3
- package/lib/assets/menuButton.svg +0 -3
- package/lib/assets/rightArrow.svg +0 -3
- package/lib/assets/send-button.svg +0 -1
- package/lib/assets/video.svg +0 -3
- package/lib/botonic-tester.js +0 -224
- package/lib/botonic-tester.js.map +0 -1
- package/lib/components/audio.js +0 -48
- package/lib/components/audio.js.map +0 -1
- package/lib/components/button.js +0 -224
- package/lib/components/button.js.map +0 -1
- package/lib/components/buttons-disabler.js +0 -133
- package/lib/components/buttons-disabler.js.map +0 -1
- package/lib/components/carousel.js +0 -194
- package/lib/components/carousel.js.map +0 -1
- package/lib/components/components.js.map +0 -1
- package/lib/components/custom-message.js +0 -131
- package/lib/components/custom-message.js.map +0 -1
- package/lib/components/document.js +0 -76
- package/lib/components/document.js.map +0 -1
- package/lib/components/element.js +0 -69
- package/lib/components/element.js.map +0 -1
- package/lib/components/handoff.js +0 -69
- package/lib/components/handoff.js.map +0 -1
- package/lib/components/image.js +0 -91
- package/lib/components/image.js.map +0 -1
- package/lib/components/index.d.ts +0 -228
- package/lib/components/index.js +0 -193
- package/lib/components/index.js.map +0 -1
- package/lib/components/location.js +0 -69
- package/lib/components/location.js.map +0 -1
- package/lib/components/markdown.js +0 -108
- package/lib/components/markdown.js.map +0 -1
- package/lib/components/message-template.js +0 -36
- package/lib/components/message-template.js.map +0 -1
- package/lib/components/message.js +0 -351
- package/lib/components/message.js.map +0 -1
- package/lib/components/multichannel/facebook/facebook.js +0 -96
- package/lib/components/multichannel/facebook/facebook.js.map +0 -1
- package/lib/components/multichannel/index.d.ts +0 -65
- package/lib/components/multichannel/index.js +0 -46
- package/lib/components/multichannel/index.js.map +0 -1
- package/lib/components/multichannel/multichannel-button.js +0 -119
- package/lib/components/multichannel/multichannel-button.js.map +0 -1
- package/lib/components/multichannel/multichannel-carousel.js +0 -143
- package/lib/components/multichannel/multichannel-carousel.js.map +0 -1
- package/lib/components/multichannel/multichannel-context.js +0 -24
- package/lib/components/multichannel/multichannel-context.js.map +0 -1
- package/lib/components/multichannel/multichannel-reply.js +0 -46
- package/lib/components/multichannel/multichannel-reply.js.map +0 -1
- package/lib/components/multichannel/multichannel-text.js +0 -222
- package/lib/components/multichannel/multichannel-text.js.map +0 -1
- package/lib/components/multichannel/multichannel-utils.js +0 -126
- package/lib/components/multichannel/multichannel-utils.js.map +0 -1
- package/lib/components/multichannel/multichannel.js +0 -111
- package/lib/components/multichannel/multichannel.js.map +0 -1
- package/lib/components/pic.js +0 -50
- package/lib/components/pic.js.map +0 -1
- package/lib/components/raw.js +0 -70
- package/lib/components/raw.js.map +0 -1
- package/lib/components/reply.js +0 -107
- package/lib/components/reply.js.map +0 -1
- package/lib/components/share-button.js +0 -36
- package/lib/components/share-button.js.map +0 -1
- package/lib/components/subtitle.js +0 -54
- package/lib/components/subtitle.js.map +0 -1
- package/lib/components/text.js +0 -80
- package/lib/components/text.js.map +0 -1
- package/lib/components/timestamps.js +0 -69
- package/lib/components/timestamps.js.map +0 -1
- package/lib/components/title.js +0 -52
- package/lib/components/title.js.map +0 -1
- package/lib/components/video.js +0 -51
- package/lib/components/video.js.map +0 -1
- package/lib/components/webchat-settings.js +0 -118
- package/lib/components/webchat-settings.js.map +0 -1
- package/lib/components/whatsapp-template.js +0 -53
- package/lib/components/whatsapp-template.js.map +0 -1
- package/lib/constants.js +0 -203
- package/lib/constants.js.map +0 -1
- package/lib/contexts.js +0 -57
- package/lib/contexts.js.map +0 -1
- package/lib/dev-app.js +0 -241
- package/lib/dev-app.js.map +0 -1
- package/lib/index.d.ts +0 -238
- package/lib/index.js +0 -131
- package/lib/index.js.map +0 -1
- package/lib/message-utils.js +0 -149
- package/lib/message-utils.js.map +0 -1
- package/lib/msg-to-botonic.js +0 -199
- package/lib/msg-to-botonic.js.map +0 -1
- package/lib/node-app.js +0 -97
- package/lib/node-app.js.map +0 -1
- package/lib/react-bot.js +0 -167
- package/lib/react-bot.js.map +0 -1
- package/lib/util/dom.js +0 -84
- package/lib/util/dom.js.map +0 -1
- package/lib/util/environment.js +0 -42
- package/lib/util/environment.js.map +0 -1
- package/lib/util/error-boundary.js +0 -105
- package/lib/util/error-boundary.js.map +0 -1
- package/lib/util/index.d.ts +0 -9
- package/lib/util/index.js +0 -2
- package/lib/util/index.js.map +0 -1
- package/lib/util/logs.js +0 -28
- package/lib/util/logs.js.map +0 -1
- package/lib/util/objects.js +0 -60
- package/lib/util/objects.js.map +0 -1
- package/lib/util/react.js +0 -75
- package/lib/util/react.js.map +0 -1
- package/lib/util/regexs.js +0 -31
- package/lib/util/regexs.js.map +0 -1
- package/lib/util/webchat.js +0 -92
- package/lib/util/webchat.js.map +0 -1
- package/lib/webchat/actions.js +0 -53
- package/lib/webchat/actions.js.map +0 -1
- package/lib/webchat/components/attachment.js +0 -68
- package/lib/webchat/components/attachment.js.map +0 -1
- package/lib/webchat/components/common.js +0 -29
- package/lib/webchat/components/common.js.map +0 -1
- package/lib/webchat/components/conditional-animation.js +0 -42
- package/lib/webchat/components/conditional-animation.js.map +0 -1
- package/lib/webchat/components/emoji-picker.js +0 -89
- package/lib/webchat/components/emoji-picker.js.map +0 -1
- package/lib/webchat/components/persistent-menu.js +0 -104
- package/lib/webchat/components/persistent-menu.js.map +0 -1
- package/lib/webchat/components/send-button.js +0 -45
- package/lib/webchat/components/send-button.js.map +0 -1
- package/lib/webchat/components/styled-scrollbar.js +0 -55
- package/lib/webchat/components/styled-scrollbar.js.map +0 -1
- package/lib/webchat/components/styled-scrollbar.scss +0 -12
- package/lib/webchat/components/typing-indicator.js +0 -27
- package/lib/webchat/components/typing-indicator.js.map +0 -1
- package/lib/webchat/components/typing-indicator.scss +0 -38
- package/lib/webchat/devices/device-adapter.js +0 -82
- package/lib/webchat/devices/device-adapter.js.map +0 -1
- package/lib/webchat/devices/index.js +0 -32
- package/lib/webchat/devices/index.js.map +0 -1
- package/lib/webchat/devices/scrollbar-controller.js +0 -152
- package/lib/webchat/devices/scrollbar-controller.js.map +0 -1
- package/lib/webchat/devices/webchat-resizer.js +0 -76
- package/lib/webchat/devices/webchat-resizer.js.map +0 -1
- package/lib/webchat/header.js +0 -116
- package/lib/webchat/header.js.map +0 -1
- package/lib/webchat/hooks.js +0 -359
- package/lib/webchat/hooks.js.map +0 -1
- package/lib/webchat/index.d.ts +0 -62
- package/lib/webchat/index.js +0 -32
- package/lib/webchat/index.js.map +0 -1
- package/lib/webchat/message-list.js +0 -88
- package/lib/webchat/message-list.js.map +0 -1
- package/lib/webchat/messages-reducer.js +0 -93
- package/lib/webchat/messages-reducer.js.map +0 -1
- package/lib/webchat/replies.js +0 -78
- package/lib/webchat/replies.js.map +0 -1
- package/lib/webchat/session-view.js +0 -106
- package/lib/webchat/session-view.js.map +0 -1
- package/lib/webchat/use-storage-state-hook.js +0 -60
- package/lib/webchat/use-storage-state-hook.js.map +0 -1
- package/lib/webchat/webchat-dev.js +0 -109
- package/lib/webchat/webchat-dev.js.map +0 -1
- package/lib/webchat/webchat-reducer.js +0 -108
- package/lib/webchat/webchat-reducer.js.map +0 -1
- package/lib/webchat/webchat.js +0 -1108
- package/lib/webchat/webchat.js.map +0 -1
- package/lib/webchat/webview.js +0 -122
- package/lib/webchat/webview.js.map +0 -1
- package/lib/webchat-app.js +0 -660
- package/lib/webchat-app.js.map +0 -1
- package/lib/webchat.template.html +0 -37
- package/lib/webview.js +0 -231
- package/lib/webview.js.map +0 -1
- package/lib/webview.template.html +0 -39
|
@@ -0,0 +1,147 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.MultichannelText = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const react_1 = tslib_1.__importStar(require("react"));
|
|
6
|
+
const contexts_1 = require("../../contexts");
|
|
7
|
+
const text_1 = require("../text");
|
|
8
|
+
const facebook_1 = require("./facebook/facebook");
|
|
9
|
+
const multichannel_button_1 = require("./multichannel-button");
|
|
10
|
+
const multichannel_context_1 = require("./multichannel-context");
|
|
11
|
+
const multichannel_utils_1 = require("./multichannel-utils");
|
|
12
|
+
const MultichannelText = props => {
|
|
13
|
+
var _a;
|
|
14
|
+
const requestContext = react_1.useContext(contexts_1.RequestContext);
|
|
15
|
+
const multichannelContext = react_1.useContext(multichannel_context_1.MultichannelContext);
|
|
16
|
+
const postbackButtonsAsText = (_a = props.buttonsAsText) !== null && _a !== void 0 ? _a : true;
|
|
17
|
+
let elements = [];
|
|
18
|
+
const getText = children => {
|
|
19
|
+
children = Array.isArray(children) ? children : [children];
|
|
20
|
+
const text = children
|
|
21
|
+
.filter(e => e && !e.type)
|
|
22
|
+
.map(e => {
|
|
23
|
+
if (Array.isArray(e))
|
|
24
|
+
return getText(e);
|
|
25
|
+
else
|
|
26
|
+
return String(e);
|
|
27
|
+
})
|
|
28
|
+
.join('');
|
|
29
|
+
if (text == undefined) {
|
|
30
|
+
return [];
|
|
31
|
+
}
|
|
32
|
+
return [text].filter(t => t !== ''); // to avoid line breaks when the carousel doesn't have title or subtitle
|
|
33
|
+
};
|
|
34
|
+
const getButtonsAndReplies = () => [].concat(multichannel_utils_1.getMultichannelButtons(react_1.default.Children.toArray(props.children)), multichannel_utils_1.getMultichannelReplies(react_1.default.Children.toArray(props.children)));
|
|
35
|
+
const getWhatsappButtons = () => {
|
|
36
|
+
const postbackButtons = [];
|
|
37
|
+
const urlButtons = [];
|
|
38
|
+
const webviewButtons = [];
|
|
39
|
+
for (const button of getButtonsAndReplies()) {
|
|
40
|
+
if (multichannel_utils_1.elementHasUrl(button))
|
|
41
|
+
urlButtons.push(button);
|
|
42
|
+
if (multichannel_utils_1.elementHasPostback(button))
|
|
43
|
+
postbackButtons.push(button);
|
|
44
|
+
if (multichannel_utils_1.elementHasWebview(button))
|
|
45
|
+
webviewButtons.push(button);
|
|
46
|
+
}
|
|
47
|
+
return { postbackButtons, urlButtons, webviewButtons };
|
|
48
|
+
};
|
|
49
|
+
const getDefaultIndex = () => {
|
|
50
|
+
if (props.indexMode == undefined) {
|
|
51
|
+
return undefined;
|
|
52
|
+
}
|
|
53
|
+
if (multichannelContext.currentIndex != null) {
|
|
54
|
+
return multichannelContext.currentIndex;
|
|
55
|
+
}
|
|
56
|
+
return props.indexMode === 'letter' ? 'a' : 1;
|
|
57
|
+
};
|
|
58
|
+
const regenerateMultichannelButtons = (newLineFirstButton = true) => {
|
|
59
|
+
const generator = (multichannelButton, i) => {
|
|
60
|
+
const type = multichannel_utils_1.getButtonType(multichannelButton);
|
|
61
|
+
const asText = type === multichannel_utils_1.buttonTypes.POSTBACK ? postbackButtonsAsText : true;
|
|
62
|
+
const newline = multichannelContext.messageSeparator == null &&
|
|
63
|
+
!newLineFirstButton &&
|
|
64
|
+
i === 0
|
|
65
|
+
? ''
|
|
66
|
+
: '\n';
|
|
67
|
+
return (<multichannel_button_1.MultichannelButton key={`${type}${i}`} newline={newline} asText={asText} {...multichannelButton.props}>
|
|
68
|
+
{multichannelButton.props.children}
|
|
69
|
+
</multichannel_button_1.MultichannelButton>);
|
|
70
|
+
};
|
|
71
|
+
return generator;
|
|
72
|
+
};
|
|
73
|
+
const splitPostbackButtons = postbackButtons => {
|
|
74
|
+
const messages = [];
|
|
75
|
+
for (let i = 0; i < postbackButtons.length; i += multichannel_utils_1.WHATSAPP_MAX_BUTTONS) {
|
|
76
|
+
messages.push(postbackButtons.slice(i, i + multichannel_utils_1.WHATSAPP_MAX_BUTTONS));
|
|
77
|
+
}
|
|
78
|
+
return messages;
|
|
79
|
+
};
|
|
80
|
+
if (multichannel_utils_1.isWhatsapp(requestContext)) {
|
|
81
|
+
const texts = getText(props.children);
|
|
82
|
+
const { postbackButtons, urlButtons, webviewButtons } = getWhatsappButtons();
|
|
83
|
+
const textElements = texts.map(text => {
|
|
84
|
+
return (props.newline || '') + text;
|
|
85
|
+
});
|
|
86
|
+
const webviewButtonElements = webviewButtons.map(regenerateMultichannelButtons(false));
|
|
87
|
+
const buttonsTextSeparator = props.buttonsTextSeparator || multichannel_utils_1.DEFAULT_WHATSAPP_MAX_BUTTON_SEPARATOR;
|
|
88
|
+
if (!postbackButtonsAsText &&
|
|
89
|
+
postbackButtons.length > multichannel_utils_1.WHATSAPP_MAX_BUTTONS) {
|
|
90
|
+
const urlButtonElements = urlButtons.map(regenerateMultichannelButtons(!!texts.length));
|
|
91
|
+
const postbackButtonElements = postbackButtons.map(regenerateMultichannelButtons(!!texts.length || !!urlButtons.length));
|
|
92
|
+
const messagesPostbackButtons = splitPostbackButtons(postbackButtonElements);
|
|
93
|
+
const messages = messagesPostbackButtons.map((postbackButtons, i) => {
|
|
94
|
+
if (i === 0) {
|
|
95
|
+
return [].concat(...textElements, ...urlButtonElements, ...postbackButtons);
|
|
96
|
+
}
|
|
97
|
+
else {
|
|
98
|
+
return [].concat(buttonsTextSeparator, ...postbackButtons);
|
|
99
|
+
}
|
|
100
|
+
});
|
|
101
|
+
if (webviewButtonElements.length) {
|
|
102
|
+
messages.push([buttonsTextSeparator, ...webviewButtonElements]);
|
|
103
|
+
}
|
|
104
|
+
return (<>
|
|
105
|
+
{messages.map((message, i) => (<text_1.Text key={i} {...multichannel_utils_1.MULTICHANNEL_WHATSAPP_PROPS} {...props}>
|
|
106
|
+
{message}
|
|
107
|
+
</text_1.Text>))}
|
|
108
|
+
</>);
|
|
109
|
+
}
|
|
110
|
+
multichannelContext.currentIndex = getDefaultIndex();
|
|
111
|
+
const postbackButtonElements = postbackButtons.map(regenerateMultichannelButtons(!!texts.length));
|
|
112
|
+
const urlButtonElements = urlButtons.map(regenerateMultichannelButtons(!!texts.length || !!postbackButtons.length));
|
|
113
|
+
elements = [].concat([...textElements], [...postbackButtonElements], [...urlButtonElements]);
|
|
114
|
+
if (multichannelContext.messageSeparator != null) {
|
|
115
|
+
return elements;
|
|
116
|
+
}
|
|
117
|
+
const messages = [
|
|
118
|
+
<text_1.Text key={0} {...multichannel_utils_1.MULTICHANNEL_WHATSAPP_PROPS} {...props}>
|
|
119
|
+
{elements}
|
|
120
|
+
</text_1.Text>,
|
|
121
|
+
];
|
|
122
|
+
if (webviewButtonElements.length) {
|
|
123
|
+
messages.push(<text_1.Text key={1} {...multichannel_utils_1.MULTICHANNEL_WHATSAPP_PROPS} {...props}>
|
|
124
|
+
{buttonsTextSeparator}
|
|
125
|
+
{webviewButtonElements}
|
|
126
|
+
</text_1.Text>);
|
|
127
|
+
}
|
|
128
|
+
return <>{messages}</>;
|
|
129
|
+
}
|
|
130
|
+
if (multichannel_utils_1.isFacebook(requestContext)) {
|
|
131
|
+
const text = getText(props.children);
|
|
132
|
+
const multichannelFacebook = new facebook_1.MultichannelFacebook();
|
|
133
|
+
const { texts, propsLastText, propsWithoutChildren, } = multichannelFacebook.convertText(props, text[0]);
|
|
134
|
+
return (<>
|
|
135
|
+
{texts &&
|
|
136
|
+
texts.map((e, i) => (<text_1.Text key={i} {...propsWithoutChildren}>
|
|
137
|
+
{e}
|
|
138
|
+
</text_1.Text>))}
|
|
139
|
+
<text_1.Text {...propsLastText}>{propsLastText.children}</text_1.Text>
|
|
140
|
+
</>);
|
|
141
|
+
}
|
|
142
|
+
else {
|
|
143
|
+
return <text_1.Text {...props}>{props.children}</text_1.Text>;
|
|
144
|
+
}
|
|
145
|
+
};
|
|
146
|
+
exports.MultichannelText = MultichannelText;
|
|
147
|
+
//# sourceMappingURL=multichannel-text.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"multichannel-text.js","sourceRoot":"","sources":["../../../../src/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,83 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.isFacebook = exports.isWhatsapp = exports.getMultichannelReplies = exports.getMultichannelButtons = exports.getFilteredElements = exports.getButtonType = exports.buttonTypes = exports.elementHasWebview = exports.elementHasPostback = exports.elementHasUrl = exports.isNodeKind = exports.isButton = exports.isMultichannelReply = exports.isMultichannelButton = exports.DEFAULT_WHATSAPP_MAX_BUTTON_SEPARATOR = exports.WHATSAPP_MAX_BUTTON_CHARS = exports.WHATSAPP_MAX_BUTTONS = exports.MULTICHANNEL_WHATSAPP_PROPS = void 0;
|
|
4
|
+
const core_1 = require("@botonic/core");
|
|
5
|
+
/**
|
|
6
|
+
*
|
|
7
|
+
* Whatsapp does not support Markdown
|
|
8
|
+
* (its markup syntax is different)
|
|
9
|
+
*/
|
|
10
|
+
exports.MULTICHANNEL_WHATSAPP_PROPS = { markdown: false };
|
|
11
|
+
exports.WHATSAPP_MAX_BUTTONS = 3;
|
|
12
|
+
exports.WHATSAPP_MAX_BUTTON_CHARS = 20;
|
|
13
|
+
exports.DEFAULT_WHATSAPP_MAX_BUTTON_SEPARATOR = 'More options:';
|
|
14
|
+
function isMultichannelButton(node) {
|
|
15
|
+
return isNodeKind(node, 'MultichannelButton');
|
|
16
|
+
}
|
|
17
|
+
exports.isMultichannelButton = isMultichannelButton;
|
|
18
|
+
function isMultichannelReply(node) {
|
|
19
|
+
return isNodeKind(node, 'MultichannelReply');
|
|
20
|
+
}
|
|
21
|
+
exports.isMultichannelReply = isMultichannelReply;
|
|
22
|
+
function isButton(node) {
|
|
23
|
+
return isNodeKind(node, 'Button');
|
|
24
|
+
}
|
|
25
|
+
exports.isButton = isButton;
|
|
26
|
+
function isNodeKind(node, kind) {
|
|
27
|
+
return node.type && node.type.name == kind;
|
|
28
|
+
}
|
|
29
|
+
exports.isNodeKind = isNodeKind;
|
|
30
|
+
function elementHasUrl(element) {
|
|
31
|
+
return element.props && element.props.url;
|
|
32
|
+
}
|
|
33
|
+
exports.elementHasUrl = elementHasUrl;
|
|
34
|
+
function elementHasPostback(element) {
|
|
35
|
+
return ((element.props && element.props.payload) ||
|
|
36
|
+
(element.props && element.props.path));
|
|
37
|
+
}
|
|
38
|
+
exports.elementHasPostback = elementHasPostback;
|
|
39
|
+
function elementHasWebview(element) {
|
|
40
|
+
return element.props && element.props.webview;
|
|
41
|
+
}
|
|
42
|
+
exports.elementHasWebview = elementHasWebview;
|
|
43
|
+
exports.buttonTypes = {
|
|
44
|
+
POSTBACK: 'postback',
|
|
45
|
+
URL: 'url',
|
|
46
|
+
WEBVIEW: 'webview',
|
|
47
|
+
};
|
|
48
|
+
function getButtonType(multichannelButton) {
|
|
49
|
+
if (elementHasUrl(multichannelButton))
|
|
50
|
+
return exports.buttonTypes.URL;
|
|
51
|
+
if (elementHasPostback(multichannelButton))
|
|
52
|
+
return exports.buttonTypes.POSTBACK;
|
|
53
|
+
if (elementHasWebview(multichannelButton))
|
|
54
|
+
return exports.buttonTypes.WEBVIEW;
|
|
55
|
+
return undefined;
|
|
56
|
+
}
|
|
57
|
+
exports.getButtonType = getButtonType;
|
|
58
|
+
function getFilteredElements(node, filter) {
|
|
59
|
+
const elements = [];
|
|
60
|
+
for (const n of node) {
|
|
61
|
+
if (filter(n))
|
|
62
|
+
elements.push(n);
|
|
63
|
+
}
|
|
64
|
+
return elements;
|
|
65
|
+
}
|
|
66
|
+
exports.getFilteredElements = getFilteredElements;
|
|
67
|
+
function getMultichannelButtons(node) {
|
|
68
|
+
return getFilteredElements(node, isMultichannelButton);
|
|
69
|
+
}
|
|
70
|
+
exports.getMultichannelButtons = getMultichannelButtons;
|
|
71
|
+
function getMultichannelReplies(node) {
|
|
72
|
+
return getFilteredElements(node, isMultichannelReply);
|
|
73
|
+
}
|
|
74
|
+
exports.getMultichannelReplies = getMultichannelReplies;
|
|
75
|
+
const isWhatsapp = context => context.session &&
|
|
76
|
+
context.session.user &&
|
|
77
|
+
context.session.user.provider == core_1.Providers.Messaging.WHATSAPP;
|
|
78
|
+
exports.isWhatsapp = isWhatsapp;
|
|
79
|
+
const isFacebook = context => context.session &&
|
|
80
|
+
context.session.user &&
|
|
81
|
+
context.session.user.provider == core_1.Providers.Messaging.FACEBOOK;
|
|
82
|
+
exports.isFacebook = isFacebook;
|
|
83
|
+
//# sourceMappingURL=multichannel-utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"multichannel-utils.js","sourceRoot":"","sources":["../../../../src/components/multichannel/multichannel-utils.js"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export function Multichannel(props: any): any;
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Multichannel = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const react_1 = tslib_1.__importStar(require("react"));
|
|
6
|
+
const constants_1 = require("../../constants");
|
|
7
|
+
const contexts_1 = require("../../contexts");
|
|
8
|
+
const react_2 = require("../../util/react");
|
|
9
|
+
const text_1 = require("../text");
|
|
10
|
+
const multichannel_button_1 = require("./multichannel-button");
|
|
11
|
+
const multichannel_carousel_1 = require("./multichannel-carousel");
|
|
12
|
+
const multichannel_context_1 = require("./multichannel-context");
|
|
13
|
+
const multichannel_reply_1 = require("./multichannel-reply");
|
|
14
|
+
const multichannel_text_1 = require("./multichannel-text");
|
|
15
|
+
const multichannel_utils_1 = require("./multichannel-utils");
|
|
16
|
+
const Multichannel = props => {
|
|
17
|
+
const requestContext = react_1.useContext(contexts_1.RequestContext);
|
|
18
|
+
if (!multichannel_utils_1.isWhatsapp(requestContext) && !multichannel_utils_1.isFacebook(requestContext)) {
|
|
19
|
+
return props.children;
|
|
20
|
+
}
|
|
21
|
+
if (multichannel_utils_1.isFacebook(requestContext)) {
|
|
22
|
+
const newChildren = react_2.deepMapWithIndex(props.children, child => {
|
|
23
|
+
if (child && child.type && child.type.name === constants_1.COMPONENT_TYPE.TEXT) {
|
|
24
|
+
return (<multichannel_text_1.MultichannelText {...child.props} key={child.key}>
|
|
25
|
+
{child.props.children}
|
|
26
|
+
</multichannel_text_1.MultichannelText>);
|
|
27
|
+
}
|
|
28
|
+
return child;
|
|
29
|
+
});
|
|
30
|
+
return newChildren;
|
|
31
|
+
}
|
|
32
|
+
let newChildren = react_2.deepMapWithIndex(props.children, (child, index) => {
|
|
33
|
+
if (child && child.type && child.type.name === constants_1.COMPONENT_TYPE.BUTTON) {
|
|
34
|
+
return (<multichannel_button_1.MultichannelButton {...child.props} key={child.key}>
|
|
35
|
+
{child.props.children}
|
|
36
|
+
</multichannel_button_1.MultichannelButton>);
|
|
37
|
+
}
|
|
38
|
+
if (child && child.type && child.type.name === constants_1.COMPONENT_TYPE.REPLY) {
|
|
39
|
+
return (<multichannel_reply_1.MultichannelReply {...child.props} key={child.key}>
|
|
40
|
+
{child.props.children}
|
|
41
|
+
</multichannel_reply_1.MultichannelReply>);
|
|
42
|
+
}
|
|
43
|
+
if (child && child.type && child.type.name === constants_1.COMPONENT_TYPE.TEXT) {
|
|
44
|
+
return (<multichannel_text_1.MultichannelText {...child.props} {...props.text} key={child.key} {...(props.messageSeparator &&
|
|
45
|
+
index > 0 && { newline: props.messageSeparator })}>
|
|
46
|
+
{child.props.children}
|
|
47
|
+
</multichannel_text_1.MultichannelText>);
|
|
48
|
+
}
|
|
49
|
+
if (child && child.type && child.type.name === constants_1.COMPONENT_TYPE.CAROUSEL) {
|
|
50
|
+
return (<multichannel_carousel_1.MultichannelCarousel {...child.props} {...props.carousel} key={child.key}>
|
|
51
|
+
{child.props.children}
|
|
52
|
+
</multichannel_carousel_1.MultichannelCarousel>);
|
|
53
|
+
}
|
|
54
|
+
return child;
|
|
55
|
+
});
|
|
56
|
+
if (props.messageSeparator != null) {
|
|
57
|
+
newChildren = newChildren.map((c, index) => index > 0 && typeof c === 'string' ? props.messageSeparator + c : c);
|
|
58
|
+
newChildren = (<text_1.Text key={props.key} {...multichannel_utils_1.MULTICHANNEL_WHATSAPP_PROPS}>
|
|
59
|
+
{newChildren}
|
|
60
|
+
</text_1.Text>);
|
|
61
|
+
}
|
|
62
|
+
return (<multichannel_context_1.MultichannelContext.Provider value={{
|
|
63
|
+
currentIndex: props.firstIndex,
|
|
64
|
+
boldIndex: props.boldIndex,
|
|
65
|
+
indexSeparator: props.indexSeparator,
|
|
66
|
+
messageSeparator: props.messageSeparator,
|
|
67
|
+
}}>
|
|
68
|
+
{newChildren}
|
|
69
|
+
</multichannel_context_1.MultichannelContext.Provider>);
|
|
70
|
+
};
|
|
71
|
+
exports.Multichannel = Multichannel;
|
|
72
|
+
//# sourceMappingURL=multichannel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"multichannel.js","sourceRoot":"","sources":["../../../../src/components/multichannel/multichannel.jsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Pic = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const react_1 = tslib_1.__importDefault(require("react"));
|
|
6
|
+
const styled_components_1 = tslib_1.__importDefault(require("styled-components"));
|
|
7
|
+
const constants_1 = require("../constants");
|
|
8
|
+
const environment_1 = require("../util/environment");
|
|
9
|
+
const react_2 = require("../util/react");
|
|
10
|
+
const PicStyled = styled_components_1.default.img `
|
|
11
|
+
border-top-left-radius: 8px;
|
|
12
|
+
border-top-right-radius: 8px;
|
|
13
|
+
width: ${constants_1.WEBCHAT.DEFAULTS.ELEMENT_WIDTH}px;
|
|
14
|
+
height: 140px;
|
|
15
|
+
background: ${constants_1.COLORS.SOLID_WHITE} url(${props => props.src}) no-repeat
|
|
16
|
+
center/cover;
|
|
17
|
+
border-bottom: 1px solid ${constants_1.COLORS.SEASHELL_WHITE};
|
|
18
|
+
`;
|
|
19
|
+
const Pic = props => {
|
|
20
|
+
props = Object.assign(Object.assign({}, props), { src: environment_1.staticAsset(props.src) });
|
|
21
|
+
const renderBrowser = () => <PicStyled src={props.src}/>;
|
|
22
|
+
const renderNode = () => <pic>{props.src}</pic>;
|
|
23
|
+
return react_2.renderComponent({ renderBrowser, renderNode });
|
|
24
|
+
};
|
|
25
|
+
exports.Pic = Pic;
|
|
26
|
+
exports.Pic.serialize = picProps => {
|
|
27
|
+
return { pic: picProps.src };
|
|
28
|
+
};
|
|
29
|
+
//# sourceMappingURL=pic.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pic.js","sourceRoot":"","sources":["../../../src/components/pic.jsx"],"names":[],"mappings":";;;;AAAA,0DAAyB;AACzB,kFAAsC;AAEtC,4CAA8C;AAC9C,qDAAiD;AACjD,yCAA+C;AAE/C,MAAM,SAAS,GAAG,2BAAM,CAAC,GAAG,CAAA;;;WAGjB,mBAAO,CAAC,QAAQ,CAAC,aAAa;;gBAEzB,kBAAM,CAAC,WAAW,QAAQ,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,GAAG;;6BAE/B,kBAAM,CAAC,cAAc;CACjD,CAAA;AAEM,MAAM,GAAG,GAAG,KAAK,CAAC,EAAE;IACzB,KAAK,mCAAQ,KAAK,KAAE,GAAG,EAAE,yBAAW,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,uBAAe,CAAC,EAAE,aAAa,EAAE,UAAU,EAAE,CAAC,CAAA;AACvD,CAAC,CAAA;AALY,QAAA,GAAG,OAKf;AAED,WAAG,CAAC,SAAS,GAAG,QAAQ,CAAC,EAAE;IACzB,OAAO,EAAE,GAAG,EAAE,QAAQ,CAAC,GAAG,EAAE,CAAA;AAC9B,CAAC,CAAA"}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Raw = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const core_1 = require("@botonic/core");
|
|
6
|
+
const react_1 = tslib_1.__importStar(require("react"));
|
|
7
|
+
const styled_components_1 = tslib_1.__importDefault(require("styled-components"));
|
|
8
|
+
const constants_1 = require("../constants");
|
|
9
|
+
const message_1 = require("./message");
|
|
10
|
+
const RawDataButton = styled_components_1.default.div `
|
|
11
|
+
align-self: flex-start;
|
|
12
|
+
background-color: ${constants_1.COLORS.CURIOUS_BLUE};
|
|
13
|
+
padding: 4px;
|
|
14
|
+
margin: 4px 0px;
|
|
15
|
+
cursor: pointer;
|
|
16
|
+
color: ${constants_1.COLORS.SOLID_WHITE_ALPHA_0_8};
|
|
17
|
+
font-size: 10px;
|
|
18
|
+
border-radius: 2px;
|
|
19
|
+
`;
|
|
20
|
+
const Popover = styled_components_1.default.div `
|
|
21
|
+
max-width: 100%;
|
|
22
|
+
max-height: 500px;
|
|
23
|
+
overflow: auto;
|
|
24
|
+
background-color: ${constants_1.COLORS.LIGHT_GRAY};
|
|
25
|
+
padding: 10px;
|
|
26
|
+
pre {
|
|
27
|
+
margin: 0px;
|
|
28
|
+
}
|
|
29
|
+
`;
|
|
30
|
+
const serialize = rawProps => {
|
|
31
|
+
return { data: rawProps.data, alt: rawProps.alt };
|
|
32
|
+
};
|
|
33
|
+
const Raw = props => {
|
|
34
|
+
let content = props.children;
|
|
35
|
+
const data = JSON.stringify(props.data, null, ' ');
|
|
36
|
+
const [isOpen, setIsOpen] = react_1.useState(false);
|
|
37
|
+
if (core_1.isBrowser())
|
|
38
|
+
content = (<>
|
|
39
|
+
<div>{props.alt}</div>
|
|
40
|
+
<RawDataButton onClick={() => setIsOpen(!isOpen)}>
|
|
41
|
+
RAW DATA <small>{isOpen ? '▲' : '▼'}</small>
|
|
42
|
+
</RawDataButton>
|
|
43
|
+
{isOpen && (<Popover>
|
|
44
|
+
<pre>{data}</pre>
|
|
45
|
+
</Popover>)}
|
|
46
|
+
</>);
|
|
47
|
+
return (<message_1.Message role={constants_1.ROLES.RAW_MESSAGE} json={serialize(props)} {...props} data={data} type={core_1.INPUT.RAW}>
|
|
48
|
+
{content}
|
|
49
|
+
</message_1.Message>);
|
|
50
|
+
};
|
|
51
|
+
exports.Raw = Raw;
|
|
52
|
+
exports.Raw.serialize = serialize;
|
|
53
|
+
//# sourceMappingURL=raw.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"raw.js","sourceRoot":"","sources":["../../../src/components/raw.jsx"],"names":[],"mappings":";;;;AAAA,wCAAgD;AAChD,uDAAuC;AACvC,kFAAsC;AAEtC,4CAA4C;AAC5C,uCAAmC;AAEnC,MAAM,aAAa,GAAG,2BAAM,CAAC,GAAG,CAAA;;sBAEV,kBAAM,CAAC,YAAY;;;;WAI9B,kBAAM,CAAC,qBAAqB;;;CAGtC,CAAA;AAED,MAAM,OAAO,GAAG,2BAAM,CAAC,GAAG,CAAA;;;;sBAIJ,kBAAM,CAAC,UAAU;;;;;CAKtC,CAAA;AAED,MAAM,SAAS,GAAG,QAAQ,CAAC,EAAE;IAC3B,OAAO,EAAE,IAAI,EAAE,QAAQ,CAAC,IAAI,EAAE,GAAG,EAAE,QAAQ,CAAC,GAAG,EAAE,CAAA;AACnD,CAAC,CAAA;AAEM,MAAM,GAAG,GAAG,KAAK,CAAC,EAAE;IACzB,IAAI,OAAO,GAAG,KAAK,CAAC,QAAQ,CAAA;IAC5B,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,EAAE,IAAI,EAAE,GAAG,CAAC,CAAA;IAClD,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,gBAAQ,CAAC,KAAK,CAAC,CAAA;IAC3C,IAAI,gBAAS,EAAE;QACb,OAAO,GAAG,CACR,EACE;QAAA,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,GAAG,CACrB;QAAA,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,CAAC,CAC/C;mBAAS,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,KAAK,CAC7C;QAAA,EAAE,aAAa,CACf;QAAA,CAAC,MAAM,IAAI,CACT,CAAC,OAAO,CACN;YAAA,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,GAAG,CAClB;UAAA,EAAE,OAAO,CAAC,CACX,CACH;MAAA,GAAG,CACJ,CAAA;IACH,OAAO,CACL,CAAC,iBAAO,CACN,IAAI,CAAC,CAAC,iBAAK,CAAC,WAAW,CAAC,CACxB,IAAI,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CACvB,IAAI,KAAK,CAAC,CACV,IAAI,CAAC,CAAC,IAAI,CAAC,CACX,IAAI,CAAC,CAAC,YAAK,CAAC,GAAG,CAAC,CAEhB;MAAA,CAAC,OAAO,CACV;IAAA,EAAE,iBAAO,CAAC,CACX,CAAA;AACH,CAAC,CAAA;AA7BY,QAAA,GAAG,OA6Bf;AAED,WAAG,CAAC,SAAS,GAAG,SAAS,CAAA"}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Reply = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const react_1 = tslib_1.__importStar(require("react"));
|
|
6
|
+
const styled_components_1 = tslib_1.__importDefault(require("styled-components"));
|
|
7
|
+
const constants_1 = require("../constants");
|
|
8
|
+
const contexts_1 = require("../contexts");
|
|
9
|
+
const react_2 = require("../util/react");
|
|
10
|
+
const StyledButton = styled_components_1.default.button `
|
|
11
|
+
width: 100%;
|
|
12
|
+
padding: 4px 8px;
|
|
13
|
+
font-family: inherit;
|
|
14
|
+
border-radius: 8px;
|
|
15
|
+
cursor: pointer;
|
|
16
|
+
outline: 0;
|
|
17
|
+
`;
|
|
18
|
+
const Reply = props => {
|
|
19
|
+
const { sendText, getThemeProperty } = react_1.useContext(contexts_1.WebchatContext);
|
|
20
|
+
const handleClick = event => {
|
|
21
|
+
event.preventDefault();
|
|
22
|
+
if (props.children) {
|
|
23
|
+
let payload = props.payload;
|
|
24
|
+
if (props.path)
|
|
25
|
+
payload = `__PATH_PAYLOAD__${props.path}`;
|
|
26
|
+
sendText(props.children, payload);
|
|
27
|
+
}
|
|
28
|
+
};
|
|
29
|
+
const renderBrowser = () => {
|
|
30
|
+
const replyStyle = getThemeProperty(constants_1.WEBCHAT.CUSTOM_PROPERTIES.replyStyle);
|
|
31
|
+
const CustomReply = getThemeProperty(constants_1.WEBCHAT.CUSTOM_PROPERTIES.customReply);
|
|
32
|
+
if (CustomReply) {
|
|
33
|
+
return (<div onClick={e => handleClick(e)}>
|
|
34
|
+
<CustomReply>{props.children}</CustomReply>
|
|
35
|
+
</div>);
|
|
36
|
+
}
|
|
37
|
+
return (<StyledButton style={Object.assign({ border: `1px solid ${getThemeProperty(constants_1.WEBCHAT.CUSTOM_PROPERTIES.brandColor, constants_1.COLORS.BOTONIC_BLUE)}`, color: getThemeProperty(constants_1.WEBCHAT.CUSTOM_PROPERTIES.brandColor, constants_1.COLORS.BOTONIC_BLUE) }, replyStyle)} onClick={e => handleClick(e)}>
|
|
38
|
+
{props.children}
|
|
39
|
+
</StyledButton>);
|
|
40
|
+
};
|
|
41
|
+
const renderNode = () => {
|
|
42
|
+
if (props.path) {
|
|
43
|
+
const payload = `__PATH_PAYLOAD__${props.path}`;
|
|
44
|
+
return <reply payload={payload}>{props.children}</reply>;
|
|
45
|
+
}
|
|
46
|
+
return <reply payload={props.payload}>{props.children}</reply>;
|
|
47
|
+
};
|
|
48
|
+
return react_2.renderComponent({ renderBrowser, renderNode });
|
|
49
|
+
};
|
|
50
|
+
exports.Reply = Reply;
|
|
51
|
+
exports.Reply.serialize = replyProps => {
|
|
52
|
+
let payload = replyProps.payload;
|
|
53
|
+
if (replyProps.path)
|
|
54
|
+
payload = `__PATH_PAYLOAD__${replyProps.path}`;
|
|
55
|
+
return { reply: { title: replyProps.children, payload } };
|
|
56
|
+
};
|
|
57
|
+
//# sourceMappingURL=reply.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reply.js","sourceRoot":"","sources":["../../../src/components/reply.jsx"],"names":[],"mappings":";;;;AAAA,uDAAyC;AACzC,kFAAsC;AAEtC,4CAA8C;AAC9C,0CAA4C;AAC5C,yCAA+C;AAE/C,MAAM,YAAY,GAAG,2BAAM,CAAC,MAAM,CAAA;;;;;;;CAOjC,CAAA;AAEM,MAAM,KAAK,GAAG,KAAK,CAAC,EAAE;IAC3B,MAAM,EAAE,QAAQ,EAAE,gBAAgB,EAAE,GAAG,kBAAU,CAAC,yBAAc,CAAC,CAAA;IACjE,MAAM,WAAW,GAAG,KAAK,CAAC,EAAE;QAC1B,KAAK,CAAC,cAAc,EAAE,CAAA;QACtB,IAAI,KAAK,CAAC,QAAQ,EAAE;YAClB,IAAI,OAAO,GAAG,KAAK,CAAC,OAAO,CAAA;YAC3B,IAAI,KAAK,CAAC,IAAI;gBAAE,OAAO,GAAG,mBAAmB,KAAK,CAAC,IAAI,EAAE,CAAA;YACzD,QAAQ,CAAC,KAAK,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAA;SAClC;IACH,CAAC,CAAA;IAED,MAAM,aAAa,GAAG,GAAG,EAAE;QACzB,MAAM,UAAU,GAAG,gBAAgB,CAAC,mBAAO,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAA;QACzE,MAAM,WAAW,GAAG,gBAAgB,CAAC,mBAAO,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAA;QAC3E,IAAI,WAAW,EAAE;YACf,OAAO,CACL,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAChC;UAAA,CAAC,WAAW,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,WAAW,CAC5C;QAAA,EAAE,GAAG,CAAC,CACP,CAAA;SACF;QAED,OAAO,CACL,CAAC,YAAY,CACX,KAAK,CAAC,iBACJ,MAAM,EAAE,aAAa,gBAAgB,CACnC,mBAAO,CAAC,iBAAiB,CAAC,UAAU,EACpC,kBAAM,CAAC,YAAY,CACpB,EAAE,EACH,KAAK,EAAE,gBAAgB,CACrB,mBAAO,CAAC,iBAAiB,CAAC,UAAU,EACpC,kBAAM,CAAC,YAAY,CACpB,IACE,UAAU,EACb,CACF,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAE7B;QAAA,CAAC,KAAK,CAAC,QAAQ,CACjB;MAAA,EAAE,YAAY,CAAC,CAChB,CAAA;IACH,CAAC,CAAA;IAED,MAAM,UAAU,GAAG,GAAG,EAAE;QACtB,IAAI,KAAK,CAAC,IAAI,EAAE;YACd,MAAM,OAAO,GAAG,mBAAmB,KAAK,CAAC,IAAI,EAAE,CAAA;YAC/C,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,KAAK,CAAC,CAAA;SACzD;QACD,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,KAAK,CAAC,CAAA;IAChE,CAAC,CAAA;IAED,OAAO,uBAAe,CAAC,EAAE,aAAa,EAAE,UAAU,EAAE,CAAC,CAAA;AACvD,CAAC,CAAA;AAnDY,QAAA,KAAK,SAmDjB;AAED,aAAK,CAAC,SAAS,GAAG,UAAU,CAAC,EAAE;IAC7B,IAAI,OAAO,GAAG,UAAU,CAAC,OAAO,CAAA;IAChC,IAAI,UAAU,CAAC,IAAI;QAAE,OAAO,GAAG,mBAAmB,UAAU,CAAC,IAAI,EAAE,CAAA;IACnE,OAAO,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,UAAU,CAAC,QAAQ,EAAE,OAAO,EAAE,EAAE,CAAA;AAC3D,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export function ShareButton(props: any): any;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ShareButton = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const react_1 = tslib_1.__importDefault(require("react"));
|
|
6
|
+
const react_2 = require("../util/react");
|
|
7
|
+
const ShareButton = props => {
|
|
8
|
+
const renderBrowser = () => null;
|
|
9
|
+
const renderNode = () => (<button type='element_share'>
|
|
10
|
+
<pre dangerouslySetInnerHTML={{ __html: JSON.stringify(props.payload) }}/>
|
|
11
|
+
</button>);
|
|
12
|
+
return react_2.renderComponent({ renderBrowser, renderNode });
|
|
13
|
+
};
|
|
14
|
+
exports.ShareButton = ShareButton;
|
|
15
|
+
//# sourceMappingURL=share-button.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"share-button.js","sourceRoot":"","sources":["../../../src/components/share-button.jsx"],"names":[],"mappings":";;;;AAAA,0DAAyB;AAEzB,yCAA+C;AAExC,MAAM,WAAW,GAAG,KAAK,CAAC,EAAE;IACjC,MAAM,aAAa,GAAG,GAAG,EAAE,CAAC,IAAI,CAAA;IAChC,MAAM,UAAU,GAAG,GAAG,EAAE,CAAC,CACvB,CAAC,MAAM,CAAC,IAAI,CAAC,eAAe,CAC1B;MAAA,CAAC,GAAG,CACF,uBAAuB,CAAC,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC,EAEvE;IAAA,EAAE,MAAM,CAAC,CACV,CAAA;IAED,OAAO,uBAAe,CAAC,EAAE,aAAa,EAAE,UAAU,EAAE,CAAC,CAAA;AACvD,CAAC,CAAA;AAXY,QAAA,WAAW,eAWvB"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Subtitle = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const react_1 = tslib_1.__importDefault(require("react"));
|
|
6
|
+
const styled_components_1 = tslib_1.__importDefault(require("styled-components"));
|
|
7
|
+
const constants_1 = require("../constants");
|
|
8
|
+
const react_2 = require("../util/react");
|
|
9
|
+
const SubtitleContainer = styled_components_1.default.div `
|
|
10
|
+
font-size: 12px;
|
|
11
|
+
padding: 0px 15px 10px 15px;
|
|
12
|
+
color: ${constants_1.COLORS.MID_GRAY};
|
|
13
|
+
`;
|
|
14
|
+
const Subtitle = props => {
|
|
15
|
+
const renderBrowser = () => (<SubtitleContainer style={Object.assign({}, props.style)}>
|
|
16
|
+
{props.children}
|
|
17
|
+
</SubtitleContainer>);
|
|
18
|
+
const renderNode = () => <desc>{props.children}</desc>;
|
|
19
|
+
return react_2.renderComponent({ renderBrowser, renderNode });
|
|
20
|
+
};
|
|
21
|
+
exports.Subtitle = Subtitle;
|
|
22
|
+
exports.Subtitle.serialize = subtitleProps => {
|
|
23
|
+
return { subtitle: subtitleProps.children };
|
|
24
|
+
};
|
|
25
|
+
//# sourceMappingURL=subtitle.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"subtitle.js","sourceRoot":"","sources":["../../../src/components/subtitle.jsx"],"names":[],"mappings":";;;;AAAA,0DAAyB;AACzB,kFAAsC;AAEtC,4CAAqC;AACrC,yCAA+C;AAE/C,MAAM,iBAAiB,GAAG,2BAAM,CAAC,GAAG,CAAA;;;WAGzB,kBAAM,CAAC,QAAQ;CACzB,CAAA;AACM,MAAM,QAAQ,GAAG,KAAK,CAAC,EAAE;IAC9B,MAAM,aAAa,GAAG,GAAG,EAAE,CAAC,CAC1B,CAAC,iBAAiB,CAChB,KAAK,CAAC,mBACD,KAAK,CAAC,KAAK,EACd,CAEF;MAAA,CAAC,KAAK,CAAC,QAAQ,CACjB;IAAA,EAAE,iBAAiB,CAAC,CACrB,CAAA;IACD,MAAM,UAAU,GAAG,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,IAAI,CAAC,CAAA;IAEtD,OAAO,uBAAe,CAAC,EAAE,aAAa,EAAE,UAAU,EAAE,CAAC,CAAA;AACvD,CAAC,CAAA;AAbY,QAAA,QAAQ,YAapB;AAED,gBAAQ,CAAC,SAAS,GAAG,aAAa,CAAC,EAAE;IACnC,OAAO,EAAE,QAAQ,EAAE,aAAa,CAAC,QAAQ,EAAE,CAAA;AAC7C,CAAC,CAAA"}
|