UNPKG

@sendbird/uikit-react

Version:

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

288 lines (282 loc) 15.9 kB
import React__default, { useMemo, useState, useRef } from 'react'; import { u as useLocalization } from '../../chunks/bundle-Del33VzI.js'; import { g as getChannelTitle } from '../../chunks/bundle-DfS7BDcp.js'; import ParentMessageInfo from './ParentMessageInfo.js'; import ThreadHeader from './ThreadHeader.js'; import ThreadList from './ThreadList.js'; import ThreadMessageInput from './ThreadMessageInput.js'; import { ParentMessageStateTypes, ThreadListStateTypes } from '../context/types.js'; import PlaceHolder, { PlaceHolderTypes } from '../../ui/PlaceHolder.js'; import { L as Label, a as LabelTypography, b as LabelColors } from '../../chunks/bundle-viBng0Kh.js'; import { i as isAboutSame } from '../../chunks/bundle-CIQCAe1h.js'; import { MessageProvider } from '../../Message/context.js'; import { O as getHTMLTextDirection } from '../../chunks/bundle-vmZ9LoYK.js'; import { c as classnames } from '../../chunks/bundle-MlG9piGf.js'; import { u as useThread } from '../../chunks/bundle-a_zBi15q.js'; import { u as useSendbird } from '../../chunks/bundle-i_3w58Zd.js'; import '../../chunks/bundle-yl5d1NoZ.js'; import '../../chunks/bundle-C1dqPUnT.js'; import '../../chunks/bundle-BZGITC2g.js'; import '../../chunks/bundle-mGsud0ec.js'; import '../../chunks/bundle-fdEQfX2s.js'; import '../../chunks/bundle-D1OvmDcy.js'; import '../../chunks/bundle-CtQtfJlT.js'; import 'react-dom'; import '../../chunks/bundle-DBhJIxHw.js'; import '../../ui/IconButton.js'; import '../../ui/Button.js'; import '../../ui/Icon.js'; import '../../chunks/bundle-DGh2T5IL.js'; import '../../chunks/bundle-BxzlMlCv.js'; import '../../chunks/bundle-DEuCwnTn.js'; import './ParentMessageInfoItem.js'; import '../../ui/ImageRenderer.js'; import '../../ui/TextButton.js'; import '../../chunks/bundle-Bokm7tQ9.js'; import '../../ui/EmojiReactions.js'; import '../../ui/ReactionBadge.js'; import '../../ui/ReactionButton.js'; import '../../chunks/bundle-Ba_cV-Zm.js'; import '../../chunks/bundle-Bch_Ry4S.js'; import '@sendbird/chat'; import '@sendbird/chat/openChannel'; import '../../ui/SortByRow.js'; import '../../chunks/bundle-BUYU9H94.js'; import '../../chunks/bundle-CqLLOVG5.js'; import '@sendbird/chat/groupChannel'; import '../../ui/BottomSheet.js'; import '../../hooks/useModal.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 '../../utils/message/getOutgoingMessageState.js'; import '../../chunks/bundle-DgosLQK9.js'; import '../../ui/Tooltip.js'; import '../../ui/TooltipWrapper.js'; import '../../chunks/bundle-BSy5MmTl.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/Loader.js'; import '../../chunks/bundle-DcLgcUpC.js'; import '../../chunks/bundle-BwvurfUT.js'; import '../../ui/MentionLabel.js'; import '../../ui/LinkLabel.js'; import '../../chunks/bundle-HwtLrcpn.js'; import '@sendbird/chat/message'; import '../../ui/FileViewer.js'; import '../../chunks/bundle-Ha1krmtK.js'; import '@sendbird/uikit-tools'; import '../../chunks/bundle-DFni3Lhf.js'; import '../../chunks/bundle-CM73CDTO.js'; import '../../chunks/bundle-BmoSvBYM.js'; import '../../chunks/bundle-Coe_wsHL.js'; import '../../chunks/bundle-sf0POh6_.js'; import '../../chunks/bundle-BEx1sWnS.js'; import '../../chunks/bundle-BNtO7aXk.js'; import '../../ui/MessageItemReactionMenu.js'; import '../../ui/MessageInput.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-BY2z9V57.js'; import '../../ui/MobileMenu.js'; import '../../Message/hooks/useDirtyGetMentions.js'; import '../../chunks/bundle-DK3-aB7E.js'; import '../../chunks/bundle-CQ_-cyp9.js'; import '../../chunks/bundle-C8U5aHBw.js'; import '../../ui/Header.js'; import './ThreadListItem.js'; import '../../ui/DateSeparator.js'; import '../../chunks/bundle-2U8QpYXo.js'; import '../../chunks/bundle-BhhLSKSz.js'; import '../../chunks/bundle-Cl9rtdlj.js'; import '../../chunks/bundle-BdQWhaHB.js'; import '../../ui/OGMessageItemBody.js'; import '../../ui/TextMessageItemBody.js'; import '../../ui/FileMessageItemBody.js'; import '../../ui/ThumbnailMessageItemBody.js'; import '../../chunks/bundle-h6bAY7E9.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 '../../chunks/bundle-CzwYTfhQ.js'; import '../../Channel/utils/compareMessagesForGrouping.js'; import 'date-fns'; import '../../chunks/bundle-xxejwSP0.js'; import '../../GroupChannel/components/SuggestedMentionList.js'; import '../../ui/QuoteMessageInput.js'; import '../../VoiceRecorder/useVoiceRecorder.js'; import '../../chunks/bundle-C25g6A23.js'; import '../../chunks/bundle-BtCCRSPc.js'; import '../../chunks/bundle-CmmJVpwV.js'; import '../../chunks/bundle-D1nuDKhb.js'; import '../../Channel/hooks/useHandleUploadFiles.js'; var useMemorizedHeader = function (_a) { var renderHeader = _a.renderHeader; return useMemo(function () { if (typeof renderHeader === 'function') { return renderHeader(); } return null; }, [renderHeader]); }; var useMemorizedParentMessageInfo = function (_a) { var parentMessage = _a.parentMessage, parentMessageState = _a.parentMessageState, renderParentMessageInfo = _a.renderParentMessageInfo, renderParentMessageInfoPlaceholder = _a.renderParentMessageInfoPlaceholder; return useMemo(function () { if (parentMessageState === ParentMessageStateTypes.NIL || parentMessageState === ParentMessageStateTypes.LOADING || parentMessageState === ParentMessageStateTypes.INVALID) { if (typeof renderParentMessageInfoPlaceholder === 'function') { return renderParentMessageInfoPlaceholder(parentMessageState); } switch (parentMessageState) { case ParentMessageStateTypes.NIL: { return (React__default.createElement(PlaceHolder, { className: "sendbird-thread-ui__parent-message-info placeholder-nil", type: PlaceHolderTypes.NO_RESULTS, iconSize: "64px" })); } case ParentMessageStateTypes.LOADING: { return (React__default.createElement(PlaceHolder, { className: "sendbird-thread-ui__parent-message-info placeholder-loading", type: PlaceHolderTypes.LOADING, iconSize: "64px" })); } case ParentMessageStateTypes.INVALID: { return (React__default.createElement(PlaceHolder, { className: "sendbird-thread-ui__parent-message-info placeholder-invalid", type: PlaceHolderTypes.WRONG, iconSize: "64px" })); } default: { return null; } } } else if (parentMessageState === ParentMessageStateTypes.INITIALIZED) { if (typeof renderParentMessageInfo === 'function') { return renderParentMessageInfo(); } } return null; }, [ parentMessage, parentMessageState, renderParentMessageInfo, renderParentMessageInfoPlaceholder, ]); }; var useMemorizedThreadList = function (_a) { var threadListState = _a.threadListState, renderThreadListPlaceHolder = _a.renderThreadListPlaceHolder; return useMemo(function () { if (threadListState === ThreadListStateTypes.NIL || threadListState === ThreadListStateTypes.LOADING || threadListState === ThreadListStateTypes.INVALID) { if (typeof renderThreadListPlaceHolder === 'function') { return renderThreadListPlaceHolder(threadListState); } switch (threadListState) { case ThreadListStateTypes.LOADING: { return (React__default.createElement(PlaceHolder, { className: "sendbird-thread-ui__thread-list placeholder-loading", type: PlaceHolderTypes.LOADING, iconSize: "64px" })); } case ThreadListStateTypes.INVALID: { return (React__default.createElement(PlaceHolder, { className: "sendbird-thread-ui__thread-list placeholder-invalid", type: PlaceHolderTypes.WRONG, iconSize: "64px" })); } case ThreadListStateTypes.NIL: { return React__default.createElement(React__default.Fragment, null); } default: { return null; } } } return null; }, [ threadListState, renderThreadListPlaceHolder, ]); }; var ThreadUI = function (_a) { var _b, _c, _d, _e; var renderHeader = _a.renderHeader, _f = _a.renderParentMessageInfo, renderParentMessageInfo = _f === void 0 ? function () { return React__default.createElement(ParentMessageInfo, { className: "sendbird-thread-ui__parent-message-info" }); } : _f, renderMessage = _a.renderMessage, renderMessageInput = _a.renderMessageInput, renderCustomSeparator = _a.renderCustomSeparator, renderParentMessageInfoPlaceholder = _a.renderParentMessageInfoPlaceholder, renderThreadListPlaceHolder = _a.renderThreadListPlaceHolder, renderFileUploadIcon = _a.renderFileUploadIcon, renderVoiceMessageIcon = _a.renderVoiceMessageIcon, renderSendMessageIcon = _a.renderSendMessageIcon; var _g = useSendbird().state, stores = _g.stores, config = _g.config; var currentUserId = (_d = (_c = (_b = stores === null || stores === void 0 ? void 0 : stores.sdkStore) === null || _b === void 0 ? void 0 : _b.sdk) === null || _c === void 0 ? void 0 : _c.currentUser) === null || _d === void 0 ? void 0 : _d.userId; var stringSet = useLocalization().stringSet; var _h = useThread(), _j = _h.state, currentChannel = _j.currentChannel, allThreadMessages = _j.allThreadMessages, parentMessage = _j.parentMessage, parentMessageState = _j.parentMessageState, threadListState = _j.threadListState, hasMorePrev = _j.hasMorePrev, hasMoreNext = _j.hasMoreNext, onHeaderActionClick = _j.onHeaderActionClick, onMoveToParentMessage = _j.onMoveToParentMessage, _k = _h.actions, fetchPrevThreads = _k.fetchPrevThreads, fetchNextThreads = _k.fetchNextThreads; var replyCount = allThreadMessages.length; var isByMe = currentUserId === ((_e = parentMessage === null || parentMessage === void 0 ? void 0 : parentMessage.sender) === null || _e === void 0 ? void 0 : _e.userId); // Memoized custom components var MemorizedHeader = useMemorizedHeader({ renderHeader: renderHeader }); var MemorizedParentMessageInfo = useMemorizedParentMessageInfo({ parentMessage: parentMessage, parentMessageState: parentMessageState, renderParentMessageInfo: renderParentMessageInfo, renderParentMessageInfoPlaceholder: renderParentMessageInfoPlaceholder, }); var MemorizedThreadList = useMemorizedThreadList({ threadListState: threadListState, renderThreadListPlaceHolder: renderThreadListPlaceHolder, }); // scroll var _l = useState(0), scrollBottom = _l[0], setScrollBottom = _l[1]; var scrollRef = useRef(null); var onScroll = function (e) { var _a; var element = e.target; var scrollTop = element.scrollTop, clientHeight = element.clientHeight, scrollHeight = element.scrollHeight; var threadItemNodes = (_a = scrollRef.current) === null || _a === void 0 ? void 0 : _a.querySelectorAll('.sendbird-thread-list-item'); var firstNode = threadItemNodes === null || threadItemNodes === void 0 ? void 0 : threadItemNodes[0]; if (isAboutSame(scrollTop, 0, 10) && hasMorePrev) { fetchPrevThreads(function (messages) { var _a; if (messages) { try { (_a = firstNode === null || firstNode === void 0 ? void 0 : firstNode.scrollIntoView) === null || _a === void 0 ? void 0 : _a.call(firstNode, { block: 'start', inline: 'nearest' }); } catch (error) { // } } }); } if (isAboutSame(clientHeight + scrollTop, scrollHeight, 10) && hasMoreNext) { var scrollTop_1 = scrollTop; fetchNextThreads(function (messages) { if (messages) { try { element.scrollTop = scrollTop_1; if (scrollRef.current) { scrollRef.current.scrollTop = scrollTop_1; } } catch (error) { // } } }); } // save the lastest scroll bottom value if (scrollRef === null || scrollRef === void 0 ? void 0 : scrollRef.current) { var current = scrollRef === null || scrollRef === void 0 ? void 0 : scrollRef.current; setScrollBottom(current.scrollHeight - current.scrollTop - current.offsetHeight); } }; return (React__default.createElement("div", { className: 'sendbird-thread-ui' }, MemorizedHeader || (React__default.createElement(ThreadHeader, { className: "sendbird-thread-ui__header", channelName: getChannelTitle(currentChannel, currentUserId !== null && currentUserId !== void 0 ? currentUserId : '', stringSet), onActionIconClick: onHeaderActionClick, onChannelNameClick: function () { onMoveToParentMessage === null || onMoveToParentMessage === void 0 ? void 0 : onMoveToParentMessage({ message: parentMessage, channel: currentChannel }); } })), React__default.createElement("div", { className: classnames('sendbird-thread-ui--scroll', 'sendbird-conversation__messages'), ref: scrollRef, onScroll: onScroll, dir: getHTMLTextDirection(config === null || config === void 0 ? void 0 : config.htmlTextDirection, config === null || config === void 0 ? void 0 : config.forceLeftToRightMessageLayout) }, React__default.createElement(MessageProvider, { message: parentMessage, isByMe: isByMe }, MemorizedParentMessageInfo), replyCount > 0 && (React__default.createElement("div", { className: "sendbird-thread-ui__reply-counts" }, React__default.createElement(Label, { type: LabelTypography.BODY_1, color: LabelColors.ONBACKGROUND_3 }, "".concat(replyCount, " ").concat(replyCount > 1 ? stringSet.THREAD__THREAD_REPLIES : stringSet.THREAD__THREAD_REPLY)))), MemorizedThreadList || (React__default.createElement(ThreadList, { className: "sendbird-thread-ui__thread-list", renderMessage: renderMessage, renderCustomSeparator: renderCustomSeparator, scrollRef: scrollRef, scrollBottom: scrollBottom }))), (renderMessageInput === null || renderMessageInput === void 0 ? void 0 : renderMessageInput()) || (React__default.createElement(ThreadMessageInput, { className: "sendbird-thread-ui__message-input", renderFileUploadIcon: renderFileUploadIcon, renderVoiceMessageIcon: renderVoiceMessageIcon, renderSendMessageIcon: renderSendMessageIcon })))); }; export { ThreadUI as default }; //# sourceMappingURL=ThreadUI.js.map