UNPKG

@sendbird/uikit-react

Version:

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

136 lines (133 loc) 7.67 kB
import { _ as __assign } from '../../chunks/bundle-Bpofr334.js'; import React__default, { useState, useContext, useEffect, useMemo } from 'react'; import { B as BannedUserList, M as MutedMemberList, O as OperatorList } from '../../chunks/bundle-KmABwClk.js'; import { M as MemberList } from '../../chunks/bundle-DC25kzte.js'; import { L as LocalizationContext } from '../../chunks/bundle-Cdqsdoa8.js'; import { IconColors, IconTypes } from '../../ui/Icon.js'; import Badge from '../../ui/Badge.js'; import { Toggle } from '../../ui/Toggle.js'; import { a as LabelColors, c as LabelTypography } from '../../chunks/bundle-Cdplrrlw.js'; import { MenuItemAction } from '../components/ChannelSettingsMenuItem.js'; import { u as useChannelSettings } from '../../chunks/bundle-5y4qYKhm.js'; import '../../chunks/bundle-CLrmFXHj.js'; import '@sendbird/chat'; import '@sendbird/chat/openChannel'; import '../../chunks/bundle-4clodtJA.js'; import '../../chunks/bundle-B56O1y8C.js'; import '../../chunks/bundle-JhKiWlXT.js'; import '@sendbird/chat/groupChannel'; import '../../chunks/bundle-zNUBt0Cg.js'; import 'react-dom'; import '../../chunks/bundle-DX6fRIJl.js'; import '../../ui/SortByRow.js'; import '../../chunks/bundle-LLA95Pqf.js'; import '../../ui/IconButton.js'; import '../../chunks/bundle-BZSLsKkw.js'; import '../../utils/message/getOutgoingMessageState.js'; import '../../chunks/bundle-CglqREVl.js'; import '../../chunks/bundle-lqEjT2ED.js'; import '../../chunks/bundle-BqKoZDqX.js'; import '../../ui/Button.js'; import '../../ui/UserListItem.js'; import '../../chunks/bundle-B5LKcMN_.js'; import '../../chunks/bundle-BJShQs4P.js'; import '../../ui/ImageRenderer.js'; import '../../chunks/bundle-F_R9C4cW.js'; import '../../ui/MutedAvatarOverlay.js'; import '../../ui/Checkbox.js'; import '../../ui/UserProfile.js'; import '../../sendbirdSelectors.js'; import '../../chunks/bundle-YDriVB8K.js'; import '../../chunks/bundle-C4anRHWY.js'; import '../../chunks/bundle-C2ARCMSL.js'; import '../../chunks/bundle-FnWZX8on.js'; import '../../chunks/bundle-ChLik1Zs.js'; import '@sendbird/chat/message'; import '@sendbird/uikit-tools'; import '../../chunks/bundle-Cd8fnvI_.js'; import '../../chunks/bundle-oM0Fxt9G.js'; import '../../chunks/bundle-DmnXeBdU.js'; import '../../chunks/bundle-DpOgiF9r.js'; var kFormatter = function (num) { return Math.abs(num) > 999 ? "".concat((Math.abs(num) / 1000).toFixed(1), "K") : num; }; var commonIconProps = { fillColor: IconColors.PRIMARY, width: 24, height: 24, className: 'sendbird-channel-settings__accordion-icon', }; var commonLabelProps = { type: LabelTypography.SUBTITLE_1, color: LabelColors.ONBACKGROUND_1, }; var useMenuItems = function () { var _a = useState(false), frozen = _a[0], setFrozen = _a[1]; var stringSet = useContext(LocalizationContext).stringSet; var _b = useChannelSettings().state, channel = _b.channel, renderUserListItem = _b.renderUserListItem; // work around for // https://sendbird.slack.com/archives/G01290GCDCN/p1595922832000900 // SDK bug - after frozen/unfrozen myRole becomes "none" useEffect(function () { var _a; setFrozen((_a = channel === null || channel === void 0 ? void 0 : channel.isFrozen) !== null && _a !== void 0 ? _a : false); }, [channel === null || channel === void 0 ? void 0 : channel.isFrozen]); return useMemo(function () { return ({ operator: { operators: { icon: __assign(__assign({}, commonIconProps), { type: IconTypes.OPERATOR }), label: __assign(__assign({}, commonLabelProps), { children: stringSet.CHANNEL_SETTING__OPERATORS__TITLE }), accordionComponent: function () { return React__default.createElement(OperatorList, { renderUserListItem: renderUserListItem }); }, }, allUsers: { icon: __assign(__assign({}, commonIconProps), { type: IconTypes.MEMBERS }), label: __assign(__assign({}, commonLabelProps), { children: stringSet.CHANNEL_SETTING__MEMBERS__TITLE }), rightComponent: function (props) { return (React__default.createElement("div", { className: "sendbird-channel-settings__members" }, React__default.createElement(Badge, { count: (channel === null || channel === void 0 ? void 0 : channel.memberCount) ? kFormatter(channel.memberCount) : '' }), React__default.createElement(MenuItemAction, __assign({}, props)))); }, accordionComponent: function () { return React__default.createElement(MemberList, { renderUserListItem: renderUserListItem }); }, }, mutedUsers: { icon: __assign(__assign({}, commonIconProps), { type: IconTypes.MUTE }), label: __assign(__assign({}, commonLabelProps), { children: stringSet.CHANNEL_SETTING__MUTED_MEMBERS__TITLE }), accordionComponent: function () { return React__default.createElement(MutedMemberList, { renderUserListItem: renderUserListItem }); }, }, bannedUsers: { icon: __assign(__assign({}, commonIconProps), { type: IconTypes.BAN }), label: __assign(__assign({}, commonLabelProps), { children: stringSet.CHANNEL_SETTING__BANNED_MEMBERS__TITLE }), accordionComponent: function () { return React__default.createElement(BannedUserList, { renderUserListItem: renderUserListItem }); }, }, freezeChannel: { hideMenu: channel === null || channel === void 0 ? void 0 : channel.isBroadcast, icon: __assign(__assign({}, commonIconProps), { type: IconTypes.FREEZE }), label: __assign(__assign({}, commonLabelProps), { children: stringSet.CHANNEL_SETTING__FREEZE_CHANNEL }), rightComponent: function () { return React__default.createElement(Toggle, { className: "sendbird-channel-settings__frozen-icon", checked: frozen, onChange: function () { if (frozen) { channel === null || channel === void 0 ? void 0 : channel.unfreeze().then(function () { setFrozen(function (prev) { return !prev; }); }); } else { channel === null || channel === void 0 ? void 0 : channel.freeze().then(function () { setFrozen(function (prev) { return !prev; }); }); } } }); }, }, }, nonOperator: { allUsers: { icon: __assign(__assign({}, commonIconProps), { type: IconTypes.MEMBERS }), label: __assign(__assign({}, commonLabelProps), { children: stringSet.CHANNEL_SETTING__MEMBERS__TITLE }), rightComponent: function (props) { return (React__default.createElement("div", { className: "sendbird-channel-settings__members" }, React__default.createElement(Badge, { count: (channel === null || channel === void 0 ? void 0 : channel.memberCount) ? kFormatter(channel.memberCount) : '' }), React__default.createElement(MenuItemAction, __assign({}, props)))); }, accordionComponent: function () { return React__default.createElement(MemberList, { renderUserListItem: renderUserListItem }); }, }, } }); }, [channel === null || channel === void 0 ? void 0 : channel.url, frozen]); }; export { useMenuItems as default, useMenuItems }; //# sourceMappingURL=useMenuList.js.map