UNPKG

@sendbird/uikit-react

Version:

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

175 lines (172 loc) 15.4 kB
import { _ as __assign, c as __spreadArray } from '../chunks/bundle-DlZj_j5B.js'; import React__default, { useState, useRef, useMemo, useEffect } from 'react'; import { f as format } from '../chunks/bundle-DQG1nDod.js'; import { A as Avatar } from '../chunks/bundle-Dgt7lb2O.js'; import { C as ContextMenu, b as MenuItems, c as MenuItem } from '../chunks/bundle-BRB1saAI.js'; import Icon, { IconTypes, IconColors } from './Icon.js'; import IconButton from './IconButton.js'; import ImageRenderer from './ImageRenderer.js'; import LinkLabel from './LinkLabel.js'; import { L as Label, a as LabelTypography, b as LabelColors } from '../chunks/bundle-FZ_FdxZT.js'; import Loader from './Loader.js'; import UserProfile from './UserProfile.js'; import { u as useUserProfileContext } from '../chunks/bundle-tDk7wyaM.js'; import { u as uuidv4 } from '../chunks/bundle-CSjCAZib.js'; import { c as copyToClipboard } from '../chunks/bundle-CjekBWOL.js'; import { u as useLocalization } from '../chunks/bundle-DxLnjDoJ.js'; import { g as getSenderFromMessage, s as showMenuTrigger, i as isFineCopy, a as isFineEdit, b as isFineResend, c as isFineDelete, O as OpenChannelMobileMenu, d as checkIsPending, e as checkIsFailed } from '../chunks/bundle-8XssNFcq.js'; import { u as useMediaQueryContext } from '../chunks/bundle-DWJPyrDa.js'; import { u as useLongPress } from '../chunks/bundle-B1FaeCoO.js'; import { T as TextFragment } from '../chunks/bundle-CR2Uxj3o.js'; import { t as tokenizeMessage } from '../chunks/bundle-l40KXk4C.js'; import { o as openURL } from '../chunks/bundle-CaW4IP0_.js'; import '../chunks/bundle-0bJlK18Z.js'; import '../chunks/bundle-D89Qj0P4.js'; import '../chunks/bundle-h43SVTxb.js'; import 'react-dom'; import '@sendbird/chat'; import '@sendbird/chat/openChannel'; import './SortByRow.js'; import '../chunks/bundle-C5Cl3Igw.js'; import '@sendbird/chat/groupChannel'; import '../utils/message/getOutgoingMessageState.js'; import '../chunks/bundle-OJHU7Q3U.js'; import '../chunks/bundle-DZaN4z9l.js'; import '../chunks/bundle-C8kxBudB.js'; import '../chunks/bundle-C1jTnXNH.js'; import '../chunks/bundle-Dhutxl0X.js'; import '../sendbirdSelectors.js'; import '../chunks/bundle-D9lZlE3H.js'; import './Button.js'; import '../chunks/bundle-BnaoVUUl.js'; import '../Message/context.js'; import './MentionLabel.js'; function OpenChannelOGMessage(_a) { var _b, _c, _d; var message = _a.message, isOperator = _a.isOperator, _e = _a.isEphemeral, isEphemeral = _e === void 0 ? false : _e, className = _a.className, disabled = _a.disabled, showEdit = _a.showEdit, showRemove = _a.showRemove, resendMessage = _a.resendMessage, chainTop = _a.chainTop, userId = _a.userId; var status = message === null || message === void 0 ? void 0 : message.sendingStatus; var ogMetaData = (_b = message.ogMetaData) !== null && _b !== void 0 ? _b : null; var defaultImage = ogMetaData === null || ogMetaData === void 0 ? void 0 : ogMetaData.defaultImage; var _f = useLocalization(), stringSet = _f.stringSet, dateLocale = _f.dateLocale; var isMobile = useMediaQueryContext().isMobile; var _g = useUserProfileContext(), disableUserProfile = _g.disableUserProfile, renderUserProfile = _g.renderUserProfile; var _h = useState({}), contextStyle = _h[0], setContextStyle = _h[1]; var _j = useState(false), showContextMenu = _j[0], setShowContextMenu = _j[1]; var openLink = function () { return openURL(ogMetaData === null || ogMetaData === void 0 ? void 0 : ogMetaData.url); }; var onLongPress = useLongPress({ onLongPress: function () { return setShowContextMenu(true); }, onClick: openLink, }, { delay: 300, }); var messageComponentRef = useRef(); var contextMenuRef = useRef(); var mobileMenuRef = useRef(); var avatarRef = useRef(); var isPending = checkIsPending(status); var isFailed = checkIsFailed(status); var sender = getSenderFromMessage(message); var tokens = useMemo(function () { return tokenizeMessage({ messageText: message.message, }); }, [message === null || message === void 0 ? void 0 : message.updatedAt, message === null || message === void 0 ? void 0 : message.message]); // place conxt menu top depending clientHeight of message component useEffect(function () { var _a, _b; if (((_a = messageComponentRef === null || messageComponentRef === void 0 ? void 0 : messageComponentRef.current) === null || _a === void 0 ? void 0 : _a.clientHeight) && ((_b = messageComponentRef === null || messageComponentRef === void 0 ? void 0 : messageComponentRef.current) === null || _b === void 0 ? void 0 : _b.clientHeight) > 36) { setContextStyle({ top: '8px ' }); } else { setContextStyle({ top: '2px' }); } }, [window.innerWidth]); if (!message || message.messageType !== 'user') { return React__default.createElement(React__default.Fragment, null); } return (React__default.createElement(React__default.Fragment, null, React__default.createElement("div", __assign({ className: __spreadArray(__spreadArray([], (Array.isArray(className) ? className : [className]), true), [ 'sendbird-openchannel-og-message', ], false).join(' '), ref: messageComponentRef }, (isMobile ? __assign({}, onLongPress) : {})), React__default.createElement("div", { className: "sendbird-openchannel-og-message__top" }, React__default.createElement("div", { className: "sendbird-openchannel-og-message__top__left" }, !chainTop && (React__default.createElement(ContextMenu, { menuTrigger: function (toggleDropdown) { return (React__default.createElement(Avatar, { className: "sendbird-openchannel-og-message__top__left__avatar", src: sender.profileUrl || '', ref: avatarRef, width: "28px", height: "28px", onClick: function () { if (!disableUserProfile) { toggleDropdown(); } } })); }, menuItems: function (closeDropdown) { return (renderUserProfile ? (renderUserProfile({ user: sender, close: closeDropdown, currentUserId: userId, avatarRef: avatarRef, })) : (React__default.createElement(MenuItems, { parentRef: avatarRef, parentContainRef: avatarRef, closeDropdown: closeDropdown, style: { paddingTop: '0px', paddingBottom: '0px' } }, React__default.createElement(UserProfile, { user: sender, onSuccess: closeDropdown, disableMessaging: true })))); } }))), React__default.createElement("div", { className: "sendbird-openchannel-og-message__top__right" }, !chainTop && (React__default.createElement("div", { className: "sendbird-openchannel-og-message__top__right__title" }, React__default.createElement(Label, { className: "sendbird-openchannel-og-message__top__right__title__sender-name", type: LabelTypography.CAPTION_2, color: isOperator ? LabelColors.SECONDARY_3 : LabelColors.ONBACKGROUND_2 }, sender && (sender.friendName || sender.nickname || sender.userId)), React__default.createElement(Label, { className: "sendbird-openchannel-og-message__top__right__title__sent-at", type: LabelTypography.CAPTION_3, color: LabelColors.ONBACKGROUND_3 }, (message === null || message === void 0 ? void 0 : message.createdAt) && (format(message === null || message === void 0 ? void 0 : message.createdAt, stringSet.DATE_FORMAT__MESSAGE_CREATED_AT, { locale: dateLocale, }))))), React__default.createElement("div", { className: "sendbird-openchannel-og-message__top__right__description" }, React__default.createElement(Label, { className: "sendbird-openchannel-og-message__top__right__description__message", type: LabelTypography.BODY_1, color: LabelColors.ONBACKGROUND_1 }, React__default.createElement(TextFragment, { tokens: tokens }), (((_c = message === null || message === void 0 ? void 0 : message.updatedAt) !== null && _c !== void 0 ? _c : 0) > 0) && (React__default.createElement(Label, { key: uuidv4(), className: 'sendbird-openchannel-og-message--word', type: LabelTypography.BODY_1, color: LabelColors.ONBACKGROUND_2 }, stringSet.MESSAGE_EDITED))))), !isMobile && (React__default.createElement("div", { className: "sendbird-openchannel-og-message__top__context-menu", ref: contextMenuRef, style: contextStyle }, React__default.createElement(ContextMenu, { menuTrigger: function (toggleDropdown) { return (showMenuTrigger({ message: message, userId: userId, status: status }) && (React__default.createElement(IconButton, { className: "sendbird-openchannel-og-message__top__context-menu--icon", width: "32px", height: "32px", onClick: function () { toggleDropdown(); } }, React__default.createElement(Icon, { type: IconTypes.MORE, fillColor: IconColors.CONTENT_INVERSE, width: "24px", height: "24px" })))); }, menuItems: function (closeDropdown) { return (React__default.createElement(MenuItems, { parentRef: contextMenuRef, parentContainRef: contextMenuRef, closeDropdown: closeDropdown, openLeft: true }, isFineCopy({ message: message, userId: userId, status: status }) && (React__default.createElement(MenuItem, { className: "sendbird-openchannel-og-message__top__context-menu__copy", onClick: function () { copyToClipboard(message.message); closeDropdown(); }, testID: "open_channel_og_message_menu_copy" }, stringSet.CONTEXT_MENU_DROPDOWN__COPY)), (!isEphemeral && isFineEdit({ message: message, userId: userId, status: status })) && (React__default.createElement(MenuItem, { className: "sendbird-openchannel-og-message__top__context-menu__edit", onClick: function () { if (disabled) { return; } showEdit(true); closeDropdown(); }, testID: "open_channel_og_message_menu_edit" }, stringSet.CONTEXT_MENU_DROPDOWN__EDIT)), isFineResend({ message: message, userId: userId, status: status }) && (React__default.createElement(MenuItem, { className: "sendbird-openchannel-og-message__top__context-menu__resend", onClick: function () { resendMessage(message); closeDropdown(); }, testID: "open_channel_og_message_menu_resend" }, stringSet.CONTEXT_MENU_DROPDOWN__RESEND)), (!isEphemeral && isFineDelete({ message: message, userId: userId, status: status })) && (React__default.createElement(MenuItem, { className: "sendbird-openchannel-og-message__top__context-menu__delete", onClick: function () { if (disabled) { return; } showRemove(true); closeDropdown(); }, testID: "open_channel_og_message_menu_delete" }, stringSet.CONTEXT_MENU_DROPDOWN__DELETE)))); } })))), React__default.createElement("div", { className: "sendbird-openchannel-og-message__bottom" }, React__default.createElement("div", { className: "sendbird-openchannel-og-message__bottom__og-tag", ref: mobileMenuRef }, (ogMetaData === null || ogMetaData === void 0 ? void 0 : ogMetaData.url) && (React__default.createElement(Label, { className: "sendbird-openchannel-og-message__bottom__og-tag__url", type: LabelTypography.CAPTION_3, color: LabelColors.ONBACKGROUND_2 }, ogMetaData.url)), (ogMetaData === null || ogMetaData === void 0 ? void 0 : ogMetaData.title) && (React__default.createElement(LinkLabel, { className: "sendbird-openchannel-og-message__bottom__og-tag__title", src: (_d = ogMetaData.url) !== null && _d !== void 0 ? _d : '', type: LabelTypography.SUBTITLE_2, color: LabelColors.PRIMARY }, ogMetaData.title)), (ogMetaData === null || ogMetaData === void 0 ? void 0 : ogMetaData.description) && (React__default.createElement(Label, { className: "sendbird-openchannel-og-message__bottom__og-tag__description", type: LabelTypography.BODY_2, color: LabelColors.ONBACKGROUND_1 }, ogMetaData.description)), (ogMetaData === null || ogMetaData === void 0 ? void 0 : ogMetaData.url) && (React__default.createElement("div", { className: "sendbird-openchannel-og-message__bottom__og-tag__thumbnail", role: "button", onClick: openLink, onKeyDown: openLink, tabIndex: 0 }, defaultImage && (React__default.createElement(ImageRenderer, { className: "sendbird-openchannel-og-message__bottom__og-tag__thumbnail__image", url: defaultImage.url || '', alt: defaultImage.alt || '', width: "334px", height: "189px", defaultComponent: (React__default.createElement("div", { className: "sendbird-openchannel-og-message__bottom__og-tag__thumbnail__image--placeholder" }, React__default.createElement(Icon, { type: IconTypes.THUMBNAIL_NONE, width: "56px", height: "56px" }))) }))))), (isPending || isFailed) && (React__default.createElement("div", { className: "sendbird-openchannel-og-message__top__right__tail" }, isPending && (React__default.createElement(Loader, { width: "16px", height: "16px" }, React__default.createElement(Icon, { className: "sendbird-openchannel-og-message__top__right__tail__pending", type: IconTypes.SPINNER, fillColor: IconColors.PRIMARY, width: "16px", height: "16px" }))), isFailed && (React__default.createElement(Icon, { className: "sendbird-openchannel-og-message__top__right__tail__failed", type: IconTypes.ERROR, fillColor: IconColors.ERROR, width: "16px", height: "16px" })))))), showContextMenu && (React__default.createElement(OpenChannelMobileMenu, { message: message, parentRef: mobileMenuRef, hideMenu: function () { setShowContextMenu(false); }, showRemove: function () { setShowContextMenu(false); showRemove(true); }, showEdit: function () { setShowContextMenu(false); showEdit(true); }, copyToClipboard: function () { setShowContextMenu(false); copyToClipboard(message === null || message === void 0 ? void 0 : message.message); }, resendMessage: function () { setShowContextMenu(false); resendMessage(message); } })))); } export { OpenChannelOGMessage as default }; //# sourceMappingURL=OpenchannelOGMessage.js.map