@sendbird/uikit-react
Version:
Sendbird UIKit for React: A feature-rich and customizable chat UI kit with messaging, channel management, and user authentication.
350 lines (341 loc) • 21.4 kB
JavaScript
'use strict';
Object.defineProperty(exports, '__esModule', { value: true });
var React = require('react');
var Channel_context = require('../context.js');
var ui_PlaceHolder = require('../../ui/PlaceHolder.js');
var ui_Icon = require('../../ui/Icon.js');
var Channel_components_Message = require('./Message.js');
var types = require('../../chunks/bundle-BS4GiQtn.js');
var utils$1 = require('../../chunks/bundle-B78tdF27.js');
var GroupChannel_components_UnreadCount = require('../../GroupChannel/components/UnreadCount.js');
var GroupChannel_components_FrozenNotification = require('../../GroupChannel/components/FrozenNotification.js');
var consts = require('../../chunks/bundle-Cfh78Xnm.js');
var Message_context = require('../../Message/context.js');
var index = require('../../chunks/bundle-DsPceGve.js');
var useThrottleCallback = require('../../chunks/bundle-DNv-S_8I.js');
var ui_TypingIndicatorBubble = require('../../ui/TypingIndicatorBubble.js');
var index$1 = require('../../chunks/bundle-B9fRtMCR.js');
var Channel_utils_getMessagePartsInfo = require('../utils/getMessagePartsInfo.js');
var utils = require('../../chunks/bundle-CkQrhwR6.js');
var index$2 = require('../../chunks/bundle-fYxs1lss.js');
var useSendbird = require('../../chunks/bundle-Bq15P9qk.js');
var LocalizationContext = require('../../chunks/bundle-DPDyqKIJ.js');
require('../../chunks/bundle-Conb-pOy.js');
require('@sendbird/uikit-tools');
require('../../chunks/bundle-Bnb8seJF.js');
require('../../chunks/bundle-BLz2EOZ5.js');
require('../../chunks/bundle-CXbYckbN.js');
require('../../chunks/bundle-BbrBawlX.js');
require('../../chunks/bundle-CHAKEXIJ.js');
require('../../chunks/bundle-CVJwHwWn.js');
require('../../chunks/bundle-Cyl6_qLo.js');
require('@sendbird/chat/message');
require('../../chunks/bundle-Dobj18FB.js');
require('../../chunks/bundle-DGb1FlkJ.js');
require('../../chunks/bundle-CZ38Etcw.js');
require('@sendbird/chat/groupChannel');
require('../../chunks/bundle-t8BQsgL5.js');
require('../../chunks/bundle-C8INNeGk.js');
require('../../chunks/bundle-dUH189qO.js');
require('../../chunks/bundle-BPUhuptz.js');
require('../../chunks/bundle-BLLzQxHS.js');
require('../../utils/message/getOutgoingMessageState.js');
require('../../chunks/bundle-C6rru8Hj.js');
require('../../chunks/bundle-zgmRG2KL.js');
require('../../ui/Loader.js');
require('../../chunks/bundle-CPoi7VvJ.js');
require('../../chunks/bundle-PVDrKOjZ.js');
require('../../Message/hooks/useDirtyGetMentions.js');
require('../../ui/DateSeparator.js');
require('../../chunks/bundle-DurllD3r.js');
require('../../ui/MessageInput.js');
require('../../chunks/bundle-Bomzwcdt.js');
require('../../ui/IconButton.js');
require('../../ui/Button.js');
require('../../chunks/bundle-VKi81862.js');
require('dompurify');
require('../../chunks/bundle-DHuNGmIj.js');
require('../../chunks/bundle-2PCdBxVA.js');
require('../../chunks/bundle-BkgFGPs_.js');
require('../../chunks/bundle-CzkEKbFB.js');
require('../../chunks/bundle-DAdgL6r8.js');
require('../../chunks/bundle-B19RHFpR.js');
require('@sendbird/chat');
require('@sendbird/chat/openChannel');
require('../../ui/MessageContent.js');
require('../../chunks/bundle-DO5FgbkI.js');
require('../../chunks/bundle-ptQgj0WJ.js');
require('../../chunks/bundle-DQaXgp8o.js');
require('../../chunks/bundle-Y-wq3CF0.js');
require('../../chunks/bundle-DGV1BX0m.js');
require('react-dom');
require('../../ui/SortByRow.js');
require('../../ui/MessageItemReactionMenu.js');
require('../../ui/ImageRenderer.js');
require('../../ui/ReactionButton.js');
require('../../chunks/bundle-C5p82xwC.js');
require('../../chunks/bundle-Fv6PNPGZ.js');
require('../../ui/EmojiReactions.js');
require('../../ui/ReactionBadge.js');
require('../../ui/BottomSheet.js');
require('../../hooks/useModal.js');
require('../../chunks/bundle-DZlJeh0V.js');
require('../../ui/UserListItem.js');
require('../../chunks/bundle-B7KG10z2.js');
require('../../chunks/bundle-C99t7tzf.js');
require('../../ui/MutedAvatarOverlay.js');
require('../../ui/Checkbox.js');
require('../../ui/UserProfile.js');
require('../../sendbirdSelectors.js');
require('../../ui/Tooltip.js');
require('../../ui/TooltipWrapper.js');
require('../../ui/AdminMessage.js');
require('../../ui/QuoteMessage.js');
require('../../chunks/bundle-D9d0Qum8.js');
require('../../ui/MobileMenu.js');
require('../../ui/ThreadReplies.js');
require('../../chunks/bundle-DYon6O60.js');
require('../../ui/OGMessageItemBody.js');
require('../../chunks/bundle-CX7K4z2J.js');
require('../../ui/MentionLabel.js');
require('../../ui/LinkLabel.js');
require('../../ui/TextMessageItemBody.js');
require('../../ui/FileMessageItemBody.js');
require('../../ui/TextButton.js');
require('../../chunks/bundle-KzwW_H6y.js');
require('../../ui/FileViewer.js');
require('../../chunks/bundle-Yq_R9TAN.js');
require('../../ui/VoiceMessageItemBody.js');
require('../../ui/ProgressBar.js');
require('../../VoicePlayer/useVoicePlayer.js');
require('../../chunks/bundle-BHp3N9Mz.js');
require('../../VoiceRecorder/context.js');
require('../../ui/PlaybackTime.js');
require('../../ui/ThumbnailMessageItemBody.js');
require('../../ui/UnknownMessageItemBody.js');
require('../../ui/TemplateMessageItemBody.js');
require('../../chunks/bundle-Bt1qvip8.js');
require('../../ui/FallbackTemplateMessageItemBody.tsx.js');
require('../../ui/LoadingTemplateMessageItemBody.tsx.js');
require('../../ui/MessageFeedbackFailedModal.js');
require('../../ui/FeedbackIconButton.js');
require('../../ui/MobileFeedbackMenu.js');
require('../../ui/MessageFeedbackModal.js');
require('../../ui/Input.js');
require('../../chunks/bundle-BwwNS3QS.js');
require('../../GroupChannel/components/SuggestedReplies.js');
require('../../chunks/bundle-B7tlFbQZ.js');
require('./FileViewer.js');
require('../../chunks/bundle-8juyGk3c.js');
require('./RemoveMessageModal.js');
require('../../chunks/bundle-COgAaDxc.js');
require('../../chunks/bundle-B2b-r84m.js');
require('../utils/compareMessagesForGrouping.js');
function _interopDefaultCompat (e) { return e && typeof e === 'object' && 'default' in e ? e : { default: e }; }
var React__default = /*#__PURE__*/_interopDefaultCompat(React);
var DELAY = 100;
function useSetScrollToBottom(_a) {
var loading = _a.loading;
var _b = React.useState(0), scrollBottom = _b[0], setScrollBottom = _b[1];
React.useEffect(function () {
if (loading) {
setScrollBottom(0);
}
}, [loading]);
var scrollCb = function (e) {
var element = e.target;
try {
setScrollBottom(element.scrollHeight - element.scrollTop - element.offsetHeight);
}
catch (_a) {
//
}
};
return {
scrollBottom: scrollBottom,
scrollToBottomHandler: useThrottleCallback.useThrottleCallback(scrollCb, DELAY, { trailing: true }),
};
}
function useScrollBehavior() {
var _a = Channel_context.useChannelContext(), scrollRef = _a.scrollRef, _b = _a.scrollBehavior, scrollBehavior = _b === void 0 ? 'auto' : _b;
React.useEffect(function () {
if (scrollRef.current) {
scrollRef.current.style.scrollBehavior = scrollBehavior;
}
}, [scrollRef.current]);
return null;
}
/* We operate the CSS files for Channel&GroupChannel modules in the GroupChannel */
var SCROLL_BOTTOM_PADDING = 50;
/**
* @deprecated This component is deprecated and will be removed in the next major update.
* Please use the `GroupChannel` component from '@sendbird/uikit-react/GroupChannel' instead.
* For more information, please refer to the migration guide:
* https://docs.sendbird.com/docs/chat/uikit/v3/react/introduction/group-channel-migration-guide
*/
var MessageList = function (props) {
var _a, _b, _c, _d, _e, _f, _g;
var _h = props.className, className = _h === void 0 ? '' : _h;
var _j = utils.deleteNullish(props), renderMessage = _j.renderMessage, renderMessageContent = _j.renderMessageContent, renderSuggestedReplies = _j.renderSuggestedReplies, renderCustomSeparator = _j.renderCustomSeparator, _k = _j.renderPlaceholderLoader, renderPlaceholderLoader = _k === void 0 ? function () { return React__default.default.createElement(ui_PlaceHolder.default, { type: ui_PlaceHolder.PlaceHolderTypes.LOADING }); } : _k, _l = _j.renderPlaceholderEmpty, renderPlaceholderEmpty = _l === void 0 ? function () { return React__default.default.createElement(ui_PlaceHolder.default, { className: "sendbird-conversation__no-messages", type: ui_PlaceHolder.PlaceHolderTypes.NO_MESSAGES }); } : _l, _m = _j.renderFrozenNotification, renderFrozenNotification = _m === void 0 ? function () { return React__default.default.createElement(GroupChannel_components_FrozenNotification.FrozenNotification, { className: "sendbird-conversation__messages__notification" }); } : _m;
var _o = Channel_context.useChannelContext(), allMessages = _o.allMessages, localMessages = _o.localMessages, hasMorePrev = _o.hasMorePrev, hasMoreNext = _o.hasMoreNext, setInitialTimeStamp = _o.setInitialTimeStamp, setAnimatedMessageId = _o.setAnimatedMessageId, setHighLightedMessageId = _o.setHighLightedMessageId, isMessageGroupingEnabled = _o.isMessageGroupingEnabled, scrollRef = _o.scrollRef, onScrollCallback = _o.onScrollCallback, onScrollDownCallback = _o.onScrollDownCallback, messagesDispatcher = _o.messagesDispatcher, messageActionTypes = _o.messageActionTypes, currentGroupChannel = _o.currentGroupChannel, disableMarkAsRead = _o.disableMarkAsRead, filterMessageList = _o.filterMessageList, replyType = _o.replyType, loading = _o.loading, isScrolled = _o.isScrolled, unreadSince = _o.unreadSince, unreadSinceDate = _o.unreadSinceDate, typingMembers = _o.typingMembers;
var store = useSendbird.useSendbird().state;
var stringSet = LocalizationContext.useLocalization().stringSet;
var allMessagesFiltered = typeof filterMessageList === 'function' ? allMessages.filter(filterMessageList) : allMessages;
var markAsReadScheduler = store.config.markAsReadScheduler;
var _p = React.useState(false), isScrollBottom = _p[0], setIsScrollBottom = _p[1];
useScrollBehavior();
/**
* @param {function} callback callback from useHandleOnScrollCallback, it adjusts scroll position
* */
var onScroll = function (callback) {
var element = scrollRef === null || scrollRef === void 0 ? void 0 : scrollRef.current;
if (element == null) {
return;
}
var scrollTop = element.scrollTop, clientHeight = element.clientHeight, scrollHeight = element.scrollHeight;
if (hasMorePrev && utils$1.isAboutSame(scrollTop, 0, consts.SCROLL_BUFFER)) {
onScrollCallback(callback);
}
if (hasMoreNext && utils$1.isAboutSame(clientHeight + scrollTop, scrollHeight, consts.SCROLL_BUFFER)) {
onScrollDownCallback(callback);
}
if (!disableMarkAsRead && utils$1.isAboutSame(clientHeight + scrollTop, scrollHeight, consts.SCROLL_BUFFER) && !!currentGroupChannel) {
messagesDispatcher({
type: messageActionTypes.MARK_AS_READ,
payload: { channel: currentGroupChannel },
});
markAsReadScheduler.push(currentGroupChannel);
}
};
var onClickScrollBot = function () {
var _a, _b;
setInitialTimeStamp === null || setInitialTimeStamp === void 0 ? void 0 : setInitialTimeStamp(null);
setAnimatedMessageId === null || setAnimatedMessageId === void 0 ? void 0 : setAnimatedMessageId(null);
setHighLightedMessageId === null || setHighLightedMessageId === void 0 ? void 0 : setHighLightedMessageId(null);
if (scrollRef.current && scrollRef.current.scrollTop > -1) {
scrollRef.current.scrollTop = ((_a = scrollRef.current.scrollHeight) !== null && _a !== void 0 ? _a : 0) - ((_b = scrollRef.current.offsetHeight) !== null && _b !== void 0 ? _b : 0);
}
};
/**
* 1. Move the messsage list scroll
* when each message's height is changed by `reactions` OR `showEdit`
* 2. Keep the scrollBottom value after fetching new message list
*/
var moveScroll = function (isBottomMessageAffected) {
if (isBottomMessageAffected === void 0) { isBottomMessageAffected = false; }
var current = scrollRef === null || scrollRef === void 0 ? void 0 : scrollRef.current;
if (current) {
var bottom = current.scrollHeight - current.scrollTop - current.offsetHeight;
if (scrollBottom < bottom && (!isBottomMessageAffected || scrollBottom < consts.SCROLL_BUFFER)) {
// Move the scroll as much as the height of the message has changed
current.scrollTop += bottom - scrollBottom;
}
}
};
var handleOnScroll = index.useHandleOnScrollCallback({
hasMore: hasMorePrev,
hasNext: hasMoreNext,
onScroll: onScroll,
scrollRef: scrollRef,
});
var onScrollReachedEndDetector = index$1.useOnScrollPositionChangeDetector({
onReachedBottom: function () {
/**
* Note that this event is already being called in onScroll() above. However, it is only being called when
* hasMoreNext is true but it needs to be called when hasNext is false when reached bottom as well.
*/
if (!hasMoreNext && !disableMarkAsRead && !!currentGroupChannel) {
messagesDispatcher({
type: messageActionTypes.MARK_AS_READ,
payload: { channel: currentGroupChannel },
});
markAsReadScheduler.push(currentGroupChannel);
}
setIsScrollBottom(true);
},
onReachedTop: function () {
setIsScrollBottom(false);
},
onInBetween: function () {
setIsScrollBottom(false);
},
});
var _q = useSetScrollToBottom({ loading: loading }), scrollToBottomHandler = _q.scrollToBottomHandler, scrollBottom = _q.scrollBottom;
if (loading) {
return renderPlaceholderLoader();
}
if (allMessagesFiltered.length < 1) {
return renderPlaceholderEmpty();
}
return (React__default.default.createElement(React__default.default.Fragment, null,
!isScrolled && React__default.default.createElement(ui_PlaceHolder.default, { type: ui_PlaceHolder.PlaceHolderTypes.LOADING }),
React__default.default.createElement("div", { className: "sendbird-conversation__messages ".concat(className), dir: index$2.getHTMLTextDirection((_a = store === null || store === void 0 ? void 0 : store.config) === null || _a === void 0 ? void 0 : _a.htmlTextDirection, (_b = store === null || store === void 0 ? void 0 : store.config) === null || _b === void 0 ? void 0 : _b.forceLeftToRightMessageLayout) },
React__default.default.createElement("div", { className: "sendbird-conversation__scroll-container" },
React__default.default.createElement("div", { className: "sendbird-conversation__padding" }),
React__default.default.createElement("div", { className: "sendbird-conversation__messages-padding", "data-testid": "sendbird-message-list-container", ref: scrollRef, onScroll: function (e) {
handleOnScroll();
scrollToBottomHandler(e);
onScrollReachedEndDetector(e);
} },
allMessagesFiltered.map(function (m, idx) {
var _a, _b;
var _c = Channel_utils_getMessagePartsInfo.getMessagePartsInfo({
allMessages: allMessagesFiltered,
stringSet: stringSet,
replyType: replyType,
isMessageGroupingEnabled: isMessageGroupingEnabled,
currentIndex: idx,
currentMessage: m,
currentChannel: currentGroupChannel,
}), chainTop = _c.chainTop, chainBottom = _c.chainBottom, hasSeparator = _c.hasSeparator;
var isByMe = ((_a = m === null || m === void 0 ? void 0 : m.sender) === null || _a === void 0 ? void 0 : _a.userId) === ((_b = store === null || store === void 0 ? void 0 : store.config) === null || _b === void 0 ? void 0 : _b.userId);
return (React__default.default.createElement(Message_context.MessageProvider, { message: m, key: m === null || m === void 0 ? void 0 : m.messageId, isByMe: isByMe },
React__default.default.createElement(Channel_components_Message, { handleScroll: moveScroll, message: m, hasSeparator: hasSeparator, chainTop: chainTop, chainBottom: chainBottom, renderMessageContent: renderMessageContent, renderSuggestedReplies: renderSuggestedReplies, renderCustomSeparator: renderCustomSeparator,
// backward compatibility
renderMessage: renderMessage })));
}),
localMessages.map(function (m, idx) {
var _a, _b;
var _c = Channel_utils_getMessagePartsInfo.getMessagePartsInfo({
allMessages: allMessagesFiltered,
stringSet: stringSet,
replyType: replyType,
isMessageGroupingEnabled: isMessageGroupingEnabled,
currentIndex: idx,
currentMessage: m,
currentChannel: currentGroupChannel,
}), chainTop = _c.chainTop, chainBottom = _c.chainBottom;
var isByMe = ((_a = m === null || m === void 0 ? void 0 : m.sender) === null || _a === void 0 ? void 0 : _a.userId) === ((_b = store === null || store === void 0 ? void 0 : store.config) === null || _b === void 0 ? void 0 : _b.userId);
return (React__default.default.createElement(Message_context.MessageProvider, { message: m, key: m === null || m === void 0 ? void 0 : m.messageId, isByMe: isByMe },
React__default.default.createElement(Channel_components_Message, { handleScroll: moveScroll, message: m, chainTop: chainTop, chainBottom: chainBottom, renderMessageContent: renderMessageContent, renderSuggestedReplies: renderSuggestedReplies, renderCustomSeparator: renderCustomSeparator,
// backward compatibility
renderMessage: renderMessage })));
}),
!hasMoreNext
&& ((_d = (_c = store === null || store === void 0 ? void 0 : store.config) === null || _c === void 0 ? void 0 : _c.groupChannel) === null || _d === void 0 ? void 0 : _d.enableTypingIndicator)
&& ((_g = (_f = (_e = store === null || store === void 0 ? void 0 : store.config) === null || _e === void 0 ? void 0 : _e.groupChannel) === null || _f === void 0 ? void 0 : _f.typingIndicatorTypes) === null || _g === void 0 ? void 0 : _g.has(types.TypingIndicatorType.Bubble)) && (React__default.default.createElement(ui_TypingIndicatorBubble, { typingMembers: typingMembers, handleScroll: moveScroll })))),
(currentGroupChannel === null || currentGroupChannel === void 0 ? void 0 : currentGroupChannel.isFrozen) && renderFrozenNotification(),
/**
* Show unread count IFF scroll is not bottom or is bottom but hasNext is true.
*/
(!isScrollBottom || hasMoreNext) && (unreadSince || unreadSinceDate) && (React__default.default.createElement(GroupChannel_components_UnreadCount.UnreadCount, { className: "sendbird-conversation__messages__notification", count: currentGroupChannel === null || currentGroupChannel === void 0 ? void 0 : currentGroupChannel.unreadMessageCount, time: unreadSince, lastReadAt: unreadSinceDate, onClick: function () {
if (scrollRef === null || scrollRef === void 0 ? void 0 : scrollRef.current)
scrollRef.current.scrollTop = scrollRef.current.scrollHeight;
if (!disableMarkAsRead && !!currentGroupChannel) {
markAsReadScheduler.push(currentGroupChannel);
messagesDispatcher({
type: messageActionTypes.MARK_AS_READ,
payload: { channel: currentGroupChannel },
});
}
setInitialTimeStamp(null);
setAnimatedMessageId(null);
setHighLightedMessageId(null);
} })),
// This flag is an unmatched variable
scrollBottom > SCROLL_BOTTOM_PADDING && (React__default.default.createElement("div", { className: "sendbird-conversation__scroll-bottom-button", onClick: onClickScrollBot, onKeyDown: onClickScrollBot, tabIndex: 0, role: "button" },
React__default.default.createElement(ui_Icon.default, { width: "24px", height: "24px", type: ui_Icon.IconTypes.CHEVRON_DOWN, fillColor: ui_Icon.IconColors.PRIMARY }))))));
};
exports.MessageList = MessageList;
exports.default = MessageList;
//# sourceMappingURL=MessageList.js.map