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-DxLnjDoJ.js'; import { g as getChannelTitle } from '../../chunks/bundle-DJzTnBLa.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-FZ_FdxZT.js'; import { i as isAboutSame } from '../../chunks/bundle-CM15Zz-B.js'; import { MessageProvider } from '../../Message/context.js'; import { O as getHTMLTextDirection } from '../../chunks/bundle-C5Cl3Igw.js'; import { c as classnames } from '../../chunks/bundle-CaW4IP0_.js'; import { u as useThread } from '../../chunks/bundle-D14uJuP3.js'; import { u as useSendbird } from '../../chunks/bundle-BnaoVUUl.js'; import '../../chunks/bundle-DlZj_j5B.js'; import '../../chunks/bundle-Dhutxl0X.js'; import '../../chunks/bundle-D89Qj0P4.js'; import '../../chunks/bundle-DQG1nDod.js'; import '../../chunks/bundle-0bJlK18Z.js'; import '../../chunks/bundle-opK13Cg3.js'; import '../../chunks/bundle-BDItDVZl.js'; import 'react-dom'; import '../../chunks/bundle-DWJPyrDa.js'; import '../../ui/IconButton.js'; import '../../ui/Button.js'; import '../../ui/Icon.js'; import '../../chunks/bundle-CSjCAZib.js'; import '../../chunks/bundle-s0NWd4qh.js'; import '../../chunks/bundle-DZaN4z9l.js'; import './ParentMessageInfoItem.js'; import '../../ui/ImageRenderer.js'; import '../../ui/TextButton.js'; import '../../chunks/bundle-Bv6iXkjg.js'; import '../../ui/EmojiReactions.js'; import '../../ui/ReactionBadge.js'; import '../../ui/ReactionButton.js'; import '../../chunks/bundle-B1FaeCoO.js'; import '../../chunks/bundle-BRB1saAI.js'; import '@sendbird/chat'; import '@sendbird/chat/openChannel'; import '../../ui/SortByRow.js'; import '../../chunks/bundle-C1jTnXNH.js'; import '../../chunks/bundle-C8kxBudB.js'; import '@sendbird/chat/groupChannel'; import '../../ui/BottomSheet.js'; import '../../hooks/useModal.js'; import '../../ui/UserListItem.js'; import '../../chunks/bundle-tDk7wyaM.js'; import '../../chunks/bundle-Dgt7lb2O.js'; import '../../chunks/bundle-h43SVTxb.js'; import '../../ui/MutedAvatarOverlay.js'; import '../../ui/Checkbox.js'; import '../../ui/UserProfile.js'; import '../../sendbirdSelectors.js'; import '../../chunks/bundle-D9lZlE3H.js'; import '../../utils/message/getOutgoingMessageState.js'; import '../../chunks/bundle-OJHU7Q3U.js'; import '../../ui/Tooltip.js'; import '../../ui/TooltipWrapper.js'; import '../../chunks/bundle-yGY7tz0s.js'; import '../../ui/VoiceMessageItemBody.js'; import '../../ui/ProgressBar.js'; import '../../VoicePlayer/useVoicePlayer.js'; import '../../chunks/bundle-DaRQ4hYm.js'; import '../../VoiceRecorder/context.js'; import '../../ui/PlaybackTime.js'; import '../../ui/Loader.js'; import '../../chunks/bundle-CR2Uxj3o.js'; import '../../chunks/bundle-l40KXk4C.js'; import '../../ui/MentionLabel.js'; import '../../ui/LinkLabel.js'; import '../../chunks/bundle-4KIPG09a.js'; import '@sendbird/chat/message'; import '../../ui/FileViewer.js'; import '../../chunks/bundle-86aNeIDh.js'; import '@sendbird/uikit-tools'; import '../../chunks/bundle-Zll3bhLI.js'; import '../../chunks/bundle-CQBvCw9O.js'; import '../../chunks/bundle-CG0xn0QL.js'; import '../../chunks/bundle-CqUKQRuq.js'; import '../../chunks/bundle-DaZcJrxP.js'; import '../../chunks/bundle-CVos_O7L.js'; import '../../chunks/bundle-LDv-FNzw.js'; import '../../ui/MessageItemReactionMenu.js'; import '../../ui/MessageInput.js'; import '../../chunks/bundle-ZgaJ1zMw.js'; import 'dompurify'; import '../../chunks/bundle-BtgjnqNn.js'; import '../../chunks/bundle-Bmy70Etb.js'; import '../../chunks/bundle-Cii8q6Vf.js'; import '../../chunks/bundle-dPnGsEg0.js'; import '../../ui/MobileMenu.js'; import '../../Message/hooks/useDirtyGetMentions.js'; import '../../chunks/bundle-QUj4_z_2.js'; import '../../chunks/bundle-DM0GI2HV.js'; import '../../chunks/bundle-njmblZhI.js'; import '../../ui/Header.js'; import './ThreadListItem.js'; import '../../ui/DateSeparator.js'; import '../../chunks/bundle-CZv_p-rQ.js'; import '../../chunks/bundle-P0PyHY_w.js'; import '../../chunks/bundle-DqCu8NcC.js'; import '../../chunks/bundle-B6_pp1pT.js'; import '../../ui/OGMessageItemBody.js'; import '../../ui/TextMessageItemBody.js'; import '../../ui/FileMessageItemBody.js'; import '../../ui/ThumbnailMessageItemBody.js'; import '../../chunks/bundle-BQDrTbuZ.js'; import '../../ui/UnknownMessageItemBody.js'; import '../../ui/TemplateMessageItemBody.js'; import '../../chunks/bundle-ChE9cvzN.js'; import '../../ui/FallbackTemplateMessageItemBody.tsx.js'; import '../../ui/LoadingTemplateMessageItemBody.tsx.js'; import '../../ui/MessageFeedbackFailedModal.js'; import '../../chunks/bundle-lyBHlixS.js'; import '../../Channel/utils/compareMessagesForGrouping.js'; import 'date-fns'; import '../../chunks/bundle-CEoddlc-.js'; import '../../GroupChannel/components/SuggestedMentionList.js'; import '../../ui/QuoteMessageInput.js'; import '../../VoiceRecorder/useVoiceRecorder.js'; import '../../chunks/bundle-C7zjmXlk.js'; import '../../chunks/bundle-WQ_CLl_f.js'; import '../../chunks/bundle-CXBvqtFA.js'; import '../../chunks/bundle-DPzvLwMf.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