@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 kB
JavaScript
import React__default, { useState } from 'react';
import { u as useChannelSettings } from '../../chunks/bundle-tHlm6elM.js';
import { u as useLocalization } from '../../chunks/bundle-Dx_38OXn.js';
import Badge from '../../ui/Badge.js';
import { L as Label, a as LabelTypography, b as LabelColors } from '../../chunks/bundle-DHMhzdxb.js';
import Icon, { IconTypes, IconColors } from '../../ui/Icon.js';
import { M as MemberList } from '../../chunks/bundle-C6gxsmD2.js';
import '../../chunks/bundle-k5pprEL4.js';
import '../../chunks/bundle-3CHYtOfL.js';
import '../../chunks/bundle-CAqNV7Jw.js';
import '@sendbird/chat/groupChannel';
import '../../chunks/bundle-Dub55x6v.js';
import '../../chunks/bundle-dMfcSy1Y.js';
import '../../chunks/bundle-Ds9YPch2.js';
import '../../chunks/bundle-D6tIALJA.js';
import '../../chunks/bundle-DlIBbbMW.js';
import '@sendbird/chat';
import '@sendbird/chat/openChannel';
import '../../chunks/bundle-DoyzmJ4N.js';
import '../../chunks/bundle-Dsv3ZewI.js';
import '../../ui/Button.js';
import '../../chunks/bundle-RS55OcKI.js';
import '../../chunks/bundle-ACCb-8jH.js';
import 'react-dom';
import '../../ui/SortByRow.js';
import '../../ui/IconButton.js';
import '../../chunks/bundle-BKsKPtjg.js';
import '../../utils/message/getOutgoingMessageState.js';
import '../../chunks/bundle-DTJNwlmx.js';
import '../../chunks/bundle-CmS7TEQp.js';
import '../../chunks/bundle-Dhfbe9sC.js';
import '../../ui/UserListItem.js';
import '../../chunks/bundle-DzLymkLP.js';
import '../../ui/ImageRenderer.js';
import '../../chunks/bundle-BCC98_OB.js';
import '../../ui/MutedAvatarOverlay.js';
import '../../ui/Checkbox.js';
import '../../ui/UserProfile.js';
import '../../sendbirdSelectors.js';
import '../../chunks/bundle-Bv2JmaC2.js';
import '../../chunks/bundle-EGZmMlDM.js';
import '../../chunks/bundle-CDtkDyUw.js';
import '../../chunks/bundle-B8vkzJuS.js';
import '../../chunks/bundle-SYD-r_6g.js';
import '@sendbird/chat/message';
import '@sendbird/uikit-tools';
import '../../chunks/bundle-BAYOQ4lI.js';
var kFormatter = function (num) {
return Math.abs(num) > 999
? "".concat((Math.abs(num) / 1000).toFixed(1), "K")
: num;
};
var UserPanel = function () {
var stringSet = useLocalization().stringSet;
var _a = useState(false), showAccordion = _a[0], setShowAccordion = _a[1];
var channel = useChannelSettings().state.channel;
return (React__default.createElement("div", { className: 'sendbird-channel-settings__user-panel' },
React__default.createElement("div", { className: [
'sendbird-channel-settings__panel-item',
'sendbird-channel-settings__members',
].join(' '), role: "switch", "aria-checked": showAccordion, onKeyDown: function () { return setShowAccordion(!showAccordion); }, onClick: function () { return setShowAccordion(!showAccordion); }, tabIndex: 0 },
React__default.createElement(Icon, { className: "sendbird-channel-settings__panel-icon-left", type: IconTypes.MEMBERS, fillColor: IconColors.PRIMARY, height: "24px", width: "24px" }),
React__default.createElement(Label, { type: LabelTypography.SUBTITLE_1, color: LabelColors.ONBACKGROUND_1 },
stringSet.CHANNEL_SETTING__MEMBERS__TITLE,
React__default.createElement(Badge, { className: 'sendbird-channel-settings__badge', count: channel ? kFormatter(channel === null || channel === void 0 ? void 0 : channel.memberCount) : '' })),
React__default.createElement(Icon, { className: [
'sendbird-channel-settings__panel-icon-right',
'sendbird-channel-settings__panel-icon--chevron',
(showAccordion ? 'sendbird-channel-settings__panel-icon--open' : ''),
].join(' '), type: IconTypes.CHEVRON_RIGHT, height: "24px", width: "24px" })),
showAccordion && (React__default.createElement(MemberList, null))));
};
export { UserPanel as default };
//# sourceMappingURL=UserPanel.js.map