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