UNPKG

@sendbird/uikit-react

Version:

Sendbird UIKit for React: A feature-rich and customizable chat UI kit with messaging, channel management, and user authentication.

455 lines (449 loc) 28.6 kB
import { a as __awaiter, b as __generator, _ as __assign } from '../../chunks/bundle-yl5d1NoZ.js'; import React__default, { useContext, useMemo, forwardRef, useRef, useLayoutEffect, useCallback, useState, useEffect } from 'react'; import { useGroupChannelHandler } from '@sendbird/uikit-tools'; import { b as isAdminMessage, O as getHTMLTextDirection, m as isSendableMessage } from '../../chunks/bundle-vmZ9LoYK.js'; import { T as TypingIndicatorType } from '../../chunks/bundle-BpdtepPX.js'; import PlaceHolder, { PlaceHolderTypes } from '../../ui/PlaceHolder.js'; import Icon, { IconTypes, IconColors } from '../../ui/Icon.js'; import { Message } from './Message.js'; import { UnreadCount as UnreadCount$1 } from './UnreadCount.js'; import { L as LocalizationContext, u as useLocalization } from '../../chunks/bundle-Del33VzI.js'; import { L as Label, b as LabelColors, a as LabelTypography } from '../../chunks/bundle-viBng0Kh.js'; import { c as classnames, n as noop, d as deleteNullish } from '../../chunks/bundle-MlG9piGf.js'; import { u as useMediaQueryContext } from '../../chunks/bundle-DBhJIxHw.js'; import { FrozenNotification } from './FrozenNotification.js'; import { S as SCROLL_BUFFER } from '../../chunks/bundle-CqLLOVG5.js'; import TypingIndicatorBubble from '../../ui/TypingIndicatorBubble.js'; import { getMessagePartsInfo } from '../../Channel/utils/getMessagePartsInfo.js'; import { MessageProvider } from '../../Message/context.js'; import { e as getComponentKeyFromMessage, d as isContextMenuClosed } from '../../chunks/bundle-CzwYTfhQ.js'; import { a as isAboutSame } from '../../chunks/bundle-DFni3Lhf.js'; import { u as useGroupChannel } from '../../chunks/bundle-CmmJVpwV.js'; import { u as useSendbird } from '../../chunks/bundle-i_3w58Zd.js'; import '@sendbird/chat/groupChannel'; import '../../utils/message/getOutgoingMessageState.js'; import '../../chunks/bundle-DgosLQK9.js'; import '../../chunks/bundle-DEuCwnTn.js'; import '../../chunks/bundle-fdEQfX2s.js'; import '../../ui/Loader.js'; import '../../chunks/bundle-C1dqPUnT.js'; import '../../chunks/bundle-BZGITC2g.js'; import '../../chunks/bundle-CRpOTB7B.js'; import '../../chunks/bundle-mGsud0ec.js'; import '../../chunks/bundle-BEx1sWnS.js'; import '../../Message/hooks/useDirtyGetMentions.js'; import '../../ui/DateSeparator.js'; import '../../chunks/bundle-Bokm7tQ9.js'; import '../../ui/MessageInput.js'; import '../../chunks/bundle-BNtO7aXk.js'; import '../../ui/IconButton.js'; import '../../ui/Button.js'; import '../../chunks/bundle-CN_mZmg1.js'; import 'dompurify'; import '../../chunks/bundle-D6b2YGeE.js'; import '../../chunks/bundle-B6udMinl.js'; import '../../chunks/bundle-Cc1gzgza.js'; import '../../chunks/bundle-BwvurfUT.js'; import '../../chunks/bundle-BUYU9H94.js'; import '@sendbird/chat'; import '@sendbird/chat/openChannel'; import '../../ui/MessageContent.js'; import '../../chunks/bundle-2U8QpYXo.js'; import '../../chunks/bundle-BhhLSKSz.js'; import '../../chunks/bundle-Cl9rtdlj.js'; import '../../chunks/bundle-CQ_-cyp9.js'; import '../../chunks/bundle-Bch_Ry4S.js'; import 'react-dom'; import '../../ui/SortByRow.js'; import '../../chunks/bundle-DGh2T5IL.js'; import '../../ui/MessageItemReactionMenu.js'; import '../../ui/ImageRenderer.js'; import '../../ui/ReactionButton.js'; import '../../chunks/bundle-Ba_cV-Zm.js'; import '../../ui/EmojiReactions.js'; import '../../ui/ReactionBadge.js'; import '../../ui/BottomSheet.js'; import '../../hooks/useModal.js'; import '../../chunks/bundle-CtQtfJlT.js'; import '../../ui/UserListItem.js'; import '../../chunks/bundle-B0s_McF0.js'; import '../../chunks/bundle-CAEBoiEz.js'; import '../../chunks/bundle-Dl_v8XoN.js'; import '../../ui/MutedAvatarOverlay.js'; import '../../ui/Checkbox.js'; import '../../ui/UserProfile.js'; import '../../sendbirdSelectors.js'; import '../../chunks/bundle-BOykFtQ3.js'; import '../../ui/Tooltip.js'; import '../../ui/TooltipWrapper.js'; import '../../chunks/bundle-BSy5MmTl.js'; import '../../ui/AdminMessage.js'; import '../../ui/QuoteMessage.js'; import '../../chunks/bundle-h6bAY7E9.js'; import '@sendbird/chat/message'; import '../../ui/MobileMenu.js'; import '../../ui/ThreadReplies.js'; import '../../chunks/bundle-BdQWhaHB.js'; import '../../ui/OGMessageItemBody.js'; import '../../chunks/bundle-DcLgcUpC.js'; import '../../ui/MentionLabel.js'; import '../../ui/LinkLabel.js'; import '../../ui/TextMessageItemBody.js'; import '../../ui/FileMessageItemBody.js'; import '../../ui/TextButton.js'; import '../../chunks/bundle-HwtLrcpn.js'; import '../../ui/FileViewer.js'; import '../../chunks/bundle-Ha1krmtK.js'; import '../../ui/VoiceMessageItemBody.js'; import '../../ui/ProgressBar.js'; import '../../VoicePlayer/useVoicePlayer.js'; import '../../chunks/bundle-BrBLR_c-.js'; import '../../VoiceRecorder/context.js'; import '../../ui/PlaybackTime.js'; import '../../ui/ThumbnailMessageItemBody.js'; import '../../ui/UnknownMessageItemBody.js'; import '../../ui/TemplateMessageItemBody.js'; import '../../chunks/bundle-BJYztm64.js'; import '../../ui/FallbackTemplateMessageItemBody.tsx.js'; import '../../ui/LoadingTemplateMessageItemBody.tsx.js'; import '../../ui/MessageFeedbackFailedModal.js'; import '../../ui/FeedbackIconButton.js'; import '../../ui/MobileFeedbackMenu.js'; import '../../ui/MessageFeedbackModal.js'; import '../../ui/Input.js'; import '../../chunks/bundle-C8U5aHBw.js'; import './SuggestedReplies.js'; import '../../chunks/bundle-sf0POh6_.js'; import './FileViewer.js'; import '../../chunks/bundle-c7SN5XJA.js'; import '../../chunks/bundle-D1nuDKhb.js'; import '../../chunks/bundle-DK3-aB7E.js'; import '../../chunks/bundle-BmoSvBYM.js'; import './RemoveMessageModal.js'; import '../../chunks/bundle-So54Aj7k.js'; import '../../chunks/bundle-BxzlMlCv.js'; import '../../Channel/utils/compareMessagesForGrouping.js'; var UnreadCount = function (_a) { var _b = _a.className, className = _b === void 0 ? '' : _b, _c = _a.count, count = _c === void 0 ? 0 : _c, onClick = _a.onClick, _d = _a.isFrozenChannel, isFrozenChannel = _d === void 0 ? false : _d; var stringSet = useContext(LocalizationContext).stringSet; var unreadMessageCountText = useMemo(function () { if (count === 1) { return stringSet.CHANNEL__MESSAGE_LIST__NOTIFICATION__UNREAD_MESSAGE; } else if (count > 1) { return stringSet.CHANNEL__MESSAGE_LIST__NOTIFICATION__UNREAD_MESSAGE_S; } }, [count]); return (React__default.createElement("div", { className: classnames(count < 1 ? 'sendbird-unread-floating-button--hide' : 'sendbird-unread-floating-button', isFrozenChannel && 'sendbird-unread-floating-button--below-frozen', className), "data-testid": "sendbird-notification" }, React__default.createElement(Label, { className: "sendbird-unread-floating-button__text", testID: "sendbird-notification__text", color: LabelColors.ONCONTENT_1, type: LabelTypography.CAPTION_2 }, "".concat(count > 99 ? '99+' : count, " "), unreadMessageCountText), React__default.createElement(Icon, { width: "24px", height: "24px", type: IconTypes.FLOATING_BUTTON_CLOSE, fillColor: IconColors.CONTENT, onClick: onClick }))); }; var NewMessageCount = function (_a) { var _b = _a.className, className = _b === void 0 ? '' : _b, _c = _a.count, count = _c === void 0 ? 0 : _c, onClick = _a.onClick; var stringSet = useContext(LocalizationContext).stringSet; var isMobile = useMediaQueryContext().isMobile; var newMessageCountText = useMemo(function () { if (count === 1) { return stringSet.CHANNEL__MESSAGE_LIST__NOTIFICATION__NEW_MESSAGE; } else if (count > 1) { return stringSet.CHANNEL__MESSAGE_LIST__NOTIFICATION__NEW_MESSAGE_S; } }, [count]); return (React__default.createElement("div", { className: classnames(count < 1 ? 'sendbird-new-message-floating-button--hide' : 'sendbird-new-message-floating-button', className), "data-testid": "sendbird-new-message-notification", onClick: onClick }, React__default.createElement(Label, { className: "sendbird-new-message-floating-button__text", testID: "sendbird-new-message-notification__text", color: LabelColors.ONCONTENT_1, type: LabelTypography.CAPTION_2 }, "".concat(count > 99 ? '99+' : count, " "), newMessageCountText), !isMobile && (React__default.createElement(Icon, { width: "24px", height: "24px", type: IconTypes.CHEVRON_DOWN, fillColor: IconColors.PRIMARY })))); }; var InfiniteList = forwardRef(function (props, listRef) { var messages = props.messages, renderMessage = props.renderMessage, scrollPositionRef = props.scrollPositionRef, scrollDistanceFromBottomRef = props.scrollDistanceFromBottomRef, onLoadPrevious = props.onLoadPrevious, onLoadNext = props.onLoadNext, _a = props.loadThreshold, loadThreshold = _a === void 0 ? 0.05 : _a, typingIndicator = props.typingIndicator, _b = props.onScrollPosition, onScrollPosition = _b === void 0 ? noop : _b, initDeps = props.initDeps; var isFetching = React__default.useRef(false); var direction = React__default.useRef(); var oldScrollTop = useRef(0); // SideEffect: scroll to bottom on initialized useLayoutEffect(function () { if (listRef.current) { listRef.current.scrollTop = listRef.current.scrollHeight; } }, initDeps); // SideEffect: keep scroll position useLayoutEffect(function () { if (listRef.current) { if (direction.current === 'top') { listRef.current.scrollTop = listRef.current.scrollHeight - scrollPositionRef.current; } if (direction.current === 'bottom') { listRef.current.scrollTop = oldScrollTop.current; } direction.current = undefined; } }, [listRef.current, messages.length]); var handleScroll = useCallback(function () { return __awaiter(void 0, void 0, void 0, function () { var list, threshold; return __generator(this, function (_a) { switch (_a.label) { case 0: if (!listRef.current) return [2 /*return*/]; list = listRef.current; onScrollPosition(getReachedStatus(list)); scrollPositionRef.current = list.scrollHeight - list.scrollTop; scrollDistanceFromBottomRef.current = scrollPositionRef.current - list.clientHeight; oldScrollTop.current = list.scrollTop; if (isFetching.current) return [2 /*return*/]; threshold = list.clientHeight * Math.min(Math.max(0, loadThreshold), 1); if (!(list.scrollTop <= threshold)) return [3 /*break*/, 2]; isFetching.current = true; direction.current = 'top'; return [4 /*yield*/, onLoadPrevious()]; case 1: _a.sent(); isFetching.current = false; return [3 /*break*/, 5]; case 2: if (!(list.scrollHeight - list.scrollTop - list.clientHeight <= threshold)) return [3 /*break*/, 4]; isFetching.current = true; direction.current = 'bottom'; return [4 /*yield*/, onLoadNext()]; case 3: _a.sent(); isFetching.current = false; return [3 /*break*/, 5]; case 4: direction.current = undefined; _a.label = 5; case 5: return [2 /*return*/]; } }); }); }, [messages.length]); return (React__default.createElement("div", { className: "sendbird-conversation__scroll-container" }, React__default.createElement("div", { className: "sendbird-conversation__padding" }), React__default.createElement("div", { ref: listRef, className: "sendbird-conversation__messages-padding", "data-testid": "sendbird-message-list-container", onScroll: handleScroll }, messages.map(function (message, index) { return renderMessage({ message: message, index: index }); }), typingIndicator))); }); function getReachedStatus(element) { if (isAboutSame(element.scrollTop, 0, SCROLL_BUFFER)) { return 'top'; } if (isAboutSame(element.scrollHeight, element.clientHeight + element.scrollTop, SCROLL_BUFFER)) { return 'bottom'; } return 'middle'; } var MessageList = function (props) { var _a, _b, _c, _d, _e; var _f = props.className, className = _f === void 0 ? '' : _f; var _g = deleteNullish(props), _h = _g.renderMessage, renderMessage = _h === void 0 ? function (props) { return React__default.createElement(Message, __assign({}, props)); } : _h, renderMessageContent = _g.renderMessageContent, renderSuggestedReplies = _g.renderSuggestedReplies, renderCustomSeparator = _g.renderCustomSeparator, _j = _g.renderPlaceholderLoader, renderPlaceholderLoader = _j === void 0 ? function () { return React__default.createElement(PlaceHolder, { type: PlaceHolderTypes.LOADING }); } : _j, _k = _g.renderPlaceholderEmpty, renderPlaceholderEmpty = _k === void 0 ? function () { return React__default.createElement(PlaceHolder, { className: "sendbird-conversation__no-messages", type: PlaceHolderTypes.NO_MESSAGES }); } : _k, _l = _g.renderFrozenNotification, renderFrozenNotification = _l === void 0 ? function () { return React__default.createElement(FrozenNotification, { className: "sendbird-conversation__messages__notification" }); } : _l; var _m = useGroupChannel(), _o = _m.state, channelUrl = _o.channelUrl, hasNext = _o.hasNext, loading = _o.loading, messages = _o.messages, newMessages = _o.newMessages, isScrollBottomReached = _o.isScrollBottomReached, isMessageGroupingEnabled = _o.isMessageGroupingEnabled, currentChannel = _o.currentChannel, replyType = _o.replyType, scrollPubSub = _o.scrollPubSub, loadNext = _o.loadNext, loadPrevious = _o.loadPrevious, resetNewMessages = _o.resetNewMessages, scrollRef = _o.scrollRef, scrollPositionRef = _o.scrollPositionRef, scrollDistanceFromBottomRef = _o.scrollDistanceFromBottomRef, markAsUnreadSourceRef = _o.markAsUnreadSourceRef, readState = _o.readState, _p = _m.actions, scrollToBottom = _p.scrollToBottom, setIsScrollBottomReached = _p.setIsScrollBottomReached, markAsReadAll = _p.markAsReadAll, markAsUnread = _p.markAsUnread; var _q = useSendbird(), state = _q.state, enableMarkAsUnread = _q.state.config.groupChannel.enableMarkAsUnread; var stringSet = useLocalization().stringSet; var _r = useState(), unreadSinceDate = _r[0], setUnreadSinceDate = _r[1]; var _s = useState(false), showUnreadCount = _s[0], setShowUnreadCount = _s[1]; var isInitializedRef = useRef(false); var separatorMessageRef = useRef(undefined); var isUnreadMessageExistInChannel = useRef(false); // Find the first unread message var firstUnreadMessage = useMemo(function () { if (!enableMarkAsUnread || !isInitializedRef.current || messages.length === 0 || readState === 'read') { return undefined; } if (readState === 'unread') { separatorMessageRef.current = undefined; isUnreadMessageExistInChannel.current = true; } var myLastRead = currentChannel.myLastRead; var willFindMessageCreatedAt = myLastRead + 1; // 조건 1: 정확히 myLastRead + 1인 메시지 찾기 var exactMatchMessage = messages.find(function (message) { return message.createdAt === willFindMessageCreatedAt; }); if (exactMatchMessage) { return exactMatchMessage; } // 조건 2: myLastRead + 1보다 큰 첫 번째 메시지 찾기 (Admin 메시지 제외) return messages.find(function (message) { return message.createdAt > willFindMessageCreatedAt && !isAdminMessage(message); }); }, [messages, currentChannel === null || currentChannel === void 0 ? void 0 : currentChannel.myLastRead, readState]); useEffect(function () { var _a; if ((currentChannel === null || currentChannel === void 0 ? void 0 : currentChannel.url) && loading) { // done get channel and messages setShowUnreadCount((currentChannel === null || currentChannel === void 0 ? void 0 : currentChannel.unreadMessageCount) > 0); isInitializedRef.current = true; isUnreadMessageExistInChannel.current = ((_a = currentChannel === null || currentChannel === void 0 ? void 0 : currentChannel.lastMessage) === null || _a === void 0 ? void 0 : _a.createdAt) > (currentChannel === null || currentChannel === void 0 ? void 0 : currentChannel.myLastRead); } }, [currentChannel === null || currentChannel === void 0 ? void 0 : currentChannel.url, loading]); useEffect(function () { if (!isInitializedRef.current) return; if (!enableMarkAsUnread) { // backward compatibility if (isScrollBottomReached) { setUnreadSinceDate(undefined); } else { setUnreadSinceDate(new Date()); } } else if (isScrollBottomReached) { if ((markAsUnreadSourceRef === null || markAsUnreadSourceRef === void 0 ? void 0 : markAsUnreadSourceRef.current) !== 'manual') { if ((currentChannel === null || currentChannel === void 0 ? void 0 : currentChannel.unreadMessageCount) > 0) { if (separatorMessageRef.current || !isUnreadMessageExistInChannel.current) { // called markAsReadAll as after the first unread message is displayed markAsReadAll(currentChannel); } } } } }, [isScrollBottomReached]); var checkDisplayedNewMessageSeparator = useCallback(function (isNewMessageSeparatorVisible) { if (!isInitializedRef.current || !firstUnreadMessage) return; if (isNewMessageSeparatorVisible && (currentChannel === null || currentChannel === void 0 ? void 0 : currentChannel.unreadMessageCount) > 0) { setShowUnreadCount(false); } else if (!isNewMessageSeparatorVisible && (currentChannel === null || currentChannel === void 0 ? void 0 : currentChannel.unreadMessageCount) > 0) { setShowUnreadCount(true); } if (isNewMessageSeparatorVisible && (markAsUnreadSourceRef === null || markAsUnreadSourceRef === void 0 ? void 0 : markAsUnreadSourceRef.current) !== 'manual') { if ((newMessages === null || newMessages === void 0 ? void 0 : newMessages.length) > 0) { markAsUnread(newMessages[0], 'internal'); separatorMessageRef.current = undefined; } else if (firstUnreadMessage) { if (!separatorMessageRef.current || separatorMessageRef.current.messageId !== firstUnreadMessage.messageId) { separatorMessageRef.current = firstUnreadMessage; } markAsReadAll(currentChannel); } } }, [firstUnreadMessage, markAsUnread, markAsReadAll, currentChannel === null || currentChannel === void 0 ? void 0 : currentChannel.unreadMessageCount]); /** * 1. Move the message list scroll * when each message's height is changed by `reactions` OR `showEdit` * 2. Keep the scrollBottom value after fetching new message list */ var onMessageContentSizeChanged = function (isBottomMessageAffected) { if (isBottomMessageAffected === void 0) { isBottomMessageAffected = false; } var elem = scrollRef.current; if (elem) { var latestDistance = scrollDistanceFromBottomRef.current; var currentDistance = elem.scrollHeight - elem.scrollTop - elem.offsetHeight; if (latestDistance < currentDistance && (!isBottomMessageAffected || latestDistance < SCROLL_BUFFER)) { var diff = currentDistance - latestDistance; // Move the scroll as much as the height of the message has changed scrollPubSub.publish('scroll', { top: elem.scrollTop + diff, lazy: false, animated: false }); } } }; var renderer = { frozenNotification: function () { if (!currentChannel || !currentChannel.isFrozen) return null; return renderFrozenNotification(); }, unreadMessagesNotification: function () { var _a; if (enableMarkAsUnread) { if (!showUnreadCount || (currentChannel === null || currentChannel === void 0 ? void 0 : currentChannel.unreadMessageCount) === 0) return null; return (React__default.createElement(UnreadCount, { className: "sendbird-unread-messages-count", count: (_a = currentChannel === null || currentChannel === void 0 ? void 0 : currentChannel.unreadMessageCount) !== null && _a !== void 0 ? _a : 0, isFrozenChannel: (currentChannel === null || currentChannel === void 0 ? void 0 : currentChannel.isFrozen) || false, onClick: function () { if (newMessages.length > 0) { resetNewMessages(); } isUnreadMessageExistInChannel.current = false; markAsReadAll(currentChannel); } })); } if (isScrollBottomReached || !unreadSinceDate) return null; return (React__default.createElement(UnreadCount$1, { className: "sendbird-conversation__messages__notification", count: newMessages.length, lastReadAt: unreadSinceDate, onClick: function () { return scrollToBottom(); } })); }, scrollToBottomButton: function () { if (!hasNext() && isScrollBottomReached) return null; return (React__default.createElement("div", { className: "sendbird-conversation__scroll-bottom-button", onClick: function () { return scrollToBottom(); }, onKeyDown: function () { return scrollToBottom(); }, tabIndex: 0, role: "button" }, React__default.createElement(Icon, { width: "24px", height: "24px", type: IconTypes.CHEVRON_DOWN, fillColor: IconColors.PRIMARY }))); }, newMessageCount: function () { // 스크롤이 bottom에 있을 때는 new message count를 표시하지 않음 if (isScrollBottomReached) return null; return (React__default.createElement(NewMessageCount, { className: "sendbird-new-messages-count", count: newMessages.length, onClick: function () { return scrollToBottom(); } })); }, }; if (loading) { return renderPlaceholderLoader(); } if (messages.length === 0) { return renderPlaceholderEmpty(); } return (React__default.createElement(React__default.Fragment, null, React__default.createElement("div", { className: "sendbird-conversation__messages ".concat(className), dir: getHTMLTextDirection(state.config.htmlTextDirection, state.config.forceLeftToRightMessageLayout) }, React__default.createElement(InfiniteList, { ref: scrollRef, initDeps: [channelUrl], scrollPositionRef: scrollPositionRef, scrollDistanceFromBottomRef: scrollDistanceFromBottomRef, onLoadNext: loadNext, onLoadPrevious: loadPrevious, onScrollPosition: function (it) { var isScrollBottomReached = it === 'bottom'; if (isInitializedRef.current && isScrollBottomReached) { if (newMessages.length > 0) { resetNewMessages(); } else if (!isUnreadMessageExistInChannel.current && (currentChannel === null || currentChannel === void 0 ? void 0 : currentChannel.unreadMessageCount) === 0) { markAsReadAll(currentChannel); } } setIsScrollBottomReached(isScrollBottomReached); }, messages: messages, renderMessage: function (_a) { var _b; var message = _a.message, index = _a.index; var finalFirstUnreadMessageId = ((_b = separatorMessageRef.current) === null || _b === void 0 ? void 0 : _b.messageId) || (firstUnreadMessage === null || firstUnreadMessage === void 0 ? void 0 : firstUnreadMessage.messageId); var _c = getMessagePartsInfo({ allMessages: messages, stringSet: stringSet, replyType: replyType !== null && replyType !== void 0 ? replyType : 'NONE', isMessageGroupingEnabled: isMessageGroupingEnabled !== null && isMessageGroupingEnabled !== void 0 ? isMessageGroupingEnabled : false, currentIndex: index, currentMessage: message, currentChannel: currentChannel, firstUnreadMessageId: finalFirstUnreadMessageId, isUnreadMessageExistInChannel: isUnreadMessageExistInChannel, }), chainTop = _c.chainTop, chainBottom = _c.chainBottom, hasSeparator = _c.hasSeparator, hasNewMessageSeparator = _c.hasNewMessageSeparator; var isOutgoingMessage = isSendableMessage(message) && message.sender.userId === state.config.userId; return (React__default.createElement(MessageProvider, { message: message, key: getComponentKeyFromMessage(message), isByMe: isOutgoingMessage }, renderMessage({ handleScroll: onMessageContentSizeChanged, message: message, hasSeparator: hasSeparator, hasNewMessageSeparator: hasNewMessageSeparator, chainTop: chainTop, chainBottom: chainBottom, renderMessageContent: renderMessageContent, renderSuggestedReplies: renderSuggestedReplies, renderCustomSeparator: renderCustomSeparator, onNewMessageSeparatorVisibilityChange: checkDisplayedNewMessageSeparator, }))); }, typingIndicator: !hasNext() && ((_b = (_a = state === null || state === void 0 ? void 0 : state.config) === null || _a === void 0 ? void 0 : _a.groupChannel) === null || _b === void 0 ? void 0 : _b.enableTypingIndicator) && ((_e = (_d = (_c = state === null || state === void 0 ? void 0 : state.config) === null || _c === void 0 ? void 0 : _c.groupChannel) === null || _d === void 0 ? void 0 : _d.typingIndicatorTypes) === null || _e === void 0 ? void 0 : _e.has(TypingIndicatorType.Bubble)) && (React__default.createElement(TypingIndicatorBubbleWrapper, { channelUrl: channelUrl, handleScroll: onMessageContentSizeChanged })) }), React__default.createElement(React__default.Fragment, null, renderer.frozenNotification()), React__default.createElement(React__default.Fragment, null, renderer.unreadMessagesNotification()), React__default.createElement(React__default.Fragment, null, renderer.scrollToBottomButton()), React__default.createElement(React__default.Fragment, null, renderer.newMessageCount())))); }; var TypingIndicatorBubbleWrapper = function (props) { var stores = useSendbird().state.stores; var _a = useGroupChannel().state, isScrollBottomReached = _a.isScrollBottomReached, scrollPubSub = _a.scrollPubSub; var _b = useState([]), typingMembers = _b[0], setTypingMembers = _b[1]; useGroupChannelHandler(stores.sdkStore.sdk, { onTypingStatusUpdated: function (channel) { if (channel.url === props.channelUrl) { setTypingMembers(channel.getTypingUsers()); } if (isScrollBottomReached && isContextMenuClosed()) { setTimeout(function () { scrollPubSub.publish('scrollToBottom', {}); }, 10); } }, }); return React__default.createElement(TypingIndicatorBubble, { typingMembers: typingMembers, handleScroll: props.handleScroll }); }; export { MessageList, MessageList as default }; //# sourceMappingURL=MessageList.js.map