botframework-webchat-component 4.15.0 → 4.15.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- {"version":3,"file":"BasicTranscript.d.ts","sourceRoot":"","sources":["../src/BasicTranscript.tsx"],"names":[],"mappings":"AAkBA,OAAO,KAAK,EAAyD,GAAG,EAAE,MAAM,OAAO,CAAC;AA+zBxF,aAAK,oBAAoB,GAAG;IAC1B,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,QAAA,MAAM,eAAe,EAAE,GAAG,CAAC,oBAAoB,CAc9C,CAAC;AAUF,eAAe,eAAe,CAAC"}
1
+ {"version":3,"file":"BasicTranscript.d.ts","sourceRoot":"","sources":["../src/BasicTranscript.tsx"],"names":[],"mappings":"AAkBA,OAAO,KAAK,EAAyD,GAAG,EAAE,MAAM,OAAO,CAAC;AAm1BxF,aAAK,oBAAoB,GAAG;IAC1B,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,QAAA,MAAM,eAAe,EAAE,GAAG,CAAC,oBAAoB,CAc9C,CAAC;AAUF,eAAe,eAAe,CAAC"}
@@ -297,19 +297,23 @@ var InternalTranscript = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref
297
297
  if (scrollableElement && activityBoundingBoxElement) {
298
298
  // ESLint conflict with TypeScript. The result of getClientRects() is not an Array but DOMRectList, and cannot be destructured.
299
299
  // eslint-disable-next-line prefer-destructuring
300
- var _activityBoundingBoxE = activityBoundingBoxElement.getClientRects()[0],
301
- activityHeight = _activityBoundingBoxE.height,
302
- activityY = _activityBoundingBoxE.y; // ESLint conflict with TypeScript. The result of getClientRects() is not an Array but DOMRectList, and cannot be destructured.
300
+ var activityBoundingBoxElementClientRect = activityBoundingBoxElement.getClientRects()[0]; // ESLint conflict with TypeScript. The result of getClientRects() is not an Array but DOMRectList, and cannot be destructured.
303
301
  // eslint-disable-next-line prefer-destructuring
304
302
 
305
- var scrollableHeight = scrollableElement.getClientRects()[0].height;
306
- var activityOffsetTop = activityY + scrollableElement.scrollTop;
303
+ var scrollableElementClientRect = scrollableElement.getClientRects()[0]; // If either the activity or the transcript scrollable is not on DOM, we will not scroll the view.
307
304
 
308
- var _scrollTop = Math.min(activityOffsetTop, activityOffsetTop - scrollableHeight + activityHeight);
305
+ if (activityBoundingBoxElementClientRect && scrollableElementClientRect) {
306
+ var activityHeight = activityBoundingBoxElementClientRect.height,
307
+ activityY = activityBoundingBoxElementClientRect.y;
308
+ var scrollableHeight = scrollableElementClientRect.height;
309
+ var activityOffsetTop = activityY + scrollableElement.scrollTop;
309
310
 
310
- scrollToBottomScrollTo(_scrollTop, {
311
- behavior: behavior
312
- });
311
+ var _scrollTop = Math.min(activityOffsetTop, activityOffsetTop - scrollableHeight + activityHeight);
312
+
313
+ scrollToBottomScrollTo(_scrollTop, {
314
+ behavior: behavior
315
+ });
316
+ }
313
317
  }
314
318
  }
315
319
  }, [activityElementMapRef, getKeyByActivityId, rootElementRef, scrollToBottomScrollTo]);
@@ -367,7 +371,13 @@ var InternalTranscript = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref
367
371
  var scrollableElement = rootElement.querySelector('.webchat__basic-transcript__scrollable'); // "getClientRects()" is not returning an array, thus, it is not destructurable.
368
372
  // eslint-disable-next-line prefer-destructuring
369
373
 
370
- var scrollableClientBottom = scrollableElement.getClientRects()[0].bottom; // Find the activity just above scroll view bottom.
374
+ var scrollableElementClientRect = scrollableElement.getClientRects()[0]; // If the scrollable is not mounted, we cannot measure which activity is in view. Thus, we will not fire any events.
375
+
376
+ if (!scrollableElementClientRect) {
377
+ return;
378
+ }
379
+
380
+ var scrollableClientBottom = scrollableElementClientRect.bottom; // Find the activity just above scroll view bottom.
371
381
  // If the scroll view is already on top, get the first activity.
372
382
 
373
383
  var activityElements = Array.from(activityElementMapRef.current.entries());
@@ -376,7 +386,12 @@ var InternalTranscript = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref
376
386
  var _ref8 = _slicedToArray(_ref7, 2),
377
387
  element = _ref8[1];
378
388
 
379
- return element.getClientRects()[0].bottom < scrollableClientBottom + 1;
389
+ // "getClientRects()" is not returning an array, thus, it is not destructurable.
390
+ // eslint-disable-next-line prefer-destructuring
391
+ var elementClientRect = element.getClientRects()[0]; // If the activity is not attached to DOM tree, we should not count it as "bottommost visible activity", as it is not visible.
392
+
393
+ // If the activity is not attached to DOM tree, we should not count it as "bottommost visible activity", as it is not visible.
394
+ return elementClientRect && elementClientRect.bottom < scrollableClientBottom + 1;
380
395
  }) : activityElements[0]) === null || _ref6 === void 0 ? void 0 : _ref6[0]; // When the end-user slowly scrolling the view down, we will mark activity as read when the message fully appear on the screen.
381
396
 
382
397
  activityKeyJustAboveScrollBottom && markActivityKeyAsRead(activityKeyJustAboveScrollBottom);
@@ -836,4 +851,4 @@ BasicTranscript.propTypes = {
836
851
  };
837
852
  var _default = BasicTranscript;
838
853
  exports.default = _default;
839
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/BasicTranscript.tsx"],"names":["useActivityKeys","hooks","useActivityKeysByRead","useCreateActivityStatusRenderer","useCreateAvatarRenderer","useCreateScrollToEndButtonRenderer","useDirection","useGetActivityByKey","useGetKeyByActivity","useGetKeyByActivityId","useLastAcknowledgedActivityKey","useLocalizer","useMarkActivityKeyAsRead","useMarkAllAsAcknowledged","useStyleOptions","ROOT_STYLE","display","flexDirection","overflow","position","flex","overflowX","WebkitOverflowScrolling","listStyleType","InternalTranscript","ref","activityElementMapRef","className","basicTranscriptStyleSet","basicTranscript","bubbleFromUserNubOffset","bubbleNubOffset","groupTimestamp","showAvatarInGroup","activeDescendantId","activityWithRendererTree","direction","focusedActivityKey","focusedExplicitly","createActivityStatusRenderer","createAvatarRenderer","focus","focusByActivityKey","focusRelativeActivity","getActivityByKey","getKeyByActivity","getKeyByActivityId","localize","rootClassName","rootElementRef","terminatorLabelId","terminatorRef","focusedActivityKeyRef","hideAllTimestamps","terminatorText","transcriptAriaLabel","callbackRef","element","current","renderingElements","topSideBotNub","topSideUserNub","forEach","entriesWithSameSender","firstActivity","activity","renderAvatar","entriesWithSameSenderAndStatus","indexWithinSenderGroup","firstInSenderGroup","lastInSenderGroup","length","indexWithinSenderAndStatusGroup","renderActivity","firstInSenderAndStatusGroup","key","lastInSenderAndStatusGroup","renderActivityStatus","nextVisibleActivity","undefined","topSideNub","from","role","showCallout","push","activityElement","set","delete","hideTimestamp","scrollToBottomScrollTo","scrollToBottomScrollToEnd","scrollTo","behavior","Error","activityId","activityID","scrollTop","activityBoundingBoxElement","get","querySelector","scrollableElement","getClientRects","activityHeight","height","activityY","y","scrollableHeight","activityOffsetTop","Math","min","scrollToEnd","scrollRelative","displacement","rootElement","scrollable","nextScrollTop","offsetHeight","max","scrollHeight","markActivityKeyAsRead","dispatchScrollPositionWithActivityId","handleScrollPosition","scrollableClientBottom","bottom","activityElements","Array","entries","activityKeyJustAboveScrollBottom","reverse","find","id","handleTranscriptKeyDown","event","target","fromEndOfTranscriptIndicator","fromTranscript","currentTarget","handled","Infinity","body","preventDefault","stopPropagation","handleTranscriptKeyDownCapture","altKey","ctrlKey","metaKey","dispatchTranscriptFocusByActivityKey","handleFocus","handleFocusFiller","android","map","defaultProps","propTypes","PropTypes","shape","instanceOf","Map","isRequired","string","InternalTranscriptScrollable","children","onFocusFiller","activitiesStyleSet","activities","animatingToEnd","atEnd","unreadActivityKeys","sticky","styleOptions","markAllAsAcknowledged","prevSticky","transcriptRoleDescription","stickyChangedToTrue","flat","flattenedActivityTreeWithRenderer","renderingActivityKeys","renderingActivityKeysRef","nextUnreadActivityKeys","nextUnreadActivityKeysRef","unread","some","includes","handleScrollToEndButtonClick","firstUnreadRenderingActivityKey","renderScrollToEndButton","onClick","React","Children","count","any","func","useScroller","activityKeys","lastAcknowledgedActivityKey","activityKeysRef","lastAcknowledgedActivityKeyRef","styleOptionsRef","autoScrollSnapOnActivity","autoScrollSnapOnActivityOffset","autoScrollSnapOnPage","autoScrollSnapOnPageOffset","patchedAutoScrollSnapOnActivity","patchedAutoScrollSnapOnPage","patchedAutoScrollSnapOnActivityOffset","patchedAutoScrollSnapOnPageOffset","activityElementMap","values","lastAcknowledgedActivityKeyIndex","indexOf","keys","firstUnacknowledgedActivityElementIndex","slice","acknowledgedActivityKey","index","nthUnacknowledgedActivityElement","nthUnacknowledgedActivityBoundingBoxElement","nthUnacknowledgedActivityOffsetTop","offsetTop","firstUnacknowledgedActivityElement","firstUnacknowledgedActivityBoundingBoxElement","firstUnacknowledgedActivityOffsetTop","BasicTranscript","containerRef","scroller"],"mappings":"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","sourceRoot":"component:///","sourcesContent":["import { hooks } from 'botframework-webchat-api';\nimport {\n  Composer as ReactScrollToBottomComposer,\n  Panel as ReactScrollToBottomPanel,\n  useAnimatingToEnd,\n  useAtEnd,\n  useObserveScrollPosition,\n  useScrollTo,\n  useScrollToEnd,\n  useSticky\n} from 'react-scroll-to-bottom';\nimport classNames from 'classnames';\nimport PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useCallback, useMemo, useRef } from 'react';\n\nimport type { ActivityComponentFactory, AvatarComponentFactory } from 'botframework-webchat-api';\nimport type { ActivityElementMap } from './Transcript/types';\nimport type { DirectLineActivity } from 'botframework-webchat-core';\nimport type { FC, KeyboardEventHandler, MutableRefObject, ReactNode, VFC } from 'react';\n\nimport { android } from './Utils/detectBrowser';\nimport ActivityRow from './Transcript/ActivityRow';\nimport BasicTypingIndicator from './BasicTypingIndicator';\nimport FocusRedirector from './Utils/FocusRedirector';\nimport inputtableKey from './Utils/TypeFocusSink/inputtableKey';\nimport isZeroOrPositive from './Utils/isZeroOrPositive';\nimport KeyboardHelp from './Transcript/KeyboardHelp';\nimport LiveRegionTranscript from './Transcript/LiveRegionTranscript';\n// TODO: [P2] #4133 Rename to \"getTabbableElements\".\nimport tabbableElements from './Utils/tabbableElements';\nimport TranscriptFocusComposer from './providers/TranscriptFocus/TranscriptFocusComposer';\nimport useActiveDescendantId from './providers/TranscriptFocus/useActiveDescendantId';\nimport useActivityTreeWithRenderer from './providers/ActivityTree/useActivityTreeWithRenderer';\nimport useDispatchScrollPosition from './hooks/internal/useDispatchScrollPosition';\nimport useDispatchTranscriptFocusByActivityKey from './hooks/internal/useDispatchTranscriptFocusByActivityKey';\nimport useFocus from './hooks/useFocus';\nimport useFocusByActivityKey from './providers/TranscriptFocus/useFocusByActivityKey';\nimport useFocusedActivityKey from './providers/TranscriptFocus/useFocusedActivityKey';\nimport useFocusedExplicitly from './providers/TranscriptFocus/useFocusedExplicitly';\nimport useFocusRelativeActivity from './providers/TranscriptFocus/useFocusRelativeActivity';\nimport useObserveFocusVisible from './hooks/internal/useObserveFocusVisible';\nimport usePrevious from './hooks/internal/usePrevious';\nimport useRegisterFocusTranscript from './hooks/internal/useRegisterFocusTranscript';\nimport useRegisterScrollRelative from './hooks/internal/useRegisterScrollRelative';\nimport useRegisterScrollTo from './hooks/internal/useRegisterScrollTo';\nimport useRegisterScrollToEnd from './hooks/internal/useRegisterScrollToEnd';\nimport useStyleSet from './hooks/useStyleSet';\nimport useStyleToEmotionObject from './hooks/internal/useStyleToEmotionObject';\nimport useUniqueId from './hooks/internal/useUniqueId';\nimport useValueRef from './hooks/internal/useValueRef';\n\nconst {\n  useActivityKeys,\n  useActivityKeysByRead,\n  useCreateActivityStatusRenderer,\n  useCreateAvatarRenderer,\n  useCreateScrollToEndButtonRenderer,\n  useDirection,\n  useGetActivityByKey,\n  useGetKeyByActivity,\n  useGetKeyByActivityId,\n  useLastAcknowledgedActivityKey,\n  useLocalizer,\n  useMarkActivityKeyAsRead,\n  useMarkAllAsAcknowledged,\n  useStyleOptions\n} = hooks;\n\nconst ROOT_STYLE = {\n  '&.webchat__basic-transcript': {\n    display: 'flex',\n    flexDirection: 'column',\n    overflow: 'hidden',\n    // Make sure to set \"position: relative\" here to form another stacking context for the scroll-to-end button.\n    // Stacking context help isolating elements that use \"z-index\" from global pollution.\n    // https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Positioning/Understanding_z_index/The_stacking_context\n    position: 'relative',\n\n    '& .webchat__basic-transcript__filler': {\n      flex: 1\n    },\n\n    '& .webchat__basic-transcript__scrollable': {\n      display: 'flex',\n      flexDirection: 'column',\n      overflowX: 'hidden',\n      WebkitOverflowScrolling: 'touch'\n    },\n\n    '& .webchat__basic-transcript__transcript': {\n      listStyleType: 'none'\n    }\n  }\n};\n\ntype RenderingElement = {\n  activity: DirectLineActivity & {\n    channelData?: {\n      ['webchat:fallback-text']: string;\n    };\n  };\n  callbackRef: (element: HTMLElement) => void;\n  hideTimestamp: boolean;\n  key: string;\n  renderActivity: Exclude<ReturnType<ActivityComponentFactory>, false>;\n  renderActivityStatus: (props: { hideTimestamp?: boolean }) => ReactNode;\n  renderAvatar: AvatarComponentFactory;\n  showCallout: boolean;\n};\n\ntype ScrollBehavior = 'auto' | 'smooth';\ntype ScrollToOptions = { behavior?: ScrollBehavior };\ntype ScrollToPosition = { activityID?: string; scrollTop?: number };\n\ntype InternalTranscriptProps = {\n  activityElementMapRef: MutableRefObject<ActivityElementMap>;\n  className?: string;\n};\n\n// TODO: [P1] #4133 Add telemetry for computing how many re-render done so far.\nconst InternalTranscript = forwardRef<HTMLDivElement, InternalTranscriptProps>(\n  ({ activityElementMapRef, className }, ref) => {\n    const [{ basicTranscript: basicTranscriptStyleSet }] = useStyleSet();\n    const [{ bubbleFromUserNubOffset, bubbleNubOffset, groupTimestamp, showAvatarInGroup }] = useStyleOptions();\n    const [activeDescendantId] = useActiveDescendantId();\n    const [activityWithRendererTree] = useActivityTreeWithRenderer();\n    const [direction] = useDirection();\n    const [focusedActivityKey] = useFocusedActivityKey();\n    const [focusedExplicitly] = useFocusedExplicitly();\n    const createActivityStatusRenderer = useCreateActivityStatusRenderer();\n    const createAvatarRenderer = useCreateAvatarRenderer();\n    const focus = useFocus();\n    const focusByActivityKey = useFocusByActivityKey();\n    const focusRelativeActivity = useFocusRelativeActivity();\n    const getActivityByKey = useGetActivityByKey();\n    const getKeyByActivity = useGetKeyByActivity();\n    const getKeyByActivityId = useGetKeyByActivityId();\n    const localize = useLocalizer();\n    const rootClassName = useStyleToEmotionObject()(ROOT_STYLE) + '';\n    const rootElementRef = useRef<HTMLDivElement>();\n    const terminatorLabelId = useUniqueId('webchat__basic-transcript__terminator-label');\n    const terminatorRef = useRef<HTMLDivElement>();\n\n    const focusedActivityKeyRef = useValueRef(focusedActivityKey);\n    const hideAllTimestamps = groupTimestamp === false;\n    const terminatorText = localize('TRANSCRIPT_TERMINATOR_TEXT');\n    const transcriptAriaLabel = localize('TRANSCRIPT_ARIA_LABEL_ALT');\n\n    const callbackRef = useCallback(\n      (element: HTMLDivElement) => {\n        if (typeof ref === 'function') {\n          ref(element);\n        } else {\n          ref.current = element;\n        }\n\n        rootElementRef.current = element;\n      },\n      [ref, rootElementRef]\n    );\n\n    // Flatten the tree back into an array with information related to rendering.\n    const renderingElements = useMemo(() => {\n      const renderingElements: RenderingElement[] = [];\n      const topSideBotNub = isZeroOrPositive(bubbleNubOffset);\n      const topSideUserNub = isZeroOrPositive(bubbleFromUserNubOffset);\n\n      activityWithRendererTree.forEach(entriesWithSameSender => {\n        const [[{ activity: firstActivity }]] = entriesWithSameSender;\n        const renderAvatar = createAvatarRenderer({ activity: firstActivity });\n\n        entriesWithSameSender.forEach((entriesWithSameSenderAndStatus, indexWithinSenderGroup) => {\n          const firstInSenderGroup = !indexWithinSenderGroup;\n          const lastInSenderGroup = indexWithinSenderGroup === entriesWithSameSender.length - 1;\n\n          entriesWithSameSenderAndStatus.forEach(({ activity, renderActivity }, indexWithinSenderAndStatusGroup) => {\n            // We only show the timestamp at the end of the sender group. But we always show the \"Send failed, retry\" prompt.\n            const firstInSenderAndStatusGroup = !indexWithinSenderAndStatusGroup;\n            const key: string = getKeyByActivity(activity);\n            const lastInSenderAndStatusGroup =\n              indexWithinSenderAndStatusGroup === entriesWithSameSenderAndStatus.length - 1;\n            const renderActivityStatus = createActivityStatusRenderer({\n              activity,\n              nextVisibleActivity: undefined\n            });\n            const topSideNub = activity.from?.role === 'user' ? topSideUserNub : topSideBotNub;\n\n            let showCallout: boolean;\n\n            // Depending on the \"showAvatarInGroup\" setting, the avatar will render in different positions.\n            if (showAvatarInGroup === 'sender') {\n              if (topSideNub) {\n                showCallout = firstInSenderGroup && firstInSenderAndStatusGroup;\n              } else {\n                showCallout = lastInSenderGroup && lastInSenderAndStatusGroup;\n              }\n            } else if (showAvatarInGroup === 'status') {\n              if (topSideNub) {\n                showCallout = firstInSenderAndStatusGroup;\n              } else {\n                showCallout = lastInSenderAndStatusGroup;\n              }\n            } else {\n              showCallout = true;\n            }\n\n            renderingElements.push({\n              activity,\n\n              // After the element is mounted, set it to activityElementsRef.\n              callbackRef: activityElement => {\n                activityElement\n                  ? activityElementMapRef.current.set(key, activityElement)\n                  : activityElementMapRef.current.delete(key);\n              },\n\n              // \"hideTimestamp\" is a render-time parameter for renderActivityStatus().\n              // If true, it will hide the timestamp, but it will continue to show the\n              // retry prompt. And show the screen reader version of the timestamp.\n              hideTimestamp:\n                hideAllTimestamps || indexWithinSenderAndStatusGroup !== entriesWithSameSenderAndStatus.length - 1,\n              key,\n              renderActivity,\n              renderActivityStatus,\n              renderAvatar,\n              showCallout\n            });\n          });\n        });\n      });\n\n      return renderingElements;\n    }, [\n      activityElementMapRef,\n      activityWithRendererTree,\n      bubbleFromUserNubOffset,\n      bubbleNubOffset,\n      createActivityStatusRenderer,\n      createAvatarRenderer,\n      getKeyByActivity,\n      hideAllTimestamps,\n      showAvatarInGroup\n    ]);\n\n    const scrollToBottomScrollTo: (scrollTop: number, options?: ScrollToOptions) => void = useScrollTo();\n    const scrollToBottomScrollToEnd: (options?: ScrollToOptions) => void = useScrollToEnd();\n\n    const scrollTo = useCallback(\n      (position: ScrollToPosition, { behavior = 'auto' }: ScrollToOptions = {}) => {\n        if (!position) {\n          throw new Error(\n            'botframework-webchat: First argument passed to \"useScrollTo\" must be a ScrollPosition object.'\n          );\n        }\n\n        const { activityID: activityId, scrollTop } = position;\n\n        if (typeof scrollTop !== 'undefined') {\n          scrollToBottomScrollTo(scrollTop, { behavior });\n        } else if (typeof activityId !== 'undefined') {\n          const activityBoundingBoxElement = activityElementMapRef.current\n            .get(getKeyByActivityId(activityId))\n            ?.querySelector('.webchat__basic-transcript__activity-active-descendant');\n\n          const scrollableElement = rootElementRef.current.querySelector('.webchat__basic-transcript__scrollable');\n\n          if (scrollableElement && activityBoundingBoxElement) {\n            // ESLint conflict with TypeScript. The result of getClientRects() is not an Array but DOMRectList, and cannot be destructured.\n            // eslint-disable-next-line prefer-destructuring\n            const { height: activityHeight, y: activityY } = activityBoundingBoxElement.getClientRects()[0];\n\n            // ESLint conflict with TypeScript. The result of getClientRects() is not an Array but DOMRectList, and cannot be destructured.\n            // eslint-disable-next-line prefer-destructuring\n            const { height: scrollableHeight } = scrollableElement.getClientRects()[0];\n            const activityOffsetTop = activityY + scrollableElement.scrollTop;\n\n            const scrollTop = Math.min(activityOffsetTop, activityOffsetTop - scrollableHeight + activityHeight);\n\n            scrollToBottomScrollTo(scrollTop, { behavior });\n          }\n        }\n      },\n      [activityElementMapRef, getKeyByActivityId, rootElementRef, scrollToBottomScrollTo]\n    );\n\n    const scrollToEnd = useCallback(\n      () => scrollToBottomScrollToEnd({ behavior: 'smooth' }),\n      [scrollToBottomScrollToEnd]\n    );\n\n    const scrollRelative = useCallback(\n      (direction: 'down' | 'up', { displacement }: { displacement?: number } = {}) => {\n        const { current: rootElement } = rootElementRef;\n\n        if (!rootElement) {\n          return;\n        }\n\n        const scrollable: HTMLElement = rootElement.querySelector('.webchat__basic-transcript__scrollable');\n        let nextScrollTop: number;\n\n        if (typeof displacement === 'number') {\n          // eslint-disable-next-line no-magic-numbers\n          nextScrollTop = scrollable.scrollTop + (direction === 'down' ? 1 : -1) * displacement;\n        } else {\n          // eslint-disable-next-line no-magic-numbers\n          nextScrollTop = scrollable.scrollTop + (direction === 'down' ? 1 : -1) * scrollable.offsetHeight;\n        }\n\n        scrollTo(\n          {\n            scrollTop: Math.max(0, Math.min(scrollable.scrollHeight - scrollable.offsetHeight, nextScrollTop))\n          },\n          { behavior: 'smooth' }\n        );\n      },\n      [rootElementRef, scrollTo]\n    );\n\n    // Since there could be multiple instances of <BasicTranscript> inside the <Composer>, when the developer calls `scrollXXX`, we need to call it on all instances.\n    // We call `useRegisterScrollXXX` to register a callback function, the `useScrollXXX` will multiplex the call into each instance of <BasicTranscript>.\n    useRegisterScrollTo(scrollTo);\n    useRegisterScrollToEnd(scrollToEnd);\n    useRegisterScrollRelative(scrollRelative);\n\n    const markActivityKeyAsRead = useMarkActivityKeyAsRead();\n\n    const dispatchScrollPositionWithActivityId: (scrollPosition: ScrollToPosition) => void =\n      useDispatchScrollPosition();\n\n    // TODO: [P2] We should use IntersectionObserver to track what activity is in the scrollable.\n    //            However, IntersectionObserver is not available on IE11, we need to make a limited polyfill in React style.\n    const handleScrollPosition = useCallback(\n      ({ scrollTop }: { scrollTop: number }) => {\n        const { current: rootElement } = rootElementRef;\n\n        if (!rootElement) {\n          return;\n        }\n\n        const scrollableElement = rootElement.querySelector('.webchat__basic-transcript__scrollable');\n\n        // \"getClientRects()\" is not returning an array, thus, it is not destructurable.\n        // eslint-disable-next-line prefer-destructuring\n        const { bottom: scrollableClientBottom } = scrollableElement.getClientRects()[0];\n\n        // Find the activity just above scroll view bottom.\n        // If the scroll view is already on top, get the first activity.\n        const activityElements = Array.from(activityElementMapRef.current.entries());\n        const activityKeyJustAboveScrollBottom: string | undefined = (\n          scrollableElement.scrollTop\n            ? activityElements\n                .reverse()\n                // Add subpixel tolerance\n                .find(([, element]) => element.getClientRects()[0].bottom < scrollableClientBottom + 1)\n            : activityElements[0]\n        )?.[0];\n\n        // When the end-user slowly scrolling the view down, we will mark activity as read when the message fully appear on the screen.\n        activityKeyJustAboveScrollBottom && markActivityKeyAsRead(activityKeyJustAboveScrollBottom);\n\n        if (dispatchScrollPositionWithActivityId) {\n          const activity = getActivityByKey(activityKeyJustAboveScrollBottom);\n\n          dispatchScrollPositionWithActivityId({ ...(activity ? { activityID: activity.id } : {}), scrollTop });\n        }\n      },\n      [\n        activityElementMapRef,\n        dispatchScrollPositionWithActivityId,\n        getActivityByKey,\n        markActivityKeyAsRead,\n        rootElementRef\n      ]\n    );\n\n    useObserveScrollPosition(handleScrollPosition);\n\n    const handleTranscriptKeyDown = useCallback<KeyboardEventHandler<HTMLDivElement>>(\n      event => {\n        const { target } = event;\n\n        const fromEndOfTranscriptIndicator = target === terminatorRef.current;\n        const fromTranscript = target === event.currentTarget;\n\n        if (!fromEndOfTranscriptIndicator && !fromTranscript) {\n          return;\n        }\n\n        let handled = true;\n\n        switch (event.key) {\n          case 'ArrowDown':\n            focusRelativeActivity(fromEndOfTranscriptIndicator ? 0 : 1);\n            break;\n\n          case 'ArrowUp':\n            // eslint-disable-next-line no-magic-numbers\n            focusRelativeActivity(fromEndOfTranscriptIndicator ? 0 : -1);\n            break;\n\n          case 'End':\n            focusRelativeActivity(Infinity);\n            break;\n\n          case 'Enter':\n            // This is capturing plain ENTER.\n            // When screen reader is not running, or screen reader is running outside of scan mode, the ENTER key will be captured here.\n            if (!fromEndOfTranscriptIndicator) {\n              const body: HTMLElement = activityElementMapRef.current\n                .get(focusedActivityKeyRef.current)\n                ?.querySelector('.webchat__basic-transcript__activity-body');\n\n              tabbableElements(body)[0]?.focus();\n            }\n\n            break;\n\n          case 'Escape':\n            focus('sendBoxWithoutKeyboard');\n            break;\n\n          case 'Home':\n            focusRelativeActivity(-Infinity);\n            break;\n\n          default:\n            handled = false;\n            break;\n        }\n\n        if (handled) {\n          event.preventDefault();\n\n          // If a custom HTML control wants to handle up/down arrow, we will prevent them from listening to this event to prevent bugs due to handling arrow keys twice.\n          event.stopPropagation();\n        }\n      },\n      [activityElementMapRef, focus, focusedActivityKeyRef, focusRelativeActivity, terminatorRef]\n    );\n\n    const handleTranscriptKeyDownCapture = useCallback<KeyboardEventHandler<HTMLDivElement>>(\n      event => {\n        const { altKey, ctrlKey, key, metaKey, target } = event;\n\n        if (altKey || (ctrlKey && key !== 'v') || metaKey || (!inputtableKey(key) && key !== 'Backspace')) {\n          // Ignore if one of the utility key (except SHIFT) is pressed\n          // E.g. CTRL-C on a link in one of the message should not jump to chat box\n          // E.g. \"A\" or \"Backspace\" should jump to chat box\n          return;\n        }\n\n        // Send keystrokes to send box if we are focusing on the transcript or terminator.\n        if (target === event.currentTarget || target === terminatorRef.current) {\n          event.stopPropagation();\n\n          focus('sendBox');\n        }\n      },\n      [focus]\n    );\n\n    useRegisterFocusTranscript(useCallback(() => focusByActivityKey(undefined), [focusByActivityKey]));\n\n    // When the focusing activity has changed, dispatch an event to observers of \"useObserveTranscriptFocus\".\n    const dispatchTranscriptFocusByActivityKey = useDispatchTranscriptFocusByActivityKey();\n\n    // Dispatch a \"transcript focus\" event based on user selection.\n    // We should not dispatch \"transcript focus\" when a new activity come. Although the selection change, it is not initiated from the user.\n    useMemo(\n      () => dispatchTranscriptFocusByActivityKey(focusedExplicitly ? focusedActivityKey : undefined),\n      [dispatchTranscriptFocusByActivityKey, focusedActivityKey, focusedExplicitly]\n    );\n\n    // When the transcript is being focused on, we should dispatch a \"transcriptfocus\" event.\n    const handleFocus = useCallback(\n      // We call \"focusByActivityKey\" with activity key of \"true\".\n      // It means, tries to focus on anything.\n      ({ currentTarget, target }) => target === currentTarget && focusByActivityKey(true, false),\n      [focusByActivityKey]\n    );\n\n    // This is required by IE11.\n    // When the user clicks on and empty space (a.k.a. filler) in an empty transcript, IE11 says the focus is on the <div className=\"filler\">,\n    // despite the fact there are no \"tabIndex\" attributes set on the filler.\n    // We need to artificially send the focus back to the transcript.\n    const handleFocusFiller = useCallback(() => focusByActivityKey(undefined), [focusByActivityKey]);\n\n    // When focus into the transcript using TAB/SHIFT-TAB, scroll the focused activity into view.\n    useObserveFocusVisible(\n      rootElementRef,\n      useCallback(() => focusByActivityKey(undefined), [focusByActivityKey])\n    );\n\n    return (\n      <div\n        // Although Android TalkBack 12.1 does not support `aria-activedescendant`, when used, it become buggy and will narrate content twice.\n        // We are disabling `aria-activedescendant` for Android. See <ActivityRow> for details.\n        aria-activedescendant={android ? undefined : activeDescendantId}\n        aria-label={transcriptAriaLabel}\n        className={classNames(\n          'webchat__basic-transcript',\n          basicTranscriptStyleSet + '',\n          rootClassName,\n          (className || '') + ''\n        )}\n        dir={direction}\n        onFocus={handleFocus}\n        onKeyDown={handleTranscriptKeyDown}\n        onKeyDownCapture={handleTranscriptKeyDownCapture}\n        ref={callbackRef}\n        // \"aria-activedescendant\" will only works with a number of roles and it must be explicitly set.\n        // https://www.w3.org/TR/wai-aria/#aria-activedescendant\n        role=\"group\"\n        // For up/down arrow key navigation across activities, this component must be included in the tab sequence.\n        // Otherwise, \"aria-activedescendant\" will not be narrated when the user press up/down arrow keys.\n        // https://www.w3.org/TR/wai-aria-practices-1.1/#kbd_focus_activedescendant\n        tabIndex={0}\n      >\n        <LiveRegionTranscript activityElementMapRef={activityElementMapRef} />\n        {/* TODO: [P2] Fix ESLint error `no-use-before-define` */}\n        {/* eslint-disable-next-line @typescript-eslint/no-use-before-define */}\n        <InternalTranscriptScrollable onFocusFiller={handleFocusFiller} terminatorRef={terminatorRef}>\n          {renderingElements.map(\n            ({\n              activity,\n              callbackRef,\n              hideTimestamp,\n              key,\n              renderActivity,\n              renderActivityStatus,\n              renderAvatar,\n              showCallout\n            }) => (\n              <ActivityRow activity={activity} key={key} ref={callbackRef}>\n                {renderActivity({\n                  hideTimestamp,\n                  renderActivityStatus,\n                  renderAvatar,\n                  showCallout\n                })}\n              </ActivityRow>\n            )\n          )}\n        </InternalTranscriptScrollable>\n        {!!renderingElements.length && (\n          <Fragment>\n            <FocusRedirector redirectRef={rootElementRef} />\n            <div\n              aria-hidden={true}\n              aria-labelledby={terminatorLabelId}\n              className=\"webchat__basic-transcript__terminator\"\n              ref={terminatorRef}\n              role=\"note\"\n              tabIndex={0}\n            >\n              <div className=\"webchat__basic-transcript__terminator-body\">\n                {/* `id` is required for `aria-labelledby` */}\n                {/* eslint-disable-next-line react/forbid-dom-props */}\n                <div className=\"webchat__basic-transcript__terminator-text\" id={terminatorLabelId}>\n                  {terminatorText}\n                </div>\n              </div>\n            </div>\n          </Fragment>\n        )}\n        <div className=\"webchat__basic-transcript__focus-indicator\" />\n      </div>\n    );\n  }\n);\n\nInternalTranscript.defaultProps = {\n  className: ''\n};\n\nInternalTranscript.propTypes = {\n  // PropTypes cannot validate precisely with its TypeScript counterpart.\n  // @ts-ignore\n  activityElementMapRef: PropTypes.shape({\n    current: PropTypes.instanceOf(Map)\n  }).isRequired,\n  className: PropTypes.string\n};\n\ntype InternalTranscriptScrollableProps = {\n  children?: ReactNode;\n  onFocusFiller: () => void;\n  terminatorRef: MutableRefObject<HTMLDivElement>;\n};\n\n// Separating high-frequency hooks to improve performance.\nconst InternalTranscriptScrollable: FC<InternalTranscriptScrollableProps> = ({\n  children,\n  onFocusFiller,\n  terminatorRef\n}) => {\n  const [{ activities: activitiesStyleSet }] = useStyleSet();\n  const [animatingToEnd]: [boolean] = useAnimatingToEnd();\n  const [atEnd]: [boolean] = useAtEnd();\n  const [, unreadActivityKeys] = useActivityKeysByRead();\n  const [sticky]: [boolean] = useSticky();\n  const [styleOptions] = useStyleOptions();\n  const focusByActivityKey = useFocusByActivityKey();\n  const localize = useLocalizer();\n  const markActivityKeyAsRead = useMarkActivityKeyAsRead();\n  const markAllAsAcknowledged = useMarkAllAsAcknowledged();\n  const scrollToEnd: (options?: ScrollToOptions) => void = useScrollToEnd();\n\n  const prevSticky = usePrevious(sticky);\n  const transcriptRoleDescription = localize('TRANSCRIPT_ARIA_ROLE_ALT');\n\n  const stickyChangedToTrue = prevSticky !== sticky && sticky;\n\n  // Acknowledged means either:\n  // 1. The user sent a message\n  //    - We don't need a condition here. When Web Chat sends the user's message, it will scroll to bottom, and it will trigger condition 2 below.\n  // 2. The user scroll to the bottom of the transcript, from a non-bottom scroll position\n  //    - If the transcript is already at the bottom, the user needs to scroll up and then go back down\n  //    - What happens if we are relaxing \"scrolled from a non-bottom scroll position\":\n  //      1. The condition will become solely \"at the bottom of the transcript\"\n  //      2. Auto-scroll will always scroll the transcript to the bottom\n  //      3. Web Chat will always acknowledge all activities as it is at the bottom\n  //      4. Acknowledge flag become useless\n  //      5. Therefore, even the developer set \"pause after 3 activities\", if activities are coming in at a slow pace (not batched in a single render)\n  //         Web Chat will keep scrolling and not snapped/paused\n\n  // Note: When Web Chat is loaded, there are no activities acknowledged. We need to assume all arriving activities are acknowledged until end-user sends their first activity.\n  //       Activities loaded initially could be from conversation history. Without assuming acknowledgement, Web Chat will not scroll initially (as everything is not acknowledged).\n  //       It would be better if the chat adapter should let Web Chat know if the activity is loaded from history or not.\n\n  // TODO: [P2] #3670 Move the \"conversation history acknowledgement\" logic mentioned above to polyfill of chat adapters.\n  //       1. Chat adapter should send \"acknowledged\" as part of \"channelData\"\n  //       2. If \"acknowledged\" is \"undefined\", we set it to:\n  //          a. true, if there are no egress activities yet\n  //          b. Otherwise, false\n\n  useMemo(\n    () =>\n      stickyChangedToTrue &&\n      // TODO: [P2] Both `markActivityKeyAsRead` and `markAllAsAcknowledged` hook are setters of useState.\n      //       This means, in a render loop, we will be calling setter and will cause another re-render.\n      //       This is not trivial but we should think if there is a way to avoid this.\n      markAllAsAcknowledged(),\n    [markAllAsAcknowledged, stickyChangedToTrue]\n  );\n\n  const [flattenedActivityTreeWithRenderer] = useActivityTreeWithRenderer({ flat: true });\n  const getKeyByActivity = useGetKeyByActivity();\n\n  const renderingActivityKeys: string[] = useMemo<string[]>(\n    () => flattenedActivityTreeWithRenderer.map(({ activity }) => getKeyByActivity(activity)),\n    [flattenedActivityTreeWithRenderer, getKeyByActivity]\n  );\n\n  const renderingActivityKeysRef = useValueRef(renderingActivityKeys);\n\n  // To prevent flashy button, we are not waiting for another render loop to update the `[readActivityKeys, unreadActivityKeys]` state.\n  // Instead, we are building the next one in this `useMemo` call.\n  const nextUnreadActivityKeys = useMemo(() => {\n    // This code need to be careful reviewed as it will cause another render. The code should be converging.\n    // After we call `markActivityKeyAsRead`, everything will be read and nothing will be unread.\n    // That means, in next render, `unreadActivityKeys` will be emptied and the `markActivityKeyAsRead` will not get called again.\n    if (sticky && unreadActivityKeys.length) {\n      markActivityKeyAsRead(unreadActivityKeys[unreadActivityKeys.length - 1]);\n\n      return [];\n    }\n\n    return unreadActivityKeys;\n  }, [markActivityKeyAsRead, sticky, unreadActivityKeys]);\n\n  const nextUnreadActivityKeysRef = useValueRef(nextUnreadActivityKeys);\n\n  // If we are rendering anything that is unread, we should show the \"New messages\" button.\n  // Not everything in the `unreadActivityKeys` are rendered, say, bot typing indicator.\n  // We should not show the \"New messages\" button for bot typing indicator as it will confuse the user.\n  const unread = useMemo(\n    () => nextUnreadActivityKeys.some(key => renderingActivityKeys.includes(key)),\n    [renderingActivityKeys, nextUnreadActivityKeys]\n  );\n\n  const handleScrollToEndButtonClick = useCallback(() => {\n    scrollToEnd({ behavior: 'smooth' });\n\n    const { current: renderingActivityKeys } = renderingActivityKeysRef;\n\n    // After the \"New message\" button is clicked, focus on the first unread activity which will be rendered.\n    const firstUnreadRenderingActivityKey = nextUnreadActivityKeysRef.current.find(key =>\n      renderingActivityKeys.includes(key)\n    );\n\n    if (firstUnreadRenderingActivityKey) {\n      focusByActivityKey(firstUnreadRenderingActivityKey);\n    } else {\n      // If no unread activity, send the focus to the terminator block.\n      terminatorRef.current?.focus();\n    }\n  }, [focusByActivityKey, nextUnreadActivityKeysRef, renderingActivityKeysRef, scrollToEnd, terminatorRef]);\n\n  const renderScrollToEndButton = useCreateScrollToEndButtonRenderer()({\n    atEnd: animatingToEnd || atEnd || sticky,\n    styleOptions,\n    unread\n  });\n\n  return (\n    <React.Fragment>\n      {renderScrollToEndButton && renderScrollToEndButton({ onClick: handleScrollToEndButtonClick })}\n      {!!React.Children.count(children) && <FocusRedirector redirectRef={terminatorRef} />}\n      <ReactScrollToBottomPanel className=\"webchat__basic-transcript__scrollable\">\n        <div aria-hidden={true} className=\"webchat__basic-transcript__filler\" onFocus={onFocusFiller} />\n        <section\n          aria-roledescription={transcriptRoleDescription}\n          className={classNames(activitiesStyleSet + '', 'webchat__basic-transcript__transcript')}\n          role=\"feed\"\n        >\n          {children}\n        </section>\n        <BasicTypingIndicator />\n      </ReactScrollToBottomPanel>\n    </React.Fragment>\n  );\n};\n\nInternalTranscriptScrollable.propTypes = {\n  children: PropTypes.any.isRequired,\n  onFocusFiller: PropTypes.func.isRequired,\n  terminatorRef: PropTypes.any.isRequired\n};\n\ntype Scroller = ({ offsetHeight, scrollTop }: { offsetHeight: number; scrollTop: number }) => number;\n\n// \"scroller\" is the auto-scroll limiter, a.k.a. auto scroll snap.\nconst useScroller = (activityElementMapRef: MutableRefObject<ActivityElementMap>): Scroller => {\n  const [activityKeys] = useActivityKeys();\n  const [lastAcknowledgedActivityKey] = useLastAcknowledgedActivityKey();\n  const [styleOptions] = useStyleOptions();\n\n  const activityKeysRef = useValueRef(activityKeys);\n  const lastAcknowledgedActivityKeyRef = useValueRef(lastAcknowledgedActivityKey);\n  const styleOptionsRef = useValueRef(styleOptions);\n\n  return useCallback(\n    ({ offsetHeight, scrollTop }) => {\n      const {\n        current: {\n          autoScrollSnapOnActivity,\n          autoScrollSnapOnActivityOffset,\n          autoScrollSnapOnPage,\n          autoScrollSnapOnPageOffset\n        }\n      } = styleOptionsRef;\n\n      const patchedAutoScrollSnapOnActivity =\n        typeof autoScrollSnapOnActivity === 'number'\n          ? Math.max(0, autoScrollSnapOnActivity)\n          : autoScrollSnapOnActivity\n          ? 1\n          : 0;\n      const patchedAutoScrollSnapOnPage =\n        typeof autoScrollSnapOnPage === 'number'\n          ? Math.max(0, Math.min(1, autoScrollSnapOnPage))\n          : autoScrollSnapOnPage\n          ? 1\n          : 0;\n      const patchedAutoScrollSnapOnActivityOffset =\n        typeof autoScrollSnapOnActivityOffset === 'number' ? autoScrollSnapOnActivityOffset : 0;\n      const patchedAutoScrollSnapOnPageOffset =\n        typeof autoScrollSnapOnPageOffset === 'number' ? autoScrollSnapOnPageOffset : 0;\n\n      if (patchedAutoScrollSnapOnActivity || patchedAutoScrollSnapOnPage) {\n        const { current: activityElementMap } = activityElementMapRef;\n        const { current: activityKeys } = activityKeysRef;\n        const { current: lastAcknowledgedActivityKey } = lastAcknowledgedActivityKeyRef;\n        const values: number[] = [];\n\n        const lastAcknowledgedActivityKeyIndex = activityKeys.indexOf(lastAcknowledgedActivityKey);\n\n        if (~lastAcknowledgedActivityKeyIndex) {\n          // The activity that we acknowledged could be not rendered, such as post back activity.\n          // When calculating scroll snap, we can only base on the first unacknowledged-and-rendering activity.\n          const renderingActivityKeys = Array.from(activityElementMap.keys());\n          let firstUnacknowledgedActivityElementIndex = -1;\n\n          for (const acknowledgedActivityKey of activityKeys.slice(0, lastAcknowledgedActivityKeyIndex + 1).reverse()) {\n            const index = renderingActivityKeys.indexOf(acknowledgedActivityKey);\n\n            if (~index) {\n              if (index !== renderingActivityKeys.length - 1) {\n                firstUnacknowledgedActivityElementIndex = index + 1;\n              }\n\n              break;\n            }\n          }\n\n          if (~firstUnacknowledgedActivityElementIndex) {\n            const activityElements = Array.from(activityElementMap.values());\n\n            if (patchedAutoScrollSnapOnActivity) {\n              // Gets the activity element which we should snap to.\n              const nthUnacknowledgedActivityElement =\n                activityElements[firstUnacknowledgedActivityElementIndex + patchedAutoScrollSnapOnActivity - 1];\n\n              if (nthUnacknowledgedActivityElement) {\n                const nthUnacknowledgedActivityBoundingBoxElement = nthUnacknowledgedActivityElement?.querySelector(\n                  '.webchat__basic-transcript__activity-active-descendant'\n                ) as HTMLElement;\n                const nthUnacknowledgedActivityOffsetTop =\n                  nthUnacknowledgedActivityElement.offsetTop + nthUnacknowledgedActivityBoundingBoxElement.offsetTop;\n\n                values.push(\n                  nthUnacknowledgedActivityOffsetTop +\n                    nthUnacknowledgedActivityBoundingBoxElement.offsetHeight -\n                    offsetHeight -\n                    scrollTop +\n                    patchedAutoScrollSnapOnActivityOffset\n                );\n              }\n            }\n\n            if (patchedAutoScrollSnapOnPage) {\n              const firstUnacknowledgedActivityElement = activityElements[+firstUnacknowledgedActivityElementIndex];\n              const firstUnacknowledgedActivityBoundingBoxElement = firstUnacknowledgedActivityElement.querySelector(\n                '.webchat__basic-transcript__activity-active-descendant'\n              ) as HTMLElement;\n              const firstUnacknowledgedActivityOffsetTop =\n                firstUnacknowledgedActivityElement.offsetTop + firstUnacknowledgedActivityBoundingBoxElement.offsetTop;\n\n              values.push(\n                firstUnacknowledgedActivityOffsetTop -\n                  scrollTop -\n                  offsetHeight * (1 - patchedAutoScrollSnapOnPage) +\n                  patchedAutoScrollSnapOnPageOffset\n              );\n            }\n          }\n        }\n\n        return Math.min(...values);\n      }\n\n      return Infinity;\n    },\n    [activityElementMapRef, activityKeysRef, lastAcknowledgedActivityKeyRef, styleOptionsRef]\n  );\n};\n\ntype BasicTranscriptProps = {\n  className?: string;\n};\n\nconst BasicTranscript: VFC<BasicTranscriptProps> = ({ className }) => {\n  const activityElementMapRef = useRef<ActivityElementMap>(new Map());\n  const containerRef = useRef<HTMLDivElement>();\n\n  const scroller = useScroller(activityElementMapRef);\n\n  return (\n    <TranscriptFocusComposer containerRef={containerRef}>\n      <ReactScrollToBottomComposer scroller={scroller}>\n        <KeyboardHelp />\n        <InternalTranscript activityElementMapRef={activityElementMapRef} className={className} ref={containerRef} />\n      </ReactScrollToBottomComposer>\n    </TranscriptFocusComposer>\n  );\n};\n\nBasicTranscript.defaultProps = {\n  className: ''\n};\n\nBasicTranscript.propTypes = {\n  className: PropTypes.string\n};\n\nexport default BasicTranscript;\n"]}
854
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/BasicTranscript.tsx"],"names":["useActivityKeys","hooks","useActivityKeysByRead","useCreateActivityStatusRenderer","useCreateAvatarRenderer","useCreateScrollToEndButtonRenderer","useDirection","useGetActivityByKey","useGetKeyByActivity","useGetKeyByActivityId","useLastAcknowledgedActivityKey","useLocalizer","useMarkActivityKeyAsRead","useMarkAllAsAcknowledged","useStyleOptions","ROOT_STYLE","display","flexDirection","overflow","position","flex","overflowX","WebkitOverflowScrolling","listStyleType","InternalTranscript","ref","activityElementMapRef","className","basicTranscriptStyleSet","basicTranscript","bubbleFromUserNubOffset","bubbleNubOffset","groupTimestamp","showAvatarInGroup","activeDescendantId","activityWithRendererTree","direction","focusedActivityKey","focusedExplicitly","createActivityStatusRenderer","createAvatarRenderer","focus","focusByActivityKey","focusRelativeActivity","getActivityByKey","getKeyByActivity","getKeyByActivityId","localize","rootClassName","rootElementRef","terminatorLabelId","terminatorRef","focusedActivityKeyRef","hideAllTimestamps","terminatorText","transcriptAriaLabel","callbackRef","element","current","renderingElements","topSideBotNub","topSideUserNub","forEach","entriesWithSameSender","firstActivity","activity","renderAvatar","entriesWithSameSenderAndStatus","indexWithinSenderGroup","firstInSenderGroup","lastInSenderGroup","length","indexWithinSenderAndStatusGroup","renderActivity","firstInSenderAndStatusGroup","key","lastInSenderAndStatusGroup","renderActivityStatus","nextVisibleActivity","undefined","topSideNub","from","role","showCallout","push","activityElement","set","delete","hideTimestamp","scrollToBottomScrollTo","scrollToBottomScrollToEnd","scrollTo","behavior","Error","activityId","activityID","scrollTop","activityBoundingBoxElement","get","querySelector","scrollableElement","activityBoundingBoxElementClientRect","getClientRects","scrollableElementClientRect","activityHeight","height","activityY","y","scrollableHeight","activityOffsetTop","Math","min","scrollToEnd","scrollRelative","displacement","rootElement","scrollable","nextScrollTop","offsetHeight","max","scrollHeight","markActivityKeyAsRead","dispatchScrollPositionWithActivityId","handleScrollPosition","scrollableClientBottom","bottom","activityElements","Array","entries","activityKeyJustAboveScrollBottom","reverse","find","elementClientRect","id","handleTranscriptKeyDown","event","target","fromEndOfTranscriptIndicator","fromTranscript","currentTarget","handled","Infinity","body","preventDefault","stopPropagation","handleTranscriptKeyDownCapture","altKey","ctrlKey","metaKey","dispatchTranscriptFocusByActivityKey","handleFocus","handleFocusFiller","android","map","defaultProps","propTypes","PropTypes","shape","instanceOf","Map","isRequired","string","InternalTranscriptScrollable","children","onFocusFiller","activitiesStyleSet","activities","animatingToEnd","atEnd","unreadActivityKeys","sticky","styleOptions","markAllAsAcknowledged","prevSticky","transcriptRoleDescription","stickyChangedToTrue","flat","flattenedActivityTreeWithRenderer","renderingActivityKeys","renderingActivityKeysRef","nextUnreadActivityKeys","nextUnreadActivityKeysRef","unread","some","includes","handleScrollToEndButtonClick","firstUnreadRenderingActivityKey","renderScrollToEndButton","onClick","React","Children","count","any","func","useScroller","activityKeys","lastAcknowledgedActivityKey","activityKeysRef","lastAcknowledgedActivityKeyRef","styleOptionsRef","autoScrollSnapOnActivity","autoScrollSnapOnActivityOffset","autoScrollSnapOnPage","autoScrollSnapOnPageOffset","patchedAutoScrollSnapOnActivity","patchedAutoScrollSnapOnPage","patchedAutoScrollSnapOnActivityOffset","patchedAutoScrollSnapOnPageOffset","activityElementMap","values","lastAcknowledgedActivityKeyIndex","indexOf","keys","firstUnacknowledgedActivityElementIndex","slice","acknowledgedActivityKey","index","nthUnacknowledgedActivityElement","nthUnacknowledgedActivityBoundingBoxElement","nthUnacknowledgedActivityOffsetTop","offsetTop","firstUnacknowledgedActivityElement","firstUnacknowledgedActivityBoundingBoxElement","firstUnacknowledgedActivityOffsetTop","BasicTranscript","containerRef","scroller"],"mappings":";;;;;;;;;AAAA;;AACA;;AAUA;;AACA;;AACA;;AAOA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAEA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEA,IACEA,eADF,GAeIC,6BAfJ,CACED,eADF;AAAA,IAEEE,qBAFF,GAeID,6BAfJ,CAEEC,qBAFF;AAAA,IAGEC,+BAHF,GAeIF,6BAfJ,CAGEE,+BAHF;AAAA,IAIEC,uBAJF,GAeIH,6BAfJ,CAIEG,uBAJF;AAAA,IAKEC,kCALF,GAeIJ,6BAfJ,CAKEI,kCALF;AAAA,IAMEC,YANF,GAeIL,6BAfJ,CAMEK,YANF;AAAA,IAOEC,mBAPF,GAeIN,6BAfJ,CAOEM,mBAPF;AAAA,IAQEC,mBARF,GAeIP,6BAfJ,CAQEO,mBARF;AAAA,IASEC,qBATF,GAeIR,6BAfJ,CASEQ,qBATF;AAAA,IAUEC,8BAVF,GAeIT,6BAfJ,CAUES,8BAVF;AAAA,IAWEC,YAXF,GAeIV,6BAfJ,CAWEU,YAXF;AAAA,IAYEC,wBAZF,GAeIX,6BAfJ,CAYEW,wBAZF;AAAA,IAaEC,wBAbF,GAeIZ,6BAfJ,CAaEY,wBAbF;AAAA,IAcEC,eAdF,GAeIb,6BAfJ,CAcEa,eAdF;AAiBA,IAAMC,UAAU,GAAG;AACjB,iCAA+B;AAC7BC,IAAAA,OAAO,EAAE,MADoB;AAE7BC,IAAAA,aAAa,EAAE,QAFc;AAG7BC,IAAAA,QAAQ,EAAE,QAHmB;AAI7B;AACA;AACA;AACAC,IAAAA,QAAQ,EAAE,UAPmB;AAS7B,4CAAwC;AACtCC,MAAAA,IAAI,EAAE;AADgC,KATX;AAa7B,gDAA4C;AAC1CJ,MAAAA,OAAO,EAAE,MADiC;AAE1CC,MAAAA,aAAa,EAAE,QAF2B;AAG1CI,MAAAA,SAAS,EAAE,QAH+B;AAI1CC,MAAAA,uBAAuB,EAAE;AAJiB,KAbf;AAoB7B,gDAA4C;AAC1CC,MAAAA,aAAa,EAAE;AAD2B;AApBf;AADd,CAAnB;AAmDA;AACA,IAAMC,kBAAkB,gBAAG,uBACzB,gBAAuCC,GAAvC,EAA+C;AAAA,MAA5CC,qBAA4C,QAA5CA,qBAA4C;AAAA,MAArBC,SAAqB,QAArBA,SAAqB;;AAC7C,qBAAuD,4BAAvD;AAAA;AAAA,MAA0BC,uBAA1B,oBAASC,eAAT;;AACA,yBAA0Ff,eAAe,EAAzG;AAAA;AAAA;AAAA,MAASgB,uBAAT,sBAASA,uBAAT;AAAA,MAAkCC,eAAlC,sBAAkCA,eAAlC;AAAA,MAAmDC,cAAnD,sBAAmDA,cAAnD;AAAA,MAAmEC,iBAAnE,sBAAmEA,iBAAnE;;AACA,8BAA6B,qCAA7B;AAAA;AAAA,MAAOC,kBAAP;;AACA,8BAAmC,2CAAnC;AAAA;AAAA,MAAOC,wBAAP;;AACA,sBAAoB7B,YAAY,EAAhC;AAAA;AAAA,MAAO8B,SAAP;;AACA,8BAA6B,qCAA7B;AAAA;AAAA,MAAOC,kBAAP;;AACA,8BAA4B,qCAA5B;AAAA;AAAA,MAAOC,iBAAP;;AACA,MAAMC,4BAA4B,GAAGpC,+BAA+B,EAApE;AACA,MAAMqC,oBAAoB,GAAGpC,uBAAuB,EAApD;AACA,MAAMqC,KAAK,GAAG,wBAAd;AACA,MAAMC,kBAAkB,GAAG,qCAA3B;AACA,MAAMC,qBAAqB,GAAG,wCAA9B;AACA,MAAMC,gBAAgB,GAAGrC,mBAAmB,EAA5C;AACA,MAAMsC,gBAAgB,GAAGrC,mBAAmB,EAA5C;AACA,MAAMsC,kBAAkB,GAAGrC,qBAAqB,EAAhD;AACA,MAAMsC,QAAQ,GAAGpC,YAAY,EAA7B;AACA,MAAMqC,aAAa,GAAG,wCAA0BjC,UAA1B,IAAwC,EAA9D;AACA,MAAMkC,cAAc,GAAG,oBAAvB;AACA,MAAMC,iBAAiB,GAAG,0BAAY,6CAAZ,CAA1B;AACA,MAAMC,aAAa,GAAG,oBAAtB;AAEA,MAAMC,qBAAqB,GAAG,0BAAYf,kBAAZ,CAA9B;AACA,MAAMgB,iBAAiB,GAAGrB,cAAc,KAAK,KAA7C;AACA,MAAMsB,cAAc,GAAGP,QAAQ,CAAC,4BAAD,CAA/B;AACA,MAAMQ,mBAAmB,GAAGR,QAAQ,CAAC,2BAAD,CAApC;AAEA,MAAMS,WAAW,GAAG,wBAClB,UAACC,OAAD,EAA6B;AAC3B,QAAI,OAAOhC,GAAP,KAAe,UAAnB,EAA+B;AAC7BA,MAAAA,GAAG,CAACgC,OAAD,CAAH;AACD,KAFD,MAEO;AACLhC,MAAAA,GAAG,CAACiC,OAAJ,GAAcD,OAAd;AACD;;AAEDR,IAAAA,cAAc,CAACS,OAAf,GAAyBD,OAAzB;AACD,GATiB,EAUlB,CAAChC,GAAD,EAAMwB,cAAN,CAVkB,CAApB,CA3B6C,CAwC7C;;AACA,MAAMU,iBAAiB,GAAG,oBAAQ,YAAM;AACtC,QAAMA,iBAAqC,GAAG,EAA9C;AACA,QAAMC,aAAa,GAAG,+BAAiB7B,eAAjB,CAAtB;AACA,QAAM8B,cAAc,GAAG,+BAAiB/B,uBAAjB,CAAvB;AAEAK,IAAAA,wBAAwB,CAAC2B,OAAzB,CAAiC,UAAAC,qBAAqB,EAAI;AACxD,iDAAwCA,qBAAxC;AAAA;AAAA,UAAoBC,aAApB,6BAAUC,QAAV;;AACA,UAAMC,YAAY,GAAG1B,oBAAoB,CAAC;AAAEyB,QAAAA,QAAQ,EAAED;AAAZ,OAAD,CAAzC;AAEAD,MAAAA,qBAAqB,CAACD,OAAtB,CAA8B,UAACK,8BAAD,EAAiCC,sBAAjC,EAA4D;AACxF,YAAMC,kBAAkB,GAAG,CAACD,sBAA5B;AACA,YAAME,iBAAiB,GAAGF,sBAAsB,KAAKL,qBAAqB,CAACQ,MAAtB,GAA+B,CAApF;AAEAJ,QAAAA,8BAA8B,CAACL,OAA/B,CAAuC,iBAA+BU,+BAA/B,EAAmE;AAAA;;AAAA,cAAhEP,QAAgE,SAAhEA,QAAgE;AAAA,cAAtDQ,cAAsD,SAAtDA,cAAsD;AACxG;AACA,cAAMC,2BAA2B,GAAG,CAACF,+BAArC;AACA,cAAMG,GAAW,GAAG9B,gBAAgB,CAACoB,QAAD,CAApC;AACA,cAAMW,0BAA0B,GAC9BJ,+BAA+B,KAAKL,8BAA8B,CAACI,MAA/B,GAAwC,CAD9E;AAEA,cAAMM,oBAAoB,GAAGtC,4BAA4B,CAAC;AACxD0B,YAAAA,QAAQ,EAARA,QADwD;AAExDa,YAAAA,mBAAmB,EAAEC;AAFmC,WAAD,CAAzD;AAIA,cAAMC,UAAU,GAAG,mBAAAf,QAAQ,CAACgB,IAAT,kEAAeC,IAAf,MAAwB,MAAxB,GAAiCrB,cAAjC,GAAkDD,aAArE;AAEA,cAAIuB,WAAJ,CAZwG,CAcxG;;AACA,cAAIlD,iBAAiB,KAAK,QAA1B,EAAoC;AAClC,gBAAI+C,UAAJ,EAAgB;AACdG,cAAAA,WAAW,GAAGd,kBAAkB,IAAIK,2BAApC;AACD,aAFD,MAEO;AACLS,cAAAA,WAAW,GAAGb,iBAAiB,IAAIM,0BAAnC;AACD;AACF,WAND,MAMO,IAAI3C,iBAAiB,KAAK,QAA1B,EAAoC;AACzC,gBAAI+C,UAAJ,EAAgB;AACdG,cAAAA,WAAW,GAAGT,2BAAd;AACD,aAFD,MAEO;AACLS,cAAAA,WAAW,GAAGP,0BAAd;AACD;AACF,WANM,MAMA;AACLO,YAAAA,WAAW,GAAG,IAAd;AACD;;AAEDxB,UAAAA,iBAAiB,CAACyB,IAAlB,CAAuB;AACrBnB,YAAAA,QAAQ,EAARA,QADqB;AAGrB;AACAT,YAAAA,WAAW,EAAE,qBAAA6B,eAAe,EAAI;AAC9BA,cAAAA,eAAe,GACX3D,qBAAqB,CAACgC,OAAtB,CAA8B4B,GAA9B,CAAkCX,GAAlC,EAAuCU,eAAvC,CADW,GAEX3D,qBAAqB,CAACgC,OAAtB,CAA8B6B,MAA9B,CAAqCZ,GAArC,CAFJ;AAGD,aARoB;AAUrB;AACA;AACA;AACAa,YAAAA,aAAa,EACXnC,iBAAiB,IAAImB,+BAA+B,KAAKL,8BAA8B,CAACI,MAA/B,GAAwC,CAd9E;AAerBI,YAAAA,GAAG,EAAHA,GAfqB;AAgBrBF,YAAAA,cAAc,EAAdA,cAhBqB;AAiBrBI,YAAAA,oBAAoB,EAApBA,oBAjBqB;AAkBrBX,YAAAA,YAAY,EAAZA,YAlBqB;AAmBrBiB,YAAAA,WAAW,EAAXA;AAnBqB,WAAvB;AAqBD,SApDD;AAqDD,OAzDD;AA0DD,KA9DD;AAgEA,WAAOxB,iBAAP;AACD,GAtEyB,EAsEvB,CACDjC,qBADC,EAEDS,wBAFC,EAGDL,uBAHC,EAIDC,eAJC,EAKDQ,4BALC,EAMDC,oBANC,EAODK,gBAPC,EAQDQ,iBARC,EASDpB,iBATC,CAtEuB,CAA1B;AAkFA,MAAMwD,sBAA8E,GAAG,uCAAvF;AACA,MAAMC,yBAA8D,GAAG,0CAAvE;AAEA,MAAMC,QAAQ,GAAG,wBACf,UAACxE,QAAD,EAA6E;AAAA,oFAAP,EAAO;AAAA,+BAA9CyE,QAA8C;AAAA,QAA9CA,QAA8C,+BAAnC,MAAmC;;AAC3E,QAAI,CAACzE,QAAL,EAAe;AACb,YAAM,IAAI0E,KAAJ,CACJ,+FADI,CAAN;AAGD;;AAED,QAAoBC,UAApB,GAA8C3E,QAA9C,CAAQ4E,UAAR;AAAA,QAAgCC,SAAhC,GAA8C7E,QAA9C,CAAgC6E,SAAhC;;AAEA,QAAI,OAAOA,SAAP,KAAqB,WAAzB,EAAsC;AACpCP,MAAAA,sBAAsB,CAACO,SAAD,EAAY;AAAEJ,QAAAA,QAAQ,EAARA;AAAF,OAAZ,CAAtB;AACD,KAFD,MAEO,IAAI,OAAOE,UAAP,KAAsB,WAA1B,EAAuC;AAAA;;AAC5C,UAAMG,0BAA0B,4BAAGvE,qBAAqB,CAACgC,OAAtB,CAChCwC,GADgC,CAC5BpD,kBAAkB,CAACgD,UAAD,CADU,CAAH,0DAAG,sBAE/BK,aAF+B,CAEjB,wDAFiB,CAAnC;AAIA,UAAMC,iBAAiB,GAAGnD,cAAc,CAACS,OAAf,CAAuByC,aAAvB,CAAqC,wCAArC,CAA1B;;AAEA,UAAIC,iBAAiB,IAAIH,0BAAzB,EAAqD;AACnD;AACA;AACA,YAAMI,oCAAoC,GAAGJ,0BAA0B,CAACK,cAA3B,GAA4C,CAA5C,CAA7C,CAHmD,CAKnD;AACA;;AACA,YAAMC,2BAA2B,GAAGH,iBAAiB,CAACE,cAAlB,GAAmC,CAAnC,CAApC,CAPmD,CASnD;;AACA,YAAID,oCAAoC,IAAIE,2BAA5C,EAAyE;AACvE,cAAgBC,cAAhB,GAAiDH,oCAAjD,CAAQI,MAAR;AAAA,cAAmCC,SAAnC,GAAiDL,oCAAjD,CAAgCM,CAAhC;AACA,cAAgBC,gBAAhB,GAAqCL,2BAArC,CAAQE,MAAR;AACA,cAAMI,iBAAiB,GAAGH,SAAS,GAAGN,iBAAiB,CAACJ,SAAxD;;AAEA,cAAMA,UAAS,GAAGc,IAAI,CAACC,GAAL,CAASF,iBAAT,EAA4BA,iBAAiB,GAAGD,gBAApB,GAAuCJ,cAAnE,CAAlB;;AAEAf,UAAAA,sBAAsB,CAACO,UAAD,EAAY;AAAEJ,YAAAA,QAAQ,EAARA;AAAF,WAAZ,CAAtB;AACD;AACF;AACF;AACF,GAxCc,EAyCf,CAAClE,qBAAD,EAAwBoB,kBAAxB,EAA4CG,cAA5C,EAA4DwC,sBAA5D,CAzCe,CAAjB;AA4CA,MAAMuB,WAAW,GAAG,wBAClB;AAAA,WAAMtB,yBAAyB,CAAC;AAAEE,MAAAA,QAAQ,EAAE;AAAZ,KAAD,CAA/B;AAAA,GADkB,EAElB,CAACF,yBAAD,CAFkB,CAApB;AAKA,MAAMuB,cAAc,GAAG,wBACrB,UAAC7E,SAAD,EAAgF;AAAA,oFAAP,EAAO;AAAA,QAAnD8E,YAAmD,SAAnDA,YAAmD;;AAC9E,QAAiBC,WAAjB,GAAiClE,cAAjC,CAAQS,OAAR;;AAEA,QAAI,CAACyD,WAAL,EAAkB;AAChB;AACD;;AAED,QAAMC,UAAuB,GAAGD,WAAW,CAAChB,aAAZ,CAA0B,wCAA1B,CAAhC;AACA,QAAIkB,aAAJ;;AAEA,QAAI,OAAOH,YAAP,KAAwB,QAA5B,EAAsC;AACpC;AACAG,MAAAA,aAAa,GAAGD,UAAU,CAACpB,SAAX,GAAuB,CAAC5D,SAAS,KAAK,MAAd,GAAuB,CAAvB,GAA2B,CAAC,CAA7B,IAAkC8E,YAAzE;AACD,KAHD,MAGO;AACL;AACAG,MAAAA,aAAa,GAAGD,UAAU,CAACpB,SAAX,GAAuB,CAAC5D,SAAS,KAAK,MAAd,GAAuB,CAAvB,GAA2B,CAAC,CAA7B,IAAkCgF,UAAU,CAACE,YAApF;AACD;;AAED3B,IAAAA,QAAQ,CACN;AACEK,MAAAA,SAAS,EAAEc,IAAI,CAACS,GAAL,CAAS,CAAT,EAAYT,IAAI,CAACC,GAAL,CAASK,UAAU,CAACI,YAAX,GAA0BJ,UAAU,CAACE,YAA9C,EAA4DD,aAA5D,CAAZ;AADb,KADM,EAIN;AAAEzB,MAAAA,QAAQ,EAAE;AAAZ,KAJM,CAAR;AAMD,GAzBoB,EA0BrB,CAAC3C,cAAD,EAAiB0C,QAAjB,CA1BqB,CAAvB,CA/K6C,CA4M7C;AACA;;AACA,oCAAoBA,QAApB;AACA,uCAAuBqB,WAAvB;AACA,0CAA0BC,cAA1B;AAEA,MAAMQ,qBAAqB,GAAG7G,wBAAwB,EAAtD;AAEA,MAAM8G,oCAAgF,GACpF,yCADF,CApN6C,CAuN7C;AACA;;AACA,MAAMC,oBAAoB,GAAG,wBAC3B,iBAA0C;AAAA;;AAAA,QAAvC3B,SAAuC,SAAvCA,SAAuC;AACxC,QAAiBmB,WAAjB,GAAiClE,cAAjC,CAAQS,OAAR;;AAEA,QAAI,CAACyD,WAAL,EAAkB;AAChB;AACD;;AAED,QAAMf,iBAAiB,GAAGe,WAAW,CAAChB,aAAZ,CAA0B,wCAA1B,CAA1B,CAPwC,CASxC;AACA;;AACA,QAAMI,2BAA2B,GAAGH,iBAAiB,CAACE,cAAlB,GAAmC,CAAnC,CAApC,CAXwC,CAaxC;;AACA,QAAI,CAACC,2BAAL,EAAkC;AAChC;AACD;;AAED,QAAgBqB,sBAAhB,GAA2CrB,2BAA3C,CAAQsB,MAAR,CAlBwC,CAoBxC;AACA;;AACA,QAAMC,gBAAgB,GAAGC,KAAK,CAAC9C,IAAN,CAAWvD,qBAAqB,CAACgC,OAAtB,CAA8BsE,OAA9B,EAAX,CAAzB;AACA,QAAMC,gCAAoD,YACxD7B,iBAAiB,CAACJ,SAAlB,GACI8B,gBAAgB,CACbI,OADH,GAEE;AAFF,KAGGC,IAHH,CAGQ,iBAAiB;AAAA;AAAA,UAAb1E,OAAa;;AACrB;AACA;AACA,UAAM2E,iBAAiB,GAAG3E,OAAO,CAAC6C,cAAR,GAAyB,CAAzB,CAA1B,CAHqB,CAKrB;;AAAA;AACA,aAAO8B,iBAAiB,IAAIA,iBAAiB,CAACP,MAAlB,GAA2BD,sBAAsB,GAAG,CAAhF;AACD,KAVH,CADJ,GAYIE,gBAAgB,CAAC,CAAD,CAboC,0CAAG,MAczD,CAdyD,CAA7D,CAvBwC,CAuCxC;;AACAG,IAAAA,gCAAgC,IAAIR,qBAAqB,CAACQ,gCAAD,CAAzD;;AAEA,QAAIP,oCAAJ,EAA0C;AACxC,UAAMzD,QAAQ,GAAGrB,gBAAgB,CAACqF,gCAAD,CAAjC;AAEAP,MAAAA,oCAAoC,iCAAOzD,QAAQ,GAAG;AAAE8B,QAAAA,UAAU,EAAE9B,QAAQ,CAACoE;AAAvB,OAAH,GAAiC,EAAhD;AAAqDrC,QAAAA,SAAS,EAATA;AAArD,SAApC;AACD;AACF,GAhD0B,EAiD3B,CACEtE,qBADF,EAEEgG,oCAFF,EAGE9E,gBAHF,EAIE6E,qBAJF,EAKExE,cALF,CAjD2B,CAA7B;AA0DA,qDAAyB0E,oBAAzB;AAEA,MAAMW,uBAAuB,GAAG,wBAC9B,UAAAC,KAAK,EAAI;AACP,QAAQC,MAAR,GAAmBD,KAAnB,CAAQC,MAAR;AAEA,QAAMC,4BAA4B,GAAGD,MAAM,KAAKrF,aAAa,CAACO,OAA9D;AACA,QAAMgF,cAAc,GAAGF,MAAM,KAAKD,KAAK,CAACI,aAAxC;;AAEA,QAAI,CAACF,4BAAD,IAAiC,CAACC,cAAtC,EAAsD;AACpD;AACD;;AAED,QAAIE,OAAO,GAAG,IAAd;;AAEA,YAAQL,KAAK,CAAC5D,GAAd;AACE,WAAK,WAAL;AACEhC,QAAAA,qBAAqB,CAAC8F,4BAA4B,GAAG,CAAH,GAAO,CAApC,CAArB;AACA;;AAEF,WAAK,SAAL;AACE;AACA9F,QAAAA,qBAAqB,CAAC8F,4BAA4B,GAAG,CAAH,GAAO,CAAC,CAArC,CAArB;AACA;;AAEF,WAAK,KAAL;AACE9F,QAAAA,qBAAqB,CAACkG,QAAD,CAArB;AACA;;AAEF,WAAK,OAAL;AACE;AACA;AACA,YAAI,CAACJ,4BAAL,EAAmC;AAAA;;AACjC,cAAMK,IAAiB,6BAAGpH,qBAAqB,CAACgC,OAAtB,CACvBwC,GADuB,CACnB9C,qBAAqB,CAACM,OADH,CAAH,2DAAG,uBAEtByC,aAFsB,CAER,2CAFQ,CAA1B;AAIA,+DAAiB2C,IAAjB,EAAuB,CAAvB,2EAA2BrG,KAA3B;AACD;;AAED;;AAEF,WAAK,QAAL;AACEA,QAAAA,KAAK,CAAC,wBAAD,CAAL;AACA;;AAEF,WAAK,MAAL;AACEE,QAAAA,qBAAqB,CAAC,CAACkG,QAAF,CAArB;AACA;;AAEF;AACED,QAAAA,OAAO,GAAG,KAAV;AACA;AArCJ;;AAwCA,QAAIA,OAAJ,EAAa;AACXL,MAAAA,KAAK,CAACQ,cAAN,GADW,CAGX;;AACAR,MAAAA,KAAK,CAACS,eAAN;AACD;AACF,GA3D6B,EA4D9B,CAACtH,qBAAD,EAAwBe,KAAxB,EAA+BW,qBAA/B,EAAsDT,qBAAtD,EAA6EQ,aAA7E,CA5D8B,CAAhC;AA+DA,MAAM8F,8BAA8B,GAAG,wBACrC,UAAAV,KAAK,EAAI;AACP,QAAQW,MAAR,GAAkDX,KAAlD,CAAQW,MAAR;AAAA,QAAgBC,OAAhB,GAAkDZ,KAAlD,CAAgBY,OAAhB;AAAA,QAAyBxE,GAAzB,GAAkD4D,KAAlD,CAAyB5D,GAAzB;AAAA,QAA8ByE,OAA9B,GAAkDb,KAAlD,CAA8Ba,OAA9B;AAAA,QAAuCZ,MAAvC,GAAkDD,KAAlD,CAAuCC,MAAvC;;AAEA,QAAIU,MAAM,IAAKC,OAAO,IAAIxE,GAAG,KAAK,GAA9B,IAAsCyE,OAAtC,IAAkD,CAAC,4BAAczE,GAAd,CAAD,IAAuBA,GAAG,KAAK,WAArF,EAAmG;AACjG;AACA;AACA;AACA;AACD,KARM,CAUP;;;AACA,QAAI6D,MAAM,KAAKD,KAAK,CAACI,aAAjB,IAAkCH,MAAM,KAAKrF,aAAa,CAACO,OAA/D,EAAwE;AACtE6E,MAAAA,KAAK,CAACS,eAAN;AAEAvG,MAAAA,KAAK,CAAC,SAAD,CAAL;AACD;AACF,GAjBoC,EAkBrC,CAACA,KAAD,CAlBqC,CAAvC;AAqBA,2CAA2B,wBAAY;AAAA,WAAMC,kBAAkB,CAACqC,SAAD,CAAxB;AAAA,GAAZ,EAAiD,CAACrC,kBAAD,CAAjD,CAA3B,EAzW6C,CA2W7C;;AACA,MAAM2G,oCAAoC,GAAG,uDAA7C,CA5W6C,CA8W7C;AACA;;AACA,sBACE;AAAA,WAAMA,oCAAoC,CAAC/G,iBAAiB,GAAGD,kBAAH,GAAwB0C,SAA1C,CAA1C;AAAA,GADF,EAEE,CAACsE,oCAAD,EAAuChH,kBAAvC,EAA2DC,iBAA3D,CAFF,EAhX6C,CAqX7C;;AACA,MAAMgH,WAAW,GAAG,yBAClB;AACA;AACA;AAAA,QAAGX,aAAH,SAAGA,aAAH;AAAA,QAAkBH,MAAlB,SAAkBA,MAAlB;AAAA,WAA+BA,MAAM,KAAKG,aAAX,IAA4BjG,kBAAkB,CAAC,IAAD,EAAO,KAAP,CAA7E;AAAA,GAHkB,EAIlB,CAACA,kBAAD,CAJkB,CAApB,CAtX6C,CA6X7C;AACA;AACA;AACA;;AACA,MAAM6G,iBAAiB,GAAG,wBAAY;AAAA,WAAM7G,kBAAkB,CAACqC,SAAD,CAAxB;AAAA,GAAZ,EAAiD,CAACrC,kBAAD,CAAjD,CAA1B,CAjY6C,CAmY7C;;AACA,uCACEO,cADF,EAEE,wBAAY;AAAA,WAAMP,kBAAkB,CAACqC,SAAD,CAAxB;AAAA,GAAZ,EAAiD,CAACrC,kBAAD,CAAjD,CAFF;AAKA,sBACE;AACE;AACA;AACA,6BAAuB8G,yBAAUzE,SAAV,GAAsB7C,kBAH/C;AAIE,kBAAYqB,mBAJd;AAKE,IAAA,SAAS,EAAE,yBACT,2BADS,EAET3B,uBAAuB,GAAG,EAFjB,EAGToB,aAHS,EAIT,CAACrB,SAAS,IAAI,EAAd,IAAoB,EAJX,CALb;AAWE,IAAA,GAAG,EAAES,SAXP;AAYE,IAAA,OAAO,EAAEkH,WAZX;AAaE,IAAA,SAAS,EAAEhB,uBAbb;AAcE,IAAA,gBAAgB,EAAEW,8BAdpB;AAeE,IAAA,GAAG,EAAEzF,WAfP,CAgBE;AACA;AAjBF;AAkBE,IAAA,IAAI,EAAC,OAlBP,CAmBE;AACA;AACA;AArBF;AAsBE,IAAA,QAAQ,EAAE;AAtBZ,kBAwBE,6BAAC,6BAAD;AAAsB,IAAA,qBAAqB,EAAE9B;AAA7C,IAxBF,eA2BE,6BAAC,4BAAD;AAA8B,IAAA,aAAa,EAAE6H,iBAA7C;AAAgE,IAAA,aAAa,EAAEpG;AAA/E,KACGQ,iBAAiB,CAAC8F,GAAlB,CACC;AAAA,QACExF,QADF,UACEA,QADF;AAAA,QAEET,WAFF,UAEEA,WAFF;AAAA,QAGEgC,aAHF,UAGEA,aAHF;AAAA,QAIEb,GAJF,UAIEA,GAJF;AAAA,QAKEF,cALF,UAKEA,cALF;AAAA,QAMEI,oBANF,UAMEA,oBANF;AAAA,QAOEX,YAPF,UAOEA,YAPF;AAAA,QAQEiB,WARF,UAQEA,WARF;AAAA,wBAUE,6BAAC,oBAAD;AAAa,MAAA,QAAQ,EAAElB,QAAvB;AAAiC,MAAA,GAAG,EAAEU,GAAtC;AAA2C,MAAA,GAAG,EAAEnB;AAAhD,OACGiB,cAAc,CAAC;AACde,MAAAA,aAAa,EAAbA,aADc;AAEdX,MAAAA,oBAAoB,EAApBA,oBAFc;AAGdX,MAAAA,YAAY,EAAZA,YAHc;AAIdiB,MAAAA,WAAW,EAAXA;AAJc,KAAD,CADjB,CAVF;AAAA,GADD,CADH,CA3BF,EAkDG,CAAC,CAACxB,iBAAiB,CAACY,MAApB,iBACC,6BAAC,eAAD,qBACE,6BAAC,wBAAD;AAAiB,IAAA,WAAW,EAAEtB;AAA9B,IADF,eAEE;AACE,mBAAa,IADf;AAEE,uBAAiBC,iBAFnB;AAGE,IAAA,SAAS,EAAC,uCAHZ;AAIE,IAAA,GAAG,EAAEC,aAJP;AAKE,IAAA,IAAI,EAAC,MALP;AAME,IAAA,QAAQ,EAAE;AANZ,kBAQE;AAAK,IAAA,SAAS,EAAC;AAAf,kBAGE;AAAK,IAAA,SAAS,EAAC,4CAAf;AAA4D,IAAA,EAAE,EAAED;AAAhE,KACGI,cADH,CAHF,CARF,CAFF,CAnDJ,eAuEE;AAAK,IAAA,SAAS,EAAC;AAAf,IAvEF,CADF;AA2ED,CArdwB,CAA3B;AAwdA9B,kBAAkB,CAACkI,YAAnB,GAAkC;AAChC/H,EAAAA,SAAS,EAAE;AADqB,CAAlC;AAIAH,kBAAkB,CAACmI,SAAnB,GAA+B;AAC7B;AACA;AACAjI,EAAAA,qBAAqB,EAAEkI,mBAAUC,KAAV,CAAgB;AACrCnG,IAAAA,OAAO,EAAEkG,mBAAUE,UAAV,CAAqBC,GAArB;AAD4B,GAAhB,EAEpBC,UAL0B;AAM7BrI,EAAAA,SAAS,EAAEiI,mBAAUK;AANQ,CAA/B;;AAeA;AACA,IAAMC,4BAAmE,GAAG,SAAtEA,4BAAsE,SAItE;AAAA,MAHJC,QAGI,UAHJA,QAGI;AAAA,MAFJC,aAEI,UAFJA,aAEI;AAAA,MADJjH,aACI,UADJA,aACI;;AACJ,sBAA6C,4BAA7C;AAAA;AAAA,MAAqBkH,kBAArB,oBAASC,UAAT;;AACA,2BAAoC,6CAApC;AAAA;AAAA,MAAOC,cAAP;;AACA,kBAA2B,oCAA3B;AAAA;AAAA,MAAOC,KAAP;;AACA,8BAA+BtK,qBAAqB,EAApD;AAAA;AAAA,MAASuK,kBAAT;;AACA,mBAA4B,qCAA5B;AAAA;AAAA,MAAOC,MAAP;;AACA,0BAAuB5J,eAAe,EAAtC;AAAA;AAAA,MAAO6J,YAAP;;AACA,MAAMjI,kBAAkB,GAAG,qCAA3B;AACA,MAAMK,QAAQ,GAAGpC,YAAY,EAA7B;AACA,MAAM8G,qBAAqB,GAAG7G,wBAAwB,EAAtD;AACA,MAAMgK,qBAAqB,GAAG/J,wBAAwB,EAAtD;AACA,MAAMmG,WAAgD,GAAG,0CAAzD;AAEA,MAAM6D,UAAU,GAAG,0BAAYH,MAAZ,CAAnB;AACA,MAAMI,yBAAyB,GAAG/H,QAAQ,CAAC,0BAAD,CAA1C;AAEA,MAAMgI,mBAAmB,GAAGF,UAAU,KAAKH,MAAf,IAAyBA,MAArD,CAhBI,CAkBJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;;AAEA,sBACE;AAAA,WACEK,mBAAmB,IACnB;AACA;AACA;AACAH,IAAAA,qBAAqB,EALvB;AAAA,GADF,EAOE,CAACA,qBAAD,EAAwBG,mBAAxB,CAPF;;AAUA,+BAA4C,0CAA4B;AAAEC,IAAAA,IAAI,EAAE;AAAR,GAA5B,CAA5C;AAAA;AAAA,MAAOC,iCAAP;;AACA,MAAMpI,gBAAgB,GAAGrC,mBAAmB,EAA5C;AAEA,MAAM0K,qBAA+B,GAAG,oBACtC;AAAA,WAAMD,iCAAiC,CAACxB,GAAlC,CAAsC;AAAA,UAAGxF,QAAH,UAAGA,QAAH;AAAA,aAAkBpB,gBAAgB,CAACoB,QAAD,CAAlC;AAAA,KAAtC,CAAN;AAAA,GADsC,EAEtC,CAACgH,iCAAD,EAAoCpI,gBAApC,CAFsC,CAAxC;AAKA,MAAMsI,wBAAwB,GAAG,0BAAYD,qBAAZ,CAAjC,CA3DI,CA6DJ;AACA;;AACA,MAAME,sBAAsB,GAAG,oBAAQ,YAAM;AAC3C;AACA;AACA;AACA,QAAIV,MAAM,IAAID,kBAAkB,CAAClG,MAAjC,EAAyC;AACvCkD,MAAAA,qBAAqB,CAACgD,kBAAkB,CAACA,kBAAkB,CAAClG,MAAnB,GAA4B,CAA7B,CAAnB,CAArB;AAEA,aAAO,EAAP;AACD;;AAED,WAAOkG,kBAAP;AACD,GAX8B,EAW5B,CAAChD,qBAAD,EAAwBiD,MAAxB,EAAgCD,kBAAhC,CAX4B,CAA/B;AAaA,MAAMY,yBAAyB,GAAG,0BAAYD,sBAAZ,CAAlC,CA5EI,CA8EJ;AACA;AACA;;AACA,MAAME,MAAM,GAAG,oBACb;AAAA,WAAMF,sBAAsB,CAACG,IAAvB,CAA4B,UAAA5G,GAAG;AAAA,aAAIuG,qBAAqB,CAACM,QAAtB,CAA+B7G,GAA/B,CAAJ;AAAA,KAA/B,CAAN;AAAA,GADa,EAEb,CAACuG,qBAAD,EAAwBE,sBAAxB,CAFa,CAAf;AAKA,MAAMK,4BAA4B,GAAG,wBAAY,YAAM;AACrDzE,IAAAA,WAAW,CAAC;AAAEpB,MAAAA,QAAQ,EAAE;AAAZ,KAAD,CAAX;AAEA,QAAiBsF,qBAAjB,GAA2CC,wBAA3C,CAAQzH,OAAR,CAHqD,CAKrD;;AACA,QAAMgI,+BAA+B,GAAGL,yBAAyB,CAAC3H,OAA1B,CAAkCyE,IAAlC,CAAuC,UAAAxD,GAAG;AAAA,aAChFuG,qBAAqB,CAACM,QAAtB,CAA+B7G,GAA/B,CADgF;AAAA,KAA1C,CAAxC;;AAIA,QAAI+G,+BAAJ,EAAqC;AACnChJ,MAAAA,kBAAkB,CAACgJ,+BAAD,CAAlB;AACD,KAFD,MAEO;AAAA;;AACL;AACA,+BAAAvI,aAAa,CAACO,OAAd,gFAAuBjB,KAAvB;AACD;AACF,GAhBoC,EAgBlC,CAACC,kBAAD,EAAqB2I,yBAArB,EAAgDF,wBAAhD,EAA0EnE,WAA1E,EAAuF7D,aAAvF,CAhBkC,CAArC;AAkBA,MAAMwI,uBAAuB,GAAGtL,kCAAkC,GAAG;AACnEmK,IAAAA,KAAK,EAAED,cAAc,IAAIC,KAAlB,IAA2BE,MADiC;AAEnEC,IAAAA,YAAY,EAAZA,YAFmE;AAGnEW,IAAAA,MAAM,EAANA;AAHmE,GAAH,CAAlE;AAMA,sBACE,6BAAC,cAAD,CAAO,QAAP,QACGK,uBAAuB,IAAIA,uBAAuB,CAAC;AAAEC,IAAAA,OAAO,EAAEH;AAAX,GAAD,CADrD,EAEG,CAAC,CAACI,eAAMC,QAAN,CAAeC,KAAf,CAAqB5B,QAArB,CAAF,iBAAoC,6BAAC,wBAAD;AAAiB,IAAA,WAAW,EAAEhH;AAA9B,IAFvC,eAGE,6BAAC,0BAAD;AAA0B,IAAA,SAAS,EAAC;AAApC,kBACE;AAAK,mBAAa,IAAlB;AAAwB,IAAA,SAAS,EAAC,mCAAlC;AAAsE,IAAA,OAAO,EAAEiH;AAA/E,IADF,eAEE;AACE,4BAAsBU,yBADxB;AAEE,IAAA,SAAS,EAAE,yBAAWT,kBAAkB,GAAG,EAAhC,EAAoC,uCAApC,CAFb;AAGE,IAAA,IAAI,EAAC;AAHP,KAKGF,QALH,CAFF,eASE,6BAAC,6BAAD,OATF,CAHF,CADF;AAiBD,CAnID;;AAqIAD,4BAA4B,CAACP,SAA7B,GAAyC;AACvCQ,EAAAA,QAAQ,EAAEP,mBAAUoC,GAAV,CAAchC,UADe;AAEvCI,EAAAA,aAAa,EAAER,mBAAUqC,IAAV,CAAejC,UAFS;AAGvC7G,EAAAA,aAAa,EAAEyG,mBAAUoC,GAAV,CAAchC;AAHU,CAAzC;;AAQA;AACA,IAAMkC,WAAW,GAAG,SAAdA,WAAc,CAACxK,qBAAD,EAA2E;AAC7F,yBAAuB1B,eAAe,EAAtC;AAAA;AAAA,MAAOmM,YAAP;;AACA,8BAAsCzL,8BAA8B,EAApE;AAAA;AAAA,MAAO0L,2BAAP;;AACA,0BAAuBtL,eAAe,EAAtC;AAAA;AAAA,MAAO6J,YAAP;;AAEA,MAAM0B,eAAe,GAAG,0BAAYF,YAAZ,CAAxB;AACA,MAAMG,8BAA8B,GAAG,0BAAYF,2BAAZ,CAAvC;AACA,MAAMG,eAAe,GAAG,0BAAY5B,YAAZ,CAAxB;AAEA,SAAO,wBACL,kBAAiC;AAAA,QAA9BrD,YAA8B,UAA9BA,YAA8B;AAAA,QAAhBtB,SAAgB,UAAhBA,SAAgB;AAC/B,gCAOIuG,eAPJ,CACE7I,OADF;AAAA,QAEI8I,wBAFJ,yBAEIA,wBAFJ;AAAA,QAGIC,8BAHJ,yBAGIA,8BAHJ;AAAA,QAIIC,oBAJJ,yBAIIA,oBAJJ;AAAA,QAKIC,0BALJ,yBAKIA,0BALJ;AASA,QAAMC,+BAA+B,GACnC,OAAOJ,wBAAP,KAAoC,QAApC,GACI1F,IAAI,CAACS,GAAL,CAAS,CAAT,EAAYiF,wBAAZ,CADJ,GAEIA,wBAAwB,GACxB,CADwB,GAExB,CALN;AAMA,QAAMK,2BAA2B,GAC/B,OAAOH,oBAAP,KAAgC,QAAhC,GACI5F,IAAI,CAACS,GAAL,CAAS,CAAT,EAAYT,IAAI,CAACC,GAAL,CAAS,CAAT,EAAY2F,oBAAZ,CAAZ,CADJ,GAEIA,oBAAoB,GACpB,CADoB,GAEpB,CALN;AAMA,QAAMI,qCAAqC,GACzC,OAAOL,8BAAP,KAA0C,QAA1C,GAAqDA,8BAArD,GAAsF,CADxF;AAEA,QAAMM,iCAAiC,GACrC,OAAOJ,0BAAP,KAAsC,QAAtC,GAAiDA,0BAAjD,GAA8E,CADhF;;AAGA,QAAIC,+BAA+B,IAAIC,2BAAvC,EAAoE;AAClE,UAAiBG,kBAAjB,GAAwCtL,qBAAxC,CAAQgC,OAAR;AACA,UAAiByI,aAAjB,GAAkCE,eAAlC,CAAQ3I,OAAR;AACA,UAAiB0I,4BAAjB,GAAiDE,8BAAjD,CAAQ5I,OAAR;AACA,UAAMuJ,MAAgB,GAAG,EAAzB;;AAEA,UAAMC,gCAAgC,GAAGf,aAAY,CAACgB,OAAb,CAAqBf,4BAArB,CAAzC;;AAEA,UAAI,CAACc,gCAAL,EAAuC;AACrC;AACA;AACA,YAAMhC,qBAAqB,GAAGnD,KAAK,CAAC9C,IAAN,CAAW+H,kBAAkB,CAACI,IAAnB,EAAX,CAA9B;AACA,YAAIC,uCAAuC,GAAG,CAAC,CAA/C;;AAJqC,mDAMClB,aAAY,CAACmB,KAAb,CAAmB,CAAnB,EAAsBJ,gCAAgC,GAAG,CAAzD,EAA4DhF,OAA5D,EAND;AAAA;;AAAA;AAMrC,8DAA6G;AAAA,gBAAlGqF,uBAAkG;AAC3G,gBAAMC,KAAK,GAAGtC,qBAAqB,CAACiC,OAAtB,CAA8BI,uBAA9B,CAAd;;AAEA,gBAAI,CAACC,KAAL,EAAY;AACV,kBAAIA,KAAK,KAAKtC,qBAAqB,CAAC3G,MAAtB,GAA+B,CAA7C,EAAgD;AAC9C8I,gBAAAA,uCAAuC,GAAGG,KAAK,GAAG,CAAlD;AACD;;AAED;AACD;AACF;AAhBoC;AAAA;AAAA;AAAA;AAAA;;AAkBrC,YAAI,CAACH,uCAAL,EAA8C;AAC5C,cAAMvF,gBAAgB,GAAGC,KAAK,CAAC9C,IAAN,CAAW+H,kBAAkB,CAACC,MAAnB,EAAX,CAAzB;;AAEA,cAAIL,+BAAJ,EAAqC;AACnC;AACA,gBAAMa,gCAAgC,GACpC3F,gBAAgB,CAACuF,uCAAuC,GAAGT,+BAA1C,GAA4E,CAA7E,CADlB;;AAGA,gBAAIa,gCAAJ,EAAsC;AACpC,kBAAMC,2CAA2C,GAAGD,gCAAH,aAAGA,gCAAH,uBAAGA,gCAAgC,CAAEtH,aAAlC,CAClD,wDADkD,CAApD;AAGA,kBAAMwH,kCAAkC,GACtCF,gCAAgC,CAACG,SAAjC,GAA6CF,2CAA2C,CAACE,SAD3F;AAGAX,cAAAA,MAAM,CAAC7H,IAAP,CACEuI,kCAAkC,GAChCD,2CAA2C,CAACpG,YAD9C,GAEEA,YAFF,GAGEtB,SAHF,GAIE8G,qCALJ;AAOD;AACF;;AAED,cAAID,2BAAJ,EAAiC;AAC/B,gBAAMgB,kCAAkC,GAAG/F,gBAAgB,CAAC,CAACuF,uCAAF,CAA3D;AACA,gBAAMS,6CAA6C,GAAGD,kCAAkC,CAAC1H,aAAnC,CACpD,wDADoD,CAAtD;AAGA,gBAAM4H,oCAAoC,GACxCF,kCAAkC,CAACD,SAAnC,GAA+CE,6CAA6C,CAACF,SAD/F;AAGAX,YAAAA,MAAM,CAAC7H,IAAP,CACE2I,oCAAoC,GAClC/H,SADF,GAEEsB,YAAY,IAAI,IAAIuF,2BAAR,CAFd,GAGEE,iCAJJ;AAMD;AACF;AACF;;AAED,aAAOjG,IAAI,CAACC,GAAL,OAAAD,IAAI,EAAQmG,MAAR,CAAX;AACD;;AAED,WAAOpE,QAAP;AACD,GArGI,EAsGL,CAACnH,qBAAD,EAAwB2K,eAAxB,EAAyCC,8BAAzC,EAAyEC,eAAzE,CAtGK,CAAP;AAwGD,CAjHD;;AAuHA,IAAMyB,eAA0C,GAAG,SAA7CA,eAA6C,SAAmB;AAAA,MAAhBrM,SAAgB,UAAhBA,SAAgB;AACpE,MAAMD,qBAAqB,GAAG,mBAA2B,IAAIqI,GAAJ,EAA3B,CAA9B;AACA,MAAMkE,YAAY,GAAG,oBAArB;AAEA,MAAMC,QAAQ,GAAGhC,WAAW,CAACxK,qBAAD,CAA5B;AAEA,sBACE,6BAAC,gCAAD;AAAyB,IAAA,YAAY,EAAEuM;AAAvC,kBACE,6BAAC,6BAAD;AAA6B,IAAA,QAAQ,EAAEC;AAAvC,kBACE,6BAAC,qBAAD,OADF,eAEE,6BAAC,kBAAD;AAAoB,IAAA,qBAAqB,EAAExM,qBAA3C;AAAkE,IAAA,SAAS,EAAEC,SAA7E;AAAwF,IAAA,GAAG,EAAEsM;AAA7F,IAFF,CADF,CADF;AAQD,CAdD;;AAgBAD,eAAe,CAACtE,YAAhB,GAA+B;AAC7B/H,EAAAA,SAAS,EAAE;AADkB,CAA/B;AAIAqM,eAAe,CAACrE,SAAhB,GAA4B;AAC1BhI,EAAAA,SAAS,EAAEiI,mBAAUK;AADK,CAA5B;eAIe+D,e","sourceRoot":"component:///","sourcesContent":["import { hooks } from 'botframework-webchat-api';\nimport {\n  Composer as ReactScrollToBottomComposer,\n  Panel as ReactScrollToBottomPanel,\n  useAnimatingToEnd,\n  useAtEnd,\n  useObserveScrollPosition,\n  useScrollTo,\n  useScrollToEnd,\n  useSticky\n} from 'react-scroll-to-bottom';\nimport classNames from 'classnames';\nimport PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useCallback, useMemo, useRef } from 'react';\n\nimport type { ActivityComponentFactory, AvatarComponentFactory } from 'botframework-webchat-api';\nimport type { ActivityElementMap } from './Transcript/types';\nimport type { DirectLineActivity } from 'botframework-webchat-core';\nimport type { FC, KeyboardEventHandler, MutableRefObject, ReactNode, VFC } from 'react';\n\nimport { android } from './Utils/detectBrowser';\nimport ActivityRow from './Transcript/ActivityRow';\nimport BasicTypingIndicator from './BasicTypingIndicator';\nimport FocusRedirector from './Utils/FocusRedirector';\nimport inputtableKey from './Utils/TypeFocusSink/inputtableKey';\nimport isZeroOrPositive from './Utils/isZeroOrPositive';\nimport KeyboardHelp from './Transcript/KeyboardHelp';\nimport LiveRegionTranscript from './Transcript/LiveRegionTranscript';\n// TODO: [P2] #4133 Rename to \"getTabbableElements\".\nimport tabbableElements from './Utils/tabbableElements';\nimport TranscriptFocusComposer from './providers/TranscriptFocus/TranscriptFocusComposer';\nimport useActiveDescendantId from './providers/TranscriptFocus/useActiveDescendantId';\nimport useActivityTreeWithRenderer from './providers/ActivityTree/useActivityTreeWithRenderer';\nimport useDispatchScrollPosition from './hooks/internal/useDispatchScrollPosition';\nimport useDispatchTranscriptFocusByActivityKey from './hooks/internal/useDispatchTranscriptFocusByActivityKey';\nimport useFocus from './hooks/useFocus';\nimport useFocusByActivityKey from './providers/TranscriptFocus/useFocusByActivityKey';\nimport useFocusedActivityKey from './providers/TranscriptFocus/useFocusedActivityKey';\nimport useFocusedExplicitly from './providers/TranscriptFocus/useFocusedExplicitly';\nimport useFocusRelativeActivity from './providers/TranscriptFocus/useFocusRelativeActivity';\nimport useObserveFocusVisible from './hooks/internal/useObserveFocusVisible';\nimport usePrevious from './hooks/internal/usePrevious';\nimport useRegisterFocusTranscript from './hooks/internal/useRegisterFocusTranscript';\nimport useRegisterScrollRelative from './hooks/internal/useRegisterScrollRelative';\nimport useRegisterScrollTo from './hooks/internal/useRegisterScrollTo';\nimport useRegisterScrollToEnd from './hooks/internal/useRegisterScrollToEnd';\nimport useStyleSet from './hooks/useStyleSet';\nimport useStyleToEmotionObject from './hooks/internal/useStyleToEmotionObject';\nimport useUniqueId from './hooks/internal/useUniqueId';\nimport useValueRef from './hooks/internal/useValueRef';\n\nconst {\n  useActivityKeys,\n  useActivityKeysByRead,\n  useCreateActivityStatusRenderer,\n  useCreateAvatarRenderer,\n  useCreateScrollToEndButtonRenderer,\n  useDirection,\n  useGetActivityByKey,\n  useGetKeyByActivity,\n  useGetKeyByActivityId,\n  useLastAcknowledgedActivityKey,\n  useLocalizer,\n  useMarkActivityKeyAsRead,\n  useMarkAllAsAcknowledged,\n  useStyleOptions\n} = hooks;\n\nconst ROOT_STYLE = {\n  '&.webchat__basic-transcript': {\n    display: 'flex',\n    flexDirection: 'column',\n    overflow: 'hidden',\n    // Make sure to set \"position: relative\" here to form another stacking context for the scroll-to-end button.\n    // Stacking context help isolating elements that use \"z-index\" from global pollution.\n    // https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Positioning/Understanding_z_index/The_stacking_context\n    position: 'relative',\n\n    '& .webchat__basic-transcript__filler': {\n      flex: 1\n    },\n\n    '& .webchat__basic-transcript__scrollable': {\n      display: 'flex',\n      flexDirection: 'column',\n      overflowX: 'hidden',\n      WebkitOverflowScrolling: 'touch'\n    },\n\n    '& .webchat__basic-transcript__transcript': {\n      listStyleType: 'none'\n    }\n  }\n};\n\ntype RenderingElement = {\n  activity: DirectLineActivity & {\n    channelData?: {\n      ['webchat:fallback-text']: string;\n    };\n  };\n  callbackRef: (element: HTMLElement) => void;\n  hideTimestamp: boolean;\n  key: string;\n  renderActivity: Exclude<ReturnType<ActivityComponentFactory>, false>;\n  renderActivityStatus: (props: { hideTimestamp?: boolean }) => ReactNode;\n  renderAvatar: AvatarComponentFactory;\n  showCallout: boolean;\n};\n\ntype ScrollBehavior = 'auto' | 'smooth';\ntype ScrollToOptions = { behavior?: ScrollBehavior };\ntype ScrollToPosition = { activityID?: string; scrollTop?: number };\n\ntype InternalTranscriptProps = {\n  activityElementMapRef: MutableRefObject<ActivityElementMap>;\n  className?: string;\n};\n\n// TODO: [P1] #4133 Add telemetry for computing how many re-render done so far.\nconst InternalTranscript = forwardRef<HTMLDivElement, InternalTranscriptProps>(\n  ({ activityElementMapRef, className }, ref) => {\n    const [{ basicTranscript: basicTranscriptStyleSet }] = useStyleSet();\n    const [{ bubbleFromUserNubOffset, bubbleNubOffset, groupTimestamp, showAvatarInGroup }] = useStyleOptions();\n    const [activeDescendantId] = useActiveDescendantId();\n    const [activityWithRendererTree] = useActivityTreeWithRenderer();\n    const [direction] = useDirection();\n    const [focusedActivityKey] = useFocusedActivityKey();\n    const [focusedExplicitly] = useFocusedExplicitly();\n    const createActivityStatusRenderer = useCreateActivityStatusRenderer();\n    const createAvatarRenderer = useCreateAvatarRenderer();\n    const focus = useFocus();\n    const focusByActivityKey = useFocusByActivityKey();\n    const focusRelativeActivity = useFocusRelativeActivity();\n    const getActivityByKey = useGetActivityByKey();\n    const getKeyByActivity = useGetKeyByActivity();\n    const getKeyByActivityId = useGetKeyByActivityId();\n    const localize = useLocalizer();\n    const rootClassName = useStyleToEmotionObject()(ROOT_STYLE) + '';\n    const rootElementRef = useRef<HTMLDivElement>();\n    const terminatorLabelId = useUniqueId('webchat__basic-transcript__terminator-label');\n    const terminatorRef = useRef<HTMLDivElement>();\n\n    const focusedActivityKeyRef = useValueRef(focusedActivityKey);\n    const hideAllTimestamps = groupTimestamp === false;\n    const terminatorText = localize('TRANSCRIPT_TERMINATOR_TEXT');\n    const transcriptAriaLabel = localize('TRANSCRIPT_ARIA_LABEL_ALT');\n\n    const callbackRef = useCallback(\n      (element: HTMLDivElement) => {\n        if (typeof ref === 'function') {\n          ref(element);\n        } else {\n          ref.current = element;\n        }\n\n        rootElementRef.current = element;\n      },\n      [ref, rootElementRef]\n    );\n\n    // Flatten the tree back into an array with information related to rendering.\n    const renderingElements = useMemo(() => {\n      const renderingElements: RenderingElement[] = [];\n      const topSideBotNub = isZeroOrPositive(bubbleNubOffset);\n      const topSideUserNub = isZeroOrPositive(bubbleFromUserNubOffset);\n\n      activityWithRendererTree.forEach(entriesWithSameSender => {\n        const [[{ activity: firstActivity }]] = entriesWithSameSender;\n        const renderAvatar = createAvatarRenderer({ activity: firstActivity });\n\n        entriesWithSameSender.forEach((entriesWithSameSenderAndStatus, indexWithinSenderGroup) => {\n          const firstInSenderGroup = !indexWithinSenderGroup;\n          const lastInSenderGroup = indexWithinSenderGroup === entriesWithSameSender.length - 1;\n\n          entriesWithSameSenderAndStatus.forEach(({ activity, renderActivity }, indexWithinSenderAndStatusGroup) => {\n            // We only show the timestamp at the end of the sender group. But we always show the \"Send failed, retry\" prompt.\n            const firstInSenderAndStatusGroup = !indexWithinSenderAndStatusGroup;\n            const key: string = getKeyByActivity(activity);\n            const lastInSenderAndStatusGroup =\n              indexWithinSenderAndStatusGroup === entriesWithSameSenderAndStatus.length - 1;\n            const renderActivityStatus = createActivityStatusRenderer({\n              activity,\n              nextVisibleActivity: undefined\n            });\n            const topSideNub = activity.from?.role === 'user' ? topSideUserNub : topSideBotNub;\n\n            let showCallout: boolean;\n\n            // Depending on the \"showAvatarInGroup\" setting, the avatar will render in different positions.\n            if (showAvatarInGroup === 'sender') {\n              if (topSideNub) {\n                showCallout = firstInSenderGroup && firstInSenderAndStatusGroup;\n              } else {\n                showCallout = lastInSenderGroup && lastInSenderAndStatusGroup;\n              }\n            } else if (showAvatarInGroup === 'status') {\n              if (topSideNub) {\n                showCallout = firstInSenderAndStatusGroup;\n              } else {\n                showCallout = lastInSenderAndStatusGroup;\n              }\n            } else {\n              showCallout = true;\n            }\n\n            renderingElements.push({\n              activity,\n\n              // After the element is mounted, set it to activityElementsRef.\n              callbackRef: activityElement => {\n                activityElement\n                  ? activityElementMapRef.current.set(key, activityElement)\n                  : activityElementMapRef.current.delete(key);\n              },\n\n              // \"hideTimestamp\" is a render-time parameter for renderActivityStatus().\n              // If true, it will hide the timestamp, but it will continue to show the\n              // retry prompt. And show the screen reader version of the timestamp.\n              hideTimestamp:\n                hideAllTimestamps || indexWithinSenderAndStatusGroup !== entriesWithSameSenderAndStatus.length - 1,\n              key,\n              renderActivity,\n              renderActivityStatus,\n              renderAvatar,\n              showCallout\n            });\n          });\n        });\n      });\n\n      return renderingElements;\n    }, [\n      activityElementMapRef,\n      activityWithRendererTree,\n      bubbleFromUserNubOffset,\n      bubbleNubOffset,\n      createActivityStatusRenderer,\n      createAvatarRenderer,\n      getKeyByActivity,\n      hideAllTimestamps,\n      showAvatarInGroup\n    ]);\n\n    const scrollToBottomScrollTo: (scrollTop: number, options?: ScrollToOptions) => void = useScrollTo();\n    const scrollToBottomScrollToEnd: (options?: ScrollToOptions) => void = useScrollToEnd();\n\n    const scrollTo = useCallback(\n      (position: ScrollToPosition, { behavior = 'auto' }: ScrollToOptions = {}) => {\n        if (!position) {\n          throw new Error(\n            'botframework-webchat: First argument passed to \"useScrollTo\" must be a ScrollPosition object.'\n          );\n        }\n\n        const { activityID: activityId, scrollTop } = position;\n\n        if (typeof scrollTop !== 'undefined') {\n          scrollToBottomScrollTo(scrollTop, { behavior });\n        } else if (typeof activityId !== 'undefined') {\n          const activityBoundingBoxElement = activityElementMapRef.current\n            .get(getKeyByActivityId(activityId))\n            ?.querySelector('.webchat__basic-transcript__activity-active-descendant');\n\n          const scrollableElement = rootElementRef.current.querySelector('.webchat__basic-transcript__scrollable');\n\n          if (scrollableElement && activityBoundingBoxElement) {\n            // ESLint conflict with TypeScript. The result of getClientRects() is not an Array but DOMRectList, and cannot be destructured.\n            // eslint-disable-next-line prefer-destructuring\n            const activityBoundingBoxElementClientRect = activityBoundingBoxElement.getClientRects()[0];\n\n            // ESLint conflict with TypeScript. The result of getClientRects() is not an Array but DOMRectList, and cannot be destructured.\n            // eslint-disable-next-line prefer-destructuring\n            const scrollableElementClientRect = scrollableElement.getClientRects()[0];\n\n            // If either the activity or the transcript scrollable is not on DOM, we will not scroll the view.\n            if (activityBoundingBoxElementClientRect && scrollableElementClientRect) {\n              const { height: activityHeight, y: activityY } = activityBoundingBoxElementClientRect;\n              const { height: scrollableHeight } = scrollableElementClientRect;\n              const activityOffsetTop = activityY + scrollableElement.scrollTop;\n\n              const scrollTop = Math.min(activityOffsetTop, activityOffsetTop - scrollableHeight + activityHeight);\n\n              scrollToBottomScrollTo(scrollTop, { behavior });\n            }\n          }\n        }\n      },\n      [activityElementMapRef, getKeyByActivityId, rootElementRef, scrollToBottomScrollTo]\n    );\n\n    const scrollToEnd = useCallback(\n      () => scrollToBottomScrollToEnd({ behavior: 'smooth' }),\n      [scrollToBottomScrollToEnd]\n    );\n\n    const scrollRelative = useCallback(\n      (direction: 'down' | 'up', { displacement }: { displacement?: number } = {}) => {\n        const { current: rootElement } = rootElementRef;\n\n        if (!rootElement) {\n          return;\n        }\n\n        const scrollable: HTMLElement = rootElement.querySelector('.webchat__basic-transcript__scrollable');\n        let nextScrollTop: number;\n\n        if (typeof displacement === 'number') {\n          // eslint-disable-next-line no-magic-numbers\n          nextScrollTop = scrollable.scrollTop + (direction === 'down' ? 1 : -1) * displacement;\n        } else {\n          // eslint-disable-next-line no-magic-numbers\n          nextScrollTop = scrollable.scrollTop + (direction === 'down' ? 1 : -1) * scrollable.offsetHeight;\n        }\n\n        scrollTo(\n          {\n            scrollTop: Math.max(0, Math.min(scrollable.scrollHeight - scrollable.offsetHeight, nextScrollTop))\n          },\n          { behavior: 'smooth' }\n        );\n      },\n      [rootElementRef, scrollTo]\n    );\n\n    // Since there could be multiple instances of <BasicTranscript> inside the <Composer>, when the developer calls `scrollXXX`, we need to call it on all instances.\n    // We call `useRegisterScrollXXX` to register a callback function, the `useScrollXXX` will multiplex the call into each instance of <BasicTranscript>.\n    useRegisterScrollTo(scrollTo);\n    useRegisterScrollToEnd(scrollToEnd);\n    useRegisterScrollRelative(scrollRelative);\n\n    const markActivityKeyAsRead = useMarkActivityKeyAsRead();\n\n    const dispatchScrollPositionWithActivityId: (scrollPosition: ScrollToPosition) => void =\n      useDispatchScrollPosition();\n\n    // TODO: [P2] We should use IntersectionObserver to track what activity is in the scrollable.\n    //            However, IntersectionObserver is not available on IE11, we need to make a limited polyfill in React style.\n    const handleScrollPosition = useCallback(\n      ({ scrollTop }: { scrollTop: number }) => {\n        const { current: rootElement } = rootElementRef;\n\n        if (!rootElement) {\n          return;\n        }\n\n        const scrollableElement = rootElement.querySelector('.webchat__basic-transcript__scrollable');\n\n        // \"getClientRects()\" is not returning an array, thus, it is not destructurable.\n        // eslint-disable-next-line prefer-destructuring\n        const scrollableElementClientRect = scrollableElement.getClientRects()[0];\n\n        // If the scrollable is not mounted, we cannot measure which activity is in view. Thus, we will not fire any events.\n        if (!scrollableElementClientRect) {\n          return;\n        }\n\n        const { bottom: scrollableClientBottom } = scrollableElementClientRect;\n\n        // Find the activity just above scroll view bottom.\n        // If the scroll view is already on top, get the first activity.\n        const activityElements = Array.from(activityElementMapRef.current.entries());\n        const activityKeyJustAboveScrollBottom: string | undefined = (\n          scrollableElement.scrollTop\n            ? activityElements\n                .reverse()\n                // Add subpixel tolerance\n                .find(([, element]) => {\n                  // \"getClientRects()\" is not returning an array, thus, it is not destructurable.\n                  // eslint-disable-next-line prefer-destructuring\n                  const elementClientRect = element.getClientRects()[0];\n\n                  // If the activity is not attached to DOM tree, we should not count it as \"bottommost visible activity\", as it is not visible.\n                  return elementClientRect && elementClientRect.bottom < scrollableClientBottom + 1;\n                })\n            : activityElements[0]\n        )?.[0];\n\n        // When the end-user slowly scrolling the view down, we will mark activity as read when the message fully appear on the screen.\n        activityKeyJustAboveScrollBottom && markActivityKeyAsRead(activityKeyJustAboveScrollBottom);\n\n        if (dispatchScrollPositionWithActivityId) {\n          const activity = getActivityByKey(activityKeyJustAboveScrollBottom);\n\n          dispatchScrollPositionWithActivityId({ ...(activity ? { activityID: activity.id } : {}), scrollTop });\n        }\n      },\n      [\n        activityElementMapRef,\n        dispatchScrollPositionWithActivityId,\n        getActivityByKey,\n        markActivityKeyAsRead,\n        rootElementRef\n      ]\n    );\n\n    useObserveScrollPosition(handleScrollPosition);\n\n    const handleTranscriptKeyDown = useCallback<KeyboardEventHandler<HTMLDivElement>>(\n      event => {\n        const { target } = event;\n\n        const fromEndOfTranscriptIndicator = target === terminatorRef.current;\n        const fromTranscript = target === event.currentTarget;\n\n        if (!fromEndOfTranscriptIndicator && !fromTranscript) {\n          return;\n        }\n\n        let handled = true;\n\n        switch (event.key) {\n          case 'ArrowDown':\n            focusRelativeActivity(fromEndOfTranscriptIndicator ? 0 : 1);\n            break;\n\n          case 'ArrowUp':\n            // eslint-disable-next-line no-magic-numbers\n            focusRelativeActivity(fromEndOfTranscriptIndicator ? 0 : -1);\n            break;\n\n          case 'End':\n            focusRelativeActivity(Infinity);\n            break;\n\n          case 'Enter':\n            // This is capturing plain ENTER.\n            // When screen reader is not running, or screen reader is running outside of scan mode, the ENTER key will be captured here.\n            if (!fromEndOfTranscriptIndicator) {\n              const body: HTMLElement = activityElementMapRef.current\n                .get(focusedActivityKeyRef.current)\n                ?.querySelector('.webchat__basic-transcript__activity-body');\n\n              tabbableElements(body)[0]?.focus();\n            }\n\n            break;\n\n          case 'Escape':\n            focus('sendBoxWithoutKeyboard');\n            break;\n\n          case 'Home':\n            focusRelativeActivity(-Infinity);\n            break;\n\n          default:\n            handled = false;\n            break;\n        }\n\n        if (handled) {\n          event.preventDefault();\n\n          // If a custom HTML control wants to handle up/down arrow, we will prevent them from listening to this event to prevent bugs due to handling arrow keys twice.\n          event.stopPropagation();\n        }\n      },\n      [activityElementMapRef, focus, focusedActivityKeyRef, focusRelativeActivity, terminatorRef]\n    );\n\n    const handleTranscriptKeyDownCapture = useCallback<KeyboardEventHandler<HTMLDivElement>>(\n      event => {\n        const { altKey, ctrlKey, key, metaKey, target } = event;\n\n        if (altKey || (ctrlKey && key !== 'v') || metaKey || (!inputtableKey(key) && key !== 'Backspace')) {\n          // Ignore if one of the utility key (except SHIFT) is pressed\n          // E.g. CTRL-C on a link in one of the message should not jump to chat box\n          // E.g. \"A\" or \"Backspace\" should jump to chat box\n          return;\n        }\n\n        // Send keystrokes to send box if we are focusing on the transcript or terminator.\n        if (target === event.currentTarget || target === terminatorRef.current) {\n          event.stopPropagation();\n\n          focus('sendBox');\n        }\n      },\n      [focus]\n    );\n\n    useRegisterFocusTranscript(useCallback(() => focusByActivityKey(undefined), [focusByActivityKey]));\n\n    // When the focusing activity has changed, dispatch an event to observers of \"useObserveTranscriptFocus\".\n    const dispatchTranscriptFocusByActivityKey = useDispatchTranscriptFocusByActivityKey();\n\n    // Dispatch a \"transcript focus\" event based on user selection.\n    // We should not dispatch \"transcript focus\" when a new activity come. Although the selection change, it is not initiated from the user.\n    useMemo(\n      () => dispatchTranscriptFocusByActivityKey(focusedExplicitly ? focusedActivityKey : undefined),\n      [dispatchTranscriptFocusByActivityKey, focusedActivityKey, focusedExplicitly]\n    );\n\n    // When the transcript is being focused on, we should dispatch a \"transcriptfocus\" event.\n    const handleFocus = useCallback(\n      // We call \"focusByActivityKey\" with activity key of \"true\".\n      // It means, tries to focus on anything.\n      ({ currentTarget, target }) => target === currentTarget && focusByActivityKey(true, false),\n      [focusByActivityKey]\n    );\n\n    // This is required by IE11.\n    // When the user clicks on and empty space (a.k.a. filler) in an empty transcript, IE11 says the focus is on the <div className=\"filler\">,\n    // despite the fact there are no \"tabIndex\" attributes set on the filler.\n    // We need to artificially send the focus back to the transcript.\n    const handleFocusFiller = useCallback(() => focusByActivityKey(undefined), [focusByActivityKey]);\n\n    // When focus into the transcript using TAB/SHIFT-TAB, scroll the focused activity into view.\n    useObserveFocusVisible(\n      rootElementRef,\n      useCallback(() => focusByActivityKey(undefined), [focusByActivityKey])\n    );\n\n    return (\n      <div\n        // Although Android TalkBack 12.1 does not support `aria-activedescendant`, when used, it become buggy and will narrate content twice.\n        // We are disabling `aria-activedescendant` for Android. See <ActivityRow> for details.\n        aria-activedescendant={android ? undefined : activeDescendantId}\n        aria-label={transcriptAriaLabel}\n        className={classNames(\n          'webchat__basic-transcript',\n          basicTranscriptStyleSet + '',\n          rootClassName,\n          (className || '') + ''\n        )}\n        dir={direction}\n        onFocus={handleFocus}\n        onKeyDown={handleTranscriptKeyDown}\n        onKeyDownCapture={handleTranscriptKeyDownCapture}\n        ref={callbackRef}\n        // \"aria-activedescendant\" will only works with a number of roles and it must be explicitly set.\n        // https://www.w3.org/TR/wai-aria/#aria-activedescendant\n        role=\"group\"\n        // For up/down arrow key navigation across activities, this component must be included in the tab sequence.\n        // Otherwise, \"aria-activedescendant\" will not be narrated when the user press up/down arrow keys.\n        // https://www.w3.org/TR/wai-aria-practices-1.1/#kbd_focus_activedescendant\n        tabIndex={0}\n      >\n        <LiveRegionTranscript activityElementMapRef={activityElementMapRef} />\n        {/* TODO: [P2] Fix ESLint error `no-use-before-define` */}\n        {/* eslint-disable-next-line @typescript-eslint/no-use-before-define */}\n        <InternalTranscriptScrollable onFocusFiller={handleFocusFiller} terminatorRef={terminatorRef}>\n          {renderingElements.map(\n            ({\n              activity,\n              callbackRef,\n              hideTimestamp,\n              key,\n              renderActivity,\n              renderActivityStatus,\n              renderAvatar,\n              showCallout\n            }) => (\n              <ActivityRow activity={activity} key={key} ref={callbackRef}>\n                {renderActivity({\n                  hideTimestamp,\n                  renderActivityStatus,\n                  renderAvatar,\n                  showCallout\n                })}\n              </ActivityRow>\n            )\n          )}\n        </InternalTranscriptScrollable>\n        {!!renderingElements.length && (\n          <Fragment>\n            <FocusRedirector redirectRef={rootElementRef} />\n            <div\n              aria-hidden={true}\n              aria-labelledby={terminatorLabelId}\n              className=\"webchat__basic-transcript__terminator\"\n              ref={terminatorRef}\n              role=\"note\"\n              tabIndex={0}\n            >\n              <div className=\"webchat__basic-transcript__terminator-body\">\n                {/* `id` is required for `aria-labelledby` */}\n                {/* eslint-disable-next-line react/forbid-dom-props */}\n                <div className=\"webchat__basic-transcript__terminator-text\" id={terminatorLabelId}>\n                  {terminatorText}\n                </div>\n              </div>\n            </div>\n          </Fragment>\n        )}\n        <div className=\"webchat__basic-transcript__focus-indicator\" />\n      </div>\n    );\n  }\n);\n\nInternalTranscript.defaultProps = {\n  className: ''\n};\n\nInternalTranscript.propTypes = {\n  // PropTypes cannot validate precisely with its TypeScript counterpart.\n  // @ts-ignore\n  activityElementMapRef: PropTypes.shape({\n    current: PropTypes.instanceOf(Map)\n  }).isRequired,\n  className: PropTypes.string\n};\n\ntype InternalTranscriptScrollableProps = {\n  children?: ReactNode;\n  onFocusFiller: () => void;\n  terminatorRef: MutableRefObject<HTMLDivElement>;\n};\n\n// Separating high-frequency hooks to improve performance.\nconst InternalTranscriptScrollable: FC<InternalTranscriptScrollableProps> = ({\n  children,\n  onFocusFiller,\n  terminatorRef\n}) => {\n  const [{ activities: activitiesStyleSet }] = useStyleSet();\n  const [animatingToEnd]: [boolean] = useAnimatingToEnd();\n  const [atEnd]: [boolean] = useAtEnd();\n  const [, unreadActivityKeys] = useActivityKeysByRead();\n  const [sticky]: [boolean] = useSticky();\n  const [styleOptions] = useStyleOptions();\n  const focusByActivityKey = useFocusByActivityKey();\n  const localize = useLocalizer();\n  const markActivityKeyAsRead = useMarkActivityKeyAsRead();\n  const markAllAsAcknowledged = useMarkAllAsAcknowledged();\n  const scrollToEnd: (options?: ScrollToOptions) => void = useScrollToEnd();\n\n  const prevSticky = usePrevious(sticky);\n  const transcriptRoleDescription = localize('TRANSCRIPT_ARIA_ROLE_ALT');\n\n  const stickyChangedToTrue = prevSticky !== sticky && sticky;\n\n  // Acknowledged means either:\n  // 1. The user sent a message\n  //    - We don't need a condition here. When Web Chat sends the user's message, it will scroll to bottom, and it will trigger condition 2 below.\n  // 2. The user scroll to the bottom of the transcript, from a non-bottom scroll position\n  //    - If the transcript is already at the bottom, the user needs to scroll up and then go back down\n  //    - What happens if we are relaxing \"scrolled from a non-bottom scroll position\":\n  //      1. The condition will become solely \"at the bottom of the transcript\"\n  //      2. Auto-scroll will always scroll the transcript to the bottom\n  //      3. Web Chat will always acknowledge all activities as it is at the bottom\n  //      4. Acknowledge flag become useless\n  //      5. Therefore, even the developer set \"pause after 3 activities\", if activities are coming in at a slow pace (not batched in a single render)\n  //         Web Chat will keep scrolling and not snapped/paused\n\n  // Note: When Web Chat is loaded, there are no activities acknowledged. We need to assume all arriving activities are acknowledged until end-user sends their first activity.\n  //       Activities loaded initially could be from conversation history. Without assuming acknowledgement, Web Chat will not scroll initially (as everything is not acknowledged).\n  //       It would be better if the chat adapter should let Web Chat know if the activity is loaded from history or not.\n\n  // TODO: [P2] #3670 Move the \"conversation history acknowledgement\" logic mentioned above to polyfill of chat adapters.\n  //       1. Chat adapter should send \"acknowledged\" as part of \"channelData\"\n  //       2. If \"acknowledged\" is \"undefined\", we set it to:\n  //          a. true, if there are no egress activities yet\n  //          b. Otherwise, false\n\n  useMemo(\n    () =>\n      stickyChangedToTrue &&\n      // TODO: [P2] Both `markActivityKeyAsRead` and `markAllAsAcknowledged` hook are setters of useState.\n      //       This means, in a render loop, we will be calling setter and will cause another re-render.\n      //       This is not trivial but we should think if there is a way to avoid this.\n      markAllAsAcknowledged(),\n    [markAllAsAcknowledged, stickyChangedToTrue]\n  );\n\n  const [flattenedActivityTreeWithRenderer] = useActivityTreeWithRenderer({ flat: true });\n  const getKeyByActivity = useGetKeyByActivity();\n\n  const renderingActivityKeys: string[] = useMemo<string[]>(\n    () => flattenedActivityTreeWithRenderer.map(({ activity }) => getKeyByActivity(activity)),\n    [flattenedActivityTreeWithRenderer, getKeyByActivity]\n  );\n\n  const renderingActivityKeysRef = useValueRef(renderingActivityKeys);\n\n  // To prevent flashy button, we are not waiting for another render loop to update the `[readActivityKeys, unreadActivityKeys]` state.\n  // Instead, we are building the next one in this `useMemo` call.\n  const nextUnreadActivityKeys = useMemo(() => {\n    // This code need to be careful reviewed as it will cause another render. The code should be converging.\n    // After we call `markActivityKeyAsRead`, everything will be read and nothing will be unread.\n    // That means, in next render, `unreadActivityKeys` will be emptied and the `markActivityKeyAsRead` will not get called again.\n    if (sticky && unreadActivityKeys.length) {\n      markActivityKeyAsRead(unreadActivityKeys[unreadActivityKeys.length - 1]);\n\n      return [];\n    }\n\n    return unreadActivityKeys;\n  }, [markActivityKeyAsRead, sticky, unreadActivityKeys]);\n\n  const nextUnreadActivityKeysRef = useValueRef(nextUnreadActivityKeys);\n\n  // If we are rendering anything that is unread, we should show the \"New messages\" button.\n  // Not everything in the `unreadActivityKeys` are rendered, say, bot typing indicator.\n  // We should not show the \"New messages\" button for bot typing indicator as it will confuse the user.\n  const unread = useMemo(\n    () => nextUnreadActivityKeys.some(key => renderingActivityKeys.includes(key)),\n    [renderingActivityKeys, nextUnreadActivityKeys]\n  );\n\n  const handleScrollToEndButtonClick = useCallback(() => {\n    scrollToEnd({ behavior: 'smooth' });\n\n    const { current: renderingActivityKeys } = renderingActivityKeysRef;\n\n    // After the \"New message\" button is clicked, focus on the first unread activity which will be rendered.\n    const firstUnreadRenderingActivityKey = nextUnreadActivityKeysRef.current.find(key =>\n      renderingActivityKeys.includes(key)\n    );\n\n    if (firstUnreadRenderingActivityKey) {\n      focusByActivityKey(firstUnreadRenderingActivityKey);\n    } else {\n      // If no unread activity, send the focus to the terminator block.\n      terminatorRef.current?.focus();\n    }\n  }, [focusByActivityKey, nextUnreadActivityKeysRef, renderingActivityKeysRef, scrollToEnd, terminatorRef]);\n\n  const renderScrollToEndButton = useCreateScrollToEndButtonRenderer()({\n    atEnd: animatingToEnd || atEnd || sticky,\n    styleOptions,\n    unread\n  });\n\n  return (\n    <React.Fragment>\n      {renderScrollToEndButton && renderScrollToEndButton({ onClick: handleScrollToEndButtonClick })}\n      {!!React.Children.count(children) && <FocusRedirector redirectRef={terminatorRef} />}\n      <ReactScrollToBottomPanel className=\"webchat__basic-transcript__scrollable\">\n        <div aria-hidden={true} className=\"webchat__basic-transcript__filler\" onFocus={onFocusFiller} />\n        <section\n          aria-roledescription={transcriptRoleDescription}\n          className={classNames(activitiesStyleSet + '', 'webchat__basic-transcript__transcript')}\n          role=\"feed\"\n        >\n          {children}\n        </section>\n        <BasicTypingIndicator />\n      </ReactScrollToBottomPanel>\n    </React.Fragment>\n  );\n};\n\nInternalTranscriptScrollable.propTypes = {\n  children: PropTypes.any.isRequired,\n  onFocusFiller: PropTypes.func.isRequired,\n  terminatorRef: PropTypes.any.isRequired\n};\n\ntype Scroller = ({ offsetHeight, scrollTop }: { offsetHeight: number; scrollTop: number }) => number;\n\n// \"scroller\" is the auto-scroll limiter, a.k.a. auto scroll snap.\nconst useScroller = (activityElementMapRef: MutableRefObject<ActivityElementMap>): Scroller => {\n  const [activityKeys] = useActivityKeys();\n  const [lastAcknowledgedActivityKey] = useLastAcknowledgedActivityKey();\n  const [styleOptions] = useStyleOptions();\n\n  const activityKeysRef = useValueRef(activityKeys);\n  const lastAcknowledgedActivityKeyRef = useValueRef(lastAcknowledgedActivityKey);\n  const styleOptionsRef = useValueRef(styleOptions);\n\n  return useCallback(\n    ({ offsetHeight, scrollTop }) => {\n      const {\n        current: {\n          autoScrollSnapOnActivity,\n          autoScrollSnapOnActivityOffset,\n          autoScrollSnapOnPage,\n          autoScrollSnapOnPageOffset\n        }\n      } = styleOptionsRef;\n\n      const patchedAutoScrollSnapOnActivity =\n        typeof autoScrollSnapOnActivity === 'number'\n          ? Math.max(0, autoScrollSnapOnActivity)\n          : autoScrollSnapOnActivity\n          ? 1\n          : 0;\n      const patchedAutoScrollSnapOnPage =\n        typeof autoScrollSnapOnPage === 'number'\n          ? Math.max(0, Math.min(1, autoScrollSnapOnPage))\n          : autoScrollSnapOnPage\n          ? 1\n          : 0;\n      const patchedAutoScrollSnapOnActivityOffset =\n        typeof autoScrollSnapOnActivityOffset === 'number' ? autoScrollSnapOnActivityOffset : 0;\n      const patchedAutoScrollSnapOnPageOffset =\n        typeof autoScrollSnapOnPageOffset === 'number' ? autoScrollSnapOnPageOffset : 0;\n\n      if (patchedAutoScrollSnapOnActivity || patchedAutoScrollSnapOnPage) {\n        const { current: activityElementMap } = activityElementMapRef;\n        const { current: activityKeys } = activityKeysRef;\n        const { current: lastAcknowledgedActivityKey } = lastAcknowledgedActivityKeyRef;\n        const values: number[] = [];\n\n        const lastAcknowledgedActivityKeyIndex = activityKeys.indexOf(lastAcknowledgedActivityKey);\n\n        if (~lastAcknowledgedActivityKeyIndex) {\n          // The activity that we acknowledged could be not rendered, such as post back activity.\n          // When calculating scroll snap, we can only base on the first unacknowledged-and-rendering activity.\n          const renderingActivityKeys = Array.from(activityElementMap.keys());\n          let firstUnacknowledgedActivityElementIndex = -1;\n\n          for (const acknowledgedActivityKey of activityKeys.slice(0, lastAcknowledgedActivityKeyIndex + 1).reverse()) {\n            const index = renderingActivityKeys.indexOf(acknowledgedActivityKey);\n\n            if (~index) {\n              if (index !== renderingActivityKeys.length - 1) {\n                firstUnacknowledgedActivityElementIndex = index + 1;\n              }\n\n              break;\n            }\n          }\n\n          if (~firstUnacknowledgedActivityElementIndex) {\n            const activityElements = Array.from(activityElementMap.values());\n\n            if (patchedAutoScrollSnapOnActivity) {\n              // Gets the activity element which we should snap to.\n              const nthUnacknowledgedActivityElement =\n                activityElements[firstUnacknowledgedActivityElementIndex + patchedAutoScrollSnapOnActivity - 1];\n\n              if (nthUnacknowledgedActivityElement) {\n                const nthUnacknowledgedActivityBoundingBoxElement = nthUnacknowledgedActivityElement?.querySelector(\n                  '.webchat__basic-transcript__activity-active-descendant'\n                ) as HTMLElement;\n                const nthUnacknowledgedActivityOffsetTop =\n                  nthUnacknowledgedActivityElement.offsetTop + nthUnacknowledgedActivityBoundingBoxElement.offsetTop;\n\n                values.push(\n                  nthUnacknowledgedActivityOffsetTop +\n                    nthUnacknowledgedActivityBoundingBoxElement.offsetHeight -\n                    offsetHeight -\n                    scrollTop +\n                    patchedAutoScrollSnapOnActivityOffset\n                );\n              }\n            }\n\n            if (patchedAutoScrollSnapOnPage) {\n              const firstUnacknowledgedActivityElement = activityElements[+firstUnacknowledgedActivityElementIndex];\n              const firstUnacknowledgedActivityBoundingBoxElement = firstUnacknowledgedActivityElement.querySelector(\n                '.webchat__basic-transcript__activity-active-descendant'\n              ) as HTMLElement;\n              const firstUnacknowledgedActivityOffsetTop =\n                firstUnacknowledgedActivityElement.offsetTop + firstUnacknowledgedActivityBoundingBoxElement.offsetTop;\n\n              values.push(\n                firstUnacknowledgedActivityOffsetTop -\n                  scrollTop -\n                  offsetHeight * (1 - patchedAutoScrollSnapOnPage) +\n                  patchedAutoScrollSnapOnPageOffset\n              );\n            }\n          }\n        }\n\n        return Math.min(...values);\n      }\n\n      return Infinity;\n    },\n    [activityElementMapRef, activityKeysRef, lastAcknowledgedActivityKeyRef, styleOptionsRef]\n  );\n};\n\ntype BasicTranscriptProps = {\n  className?: string;\n};\n\nconst BasicTranscript: VFC<BasicTranscriptProps> = ({ className }) => {\n  const activityElementMapRef = useRef<ActivityElementMap>(new Map());\n  const containerRef = useRef<HTMLDivElement>();\n\n  const scroller = useScroller(activityElementMapRef);\n\n  return (\n    <TranscriptFocusComposer containerRef={containerRef}>\n      <ReactScrollToBottomComposer scroller={scroller}>\n        <KeyboardHelp />\n        <InternalTranscript activityElementMapRef={activityElementMapRef} className={className} ref={containerRef} />\n      </ReactScrollToBottomComposer>\n    </TranscriptFocusComposer>\n  );\n};\n\nBasicTranscript.defaultProps = {\n  className: ''\n};\n\nBasicTranscript.propTypes = {\n  className: PropTypes.string\n};\n\nexport default BasicTranscript;\n"]}
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.0";
146
+ var version = "4.15.1";
147
147
  exports.version = version;
148
148
  var Components = {
149
149
  BasicWebChat: _BasicWebChat.default,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "botframework-webchat-component",
3
- "version": "4.15.0",
3
+ "version": "4.15.1",
4
4
  "description": "React component of botframework-webchat",
5
5
  "main": "lib/index.js",
6
6
  "typings": "lib/index.d.ts",
@@ -48,8 +48,8 @@
48
48
  "dependencies": {
49
49
  "@emotion/css": "11.1.3",
50
50
  "base64-js": "1.5.1",
51
- "botframework-webchat-api": "4.15.0",
52
- "botframework-webchat-core": "4.15.0",
51
+ "botframework-webchat-api": "4.15.1",
52
+ "botframework-webchat-core": "4.15.1",
53
53
  "classnames": "2.3.1",
54
54
  "compute-scroll-into-view": "1.0.17",
55
55
  "event-target-shim": "6.0.2",
@@ -267,16 +267,22 @@ const InternalTranscript = forwardRef<HTMLDivElement, InternalTranscriptProps>(
267
267
  if (scrollableElement && activityBoundingBoxElement) {
268
268
  // ESLint conflict with TypeScript. The result of getClientRects() is not an Array but DOMRectList, and cannot be destructured.
269
269
  // eslint-disable-next-line prefer-destructuring
270
- const { height: activityHeight, y: activityY } = activityBoundingBoxElement.getClientRects()[0];
270
+ const activityBoundingBoxElementClientRect = activityBoundingBoxElement.getClientRects()[0];
271
271
 
272
272
  // ESLint conflict with TypeScript. The result of getClientRects() is not an Array but DOMRectList, and cannot be destructured.
273
273
  // eslint-disable-next-line prefer-destructuring
274
- const { height: scrollableHeight } = scrollableElement.getClientRects()[0];
275
- const activityOffsetTop = activityY + scrollableElement.scrollTop;
274
+ const scrollableElementClientRect = scrollableElement.getClientRects()[0];
276
275
 
277
- const scrollTop = Math.min(activityOffsetTop, activityOffsetTop - scrollableHeight + activityHeight);
276
+ // If either the activity or the transcript scrollable is not on DOM, we will not scroll the view.
277
+ if (activityBoundingBoxElementClientRect && scrollableElementClientRect) {
278
+ const { height: activityHeight, y: activityY } = activityBoundingBoxElementClientRect;
279
+ const { height: scrollableHeight } = scrollableElementClientRect;
280
+ const activityOffsetTop = activityY + scrollableElement.scrollTop;
278
281
 
279
- scrollToBottomScrollTo(scrollTop, { behavior });
282
+ const scrollTop = Math.min(activityOffsetTop, activityOffsetTop - scrollableHeight + activityHeight);
283
+
284
+ scrollToBottomScrollTo(scrollTop, { behavior });
285
+ }
280
286
  }
281
287
  }
282
288
  },
@@ -342,7 +348,14 @@ const InternalTranscript = forwardRef<HTMLDivElement, InternalTranscriptProps>(
342
348
 
343
349
  // "getClientRects()" is not returning an array, thus, it is not destructurable.
344
350
  // eslint-disable-next-line prefer-destructuring
345
- const { bottom: scrollableClientBottom } = scrollableElement.getClientRects()[0];
351
+ const scrollableElementClientRect = scrollableElement.getClientRects()[0];
352
+
353
+ // If the scrollable is not mounted, we cannot measure which activity is in view. Thus, we will not fire any events.
354
+ if (!scrollableElementClientRect) {
355
+ return;
356
+ }
357
+
358
+ const { bottom: scrollableClientBottom } = scrollableElementClientRect;
346
359
 
347
360
  // Find the activity just above scroll view bottom.
348
361
  // If the scroll view is already on top, get the first activity.
@@ -352,7 +365,14 @@ const InternalTranscript = forwardRef<HTMLDivElement, InternalTranscriptProps>(
352
365
  ? activityElements
353
366
  .reverse()
354
367
  // Add subpixel tolerance
355
- .find(([, element]) => element.getClientRects()[0].bottom < scrollableClientBottom + 1)
368
+ .find(([, element]) => {
369
+ // "getClientRects()" is not returning an array, thus, it is not destructurable.
370
+ // eslint-disable-next-line prefer-destructuring
371
+ const elementClientRect = element.getClientRects()[0];
372
+
373
+ // If the activity is not attached to DOM tree, we should not count it as "bottommost visible activity", as it is not visible.
374
+ return elementClientRect && elementClientRect.bottom < scrollableClientBottom + 1;
375
+ })
356
376
  : activityElements[0]
357
377
  )?.[0];
358
378