@sendbird/uikit-react
Version:
Sendbird UIKit for React: A feature-rich and customizable chat UI kit with messaging, channel management, and user authentication.
77 lines (74 loc) • 4.33 kB
JavaScript
import React__default, { useContext, useMemo } from 'react';
import { L as Label, a as LabelTypography, b as LabelColors } from '../chunks/bundle-viBng0Kh.js';
import { z as getClassName, f as isEditedMessage } from '../chunks/bundle-vmZ9LoYK.js';
import { L as LocalizationContext } from '../chunks/bundle-Del33VzI.js';
import { t as tokenizeMessage } from '../chunks/bundle-BwvurfUT.js';
import { T as TextFragment } from '../chunks/bundle-DcLgcUpC.js';
import { T as TEXT_MESSAGE_BODY_CLASSNAME } from '../chunks/bundle-B6udMinl.js';
import '../chunks/bundle-yl5d1NoZ.js';
import '../chunks/bundle-C1dqPUnT.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 '../chunks/bundle-BZGITC2g.js';
import '../Message/context.js';
import './MentionLabel.js';
import '../chunks/bundle-Bch_Ry4S.js';
import 'react-dom';
import '../chunks/bundle-MlG9piGf.js';
import '@sendbird/chat';
import '@sendbird/chat/openChannel';
import './SortByRow.js';
import '../chunks/bundle-DGh2T5IL.js';
import './IconButton.js';
import '../chunks/bundle-BUYU9H94.js';
import './UserProfile.js';
import '../chunks/bundle-B0s_McF0.js';
import '../chunks/bundle-i_3w58Zd.js';
import '../sendbirdSelectors.js';
import '../chunks/bundle-BOykFtQ3.js';
import '../chunks/bundle-CAEBoiEz.js';
import './ImageRenderer.js';
import '../chunks/bundle-Dl_v8XoN.js';
import './Icon.js';
import './Button.js';
import './LinkLabel.js';
function TextMessageItemBody(_a) {
var _b;
var _c = _a.className, className = _c === void 0 ? '' : _c, message = _a.message, _d = _a.isByMe, isByMe = _d === void 0 ? false : _d, _e = _a.mouseHover, mouseHover = _e === void 0 ? false : _e, _f = _a.isMentionEnabled, isMentionEnabled = _f === void 0 ? false : _f, _g = _a.isReactionEnabled, isReactionEnabled = _g === void 0 ? false : _g, _h = _a.isMarkdownEnabled, isMarkdownEnabled = _h === void 0 ? false : _h;
var stringSet = useContext(LocalizationContext).stringSet;
var isMessageMentioned = isMentionEnabled
&& (message === null || message === void 0 ? void 0 : message.mentionedMessageTemplate)
&& message.mentionedMessageTemplate.length > 0
&& (message === null || message === void 0 ? void 0 : message.mentionedUsers)
&& message.mentionedUsers.length > 0;
var tokens = useMemo(function () {
var _a;
if (isMessageMentioned) {
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: isMarkdownEnabled,
});
}
return tokenizeMessage({
messageText: message === null || message === void 0 ? void 0 : message.message,
includeMarkdown: isMarkdownEnabled,
});
}, [message === null || message === void 0 ? void 0 : message.updatedAt, message === null || message === void 0 ? void 0 : message.message]);
return (React__default.createElement(Label, { type: LabelTypography.BODY_1, color: isByMe ? LabelColors.ONCONTENT_1 : LabelColors.ONBACKGROUND_1 },
React__default.createElement("div", { className: getClassName([
className,
TEXT_MESSAGE_BODY_CLASSNAME,
isByMe ? 'outgoing' : 'incoming',
mouseHover ? 'mouse-hover' : '',
(isReactionEnabled && ((_b = message === null || message === void 0 ? void 0 : message.reactions) === null || _b === void 0 ? void 0 : _b.length) > 0) ? 'reactions' : '',
]) },
React__default.createElement(TextFragment, { tokens: tokens }),
isEditedMessage(message) && (React__default.createElement(Label, { className: "sendbird-text-message-item-body__message edited", type: LabelTypography.BODY_1, color: isByMe ? LabelColors.ONCONTENT_2 : LabelColors.ONBACKGROUND_2 }, " ".concat(stringSet.MESSAGE_EDITED, " "))))));
}
export { TextMessageItemBody as default };
//# sourceMappingURL=TextMessageItemBody.js.map