@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
JavaScript
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