@botonic/react 0.24.0-alpha.3 → 0.24.0-alpha.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/cjs/components/index-types.d.ts +1 -0
- package/lib/cjs/components/index-types.js.map +1 -1
- package/lib/cjs/components/{message.js → message/index.js} +20 -65
- package/lib/cjs/components/message/index.js.map +1 -0
- package/lib/cjs/components/message/message-image.d.ts +7 -0
- package/lib/cjs/components/message/message-image.js +18 -0
- package/lib/cjs/components/message/message-image.js.map +1 -0
- package/lib/cjs/components/message/styles.d.ts +8 -0
- package/lib/cjs/components/message/styles.js +69 -0
- package/lib/cjs/components/message/styles.js.map +1 -0
- package/lib/cjs/components/{timestamps.d.ts → message/timestamps.d.ts} +2 -1
- package/lib/cjs/components/message/timestamps.js +36 -0
- package/lib/cjs/components/message/timestamps.js.map +1 -0
- package/lib/cjs/constants.d.ts +1 -0
- package/lib/cjs/constants.js +2 -0
- package/lib/cjs/constants.js.map +1 -1
- package/lib/cjs/webchat/trigger-button/index.js +3 -2
- package/lib/cjs/webchat/trigger-button/index.js.map +1 -1
- 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/index-types.d.ts +4 -0
- package/lib/esm/assets/index-types.js +2 -0
- package/lib/esm/assets/index-types.js.map +1 -0
- package/lib/esm/botonic-tester.d.ts +18 -0
- package/lib/esm/botonic-tester.js +62 -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 +18 -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 +140 -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 +10 -0
- package/lib/esm/components/carousel.js +102 -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 +12 -0
- package/lib/esm/components/custom-message.js +55 -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 +42 -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 +51 -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 +49 -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 +35 -0
- package/lib/esm/components/image.js.map +1 -0
- package/lib/esm/components/index-types.d.ts +190 -0
- package/lib/esm/components/index-types.js +16 -0
- package/lib/esm/components/index-types.js.map +1 -0
- package/lib/esm/components/index.d.ts +23 -0
- package/lib/esm/components/index.js +24 -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 +27 -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/index.d.ts +1 -0
- package/lib/esm/components/message/index.js +143 -0
- package/lib/esm/components/message/index.js.map +1 -0
- package/lib/esm/components/message/message-image.d.ts +7 -0
- package/lib/esm/components/message/message-image.js +14 -0
- package/lib/esm/components/message/message-image.js.map +1 -0
- package/lib/esm/components/message/styles.d.ts +8 -0
- package/lib/esm/components/message/styles.js +65 -0
- package/lib/esm/components/message/styles.js.map +1 -0
- package/lib/esm/components/message/timestamps.d.ts +11 -0
- package/lib/esm/components/message/timestamps.js +30 -0
- package/lib/esm/components/message/timestamps.js.map +1 -0
- package/lib/esm/components/message-template.d.ts +1 -0
- package/lib/esm/components/message-template.js +9 -0
- package/lib/esm/components/message-template.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-types.d.ts +46 -0
- package/lib/esm/components/multichannel/index-types.js +2 -0
- package/lib/esm/components/multichannel/index-types.js.map +1 -0
- package/lib/esm/components/multichannel/index.d.ts +11 -0
- package/lib/esm/components/multichannel/index.js +12 -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 +71 -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 +73 -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 +20 -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 +153 -0
- package/lib/esm/components/multichannel/multichannel-text.js.map +1 -0
- package/lib/esm/components/multichannel/multichannel-utils.d.ts +26 -0
- package/lib/esm/components/multichannel/multichannel-utils.js +69 -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 +55 -0
- package/lib/esm/components/multichannel/multichannel.js.map +1 -0
- package/lib/esm/components/multichannel/whatsapp/markdown.d.ts +1 -0
- package/lib/esm/components/multichannel/whatsapp/markdown.js +53 -0
- package/lib/esm/components/multichannel/whatsapp/markdown.js.map +1 -0
- package/lib/esm/components/pic.d.ts +6 -0
- package/lib/esm/components/pic.js +25 -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 +39 -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 +49 -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 +9 -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 +19 -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 +42 -0
- package/lib/esm/components/text.js.map +1 -0
- package/lib/esm/components/title.d.ts +6 -0
- package/lib/esm/components/title.js +17 -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 +26 -0
- package/lib/esm/components/video.js.map +1 -0
- package/lib/esm/components/webchat-settings.d.ts +3 -0
- package/lib/esm/components/webchat-settings.js +69 -0
- package/lib/esm/components/webchat-settings.js.map +1 -0
- package/lib/esm/components/whatsapp-button-list.d.ts +17 -0
- package/lib/esm/components/whatsapp-button-list.js +22 -0
- package/lib/esm/components/whatsapp-button-list.js.map +1 -0
- package/lib/esm/components/whatsapp-template.d.ts +1 -0
- package/lib/esm/components/whatsapp-template.js +20 -0
- package/lib/esm/components/whatsapp-template.js.map +1 -0
- package/lib/esm/constants.d.ts +173 -0
- package/lib/esm/constants.js +194 -0
- package/lib/esm/constants.js.map +1 -0
- package/lib/esm/contexts.d.ts +12 -0
- package/lib/esm/contexts.js +67 -0
- package/lib/esm/contexts.js.map +1 -0
- package/lib/esm/dev-app.d.ts +30 -0
- package/lib/esm/dev-app.js +74 -0
- package/lib/esm/dev-app.js.map +1 -0
- package/lib/esm/index-types.d.ts +128 -0
- package/lib/esm/index-types.js +12 -0
- package/lib/esm/index-types.js.map +1 -0
- package/lib/esm/index.d.ts +11 -0
- package/lib/esm/index.js +12 -0
- package/lib/esm/index.js.map +1 -0
- package/lib/esm/message-utils.d.ts +19 -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 +135 -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 +8 -0
- package/lib/esm/react-bot.js +29 -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 +7 -0
- package/lib/esm/util/error-boundary.js +28 -0
- package/lib/esm/util/error-boundary.js.map +1 -0
- package/lib/esm/util/index.d.ts +8 -0
- package/lib/esm/util/index.js +9 -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 +27 -0
- package/lib/esm/webchat/actions.js +29 -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 +24 -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 +9 -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 +12 -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 +37 -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 +39 -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 +14 -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/typing-indicator.d.ts +1 -0
- package/lib/esm/webchat/components/typing-indicator.js +6 -0
- package/lib/esm/webchat/components/typing-indicator.js.map +1 -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 +79 -0
- package/lib/esm/webchat/header.js.map +1 -0
- package/lib/esm/webchat/hooks/index.d.ts +5 -0
- package/lib/esm/webchat/hooks/index.js +6 -0
- package/lib/esm/webchat/hooks/index.js.map +1 -0
- package/lib/esm/webchat/hooks/use-component-visible.d.ts +8 -0
- package/lib/esm/webchat/hooks/use-component-visible.js +20 -0
- package/lib/esm/webchat/hooks/use-component-visible.js.map +1 -0
- package/lib/esm/webchat/hooks/use-component-will-mount.d.ts +1 -0
- package/lib/esm/webchat/hooks/use-component-will-mount.js +5 -0
- package/lib/esm/webchat/hooks/use-component-will-mount.js.map +1 -0
- package/lib/esm/webchat/hooks/use-previous.d.ts +1 -0
- package/lib/esm/webchat/hooks/use-previous.js +9 -0
- package/lib/esm/webchat/hooks/use-previous.js.map +1 -0
- package/lib/esm/webchat/hooks/use-typing.d.ts +10 -0
- package/lib/esm/webchat/hooks/use-typing.js +26 -0
- package/lib/esm/webchat/hooks/use-typing.js.map +1 -0
- package/lib/esm/webchat/hooks/use-webchat.d.ts +41 -0
- package/lib/esm/webchat/hooks/use-webchat.js +177 -0
- package/lib/esm/webchat/hooks/use-webchat.js.map +1 -0
- package/lib/esm/webchat/index-types.d.ts +62 -0
- package/lib/esm/webchat/index-types.js +2 -0
- package/lib/esm/webchat/index-types.js.map +1 -0
- package/lib/esm/webchat/index.d.ts +4 -0
- package/lib/esm/webchat/index.js +10 -0
- package/lib/esm/webchat/index.js.map +1 -0
- package/lib/esm/webchat/message-list/index.d.ts +1 -0
- package/lib/esm/webchat/message-list/index.js +73 -0
- package/lib/esm/webchat/message-list/index.js.map +1 -0
- package/lib/esm/webchat/message-list/intro-message.d.ts +1 -0
- package/lib/esm/webchat/message-list/intro-message.js +18 -0
- package/lib/esm/webchat/message-list/intro-message.js.map +1 -0
- package/lib/esm/webchat/message-list/scroll-button.d.ts +5 -0
- package/lib/esm/webchat/message-list/scroll-button.js +17 -0
- package/lib/esm/webchat/message-list/scroll-button.js.map +1 -0
- package/lib/esm/webchat/message-list/styles.d.ts +4 -0
- package/lib/esm/webchat/message-list/styles.js +46 -0
- package/lib/esm/webchat/message-list/styles.js.map +1 -0
- package/lib/esm/webchat/message-list/unread-messages-banner.d.ts +6 -0
- package/lib/esm/webchat/message-list/unread-messages-banner.js +16 -0
- package/lib/esm/webchat/message-list/unread-messages-banner.js.map +1 -0
- package/lib/esm/webchat/message-list/use-debounce.d.ts +1 -0
- package/lib/esm/webchat/message-list/use-debounce.js +14 -0
- package/lib/esm/webchat/message-list/use-debounce.js.map +1 -0
- package/lib/esm/webchat/messages-reducer.d.ts +6 -0
- package/lib/esm/webchat/messages-reducer.js +82 -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 +38 -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 +96 -0
- package/lib/esm/webchat/session-view.js.map +1 -0
- package/lib/esm/webchat/trigger-button/index.d.ts +1 -0
- package/lib/esm/webchat/trigger-button/index.js +28 -0
- package/lib/esm/webchat/trigger-button/index.js.map +1 -0
- package/lib/esm/webchat/trigger-button/styles.d.ts +3 -0
- package/lib/esm/webchat/trigger-button/styles.js +36 -0
- package/lib/esm/webchat/trigger-button/styles.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 +38 -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 +56 -0
- package/lib/esm/webchat/webchat-dev.js.map +1 -0
- package/lib/esm/webchat/webchat-reducer.d.ts +6 -0
- package/lib/esm/webchat/webchat-reducer.js +46 -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 +637 -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 +78 -0
- package/lib/esm/webchat/webview.js.map +1 -0
- package/lib/esm/webchat-app.d.ts +99 -0
- package/lib/esm/webchat-app.js +281 -0
- package/lib/esm/webchat-app.js.map +1 -0
- package/lib/esm/webview-app.d.ts +7 -0
- package/lib/esm/webview-app.js +95 -0
- package/lib/esm/webview-app.js.map +1 -0
- package/package.json +2 -2
- package/src/.DS_Store +0 -0
- package/src/components/index-types.ts +1 -0
- package/src/components/{message.jsx → message/index.jsx} +32 -92
- package/src/components/message/message-image.tsx +52 -0
- package/src/components/message/styles.ts +73 -0
- package/src/components/message/timestamps.jsx +62 -0
- package/src/constants.js +2 -0
- package/src/webchat/trigger-button/index.tsx +10 -5
- package/lib/cjs/components/message.js.map +0 -1
- package/lib/cjs/components/timestamps.js +0 -51
- package/lib/cjs/components/timestamps.js.map +0 -1
- package/src/components/timestamps.jsx +0 -68
- /package/lib/cjs/components/{message.d.ts → message/index.d.ts} +0 -0
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import { jsxs as _jsxs, jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import React, { useContext } from 'react';
|
|
3
|
+
import { RequestContext } from '../../contexts';
|
|
4
|
+
import { Carousel } from '../carousel';
|
|
5
|
+
import { MultichannelText } from './multichannel-text';
|
|
6
|
+
import { getFilteredElements, isMultichannelButton, isNodeKind, isWhatsapp, } from './multichannel-utils';
|
|
7
|
+
export const MultichannelCarousel = props => {
|
|
8
|
+
const requestContext = useContext(RequestContext);
|
|
9
|
+
const getButtons = node => [].concat(getFilteredElements(node, isMultichannelButton));
|
|
10
|
+
if (isWhatsapp(requestContext)) {
|
|
11
|
+
const elements = props.children
|
|
12
|
+
.map(e => e.props.children)
|
|
13
|
+
.map((element, i) => {
|
|
14
|
+
let imageProps = undefined;
|
|
15
|
+
let title = undefined;
|
|
16
|
+
let subtitle = undefined;
|
|
17
|
+
const buttons = [];
|
|
18
|
+
for (const node of element) {
|
|
19
|
+
if (isNodeKind(node, 'Pic')) {
|
|
20
|
+
imageProps = node.props;
|
|
21
|
+
}
|
|
22
|
+
if (isNodeKind(node, 'Title')) {
|
|
23
|
+
title = node.props.children;
|
|
24
|
+
}
|
|
25
|
+
if (isNodeKind(node, 'Subtitle')) {
|
|
26
|
+
subtitle = node.props.children;
|
|
27
|
+
}
|
|
28
|
+
if (isNodeKind(node, 'MultichannelButton')) {
|
|
29
|
+
buttons.push(node);
|
|
30
|
+
}
|
|
31
|
+
//TODO support fragment containing an array
|
|
32
|
+
if (Array.isArray(node)) {
|
|
33
|
+
buttons.push(getButtons(node));
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
let header = '';
|
|
37
|
+
if (props.showTitle && title) {
|
|
38
|
+
header += `${title ? `**${title}**` : ''}`;
|
|
39
|
+
if (title && subtitle) {
|
|
40
|
+
header += ' ';
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
if (props.showSubtitle && subtitle) {
|
|
44
|
+
header += `_${subtitle}_`;
|
|
45
|
+
}
|
|
46
|
+
return (
|
|
47
|
+
// TODO: newkey only for 1 nested button
|
|
48
|
+
_jsxs(MultichannelText, Object.assign({ newkey: i, indexMode: props.indexMode, buttonsAsText: props.buttonsAsText }, { children: [header || null, buttons] }), i));
|
|
49
|
+
// TODO: in the future, this would be the default mode
|
|
50
|
+
// } else {
|
|
51
|
+
// return (
|
|
52
|
+
// <React.Fragment key={i}>
|
|
53
|
+
// <Image
|
|
54
|
+
// src={imageSrc}
|
|
55
|
+
// caption={carouselToCaption(
|
|
56
|
+
// i + 1,
|
|
57
|
+
// title,
|
|
58
|
+
// subtitle,
|
|
59
|
+
// imageSrc,
|
|
60
|
+
// buttonProps
|
|
61
|
+
// )}
|
|
62
|
+
// ></Image>
|
|
63
|
+
// </React.Fragment>
|
|
64
|
+
// )
|
|
65
|
+
// }
|
|
66
|
+
});
|
|
67
|
+
return elements;
|
|
68
|
+
}
|
|
69
|
+
else {
|
|
70
|
+
return _jsx(Carousel, Object.assign({}, props, { children: props.children }));
|
|
71
|
+
}
|
|
72
|
+
};
|
|
73
|
+
//# sourceMappingURL=multichannel-carousel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"multichannel-carousel.js","sourceRoot":"src/","sources":["components/multichannel/multichannel-carousel.jsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export const MultichannelContext = React.createContext({
|
|
3
|
+
boldIndex: true,
|
|
4
|
+
carousel: {
|
|
5
|
+
indexMode: undefined,
|
|
6
|
+
},
|
|
7
|
+
text: {
|
|
8
|
+
indexMode: 'letter',
|
|
9
|
+
},
|
|
10
|
+
indexSeparator: '.',
|
|
11
|
+
});
|
|
12
|
+
//# sourceMappingURL=multichannel-context.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"multichannel-context.js","sourceRoot":"src/","sources":["components/multichannel/multichannel-context.jsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,MAAM,CAAC,MAAM,mBAAmB,GAAG,KAAK,CAAC,aAAa,CAAC;IACrD,SAAS,EAAE,IAAI;IACf,QAAQ,EAAE;QACR,SAAS,EAAE,SAAS;KACrB;IACD,IAAI,EAAE;QACJ,SAAS,EAAE,QAAQ;KACpB;IACD,cAAc,EAAE,GAAG;CACpB,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export function MultichannelReply(props: any): string | JSX.Element | null;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import React, { useContext } from 'react';
|
|
3
|
+
import { RequestContext } from '../../contexts';
|
|
4
|
+
import { Reply } from '../reply';
|
|
5
|
+
import { isWhatsapp } from './multichannel-utils';
|
|
6
|
+
export const MultichannelReply = props => {
|
|
7
|
+
const requestContext = useContext(RequestContext);
|
|
8
|
+
const hasPath = () => Boolean(props.path);
|
|
9
|
+
const hasPayload = () => Boolean(props.payload);
|
|
10
|
+
const getText = () => `${props.children}`;
|
|
11
|
+
if (isWhatsapp(requestContext)) {
|
|
12
|
+
if (hasPath() || hasPayload())
|
|
13
|
+
return `${getText()}`;
|
|
14
|
+
return null;
|
|
15
|
+
}
|
|
16
|
+
else {
|
|
17
|
+
return _jsx(Reply, Object.assign({}, props, { children: props.children }));
|
|
18
|
+
}
|
|
19
|
+
};
|
|
20
|
+
//# sourceMappingURL=multichannel-reply.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"multichannel-reply.js","sourceRoot":"src/","sources":["components/multichannel/multichannel-reply.jsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,OAAO,CAAA;AAEzC,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;AAC/C,OAAO,EAAE,KAAK,EAAE,MAAM,UAAU,CAAA;AAChC,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAA;AAEjD,MAAM,CAAC,MAAM,iBAAiB,GAAG,KAAK,CAAC,EAAE;IACvC,MAAM,cAAc,GAAG,UAAU,CAAC,cAAc,CAAC,CAAA;IACjD,MAAM,OAAO,GAAG,GAAG,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;IACzC,MAAM,UAAU,GAAG,GAAG,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;IAC/C,MAAM,OAAO,GAAG,GAAG,EAAE,CAAC,GAAG,KAAK,CAAC,QAAQ,EAAE,CAAA;IAEzC,IAAI,UAAU,CAAC,cAAc,CAAC,EAAE;QAC9B,IAAI,OAAO,EAAE,IAAI,UAAU,EAAE;YAAE,OAAO,GAAG,OAAO,EAAE,EAAE,CAAA;QACpD,OAAO,IAAI,CAAA;KACZ;SAAM;QACL,OAAO,KAAC,KAAK,oBAAK,KAAK,cAAG,KAAK,CAAC,QAAQ,IAAS,CAAA;KAClD;AACH,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export function MultichannelText(props: any): never[] | JSX.Element;
|
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
import { INPUT } from '@botonic/core';
|
|
3
|
+
import React, { useContext } from 'react';
|
|
4
|
+
import { RequestContext } from '../../contexts';
|
|
5
|
+
import { WhatsappButtonList } from '..';
|
|
6
|
+
import { Text } from '../text';
|
|
7
|
+
import { MultichannelFacebook } from './facebook/facebook';
|
|
8
|
+
import { MultichannelButton } from './multichannel-button';
|
|
9
|
+
import { MultichannelContext } from './multichannel-context';
|
|
10
|
+
import { buttonTypes, DEFAULT_WHATSAPP_MAX_BUTTON_SEPARATOR, elementHasPostback, elementHasUrl, elementHasWebview, getButtonType, getMultichannelButtons, getMultichannelReplies, isFacebook, isWhatsapp, MENU_BUTTON_WHATSAPP_BUTTON_LIST, MULTICHANNEL_WHATSAPP_PROPS, WHATSAPP_LIST_MAX_BUTTONS, WHATSAPP_MAX_BUTTONS, } from './multichannel-utils';
|
|
11
|
+
import { whatsappMarkdown } from './whatsapp/markdown';
|
|
12
|
+
export const MultichannelText = props => {
|
|
13
|
+
var _a;
|
|
14
|
+
const requestContext = useContext(RequestContext);
|
|
15
|
+
const multichannelContext = useContext(MultichannelContext);
|
|
16
|
+
const postbackButtonsAsText = (_a = props.buttonsAsText) !== null && _a !== void 0 ? _a : true;
|
|
17
|
+
let elements = [];
|
|
18
|
+
const getText = children => {
|
|
19
|
+
children = Array.isArray(children) ? children : [children];
|
|
20
|
+
const text = children
|
|
21
|
+
.filter(e => e && !e.type)
|
|
22
|
+
.map(e => {
|
|
23
|
+
if (Array.isArray(e))
|
|
24
|
+
return getText(e);
|
|
25
|
+
else
|
|
26
|
+
return String(e);
|
|
27
|
+
})
|
|
28
|
+
.join('');
|
|
29
|
+
if (text == undefined) {
|
|
30
|
+
return [];
|
|
31
|
+
}
|
|
32
|
+
return [text].filter(t => t !== ''); // to avoid line breaks when the carousel doesn't have title or subtitle
|
|
33
|
+
};
|
|
34
|
+
const getButtonsAndReplies = () => [].concat(getMultichannelButtons(React.Children.toArray(props.children)), getMultichannelReplies(React.Children.toArray(props.children)));
|
|
35
|
+
const getWhatsappButtons = () => {
|
|
36
|
+
const postbackButtons = [];
|
|
37
|
+
const urlButtons = [];
|
|
38
|
+
const webviewButtons = [];
|
|
39
|
+
for (const button of getButtonsAndReplies()) {
|
|
40
|
+
if (elementHasUrl(button))
|
|
41
|
+
urlButtons.push(button);
|
|
42
|
+
else if (elementHasWebview(button))
|
|
43
|
+
webviewButtons.push(button);
|
|
44
|
+
else if (elementHasPostback(button))
|
|
45
|
+
postbackButtons.push(button);
|
|
46
|
+
}
|
|
47
|
+
return { postbackButtons, urlButtons, webviewButtons };
|
|
48
|
+
};
|
|
49
|
+
const getDefaultIndex = () => {
|
|
50
|
+
if (props.indexMode == undefined) {
|
|
51
|
+
return undefined;
|
|
52
|
+
}
|
|
53
|
+
if (multichannelContext.currentIndex != null) {
|
|
54
|
+
return multichannelContext.currentIndex;
|
|
55
|
+
}
|
|
56
|
+
return props.indexMode === 'letter' ? 'a' : 1;
|
|
57
|
+
};
|
|
58
|
+
const regenerateMultichannelButtons = (newLineFirstButton = true) => {
|
|
59
|
+
const generator = (multichannelButton, i) => {
|
|
60
|
+
const type = getButtonType(multichannelButton);
|
|
61
|
+
const asText = type === buttonTypes.POSTBACK ? postbackButtonsAsText : true;
|
|
62
|
+
const newline = multichannelContext.messageSeparator == null &&
|
|
63
|
+
!newLineFirstButton &&
|
|
64
|
+
i === 0
|
|
65
|
+
? ''
|
|
66
|
+
: '\n';
|
|
67
|
+
return (_jsx(MultichannelButton, Object.assign({ newline: newline, asText: asText }, multichannelButton.props, { children: multichannelButton.props.children }), `${type}${i}`));
|
|
68
|
+
};
|
|
69
|
+
return generator;
|
|
70
|
+
};
|
|
71
|
+
const splitInWhatsappListButtons = postbackButtons => {
|
|
72
|
+
const messages = [];
|
|
73
|
+
for (let i = 0; i < postbackButtons.length; i += WHATSAPP_LIST_MAX_BUTTONS) {
|
|
74
|
+
messages.push(postbackButtons.slice(i, i + WHATSAPP_LIST_MAX_BUTTONS));
|
|
75
|
+
}
|
|
76
|
+
return messages;
|
|
77
|
+
};
|
|
78
|
+
if (isWhatsapp(requestContext)) {
|
|
79
|
+
const texts = getText(props.children);
|
|
80
|
+
const { postbackButtons, urlButtons, webviewButtons } = getWhatsappButtons();
|
|
81
|
+
const textElements = texts.map(text => {
|
|
82
|
+
const textWithMarkdown = whatsappMarkdown(text);
|
|
83
|
+
return (props.newline || '') + textWithMarkdown;
|
|
84
|
+
});
|
|
85
|
+
const webviewButtonElements = webviewButtons.map(regenerateMultichannelButtons(false));
|
|
86
|
+
const buttonsTextSeparator = props.buttonsTextSeparator || DEFAULT_WHATSAPP_MAX_BUTTON_SEPARATOR;
|
|
87
|
+
const exceedWhatsAppMaxButtonNumber = !postbackButtonsAsText && postbackButtons.length > WHATSAPP_MAX_BUTTONS;
|
|
88
|
+
if (exceedWhatsAppMaxButtonNumber) {
|
|
89
|
+
const menuButtonTextWhatsappList = props.menuButtonTextWhatsappList || MENU_BUTTON_WHATSAPP_BUTTON_LIST;
|
|
90
|
+
const urlButtonElements = urlButtons.map(regenerateMultichannelButtons(!!texts.length));
|
|
91
|
+
const postbackButtonElements = postbackButtons.map(regenerateMultichannelButtons(!!texts.length || !!urlButtons.length));
|
|
92
|
+
const messagesPostbackButtonList = splitInWhatsappListButtons(postbackButtonElements);
|
|
93
|
+
const messages = messagesPostbackButtonList.map((postbackButtons, index) => {
|
|
94
|
+
if (postbackButtons.length <= WHATSAPP_MAX_BUTTONS) {
|
|
95
|
+
return {
|
|
96
|
+
type: INPUT.TEXT,
|
|
97
|
+
children: [...buttonsTextSeparator, ...postbackButtons],
|
|
98
|
+
};
|
|
99
|
+
}
|
|
100
|
+
const rows = postbackButtons.map(postbackButton => {
|
|
101
|
+
const row = {
|
|
102
|
+
id: postbackButton.props.path
|
|
103
|
+
? `__PATH_PAYLOAD__${postbackButton.props.path}`
|
|
104
|
+
: postbackButton.props.payload,
|
|
105
|
+
title: postbackButton.props.children,
|
|
106
|
+
};
|
|
107
|
+
return row;
|
|
108
|
+
});
|
|
109
|
+
const whatsbuttonlistProps = {
|
|
110
|
+
body: index === 0 ? textElements : buttonsTextSeparator,
|
|
111
|
+
button: menuButtonTextWhatsappList,
|
|
112
|
+
sections: [{ rows }],
|
|
113
|
+
};
|
|
114
|
+
return {
|
|
115
|
+
type: INPUT.WHATSAPP_BUTTON_LIST,
|
|
116
|
+
props: whatsbuttonlistProps,
|
|
117
|
+
};
|
|
118
|
+
});
|
|
119
|
+
const messageWithUrlButtonElements = (_jsx(Text, Object.assign({}, MULTICHANNEL_WHATSAPP_PROPS, props, { children: urlButtonElements }), `msg-with-url-button`));
|
|
120
|
+
const messageWithWebviewButtonElements = (_jsxs(Text, Object.assign({}, MULTICHANNEL_WHATSAPP_PROPS, props, { children: [buttonsTextSeparator, webviewButtonElements] }), `msg-with-webview-button`));
|
|
121
|
+
return (_jsxs(_Fragment, { children: [messages.map((message, i) => {
|
|
122
|
+
if (message.type === INPUT.WHATSAPP_BUTTON_LIST)
|
|
123
|
+
return (_jsx(WhatsappButtonList, Object.assign({}, message.props), `msg-${i}-whatsapp-list`));
|
|
124
|
+
return (_jsx(Text, Object.assign({}, MULTICHANNEL_WHATSAPP_PROPS, props, { children: message.children }), `msg-${i}-with-postback-buttons`));
|
|
125
|
+
}), urlButtonElements.length > 0 && messageWithUrlButtonElements, webviewButtonElements.length > 0 && messageWithWebviewButtonElements] }));
|
|
126
|
+
}
|
|
127
|
+
multichannelContext.currentIndex = getDefaultIndex();
|
|
128
|
+
const postbackButtonElements = postbackButtons.map(regenerateMultichannelButtons(!!texts.length));
|
|
129
|
+
const urlButtonElements = urlButtons.map(regenerateMultichannelButtons(!!texts.length || !!postbackButtons.length));
|
|
130
|
+
elements = [].concat([...textElements], [...postbackButtonElements], [...urlButtonElements]);
|
|
131
|
+
if (multichannelContext.messageSeparator != null) {
|
|
132
|
+
return elements;
|
|
133
|
+
}
|
|
134
|
+
const messages = [
|
|
135
|
+
_jsx(Text, Object.assign({}, MULTICHANNEL_WHATSAPP_PROPS, props, { children: elements }), 0),
|
|
136
|
+
];
|
|
137
|
+
if (webviewButtonElements.length) {
|
|
138
|
+
messages.push(_jsxs(Text, Object.assign({}, MULTICHANNEL_WHATSAPP_PROPS, props, { children: [buttonsTextSeparator, webviewButtonElements] }), 1));
|
|
139
|
+
}
|
|
140
|
+
return _jsx(_Fragment, { children: messages });
|
|
141
|
+
}
|
|
142
|
+
if (isFacebook(requestContext)) {
|
|
143
|
+
const text = getText(props.children);
|
|
144
|
+
const multichannelFacebook = new MultichannelFacebook();
|
|
145
|
+
const { texts, propsLastText, propsWithoutChildren } = multichannelFacebook.convertText(props, text[0]);
|
|
146
|
+
return (_jsxs(_Fragment, { children: [texts &&
|
|
147
|
+
texts.map((e, i) => (_jsx(Text, Object.assign({}, propsWithoutChildren, { children: e }), i))), _jsx(Text, Object.assign({}, propsLastText, { children: propsLastText.children }))] }));
|
|
148
|
+
}
|
|
149
|
+
else {
|
|
150
|
+
return _jsx(Text, Object.assign({}, props, { children: props.children }));
|
|
151
|
+
}
|
|
152
|
+
};
|
|
153
|
+
//# sourceMappingURL=multichannel-text.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"multichannel-text.js","sourceRoot":"src/","sources":["components/multichannel/multichannel-text.jsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
export function isMultichannelButton(node: any): any;
|
|
2
|
+
export function isMultichannelReply(node: any): any;
|
|
3
|
+
export function isButton(node: any): any;
|
|
4
|
+
export function isNodeKind(node: any, kind: any): any;
|
|
5
|
+
export function elementHasUrl(element: any): any;
|
|
6
|
+
export function elementHasPostback(element: any): any;
|
|
7
|
+
export function elementHasWebview(element: any): any;
|
|
8
|
+
export function getButtonType(multichannelButton: any): string | undefined;
|
|
9
|
+
export function getFilteredElements(node: any, filter: any): any[];
|
|
10
|
+
export function getMultichannelButtons(node: any): any[];
|
|
11
|
+
export function getMultichannelReplies(node: any): any[];
|
|
12
|
+
export namespace MULTICHANNEL_WHATSAPP_PROPS {
|
|
13
|
+
const markdown: boolean;
|
|
14
|
+
}
|
|
15
|
+
export const WHATSAPP_MAX_BUTTONS: 3;
|
|
16
|
+
export const WHATSAPP_LIST_MAX_BUTTONS: 10;
|
|
17
|
+
export const WHATSAPP_MAX_BUTTON_CHARS: 20;
|
|
18
|
+
export const DEFAULT_WHATSAPP_MAX_BUTTON_SEPARATOR: "More options:";
|
|
19
|
+
export const MENU_BUTTON_WHATSAPP_BUTTON_LIST: "Show options";
|
|
20
|
+
export namespace buttonTypes {
|
|
21
|
+
const POSTBACK: string;
|
|
22
|
+
const URL: string;
|
|
23
|
+
const WEBVIEW: string;
|
|
24
|
+
}
|
|
25
|
+
export function isWhatsapp(context: any): any;
|
|
26
|
+
export function isFacebook(context: any): any;
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
import { Providers } from '@botonic/core';
|
|
2
|
+
/**
|
|
3
|
+
*
|
|
4
|
+
* Whatsapp does not support Markdown
|
|
5
|
+
* (its markup syntax is different)
|
|
6
|
+
*/
|
|
7
|
+
export const MULTICHANNEL_WHATSAPP_PROPS = { markdown: false };
|
|
8
|
+
export const WHATSAPP_MAX_BUTTONS = 3;
|
|
9
|
+
export const WHATSAPP_LIST_MAX_BUTTONS = 10;
|
|
10
|
+
export const WHATSAPP_MAX_BUTTON_CHARS = 20;
|
|
11
|
+
export const DEFAULT_WHATSAPP_MAX_BUTTON_SEPARATOR = 'More options:';
|
|
12
|
+
export const MENU_BUTTON_WHATSAPP_BUTTON_LIST = 'Show options';
|
|
13
|
+
export function isMultichannelButton(node) {
|
|
14
|
+
return isNodeKind(node, 'MultichannelButton');
|
|
15
|
+
}
|
|
16
|
+
export function isMultichannelReply(node) {
|
|
17
|
+
return isNodeKind(node, 'MultichannelReply');
|
|
18
|
+
}
|
|
19
|
+
export function isButton(node) {
|
|
20
|
+
return isNodeKind(node, 'Button');
|
|
21
|
+
}
|
|
22
|
+
export function isNodeKind(node, kind) {
|
|
23
|
+
return node.type && node.type.name == kind;
|
|
24
|
+
}
|
|
25
|
+
export function elementHasUrl(element) {
|
|
26
|
+
return element.props && element.props.url;
|
|
27
|
+
}
|
|
28
|
+
export function elementHasPostback(element) {
|
|
29
|
+
return ((element.props && element.props.payload) ||
|
|
30
|
+
(element.props && element.props.path));
|
|
31
|
+
}
|
|
32
|
+
export function elementHasWebview(element) {
|
|
33
|
+
return element.props && element.props.webview;
|
|
34
|
+
}
|
|
35
|
+
export const buttonTypes = {
|
|
36
|
+
POSTBACK: 'postback',
|
|
37
|
+
URL: 'url',
|
|
38
|
+
WEBVIEW: 'webview',
|
|
39
|
+
};
|
|
40
|
+
export function getButtonType(multichannelButton) {
|
|
41
|
+
if (elementHasUrl(multichannelButton))
|
|
42
|
+
return buttonTypes.URL;
|
|
43
|
+
if (elementHasPostback(multichannelButton))
|
|
44
|
+
return buttonTypes.POSTBACK;
|
|
45
|
+
if (elementHasWebview(multichannelButton))
|
|
46
|
+
return buttonTypes.WEBVIEW;
|
|
47
|
+
return undefined;
|
|
48
|
+
}
|
|
49
|
+
export function getFilteredElements(node, filter) {
|
|
50
|
+
const elements = [];
|
|
51
|
+
for (const n of node) {
|
|
52
|
+
if (filter(n))
|
|
53
|
+
elements.push(n);
|
|
54
|
+
}
|
|
55
|
+
return elements;
|
|
56
|
+
}
|
|
57
|
+
export function getMultichannelButtons(node) {
|
|
58
|
+
return getFilteredElements(node, isMultichannelButton);
|
|
59
|
+
}
|
|
60
|
+
export function getMultichannelReplies(node) {
|
|
61
|
+
return getFilteredElements(node, isMultichannelReply);
|
|
62
|
+
}
|
|
63
|
+
export const isWhatsapp = context => context.session &&
|
|
64
|
+
context.session.user &&
|
|
65
|
+
context.session.user.provider == Providers.Messaging.WHATSAPP;
|
|
66
|
+
export const isFacebook = context => context.session &&
|
|
67
|
+
context.session.user &&
|
|
68
|
+
context.session.user.provider == Providers.Messaging.FACEBOOK;
|
|
69
|
+
//# sourceMappingURL=multichannel-utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"multichannel-utils.js","sourceRoot":"src/","sources":["components/multichannel/multichannel-utils.js"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export function Multichannel(props: any): any;
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { createElement as _createElement } from "react";
|
|
3
|
+
import React, { useContext } from 'react';
|
|
4
|
+
import { COMPONENT_TYPE } from '../../constants';
|
|
5
|
+
import { RequestContext } from '../../contexts';
|
|
6
|
+
import { deepMapWithIndex } from '../../util/react';
|
|
7
|
+
import { Text } from '../text';
|
|
8
|
+
import { MultichannelButton } from './multichannel-button';
|
|
9
|
+
import { MultichannelCarousel } from './multichannel-carousel';
|
|
10
|
+
import { MultichannelContext } from './multichannel-context';
|
|
11
|
+
import { MultichannelReply } from './multichannel-reply';
|
|
12
|
+
import { MultichannelText } from './multichannel-text';
|
|
13
|
+
import { isFacebook, isWhatsapp, MULTICHANNEL_WHATSAPP_PROPS, } from './multichannel-utils';
|
|
14
|
+
export const Multichannel = props => {
|
|
15
|
+
const requestContext = useContext(RequestContext);
|
|
16
|
+
if (!isWhatsapp(requestContext) && !isFacebook(requestContext)) {
|
|
17
|
+
return props.children;
|
|
18
|
+
}
|
|
19
|
+
if (isFacebook(requestContext)) {
|
|
20
|
+
const newChildren = deepMapWithIndex(props.children, child => {
|
|
21
|
+
if (child && child.type && child.type.name === COMPONENT_TYPE.TEXT) {
|
|
22
|
+
return (_createElement(MultichannelText, Object.assign({}, child.props, { key: child.key }), child.props.children));
|
|
23
|
+
}
|
|
24
|
+
return child;
|
|
25
|
+
});
|
|
26
|
+
return newChildren;
|
|
27
|
+
}
|
|
28
|
+
let newChildren = deepMapWithIndex(props.children, (child, index) => {
|
|
29
|
+
if (child && child.type && child.type.name === COMPONENT_TYPE.BUTTON) {
|
|
30
|
+
return (_createElement(MultichannelButton, Object.assign({}, child.props, { key: child.key }), child.props.children));
|
|
31
|
+
}
|
|
32
|
+
if (child && child.type && child.type.name === COMPONENT_TYPE.REPLY) {
|
|
33
|
+
return (_createElement(MultichannelReply, Object.assign({}, child.props, { key: child.key }), child.props.children));
|
|
34
|
+
}
|
|
35
|
+
if (child && child.type && child.type.name === COMPONENT_TYPE.TEXT) {
|
|
36
|
+
return (_createElement(MultichannelText, Object.assign({}, child.props, props.text, { key: child.key }, (props.messageSeparator &&
|
|
37
|
+
index > 0 && { newline: props.messageSeparator })), child.props.children));
|
|
38
|
+
}
|
|
39
|
+
if (child && child.type && child.type.name === COMPONENT_TYPE.CAROUSEL) {
|
|
40
|
+
return (_createElement(MultichannelCarousel, Object.assign({}, child.props, props.carousel, { key: child.key }), child.props.children));
|
|
41
|
+
}
|
|
42
|
+
return child;
|
|
43
|
+
});
|
|
44
|
+
if (props.messageSeparator != null) {
|
|
45
|
+
newChildren = newChildren.map((c, index) => index > 0 && typeof c === 'string' ? props.messageSeparator + c : c);
|
|
46
|
+
newChildren = (_jsx(Text, Object.assign({}, MULTICHANNEL_WHATSAPP_PROPS, { children: newChildren }), props.key));
|
|
47
|
+
}
|
|
48
|
+
return (_jsx(MultichannelContext.Provider, Object.assign({ value: {
|
|
49
|
+
currentIndex: props.firstIndex,
|
|
50
|
+
boldIndex: props.boldIndex,
|
|
51
|
+
indexSeparator: props.indexSeparator,
|
|
52
|
+
messageSeparator: props.messageSeparator,
|
|
53
|
+
} }, { children: newChildren })));
|
|
54
|
+
};
|
|
55
|
+
//# sourceMappingURL=multichannel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"multichannel.js","sourceRoot":"src/","sources":["components/multichannel/multichannel.jsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function whatsappMarkdown(text: string): string;
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
const MARKDOWN_BOLD_OPTION_1 = '**';
|
|
2
|
+
const MARKDOWN_BOLD_OPTION_2 = '__';
|
|
3
|
+
const MARKDOWN_WHATSAPP_BOLD = '*';
|
|
4
|
+
const MARKDOWN_ITALIC_OPTION_1 = '*';
|
|
5
|
+
const MARKDOWN_WHATSAPP_ITALIC = '_';
|
|
6
|
+
const MARKDOWN_BOLD_OR_ITALIC_REGEX = /(\*\*|__)(.*?)\1|(\*|_)(.*?)\3/g;
|
|
7
|
+
const MARKDOWN_NORMALIZED_BOLD_ITALIC_OPEN = '**_';
|
|
8
|
+
const MARKDOWN_NORMALIZED_BOLD_ITALIC_CLOSE = '_**';
|
|
9
|
+
const MARKDOWN_BOLD_AND_ITALIC_OPTION1 = /(_\*\*)(.*?)(\*\*_)/g;
|
|
10
|
+
const MARKDOWN_BOLD_AND_ITALIC_OPTION2 = /(\*__)(.*?)(__\*)/g;
|
|
11
|
+
const MARKDOWN_BOLD_AND_ITALIC_OPTION3 = /(__\*)(.*?)(\*__)/g;
|
|
12
|
+
export function whatsappMarkdown(text) {
|
|
13
|
+
const textNormalized = normalizeMarkdown(text);
|
|
14
|
+
const matches = textNormalized.match(MARKDOWN_BOLD_OR_ITALIC_REGEX);
|
|
15
|
+
if (matches) {
|
|
16
|
+
const matchesResult = matches.map(match => {
|
|
17
|
+
if (match.startsWith(MARKDOWN_BOLD_OPTION_1)) {
|
|
18
|
+
return replaceAllOccurrences(match, MARKDOWN_BOLD_OPTION_1, MARKDOWN_WHATSAPP_BOLD);
|
|
19
|
+
}
|
|
20
|
+
if (match.startsWith(MARKDOWN_BOLD_OPTION_2)) {
|
|
21
|
+
return replaceAllOccurrences(match, MARKDOWN_BOLD_OPTION_2, MARKDOWN_WHATSAPP_BOLD);
|
|
22
|
+
}
|
|
23
|
+
if (match.startsWith(MARKDOWN_ITALIC_OPTION_1)) {
|
|
24
|
+
return replaceAllOccurrences(match, MARKDOWN_ITALIC_OPTION_1, MARKDOWN_WHATSAPP_ITALIC);
|
|
25
|
+
}
|
|
26
|
+
return match;
|
|
27
|
+
});
|
|
28
|
+
let textWhatsapp = textNormalized;
|
|
29
|
+
for (let i = 0; i < matches.length; i++) {
|
|
30
|
+
textWhatsapp = replaceAllOccurrences(textWhatsapp, matches[i], matchesResult[i]);
|
|
31
|
+
}
|
|
32
|
+
return textWhatsapp;
|
|
33
|
+
}
|
|
34
|
+
return text;
|
|
35
|
+
}
|
|
36
|
+
function normalizeMarkdown(text) {
|
|
37
|
+
text = replaceBoldItalic(text, MARKDOWN_BOLD_AND_ITALIC_OPTION1);
|
|
38
|
+
text = replaceBoldItalic(text, MARKDOWN_BOLD_AND_ITALIC_OPTION2);
|
|
39
|
+
text = replaceBoldItalic(text, MARKDOWN_BOLD_AND_ITALIC_OPTION3);
|
|
40
|
+
return text;
|
|
41
|
+
}
|
|
42
|
+
function replaceBoldItalic(text, regex) {
|
|
43
|
+
return text.replace(regex, (match, markdownOpen, textInsideMarkdown, markdownClose) => {
|
|
44
|
+
if (match.startsWith(markdownOpen) && match.endsWith(markdownClose)) {
|
|
45
|
+
return `${MARKDOWN_NORMALIZED_BOLD_ITALIC_OPEN}${textInsideMarkdown}${MARKDOWN_NORMALIZED_BOLD_ITALIC_CLOSE}`;
|
|
46
|
+
}
|
|
47
|
+
return match;
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
function replaceAllOccurrences(text, searchValue, replaceValue) {
|
|
51
|
+
return text.split(searchValue).join(replaceValue);
|
|
52
|
+
}
|
|
53
|
+
//# sourceMappingURL=markdown.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"markdown.js","sourceRoot":"src/","sources":["components/multichannel/whatsapp/markdown.ts"],"names":[],"mappings":"AAAA,MAAM,sBAAsB,GAAG,IAAI,CAAA;AACnC,MAAM,sBAAsB,GAAG,IAAI,CAAA;AACnC,MAAM,sBAAsB,GAAG,GAAG,CAAA;AAElC,MAAM,wBAAwB,GAAG,GAAG,CAAA;AACpC,MAAM,wBAAwB,GAAG,GAAG,CAAA;AAEpC,MAAM,6BAA6B,GAAG,iCAAiC,CAAA;AAEvE,MAAM,oCAAoC,GAAG,KAAK,CAAA;AAClD,MAAM,qCAAqC,GAAG,KAAK,CAAA;AAEnD,MAAM,gCAAgC,GAAG,sBAAsB,CAAA;AAC/D,MAAM,gCAAgC,GAAG,oBAAoB,CAAA;AAC7D,MAAM,gCAAgC,GAAG,oBAAoB,CAAA;AAE7D,MAAM,UAAU,gBAAgB,CAAC,IAAY;IAC3C,MAAM,cAAc,GAAG,iBAAiB,CAAC,IAAI,CAAC,CAAA;IAC9C,MAAM,OAAO,GAAG,cAAc,CAAC,KAAK,CAAC,6BAA6B,CAAC,CAAA;IACnE,IAAI,OAAO,EAAE;QACX,MAAM,aAAa,GAAG,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE;YACxC,IAAI,KAAK,CAAC,UAAU,CAAC,sBAAsB,CAAC,EAAE;gBAC5C,OAAO,qBAAqB,CAC1B,KAAK,EACL,sBAAsB,EACtB,sBAAsB,CACvB,CAAA;aACF;YACD,IAAI,KAAK,CAAC,UAAU,CAAC,sBAAsB,CAAC,EAAE;gBAC5C,OAAO,qBAAqB,CAC1B,KAAK,EACL,sBAAsB,EACtB,sBAAsB,CACvB,CAAA;aACF;YACD,IAAI,KAAK,CAAC,UAAU,CAAC,wBAAwB,CAAC,EAAE;gBAC9C,OAAO,qBAAqB,CAC1B,KAAK,EACL,wBAAwB,EACxB,wBAAwB,CACzB,CAAA;aACF;YACD,OAAO,KAAK,CAAA;QACd,CAAC,CAAC,CAAA;QACF,IAAI,YAAY,GAAG,cAAc,CAAA;QACjC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YACvC,YAAY,GAAG,qBAAqB,CAClC,YAAY,EACZ,OAAO,CAAC,CAAC,CAAC,EACV,aAAa,CAAC,CAAC,CAAC,CACjB,CAAA;SACF;QACD,OAAO,YAAY,CAAA;KACpB;IACD,OAAO,IAAI,CAAA;AACb,CAAC;AAED,SAAS,iBAAiB,CAAC,IAAY;IACrC,IAAI,GAAG,iBAAiB,CAAC,IAAI,EAAE,gCAAgC,CAAC,CAAA;IAChE,IAAI,GAAG,iBAAiB,CAAC,IAAI,EAAE,gCAAgC,CAAC,CAAA;IAChE,IAAI,GAAG,iBAAiB,CAAC,IAAI,EAAE,gCAAgC,CAAC,CAAA;IAChE,OAAO,IAAI,CAAA;AACb,CAAC;AAED,SAAS,iBAAiB,CAAC,IAAY,EAAE,KAAa;IACpD,OAAO,IAAI,CAAC,OAAO,CACjB,KAAK,EACL,CACE,KAAa,EACb,YAAoB,EACpB,kBAA0B,EAC1B,aAAqB,EACrB,EAAE;QACF,IAAI,KAAK,CAAC,UAAU,CAAC,YAAY,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,aAAa,CAAC,EAAE;YACnE,OAAO,GAAG,oCAAoC,GAAG,kBAAkB,GAAG,qCAAqC,EAAE,CAAA;SAC9G;QACD,OAAO,KAAK,CAAA;IACd,CAAC,CACF,CAAA;AACH,CAAC;AAED,SAAS,qBAAqB,CAC5B,IAAY,EACZ,WAAmB,EACnB,YAAoB;IAEpB,OAAO,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAA;AACnD,CAAC"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import styled from 'styled-components';
|
|
4
|
+
import { COLORS, WEBCHAT } from '../constants';
|
|
5
|
+
import { staticAsset } from '../util/environment';
|
|
6
|
+
import { renderComponent } from '../util/react';
|
|
7
|
+
const PicStyled = styled.img `
|
|
8
|
+
border-top-left-radius: 8px;
|
|
9
|
+
border-top-right-radius: 8px;
|
|
10
|
+
width: ${WEBCHAT.DEFAULTS.ELEMENT_WIDTH}px;
|
|
11
|
+
height: 140px;
|
|
12
|
+
background: ${COLORS.SOLID_WHITE} url(${props => props.src}) no-repeat
|
|
13
|
+
center/cover;
|
|
14
|
+
border-bottom: 1px solid ${COLORS.SEASHELL_WHITE};
|
|
15
|
+
`;
|
|
16
|
+
export const Pic = props => {
|
|
17
|
+
props = Object.assign(Object.assign({}, props), { src: staticAsset(props.src) });
|
|
18
|
+
const renderBrowser = () => _jsx(PicStyled, { src: props.src });
|
|
19
|
+
const renderNode = () => _jsx("pic", { children: props.src });
|
|
20
|
+
return renderComponent({ renderBrowser, renderNode });
|
|
21
|
+
};
|
|
22
|
+
Pic.serialize = picProps => {
|
|
23
|
+
return { pic: picProps.src };
|
|
24
|
+
};
|
|
25
|
+
//# sourceMappingURL=pic.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pic.js","sourceRoot":"src/","sources":["components/pic.jsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,MAAM,MAAM,mBAAmB,CAAA;AAEtC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,cAAc,CAAA;AAC9C,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAA;AACjD,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAA;AAE/C,MAAM,SAAS,GAAG,MAAM,CAAC,GAAG,CAAA;;;WAGjB,OAAO,CAAC,QAAQ,CAAC,aAAa;;gBAEzB,MAAM,CAAC,WAAW,QAAQ,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,GAAG;;6BAE/B,MAAM,CAAC,cAAc;CACjD,CAAA;AAED,MAAM,CAAC,MAAM,GAAG,GAAG,KAAK,CAAC,EAAE;IACzB,KAAK,mCAAQ,KAAK,KAAE,GAAG,EAAE,WAAW,CAAC,KAAK,CAAC,GAAG,CAAC,GAAE,CAAA;IACjD,MAAM,aAAa,GAAG,GAAG,EAAE,CAAC,KAAC,SAAS,IAAC,GAAG,EAAE,KAAK,CAAC,GAAG,GAAI,CAAA;IACzD,MAAM,UAAU,GAAG,GAAG,EAAE,CAAC,wBAAM,KAAK,CAAC,GAAG,GAAO,CAAA;IAC/C,OAAO,eAAe,CAAC,EAAE,aAAa,EAAE,UAAU,EAAE,CAAC,CAAA;AACvD,CAAC,CAAA;AAED,GAAG,CAAC,SAAS,GAAG,QAAQ,CAAC,EAAE;IACzB,OAAO,EAAE,GAAG,EAAE,QAAQ,CAAC,GAAG,EAAE,CAAA;AAC9B,CAAC,CAAA"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
import { INPUT, isBrowser } from '@botonic/core';
|
|
3
|
+
import React, { useState } from 'react';
|
|
4
|
+
import styled from 'styled-components';
|
|
5
|
+
import { COLORS, ROLES } from '../constants';
|
|
6
|
+
import { Message } from './message';
|
|
7
|
+
const RawDataButton = styled.div `
|
|
8
|
+
align-self: flex-start;
|
|
9
|
+
background-color: ${COLORS.CURIOUS_BLUE};
|
|
10
|
+
padding: 4px;
|
|
11
|
+
margin: 4px 0px;
|
|
12
|
+
cursor: pointer;
|
|
13
|
+
color: ${COLORS.SOLID_WHITE_ALPHA_0_8};
|
|
14
|
+
font-size: 10px;
|
|
15
|
+
border-radius: 2px;
|
|
16
|
+
`;
|
|
17
|
+
const Popover = styled.div `
|
|
18
|
+
max-width: 100%;
|
|
19
|
+
max-height: 500px;
|
|
20
|
+
overflow: auto;
|
|
21
|
+
background-color: ${COLORS.LIGHT_GRAY};
|
|
22
|
+
padding: 10px;
|
|
23
|
+
pre {
|
|
24
|
+
margin: 0px;
|
|
25
|
+
}
|
|
26
|
+
`;
|
|
27
|
+
const serialize = rawProps => {
|
|
28
|
+
return { data: rawProps.data, alt: rawProps.alt };
|
|
29
|
+
};
|
|
30
|
+
export const Raw = props => {
|
|
31
|
+
let content = props.children;
|
|
32
|
+
const data = JSON.stringify(props.data, null, ' ');
|
|
33
|
+
const [isOpen, setIsOpen] = useState(false);
|
|
34
|
+
if (isBrowser())
|
|
35
|
+
content = (_jsxs(_Fragment, { children: [_jsx("div", { children: props.alt }), _jsxs(RawDataButton, Object.assign({ onClick: () => setIsOpen(!isOpen) }, { children: ["RAW DATA ", _jsx("small", { children: isOpen ? '▲' : '▼' })] })), isOpen && (_jsx(Popover, { children: _jsx("pre", { children: data }) }))] }));
|
|
36
|
+
return (_jsx(Message, Object.assign({ role: ROLES.RAW_MESSAGE, json: serialize(props) }, props, { data: data, type: INPUT.RAW }, { children: content })));
|
|
37
|
+
};
|
|
38
|
+
Raw.serialize = serialize;
|
|
39
|
+
//# sourceMappingURL=raw.js.map
|