botframework-webchat-component
Version:
React component of botframework-webchat
233 lines (230 loc) • 43.9 kB
JavaScript
"use strict";
function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _botframeworkWebchatApi = require("botframework-webchat-api");
var _classnames = _interopRequireDefault(require("classnames"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _react = _interopRequireWildcard(require("react"));
var _decorator = require("botframework-webchat-api/decorator");
var _Bubble = _interopRequireDefault(require("./Bubble"));
var _isZeroOrPositive = _interopRequireDefault(require("../Utils/isZeroOrPositive"));
var _ScreenReaderText = _interopRequireDefault(require("../ScreenReaderText"));
var _textFormatToContentType = _interopRequireDefault(require("../Utils/textFormatToContentType"));
var _useStyleSet3 = _interopRequireDefault(require("../hooks/useStyleSet"));
var _useStyleToEmotionObject = _interopRequireDefault(require("../hooks/internal/useStyleToEmotionObject"));
var _useUniqueId = _interopRequireDefault(require("../hooks/internal/useUniqueId"));
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } /* eslint complexity: ["error", 50] */
var useAvatarForBot = _botframeworkWebchatApi.hooks.useAvatarForBot,
useAvatarForUser = _botframeworkWebchatApi.hooks.useAvatarForUser,
useLocalizer = _botframeworkWebchatApi.hooks.useLocalizer,
useStyleOptions = _botframeworkWebchatApi.hooks.useStyleOptions;
var ROOT_STYLE = {
'&.webchat__stacked-layout': {
position: 'relative',
// This is to keep screen reader text in the destinated area.
'& .webchat__stacked-layout__attachment-row, & .webchat__stacked-layout__main, & .webchat__stacked-layout__message-row, & .webchat__stacked-layout__status': {
display: 'flex'
},
'& .webchat__stacked-layout__alignment-pad': {
flexShrink: 0
},
'& .webchat__stacked-layout__attachment': {
width: '100%'
},
'& .webchat__stacked-layout__avatar-gutter': {
display: 'flex',
flexDirection: 'column',
flexShrink: 0
},
'&.webchat__stacked-layout--from-user': {
'& .webchat__stacked-layout__attachment-row, & .webchat__stacked-layout__main, & .webchat__stacked-layout__message-row, & .webchat__stacked-layout__status': {
flexDirection: 'row-reverse'
}
},
'& .webchat__stacked-layout__content': {
flex: 1,
// This is for bottom aligning an avatar with a message bubble shorter than the avatar.
// Related to the test at activityGrouping.avatarMiddleware.atBottom.js.
display: 'flex',
flexDirection: 'column',
// This "overflow: hidden" is to make sure text overflow will get clipped correctly.
// Related to the test at basic.js "long URLs with keep-all".
overflow: 'hidden'
},
'& .webchat__stacked-layout__nub-pad': {
flexShrink: 0
}
}
};
var StackedLayout = function StackedLayout(_ref) {
var _activity$channelData, _activity$channelData2;
var activity = _ref.activity,
hideTimestamp = _ref.hideTimestamp,
renderActivityStatus = _ref.renderActivityStatus,
renderAttachment = _ref.renderAttachment,
renderAvatar = _ref.renderAvatar,
showCallout = _ref.showCallout;
var _useStyleOptions = useStyleOptions(),
_useStyleOptions2 = _slicedToArray(_useStyleOptions, 1),
styleOptions = _useStyleOptions2[0];
var _useAvatarForBot = useAvatarForBot(),
_useAvatarForBot2 = _slicedToArray(_useAvatarForBot, 1),
botInitials = _useAvatarForBot2[0].initials;
var _useAvatarForUser = useAvatarForUser(),
_useAvatarForUser2 = _slicedToArray(_useAvatarForUser, 1),
userInitials = _useAvatarForUser2[0].initials;
var _useStyleSet = (0, _useStyleSet3.default)(),
_useStyleSet2 = _slicedToArray(_useStyleSet, 1),
stackedLayoutStyleSet = _useStyleSet2[0].stackedLayout;
var ariaLabelId = (0, _useUniqueId.default)('webchat__stacked-layout__id');
var localize = useLocalizer();
var rootClassName = (0, _useStyleToEmotionObject.default)()(ROOT_STYLE) + '';
var bubbleNubOffset = styleOptions.bubbleNubOffset,
bubbleNubSize = styleOptions.bubbleNubSize,
bubbleFromUserNubOffset = styleOptions.bubbleFromUserNubOffset,
bubbleFromUserNubSize = styleOptions.bubbleFromUserNubSize;
var isMessage = activity.type === 'message';
var attachments = isMessage && activity.attachments || [];
var fromUser = activity.from.role === 'user';
var messageBackDisplayText = isMessage && ((_activity$channelData = activity.channelData) === null || _activity$channelData === void 0 ? void 0 : (_activity$channelData2 = _activity$channelData.messageBack) === null || _activity$channelData2 === void 0 ? void 0 : _activity$channelData2.displayText) || '';
var activityDisplayText = isMessage ? messageBackDisplayText || activity.text : '';
var attachedAlt = localize(fromUser ? 'ACTIVITY_YOU_ATTACHED_ALT' : 'ACTIVITY_BOT_ATTACHED_ALT');
var greetingAlt = (fromUser ? localize('ACTIVITY_YOU_SAID_ALT') : localize('ACTIVITY_BOT_SAID_ALT', botInitials || '')).replace(/[\t-\r \xA0\u1680\u2000-\u200A\u2028\u2029\u202F\u205F\u3000\uFEFF]{2,}/g, ' ');
var initials = fromUser ? userInitials : botInitials;
var nubOffset = fromUser ? bubbleFromUserNubOffset : bubbleNubOffset;
var nubSize = fromUser ? bubbleFromUserNubSize : bubbleNubSize;
var otherInitials = fromUser ? botInitials : userInitials;
var otherNubSize = fromUser ? bubbleNubSize : bubbleFromUserNubSize;
var hasAvatar = initials || typeof initials === 'string';
var hasOtherAvatar = otherInitials || typeof otherInitials === 'string';
var hasNub = typeof nubSize === 'number';
var hasOtherNub = typeof otherNubSize === 'number';
var topAlignedCallout = (0, _isZeroOrPositive.default)(nubOffset);
var extraTrailing = !hasOtherAvatar && hasOtherNub; // This is for bot message with user nub and no user avatar. And vice versa.
var showAvatar = showCallout && hasAvatar && !!renderAvatar;
var showNub = showCallout && hasNub && (topAlignedCallout || !(attachments !== null && attachments !== void 0 && attachments.length));
return /*#__PURE__*/_react.default.createElement("div", {
"aria-labelledby": activityDisplayText ? ariaLabelId : undefined,
className: (0, _classnames.default)('webchat__stacked-layout', rootClassName, stackedLayoutStyleSet + '', {
'webchat__stacked-layout--extra-trailing': extraTrailing,
'webchat__stacked-layout--from-user': fromUser,
'webchat__stacked-layout--hide-avatar': hasAvatar && !showAvatar,
'webchat__stacked-layout--hide-nub': hasNub && !showNub,
'webchat__stacked-layout--no-message': !activityDisplayText,
'webchat__stacked-layout--show-avatar': showAvatar,
'webchat__stacked-layout--show-nub': showNub,
'webchat__stacked-layout--top-callout': topAlignedCallout
})
}, /*#__PURE__*/_react.default.createElement("div", {
className: "webchat__stacked-layout__main"
}, /*#__PURE__*/_react.default.createElement("div", {
className: "webchat__stacked-layout__avatar-gutter"
}, showAvatar && renderAvatar()), /*#__PURE__*/_react.default.createElement("div", {
className: "webchat__stacked-layout__content"
}, !!activityDisplayText && /*#__PURE__*/_react.default.createElement("div", {
"aria-roledescription": "message",
className: "webchat__stacked-layout__message-row"
// Disable "Prop `id` is forbidden on DOM Nodes" rule because we are using the ID prop for accessibility.
/* eslint-disable-next-line react/forbid-dom-props */,
id: ariaLabelId,
role: "group"
}, /*#__PURE__*/_react.default.createElement(_ScreenReaderText.default, {
text: greetingAlt
}), /*#__PURE__*/_react.default.createElement(_Bubble.default, {
className: "webchat__stacked-layout__message",
fromUser: fromUser,
nub: showNub || (hasAvatar || hasNub ? 'hidden' : false)
}, /*#__PURE__*/_react.default.createElement(_decorator.ActivityDecorator, {
activity: activity
}, renderAttachment({
activity: activity,
attachment: isMessage ? {
content: activityDisplayText,
contentType: (0, _textFormatToContentType.default)(activity.textFormat)
} : undefined
})))), attachments.map(function (attachment, index) {
return /*#__PURE__*/_react.default.createElement("div", {
"aria-roledescription": "attachment",
className: (0, _classnames.default)('webchat__stacked-layout__attachment-row', {
'webchat__stacked-layout__attachment-row--first': !index
})
/* attachments do not have an ID, it is always indexed by number */
/* eslint-disable-next-line react/no-array-index-key */,
key: index,
role: "group"
}, /*#__PURE__*/_react.default.createElement(_ScreenReaderText.default, {
text: attachedAlt
}), /*#__PURE__*/_react.default.createElement(_Bubble.default, {
className: "webchat__stacked-layout__attachment",
fromUser: fromUser
/* eslint-disable-next-line react/no-array-index-key */,
key: index,
nub: hasAvatar || hasNub ? 'hidden' : false
}, renderAttachment({
activity: activity,
attachment: attachment
})));
})), /*#__PURE__*/_react.default.createElement("div", {
className: "webchat__stacked-layout__alignment-pad"
})), typeof renderActivityStatus === 'function' && /*#__PURE__*/_react.default.createElement("div", {
className: "webchat__stacked-layout__status"
}, /*#__PURE__*/_react.default.createElement("div", {
className: "webchat__stacked-layout__avatar-gutter"
}), /*#__PURE__*/_react.default.createElement("div", {
className: "webchat__stacked-layout__nub-pad"
}), renderActivityStatus({
hideTimestamp: hideTimestamp
}), /*#__PURE__*/_react.default.createElement("div", {
className: "webchat__stacked-layout__alignment-pad"
})));
};
StackedLayout.defaultProps = {
hideTimestamp: false,
renderActivityStatus: function renderActivityStatus() {
return false;
},
renderAvatar: undefined,
showCallout: true
};
StackedLayout.propTypes = {
// PropTypes cannot fully capture TypeScript types.
// @ts-ignore
activity: _propTypes.default.shape({
attachments: _propTypes.default.array,
channelData: _propTypes.default.shape({
messageBack: _propTypes.default.shape({
displayText: _propTypes.default.string
})
}),
from: _propTypes.default.shape({
role: _propTypes.default.string.isRequired
}).isRequired,
text: _propTypes.default.string,
textFormat: _propTypes.default.oneOf(['markdown', 'plain', 'xml']),
timestamp: _propTypes.default.string,
type: _propTypes.default.string.isRequired
}).isRequired,
hideTimestamp: _propTypes.default.bool,
// PropTypes cannot validate precisely with its TypeScript counterpart.
// @ts-ignore
renderActivityStatus: _propTypes.default.oneOfType([_propTypes.default.oneOf([false]), _propTypes.default.func]),
renderAttachment: _propTypes.default.func.isRequired,
// PropTypes cannot validate precisely with its TypeScript counterpart.
// @ts-ignore
renderAvatar: _propTypes.default.oneOfType([_propTypes.default.oneOf([false]), _propTypes.default.func]),
showCallout: _propTypes.default.bool
};
var _default = /*#__PURE__*/(0, _react.memo)(StackedLayout);
exports.default = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_botframeworkWebchatApi","require","_classnames","_interopRequireDefault","_propTypes","_react","_interopRequireWildcard","_decorator","_Bubble","_isZeroOrPositive","_ScreenReaderText","_textFormatToContentType","_useStyleSet3","_useStyleToEmotionObject","_useUniqueId","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_slicedToArray","arr","i","_arrayWithHoles","_iterableToArrayLimit","_unsupportedIterableToArray","_nonIterableRest","TypeError","o","minLen","_arrayLikeToArray","n","toString","slice","constructor","name","Array","from","test","len","length","arr2","_i","Symbol","iterator","_arr","_n","_d","_s","_e","next","done","push","value","err","isArray","useAvatarForBot","hooks","useAvatarForUser","useLocalizer","useStyleOptions","ROOT_STYLE","position","display","flexShrink","width","flexDirection","flex","overflow","StackedLayout","_ref","_activity$channelData","_activity$channelData2","activity","hideTimestamp","renderActivityStatus","renderAttachment","renderAvatar","showCallout","_useStyleOptions","_useStyleOptions2","styleOptions","_useAvatarForBot","_useAvatarForBot2","botInitials","initials","_useAvatarForUser","_useAvatarForUser2","userInitials","_useStyleSet","useStyleSet","_useStyleSet2","stackedLayoutStyleSet","stackedLayout","ariaLabelId","useUniqueId","localize","rootClassName","useStyleToEmotionObject","bubbleNubOffset","bubbleNubSize","bubbleFromUserNubOffset","bubbleFromUserNubSize","isMessage","type","attachments","fromUser","role","messageBackDisplayText","channelData","messageBack","displayText","activityDisplayText","text","attachedAlt","greetingAlt","replace","nubOffset","nubSize","otherInitials","otherNubSize","hasAvatar","hasOtherAvatar","hasNub","hasOtherNub","topAlignedCallout","isZeroOrPositive","extraTrailing","showAvatar","showNub","createElement","undefined","className","classNames","id","nub","ActivityDecorator","attachment","content","contentType","textFormatToContentType","textFormat","map","index","defaultProps","propTypes","PropTypes","shape","array","string","isRequired","oneOf","timestamp","bool","oneOfType","func","_default","memo","exports"],"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, { memo } from 'react';\nimport { ActivityDecorator } from 'botframework-webchat-api/decorator';\n\nimport Bubble from './Bubble';\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\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                <ActivityDecorator activity={activity}>\n                  {renderAttachment({\n                    activity,\n                    attachment: isMessage\n                      ? {\n                          content: activityDisplayText,\n                          contentType: textFormatToContentType(activity.textFormat)\n                        }\n                      : undefined\n                  })}\n                </ActivityDecorator>\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 memo(StackedLayout);\n"],"mappings":"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"}