UNPKG

@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
import React__default, { useContext, useMemo } from 'react'; import { L as Label, a as LabelTypography, b as LabelColors } from '../chunks/bundle-sYB0sr_l.js'; import { y as getClassName, e as isEditedMessage } from '../chunks/bundle-D4ssOJFH.js'; import { L as LocalizationContext } from '../chunks/bundle-DVsUiVO7.js'; import { t as tokenizeMessage } from '../chunks/bundle-BqgOvZNO.js'; import { T as TextFragment } from '../chunks/bundle-B4lXe9Vx.js'; import { T as TEXT_MESSAGE_BODY_CLASSNAME } from '../chunks/bundle-DJDLoCXy.js'; import '../chunks/bundle-B7RvGM03.js'; import '../chunks/bundle-B4JqClb8.js'; import '@sendbird/chat/groupChannel'; import '../utils/message/getOutgoingMessageState.js'; import '../chunks/bundle-DHiHHi0U.js'; import '../chunks/bundle-jVso52Zj.js'; import '../chunks/bundle-BGdOmHwC.js'; import '../chunks/bundle-DwUX_8pX.js'; import '../chunks/bundle-D0GNokoe.js'; import '../Message/context.js'; import './MentionLabel.js'; import '../chunks/bundle-Hge7crLJ.js'; import 'react-dom'; import '../chunks/bundle-BsH3r84n.js'; import '@sendbird/chat'; import '@sendbird/chat/openChannel'; import './SortByRow.js'; import '../chunks/bundle-BgnOPI6k.js'; import './IconButton.js'; import '../chunks/bundle-Pi8D8X0p.js'; import './UserProfile.js'; import '../chunks/bundle-CZiyJYBm.js'; import '../chunks/bundle-BwKOzdpa.js'; import '../sendbirdSelectors.js'; import '../chunks/bundle-CRkzqUcm.js'; import '../chunks/bundle-BIjkVTPN.js'; import './ImageRenderer.js'; import '../chunks/bundle-sT3ilq3P.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