UNPKG

@sendbird/uikit-react

Version:

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

107 lines (104 loc) 8.19 kB
import React__default, { useContext, useMemo, useRef, useEffect } from 'react'; import ImageRenderer from './ImageRenderer.js'; import Icon, { IconTypes } from './Icon.js'; 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 TextFragment } from '../chunks/bundle-DcLgcUpC.js'; import { t as tokenizeMessage } from '../chunks/bundle-BwvurfUT.js'; import { O as OG_MESSAGE_BODY_CLASSNAME } from '../chunks/bundle-Cc1gzgza.js'; import { u as useMediaQueryContext } from '../chunks/bundle-DBhJIxHw.js'; import { o as openURL, c as classnames } from '../chunks/bundle-MlG9piGf.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 '@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 '../chunks/bundle-Dl_v8XoN.js'; import './Button.js'; import './LinkLabel.js'; function OGMessageItemBody(_a) { var _b, _c, _d, _e; var className = _a.className, message = _a.message, _f = _a.isByMe, isByMe = _f === void 0 ? false : _f, _g = _a.mouseHover, mouseHover = _g === void 0 ? false : _g, _h = _a.isMentionEnabled, isMentionEnabled = _h === void 0 ? false : _h, _j = _a.isReactionEnabled, isReactionEnabled = _j === void 0 ? false : _j, _k = _a.isMarkdownEnabled, isMarkdownEnabled = _k === void 0 ? false : _k, _l = _a.onMessageHeightChange, onMessageHeightChange = _l === void 0 ? function () { /* noop */ } : _l; var stringSet = useContext(LocalizationContext).stringSet; var isMessageMentioned = isMentionEnabled && ((_b = message === null || message === void 0 ? void 0 : message.mentionedMessageTemplate) === null || _b === void 0 ? void 0 : _b.length) > 0 && (message === null || message === void 0 ? void 0 : message.mentionedUsers) && ((_c = message === null || message === void 0 ? void 0 : message.mentionedUsers) === null || _c === void 0 ? void 0 : _c.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]); var openOpenGraphURL = function () { var _a; return openURL((_a = message === null || message === void 0 ? void 0 : message.ogMetaData) === null || _a === void 0 ? void 0 : _a.url); }; return (React__default.createElement("div", { className: getClassName([ className !== null && className !== void 0 ? className : '', 'sendbird-og-message-item-body', isByMe ? 'outgoing' : 'incoming', mouseHover ? 'mouse-hover' : '', isReactionEnabled && ((_d = message === null || message === void 0 ? void 0 : message.reactions) === null || _d === void 0 ? void 0 : _d.length) > 0 ? 'reactions' : '', ]) }, React__default.createElement(Label, { type: LabelTypography.BODY_1, color: isByMe ? LabelColors.ONCONTENT_1 : LabelColors.ONBACKGROUND_1 }, React__default.createElement("div", { className: OG_MESSAGE_BODY_CLASSNAME }, React__default.createElement(TextFragment, { tokens: tokens }), isEditedMessage(message) && (React__default.createElement(Label, { className: "sendbird-og-message-item-body__text-bubble__message", type: LabelTypography.BODY_1, color: isByMe ? LabelColors.ONCONTENT_2 : LabelColors.ONBACKGROUND_2 }, " ".concat(stringSet.MESSAGE_EDITED, " "))))), ((_e = message.ogMetaData) === null || _e === void 0 ? void 0 : _e.defaultImage) && (React__default.createElement(OGImageSection, { onClick: openOpenGraphURL, ogImage: message.ogMetaData.defaultImage, onMessageHeightChange: onMessageHeightChange })), message.ogMetaData && (React__default.createElement(OGDescriptionSection, { onClick: openOpenGraphURL, ogMetaData: message.ogMetaData, onMessageHeightChange: onMessageHeightChange })), React__default.createElement("div", { className: "sendbird-og-message-item-body__cover" }))); } var OGImageSection = function (props) { var onClick = props.onClick, ogImage = props.ogImage, onMessageHeightChange = props.onMessageHeightChange; var imageRef = useRef(null); var isMobile = useMediaQueryContext().isMobile; return (React__default.createElement("div", { ref: imageRef, className: classnames('sendbird-og-message-item-body__og-thumbnail', !ogImage.url && 'sendbird-og-message-item-body__og-thumbnail__empty'), onClick: function () { return onClick(); } }, React__default.createElement(ImageRenderer, { className: "sendbird-og-message-item-body__og-thumbnail__image", url: ogImage.url || '', alt: ogImage.alt || '', width: "100%", height: isMobile ? '136px' : '240px', onLoad: onMessageHeightChange, onError: function () { var _a, _b; try { (_b = (_a = imageRef === null || imageRef === void 0 ? void 0 : imageRef.current) === null || _a === void 0 ? void 0 : _a.classList) === null || _b === void 0 ? void 0 : _b.add('sendbird-og-message-item-body__og-thumbnail__empty'); } catch (error) { // do nothing } }, defaultComponent: React__default.createElement("div", { className: "sendbird-og-message-item-body__og-thumbnail__place-holder" }, React__default.createElement(Icon, { className: "sendbird-og-message-item-body__og-thumbnail__place-holder__icon", type: IconTypes.THUMBNAIL_NONE, width: "56px", height: "56px" })) }))); }; var OGDescriptionSection = function (props) { var onClick = props.onClick, ogMetaData = props.ogMetaData, onMessageHeightChange = props.onMessageHeightChange; useEffect(function () { onMessageHeightChange(); }, [ogMetaData.title, ogMetaData.description, ogMetaData.url]); return (React__default.createElement("div", { className: "sendbird-og-message-item-body__description", onClick: function () { return onClick(); } }, ogMetaData.title && (React__default.createElement(Label, { className: "sendbird-og-message-item-body__description__title", type: LabelTypography.SUBTITLE_2, color: LabelColors.ONBACKGROUND_1 }, ogMetaData.title)), ogMetaData.description && (React__default.createElement(Label, { className: "sendbird-og-message-item-body__description__description", type: LabelTypography.BODY_2, color: LabelColors.ONBACKGROUND_1 }, ogMetaData.description)), ogMetaData.url && (React__default.createElement(Label, { className: "sendbird-og-message-item-body__description__url", type: LabelTypography.CAPTION_3, color: LabelColors.ONBACKGROUND_2 }, ogMetaData.url)))); }; export { OGMessageItemBody as default }; //# sourceMappingURL=OGMessageItemBody.js.map