UNPKG

@sendbird/uikit-react

Version:

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

199 lines (196 loc) 15.7 kB
import { a as __awaiter, b as __generator } from '../../chunks/bundle-yl5d1NoZ.js'; import React__default, { useMemo, useState } from 'react'; import { u as useLocalization } from '../../chunks/bundle-Del33VzI.js'; import { n as isUserMessage, f as isEditedMessage, o as getUIKitMessageType, p as getUIKitMessageTypes, q as getUIKitFileType, t as truncateString, e as isMultipleFilesMessage, i as isVoiceMessage, r as isThumbnailMessage, s as isSentMessage, u as isVideoMessage, v as isGifMessage, d as isFileMessage } from '../../chunks/bundle-vmZ9LoYK.js'; import { L as Label, a as LabelTypography, b as LabelColors } from '../../chunks/bundle-viBng0Kh.js'; import ImageRenderer from '../../ui/ImageRenderer.js'; import Icon, { IconTypes, IconColors } from '../../ui/Icon.js'; import TextButton from '../../ui/TextButton.js'; import EmojiReactions from '../../ui/EmojiReactions.js'; import { VoiceMessageItemBody } from '../../ui/VoiceMessageItemBody.js'; import { T as TextFragment } from '../../chunks/bundle-DcLgcUpC.js'; import { t as tokenizeMessage } from '../../chunks/bundle-BwvurfUT.js'; import { u as useThreadMessageKindKeySelector, a as useFileInfoListWithUploaded, M as MultipleFilesMessageItemBody, T as ThreadMessageKind } from '../../chunks/bundle-HwtLrcpn.js'; import { u as useMediaQueryContext } from '../../chunks/bundle-DBhJIxHw.js'; import { C as Colors } from '../../chunks/bundle-Bokm7tQ9.js'; import { o as openURL } 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-C1dqPUnT.js'; import '../../chunks/bundle-BZGITC2g.js'; import '@sendbird/chat/groupChannel'; import '../../utils/message/getOutgoingMessageState.js'; import '../../chunks/bundle-DgosLQK9.js'; import '../../chunks/bundle-DEuCwnTn.js'; import '../../chunks/bundle-fdEQfX2s.js'; import '../../chunks/bundle-CqLLOVG5.js'; import '../../ui/ReactionBadge.js'; import '../../ui/ReactionButton.js'; import '../../chunks/bundle-Ba_cV-Zm.js'; import '../../chunks/bundle-Bch_Ry4S.js'; import 'react-dom'; import '@sendbird/chat'; import '@sendbird/chat/openChannel'; import '../../ui/SortByRow.js'; import '../../chunks/bundle-DGh2T5IL.js'; import '../../ui/IconButton.js'; import '../../chunks/bundle-BUYU9H94.js'; import '../../ui/BottomSheet.js'; import '../../hooks/useModal.js'; import '../../chunks/bundle-CtQtfJlT.js'; import '../../ui/Button.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 '../../ui/Tooltip.js'; import '../../ui/TooltipWrapper.js'; import '../../Message/context.js'; import '../../chunks/bundle-BSy5MmTl.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 '../../ui/MentionLabel.js'; import '../../ui/LinkLabel.js'; import '@sendbird/chat/message'; import '../../ui/FileViewer.js'; import '../../chunks/bundle-Ha1krmtK.js'; import '@sendbird/uikit-tools'; import '../../chunks/bundle-CIQCAe1h.js'; import '../../chunks/bundle-DFni3Lhf.js'; import '../../chunks/bundle-CM73CDTO.js'; import '../context/types.js'; import '../../chunks/bundle-BmoSvBYM.js'; function ParentMessageInfoItem(_a) { var _this = this; var _b, _c, _d, _e, _f, _g, _h, _j; var className = _a.className, message = _a.message, showFileViewer = _a.showFileViewer, _k = _a.onBeforeDownloadFileMessage, onBeforeDownloadFileMessage = _k === void 0 ? null : _k; var _l = useSendbird().state, stores = _l.stores, config = _l.config, eventHandlers = _l.eventHandlers; var logger = config.logger; var onPressUserProfileHandler = (_b = eventHandlers === null || eventHandlers === void 0 ? void 0 : eventHandlers.reaction) === null || _b === void 0 ? void 0 : _b.onPressUserProfile; var currentUserId = (_d = (_c = stores === null || stores === void 0 ? void 0 : stores.userStore) === null || _c === void 0 ? void 0 : _c.user) === null || _d === void 0 ? void 0 : _d.userId; var stringSet = useLocalization().stringSet; var _m = useThread(), _o = _m.state, currentChannel = _o.currentChannel, emojiContainer = _o.emojiContainer, nicknamesMap = _o.nicknamesMap, filterEmojiCategoryIds = _o.filterEmojiCategoryIds, toggleReaction = _m.actions.toggleReaction; var isMobile = useMediaQueryContext().isMobile; var isReactionEnabled = config.groupChannel.enableReactions; var isMentionEnabled = config.groupChannel.enableMention; var threadMessageKindKey = useThreadMessageKindKeySelector({ threadMessageKind: ThreadMessageKind.PARENT, isMobile: isMobile, }); // For MultipleFilesMessage only. var statefulFileInfoList = useFileInfoListWithUploaded(message); var isMentionedMessage = isMentionEnabled && (message === null || message === void 0 ? void 0 : message.isUserMessage()) && ((_e = message === null || message === void 0 ? void 0 : message.mentionedMessageTemplate) === null || _e === void 0 ? void 0 : _e.length) > 0 && (message === null || message === void 0 ? void 0 : message.mentionedUsers) && message.mentionedUsers.length > 0; // Emoji reactions var isReactionActivated = isReactionEnabled && config.groupChannel.replyType === 'thread' && ((_f = message === null || message === void 0 ? void 0 : message.reactions) === null || _f === void 0 ? void 0 : _f.length) > 0; var tokens = useMemo(function () { var _a; if (isMentionedMessage) { return tokenizeMessage({ mentionedUsers: (_a = message === null || message === void 0 ? void 0 : message.mentionedUsers) !== null && _a !== void 0 ? _a : undefined, messageText: message === null || message === void 0 ? void 0 : message.mentionedMessageTemplate, includeMarkdown: config.groupChannel.enableMarkdownForUserMessage, }); } return tokenizeMessage({ messageText: message === null || message === void 0 ? void 0 : message.message, includeMarkdown: config.groupChannel.enableMarkdownForUserMessage, }); }, [message === null || message === void 0 ? void 0 : message.updatedAt, message === null || message === void 0 ? void 0 : message.message]); // Only for the FileMessageItemBody var downloadFileWithUrl = function () { if (isFileMessage(message)) openURL(message.url); }; var handleOnClickTextButton = onBeforeDownloadFileMessage ? function () { return __awaiter(_this, void 0, void 0, function () { var allowDownload, err_1; var _a, _b; return __generator(this, function (_c) { switch (_c.label) { case 0: if (!(message.messageType === 'file')) return [3 /*break*/, 4]; _c.label = 1; case 1: _c.trys.push([1, 3, , 4]); return [4 /*yield*/, onBeforeDownloadFileMessage({ message: message })]; case 2: allowDownload = _c.sent(); if (allowDownload) { downloadFileWithUrl(); } else { (_a = logger === null || logger === void 0 ? void 0 : logger.info) === null || _a === void 0 ? void 0 : _a.call(logger, 'ParentMessageInfoItem: Not allowed to download.'); } return [3 /*break*/, 4]; case 3: err_1 = _c.sent(); (_b = logger === null || logger === void 0 ? void 0 : logger.error) === null || _b === void 0 ? void 0 : _b.call(logger, 'ParentMessageInfoItem: Error occurred while determining download continuation:', err_1); return [3 /*break*/, 4]; case 4: return [2 /*return*/]; } }); }); } : downloadFileWithUrl; // Thumbnail mesage var _p = useState(false), isImageRendered = _p[0], setImageRendered = _p[1]; var thumbnailUrl = ((_g = message === null || message === void 0 ? void 0 : message.thumbnails) === null || _g === void 0 ? void 0 : _g.length) > 0 ? (_h = message === null || message === void 0 ? void 0 : message.thumbnails[0]) === null || _h === void 0 ? void 0 : _h.url : ''; return (React__default.createElement("div", { className: "sendbird-parent-message-info-item ".concat(className) }, isUserMessage(message) && (React__default.createElement(Label, { className: "sendbird-parent-message-info-item__text-message", type: LabelTypography.BODY_1, color: LabelColors.ONBACKGROUND_1 }, React__default.createElement(TextFragment, { tokens: tokens }), isEditedMessage(message) && (React__default.createElement(Label, { className: "sendbird-parent-message-info-item__text-message edited", type: LabelTypography.BODY_1, color: LabelColors.ONBACKGROUND_2 }, " ".concat(stringSet.MESSAGE_EDITED, " "))))), // Instead of the FileMessageItemBody component (getUIKitMessageType(message) === getUIKitMessageTypes().FILE) && (React__default.createElement("div", { className: "sendbird-parent-message-info-item__file-message" }, React__default.createElement("div", { className: "sendbird-parent-message-info-item__file-message__file-icon" }, React__default.createElement(Icon, { className: "sendbird-parent-message-info-item__file-message__file-icon__icon", type: { IMAGE: IconTypes.PHOTO, VIDEO: IconTypes.PLAY, AUDIO: IconTypes.FILE_AUDIO, GIF: IconTypes.GIF, OTHERS: IconTypes.FILE_DOCUMENT, }[getUIKitFileType(message === null || message === void 0 ? void 0 : message.type)], fillColor: IconColors.PRIMARY, width: "24px", height: "24px" })), React__default.createElement(TextButton, { className: "sendbird-parent-message-info-item__file-message__file-name", onClick: handleOnClickTextButton, color: Colors.ONBACKGROUND_1 }, React__default.createElement(Label, { className: "sendbird-parent-message-info-item__file-message__file-name__text", type: LabelTypography.BODY_1, color: LabelColors.ONBACKGROUND_1 }, truncateString((message === null || message === void 0 ? void 0 : message.name) || (message === null || message === void 0 ? void 0 : message.url), 30))))), isMultipleFilesMessage(message) && (React__default.createElement(MultipleFilesMessageItemBody, { className: "sendbird-parent-message-info-item__multiple-files-message-wrapper", message: message, isByMe: false, isReactionEnabled: isReactionEnabled, threadMessageKindKey: threadMessageKindKey, statefulFileInfoList: statefulFileInfoList, onBeforeDownloadFileMessage: onBeforeDownloadFileMessage })), isVoiceMessage(message) && (React__default.createElement("div", { className: "sendbird-parent-message-info-item__voice-message" }, React__default.createElement(VoiceMessageItemBody, { className: "sendbird-parent-message-info-item__voice-message__item", message: message, channelUrl: currentChannel === null || currentChannel === void 0 ? void 0 : currentChannel.url, isByMe: false, isReactionEnabled: isReactionEnabled }))), isThumbnailMessage(message) && (React__default.createElement("div", { className: "sendbird-parent-message-info-item__thumbnail-message", onClick: function () { if (isSentMessage(message)) { showFileViewer === null || showFileViewer === void 0 ? void 0 : showFileViewer(true); } } }, React__default.createElement(ImageRenderer, { className: "sendbird-parent-message-info-item__thumbnail-message__thumbnail", url: thumbnailUrl || (message === null || message === void 0 ? void 0 : message.url) || (message === null || message === void 0 ? void 0 : message.plainUrl), alt: message === null || message === void 0 ? void 0 : message.type, width: "200px", height: "148px", onLoad: function () { setImageRendered(true); }, placeHolder: function (_a) { var style = _a.style; return (React__default.createElement("div", { className: "sendbird-parent-message-info-item__thumbnail-message__placeholder", style: style }, React__default.createElement("div", { className: "sendbird-parent-message-info-item__thumbnail-message__placeholder__icon" }, React__default.createElement(Icon, { type: isVideoMessage(message) ? IconTypes.PLAY : IconTypes.PHOTO, fillColor: IconColors.ON_BACKGROUND_2, width: "34px", height: "34px" })))); } }), (isVideoMessage(message) && !thumbnailUrl) && !isImageRendered && (React__default.createElement("video", { className: "sendbird-parent-message-info-item__thumbnail-message__video" }, React__default.createElement("source", { src: (message === null || message === void 0 ? void 0 : message.url) || (message === null || message === void 0 ? void 0 : message.plainUrl), type: message === null || message === void 0 ? void 0 : message.type }))), React__default.createElement("div", { className: "sendbird-parent-message-info-item__thumbnail-message__image-cover" }), (isVideoMessage(message) || isGifMessage(message)) && (React__default.createElement("div", { className: "sendbird-parent-message-info-item__thumbnail-message__icon-wrapper" }, React__default.createElement("div", { className: "sendbird-parent-message-info-item__thumbnail-message__icon-wrapper__icon" }, React__default.createElement(Icon, { type: isVideoMessage(message) ? IconTypes.PLAY : IconTypes.GIF, fillColor: IconColors.ON_BACKGROUND_2, width: "34px", height: "34px" })))))), getUIKitMessageType(message) === ((_j = getUIKitMessageTypes === null || getUIKitMessageTypes === void 0 ? void 0 : getUIKitMessageTypes()) === null || _j === void 0 ? void 0 : _j.UNKNOWN) && (React__default.createElement("div", { className: "sendbird-parent-message-info-item__unknown-message" }, React__default.createElement(Label, { className: "sendbird-parent-message-info-item__unknown-message__header", type: LabelTypography.BODY_1, color: LabelColors.ONBACKGROUND_1 }, stringSet.UNKNOWN__UNKNOWN_MESSAGE_TYPE), React__default.createElement(Label, { className: "sendbird-parent-message-info-item__unknown-message__description", type: LabelTypography.BODY_1, color: LabelColors.ONBACKGROUND_2 }, stringSet.UNKNOWN__CANNOT_READ_MESSAGE))), isReactionActivated && (React__default.createElement("div", { className: "sendbird-parent-message-info__reactions" }, React__default.createElement(EmojiReactions, { userId: currentUserId, message: message, channel: currentChannel, isByMe: false, emojiContainer: emojiContainer, memberNicknamesMap: nicknamesMap, toggleReaction: toggleReaction, onPressUserProfile: onPressUserProfileHandler, filterEmojiCategoryIds: filterEmojiCategoryIds }))))); } export { ParentMessageInfoItem as default }; //# sourceMappingURL=ParentMessageInfoItem.js.map