@sendbird/uikit-react
Version:
Sendbird UIKit for React: A feature-rich and customizable chat UI kit with messaging, channel management, and user authentication.
83 lines (77 loc) • 4.37 kB
JavaScript
'use strict';
var React = require('react');
var useChannelSettings = require('../../chunks/bundle-_yh4eC6v.js');
var LocalizationContext = require('../../chunks/bundle-ClT0IexP.js');
var ui_Badge = require('../../ui/Badge.js');
var ui_Label = require('../../chunks/bundle-DxZzcGya.js');
var ui_Icon = require('../../ui/Icon.js');
var MemberList = require('../../chunks/bundle-CIn5419q.js');
require('../../chunks/bundle-jAsAzWpU.js');
require('../../chunks/bundle-Buar9ys-.js');
require('../../chunks/bundle-DZN-28o5.js');
require('@sendbird/chat/groupChannel');
require('../../chunks/bundle-BNgfU9I_.js');
require('../../chunks/bundle-BSCZWP_l.js');
require('../../chunks/bundle-1F9guuKw.js');
require('../../chunks/bundle-iF1pW7_s.js');
require('../../chunks/bundle-on0zTbLT.js');
require('@sendbird/chat');
require('@sendbird/chat/openChannel');
require('../../chunks/bundle-D-_6Kk3L.js');
require('../../chunks/bundle-BXuNw6bR.js');
require('../../ui/Button.js');
require('../../chunks/bundle-CofqAAwu.js');
require('../../chunks/bundle-BTzm82Jl.js');
require('react-dom');
require('../../ui/SortByRow.js');
require('../../ui/IconButton.js');
require('../../chunks/bundle-CskFALvU.js');
require('../../utils/message/getOutgoingMessageState.js');
require('../../chunks/bundle-BVn2UMtk.js');
require('../../chunks/bundle-DvHjgbFi.js');
require('../../chunks/bundle-DS7dko_G.js');
require('../../ui/UserListItem.js');
require('../../chunks/bundle-Czc5a05Q.js');
require('../../ui/ImageRenderer.js');
require('../../chunks/bundle-CZmT_dIf.js');
require('../../ui/MutedAvatarOverlay.js');
require('../../ui/Checkbox.js');
require('../../ui/UserProfile.js');
require('../../sendbirdSelectors.js');
require('../../chunks/bundle-B14gP5iL.js');
require('../../chunks/bundle-BFmC2V1o.js');
require('../../chunks/bundle-DDUAkmTu.js');
require('../../chunks/bundle-CgDPAVTm.js');
require('../../chunks/bundle-9izlRrTd.js');
require('@sendbird/chat/message');
require('@sendbird/uikit-tools');
require('../../chunks/bundle-BiR_Hvsk.js');
function _interopDefaultCompat (e) { return e && typeof e === 'object' && 'default' in e ? e : { default: e }; }
var React__default = /*#__PURE__*/_interopDefaultCompat(React);
var kFormatter = function (num) {
return Math.abs(num) > 999
? "".concat((Math.abs(num) / 1000).toFixed(1), "K")
: num;
};
var UserPanel = function () {
var stringSet = LocalizationContext.useLocalization().stringSet;
var _a = React.useState(false), showAccordion = _a[0], setShowAccordion = _a[1];
var channel = useChannelSettings.useChannelSettings().state.channel;
return (React__default.default.createElement("div", { className: 'sendbird-channel-settings__user-panel' },
React__default.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.default.createElement(ui_Icon.default, { className: "sendbird-channel-settings__panel-icon-left", type: ui_Icon.IconTypes.MEMBERS, fillColor: ui_Icon.IconColors.PRIMARY, height: "24px", width: "24px" }),
React__default.default.createElement(ui_Label.Label, { type: ui_Label.LabelTypography.SUBTITLE_1, color: ui_Label.LabelColors.ONBACKGROUND_1 },
stringSet.CHANNEL_SETTING__MEMBERS__TITLE,
React__default.default.createElement(ui_Badge, { className: 'sendbird-channel-settings__badge', count: channel ? kFormatter(channel === null || channel === void 0 ? void 0 : channel.memberCount) : '' })),
React__default.default.createElement(ui_Icon.default, { className: [
'sendbird-channel-settings__panel-icon-right',
'sendbird-channel-settings__panel-icon--chevron',
(showAccordion ? 'sendbird-channel-settings__panel-icon--open' : ''),
].join(' '), type: ui_Icon.IconTypes.CHEVRON_RIGHT, height: "24px", width: "24px" })),
showAccordion && (React__default.default.createElement(MemberList.MemberList, null))));
};
module.exports = UserPanel;
//# sourceMappingURL=UserPanel.js.map