UNPKG

@sendbird/uikit-react

Version:

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

85 lines (82 loc) 6.93 kB
import { c as __spreadArray } from '../chunks/bundle-DlZj_j5B.js'; import React__default, { useRef } from 'react'; import { u as useUserProfileContext } from '../chunks/bundle-tDk7wyaM.js'; import { u as useLocalization } from '../chunks/bundle-DxLnjDoJ.js'; import { A as Avatar } from '../chunks/bundle-Dgt7lb2O.js'; import MutedAvatarOverlay from './MutedAvatarOverlay.js'; import Checkbox from './Checkbox.js'; import UserProfile from './UserProfile.js'; import { C as ContextMenu, b as MenuItems } from '../chunks/bundle-BRB1saAI.js'; import { L as Label, a as LabelTypography, b as LabelColors } from '../chunks/bundle-FZ_FdxZT.js'; import { c as classnames } from '../chunks/bundle-CaW4IP0_.js'; import { p as pxToNumber } from '../chunks/bundle-h43SVTxb.js'; import { u as useSendbird } from '../chunks/bundle-BnaoVUUl.js'; import '../chunks/bundle-Dhutxl0X.js'; import '../chunks/bundle-D89Qj0P4.js'; import './ImageRenderer.js'; import './Icon.js'; import '../sendbirdSelectors.js'; import '../chunks/bundle-D9lZlE3H.js'; import './Button.js'; import 'react-dom'; import '@sendbird/chat'; import '@sendbird/chat/openChannel'; import './SortByRow.js'; import '../chunks/bundle-CSjCAZib.js'; import './IconButton.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-0bJlK18Z.js'; import '../chunks/bundle-C8kxBudB.js'; import '../chunks/bundle-C1jTnXNH.js'; function UserListItem(_a) { var user = _a.user, channel = _a.channel, _b = _a.className, className = _b === void 0 ? undefined : _b, checked = _a.checked, checkBox = _a.checkBox, isOperator = _a.isOperator, disabled = _a.disabled, disableMessaging = _a.disableMessaging, action = _a.action, onChange = _a.onChange, _c = _a.avatarSize, avatarSize = _c === void 0 ? '40px' : _c, onClick = _a.onClick, onUserAvatarClick = _a.onUserAvatarClick, renderListItemMenu = _a.renderListItemMenu, _d = _a.size, size = _d === void 0 ? 'normal' : _d; var operator = isOperator !== null && isOperator !== void 0 ? isOperator : (user === null || user === void 0 ? void 0 : user.role) === 'operator'; var uniqueKey = user.userId; var actionRef = useRef(null); var parentRef = useRef(null); var avatarRef = useRef(null); var _e = useUserProfileContext(), disableUserProfile = _e.disableUserProfile, renderUserProfile = _e.renderUserProfile; var stringSet = useLocalization().stringSet; var config = useSendbird().state.config; var currentUser = config.userId; var itemClassName = size === 'small' ? 'sendbird-user-list-item--small' : 'sendbird-user-list-item'; var avatarClassName = size === 'small' ? 'sendbird-user-list-item--small__avatar' : 'sendbird-user-list-item__avatar'; var titleClassName = size === 'small' ? 'sendbird-user-list-item--small__title' : 'sendbird-user-list-item__title'; var subtitleClassName = size === 'small' ? 'sendbird-user-list-item--small__subtitle' : 'sendbird-user-list-item__subtitle'; var checkboxClassName = size === 'small' ? 'sendbird-user-list-item--small__checkbox' : 'sendbird-user-list-item__checkbox'; var actionClassName = size === 'small' ? 'sendbird-user-list-item--small__action' : 'sendbird-user-list-item__action'; var operatorClassName = size === 'small' ? 'sendbird-user-list-item--small__operator' : 'sendbird-user-list-item__operator'; return (React__default.createElement("div", { className: classnames.apply(void 0, __spreadArray([itemClassName], (Array.isArray(className) ? className : [className]), false)), ref: parentRef }, React__default.createElement(ContextMenu, { menuTrigger: function (toggleDropdown) { return (React__default.createElement(React__default.Fragment, null, React__default.createElement(Avatar, { className: avatarClassName, ref: avatarRef, src: (user === null || user === void 0 ? void 0 : user.profileUrl) || (user === null || user === void 0 ? void 0 : user.plainProfileUrl) || '', width: avatarSize, height: avatarSize, onClick: function () { var _a; if (!disableUserProfile) { toggleDropdown(); (_a = (onUserAvatarClick !== null && onUserAvatarClick !== void 0 ? onUserAvatarClick : onClick)) === null || _a === void 0 ? void 0 : _a(); } } }), (user === null || user === void 0 ? void 0 : user.isMuted) && (React__default.createElement(MutedAvatarOverlay, { height: pxToNumber(avatarSize), width: pxToNumber(avatarSize) })))); }, menuItems: function (closeDropdown) { return (renderUserProfile ? renderUserProfile({ user: user, currentUserId: currentUser !== null && currentUser !== void 0 ? currentUser : '', close: closeDropdown, avatarRef: avatarRef, }) : (React__default.createElement(MenuItems, { openLeft: true, parentRef: avatarRef, parentContainRef: avatarRef, closeDropdown: closeDropdown, style: { paddingTop: '0px', paddingBottom: '0px' } }, React__default.createElement(UserProfile, { disableMessaging: disableMessaging, user: user, currentUserId: currentUser, onSuccess: closeDropdown })))); } }), React__default.createElement(Label, { className: titleClassName, type: LabelTypography.SUBTITLE_1, color: LabelColors.ONBACKGROUND_1 }, user.nickname || stringSet.NO_NAME, (currentUser === user.userId) && (stringSet.CHANNEL_SETTING__MEMBERS__YOU)), !user.nickname && (React__default.createElement(Label, { className: subtitleClassName, type: LabelTypography.CAPTION_3, color: LabelColors.ONBACKGROUND_2 }, user.userId)), checkBox && (React__default.createElement("label", { className: checkboxClassName, htmlFor: uniqueKey }, React__default.createElement(Checkbox, { id: uniqueKey, checked: checked, disabled: disabled, onChange: function (event) { return onChange === null || onChange === void 0 ? void 0 : onChange(event); } }))), operator && (React__default.createElement(Label, { className: classnames(operatorClassName, checkBox && 'checkbox'), type: LabelTypography.SUBTITLE_2, color: LabelColors.ONBACKGROUND_2 }, stringSet.LABEL__OPERATOR)), !checkBox && !renderListItemMenu && action && (React__default.createElement("div", { className: actionClassName, ref: actionRef }, action({ actionRef: actionRef, parentRef: parentRef }))), !checkBox && renderListItemMenu && (React__default.createElement("div", { className: actionClassName, ref: actionRef }, renderListItemMenu({ channel: channel, user: user }))))); } export { UserListItem, UserListItem as default }; //# sourceMappingURL=UserListItem.js.map