botframework-webchat-component 4.15.4 → 4.15.5-main.20220927.f9dd67a
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/Activity/StackedLayout.d.ts +2 -2
- package/lib/Activity/StackedLayout.d.ts.map +1 -1
- package/lib/Activity/StackedLayout.js +1 -1
- package/lib/Composer.d.ts +4 -4
- package/lib/Composer.d.ts.map +1 -1
- package/lib/Composer.js +1 -1
- package/lib/index.js +2 -2
- package/package.json +18 -16
- package/src/Activity/StackedLayout.tsx +1 -1
- package/src/Composer.tsx +5 -1
|
@@ -5,8 +5,8 @@ declare const connectStackedLayout: (...selectors: any[]) => any;
|
|
|
5
5
|
declare type StackedLayoutProps = {
|
|
6
6
|
activity: WebChatActivity;
|
|
7
7
|
hideTimestamp?: boolean;
|
|
8
|
-
renderActivityStatus?: (
|
|
9
|
-
hideTimestamp:
|
|
8
|
+
renderActivityStatus?: (options: {
|
|
9
|
+
hideTimestamp: boolean;
|
|
10
10
|
}) => ReactNode;
|
|
11
11
|
renderAttachment?: RenderAttachment;
|
|
12
12
|
renderAvatar?: false | (() => Exclude<ReactNode, boolean | null | undefined>);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"StackedLayout.d.ts","sourceRoot":"","sources":["../../src/Activity/StackedLayout.tsx"],"names":[],"mappings":"AAgBA,OAAO,KAAK,EAAE,EAAE,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAC3C,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AACjE,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAqDjE,QAAA,MAAM,oBAAoB,8BAmBvB,CAAC;AAEJ,aAAK,kBAAkB,GAAG;IACxB,QAAQ,EAAE,eAAe,CAAC;IAC1B,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,oBAAoB,CAAC,EAAE,CAAC,EAAE,aAAa,EAAE,OAAO,
|
|
1
|
+
{"version":3,"file":"StackedLayout.d.ts","sourceRoot":"","sources":["../../src/Activity/StackedLayout.tsx"],"names":[],"mappings":"AAgBA,OAAO,KAAK,EAAE,EAAE,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAC3C,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AACjE,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAqDjE,QAAA,MAAM,oBAAoB,8BAmBvB,CAAC;AAEJ,aAAK,kBAAkB,GAAG;IACxB,QAAQ,EAAE,eAAe,CAAC;IAC1B,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,oBAAoB,CAAC,EAAE,CAAC,OAAO,EAAE;QAAE,aAAa,EAAE,OAAO,CAAA;KAAE,KAAK,SAAS,CAAC;IAC1E,gBAAgB,CAAC,EAAE,gBAAgB,CAAC;IACpC,YAAY,CAAC,EAAE,KAAK,GAAG,CAAC,MAAM,OAAO,CAAC,SAAS,EAAE,OAAO,GAAG,IAAI,GAAG,SAAS,CAAC,CAAC,CAAC;IAC9E,WAAW,CAAC,EAAE,OAAO,CAAC;CACvB,CAAC;AAEF,QAAA,MAAM,aAAa,EAAE,EAAE,CAAC,kBAAkB,CA+HzC,CAAC;AAwCF,eAAe,aAAa,CAAC;AAE7B,OAAO,EAAE,oBAAoB,EAAE,CAAC"}
|
|
@@ -284,4 +284,4 @@ StackedLayout.propTypes = {
|
|
|
284
284
|
};
|
|
285
285
|
var _default = StackedLayout;
|
|
286
286
|
exports.default = _default;
|
|
287
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["useAvatarForBot","hooks","useAvatarForUser","useLocalizer","useStyleOptions","ROOT_STYLE","position","display","flexShrink","width","flexDirection","flex","overflow","connectStackedLayout","selectors","connectToWebChat","language","styleSet","options","botAvatarInitials","userAvatarInitials","activity","from","role","undefined","avatarInitials","StackedLayout","hideTimestamp","renderActivityStatus","renderAttachment","renderAvatar","showCallout","styleOptions","botInitials","initials","userInitials","useStyleSet","stackedLayoutStyleSet","stackedLayout","ariaLabelId","useUniqueId","localize","rootClassName","useStyleToEmotionObject","bubbleNubOffset","bubbleNubSize","bubbleFromUserNubOffset","bubbleFromUserNubSize","isMessage","type","attachments","fromUser","messageBackDisplayText","channelData","messageBack","displayText","activityDisplayText","text","attachedAlt","greetingAlt","replace","nubOffset","nubSize","otherInitials","otherNubSize","hasAvatar","hasOtherAvatar","hasNub","hasOtherNub","topAlignedCallout","isZeroOrPositive","extraTrailing","showAvatar","showNub","length","classNames","attachment","content","contentType","textFormatToContentType","textFormat","map","index","defaultProps","propTypes","PropTypes","shape","array","string","isRequired","oneOf","timestamp","bool","oneOfType","func"],"sourceRoot":"component:///","sources":["../../src/Activity/StackedLayout.tsx"],"sourcesContent":["/* eslint complexity: [\"error\", 50] */\n\nimport { hooks } from 'botframework-webchat-api';\nimport classNames from 'classnames';\nimport PropTypes from 'prop-types';\nimport React from 'react';\n\nimport Bubble from './Bubble';\nimport connectToWebChat from '../connectToWebChat';\nimport isZeroOrPositive from '../Utils/isZeroOrPositive';\nimport ScreenReaderText from '../ScreenReaderText';\nimport textFormatToContentType from '../Utils/textFormatToContentType';\nimport useStyleSet from '../hooks/useStyleSet';\nimport useStyleToEmotionObject from '../hooks/internal/useStyleToEmotionObject';\nimport useUniqueId from '../hooks/internal/useUniqueId';\n\nimport type { FC, ReactNode } from 'react';\nimport type { RenderAttachment } from 'botframework-webchat-api';\nimport type { WebChatActivity } from 'botframework-webchat-core';\n\nconst { useAvatarForBot, useAvatarForUser, useLocalizer, useStyleOptions } = hooks;\n\nconst ROOT_STYLE = {\n  '&.webchat__stacked-layout': {\n    position: 'relative', // This is to keep screen reader text in the destinated area.\n\n    '& .webchat__stacked-layout__attachment-row, & .webchat__stacked-layout__main, & .webchat__stacked-layout__message-row, & .webchat__stacked-layout__status':\n      {\n        display: 'flex'\n      },\n\n    '& .webchat__stacked-layout__alignment-pad': {\n      flexShrink: 0\n    },\n\n    '& .webchat__stacked-layout__attachment': {\n      width: '100%'\n    },\n\n    '& .webchat__stacked-layout__avatar-gutter': {\n      display: 'flex',\n      flexDirection: 'column',\n      flexShrink: 0\n    },\n\n    '&.webchat__stacked-layout--from-user': {\n      '& .webchat__stacked-layout__attachment-row, & .webchat__stacked-layout__main, & .webchat__stacked-layout__message-row, & .webchat__stacked-layout__status':\n        {\n          flexDirection: 'row-reverse'\n        }\n    },\n\n    '& .webchat__stacked-layout__content': {\n      flex: 1,\n\n      // This is for bottom aligning an avatar with a message bubble shorter than the avatar.\n      // Related to the test at activityGrouping.avatarMiddleware.atBottom.js.\n      display: 'flex',\n      flexDirection: 'column',\n\n      // This \"overflow: hidden\" is to make sure text overflow will get clipped correctly.\n      // Related to the test at basic.js \"long URLs with keep-all\".\n      overflow: 'hidden'\n    },\n\n    '& .webchat__stacked-layout__nub-pad': {\n      flexShrink: 0\n    }\n  }\n};\n\nconst connectStackedLayout = (...selectors) =>\n  connectToWebChat(\n    (\n      {\n        language,\n        styleSet: {\n          options: { botAvatarInitials, userAvatarInitials }\n        }\n      },\n      { activity: { from: { role = undefined } = {} } = {} }\n    ) => ({\n      avatarInitials: role === 'user' ? userAvatarInitials : botAvatarInitials,\n      language,\n\n      // TODO: [P4] We want to deprecate botAvatarInitials/userAvatarInitials because they are not as helpful as avatarInitials\n      botAvatarInitials,\n      userAvatarInitials\n    }),\n    ...selectors\n  );\n\ntype StackedLayoutProps = {\n  activity: WebChatActivity;\n  hideTimestamp?: boolean;\n  renderActivityStatus?: ({ hideTimestamp: boolean }) => ReactNode;\n  renderAttachment?: RenderAttachment;\n  renderAvatar?: false | (() => Exclude<ReactNode, boolean | null | undefined>);\n  showCallout?: boolean;\n};\n\nconst StackedLayout: FC<StackedLayoutProps> = ({\n  activity,\n  hideTimestamp,\n  renderActivityStatus,\n  renderAttachment,\n  renderAvatar,\n  showCallout\n}) => {\n  const [styleOptions] = useStyleOptions();\n  const [{ initials: botInitials }] = useAvatarForBot();\n  const [{ initials: userInitials }] = useAvatarForUser();\n  const [{ stackedLayout: stackedLayoutStyleSet }] = useStyleSet();\n  const ariaLabelId = useUniqueId('webchat__stacked-layout__id');\n  const localize = useLocalizer();\n  const rootClassName = useStyleToEmotionObject()(ROOT_STYLE) + '';\n\n  const { bubbleNubOffset, bubbleNubSize, bubbleFromUserNubOffset, bubbleFromUserNubSize } = styleOptions;\n\n  const isMessage = activity.type === 'message';\n\n  const attachments = (isMessage && activity.attachments) || [];\n  const fromUser = activity.from.role === 'user';\n  const messageBackDisplayText: string = (isMessage && activity.channelData?.messageBack?.displayText) || '';\n\n  const activityDisplayText = isMessage ? messageBackDisplayText || activity.text : '';\n  const attachedAlt = localize(fromUser ? 'ACTIVITY_YOU_ATTACHED_ALT' : 'ACTIVITY_BOT_ATTACHED_ALT');\n  const greetingAlt = (\n    fromUser ? localize('ACTIVITY_YOU_SAID_ALT') : localize('ACTIVITY_BOT_SAID_ALT', botInitials || '')\n  ).replace(/\\s{2,}/gu, ' ');\n\n  const initials = fromUser ? userInitials : botInitials;\n  const nubOffset = fromUser ? bubbleFromUserNubOffset : bubbleNubOffset;\n  const nubSize = fromUser ? bubbleFromUserNubSize : bubbleNubSize;\n  const otherInitials = fromUser ? botInitials : userInitials;\n  const otherNubSize = fromUser ? bubbleNubSize : bubbleFromUserNubSize;\n\n  const hasAvatar = initials || typeof initials === 'string';\n  const hasOtherAvatar = otherInitials || typeof otherInitials === 'string';\n  const hasNub = typeof nubSize === 'number';\n  const hasOtherNub = typeof otherNubSize === 'number';\n  const topAlignedCallout = isZeroOrPositive(nubOffset);\n\n  const extraTrailing = !hasOtherAvatar && hasOtherNub; // This is for bot message with user nub and no user avatar. And vice versa.\n\n  const showAvatar = showCallout && hasAvatar && !!renderAvatar;\n  const showNub = showCallout && hasNub && (topAlignedCallout || !attachments?.length);\n\n  return (\n    <div\n      aria-labelledby={activityDisplayText ? ariaLabelId : undefined}\n      className={classNames('webchat__stacked-layout', rootClassName, stackedLayoutStyleSet + '', {\n        'webchat__stacked-layout--extra-trailing': extraTrailing,\n        'webchat__stacked-layout--from-user': fromUser,\n        'webchat__stacked-layout--hide-avatar': hasAvatar && !showAvatar,\n        'webchat__stacked-layout--hide-nub': hasNub && !showNub,\n        'webchat__stacked-layout--no-message': !activityDisplayText,\n        'webchat__stacked-layout--show-avatar': showAvatar,\n        'webchat__stacked-layout--show-nub': showNub,\n        'webchat__stacked-layout--top-callout': topAlignedCallout\n      })}\n    >\n      <div className=\"webchat__stacked-layout__main\">\n        <div className=\"webchat__stacked-layout__avatar-gutter\">{showAvatar && renderAvatar()}</div>\n        <div className=\"webchat__stacked-layout__content\">\n          {!!activityDisplayText && (\n            <div\n              aria-roledescription=\"message\"\n              className=\"webchat__stacked-layout__message-row\"\n              // Disable \"Prop `id` is forbidden on DOM Nodes\" rule because we are using the ID prop for accessibility.\n              /* eslint-disable-next-line react/forbid-dom-props */\n              id={ariaLabelId}\n              role=\"group\"\n            >\n              <ScreenReaderText text={greetingAlt} />\n              <Bubble\n                className=\"webchat__stacked-layout__message\"\n                fromUser={fromUser}\n                nub={showNub || (hasAvatar || hasNub ? 'hidden' : false)}\n              >\n                {renderAttachment({\n                  activity,\n                  attachment: isMessage\n                    ? {\n                        content: activityDisplayText,\n                        contentType: textFormatToContentType(activity.textFormat)\n                      }\n                    : undefined\n                })}\n              </Bubble>\n            </div>\n          )}\n          {attachments.map((attachment, index) => (\n            <div\n              aria-roledescription=\"attachment\"\n              className={classNames('webchat__stacked-layout__attachment-row', {\n                'webchat__stacked-layout__attachment-row--first': !index\n              })}\n              /* attachments do not have an ID, it is always indexed by number */\n              /* eslint-disable-next-line react/no-array-index-key */\n              key={index}\n              role=\"group\"\n            >\n              <ScreenReaderText text={attachedAlt} />\n              <Bubble\n                className=\"webchat__stacked-layout__attachment\"\n                fromUser={fromUser}\n                /* eslint-disable-next-line react/no-array-index-key */\n                key={index}\n                nub={hasAvatar || hasNub ? 'hidden' : false}\n              >\n                {renderAttachment({ activity, attachment })}\n              </Bubble>\n            </div>\n          ))}\n        </div>\n        <div className=\"webchat__stacked-layout__alignment-pad\" />\n      </div>\n      {typeof renderActivityStatus === 'function' && (\n        <div className=\"webchat__stacked-layout__status\">\n          <div className=\"webchat__stacked-layout__avatar-gutter\" />\n          <div className=\"webchat__stacked-layout__nub-pad\" />\n          {renderActivityStatus({ hideTimestamp })}\n          <div className=\"webchat__stacked-layout__alignment-pad\" />\n        </div>\n      )}\n    </div>\n  );\n};\n\nStackedLayout.defaultProps = {\n  hideTimestamp: false,\n  renderActivityStatus: () => false,\n  renderAvatar: undefined,\n  showCallout: true\n};\n\nStackedLayout.propTypes = {\n  // PropTypes cannot fully capture TypeScript types.\n  // @ts-ignore\n  activity: PropTypes.shape({\n    attachments: PropTypes.array,\n    channelData: PropTypes.shape({\n      messageBack: PropTypes.shape({\n        displayText: PropTypes.string\n      })\n    }),\n    from: PropTypes.shape({\n      role: PropTypes.string.isRequired\n    }).isRequired,\n    text: PropTypes.string,\n    textFormat: PropTypes.oneOf(['markdown', 'plain', 'xml']),\n    timestamp: PropTypes.string,\n    type: PropTypes.string.isRequired\n  }).isRequired,\n  hideTimestamp: PropTypes.bool,\n\n  // PropTypes cannot validate precisely with its TypeScript counterpart.\n  // @ts-ignore\n  renderActivityStatus: PropTypes.oneOfType([PropTypes.oneOf([false]), PropTypes.func]),\n  renderAttachment: PropTypes.func.isRequired,\n\n  // PropTypes cannot validate precisely with its TypeScript counterpart.\n  // @ts-ignore\n  renderAvatar: PropTypes.oneOfType([PropTypes.oneOf([false]), PropTypes.func]),\n  showCallout: PropTypes.bool\n};\n\nexport default StackedLayout;\n\nexport { connectStackedLayout };\n"],"mappings":"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"}
|
|
287
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["useAvatarForBot","hooks","useAvatarForUser","useLocalizer","useStyleOptions","ROOT_STYLE","position","display","flexShrink","width","flexDirection","flex","overflow","connectStackedLayout","selectors","connectToWebChat","language","styleSet","options","botAvatarInitials","userAvatarInitials","activity","from","role","undefined","avatarInitials","StackedLayout","hideTimestamp","renderActivityStatus","renderAttachment","renderAvatar","showCallout","styleOptions","botInitials","initials","userInitials","useStyleSet","stackedLayoutStyleSet","stackedLayout","ariaLabelId","useUniqueId","localize","rootClassName","useStyleToEmotionObject","bubbleNubOffset","bubbleNubSize","bubbleFromUserNubOffset","bubbleFromUserNubSize","isMessage","type","attachments","fromUser","messageBackDisplayText","channelData","messageBack","displayText","activityDisplayText","text","attachedAlt","greetingAlt","replace","nubOffset","nubSize","otherInitials","otherNubSize","hasAvatar","hasOtherAvatar","hasNub","hasOtherNub","topAlignedCallout","isZeroOrPositive","extraTrailing","showAvatar","showNub","length","classNames","attachment","content","contentType","textFormatToContentType","textFormat","map","index","defaultProps","propTypes","PropTypes","shape","array","string","isRequired","oneOf","timestamp","bool","oneOfType","func"],"sourceRoot":"component:///","sources":["../../src/Activity/StackedLayout.tsx"],"sourcesContent":["/* eslint complexity: [\"error\", 50] */\n\nimport { hooks } from 'botframework-webchat-api';\nimport classNames from 'classnames';\nimport PropTypes from 'prop-types';\nimport React from 'react';\n\nimport Bubble from './Bubble';\nimport connectToWebChat from '../connectToWebChat';\nimport isZeroOrPositive from '../Utils/isZeroOrPositive';\nimport ScreenReaderText from '../ScreenReaderText';\nimport textFormatToContentType from '../Utils/textFormatToContentType';\nimport useStyleSet from '../hooks/useStyleSet';\nimport useStyleToEmotionObject from '../hooks/internal/useStyleToEmotionObject';\nimport useUniqueId from '../hooks/internal/useUniqueId';\n\nimport type { FC, ReactNode } from 'react';\nimport type { RenderAttachment } from 'botframework-webchat-api';\nimport type { WebChatActivity } from 'botframework-webchat-core';\n\nconst { useAvatarForBot, useAvatarForUser, useLocalizer, useStyleOptions } = hooks;\n\nconst ROOT_STYLE = {\n  '&.webchat__stacked-layout': {\n    position: 'relative', // This is to keep screen reader text in the destinated area.\n\n    '& .webchat__stacked-layout__attachment-row, & .webchat__stacked-layout__main, & .webchat__stacked-layout__message-row, & .webchat__stacked-layout__status':\n      {\n        display: 'flex'\n      },\n\n    '& .webchat__stacked-layout__alignment-pad': {\n      flexShrink: 0\n    },\n\n    '& .webchat__stacked-layout__attachment': {\n      width: '100%'\n    },\n\n    '& .webchat__stacked-layout__avatar-gutter': {\n      display: 'flex',\n      flexDirection: 'column',\n      flexShrink: 0\n    },\n\n    '&.webchat__stacked-layout--from-user': {\n      '& .webchat__stacked-layout__attachment-row, & .webchat__stacked-layout__main, & .webchat__stacked-layout__message-row, & .webchat__stacked-layout__status':\n        {\n          flexDirection: 'row-reverse'\n        }\n    },\n\n    '& .webchat__stacked-layout__content': {\n      flex: 1,\n\n      // This is for bottom aligning an avatar with a message bubble shorter than the avatar.\n      // Related to the test at activityGrouping.avatarMiddleware.atBottom.js.\n      display: 'flex',\n      flexDirection: 'column',\n\n      // This \"overflow: hidden\" is to make sure text overflow will get clipped correctly.\n      // Related to the test at basic.js \"long URLs with keep-all\".\n      overflow: 'hidden'\n    },\n\n    '& .webchat__stacked-layout__nub-pad': {\n      flexShrink: 0\n    }\n  }\n};\n\nconst connectStackedLayout = (...selectors) =>\n  connectToWebChat(\n    (\n      {\n        language,\n        styleSet: {\n          options: { botAvatarInitials, userAvatarInitials }\n        }\n      },\n      { activity: { from: { role = undefined } = {} } = {} }\n    ) => ({\n      avatarInitials: role === 'user' ? userAvatarInitials : botAvatarInitials,\n      language,\n\n      // TODO: [P4] We want to deprecate botAvatarInitials/userAvatarInitials because they are not as helpful as avatarInitials\n      botAvatarInitials,\n      userAvatarInitials\n    }),\n    ...selectors\n  );\n\ntype StackedLayoutProps = {\n  activity: WebChatActivity;\n  hideTimestamp?: boolean;\n  renderActivityStatus?: (options: { hideTimestamp: boolean }) => ReactNode;\n  renderAttachment?: RenderAttachment;\n  renderAvatar?: false | (() => Exclude<ReactNode, boolean | null | undefined>);\n  showCallout?: boolean;\n};\n\nconst StackedLayout: FC<StackedLayoutProps> = ({\n  activity,\n  hideTimestamp,\n  renderActivityStatus,\n  renderAttachment,\n  renderAvatar,\n  showCallout\n}) => {\n  const [styleOptions] = useStyleOptions();\n  const [{ initials: botInitials }] = useAvatarForBot();\n  const [{ initials: userInitials }] = useAvatarForUser();\n  const [{ stackedLayout: stackedLayoutStyleSet }] = useStyleSet();\n  const ariaLabelId = useUniqueId('webchat__stacked-layout__id');\n  const localize = useLocalizer();\n  const rootClassName = useStyleToEmotionObject()(ROOT_STYLE) + '';\n\n  const { bubbleNubOffset, bubbleNubSize, bubbleFromUserNubOffset, bubbleFromUserNubSize } = styleOptions;\n\n  const isMessage = activity.type === 'message';\n\n  const attachments = (isMessage && activity.attachments) || [];\n  const fromUser = activity.from.role === 'user';\n  const messageBackDisplayText: string = (isMessage && activity.channelData?.messageBack?.displayText) || '';\n\n  const activityDisplayText = isMessage ? messageBackDisplayText || activity.text : '';\n  const attachedAlt = localize(fromUser ? 'ACTIVITY_YOU_ATTACHED_ALT' : 'ACTIVITY_BOT_ATTACHED_ALT');\n  const greetingAlt = (\n    fromUser ? localize('ACTIVITY_YOU_SAID_ALT') : localize('ACTIVITY_BOT_SAID_ALT', botInitials || '')\n  ).replace(/\\s{2,}/gu, ' ');\n\n  const initials = fromUser ? userInitials : botInitials;\n  const nubOffset = fromUser ? bubbleFromUserNubOffset : bubbleNubOffset;\n  const nubSize = fromUser ? bubbleFromUserNubSize : bubbleNubSize;\n  const otherInitials = fromUser ? botInitials : userInitials;\n  const otherNubSize = fromUser ? bubbleNubSize : bubbleFromUserNubSize;\n\n  const hasAvatar = initials || typeof initials === 'string';\n  const hasOtherAvatar = otherInitials || typeof otherInitials === 'string';\n  const hasNub = typeof nubSize === 'number';\n  const hasOtherNub = typeof otherNubSize === 'number';\n  const topAlignedCallout = isZeroOrPositive(nubOffset);\n\n  const extraTrailing = !hasOtherAvatar && hasOtherNub; // This is for bot message with user nub and no user avatar. And vice versa.\n\n  const showAvatar = showCallout && hasAvatar && !!renderAvatar;\n  const showNub = showCallout && hasNub && (topAlignedCallout || !attachments?.length);\n\n  return (\n    <div\n      aria-labelledby={activityDisplayText ? ariaLabelId : undefined}\n      className={classNames('webchat__stacked-layout', rootClassName, stackedLayoutStyleSet + '', {\n        'webchat__stacked-layout--extra-trailing': extraTrailing,\n        'webchat__stacked-layout--from-user': fromUser,\n        'webchat__stacked-layout--hide-avatar': hasAvatar && !showAvatar,\n        'webchat__stacked-layout--hide-nub': hasNub && !showNub,\n        'webchat__stacked-layout--no-message': !activityDisplayText,\n        'webchat__stacked-layout--show-avatar': showAvatar,\n        'webchat__stacked-layout--show-nub': showNub,\n        'webchat__stacked-layout--top-callout': topAlignedCallout\n      })}\n    >\n      <div className=\"webchat__stacked-layout__main\">\n        <div className=\"webchat__stacked-layout__avatar-gutter\">{showAvatar && renderAvatar()}</div>\n        <div className=\"webchat__stacked-layout__content\">\n          {!!activityDisplayText && (\n            <div\n              aria-roledescription=\"message\"\n              className=\"webchat__stacked-layout__message-row\"\n              // Disable \"Prop `id` is forbidden on DOM Nodes\" rule because we are using the ID prop for accessibility.\n              /* eslint-disable-next-line react/forbid-dom-props */\n              id={ariaLabelId}\n              role=\"group\"\n            >\n              <ScreenReaderText text={greetingAlt} />\n              <Bubble\n                className=\"webchat__stacked-layout__message\"\n                fromUser={fromUser}\n                nub={showNub || (hasAvatar || hasNub ? 'hidden' : false)}\n              >\n                {renderAttachment({\n                  activity,\n                  attachment: isMessage\n                    ? {\n                        content: activityDisplayText,\n                        contentType: textFormatToContentType(activity.textFormat)\n                      }\n                    : undefined\n                })}\n              </Bubble>\n            </div>\n          )}\n          {attachments.map((attachment, index) => (\n            <div\n              aria-roledescription=\"attachment\"\n              className={classNames('webchat__stacked-layout__attachment-row', {\n                'webchat__stacked-layout__attachment-row--first': !index\n              })}\n              /* attachments do not have an ID, it is always indexed by number */\n              /* eslint-disable-next-line react/no-array-index-key */\n              key={index}\n              role=\"group\"\n            >\n              <ScreenReaderText text={attachedAlt} />\n              <Bubble\n                className=\"webchat__stacked-layout__attachment\"\n                fromUser={fromUser}\n                /* eslint-disable-next-line react/no-array-index-key */\n                key={index}\n                nub={hasAvatar || hasNub ? 'hidden' : false}\n              >\n                {renderAttachment({ activity, attachment })}\n              </Bubble>\n            </div>\n          ))}\n        </div>\n        <div className=\"webchat__stacked-layout__alignment-pad\" />\n      </div>\n      {typeof renderActivityStatus === 'function' && (\n        <div className=\"webchat__stacked-layout__status\">\n          <div className=\"webchat__stacked-layout__avatar-gutter\" />\n          <div className=\"webchat__stacked-layout__nub-pad\" />\n          {renderActivityStatus({ hideTimestamp })}\n          <div className=\"webchat__stacked-layout__alignment-pad\" />\n        </div>\n      )}\n    </div>\n  );\n};\n\nStackedLayout.defaultProps = {\n  hideTimestamp: false,\n  renderActivityStatus: () => false,\n  renderAvatar: undefined,\n  showCallout: true\n};\n\nStackedLayout.propTypes = {\n  // PropTypes cannot fully capture TypeScript types.\n  // @ts-ignore\n  activity: PropTypes.shape({\n    attachments: PropTypes.array,\n    channelData: PropTypes.shape({\n      messageBack: PropTypes.shape({\n        displayText: PropTypes.string\n      })\n    }),\n    from: PropTypes.shape({\n      role: PropTypes.string.isRequired\n    }).isRequired,\n    text: PropTypes.string,\n    textFormat: PropTypes.oneOf(['markdown', 'plain', 'xml']),\n    timestamp: PropTypes.string,\n    type: PropTypes.string.isRequired\n  }).isRequired,\n  hideTimestamp: PropTypes.bool,\n\n  // PropTypes cannot validate precisely with its TypeScript counterpart.\n  // @ts-ignore\n  renderActivityStatus: PropTypes.oneOfType([PropTypes.oneOf([false]), PropTypes.func]),\n  renderAttachment: PropTypes.func.isRequired,\n\n  // PropTypes cannot validate precisely with its TypeScript counterpart.\n  // @ts-ignore\n  renderAvatar: PropTypes.oneOfType([PropTypes.oneOf([false]), PropTypes.func]),\n  showCallout: PropTypes.bool\n};\n\nexport default StackedLayout;\n\nexport { connectStackedLayout };\n"],"mappings":"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"}
|
package/lib/Composer.d.ts
CHANGED
|
@@ -5,10 +5,10 @@ declare type ComposerCoreProps = {
|
|
|
5
5
|
children?: ReactNode;
|
|
6
6
|
extraStyleSet?: any;
|
|
7
7
|
nonce?: string;
|
|
8
|
-
renderMarkdown?: (markdown: string,
|
|
9
|
-
markdownRespectCRLF:
|
|
10
|
-
},
|
|
11
|
-
externalLinkAlt:
|
|
8
|
+
renderMarkdown?: (markdown: string, newLineOptions: {
|
|
9
|
+
markdownRespectCRLF: boolean;
|
|
10
|
+
}, linkOptions: {
|
|
11
|
+
externalLinkAlt: string;
|
|
12
12
|
}) => string;
|
|
13
13
|
styleSet?: any;
|
|
14
14
|
suggestedActionsAccessKey?: boolean | string;
|
package/lib/Composer.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Composer.d.ts","sourceRoot":"","sources":["../src/Composer.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAkC,wBAAwB,EAAE,MAAM,0BAA0B,CAAC;AAgCpG,OAAO,KAAK,EAAE,aAAa,IAAI,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAClF,OAAO,KAAK,EAAE,EAAE,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAY3C,aAAK,iBAAiB,GAAG;IACvB,QAAQ,CAAC,EAAE,SAAS,CAAC;IACrB,aAAa,CAAC,EAAE,GAAG,CAAC;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,cAAc,CAAC,EAAE,
|
|
1
|
+
{"version":3,"file":"Composer.d.ts","sourceRoot":"","sources":["../src/Composer.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAkC,wBAAwB,EAAE,MAAM,0BAA0B,CAAC;AAgCpG,OAAO,KAAK,EAAE,aAAa,IAAI,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAClF,OAAO,KAAK,EAAE,EAAE,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAY3C,aAAK,iBAAiB,GAAG;IACvB,QAAQ,CAAC,EAAE,SAAS,CAAC;IACrB,aAAa,CAAC,EAAE,GAAG,CAAC;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,cAAc,CAAC,EAAE,CACf,QAAQ,EAAE,MAAM,EAChB,cAAc,EAAE;QAAE,mBAAmB,EAAE,OAAO,CAAA;KAAE,EAChD,WAAW,EAAE;QAAE,eAAe,EAAE,MAAM,CAAA;KAAE,KACrC,MAAM,CAAC;IACZ,QAAQ,CAAC,EAAE,GAAG,CAAC;IACf,yBAAyB,CAAC,EAAE,OAAO,GAAG,MAAM,CAAC;IAC7C,wBAAwB,CAAC,EAAE,wBAAwB,CAAC;CACrD,CAAC;AAsMF,aAAK,aAAa,GAAG,gBAAgB,GAAG,iBAAiB,CAAC;AAE1D,QAAA,MAAM,QAAQ,EAAE,EAAE,CAAC,aAAa,CAwG/B,CAAC;AAcF,eAAe,QAAQ,CAAC;AAExB,YAAY,EAAE,aAAa,EAAE,CAAC"}
|
package/lib/Composer.js
CHANGED
|
@@ -365,4 +365,4 @@ Composer.propTypes = _objectSpread(_objectSpread(_objectSpread({}, _botframework
|
|
|
365
365
|
});
|
|
366
366
|
var _default = Composer;
|
|
367
367
|
exports.default = _default;
|
|
368
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["useGetActivityByKey","hooks","useReferenceGrammarID","useStyleOptions","node_env","emotionPool","styleSetToEmotionObjects","styleToEmotionObject","styleSet","mapMap","style","key","ComposerCore","children","extraStyleSet","nonce","renderMarkdown","suggestedActionsAccessKey","webSpeechPonyfillFactory","useState","dictateAbortable","setDictateAbortable","referenceGrammarID","styleOptions","focusSendBoxCallbacksRef","useRef","focusTranscriptCallbacksRef","internalMarkdownIt","useMemo","MarkdownIt","scrollToCallbacksRef","scrollToEndCallbacksRef","scrollRelativeCallbacksRef","dictationOnError","useCallback","err","console","error","internalRenderMarkdownInline","markdown","tree","parseInline","patchedTree","addTargetBlankToHyperlinksMarkdown","renderer","render","emotion","createEmotion","createCSSKey","css","patchedStyleSet","createStyleSet","webSpeechPonyfill","ponyfill","speechSynthesis","SpeechSynthesisUtterance","bypassSpeechSynthesis","BypassSpeechSynthesisUtterance","scrollPositionObserversRef","dispatchScrollPosition","event","current","forEach","observer","observeScrollPosition","filter","target","transcriptFocusObserversRef","numTranscriptFocusObservers","setNumTranscriptFocusObservers","getActivityByKey","dispatchTranscriptFocusByActivityKey","prevActivityKey","Symbol","activityKey","activity","observeTranscriptFocus","length","context","internalMarkdownItState","defaultProps","undefined","propTypes","PropTypes","any","string","func","oneOfType","oneOf","Composer","activityMiddleware","activityStatusMiddleware","attachmentForScreenReaderMiddleware","attachmentMiddleware","avatarMiddleware","cardActionMiddleware","scrollToEndButtonMiddleware","toastMiddleware","typingIndicatorMiddleware","composerProps","onTelemetry","patchedActivityMiddleware","singleToArray","createDefaultActivityMiddleware","patchedActivityStatusMiddleware","createDefaultActivityStatusMiddleware","patchedAttachmentForScreenReaderMiddleware","createDefaultAttachmentForScreenReaderMiddleware","patchedAttachmentMiddleware","createDefaultAttachmentMiddleware","patchedAvatarMiddleware","createDefaultAvatarMiddleware","patchedCardActionMiddleware","createDefaultCardActionMiddleware","patchedToastMiddleware","createDefaultToastMiddleware","patchedTypingIndicatorMiddleware","createDefaultTypingIndicatorMiddleware","defaultScrollToEndButtonMiddleware","createDefaultScrollToEndButtonMiddleware","patchedScrollToEndButtonMiddleware","downscaleImageToDataURL","ErrorBox","APIComposer"],"sourceRoot":"component:///","sources":["../src/Composer.tsx"],"sourcesContent":["import { Composer as APIComposer, hooks, WebSpeechPonyfillFactory } from 'botframework-webchat-api';\nimport { Composer as SayComposer } from 'react-say';\nimport { singleToArray } from 'botframework-webchat-core';\nimport createEmotion from '@emotion/css/create-instance';\nimport createStyleSet from './Styles/createStyleSet';\nimport MarkdownIt from 'markdown-it';\nimport PropTypes from 'prop-types';\nimport React, { useCallback, useMemo, useRef, useState } from 'react';\n\nimport {\n  speechSynthesis as bypassSpeechSynthesis,\n  SpeechSynthesisUtterance as BypassSpeechSynthesisUtterance\n} from './hooks/internal/BypassSpeechSynthesisPonyfill';\nimport ActivityTreeComposer from './providers/ActivityTree/ActivityTreeComposer';\nimport addTargetBlankToHyperlinksMarkdown from './Utils/addTargetBlankToHyperlinksMarkdown';\nimport createCSSKey from './Utils/createCSSKey';\nimport createDefaultActivityMiddleware from './Middleware/Activity/createCoreMiddleware';\nimport createDefaultActivityStatusMiddleware from './Middleware/ActivityStatus/createCoreMiddleware';\nimport createDefaultAttachmentForScreenReaderMiddleware from './Middleware/AttachmentForScreenReader/createCoreMiddleware';\nimport createDefaultAttachmentMiddleware from './Middleware/Attachment/createCoreMiddleware';\nimport createDefaultAvatarMiddleware from './Middleware/Avatar/createCoreMiddleware';\nimport createDefaultCardActionMiddleware from './Middleware/CardAction/createCoreMiddleware';\nimport createDefaultScrollToEndButtonMiddleware from './Middleware/ScrollToEndButton/createScrollToEndButtonMiddleware';\nimport createDefaultToastMiddleware from './Middleware/Toast/createCoreMiddleware';\nimport createDefaultTypingIndicatorMiddleware from './Middleware/TypingIndicator/createCoreMiddleware';\nimport Dictation from './Dictation';\nimport downscaleImageToDataURL from './Utils/downscaleImageToDataURL';\nimport ErrorBox from './ErrorBox';\nimport mapMap from './Utils/mapMap';\nimport UITracker from './hooks/internal/UITracker';\nimport WebChatUIContext from './hooks/internal/WebChatUIContext';\n\nimport type { ComposerProps as APIComposerProps } from 'botframework-webchat-api';\nimport type { FC, ReactNode } from 'react';\n\nconst { useGetActivityByKey, useReferenceGrammarID, useStyleOptions } = hooks;\n\nconst node_env = process.env.node_env || process.env.NODE_ENV;\n\nconst emotionPool = {};\n\nfunction styleSetToEmotionObjects(styleToEmotionObject, styleSet) {\n  return mapMap(styleSet, (style, key) => (key === 'options' ? style : styleToEmotionObject(style)));\n}\n\ntype ComposerCoreProps = {\n  children?: ReactNode;\n  extraStyleSet?: any;\n  nonce?: string;\n  renderMarkdown?: (markdown: string, { markdownRespectCRLF: boolean }, { externalLinkAlt: string }) => string;\n  styleSet?: any;\n  suggestedActionsAccessKey?: boolean | string;\n  webSpeechPonyfillFactory?: WebSpeechPonyfillFactory;\n};\n\nconst ComposerCore: FC<ComposerCoreProps> = ({\n  children,\n  extraStyleSet,\n  nonce,\n  renderMarkdown,\n  styleSet,\n  suggestedActionsAccessKey,\n  webSpeechPonyfillFactory\n}) => {\n  const [dictateAbortable, setDictateAbortable] = useState();\n  const [referenceGrammarID] = useReferenceGrammarID();\n  const [styleOptions] = useStyleOptions();\n  const focusSendBoxCallbacksRef = useRef([]);\n  const focusTranscriptCallbacksRef = useRef([]);\n  const internalMarkdownIt = useMemo(() => new MarkdownIt(), []);\n  const scrollToCallbacksRef = useRef([]);\n  const scrollToEndCallbacksRef = useRef([]);\n\n  // Instead of having a `scrollUpCallbacksRef` and `scrollDownCallbacksRef`, they are combined into a single `scrollRelativeCallbacksRef`.\n  // The first argument tells whether it should go \"up\" or \"down\".\n  const scrollRelativeCallbacksRef = useRef([]);\n\n  const dictationOnError = useCallback(err => {\n    console.error(err);\n  }, []);\n\n  const internalRenderMarkdownInline = useMemo(\n    () => markdown => {\n      const tree = internalMarkdownIt.parseInline(markdown);\n\n      // We should add rel=\"noopener noreferrer\" and target=\"_blank\"\n      const patchedTree = addTargetBlankToHyperlinksMarkdown(tree);\n\n      return internalMarkdownIt.renderer.render(patchedTree);\n    },\n    [internalMarkdownIt]\n  );\n\n  const styleToEmotionObject = useMemo(() => {\n    // Emotion doesn't hash with nonce. We need to provide the pooling mechanism.\n    // 1. If 2 instances use different nonce, they should result in different hash;\n    // 2. If 2 instances are being mounted, pooling will make sure we render only 1 set of <style> tags, instead of 2.\n    const emotion =\n      // Prefix \"id-\" to prevent object injection attack.\n      emotionPool[`id-${nonce}`] ||\n      (emotionPool[`id-${nonce}`] = createEmotion({ key: `webchat--css-${createCSSKey()}`, nonce }));\n\n    return style => emotion.css(style);\n  }, [nonce]);\n\n  const patchedStyleSet = useMemo(\n    () =>\n      styleSetToEmotionObjects(styleToEmotionObject, {\n        ...(styleSet || createStyleSet(styleOptions)),\n        ...extraStyleSet\n      }),\n    [extraStyleSet, styleOptions, styleSet, styleToEmotionObject]\n  );\n\n  const webSpeechPonyfill = useMemo(() => {\n    const ponyfill = webSpeechPonyfillFactory && webSpeechPonyfillFactory({ referenceGrammarID });\n    const { speechSynthesis, SpeechSynthesisUtterance } = ponyfill || {};\n\n    return {\n      ...ponyfill,\n      speechSynthesis: speechSynthesis || bypassSpeechSynthesis,\n      SpeechSynthesisUtterance: SpeechSynthesisUtterance || BypassSpeechSynthesisUtterance\n    };\n  }, [referenceGrammarID, webSpeechPonyfillFactory]);\n\n  const scrollPositionObserversRef = useRef([]);\n\n  const dispatchScrollPosition = useCallback(\n    event => scrollPositionObserversRef.current.forEach(observer => observer(event)),\n    [scrollPositionObserversRef]\n  );\n\n  const observeScrollPosition = useCallback(\n    observer => {\n      scrollPositionObserversRef.current = [...scrollPositionObserversRef.current, observer];\n\n      return () => {\n        scrollPositionObserversRef.current = scrollPositionObserversRef.current.filter(target => target !== observer);\n      };\n    },\n    [scrollPositionObserversRef]\n  );\n\n  const transcriptFocusObserversRef = useRef([]);\n  const [numTranscriptFocusObservers, setNumTranscriptFocusObservers] = useState(0);\n\n  const getActivityByKey = useGetActivityByKey();\n\n  const dispatchTranscriptFocusByActivityKey = useMemo(() => {\n    let prevActivityKey: string | Symbol | undefined = Symbol();\n\n    return activityKey => {\n      if (activityKey !== prevActivityKey) {\n        prevActivityKey = activityKey;\n\n        const event = { activity: getActivityByKey(activityKey) };\n\n        transcriptFocusObserversRef.current.forEach(observer => observer(event));\n      }\n    };\n  }, [getActivityByKey, transcriptFocusObserversRef]);\n\n  const observeTranscriptFocus = useCallback(\n    observer => {\n      transcriptFocusObserversRef.current = [...transcriptFocusObserversRef.current, observer];\n      setNumTranscriptFocusObservers(transcriptFocusObserversRef.current.length);\n\n      return () => {\n        transcriptFocusObserversRef.current = transcriptFocusObserversRef.current.filter(target => target !== observer);\n        setNumTranscriptFocusObservers(transcriptFocusObserversRef.current.length);\n      };\n    },\n    [transcriptFocusObserversRef, setNumTranscriptFocusObservers]\n  );\n\n  const context = useMemo(\n    () => ({\n      dictateAbortable,\n      dispatchScrollPosition,\n      dispatchTranscriptFocusByActivityKey,\n      focusSendBoxCallbacksRef,\n      focusTranscriptCallbacksRef,\n      internalMarkdownItState: [internalMarkdownIt],\n      internalRenderMarkdownInline,\n      nonce,\n      numTranscriptFocusObservers,\n      observeScrollPosition,\n      observeTranscriptFocus,\n      renderMarkdown,\n      scrollRelativeCallbacksRef,\n      scrollToCallbacksRef,\n      scrollToEndCallbacksRef,\n      setDictateAbortable,\n      styleSet: patchedStyleSet,\n      styleToEmotionObject,\n      suggestedActionsAccessKey,\n      webSpeechPonyfill\n    }),\n    [\n      dictateAbortable,\n      dispatchScrollPosition,\n      dispatchTranscriptFocusByActivityKey,\n      focusSendBoxCallbacksRef,\n      focusTranscriptCallbacksRef,\n      internalMarkdownIt,\n      internalRenderMarkdownInline,\n      nonce,\n      numTranscriptFocusObservers,\n      observeScrollPosition,\n      observeTranscriptFocus,\n      patchedStyleSet,\n      renderMarkdown,\n      scrollRelativeCallbacksRef,\n      scrollToCallbacksRef,\n      scrollToEndCallbacksRef,\n      setDictateAbortable,\n      styleToEmotionObject,\n      suggestedActionsAccessKey,\n      webSpeechPonyfill\n    ]\n  );\n\n  return (\n    <SayComposer ponyfill={webSpeechPonyfill}>\n      <WebChatUIContext.Provider value={context}>\n        {children}\n        <Dictation onError={dictationOnError} />\n      </WebChatUIContext.Provider>\n    </SayComposer>\n  );\n};\n\nComposerCore.defaultProps = {\n  children: undefined,\n  extraStyleSet: undefined,\n  nonce: undefined,\n  renderMarkdown: undefined,\n  styleSet: undefined,\n  suggestedActionsAccessKey: 'A a Å å',\n  webSpeechPonyfillFactory: undefined\n};\n\nComposerCore.propTypes = {\n  extraStyleSet: PropTypes.any,\n  nonce: PropTypes.string,\n  renderMarkdown: PropTypes.func,\n  styleSet: PropTypes.any,\n  suggestedActionsAccessKey: PropTypes.oneOfType([PropTypes.oneOf([false]), PropTypes.string]),\n  webSpeechPonyfillFactory: PropTypes.func\n};\n\ntype ComposerProps = APIComposerProps & ComposerCoreProps;\n\nconst Composer: FC<ComposerProps> = ({\n  activityMiddleware,\n  activityStatusMiddleware,\n  attachmentForScreenReaderMiddleware,\n  attachmentMiddleware,\n  avatarMiddleware,\n  cardActionMiddleware,\n  children,\n  extraStyleSet,\n  renderMarkdown,\n  scrollToEndButtonMiddleware,\n  styleSet,\n  suggestedActionsAccessKey,\n  toastMiddleware,\n  typingIndicatorMiddleware,\n  webSpeechPonyfillFactory,\n  ...composerProps\n}) => {\n  const { nonce, onTelemetry } = composerProps;\n\n  const patchedActivityMiddleware = useMemo(\n    () => [...singleToArray(activityMiddleware), ...createDefaultActivityMiddleware()],\n    [activityMiddleware]\n  );\n\n  const patchedActivityStatusMiddleware = useMemo(\n    () => [...singleToArray(activityStatusMiddleware), ...createDefaultActivityStatusMiddleware()],\n    [activityStatusMiddleware]\n  );\n\n  const patchedAttachmentForScreenReaderMiddleware = useMemo(\n    () => [\n      ...singleToArray(attachmentForScreenReaderMiddleware),\n      ...createDefaultAttachmentForScreenReaderMiddleware()\n    ],\n    [attachmentForScreenReaderMiddleware]\n  );\n\n  const patchedAttachmentMiddleware = useMemo(\n    () => [...singleToArray(attachmentMiddleware), ...createDefaultAttachmentMiddleware()],\n    [attachmentMiddleware]\n  );\n\n  const patchedAvatarMiddleware = useMemo(\n    () => [...singleToArray(avatarMiddleware), ...createDefaultAvatarMiddleware()],\n    [avatarMiddleware]\n  );\n\n  const patchedCardActionMiddleware = useMemo(\n    () => [...singleToArray(cardActionMiddleware), ...createDefaultCardActionMiddleware()],\n    [cardActionMiddleware]\n  );\n\n  const patchedToastMiddleware = useMemo(\n    () => [...singleToArray(toastMiddleware), ...createDefaultToastMiddleware()],\n    [toastMiddleware]\n  );\n\n  const patchedTypingIndicatorMiddleware = useMemo(\n    () => [...singleToArray(typingIndicatorMiddleware), ...createDefaultTypingIndicatorMiddleware()],\n    [typingIndicatorMiddleware]\n  );\n\n  const defaultScrollToEndButtonMiddleware = useMemo(() => createDefaultScrollToEndButtonMiddleware(), []);\n\n  const patchedScrollToEndButtonMiddleware = useMemo(\n    () => [...singleToArray(scrollToEndButtonMiddleware), ...defaultScrollToEndButtonMiddleware],\n    [defaultScrollToEndButtonMiddleware, scrollToEndButtonMiddleware]\n  );\n\n  return (\n    <React.Fragment>\n      <APIComposer\n        activityMiddleware={patchedActivityMiddleware}\n        activityStatusMiddleware={patchedActivityStatusMiddleware}\n        attachmentForScreenReaderMiddleware={patchedAttachmentForScreenReaderMiddleware}\n        attachmentMiddleware={patchedAttachmentMiddleware}\n        avatarMiddleware={patchedAvatarMiddleware}\n        cardActionMiddleware={patchedCardActionMiddleware}\n        downscaleImageToDataURL={downscaleImageToDataURL}\n        // Under dev server of create-react-app, \"NODE_ENV\" will be set to \"development\".\n        internalErrorBoxClass={node_env === 'development' ? ErrorBox : undefined}\n        nonce={nonce}\n        scrollToEndButtonMiddleware={patchedScrollToEndButtonMiddleware}\n        toastMiddleware={patchedToastMiddleware}\n        typingIndicatorMiddleware={patchedTypingIndicatorMiddleware}\n        {...composerProps}\n      >\n        <ActivityTreeComposer>\n          <ComposerCore\n            extraStyleSet={extraStyleSet}\n            nonce={nonce}\n            renderMarkdown={renderMarkdown}\n            styleSet={styleSet}\n            suggestedActionsAccessKey={suggestedActionsAccessKey}\n            webSpeechPonyfillFactory={webSpeechPonyfillFactory}\n          >\n            {children}\n            {onTelemetry && <UITracker />}\n          </ComposerCore>\n        </ActivityTreeComposer>\n      </APIComposer>\n    </React.Fragment>\n  );\n};\n\nComposer.defaultProps = {\n  ...APIComposer.defaultProps,\n  ...ComposerCore.defaultProps,\n  children: undefined\n};\n\nComposer.propTypes = {\n  ...APIComposer.propTypes,\n  ...ComposerCore.propTypes,\n  children: PropTypes.any\n};\n\nexport default Composer;\n\nexport type { ComposerProps };\n"],"mappings":"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"}
|
|
368
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["useGetActivityByKey","hooks","useReferenceGrammarID","useStyleOptions","node_env","emotionPool","styleSetToEmotionObjects","styleToEmotionObject","styleSet","mapMap","style","key","ComposerCore","children","extraStyleSet","nonce","renderMarkdown","suggestedActionsAccessKey","webSpeechPonyfillFactory","useState","dictateAbortable","setDictateAbortable","referenceGrammarID","styleOptions","focusSendBoxCallbacksRef","useRef","focusTranscriptCallbacksRef","internalMarkdownIt","useMemo","MarkdownIt","scrollToCallbacksRef","scrollToEndCallbacksRef","scrollRelativeCallbacksRef","dictationOnError","useCallback","err","console","error","internalRenderMarkdownInline","markdown","tree","parseInline","patchedTree","addTargetBlankToHyperlinksMarkdown","renderer","render","emotion","createEmotion","createCSSKey","css","patchedStyleSet","createStyleSet","webSpeechPonyfill","ponyfill","speechSynthesis","SpeechSynthesisUtterance","bypassSpeechSynthesis","BypassSpeechSynthesisUtterance","scrollPositionObserversRef","dispatchScrollPosition","event","current","forEach","observer","observeScrollPosition","filter","target","transcriptFocusObserversRef","numTranscriptFocusObservers","setNumTranscriptFocusObservers","getActivityByKey","dispatchTranscriptFocusByActivityKey","prevActivityKey","Symbol","activityKey","activity","observeTranscriptFocus","length","context","internalMarkdownItState","defaultProps","undefined","propTypes","PropTypes","any","string","func","oneOfType","oneOf","Composer","activityMiddleware","activityStatusMiddleware","attachmentForScreenReaderMiddleware","attachmentMiddleware","avatarMiddleware","cardActionMiddleware","scrollToEndButtonMiddleware","toastMiddleware","typingIndicatorMiddleware","composerProps","onTelemetry","patchedActivityMiddleware","singleToArray","createDefaultActivityMiddleware","patchedActivityStatusMiddleware","createDefaultActivityStatusMiddleware","patchedAttachmentForScreenReaderMiddleware","createDefaultAttachmentForScreenReaderMiddleware","patchedAttachmentMiddleware","createDefaultAttachmentMiddleware","patchedAvatarMiddleware","createDefaultAvatarMiddleware","patchedCardActionMiddleware","createDefaultCardActionMiddleware","patchedToastMiddleware","createDefaultToastMiddleware","patchedTypingIndicatorMiddleware","createDefaultTypingIndicatorMiddleware","defaultScrollToEndButtonMiddleware","createDefaultScrollToEndButtonMiddleware","patchedScrollToEndButtonMiddleware","downscaleImageToDataURL","ErrorBox","APIComposer"],"sourceRoot":"component:///","sources":["../src/Composer.tsx"],"sourcesContent":["import { Composer as APIComposer, hooks, WebSpeechPonyfillFactory } from 'botframework-webchat-api';\nimport { Composer as SayComposer } from 'react-say';\nimport { singleToArray } from 'botframework-webchat-core';\nimport createEmotion from '@emotion/css/create-instance';\nimport createStyleSet from './Styles/createStyleSet';\nimport MarkdownIt from 'markdown-it';\nimport PropTypes from 'prop-types';\nimport React, { useCallback, useMemo, useRef, useState } from 'react';\n\nimport {\n  speechSynthesis as bypassSpeechSynthesis,\n  SpeechSynthesisUtterance as BypassSpeechSynthesisUtterance\n} from './hooks/internal/BypassSpeechSynthesisPonyfill';\nimport ActivityTreeComposer from './providers/ActivityTree/ActivityTreeComposer';\nimport addTargetBlankToHyperlinksMarkdown from './Utils/addTargetBlankToHyperlinksMarkdown';\nimport createCSSKey from './Utils/createCSSKey';\nimport createDefaultActivityMiddleware from './Middleware/Activity/createCoreMiddleware';\nimport createDefaultActivityStatusMiddleware from './Middleware/ActivityStatus/createCoreMiddleware';\nimport createDefaultAttachmentForScreenReaderMiddleware from './Middleware/AttachmentForScreenReader/createCoreMiddleware';\nimport createDefaultAttachmentMiddleware from './Middleware/Attachment/createCoreMiddleware';\nimport createDefaultAvatarMiddleware from './Middleware/Avatar/createCoreMiddleware';\nimport createDefaultCardActionMiddleware from './Middleware/CardAction/createCoreMiddleware';\nimport createDefaultScrollToEndButtonMiddleware from './Middleware/ScrollToEndButton/createScrollToEndButtonMiddleware';\nimport createDefaultToastMiddleware from './Middleware/Toast/createCoreMiddleware';\nimport createDefaultTypingIndicatorMiddleware from './Middleware/TypingIndicator/createCoreMiddleware';\nimport Dictation from './Dictation';\nimport downscaleImageToDataURL from './Utils/downscaleImageToDataURL';\nimport ErrorBox from './ErrorBox';\nimport mapMap from './Utils/mapMap';\nimport UITracker from './hooks/internal/UITracker';\nimport WebChatUIContext from './hooks/internal/WebChatUIContext';\n\nimport type { ComposerProps as APIComposerProps } from 'botframework-webchat-api';\nimport type { FC, ReactNode } from 'react';\n\nconst { useGetActivityByKey, useReferenceGrammarID, useStyleOptions } = hooks;\n\nconst node_env = process.env.node_env || process.env.NODE_ENV;\n\nconst emotionPool = {};\n\nfunction styleSetToEmotionObjects(styleToEmotionObject, styleSet) {\n  return mapMap(styleSet, (style, key) => (key === 'options' ? style : styleToEmotionObject(style)));\n}\n\ntype ComposerCoreProps = {\n  children?: ReactNode;\n  extraStyleSet?: any;\n  nonce?: string;\n  renderMarkdown?: (\n    markdown: string,\n    newLineOptions: { markdownRespectCRLF: boolean },\n    linkOptions: { externalLinkAlt: string }\n  ) => string;\n  styleSet?: any;\n  suggestedActionsAccessKey?: boolean | string;\n  webSpeechPonyfillFactory?: WebSpeechPonyfillFactory;\n};\n\nconst ComposerCore: FC<ComposerCoreProps> = ({\n  children,\n  extraStyleSet,\n  nonce,\n  renderMarkdown,\n  styleSet,\n  suggestedActionsAccessKey,\n  webSpeechPonyfillFactory\n}) => {\n  const [dictateAbortable, setDictateAbortable] = useState();\n  const [referenceGrammarID] = useReferenceGrammarID();\n  const [styleOptions] = useStyleOptions();\n  const focusSendBoxCallbacksRef = useRef([]);\n  const focusTranscriptCallbacksRef = useRef([]);\n  const internalMarkdownIt = useMemo(() => new MarkdownIt(), []);\n  const scrollToCallbacksRef = useRef([]);\n  const scrollToEndCallbacksRef = useRef([]);\n\n  // Instead of having a `scrollUpCallbacksRef` and `scrollDownCallbacksRef`, they are combined into a single `scrollRelativeCallbacksRef`.\n  // The first argument tells whether it should go \"up\" or \"down\".\n  const scrollRelativeCallbacksRef = useRef([]);\n\n  const dictationOnError = useCallback(err => {\n    console.error(err);\n  }, []);\n\n  const internalRenderMarkdownInline = useMemo(\n    () => markdown => {\n      const tree = internalMarkdownIt.parseInline(markdown);\n\n      // We should add rel=\"noopener noreferrer\" and target=\"_blank\"\n      const patchedTree = addTargetBlankToHyperlinksMarkdown(tree);\n\n      return internalMarkdownIt.renderer.render(patchedTree);\n    },\n    [internalMarkdownIt]\n  );\n\n  const styleToEmotionObject = useMemo(() => {\n    // Emotion doesn't hash with nonce. We need to provide the pooling mechanism.\n    // 1. If 2 instances use different nonce, they should result in different hash;\n    // 2. If 2 instances are being mounted, pooling will make sure we render only 1 set of <style> tags, instead of 2.\n    const emotion =\n      // Prefix \"id-\" to prevent object injection attack.\n      emotionPool[`id-${nonce}`] ||\n      (emotionPool[`id-${nonce}`] = createEmotion({ key: `webchat--css-${createCSSKey()}`, nonce }));\n\n    return style => emotion.css(style);\n  }, [nonce]);\n\n  const patchedStyleSet = useMemo(\n    () =>\n      styleSetToEmotionObjects(styleToEmotionObject, {\n        ...(styleSet || createStyleSet(styleOptions)),\n        ...extraStyleSet\n      }),\n    [extraStyleSet, styleOptions, styleSet, styleToEmotionObject]\n  );\n\n  const webSpeechPonyfill = useMemo(() => {\n    const ponyfill = webSpeechPonyfillFactory && webSpeechPonyfillFactory({ referenceGrammarID });\n    const { speechSynthesis, SpeechSynthesisUtterance } = ponyfill || {};\n\n    return {\n      ...ponyfill,\n      speechSynthesis: speechSynthesis || bypassSpeechSynthesis,\n      SpeechSynthesisUtterance: SpeechSynthesisUtterance || BypassSpeechSynthesisUtterance\n    };\n  }, [referenceGrammarID, webSpeechPonyfillFactory]);\n\n  const scrollPositionObserversRef = useRef([]);\n\n  const dispatchScrollPosition = useCallback(\n    event => scrollPositionObserversRef.current.forEach(observer => observer(event)),\n    [scrollPositionObserversRef]\n  );\n\n  const observeScrollPosition = useCallback(\n    observer => {\n      scrollPositionObserversRef.current = [...scrollPositionObserversRef.current, observer];\n\n      return () => {\n        scrollPositionObserversRef.current = scrollPositionObserversRef.current.filter(target => target !== observer);\n      };\n    },\n    [scrollPositionObserversRef]\n  );\n\n  const transcriptFocusObserversRef = useRef([]);\n  const [numTranscriptFocusObservers, setNumTranscriptFocusObservers] = useState(0);\n\n  const getActivityByKey = useGetActivityByKey();\n\n  const dispatchTranscriptFocusByActivityKey = useMemo(() => {\n    let prevActivityKey: string | Symbol | undefined = Symbol();\n\n    return activityKey => {\n      if (activityKey !== prevActivityKey) {\n        prevActivityKey = activityKey;\n\n        const event = { activity: getActivityByKey(activityKey) };\n\n        transcriptFocusObserversRef.current.forEach(observer => observer(event));\n      }\n    };\n  }, [getActivityByKey, transcriptFocusObserversRef]);\n\n  const observeTranscriptFocus = useCallback(\n    observer => {\n      transcriptFocusObserversRef.current = [...transcriptFocusObserversRef.current, observer];\n      setNumTranscriptFocusObservers(transcriptFocusObserversRef.current.length);\n\n      return () => {\n        transcriptFocusObserversRef.current = transcriptFocusObserversRef.current.filter(target => target !== observer);\n        setNumTranscriptFocusObservers(transcriptFocusObserversRef.current.length);\n      };\n    },\n    [transcriptFocusObserversRef, setNumTranscriptFocusObservers]\n  );\n\n  const context = useMemo(\n    () => ({\n      dictateAbortable,\n      dispatchScrollPosition,\n      dispatchTranscriptFocusByActivityKey,\n      focusSendBoxCallbacksRef,\n      focusTranscriptCallbacksRef,\n      internalMarkdownItState: [internalMarkdownIt],\n      internalRenderMarkdownInline,\n      nonce,\n      numTranscriptFocusObservers,\n      observeScrollPosition,\n      observeTranscriptFocus,\n      renderMarkdown,\n      scrollRelativeCallbacksRef,\n      scrollToCallbacksRef,\n      scrollToEndCallbacksRef,\n      setDictateAbortable,\n      styleSet: patchedStyleSet,\n      styleToEmotionObject,\n      suggestedActionsAccessKey,\n      webSpeechPonyfill\n    }),\n    [\n      dictateAbortable,\n      dispatchScrollPosition,\n      dispatchTranscriptFocusByActivityKey,\n      focusSendBoxCallbacksRef,\n      focusTranscriptCallbacksRef,\n      internalMarkdownIt,\n      internalRenderMarkdownInline,\n      nonce,\n      numTranscriptFocusObservers,\n      observeScrollPosition,\n      observeTranscriptFocus,\n      patchedStyleSet,\n      renderMarkdown,\n      scrollRelativeCallbacksRef,\n      scrollToCallbacksRef,\n      scrollToEndCallbacksRef,\n      setDictateAbortable,\n      styleToEmotionObject,\n      suggestedActionsAccessKey,\n      webSpeechPonyfill\n    ]\n  );\n\n  return (\n    <SayComposer ponyfill={webSpeechPonyfill}>\n      <WebChatUIContext.Provider value={context}>\n        {children}\n        <Dictation onError={dictationOnError} />\n      </WebChatUIContext.Provider>\n    </SayComposer>\n  );\n};\n\nComposerCore.defaultProps = {\n  children: undefined,\n  extraStyleSet: undefined,\n  nonce: undefined,\n  renderMarkdown: undefined,\n  styleSet: undefined,\n  suggestedActionsAccessKey: 'A a Å å',\n  webSpeechPonyfillFactory: undefined\n};\n\nComposerCore.propTypes = {\n  extraStyleSet: PropTypes.any,\n  nonce: PropTypes.string,\n  renderMarkdown: PropTypes.func,\n  styleSet: PropTypes.any,\n  suggestedActionsAccessKey: PropTypes.oneOfType([PropTypes.oneOf([false]), PropTypes.string]),\n  webSpeechPonyfillFactory: PropTypes.func\n};\n\ntype ComposerProps = APIComposerProps & ComposerCoreProps;\n\nconst Composer: FC<ComposerProps> = ({\n  activityMiddleware,\n  activityStatusMiddleware,\n  attachmentForScreenReaderMiddleware,\n  attachmentMiddleware,\n  avatarMiddleware,\n  cardActionMiddleware,\n  children,\n  extraStyleSet,\n  renderMarkdown,\n  scrollToEndButtonMiddleware,\n  styleSet,\n  suggestedActionsAccessKey,\n  toastMiddleware,\n  typingIndicatorMiddleware,\n  webSpeechPonyfillFactory,\n  ...composerProps\n}) => {\n  const { nonce, onTelemetry } = composerProps;\n\n  const patchedActivityMiddleware = useMemo(\n    () => [...singleToArray(activityMiddleware), ...createDefaultActivityMiddleware()],\n    [activityMiddleware]\n  );\n\n  const patchedActivityStatusMiddleware = useMemo(\n    () => [...singleToArray(activityStatusMiddleware), ...createDefaultActivityStatusMiddleware()],\n    [activityStatusMiddleware]\n  );\n\n  const patchedAttachmentForScreenReaderMiddleware = useMemo(\n    () => [\n      ...singleToArray(attachmentForScreenReaderMiddleware),\n      ...createDefaultAttachmentForScreenReaderMiddleware()\n    ],\n    [attachmentForScreenReaderMiddleware]\n  );\n\n  const patchedAttachmentMiddleware = useMemo(\n    () => [...singleToArray(attachmentMiddleware), ...createDefaultAttachmentMiddleware()],\n    [attachmentMiddleware]\n  );\n\n  const patchedAvatarMiddleware = useMemo(\n    () => [...singleToArray(avatarMiddleware), ...createDefaultAvatarMiddleware()],\n    [avatarMiddleware]\n  );\n\n  const patchedCardActionMiddleware = useMemo(\n    () => [...singleToArray(cardActionMiddleware), ...createDefaultCardActionMiddleware()],\n    [cardActionMiddleware]\n  );\n\n  const patchedToastMiddleware = useMemo(\n    () => [...singleToArray(toastMiddleware), ...createDefaultToastMiddleware()],\n    [toastMiddleware]\n  );\n\n  const patchedTypingIndicatorMiddleware = useMemo(\n    () => [...singleToArray(typingIndicatorMiddleware), ...createDefaultTypingIndicatorMiddleware()],\n    [typingIndicatorMiddleware]\n  );\n\n  const defaultScrollToEndButtonMiddleware = useMemo(() => createDefaultScrollToEndButtonMiddleware(), []);\n\n  const patchedScrollToEndButtonMiddleware = useMemo(\n    () => [...singleToArray(scrollToEndButtonMiddleware), ...defaultScrollToEndButtonMiddleware],\n    [defaultScrollToEndButtonMiddleware, scrollToEndButtonMiddleware]\n  );\n\n  return (\n    <React.Fragment>\n      <APIComposer\n        activityMiddleware={patchedActivityMiddleware}\n        activityStatusMiddleware={patchedActivityStatusMiddleware}\n        attachmentForScreenReaderMiddleware={patchedAttachmentForScreenReaderMiddleware}\n        attachmentMiddleware={patchedAttachmentMiddleware}\n        avatarMiddleware={patchedAvatarMiddleware}\n        cardActionMiddleware={patchedCardActionMiddleware}\n        downscaleImageToDataURL={downscaleImageToDataURL}\n        // Under dev server of create-react-app, \"NODE_ENV\" will be set to \"development\".\n        internalErrorBoxClass={node_env === 'development' ? ErrorBox : undefined}\n        nonce={nonce}\n        scrollToEndButtonMiddleware={patchedScrollToEndButtonMiddleware}\n        toastMiddleware={patchedToastMiddleware}\n        typingIndicatorMiddleware={patchedTypingIndicatorMiddleware}\n        {...composerProps}\n      >\n        <ActivityTreeComposer>\n          <ComposerCore\n            extraStyleSet={extraStyleSet}\n            nonce={nonce}\n            renderMarkdown={renderMarkdown}\n            styleSet={styleSet}\n            suggestedActionsAccessKey={suggestedActionsAccessKey}\n            webSpeechPonyfillFactory={webSpeechPonyfillFactory}\n          >\n            {children}\n            {onTelemetry && <UITracker />}\n          </ComposerCore>\n        </ActivityTreeComposer>\n      </APIComposer>\n    </React.Fragment>\n  );\n};\n\nComposer.defaultProps = {\n  ...APIComposer.defaultProps,\n  ...ComposerCore.defaultProps,\n  children: undefined\n};\n\nComposer.propTypes = {\n  ...APIComposer.propTypes,\n  ...ComposerCore.propTypes,\n  children: PropTypes.any\n};\n\nexport default Composer;\n\nexport type { ComposerProps };\n"],"mappings":"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"}
|
package/lib/index.js
CHANGED
|
@@ -143,7 +143,7 @@ function _defineProperty(obj, key, value) { if (key in obj) { Object.definePrope
|
|
|
143
143
|
var hooks = _objectSpread(_objectSpread({}, _botframeworkWebchatApi.hooks), componentHooks);
|
|
144
144
|
|
|
145
145
|
exports.hooks = hooks;
|
|
146
|
-
var version = "4.15.
|
|
146
|
+
var version = "4.15.5-main.20220927.f9dd67a";
|
|
147
147
|
exports.version = version;
|
|
148
148
|
var Components = {
|
|
149
149
|
BasicWebChat: _BasicWebChat.default,
|
|
@@ -184,4 +184,4 @@ var Components = {
|
|
|
184
184
|
exports.Components = Components;
|
|
185
185
|
var _default = _ReactWebChat.default;
|
|
186
186
|
exports.default = _default;
|
|
187
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
187
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJob29rcyIsImFwaUhvb2tzIiwiY29tcG9uZW50SG9va3MiLCJ2ZXJzaW9uIiwiQ29tcG9uZW50cyIsIkJhc2ljV2ViQ2hhdCIsIkNvbXBvc2VyIiwiTG9jYWxpemUiLCJBdWRpb0NvbnRlbnQiLCJGaWxlQ29udGVudCIsIkhUTUxWaWRlb0NvbnRlbnQiLCJJbWFnZUNvbnRlbnQiLCJUZXh0Q29udGVudCIsIlZpZGVvQ29udGVudCIsIlZpbWVvQ29udGVudCIsIllvdVR1YmVDb250ZW50IiwiQXZhdGFyIiwiQnViYmxlIiwiRXJyb3JCb3giLCJTZW5kU3RhdHVzIiwiU3BlYWtBY3Rpdml0eSIsIlRpbWVzdGFtcCIsImNvbm5lY3RTZW5kU3RhdHVzIiwiY29ubmVjdFNwZWFrQWN0aXZpdHkiLCJEaWN0YXRpb25JbnRlcmltcyIsIk1pY3JvcGhvbmVCdXR0b24iLCJTZW5kQnV0dG9uIiwiU2VuZFRleHRCb3giLCJTdWdnZXN0ZWRBY3Rpb25zIiwiVXBsb2FkQnV0dG9uIiwiY29ubmVjdERpY3RhdGlvbkludGVyaW1zIiwiY29ubmVjdE1pY3JvcGhvbmVCdXR0b24iLCJjb25uZWN0U2VuZEJ1dHRvbiIsImNvbm5lY3RTZW5kVGV4dEJveCIsImNvbm5lY3RTdWdnZXN0ZWRBY3Rpb25zIiwiY29ubmVjdFVwbG9hZEJ1dHRvbiIsIlJlYWN0V2ViQ2hhdCJdLCJzb3VyY2VSb290IjoiY29tcG9uZW50Oi8vLyIsInNvdXJjZXMiOlsiLi4vc3JjL2luZGV4LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNvbmNhdE1pZGRsZXdhcmUsIGhvb2tzIGFzIGFwaUhvb2tzLCBMb2NhbGl6ZSwgbG9jYWxpemUgfSBmcm9tICdib3RmcmFtZXdvcmstd2ViY2hhdC1hcGknO1xuXG5pbXBvcnQgUmVhY3RXZWJDaGF0LCB7IFJlYWN0V2ViQ2hhdFByb3BzIH0gZnJvbSAnLi9SZWFjdFdlYkNoYXQnO1xuXG5pbXBvcnQgQ29tcG9zZXIsIHsgQ29tcG9zZXJQcm9wcyB9IGZyb20gJy4vQ29tcG9zZXInO1xuXG5pbXBvcnQgQmFzaWNXZWJDaGF0LCB7IEJhc2ljV2ViQ2hhdFByb3BzIH0gZnJvbSAnLi9CYXNpY1dlYkNoYXQnO1xuXG5pbXBvcnQgQXZhdGFyIGZyb20gJy4vQWN0aXZpdHkvQXZhdGFyJztcbmltcG9ydCBCdWJibGUgZnJvbSAnLi9BY3Rpdml0eS9CdWJibGUnO1xuaW1wb3J0IEVycm9yQm94IGZyb20gJy4vRXJyb3JCb3gnO1xuaW1wb3J0IFNlbmRTdGF0dXMsIHsgY29ubmVjdFNlbmRTdGF0dXMgfSBmcm9tICcuL01pZGRsZXdhcmUvQWN0aXZpdHlTdGF0dXMvU2VuZFN0YXR1cy9TZW5kU3RhdHVzJztcbmltcG9ydCBTcGVha0FjdGl2aXR5LCB7IGNvbm5lY3RTcGVha0FjdGl2aXR5IH0gZnJvbSAnLi9BY3Rpdml0eS9TcGVhayc7XG5pbXBvcnQgVGltZXN0YW1wIGZyb20gJy4vTWlkZGxld2FyZS9BY3Rpdml0eVN0YXR1cy9UaW1lc3RhbXAnO1xuXG5pbXBvcnQgQXVkaW9Db250ZW50IGZyb20gJy4vQXR0YWNobWVudC9BdWRpb0NvbnRlbnQnO1xuaW1wb3J0IEZpbGVDb250ZW50IGZyb20gJy4vQXR0YWNobWVudC9GaWxlQ29udGVudCc7XG5pbXBvcnQgSFRNTFZpZGVvQ29udGVudCBmcm9tICcuL0F0dGFjaG1lbnQvSFRNTFZpZGVvQ29udGVudCc7XG5pbXBvcnQgSW1hZ2VDb250ZW50IGZyb20gJy4vQXR0YWNobWVudC9JbWFnZUNvbnRlbnQnO1xuaW1wb3J0IFRleHRDb250ZW50IGZyb20gJy4vQXR0YWNobWVudC9UZXh0Q29udGVudCc7XG5pbXBvcnQgVmlkZW9Db250ZW50IGZyb20gJy4vQXR0YWNobWVudC9WaWRlb0NvbnRlbnQnO1xuaW1wb3J0IFZpbWVvQ29udGVudCBmcm9tICcuL0F0dGFjaG1lbnQvVmltZW9Db250ZW50JztcbmltcG9ydCBZb3VUdWJlQ29udGVudCBmcm9tICcuL0F0dGFjaG1lbnQvWW91VHViZUNvbnRlbnQnO1xuXG5pbXBvcnQgRGljdGF0aW9uSW50ZXJpbXMsIHsgY29ubmVjdERpY3RhdGlvbkludGVyaW1zIH0gZnJvbSAnLi9TZW5kQm94L0RpY3RhdGlvbkludGVyaW1zJztcbmltcG9ydCBNaWNyb3Bob25lQnV0dG9uLCB7IGNvbm5lY3RNaWNyb3Bob25lQnV0dG9uIH0gZnJvbSAnLi9TZW5kQm94L01pY3JvcGhvbmVCdXR0b24nO1xuaW1wb3J0IFNlbmRCdXR0b24sIHsgY29ubmVjdFNlbmRCdXR0b24gfSBmcm9tICcuL1NlbmRCb3gvU2VuZEJ1dHRvbic7XG5pbXBvcnQgU2VuZFRleHRCb3gsIHsgY29ubmVjdFNlbmRUZXh0Qm94IH0gZnJvbSAnLi9TZW5kQm94L1RleHRCb3gnO1xuaW1wb3J0IFN1Z2dlc3RlZEFjdGlvbnMsIHsgY29ubmVjdFN1Z2dlc3RlZEFjdGlvbnMgfSBmcm9tICcuL1NlbmRCb3gvU3VnZ2VzdGVkQWN0aW9ucyc7XG5pbXBvcnQgVXBsb2FkQnV0dG9uLCB7IGNvbm5lY3RVcGxvYWRCdXR0b24gfSBmcm9tICcuL1NlbmRCb3gvVXBsb2FkQnV0dG9uJztcblxuaW1wb3J0IGNvbm5lY3RUb1dlYkNoYXQgZnJvbSAnLi9jb25uZWN0VG9XZWJDaGF0JztcbmltcG9ydCBDb250ZXh0IGZyb20gJy4vaG9va3MvaW50ZXJuYWwvV2ViQ2hhdFVJQ29udGV4dCc7XG5pbXBvcnQgY3JlYXRlQ29yZUFjdGl2aXR5TWlkZGxld2FyZSBmcm9tICcuL01pZGRsZXdhcmUvQWN0aXZpdHkvY3JlYXRlQ29yZU1pZGRsZXdhcmUnO1xuaW1wb3J0IGNyZWF0ZUNvcmVBY3Rpdml0eVN0YXR1c01pZGRsZXdhcmUgZnJvbSAnLi9NaWRkbGV3YXJlL0FjdGl2aXR5U3RhdHVzL2NyZWF0ZUNvcmVNaWRkbGV3YXJlJztcbmltcG9ydCBjcmVhdGVDb3JlQXR0YWNobWVudE1pZGRsZXdhcmUgZnJvbSAnLi9NaWRkbGV3YXJlL0F0dGFjaG1lbnQvY3JlYXRlQ29yZU1pZGRsZXdhcmUnO1xuaW1wb3J0IGNyZWF0ZVN0eWxlU2V0IGZyb20gJy4vU3R5bGVzL2NyZWF0ZVN0eWxlU2V0JztcbmltcG9ydCBnZXRUYWJJbmRleCBmcm9tICcuL1V0aWxzL1R5cGVGb2N1c1NpbmsvZ2V0VGFiSW5kZXgnO1xuXG5pbXBvcnQgKiBhcyBjb21wb25lbnRIb29rcyBmcm9tICcuL2hvb2tzL2luZGV4JztcblxuY29uc3QgaG9va3MgPSB7XG4gIC4uLmFwaUhvb2tzLFxuICAuLi5jb21wb25lbnRIb29rc1xufTtcblxuY29uc3QgdmVyc2lvbiA9IHByb2Nlc3MuZW52Lm5wbV9wYWNrYWdlX3ZlcnNpb247XG5cbmNvbnN0IENvbXBvbmVudHMgPSB7XG4gIEJhc2ljV2ViQ2hhdCxcbiAgQ29tcG9zZXIsXG4gIExvY2FsaXplLFxuXG4gIC8vIENvbXBvbmVudHMgZm9yIHJlY29tcG9zaW5nIGFjdGl2aXRpZXMgYW5kIGF0dGFjaG1lbnRzXG4gIEF1ZGlvQ29udGVudCxcbiAgRmlsZUNvbnRlbnQsXG4gIEhUTUxWaWRlb0NvbnRlbnQsXG4gIEltYWdlQ29udGVudCxcbiAgVGV4dENvbnRlbnQsXG4gIFZpZGVvQ29udGVudCxcbiAgVmltZW9Db250ZW50LFxuICBZb3VUdWJlQ29udGVudCxcblxuICAvLyBDb21wb25lbnRzIGZvciByZWNvbXBvc2luZyB0cmFuc2NyaXB0XG4gIEF2YXRhcixcbiAgQnViYmxlLFxuICBFcnJvckJveCxcbiAgU2VuZFN0YXR1cyxcbiAgU3BlYWtBY3Rpdml0eSxcbiAgVGltZXN0YW1wLFxuXG4gIGNvbm5lY3RTZW5kU3RhdHVzLFxuICBjb25uZWN0U3BlYWtBY3Rpdml0eSxcblxuICAvLyBDb21wb25lbnRzIGZvciByZWNvbXBvc2luZyBzZW5kIGJveFxuICBEaWN0YXRpb25JbnRlcmltcyxcbiAgTWljcm9waG9uZUJ1dHRvbixcbiAgU2VuZEJ1dHRvbixcbiAgU2VuZFRleHRCb3gsXG4gIFN1Z2dlc3RlZEFjdGlvbnMsXG4gIFVwbG9hZEJ1dHRvbixcblxuICBjb25uZWN0RGljdGF0aW9uSW50ZXJpbXMsXG4gIGNvbm5lY3RNaWNyb3Bob25lQnV0dG9uLFxuICBjb25uZWN0U2VuZEJ1dHRvbixcbiAgY29ubmVjdFNlbmRUZXh0Qm94LFxuICBjb25uZWN0U3VnZ2VzdGVkQWN0aW9ucyxcbiAgY29ubmVjdFVwbG9hZEJ1dHRvblxufTtcblxuZXhwb3J0IGRlZmF1bHQgUmVhY3RXZWJDaGF0O1xuXG5leHBvcnQge1xuICBDb21wb25lbnRzLFxuICBjb25jYXRNaWRkbGV3YXJlLFxuICBjb25uZWN0VG9XZWJDaGF0LFxuICBDb250ZXh0LFxuICBjcmVhdGVDb3JlQWN0aXZpdHlNaWRkbGV3YXJlLFxuICBjcmVhdGVDb3JlQWN0aXZpdHlTdGF0dXNNaWRkbGV3YXJlLFxuICBjcmVhdGVDb3JlQXR0YWNobWVudE1pZGRsZXdhcmUsXG4gIGNyZWF0ZVN0eWxlU2V0LFxuICBnZXRUYWJJbmRleCxcbiAgaG9va3MsXG4gIGxvY2FsaXplLFxuICB2ZXJzaW9uXG59O1xuXG5leHBvcnQgdHlwZSB7IEJhc2ljV2ViQ2hhdFByb3BzLCBDb21wb3NlclByb3BzLCBSZWFjdFdlYkNoYXRQcm9wcyB9O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTs7QUFFQTs7QUFFQTs7QUFFQTs7QUFFQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFFQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFFQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFFQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFFQTs7Ozs7Ozs7Ozs7Ozs7QUFFQSxJQUFNQSxLQUFLLG1DQUNOQyw2QkFETSxHQUVOQyxjQUZNLENBQVg7OztBQUtBLElBQU1DLE9BQU8saUNBQWI7O0FBRUEsSUFBTUMsVUFBVSxHQUFHO0VBQ2pCQyxZQUFZLEVBQVpBLHFCQURpQjtFQUVqQkMsUUFBUSxFQUFSQSxpQkFGaUI7RUFHakJDLFFBQVEsRUFBUkEsZ0NBSGlCO0VBS2pCO0VBQ0FDLFlBQVksRUFBWkEscUJBTmlCO0VBT2pCQyxXQUFXLEVBQVhBLG9CQVBpQjtFQVFqQkMsZ0JBQWdCLEVBQWhCQSx5QkFSaUI7RUFTakJDLFlBQVksRUFBWkEscUJBVGlCO0VBVWpCQyxXQUFXLEVBQVhBLG9CQVZpQjtFQVdqQkMsWUFBWSxFQUFaQSxxQkFYaUI7RUFZakJDLFlBQVksRUFBWkEscUJBWmlCO0VBYWpCQyxjQUFjLEVBQWRBLHVCQWJpQjtFQWVqQjtFQUNBQyxNQUFNLEVBQU5BLGVBaEJpQjtFQWlCakJDLE1BQU0sRUFBTkEsZUFqQmlCO0VBa0JqQkMsUUFBUSxFQUFSQSxpQkFsQmlCO0VBbUJqQkMsVUFBVSxFQUFWQSxtQkFuQmlCO0VBb0JqQkMsYUFBYSxFQUFiQSxjQXBCaUI7RUFxQmpCQyxTQUFTLEVBQVRBLGtCQXJCaUI7RUF1QmpCQyxpQkFBaUIsRUFBakJBLDZCQXZCaUI7RUF3QmpCQyxvQkFBb0IsRUFBcEJBLDJCQXhCaUI7RUEwQmpCO0VBQ0FDLGlCQUFpQixFQUFqQkEsMEJBM0JpQjtFQTRCakJDLGdCQUFnQixFQUFoQkEseUJBNUJpQjtFQTZCakJDLFVBQVUsRUFBVkEsbUJBN0JpQjtFQThCakJDLFdBQVcsRUFBWEEsZ0JBOUJpQjtFQStCakJDLGdCQUFnQixFQUFoQkEseUJBL0JpQjtFQWdDakJDLFlBQVksRUFBWkEscUJBaENpQjtFQWtDakJDLHdCQUF3QixFQUF4QkEsMkNBbENpQjtFQW1DakJDLHVCQUF1QixFQUF2QkEseUNBbkNpQjtFQW9DakJDLGlCQUFpQixFQUFqQkEsNkJBcENpQjtFQXFDakJDLGtCQUFrQixFQUFsQkEsMkJBckNpQjtFQXNDakJDLHVCQUF1QixFQUF2QkEseUNBdENpQjtFQXVDakJDLG1CQUFtQixFQUFuQkE7QUF2Q2lCLENBQW5COztlQTBDZUMscUIifQ==
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "botframework-webchat-component",
|
|
3
|
-
"version": "4.15.
|
|
3
|
+
"version": "4.15.5-main.20220927.f9dd67a",
|
|
4
4
|
"description": "React component of botframework-webchat",
|
|
5
5
|
"main": "lib/index.js",
|
|
6
6
|
"typings": "lib/index.d.ts",
|
|
@@ -26,8 +26,8 @@
|
|
|
26
26
|
"build:babel": "babel src --copy-files --extensions .js,.ts,.tsx --ignore **/*.spec.js,**/*.spec.ts,**/*.spec.tsx,**/*.test.js,**/*.test.ts,**/*.test.tsx,__tests__/**/*.js,__tests__/**/*.ts,__tests__/**/*.tsx --no-copy-ignored --out-dir lib --verbose",
|
|
27
27
|
"build:typescript": "tsc --project src/tsconfig.json",
|
|
28
28
|
"bump": "npm run bump:prod && npm run bump:dev",
|
|
29
|
-
"bump:dev": "npm install $(cat package.json | jq -r '(.devDependencies | keys) - .skipBump | .[]' | awk '{print $1 \"@latest\"}')",
|
|
30
|
-
"bump:prod": "npm install --save-exact $(cat package.json | jq -r '(.dependencies | keys) - .skipBump | .[]' | awk '{print $1 \"@latest\"}')",
|
|
29
|
+
"bump:dev": "npm install --legacy-peer-deps $(cat package.json | jq -r '(.devDependencies | keys) - (.skipBump | keys) | .[]' | awk '{print $1 \"@latest\"}')",
|
|
30
|
+
"bump:prod": "npm install --legacy-peer-deps --save-exact $(cat package.json | jq -r '(.dependencies | keys) - (.skipBump | keys) | .[]' | awk '{print $1 \"@latest\"}')",
|
|
31
31
|
"eslint": "npm run precommit",
|
|
32
32
|
"precommit": "npm run precommit:eslint -- src && npm run precommit:typecheck",
|
|
33
33
|
"precommit:eslint": "../../node_modules/.bin/eslint --report-unused-disable-directives --max-warnings 0",
|
|
@@ -37,30 +37,32 @@
|
|
|
37
37
|
"start:babel": "npm run build:babel -- --skip-initial-build --watch",
|
|
38
38
|
"start:typescript": "npm run build:typescript -- --watch"
|
|
39
39
|
},
|
|
40
|
-
"skipBump":
|
|
41
|
-
"
|
|
42
|
-
|
|
40
|
+
"skipBump": {
|
|
41
|
+
"botframework-webchat-api": "use local peer version",
|
|
42
|
+
"botframework-webchat-core": "use local peer version",
|
|
43
|
+
"react-redux": ""
|
|
44
|
+
},
|
|
43
45
|
"devDependencies": {
|
|
44
46
|
"@babel/cli": "^7.18.10",
|
|
45
|
-
"@babel/core": "^7.
|
|
46
|
-
"@babel/preset-env": "^7.
|
|
47
|
+
"@babel/core": "^7.19.1",
|
|
48
|
+
"@babel/preset-env": "^7.19.1",
|
|
47
49
|
"@babel/preset-react": "^7.18.6",
|
|
48
50
|
"@babel/preset-typescript": "^7.18.6",
|
|
49
|
-
"@types/node": "^18.7.
|
|
50
|
-
"@types/react": "^18.0.
|
|
51
|
+
"@types/node": "^18.7.22",
|
|
52
|
+
"@types/react": "^18.0.21",
|
|
51
53
|
"babel-plugin-istanbul": "^6.1.1",
|
|
52
54
|
"babel-plugin-transform-inline-environment-variables": "^0.4.4",
|
|
53
|
-
"concurrently": "^7.
|
|
54
|
-
"core-js": "^3.
|
|
55
|
+
"concurrently": "^7.4.0",
|
|
56
|
+
"core-js": "^3.25.3",
|
|
55
57
|
"node-dev": "^7.4.3",
|
|
56
|
-
"typescript": "^4.
|
|
58
|
+
"typescript": "^4.8.3"
|
|
57
59
|
},
|
|
58
60
|
"dependencies": {
|
|
59
61
|
"@emotion/css": "11.10.0",
|
|
60
62
|
"base64-js": "1.5.1",
|
|
61
|
-
"botframework-webchat-api": "4.15.
|
|
62
|
-
"botframework-webchat-core": "4.15.
|
|
63
|
-
"classnames": "2.3.
|
|
63
|
+
"botframework-webchat-api": "4.15.5-main.20220927.f9dd67a",
|
|
64
|
+
"botframework-webchat-core": "4.15.5-main.20220927.f9dd67a",
|
|
65
|
+
"classnames": "2.3.2",
|
|
64
66
|
"compute-scroll-into-view": "1.0.17",
|
|
65
67
|
"event-target-shim": "6.0.2",
|
|
66
68
|
"markdown-it": "13.0.1",
|
|
@@ -93,7 +93,7 @@ const connectStackedLayout = (...selectors) =>
|
|
|
93
93
|
type StackedLayoutProps = {
|
|
94
94
|
activity: WebChatActivity;
|
|
95
95
|
hideTimestamp?: boolean;
|
|
96
|
-
renderActivityStatus?: ({ hideTimestamp: boolean }) => ReactNode;
|
|
96
|
+
renderActivityStatus?: (options: { hideTimestamp: boolean }) => ReactNode;
|
|
97
97
|
renderAttachment?: RenderAttachment;
|
|
98
98
|
renderAvatar?: false | (() => Exclude<ReactNode, boolean | null | undefined>);
|
|
99
99
|
showCallout?: boolean;
|
package/src/Composer.tsx
CHANGED
|
@@ -47,7 +47,11 @@ type ComposerCoreProps = {
|
|
|
47
47
|
children?: ReactNode;
|
|
48
48
|
extraStyleSet?: any;
|
|
49
49
|
nonce?: string;
|
|
50
|
-
renderMarkdown?: (
|
|
50
|
+
renderMarkdown?: (
|
|
51
|
+
markdown: string,
|
|
52
|
+
newLineOptions: { markdownRespectCRLF: boolean },
|
|
53
|
+
linkOptions: { externalLinkAlt: string }
|
|
54
|
+
) => string;
|
|
51
55
|
styleSet?: any;
|
|
52
56
|
suggestedActionsAccessKey?: boolean | string;
|
|
53
57
|
webSpeechPonyfillFactory?: WebSpeechPonyfillFactory;
|